Diff for /loncom/interface/lonsupportreq.pm between versions 1.3 and 1.8

version 1.3, 2004/07/03 20:57:05 version 1.8, 2004/09/09 05:58:42
Line 2  package Apache::lonsupportreq; Line 2  package Apache::lonsupportreq;
   
 use strict;  use strict;
 use lib qw(/home/httpd/lib/perl);  use lib qw(/home/httpd/lib/perl);
   use MIME::Types;
   use MIME::Lite;
 use Apache::Constants qw(:common);  use Apache::Constants qw(:common);
 use Apache::loncommon();  use Apache::loncommon();
 use Apache::lonnet();  use Apache::lonnet();
 use localenroll;  
 use Apache::lonlocal;  use Apache::lonlocal;
   
 use Mail::Send;  
 # use MIME::Lite;  
 # use MIME::Types;  
   
 sub handler {  sub handler {
     my ($r) = @_;      my ($r) = @_;
     &Apache::loncommon::content_type($r,'text/html');      &Apache::loncommon::content_type($r,'text/html');
Line 38  sub print_request_form { Line 35  sub print_request_form {
     my ($os,$browser,$bversion,$uhost,$uname,$udom,$uhome,$urole,$usec,$email,$cid,$cdom,$cnum,$ctitle,$ccode,$sectionlist,$lastname,$firstname,$server);      my ($os,$browser,$bversion,$uhost,$uname,$udom,$uhome,$urole,$usec,$email,$cid,$cdom,$cnum,$ctitle,$ccode,$sectionlist,$lastname,$firstname,$server);
     my $bodytag = &Apache::loncommon::bodytag('',$function,'topmargin="0",marginheight="0"',1);      my $bodytag = &Apache::loncommon::bodytag('',$function,'topmargin="0",marginheight="0"',1);
     my $tablecolor = &Apache::loncommon::designparm($function.'.tabbg');      my $tablecolor = &Apache::loncommon::designparm($function.'.tabbg');
       if (($tablecolor eq '') || ($tablecolor eq '#FFFFFF')) {
           $tablecolor = '#CCCCFF';
       }
     $os = $ENV{'browser.os'};      $os = $ENV{'browser.os'};
     $browser = $ENV{'browser.type'};      $browser = $ENV{'browser.type'};
     $bversion = $ENV{'browser.version'};      $bversion = $ENV{'browser.version'};
Line 49  sub print_request_form { Line 49  sub print_request_form {
     $usec = $ENV{'request.course.sec'};      $usec = $ENV{'request.course.sec'};
     $cid = $ENV{'request.course.id'};      $cid = $ENV{'request.course.id'};
     $server = $ENV{'SERVER_NAME'};      $server = $ENV{'SERVER_NAME'};
     my $scripttag;      my $scripttag = (<<END);
   function validate() {
       if (document.logproblem.email.value.indexOf("\@") == -1) {
           alert("You must enter a valid e-mail address");
           return
       }
       document.logproblem.submit();
   }
   END
     if ($cid =~ m/_/) {      if ($cid =~ m/_/) {
         ($cdom,$cnum) = split/_/,$cid;          ($cdom,$cnum) = split/_/,$cid;
     }      }
Line 77  sub print_request_form { Line 85  sub print_request_form {
         my ($sec,$grp) = split/:/,$_;          my ($sec,$grp) = split/:/,$_;
         $groupid{$sec} = $grp;          $groupid{$sec} = $grp;
     }      }
     $r->print(<<END);  
 <html>  
  <head>  
   <title>LON-CAPA support request</title>  
 END  
     my $defdom = $Apache::lonnet::perlvar{'lonDefDomain'};      my $defdom = $Apache::lonnet::perlvar{'lonDefDomain'};
     my $codedom = $defdom;      my $codedom = $defdom;
     my %coursecodes = ();      my %coursecodes = ();
Line 89  END Line 92  END
     my @codetitles = ();      my @codetitles = ();
     my %cat_titles = ();      my %cat_titles = ();
     my %cat_order = ();      my %cat_order = ();
       my %idlist = ();
       my %idnums = ();
       my %idlist_titles = ();
     my $caller = 'global';      my $caller = 'global';
     my $totcodes = 0;      my $totcodes = 0;
     my $format_reply;      my $format_reply;
       my $jscript = '';
           
     if ($cdom) {      if ($cdom) {
         $codedom = $cdom;          $codedom = $cdom;
Line 110  END Line 117  END
     }      }
     if ($totcodes > 0) {      if ($totcodes > 0) {
         $format_reply = &Apache::lonnet::auto_instcode_format($caller,$codedom,\%coursecodes,\%codes,\@codetitles,\%cat_titles,\%cat_order);          $format_reply = &Apache::lonnet::auto_instcode_format($caller,$codedom,\%coursecodes,\%codes,\@codetitles,\%cat_titles,\%cat_order);
           if ($ccode eq '') {
               my $numtypes = @codetitles;
               &build_code_selections(\%codes,\@codetitles,\%cat_titles,\%cat_order,\%idlist,\%idnums,\%idlist_titles);
               &javascript_code_selections($numtypes,\$jscript,\%idlist,\%idnums,\%idlist_titles,\@codetitles);
           }
     }      }
     $r->print(<<END);      $r->print(<<END);
 <html>  <html>
 <head>  <head>
  <title>LON-CAPA support request</title>   <title>LON-CAPA support request</title>
   <script>
 $scripttag  $scripttag
   $jscript
   </script>
 </head>  </head>
 $bodytag  $bodytag
  <table width="580" border="0" cellpadding="0" cellspacing="0" bgcolor="#000000">   <table width="580" border="0" cellpadding="0" cellspacing="0" bgcolor="#000000">
Line 128  $bodytag Line 143  $bodytag
         <tr>          <tr>
          <td>           <td>
   <table width="100%" border="0" cellpadding="0" cellspacing="1" bgcolor="#ffffff">    <table width="100%" border="0" cellpadding="0" cellspacing="1" bgcolor="#ffffff">
            <form method="post" name="logproblem" onSubmit="return validate()">             <form method="post" name="logproblem" enctype="multipart/form-data">
            <tr>             <tr>
             <td width="140" bgcolor="$tablecolor">              <td width="140" bgcolor="$tablecolor">
              <table width="140" border="0" cellpadding="8" cellspacing="0">               <table width="140" border="0" cellpadding="8" cellspacing="0">
Line 249  END Line 264  END
              <table width="100%" border="0" cellpadding="8" cellspacing="0">               <table width="100%" border="0" cellpadding="8" cellspacing="0">
               <tr>                <tr>
                <td>                 <td>
                 $server$origurl<input type="hidden" name="origurl" value="$server$origurl" />                  http://$server$origurl<input type="hidden" name="origurl" value="http://$server$origurl" />
                </td>                 </td>
               </tr>                </tr>
              </table>               </table>
Line 300  END Line 315  END
 END  END
     if ($coursecodes{$cnum}) {      if ($coursecodes{$cnum}) {
         foreach (@codetitles) {          foreach (@codetitles) {
             $r->print('<i>'.$_.'</i>:&nbsp;'.$codes{$cnum}{$_});              $r->print('<i>'.$_.'</i>:&nbsp;'.$codes{$cnum}{$_}.';&nbsp;');
         }          }
         $r->print('.&nbsp;<input type="hidden" name="coursecode" value="'.$coursecodes{$cnum}.'" />');          $r->print('&nbsp;<input type="hidden" name="coursecode" value="'.$coursecodes{$cnum}.'" />');
     } else {      } else {
         $r->print('Enter institutional course code:&nbsp;          $r->print('Enter institutional course code:&nbsp;
                   <input type="text" name="coursecode" size="15" value="" />');                    <input type="text" name="coursecode" size="15" value="" />');
Line 344  END Line 359  END
             if ($_ eq $groupid{$_} || $groupid{$_} eq '') {              if ($_ eq $groupid{$_} || $groupid{$_} eq '') {
                 $r->print("<option value=\"$_\" />$_");                  $r->print("<option value=\"$_\" />$_");
             } else {              } else {
                 $r->print("<option value=\"$_\" />$_ - (LON-CAPA sec: $groupid{$_}");                  $r->print("<option value=\"$_\" />$_ - (LON-CAPA sec: $groupid{$_})");
             }              }
         }          }
         $r->print("</select>");          $r->print("</select>");
Line 410  END Line 425  END
              <img src="/adm/lonMisc/blackdot.gif" /><br />               <img src="/adm/lonMisc/blackdot.gif" /><br />
     </td>      </td>
    </tr>     </tr>
   END
       if (defined($ENV{'user.name'})) {
           $r->print(<<END);
              <tr>
               <td width="140" bgcolor="$tablecolor">
                <table width="140" border="0" cellpadding="8" cellspacing="0">
                 <tr>
                  <td align="right"><b>Optional file upload:</b>
                  </td>
                 </tr>
                </table>
               </td>
               <td width="100%" valign="top">
                <table width="100%" border="0" cellpadding="8" cellspacing="0">
                 <tr>
                  <td>
                   <input type="file" name="screenshot" size="20" /><br />Upload a file (e.g., a screenshot) relevant to your support request (128 KB max. size).
                  </td>
                 </tr>
                </table>
               </td>
              </tr>
              <tr>
               <td width="100%" colspan="2" bgcolor="#000000">
                <img src="/adm/lonMisc/blackdot.gif" /><br />
               </td>
              </tr>
   END
       }
       $r->print(<<END);
            <tr>             <tr>
             <td width="140" bgcolor="$tablecolor">              <td width="140" bgcolor="$tablecolor">
              <table width="140" border="0" cellpadding="8" cellspacing="0">               <table width="140" border="0" cellpadding="8" cellspacing="0">
Line 424  END Line 469  END
               <tr>                <tr>
                <td>                 <td>
                 <input type="hidden" name="action" value="process" />                  <input type="hidden" name="action" value="process" />
                 <input type="submit" value="Submit Request Form" /> &nbsp;                  <input type="button" value="Submit Request Form" onClick="validate()"/> &nbsp;
                </td>                 </td>
                <td>&nbsp;</td>                 <td>&nbsp;</td>
                <td>                 <td>
Line 445  END Line 490  END
   </tr>    </tr>
  </table>   </table>
 END  END
       return;
   
 # What do we know about this user?  
 #    foreach (sort keys %ENV) {  
 #        if ($_ =~ m/^browser/) {  
 #            $r->print("key is $_, value is $ENV{$_}");  
 #        } elsif ($_ =~ m/^environment/) {  
 #            $r->print("key is $_, value is $ENV{$_}");  
 #        } elsif ($_ =~ m/^request/) {  
 #            $r->print("key is $_, value is $ENV{$_}");  
 #        } elsif ($_ =~ m/^user\.(domain|home|name)/) {  
 #            $r->print("key is $_, value is $ENV{$_}");  
 #        } elsif ($_ =~ /^[A-Z]/) {  
 #            $r->print("key is $_, value is $ENV{$_}");  
 #        }  
 #    }  
     return  
 }  }
   
 sub print_request_receipt {  sub print_request_receipt {
     my ($r,$url,$function) = @_;      my ($r,$url,$function) = @_;
     my @envvars = ('lonID','HTTP_HOST','HTTP_USER_AGENT','REMOTE_ADDR','SERVER_ADDR','SERVER_NAME','browser.os','browser.type','browser.version','user.home','request.role');      my @envvars = ('lonID','HTTP_HOST','HTTP_USER_AGENT','REMOTE_ADDR','SERVER_ADDR','SERVER_NAME','browser.os','browser.type','browser.version','user.home','request.role');
       my @loncvars = ('user.name','user.domain','request.course.sec','request.course.id');
   
     my $bodytag = &Apache::loncommon::bodytag('',$function,'topmargin="0" marginheight="0"',1);      my $bodytag = &Apache::loncommon::bodytag('',$function,'topmargin="0" marginheight="0"',1);
       my $admin = $Apache::lonnet::perlvar{'lonAdminMail'};
     my $to =  $Apache::lonnet::perlvar{'lonSupportEMail'};      my $to =  $Apache::lonnet::perlvar{'lonSupportEMail'};
       my $from = $admin;
     my $reporttime = &Apache::lonlocal::locallocaltime(time);      my $reporttime = &Apache::lonlocal::locallocaltime(time);
     my $fontcolor = &Apache::loncommon::designparm($function.'.font');      my $fontcolor = &Apache::loncommon::designparm($function.'.font');
     my $vlinkcolor = &Apache::loncommon::designparm($function.'.vlink');      my $vlinkcolor = &Apache::loncommon::designparm($function.'.vlink');
     my $tablecolor = &Apache::loncommon::designparm($function.'.tabbg');      my $tablecolor = &Apache::loncommon::designparm($function.'.tabbg');
     my @formvars = ('username','email','uname','udom','origurl','phone','section','coursecode','title','subject','description');      my @formvars = ('username','email','uname','udom','origurl','phone','section','coursecode','title','subject','description','screenshot');
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},\@formvars);      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},\@formvars);
   
 #    if ($ENV{'request.course.fn'}) {  
 #        my $formdatafile = $ENV{'request.course.fn'}.'.formdata';  
 #        if (-e $formdatafile) {  
 #            open(FILE,"<$formdatafile");  
 #            my @buffer =<FILE>;  
 #            close(FILE);  
 #            foreach (@buffer) {  
 #                print STDERR $_;  
 #            }   
 #        }  
 #    }  
   
     my $supportmsg = qq|      my $supportmsg = qq|
 Name: $ENV{'form.username'}  Name: $ENV{'form.username'}
 Email: $ENV{'form.email'}  Email: $ENV{'form.email'}
Line 500  URL: $ENV{'form.origurl'} Line 521  URL: $ENV{'form.origurl'}
 Date/Time: $reporttime  Date/Time: $reporttime
   
     |;      |;
       my $descrip = $ENV{'form.description'};
       $descrip =~ s#\n#<br />#g;
       my $displaymsg = qq|
   <font color="$fontcolor">Name:</font><font color="$vlinkcolor"> $ENV{'form.username'}</font><br />
   <font color="$fontcolor">Email: </font><font color="$vlinkcolor">$ENV{'form.email'}</font><br />
   <font color="$fontcolor">Username/domain: </font><font color="$vlinkcolor">$ENV{'form.uname'} - $ENV{'form.udom'}</font><br />
   <font color="$fontcolor">Tel: </font><font color="$vlinkcolor">$ENV{'form.phone'}</font><br />
   <font color="$fontcolor">Course Information: </font><font color="$vlinkcolor">$ENV{'form.title'} - $ENV{'form.coursecode'} - section: $ENV{'form.section'}</font><br />
   <font color="$fontcolor">Subject: </font><font color="$vlinkcolor">$ENV{'form.subject'}</font><br />
   <font color="$fontcolor">Description: </font><font color="$vlinkcolor">$descrip</font><br />
   <font color="$fontcolor">URL: </font><font color="$vlinkcolor">$ENV{'form.origurl'}</font><br />
   <font color="$fontcolor">Date/Time: </font><font color="$vlinkcolor">$reporttime</font><br />
       |;
   
     if ($to =~ m/^[^\@]+\@[^\@]+$/) {      if ($to =~ m/^[^\@]+\@[^\@]+$/) {
         $r->print(<<END);          $r->print(<<END);
 <html>  <html>
Line 510  $bodytag Line 545  $bodytag
  <h3>A support request has been sent to $to</h3>   <h3>A support request has been sent to $to</h3>
 END  END
     } else {       } else { 
         $to = 'helpdesk@lon-capa.org';  
         $r->print(<<END);          $r->print(<<END);
 <html>  <html>
 <head>  <head>
Line 518  END Line 552  END
 </head>  </head>
 $bodytag  $bodytag
  <h3>Warning: Problem with support e-mail address</h3>   <h3>Warning: Problem with support e-mail address</h3>
 As the e-mail address provided for this LON-CAPA server ($to) does not appear to be a valid e-mail address, your support request has not been sent to the LON-CAPA support staff at your institution. Instead a copy has been sent to the LON-CAPA support team at Michigan State University.   As the e-mail address provided for this LON-CAPA server ($to) does not appear to be a valid e-mail address, your support request has <b>not</b> been sent to the LON-CAPA support staff at your institution. Instead a copy has been sent to the LON-CAPA support team at Michigan State University. 
 END  END
           $to = 'helpdesk@lon-capa.org';
     }      }
     my $msg = new Mail::Send;      if (defined($ENV{'form.email'})) {
     $msg->to($to);          if ($ENV{'form.email'} =~ m/^[^\@]+\@[^\@]+$/) {
 #    if (defined($ENV{'form.email'})) {              $from = $ENV{'form.email'};
 #        if ($ENV{'form.email'} =~ m/^[^\@]+\@[^\@]+$/) {          }
 #            $msg->from($ENV{'form.email'});  
 #        }  
 #    }  
     $msg->subject('[LON-CAPA] - support request');  
     if (my $fh = $msg->open()) {  
         print $fh $supportmsg;  
         $fh->close;  
     }      }
     $r->print(<<END);  
       my $subject = $ENV{'form.subject'};
       $subject =~ s#(`)#'#g;
       $subject =~ s#\$#\(\$\)#g;
       $supportmsg =~ s#(`)#'#g;
       $supportmsg =~ s#\$#\(\$\)#g;
       $displaymsg =~ s#(`)#'#g;
       $displaymsg =~ s#\$#\(\$\)#g;
       my $fname;
   
       my $attachmentpath = '';
       my $attachmentsize = '';
       if (defined($ENV{'user.name'})) {
           if ($ENV{'form.screenshot.filename'}) {
               $attachmentsize = length($ENV{'form.screenshot'});
               if ($attachmentsize > 131072) {
                   $displaymsg .= "<br />The uploaded screenshot file ($attachmentsize bytes) included with your request exceeded the maximum allowed size - 128 KB, and has therefore been discarded.";
               } else {
                   $attachmentpath=&Apache::lonnet::userfileupload('screenshot',undef,'helprequests');
               }
           }
       }
   
       if ($attachmentpath =~ m-/([^/]+)$-) {
           $fname = $1;
           $displaymsg .= "<br />An uploaded screenshot file - $fname ($attachmentsize bytes) was included in the request sent by $ENV{'user.name'} from LON-CAPA domain: $ENV{'user.domain'}";
           $supportmsg .= "\n";
           foreach (@envvars) {
               $supportmsg .= "$_: $ENV{$_}\n";
           }
       }
    
       my $msg = MIME::Lite->new(
                    From    => $from,
                    To      => $to,
                    Subject => $subject,
                    Type    =>'TEXT',
                    Data    => $supportmsg,
                    );
   
       if ($attachmentpath) {
           my ($type, $encoding) = MIME::Types::by_suffix($attachmentpath);
           $msg->attach(Type     => $type,
                        Path     => $attachmentpath,
                        Filename => $fname
                        );
   
       } else {
           my $envdata = '';
           foreach (@envvars) {
               $envdata .= "$_: $ENV{$_}\n";
           }
           foreach (@loncvars) {
               $envdata .= "$_: $ENV{$_}\n";
           }
           $msg->attach(Type => 'TEXT',
                        Data => $envdata);
       }
   
   ### Send it:
       # ->send can cause an sh launch which can pass all of %ENV along
       # which can be to large for /bin/sh's little mind
       my %oldENV=%ENV;
       undef(%ENV);
       $msg->send('sendmail');
       %ENV=%oldENV;
       undef(%oldENV);
   
       if ($attachmentpath =~ m#$Apache::lonnet::perlvar{'lonDaemons'}/tmp/helprequests/(\d+)/[^/]+#) {
           unlink($attachmentpath);
       }
       $r->print(qq|
  <b>Your support request contained the following information</b>:<br /><br />   <b>Your support request contained the following information</b>:<br /><br />
  <table width="580" border="0" cellpadding="0" cellspacing="0" bgcolor="#000000">   <table width="580" border="0" cellpadding="0" cellspacing="0" bgcolor="#000000">
   <tr>    <tr>
Line 557  END Line 656  END
             <td width="100%" valign="top">              <td width="100%" valign="top">
              <table width="100%" border="0" cellpadding="8" cellspacing="0">               <table width="100%" border="0" cellpadding="8" cellspacing="0">
               <tr>                <tr>
                <td>                 <td>$displaymsg</td>
 END  
     my @textmsg = split/\n/,$supportmsg;  
     foreach my $line (@textmsg) {  
         $line =~ s|^|<font color="$fontcolor">|;  
         $line =~ s|:|:</font><font color="$vlinkcolor">|;  
         $r->print("$line</font><br />");  
     }  
     $r->print('</td>  
               </tr>                </tr>
              </table>               </table>
             </td>              </td>
            </tr>             </tr>
            <tr>             <tr>
             <td width="130" bgcolor="'.$tablecolor.'">              <td width="100%" colspan="2" bgcolor="#000000">
              <table width="130" border="0" cellpadding="8" cellspacing="0">               <img src="/adm/lonMisc/blackdot.gif" /><br />
               </td>
              </tr>
              <tr>
               <td width="140" bgcolor="$tablecolor">
                <table width="140" border="0" cellpadding="8" cellspacing="0">
               <tr>                <tr>
                <td align="right"><b>Additional information recorded</b>                 <td align="right"><b>Additional information recorded</b>
                </td>                 </td>
Line 583  END Line 679  END
              <table width="100%" border="0" cellpadding="8" cellspacing="0">               <table width="100%" border="0" cellpadding="8" cellspacing="0">
               <tr>                <tr>
                <td>                 <td>
     ');      |);
     foreach (@envvars) {      foreach (@envvars) {
         $r->print("$_:&nbsp;<font color='$vlinkcolor>$ENV{$_}</font>, ");          unless($ENV{$_} eq '') { 
         $supportmsg .= "$_: $ENV{$_}\n";              $r->print("$_:&nbsp;<font color='$vlinkcolor'>$ENV{$_}</font>, ");
           }
     }      }
     $r->print("      $r->print("
                </td>                 </td>
Line 619  sub retrieve_instcodes { Line 716  sub retrieve_instcodes {
     return $totcodes;      return $totcodes;
 }  }
   
   sub build_code_selections {
       my ($codes,$codetitles,$cat_titles,$cat_order,$idlist,$idnums,$idlist_titles) = @_;
       my %idarrays = ();
       for (my $i=1; $i<@{$codetitles}; $i++) {
           %{$idarrays{$$codetitles[$i]}} = ();
       }
       foreach my $cid (sort keys %{$codes}) {
           &recurse_list($cid,$codetitles,$codes,0,\%idarrays);
       }
       for (my $num=0; $num<@{$codetitles}; $num++) {
           if ($num == 0) {
               my @contents = ();
               my @contents_titles = ();
               &sort_cats($num,$cat_order,$codetitles,\@{$idarrays{$$codetitles[0]}},\@contents);
               if (defined($$cat_titles{$$codetitles[0]})) {
                   foreach (@contents) {
                       push @contents_titles, $$cat_titles{$$codetitles[0]}{$_};
                   }
               }
               $$idlist{$$codetitles[0]} = join('","',@contents);
               $$idnums{$$codetitles[0]} = scalar(@contents);
               if (defined($$cat_titles{$$codetitles[0]})) {
                   $$idlist_titles{$$codetitles[0]} = join('","',@contents_titles);
               }
           } elsif ($num == 1) {
               %{$$idlist{$$codetitles[1]}} = ();
               %{$$idlist_titles{$$codetitles[1]}} = ();
               foreach my $key_a (keys %{$idarrays{$$codetitles[1]}}) {
                   my @sorted_a = ();
                   my @sorted_a_titles = ();
                   &sort_cats($num,$cat_order,$codetitles,\@{$idarrays{$$codetitles[1]}{$key_a}},\@sorted_a);
                   if (defined($$cat_titles{$$codetitles[1]})) {
                       foreach (@sorted_a) {
                           push @sorted_a_titles, $$cat_titles{$$codetitles[1]}{$_};
                       }
                   }
                   $$idlist{$$codetitles[1]}{$key_a} = join('","',@sorted_a);
                   $$idnums{$$codetitles[1]}{$key_a} = scalar(@sorted_a);
                   if (defined($$cat_titles{$$codetitles[1]})) {
                       $$idlist_titles{$$codetitles[1]}{$key_a} = join('","',@sorted_a_titles);
                   }
               }
           } elsif ($num == 2) {
               %{$$idlist{$$codetitles[2]}} = ();
               %{$$idlist_titles{$$codetitles[2]}} = ();
               foreach my $key_a (keys %{$idarrays{$$codetitles[2]}}) {
                   %{$$idlist{$$codetitles[2]}{$key_a}} = ();
                   %{$$idlist_titles{$$codetitles[2]}{$key_a}} = ();
                   foreach my $key_b (keys %{$idarrays{$$codetitles[2]}{$key_a}}) {
                       my @sorted_b = ();
                       my @sorted_b_titles = ();
                       &sort_cats($num,$cat_order,$codetitles,\@{$idarrays{$$codetitles[2]}{$key_a}{$key_b}},\@sorted_b);
                       if (defined($$cat_titles{$$codetitles[1]})) {
                           foreach (@sorted_b) {
                               push @sorted_b_titles, $$cat_titles{$$codetitles[1]}{$_};
                           }
                       }
                       $$idlist{$$codetitles[2]}{$key_a}{$key_b} = join('","',@sorted_b);
                       $$idnums{$$codetitles[2]}{$key_a}{$key_b} = scalar(@sorted_b);
                       if (defined($$cat_titles{$$codetitles[2]})) {
                           $$idlist_titles{$$codetitles[2]}{$key_a}{$key_b} = join('","',@sorted_b_titles);
                       }
                   }
               }
           } elsif ($num == 3) {
               %{$$idlist{$$codetitles[3]}} = ();
               foreach my $key_a (keys %{$idarrays{$$codetitles[3]}}) {
                   %{$$idlist{$$codetitles[3]}{$key_a}} = ();
                   foreach my $key_b (keys %{$idarrays{$$codetitles[3]}{$key_a}}) {
                       %{$$idlist{$$codetitles[3]}{$key_a}{$key_b}} = ();
                       foreach my $key_c (keys %{$idarrays{$$codetitles[3]}{$key_a}{$key_b}}) {
                           my @sorted_c = ();
                           &sort_cats($num,$cat_order,$codetitles,\@{$idarrays{$$codetitles[3]}{$key_a}{$key_b}{$key_c}},\@sorted_c);
                           $$idlist{$$codetitles[3]}{$key_a}{$key_b}{$key_c} = join('","',@sorted_c);
                           $$idnums{$$codetitles[3]}{$key_a}{$key_b}{$key_c} = scalar(@sorted_c);
                       }
                   }
               }
           } elsif ($num == 4) {
               %{$$idlist{$$codetitles[4]}} = ();
               foreach my $key_a (keys %{$idarrays{$$codetitles[4]}}) {
                   %{$$idlist{$$codetitles[4]}{$key_a}} = ();
                   foreach my $key_b (keys %{$idarrays{$$codetitles[4]}{$key_a}}) {
                       %{$$idlist{$$codetitles[4]}{$key_a}{$key_b}} = ();
                       foreach my $key_c (keys %{$idarrays{$$codetitles[4]}{$key_a}{$key_b}}) {
                           %{$$idlist{$$codetitles[4]}{$key_a}{$key_b}{$key_c}} = ();
                           foreach my $key_d (keys %{$idarrays{$$codetitles[4]}{$key_a}{$key_b}{$key_c}}) {
                               my @sorted_d = ();
                               &sort_cats($num,$cat_order,$codetitles,$idarrays{$$codetitles[4]}{$key_a}{$key_b}{$key_c}{$key_d},\@sorted_d);
                               $$idlist{$$codetitles[4]}{$key_a}{$key_b}{$key_c}{$key_d} = join('","',@sorted_d);
                               $$idnums{$$codetitles[4]}{$key_a}{$key_b}{$key_c}{$key_d} = scalar(@sorted_d);
                           }
                       }
                   }
               }
           }
       }
   }
   
   sub sort_cats {
       my ($num,$cat_order,$codetitles,$idsarrayref,$sorted) = @_;
       my @unsorted = @{$idsarrayref};
       if (defined($$cat_order{$$codetitles[$num]})) {
           foreach (@{$$cat_order{$$codetitles[$num]}}) {
               if (grep/^$_$/,@unsorted) {
                   push @{$sorted}, $_;
               }
           }
       } else {
           @{$sorted} = sort (@unsorted);
       }
   }
   
   
   sub recurse_list {
       my ($cid,$codetitles,$codes,$num,$idarrays) = @_;
       if ($num == 0) {
           if (!grep/^$$codes{$cid}{$$codetitles[0]}$/,@{$$idarrays{$$codetitles[0]}}) {
               push @{$$idarrays{$$codetitles[0]}}, $$codes{$cid}{$$codetitles[0]};
           }
       } elsif ($num == 1) {
           if (defined($$idarrays{$$codetitles[1]}{$$codes{$cid}{$$codetitles[0]}})) {
               if (!grep/^$$codes{$cid}{$$codetitles[1]}$/,@{$$idarrays{$$codetitles[1]}{$$codes{$cid}{$$codetitles[0]}}}) {
                   push @{$$idarrays{$$codetitles[1]}{$$codes{$cid}{$$codetitles[0]}}}, $$codes{$cid}{$$codetitles[1]};
               }
           } else {
               @{$$idarrays{$$codetitles[1]}{$$codes{$cid}{$$codetitles[0]}}} = ("$$codes{$cid}{$$codetitles[1]}");
           }
       } elsif ($num == 2) {
           if (defined($$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}})) {
               if (defined($$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}})) {
                   if (!grep/^$$codes{$cid}{$$codetitles[2]}$/,@{$$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}}) {
                       push @{$$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}}, $$codes{$cid}{$$codetitles[2]};
                   }
               } else {
                   @{$$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ("$$codes{$cid}{$$codetitles[2]}");
               }
           } else {
               %{$$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}} = ();
               @{$$idarrays{$$codetitles[2]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ("$$codes{$cid}{$$codetitles[2]}");
           }
       } elsif ($num == 3) {
           if (defined($$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}})) {
               if (defined($$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}})) {
                   if (defined($$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}})) {
                       if (!grep/^$$codes{$cid}{$$codetitles[3]}$/,@{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}}) {
                           push @{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}}, $$codes{$cid}{$$codetitles[3]};
                       }
                   } else {
                       @{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ("$$codes{$cid}{$$codetitles[3]}");
                   }
               } else {
                   %{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ();
                   @{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ("$$codes{$cid}{$$codetitles[3]}");
               }
           } else {
               %{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}} = ();
               %{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ();
               @{$$idarrays{$$codetitles[3]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ("$$codes{$cid}{$$codetitles[3]}");
           }
       } elsif ($num == 4) {
           if (defined($$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}})) {
               if (defined($$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}})) {
                   if (defined($$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}})) {
                       if (defined($$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}})) {
                           if (!grep/^$$codes{$cid}{$$codetitles[4]}$/,@{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}}}) {
                               push @{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}}}, $$codes{$cid}{$$codetitles[4]};
                           }
                       } else {
                           @{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}}} = ("$$codes{$cid}{$$codetitles[4]}");
                       }
                   } else {
                       %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ();
                       @{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}}} = ("$$codes{$cid}{$$codetitles[4]}");
                   }
               } else {
                   %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ();
                   %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ();
                   @{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}{$$codes{$cid}{$$codetitles[3]}}} = ("$$codes{$cid}{$$codetitles[4]}");
               }
           } else {
               %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}} = ();
               %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}} = ();
               %{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[2]}}} = ();
               @{$$idarrays{$$codetitles[4]}{$$codes{$cid}{$$codetitles[0]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[1]}}{$$codes{$cid}{$$codetitles[3]}}} = ("$$codes{$cid}{$$codetitles[3]}");
           }
       }
       $num ++;
       if ($num <@{$codetitles}) {
           &recurse_list($cid,$codetitles,$codes,$num,$idarrays);
       }
   }
   
   sub javascript_code_selections {
       my ($numcats,$script_tag,$idlist,$idnums,$idlist_titles,$codetitles) = @_;
       $$script_tag .= <<END;
   function courseSet(caller) {
       var idyr = document.forms.logproblem.idyear.selectedIndex
       var idsem  = document.forms.logproblem.idsem.selectedIndex
       var iddept = document.forms.logproblem.iddept.selectedIndex
       var idclass = document.forms.logproblem.idclass.selectedIndex
       var idyears = new Array("$$idlist{$$codetitles[0]}");
       var idsems = new Array ($$idnums{$$codetitles[0]});
       var idsemlongs = new Array ($$idnums{$$codetitles[0]});
       var idcodes = new Array ($$idnums{$$codetitles[0]});
       var idcourses = new Array ($$idnums{$$codetitles[0]});
       var idsections = new Array ($$idnums{$$codetitles[0]})
   END
       my @sort_a = split/","/,$$idlist{$$codetitles[0]}; 
       for (my $j=0; $j<@sort_a; $j++) {
           $$script_tag .= qq| idsems[$j] = new Array("$$idlist{$$codetitles[1]}{$sort_a[$j]}")\n|;
           $$script_tag .= qq| idsemlongs[$j] = new Array("$$idlist_titles{$$codetitles[1]}{$sort_a[$j]}")\n|;
           $$script_tag .= qq| idcodes[$j] = new Array($$idnums{$$codetitles[1]}{$sort_a[$j]})\n|;
           $$script_tag .= qq| idcourses[$j] = new Array($$idnums{$$codetitles[1]}{$sort_a[$j]})\n|;
           $$script_tag .= qq| idsections[$j] = new Array($$idnums{$$codetitles[1]}{$sort_a[$j]})\n|;
           my @sort_b = split/","/,$$idlist{$$codetitles[1]}{$sort_a[$j]};
           for (my $k=0; $k<@sort_b; $k++) {
               my $idcode_entry = $$idlist{$$codetitles[2]}{$sort_a[$j]}{$sort_b[$k]};
               $$script_tag .= qq| idcodes[$j][$k] = new Array("$idcode_entry")\n|;
               $$script_tag .= qq| idcourses[$j][$k] = new Array($$idnums{$$codetitles[2]}{$sort_a[$j]}{$sort_b[$k]})\n|;
               $$script_tag .= qq| idsections[$j][$k] = new Array($$idnums{$$codetitles[2]}{$sort_a[$j]}{$sort_b[$k]})\n|;
               my @sort_c = split/","/,$$idlist{$$codetitles[2]}{$sort_a[$j]}{$sort_b[$k]};
               for (my $l=0; $l<@sort_c; $l++) {
                   my $idcourse_entry = $$idlist{$$codetitles[3]}{$sort_a[$j]}{$sort_b[$k]}{$sort_c[$l]};
                   $$script_tag .= qq| idcourses[$j][$k][$l] = new Array("$idcourse_entry")\n|;
                   $$script_tag .= qq| idsections[$j][$k][$l] = new Array($$idnums{$$codetitles[3]}{$sort_a[$j]}{$sort_b[$k]}{$sort_c[$l]})\n|;
                   my @sort_d = split/","/,$$idlist{$$codetitles[3]}{$sort_a[$j]}{$sort_b[$k]}{$sort_c[$l]};
                   for (my $m=0; $m<@sort_d; $m++) {
                       my $idsecentry = $$idlist{$$codetitles[4]}{$sort_a[$j]}{$sort_b[$k]}{$sort_c[$l]}{$sort_d[$m]};
                       $$script_tag .= qq| idsections[$j][$k][$l][$m] = new Array("$idsecentry")\n|;
                   }
               }
           }
       }
       $$script_tag .= (<<END_OF_BLOCK);
    if (caller == "semester") {
      document.forms.logproblem.iddept.length = 0
      document.forms.logproblem.idclass.length = 0
      document.forms.logproblem.idsec.length = 0
      document.forms.logproblem.iddept.options[0] = new Option("<-Pick sem.","-1",true,true)
      document.forms.logproblem.idclass.options[0] = new Option("<-Pick dept.","-1",true,true)
      document.forms.logproblem.idsec.options[0] = new Option("Pick course first (above)","-1",true,true)
      if (idyr == 0) {
       document.forms.logproblem.idsem.length = 0
       document.forms.logproblem.idsem.options[0] = new Option("<-Pick year","-1",true,true)
      }
      else {
       document.forms.logproblem.idsem.length = 0
       document.forms.logproblem.idsem.options[0] = new Option("Select","-1",true,true)
       for (var i=0; i<idsems[idyr-1].length; i++) {
         document.forms.logproblem.idsem.options[i+1] = new Option(idsemlongs[idyr-1][i],idsems[idyr-1][i],false,false)
       }
      }
      document.forms.logproblem.idsem.selectedIndex = 0;
    }
    if (caller == "dept") {
      document.forms.logproblem.iddept.length = 0
      document.forms.logproblem.idclass.length = 0
      document.forms.logproblem.idsec.length = 0
      document.forms.logproblem.idclass.options[0] = new Option("<-Pick dept.","-1",true,true)
      document.forms.logproblem.idsec.options[0] = new Option("Pick course first (above)","-1",true,true)
      if (idsem == 0) {
        document.forms.logproblem.iddept.options[0] = new Option("<-Pick sem.","-1",true,true)
        document.forms.logproblem.iddept.options[0] = new Option("<-Pick sem.","-1",true,true)
      }
      else {
       document.forms.logproblem.iddept.options[0] = new Option("Select","-1",true,true)    
       for (var i=0; i<idcodes[idyr-1][idsem-1].length; i++) {
         document.forms.logproblem.iddept.options[i+1] = new Option(idcodes[idyr-1][idsem-1][i],idcodes[idyr-1][idsem-1][i],false,false)
       }
      }
      document.forms.logproblem.iddept.selectedIndex = 0
    }
    if (caller == "course") {
      document.forms.logproblem.idclass.length = 0
      document.forms.logproblem.idsec.length = 0
      document.forms.logproblem.idsec.options[0] = new Option("Pick course first (above)","-1",true,true)
      if (iddept == 0) {
        document.forms.logproblem.idclass.options[0] = new Option("<-Pick dept.","-1",true,true)
      }
      else {
       document.forms.logproblem.idclass.options[0] = new Option("Select","-1",true,true)
       for (var i=0; i<idcourses[idyr-1][idsem-1][iddept-1].length; i++) {
         document.forms.logproblem.idclass.options[i+1] = new Option(idcourses[idyr-1][idsem-1][iddept-1][i],idcourses[idyr-1][idsem-1][iddept-1][i],false,false)
       }
      }
      document.forms.logproblem.idclass.selectedIndex = 0
    }
   }
   END_OF_BLOCK
   }
   
 1;  1;

Removed from v.1.3  
changed lines
  Added in v.1.8


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>