--- loncom/interface/lonprintout.pm	2002/08/30 20:41:09	1.52
+++ loncom/interface/lonprintout.pm	2002/09/12 15:08:43	1.62
@@ -1,7 +1,7 @@
 # The LearningOnline Network
 # Printout
 #
-# $Id: lonprintout.pm,v 1.52 2002/08/30 20:41:09 sakharuk Exp $
+# $Id: lonprintout.pm,v 1.62 2002/09/12 15:08:43 sakharuk Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -43,11 +43,16 @@ use strict;
 use Apache::Constants qw(:common :http);
 use Apache::lonxml;
 use Apache::lonnet;
+use Apache::loncommon;
 use Apache::inputtags;
+use Apache::grades;
 use Apache::edit;
 use Apache::File();
 use POSIX qw(strftime);
-use Apache::loncoursedata;
+use GDBM_File;
+
+
+my %hash;
 
 
 sub headerform {
@@ -59,38 +64,49 @@ sub headerform {
 </head>
 <body bgcolor="FFFFFF">
 <form method="post" enctype="multipart/form-data" action="/adm/printout" name="printform">
-<tt>$ENV{'form.postdata'}</tt><p>
-<h1>What do you want to print? Make a choice.</h1><br />
 ENDHEADER
+    if ($ENV{'request.role'}=~m/^cc\./ or $ENV{'request.role'}=~m/^in\./ or $ENV{'request.role'}=~m/^ta\./) { 
+    $r->print(<<ENDHEADER1);
+<b>Path to current document: </b><tt>$ENV{'form.postdata'}</tt><p>
+ENDHEADER1
+}
 }
 
 
 sub menu_for_output {
     my $r = shift;
+    my ($title_for_single_resource,$title_for_sequence,$title_for_main_map) = &details_for_menu;
+    if ($title_for_single_resource ne '') {$title_for_single_resource = '"'.$title_for_single_resource.'"';}
+    if ($title_for_sequence ne '') {$title_for_sequence = '"'.$title_for_sequence.'"';}
+    if ($title_for_main_map ne '') {$title_for_main_map = '"'.$title_for_main_map.'"';}
+    my $subdir_to_print = $ENV{'form.postdata'};
+    $subdir_to_print =~ m/\/([^\/]+)$/;
+    $subdir_to_print =~ s/$1//;
     $r->print(<<ENDMENUOUT1);
+<h1>What do you want to print? Make a choice.</h1><br />
 <input type="hidden" name="phase" value="two">
 <input type="hidden" name="url" value="$ENV{'form.postdata'}">
-<input type="radio" name="choice" value="Standard LaTeX output for current document" checked>  Current document
-(you will print what you see on the screen)<br />
+<input type="radio" name="choice" value="Standard LaTeX output for current document" checked>  Current document <b>$title_for_single_resource</b>
+(you will print what you saw on the screen)<br />
 ENDMENUOUT1
     if ((not $ENV{'request.role'}=~m/^au\./) and (not $ENV{'request.role'}=~m/^ca\./)) {
 	$r->print(<<ENDMENUOUT2);
-<input type="radio" name="choice" value="Standard LaTeX output for the primary sequence">  All problems from the primary sequence<br />
-<input type="radio" name="choice" value="Standard LaTeX output for whole primary sequence">  The whole primary sequence (problems plus all html and xml files)<br />
-<input type="radio" name="choice" value="Standard LaTeX output for the top level sequence">  All problems from the top level sequence<br />
-<br />
+<input type="radio" name="choice" value="Standard LaTeX output for the primary sequence">  All problems from the sequence <b>$title_for_sequence</b><br />
+<input type="radio" name="choice" value="Standard LaTeX output for whole primary sequence">  All problems plus any html/xml files from the sequence <b>$title_for_sequence</b><br />
 ENDMENUOUT2
     }
     if ($ENV{'request.role'}=~m/^cc\./ or $ENV{'request.role'}=~m/^in\./ or $ENV{'request.role'}=~m/^ta\./) { 
 	$r->print(<<ENDMENUOUT6);
-  <input type="radio" name="choice" value="All class print">  Print assignment for students in class<br />
+<input type="radio" name="choice" value="Standard LaTeX output for the top level sequence">  All problems in this course (<b>warning:</b> this may be time consuming) <br />
+<br />
+<input type="radio" name="choice" value="All class print">  All problems from the sequence <b>$title_for_sequence</b> for selected students<br /><br />
 ENDMENUOUT6
     }
       my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'});
       $subdirtoprint =~ s/\/[^\/]+$//;
       if (&Apache::lonnet::allowed('bre',$subdirtoprint) eq 'F') {
 	  $r->print(<<ENDMENUOUT4);
-  <input type="radio" name="choice" value="Subdirectory print">  All problems from current subdirectory (where this particular problem is)<br />
+  <input type="radio" name="choice" value="Subdirectory print">  Problems from current subdirectory <b>$subdir_to_print</b><br />
 ENDMENUOUT4
       }
     $r->print(<<ENDMENUOUT5);
@@ -105,17 +121,23 @@ ENDMENUOUT4
    <td>&nbsp;</td>
    <td rawspan="2">
      Number of columns: <select name="numberofcolumns">
-                         <option selected> 1 </option>
-                         <option> 2 </option>
-                         <option> 3 </option>
-                         <option> 4 </option>
-                         <option> 5 </option>
-                         <option> 6 </option>
-                         <option> 7 </option>
-                         <option> 8 </option>
-                         <option> 9 </option>
+                         <option> 1 </option>
+                         <option selected> 2 </option>
                         </select> 
    </td>
+   <td rawspan="2">
+     Paper size (format [width x height]): <select name="papersize">
+                                            <option selected> Letter [8 1/2x11 in] </option>
+                                            <option> Legal [8 1/2x14 in] </option>
+                                            <option> Ledger/Tabloid [11x17 in] </option>
+                                            <option> Executive [7 1/2x10 in] </option>
+                                            <option> A2 [420x594 mm] </option>
+                                            <option> A3 [297x420 mm] </option>
+                                            <option> A4 [210x297 mm] </option>
+                                            <option> A5 [148x210 mm] </option>
+                                            <option> A6 [105x148 mm] </option>
+                                           </select> 
+   </td>
  </tr>
 </table>
 </br> 
@@ -124,6 +146,77 @@ ENDMENUOUT5
 }
 
 
+sub problem_choice_menu {
+    my $r = shift;
+    my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'});
+    $subdirtoprint =~ s/\/[^\/]+$//;
+    my @list_of_files = ();
+    if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) {
+	$subdirtoprint =~ s/^[^~]*~(\w+)\//\/home\/$1\/public_html\//;
+    } else {
+	$subdirtoprint =~ s/.*(\/res\/)/$1/;
+    }
+    my @content_directory = ();
+    if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) {
+	@content_directory = &Apache::lonnet::dirlist($subdirtoprint,$ENV{'user.domain'}, $ENV{'user.name'},'');
+    } else {
+	@content_directory = &Apache::lonnet::dirlist($subdirtoprint);
+    }
+    for (my $iy=0;$iy<=$#content_directory;$iy++) {
+	my @tempo_array = split(/&/,$content_directory[$iy]);
+	if ($tempo_array[0] =~ m/^[^\.]+\.(problem|exam|quiz|assess|survey|form|library)$/) {
+	    push(@list_of_files,$tempo_array[0]);
+	}
+    }
+    $subdirtoprint =~ s/\/$//;
+    for (my $i=0;$i<=$#list_of_files;$i++) {
+	$list_of_files[$i] = $subdirtoprint.'/'.$list_of_files[$i];
+    }
+    $r->print(<<ENDMENUOUT1);
+<input type="hidden" name="url" value="$ENV{'form.url'}">
+<input type="hidden" name="choice" value="$ENV{'form.choice'}">
+<input type="hidden" name="layout" value="$ENV{'form.layout'}">
+<input type="hidden" name="numberofcolumns" value="$ENV{'form.numberofcolumns'}">
+<h1>Mark problems which you want to print</h1>
+<script>
+    function checkall() {
+	for (i=0; i<document.forms.printform.elements.length; i++) {
+            if 
+          (document.forms.printform.elements[i].name.indexOf('whattoprint')==0) {
+	      document.forms.printform.elements[i].checked=true;
+            }
+        }
+    }
+
+
+    function uncheckall() {
+	for (i=0; i<document.forms.printform.elements.length; i++) {
+            if 
+          (document.forms.printform.elements[i].name.indexOf('whattoprint')==0) {
+	      document.forms.printform.elements[i].checked=false;
+            }
+        }
+    }
+</script>
+<input type=button onClick="checkall()" value="Check All">&nbsp;
+<input type=button onClick="uncheckall()" value="Uncheck">
+<p>
+ENDMENUOUT1
+    my $i;
+    foreach my $file (@list_of_files) {
+	$r->print('<br /><input type=checkbox name="whattoprint'.$i.'" value="'.$file.'"> '.
+                  $file);
+	$i++;
+    }
+    $r->print(<<ENDMENUOUT2);
+<br />
+<input type="hidden" name="numberofproblems" value="$i">
+<input type="hidden" name="phase" value="three">
+<input type="submit" value="Submit">
+ENDMENUOUT2
+}
+
+
 sub additional_class_menu {
     my $r = shift;
     $r->print(<<ENDMENUOUT1);
@@ -133,25 +226,72 @@ sub additional_class_menu {
 <input type="hidden" name="numberofcolumns" value="$ENV{'form.numberofcolumns'}">
 <h1>Mark students which assignments you want to print</h1>
 ENDMENUOUT1
-    my $c = $r->connection;    
-    my %cache;
-    my $courseID=$ENV{'request.course.id'};
-    my $classlist=&Apache::loncoursedata::DownloadClasslist($courseID,
-                                                $cache{'ClasslistTimestamp'},
-                                                $c);
-    foreach (keys(%$classlist)) {
-        if(/^(con_lost|error|no_such_host)/i) {
-            untie(%cache);
-            return "Error getting student data.";
+    my %courselist=&Apache::lonnet::dump(
+                   'classlist',
+		   $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
+		   $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
+    my $now=time;
+    $r->print(<<ENDDISHEADER);
+<script>
+    function checkall() {
+	for (i=0; i<document.forms.printform.elements.length; i++) {
+            if 
+          (document.forms.printform.elements[i].name.indexOf('whomtoprint')==0) {
+	      document.forms.printform.elements[i].checked=true;
+            }
         }
     }
-    my $classlistaa = '';
-    foreach my $st (keys(%$classlist)) {
-	$classlistaa .= ' SSS '.$st.' => '.$$classlist{$st}.' FFF '."\r\n";
+
+    function checksec() {
+	for (i=0; i<document.forms.printform.elements.length; i++) {
+            if 
+          (document.forms.printform.elements[i].value.indexOf
+           (document.forms.printform.chksec.value)==0) {
+	      document.forms.printform.elements[i].checked=true;
+            }
+        }
     }
 
+    function uncheckall() {
+	for (i=0; i<document.forms.printform.elements.length; i++) {
+            if 
+          (document.forms.printform.elements[i].name.indexOf('whomtoprint')==0) {
+	      document.forms.printform.elements[i].checked=false;
+            }
+        }
+    }
+</script>
+<input type=button onClick="checkall()" value="Check All">&nbsp;
+<input type=button onClick="checksec()" value="Check Section/Group">
+<input type=text size=5 name=chksec>&nbsp;
+<input type=button onClick="uncheckall()" value="Uncheck">
+<p>
+ENDDISHEADER
+    my $i = 0;
+    foreach (sort keys %courselist) {
+        my ($end,$start)=split(/\:/,$courselist{$_});
+        my $active=1;
+        if (($end) && ($now>$end)) { $active=0; }
+        if ($active) {
+           my ($sname,$sdom)=split(/\:/,$_);
+           my %reply=&Apache::lonnet::get('environment',
+              ['firstname','middlename','lastname','generation'],
+              $sdom,$sname);
+           my $section=&Apache::lonnet::usection
+	       ($sdom,$sname,$ENV{'request.course.id'});
+           $r->print(
+        '<br /><input type=checkbox name="whomtoprint'.$i.'" value="'.$section.':'.$_.'"> '.
+		      $reply{'firstname'}.' '. 
+                      $reply{'middlename'}.' '.
+                      $reply{'lastname'}.' '.
+                      $reply{'generation'}.
+                      ' ('.$_.') '.$section);
+	   $i++;
+        } 
+    }
     $r->print(<<ENDMENUOUT2);
-    $classlistaa <br />
+<br />
+<input type="hidden" name="numberofstudents" value="$i">
 <input type="hidden" name="phase" value="three">
 <input type="submit" value="Submit">
 ENDMENUOUT2
@@ -160,12 +300,25 @@ ENDMENUOUT2
 
 sub additional_print_menu { 
     my $r = shift;
+    my $what_to_print = '';
+    for (my $i=0; $i<$ENV{'form.numberofstudents'};$i++) {
+	$what_to_print .= '<input type="hidden" name="whomtoprint'.$i.'" value="'.$ENV{'form.whomtoprint'.$i}.'">';
+    }
+    for (my $i=0; $i<$ENV{'form.numberofproblems'};$i++) {
+	$what_to_print .= '<input type="hidden" name="whattoprint'.$i.'" value="'.$ENV{'form.whattoprint'.$i}.'">';
+    }
     $r->print(<<ENDMENUOUT);
+    $what_to_print
 <input type="hidden" name="url" value="$ENV{'form.url'}">
 <input type="hidden" name="choice" value="$ENV{'form.choice'}">
 <input type="hidden" name="layout" value="$ENV{'form.layout'}">
+<input type="hidden" name="numberofstudents" value="$ENV{'form.numberofstudents'}">
+<input type="hidden" name="numberofproblems" value="$ENV{'form.numberofproblems'}">
 <input type="hidden" name="numberofcolumns" value="$ENV{'form.numberofcolumns'}">
-Enter width of the page: <input type="text" name="width" width="10" value="9cm"> <br />
+Define page layout parameters: <br />
+<b>Width</b>: <input type="text" name="width" width="8" value="9cm"> <br />
+<b>Height</b>: <input type="text" name="height" width="8" value="25.9cm"> <br />
+<b>Left margin</b>: <input type="text" name="leftmargin" width="8" value="-0.57in"> <br />
 <input type="hidden" name="phase" value="four">
 <input type="submit" value="Submit">
 </form>
@@ -192,9 +345,11 @@ ENDPART
     my $laystyle = 'book';
     my $result = '';
     my $number_of_columns = 1;
+    my $selectionmade = '';
  
     if ($choice eq 'Standard LaTeX output for current document') {
       #-- single document - problem, page, html, xml  
+      $selectionmade = 1;
       my %moreenv;
       $moreenv{'form.grade_target'}='tex';
       if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) {
@@ -214,21 +369,18 @@ ENDPART
       #-- minimal sequence to which the current document belongs
         #-- where is the primary sequence containing file?
 	my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'});
-	$_ = $symbolic;
-	m/([^_]+)_/;
+	$symbolic =~ m/([^_]+)_/;
 	my $primary_sequence = '/res/'.$1;
         #-- open and analyses the primary sequence
 	my $sequence_file=&Apache::lonnet::filelocation("",$primary_sequence);
 	my $sequencefilecontents=&Apache::lonnet::getfile($sequence_file);
-	my @master_seq = &content_map($sequencefilecontents);
+	my @master_seq = &coming_from_hash($primary_sequence); 
         #-- produce an output string
 	for (my $i=0;$i<=$#master_seq;$i++) {
-	    $_ = $master_seq[$i];
-	    m/\"(.*)\"/;
-            $_ = $1;
-            my $urlp = $1;		
+            my $urlp = $master_seq[$i];		
 	    if ($choice eq 'Standard LaTeX output for the primary sequence') {
-		if ($urlp =~ m/\.(problem|exam|quiz|assess|survey|form|library)/) {
+		$selectionmade = 2;
+ 		if ($urlp =~ m/\.(problem|exam|quiz|assess|survey|form|library)/) {
 		    my %moreenv;
 		    $moreenv{'form.grade_target'}='tex';
 		    &Apache::lonnet::appenv(%moreenv);
@@ -236,7 +388,8 @@ ENDPART
 		    &Apache::lonnet::delenv('form.grade_target');
 		    $result .= $texversion;        
 		}
-	    } else {
+	    } elsif ($urlp =~ /\S+/) {
+		$selectionmade = 3;
 		my %moreenv;
 		$moreenv{'form.grade_target'}='tex';
 		&Apache::lonnet::appenv(%moreenv);
@@ -248,6 +401,7 @@ ENDPART
 	$result = &additional_cleanup($result);
     }  elsif ($choice eq 'Standard LaTeX output for the top level sequence') {
         # where is the main sequence of the course?
+	$selectionmade = 4;
 	my $main_seq = '/res/'.$ENV{'request.course.uri'};
 	my $file=&Apache::lonnet::filelocation("",$main_seq);
 	my $filecontents=&Apache::lonnet::getfile($file);
@@ -309,61 +463,91 @@ ENDPART
 	}	    
 	$result = &additional_cleanup($result);
     } elsif ($choice eq 'All class print') { 
-
-
-
-    } elsif ($choice eq 'Subdirectory print') {      
-	my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'});
-	$subdirtoprint =~ s/\/[^\/]+$//;
-	my @list_of_files = ();
-	if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) {
-	    $subdirtoprint =~ s/^[^~]*~(\w+)\//\/home\/$1\/public_html\//;
-	} else {
-	    $subdirtoprint =~ s/.*(\/res\/)/$1/;
+    #-- prints assignments for whole class or for selected students  
+	$selectionmade = 5;
+        my (@students,@st_output) = ((),());
+	for (my $i=0; $i<$ENV{'form.numberofstudents'};$i++) {
+	    if ($ENV{'form.whomtoprint'.$i}=~/:/) {
+		push @students,$ENV{'form.whomtoprint'.$i};
+	    }
 	}
-	my @content_directory = ();
-	if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) {
-	    @content_directory = &Apache::lonnet::dirlist($subdirtoprint,$ENV{'user.domain'}, $ENV{'user.name'},'');
-	} else {
-	    @content_directory = &Apache::lonnet::dirlist($subdirtoprint);
+	#where is the primary sequence containing current resource (the same for all students)?
+	my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'});
+	$symbolic =~ m/([^_]+)_/;
+	my $primary_sequence = '/res/'.$1;
+	#opens and analyses the primary sequence file, produces the array of resources
+	my $sequence_file=&Apache::lonnet::filelocation("",$primary_sequence);
+	my $sequencefilecontents=&Apache::lonnet::getfile($sequence_file);
+	my @master_seq = &content_map($sequencefilecontents);
+       #loop over students
+	foreach my $person (@students) {
+	    my $current_output = ''; 
+	    my ($usersection,$username,$userdomain) = split /:/,$person;
+	    my $fullname = &Apache::grades::get_fullname($username,$userdomain);
+            #goes through all resources, checks if they are available for current student, and produces output 
+	    foreach my $curres (@master_seq)  {
+		$curres =~ s/^"//;
+		$curres =~ s/"$//;
+                if ($curres=~/\w+/) {
+		    my $symb = &Apache::lonnet::symbread($curres);
+		    my ($map,$id,$res_url) = split(/___/,$symb);
+		    if (&Apache::lonnet::allowed('bre',$res_url)) {
+			my $rendered = &Apache::loncommon::get_student_view($symb,$username,$userdomain,
+                                                                        $ENV{'request.course.id'},'tex');
+			$current_output .= $rendered;
+		    }
+		}
+	    }
+	    $current_output =~ s/\\begin{document}/\\begin{document}\\noindent\\parbox{\\minipagewidth}{\\noindent\\fbox{\\textbf{$fullname}}\\hskip 1\.4in } \\vskip 5 mm /;
+	    $result .= $current_output;
 	}
-	for (my $iy=0;$iy<=$#content_directory;$iy++) {
-	    my @tempo_array = split(/&/,$content_directory[$iy]);
-	    if ($tempo_array[0] =~ m/^[^\.]+\.(problem|exam|quiz|assess|survey|form|library)$/) {
-		push(@list_of_files,$tempo_array[0]);
+	$result = &additional_cleanup($result);
+    } elsif ($choice eq 'Subdirectory print') {      
+    #prints selected problems from the subdirectory 
+	$selectionmade = 6;
+        my @list_of_files = ();
+	for (my $i=0; $i<$ENV{'form.numberofproblems'};$i++) {
+	    if ($ENV{'form.whattoprint'.$i}=~/^\//) {
+		push @list_of_files,$ENV{'form.whattoprint'.$i};
 	    }
 	}
-	$subdirtoprint =~ s/\/$//;
 	for (my $i=0;$i<=$#list_of_files;$i++) {
-	    my $urlp = $subdirtoprint.'/'.$list_of_files[$i];
-	    my %moreenv;
-	    $moreenv{'form.grade_target'}='tex';
-	    &Apache::lonnet::appenv(%moreenv);
-	    if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) { 
-		$urlp =~ s/\/home\/([^\/]*)\/public_html/\/~$1/; 
-	    }
-	    my $texversion=&Apache::lonnet::ssi($urlp);
-	    &Apache::lonnet::delenv('form.grade_target');
-	    $texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/;
-	    $result .= $texversion;   
+	    my $urlp = $list_of_files[$i];
+	    if ($urlp=~/\//) {
+		my %moreenv;
+		$moreenv{'form.grade_target'}='tex';
+		&Apache::lonnet::appenv(%moreenv);
+		if ($ENV{'request.role'}=~m/^au\./ or $ENV{'request.role'}=~m/^ca\./) { 
+		    $urlp =~ s/\/home\/([^\/]*)\/public_html/\/~$1/; 
+		}
+		my $texversion=&Apache::lonnet::ssi($urlp);
+		&Apache::lonnet::delenv('form.grade_target');
+		$texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/;
+		$result .= $texversion;
+	    }   
 	}
-	$result = &additional_cleanup($result);
-	
-       	
+	$result = &additional_cleanup($result);       	
     }
 #-- corrections for the different page formats
     if ($layout eq 'CBI' and $numberofcolumns eq '1') {
+	$result =~ s/\\begin{document}/\\setlength{\\oddsidemargin}{-40pt}\\setlength{\\evensidemargin}{-60pt}\\setlength{\\topmargin}{200pt}\\setlength{\\textwidth}{4\.4in}\\setlength{\\textheight}{6\.8in}\\setlength{\\parindent}{20pt}\\setlength{\\marginparwidth}{90pt}\\setlength{\\textfloatsep}{8pt plus 2\.0pt minus 4\.0pt} \\begin{document}/;
+	$result =~ s/\$number_of_columns/$number_of_columns/g;
+        $laystyle = 'album';
     } elsif ($layout eq 'CBI' and $numberofcolumns eq '2') {
 	$result =~ s/\\begin{document}/\\setlength{\\oddsidemargin}{-40pt}\\setlength{\\evensidemargin}{-60pt}\\setlength{\\topmargin}{200pt}\\setlength{\\textwidth}{4\.4in}\\setlength{\\textheight}{6\.8in}\\setlength{\\parindent}{20pt}\\setlength{\\marginparwidth}{90pt}\\setlength{\\textfloatsep}{8pt plus 2\.0pt minus 4\.0pt} \\begin{document}/;
+	$result =~ s/\$number_of_columns/$number_of_columns/g;
         $laystyle = 'album';
     } elsif ($layout eq 'CAPA') {
         my $courseidinfo = $ENV{'request.role'};
         $_ = $courseidinfo;
         m/.*\/(.*)/;
         $courseidinfo = $ENV{'course.physnet_'.$1.'.description'};
-#	$result =~ s/\\documentclass\[letterpaper\]{article}/\\documentclass\[twocolumn\]{article}/;
 	$result =~ s/\\documentclass\[letterpaper\]{article}/\\documentclass{article}/;
-	$result =~ s/\\begin{document}/\\textheight 25\.9cm\\oddsidemargin = -0\.57in\\evensidemargin = -0\.57in\\textwidth= 9cm\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/$number_of_columns-0\.2cm}\\renewcommand{\\ref}{\\keephidden\}\\begin{document}\\voffset=-1\.8cm\\setcounter{page}{1}\\parbox{\\minipagewidth}{\\noindent\\fbox{\\textbf{$ENV{'environment.firstname'} $ENV{'environment.lastname'}}}\\hskip 1\.4in $courseidinfo} \\vskip 5 mm /;	
+	if ($choice ne 'All class print') { 
+	    $result =~ s/\\begin{document}/\\textheight 25\.9cm\\oddsidemargin = -0\.57in\\evensidemargin = -0\.57in\\textwidth= 9cm\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/$number_of_columns-0\.2cm}\\renewcommand{\\ref}{\\keephidden\}\\begin{document}\\voffset=-1\.8cm\\setcounter{page}{1}\\parbox{\\minipagewidth}{\\noindent\\fbox{\\textbf{$ENV{'environment.firstname'} $ENV{'environment.lastname'}}}\\hskip 1\.4in $courseidinfo} \\vskip 5 mm /;
+        } else {	
+	    $result =~ s/\\begin{document}/\\textheight 25\.9cm\\oddsidemargin = -0\.57in\\evensidemargin = -0\.57in\\textwidth= 9cm\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/$number_of_columns-0\.2cm}\\renewcommand{\\ref}{\\keephidden\}\\begin{document}\\voffset=-1\.8cm\\setcounter{page}{1}  \\vskip 5 mm /;
+	}
 	$result =~ s/\\includegraphics{/\\includegraphics\[width=9\.0 cm\]{/g;
 #	$result =~ s/\\includegraphics{/\\includegraphics\[width=\\textwidth\]{/g;
 #	$result =~ s/(\\end{document})/\\newline\\noindent\\makebox\[9.0cm\]\[b\]{\\hrulefill}\\newline\\noindent\\tiny Dept\. of Physics and Astronomy, MSU\\makebox\[1.5cm\]\[b\]{\\hfill}LON-CAPA\\copyright MSU GNU\/GPL $1/;
@@ -376,6 +560,9 @@ ENDPART
     #changes page's parameters for the one column output 
     if ($ENV{'form.numberofcolumns'} == 1) {
 	$result =~ s/\\textwidth= 9cm/\\textwidth= $ENV{'form.width'}/;
+	$result =~ s/\\textheight 25\.9cm/\\textheight $ENV{'form.height'}/;
+	$result =~ s/\\evensidemargin = -0\.57in/\\evensidemargin= $ENV{'form.leftmargin'}/;
+	$result =~ s/\\oddsidemargin = -0\.57in/\\oddsidemargin= $ENV{'form.leftmargin'}/;
     }
 #-- LaTeX corrections     
     my $first_comment = index($result,'<!--',0);
@@ -407,12 +594,32 @@ ENDPART
     } 
     print $temp_file $result;
 $r->print(<<FINALEND);
-<meta http-equiv="Refresh" content="0; url=/cgi-bin/printout.pl?$filename&$laystyle&$numberofcolumns">
+<meta http-equiv="Refresh" content="0; url=/cgi-bin/printout.pl?$filename&$laystyle&$numberofcolumns&$selectionmade">
 </body>
 </html>
 FINALEND
 }
 
+
+sub coming_from_hash {
+
+    my $mainsequence = shift;
+    my @resourcelist = ();
+    my $mapstart = $hash{'map_start_'.$mainsequence};
+    my $mapfinish = $hash{'map_finish_'.$mainsequence};
+    my $current_resource = $mapstart;
+    while ($current_resource ne $mapfinish) {
+	if (not $hash{'src_'.$current_resource}=~/\.sequence$/) {
+	    push @resourcelist,$hash{'src_'.$current_resource};
+	} else {
+	    push @resourcelist,&coming_from_hash($hash{'src_'.$current_resource});
+	}
+	$current_resource = $hash{'goesto_'.$hash{'to_'.$current_resource}};
+    }
+    return @resourcelist;
+}
+
+
 sub character_chart {
     my $result = shift;	
     $result =~ s/&#0?0?7;//g;
@@ -825,12 +1032,30 @@ sub content_map {
 }
 
 
+sub details_for_menu {
+
+    my $name_of_resourse = $hash{'title_'.$hash{'ids_'.$ENV{'form.postdata'}}};
+    my $symbolic = &Apache::lonnet::symbread($ENV{'form.postdata'});
+    $symbolic =~ m/([^_]+)_/;
+    my $name_of_sequence = $hash{'title_'.$hash{'ids_/res/'.$1}};
+    my $name_of_map = $hash{'title_'.$hash{'ids_/res/'.$ENV{'request.course.uri'}}};
+
+    return $name_of_resourse,$name_of_sequence,$name_of_map;
+
+}
+
 
 sub handler {
 
     my $r = shift;
     $r->content_type('text/html');
     $r->send_http_header;
+    $r->print(&Apache::loncommon::bodytag("Printing"));
+
+    if ($ENV{'request.course.id'}) {
+	my $fn=$ENV{'request.course.fn'};
+	tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER(),0640);
+    }
 
 #-- start form
     &headerform($r);
@@ -842,6 +1067,8 @@ sub handler {
      if ($ENV{'form.phase'} eq 'two') {
 	 if($ENV{'form.choice'} eq 'All class print') {
 	     &additional_class_menu($r);
+	 } elsif($ENV{'form.choice'} eq 'Subdirectory print') {
+	     &problem_choice_menu($r);
 	 } else {
 	     $ENV{'form.phase'} = 'three';
 	 }
@@ -857,11 +1084,13 @@ sub handler {
 #-- core part 
     if ($ENV{'form.phase'} eq 'four') {
 	&output_data($r);
-    }
+    }	
+    untie %hash;
     return OK;
-
+   
 } 
 
+
 1;
 __END__