version 1.73, 2003/05/29 21:44:53
|
version 1.93, 2004/01/15 03:18:19
|
Line 48 Main handler for statistics and chart.
|
Line 48 Main handler for statistics and chart.
|
use Apache::loncoursedata; |
use Apache::loncoursedata; |
use Apache::lonhtmlcommon; |
use Apache::lonhtmlcommon; |
use Apache::lonproblemanalysis; |
use Apache::lonproblemanalysis; |
|
use Apache::lonsubmissiontimeanalysis; |
use Apache::lonproblemstatistics; |
use Apache::lonproblemstatistics; |
use Apache::lonstudentassessment; |
use Apache::lonstudentassessment; |
use Apache::lonpercentage; |
use Apache::lonpercentage; |
Line 79 use Apache::loncommon;
|
Line 80 use Apache::loncommon;
|
use Apache::loncoursedata; |
use Apache::loncoursedata; |
use Apache::lonhtmlcommon; |
use Apache::lonhtmlcommon; |
use Apache::lonproblemanalysis(); |
use Apache::lonproblemanalysis(); |
|
use Apache::lonsubmissiontimeanalysis(); |
use Apache::lonproblemstatistics(); |
use Apache::lonproblemstatistics(); |
use Apache::lonstudentassessment(); |
use Apache::lonstudentassessment(); |
use Apache::lonpercentage; |
use Apache::lonpercentage; |
use Apache::lonmysql; |
use Apache::lonmysql; |
|
use Apache::lonlocal; |
use Time::HiRes; |
use Time::HiRes; |
|
|
####################################################### |
####################################################### |
Line 519 sub PrepareCourseData {
|
Line 522 sub PrepareCourseData {
|
my $name_length = length($seq->{'title'}); |
my $name_length = length($seq->{'title'}); |
my $num_parts = $seq->{'num_assess_parts'}; |
my $num_parts = $seq->{'num_assess_parts'}; |
# |
# |
# The number of columns needed for the summation text: |
# Use 3 digits for each the sum and total, which means 7 total... |
# " 1/5" = 1+3 columns, " 10/99" = 1+5 columns |
my $num_col = $num_parts+7; |
my $sum_length = 1+1+2*(length($num_parts)); |
|
my $num_col = $num_parts+$sum_length; |
|
if ($num_col < $name_length) { |
if ($num_col < $name_length) { |
$num_col = $name_length; |
$num_col = $name_length; |
} |
} |
Line 799 sub SectionSelect {
|
Line 800 sub SectionSelect {
|
return $Str; |
return $Str; |
} |
} |
|
|
|
####################################################### |
|
####################################################### |
|
|
|
=pod |
|
|
|
=item &CreateAndParseOutputSelector() |
|
|
|
Construct a selection list of options for output and parse output selections. |
|
|
|
=cut |
|
|
|
####################################################### |
|
####################################################### |
|
sub OutputDescriptions { |
|
my (@OutputOptions) = @_; |
|
my $Str = ''; |
|
$Str .= "<h2>Output Modes</h2>\n"; |
|
$Str .= "<dl>\n"; |
|
foreach my $outputmode (@OutputOptions) { |
|
$Str .=" <dt>".$outputmode->{'name'}."</dt>\n"; |
|
$Str .=" <dd>".$outputmode->{'description'}."</dd>\n"; |
|
} |
|
$Str .= "</dl>\n"; |
|
return $Str; |
|
} |
|
|
|
sub CreateAndParseOutputSelector { |
|
my ($elementname,$default,@OutputOptions) = @_; |
|
my $output_mode; |
|
my $show; |
|
my $Str = ''; |
|
# |
|
# Format for output options is 'mode, restrictions'; |
|
my $selected = $default; |
|
if (exists($ENV{'form.'.$elementname})) { |
|
if (ref($ENV{'form.'.$elementname} eq 'ARRAY')) { |
|
$selected = $ENV{'form.'.$elementname}->[0]; |
|
} else { |
|
$selected = $ENV{'form.'.$elementname}; |
|
} |
|
} |
|
# |
|
# Set package variables describing output mode |
|
$output_mode = 'html'; |
|
$show = 'all'; |
|
foreach my $option (@OutputOptions) { |
|
next if ($option->{'value'} ne $selected); |
|
$output_mode = $option->{'mode'}; |
|
$show = $option->{'show'}; |
|
} |
|
# |
|
# Build the form element |
|
$Str = qq/<select size="5" name="$elementname">/; |
|
foreach my $option (@OutputOptions) { |
|
if (exists($option->{'special'}) && |
|
$option->{'special'} =~ /do not show/) { |
|
next; |
|
} |
|
$Str .= "\n".' <option value="'.$option->{'value'}.'"'; |
|
$Str .= " selected " if ($option->{'value'} eq $selected); |
|
$Str .= ">".&mt($option->{'name'})."<\/option>"; |
|
} |
|
$Str .= "\n</select>"; |
|
return ($Str,$output_mode,$show); |
|
} |
|
|
|
############################################### |
|
############################################### |
|
|
|
=pod |
|
|
|
=item &Gather_Student_Data() |
|
|
|
Ensures all student data is up to date. |
|
|
|
=cut |
|
|
|
############################################### |
|
############################################### |
|
sub Gather_Student_Data { |
|
my ($r) = @_; |
|
my $c = $r->connection(); |
|
# |
|
&Apache::loncoursedata::clear_internal_caches(); |
|
# |
|
my @Sequences = &Apache::lonstatistics::Sequences_with_Assess(); |
|
# |
|
my @Students = @Apache::lonstatistics::Students; |
|
# |
|
# Open the progress window |
|
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin |
|
($r,'Statistics Compilation Status', |
|
'Statistics Compilation Progress', scalar(@Students)); |
|
# |
|
while (my $student = shift @Students) { |
|
return if ($c->aborted()); |
|
my ($status,undef) = &Apache::loncoursedata::ensure_current_data |
|
($student->{'username'},$student->{'domain'}, |
|
$ENV{'request.course.id'}); |
|
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
|
&mt('last student')); |
|
} |
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
|
$r->rflush(); |
|
} |
|
|
|
############################################### |
|
############################################### |
|
|
|
=pod |
|
|
|
=item &Gather_Full_Student_Data() |
|
|
|
Ensures all student data is up to date. |
|
|
|
=cut |
|
|
|
############################################### |
|
############################################### |
|
sub Gather_Full_Student_Data { |
|
my ($r) = @_; |
|
my $c = $r->connection(); |
|
# |
|
&Apache::loncoursedata::clear_internal_caches(); |
|
# |
|
my @Students = @Apache::lonstatistics::Students; |
|
# |
|
# Open the progress window |
|
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin |
|
($r,&mt('Student Data Compilation Status'), |
|
&mt('Student Data Compilation Progress'), scalar(@Students)); |
|
# |
|
while (my $student = shift @Students) { |
|
return if ($c->aborted()); |
|
my ($status,undef) = &Apache::loncoursedata::ensure_current_full_data |
|
($student->{'username'},$student->{'domain'}, |
|
$ENV{'request.course.id'}); |
|
&Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state, |
|
&mt('last student')); |
|
} |
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
|
$r->rflush(); |
|
} |
|
|
################################################## |
################################################## |
################################################## |
################################################## |
sub DisplayClasslist { |
sub DisplayClasslist { |
Line 807 sub DisplayClasslist {
|
Line 952 sub DisplayClasslist {
|
my @Fields = ('fullname','username','domain','id','section'); |
my @Fields = ('fullname','username','domain','id','section'); |
# |
# |
my $Str=''; |
my $Str=''; |
|
if (! @Students) { |
|
if ($SelectedSections[0] eq 'all') { |
|
if (lc($ENV{'form.Status'}) eq 'any') { |
|
$Str .= '<h2>There are no students in the course.</h2>'; |
|
} elsif (lc($ENV{'form.Status'}) eq 'active') { |
|
$Str .= '<h2>There are no currently enrolled students in '. |
|
'the course.</h2>'; |
|
} elsif (lc($ENV{'form.Status'}) eq 'expired') { |
|
$Str .= '<h2>There are no previously enrolled '. |
|
'students in the course.</h2>'; |
|
} |
|
} else { |
|
my $sections; |
|
if (@SelectedSections == 1) { |
|
$sections = 'section '.$SelectedSections[0]; |
|
} elsif (@SelectedSections > 2) { |
|
$sections = 'sections '.join(', ',@SelectedSections); |
|
$sections =~ s/, ([^,])*$/, and $1/; |
|
} else { |
|
$sections = 'sections '.join(' and ',@SelectedSections); |
|
} |
|
if (lc($ENV{'form.Status'}) eq 'any') { |
|
$Str .= '<h2>There are no students in '.$sections.'.</h2>'; |
|
} elsif (lc($ENV{'form.Status'}) eq 'active') { |
|
$Str .= '<h2>There are no currently enrolled students '. |
|
'in '.$sections.'.</h2>'; |
|
} elsif (lc($ENV{'form.Status'}) eq 'expired') { |
|
$Str .= '<h2>There are no previously enrolled students '. |
|
'in '.$sections.'.</h2>'; |
|
} |
|
} |
|
$Str.= '<a href="/adm/statistics?reportSelected=student_assessment">'. |
|
'Return to the chart.</a>'; |
|
$r->print($Str); |
|
$r->rflush(); |
|
return; |
|
} |
|
|
|
# "Click" is asinine but it is probably not my place to change the world. |
|
$Str .= '<h2>Click on a students name or username to view their chart</h2>'; |
$Str .= '<table border="0"><tr><td bgcolor="#777777">'."\n"; |
$Str .= '<table border="0"><tr><td bgcolor="#777777">'."\n"; |
$Str .= '<table border="0" cellpadding="3"><tr bgcolor="#e6ffff">'."\n"; |
$Str .= '<table border="0" cellpadding="3"><tr bgcolor="#e6ffff">'."\n"; |
foreach my $field (@Fields) { |
foreach my $field (@Fields) { |
Line 827 sub DisplayClasslist {
|
Line 1012 sub DisplayClasslist {
|
# |
# |
foreach my $field (@Fields) { |
foreach my $field (@Fields) { |
$Str .= '<td>'; |
$Str .= '<td>'; |
if ($field eq 'fullname') { |
if ($field eq 'fullname' || $field eq 'username') { |
$Str .= '<a href="/adm/statistics?reportSelected='; |
$Str .= '<a href="/adm/statistics?reportSelected='; |
$Str .= &Apache::lonnet::escape('student_assessment'); |
$Str .= &Apache::lonnet::escape('student_assessment'); |
$Str .= '&sort='.&Apache::lonnet::escape($ENV{'form.sort'}); |
$Str .= '&sort='.&Apache::lonnet::escape($ENV{'form.sort'}); |
Line 853 sub DisplayClasslist {
|
Line 1038 sub DisplayClasslist {
|
############################################## |
############################################## |
############################################## |
############################################## |
sub CreateMainMenu { |
sub CreateMainMenu { |
my ($status,$reports,$current)=@_; |
|
# |
# |
my $Str = ''; |
# Define menu data |
|
my @reports = ({ internal_name => 'problem_statistics', |
|
name => &mt('Overall Problem Statistics'), |
|
short_description => |
|
&mt('Student performance statistics on all problems.'), |
|
}, |
|
{ internal_name => 'problem_analysis', |
|
name => &mt('Detailed Problem Analysis'), |
|
short_description => |
|
&mt('Detailed statistics and graphs of student performance on problems.'), |
|
}, |
|
{ internal_name => 'submissiontime_analysis', |
|
name => &mt('Submission Time Analysis'), |
|
short_description => |
|
&mt('Display and analysis of submission times on assessments.'), |
|
}, |
|
# { internal_name => 'student_assessment', |
|
# name => &mt('Problem Status Chart'), |
|
# short_description => |
|
# &mt('Brief view of each students performance in course.'), |
|
# }, |
|
# 'percentage' => 'Correct-problems Plot', |
|
# 'activitylog' => 'Activity Log', |
|
); |
# |
# |
$Str .= '<table border="0"><tbody><tr>'."\n"; |
# Create the menu |
$Str .= '<td></td>'."\n"; |
my $Str; |
$Str .= '<td align="center"><b>Select a Report</b></td>'."\n"; |
$Str .= '<h1>'.&mt('Please select a report to generate').'</h1>'; |
$Str .= '<td></td>'."\n"; |
foreach my $reportdata (@reports) { |
$Str .= '<td></td>'."\n"; |
$Str .=' <h3><a href="/adm/statistics?reportSelected='. |
$Str .= '<tr>'."\n"; |
$reportdata->{'internal_name'}.'" >'. |
# |
$reportdata->{'name'}."</a></h3>\n"; |
$Str .= '<td align="center">'. |
$Str .= ' '.(' 'x8).$reportdata->{'short_description'}. |
'<input type="submit" name="Refresh" value="Update Display" />'. |
"\n"; |
"</td>\n"; |
} |
# |
$Str .="</dl>\n"; |
$Str .= '<td align="center">'; |
|
$Str .= '<select name="reportSelected" >'."\n"; |
|
foreach (sort(keys(%$reports))) { |
|
$Str .= '<option value="'.$_.'"'; |
|
if($current eq $_) { |
|
$Str .= ' selected'; |
|
} |
|
$Str .= '>'.$reports->{$_}.'</option>'."\n"; |
|
} |
|
$Str .= '</select></td>'."\n"; |
|
# |
|
$Str .= '<td>'.(' 'x30).'</td>'; |
|
$Str .= '<td align="center">'. |
|
'<input type="submit" name="ClearCache" value="Clear Caches" />'. |
|
"</td>\n"; |
|
$Str .= '</tr></tbody></table>'."\n"; |
|
$Str .= '<hr>'."\n"; |
|
# |
# |
return $Str; |
return $Str; |
} |
} |
Line 915 sub handler {
|
Line 1105 sub handler {
|
} |
} |
} |
} |
# |
# |
# Set document type for header only |
|
if($r->header_only) { |
|
if ($ENV{'browser.mathml'}) { |
|
$r->content_type('text/xml'); |
|
} else { |
|
$r->content_type('text/html'); |
|
} |
|
&Apache::loncommon::no_cache($r); |
|
$r->send_http_header; |
|
return OK; |
|
} |
|
# |
|
# Send the header |
# Send the header |
$r->content_type('text/html'); |
&Apache::loncommon::no_cache($r); |
|
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
|
if ($r->header_only) { return OK; } |
# |
# |
# Extract form elements from query string |
# Extract form elements from query string |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['sort','reportSelected', |
['sort','reportSelected', |
'SelectedStudent']); |
'SelectedStudent']); |
if (! exists($ENV{'form.reportSelected'})) { |
|
$ENV{'form.reportSelected'} = 'student_assessment'; |
|
} |
|
# |
# |
# Give the LON-CAPA page header |
# Give the LON-CAPA page header |
$r->print(&Apache::lonhtmlcommon::Title('Course Statistics and Charts')); |
$r->print(&Apache::lonhtmlcommon::Title('Course Statistics and Charts'). |
$r->rflush(); |
&Apache::loncommon::help_open_faq(139). |
# |
&Apache::loncommon::help_open_bug('Statistics and Charts')); |
if (! &Apache::lonmysql::verify_sql_connection()) { |
|
my $serveradmin = $r->dir_config('lonAdmEMail'); |
|
$r->print(<<END); |
|
<h2><font color="Red">Unable to connect to database!</font></h2> |
|
<p> |
|
Please notify the server administrator <b>$serveradmin</b>. |
|
</p><p> |
|
Course Statistics and Charts cannot be retrieved until the database is |
|
restarted. Your data is intact but cannot be displayed at this time. |
|
</p> |
|
</body> |
|
</html> |
|
END |
|
return; |
|
} |
|
# |
|
# Clean out the caches |
|
if (exists($ENV{'form.ClearCache'})) { |
|
&Apache::loncoursedata::delete_caches($ENV{'requres.course.id'}); |
|
} |
|
# |
|
# Set up the statistics and chart environment |
|
&PrepareClasslist(); |
|
&PrepareCourseData($r); |
|
# |
|
# Begin form output |
|
$r->print('<form name="Statistics" '); |
|
$r->print('method="post" action="/adm/statistics">'); |
|
# |
|
# Print main menu |
|
my %reports = ('classlist' => 'Class list', |
|
'problem_statistics' => 'Problem Statistics', |
|
'student_assessment' => 'Problem Status Chart', |
|
'percentage' => 'Correct-problems Plot', |
|
'option_response' => 'Option Response Analysis', |
|
# 'activitylog' => 'Activity Log', |
|
); |
|
$r->print(&CreateMainMenu($ENV{'form.status'}, |
|
\%reports,$ENV{'form.reportSelected'})); |
|
$r->rflush(); |
$r->rflush(); |
|
# |
|
# Either print out a menu for them or send them to a report |
|
if (! exists($ENV{'form.reportSelected'}) || |
|
$ENV{'form.reportSelected'} eq '') { |
|
$r->print(&CreateMainMenu()); |
|
} else { |
# |
# |
my $GoToPage = $ENV{'form.reportSelected'}; |
if (! &Apache::lonmysql::verify_sql_connection()) { |
if($GoToPage eq 'activitylog') { |
my $serveradmin = $r->dir_config('lonAdmEMail'); |
|
$r->print('<h2><font color="Red">'. |
|
&mt('Unable to connect to database!'). |
|
'</font></h2>'); |
|
$r->print('<p>'. |
|
&mt('Please notify the server administrator '). |
|
'<b>'.$serveradmin.'</b></p>'); |
|
$r->print('<p>'. |
|
&mt('Course Statistics and Charts cannot be '. |
|
'retrieved until the database is restarted. '. |
|
'Your data is intact but cannot be displayed '. |
|
'at this time.').'</p>'); |
|
$r->print('</body></html>'); |
|
return; |
|
} |
|
# |
|
# Clean out the caches |
|
if (exists($ENV{'form.ClearCache'})) { |
|
&Apache::loncoursedata::delete_caches($ENV{'requres.course.id'}); |
|
} |
|
# |
|
# Begin form output |
|
$r->print('<form name="Statistics" '); |
|
$r->print('method="post" action="/adm/statistics">'); |
|
$r->rflush(); |
|
# |
|
my $GoToPage = $ENV{'form.reportSelected'}; |
|
# |
|
# Set up the statistics and chart environment |
|
&PrepareCourseData($r); |
|
# |
|
$r->print('<input type="hidden" name="reportSelected" value="'. |
|
$GoToPage.'">'); |
|
if($GoToPage eq 'activitylog') { |
# &Apache::lonproblemstatistics::Activity(); |
# &Apache::lonproblemstatistics::Activity(); |
} elsif($GoToPage eq 'problem_statistics') { |
} elsif($GoToPage eq 'problem_statistics') { |
&Apache::lonproblemstatistics::BuildProblemStatisticsPage($r,$c); |
&Apache::lonproblemstatistics::BuildProblemStatisticsPage($r,$c); |
} elsif($GoToPage eq 'option_response') { |
} elsif($GoToPage eq 'problem_analysis') { |
# &Apache::lonproblemanalysis::BuildProblemAnalysisPage($r,$c); |
&Apache::lonproblemanalysis::BuildProblemAnalysisPage($r,$c); |
} elsif($GoToPage eq 'student_assessment') { |
} elsif($GoToPage eq 'submissiontime_analysis') { |
&Apache::lonstudentassessment::BuildStudentAssessmentPage($r,$c); |
&Apache::lonsubmissiontimeanalysis::BuildSubmissionTimePage($r,$c); |
} elsif($GoToPage eq 'DoDiffGraph' || $GoToPage eq 'PercentWrongGraph') { |
} elsif($GoToPage eq 'student_assessment') { |
|
&Apache::lonstudentassessment::BuildStudentAssessmentPage($r,$c); |
|
} elsif($GoToPage eq 'DoDiffGraph' || $GoToPage eq 'PercentWrongGraph') { |
# &Apache::lonproblemstatistics::BuildGraphicChart($r,$c); |
# &Apache::lonproblemstatistics::BuildGraphicChart($r,$c); |
} elsif($GoToPage eq 'classlist') { |
} elsif($GoToPage eq 'Correct-problems Plot') { |
&DisplayClasslist($r); |
# &Apache::lonpercentage::BuildPercentageGraph($r,$c); |
} elsif($GoToPage eq 'Correct-problems Plot') { |
} |
# &Apache::lonpercentage::BuildPercentageGraph($r,$c); |
# |
|
$r->print("</form>\n"); |
} |
} |
# |
|
$r->print("</form>\n"); |
|
$r->print("</body>\n</html>\n"); |
$r->print("</body>\n</html>\n"); |
$r->rflush(); |
$r->rflush(); |
# |
# |