--- loncom/interface/lonprintout.pm 2009/09/08 10:53:15 1.560.2.3 +++ loncom/interface/lonprintout.pm 2009/09/22 14:28:50 1.561 @@ -1,17 +1,7 @@ -# -# Issues: -# - Need to get the state flow for selected problems/resources for students -# correct -# - Need to do the CODEd stuff. -# - Need to regularize and figure out for each case who puts on the latex -# front matter and make sure it gets done. -# -# - # The LearningOnline Network # Printout # -# $Id: lonprintout.pm,v 1.560.2.3 2009/09/08 10:53:15 foxr Exp $ +# $Id: lonprintout.pm,v 1.561 2009/09/22 14:28:50 bisitz Exp $ # # Copyright Michigan State University Board of Trustees # @@ -36,6 +26,7 @@ # # package Apache::lonprintout; + use strict; use Apache::Constants qw(:common :http); use Apache::lonxml; @@ -83,105 +74,6 @@ my $ssi_retry_count = 5; # Some arbitrar my $font_size = 'normalsize'; # Default is normalsize... -#---------------------------- Helper helpers. ------------------------- - -# Returns the text needd for a student chooser. -# that text must still be parsed by the helper xml parser. -# Parameters: -# this_state - State name of the chooser. -# sort_choice - variable to hold the sorting choice. -# variable - Name of variable to hold students. -# next_state - State after chooser. - - -sub generate_student_chooser { - my ($this_state, - $sort_choice, - $variable, - $next_state) = @_; - - my $result = < - Select sorting order of printout - - - Sort by section then student - Sort by students across sections. - - -


- - - -CHOOSE_STUDENTS - - return $result; -} - -# Generate the text needed for a resource chooser given the top level of -# the sequence/page -# -# Parameters: -# this_state - State name of the chooser. -# prompt_text - Text to use to prompt user. -# resource_options - Resource tag options e.g. -# "multichoice='1', toponly='1', addstatus='1'" -# that control the selection and appearance of the -# resource selector. -# variable - Name of the variable to hold the choice -# next_state - Name of the next state the helper should transition -# to -# top_url - Top level URL within which to make the selector. -# If empty the top level sequence is shown. -# filter - How to filter the resources. -# value_func - function. -# choice_func - If not empty generates a with this function. -# start_new_option -# - Fragment appended after valuefunc. -# -# -sub generate_resource_chooser { - my ($this_state, - $prompt_text, - $resource_options, - $variable, - $next_state, - $top_url, - $filter, - $choice_func, - $value_func, - $start_new_option) = @_; - - - my $result = < - - $next_state - return $filter; -CHOOSE_RESOURCES - if ($value_func ne '') { - $result .= "return $choice_func;"; - } - if ($top_url ne '') { - $result .= "$top_url"; - } - $result .= <return $value_func; - $start_new_option - - -CHOOSE_RESOURCES - - return $result; -} - - -#----------------------------------------------------------------------- - # Fetch the contents of a resource, uninterpreted. # This is used here to fetch a latex file to be included @@ -1194,9 +1086,9 @@ sub page_format_transformation { if ($selectionmade eq '4') { if ($choice eq 'all_problems') { - $assignment='Problems from the Whole Course'; + $assignment=&mt('Problems from the Whole Course'); } else { - $assignment='Resources from the Whole Course'; + $assignment=&mt('Resources from the Whole Course'); } } else { $assignment=&Apache::lonxml::latex_special_symbols($assignment,'header'); @@ -1451,7 +1343,7 @@ sub print_page_in_course { if ($mode ne '') {$mode='\\'.$mode} - my $result = &print_latex_header($mode); + my $result.= &print_latex_header($mode); if ($currentURL=~m|^(/adm/wrapper/)?ext/|) { $currentURL=~s|^(/adm/wrapper/)?ext/|http://|; my $title=&Apache::lonnet::gettitle($symb); @@ -1521,6 +1413,9 @@ sub print_page_in_course { my $texversion = &ssi_with_retries($urlp, $ssi_retry_count, %form); + # There seems to be an extraneous \vskip 1mm \\\\ : + + $texversion =~ s/^\\vskip 1mm \\\\\\\\//; # current document with answers.. no need to encap in minipage # since there's only one answer. @@ -1543,7 +1438,7 @@ sub print_page_in_course { if ($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'no') { $texversion=~s/(\\keephidden{ENDOFPROBLEM})/$answer$1/; } else { - $texversion= &print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); + $texversion=&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); if ($helper->{'VARS'}->{'construction'} ne '1') { my $title = &Apache::lonnet::gettitle($helper->{'VARS'}->{'symb'}); $title = &Apache::lonxml::latex_special_symbols($title); @@ -1578,14 +1473,6 @@ sub print_page_in_course { $texversion=~s/(\\addcontentsline\{toc\}\{subsection\}\{[^\}]*\})/$1 URL: \\verb|$currentURL| \\strut\\\\\\strut /; } - $texversion = &latex_header_footer_remove($texversion); - - # the first remaining line is a comment from londefdef the second - # line seems to be an extraneous \vskip 1mm \\\\ : - # (imperfect removal from header_footer_remove? - - $texversion =~ s/\\vskip 1mm \\\\\\\\//; - $result .= $texversion; if ($currentURL=~m/\.page\s*$/) { ($result,$numberofcolumns) = &page_cleanup($result); @@ -1673,7 +1560,7 @@ sub recently_generated { # A reference to a page break hash. # # -use Data::Dumper; +#use Data::Dumper; #sub dump_helper_vars { # my ($helper) = @_; # my $helpervars = Dumper($helper->{'VARS'}); @@ -2075,8 +1962,6 @@ ENDPART $helper->{'VARS'}->{'symb'}); } } elsif (($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems') or - ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems_in_page') or - ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_resources_in_page') or ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems_pages') or ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'all_problems') or ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'all_resources') or # BUGBUG @@ -2085,13 +1970,9 @@ ENDPART #-- produce an output string - if (($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems') or - ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems_in_page') ) { + if ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems') { $selectionmade = 2; - } elsif (($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems_pages') or - ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_resources_in_page')) - { - &Apache::lonnet::logthis("Selectionmade => 3"); + } elsif ($helper->{'VARS'}->{'PRINT_TYPE'} eq 'map_problems_pages') { $selectionmade = 3; } elsif (($helper->{'VARS'}->{'PRINT_TYPE'} eq 'all_problems') ) { @@ -2131,11 +2012,11 @@ ENDPART $result.="\\newpage\n"; } } - my ($sequence,$middle_thingy,$urlp)=&Apache::lonnet::decode_symb($master_seq[$i]); + my ($sequence,$middle_thingy,$urlp)=&Apache::lonnet::decode_symb($master_seq[$i]); $urlp=&Apache::lonnet::clutter($urlp); $form{'symb'}=$master_seq[$i]; - &Apache::lonnet::logthis("Element $i Sequence $sequence Middle $middle_thingy URLP $urlp"); + my $assignment=&Apache::lonxml::latex_special_symbols(&Apache::lonnet::gettitle($sequence),'header'); #title of the assignment which contains this problem if ($selectionmade==7) {$helper->{VARS}->{'assignment'}=$assignment;} @@ -2143,17 +2024,11 @@ ENDPART my $texversion=''; if ($urlp!~m|^/adm/| && $urlp=~/\.(problem|exam|quiz|assess|survey|form|library|page|xml|html|htm|xhtml|xhtm)$/) { - &Apache::lonnet::logthis("Problem"); $resources_printed .= $urlp.':'; &Apache::lonxml::remember_problem_counter(); - &Apache::lonnet::logthis("Fetching tex for $urlp"); - my $debug = Dumper(%form); - &Apache::lonnet::logthis("Form: $debug"); - $texversion.=&ssi_with_retries($urlp, $ssi_retry_count, %form); - &Apache::lonnet::logthis("texversion so far: $texversion"); if ($urlp=~/\.page$/) { - &Apache::lonnet::("Special page actions"); + ($texversion,my $number_of_columns_page) = &page_cleanup($texversion); if ($number_of_columns_page > $number_of_columns) {$number_of_columns=$number_of_columns_page;} $texversion =~ s/\\end{document}\d*/\\end{document}/; @@ -2175,7 +2050,6 @@ ENDPART $texversion=~s/(\\keephidden{ENDOFPROBLEM})/$answer$1/; } else { if ($urlp=~/\.(problem|exam|quiz|assess|survey|form|library)$/) { - &Apache::lonnet::logthis("problem printing"); $texversion=&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); $texversion =~ s/\\begin{document}//; my $title = &Apache::lonnet::gettitle($master_seq[$i]); @@ -2221,7 +2095,6 @@ ENDPART } } $result .= $texversion; - &Apache::lonnet::logthis("About to set rem header true with $result"); $flag_latex_header_remove = 'YES'; } elsif ($urlp=~/\/(smppg|syllabus|aboutme|bulletinboard)$/) { $form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; @@ -3054,8 +2927,6 @@ sub printHelper { $subdir = substr($helper->{VARS}->{'filename'}, 0, rindex($helper->{VARS}->{'filename'}, '/') + 1); } else { - # From course space: - if ($symb ne '') { ($map, $id, $url) = &Apache::lonnet::decode_symb($symb); $helper->{VARS}->{'postdata'} = @@ -3063,9 +2934,9 @@ sub printHelper { } else { $url = $helper->{VARS}->{'postdata'}; $is_published=1; # From resource space. - &Apache::lonnet::logthis("Resource url $url"); } $url = &Apache::lonnet::clutter($url); + if (!$resourceTitle) { # if the resource doesn't have a title, use the filename my $postdata = $helper->{VARS}->{'postdata'}; $resourceTitle = substr($postdata, rindex($postdata, '/') + 1); @@ -3125,103 +2996,79 @@ sub printHelper { "' variable='FINISHPAGE' />"; } - # If not construction space user can print the components of a page: - - my $page_ispage; - my $page_title; - if (!$helper->{VARS}->{'construction'}) { - my $varspostdata = $helper->{VARS}->{'postdata'}; - my $varsassignment = $helper->{VARS}->{'assignment'}; - my $page_navmap = Apache::lonnavmaps::navmap->new(); - my @page_resources = $page_navmap->retrieveResources($url); - if(defined($page_resources[0])) { - $page_ispage = $page_resources[0]->is_page(); - $page_title = $page_resources[0]->title(); - my $resourcesymb = $page_resources[0]->symb(); - my ($pagemap, $pageid, $pageurl) = &Apache::lonnet::decode_symb($symb); - if ($page_ispage) { - push @{$printChoices}, - [&mt('Selected [_1]Problems[_2] from page [_3]', '', '', ''.$page_title.''), - 'map_problems_in_page', - 'CHOOSE_PROBLEMS_PAGE']; - push @{$printChoices}, - [&mt('Selected [_1]Resources[_2] from page [_3]', '', '', ''.$page_title.''), - 'map_resources_in_page', - 'CHOOSE_RESOURCES_PAGE']; - } - my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS_PAGE', - 'Select Problem(s) to print', - "multichoice='1' toponly='1', addstatus='1' closeallpages='1'", - 'RESOURCES', - 'PAGESIZE', - $url, - $isProblem, '', $symbFilter, - $start_new_option); - - - $helperFragment .= &generate_resource_chooser('CHOOSE_RESOURCES_PAGE', - 'Select Resource(s) to print', - 'multichoice="1" toponly="1" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'PAGESIZE', - $url, - $isNotMap, '', $symbFilter, - $start_new_option); - - - - - - &Apache::lonxml::xmlparse($r, 'helper', $helperFragment); - - } - } - - if (($helper->{'VAR'}->{'construction'} ne '1' ) && + if (($helper->{'VARS'}->{'construction'} ne '1' ) && $helper->{VARS}->{'postdata'} && $helper->{VARS}->{'assignment'}) { # Allow problems from sequence - push @{$printChoices}, - [&mt('Selected [_1]Problems[_2] from folder [_3]','','',''.$sequenceTitle.''), - 'map_problems', - 'CHOOSE_PROBLEMS']; + push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3]','','',''.$sequenceTitle.''), 'map_problems', 'CHOOSE_PROBLEMS']; # Allow all resources from sequence - push @{$printChoices}, [&mt('Selected [_1]Resources[_2] from folder [_3]','','',''.$sequenceTitle.''), - 'map_problems_pages', - 'CHOOSE_PROBLEMS_HTML']; - &Apache::lonnet::logthis("Map url : $map"); - my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS', - 'Select Problem(s) to print', - 'multichoice="1" toponly="1" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'PAGESIZE', - $map, - $isProblem, '', - $symbFilter, - $start_new_option); - $helperFragment .= &generate_resource_chooser('CHOOSE_PROBLEMS_HTML', - 'Select Resource(s) to print', - 'multichoice="1" toponly="1" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'PAGESIZE', - $map, - $isNotMap, '', - $symbFilter, - $start_new_option); + push @{$printChoices}, [&mt('Selected [_1]Resources[_2] from folder [_3]','','',''.$sequenceTitle.''), 'map_problems_pages', 'CHOOSE_PROBLEMS_HTML']; + + my $helperFragment = < + + PAGESIZE + return $isProblem; + $map + return $symbFilter; + $start_new_option + + + + + + PAGESIZE + return $isNotMap; + $map + return $symbFilter; + $start_new_option + + +HELPERFRAGMENT &Apache::lonxml::xmlparse($r, 'helper', $helperFragment); } # If the user has pfo (print for others) allow them to print all # problems and resources in the entire course, optionally for selected students - my $post_data = $helper->{VARS}->{'postdata'}; if ($perm{'pfo'} && !$is_published && - ($post_data=~/\/res\// || $post_data =~/\/(syllabus|smppg|aboutme|bulletinboard)$/)) { + ($helper->{VARS}->{'postdata'}=~/\/res\// || $helper->{VARS}->{'postdata'}=~/\/(syllabus|smppg|aboutme|bulletinboard)$/)) { push @{$printChoices}, [&mtn('Selected Problems from entire course'), 'all_problems', 'ALL_PROBLEMS']; push @{$printChoices}, [&mtn('Selected Resources from entire course'), 'all_resources', 'ALL_RESOURCES']; push @{$printChoices}, [&mtn('Selected Problems from entire course for selected people'), 'all_problems_students', 'ALL_PROBLEMS_STUDENTS']; -my $suffixXml = < + + PAGESIZE + return $isProblemOrMap; + return $isNotMap; + return $symbFilter; + $start_new_option + + + + + PAGESIZE + return $isNotMap; + return $symbFilter; + $start_new_option + + + + + STUDENTS1 + return $isProblemOrMap; + return $isNotMap; + return $symbFilter; + $start_new_option + + Select sorting order of printout @@ -3231,55 +3078,12 @@ my $suffixXml = <


+ ALL_PROBLEMS - &Apache::lonxml::xmlparse($r, 'helper', - &generate_resource_chooser('ALL_PROBLEMS', - 'SelectProblem(s) to print', - 'multichoice="1" suppressEmptySequences="0" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'PAGESIZE', - '', - $isProblemOrMap, $isNotMap, - $symbFilter, - $start_new_option) . - &generate_resource_chooser('ALL_RESOURCES', - 'Select Resource(s) to print', - " toponly='0' multichoice='1' suppressEmptySequences='0' addstatus='1' closeallpages='1'", - 'RESOURCES', - 'PAGESIZE', - '', - $isNotMap,,$symbFilter, - $start_new_option) . - &generate_resource_chooser('ALL_PROBLEMS_STUDENTS', - 'Select Problem(s) to print', - 'toponly="0" multichoice="1" suppressEmptySequences="0" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'STUDENTS1', - '', - $isProblemOrMap, , $symbFilter, - $start_new_option) . - $suffixXml - ); if ($helper->{VARS}->{'assignment'}) { - - # If we were looking at a page, allow a selection of problems from the page - # either for selected students or for coded assignments. - - if ($page_ispage) { - push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from page [_3] for [_4]selected people[_5]', - '', '', ''.$page_title.'', '', ''), - 'problems_for_students', 'CHOOSE_STUDENTS']; - push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from page [_3] for [_4]CODEd assignments[_5]', - '', '', ''.$page_title.'', '', ''), - 'problems_for_anon', 'CHOOSE_ANON1']; - } - push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]selected people[_5]', - '','',''.$sequenceTitle.'','',''), - 'problems_for_students', 'CHOOSE_STUDENTS']; - push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]CODEd assignments[_5]', - '','',''.$sequenceTitle.'','',''), - 'problems_for_anon', 'CHOOSE_ANON1']; + push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]selected people[_5]','','',''.$sequenceTitle.'','',''), 'problems_for_students', 'CHOOSE_STUDENTS']; + push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]CODEd assignments[_5]','','',''.$sequenceTitle.'','',''), 'problems_for_anon', 'CHOOSE_ANON1']; } my $randomly_ordered_warning = @@ -3294,15 +3098,20 @@ ALL_PROBLEMS # with one state, and use REGEXPs at inclusion time to set state names # and next states for better mix and match capability # - my $resource_selector= &generate_resource_chooser('SELECT_PROBLEMS', - 'Select resources to print', - 'multichoice="1" addstatus="1" closeallpages="1"', - 'RESOURCES', - 'PRINT_FORMATTING', - '', - $isProblem, , $symbFilter, - $start_new_option); - $resource_selector .= < + $randomly_ordered_warning + + PRINT_FORMATTING +
Select resources for the assignment
+ + return $isProblem; + $map + return $symbFilter; + $start_new_option + +
How should the results be printed?
@@ -3323,17 +3132,18 @@ ALL_PROBLEMS
RESOURCE_SELECTOR -# Generate student choosers. - - - - - &Apache::lonxml::xmlparse($r, 'helper', - &generate_student_chooser('CHOOSE_STUDENTS', - 'student_sort', - 'STUDENTS', - 'SELECT_PROBLEMS')); - &Apache::lonxml::xmlparse($r, 'helper', $resource_selector); + &Apache::lonxml::xmlparse($r, 'helper', < + Select sorting order of printout + + Sort by section then student + Sort by students across sections. + +


+ + + $resource_selector +CHOOSE_STUDENTS my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; @@ -3459,6 +3269,7 @@ CHOOSE_ANON1 $resource_selector=< $randomly_ordered_warning + PRINT_FORMATTING
Select resources for the assignment
- NUMBER_PER_PDF
How should the results be printed?