--- loncom/interface/spreadsheet/studentcalc.pm 2005/08/26 20:46:46 1.35
+++ loncom/interface/spreadsheet/studentcalc.pm 2009/06/09 14:15:42 1.44
@@ -1,5 +1,5 @@
#
-# $Id: studentcalc.pm,v 1.35 2005/08/26 20:46:46 albertel Exp $
+# $Id: studentcalc.pm,v 1.44 2009/06/09 14:15:42 bisitz Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -59,6 +59,8 @@ use Apache::assesscalc();
use HTML::Entities();
use Time::HiRes;
use Apache::lonlocal;
+use LONCAPA;
+
@Apache::studentcalc::ISA = ('Apache::Spreadsheet');
@@ -99,7 +101,7 @@ sub initialize_sequence_cache {
my @all_sequences = $navmap->retrieveResources(undef,
sub { shift->is_map(); },1,0,1);
for my $sequence ($navmap->getById('0.0'), @all_sequences) {
- if ($navmap->hasResource($sequence,sub { shift->is_problem(); }, 0)){
+ if ($navmap->hasResource($sequence,sub { shift->is_problem(); }, 0,1)){
push(@Sequences,$sequence);
&get_resources($sequence);
}
@@ -115,7 +117,7 @@ sub get_resources {
return () if (! defined($navmap) || ! ref($navmap));
my @resources = $navmap->retrieveResources($seq,
sub { shift->is_problem(); },
- 0,0,0);
+ 0,0,1);
$res_memoize{$seq->symb()}=\@resources;
return @resources;
}
@@ -221,16 +223,16 @@ END
}
$tableheader .="\n";
if ($self->blackout()) {
- $r->print(''.
+ $r->print('
'.
&mt('Some computations are not available at this time.').'
'.
&mt('There are problems whose status you are not allowed to view.').
- '
'."\n");
+ ''."\n");
} else {
$r->print($tableheader);
#
# Print out template row
if (exists($env{'request.role.adv'}) && $env{'request.role.adv'}) {
- $r->print('Template | | '.
+ $r->print('
'.&mt('Template').' | | '.
$self->html_template_row($num_uneditable,
$importcolor)."
\n");
}
@@ -271,8 +273,17 @@ END
}
foreach my $Sequence (@Sequences) {
$r->print("".$Sequence->compTitle."
\n");
+
+ my @resources = &get_resources($Sequence);
+ my $first_rownum =
+ $self->get_row_number_from_key($resources[0]->symb);
+ my $last_rownum =
+ $self->get_row_number_from_key($resources[-1]->symb);
+ $r->print(&assess_file_selector([$first_rownum, $last_rownum],
+ undef, \@AssessFileNames));
+
$r->print($tableheader);
- foreach my $resource (&get_resources($Sequence)) {
+ foreach my $resource (@resources) {
my $rownum = $self->get_row_number_from_key($resource->symb);
my $assess_filename = $self->{'row_source'}->{$rownum};
my $row_output = '';
@@ -283,7 +294,7 @@ END
''.$resource->compTitle.'
';
$row_output .= &assess_file_selector($rownum,
$assess_filename,
@@ -291,7 +302,7 @@ END
'';
} else {
$row_output .= 'Go To';
$row_output .= ' | '.$resource->compTitle.' | ';
}
@@ -328,12 +339,25 @@ sub assess_file_selector {
return '';
}
return '' if (! &Apache::lonnet::allowed('mgr',$env{'request.course.id'}));
- my $element_name = 'FileSelect_'.$row;
+ my $element_name;
+ my $source_row = $row;
+ if (ref($row)) {
+ my ($first_rownum, $last_rownum) = @$row;
+ $element_name = "FileSelect_${first_rownum}_${last_rownum}";
+ $source_row = "${first_rownum}:${last_rownum}";
+ } else {
+ $element_name = 'FileSelect_'.$row;
+ }
my $load_dialog = '