Diff for /loncom/interface/lonparmset.pm between versions 1.242 and 1.260

version 1.242, 2005/08/27 00:03:32 version 1.260, 2005/10/14 17:05:44
Line 1921  sub crsenv { Line 1921  sub crsenv {
      'disablesigfigs'       'disablesigfigs'
          => '<b>'.&mt('Disable checking of Significant Figures').'</b><br />'.           => '<b>'.&mt('Disable checking of Significant Figures').'</b><br />'.
                     ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',                      ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',
        'disableexampointprint'
            => '<b>'.&mt('Disable automatically printing point values onto exams.').'</b><br />'.
                       ' ('.&mt('"[_1]" to disable, anything else if not','<tt>yes</tt>').')',
      'tthoptions'       'tthoptions'
          => '<b>'.&mt('Default set of options to pass to tth/m when converting tex').'</b>'           => '<b>'.&mt('Default set of options to pass to tth/m when converting tex').'</b>'
              );                ); 
Line 1947  sub crsenv { Line 1950  sub crsenv {
                              'default_enrollment_start_date',                               'default_enrollment_start_date',
                              'default_enrollment_end_date',                               'default_enrollment_end_date',
      'tthoptions',       'tthoptions',
      'disablesigfigs'       'disablesigfigs',
        'disableexampointprint'
                              );                               );
  foreach my $parameter (sort(keys(%values))) {   foreach my $parameter (sort(keys(%values))) {
             unless ($parameter =~ m/^internal\./) {              unless (($parameter =~ m/^internal\./)||($parameter =~ m/^metadata\./)) {
                 if (! $descriptions{$parameter}) {                  if (! $descriptions{$parameter}) {
                     $descriptions{$parameter}=$parameter;                      $descriptions{$parameter}=$parameter;
                     push(@Display_Order,$parameter);                      push(@Display_Order,$parameter);
Line 2189  sub listdata { Line 2193  sub listdata {
     my $pointer=0;      my $pointer=0;
     $tableopen=0;      $tableopen=0;
     my $foundkeys=0;      my $foundkeys=0;
       my %keyorder=&standardkeyorder();
     foreach my $thiskey (sort {      foreach my $thiskey (sort {
  if ($sortorder eq 'realmstudent') {   if ($sortorder eq 'realmstudent') {
     my ($astudent,$arealm)=($a=~/^$env{'request.course.id'}\.([^\.]+)\.(.+)\.[^\.]+$/);      my ($astudent,$arealm)=($a=~/^\Q$env{'request.course.id'}\E\.\[([^\.]+)\]\.(.+)\.[^\.]+$/);
     my ($bstudent,$brealm)=($b=~/^$env{'request.course.id'}\.([^\.]+)\.(.+)\.[^\.]+$/);      my ($bstudent,$brealm)=($b=~/^\Q$env{'request.course.id'}\E\.\[([^\.]+)\]\.(.+)\.[^\.]+$/);
     if (!defined($astudent) && !defined($bstudent) &&      if (!defined($astudent)) {
  !defined($arealm) && !defined($brealm)) {   ($arealm)=($a=~/^\Q$env{'request.course.id'}\E\.(.+)$/);
  ($arealm)=($a=~/^$env{'request.course.id'}\.(.+)\.[^\.]+$/);      }
  ($brealm)=($b=~/^$env{'request.course.id'}\.(.+)\.[^\.]+$/);      if (!defined($bstudent)) {
    ($brealm)=($b=~/^\Q$env{'request.course.id'}\E\.(.+)$/);
       }
       $arealm=~s/\.type//;
       my ($ares, $aparm) = ($arealm=~/^(.*)\.(.*)$/);
       $aparm=$keyorder{'parameter_0_'.$aparm};
       $brealm=~s/\.type//;
       my ($bres, $bparm) = ($brealm=~/^(.*)\.(.*)$/);
       $bparm=$keyorder{'parameter_0_'.$bparm};   
       if ($ares eq $bres) {
    if (defined($aparm) && defined($bparm)) {
       ($aparm <=> $bparm);
    } elsif (defined($aparm)) {
       -1;
    } elsif (defined($bparm)) {
       1;
    } else {
       ($arealm cmp $brealm) || ($astudent cmp $bstudent);
    }
       } else {
    ($arealm cmp $brealm) || ($astudent cmp $bstudent);
     }      }
             ($arealm cmp $brealm) || ($astudent cmp $bstudent);  
  } else {   } else {
     $a cmp $b;      $a cmp $b;
  }   }
     } keys %{$listdata}) {      } keys %{$listdata}) {
     
  if ($$listdata{$thiskey.'.type'}) {   if ($$listdata{$thiskey.'.type'}) {
             my $thistype=$$listdata{$thiskey.'.type'};              my $thistype=$$listdata{$thiskey.'.type'};
             if ($$resourcedata{$thiskey.'.type'}) {              if ($$resourcedata{$thiskey.'.type'}) {
Line 2677  ENDMAINFORMHEAD Line 2702  ENDMAINFORMHEAD
     action => 'crsenv',      action => 'crsenv',
             permission => $parm_permission,              permission => $parm_permission,
             },              },
           { text => 'Set Instructor Defined Metadata',            { text => 'Set Portfolio Metadata',
     action => 'setinstmeta',      action => 'setrestrictmeta',
             permission => $parm_permission,              permission => $parm_permission,
             },              },
           { text => 'Set/Modify Resource Parameters - Helper Mode',            { text => 'Set/Modify Resource Parameters - Helper Mode',
Line 2724  ENDMAINFORMHEAD Line 2749  ENDMAINFORMHEAD
     $r->print($menu_html);      $r->print($menu_html);
     return;      return;
 }  }
 ### Set instructor defined metadata  ### Set portfolio metadata
 sub setinstmeta {  sub output_row {
     my ($r)=@_;      my ($r, $field_name, $field_text) = @_;
     my $next_meta;      my $output;
     if ($env{'form.nextmeta'}) {      my $options=$env{'course.'.$env{'request.course.id'}.'.'.$field_name.'.options'};
         $next_meta = $env{'form.nextmeta'};      my $values=$env{'course.'.$env{'request.course.id'}.'.'.$field_name.'.values'};
       my $checked;
       unless (defined($options)) {
           $options = 'active,stuadd';
           $values = 'Type a list of values separated by commas.';
       }
       $output.='<strong>'.$field_text.':</strong>';
       $output.='<input name="'.$field_name.'_values" type="text" value="'.$values.'" /><br />';
       if ($options =~ m/active/) {
           $checked = ' checked="checked" ';
       } else {
           $checked = '  ';
       }
       $output.='&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="'.$field_name.'_active" value="yes"'.$checked.' />';
       $output.='Active <br />';
       if ($options =~ m/onlyone/) {
           $checked = ' checked="checked" ';
     } else {      } else {
         $next_meta = 1;          $checked = '  ';
     }      }
       $output.='&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="'.$field_name.'_onlyone" value="yes"'.$checked.' />';
       $output.='Student may select only one choice <br />';
       if ($options =~ m/stuadd/) {
           $checked = ' checked="checked" ';
       } else {
           $checked = ' ';
       }
       $output.='&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type="checkbox" name="'.$field_name.'_stuadd" value="yes"'.$checked.' />';
       $output.='Student may type choices <br />';
       return ($output);
   }
   
   sub setrestrictmeta {
       my ($r)=@_;
       my $next_meta;
       my $output;
       my $item_num;
       my $put_result;
     $r->print(&Apache::lonxml::xmlbegin());      $r->print(&Apache::lonxml::xmlbegin());
     $r->print('<head>      $r->print('<head>
             <title>LON-CAPA Set Instructor Metadata</title>              <title>LON-CAPA Restrict Metadata</title>
             </head>');              </head>');
     $r->print(&Apache::loncommon::bodytag('Set Instructor Metadata'));      $r->print(&Apache::loncommon::bodytag('Restrict Metadata'));
     $r->print(&Apache::lonhtmlcommon::breadcrumbs(undef,      $r->print(&Apache::lonhtmlcommon::breadcrumbs(undef,
     'Set Instructor Metadata'));      'Restrict Metadata'));
     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};      my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
     if ($env{'form.state'}eq 'add') {      my $key_base = $env{'course.'.$env{'request.course.id'}.'.'};
         $r->print('<strong>Compose a new metadata item:</strong><br />');      my $save_field = '';
         $r->print('<form method="post" action="/adm/parmset">');      if ($env{'form.restrictmeta'}) {
         $r->print ('Title of item: '.&Apache::lonhtmlcommon::textbox("title",undef,undef,undef).'<br />');          foreach my $field (sort(keys(%env))) {
         $r->print ('List if items (comma separated): '.&Apache::lonhtmlcommon::textbox("values",undef,undef,undef).'<br />');              if ($field=~m/^form.(.+)_(.+)$/) {
         $r->print ('Select one: <input type="radio" name="type" value="one"><br />');                  my $options;
         $r->print ('Select many: <input type="radio" name="type" value="many"><br />');                  my $meta_field = $1;
         $r->print('<input type="hidden" name="serial" value="'.$next_meta.'" />');                  my $meta_key = $2;
         $r->print('<input type="hidden" name="action" value="setinstmeta" />');                  if ($save_field ne $meta_field) {
         $r->print('<input type="hidden" name="state" value="save" />');                      $save_field = $meta_field;
         $r->print('<input type="submit" value="Save Metadata">');                 if ($env{'form.'.$meta_field.'_stuadd'}) {
         $r->print('</form>');                     $options.='stuadd,';
     } elsif ($env{'form.state'}eq 'save') {                 } 
         $r->print('Here we save the metadata');                 if ($env{'form.'.$meta_field.'_onlyone'}) {
     } else {                     $options.='onlyone,';
         foreach my $key (sort keys %env) {                 } 
             my $found_one = 0;                 if ($env{'form.'.$meta_field.'_active'}) {
             if ($key=~m/^course\.$env{'request.course.id'}\.metadata\.title/) {                     $options.='active,';
                 unless ($found_one) {                 }
                     $found_one = 1;                      my $name = $save_field;
                     $r->print('<strong>Existing Metadata</strong><br >');                       $put_result = &Apache::lonnet::put('environment',
                 }                                                    {$meta_field.'.options'=>$options,
                 $r->print($env{$key}.'<br />');                                                     $meta_field.'.values'=>$env{'form.'.$meta_field.'_values'},
                 $key=~~m/^course\.$env{'request.course.id'}\.metadata\.title\.(d*)\./;                                                     },$dom,$crs);
                 if ($1 ge $next_meta) {  
                     $next_meta = $1 ++;  
                 }                  }
             }              }
         }          }
         $r->print('<a href="/adm/parmset?action=setinstmeta&state=add&nextmeta='.$next_meta.'">Add Metadata Item</a><br />');  
     }      }
       &Apache::lonnet::coursedescription($env{'request.course.id'});
       my %metadata_fields = &Apache::lonmeta::fieldnames('portfolio');
       foreach my $field (sort(keys(%metadata_fields))) {
    $output.= &output_row($r, $field, $metadata_fields{$field});
       }
       $r->print(<<ENDenv);       
           <form method="post" action="/adm/parmset?action=setrestrictmeta" name="form">
           <p>
           $output
           <input type="submit" name="restrictmeta" value="Update Metadata Restrictions">
           </form>
   ENDenv
     $r->print('</body>      $r->print('</body>
                 </html>');                  </html>');
     return 'ok';      return 'ok';
Line 2949  Main handler.  Calls &assessparms and &c Line 3017  Main handler.  Calls &assessparms and &c
 ##################################################  ##################################################
 #    use Data::Dumper;  #    use Data::Dumper;
   
   
 sub handler {  sub handler {
     my $r=shift;      my $r=shift;
   
Line 2962  sub handler { Line 3031  sub handler {
                                              'pres_marker',                                               'pres_marker',
                                              'pres_value',                                               'pres_value',
                                              'pres_type',                                               'pres_type',
                                              'udom','uname','symb']);                                               'udom','uname','symb','serial']);
   
   
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();
Line 3009  sub handler { Line 3078  sub handler {
             &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',              &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',
     text=>"Overview Mode"});      text=>"Overview Mode"});
     &overview($r);      &overview($r);
         } elsif ($env{'form.action'} eq 'setinstmeta' && $parm_permission) {          } elsif ($env{'form.action'} eq 'setrestrictmeta' && $parm_permission) {
             &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setinstmeta',              &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setrestrictmeta',
     text=>"Instructor Metadata"});      text=>"Restrict Metadata"});
     &setinstmeta($r);      &setrestrictmeta($r);
         } elsif ($env{'form.action'} eq 'newoverview' && $parm_permission) {          } elsif ($env{'form.action'} eq 'newoverview' && $parm_permission) {
             &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',              &Apache::lonhtmlcommon::add_breadcrumb({href=>'/adm/parmset?action=setoverview',
     text=>"Overview Mode"});      text=>"Overview Mode"});

Removed from v.1.242  
changed lines
  Added in v.1.260


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>