--- loncom/interface/statistics/lonproblemanalysis.pm 2004/01/19 20:10:36 1.59 +++ loncom/interface/statistics/lonproblemanalysis.pm 2004/01/20 15:51:06 1.61 @@ -1,6 +1,6 @@ # The LearningOnline Network with CAPA # -# $Id: lonproblemanalysis.pm,v 1.59 2004/01/19 20:10:36 matthew Exp $ +# $Id: lonproblemanalysis.pm,v 1.61 2004/01/20 15:51:06 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,6 +33,7 @@ use Apache::lonhtmlcommon(); use Apache::loncoursedata(); use Apache::lonstatistics; use Apache::lonlocal; +use Apache::lonstathelpers; use HTML::Entities(); use Time::Local(); use Spreadsheet::WriteExcel(); @@ -58,22 +59,6 @@ my @SubmitButtons = ({ name => 'PrevProb { name => 'ExcelOutput', text => 'Produce Excel Output' }); -sub render_resource { - my ($resource) = @_; - ## - ## Render the problem - my $base; - ($base,undef) = ($resource->{'src'} =~ m|(.*/)[^/]*$|); - $base = "http://".$ENV{'SERVER_NAME'}.$base; - my $rendered_problem = - &Apache::lonnet::ssi_body($resource->{'src'}); - $rendered_problem =~ s/<\s*form\s*/)|<\/nop>|g; - return '
'. - ''. - $rendered_problem. - '
'; -} sub BuildProblemAnalysisPage { my ($r,$c)=@_; @@ -130,9 +115,14 @@ sub BuildProblemAnalysisPage { $r->rflush(); # # Determine which problem we are to analyze - my $current_problem = &get_target_from_id($ENV{'form.problemchoice'}); + my $current_problem = &Apache::lonstathelpers::get_target_from_id + ($ENV{'form.problemchoice'}); # - my ($prev,$curr,$next) = &get_prev_curr_next($current_problem); + my ($prev,$curr,$next) = + &Apache::lonstathelpers::get_prev_curr_next($current_problem, + '(option|radiobutton)', + 'response', + ); if (exists($ENV{'form.PrevProblemAnalysis'}) && defined($prev)) { $current_problem = $prev; } elsif (exists($ENV{'form.NextProblemAnalysis'}) && defined($next)) { @@ -142,7 +132,8 @@ sub BuildProblemAnalysisPage { } # # Store the current problem choice and send it out in the form - $ENV{'form.problemchoice'} = &make_target_id($current_problem); + $ENV{'form.problemchoice'} = + &Apache::lonstathelpers::make_target_id($current_problem); $r->print(''); # @@ -152,7 +143,7 @@ sub BuildProblemAnalysisPage { my $resource = $current_problem->{'resource'}; $r->print('

'.$resource->{'title'}.'

'); $r->print('

'.$resource->{'src'}.'

'); - $r->print(&render_resource($resource)); + $r->print(&Apache::lonstathelpers::render_resource($resource)); $r->rflush(); my %Data = &get_problem_data($resource->{'src'}); my $ProblemData = $Data{$current_problem->{'part'}. @@ -176,7 +167,8 @@ sub BuildProblemAnalysisPage { &mt('Analyze Problem').'" />'); $r->print(' 'x5); $r->print('

'.&mt('Please select a problem to analyze').'

'); - $r->print(&ProblemSelector()); + $r->print(&Apache::lonstathelpers::ProblemSelector + ('(option|radiobutton)')); } } @@ -1492,180 +1484,6 @@ sub CreateInterface { return $Str; } -sub ProblemSelector { - my $Str; - $Str = "\n\n"; - foreach my $seq (&Apache::lonstatistics::Sequences_with_Assess()) { - next if ($seq->{'num_assess'}<1); - my $seq_str = ''; - foreach my $res (@{$seq->{'contents'}}) { - next if ($res->{'type'} ne 'assessment'); - foreach my $part (@{$res->{'parts'}}) { - my $partdata = $res->{'partdata'}->{$part}; -# &Apache::lonnet::logthis('----------------'); -# while (my ($k,$v)=each(%$partdata)) { -# if (ref($v) eq 'ARRAY') { -# &Apache::lonnet::logthis($k.' = '.join(',',@$v)); -# } else { -# &Apache::lonnet::logthis($k.' = '.$v); -# } -# } - if ((! exists($partdata->{'option'}) || - $partdata->{'option'} == 0 ) && - (! exists($partdata->{'radiobutton'}) || - $partdata->{'radiobutton'} == 0)) { - next; - } - for (my $i=0;$i{'ResponseTypes'}});$i++){ - my $respid = $partdata->{'ResponseIds'}->[$i]; - my $resptype = $partdata->{'ResponseTypes'}->[$i]; -# if ($resptype eq 'option' ){ - if ($resptype eq 'option' || $resptype eq 'radiobutton') { - my $value = &make_target_id({symb=>$res->{'symb'}, - part=>$part, - respid=>$respid, - resptype=>$resptype}); - my $checked = ''; - if ($ENV{'form.problemchoice'} eq $value) { - $checked = 'checked '; - } - my $title = $res->{'title'}; - if (! defined($title) || $title eq '') { - ($title) = ($res->{'src'} =~ m:/([^/]*)$:); - } - $seq_str .= '\n"; - } - } - } - } - if ($seq_str ne '') { - $Str .= ''. - "\n".$seq_str; - } - } - $Str .= "
'. - ''. - ''. - $resptype.''. - ''.$title.' '; -# ''.$resptype.' '.$res->{'title'}.' '; - if ($partdata->{'option'} > 1) { - $seq_str .= &mt('response').' '.$respid; - } - $seq_str .= "
 '.$seq->{'title'}.'
\n"; - return $Str; -} - -######################################################### -######################################################### -## -## Misc functions -## -######################################################### -######################################################### -sub get_problem_symb { - my $problemstring = shift(); - my ($symb,$partid,$respid,$resptype) = split(':',$problemstring); - return ({ symb => $symb, - part => $partid, - respid => $respid, - type => $resptype } ); -} - -sub get_resource_from_symb { - my ($symb) = @_; - foreach my $seq (&Apache::lonstatistics::Sequences_with_Assess()) { - foreach my $res (@{$seq->{'contents'}}) { - if ($res->{'symb'} eq $symb) { - return $res; - } - } - } - return undef; -} - -sub get_prev_curr_next { - my ($target) = @_; - # - # Build an array with the data we need to search through - my @Resource; - foreach my $seq (&Apache::lonstatistics::Sequences_with_Assess()) { - foreach my $res (@{$seq->{'contents'}}) { - next if ($res->{'type'} ne 'assessment'); - foreach my $part (@{$res->{'parts'}}) { - my $partdata = $res->{'partdata'}->{$part}; - for (my $i=0;$i{'ResponseTypes'}});$i++){ - my $respid = $partdata->{'ResponseIds'}->[$i]; - my $resptype = $partdata->{'ResponseTypes'}->[$i]; - next if ($resptype ne 'option' && - $resptype ne 'radiobutton'); - push (@Resource, - { symb => $res->{symb}, - part => $part, - respid => $partdata->{'ResponseIds'}->[$i], - resource => $res, - resptype => $resptype - } ); - } - } - } - } - # - # - # Get the index of the current situation - my $curr_idx; - for ($curr_idx=0;$curr_idx<$#Resource;$curr_idx++) { - my $curr_item = $Resource[$curr_idx]; - last if ($curr_item->{'symb'} eq $target->{'symb'} && - $curr_item->{'part'} eq $target->{'part'} && - $curr_item->{'respid'} eq $target->{'respid'} && - $curr_item->{'resptype'} eq $target->{'resptype'}); - } - my $curr_item = $Resource[$curr_idx]; - if ($curr_item->{'symb'} ne $target->{'symb'} || - $curr_item->{'part'} ne $target->{'part'} || - $curr_item->{'respid'} ne $target->{'respid'} || - $curr_item->{'resptype'} ne $target->{'resptype'}){ - # bogus symb - return nothing - return (undef,undef,undef); - } - # - # Now just pick up the data we need - my ($prev,$curr,$next); - if ($curr_idx == 0) { - $prev = undef; - $curr = $Resource[$curr_idx ]; - $next = $Resource[$curr_idx+1]; - } elsif ($curr_idx == $#Resource) { - $prev = $Resource[$curr_idx-1]; - $curr = $Resource[$curr_idx ]; - $next = undef; - } else { - $prev = $Resource[$curr_idx-1]; - $curr = $Resource[$curr_idx ]; - $next = $Resource[$curr_idx+1]; - } - return ($prev,$curr,$next); -} - -sub make_target_id { - my ($target) = @_; - my $id = &Apache::lonnet::escape($target->{'symb'}).':'. - &Apache::lonnet::escape($target->{'part'}).':'. - &Apache::lonnet::escape($target->{'respid'}).':'. - &Apache::lonnet::escape($target->{'resptype'}); - return $id; -} - -sub get_target_from_id { - my ($id) = @_; - my ($symb,$part,$respid,$resptype) = split(':',$id); - return ({ symb =>&Apache::lonnet::unescape($symb), - part =>&Apache::lonnet::unescape($part), - respid =>&Apache::lonnet::unescape($respid), - resptype =>&Apache::lonnet::unescape($resptype)}); -} - ######################################################### ######################################################### ##