version 1.107, 2019/07/25 20:23:52
|
version 1.112, 2021/08/31 17:21:24
|
Line 577 sub form_elements {
|
Line 577 sub form_elements {
|
clonedom => 'selectbox', |
clonedom => 'selectbox', |
datemode => 'radio', |
datemode => 'radio', |
dateshift => 'text', |
dateshift => 'text', |
|
tinyurls => 'radio', |
}, |
}, |
enrollment => { |
enrollment => { |
accessstart_month => 'selectbox', |
accessstart_month => 'selectbox', |
Line 2426 sub print_cancel_request {
|
Line 2427 sub print_cancel_request {
|
&Apache::loncommon::start_data_table_row(). |
&Apache::loncommon::start_data_table_row(). |
'<td>'.$history{details}{'cdescr'}.'</td><td>'. |
'<td>'.$history{details}{'cdescr'}.'</td><td>'. |
&Apache::lonlocal::locallocaltime($timestamp).'</td>'. |
&Apache::lonlocal::locallocaltime($timestamp).'</td>'. |
'<td>'.$showtype.'</td>'. |
'<td>'.&mt($showtype).'</td>'. |
&Apache::loncommon::end_data_table_row(). |
&Apache::loncommon::end_data_table_row(). |
&Apache::loncommon::end_data_table(). |
&Apache::loncommon::end_data_table(). |
'<br /><div class="LC_warning">'; |
'<br /><div class="LC_warning">'; |
Line 2780 sub requestlog_display_filter {
|
Line 2781 sub requestlog_display_filter {
|
$typename = $typenames->{$crstype}; |
$typename = $typenames->{$crstype}; |
} |
} |
} |
} |
$output .= '<option value="'.$crstype.'"'.$selstr.'>'.$typename.'</option>'."\n"; |
$output .= '<option value="'.$crstype.'"'.$selstr.'>'.&mt($typename).'</option>'."\n"; |
} |
} |
$output .= '</select></td>'; |
$output .= '</select></td>'; |
} |
} |
Line 2956 sub print_review {
|
Line 2957 sub print_review {
|
$inst_values .= '<td>'.$env{'form.coursecredits'}.'</td>'; |
$inst_values .= '<td>'.$env{'form.coursecredits'}.'</td>'; |
} |
} |
|
|
my %ctxt = &clone_text(); |
my %ctxt = &clone_text($env{'form.crstype'}); |
$inst_headers .= '<th>'.&mt('Clone From').'</th>'; |
$inst_headers .= '<th>'.&mt('Clone From').'</th>'; |
if (($env{'form.cloning'}) && |
if (($env{'form.cloning'}) && |
($env{'form.clonecrs'} =~ /^$match_name$/) && |
($env{'form.clonecrs'} =~ /^$match_name$/) && |
Line 2968 sub print_review {
|
Line 2969 sub print_review {
|
my %courseenv = &Apache::lonnet::userenvironment($env{'form.clonedom'}, |
my %courseenv = &Apache::lonnet::userenvironment($env{'form.clonedom'}, |
$env{'form.clonecrs'},('description','internal.coursecode')); |
$env{'form.clonecrs'},('description','internal.coursecode')); |
if (keys(%courseenv) > 0) { |
if (keys(%courseenv) > 0) { |
$inst_headers .= '<th>'.$ctxt{'dsh'}.'</th>'; |
$inst_headers .= '<th>'.$ctxt{'dsh'}.'</th>'. |
|
'<th>'.$ctxt{'dpl'}.'</th>'; |
$inst_values .= '<td>'.$courseenv{'description'}.' '; |
$inst_values .= '<td>'.$courseenv{'description'}.' '; |
my $cloneinst = $courseenv{'internal.coursecode'}; |
my $cloneinst = $courseenv{'internal.coursecode'}; |
if ($cloneinst ne '') { |
if ($cloneinst ne '') { |
Line 2984 sub print_review {
|
Line 2986 sub print_review {
|
} else { |
} else { |
$inst_values .= $ctxt{'ncd'}; |
$inst_values .= $ctxt{'ncd'}; |
} |
} |
|
$inst_values .= '</td><td>'; |
|
if ($env{'form.tinyurls'} eq 'delete') { |
|
$inst_values .= $ctxt{'nsl'}; |
|
} elsif ($env{'form.tinyurls'} eq 'transfer') { |
|
$inst_values .= $ctxt{'tsl'}; |
|
} else { |
|
$inst_values .= $ctxt{'csl'}; |
|
} |
$inst_values .= '</td>'; |
$inst_values .= '</td>'; |
} else { |
} else { |
$inst_values .= '<td>'.&mt('Unknown').'</td>'; |
$inst_values .= '<td>'.&mt('Unknown').'</td>'; |
Line 3215 sub clone_form {
|
Line 3225 sub clone_form {
|
} elsif ($crstype eq 'placement') { |
} elsif ($crstype eq 'placement') { |
$type = 'Placement'; |
$type = 'Placement'; |
} |
} |
my %lt = &clone_text(); |
my %lt = &clone_text($crstype); |
my $output .= |
my $output .= |
&Apache::lonhtmlcommon::row_title($lt{'dmn'}).'<label>'. |
&Apache::lonhtmlcommon::row_title($lt{'dmn'}).'<label>'. |
&Apache::loncommon::select_dom_form($dom,'clonedom').'</label>'. |
&Apache::loncommon::select_dom_form($dom,'clonedom').'</label>'. |
Line 3232 sub clone_form {
|
Line 3242 sub clone_form {
|
'</label><br /><label>'. |
'</label><br /><label>'. |
'<input type="radio" name="datemode" value="shift" checked="checked" /> '. |
'<input type="radio" name="datemode" value="shift" checked="checked" /> '. |
$lt{'shd'}.'</label>'. |
$lt{'shd'}.'</label>'. |
'<input type="text" size="5" name="dateshift" value="365" />'. |
'<input type="text" size="5" name="dateshift" value="364" />'. |
|
&Apache::lonhtmlcommon::row_closure(1). |
|
&Apache::lonhtmlcommon::row_title($lt{'dpl'}).'<label>'. |
|
'<input type="radio" name="tinyurls" value="delete" /> '.$lt{'nsl'}. |
|
'</label><br /><label>'. |
|
'<input type="radio" name="tinyurls" value="transfer" /> '.$lt{'tsl'}. |
|
'</label><br /><label>'. |
|
'<input type="radio" name="tinyurls" value="create" checked="checked" /> '.$lt{'csl'}. |
|
'</label>'. |
&Apache::lonhtmlcommon::row_closure(1); |
&Apache::lonhtmlcommon::row_closure(1); |
return $output; |
return $output; |
} |
} |
|
|
sub clone_text { |
sub clone_text { |
return &Apache::lonlocal::texthash( |
my ($crstype) = @_; |
|
my %lt = &Apache::lonlocal::texthash( |
'cid' => 'Course ID', |
'cid' => 'Course ID', |
'dmn' => 'Domain', |
'dmn' => 'Domain', |
'dsh' => 'Date Shift', |
'dsh' => 'Date Shift', |
'ncd' => 'Do not clone date parameters', |
'ncd' => 'Do not clone date parameters', |
'prd' => 'Clone date parameters as-is', |
'prd' => 'Clone date parameters as-is', |
'shd' => 'Shift date parameters by number of days', |
'shd' => 'Shift date parameters by number of days', |
); |
'dpl' => 'URL shortcuts (for deep linking)', |
|
'nsl' => 'Do not clone URL shortcuts', |
|
'tsl' => 'Transfer URL shortcuts from existing course to new course', |
|
'csl' => 'Create new URL shortcuts in new course', |
|
); |
|
if ($crstype eq 'Community') { |
|
$lt{'tsl'} = &mt('Transfer URL shortcuts from existing course to new community'); |
|
$lt{'csl'} = &mt('Create new URL shortcuts in new course'); |
|
} |
|
return %lt; |
} |
} |
|
|
sub coursecode_form { |
sub coursecode_form { |
Line 3271 sub coursecode_form {
|
Line 3299 sub coursecode_form {
|
} |
} |
if (@{$codetitles} > 0) { |
if (@{$codetitles} > 0) { |
my $lastitem = pop(@{$codetitles}); |
my $lastitem = pop(@{$codetitles}); |
my $lastinput = '<input type="text" size="5" name="'.$sel.'_'. $lastitem.'" />'; |
my $lastinput = '<input type="text" size="5" name="'.$sel.'_'.$lastitem.'" />'; |
if (@{$codetitles} > 0) { |
if (@{$codetitles} > 0) { |
my $helplink; |
my $helplink; |
if (defined($helpitem{$context})) { |
if (defined($helpitem{$context})) { |
Line 3692 sub print_request_outcome {
|
Line 3720 sub print_request_outcome {
|
clonecrs => $clonecrs, |
clonecrs => $clonecrs, |
datemode => $env{'form.datemode'}, |
datemode => $env{'form.datemode'}, |
dateshift => $env{'form.dateshift'}, |
dateshift => $env{'form.dateshift'}, |
|
tinyurls => $env{'form.tinyurls'}, |
sectotal => $sectotal, |
sectotal => $sectotal, |
sections => \%sections, |
sections => \%sections, |
crosslisttotal => $crosslisttotal, |
crosslisttotal => $crosslisttotal, |
Line 3825 sub process_request {
|
Line 3854 sub process_request {
|
$storeresult = 'rejected'; |
$storeresult = 'rejected'; |
} elsif ($disposition eq 'process') { |
} elsif ($disposition eq 'process') { |
my %domdefs = &Apache::lonnet::get_domain_defaults($dom); |
my %domdefs = &Apache::lonnet::get_domain_defaults($dom); |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response,$keysmsg,%longroles,$code); |
my ($logmsg,$newusermsg,$addresult,$enrollcount,$response, |
|
$keysmsg,%longroles,$code); |
|
my $clonemsg = []; |
my $type = 'Course'; |
my $type = 'Course'; |
if ($crstype eq 'community') { |
if ($crstype eq 'community') { |
$type = 'Community'; |
$type = 'Community'; |
Line 3858 sub process_request {
|
Line 3889 sub process_request {
|
$customitems{'_LC_coursestartdate'} = $accessstart; |
$customitems{'_LC_coursestartdate'} = $accessstart; |
$customitems{'_LC_courseenddate'} = $accessend; |
$customitems{'_LC_courseenddate'} = $accessend; |
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,$clonemsg,\$newusermsg, |
\$enrollcount,\$response,\$keysmsg,\%domdefs,\%longroles, |
\$addresult,\$enrollcount,\$response,\$keysmsg,\%domdefs, |
\$code,\%customitems); |
\%longroles,\$code,\%customitems); |
if (ref($postprocess) eq 'HASH') { |
if (ref($postprocess) eq 'HASH') { |
$customized = $postprocess->{'createdcustomized'}; |
$customized = $postprocess->{'createdcustomized'}; |
} |
} |
Line 3894 sub process_request {
|
Line 3925 sub process_request {
|
$output .= '<br />'.$role_result; |
$output .= '<br />'.$role_result; |
} |
} |
$output .= '</p>'; |
$output .= '</p>'; |
|
if ($logmsg) { |
|
$output .= '<p>'.$logmsg.'</p>'; |
|
} |
|
if ((ref($clonemsg) eq 'ARRAY') && (@{$clonemsg})) { |
|
$output .= '<p class="LC_info">'; |
|
my $user_lh = &Apache::loncommon::user_lang($env{'user.name'},$env{'user.domain'}); |
|
foreach my $item (@{$clonemsg}) { |
|
if (ref($item) eq 'HASH') { |
|
$output .= &mt_user($user_lh,$item->{mt}, |
|
@{$item->{args}}).'<br />'."\n"; |
|
} |
|
} |
|
$output .= '</p>'."\n"; |
|
} |
$creationresult = 'created'; |
$creationresult = 'created'; |
# Flush the course logs so reverse user roles immediately updated |
# Flush the course logs so reverse user roles immediately updated |
unless ($registered_flush) { |
unless ($registered_flush) { |
Line 4021 sub process_request {
|
Line 4066 sub process_request {
|
} elsif ($disposition eq 'pending') { |
} elsif ($disposition eq 'pending') { |
my $pendingform; |
my $pendingform; |
if ($crstype ne 'official') { |
if ($crstype ne 'official') { |
$pendingform = &pending_validation_form($dom,$cnum,$crstype,$now,$token, |
$pendingform = &pending_validation_form($r,$dom,$cnum,$crstype,$now,$token, |
$lonhost,$env{'form.cdescr'}); |
$lonhost,$env{'form.cdescr'}); |
} |
} |
if ($pendingform) { |
if ($pendingform) { |
Line 4339 sub notification_information {
|
Line 4384 sub notification_information {
|
} |
} |
|
|
sub pending_validation_form { |
sub pending_validation_form { |
my ($cdom,$cnum,$crstype,$now,$token,$lonhost,$cdesc) = @_; |
my ($r,$cdom,$cnum,$crstype,$now,$token,$lonhost,$cdesc) = @_; |
my $output; |
my $output; |
my %postvalues = ( |
my %postvalues = ( |
'owner' => $env{'user.name'}.':'.$env{'user.domain'}, |
'owner' => $env{'user.name'}.':'.$env{'user.domain'}, |
Line 4375 sub pending_validation_form {
|
Line 4420 sub pending_validation_form {
|
my $hostname = &Apache::lonnet::hostname($lonhost); |
my $hostname = &Apache::lonnet::hostname($lonhost); |
my $protocol = $Apache::lonnet::protocol{$lonhost}; |
my $protocol = $Apache::lonnet::protocol{$lonhost}; |
$protocol = 'http' if ($protocol ne 'https'); |
$protocol = 'http' if ($protocol ne 'https'); |
|
my $alias = &Apache::lonnet::use_proxy_alias($r,$lonhost); |
|
$hostname = $alias if ($alias ne ''); |
my $crscreator = $protocol.'://'.$hostname.'/cgi-bin/createpending.pl'; |
my $crscreator = $protocol.'://'.$hostname.'/cgi-bin/createpending.pl'; |
$output .= '<input type="hidden" name="crscreator" value="'.$crscreator.'" />'."\n". |
$output .= '<input type="hidden" name="crscreator" value="'.$crscreator.'" />'."\n". |
'<input type="hidden" name="token" value="'.$token.'" />'."\n". |
'<input type="hidden" name="token" value="'.$token.'" />'."\n". |
Line 4451 sub retrieve_settings {
|
Line 4498 sub retrieve_settings {
|
} |
} |
$env{'form.datemode'} = $reqinfo{'datemode'}; |
$env{'form.datemode'} = $reqinfo{'datemode'}; |
$env{'form.dateshift'} = $reqinfo{'dateshift'}; |
$env{'form.dateshift'} = $reqinfo{'dateshift'}; |
|
$env{'form.tinyurls'} = $reqinfo{'tinyurls'}; |
if ($reqinfo{'crstype'} eq 'official') { |
if ($reqinfo{'crstype'} eq 'official') { |
$env{'form.autoadds'} = $reqinfo{'autoadds'}; |
$env{'form.autoadds'} = $reqinfo{'autoadds'}; |
$env{'form.autodrops'} = $reqinfo{'autodrops'}; |
$env{'form.autodrops'} = $reqinfo{'autodrops'}; |
Line 4861 sub print_textbook_form {
|
Line 4909 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(); |
my %lt = &clone_text('Course'); |
if (keys(%cloneable)) { |
if (keys(%cloneable)) { |
$r->print('<div id="showexisting" style="display:none">'. |
$r->print('<div id="showexisting" style="display:none">'. |
&clone_selection_table($dom,'owned',\%cloneable). |
&clone_selection_table($dom,'owned',\%cloneable). |
'<p><input type="radio" name="owndatemode" value="delete" /> '.$lt{'ncd'}. |
'<fieldset style="display:inline-block"><legend>'.$lt{'dsh'}.'</legend><label>'. |
|
'<input type="radio" name="owndatemode" value="delete" /> '.$lt{'ncd'}. |
'</label><br /><label>'. |
'</label><br /><label>'. |
'<input type="radio" name="owndatemode" value="preserve" /> '.$lt{'prd'}. |
'<input type="radio" name="owndatemode" value="preserve" /> '.$lt{'prd'}. |
'</label><br /><label>'. |
'</label><br /><label>'. |
'<input type="radio" name="owndatemode" value="shift" checked="checked" /> '. |
'<input type="radio" name="owndatemode" value="shift" checked="checked" /> '. |
$lt{'shd'}.'</label>'. |
$lt{'shd'}.'</label>'. |
'<input type="text" size="5" name="owndateshift" value="365" />'. |
'<input type="text" size="5" name="owndateshift" value="364" />'. |
|
'</fieldset><fieldset style="display:inline-block">'. |
|
'<legend>'.$lt{'dpl'}.'</legend><label>'. |
|
'<input type="radio" name="owntinyurls" value="delete" />'.$lt{'nsl'}. |
|
'</label><br /><label>'. |
|
'<input type="radio" name="owntinyurls" value="transfer" />'.$lt{'tsl'}. |
|
'</label><br /><label>'. |
|
'<input type="radio" name="owntinyurls" value="create" checked="checked" />'.$lt{'csl'}. |
|
'</label></fieldset>'. |
'</div>'); |
'</div>'); |
} |
} |
# |
# |
Line 4880 sub print_textbook_form {
|
Line 4937 sub print_textbook_form {
|
if (keys(%domcloneable)) { |
if (keys(%domcloneable)) { |
$r->print('<div id="showcolleague" style="display:none">'. |
$r->print('<div id="showcolleague" style="display:none">'. |
&clone_selection_table($dom,'colleague',\%domcloneable). |
&clone_selection_table($dom,'colleague',\%domcloneable). |
'<p><input type="radio" name="colldatemode" value="delete" /> '.$lt{'ncd'}. |
'<fieldset style="display:inline-block"><legend>'.$lt{'dsh'}.'</legend><label>'. |
|
'<input type="radio" name="colldatemode" value="delete" /> '.$lt{'ncd'}. |
'</label><br /><label>'. |
'</label><br /><label>'. |
'<input type="radio" name="colldatemode" value="preserve" /> '.$lt{'prd'}. |
'<input type="radio" name="colldatemode" value="preserve" /> '.$lt{'prd'}. |
'</label><br /><label>'. |
'</label><br /><label>'. |
'<input type="radio" name="colldatemode" value="shift" checked="checked" /> '. |
'<input type="radio" name="colldatemode" value="shift" checked="checked" /> '. |
$lt{'shd'}.'</label>'. |
$lt{'shd'}.'</label>'. |
'<input type="text" size="5" name="colldateshift" value="365" />'. |
'<input type="text" size="5" name="colldateshift" value="364" />'. |
|
'</fieldset><fieldset style="display:inline-block">'. |
|
'<legend>'.$lt{'dpl'}.'</legend><label>'. |
|
'<input type="radio" name="colltinyurls" value="delete" />'.$lt{'nsl'}. |
|
'</label><br /><label>'. |
|
'<input type="radio" name="colltinyurls" value="create" checked="checked" />'.$lt{'csl'}. |
|
'</label></fieldset>'. |
'</div>'); |
'</div>'); |
} |
} |
|
|
Line 5134 sub process_textbook_request {
|
Line 5198 sub process_textbook_request {
|
} else { |
} else { |
$details->{dateshift} = ''; |
$details->{dateshift} = ''; |
} |
} |
|
$details->{tinyurls} = $env{'form.owntinyurls'}; |
} elsif ($reqtype eq 'colleague') { |
} elsif ($reqtype eq 'colleague') { |
$details->{datemode} = $env{'form.colldatemode'}; |
$details->{datemode} = $env{'form.colldatemode'}; |
if ($details->{datemode} eq 'shift') { |
if ($details->{datemode} eq 'shift') { |
Line 5141 sub process_textbook_request {
|
Line 5206 sub process_textbook_request {
|
} else { |
} else { |
$details->{dateshift} = ''; |
$details->{dateshift} = ''; |
} |
} |
|
$details->{tinyurls} = $env{'form.colltinyurls'}; |
} elsif (($reqtype eq 'textbook') || ($reqtype eq 'template')) { |
} elsif (($reqtype eq 'textbook') || ($reqtype eq 'template')) { |
$details->{datemode} = 'delete'; |
$details->{datemode} = 'delete'; |
$details->{dateshift} = ''; |
$details->{dateshift} = ''; |
|
$details->{tinyurls} = ''; |
} |
} |
if ($details->{dateshift} ne '') { |
if ($details->{dateshift} ne '') { |
$details->{dateshift} =~ s/[^\d\.]+//g; |
$details->{dateshift} =~ s/[^\d\.]+//g; |
Line 5151 sub process_textbook_request {
|
Line 5218 sub process_textbook_request {
|
} else { |
} else { |
$details->{datemode} = ''; |
$details->{datemode} = ''; |
$details->{dateshift} = ''; |
$details->{dateshift} = ''; |
|
$details->{tinyurls} = ''; |
} |
} |
my $lonhost = $r->dir_config('lonHostID'); |
my $lonhost = $r->dir_config('lonHostID'); |
$r->rflush(); |
$r->rflush(); |