version 1.131, 2024/02/24 23:41:44
|
version 1.134, 2025/03/15 01:03:33
|
Line 2026 sub process_ltitools {
|
Line 2026 sub process_ltitools {
|
} else { |
} else { |
$ltitools{$newid}{'display'}{'target'} = 'iframe'; |
$ltitools{$newid}{'display'}{'target'} = 'iframe'; |
} |
} |
foreach my $item ('passback','roster') { |
foreach my $item ('passback','roster','returnurl') { |
if ($env{'form.ltitools_'.$item.'_add'}) { |
if ($env{'form.ltitools_'.$item.'_add'}) { |
$ltitools{$newid}{$item} = 1; |
$ltitools{$newid}{$item} = 1; |
if ($env{'form.ltitools_'.$item.'valid_add'} ne '') { |
if ($item eq 'returnurl') { |
|
if ($env{'form.ltitools_crs'.$item.'_add'}) { |
|
$ltitools{$newid}{'crsconf'}{$item} = 1; |
|
} |
|
} elsif ($env{'form.ltitools_'.$item.'valid_add'} ne '') { |
my $lifetime = $env{'form.ltitools_'.$item.'valid_add'}; |
my $lifetime = $env{'form.ltitools_'.$item.'valid_add'}; |
$lifetime =~ s/^\s+|\s+$//g; |
$lifetime =~ s/^\s+|\s+$//g; |
if ($lifetime =~ /^\d+\.?\d*$/) { |
if ($lifetime =~ /^\d+\.?\d*$/) { |
Line 2213 sub process_ltitools {
|
Line 2217 sub process_ltitools {
|
} else { |
} else { |
$haschanges{$itemid} = 1; |
$haschanges{$itemid} = 1; |
} |
} |
foreach my $extra ('passback','roster') { |
foreach my $extra ('passback','roster','returnurl') { |
if ($env{'form.ltitools_'.$extra.'_'.$i}) { |
if ($env{'form.ltitools_'.$extra.'_'.$i}) { |
$ltitools{$itemid}{$extra} = 1; |
$ltitools{$itemid}{$extra} = 1; |
if ($env{'form.ltitools_'.$extra.'valid_'.$i} ne '') { |
if ($extra eq 'returnurl') { |
|
if ($env{'form.ltitools_crs'.$extra.'_'.$i}) { |
|
$ltitools{$itemid}{'crsconf'}{$extra} = 1; |
|
if (ref($values->{$itemid}{'crsconf'}) eq 'HASH') { |
|
if (!$values->{$itemid}{'crsconf'}{$extra}) { |
|
$haschanges{$itemid} = 1; |
|
} |
|
} else { |
|
$haschanges{$itemid} = 1; |
|
} |
|
} |
|
} elsif ($env{'form.ltitools_'.$extra.'valid_'.$i} ne '') { |
my $lifetime = $env{'form.ltitools_'.$extra.'valid_'.$i}; |
my $lifetime = $env{'form.ltitools_'.$extra.'valid_'.$i}; |
$lifetime =~ s/^\s+|\s+$//g; |
$lifetime =~ s/^\s+|\s+$//g; |
if ($lifetime =~ /^\d+\.?\d*$/) { |
if ($lifetime =~ /^\d+\.?\d*$/) { |
Line 2735 sub store_changes {
|
Line 2750 sub store_changes {
|
$displayname = &mt('Recipients of '.$text.' questions'); |
$displayname = &mt('Recipients of '.$text.' questions'); |
} |
} |
} elsif ($item eq 'discussion') { |
} elsif ($item eq 'discussion') { |
if ($key =~ /^p(lc|ch)\.roles\.denied/) { |
if ($key =~ /^p(lc|ch|ac)\.roles\.denied/) { |
$displayname = &mt("$text (role-based)"); |
$displayname = &mt("$text (role-based)"); |
if ($displayval ne '') { |
if ($displayval ne '') { |
my @roles = split(',',$displayval); |
my @roles = split(',',$displayval); |
@roles = map { &Apache::lonnet::plaintext($_); } @roles; |
@roles = map { &Apache::lonnet::plaintext($_); } @roles; |
$displayval = join(', ',@roles); |
$displayval = join(', ',@roles); |
} |
} |
} elsif ($key =~ /^p(lc|ch)\.users\.denied/) { |
} elsif ($key =~ /^p(lc|ch|ac)\.users\.denied/) { |
$displayname = &mt("$text (specific user(s))"); |
$displayname = &mt("$text (specific user(s))"); |
} else { |
} else { |
if ($key eq 'allow_discussion_post_editing') { |
if ($key eq 'allow_discussion_post_editing') { |
Line 3341 sub store_ltitools {
|
Line 3356 sub store_ltitools {
|
$output .= ' '.&mt('None'); |
$output .= ' '.&mt('None'); |
} |
} |
$output .= '</li>'; |
$output .= '</li>'; |
foreach my $item ('passback','roster') { |
foreach my $item ('passback','roster','returnurl') { |
$output .= '<li>'.$lt{$item}.' '; |
$output .= '<li>'.$lt{$item}.' '; |
if ($changes->{$itemid}{$item}) { |
if ($changes->{$itemid}{$item}) { |
$output .= &mt('Yes'); |
$output .= &mt('Yes'); |
if ($changes->{$itemid}{$item.'valid'}) { |
if ($item eq 'returnurl') { |
|
if (ref($changes->{$itemid}{'crsconf'}) eq 'HASH') { |
|
$output .= ' ['.&mt('Configurable in course').': '; |
|
if ($changes->{$itemid}{'crsconf'}{$item}) { |
|
$output .= &mt('Yes'); |
|
} else { |
|
$output .= &mt('No'); |
|
} |
|
$output .= ']'; |
|
} |
|
} elsif ($changes->{$itemid}{$item.'valid'}) { |
if ($item eq 'passback') { |
if ($item eq 'passback') { |
$output .= ' '.&mt('valid for at least [quant,_1,day] after launch', |
$output .= ' '.&mt('valid for at least [quant,_1,day] after launch', |
$changes->{$itemid}{$item.'valid'}); |
$changes->{$itemid}{$item.'valid'}); |
Line 5298 sub update_releasereq {
|
Line 5323 sub update_releasereq {
|
} |
} |
$modified_courses = []; |
$modified_courses = []; |
} |
} |
undef($registered_cleanup); |
return OK; |
return; |
|
} |
} |
|
|
sub show_autocoowners { |
sub show_autocoowners { |
Line 6628 sub print_ltitools {
|
Line 6652 sub print_ltitools {
|
'<div class="LC_left_float">'.$lt{'linktext'}.'<br />'. |
'<div class="LC_left_float">'.$lt{'linktext'}.'<br />'. |
'<input type="text" name="ltitools_linktext_'.$i.'" size="25" value="'.$currdisp{'linktext'}.'" /></div>'. |
'<input type="text" name="ltitools_linktext_'.$i.'" size="25" value="'.$currdisp{'linktext'}.'" /></div>'. |
'<div class="LC_left_float">'.$lt{'explanation'}.'<br />'. |
'<div class="LC_left_float">'.$lt{'explanation'}.'<br />'. |
'<textarea name="ltitools_explanation_'.$i.'" rows="5" cols="40">'.$currdisp{'explanation'}. |
'<textarea name="ltitools_explanation_'.$i.'" rows="5" cols="30">'.$currdisp{'explanation'}. |
'</textarea></div><div style=""></div><br />'; |
'</textarea></div><div style=""></div><br />'; |
my %units = ( |
my %units = ( |
'passback' => 'days', |
'passback' => 'days', |
'roster' => 'seconds', |
'roster' => 'seconds', |
); |
); |
foreach my $extra ('passback','roster') { |
my %courseconfig; |
|
if (ref($settings->{$item}) eq 'HASH') { |
|
if (ref($settings->{$item}->{'crsconf'}) eq 'HASH') { |
|
%courseconfig = %{$settings->{$item}->{'crsconf'}}; |
|
} |
|
} |
|
foreach my $extra ('passback','roster','returnurl') { |
my $validsty = 'none'; |
my $validsty = 'none'; |
my $currvalid; |
my $currvalid; |
my $checkedon = ''; |
my $checkedon = ''; |
my $checkedoff = ' checked="checked"'; |
my $checkedoff = ' checked="checked"'; |
|
my $crscheckedon = ''; |
|
my $crscheckedoff = ' checked="checked"'; |
if ($settings->{$item}->{$extra}) { |
if ($settings->{$item}->{$extra}) { |
$checkedon = $checkedoff; |
$checkedon = $checkedoff; |
$checkedoff = ''; |
$checkedoff = ''; |
$validsty = 'inline-block'; |
$validsty = 'inline-block'; |
if ($settings->{$item}->{$extra.'valid'} =~ /^\d+\.?\d*$/) { |
if ($extra eq 'returnurl') { |
|
if ($courseconfig{$extra}) { |
|
$crscheckedon = ' checked="checked"'; |
|
$crscheckedoff = ''; |
|
} |
|
} elsif ($settings->{$item}->{$extra.'valid'} =~ /^\d+\.?\d*$/) { |
$currvalid = $settings->{$item}->{$extra.'valid'}; |
$currvalid = $settings->{$item}->{$extra.'valid'}; |
} |
} |
} |
} |
Line 6652 sub print_ltitools {
|
Line 6689 sub print_ltitools {
|
'<label><input type="radio" name="ltitools_'.$extra.'_'.$i.'" value="0"'.$checkedoff.$onclick.' />'. |
'<label><input type="radio" name="ltitools_'.$extra.'_'.$i.'" value="0"'.$checkedoff.$onclick.' />'. |
&mt('No').'</label>'.(' 'x2). |
&mt('No').'</label>'.(' 'x2). |
'<label><input type="radio" name="ltitools_'.$extra.'_'.$i.'" value="1"'.$checkedon.$onclick.' />'. |
'<label><input type="radio" name="ltitools_'.$extra.'_'.$i.'" value="1"'.$checkedon.$onclick.' />'. |
&mt('Yes').'</label></span></div>'. |
&mt('Yes').'</label></span></div>'; |
'<div class="LC_floatleft" style="display:'.$validsty.';" id="ltitools_'.$extra.'time_'.$i.'">'. |
if ($extra eq 'returnurl') { |
'<span class="LC_nobreak">'. |
$datatable .= '<div class="LC_floatleft" style="display:'.$validsty.';" id="ltitools_course'.$extra.'_'.$i.'">'. |
&mt("until at least [_1] $units{$extra} after launch", |
'<span class="LC_nobreak"> -- '.&mt('configurable in course').': '. |
'<input type="text" name="ltitools_'.$extra.'valid_'.$i.'" value="'.$currvalid.'" />'). |
'<label><input type="radio" name="ltitools_crs'.$extra.'_'.$i.'" value="0"'.$crscheckedoff.' />'. |
'</span></div><div style="padding:0;clear:both;margin:0;border:0"></div>'; |
&mt('No').'</label>'.(' 'x2). |
|
'<label><input type="radio" name="ltitools_crs'.$extra.'_'.$i.'" value="1"'.$crscheckedon.' />'. |
|
&mt('Yes').'</label>'; |
|
} else { |
|
$datatable .= '<div class="LC_floatleft" style="display:'.$validsty.';" id="ltitools_'.$extra.'time_'.$i.'">'. |
|
'<span class="LC_nobreak">'. |
|
&mt("until at least [_1] $units{$extra} after launch", |
|
'<input type="text" name="ltitools_'.$extra.'valid_'.$i.'" value="'.$currvalid.'" />'); |
|
} |
|
$datatable .= '</span></div><div style="padding:0;clear:both;margin:0;border:0"></div>'; |
} |
} |
$datatable .= '<span class="LC_nobreak">'.$lt{'icon'}.': '; |
$datatable .= '<span class="LC_nobreak">'.$lt{'icon'}.': '; |
if ($imgsrc) { |
if ($imgsrc) { |
Line 6743 sub print_ltitools {
|
Line 6789 sub print_ltitools {
|
} |
} |
$datatable .= '</select></td>'; |
$datatable .= '</select></td>'; |
} |
} |
$datatable .= '</tr></table></fieldset>'; |
$datatable .= '</tr></table></fieldset>'."\n". |
my %courseconfig; |
'<fieldset><legend>'; |
if (ref($settings->{$item}) eq 'HASH') { |
|
if (ref($settings->{$item}->{'crsconf'}) eq 'HASH') { |
|
%courseconfig = %{$settings->{$item}->{'crsconf'}}; |
|
} |
|
} |
|
$datatable .= '<fieldset><legend>'; |
|
if ($context eq 'domain') { |
if ($context eq 'domain') { |
$datatable .= &mt('Configurable in course'); |
$datatable .= &mt('Configurable in course'); |
} else { |
} else { |
Line 6777 sub print_ltitools {
|
Line 6817 sub print_ltitools {
|
'<label><input type="checkbox" name="ltitools_customdel_'.$i.'" value="'. |
'<label><input type="checkbox" name="ltitools_customdel_'.$i.'" value="'. |
$key.'" />'.&mt('Delete').'</label></span></td><td>'.$key.'</td>'. |
$key.'" />'.&mt('Delete').'</label></span></td><td>'.$key.'</td>'. |
'<td><input type="text" name="ltitools_customval_'.$key.'_'.$i.'"'. |
'<td><input type="text" name="ltitools_customval_'.$key.'_'.$i.'"'. |
' value="'.$custom{$key}.'" /></td></tr>'; |
' value="'.$custom{$key}.'" size="35" /></td></tr>'; |
} |
} |
} |
} |
} |
} |
$datatable .= '<tr><td><span class="LC_nobreak">'. |
$datatable .= '<tr><td><span class="LC_nobreak">'. |
'<label><input type="checkbox" name="ltitools_customadd" value="'.$i.'" />'. |
'<label><input type="checkbox" name="ltitools_customadd" value="'.$i.'" />'. |
&mt('Add').'</label></span></td><td><input type="text" name="ltitools_custom_name_'.$i.'" />'. |
&mt('Add').'</label></span></td><td><input type="text" name="ltitools_custom_name_'.$i.'" />'. |
'</td><td><input type="text" name="ltitools_custom_value_'.$i.'" /></td></tr>'; |
'</td><td><input type="text" name="ltitools_custom_value_'.$i.'" size="35" /></td></tr>'; |
$datatable .= '</table></fieldset></td></tr>'."\n"; |
$datatable .= '</table></fieldset></td></tr>'."\n"; |
$itemcount ++; |
$itemcount ++; |
} |
} |
Line 6858 sub print_ltitools {
|
Line 6898 sub print_ltitools {
|
'passback' => '7', |
'passback' => '7', |
'roster' => '300', |
'roster' => '300', |
); |
); |
foreach my $extra ('passback','roster') { |
foreach my $extra ('passback','roster','returnurl') { |
my $onclick = ' onclick="toggleLTITools(this.form,'."'$extra','add'".');"'; |
my $onclick = ' onclick="toggleLTITools(this.form,'."'$extra','add'".');"'; |
$datatable .= '<div class="LC_floatleft"><span class="LC_nobreak">'.$lt{$extra}.' '. |
$datatable .= '<div class="LC_floatleft"><span class="LC_nobreak">'.$lt{$extra}.' '. |
'<label><input type="radio" name="ltitools_'.$extra.'_add" value="0" checked="checked"'.$onclick.' />'. |
'<label><input type="radio" name="ltitools_'.$extra.'_add" value="0" checked="checked"'.$onclick.' />'. |
&mt('No').'</label></span>'.(' 'x2).'<span class="LC_nobreak">'. |
&mt('No').'</label></span>'.(' 'x2).'<span class="LC_nobreak">'. |
'<label><input type="radio" name="ltitools_'.$extra.'_add" value="1"'.$onclick.' />'. |
'<label><input type="radio" name="ltitools_'.$extra.'_add" value="1"'.$onclick.' />'. |
&mt('Yes').'</label></span></div>'. |
&mt('Yes').'</label></span></div>'; |
'<div class="LC_floatleft" style="display:none;" id="ltitools_'.$extra.'time_add">'. |
if ($extra eq 'returnurl') { |
'<span class="LC_nobreak">'. |
$datatable .= '<div class="LC_floatleft" style="display:none;" id="ltitools_course'.$extra.'_add">'. |
&mt("until at least [_1] $units{$extra} after launch", |
'<span class="LC_nobreak"> -- '.&mt('configurable in course').': '. |
'<input type="text" name="ltitools_'.$extra.'valid_add" value="'.$defaulttimes{$extra}.'" />'). |
'<label><input type="radio" name="ltitools_crs'.$extra.'_add" value="0" checked="checked" />'. |
'</span></div><div style="padding:0;clear:both;margin:0;border:0"></div>'; |
&mt('No').'</label>'.(' 'x2). |
|
'<label><input type="radio" name="ltitools_crs'.$extra.'_add" value="1" />'. |
|
&mt('Yes').'</label>'; |
|
} else { |
|
$datatable .= '<div class="LC_floatleft" style="display:none;" id="ltitools_'.$extra.'time_add">'. |
|
'<span class="LC_nobreak">'. |
|
&mt("until at least [_1] $units{$extra} after launch", |
|
'<input type="text" name="ltitools_'.$extra.'valid_add" value="'.$defaulttimes{$extra}.'" />'); |
|
} |
|
$datatable .= '</span></div><div style="padding:0;clear:both;margin:0;border:0"></div>'; |
} |
} |
$datatable .= '<span class="LC_nobreak">'.$lt{'icon'}.': '. |
$datatable .= '<span class="LC_nobreak">'.$lt{'icon'}.': '. |
'('.&mt('if larger than 21x21 pixels, image will be scaled').') '; |
'('.&mt('if larger than 21x21 pixels, image will be scaled').') '; |
Line 6966 sub ltitools_names {
|
Line 7015 sub ltitools_names {
|
'explanation' => 'Default Explanation', |
'explanation' => 'Default Explanation', |
'passback' => 'Tool can return grades:', |
'passback' => 'Tool can return grades:', |
'roster' => 'Tool can retrieve roster:', |
'roster' => 'Tool can retrieve roster:', |
|
'returnurl' => 'Return URL sent on launch:', |
'crstarget' => 'Display target', |
'crstarget' => 'Display target', |
'crslabel' => 'Course label', |
'crslabel' => 'Course label', |
'crstitle' => 'Course title', |
'crstitle' => 'Course title', |