--- loncom/interface/statistics/lonproblemstatistics.pm 2004/03/26 22:04:22 1.73 +++ loncom/interface/statistics/lonproblemstatistics.pm 2004/03/29 19:50:23 1.78 @@ -1,6 +1,6 @@ # The LearningOnline Network with CAPA # -# $Id: lonproblemstatistics.pm,v 1.73 2004/03/26 22:04:22 matthew Exp $ +# $Id: lonproblemstatistics.pm,v 1.78 2004/03/29 19:50:23 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -73,23 +73,34 @@ my @Fields = ( { name => 'problem_num', title => 'P#', align => 'right', - color => '#FFFFE6' }, + color => '#FFFFE6', + selectable => 'no', + selected => 'yes', + }, { name => 'container', title => 'Sequence or Folder', align => 'left', color => '#FFFFE6', - sortable => 'yes' }, + sortable => 'yes', + selectable => 'no', + selected => 'yes', + }, { name => 'title', title => 'Title', align => 'left', color => '#FFFFE6', special => 'link', - sortable => 'yes', }, + sortable => 'yes', + selectable => 'no', + selected => 'yes', + }, { name => 'part', title => 'Part', align => 'left', color => '#FFFFE6', - }, + selectable => 'no', + selected => 'yes', + }, { name => 'num_students', title => '#Stdnts', align => 'right', @@ -97,7 +108,10 @@ my @Fields = ( format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Number of Students Attempting Problem' }, + long_title => 'Number of Students Attempting Problem', + selectable => 'yes', + selected => 'yes', + }, { name => 'tries', title => 'Tries', align => 'right', @@ -105,7 +119,10 @@ my @Fields = ( format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Total Number of Tries' }, + long_title => 'Total Number of Tries', + selectable => 'yes', + selected => 'yes', + }, { name => 'max_tries', title => 'Max Tries', align => 'right', @@ -113,7 +130,10 @@ my @Fields = ( format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Maximum Number of Tries' }, + long_title => 'Maximum Number of Tries', + selectable => 'yes', + selected => 'yes', + }, { name => 'min_tries', title => 'Min Tries', align => 'right', @@ -121,7 +141,10 @@ my @Fields = ( format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Minumum Number of Tries' }, + long_title => 'Minumum Number of Tries', + selectable => 'yes', + selected => 'yes', + }, { name => 'mean_tries', title => 'Mean Tries', align => 'right', @@ -129,7 +152,10 @@ my @Fields = ( format => '%5.2f', sortable => 'yes', graphable => 'yes', - long_title => 'Average Number of Tries' }, + long_title => 'Average Number of Tries', + selectable => 'yes', + selected => 'yes', + }, { name => 'std_tries', title => 'S.D. tries', align => 'right', @@ -137,7 +163,10 @@ my @Fields = ( format => '%5.2f', sortable => 'yes', graphable => 'yes', - long_title => 'Standard Deviation of Number of Tries' }, + long_title => 'Standard Deviation of Number of Tries', + selectable => 'yes', + selected => 'yes', + }, { name => 'skew_tries', title => 'Skew Tries', align => 'right', @@ -145,7 +174,10 @@ my @Fields = ( format => '%5.2f', sortable => 'yes', graphable => 'yes', - long_title => 'Skew of Number of Tries' }, + long_title => 'Skew of Number of Tries', + selectable => 'yes', + selected => 'no', + }, { name => 'num_solved', title => '#YES', align => 'right', @@ -153,7 +185,10 @@ my @Fields = ( format => '%4.1f',# format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Number of Students able to Solve' }, + long_title => 'Number of Students able to Solve', + selectable => 'yes', + selected => 'yes', + }, { name => 'num_override', title => '#yes', align => 'right', @@ -161,7 +196,10 @@ my @Fields = ( format => '%4.1f',# format => '%d', sortable => 'yes', graphable => 'yes', - long_title => 'Number of Students given Override' }, + long_title => 'Number of Students given Override', + selectable => 'yes', + selected => 'yes', + }, { name => 'num_wrong', title => '#Wrng', align => 'right', @@ -169,7 +207,10 @@ my @Fields = ( format => '%4.1f', sortable => 'yes', graphable => 'yes', - long_title => 'Percent of students whose final answer is wrong' }, + long_title => 'Percent of students whose final answer is wrong', + selectable => 'yes', + selected => 'yes', + }, { name => 'deg_of_diff', title => 'DoDiff', align => 'right', @@ -178,7 +219,10 @@ my @Fields = ( sortable => 'yes', graphable => 'yes', long_title => 'Degree of Difficulty'. - '[ 1 - ((#YES+#yes) / Tries) ]'}, + '[ 1 - ((#YES+#yes) / Tries) ]', + selectable => 'yes', + selected => 'yes', + }, { name => 'deg_of_disc', title => 'DoDisc', align => 'right', @@ -186,9 +230,61 @@ my @Fields = ( format => '%4.2f', sortable => 'yes', graphable => 'yes', - long_title => 'Degree of Discrimination' }, + long_title => 'Degree of Discrimination', + selectable => 'yes', + selected => 'no', + }, ); +my %SelectedFields; + +sub parse_field_selection { + # + # Pull out the defaults + if (! defined($ENV{'form.fieldselections'})) { + $ENV{'form.fieldselections'} = []; + foreach my $field (@Fields) { + next if ($field->{'selectable'} ne 'yes'); + if ($field->{'selected'} eq 'yes') { + push(@{$ENV{'form.fieldselections'}},$field->{'name'}); + } + } + } + # + # This should not happen, but in case it does... + if (ref($ENV{'form.fieldselections'}) ne 'ARRAY') { + $ENV{'form.fieldselections'} = [$ENV{'form.fieldselections'}]; + } + # + # Set the field data and the selected fields (for easier checking) + undef(%SelectedFields); + foreach my $field (@Fields) { + next if ($field->{'selectable'} ne 'yes'); + $field->{'selected'} = 'no'; + foreach my $selection (@{$ENV{'form.fieldselections'}}) { + if ($selection eq $field->{'name'} || $selection eq 'all') { + $field->{'selected'} = 'yes'; + $SelectedFields{$field->{'name'}}++; + } + } + } + return; +} + +sub field_selection_input { + my $Str = '\n"; +} + ############################################### ############################################### @@ -204,6 +300,7 @@ select sections, maps, and output. ############################################### ############################################### sub CreateInterface { + &parse_field_selection(); my $Str = ''; $Str .= &Apache::lonhtmlcommon::breadcrumbs (undef,'Overall Problem Statistics','Statistics_Overall_Key'); @@ -212,6 +309,7 @@ sub CreateInterface { $Str .= ''.&mt('Sections').''; $Str .= ''.&mt('Enrollment Status').''; $Str .= ''.&mt('Sequences and Folders').''; + $Str .= ''.&mt('Statistics').''; $Str .= ''. &Apache::lonstathelpers::limit_by_time_form().''; $Str .= ''."\n"; @@ -232,6 +330,7 @@ sub CreateInterface { }; $Str .= &Apache::lonstatistics::MapSelect('Maps','multiple,all',5, $only_seq_with_assessments); + $Str .= ''.&field_selection_input(); $Str .= ''."\n"; $Str .= ''."\n"; $Str .= '". @@ -417,6 +532,7 @@ sub statistics_html_table_data { my $row = ''; foreach my $field (@Fields) { next if ($options =~ /no $field->{'name'}/); + next if ($field->{'selected'} ne 'yes'); $row .= '{'align'})) { $row .= ' align="'.$field->{'align'}.'"'; @@ -443,6 +559,7 @@ sub statistics_table_header { my $header_row; foreach my $field (@Fields) { next if ($options =~ /no $field->{'name'}/); + next if ($field->{'selected'} ne 'yes'); $header_row .= ''; if (exists($field->{'sortable'}) && $field->{'sortable'} eq 'yes') { $header_row .= ' + Mean and S.D. of Tries + + Problem Number + + $std_error_data + + + $std_data + + +END + my $plotresult = + '

'.&Apache::lonxml::xmlparse($r,'web',$plot).'

'.$/; + $r->print($plotresult); + return; +} + sub plot_dropdown { my $current = ''; # @@ -646,7 +844,10 @@ sub plot_dropdown { my @Additional_Plots = ( { graphable=>'yes', name => 'degrees', - title => 'DoDisc and DoDiff' }); + title => 'DoDisc and DoDiff' }, + { graphable=>'yes', + name => 'tries statistics', + title => 'Mean and S.D. of Tries' }); # my $Str= "\n".'