Diff for /loncom/interface/spreadsheet/studentcalc.pm between versions 1.6 and 1.13

version 1.6, 2003/05/23 19:36:04 version 1.13, 2003/06/23 20:47:00
Line 64  my %Exportrows = (); Line 64  my %Exportrows = ();
   
 my $current_course;  my $current_course;
   
   sub initialize {
       &Apache::assesscalc::initialize();
       &initialize_sequence_cache();
   }
   
 sub initialize_package {  sub initialize_package {
     $current_course = $ENV{'request.course.id'};      $current_course = $ENV{'request.course.id'};
     &initialize_sequence_cache();      &initialize_sequence_cache();
     &load_cached_export_rows();      &load_cached_export_rows();
 }  }
   
   sub ensure_correct_sequence_data {
       if ($current_course ne $ENV{'request.course.id'}) {
           &initialize_sequence_cache();
           $current_course = $ENV{'request.course.id'};
       }
       return;
   }
   
 sub initialize_sequence_cache {  sub initialize_sequence_cache {
     #      #
     # Set up the sequences and assessments      # Set up the sequences and assessments
Line 134  sub parent_link { Line 147  sub parent_link {
 sub outsheet_html {  sub outsheet_html {
     my $self = shift;      my $self = shift;
     my ($r) = @_;      my ($r) = @_;
       my $importcolor = '#FFFFAA';
       my $exportcolor = '#88FF88';
     ####################################      ####################################
     # Get the list of assessment files #      # Get the list of assessment files #
     ####################################      ####################################
Line 150  sub outsheet_html { Line 165  sub outsheet_html {
 <table border="2">  <table border="2">
 <tr>  <tr>
   <th colspan="2" rowspan="2"><font size="+2">Student</font></th>    <th colspan="2" rowspan="2"><font size="+2">Student</font></th>
   <td bgcolor="#FFDDDD" colspan="$num_uneditable">    <td bgcolor="$importcolor" colspan="$num_uneditable">
       <b><font size="+1">Import</font></b></td>        <b><font size="+1">Import</font></b></td>
   <td colspan="$num_left">    <td colspan="$num_left">
       <b><font size="+1">Calculations</font></b></td>        <b><font size="+1">Calculations</font></b></td>
Line 159  END Line 174  END
     my $label_num = 0;      my $label_num = 0;
     foreach (split(//,'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz')){      foreach (split(//,'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz')){
         if ($label_num<$num_uneditable) {           if ($label_num<$num_uneditable) { 
             $tableheader .='<td bgcolor="#FFDDDD">';              $tableheader .='<td bgcolor="'.$importcolor.'">';
         } else {          } else {
             $tableheader .='<td>';              $tableheader .='<td>';
         }          }
Line 178  END Line 193  END
         # Print out template row          # Print out template row
         if (exists($ENV{'request.role.adv'}) && $ENV{'request.role.adv'}) {          if (exists($ENV{'request.role.adv'}) && $ENV{'request.role.adv'}) {
             $r->print('<tr><td>Template</td><td>&nbsp;</td>'.              $r->print('<tr><td>Template</td><td>&nbsp;</td>'.
                       $self->html_template_row($num_uneditable)."</tr>\n");                        $self->html_template_row($num_uneditable,
                                                  $importcolor)."</tr>\n");
         }          }
         #          #
         # Print out summary/export row          # Print out summary/export row
         $r->print('<tr><td>Summary</td><td>0</td>'.          $r->print('<tr><td>Summary</td><td>0</td>'.
                   $self->html_export_row()."</tr>\n");                    $self->html_export_row($exportcolor)."</tr>\n");
     }      }
     $r->print("</table>\n");      $r->print("</table>\n");
     #      #
Line 246  END Line 262  END
                 $row_output .=                   $row_output .= 
                     '<td colspan="52">Unavailable at this time</td></tr>'."\n";                      '<td colspan="52">Unavailable at this time</td></tr>'."\n";
             } else {              } else {
                 $row_output .= $self->html_row($num_uneditable,$rownum).                  $row_output .= $self->html_row($num_uneditable,$rownum,
                                                  $exportcolor,$importcolor).
                     "</tr>\n";                      "</tr>\n";
             }              }
             $r->print($row_output);              $r->print($row_output);
Line 312  sub modify_cell { Line 329  sub modify_cell {
     return;      return;
 }  }
   
 sub outsheet_csv {  sub csv_rows {
       # writes the meat of the spreadsheet to an excel worksheet.  Called
       # by Spreadsheet::outsheet_excel;
     my $self = shift;      my $self = shift;
     my ($r) = @_;      my ($filehandle) = @_;
     $r->print('<h1>csv output is not supported yet</h1>');      #
       # Write a header row
       $self->csv_output_row($filehandle,undef,
                             ('Sequence or Folder','Assessment title'));
       #
       # Write each assessments row
       if (scalar(@Sequences)< 1) {
           &initialize_sequence_cache();
       }
       foreach my $Sequence (@Sequences) {
    next if ($Sequence->{'num_assess'} < 1);
    foreach my $resource (@{$Sequence->{'contents'}}) {
       my $rownum = $self->get_row_number_from_key($resource->{'symb'});
               my @assessdata = ($Sequence->{'title'},
                                 $resource->{'title'});
               $self->csv_output_row($filehandle,$rownum,@assessdata);
           }
       }
       return;
 }  }
   
 sub excel_rows {  sub excel_rows {
Line 353  sub outsheet_recursive_excel { Line 390  sub outsheet_recursive_excel {
     my ($r) = @_;      my ($r) = @_;
 }   } 
   
 sub set_row_sources {  
     my $self = shift;  
     while (my ($cell,$value) = each(%{$self->{'formulas'}})) {  
         next if ($cell !~ /^A(\d+)/ && $1 > 0);  
         my $row = $1;  
         (undef,$value) = split('__&&&__',$value);  
         $value = 'Default' if (! defined($value));  
         $self->{'row_source'}->{$row} = $value;  
     }  
     return;  
 }  
   
 sub compute {  sub compute {
     my $self = shift;      my $self = shift;
     $self->logthis('computing');      $self->logthis('computing');
Line 442  sub compute { Line 467  sub compute {
     $Exportrows{$student}->{'data'} = \@exportarray;      $Exportrows{$student}->{'data'} = \@exportarray;
     # save export row      # save export row
     $self->save_export_data();      $self->save_export_data();
       #
       $self->save() if ($self->need_to_save());
       return;
   }
   
   sub set_row_sources {
       my $self = shift;
       while (my ($cell,$value) = each(%{$self->{'formulas'}})) {
           next if ($cell !~ /^A(\d+)/ && $1 > 0);
           my $row = $1;
           (undef,$value) = split('__&&&__',$value);
           $value = 'Default' if (! defined($value));
           $self->{'row_source'}->{$row} = $value;
       }
     return;      return;
 }  }
   
Line 453  sub set_row_numbers { Line 492  sub set_row_numbers {
         next if ($row == 0);          next if ($row == 0);
         my ($symb,undef) = split('__&&&__',$formula);          my ($symb,undef) = split('__&&&__',$formula);
         $self->{'row_numbers'}->{$symb} = $row;          $self->{'row_numbers'}->{$symb} = $row;
           $self->{'maxrow'} = $1 if ($1 > $self->{'maxrow'});
     }      }
 }  }
   

Removed from v.1.6  
changed lines
  Added in v.1.13


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