version 1.698, 2024/11/01 00:08:03
|
version 1.699, 2024/11/08 20:37:25
|
Line 75 my $font_size = 'normalsize'; # Default
|
Line 75 my $font_size = 'normalsize'; # Default
|
|
|
#---------------------------- Helper helpers. ------------------------- |
#---------------------------- Helper helpers. ------------------------- |
|
|
## |
## |
# Filter function to determine if a resource is a printable sequence. |
# Filter function to determine if a resource is a printable sequence. |
# |
# |
# @param $res -Resource to check. |
# @param $res -Resource to check. |
Line 164 sub create_incomplete_folder_selstud_hel
|
Line 164 sub create_incomplete_folder_selstud_hel
|
$map, |
$map, |
$selFilter, |
$selFilter, |
'', |
'', |
$symbFilter, |
$symbFilter, |
''); |
''); |
|
|
my $student_chooser = &generate_student_chooser('CHOOSE_STUDENTS_INCOMPLETE', |
my $student_chooser = &generate_student_chooser('CHOOSE_STUDENTS_INCOMPLETE', |
Line 177 sub create_incomplete_folder_selstud_hel
|
Line 177 sub create_incomplete_folder_selstud_hel
|
'CHOOSE_STUDENTS_INCOMPLETE_FORMAT'); # end state. |
'CHOOSE_STUDENTS_INCOMPLETE_FORMAT'); # end state. |
|
|
return $resource_chooser . $student_chooser . $format_chooser; |
return $resource_chooser . $student_chooser . $format_chooser; |
} |
} |
|
|
|
|
# BZ 5209 |
# BZ 5209 |
Line 197 sub create_incomplete_folder_selstud_hel
|
Line 197 sub create_incomplete_folder_selstud_hel
|
# helper - Helper we are creating states for. |
# helper - Helper we are creating states for. |
# Returns: |
# Returns: |
# Text that can be parsed by the helper. |
# Text that can be parsed by the helper. |
# |
# |
|
|
sub create_incomplete_course_helper { |
sub create_incomplete_course_helper { |
my $helper = shift; |
my $helper = shift; |
|
|
my $filter = '$res->is_problem() || $res->contains_problem() || $res->is_sequence() || $res->is_practice())'; |
my $filter = '$res->is_problem() || $res->contains_problem() || $res->is_sequence() || $res->is_practice())'; |
my $symbfilter = '$res->shown_symb()'; |
my $symbfilter = '$res->shown_symb()'; |
|
|
my $resource_chooser = &generate_resource_chooser('INCOMPLETE_PROBLEMS_COURSE_RESOURCES', |
my $resource_chooser = &generate_resource_chooser('INCOMPLETE_PROBLEMS_COURSE_RESOURCES', |
'Select problem(s) to print', |
'Select problem(s) to print', |
'multichoice = "1" suppressEmptySequences="0" addstatus="1" closeallpagtes="1" modallink="1"', |
'multichoice = "1" suppressEmptySequences="0" addstatus="1" closeallpagtes="1" modallink="1"', |
Line 230 sub create_incomplete_course_helper {
|
Line 230 sub create_incomplete_course_helper {
|
|
|
} |
} |
|
|
# BZ5209 |
# BZ5209 |
# Creates the states needed to run the print helper for a student |
# Creates the states needed to run the print helper for a student |
# that wants to print his incomplete problems from the current folder. |
# that wants to print his incomplete problems from the current folder. |
# Parameters: |
# Parameters: |
Line 258 sub create_incomplete_folder_helper {
|
Line 258 sub create_incomplete_folder_helper {
|
'RESOURCES', |
'RESOURCES', |
'PAGESIZE', |
'PAGESIZE', |
$map, |
$map, |
$filter, '', |
$filter, '', |
$symfilter, |
$symfilter, |
''); |
''); |
|
|
Line 276 sub create_incomplete_folder_helper {
|
Line 276 sub create_incomplete_folder_helper {
|
|
|
|
|
sub generate_student_chooser { |
sub generate_student_chooser { |
my ($this_state, |
my ($this_state, |
$sort_choice, |
$sort_choice, |
$variable, |
$variable, |
$next_state) = @_; |
$next_state) = @_; |
my $result = <<CHOOSE_STUDENTS; |
my $result = <<CHOOSE_STUDENTS; |
<state name="$this_state" title="Select Students and Resources"> |
<state name="$this_state" title="Select Students and Resources"> |
Line 290 sub generate_student_chooser {
|
Line 290 sub generate_student_chooser {
|
</choices> |
</choices> |
|
|
<message><br /><hr /><br /> </message> |
<message><br /><hr /><br /> </message> |
<student multichoice='1' |
<student multichoice='1' |
variable="$variable" |
variable="$variable" |
nextstate="$next_state" |
nextstate="$next_state" |
coursepersonnel="1" /> |
coursepersonnel="1" /> |
Line 309 CHOOSE_STUDENTS
|
Line 309 CHOOSE_STUDENTS
|
# prompt_text - Text to use to prompt user. |
# prompt_text - Text to use to prompt user. |
# resource_options - Resource tag options e.g. |
# resource_options - Resource tag options e.g. |
# "multichoice='1', toponly='1', addstatus='1', |
# "multichoice='1', toponly='1', addstatus='1', |
# modallink='1'" |
# modallink='1'" |
# that control the selection and appearance of the |
# that control the selection and appearance of the |
# resource selector. |
# resource selector. |
# variable - Name of the variable to hold the choice |
# variable - Name of the variable to hold the choice |
Line 320 CHOOSE_STUDENTS
|
Line 320 CHOOSE_STUDENTS
|
# filter - How to filter the resources. |
# filter - How to filter the resources. |
# value_func - <valuefunc> function. |
# value_func - <valuefunc> function. |
# choice_func - If not empty generates a <choicefunc> with this function. |
# choice_func - If not empty generates a <choicefunc> with this function. |
# start_new_option |
# start_new_option |
# - Fragment appended after valuefunc. |
# - Fragment appended after valuefunc. |
# |
# |
# |
# |
Line 452 sub generate_common_choosers {
|
Line 452 sub generate_common_choosers {
|
my $randomly_ordered_warning = |
my $randomly_ordered_warning = |
&get_randomly_ordered_warning($helper, $map); |
&get_randomly_ordered_warning($helper, $map); |
|
|
# code for a few states used for printout launched from both |
# code for a few states used for printout launched from both |
# /adm/navmaps and from a resource by a privileged user: |
# /adm/navmaps and from a resource by a privileged user: |
# - To allow resources to be selected for printing. |
# - To allow resources to be selected for printing. |
# - To determine pagination between assignments. |
# - To determine pagination between assignments. |
Line 574 sub generate_common_choosers {
|
Line 574 sub generate_common_choosers {
|
return ($randomly_ordered_warning,$codechoice,$code_selection,$namechoice); |
return ($randomly_ordered_warning,$codechoice,$code_selection,$namechoice); |
} |
} |
|
|
# Returns the XML for choosing how assignments are to be formatted |
# Returns the XML for choosing how assignments are to be formatted |
# that text must still be parsed by the helper xml parser. |
# that text must still be parsed by the helper xml parser. |
# Parameters: 3 (required) |
# Parameters: 3 (required) |
|
|
# helper - The helper; $helper->{'VARS'}->{'PRINT_TYPE'} used |
# helper - The helper; $helper->{'VARS'}->{'PRINT_TYPE'} used |
# to check if splitting PDFs by section can be offered. |
# to check if splitting PDFs by section can be offered. |
# title - Title for the current state. |
# title - Title for the current state. |
# this_state - State name of the chooser. |
# this_state - State name of the chooser. |
|
|
sub generate_format_selector { |
sub generate_format_selector { |
Line 623 RESOURCE_SELECTOR
|
Line 623 RESOURCE_SELECTOR
|
# @param \@opens - reference to an array of open dates. |
# @param \@opens - reference to an array of open dates. |
# @param \@closes - reference to an array of close dates. |
# @param \@closes - reference to an array of close dates. |
# |
# |
# @return ($open, $close) |
# @return ($open, $close) |
# |
# |
# @note If open/close dates are not defined they will be returned as undef |
# @note If open/close dates are not defined they will be returned as undef |
# @note It is possible for there to be no overlap in which case -1,-1 |
# @note It is possible for there to be no overlap in which case -1,-1 |
# will be returned. |
# will be returned. |
# @note The algorithm used is to take the latest open date and the earliest end date. |
# @note The algorithm used is to take the latest open date and the earliest end date. |
# |
# |
Line 660 sub compute_open_window {
|
Line 660 sub compute_open_window {
|
$latest_open = -1; |
$latest_open = -1; |
$earliest_close = -1; |
$earliest_close = -1; |
} |
} |
|
|
return ($latest_open, $earliest_close); |
return ($latest_open, $earliest_close); |
|
|
} |
} |
|
|
## |
## |
Line 689 sub printable {
|
Line 689 sub printable {
|
if ($close_date && ($close_date < $now)) { |
if ($close_date && ($close_date < $now)) { |
return 0; |
return 0; |
} |
} |
|
|
return 1; |
return 1; |
|
|
} |
} |
Line 698 sub printable {
|
Line 698 sub printable {
|
# Returns the innermost print start/print end dates for a resource. |
# Returns the innermost print start/print end dates for a resource. |
# This is done by looking at the start/end dates for its parts and choosing |
# This is done by looking at the start/end dates for its parts and choosing |
# the intersection of those dates. |
# the intersection of those dates. |
# |
# |
# @param res - lonnvamaps::resource object that represents the resource. |
# @param res - lonnvamaps::resource object that represents the resource. |
# |
# |
# @return (opendate, closedate) |
# @return (opendate, closedate) |
# |
# |
# @note If open/close dates are not defined they will be returned as undef |
# @note If open/close dates are not defined they will be returned as undef |
# @note It is possible for there to be no overlap in which case -1,-1 |
# @note It is possible for there to be no overlap in which case -1,-1 |
# will be returned. |
# will be returned. |
# @note The algorithm used is to take the latest open date and the earliest end date. |
# @note The algorithm used is to take the latest open date and the earliest end date. |
# For consistency with &printable() in lonnavmaps.pm determination of start |
# For consistency with &printable() in lonnavmaps.pm determination of start |
Line 822 sub incomplete {
|
Line 822 sub incomplete {
|
|
|
|
|
my $navmap = Apache::lonnavmaps::navmap->new($username, $domain); |
my $navmap = Apache::lonnavmaps::navmap->new($username, $domain); |
|
|
|
|
if (defined($navmap)) { |
if (defined($navmap)) { |
my $res = $navmap->getResourceByUrl($map); |
my $res = $navmap->getResourceByUrl($map); |
Line 858 sub incomplete {
|
Line 858 sub incomplete {
|
# Returns: |
# Returns: |
# reference to an array of resources that can be passed to |
# reference to an array of resources that can be passed to |
# print_resources. |
# print_resources. |
# |
# |
sub master_seq_to_person_seq { |
sub master_seq_to_person_seq { |
my ($map, $seq, $who, $code, $nohidemap) = @_; |
my ($map, $seq, $who, $code, $nohidemap) = @_; |
|
|
Line 876 sub master_seq_to_person_seq {
|
Line 876 sub master_seq_to_person_seq {
|
if ($nohidemap) { |
if ($nohidemap) { |
$unhidden = &Apache::lonnet::clutter($map); |
$unhidden = &Apache::lonnet::clutter($map); |
} |
} |
|
|
my $navmap = Apache::lonnavmaps::navmap->new($username, $userdomain, |
my $navmap = Apache::lonnavmaps::navmap->new($username, $userdomain, |
$code, $unhidden); |
$code, $unhidden); |
my ($start,$finish); |
my ($start,$finish); |
Line 914 sub master_seq_to_person_seq {
|
Line 914 sub master_seq_to_person_seq {
|
} |
} |
|
|
return \@output_seq; # for now. |
return \@output_seq; # for now. |
|
|
} |
} |
|
|
|
|
Line 937 sub fetch_raw_resource {
|
Line 937 sub fetch_raw_resource {
|
} |
} |
return $contents; |
return $contents; |
|
|
|
|
} |
} |
|
|
# Fetch the annotations associated with a URL and |
# Fetch the annotations associated with a URL and |
# put a centered 'annotations:' title. |
# put a centered 'annotations:' title. |
# This is all suppressed if the annotations are empty. |
# This is all suppressed if the annotations are empty. |
# |
# |
Line 987 sub set_font_size {
|
Line 987 sub set_font_size {
|
|
|
} |
} |
|
|
# include_pdf - PDF files are included into the |
# include_pdf - PDF files are included into the |
# output as follows: |
# output as follows: |
# - The PDF, if necessary, is replicated. |
# - The PDF, if necessary, is replicated. |
# - The PDF is added to the list of files to convert to postscript (along with the images). |
# - The PDF is added to the list of files to convert to postscript (along with the images). |
Line 996 sub set_font_size {
|
Line 996 sub set_font_size {
|
# |
# |
# Parameters: |
# Parameters: |
# pdf_uri - URI of the PDF file to include. |
# pdf_uri - URI of the PDF file to include. |
# |
# |
# Returns: |
# Returns: |
# The LaTeX to include. |
# The LaTeX to include. |
# |
# |
Line 1076 sub collect_languages {
|
Line 1076 sub collect_languages {
|
# the number of times requested by the caller. |
# the number of times requested by the caller. |
# If we still have a proble, no text is appended to the |
# If we still have a proble, no text is appended to the |
# output and we set some global variables. |
# output and we set some global variables. |
# to indicate to the caller an SSI error occurred. |
# to indicate to the caller an SSI error occurred. |
# All of this is supposed to deal with the issues described |
# All of this is supposed to deal with the issues described |
# in LonCAPA BZ 5631 see: |
# in LonCAPA BZ 5631 see: |
# http://bugs.lon-capa.org/show_bug.cgi?id=5631 |
# http://bugs.lon-capa.org/show_bug.cgi?id=5631 |
Line 1086 sub collect_languages {
|
Line 1086 sub collect_languages {
|
# resource - The resource to include. This is passed directly, without |
# resource - The resource to include. This is passed directly, without |
# interpretation to lonnet::ssi. |
# interpretation to lonnet::ssi. |
# form - The form hash parameters that guide the interpretation of the resource |
# form - The form hash parameters that guide the interpretation of the resource |
# |
# |
# retries - Number of retries allowed before giving up completely. |
# retries - Number of retries allowed before giving up completely. |
# Returns: |
# Returns: |
# On success, returns the rendered resource identified by the resource parameter. |
# On success, returns the rendered resource identified by the resource parameter. |
Line 1137 sub get_student_view_with_retries {
|
Line 1137 sub get_student_view_with_retries {
|
|
|
# |
# |
# printf_style_subst item format_string repl |
# printf_style_subst item format_string repl |
# |
# |
# Does printf style substitution for a format string that |
# Does printf style substitution for a format string that |
# can have %[n]item in it.. wherever, %[n]item occurs, |
# can have %[n]item in it.. wherever, %[n]item occurs, |
# rep is substituted in format_string. Note that |
# rep is substituted in format_string. Note that |
# [n] is an optional integer length. If provided, |
# [n] is an optional integer length. If provided, |
# repl is truncated to at most [n] characters prior to |
# repl is truncated to at most [n] characters prior to |
# substitution. |
# substitution. |
# |
# |
sub printf_style_subst { |
sub printf_style_subst { |
Line 1154 sub printf_style_subst {
|
Line 1154 sub printf_style_subst {
|
my $subst = $repl; |
my $subst = $repl; |
if ($size ne "") { |
if ($size ne "") { |
$subst = substr($subst, 0, $size); |
$subst = substr($subst, 0, $size); |
|
|
# Here's a nice edge case ... suppose the end of the |
# Here's a nice edge case ... suppose the end of the |
# substring is a \. In that case may have just |
# substring is a \. In that case may have just |
# chopped off a TeX escape... in that case, we append |
# chopped off a TeX escape... in that case, we append |
# " " for the trailing character, and let the field |
# " " for the trailing character, and let the field |
# spill over a bit (sigh). |
# spill over a bit (sigh). |
# We don't just chop off the last character in order to deal |
# We don't just chop off the last character in order to deal |
# with one last pathology, and that would be if substr had |
# with one last pathology, and that would be if substr had |
# trimmed us to e.g. \\\ |
# trimmed us to e.g. \\\ |
|
|
|
|
if ($subst =~ /\\$/) { |
if ($subst =~ /\\$/) { |
Line 1182 sub printf_style_subst {
|
Line 1182 sub printf_style_subst {
|
} |
} |
|
|
|
|
# Format a header according to a format. |
# Format a header according to a format. |
# |
# |
|
|
# Substitutions: |
# Substitutions: |
# %a - Assignment name. |
# %a - Assignment name. |
Line 1207 sub format_page_header {
|
Line 1207 sub format_page_header {
|
# we assume that each character is about 2mm in width. |
# we assume that each character is about 2mm in width. |
# (correct for the header text size??). We ignore |
# (correct for the header text size??). We ignore |
# any formatting (e.g. boldfacing in this). |
# any formatting (e.g. boldfacing in this). |
# |
# |
# - Allow the student/course to be one line. |
# - Allow the student/course to be one line. |
# but only truncate the course. |
# but only truncate the course. |
# - Allow the assignment to be 2 lines (wrapped). |
# - Allow the assignment to be 2 lines (wrapped). |
Line 1225 sub format_page_header {
|
Line 1225 sub format_page_header {
|
} |
} |
|
|
$format .= '\\\\%c \\\\ %a'; |
$format .= '\\\\%c \\\\ %a'; |
|
|
|
|
} |
} |
# An open question is how to handle long user formatted page headers... |
# An open question is how to handle long user formatted page headers... |
Line 1236 sub format_page_header {
|
Line 1236 sub format_page_header {
|
$format = &printf_style_subst("c", $format, $course); |
$format = &printf_style_subst("c", $format, $course); |
$format = &printf_style_subst("n", $format, $student); |
$format = &printf_style_subst("n", $format, $student); |
$format = &printf_style_subst("s", $format, $section); |
$format = &printf_style_subst("s", $format, $section); |
|
|
|
|
# If the user put %'s in the format string, they must be escaped |
# If the user put %'s in the format string, they must be escaped |
# to \% else LaTeX will think they are comments and terminate |
# to \% else LaTeX will think they are comments and terminate |
# the line.. which is bad!!! |
# the line.. which is bad!!! |
|
|
# If the user has role author, $course and $assignment are empty so |
# If the user has role author, $course and $assignment are empty so |
# there is '\\ \\ ' in the page header. That's cause a error in LaTeX |
# there is '\\ \\ ' in the page header. That's cause a error in LaTeX |
if($format =~ /\\\\\s\\\\\s/) { |
if($format =~ /\\\\\s\\\\\s/) { |
Line 1264 sub format_page_header {
|
Line 1264 sub format_page_header {
|
|
|
|
|
return $format; |
return $format; |
|
|
} |
} |
|
|
# |
# |
Line 1312 sub is_valid_numeric_code {
|
Line 1312 sub is_valid_numeric_code {
|
# Remove leading/trailing whitespace; |
# Remove leading/trailing whitespace; |
$value =~ s/^\s*//g; |
$value =~ s/^\s*//g; |
$value =~ s/\s*$//g; |
$value =~ s/\s*$//g; |
|
|
# All digits? |
# All digits? |
if ($value !~ /^[0-9]+$/) { |
if ($value !~ /^[0-9]+$/) { |
return "Numeric code $value has invalid characters - must only be digits"; |
return "Numeric code $value has invalid characters - must only be digits"; |
Line 1333 sub is_valid_numeric_code {
|
Line 1333 sub is_valid_numeric_code {
|
# |
# |
sub is_valid_alpha_code { |
sub is_valid_alpha_code { |
my ($value, $num_letters) = @_; |
my ($value, $num_letters) = @_; |
|
|
# strip leading and trailing spaces. |
# strip leading and trailing spaces. |
|
|
$value =~ s/^\s*//g; |
$value =~ s/^\s*//g; |
Line 1351 sub is_valid_alpha_code {
|
Line 1351 sub is_valid_alpha_code {
|
|
|
# Determine if a code entered by the user in a helper is valid. |
# Determine if a code entered by the user in a helper is valid. |
# valid depends on the code type and the type of code selected. |
# valid depends on the code type and the type of code selected. |
# The type of code selected can either be numeric or |
# The type of code selected can either be numeric or |
# Alphabetic. If alphabetic, the code, in fact is a simple |
# Alphabetic. If alphabetic, the code, in fact is a simple |
# substitution cipher for the actual numeric code: 0->A, 1->B ... |
# substitution cipher for the actual numeric code: 0->A, 1->B ... |
# We'll be nice and be case insensitive for alpha codes. |
# We'll be nice and be case insensitive for alpha codes. |
Line 1388 sub is_code_valid {
|
Line 1388 sub is_code_valid {
|
# |
# |
# Compare two students by section (Used to sort by section). |
# Compare two students by section (Used to sort by section). |
# |
# |
# Implicit inputs, |
# Implicit inputs, |
# $a - The first one |
# $a - The first one |
# $b - The second one. |
# $b - The second one. |
# |
# |
Line 1444 sub compare_names {
|
Line 1444 sub compare_names {
|
# |
# |
$f1 =~ s/^\s+//; # Remove leading... |
$f1 =~ s/^\s+//; # Remove leading... |
$f1 =~ s/\s+$//; # Trailing spaces from first 1... |
$f1 =~ s/\s+$//; # Trailing spaces from first 1... |
|
|
$f2 =~ s/^\s+//; |
$f2 =~ s/^\s+//; |
$f2 =~ s/\s+$//; # And the same for first 2... |
$f2 =~ s/\s+$//; # And the same for first 2... |
|
|
Line 1454 sub compare_names {
|
Line 1454 sub compare_names {
|
if($f1 gt $f2) { |
if($f1 gt $f2) { |
return 1; |
return 1; |
} |
} |
|
|
# Must be the same name. |
# Must be the same name. |
|
|
return 0; |
return 0; |
Line 1467 sub latex_header_footer_remove {
|
Line 1467 sub latex_header_footer_remove {
|
return $text; |
return $text; |
} |
} |
# |
# |
# If necessary, encapsulate text inside |
# If necessary, encapsulate text inside |
# a minipage env. |
# a minipage env. |
# necessity is determined by the problem_split param. |
# necessity is determined by the problem_split param. |
# |
# |
Line 1491 sub adjust_number_to_print {
|
Line 1491 sub adjust_number_to_print {
|
my $helper = shift; |
my $helper = shift; |
|
|
my $split_pdf = $helper->{'VARS'}->{'SPLIT_PDFS'}; |
my $split_pdf = $helper->{'VARS'}->{'SPLIT_PDFS'}; |
|
|
if ($split_pdf eq 'all') { |
if ($split_pdf eq 'all') { |
$helper->{'VARS'}->{'NUMBER_TO_PRINT'} = 'all'; |
$helper->{'VARS'}->{'NUMBER_TO_PRINT'} = 'all'; |
} elsif ($split_pdf eq 'oneper') { |
} elsif ($split_pdf eq 'oneper') { |
Line 1523 sub old_character_chart {
|
Line 1523 sub old_character_chart {
|
$result =~ s/&(\#0?34|quot);/\"/g; |
$result =~ s/&(\#0?34|quot);/\"/g; |
$result =~ s/&\#0?35;/\\\#/g; |
$result =~ s/&\#0?35;/\\\#/g; |
$result =~ s/&\#0?36;/\\\$/g; |
$result =~ s/&\#0?36;/\\\$/g; |
$result =~ s/&\#0?37;/\\%/g; |
$result =~ s/&\#0?37;/\\%/g; |
$result =~ s/&(\#0?38|amp);/\\&/g; |
$result =~ s/&(\#0?38|amp);/\\&/g; |
$result =~ s/&\#(0?39|146);/\'/g; |
$result =~ s/&\#(0?39|146);/\'/g; |
$result =~ s/&\#0?40;/(/g; |
$result =~ s/&\#0?40;/(/g; |
$result =~ s/&\#0?41;/)/g; |
$result =~ s/&\#0?41;/)/g; |
Line 1631 sub old_character_chart {
|
Line 1631 sub old_character_chart {
|
$result =~ s/&(\#160|nbsp);/~/g; |
$result =~ s/&(\#160|nbsp);/~/g; |
$result =~ s/&(\#161|iexcl);/!\`/g; |
$result =~ s/&(\#161|iexcl);/!\`/g; |
$result =~ s/&(\#162|cent);/\\textcent /g; |
$result =~ s/&(\#162|cent);/\\textcent /g; |
$result =~ s/&(\#163|pound);/\\pounds /g; |
$result =~ s/&(\#163|pound);/\\pounds /g; |
$result =~ s/&(\#164|curren);/\\textcurrency /g; |
$result =~ s/&(\#164|curren);/\\textcurrency /g; |
$result =~ s/&(\#165|yen);/\\textyen /g; |
$result =~ s/&(\#165|yen);/\\textyen /g; |
$result =~ s/&(\#166|brvbar);/\\textbrokenbar /g; |
$result =~ s/&(\#166|brvbar);/\\textbrokenbar /g; |
Line 1657 sub old_character_chart {
|
Line 1657 sub old_character_chart {
|
$result =~ s/&(\#188|frac14);/\\textonequarter /g; |
$result =~ s/&(\#188|frac14);/\\textonequarter /g; |
$result =~ s/&(\#189|frac12);/\\textonehalf /g; |
$result =~ s/&(\#189|frac12);/\\textonehalf /g; |
$result =~ s/&(\#190|frac34);/\\textthreequarters /g; |
$result =~ s/&(\#190|frac34);/\\textthreequarters /g; |
$result =~ s/&(\#191|iquest);/?\`/g; |
$result =~ s/&(\#191|iquest);/?\`/g; |
$result =~ s/&(\#192|Agrave);/\\\`{A}/g; |
$result =~ s/&(\#192|Agrave);/\\\`{A}/g; |
$result =~ s/&(\#193|Aacute);/\\\'{A}/g; |
$result =~ s/&(\#193|Aacute);/\\\'{A}/g; |
$result =~ s/&(\#194|Acirc);/\\^{A}/g; |
$result =~ s/&(\#194|Acirc);/\\^{A}/g; |
$result =~ s/&(\#195|Atilde);/\\~{A}/g; |
$result =~ s/&(\#195|Atilde);/\\~{A}/g; |
$result =~ s/&(\#196|Auml);/\\\"{A}/g; |
$result =~ s/&(\#196|Auml);/\\\"{A}/g; |
$result =~ s/&(\#197|Aring);/{\\AA}/g; |
$result =~ s/&(\#197|Aring);/{\\AA}/g; |
$result =~ s/&(\#198|AElig);/{\\AE}/g; |
$result =~ s/&(\#198|AElig);/{\\AE}/g; |
$result =~ s/&(\#199|Ccedil);/\\c{c}/g; |
$result =~ s/&(\#199|Ccedil);/\\c{c}/g; |
$result =~ s/&(\#200|Egrave);/\\\`{E}/g; |
$result =~ s/&(\#200|Egrave);/\\\`{E}/g; |
$result =~ s/&(\#201|Eacute);/\\\'{E}/g; |
$result =~ s/&(\#201|Eacute);/\\\'{E}/g; |
$result =~ s/&(\#202|Ecirc);/\\^{E}/g; |
$result =~ s/&(\#202|Ecirc);/\\^{E}/g; |
$result =~ s/&(\#203|Euml);/\\\"{E}/g; |
$result =~ s/&(\#203|Euml);/\\\"{E}/g; |
$result =~ s/&(\#204|Igrave);/\\\`{I}/g; |
$result =~ s/&(\#204|Igrave);/\\\`{I}/g; |
$result =~ s/&(\#205|Iacute);/\\\'{I}/g; |
$result =~ s/&(\#205|Iacute);/\\\'{I}/g; |
$result =~ s/&(\#206|Icirc);/\\^{I}/g; |
$result =~ s/&(\#206|Icirc);/\\^{I}/g; |
$result =~ s/&(\#207|Iuml);/\\\"{I}/g; |
$result =~ s/&(\#207|Iuml);/\\\"{I}/g; |
$result =~ s/&(\#209|Ntilde);/\\~{N}/g; |
$result =~ s/&(\#209|Ntilde);/\\~{N}/g; |
$result =~ s/&(\#210|Ograve);/\\\`{O}/g; |
$result =~ s/&(\#210|Ograve);/\\\`{O}/g; |
$result =~ s/&(\#211|Oacute);/\\\'{O}/g; |
$result =~ s/&(\#211|Oacute);/\\\'{O}/g; |
$result =~ s/&(\#212|Ocirc);/\\^{O}/g; |
$result =~ s/&(\#212|Ocirc);/\\^{O}/g; |
$result =~ s/&(\#213|Otilde);/\\~{O}/g; |
$result =~ s/&(\#213|Otilde);/\\~{O}/g; |
$result =~ s/&(\#214|Ouml);/\\\"{O}/g; |
$result =~ s/&(\#214|Ouml);/\\\"{O}/g; |
$result =~ s/&(\#215|times);/\\ensuremath\{\\times\}/g; |
$result =~ s/&(\#215|times);/\\ensuremath\{\\times\}/g; |
$result =~ s/&(\#216|Oslash);/{\\O}/g; |
$result =~ s/&(\#216|Oslash);/{\\O}/g; |
$result =~ s/&(\#217|Ugrave);/\\\`{U}/g; |
$result =~ s/&(\#217|Ugrave);/\\\`{U}/g; |
$result =~ s/&(\#218|Uacute);/\\\'{U}/g; |
$result =~ s/&(\#218|Uacute);/\\\'{U}/g; |
$result =~ s/&(\#219|Ucirc);/\\^{U}/g; |
$result =~ s/&(\#219|Ucirc);/\\^{U}/g; |
$result =~ s/&(\#220|Uuml);/\\\"{U}/g; |
$result =~ s/&(\#220|Uuml);/\\\"{U}/g; |
Line 1713 sub old_character_chart {
|
Line 1713 sub old_character_chart {
|
$result =~ s/&(\#246|ouml);/\\\"{o}/g; |
$result =~ s/&(\#246|ouml);/\\\"{o}/g; |
$result =~ s/&(\#247|divide);/\\ensuremath\{\\div\}/g; |
$result =~ s/&(\#247|divide);/\\ensuremath\{\\div\}/g; |
$result =~ s/&(\#248|oslash);/{\\o}/g; |
$result =~ s/&(\#248|oslash);/{\\o}/g; |
$result =~ s/&(\#249|ugrave);/\\\`{u}/g; |
$result =~ s/&(\#249|ugrave);/\\\`{u}/g; |
$result =~ s/&(\#250|uacute);/\\\'{u}/g; |
$result =~ s/&(\#250|uacute);/\\\'{u}/g; |
$result =~ s/&(\#251|ucirc);/\\^{u}/g; |
$result =~ s/&(\#251|ucirc);/\\^{u}/g; |
$result =~ s/&(\#252|uuml);/\\\"{u}/g; |
$result =~ s/&(\#252|uuml);/\\\"{u}/g; |
Line 1957 sub page_format {
|
Line 1957 sub page_format {
|
# "A2 [420x594 mm]", "A3 [297x420 mm]", |
# "A2 [420x594 mm]", "A3 [297x420 mm]", |
# "A4 [210x297 mm]", "A5 [148x210 mm]", |
# "A4 [210x297 mm]", "A5 [148x210 mm]", |
# "A6 [105x148 mm]" |
# "A6 [105x148 mm]" |
# |
# |
my ($papersize,$layout,$numberofcolumns) = @_; |
my ($papersize,$layout,$numberofcolumns) = @_; |
return @{$page_formats{$papersize}->{$layout}->{$numberofcolumns}}; |
return @{$page_formats{$papersize}->{$layout}->{$numberofcolumns}}; |
} |
} |
|
|
Line 1978 sub get_course {
|
Line 1978 sub get_course {
|
if (defined($env{'request.course.id'})) { |
if (defined($env{'request.course.id'})) { |
$courseidinfo = &Apache::lonxml::latex_special_symbols(&unescape($env{'course.'.$env{'request.course.id'}.'.description'}),'header'); |
$courseidinfo = &Apache::lonxml::latex_special_symbols(&unescape($env{'course.'.$env{'request.course.id'}.'.description'}),'header'); |
my $sec = $env{'request.course.sec'}; |
my $sec = $env{'request.course.sec'}; |
|
|
} |
} |
return $courseidinfo; |
return $courseidinfo; |
} |
} |
|
|
sub page_format_transformation { |
sub page_format_transformation { |
my ($papersize,$layout,$numberofcolumns,$choice,$text,$assignment,$tableofcontents,$indexlist,$selectionmade) = @_; |
my ($papersize,$layout,$numberofcolumns,$choice,$text,$assignment,$tableofcontents,$indexlist,$selectionmade) = @_; |
my ($textwidth,$textheight,$oddoffset,$evenoffset,$topmargin); |
my ($textwidth,$textheight,$oddoffset,$evenoffset,$topmargin); |
|
|
if ($selectionmade eq '4') { |
if ($selectionmade eq '4') { |
Line 2028 sub page_format_transformation {
|
Line 2028 sub page_format_transformation {
|
} |
} |
} |
} |
} elsif ($layout eq 'book') { |
} elsif ($layout eq 'book') { |
if ($choice ne 'All class print') { |
if ($choice ne 'All class print') { |
$text =~ s/\\begin\{document}/\\textheight $textheight\\oddsidemargin = $evenoffset\\evensidemargin = $evenoffset $topmargintoinsert\n\\textwidth= $textwidth\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/\$number_of_columns-0\.2cm}\n\\renewcommand{\\ref}{\\keephidden\}\\usepackage{fancyhdr}\\addtolength{\\headheight}{\\baselineskip}\\pagestyle{fancy}$fancypagestatement\\usepackage{booktabs}\\begin{document}\n\\voffset=-0\.8 cm\\setcounter{page}{1}\n/; |
$text =~ s/\\begin\{document}/\\textheight $textheight\\oddsidemargin = $evenoffset\\evensidemargin = $evenoffset $topmargintoinsert\n\\textwidth= $textwidth\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/\$number_of_columns-0\.2cm}\n\\renewcommand{\\ref}{\\keephidden\}\\usepackage{fancyhdr}\\addtolength{\\headheight}{\\baselineskip}\\pagestyle{fancy}$fancypagestatement\\usepackage{booktabs}\\begin{document}\n\\voffset=-0\.8 cm\\setcounter{page}{1}\n/; |
} else { |
} else { |
$text =~ s/\\pagestyle\{fancy}\\rhead\{}\\chead\{}\s*\\begin\{document}/\\textheight = $textheight\\oddsidemargin = $evenoffset\n\\evensidemargin = $evenoffset $topmargintoinsert\\textwidth= $textwidth\\newlength{\\minipagewidth}\n\\setlength{\\minipagewidth}{\\textwidth\/\$number_of_columns-0\.2cm}\\renewcommand{\\ref}{\\keephidden\}\\pagestyle{fancy}\\rhead{}\\chead{}\\usepackage{booktabs}\\begin{document}\\voffset=-0\.8cm\n\\setcounter{page}{1} \\vskip 5 mm\n /; |
$text =~ s/\\pagestyle\{fancy}\\rhead\{}\\chead\{}\s*\\begin\{document}/\\textheight = $textheight\\oddsidemargin = $evenoffset\n\\evensidemargin = $evenoffset $topmargintoinsert\\textwidth= $textwidth\\newlength{\\minipagewidth}\n\\setlength{\\minipagewidth}{\\textwidth\/\$number_of_columns-0\.2cm}\\renewcommand{\\ref}{\\keephidden\}\\pagestyle{fancy}\\rhead{}\\chead{}\\usepackage{booktabs}\\begin{document}\\voffset=-0\.8cm\n\\setcounter{page}{1} \\vskip 5 mm\n /; |
Line 2064 sub page_format_transformation {
|
Line 2064 sub page_format_transformation {
|
|
|
sub page_cleanup { |
sub page_cleanup { |
my $result = shift; |
my $result = shift; |
|
|
$result =~ m/\\end\{document}(\d*)$/; |
$result =~ m/\\end\{document}(\d*)$/; |
my $number_of_columns = $1; |
my $number_of_columns = $1; |
my $insert = '{'; |
my $insert = '{'; |
Line 2116 sub latex_corrections {
|
Line 2116 sub latex_corrections {
|
$result =~ s/\$number_of_columns/$number_of_columns/g; |
$result =~ s/\$number_of_columns/$number_of_columns/g; |
$result =~ s/(\\end\{longtable}\s*)(\\strut\\newline\\noindent\\makebox\[\\textwidth\/$number_of_columns\]\[b\]\{\\hrulefill})/$2$1/g; |
$result =~ s/(\\end\{longtable}\s*)(\\strut\\newline\\noindent\\makebox\[\\textwidth\/$number_of_columns\]\[b\]\{\\hrulefill})/$2$1/g; |
$result =~ s/(\\end\{longtable}\s*)\\strut\\newline/$1/g; |
$result =~ s/(\\end\{longtable}\s*)\\strut\\newline/$1/g; |
#-- LaTeX corrections |
#-- LaTeX corrections |
my $first_comment = index($result,'<!--',0); |
my $first_comment = index($result,'<!--',0); |
while ($first_comment != -1) { |
while ($first_comment != -1) { |
my $end_comment = index($result,'-->',$first_comment); |
my $end_comment = index($result,'-->',$first_comment); |
Line 2285 sub print_page_in_course {
|
Line 2285 sub print_page_in_course {
|
$laystyle = &map_laystyle($laystyle); |
$laystyle = &map_laystyle($laystyle); |
my ($textwidth,$textheight,$oddoffset,$evenoffset) = &page_format($papersize,$laystyle, |
my ($textwidth,$textheight,$oddoffset,$evenoffset) = &page_format($papersize,$laystyle, |
$numberofcolumns); |
$numberofcolumns); |
my $LaTeXwidth=&recalcto_mm($textwidth); |
my $LaTeXwidth=&recalcto_mm($textwidth); |
|
|
if ($mode ne '') {$mode='\\'.$mode} |
if ($mode ne '') {$mode='\\'.$mode} |
my $result = &print_latex_header($mode); |
my $result = &print_latex_header($mode); |
Line 2301 sub print_page_in_course {
|
Line 2301 sub print_page_in_course {
|
&Apache::lonnet::delenv('construct.style'); |
&Apache::lonnet::delenv('construct.style'); |
} |
} |
|
|
# First is the overall page description. This is then followed by the |
# First is the overall page description. This is then followed by the |
# components of the page. Each of which must be printed independently. |
# components of the page. Each of which must be printed independently. |
my $the_page = shift(@page_resources); |
my $the_page = shift(@page_resources); |
|
|
|
|
foreach my $resource (@page_resources) { |
foreach my $resource (@page_resources) { |
Line 2315 sub print_page_in_course {
|
Line 2315 sub print_page_in_course {
|
if ($resource_src =~ /.page$/i) { |
if ($resource_src =~ /.page$/i) { |
my $navmap = Apache::lonnavmaps::navmap->new(); |
my $navmap = Apache::lonnavmaps::navmap->new(); |
my @page_resources = $navmap->retrieveResources($resource_src); |
my @page_resources = $navmap->retrieveResources($resource_src); |
$result .= &print_page_in_course($helper, $rparmhash, |
$result .= &print_page_in_course($helper, $rparmhash, |
$resource_src, \@page_resources); |
$resource_src, \@page_resources); |
} elsif ($resource->ext()) { |
} elsif ($resource->ext()) { |
$result.=&latex_header_footer_remove(&unsupported($current_url,$mode,$resource->symb)); |
$result.=&latex_header_footer_remove(&unsupported($current_url,$mode,$resource->symb)); |
Line 2334 sub print_page_in_course {
|
Line 2334 sub print_page_in_course {
|
|
|
$form{'grade_target'} = 'tex'; |
$form{'grade_target'} = 'tex'; |
$form{'textwidth'} = &get_textwidth($helper, $LaTeXwidth); |
$form{'textwidth'} = &get_textwidth($helper, $LaTeXwidth); |
$form{'pdfFormFields'} = $pdfFormFields; # |
$form{'pdfFormFields'} = $pdfFormFields; # |
$form{'showallfoils'} = $helper->{'VARS'}->{'showallfoils'}; |
$form{'showallfoils'} = $helper->{'VARS'}->{'showallfoils'}; |
|
|
$form{'problem_split'}=$parmhash{'problem_stream_switch'}; |
$form{'problem_split'}=$parmhash{'problem_stream_switch'}; |
$form{'suppress_tries'}=$parmhash{'suppress_tries'}; |
$form{'suppress_tries'}=$parmhash{'suppress_tries'}; |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
Line 2352 sub print_page_in_course {
|
Line 2352 sub print_page_in_course {
|
} |
} |
$form{'rndseed'}=$rndseed; |
$form{'rndseed'}=$rndseed; |
&Apache::lonnet::appenv(\%moreenv); |
&Apache::lonnet::appenv(\%moreenv); |
|
|
&Apache::lonxml::clear_problem_counter(); |
&Apache::lonxml::clear_problem_counter(); |
|
|
my $texversion = &ssi_with_retries($urlp, $ssi_retry_count, %form); |
my $texversion = &ssi_with_retries($urlp, $ssi_retry_count, %form); |
Line 2392 sub print_page_in_course {
|
Line 2392 sub print_page_in_course {
|
} |
} |
$texversion.='\vskip 1 mm '.$answer.'\end{document}'; |
$texversion.='\vskip 1 mm '.$answer.'\end{document}'; |
} |
} |
|
|
|
|
|
|
|
|
|
|
} |
} |
# Print annotations. |
# Print annotations. |
|
|
Line 2405 sub print_page_in_course {
|
Line 2400 sub print_page_in_course {
|
my $annotation .= &annotate($currentURL); |
my $annotation .= &annotate($currentURL); |
$texversion =~ s/(\\keephidden\{ENDOFPROBLEM})/$annotation$1/; |
$texversion =~ s/(\\keephidden\{ENDOFPROBLEM})/$annotation$1/; |
} |
} |
|
|
if ($helper->{'VARS'}->{'TABLE_INDEX'} eq 'yes') { |
if ($helper->{'VARS'}->{'TABLE_INDEX'} eq 'yes') { |
$texversion=&IndexCreation($texversion,$currentURL); |
$texversion=&IndexCreation($texversion,$currentURL); |
} |
} |
Line 2443 sub recently_generated {
|
Line 2438 sub recently_generated {
|
my $pdf_result; |
my $pdf_result; |
opendir(DIR,$prtspool); |
opendir(DIR,$prtspool); |
|
|
my @files = |
my @files = |
grep(/^$env{'user.name'}_$env{'user.domain'}_printout_(\d+)_.*\.(pdf|zip)$/,readdir(DIR)); |
grep(/^$env{'user.name'}_$env{'user.domain'}_printout_(\d+)_.*\.(pdf|zip)$/,readdir(DIR)); |
closedir(DIR); |
closedir(DIR); |
|
|
Line 2523 sub get_page_breaks {
|
Line 2518 sub get_page_breaks {
|
} |
} |
return %page_breaks; |
return %page_breaks; |
} |
} |
# |
# |
# Returns text to insert for any extra vskip prior to the resource. |
# Returns text to insert for any extra vskip prior to the resource. |
# Parameters: |
# Parameters: |
# helper - Reference to the helper object driving the printout. |
# helper - Reference to the helper object driving the printout. |
Line 2534 sub get_page_breaks {
|
Line 2529 sub get_page_breaks {
|
# EXTRASPACE has the list of extra space values. |
# EXTRASPACE has the list of extra space values. |
# EXTRASPACE_UNITS is the set of resources for which the units are |
# EXTRASPACE_UNITS is the set of resources for which the units are |
# mm. All others are 'in'. |
# mm. All others are 'in'. |
# |
# |
# The resource is found in the POSSIBLE_RESOURCES to get the index |
# The resource is found in the POSSIBLE_RESOURCES to get the index |
# of the EXTRASPACE value. |
# of the EXTRASPACE value. |
# |
# |
Line 2603 sub get_extra_vspaces {
|
Line 2598 sub get_extra_vspaces {
|
# The resource chooser part of the helper needs more than just |
# The resource chooser part of the helper needs more than just |
# the value of the extraspaces var to recover the value into a text |
# the value of the extraspaces var to recover the value into a text |
# field option. This sub produces the required format for the saved var: |
# field option. This sub produces the required format for the saved var: |
# specifically |
# specifically |
# ||| separated fields of the form resourcename=value |
# ||| separated fields of the form resourcename=value |
# |
# |
# Parameters: |
# Parameters: |
Line 2637 sub set_form_extraspace {
|
Line 2632 sub set_form_extraspace {
|
$env{'form.extraspace'} = $result; |
$env{'form.extraspace'} = $result; |
$env{'form.extraspace_units'} = $helper->{'VARS'}->{'EXTRASPACE_UNITS'}; |
$env{'form.extraspace_units'} = $helper->{'VARS'}->{'EXTRASPACE_UNITS'}; |
return $result; |
return $result; |
|
|
} |
} |
|
|
# Output a sequence (recursively if neeed) |
# Output a sequence (recursively if neeed) |
Line 2663 sub print_construction_sequence {
|
Line 2658 sub print_construction_sequence {
|
} |
} |
my $errtext=&LONCAPA::map::mapread(&Apache::lonnet::filelocation('',$currentURL)); |
my $errtext=&LONCAPA::map::mapread(&Apache::lonnet::filelocation('',$currentURL)); |
|
|
# |
# |
# These make this all support recursing for subsequences. |
# These make this all support recursing for subsequences. |
# |
# |
my @order = @LONCAPA::map::order; |
my @order = @LONCAPA::map::order; |
my @resources = @LONCAPA::map::resources; |
my @resources = @LONCAPA::map::resources; |
|
|
for (my $member=0;$member<=$#order;$member++) { |
for (my $member=0;$member<=$#order;$member++) { |
$resources[$order[$member]]=~/^([^:]*):([^:]*):/; |
$resources[$order[$member]]=~/^([^:]*):([^:]*):/; |
Line 2683 sub print_construction_sequence {
|
Line 2678 sub print_construction_sequence {
|
$texversion=&ssi_with_retries($urlp, $ssi_retry_count, %form); |
$texversion=&ssi_with_retries($urlp, $ssi_retry_count, %form); |
} |
} |
if((($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'no') || |
if((($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'no') || |
($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'only')) && |
($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'only')) && |
($urlp=~/$LONCAPA::assess_page_re/)) { |
($urlp=~/$LONCAPA::assess_page_re/)) { |
# Don't permanently modify %$form... |
# Don't permanently modify %$form... |
my %answerform = %form; |
my %answerform = %form; |
Line 2698 sub print_construction_sequence {
|
Line 2693 sub print_construction_sequence {
|
$texversion=~s/(\\keephidden\{ENDOFPROBLEM})/$answer$1/; |
$texversion=~s/(\\keephidden\{ENDOFPROBLEM})/$answer$1/; |
} else { |
} else { |
# If necessary, encapsulate answer in minipage: |
# If necessary, encapsulate answer in minipage: |
|
|
$texversion=&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); |
$texversion=&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); |
my $title = &Apache::lonnet::gettitle($helper->{'VARS'}->{'symb'}); |
my $title = &Apache::lonnet::gettitle($helper->{'VARS'}->{'symb'}); |
$title = &Apache::lonxml::latex_special_symbols($title); |
$title = &Apache::lonxml::latex_special_symbols($title); |
Line 2720 sub print_construction_sequence {
|
Line 2715 sub print_construction_sequence {
|
$result.=$texversion; |
$result.=$texversion; |
|
|
} elsif ($urlp=~/\.(sequence|page)$/) { |
} elsif ($urlp=~/\.(sequence|page)$/) { |
|
|
# header: |
# header: |
|
|
$result.='\strut\newline\noindent Sequence/page '.$urlp.'\strut\newline\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}\newline\noindent '; |
$result.='\strut\newline\noindent Sequence/page '.$urlp.'\strut\newline\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}\newline\noindent '; |
|
|
# IF sequence, recurse: |
# IF sequence, recurse: |
|
|
if ($urlp =~ /\.sequence$/) { |
if ($urlp =~ /\.sequence$/) { |
$result .= &print_construction_sequence($urlp, |
$result .= &print_construction_sequence($urlp, |
$helper, %form, |
$helper, %form, |
$LaTeXwidth); |
$LaTeXwidth); |
} |
} |
} |
} |
Line 2744 sub print_construction_sequence {
|
Line 2739 sub print_construction_sequence {
|
if ($member != $#order) { |
if ($member != $#order) { |
$texversion .= '\\ \cleardoublepage'; |
$texversion .= '\\ \cleardoublepage'; |
} |
} |
|
|
$result .= $texversion; |
$result .= $texversion; |
} |
} |
} |
} |
Line 2805 sub output_data {
|
Line 2800 sub output_data {
|
url += 'form=' + formname + '&'; |
url += 'form=' + formname + '&'; |
if (only != null) { |
if (only != null) { |
url += 'only=' + only + '&'; |
url += 'only=' + only + '&'; |
} |
} |
if (omit != null) { |
if (omit != null) { |
url += 'omit=' + omit + '&'; |
url += 'omit=' + omit + '&'; |
} |
} |
Line 2840 ENDPART
|
Line 2835 ENDPART
|
|
|
$env{'form.pagebreaks'} = $helper->{'VARS'}->{'FINISHPAGE'}; |
$env{'form.pagebreaks'} = $helper->{'VARS'}->{'FINISHPAGE'}; |
&set_form_extraspace($helper); |
&set_form_extraspace($helper); |
$env{'form.lastprinttype'} = $print_type; |
$env{'form.lastprinttype'} = $print_type; |
&Apache::loncommon::store_course_settings('print', |
&Apache::loncommon::store_course_settings('print', |
{'pagebreaks' => 'scalar', |
{'pagebreaks' => 'scalar', |
'extraspace' => 'scalar', |
'extraspace' => 'scalar', |
Line 2857 ENDPART
|
Line 2852 ENDPART
|
$laystyle = &map_laystyle($laystyle); |
$laystyle = &map_laystyle($laystyle); |
my ($textwidth,$textheight,$oddoffset,$evenoffset) = &page_format($papersize,$laystyle,$numberofcolumns); |
my ($textwidth,$textheight,$oddoffset,$evenoffset) = &page_format($papersize,$laystyle,$numberofcolumns); |
my $assignment = $env{'form.assignment'}; |
my $assignment = $env{'form.assignment'}; |
my $LaTeXwidth=&recalcto_mm($textwidth); |
my $LaTeXwidth=&recalcto_mm($textwidth); |
my @print_array=(); |
my @print_array=(); |
my @student_names=(); |
my @student_names=(); |
|
|
|
|
# Common settings for the %form hash: |
# Common settings for the %form hash: |
# In some cases these settings get overridden by specific cases, but the |
# In some cases these settings get overridden by specific cases, but the |
# settings are common enough to make it worthwhile factoring them out |
# settings are common enough to make it worthwhile factoring them out |
Line 2873 ENDPART
|
Line 2868 ENDPART
|
$form{'pdfFormFields'} = $pdfFormFields; |
$form{'pdfFormFields'} = $pdfFormFields; |
|
|
# If form.showallfoils is set, then request all foils be shown: |
# If form.showallfoils is set, then request all foils be shown: |
# privilege will be enforced both by not allowing the |
# privilege will be enforced both by not allowing the |
# check box selecting this option to be presnt unless it's ok, |
# check box selecting this option to be presnt unless it's ok, |
# and by lonresponse's priv. check. |
# and by lonresponse's priv. check. |
# The if is here because lonresponse.pm only cares that |
# The if is here because lonresponse.pm only cares that |
# showallfoils is defined, not what the value is. |
# showallfoils is defined, not what the value is. |
|
|
if ($helper->{'VARS'}->{'showallfoils'} eq "1") { |
if ($helper->{'VARS'}->{'showallfoils'} eq "1") { |
$form{'showallfoils'} = $helper->{'VARS'}->{'showallfoils'}; |
$form{'showallfoils'} = $helper->{'VARS'}->{'showallfoils'}; |
} |
} |
|
|
if ($helper->{'VARS'}->{'style_file'}=~/\w/) { |
if ($helper->{'VARS'}->{'style_file'}=~/\w/) { |
&Apache::lonnet::appenv({'construct.style' => |
&Apache::lonnet::appenv({'construct.style' => |
$helper->{'VARS'}->{'style_file'}}); |
$helper->{'VARS'}->{'style_file'}}); |
Line 2935 ENDPART
|
Line 2930 ENDPART
|
$texversion.=&ssi_with_retries($currentURL,$ssi_retry_count, %form); |
$texversion.=&ssi_with_retries($currentURL,$ssi_retry_count, %form); |
|
|
# Add annotations if required: |
# Add annotations if required: |
|
|
&Apache::lonxml::clear_problem_counter(); |
&Apache::lonxml::clear_problem_counter(); |
|
|
&Apache::lonnet::delenv('request.filename'); |
&Apache::lonnet::delenv('request.filename'); |
Line 2978 ENDPART
|
Line 2973 ENDPART
|
|
|
|
|
|
|
|
|
} |
} |
# Print annotations. |
# Print annotations. |
|
|
Line 3004 ENDPART
|
Line 2999 ENDPART
|
&& $currentURL=~/\.(sequence|page)$/ && $helper->{'VARS'}->{'construction'} eq '1') { |
&& $currentURL=~/\.(sequence|page)$/ && $helper->{'VARS'}->{'construction'} eq '1') { |
$result .= &print_construction_sequence($currentURL, $helper, %form, |
$result .= &print_construction_sequence($currentURL, $helper, %form, |
$LaTeXwidth); |
$LaTeXwidth); |
$result .= '\end{document}'; |
$result .= '\end{document}'; |
if (!($result =~ /\\begin\{document\}/)) { |
if (!($result =~ /\\begin\{document\}/)) { |
$result = &print_latex_header() . $result; |
$result = &print_latex_header() . $result; |
} |
} |
# End construction space sequence. |
# End construction space sequence. |
} elsif ($cleanURL=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
} elsif ($cleanURL=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
if ($currentURL=~/\/syllabus$/) {$currentURL=~s/\/res//;} |
if ($currentURL=~/\/syllabus$/) {$currentURL=~s/\/res//;} |
if ($currentURL=~/\/ext\.tool$/) {$currentURL=~s/^\/adm\/wrapper//;} |
if ($currentURL=~/\/ext\.tool$/) {$currentURL=~s/^\/adm\/wrapper//;} |
Line 3045 ENDPART
|
Line 3040 ENDPART
|
$result .= &print_page_in_course($helper, $rparmhash, |
$result .= &print_page_in_course($helper, $rparmhash, |
$cleanURL, \@page_resources); |
$cleanURL, \@page_resources); |
|
|
|
|
} else { |
} else { |
$result.=&unsupported($currentURL,$helper->{'VARS'}->{'LATEX_TYPE'}, |
$result.=&unsupported($currentURL,$helper->{'VARS'}->{'LATEX_TYPE'}, |
$helper->{'VARS'}->{'symb'}); |
$helper->{'VARS'}->{'symb'}); |
Line 3059 ENDPART
|
Line 3054 ENDPART
|
($print_type eq 'select_sequences') or |
($print_type eq 'select_sequences') or |
($print_type eq 'map_incomplete_problems_seq') |
($print_type eq 'map_incomplete_problems_seq') |
) { |
) { |
|
|
#-- produce an output string |
#-- produce an output string |
if (($print_type eq 'map_problems') or |
if (($print_type eq 'map_problems') or |
($print_type eq 'map_incomplete_problems_seq') or |
($print_type eq 'map_incomplete_problems_seq') or |
Line 3069 ENDPART
|
Line 3064 ENDPART
|
($print_type eq 'map_resources_in_page')) |
($print_type eq 'map_resources_in_page')) |
{ |
{ |
$selectionmade = 3; |
$selectionmade = 3; |
} elsif (($print_type eq 'all_problems') |
} elsif (($print_type eq 'all_problems') |
) { |
) { |
$selectionmade = 4; |
$selectionmade = 4; |
} elsif ($print_type eq 'all_resources') { #BUGBUG |
} elsif ($print_type eq 'all_resources') { #BUGBUG |
Line 3134 ENDPART
|
Line 3129 ENDPART
|
$texversion.=&ssi_with_retries($urlp, $ssi_retry_count, %form); |
$texversion.=&ssi_with_retries($urlp, $ssi_retry_count, %form); |
if ($urlp=~/\.page$/) { |
if ($urlp=~/\.page$/) { |
($texversion,my $number_of_columns_page) = &page_cleanup($texversion); |
($texversion,my $number_of_columns_page) = &page_cleanup($texversion); |
if ($number_of_columns_page > $number_of_columns) {$number_of_columns=$number_of_columns_page;} |
if ($number_of_columns_page > $number_of_columns) {$number_of_columns=$number_of_columns_page;} |
$texversion =~ s/\\end\{document}\d*/\\end{document}/; |
$texversion =~ s/\\end\{document}\d*/\\end{document}/; |
$flag_page_in_sequence = 'YES'; |
$flag_page_in_sequence = 'YES'; |
} |
} |
Line 3197 ENDPART
|
Line 3192 ENDPART
|
$prevassignment=$assignment; |
$prevassignment=$assignment; |
my $header_text = $parmhash{'print_header_format'}; |
my $header_text = $parmhash{'print_header_format'}; |
$header_text = &format_page_header($textwidth, $header_text, |
$header_text = &format_page_header($textwidth, $header_text, |
$assignment, |
$assignment, |
$courseidinfo, |
$courseidinfo, |
$name); |
$name); |
if ($numberofcolumns eq '1') { |
if ($numberofcolumns eq '1') { |
$result .='\newpage \noindent\parbox{\minipagewidth}{\noindent\\lhead{'.$header_text.'}} \vskip 5 mm '; |
$result .='\newpage \noindent\parbox{\minipagewidth}{\noindent\\lhead{'.$header_text.'}} \vskip 5 mm '; |
Line 3207 ENDPART
|
Line 3202 ENDPART
|
} |
} |
} |
} |
$result .= $texversion; |
$result .= $texversion; |
$flag_latex_header_remove = 'YES'; |
$flag_latex_header_remove = 'YES'; |
} elsif ($urlp=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
} elsif ($urlp=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
$form{'latex_type'}=$helper->{'VARS'}->{'LATEX_TYPE'}; |
if ($urlp=~/\/syllabus$/) {$urlp=~s/\/res//;} |
if ($urlp=~/\/syllabus$/) {$urlp=~s/\/res//;} |
if ($urlp=~/\/ext\.tool$/) {$urlp=~s/^\/adm\/wrapper//;} |
if ($urlp=~/\/ext\.tool$/) {$urlp=~s/^\/adm\/wrapper//;} |
Line 3225 ENDPART
|
Line 3220 ENDPART
|
$texversion =~ s/\\end\{document}/\\vskip 0\.5mm\\noindent\\makebox\[\\textwidth\/\$number_of_columns\]\[b\]\{\\hrulefill\}/; |
$texversion =~ s/\\end\{document}/\\vskip 0\.5mm\\noindent\\makebox\[\\textwidth\/\$number_of_columns\]\[b\]\{\\hrulefill\}/; |
} |
} |
$result .= $texversion; |
$result .= $texversion; |
$flag_latex_header_remove = 'YES'; |
$flag_latex_header_remove = 'YES'; |
} elsif ($urlp=~ /\.pdf$/i) { |
} elsif ($urlp=~ /\.pdf$/i) { |
if ($i > 0) { |
if ($i > 0) { |
$result .= '\cleardoublepage'; |
$result .= '\cleardoublepage'; |
Line 3256 ENDPART
|
Line 3251 ENDPART
|
$texversion =~ s/\\end\{document}//; |
$texversion =~ s/\\end\{document}//; |
} |
} |
$result .= $texversion; |
$result .= $texversion; |
$flag_latex_header_remove = 'YES'; |
$flag_latex_header_remove = 'YES'; |
} |
} |
if (&Apache::loncommon::connection_aborted($r)) { |
if (&Apache::loncommon::connection_aborted($r)) { |
last; |
last; |
} |
} |
} |
} |
&Apache::lonxml::clear_problem_counter(); |
&Apache::lonxml::clear_problem_counter(); |
Line 3277 ENDPART
|
Line 3272 ENDPART
|
($print_type eq 'select_sequences_resources_for_students')) { |
($print_type eq 'select_sequences_resources_for_students')) { |
|
|
|
|
#-- prints assignments for whole class or for selected students |
#-- prints assignments for whole class or for selected students |
my $type; |
my $type; |
if (($print_type eq 'problems_for_students') || |
if (($print_type eq 'problems_for_students') || |
($print_type eq 'problems_for_students_from_page') || |
($print_type eq 'problems_for_students_from_page') || |
Line 3298 ENDPART
|
Line 3293 ENDPART
|
# to override this and output the students by name. |
# to override this and output the students by name. |
# Each element of the students array is of the form: |
# Each element of the students array is of the form: |
# username:domain:section:last, first:status |
# username:domain:section:last, first:status |
# |
# |
# Note that student sort is not compatible with printing |
# Note that student sort is not compatible with printing |
# 1 section per pdf...so that setting overrides. |
# 1 section per pdf...so that setting overrides. |
# |
# |
if (($helper->{'VARS'}->{'student_sort'} eq 1) && |
if (($helper->{'VARS'}->{'student_sort'} eq 1) && |
($helper->{'VARS'}->{'SPLIT_PDFS'} ne "sections")) { |
($helper->{'VARS'}->{'SPLIT_PDFS'} ne "sections")) { |
@students = sort compare_names @students; |
@students = sort compare_names @students; |
} else { |
} else { |
@students = sort compare_sections @students; |
@students = sort compare_sections @students; |
} |
} |
&adjust_number_to_print($helper); |
&adjust_number_to_print($helper); |
|
|
Line 3314 ENDPART
|
Line 3309 ENDPART
|
$helper->{'VARS'}->{'NUMBER_TO_PRINT'} eq 'all' ) { |
$helper->{'VARS'}->{'NUMBER_TO_PRINT'} eq 'all' ) { |
$helper->{'VARS'}->{'NUMBER_TO_PRINT'}=$#students+1; |
$helper->{'VARS'}->{'NUMBER_TO_PRINT'}=$#students+1; |
} |
} |
# If we are splitting on section boundaries, we need |
# If we are splitting on section boundaries, we need |
# to remember that in split_on_sections and |
# to remember that in split_on_sections and |
# print all of the students in the list. |
# print all of the students in the list. |
# |
# |
my $split_on_sections = 0; |
my $split_on_sections = 0; |
Line 3409 ENDPART
|
Line 3404 ENDPART
|
my ($code_type,$code_length,$bubbles_per_row)=('letter',6,10); |
my ($code_type,$code_length,$bubbles_per_row)=('letter',6,10); |
foreach my $line (@lines) { |
foreach my $line (@lines) { |
next if (($line =~ /^\#/) || ($line eq '')); |
next if (($line =~ /^\#/) || ($line eq '')); |
my ($name,$type,$length,$bubbles_per_item) = |
my ($name,$type,$length,$bubbles_per_item) = |
(split(/:/,$line))[0,2,4,17]; |
(split(/:/,$line))[0,2,4,17]; |
if ($name eq $code_option) { |
if ($name eq $code_option) { |
$code_length=$length; |
$code_length=$length; |
if ($type eq 'number') { $code_type = 'number'; } |
if ($type eq 'number') { $code_type = 'number'; } |
chomp($bubbles_per_item); |
chomp($bubbles_per_item); |
if (($bubbles_per_item ne '') && ($bubbles_per_item > 0)) { |
if (($bubbles_per_item ne '') && ($bubbles_per_item > 0)) { |
$bubbles_per_row = $bubbles_per_item; |
$bubbles_per_row = $bubbles_per_item; |
} |
} |
} |
} |
} |
} |
Line 3481 ENDPART
|
Line 3476 ENDPART
|
|| $number_per_page eq 'section') { |
|| $number_per_page eq 'section') { |
$number_per_page=$num_todo > 0 ? $num_todo : 1; |
$number_per_page=$num_todo > 0 ? $num_todo : 1; |
} |
} |
my $flag_latex_header_remove = 'NO'; |
my $flag_latex_header_remove = 'NO'; |
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin($r,$num_todo); |
my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin($r,$num_todo); |
my $count=0; |
my $count=0; |
my $nohidemap; |
my $nohidemap; |
Line 3490 ENDPART
|
Line 3485 ENDPART
|
} |
} |
foreach my $code (sort(@allcodes)) { |
foreach my $code (sort(@allcodes)) { |
my $file_num=int($count/$number_per_page); |
my $file_num=int($count/$number_per_page); |
if ($code_type eq 'number') { |
if ($code_type eq 'number') { |
$moreenv{'CODE'}=$code; |
$moreenv{'CODE'}=$code; |
} else { |
} else { |
$moreenv{'CODE'}=&num_to_letters($code); |
$moreenv{'CODE'}=&num_to_letters($code); |
Line 3515 ENDPART
|
Line 3510 ENDPART
|
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
&Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state); |
$result .= $print_array[0].' \end{document}'; |
$result .= $print_array[0].' \end{document}'; |
} elsif ($print_type eq 'problems_from_directory') { |
} elsif ($print_type eq 'problems_from_directory') { |
#prints selected problems from the subdirectory |
#prints selected problems from the subdirectory |
$selectionmade = 6; |
$selectionmade = 6; |
my @list_of_files=split /\|\|\|/, $helper->{'VARS'}->{'FILES'}; |
my @list_of_files=split /\|\|\|/, $helper->{'VARS'}->{'FILES'}; |
@list_of_files=sort @list_of_files; |
@list_of_files=sort @list_of_files; |
my $flag_latex_header_remove = 'NO'; |
my $flag_latex_header_remove = 'NO'; |
my $rndseed=time; |
my $rndseed=time; |
if ($helper->{'VARS'}->{'curseed'}) { |
if ($helper->{'VARS'}->{'curseed'}) { |
$rndseed=$helper->{'VARS'}->{'curseed'}; |
$rndseed=$helper->{'VARS'}->{'curseed'}; |
Line 3575 ENDPART
|
Line 3570 ENDPART
|
} |
} |
if ($helper->{'VARS'}->{'CONSTR_RESOURSE_URL'} eq 'yes') { |
if ($helper->{'VARS'}->{'CONSTR_RESOURSE_URL'} eq 'yes') { |
$texversion=~s/(\\addcontentsline\{toc\}\{subsection\}\{[^\}]*\})/$1 URL: \\verb|$urlp| \\strut\\\\\\strut /; |
$texversion=~s/(\\addcontentsline\{toc\}\{subsection\}\{[^\}]*\})/$1 URL: \\verb|$urlp| \\strut\\\\\\strut /; |
|
|
} |
} |
$result .= $texversion; |
$result .= $texversion; |
} |
} |
$flag_latex_header_remove = 'YES'; |
$flag_latex_header_remove = 'YES'; |
} |
} |
if ($helper->{VARS}->{'construction'} eq '1') {$result=~s/(\\typeout)/ RANDOM SEED IS $rndseed $1/;} |
if ($helper->{VARS}->{'construction'} eq '1') {$result=~s/(\\typeout)/ RANDOM SEED IS $rndseed $1/;} |
$result .= '\end{document}'; |
$result .= '\end{document}'; |
Line 3628 ENDPART
|
Line 3623 ENDPART
|
} |
} |
} |
} |
if ($env{'request.enc'}) { |
if ($env{'request.enc'}) { |
$url = &Apache::lonenc::encrypted($url); |
$url = &Apache::lonenc::encrypted($url); |
} |
} |
if ($url ne '') { |
if ($url ne '') { |
my $symb = $helper->{VARS}{'symb'}; |
my $symb = $helper->{VARS}{'symb'}; |
Line 3663 ENDPART
|
Line 3658 ENDPART
|
$result = &collect_languages($result); |
$result = &collect_languages($result); |
|
|
|
|
#-- writing .tex file in prtspool |
#-- writing .tex file in prtspool |
my $temp_file; |
my $temp_file; |
my $identifier = &Apache::loncommon::get_cgi_id(); |
my $identifier = &Apache::loncommon::get_cgi_id(); |
my $filename = "/home/httpd/prtspool/$env{'user.name'}_$env{'user.domain'}_printout_$identifier.tex"; |
my $filename = "/home/httpd/prtspool/$env{'user.name'}_$env{'user.domain'}_printout_$identifier.tex"; |
if (!($#print_array>0)) { |
if (!($#print_array>0)) { |
unless ($temp_file = Apache::File->new('>'.$filename)) { |
unless ($temp_file = Apache::File->new('>'.$filename)) { |
$r->log_error("Couldn't open $filename for output $!"); |
$r->log_error("Couldn't open $filename for output $!"); |
return SERVER_ERROR; |
return SERVER_ERROR; |
} |
} |
print $temp_file $result; |
print $temp_file $result; |
my $begin=index($result,'\begin{document}',0); |
my $begin=index($result,'\begin{document}',0); |
my $inc=substr($result,0,$begin+16); |
my $inc=substr($result,0,$begin+16); |
} else { |
} else { |
my $begin=index($result,'\begin{document}',0); |
my $begin=index($result,'\begin{document}',0); |
my $inc=substr($result,0,$begin+16); |
my $inc=substr($result,0,$begin+16); |
Line 3683 ENDPART
|
Line 3678 ENDPART
|
$print_array[$i]=$result; |
$print_array[$i]=$result; |
} else { |
} else { |
$print_array[$i].='\end{document}'; |
$print_array[$i].='\end{document}'; |
$print_array[$i] = |
$print_array[$i] = |
&latex_corrections($number_of_columns,$print_array[$i], |
&latex_corrections($number_of_columns,$print_array[$i], |
$selectionmade, |
$selectionmade, |
$helper->{'VARS'}->{'ANSWER_TYPE'}); |
$helper->{'VARS'}->{'ANSWER_TYPE'}); |
|
|
my $anobegin=index($print_array[$i],'\setcounter{page}',0); |
my $anobegin=index($print_array[$i],'\setcounter{page}',0); |
substr($print_array[$i],0,$anobegin)=''; |
substr($print_array[$i],0,$anobegin)=''; |
$print_array[$i]=$inc.$print_array[$i]; |
$print_array[$i]=$inc.$print_array[$i]; |
Line 3695 ENDPART
|
Line 3690 ENDPART
|
my $temp_file; |
my $temp_file; |
my $newfilename=$filename; |
my $newfilename=$filename; |
my $num=$i+1; |
my $num=$i+1; |
$newfilename =~s/\.tex$//; |
$newfilename =~s/\.tex$//; |
$newfilename=sprintf("%s_%03d.tex",$newfilename, $num); |
$newfilename=sprintf("%s_%03d.tex",$newfilename, $num); |
unless ($temp_file = Apache::File->new('>'.$newfilename)) { |
unless ($temp_file = Apache::File->new('>'.$newfilename)) { |
$r->log_error("Couldn't open $newfilename for output $!"); |
$r->log_error("Couldn't open $newfilename for output $!"); |
return SERVER_ERROR; |
return SERVER_ERROR; |
} |
} |
print $temp_file $print_array[$i]; |
print $temp_file $print_array[$i]; |
} |
} |
Line 3737 ENDPART
|
Line 3732 ENDPART
|
'cgi.'.$identifier.'.backref' => &escape($URLback),}); |
'cgi.'.$identifier.'.backref' => &escape($URLback),}); |
&Apache::lonnet::appenv({"cgi.$identifier.user" => $env{'user.name'}, |
&Apache::lonnet::appenv({"cgi.$identifier.user" => $env{'user.name'}, |
"cgi.$identifier.domain" => $env{'user.domain'}, |
"cgi.$identifier.domain" => $env{'user.domain'}, |
"cgi.$identifier.courseid" => $cnum, |
"cgi.$identifier.courseid" => $cnum, |
"cgi.$identifier.coursedom" => $cdom, |
"cgi.$identifier.coursedom" => $cdom, |
"cgi.$identifier.resources" => $resources_printed}); |
"cgi.$identifier.resources" => $resources_printed}); |
|
|
my $end_page = &Apache::loncommon::end_page(); |
my $end_page = &Apache::loncommon::end_page(); |
Line 3785 sub get_CODE {
|
Line 3780 sub get_CODE {
|
sub print_resources { |
sub print_resources { |
my ($r,$helper,$person,$type,$moreenv,$master_seq,$remove_latex_header, |
my ($r,$helper,$person,$type,$moreenv,$master_seq,$remove_latex_header, |
$LaTeXwidth)=@_; |
$LaTeXwidth)=@_; |
my $current_output = ''; |
my $current_output = ''; |
my $printed = ''; |
my $printed = ''; |
my ($username,$userdomain,$usersection) = split /:/,$person; |
my ($username,$userdomain,$usersection) = split /:/,$person; |
my $fullname = &get_name($username,$userdomain); |
my $fullname = &get_name($username,$userdomain); |
Line 3812 sub print_resources {
|
Line 3807 sub print_resources {
|
|
|
my $i = 0; |
my $i = 0; |
my $actually_printed = 0; # Count of resources printed. |
my $actually_printed = 0; # Count of resources printed. |
#goes through all resources, checks if they are available for |
#goes through all resources, checks if they are available for |
#current student, and produces output |
#current student, and produces output |
|
|
&Apache::lonxml::clear_problem_counter(); |
&Apache::lonxml::clear_problem_counter(); |
my %page_breaks = &get_page_breaks($helper); |
my %page_breaks = &get_page_breaks($helper); |
my $columns_in_format = (split(/\|/,$helper->{'VARS'}->{'FORMAT'}))[1]; |
my $columns_in_format = (split(/\|/,$helper->{'VARS'}->{'FORMAT'}))[1]; |
# |
# |
# end each student with a |
# end each student with a |
# Special that allows the post processor to even out the page |
# Special that allows the post processor to even out the page |
# counts later. Nasty problem this... it would be really |
# counts later. Nasty problem this... it would be really |
# nice to put the special in as a postscript comment |
# nice to put the special in as a postscript comment |
Line 3847 sub print_resources {
|
Line 3842 sub print_resources {
|
|
|
# See if we need to emit a new header: |
# See if we need to emit a new header: |
|
|
if ( !($type eq 'problems' && |
if ( !($type eq 'problems' && |
($curresline!~ m/$LONCAPA::assess_page_re/)) ) { |
($curresline!~ m/$LONCAPA::assess_page_re/)) ) { |
if ($print_incomplete && !&incomplete($username, $userdomain, $res_url)) { |
if ($print_incomplete && !&incomplete($username, $userdomain, $res_url)) { |
next; |
next; |
Line 3858 sub print_resources {
|
Line 3853 sub print_resources {
|
if ($res_url!~m|^ext/| |
if ($res_url!~m|^ext/| |
&& $res_url=~/\.(problem|exam|quiz|assess|survey|form|library|page|xml|html|htm|xhtml|xhtm)$/) { |
&& $res_url=~/\.(problem|exam|quiz|assess|survey|form|library|page|xml|html|htm|xhtml|xhtm)$/) { |
$printed .= $curresline.':'; |
$printed .= $curresline.':'; |
&Apache::lonxml::remember_problem_counter(); |
&Apache::lonxml::remember_problem_counter(); |
|
|
my $rendered = &get_student_view_with_retries($curresline,$ssi_retry_count,$username,$userdomain,$env{'request.course.id'},'tex',$moreenv); |
my $rendered = &get_student_view_with_retries($curresline,$ssi_retry_count,$username,$userdomain,$env{'request.course.id'},'tex',$moreenv); |
if ($res_url =~ /\.page$/) { |
if ($res_url =~ /\.page$/) { |
Line 3890 sub print_resources {
|
Line 3885 sub print_resources {
|
if ($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'no') { |
if ($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'no') { |
$rendered=~s/(\\keephidden\{ENDOFPROBLEM})/$ansrendered$1/; |
$rendered=~s/(\\keephidden\{ENDOFPROBLEM})/$ansrendered$1/; |
} else { |
} else { |
|
|
|
|
my $header =&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); |
my $header =&print_latex_header($helper->{'VARS'}->{'LATEX_TYPE'}); |
unless ($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'only') { |
unless ($helper->{'VARS'}->{'ANSWER_TYPE'} eq 'only') { |
$header =~ s/\\begin\{document}//; #<<<<< |
$header =~ s/\\begin\{document}//; #<<<<< |
Line 3916 sub print_resources {
|
Line 3909 sub print_resources {
|
} else { |
} else { |
$rendered =~ s/\\end\{document}//; |
$rendered =~ s/\\end\{document}//; |
} |
} |
$current_output .= $rendered; |
$current_output .= $rendered; |
} elsif ($res_url=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
} elsif ($res_url=~/\/(smppg|syllabus|aboutme|bulletinboard|ext\.tool)$/) { |
if ($i == 1) { |
if ($i == 1) { |
$syllabus_first = 1; |
$syllabus_first = 1; |
Line 3957 sub print_resources {
|
Line 3950 sub print_resources {
|
&Apache::lonnet::gettitle($map), 'header'); |
&Apache::lonnet::gettitle($map), 'header'); |
if (($assignment ne $current_assignment) && ($assignment ne "")) { |
if (($assignment ne $current_assignment) && ($assignment ne "")) { |
my $header_line = &format_page_header($LaTeXwidth, $parmhash{'print_header_format'}, |
my $header_line = &format_page_header($LaTeXwidth, $parmhash{'print_header_format'}, |
$assignment, $courseidinfo, |
$assignment, $courseidinfo, |
$fullname, $usersection); |
$fullname, $usersection); |
my $header_start = ($columns_in_format == 1) ? '\lhead' |
my $header_start = ($columns_in_format == 1) ? '\lhead' |
: '\fancyhead[LO]'; |
: '\fancyhead[LO]'; |
Line 3990 sub print_resources {
|
Line 3983 sub print_resources {
|
} elsif ($print_incomplete) { |
} elsif ($print_incomplete) { |
$message = &mt('No incomplete resources'); |
$message = &mt('No incomplete resources'); |
} |
} |
if ($message) { |
if ($message) { |
$current_output = &encapsulate_minipage("\\vskip -10mm \n$message\n \\vskip 100 mm { }\n",$moreenv->{'problem_split'}); |
$current_output = &encapsulate_minipage("\\vskip -10mm \n$message\n \\vskip 100 mm { }\n",$moreenv->{'problem_split'}); |
} |
} |
if ($remove_latex_header eq "NO") { |
if ($remove_latex_header eq "NO") { |
Line 4013 sub print_resources {
|
Line 4006 sub print_resources {
|
$current_output =~ s/\\begin\{document}/\\setlength{\\topmargin}{1cm} \\begin{document}\\noindent\\parbox{\\minipagewidth}{\\noindent$newheader$namepostfix}\\vskip 5 mm /; |
$current_output =~ s/\\begin\{document}/\\setlength{\\topmargin}{1cm} \\begin{document}\\noindent\\parbox{\\minipagewidth}{\\noindent$newheader$namepostfix}\\vskip 5 mm /; |
|
|
} else { |
} else { |
my $blankpages = |
my $blankpages = |
'\clearpage\strut\clearpage'x$helper->{'VARS'}->{'EMPTY_PAGES'}; |
'\clearpage\strut\clearpage'x$helper->{'VARS'}->{'EMPTY_PAGES'}; |
|
|
$current_output = '\strut\vspace*{-6 mm}\\newline'. |
$current_output = '\strut\vspace*{-6 mm}\\newline'. |
Line 4054 sub handler {
|
Line 4047 sub handler {
|
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $clientip = &Apache::lonnet::get_requestor_ip($r); |
my $clientip = &Apache::lonnet::get_requestor_ip($r); |
my ($blocked,$blocktext) = |
my ($blocked,$blocktext) = |
&Apache::loncommon::blocking_status('printout',$clientip,$cnum,$cdom); |
&Apache::loncommon::blocking_status('printout',$clientip,$cnum,$cdom); |
if ($blocked) { |
if ($blocked) { |
my $checkrole = "cm./$cdom/$cnum"; |
my $checkrole = "cm./$cdom/$cnum"; |
if ($env{'request.course.sec'} ne '') { |
if ($env{'request.course.sec'} ne '') { |
$checkrole .= "/$env{'request.course.sec'}"; |
$checkrole .= "/$env{'request.course.sec'}"; |
} |
} |
unless ((&Apache::lonnet::allowed('evb',undef,undef,$checkrole)) && |
unless ((&Apache::lonnet::allowed('evb',undef,undef,$checkrole)) && |
($env{'request.role'} !~ m{^st\./$cdom/$cnum})) { |
($env{'request.role'} !~ m{^st\./$cdom/$cnum})) { |
&printing_blocked($r,$blocktext); |
&printing_blocked($r,$blocktext); |
return OK; |
return OK; |
} |
} |
} |
} |
} |
} |
|
|
&init_perm(); |
&init_perm(); |
my $helper = printHelper($r); |
my $helper = printHelper($r); |
if (!ref($helper)) { |
if (!ref($helper)) { |
return $helper; |
return $helper; |
} |
} |
|
|
|
|
%parmhash=&Apache::lonnet::coursedescription($env{'request.course.id'}); |
|
|
|
|
|
|
|
|
%parmhash=&Apache::lonnet::coursedescription($env{'request.course.id'}); |
|
|
# If a figure conversion queue file exists for this user.domain |
# If a figure conversion queue file exists for this user.domain |
# we delete it since it can only be bad (if it were good, printout.pl |
# we delete it since it can only be bad (if it were good, printout.pl |
Line 4089 sub handler {
|
Line 4079 sub handler {
|
if(-e $conversion_queuefile) { |
if(-e $conversion_queuefile) { |
unlink $conversion_queuefile; |
unlink $conversion_queuefile; |
} |
} |
|
|
|
|
&output_data($r,$helper,\%parmhash); |
&output_data($r,$helper,\%parmhash); |
return OK; |
return OK; |
Line 4135 sub get_randomly_ordered_warning {
|
Line 4124 sub get_randomly_ordered_warning {
|
if (defined($navmap)) { |
if (defined($navmap)) { |
my $res = $navmap->getResourceByUrl($map); |
my $res = $navmap->getResourceByUrl($map); |
if ($res) { |
if ($res) { |
my $func = |
my $func = |
sub { return ($_[0]->is_map() && $_[0]->randomorder); }; |
sub { return ($_[0]->is_map() && $_[0]->randomorder); }; |
my @matches = $navmap->retrieveResources($res, $func,1,1,1); |
my @matches = $navmap->retrieveResources($res, $func,1,1,1); |
|
|
} |
} |
} else { |
} else { |
$message = "Retrieval of information about ordering of resources failed."; |
$message = "Retrieval of information about ordering of resources failed."; |
return '<message type="warning">'.$message.'</message>'; |
return '<message type="warning">'.$message.'</message>'; |
} |
} |
return; |
return; |
Line 4174 sub printHelper {
|
Line 4163 sub printHelper {
|
# write it by hand |
# write it by hand |
|
|
Apache::loncommon::get_unprocessed_cgi($ENV{QUERY_STRING}); |
Apache::loncommon::get_unprocessed_cgi($ENV{QUERY_STRING}); |
|
|
my $helper = Apache::lonhelper::helper->new("Printing Helper"); |
my $helper = Apache::lonhelper::helper->new("Printing Helper"); |
$helper->declareVar('symb'); |
$helper->declareVar('symb'); |
$helper->declareVar('postdata'); |
$helper->declareVar('postdata'); |
$helper->declareVar('curseed'); |
$helper->declareVar('curseed'); |
$helper->declareVar('probstatus'); |
$helper->declareVar('probstatus'); |
$helper->declareVar('filename'); |
$helper->declareVar('filename'); |
$helper->declareVar('construction'); |
$helper->declareVar('construction'); |
$helper->declareVar('assignment'); |
$helper->declareVar('assignment'); |
Line 4191 sub printHelper {
|
Line 4180 sub printHelper {
|
$helper->declareVar("STUDENTS"); |
$helper->declareVar("STUDENTS"); |
$helper->declareVar("EXTRASPACE"); |
$helper->declareVar("EXTRASPACE"); |
|
|
|
|
|
|
|
|
# The page breaks and extra spaces |
# The page breaks and extra spaces |
Line 4199 sub printHelper {
|
Line 4188 sub printHelper {
|
# But we only do this in the initial state so that they are allowed to change. |
# But we only do this in the initial state so that they are allowed to change. |
# |
# |
|
|
|
|
&Apache::loncommon::restore_course_settings('print', |
&Apache::loncommon::restore_course_settings('print', |
{'pagebreaks' => 'scalar', |
{'pagebreaks' => 'scalar', |
'extraspace' => 'scalar', |
'extraspace' => 'scalar', |
'extraspace_units' => 'scalar', |
'extraspace_units' => 'scalar', |
'lastprinttype' => 'scalar'}); |
'lastprinttype' => 'scalar'}); |
|
|
# This will persistently load in the data we want from the |
# This will persistently load in the data we want from the |
# very first screen. |
# very first screen. |
|
|
if($helper->{VARS}->{PRINT_TYPE} eq $env{'form.lastprinttype'}) { |
if($helper->{VARS}->{PRINT_TYPE} eq $env{'form.lastprinttype'}) { |
if (!defined ($env{"form.CURRENT_STATE"})) { |
if (!defined ($env{"form.CURRENT_STATE"})) { |
|
|
$helper->{VARS}->{FINISHPAGE} = $env{'form.pagebreaks'}; |
$helper->{VARS}->{FINISHPAGE} = $env{'form.pagebreaks'}; |
$helper->{VARS}->{EXTRASPACE} = $env{'form.extraspace'}; |
$helper->{VARS}->{EXTRASPACE} = $env{'form.extraspace'}; |
$helper->{VARS}->{EXTRASPACE_UNITS} = $env{'form.extraspace_units'}; |
$helper->{VARS}->{EXTRASPACE_UNITS} = $env{'form.extraspace_units'}; |
Line 4282 sub printHelper {
|
Line 4271 sub printHelper {
|
} |
} |
if ($sequenceTitle ne '') {$helper->{VARS}->{'assignment'}=$sequenceTitle;} |
if ($sequenceTitle ne '') {$helper->{VARS}->{'assignment'}=$sequenceTitle;} |
|
|
|
|
# Extract map |
# Extract map |
my $symb = $helper->{VARS}->{'symb'}; |
my $symb = $helper->{VARS}->{'symb'}; |
my ($map, $id, $url); |
my ($map, $id, $url); |
my $subdir; |
my $subdir; |
my $is_published=0; # True when printing from resource space. |
my $is_published=0; # True when printing from resource space. |
my $res_printable = 1; # By default the current resource is printable. |
my $res_printable = 1; # By default the current resource is printable. |
my $res_error; |
my $res_error; |
my $userCanPrint = ($perm{'pav'} || $perm{'pfo'}); |
my $userCanPrint = ($perm{'pav'} || $perm{'pfo'}); |
my $res_printstartdate; |
my $res_printstartdate; |
Line 4300 sub printHelper {
|
Line 4288 sub printHelper {
|
|
|
# Get the resource name from construction space |
# Get the resource name from construction space |
if ($helper->{VARS}->{'construction'}) { |
if ($helper->{VARS}->{'construction'}) { |
$resourceTitle = substr($helper->{VARS}->{'filename'}, |
$resourceTitle = substr($helper->{VARS}->{'filename'}, |
rindex($helper->{VARS}->{'filename'}, '/')+1); |
rindex($helper->{VARS}->{'filename'}, '/')+1); |
$subdir = substr($helper->{VARS}->{'filename'}, |
$subdir = substr($helper->{VARS}->{'filename'}, |
0, rindex($helper->{VARS}->{'filename'}, '/') + 1); |
0, rindex($helper->{VARS}->{'filename'}, '/') + 1); |
Line 4309 sub printHelper {
|
Line 4297 sub printHelper {
|
|
|
if ($symb ne '') { |
if ($symb ne '') { |
($map, $id, $url) = &Apache::lonnet::decode_symb($symb); |
($map, $id, $url) = &Apache::lonnet::decode_symb($symb); |
$helper->{VARS}->{'postdata'} = |
$helper->{VARS}->{'postdata'} = |
&Apache::lonenc::check_encrypt(&Apache::lonnet::clutter($url)); |
&Apache::lonenc::check_encrypt(&Apache::lonnet::clutter($url)); |
} elsif (($helper->{VARS}->{'postdata'} eq '/adm/navmaps') && |
} elsif (($helper->{VARS}->{'postdata'} eq '/adm/navmaps') && |
($env{'request.course.id'} ne '')) { |
($env{'request.course.id'} ne '')) { |
Line 4335 sub printHelper {
|
Line 4323 sub printHelper {
|
($course_open, $course_close) = &course_print_dates($res); |
($course_open, $course_close) = &course_print_dates($res); |
($map_open, $map_close) = &map_print_dates($res); |
($map_open, $map_close) = &map_print_dates($res); |
} else { |
} else { |
$res_error = 1; |
$res_error = 1; |
} |
} |
} else { |
} else { |
$res_error = 1; |
$res_error = 1; |
Line 4394 sub printHelper {
|
Line 4382 sub printHelper {
|
|
|
if ($resourceTitle && $res_printable) { |
if ($resourceTitle && $res_printable) { |
push @{$printChoices}, ["<b><i>$resourceTitle</i></b> (".&mt('the resource you just saw on the screen').")", 'current_document', 'PAGESIZE']; |
push @{$printChoices}, ["<b><i>$resourceTitle</i></b> (".&mt('the resource you just saw on the screen').")", 'current_document', 'PAGESIZE']; |
} |
} |
|
|
# Useful filter strings |
# Useful filter strings |
|
|
Line 4419 sub printHelper {
|
Line 4407 sub printHelper {
|
|
|
my $start_new_option; |
my $start_new_option; |
if ($perm{'pav'}) { |
if ($perm{'pav'}) { |
$start_new_option = |
$start_new_option = |
"<option text='".&mt('Start new page[_1]before selected','<br />'). |
"<option text='".&mt('Start new page[_1]before selected','<br />'). |
"' variable='FINISHPAGE' />". |
"' variable='FINISHPAGE' />". |
"<option text='".&mt('Extra space[_1]before selected','<br />'). |
"<option text='".&mt('Extra space[_1]before selected','<br />'). |
Line 4429 sub printHelper {
|
Line 4417 sub printHelper {
|
"<option text='".&mt('Space units[_1]check for mm','<br />'). |
"<option text='".&mt('Space units[_1]check for mm','<br />'). |
"' variable='EXTRASPACE_UNITS' type='checkbox' />" |
"' variable='EXTRASPACE_UNITS' type='checkbox' />" |
; |
; |
|
|
|
|
} |
} |
|
|
# If not construction space user can print the components of a page: |
# If not construction space user can print the components of a page: |
Line 4449 sub printHelper {
|
Line 4435 sub printHelper {
|
my $resourcesymb = $page_resources[0]->symb(); |
my $resourcesymb = $page_resources[0]->symb(); |
my ($pagemap, $pageid, $pageurl) = &Apache::lonnet::decode_symb($symb); |
my ($pagemap, $pageid, $pageurl) = &Apache::lonnet::decode_symb($symb); |
if ($page_ispage) { |
if ($page_ispage) { |
push @{$printChoices}, |
push @{$printChoices}, |
[&mt('Selected [_1]Problems[_2] from page [_3]', '<b>', '</b>', '<b><i>'.$page_title.'</i></b>'), |
[&mt('Selected [_1]Problems[_2] from page [_3]', '<b>', '</b>', '<b><i>'.$page_title.'</i></b>'), |
'map_problems_in_page', |
'map_problems_in_page', |
'CHOOSE_PROBLEMS_PAGE']; |
'CHOOSE_PROBLEMS_PAGE']; |
push @{$printChoices}, |
push @{$printChoices}, |
[&mt('Selected [_1]Resources[_2] from page [_3]', '<b>', '</b>', '<b><i>'.$page_title.'</i></b>'), |
[&mt('Selected [_1]Resources[_2] from page [_3]', '<b>', '</b>', '<b><i>'.$page_title.'</i></b>'), |
'map_resources_in_page', |
'map_resources_in_page', |
'CHOOSE_RESOURCES_PAGE']; |
'CHOOSE_RESOURCES_PAGE']; |
} |
} |
my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS_PAGE', |
my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS_PAGE', |
Line 4509 sub printHelper {
|
Line 4495 sub printHelper {
|
$nextState = 'CHOOSE_INCOMPLETE_PEOPLE_SEQ'; |
$nextState = 'CHOOSE_INCOMPLETE_PEOPLE_SEQ'; |
$textSuffix = ' for selected students'; |
$textSuffix = ' for selected students'; |
my $helperStates = |
my $helperStates = |
&create_incomplete_folder_selstud_helper($helper, $map, $nocurrloc); |
&create_incomplete_folder_selstud_helper($helper, $map, $nocurrloc); |
&Apache::lonxml::xmlparse($r, 'helper', $helperStates); |
&Apache::lonxml::xmlparse($r, 'helper', $helperStates); |
} else { |
} else { |
if (&printable($map_open, $map_close)) { |
if (&printable($map_open, $map_close)) { |
Line 4540 sub printHelper {
|
Line 4526 sub printHelper {
|
} else { |
} else { |
$optionText = &mt('Selected [_1]Problems[_2] from folder [_3]','<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>'); |
$optionText = &mt('Selected [_1]Problems[_2] from folder [_3]','<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>'); |
} |
} |
push @{$printChoices}, |
push @{$printChoices}, |
[$optionText, |
[$optionText, |
'map_problems', |
'map_problems', |
'CHOOSE_PROBLEMS']; |
'CHOOSE_PROBLEMS']; |
# Allow all resources from sequence |
# Allow all resources from sequence |
if ($helper->{VARS}->{'postdata'} eq '/adm/navmaps') { |
if ($helper->{VARS}->{'postdata'} eq '/adm/navmaps') { |
Line 4550 sub printHelper {
|
Line 4536 sub printHelper {
|
} else { |
} else { |
$optionText = &mt('Selected [_1]Resources[_2] from folder [_3]','<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>'); |
$optionText = &mt('Selected [_1]Resources[_2] from folder [_3]','<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>'); |
} |
} |
push @{$printChoices}, [$optionText, |
push @{$printChoices}, [$optionText, |
'map_problems_pages', |
'map_problems_pages', |
'CHOOSE_PROBLEMS_HTML']; |
'CHOOSE_PROBLEMS_HTML']; |
my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS', |
my $helperFragment = &generate_resource_chooser('CHOOSE_PROBLEMS', |
'Select Problem(s) to print', |
'Select Problem(s) to print', |
Line 4571 sub printHelper {
|
Line 4557 sub printHelper {
|
$isNotMap, '', |
$isNotMap, '', |
$symbFilter, |
$symbFilter, |
$start_new_option); |
$start_new_option); |
|
|
&Apache::lonxml::xmlparse($r, 'helper', $helperFragment); |
&Apache::lonxml::xmlparse($r, 'helper', $helperFragment); |
} else { |
} else { |
# TODO: Figure out how to tell them the folder is not printable. |
# TODO: Figure out how to tell them the folder is not printable. |
} |
} |
} |
} |
# If the user has pfo (print for others) allow them to print all |
# If the user has pfo (print for others) allow them to print all |
# problems and resources in the entire course, optionally for selected students |
# problems and resources in the entire course, optionally for selected students |
my $post_data = $helper->{VARS}->{'postdata'}; |
my $post_data = $helper->{VARS}->{'postdata'}; |
|
|
if ($perm{'pfo'} && !$is_published && |
if ($perm{'pfo'} && !$is_published && |
($post_data=~/\/res\// || $post_data =~/\/(syllabus|smppg|aboutme|bulletinboard)$/)) { |
($post_data=~/\/res\// || $post_data =~/\/(syllabus|smppg|aboutme|bulletinboard)$/)) { |
|
|
Line 4610 my $suffixXml = <<ALL_PROBLEMS;
|
Line 4596 my $suffixXml = <<ALL_PROBLEMS;
|
<student multichoice='1' variable="STUDENTS" nextstate="PRINT_FORMATTING" coursepersonnel="1"/> |
<student multichoice='1' variable="STUDENTS" nextstate="PRINT_FORMATTING" coursepersonnel="1"/> |
</state> |
</state> |
ALL_PROBLEMS |
ALL_PROBLEMS |
&Apache::lonxml::xmlparse($r, 'helper', |
&Apache::lonxml::xmlparse($r, 'helper', |
&generate_resource_chooser('ALL_PROBLEMS', |
&generate_resource_chooser('ALL_PROBLEMS', |
'Select Problem(s) to print', |
'Select Problem(s) to print', |
'multichoice="1" suppressEmptySequences="0" addstatus="1" closeallpages="1" modallink="1"', |
'multichoice="1" suppressEmptySequences="0" addstatus="1" closeallpages="1" modallink="1"', |
Line 4653 ALL_PROBLEMS
|
Line 4639 ALL_PROBLEMS
|
'problems_for_anon_page', 'CHOOSE_ANON1_PAGE']; |
'problems_for_anon_page', 'CHOOSE_ANON1_PAGE']; |
} |
} |
push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]selected people[_5]', |
push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]selected people[_5]', |
'<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>','<b>','</b>'), |
'<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>','<b>','</b>'), |
'problems_for_students', 'CHOOSE_STUDENTS']; |
'problems_for_students', 'CHOOSE_STUDENTS']; |
push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]CODEd assignments[_5]', |
push @{$printChoices}, [&mt('Selected [_1]Problems[_2] from folder [_3] for [_4]CODEd assignments[_5]', |
'<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>','<b>','</b>'), |
'<b>','</b>','<b><i>'.$sequenceTitle.'</i></b>','<b>','</b>'), |
'problems_for_anon', 'CHOOSE_ANON1']; |
'problems_for_anon', 'CHOOSE_ANON1']; |
} |
} |
|
|
Line 4686 ALL_PROBLEMS
|
Line 4672 ALL_PROBLEMS
|
$randomly_ordered_warning |
$randomly_ordered_warning |
<nextstate>PRINT_FORMATTING</nextstate> |
<nextstate>PRINT_FORMATTING</nextstate> |
<message><br /><big><i><b>Select resources for the assignment</b></i></big><br /></message> |
<message><br /><big><i><b>Select resources for the assignment</b></i></big><br /></message> |
<resource variable="RESOURCES" multichoice="1" addstatus="1" |
<resource variable="RESOURCES" multichoice="1" addstatus="1" |
closeallpages="1" modallink="1"> |
closeallpages="1" modallink="1"> |
<filterfunc>return $isNotMap;</filterfunc> |
<filterfunc>return $isNotMap;</filterfunc> |
<mapurl>$map</mapurl> |
<mapurl>$map</mapurl> |
Line 4797 CHOOSE_ANON2
|
Line 4783 CHOOSE_ANON2
|
<nextstate>PAGESIZE</nextstate> |
<nextstate>PAGESIZE</nextstate> |
<filechoice>return '$subdir';</filechoice> |
<filechoice>return '$subdir';</filechoice> |
CHOOSE_FROM_SUBDIR |
CHOOSE_FROM_SUBDIR |
|
|
# this is broken up because I really want interpolation above, |
# this is broken up because I really want interpolation above, |
# and I really DON'T want it below |
# and I really DON'T want it below |
$xmlfrag .= <<'CHOOSE_FROM_SUBDIR'; |
$xmlfrag .= <<'CHOOSE_FROM_SUBDIR'; |
Line 5023 CHOOSE_FROM_ANY_SEQUENCE
|
Line 5009 CHOOSE_FROM_ANY_SEQUENCE
|
|
|
if ($noprintmsg) { |
if ($noprintmsg) { |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{MESSAGE_TEXT} = |
$paramHash->{MESSAGE_TEXT} = |
'<p class="LC_info">'.$noprintmsg.'</p>'; |
'<p class="LC_info">'.$noprintmsg.'</p>'; |
Apache::lonhelper::message->new(); |
Apache::lonhelper::message->new(); |
} |
} |
Line 5052 CHOOSE_FROM_ANY_SEQUENCE
|
Line 5038 CHOOSE_FROM_ANY_SEQUENCE
|
) |
) |
); |
); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{'variable'} = 'ANSWER_TYPE'; |
$paramHash->{'variable'} = 'ANSWER_TYPE'; |
$helper->declareVar('ANSWER_TYPE'); |
$helper->declareVar('ANSWER_TYPE'); |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
['Without Answers', 'yes'], |
['Without Answers', 'yes'], |
['With Answers', 'no'], |
['With Answers', 'no'], |
Line 5071 CHOOSE_FROM_ANY_SEQUENCE
|
Line 5057 CHOOSE_FROM_ANY_SEQUENCE
|
&addMessage(&Apache::lonhtmlcommon::row_title(&mt('Font Size'))); |
&addMessage(&Apache::lonhtmlcommon::row_title(&mt('Font Size'))); |
my $xmlfrag = << "FONT_SELECTION"; |
my $xmlfrag = << "FONT_SELECTION"; |
|
|
|
|
<dropdown variable='fontsize' multichoice='0' allowempty='0'> |
<dropdown variable='fontsize' multichoice='0' allowempty='0'> |
<defaultvalue> |
<defaultvalue> |
return 'normalsize'; |
return 'normalsize'; |
Line 5108 FONT_SELECTION
|
Line 5094 FONT_SELECTION
|
); |
); |
} |
} |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{'variable'} = 'LATEX_TYPE'; |
$paramHash->{'variable'} = 'LATEX_TYPE'; |
$helper->declareVar('LATEX_TYPE'); |
$helper->declareVar('LATEX_TYPE'); |
if ($helper->{VARS}->{'construction'} eq '1') { |
if ($helper->{VARS}->{'construction'} eq '1') { |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
['standard LaTeX mode', 'standard'], |
['standard LaTeX mode', 'standard'], |
['LaTeX batchmode', 'batchmode'], ]; |
['LaTeX batchmode', 'batchmode'], ]; |
} else { |
} else { |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
Line 5120 FONT_SELECTION
|
Line 5106 FONT_SELECTION
|
['standard LaTeX mode', 'standard'] ]; |
['standard LaTeX mode', 'standard'] ]; |
} |
} |
Apache::lonhelper::dropdown->new(); |
Apache::lonhelper::dropdown->new(); |
|
|
&addMessage(&Apache::lonhtmlcommon::row_closure() |
&addMessage(&Apache::lonhtmlcommon::row_closure() |
.&Apache::lonhtmlcommon::row_title( |
.&Apache::lonhtmlcommon::row_title( |
'<label for="TABLE_CONTENTS_forminput">' |
'<label for="TABLE_CONTENTS_forminput">' |
Line 5129 FONT_SELECTION
|
Line 5115 FONT_SELECTION
|
) |
) |
); |
); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{'variable'} = 'TABLE_CONTENTS'; |
$paramHash->{'variable'} = 'TABLE_CONTENTS'; |
$helper->declareVar('TABLE_CONTENTS'); |
$helper->declareVar('TABLE_CONTENTS'); |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
['No', 'no'], |
['No', 'no'], |
['Yes', 'yes'] ]; |
['Yes', 'yes'] ]; |
Apache::lonhelper::dropdown->new(); |
Apache::lonhelper::dropdown->new(); |
&addMessage(&Apache::lonhtmlcommon::row_closure()); |
&addMessage(&Apache::lonhtmlcommon::row_closure()); |
|
|
if (not $helper->{VARS}->{'construction'}) { |
if (not $helper->{VARS}->{'construction'}) { |
&addMessage(&Apache::lonhtmlcommon::row_title( |
&addMessage(&Apache::lonhtmlcommon::row_title( |
'<label for="TABLE_INDEX_forminput">' |
'<label for="TABLE_INDEX_forminput">' |
Line 5145 FONT_SELECTION
|
Line 5131 FONT_SELECTION
|
) |
) |
); |
); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{'variable'} = 'TABLE_INDEX'; |
$paramHash->{'variable'} = 'TABLE_INDEX'; |
$helper->declareVar('TABLE_INDEX'); |
$helper->declareVar('TABLE_INDEX'); |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
['No', 'no'], |
['No', 'no'], |
['Yes', 'yes'] ]; |
['Yes', 'yes'] ]; |
Line 5159 FONT_SELECTION
|
Line 5145 FONT_SELECTION
|
) |
) |
); |
); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash = Apache::lonhelper::getParamHash(); |
$paramHash->{'variable'} = 'PRINT_DISCUSSIONS'; |
$paramHash->{'variable'} = 'PRINT_DISCUSSIONS'; |
$helper->declareVar('PRINT_DISCUSSIONS'); |
$helper->declareVar('PRINT_DISCUSSIONS'); |
$paramHash->{CHOICES} = [ |
$paramHash->{CHOICES} = [ |
['No', 'no'], |
['No', 'no'], |
['Yes', 'yes'] ]; |
['Yes', 'yes'] ]; |
Line 5194 FONT_SELECTION
|
Line 5180 FONT_SELECTION
|
&addMessage(&Apache::lonhtmlcommon::row_closure(1)); |
&addMessage(&Apache::lonhtmlcommon::row_closure(1)); |
} |
} |
|
|
if ($helper->{'VARS'}->{'construction'}) { |
if ($helper->{'VARS'}->{'construction'}) { |
my $stylevalue='$Apache::lonnet::env{"construct.style"}'; |
my $stylevalue='$Apache::lonnet::env{"construct.style"}'; |
my $randseedtext=&mt("Use random seed"); |
my $randseedtext=&mt("Use random seed"); |
my $stylefiletext=&mt("Use style file"); |
my $stylefiletext=&mt("Use style file"); |
Line 5285 PROBTYPE
|
Line 5271 PROBTYPE
|
# If we're in the "final" state, bailout and return to handler |
# If we're in the "final" state, bailout and return to handler |
if ($helper->{STATE} eq 'FINAL') { |
if ($helper->{STATE} eq 'FINAL') { |
return $helper; |
return $helper; |
} |
} |
|
|
my $footer; |
my $footer; |
if ($helper->{STATE} eq 'START') { |
if ($helper->{STATE} eq 'START') { |
my $prtspool=$r->dir_config('lonPrtDir'); |
my $prtspool=$r->dir_config('lonPrtDir'); |
$footer = &recently_generated($prtspool); |
$footer = &recently_generated($prtspool); |
} |
} |
$r->print($helper->display($footer)); |
$r->print($helper->display($footer)); |
Line 5309 package Apache::lonprintout::page_format
|
Line 5295 package Apache::lonprintout::page_format
|
|
|
See lonhelper.pm documentation for discussion of the helper framework. |
See lonhelper.pm documentation for discussion of the helper framework. |
|
|
Apache::lonprintout::page_format_state is an element that gives the |
Apache::lonprintout::page_format_state is an element that gives the |
user an opportunity to select the page layout they wish to print |
user an opportunity to select the page layout they wish to print |
with: Number of columns, portrait/landscape, and paper size. If you |
with: Number of columns, portrait/landscape, and paper size. If you |
want to change the paper size choices, change the @paperSize array |
want to change the paper size choices, change the @paperSize array |
contents in this package. |
contents in this package. |
|
|
page_format_state is always directly invoked in lonprintout.pm, so there |
page_format_state is always directly invoked in lonprintout.pm, so there |
Line 5336 use Apache::lonnet;
|
Line 5322 use Apache::lonnet;
|
|
|
my $maxColumns = 2; |
my $maxColumns = 2; |
# it'd be nice if these all worked |
# it'd be nice if these all worked |
#my @paperSize = ("letter [8 1/2x11 in]", "legal [8 1/2x14 in]", |
#my @paperSize = ("letter [8 1/2x11 in]", "legal [8 1/2x14 in]", |
# "tabloid (ledger) [11x17 in]", "executive [7 1/2x10 in]", |
# "tabloid (ledger) [11x17 in]", "executive [7 1/2x10 in]", |
# "a2 [420x594 mm]", "a3 [297x420 mm]", "a4 [210x297 mm]", |
# "a2 [420x594 mm]", "a3 [297x420 mm]", "a4 [210x297 mm]", |
# "a5 [148x210 mm]", "a6 [105x148 mm]" ); |
# "a5 [148x210 mm]", "a6 [105x148 mm]" ); |
my @paperSize = ("letter [8 1/2x11 in]", "legal [8 1/2x14 in]", |
my @paperSize = ("letter [8 1/2x11 in]", "legal [8 1/2x14 in]", |
"a4 [210x297 mm]"); |
"a4 [210x297 mm]"); |
|
|
# Tentative format: Orientation (L = Landscape, P = portrait) | Colnum | |
# Tentative format: Orientation (L = Landscape, P = portrait) | Colnum | |
# Paper type |
# Paper type |
|
|
sub new { |
sub new { |
my $self = Apache::lonhelper::element->new(); |
my $self = Apache::lonhelper::element->new(); |
|
|
shift; |
shift; |
Line 5371 sub render {
|
Line 5357 sub render {
|
my $pdfFormLabel=&mt('PDF Form Fields'); |
my $pdfFormLabel=&mt('PDF Form Fields'); |
my $with=&mt('with Form Fields'); |
my $with=&mt('with Form Fields'); |
my $without=&mt('without Form Fields'); |
my $without=&mt('without Form Fields'); |
|
|
|
|
$result.='<h3>'.&mt('Layout Options').'</h3>' |
$result.='<h3>'.&mt('Layout Options').'</h3>' |
.&Apache::loncommon::start_data_table() |
.&Apache::loncommon::start_data_table() |
Line 5438 sub postprocess {
|
Line 5424 sub postprocess {
|
|
|
my $var = $self->{'variable'}; |
my $var = $self->{'variable'}; |
my $helper = Apache::lonhelper->getHelper(); |
my $helper = Apache::lonhelper->getHelper(); |
$helper->{VARS}->{$var} = |
$helper->{VARS}->{$var} = |
$env{"form.$var.layout"} . '|' . $env{"form.$var.cols"} . '|' . |
$env{"form.$var.layout"} . '|' . $env{"form.$var.cols"} . '|' . |
$env{"form.$var.paper"} . '|' . $env{"form.$var.pdfFormFields"}; |
$env{"form.$var.paper"} . '|' . $env{"form.$var.pdfFormFields"}; |
return 1; |
return 1; |
Line 5454 package Apache::lonprintout::page_size_s
|
Line 5440 package Apache::lonprintout::page_size_s
|
|
|
See lonhelper.pm documentation for discussion of the helper framework. |
See lonhelper.pm documentation for discussion of the helper framework. |
|
|
Apache::lonprintout::page_size_state is an element that gives the |
Apache::lonprintout::page_size_state is an element that gives the |
user the opportunity to further refine the page settings if they |
user the opportunity to further refine the page settings if they |
select a single-column page. |
select a single-column page. |
|
|
Line 5477 use strict;
|
Line 5463 use strict;
|
|
|
|
|
|
|
sub new { |
sub new { |
my $self = Apache::lonhelper::element->new(); |
my $self = Apache::lonhelper::element->new(); |
|
|
shift; # disturbs me (probably prevents subclassing) but works (drops |
shift; # disturbs me (probably prevents subclassing) but works (drops |
Line 5487 sub new {
|
Line 5473 sub new {
|
my $helper = Apache::lonhelper::getHelper(); |
my $helper = Apache::lonhelper::getHelper(); |
$helper->declareVar($self->{'variable'}); |
$helper->declareVar($self->{'variable'}); |
|
|
# The variable name of the format element, so we can look into |
# The variable name of the format element, so we can look into |
# $helper->{VARS} to figure out whether the columns are one or two |
# $helper->{VARS} to figure out whether the columns are one or two |
$self->{'formatvar'} = shift; |
$self->{'formatvar'} = shift; |
|
|
Line 5527 sub render {
|
Line 5513 sub render {
|
$size{'height_and_units'}, |
$size{'height_and_units'}, |
$size{'margin_and_units'})= |
$size{'margin_and_units'})= |
&Apache::lonprintout::page_format($papersize, $laystyle, $cols); |
&Apache::lonprintout::page_format($papersize, $laystyle, $cols); |
|
|
foreach my $dimension ('width','height','margin') { |
foreach my $dimension ('width','height','margin') { |
($size{$dimension},$size{$dimension.'_unit'}) = |
($size{$dimension},$size{$dimension.'_unit'}) = |
split(/ +/, $size{$dimension.'_and_units'},2); |
split(/ +/, $size{$dimension.'_and_units'},2); |
Line 5612 sub preprocess {
|
Line 5598 sub preprocess {
|
|
|
foreach my $dim ('width', 'height', 'lmargin') { |
foreach my $dim ('width', 'height', 'lmargin') { |
my ($value, $units) = split(/ /, $size{$dim}); |
my ($value, $units) = split(/ /, $size{$dim}); |
|
|
$helper->{VARS}->{"$var.".$dim} = $value; |
$helper->{VARS}->{"$var.".$dim} = $value; |
$helper->{VARS}->{"$var.".$dim.'unit'} = $units; |
$helper->{VARS}->{"$var.".$dim.'unit'} = $units; |
|
|
} |
} |
|
|
|
|
Line 5623 sub preprocess {
|
Line 5609 sub preprocess {
|
|
|
$helper->changeState($self->{NEXTSTATE}); |
$helper->changeState($self->{NEXTSTATE}); |
} |
} |
|
|
return 1; |
return 1; |
} |
} |
|
|
Line 5632 sub postprocess {
|
Line 5618 sub postprocess {
|
|
|
my $var = $self->{'variable'}; |
my $var = $self->{'variable'}; |
my $helper = Apache::lonhelper->getHelper(); |
my $helper = Apache::lonhelper->getHelper(); |
my $width = $helper->{VARS}->{$var .'.width'} = $env{"form.${var}.width"}; |
my $width = $helper->{VARS}->{$var .'.width'} = $env{"form.${var}.width"}; |
my $height = $helper->{VARS}->{$var .'.height'} = $env{"form.${var}.height"}; |
my $height = $helper->{VARS}->{$var .'.height'} = $env{"form.${var}.height"}; |
my $lmargin = $helper->{VARS}->{$var .'.lmargin'} = $env{"form.${var}.lmargin"}; |
my $lmargin = $helper->{VARS}->{$var .'.lmargin'} = $env{"form.${var}.lmargin"}; |
$helper->{VARS}->{$var .'.widthunit'} = $env{"form.${var}.widthunit"}; |
$helper->{VARS}->{$var .'.widthunit'} = $env{"form.${var}.widthunit"}; |
$helper->{VARS}->{$var .'.heightunit'} = $env{"form.${var}.heightunit"}; |
$helper->{VARS}->{$var .'.heightunit'} = $env{"form.${var}.heightunit"}; |
$helper->{VARS}->{$var .'.lmarginunit'} = $env{"form.${var}.lmarginunit"}; |
$helper->{VARS}->{$var .'.lmarginunit'} = $env{"form.${var}.lmarginunit"}; |
|
|
my $error = ''; |
my $error = ''; |
|
|
# /^-?[0-9]+(\.[0-9]*)?$/ -> optional minus, at least on digit, followed |
# /^-?[0-9]+(\.[0-9]*)?$/ -> optional minus, at least on digit, followed |
# by an optional period, followed by digits, ending the string |
# by an optional period, followed by digits, ending the string |
|
|
if ($width !~ /^-?[0-9]*(\.[0-9]*)?$/) { |
if ($width !~ /^-?[0-9]*(\.[0-9]*)?$/) { |