version 1.48, 2002/07/01 15:39:55
|
version 1.49, 2002/07/01 21:12:06
|
Line 59 my $jr;
|
Line 59 my $jr;
|
# ----- FORMAT PRINT DATA ---------------------------------------------- |
# ----- FORMAT PRINT DATA ---------------------------------------------- |
|
|
sub FormatStudentInformation { |
sub FormatStudentInformation { |
my ($cache,$name,$studentInformation,$spacePadding)=@_; |
my ($cache,$name,$studentInformation,$reselected,$spacePadding)=@_; |
my $Str='<pre>'; |
my $Str='<pre>'; |
|
|
foreach (@$studentInformation) { |
for(my $index=0; $index<(scalar @$studentInformation); $index++) { |
my $data=$cache->{$name.':'.$_}; |
if(!&ShouldShowColumn($reselected, 'heading', $index)) { |
|
next; |
|
} |
|
my $data=$cache->{$name.':'.$studentInformation->[$index]}; |
$Str .= $data; |
$Str .= $data; |
|
|
my @dataLength=split(//,$data); |
my @dataLength=split(//,$data); |
my $length=scalar @dataLength; |
my $length=scalar @dataLength; |
$Str .= (' 'x($cache->{$_.'Length'}-$length)); |
$Str .= (' 'x($cache->{$studentInformation->[$index].'Length'}- |
|
$length)); |
$Str .= $spacePadding; |
$Str .= $spacePadding; |
} |
} |
|
|
Line 76 sub FormatStudentInformation {
|
Line 80 sub FormatStudentInformation {
|
} |
} |
|
|
sub FormatStudentData { |
sub FormatStudentData { |
my ($name,$coid,$studentInformation,$spacePadding,$ChartDB)=@_; |
my ($reselected,$name,$coid,$studentInformation,$spacePadding,$ChartDB)=@_; |
my ($sname,$sdom) = split(/\:/,$name); |
my ($sname,$sdom) = split(/\:/,$name); |
my $Str; |
my $Str; |
my %CacheData; |
my %CacheData; |
Line 87 sub FormatStudentData {
|
Line 91 sub FormatStudentData {
|
# Handle Student information ------------------------------------------ |
# Handle Student information ------------------------------------------ |
# Handle user data |
# Handle user data |
$Str=&FormatStudentInformation(\%CacheData, $name, $studentInformation, |
$Str=&FormatStudentInformation(\%CacheData, $name, $studentInformation, |
$spacePadding); |
$reselected, $spacePadding); |
|
|
# Handle errors |
# Handle errors |
if($CacheData{$name.':error'} =~ /environment/) { |
if($CacheData{$name.':error'} =~ /environment/) { |
Line 116 sub FormatStudentData {
|
Line 120 sub FormatStudentData {
|
my $problemsSolved = 0; |
my $problemsSolved = 0; |
my $numberOfParts = 0; |
my $numberOfParts = 0; |
foreach my $sequence (split(/\:/,$CacheData{'orderedSequences'})) { |
foreach my $sequence (split(/\:/,$CacheData{'orderedSequences'})) { |
|
if(!&ShouldShowColumn($reselected, 'sequence', $sequence)) { |
|
next; |
|
} |
|
|
my $characterCount=0; |
my $characterCount=0; |
foreach my $problemID (split(/\:/,$CacheData{$sequence.':problems'})) { |
foreach my $problemID (split(/\:/,$CacheData{$sequence.':problems'})) { |
my $problem = $CacheData{$problemID.':problem'}; |
my $problem = $CacheData{$problemID.':problem'}; |
Line 215 sub FormatStudentData {
|
Line 223 sub FormatStudentData {
|
} |
} |
|
|
sub CreateTableHeadings { |
sub CreateTableHeadings { |
my ($CacheData,$studentInformation,$headings,$spacePadding)=@_; |
my ($CacheData,$studentInformation,$headings,$reselected,$spacePadding)=@_; |
my $Str='<pre>'; |
my $Str='<pre>'; |
|
|
for(my $index=0; $index<(scalar @$headings); $index++) { |
for(my $index=0; $index<(scalar @$headings); $index++) { |
|
if(!&ShouldShowColumn($reselected, 'heading', $index)) { |
|
next; |
|
} |
|
|
my $data=$$headings[$index]; |
my $data=$$headings[$index]; |
$Str .= $data; |
$Str .= $data; |
|
|
Line 230 sub CreateTableHeadings {
|
Line 242 sub CreateTableHeadings {
|
} |
} |
|
|
foreach my $sequence (split(/\:/,$CacheData->{'orderedSequences'})) { |
foreach my $sequence (split(/\:/,$CacheData->{'orderedSequences'})) { |
$Str .= $CacheData->{$sequence.':title'}; |
if(!&ShouldShowColumn($reselected, 'sequence', $sequence)) { |
|
next; |
|
} |
|
|
|
my $name = $CacheData->{$sequence.':title'}; |
|
$Str .= $name; |
my @titleLength=split(//,$CacheData->{$sequence.':title'}); |
my @titleLength=split(//,$CacheData->{$sequence.':title'}); |
my $leftover=$CacheData->{$sequence.':columnWidth'}- |
my $leftover=$CacheData->{$sequence.':columnWidth'}- |
(scalar @titleLength); |
(scalar @titleLength); |
Line 244 sub CreateTableHeadings {
|
Line 261 sub CreateTableHeadings {
|
return $Str; |
return $Str; |
} |
} |
|
|
sub CreateColumnSelectors { |
sub CreateColumnSelectionBox { |
my ($CacheData,$studentInformation,$headings,$spacePadding)=@_; |
my ($CacheData,$studentInformation,$headings,$reselected,$spacePadding)=@_; |
my $Str=''; |
|
|
|
$Str .= '<form name="stat" method="post" action="/adm/chart" >'."\n"; |
my $missing=0; |
$Str .= '<input type="submit" name="sort" value="Refresh Chart"/>'; |
my $notThere='<br><br><b>Select column to view:</b><br><br>'; |
$Str .= '</form>'."\n"; |
my $name; |
return $Str; |
$notThere .= '  '; |
|
$notThere .= '<select name="reselect" size="4" multiple="true">'."\n"; |
|
|
for(my $index=0; $index<(scalar @$headings); $index++) { |
for(my $index=0; $index<(scalar @$headings); $index++) { |
my $data=$$headings[$index]; |
if(&ShouldShowColumn($reselected, 'heading', $index)) { |
$Str .= $data; |
next; |
|
} |
|
$name = $headings->[$index]; |
|
$notThere .= '<option value="heading'.$index.'">'; |
|
$notThere .= $name.'</option>'."\n"; |
|
$missing++; |
|
} |
|
|
my @dataLength=split(//,$data); |
foreach my $sequence (split(/\:/,$CacheData->{'orderedSequences'})) { |
my $length=scalar @dataLength; |
if(&ShouldShowColumn($reselected, 'sequence', $sequence)) { |
$Str .= (' 'x($CacheData->{$$studentInformation[$index].'Length'}- |
next; |
$length)); |
} |
$Str .= $spacePadding; |
$name = $CacheData->{$sequence.':title'}; |
|
$notThere .= '<option value="sequence'.$sequence.'">'; |
|
$notThere .= $name.'</option>'."\n"; |
|
$missing++; |
|
} |
|
|
|
if($missing) { |
|
$notThere .= '</select><br><br>'; |
|
} else { |
|
$notThere=''; |
|
} |
|
|
|
return $notThere; |
|
} |
|
|
|
sub CreateColumnSelectors { |
|
my ($CacheData,$studentInformation,$headings,$reselected,$spacePadding)=@_; |
|
|
|
my $found=0; |
|
my ($name, $length, $position); |
|
my $present='<pre>'; |
|
for(my $index=0; $index<(scalar @$headings); $index++) { |
|
if(!&ShouldShowColumn($reselected, 'heading', $index)) { |
|
next; |
|
} |
|
$name = $headings->[$index]; |
|
$length=$CacheData->{$$studentInformation[$index].'Length'}; |
|
$position=int($length/2); |
|
$present .= (' 'x($position)); |
|
$present .= '<input type="checkbox" checked="on" '; |
|
$present .= 'name="heading'.$index.'">'; |
|
$position+=2; |
|
$present .= (' 'x($length-$position)); |
|
$present .= $spacePadding; |
|
$found++; |
} |
} |
|
|
foreach my $sequence (split(/\:/,$CacheData->{'orderedSequences'})) { |
foreach my $sequence (split(/\:/,$CacheData->{'orderedSequences'})) { |
$Str .= $CacheData->{$sequence.':title'}; |
if(!&ShouldShowColumn($reselected, 'sequence', $sequence)) { |
my @titleLength=split(//,$CacheData->{$sequence.':title'}); |
next; |
my $leftover=$CacheData->{$sequence.':columnWidth'}- |
} |
(scalar @titleLength); |
$name = $CacheData->{$sequence.':title'}; |
$Str .= (' 'x$leftover); |
$length=$CacheData->{$sequence.':columnWidth'}; |
$Str .= $spacePadding; |
$position=int($length/2); |
|
$present .= (' 'x($position)); |
|
$present .= '<input type="checkbox" checked="on" '; |
|
$present .= 'name="sequence'.$sequence.'">'; |
|
$position+=2; |
|
$present .= (' 'x($length-$position)); |
|
$present .= $spacePadding; |
|
$found++; |
} |
} |
|
|
return $Str; |
if($found) { |
|
$present .= '</pre>'; |
|
$present = $present; |
|
} else { |
|
$present = ''; |
|
} |
|
|
|
return $present.'</form>'."\n";; |
} |
} |
|
|
sub CreateForm { |
sub CreateForm { |
Line 286 sub CreateForm {
|
Line 357 sub CreateForm {
|
else { $OpSel1 = 'selected'; } |
else { $OpSel1 = 'selected'; } |
|
|
my $Ptr = '<form name="stat" method="post" action="/adm/chart" >'."\n"; |
my $Ptr = '<form name="stat" method="post" action="/adm/chart" >'."\n"; |
|
$Ptr .= '<input type="submit" name="sort" value="Recalculate Chart"/>'; |
|
$Ptr .= "\n"; |
|
$Ptr .= ' '; |
|
$Ptr .= '<input type="submit" name="refresh" value="Refresh Chart"/>'; |
|
$Ptr .= "\n"; |
|
$Ptr .= '<br><br>'; |
$Ptr .= '<b> Sort by: </b>'."\n"; |
$Ptr .= '<b> Sort by: </b>'."\n"; |
$Ptr .= ' '; |
$Ptr .= ' '; |
$Ptr .= '<input type="submit" name="sort" value="User Name" />'."\n"; |
$Ptr .= '<input type="submit" name="sort" value="User Name" />'."\n"; |
Line 295 sub CreateForm {
|
Line 372 sub CreateForm {
|
$Ptr .= '<input type="submit" name="sort" value="Section"/>'."\n"; |
$Ptr .= '<input type="submit" name="sort" value="Section"/>'."\n"; |
$Ptr .= '<br><br>'; |
$Ptr .= '<br><br>'; |
$Ptr .= '<b> Student Status: </b>'."\n". |
$Ptr .= '<b> Student Status: </b>'."\n". |
|
' '. |
'<select name="status">'. |
'<select name="status">'. |
'<option '.$OpSel1.' >Active</option>'."\n". |
'<option '.$OpSel1.' >Active</option>'."\n". |
'<option '.$OpSel2.' >Expired</option>'."\n". |
'<option '.$OpSel2.' >Expired</option>'."\n". |
'<option '.$OpSel3.' >Any</option> </select> '."\n"; |
'<option '.$OpSel3.' >Any</option> </select> '."\n"; |
$Ptr .= '<br><br>'; |
|
$Ptr .= '<input type="submit" name="sort" value="Recalculate Chart"/>'; |
|
$Ptr .= "\n"; |
|
$Ptr .= ' '; |
|
$Ptr .= '<input type="submit" name="sort" value="Refresh Chart"/>'; |
|
$Ptr .= "\n"; |
|
$Ptr .= '</form>'."\n"; |
|
|
|
return $Ptr; |
return $Ptr; |
} |
} |
Line 867 sub ExtractStudentData {
|
Line 938 sub ExtractStudentData {
|
return; |
return; |
} |
} |
|
|
|
sub ShouldShowColumn { |
|
my ($reselected,$type,$value)=@_; |
|
|
|
if($ENV{'form.sort'} eq 'Recalculate Chart') { |
|
return 1; |
|
} |
|
|
|
if(defined($ENV{'form.'.$type.$value})) { |
|
return 1; |
|
} |
|
|
|
return &CheckForStringInArray($reselected, $type.$value); |
|
} |
|
|
|
sub CheckForStringInArray { |
|
my ($inputArray,$checkString)=@_; |
|
foreach (@$inputArray) { |
|
# $jr->print('a:'.$_.' b:'.$checkString.'<br>'); |
|
if($_ eq $checkString) { |
|
return 1; |
|
} |
|
} |
|
return 0; |
|
} |
|
|
# ----- END HELPER FUNCTIONS -------------------------------------------- |
# ----- END HELPER FUNCTIONS -------------------------------------------- |
|
|
sub BuildChart { |
sub BuildChart { |
Line 884 sub BuildChart {
|
Line 980 sub BuildChart {
|
my $cid=$ENV{'request.course.id'}; |
my $cid=$ENV{'request.course.id'}; |
my $ChartDB = "/home/httpd/perl/tmp/$ENV{'user.name'}". |
my $ChartDB = "/home/httpd/perl/tmp/$ENV{'user.name'}". |
"_$ENV{'user.domain'}_$cid\_chart.db"; |
"_$ENV{'user.domain'}_$cid\_chart.db"; |
|
# $ENV{'form.domains'} can be either a scalar or an array reference. |
|
# We need an array. |
|
my @reselected = (ref($ENV{'form.reselect'}) ? @{$ENV{'form.reselect'}} |
|
: ($ENV{'form.reselect'})); |
|
|
$isCached=&TestCacheData($ChartDB); |
$isCached=&TestCacheData($ChartDB); |
if($isCached < 0) { |
if($isCached < 0) { |
Line 928 sub BuildChart {
|
Line 1028 sub BuildChart {
|
if(tie(%CacheData,'GDBM_File',$ChartDB,&GDBM_READER,0640)) { |
if(tie(%CacheData,'GDBM_File',$ChartDB,&GDBM_READER,0640)) { |
if(!$c->aborted()) { @students=&SortStudents(\@students,\%CacheData); } |
if(!$c->aborted()) { @students=&SortStudents(\@students,\%CacheData); } |
if(!$c->aborted()) { $r->print(&CreateLegend()); } |
if(!$c->aborted()) { $r->print(&CreateLegend()); } |
|
if(!$c->aborted()) { $r->rflush(); } |
if(!$c->aborted()) { $r->print(&CreateForm()); } |
if(!$c->aborted()) { $r->print(&CreateForm()); } |
if(!$c->aborted()) { $r->print('<h3>'.(scalar @students). |
if(!$c->aborted()) { $r->print(&CreateColumnSelectionBox( |
|
\%CacheData, |
|
\@studentInformation, |
|
\@headings, |
|
\@reselected, |
|
$spacePadding)); } |
|
if(!$c->aborted()) { $r->print('<h3>'.(scalar @students). |
' students</h3>'); } |
' students</h3>'); } |
if(!$c->aborted()) { $r->rflush(); } |
if(!$c->aborted()) { $r->print(&CreateColumnSelectors( |
# if(!$c->aborted()) { $r->print(&CreateColumnSelectors( |
\%CacheData, |
# \%CacheData, |
\@studentInformation, |
# \@studentInformation, |
\@headings, |
# \@headings, |
\@reselected, |
# $spacePadding)); } |
$spacePadding)); } |
if(!$c->aborted()) { $r->print(&CreateTableHeadings( |
if(!$c->aborted()) { $r->print(&CreateTableHeadings( |
\%CacheData, |
\%CacheData, |
\@studentInformation, |
\@studentInformation, |
\@headings, |
\@headings, |
|
\@reselected, |
$spacePadding)); } |
$spacePadding)); } |
|
if(!$c->aborted()) { $r->rflush(); } |
untie(%CacheData); |
untie(%CacheData); |
} else { |
} else { |
$r->print("Init2: Unable to tie hash to db file"); |
$r->print("Init2: Unable to tie hash to db file"); |
Line 968 sub BuildChart {
|
Line 1077 sub BuildChart {
|
push(@updateStudentList, $_); |
push(@updateStudentList, $_); |
&ExtractStudentData($courseData, $_, $ChartDB); |
&ExtractStudentData($courseData, $_, $ChartDB); |
} |
} |
$r->print(&FormatStudentData($_, $cid, \@studentInformation, |
$r->print(&FormatStudentData(\@reselected, $_, $cid, |
|
\@studentInformation, |
$spacePadding, $ChartDB)); |
$spacePadding, $ChartDB)); |
$r->rflush(); |
$r->rflush(); |
} |
} |