--- loncom/interface/londocs.pm 2004/04/26 16:56:26 1.121 +++ loncom/interface/londocs.pm 2004/05/06 20:34:06 1.125 @@ -1,7 +1,7 @@ # The LearningOnline Network # Documents # -# $Id: londocs.pm,v 1.121 2004/04/26 16:56:26 www Exp $ +# $Id: londocs.pm,v 1.125 2004/05/06 20:34:06 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -301,31 +301,70 @@ sub editor { # ---------------- if they are for this folder and user allowed to make changes if (($allowed) && ($ENV{'form.folder'} eq $folder)) { -# set parameters +# set parameters and change order if (defined($ENV{'form.setparms'})) { my $idx=$ENV{'form.setparms'}; +# set parameters if ($ENV{'form.randpick_'.$idx}) { - &Apache::lonratedt::storeparameter($idx,'randompick',$ENV{'form.randpick_'.$idx},'int_pos'); + &Apache::lonratedt::storeparameter($idx,'parameter_randompick',$ENV{'form.randpick_'.$idx},'int_pos'); } else { - &Apache::lonratedt::delparameter($idx,'randompick'); + &Apache::lonratedt::delparameter($idx,'parameter_randompick'); } if ($ENV{'form.hidprs_'.$idx}) { - &Apache::lonratedt::storeparameter($idx,'hiddenresource','yes','string_yesno'); + &Apache::lonratedt::storeparameter($idx,'parameter_hiddenresource','yes','string_yesno'); } else { - &Apache::lonratedt::delparameter($idx,'hiddenresource'); + &Apache::lonratedt::delparameter($idx,'parameter_hiddenresource'); } if ($ENV{'form.encprs_'.$idx}) { - &Apache::lonratedt::storeparameter($idx,'encrypturl','yes','string_yesno'); + &Apache::lonratedt::storeparameter($idx,'parameter_encrypturl','yes','string_yesno'); } else { - &Apache::lonratedt::delparameter($idx,'encrypturl'); + &Apache::lonratedt::delparameter($idx,'parameter_encrypturl'); + } + + if ($ENV{'form.newpos'}) { +# change order + + my $newpos=$ENV{'form.newpos'}-1; + my $currentpos=$ENV{'form.currentpos'}-1; + my $i; + my @neworder=(); + if ($newpos>$currentpos) { +# moving stuff up + for ($i=0;$i<$currentpos;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i]; + } + for ($i=$currentpos;$i<$newpos;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i+1]; + } + $neworder[$newpos]=$Apache::lonratedt::order[$currentpos]; + for ($i=$newpos+1;$i<=$#Apache::lonratedt::order;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i]; + } + } else { +# moving stuff down + for ($i=0;$i<$newpos;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i]; + } + $neworder[$newpos]=$Apache::lonratedt::order[$currentpos]; + for ($i=$newpos+1;$i<$currentpos+1;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i-1]; + } + for ($i=$currentpos+1;$i<=$#Apache::lonratedt::order;$i++) { + $neworder[$i]=$Apache::lonratedt::order[$i]; + } + } + @Apache::lonratedt::order=@neworder; } +# store the changed version ($errtext,$fatal)=&storemap($coursenum,$coursedom,$folder.'.sequence'); if ($fatal) { $r->print('

'.$errtext.'

'); return; } + } + # upload a file, if present if (($ENV{'form.uploaddoc.filename'}) && ($ENV{'form.cmd'}=~/^upload_(\w+)/)) { @@ -463,6 +502,7 @@ sub entryline { &Apache::lonnet::unescape($title)),'"<>&\''); my $renametitle=$title; my $foldertitle=$title; + my $orderidx=$Apache::lonratedt::order[$index]; if ($title=~ /^(\d+)___&&&___(\w+)___&&&___(\w+)___&&&___(.*)$/ ) { $foldertitle=&Apache::lontexconvert::msgtexconverted($4); $renametitle=$4; @@ -479,6 +519,21 @@ sub entryline { # $htmlfoldername=&HTML::Entities::encode($ENV{'form.foldername'},'<>&"'); } if ($allowed) { + my $incindex=$index+1; + my $selectbox=''; + if ($folder!~/^supplemental/) { + $selectbox= + ''. + ''; + } my %lt=&Apache::lonlocal::texthash( 'up' => 'Move Up', 'dw' => 'Move Down', @@ -487,7 +542,7 @@ sub entryline { $line.=(< - + -
@@ -495,7 +550,9 @@ sub entryline {
$lt{
+ +$selectbox + $lt{'rm'} @@ -538,8 +595,8 @@ END $folderpath.=$folderarg.'&'.$foldername; $url.='folderpath='.&Apache::lonnet::escape($folderpath); $parameterset=&mt('Randomly Pick: '). - ''; + ''; } $line.=''. @@ -549,11 +606,15 @@ END 'hd' => 'Hidden', 'ec' => 'URL hidden', 'sp' => 'Store Parameters'); + my $enctext= + ((&Apache::lonratedt::getparameter($orderidx,'parameter_encrypturl'))[0]=~/^yes$/i?' checked="1"':''); + my $hidtext= + ((&Apache::lonratedt::getparameter($orderidx,'parameter_hiddenresource'))[0]=~/^yes$/i?' checked="1"':''); $line.=(< - $lt{'hd'} + $lt{'hd'} - $lt{'ec'} + $lt{'ec'} $parameterset