Diff for /loncom/interface/Attic/lonspreadsheet.pm between versions 1.152 and 1.156

version 1.152, 2002/12/02 21:22:39 version 1.156, 2002/12/09 14:50:11
Line 981  sub outrowassess { Line 981  sub outrowassess {
     if ($n) {      if ($n) {
         my ($usy,$ufn)=split(/__&&&\__/,$sheet->{'f'}->{'A'.$n});          my ($usy,$ufn)=split(/__&&&\__/,$sheet->{'f'}->{'A'.$n});
         if (exists($sheet->{'rowlabel'}->{$usy})) {          if (exists($sheet->{'rowlabel'}->{$usy})) {
             $rowlabel = $sheet->{'rowlabel'}->{$usy};              # This is dumb, but we need the information when we output
               # the html version of the studentcalc spreadsheet for the
               # links to the assesscalc sheets.
               $rowlabel = $sheet->{'rowlabel'}->{$usy}.':'.
                   &Apache::lonnet::escape($ufn);
         } else {           } else { 
             $rowlabel = '';              $rowlabel = '';
         }          }
Line 1198  sub sort_indicies { Line 1202  sub sort_indicies {
         my @sortby2=(undef);          my @sortby2=(undef);
         # Skip row 0          # Skip row 0
         for (my $row=1;$row<=$sheet->{'maxrow'};$row++) {          for (my $row=1;$row<=$sheet->{'maxrow'};$row++) {
             my (undef,$symb,$uname,$udom,$mapid,$resid,$title) =               my ($key,undef) = split(/__&&&\__/,$sheet->{'f'}->{'A'.$row});
                 split(':',$sheet->{'rowlabel'}->{$sheet->{'f'}->{'A'.$row}});              my $rowlabel = $sheet->{'rowlabel'}->{$key};
             $symb = &Apache::lonnet::unescape($symb);              my (undef,$symb,$mapid,$resid,$title,$ufn) = 
                   split(':',$rowlabel);
               $ufn   = &Apache::lonnet::unescape($ufn);
               $symb  = &Apache::lonnet::unescape($symb);
               $title = &Apache::lonnet::unescape($title);
             my ($sequence) = ($symb =~ /\/([^\/]*\.sequence)/);              my ($sequence) = ($symb =~ /\/([^\/]*\.sequence)/);
             if ($sequence eq '') {              if ($sequence eq '') {
                 $sequence = $symb;                  $sequence = $symb;
Line 1276  sub html_uneditable_cell { Line 1284  sub html_uneditable_cell {
 sub outsheet_html  {  sub outsheet_html  {
     my ($sheet,$r) = @_;      my ($sheet,$r) = @_;
     my ($num_uneditable,$realm,$row_type);      my ($num_uneditable,$realm,$row_type);
       my $requester_is_student = ($ENV{'request.role'} =~ /^st\./);
     if ($sheet->{'sheettype'} eq 'assesscalc') {      if ($sheet->{'sheettype'} eq 'assesscalc') {
         $num_uneditable = 1;          $num_uneditable = 1;
         $realm = 'Assessment';          $realm = 'Assessment';
Line 1320  END Line 1329  END
     ####################################      ####################################
     # Print out template row      # Print out template row
     ####################################      ####################################
     my ($rowlabel,@rowdata) = &get_row($sheet,'-');      my ($num_cols_output,$row_html,$rowlabel,@rowdata);
     my $row_html = '<tr><td>'.&format_html_rowlabel($sheet,$rowlabel).'</td>';      
     my $num_cols_output = 0;      if (! $requester_is_student) {
     foreach my $cell (@rowdata) {          ($rowlabel,@rowdata) = &get_row($sheet,'-');
         if ($num_cols_output++ < $num_uneditable) {          $row_html = '<tr><td>'.&format_html_rowlabel($sheet,$rowlabel).'</td>';
             $row_html .= '<td bgcolor="#FFDDDD">';          $num_cols_output = 0;
             $row_html .= &html_uneditable_cell($cell,'#FFDDDD');          foreach my $cell (@rowdata) {
         } else {              if ($requester_is_student || 
             $row_html .= '<td bgcolor="#EOFFDD">';                  $num_cols_output++ < $num_uneditable) {
             $row_html .= &html_editable_cell($cell,'#E0FFDD');                  $row_html .= '<td bgcolor="#FFDDDD">';
                   $row_html .= &html_uneditable_cell($cell,'#FFDDDD');
               } else {
                   $row_html .= '<td bgcolor="#EOFFDD">';
                   $row_html .= &html_editable_cell($cell,'#E0FFDD');
               }
               $row_html .= '</td>';
         }          }
         $row_html .= '</td>';          $row_html.= "</tr>\n";
           $r->print($row_html);
     }      }
     $row_html.= "</tr>\n";  
     $r->print($row_html);  
     ####################################      ####################################
     # Print out summary/export row      # Print out summary/export row
     ####################################      ####################################
     ($rowlabel,@rowdata) = &get_row($sheet,'0');      ($rowlabel,@rowdata) = &get_row($sheet,'0');
     $row_html = '<tr><td>'.&format_html_rowlabel($sheet,$rowlabel).'</td>';      $row_html = '<tr><td>'.&format_html_rowlabel($sheet,'Summary').'</td>';
     $num_cols_output = 0;      $num_cols_output = 0;
     foreach my $cell (@rowdata) {      foreach my $cell (@rowdata) {
         if ($num_cols_output++ < 26) {          if ($num_cols_output++ < 26 && ! $requester_is_student) {
             $row_html .= '<td bgcolor="#CCCCFF">';              $row_html .= '<td bgcolor="#CCCCFF">';
             $row_html .= &html_editable_cell($cell,'#CCCCFF');              $row_html .= &html_editable_cell($cell,'#CCCCFF');
         } else {          } else {
             $row_html .= '<td bgcolor="#DDCCFF">';              $row_html .= '<td bgcolor="#DDCCFF">';
             $row_html .= &html_uneditable_cell(undef,'#CCCCFF');              $row_html .= &html_uneditable_cell($cell,'#CCCCFF');
         }          }
         $row_html .= '</td>';          $row_html .= '</td>';
     }      }
Line 1387  END Line 1401  END
         if ($sheet->{'sheettype'} eq 'classcalc') {          if ($sheet->{'sheettype'} eq 'classcalc') {
             $row_html.='<td>'.&format_html_rowlabel($sheet,$rowlabel).'</td>';              $row_html.='<td>'.&format_html_rowlabel($sheet,$rowlabel).'</td>';
             # Output links for each student?              # Output links for each student?
             # Nope, that is already done for us in format_html_rowlabel (for now)              # Nope, that is already done for us in format_html_rowlabel 
               # (for now)
         } elsif ($sheet->{'sheettype'} eq 'studentcalc') {          } elsif ($sheet->{'sheettype'} eq 'studentcalc') {
               my $ufn = (split(/:/,$rowlabel))[5];
             $row_html.='<td>'.&format_html_rowlabel($sheet,$rowlabel);              $row_html.='<td>'.&format_html_rowlabel($sheet,$rowlabel);
             $row_html.= '<br>'.              $row_html.= '<br>'.
                 '<select name="sel_'.$rownum.'" '.                  '<select name="sel_'.$rownum.'" '.
                     'onChange="changesheet('.$rownum.')">'.                      'onChange="changesheet('.$rownum.')">'.
                         '<option name="default">Default</option>';                          '<option name="default">Default</option>';
   
             foreach (@{$sheet->{'othersheets'}}) {              foreach (@{$sheet->{'othersheets'}}) {
                 $row_html.='<option name="'.$_.'"';                  $row_html.='<option name="'.$_.'"';
                 #if ($ufn eq $_) {                  if ($ufn eq $_) {
                 #    $row_html.=' selected';                      $row_html.=' selected';
                 #}                  }
                 $row_html.='>'.$_.'</option>';                  $row_html.='>'.$_.'</option>';
             }              }
             $row_html.='</select></td>';              $row_html.='</select></td>';
Line 1421  END Line 1438  END
             $bgcolor='#FFDDDD' if ($shown_cells < $num_uneditable);              $bgcolor='#FFDDDD' if ($shown_cells < $num_uneditable);
             #              #
             $row_html.='<td bgcolor='.$bgcolor.'>';              $row_html.='<td bgcolor='.$bgcolor.'>';
             if ($shown_cells < $num_uneditable) {              if ($requester_is_student || $shown_cells < $num_uneditable) {
                 $row_html .= &html_uneditable_cell($cell,$bgcolor);                  $row_html .= &html_uneditable_cell($cell,$bgcolor);
             } else {              } else {
                 $row_html .= &html_editable_cell($cell,$bgcolor);                  $row_html .= &html_editable_cell($cell,$bgcolor);
Line 1902  sub writesheet { Line 1919  sub writesheet {
                                           $cdom,$cnum);                                            $cdom,$cnum);
             if ($reply eq 'ok') {              if ($reply eq 'ok') {
                 if ($makedef) {                   if ($makedef) { 
                     return &Apache::lonnet::put('environment',                      $reply = &Apache::lonnet::put('environment',
                                   {'spreadsheet_default_'.$stype => $fn },                                      {'spreadsheet_default_'.$stype => $fn },
                                                 $cdom,$cnum);                                                    $cdom,$cnum);
                       if ($reply eq 'ok' && 
                           ($sheet->{'sheettype'} eq 'studentcalc' ||
                            $sheet->{'sheettype'} eq 'assesscalc')) {
                           # Expire the spreadsheets of the other students.
                           &Apache::lonnet::expirespread('','','studentcalc','');
                       }
                       return $reply;
                 }                   } 
                 return $reply;                  return $reply;
             }               } 
Line 1927  sub tmpwrite { Line 1951  sub tmpwrite {
     $fn=$tmpdir.$fn.'.tmp';      $fn=$tmpdir.$fn.'.tmp';
     my $fh;      my $fh;
     if ($fh=Apache::File->new('>'.$fn)) {      if ($fh=Apache::File->new('>'.$fn)) {
  print $fh join("\n",&getformulas($sheet));          my %f = &getformulas($sheet);
           while( my ($cell,$formula) = each(%f)) {
               print $fh &Apache::lonnet::escape($cell)."=".&Apache::lonnet::escape($formula)."\n";
           }
     }      }
 }  }
   
Line 1943  sub tmpread { Line 1970  sub tmpread {
     my %fo=();      my %fo=();
     my $countrows=0;      my $countrows=0;
     if ($fh=Apache::File->new($fn)) {      if ($fh=Apache::File->new($fn)) {
         my $name;          while (<$fh>) {
         while ($name=<$fh>) {      chomp;
     chomp($name);              my ($cell,$formula) = split(/=/);
             my $value=<$fh>;              $cell    = &Apache::lonnet::unescape($cell);
             chomp($value);              $formula = &Apache::lonnet::unescape($formula);
             $fo{$name}=$value;              $fo{$cell} = $formula;
             if ($name=~/^A(\d+)$/) {          }
  if ($1>$countrows) {      }
     $countrows=$1;  #            chomp($value);
                 }  #            $fo{$name}=$value;
             }  #            if ($name=~/^A(\d+)$/) {
         }  # if ($1>$countrows) {
     }  #    $countrows=$1;
   #                }
   #            }
   #        }
   #    }
     if ($nform eq 'changesheet') {      if ($nform eq 'changesheet') {
         $fo{'A'.$nfield}=(split(/__&&&\__/,$fo{'A'.$nfield}))[0];          $fo{'A'.$nfield}=(split(/__&&&\__/,$fo{'A'.$nfield}))[0];
         unless ($ENV{'form.sel_'.$nfield} eq 'Default') {          unless ($ENV{'form.sel_'.$nfield} eq 'Default') {
     $fo{'A'.$nfield}.='__&&&__'.$ENV{'form.sel_'.$nfield};      $fo{'A'.$nfield}.='__&&&__'.$ENV{'form.sel_'.$nfield};
         }          }
     } elsif ($nfield eq 'insertrow') {  #    } elsif ($nfield eq 'insertrow') {
         $countrows++;  #        $countrows++;
         my $newrow=substr('000000'.$countrows,-7);  #        my $newrow=substr('000000'.$countrows,-7);
         if ($nform eq 'top') {  #        if ($nform eq 'top') {
     $fo{'A'.$countrows}='--- '.$newrow;  #    $fo{'A'.$countrows}='--- '.$newrow;
         } else {  #        } else {
             $fo{'A'.$countrows}='~~~ '.$newrow;  #            $fo{'A'.$countrows}='~~~ '.$newrow;
         }  #        }
     } else {      } else {
        if ($nfield) { $fo{$nfield}=$nform; }         if ($nfield) { $fo{$nfield}=$nform; }
     }      }
Line 2062  sub format_html_rowlabel { Line 2093  sub format_html_rowlabel {
     my ($type,$labeldata) = split(':',$rowlabel,2);      my ($type,$labeldata) = split(':',$rowlabel,2);
     my $result = '';      my $result = '';
     if ($type eq 'symb') {      if ($type eq 'symb') {
         my ($symb,$mapid,$resid,$title) = split(':',$labeldata);          my ($symb,$mapid,$resid,$title,$ufn) = split(':',$labeldata);
         $symb = &Apache::lonnet::unescape($symb);          $ufn   = 'default' if (!defined($ufn) || $ufn eq '');
           $ufn   = &Apache::lonnet::unescape($ufn);
           $symb  = &Apache::lonnet::unescape($symb);
           $title = &Apache::lonnet::unescape($title);
         $result = '<a href="/adm/assesscalc?usymb='.$symb.          $result = '<a href="/adm/assesscalc?usymb='.$symb.
             '&uname='.$sheet->{'uname'}.'&udom='.$sheet->{'udom'}.              '&uname='.$sheet->{'uname'}.'&udom='.$sheet->{'udom'}.
                 '&mapid='.$mapid.'&resid='.$resid.'">'.$title.'</a>';                  '&ufn='.$ufn.
                       '&mapid='.$mapid.'&resid='.$resid.'">'.$title.'</a>';
     } elsif ($type eq 'student') {      } elsif ($type eq 'student') {
         my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);          my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);
         if ($fullname =~ /^\s*$/) {          if ($fullname =~ /^\s*$/) {
Line 2090  sub format_csv_rowlabel { Line 2125  sub format_csv_rowlabel {
     my ($type,$labeldata) = split(':',$rowlabel,2);      my ($type,$labeldata) = split(':',$rowlabel,2);
     my $result = '';      my $result = '';
     if ($type eq 'symb') {      if ($type eq 'symb') {
         my ($symb,$mapid,$resid,$title) = split(':',$labeldata);          my ($symb,$mapid,$resid,$title,$ufn) = split(':',$labeldata);
         $symb = &Apache::lonnet::unescape($symb);          $ufn   = &Apache::lonnet::unescape($ufn);
           $symb  = &Apache::lonnet::unescape($symb);
           $title = &Apache::lonnet::unescape($title);
         $result = $title;          $result = $title;
     } elsif ($type eq 'student') {      } elsif ($type eq 'student') {
         my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);          my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);
Line 2112  sub format_excel_rowlabel { Line 2149  sub format_excel_rowlabel {
     my ($type,$labeldata) = split(':',$rowlabel,2);      my ($type,$labeldata) = split(':',$rowlabel,2);
     my $result = '';      my $result = '';
     if ($type eq 'symb') {      if ($type eq 'symb') {
         my ($symb,$mapid,$resid,$title) = split(':',$labeldata);          my ($symb,$mapid,$resid,$title,$ufn) = split(':',$labeldata);
         $symb = &Apache::lonnet::unescape($symb);          $ufn   = &Apache::lonnet::unescape($ufn);
           $symb  = &Apache::lonnet::unescape($symb);
           $title = &Apache::lonnet::unescape($title);
         $result = $title;          $result = $title;
     } elsif ($type eq 'student') {      } elsif ($type eq 'student') {
         my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);          my ($sname,$sdom,$fullname,$section,$id) = split(':',$labeldata);
Line 2221  sub get_student_rowlabels { Line 2260  sub get_student_rowlabels {
             return 'Could not access course data';              return 'Could not access course data';
         }          }
         #          #
         my %assesslist;          my %assesslist = ();
         foreach ('Feedback','Evaluation','Tutoring','Discussion') {          foreach ('Feedback','Evaluation','Tutoring','Discussion') {
             my $symb = '_'.lc($_);              my $symb = '_'.lc($_);
             $assesslist{$symb} = join(':',('symb',$symb,0,0,$_));              $assesslist{$symb} = join(':',('symb',$symb,0,0,
                                              &Apache::lonnet::escape($_)));
         }          }
         #          #
         while (my ($key,$srcf) = each(%course_db)) {          while (my ($key,$srcf) = each(%course_db)) {
Line 2236  sub get_student_rowlabels { Line 2276  sub get_student_rowlabels {
                 my $symb=                  my $symb=
                     &Apache::lonnet::declutter($course_db{'map_id_'.$mapid}).                      &Apache::lonnet::declutter($course_db{'map_id_'.$mapid}).
                         '___'.$resid.'___'.&Apache::lonnet::declutter($srcf);                          '___'.$resid.'___'.&Apache::lonnet::declutter($srcf);
                 $assesslist{$symb}='symb:'.&Apache::lonnet::escape($symb).':'                  $assesslist{$symb} ='symb:'.&Apache::lonnet::escape($symb).':'
                     .$mapid.':'.$resid.':'.$course_db{'title_'.$id};                      .$mapid.':'.$resid.':'.
                           &Apache::lonnet::escape($course_db{'title_'.$id});
             }              }
         }          }
         untie(%course_db);          untie(%course_db);
Line 2336  sub updatestudentassesssheet { Line 2377  sub updatestudentassesssheet {
                  ($formula =~ /^(~~~|---)/) )) {                   ($formula =~ /^(~~~|---)/) )) {
             $f{$_}='!!! Obsolete';              $f{$_}='!!! Obsolete';
             $changed=1;              $changed=1;
         } elsif ($ufn) {  
             # I do not think this works any more  
             $sheet->{'rowlabel'}->{$usy}  
                 =~s/assesscalc\?usymb\=/assesscalc\?ufn\=$ufn&\usymb\=/;  
         }          }
     }      }
     # New and unknown keys      # New and unknown keys
Line 2680  sub forcedrecalc { Line 2717  sub forcedrecalc {
             &checkthis($uname.':'.$udom.':assesscalc:'.$map,$time) ||              &checkthis($uname.':'.$udom.':assesscalc:'.$map,$time) ||
             &checkthis($uname.':'.$udom.':assesscalc:'.$usymb,$time)) {              &checkthis($uname.':'.$udom.':assesscalc:'.$usymb,$time)) {
             return 1;              return 1;
         }           }
     } else {      } else {
         if (&checkthis('::studentcalc:',$time) ||           if (&checkthis('::studentcalc:',$time) || 
             &checkthis($uname.':'.$udom.':studentcalc:',$time)) {              &checkthis($uname.':'.$udom.':studentcalc:',$time)) {
Line 2701  sub exportsheet { Line 2738  sub exportsheet {
     $udom  = $udom  || $sheet->{'udom'};      $udom  = $udom  || $sheet->{'udom'};
     $stype = $stype || $sheet->{'sheettype'};      $stype = $stype || $sheet->{'sheettype'};
     my @exportarr=();      my @exportarr=();
       # This handles the assessment sheets for '_feedback', etc
     if (defined($usymb) && ($usymb=~/^\_(\w+)/) &&       if (defined($usymb) && ($usymb=~/^\_(\w+)/) && 
         (!defined($fn) || $fn eq '')) {          (!defined($fn) || $fn eq '')) {
         $fn='default_'.$1;          $fn='default_'.$1;
Line 2946  sub handler { Line 2984  sub handler {
         delete $ENV{'form.unewformula'} if (exists($ENV{'form.unewformula'}));          delete $ENV{'form.unewformula'} if (exists($ENV{'form.unewformula'}));
     }      }
     #      #
     # Clean up symb and spreadsheet filename      # Look for special assessment spreadsheets - '_feedback', etc.
     #      #
     if (($ENV{'form.usymb'}=~/^\_(\w+)/) && (!$ENV{'form.ufn'})) {      if (($ENV{'form.usymb'}=~/^\_(\w+)/) && (!$ENV{'form.ufn'} || 
                                                $ENV{'form.ufn'} eq '' || 
                                                $ENV{'form.ufn'} eq 'default')) {
         $ENV{'form.ufn'}='default_'.$1;          $ENV{'form.ufn'}='default_'.$1;
     }      }
       if (!$ENV{'form.ufn'} || $ENV{'form.ufn'} eq 'default') {
           $ENV{'form.ufn'}='course_default_'.$sheettype;
       }
     #      #
     # Interactive loading of specific sheet?      # Interactive loading of specific sheet?
     #      #
Line 3086  ENDSCRIPT Line 3129  ENDSCRIPT
     # If a new formula had been entered, go from work copy      # If a new formula had been entered, go from work copy
     if ($ENV{'form.unewfield'}) {      if ($ENV{'form.unewfield'}) {
         $r->print('<h2>Modified Workcopy</h2>');          $r->print('<h2>Modified Workcopy</h2>');
         $ENV{'form.unewformula'}=~s/\'/\"/g;          #$ENV{'form.unewformula'}=~s/\'/\"/g;
         $r->print('<p>Cell '.$ENV{'form.unewfield'}.' = <pre>');          $r->print('<p>Cell '.$ENV{'form.unewfield'}.' = <pre>');
         $r->print(&HTML::Entities::encode($ENV{'form.unewformula'}).          $r->print(&HTML::Entities::encode($ENV{'form.unewformula'}).
                   '</pre></p>');                    '</pre></p>');
Line 3265  ENDSCRIPT Line 3308  ENDSCRIPT
   
 1;  1;
 __END__  __END__
   
   

Removed from v.1.152  
changed lines
  Added in v.1.156


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