Diff for /loncom/interface/lonrequestcourse.pm between versions 1.89 and 1.90

version 1.89, 2015/06/09 21:22:57 version 1.90, 2015/06/14 00:02:43
Line 1574  sub print_request_form { Line 1574  sub print_request_form {
                                                      \%cat_order,\@code_order);                                                       \%cat_order,\@code_order);
         }          }
         my $lonhost = $r->dir_config('lonHostID');          my $lonhost = $r->dir_config('lonHostID');
         my ($storeresult,$result) = &print_request_outcome($r,$lonhost,$dom,\@codetitles,          my ($storeresult,$result,$customized) = &print_request_outcome($r,$lonhost,$dom,\@codetitles,
                                                            \@code_order,$instcredits);                                                                        \@code_order,$instcredits);
         $r->print($result);          $r->print($result);
         if (($storeresult eq 'ok') || ($storeresult eq 'created')) {          if (($storeresult eq 'ok') || ($storeresult eq 'created')) {
             if ($storeresult eq 'ok') {              if ($storeresult eq 'ok') {
Line 1584  sub print_request_form { Line 1584  sub print_request_form {
                           '<a href="/adm/requestcourse">'.&mt('Make another request').'</a></p>');                            '<a href="/adm/requestcourse">'.&mt('Make another request').'</a></p>');
             }              }
             if (&Apache::loncoursequeueadmin::author_prompt()) {              if (&Apache::loncoursequeueadmin::author_prompt()) {
                 &print_author_prompt($r,$env{'form.action'},$env{'form.cnum'},$env{'form.showdom'},                  unless ($customized) {
                                      $env{'form.crstype'},$storeresult);                      &print_author_prompt($r,$env{'form.action'},$env{'form.cnum'},$env{'form.showdom'},
                                            $env{'form.crstype'},$storeresult);
                   }
             } elsif ($storeresult eq 'created') {              } elsif ($storeresult eq 'created') {
                 $r->print('<p><a href="/adm/requestcourse">'.&mt('Make another request').'</a></p>');                  unless ($customized) {
                       $r->print('<p><a href="/adm/requestcourse">'.&mt('Make another request').'</a></p>');
                   }
             }              }
         }          }
     } elsif ($state eq 'reqauthor') {      } elsif ($state eq 'reqauthor') {
Line 3636  sub print_request_outcome { Line 3640  sub print_request_outcome {
                     accessend      => $accessend,                      accessend      => $accessend,
                     personnel      => \%personnel,                      personnel      => \%personnel,
                   };                    };
     my ($result,$output) = &process_request($r,$lonhost,$dom,$cnum,$crstype,$now,$details,$instcode,      my ($result,$output,$customized) = &process_request($r,$lonhost,$dom,$cnum,$crstype,$now,$details,
                                             $req_notifylist,\@instsections,\%domconfig);                                                          $instcode,$req_notifylist,\@instsections,\%domconfig);
     return ($result,$output);      return ($result,$output,$customized);
 }  }
           
 sub process_request {  sub process_request {
     my ($r,$lonhost,$dom,$cnum,$crstype,$now,$details,$instcode,$req_notifylist,$instsections,      my ($r,$lonhost,$dom,$cnum,$crstype,$now,$details,$instcode,$req_notifylist,$instsections,
         $domconfig) = @_;           $domconfig) = @_; 
     my (@inststatuses,$storeresult,$creationresult,$output);      my (@inststatuses,$storeresult,$creationresult,$output,$customized);
     my $val =       my $val = 
         &Apache::loncoursequeueadmin::get_processtype('course',$env{'user.name'},          &Apache::loncoursequeueadmin::get_processtype('course',$env{'user.name'},
                                                       $env{'user.domain'},$env{'user.adv'},                                                        $env{'user.domain'},$env{'user.adv'},
Line 3663  sub process_request { Line 3667  sub process_request {
         }          }
         $storeresult = 'notpermitted';           $storeresult = 'notpermitted'; 
     } else {      } else {
         my ($disposition,$message,$reqstatus,$coursedesc);          my ($disposition,$message,$reqstatus,$coursedesc,%customvalidation);
         my %reqhash = (          my %reqhash = (
                         reqtime   => $now,                          reqtime   => $now,
                         crstype   => $crstype,                          crstype   => $crstype,
Line 3683  sub process_request { Line 3687  sub process_request {
             $disposition = &check_autolimit($env{'user.name'},$env{'user.domain'},              $disposition = &check_autolimit($env{'user.name'},$env{'user.domain'},
                                             $dom,$crstype,$limit,\$message);                                              $dom,$crstype,$limit,\$message);
         } elsif ($val eq 'validate') {          } elsif ($val eq 'validate') {
             my ($inststatuslist,$validationchk,$validation,%custominfo);              my ($inststatuslist,$validationchk,$validation);
             if (ref($details) eq 'HASH') {              if (ref($details) eq 'HASH') {
                 if ($details->{'clonecrs'}) {                  if ($details->{'clonecrs'}) {
                     $custominfo{'_LC_clonefrom'} = $details->{'clonedom'}.'_'.$details->{'clonecrs'};                      $customvalidation{'_LC_clonefrom'} = $details->{'clonedom'}.'_'.$details->{'clonecrs'};
                 }                  }
             }              }
             if (@inststatuses > 0) {              if (@inststatuses > 0) {
Line 3698  sub process_request { Line 3702  sub process_request {
                     $instseclist = join(',',@{$instsections});                      $instseclist = join(',',@{$instsections});
                 }                  }
             }              }
   #
   # Retrieve any custom form information used for validation 
   #
             my $preprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'prevalidate',$env{'user.name'},              my $preprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'prevalidate',$env{'user.name'},
                                                                  $env{'user.domain'},$fullname,$coursedesc);                                                                   $env{'user.domain'},$fullname,$coursedesc);
             if (ref($preprocess) eq 'HASH') {              if (ref($preprocess) eq 'HASH') {
                 if (ref($preprocess->{'formitems'}) eq 'HASH') {                  &custom_formitems($preprocess,\%customvalidation);
                     foreach my $key (keys(%{$preprocess->{'formitems'}})) {  
                         if ($preprocess->{'formitems'}->{$key} eq 'multiple') {  
                             if (exists($env{'form.'.$key})) {  
                                 @{$custominfo{$key}} = &Apache::loncommon::get_env_multiple($env{'form.'.$key});  
                             }  
                         } else {  
                             if (exists($env{'form.'.$key})) {  
                                 $custominfo{$key} = $env{'form.'.$key};  
                             }  
                         }  
                     }  
                 }  
             }              }
             $validationchk =               $validationchk = 
                 &Apache::lonnet::auto_courserequest_validation($dom,                  &Apache::lonnet::auto_courserequest_validation($dom,
                     $env{'user.name'}.':'.$env{'user.domain'},$crstype,                      $env{'user.name'}.':'.$env{'user.domain'},$crstype,
                     $inststatuslist,$instcode,$instseclist,\%custominfo);                      $inststatuslist,$instcode,$instseclist,\%customvalidation);
             if ($validationchk =~ /:/) {              if ($validationchk =~ /:/) {
                 ($validation,$message) = split(':',$validationchk);                  ($validation,$message) = split(':',$validationchk);
             } else {              } else {
Line 3738  sub process_request { Line 3733  sub process_request {
         my ($modified,$queued,$coursedesc,$token,%customitems);          my ($modified,$queued,$coursedesc,$token,%customitems);
         unless ($disposition eq 'rejected') {          unless ($disposition eq 'rejected') {
             my $inprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'process',$env{'user.name'},              my $inprocess = &Apache::lonnet::auto_crsreq_update($dom,$cnum,$crstype,'process',$env{'user.name'},
                                                                 $env{'user.domain'},$fullname,$coursedesc);                                                                  $env{'user.domain'},$fullname,$coursedesc,undef,
                                                                   undef,undef,\%customvalidation);
   #
   # Retrieve any custom form information submitted with review page and include in request details.
   #
             if (ref($inprocess) eq 'HASH') {              if (ref($inprocess) eq 'HASH') {
                 if (ref($inprocess->{'formitems'}) eq 'HASH') {                  &custom_formitems($inprocess,\%customitems);
                     foreach my $key (keys(%{$inprocess->{'formitems'}})) {                  foreach my $key (keys(%customitems)) {
                         if ($inprocess->{'formitems'}->{$key} eq 'multiple') {                      $reqhash{'custom'}{$key} = $customitems{$key};
                             if (exists($env{'form.'.$key})) {  
                                 @{$customitems{$key}} = &Apache::loncommon::get_env_multiple($env{'form.'.$key});  
                             }  
                         } else {  
                             if (exists($env{'form.'.$key})) {  
                                 $customitems{$key} = $env{'form.'.$key};  
                                 $reqhash{'custom'}{$key} = $customitems{$key};  
                             }  
                         }  
                     }  
                 }                  }
             }              }
         }          }
Line 3786  sub process_request { Line 3775  sub process_request {
                     $customitems{'_LC_clonefrom'} = $details->{'clonedom'}.'_'.$details->{'clonecrs'};                      $customitems{'_LC_clonefrom'} = $details->{'clonedom'}.'_'.$details->{'clonecrs'};
                 }                  }
             }              }
               $customitems{'_LC_ownerfullname'} = &Apache::loncommon::plainname($env{'user.name'},$env{'user.domain'},'first');
               my $owneremail;
               my %emails = &Apache::loncommon::getemails();
               foreach my $email ('permanentemail','critnotification','notification') {
                   $owneremail = $emails{$email};
                   last if ($owneremail ne '');
               }
               if ($owneremail ne '') {
                   $customitems{'_LC_owneremail'} = $owneremail;
               }
               $customitems{'_LC_coursedomainname'} = &Apache::lonnet::domain($dom,'description');
             my ($result,$postprocess) = &Apache::loncoursequeueadmin::course_creation($dom,$cnum,              my ($result,$postprocess) = &Apache::loncoursequeueadmin::course_creation($dom,$cnum,
                                           'autocreate',$details,\$logmsg,\$newusermsg,\$addresult,                                            'autocreate',$details,\$logmsg,\$newusermsg,\$addresult,
                                           \$enrollcount,\$response,\$keysmsg,\%domdefs,\%longroles,                                            \$enrollcount,\$response,\$keysmsg,\%domdefs,\%longroles,
                                           \$code,\%customitems);                                            \$code,\%customitems);
               if (ref($postprocess) eq 'HASH') {
                   $customized = $postprocess->{'createdcustomized'};
               }
             if ($result eq 'created') {              if ($result eq 'created') {
                 $disposition = 'created';                  $disposition = 'created';
                 $reqstatus = 'created';                  $reqstatus = 'created';
Line 3816  sub process_request { Line 3819  sub process_request {
                         }                          }
                     }                      }
                 }                  }
                 $output .= '<br />'.$role_result.'</p>';                  unless ($customized) { 
                       $output .= '<br />'.$role_result;
                   }
                   $output .= '</p>';
                 $creationresult = 'created';                  $creationresult = 'created';
             } else {              } else {
                 $output = '<span class="LC_error">';                  $output = '<span class="LC_error">';
Line 3921  sub process_request { Line 3927  sub process_request {
                 if ((ref($postprocess) eq 'HASH') &&                   if ((ref($postprocess) eq 'HASH') && 
                     ((ref($postprocess->{'queuedmsg'}) eq 'HASH') || ($postprocess->{'queuedweb'}))) {                       ((ref($postprocess->{'queuedmsg'}) eq 'HASH') || ($postprocess->{'queuedweb'}))) { 
                     &notification_information($disposition,undef,$dom,$cnum,$now,undef,$postprocess);                      &notification_information($disposition,undef,$dom,$cnum,$now,undef,$postprocess);
                       $customized = $postprocess->{'createdcustomized'};
                 }                  }
             } elsif ($disposition eq 'pending') {              } elsif ($disposition eq 'pending') {
                 my $pendingform;                  my $pendingform;
Line 3933  sub process_request { Line 3940  sub process_request {
                 } else {                   } else { 
                     $output .= &notification_information($disposition,undef,$dom,$cnum,$now,undef,$postprocess);                      $output .= &notification_information($disposition,undef,$dom,$cnum,$now,undef,$postprocess);
                 }                  }
                   if (ref($postprocess) eq 'HASH') {
                       $customized = $postprocess->{'createdcustomized'};
                   }
             }              }
         }          }
         if ($validationerror ne '') {          if ($validationerror ne '') {
Line 3943  sub process_request { Line 3953  sub process_request {
         }          }
     }      }
     if ($creationresult ne '') {      if ($creationresult ne '') {
         return ($creationresult,$output);          return ($creationresult,$output,$customized);
     } else {      } else {
         return ($storeresult,$output);          return ($storeresult,$output,$customized);
       }
   }
   
   sub custom_formitems {
       my ($preprocess,$customhash) = @_;
       return unless ((ref($preprocess) eq 'HASH') && (ref($customhash) eq 'HASH'));  
       if (ref($preprocess->{'formitems'}) eq 'HASH') {
           foreach my $key (keys(%{$preprocess->{'formitems'}})) {
               if ($preprocess->{'formitems'}->{$key} eq 'multiple') {
                   if (exists($env{'form.'.$key})) {
                       my @items = &Apache::loncommon::get_env_multiple($env{'form.'.$key});
                       foreach my $item (@items) {
                           $item =~ s/(`)/'/g;
                           $item =~ s/\$/\(\$\)/g;
                           push(@{$customhash->{$key}},$item);
                       }
                   }
               } else {
                   if (exists($env{'form.'.$key})) {
                       $customhash->{$key} = $env{'form.'.$key};
                       $customhash->{$key} =~ s/(`)/'/g;
                       $customhash->{$key} =~ s/\$/\(\$\)/g;
                   }
               }
           }
     }      }
 }  }
   
Line 4499  sub print_textbook_form { Line 4534  sub print_textbook_form {
     }      }
   
 #  #
 # Retrieve information about courses owned by user, or in which user has an active or future   # Retrieve information about courses owned by user, or in which user has an active
 # Course Coordinator role   # Course Coordinator role
 #  #
     my $numcurrent;      my $numcurrent;
     my %cloneable = &Apache::lonnet::courseiddump($dom,'.',1,'.',$env{'user.name'}.':'.$env{'user.domain'},      my %cloneable = &Apache::lonnet::courseiddump($dom,'.',1,'.',$env{'user.name'}.':'.$env{'user.domain'},
                                               undef,undef,undef,'Course');                                                    '.',undef,undef,'Course');
     my %ccroles = &Apache::lonnet::get_my_roles($env{'user.name'},$env{'user.domain'},'userroles',      my %ccroles = &Apache::lonnet::get_my_roles($env{'user.name'},$env{'user.domain'},'userroles',
                                                 ['active','future'],['cc']);                                                  ['active'],['cc']);
   
       my $cc_clone = '';
     foreach my $role (keys(%ccroles)) {      foreach my $role (keys(%ccroles)) {
         my ($cnum,$cdom,$rest) = split(/:/,$role,3);          my ($cnum,$cdom,$rest) = split(/:/,$role,3);
           $cc_clone .= $cdom.':'.$cnum.'&';
         unless (exists($cloneable{$cdom.'_'.$cnum})) {          unless (exists($cloneable{$cdom.'_'.$cnum})) {
             my %courseinfo = &Apache::lonnet::coursedescription($cdom.'_'.$cnum,{'one_time' => 1});              my %courseinfo = &Apache::lonnet::coursedescription($cdom.'_'.$cnum,{'one_time' => 1});
             $cloneable{$cdom.'_'.$cnum} = \%courseinfo;              $cloneable{$cdom.'_'.$cnum} = \%courseinfo;
Line 4517  sub print_textbook_form { Line 4555  sub print_textbook_form {
   
     my $numcurrent = scalar(keys(%cloneable));      my $numcurrent = scalar(keys(%cloneable));
   
     my $jscript = &textbook_request_javascript(\%numprefab,$numcurrent);  #
   # Retrieve information about courses from user's domain which user can clone, but which not owned
   # or cloneable based on Course Coordinator role.
   #
       my ($numdomcourses,%domcloneable);
       my %allcloneable = &Apache::lonnet::courseiddump($dom,'.',1,'.','.','.',undef,undef,'Course',
                                                        undef,undef,undef,undef,undef,
                                                        $env{'user.name'}.':'.$env{'user.domain'},
                                                        $cc_clone,1);
       foreach my $cid (keys(%allcloneable)) {
           unless (exists($cloneable{$cid})) {
               $domcloneable{$cid} = $allcloneable{$cid};
           }
       }
       $numdomcourses = scalar(keys(%domcloneable));
   
       my $fullname = &Apache::loncommon::plainname($env{'user.name'},
                                                    $env{'user.domain'});
   
   #
   # Retrieve any custom form information prior to rendering page
   #
   
       my $initprocess = &Apache::lonnet::auto_crsreq_update($dom,undef,$crstype,'initializereview',$env{'user.name'},
                                                            $env{'user.domain'},$fullname);
       my %custominit;
       if (ref($initprocess) eq 'HASH') {
           &custom_formitems($initprocess,\%custominit);
       }
   
   #
   # Retrieve any custom onload actions or javascript used for page before rendering
   #
   
       my ($customonload,$customjs,$customvalidationjs);
       my $inprocess = &Apache::lonnet::auto_crsreq_update($dom,undef,$crstype,'prereview',$env{'user.name'},
                                                           $env{'user.domain'},$fullname,undef,undef,
                                                           undef,undef,\%custominit);
       if (ref($inprocess) eq 'HASH') {
           $customonload = $inprocess->{'onload'};
           $customjs = $inprocess->{'javascript'};
           $customvalidationjs = $inprocess->{'validationjs'};
       }
   
       my $postprocess = &Apache::lonnet::auto_crsreq_update($dom,undef,$crstype,'review',
                                                             $env{'user.name'},
                                                             $env{'user.domain'},$fullname,undef,undef,
                                                             undef,undef,\%custominit);
   
       my $jscript = &textbook_request_javascript(\%numprefab,$numcurrent,$numdomcourses,$customvalidationjs);
       $jscript .= $customjs;
     my %loaditems;      my %loaditems;
     $loaditems{'onload'} = 'javascript:uncheckAllRadio();';      $loaditems{'onload'} = 'javascript:uncheckAllRadio();'.$customonload;
     $r->print(&header('Course Request',$jscript,\%loaditems));      $r->print(&header('Course Request',$jscript,\%loaditems));
   
     if (ref($can_request) eq 'HASH') {      if (ref($can_request) eq 'HASH') {
Line 4564  sub print_textbook_form { Line 4652  sub print_textbook_form {
 #  #
 # Content source selection, if more than one available  # Content source selection, if more than one available
 #  #
     if (keys(%cloneable) || keys(%ordered)) {      if (keys(%cloneable) || keys(%ordered) || keys(%domcloneable)) {
         $r->print('<div>'.           $r->print('<div>'. 
                   '<fieldset><legend>'.&mt('Course Content').'</legend>');                    '<fieldset><legend>'.&mt('Course Content').'</legend>');
         if (keys(%ordered)) {          if (keys(%ordered)) {
Line 4584  sub print_textbook_form { Line 4672  sub print_textbook_form {
                       '<input type="radio" name="cloning" value="existing" onclick="javascript:cloneChoice();" />'.                        '<input type="radio" name="cloning" value="existing" onclick="javascript:cloneChoice();" />'.
                       &mt('Copy one of your courses').'</label></span>'.('&nbsp;'x2).' ');                        &mt('Copy one of your courses').'</label></span>'.('&nbsp;'x2).' ');
         }          }
           if (keys(%domcloneable)) {
               $r->print('<span class="LC_nobreak"><label>'.
                         '<input type="radio" name="cloning" value="colleague" onclick="javascript:cloneChoice();" />'.
                         &mt("Copy a colleague's course").'</label></span>'.('&nbsp;'x2).' ');
           }
         $r->print('<span class="LC_nobreak"><label>'.          $r->print('<span class="LC_nobreak"><label>'.
                   '<input type="radio" name="cloning" value="none" checked="checked" onclick="javascript:cloneChoice();" />'.                    '<input type="radio" name="cloning" value="none" checked="checked" onclick="javascript:cloneChoice();" />'.
                   &mt('Empty course shell').'</label></span>');                    &mt('Empty course shell').'</label></span>');
Line 4645  sub print_textbook_form { Line 4738  sub print_textbook_form {
 #  #
 # Table of user's current courses (owner and/or course coordinator)  # Table of user's current courses (owner and/or course coordinator)
 #  #
       my %lt = &clone_text();
     if (keys(%cloneable)) {      if (keys(%cloneable)) {
         my %lt = &clone_text();  
         $r->print('<div id="showexisting" style="display:none">'.          $r->print('<div id="showexisting" style="display:none">'.
                   &Apache::loncommon::start_data_table().                    &clone_selection_table($dom,'owned',\%cloneable).
                   &Apache::loncommon::start_data_table_header_row().                    '<p><input type="radio" name="datemode" value="delete" /> '.$lt{'ncd'}.
                   '<th>'.&mt('Title').'</th>'.                    '</label><br /><label>'.
                   '<th>'.&mt('Owner/co-owner(s)').'</th>'.                    '<input type="radio" name="datemode" value="preserve" /> '.$lt{'prd'}.
                   &Apache::loncommon::end_data_table_header_row());                    '</label><br /><label>'.
         my %allownernames;                    '<input type="radio" name="datemode" value="shift" checked="checked" /> '.
         my %sortbytitle;                     $lt{'shd'}.'</label>'.
         foreach my $cid (sort(keys(%cloneable))) {                    '<input type="text" size="5" name="dateshift" value="365" />'.
             if (ref($cloneable{$cid}) eq 'HASH') {                    '</div>');
                 my $cdesc = $cloneable{$cid}{'description'};      }
                 $cdesc =~ s/`/'/g;  #
                 if ($cdesc ne '') {  # Table of other cloneable courses from user's domain (exclude own courses)
                     push(@{$sortbytitle{$cdesc}},$cid);  #
                 }      if (keys(%domcloneable)) {
             }          $r->print('<div id="showcolleague" style="display:none">'.
          }                    &clone_selection_table($dom,'colleague',\%domcloneable).
          foreach my $title (sort(keys(%sortbytitle))) {                    '<p><input type="radio" name="datemode" value="delete" /> '.$lt{'ncd'}.
              if (ref($sortbytitle{$title}) eq 'ARRAY') {                    '</label><br /><label>'.
                 foreach my $cid (sort(@{$sortbytitle{$title}})) {                    '<input type="radio" name="datemode" value="preserve" /> '.$lt{'prd'}.
                     my $cleantitle=&HTML::Entities::encode($title,'<>&"');                    '</label><br /><label>'.
                     $cleantitle=~s/'/\\'/g;                    '<input type="radio" name="datemode" value="shift" checked="checked" /> '.
                     $cleantitle =~ s/^\s+//;                    $lt{'shd'}.'</label>'.
                     my ($namestr,@owners,%ownernames);                    '<input type="text" size="5" name="dateshift" value="365" />'.
                     my $singleowner = $cloneable{$cid}{'internal.courseowner'};                    '</div>');
                     push(@owners,$singleowner);  
                     if ($cloneable{$cid}{'co-owners'} ne '') {  
                         foreach my $item (split(/,/,$cloneable{$cid}{'internal.co-owners'})) {  
                             push(@owners,$item);  
                         }  
                     }  
                     foreach my $owner (@owners) {  
                         my ($ownername,$ownerdom);  
                         if ($owner =~ /:/) {  
                             ($ownername,$ownerdom) = split(/:/,$owner);  
                         } else {  
                             $ownername = $owner;  
                             if ($owner ne '') {  
                                 $ownerdom = $dom;  
                             }  
                         }  
                         if ($ownername ne '' && $ownerdom ne '') {  
                             if (exists($allownernames{$ownername.':'.$ownerdom})) {  
                                 $ownernames{$ownername.':'.$ownerdom} = $allownernames{$ownername.':'.$ownerdom};   
                             } else {  
                                 my %namehash=&Apache::loncommon::getnames($ownername,$ownerdom);  
                                 $ownernames{$ownername.':'.$ownerdom} = \%namehash;  
                                 $allownernames{$ownername.':'.$ownerdom} = $ownernames{$ownername.':'.$ownerdom};  
                             }  
                         }  
                     }  
                     my @lastnames;  
                     foreach my $owner (keys(%ownernames)) {  
                         if (ref($ownernames{$owner}) eq 'HASH') {  
                             push(@lastnames,$ownernames{$owner}{'lastname'});  
                         }  
                     }  
                     if (@lastnames) {  
                         $namestr = join(', ',sort(@lastnames));  
                     }  
                     $r->print(&Apache::loncommon::start_data_table_row().  
                               '<td><label><input type="radio" name="owned" value="'.$cid.'" />'.  
                               '&nbsp'.$cleantitle.'</label></td>'.  
                               '<td>'.$namestr.'</td>'.  
                               &Apache::loncommon::end_data_table_row());  
                 }  
             }  
         }  
         $r->print(&Apache::loncommon::end_data_table().  
               '<p><input type="radio" name="datemode" value="delete" /> '.$lt{'ncd'}.  
               '</label><br /><label>'.  
               '<input type="radio" name="datemode" value="preserve" /> '.$lt{'prd'}.  
               '</label><br /><label>'.  
               '<input type="radio" name="datemode" value="shift" checked="checked" /> '.  
               $lt{'shd'}.'</label>'.  
               '<input type="text" size="5" name="dateshift" value="365" />'.  
               '</div>');  
     }      }
   
 #  #
 # End of content selector  # End of content selector
 #  #
     if (keys(%cloneable) || keys(%ordered)) {      if (keys(%cloneable) || keys(%domcloneable) || keys(%ordered)) {
         $r->print('</fieldset></div>');          $r->print('</fieldset></div>');
     }      }
   
Line 4759  sub print_textbook_form { Line 4801  sub print_textbook_form {
 #  #
 # Display any custom fields for this course type  # Display any custom fields for this course type
 #  #
     my $fullname = &Apache::loncommon::plainname($env{'user.name'},  
                                                  $env{'user.domain'});  
     my $postprocess = &Apache::lonnet::auto_crsreq_update($dom,undef,$crstype,'review',  
                                                           $env{'user.name'},  
                                                           $env{'user.domain'},$fullname);  
     if (ref($postprocess) eq 'HASH') {      if (ref($postprocess) eq 'HASH') {
         if ($postprocess->{'reviewweb'}) {          if ($postprocess->{'reviewweb'}) {
             $r->print($postprocess->{'reviewweb'});              $r->print($postprocess->{'reviewweb'});
Line 4786  sub print_textbook_form { Line 4823  sub print_textbook_form {
     return;      return;
 }  }
   
   sub clone_selection_table {
       my ($dom,$name,$cloneableref) = @_;
       return unless ((ref($cloneableref) eq 'HASH') && (($name eq 'owned') || ($name eq 'colleague')));
       my %allownernames;
       my %sortbytitle;
       my $output;
       foreach my $cid (sort(keys(%{$cloneableref}))) {
           if (ref($cloneableref->{$cid}) eq 'HASH') {
               my $cdesc = $cloneableref->{$cid}{'description'};
               $cdesc =~ s/`/'/g;
               if ($cdesc ne '') {
                   push(@{$sortbytitle{$cdesc}},$cid);
               }
           }
       }
       foreach my $title (sort(keys(%sortbytitle))) {
            if (ref($sortbytitle{$title}) eq 'ARRAY') {
               foreach my $cid (sort(@{$sortbytitle{$title}})) {
                   my $cleantitle=&HTML::Entities::encode($title,'<>&"');
                   $cleantitle=~s/'/\\'/g;
                   $cleantitle =~ s/^\s+//;
                   my ($namestr,@owners,%ownernames);
                   my $singleowner = $cloneableref->{$cid}{'internal.courseowner'};
                   push(@owners,$singleowner);
                   if ($cloneableref->{$cid}{'co-owners'} ne '') {
                       foreach my $item (split(/,/,$cloneableref->{$cid}{'internal.co-owners'})) {
                           push(@owners,$item);
                       }
                   }
                   foreach my $owner (@owners) {
                       my ($ownername,$ownerdom);
                       if ($owner =~ /:/) {
                           ($ownername,$ownerdom) = split(/:/,$owner);
                       } else {
                           $ownername = $owner;
                           if ($owner ne '') {
                               $ownerdom = $dom;
                           }
                       }
                       if ($ownername ne '' && $ownerdom ne '') {
                           if (exists($allownernames{$ownername.':'.$ownerdom})) {
                               $ownernames{$ownername.':'.$ownerdom} = $allownernames{$ownername.':'.$ownerdom};
                           } else {
                               my %namehash=&Apache::loncommon::getnames($ownername,$ownerdom);
                               $ownernames{$ownername.':'.$ownerdom} = \%namehash;
                               $allownernames{$ownername.':'.$ownerdom} = $ownernames{$ownername.':'.$ownerdom};
                           }
                       }
                   }
                   my @lastnames;
                   foreach my $owner (keys(%ownernames)) {
                       if (ref($ownernames{$owner}) eq 'HASH') {
                           push(@lastnames,$ownernames{$owner}{'lastname'});
                       }
                   }
                   if (@lastnames) {
                       $namestr = join(', ',sort(@lastnames));
                   }
                   $output .= &Apache::loncommon::start_data_table_row().
                              '<td><label><input type="radio" name="'.$name.'" value="'.$cid.'" />'.
                              '&nbsp;'.$cleantitle.'</label></td>'.
                              '<td>'.$namestr.'</td>'.
                              &Apache::loncommon::end_data_table_row();
               }
           }
       }
       if ($output) {
           return &Apache::loncommon::start_data_table().
                  &Apache::loncommon::start_data_table_header_row().
                  '<th>'.&mt('Title').'</th>'.
                  '<th>'.&mt('Owner/co-owner(s)').'</th>'.
                  &Apache::loncommon::end_data_table_header_row().
                  $output.
                  &Apache::loncommon::end_data_table();
       }
       return;
   }
   
 sub process_textbook_request {  sub process_textbook_request {
     my ($r,$dom,$action,$domdefs,$domconfig,$can_request) = @_;      my ($r,$dom,$action,$domdefs,$domconfig,$can_request) = @_;
     my ($uniquecode,$req_notifylist);      my ($uniquecode,$req_notifylist);
Line 4811  sub process_textbook_request { Line 4926  sub process_textbook_request {
         $clonefrom = $env{'form.template'};          $clonefrom = $env{'form.template'};
     } elsif ($reqtype eq 'existing') {      } elsif ($reqtype eq 'existing') {
         $clonefrom = $env{'form.owned'};          $clonefrom = $env{'form.owned'};
       } elsif ($reqtype eq 'colleague') {
           $clonefrom = $env{'form.colleague'};
     }      }
     my ($accessstart,$accessend) = &dates_from_form('accessstart','accessend');      my ($accessstart,$accessend) = &dates_from_form('accessstart','accessend');
     if ($clonefrom) {      if ($clonefrom) {
Line 4872  sub process_textbook_request { Line 4989  sub process_textbook_request {
     }      }
     my $lonhost = $r->dir_config('lonHostID');      my $lonhost = $r->dir_config('lonHostID');
     $r->rflush();      $r->rflush();
     my ($result,$output) = &process_request($r,$lonhost,$dom,$cnum,$crstype,$now,$details,'',      my ($result,$output,$customized) = &process_request($r,$lonhost,$dom,$cnum,$crstype,$now,$details,
                                             $req_notifylist,[],$domconfig);                                                          '',$req_notifylist,[],$domconfig);
     $r->print($output);      $r->print($output);
     if (&Apache::loncoursequeueadmin::author_prompt()) {      if (&Apache::loncoursequeueadmin::author_prompt()) {
         &print_author_prompt($r,$action,$cnum,$dom,$crstype,$result);          unless ($customized) {
               &print_author_prompt($r,$action,$cnum,$dom,$crstype,$result);
           }
     } elsif ($result eq 'created') {      } elsif ($result eq 'created') {
         $r->print('<p><a href="/adm/requestcourse">'.&mt('Create another course').'</a></p>');          unless ($customized) {
               $r->print('<p><a href="/adm/requestcourse">'.&mt('Create another course').'</a></p>');
           }
     }      }
     &endContentScreen($r);      &endContentScreen($r);
     $r->print(&Apache::loncommon::end_page());      $r->print(&Apache::loncommon::end_page());
 }  }
   
 sub textbook_request_javascript {  sub textbook_request_javascript {
     my ($numprefab,$numcurrent) = @_;      my ($numprefab,$numcurrent,$numcolleague,$customvalidationjs) = @_;
     return unless (ref($numprefab) eq 'HASH');      return unless (ref($numprefab) eq 'HASH');
     return if (!$numprefab->{'textbooks'} && !$numprefab->{'templates'} && !$numcurrent);      return if (!$numprefab->{'textbooks'} && !$numprefab->{'templates'} && !$numcurrent && !$numcolleague);
     my %js_lt = &Apache::lonlocal::texthash(      my %js_lt = &Apache::lonlocal::texthash(
                  choose   => 'Please select a content option.',                   choose    => 'Please select a content option.',
                  textbook => 'Please select a textbook, or choose a different option.',                   textbook  => 'Please select a textbook, or choose a different option.',
                  template => 'Please select a template, or choose a different option.',                           template  => 'Please select a template, or choose a different option.',        
                  existing => 'Please select one of your existing courses to copy, or choose a different option.',                   existing  => 'Please select one of your existing courses to copy, or choose a different option.',
                  title    => 'Please enter a course title.',                   colleague => "Please select a colleague's course to copy, or choose a different option.", 
                    title     => 'Please enter a course title.',
              );               );
     &js_escape(\%js_lt);      &js_escape(\%js_lt);
     return <<"ENDSCRIPT";      return <<"ENDSCRIPT";
Line 4902  function cloneChoice() { Line 5024  function cloneChoice() {
         var radioLength = document.requestcourse.cloning.length;          var radioLength = document.requestcourse.cloning.length;
         if (radioLength == undefined) {          if (radioLength == undefined) {
             var val = document.requestcourse.cloning.value;              var val = document.requestcourse.cloning.value;
             if ((val == 'textbook') || (val == 'template') || (val == 'existing')) {              if ((val == 'textbook') || (val == 'template') || (val == 'existing') || (val == 'colleague')) {
                 var elem = document.getElementById('show'+val);                  var elem = document.getElementById('show'+val);
                 if (document.requestcourse.cloning.checked) {                  if (document.requestcourse.cloning.checked) {
                     elem.style.display = 'block';                      elem.style.display = 'block';
Line 4914  function cloneChoice() { Line 5036  function cloneChoice() {
         } else {          } else {
             for (var i=0; i<radioLength; i++) {              for (var i=0; i<radioLength; i++) {
                 var val = document.requestcourse.cloning[i].value;                  var val = document.requestcourse.cloning[i].value;
                 if ((val == 'textbook') || (val == 'template') || (val == 'existing')) {                  if ((val == 'textbook') || (val == 'template') || (val == 'existing') || (val == 'colleague')) {
                     var elem = document.getElementById('show'+val);                      var elem = document.getElementById('show'+val);
                     if (document.requestcourse.cloning[i].checked) {                      if (document.requestcourse.cloning[i].checked) {
                         elem.style.display = 'block';                          elem.style.display = 'block';
Line 4928  function cloneChoice() { Line 5050  function cloneChoice() {
                         if (val == 'existing') {                          if (val == 'existing') {
                             uncheckRadio('owned');                              uncheckRadio('owned');
                         }                          }
                           if (val == 'colleague') {
                               uncheckRadio('colleague');
                           }
                         elem.style.display = 'none';                          elem.style.display = 'none';
                     }                      }
                 }                  }
Line 4955  function uncheckAllRadio() { Line 5080  function uncheckAllRadio() {
     var numbook = $numprefab->{'textbooks'};      var numbook = $numprefab->{'textbooks'};
     var numtemplate = $numprefab->{'templates'};      var numtemplate = $numprefab->{'templates'};
     var numcurrent = $numcurrent;      var numcurrent = $numcurrent;
       var numcolleague = $numcolleague;
     if (numbook > 0) {      if (numbook > 0) {
         uncheckRadio('textbook');           uncheckRadio('textbook'); 
     }      }
Line 4964  function uncheckAllRadio() { Line 5090  function uncheckAllRadio() {
     if (numcurrent > 0) {      if (numcurrent > 0) {
         uncheckRadio('existing');          uncheckRadio('existing');
     }      }
       if (numcolleague > 0) {
           uncheckRadio('colleague');
       }
     return;      return;
 }  }
   
Line 4991  function validTextbookReq() { Line 5120  function validTextbookReq() {
             }              }
         }          }
         var group;          var group;
         if ((cloneChoice == 'textbook') || (cloneChoice == 'template') || (cloneChoice == 'existing')) {          if ((cloneChoice == 'textbook') || (cloneChoice == 'template') || (cloneChoice == 'existing') || (cloneChoice == 'colleague')) {
             var group;              var group;
             if (cloneChoice == 'textbook') {              if (cloneChoice == 'textbook') {
                 group = document.getElementsByName('book');                  group = document.getElementsByName('book');
Line 4999  function validTextbookReq() { Line 5128  function validTextbookReq() {
                 if (cloneChoice == 'template') {                  if (cloneChoice == 'template') {
                     group = document.getElementsByName('template');                      group = document.getElementsByName('template');
                 } else {                  } else {
                     group = document.getElementsByName('owned');                      if (cloneChoice == 'existing') {
                           group = document.getElementsByName('owned');
                       } else {
                           group = document.getElementsByName('colleague');
                       }
                 }                  }
             }              }
             var groupLength = group.length;              var groupLength = group.length;
Line 5023  function validTextbookReq() { Line 5156  function validTextbookReq() {
                    if (cloneChoice == 'template') {                     if (cloneChoice == 'template') {
                        alert("$js_lt{'template'}");                         alert("$js_lt{'template'}");
                    } else {                     } else {
                        alert("$js_lt{'existing'}");                         if (cloneChoice == 'existing') {
                              alert("$js_lt{'existing'}");
                          } else {
                              alert("js_$lt{'colleague'}");
                          }
                    }                     }
                }                 }
                return false;                 return false;
Line 5034  function validTextbookReq() { Line 5171  function validTextbookReq() {
         alert("$js_lt{'title'}");          alert("$js_lt{'title'}");
         return false;          return false;
     }      }
       $customvalidationjs
     return true;      return true;
 }  }
     

Removed from v.1.89  
changed lines
  Added in v.1.90


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