version 1.178, 2023/06/11 20:45:40
|
version 1.179, 2023/07/13 21:41:40
|
Line 128 sub handler {
|
Line 128 sub handler {
|
} |
} |
|
|
# Put out actions for directory, browse/upload + new file page. |
# Put out actions for directory, browse/upload + new file page. |
&dircontrols($r,$uname,$udom,$thisdisfn, $current_disk_usage, $disk_quota); |
&dircontrols($r,$uname,$udom,$thisdisfn,$current_disk_usage,$disk_quota,$crsauthor); |
&resourceactions($r,$uname,$udom,$thisdisfn); # Put out form used for printing/deletion etc. |
&resourceactions($r,$uname,$udom,$thisdisfn); # Put out form used for printing/deletion etc. |
|
|
my $numdir = 0; |
my $numdir = 0; |
Line 247 my $result = "<script type=\"text/javasc
|
Line 247 my $result = "<script type=\"text/javasc
|
if (!($cmode&$dirptr)) { |
if (!($cmode&$dirptr)) { |
($status, $pubstatus) = &getStatus($resdir, $targetdir, $cstr_dir, |
($status, $pubstatus) = &getStatus($resdir, $targetdir, $cstr_dir, |
$filename, $linkfilename, $cmtime, $meta_same); |
$filename, $linkfilename, $cmtime, $meta_same); |
($fulltitle, $title) = &getTitle($resdir, $targetdir, $filename, |
if (($crsauthor) && ($extension eq 'rights')) { |
$linkfilename, $meta_same, \%bombs); |
$title = &getTitleString($targetdir.'/'.$filename); |
|
$fulltitle = $title; |
|
} else { |
|
($fulltitle, $title) = &getTitle($resdir, $targetdir, $filename, |
|
$linkfilename, $meta_same, \%bombs); |
|
} |
} else { |
} else { |
($status, $pubstatus) = ('',''); |
($status, $pubstatus) = ('',''); |
($fulltitle, $title) = ('',''); |
($fulltitle, $title) = ('',''); |
Line 317 my $result = "<script type=\"text/javasc
|
Line 322 my $result = "<script type=\"text/javasc
|
$targetdir, \%bombs, \$numdir); |
$targetdir, \%bombs, \$numdir); |
} else { # Files |
} else { # Files |
&putresource($r, $udom, $uname, $filename, $thisdisfn, $resdir, |
&putresource($r, $udom, $uname, $filename, $thisdisfn, $resdir, |
$targetdir, $linkdir, $filehash->{$filename}->{"cmtime"}, |
$targetdir, $linkdir, $crsauthor, |
|
$filehash->{$filename}->{"cmtime"}, |
$filehash->{$filename}->{"size"}, \$numres, |
$filehash->{$filename}->{"size"}, \$numres, |
$filehash->{$filename}->{"linkfilename"}, |
$filehash->{$filename}->{"linkfilename"}, |
$filehash->{$filename}->{"fulltitle"}, |
$filehash->{$filename}->{"fulltitle"}, |
Line 391 sub startpage {
|
Line 397 sub startpage {
|
|
|
$disk_quota = 1024 * $disk_quota; # convert from MB to kB |
$disk_quota = 1024 * $disk_quota; # convert from MB to kB |
|
|
|
my $headertext = &mt('Directory'); |
|
if ($crsauthor) { |
|
$headertext = &mt('Course Authoring Directory'); |
|
} |
$r->print(&Apache::loncommon::head_subbox( |
$r->print(&Apache::loncommon::head_subbox( |
'<div style="float:right;padding-top:0;margin-top;0">' |
'<div style="float:right;padding-top:0;margin-top;0">' |
.&Apache::lonhtmlcommon::display_usage($current_disk_usage, |
.&Apache::lonhtmlcommon::display_usage($current_disk_usage, |
$disk_quota,'authoring') |
$disk_quota,'authoring') |
.'</div>' |
.'</div>' |
.&Apache::loncommon::CSTR_pageheader('','',&mt('Directory')))); |
.&Apache::loncommon::CSTR_pageheader('','',$headertext))); |
|
|
my $esc_thisdisfn = &Apache::loncommon::escape_single($thisdisfn); |
my $esc_thisdisfn = &Apache::loncommon::escape_single($thisdisfn); |
my $doctitle = 'LON-CAPA '.&mt($title); |
my $doctitle = 'LON-CAPA '.&mt($title); |
Line 493 ENDPUBDIRSCRIPT
|
Line 503 ENDPUBDIRSCRIPT
|
} |
} |
|
|
sub dircontrols { |
sub dircontrols { |
my ($r,$uname,$udom,$thisdisfn, $current_disk_usage, $disk_quota) = @_; |
my ($r,$uname,$udom,$thisdisfn,$current_disk_usage,$disk_quota,$crsauthor) = @_; |
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash( |
cnpd => 'Cannot publish directory', |
cnpd => 'Cannot publish directory', |
cnrd => 'Cannot retrieve directory', |
cnrd => 'Cannot retrieve directory', |
Line 552 sub dircontrols {
|
Line 562 sub dircontrols {
|
</fieldset> |
</fieldset> |
</div> |
</div> |
END |
END |
|
my %fileoptions = ( |
|
none => "$lt{'sela'}:", |
|
newfile => "$lt{'nfil'}:", |
|
newhtmlfile => "$lt{'nhtm'}:", |
|
newproblemfile => "$lt{'nprb'}:", |
|
newdir => "$lt{'nsub'}:", |
|
); |
|
$fileoptions{'select_form_order'} = ['none','newfile','newhtmlfile','newproblemfile']; |
|
if ($crsauthor) { |
|
push(@{$fileoptions{'select_form_order'}},'newdir'); |
|
} else { |
|
my %extraoptions = ( |
|
newpagefile => "$lt{'npag'}:", |
|
newsequencefile => "$lt{'nseq'}:", |
|
newrightsfile => "$lt{'ncrf'}:", |
|
newstyfile => "$lt{'nsty'}:", |
|
newtaskfile => "$lt{'nbt'}:", |
|
newlibraryfile => "$lt{'nlib'}:", |
|
); |
|
%fileoptions = (%fileoptions,%extraoptions); |
|
push(@{$fileoptions{'select_form_order'}},('newpagefile','newsequencefile', |
|
'newrightsfile','newstyfile', |
|
'newtaskfile','newlibraryfile', |
|
'newdir')); |
|
} |
|
my $selectbox = &Apache::loncommon::select_form('none','action',\%fileoptions); |
$r->print(<<END); |
$r->print(<<END); |
<div style="padding-bottom: 2px"> |
<div style="padding-bottom: 2px"> |
<form name="upublisher" enctype="multipart/form-data" method="post" action="/adm/upload"> |
<form name="upublisher" enctype="multipart/form-data" method="post" action="/adm/upload"> |
Line 581 END
|
Line 617 END
|
} |
} |
} |
} |
</script> |
</script> |
<select name="action"> |
$selectbox <input type="text" id="newnameid" name="newfilename" placeholder="$lt{'type'}" value="" onfocus="if (this.value == is.empty()) this.value=''" /> <input type="button" value="Go" onclick="validate_go();" /> |
<option value="none">$lt{'sela'}</option> |
|
<option value="newfile">$lt{'nfil'}:</option> |
|
<option value="newhtmlfile">$lt{'nhtm'}:</option> |
|
<option value="newproblemfile">$lt{'nprb'}:</option> |
|
<option value="newpagefile">$lt{'npag'}:</option> |
|
<option value="newsequencefile">$lt{'nseq'}:</option> |
|
<option value="newrightsfile">$lt{'ncrf'}:</option> |
|
<option value="newstyfile">$lt{'nsty'}:</option> |
|
<option value="newtaskfile">$lt{'nbt'}:</option> |
|
<option value="newlibraryfile">$lt{'nlib'}:</option> |
|
<option value="newdir">$lt{'nsub'}:</option> |
|
</select> <input type="text" id="newnameid" name="newfilename" placeholder="$lt{'type'}" value="" onfocus="if (this.value == is.empty()) this.value=''" /> <input type="button" value="Go" onclick="validate_go();" /> |
|
<br /> |
<br /> |
<span>$lt{'shcu'}: |
<span>$lt{'shcu'}: |
<input type="hidden" name="mode"/> |
<input type="hidden" name="mode"/> |
Line 827 sub isMetaSame {
|
Line 851 sub isMetaSame {
|
|
|
sub getStatus { |
sub getStatus { |
my ($resdir, $targetdir, $cstr_dir, $filename, |
my ($resdir, $targetdir, $cstr_dir, $filename, |
$linkfilename, $cmtime, $meta_same) = @_; |
$linkfilename, $crsauthor, $cmtime, $meta_same) = @_; |
my $pubstatus = 'unpublished'; |
my $pubstatus = 'unpublished'; |
my $status = &mt('Unpublished'); |
my $status = &mt('Unpublished'); |
|
|
Line 853 sub getStatus {
|
Line 877 sub getStatus {
|
); |
); |
$rights_status .= |
$rights_status .= |
$lt_SourceRight{&getSourceRightString($targetdir.'/'.$filename)}; |
$lt_SourceRight{&getSourceRightString($targetdir.'/'.$filename)}; |
|
if (($crsauthor) && ($filename =~ /\.rights$/)) { |
|
$rights_status =~ s/,\s+$//; |
|
} |
if ($same) { |
if ($same) { |
if (&Apache::lonnet::metadata($targetdir.'/'.$filename,'obsolete')) { |
if (&Apache::lonnet::metadata($targetdir.'/'.$filename,'obsolete')) { |
$pubstatus = 'obsolete'; |
$pubstatus = 'obsolete'; |
Line 871 sub getStatus {
|
Line 897 sub getStatus {
|
$pubstatus = 'modified'; |
$pubstatus = 'modified'; |
$status=&mt('Modified'). |
$status=&mt('Modified'). |
'<br />'. $rights_status; |
'<br />'. $rights_status; |
if (&Apache::loncommon::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { |
unless (($crsauthor) && ($filename =~ /\.rights$/)) { |
$status.='<br />'. |
if (&Apache::loncommon::fileembstyle(($filename=~/\.(\w+)$/)) eq 'ssi') { |
&Apache::loncommon::modal_link( |
$status.='<br />'. |
'/adm/diff?filename='.$linkfilename.'&versiontwo=priv', |
&Apache::loncommon::modal_link( |
&mt('Diffs'),600,500); |
'/adm/diff?filename='.$linkfilename.'&versiontwo=priv', |
|
&mt('Diffs'),600,500); |
|
} |
} |
} |
} |
} |
|
|
$status.="\n".'<br />'. |
unless (($crsauthor) && ($filename =~ /\.rights$/)) { |
&Apache::loncommon::modal_link( |
$status.="\n".'<br />'. |
'/adm/retrieve?filename='.$linkfilename.'&inhibitmenu=yes&add_modal=yes',&mt('Retrieve'),600,500); |
&Apache::loncommon::modal_link( |
|
'/adm/retrieve?filename='.$linkfilename.'&inhibitmenu=yes&add_modal=yes',&mt('Retrieve'),600,500); |
|
} |
} |
} |
|
|
return ($status, $pubstatus); |
return ($status, $pubstatus); |
Line 892 sub getStatus {
|
Line 922 sub getStatus {
|
# Put a table row for a file resource. |
# Put a table row for a file resource. |
# |
# |
sub putresource { |
sub putresource { |
my ($r, $udom, $uname, $filename, $thisdisfn, $resdir, $targetdir, |
my ($r, $udom, $uname, $filename, $thisdisfn, $resdir, |
$linkdir, $cmtime, $size, $numres, $linkfilename, $title, |
$targetdir, $linkdir, $crsauthor, $cmtime, $size, |
$status, $pubstatus) = @_; |
$numres, $linkfilename, $title, $status, $pubstatus) = @_; |
&Apache::lonnet::devalidate_cache_new('meta',$targetdir.'/'.$filename); |
&Apache::lonnet::devalidate_cache_new('meta',$targetdir.'/'.$filename); |
|
|
my $editlink=''; |
my $editlink=''; |
Line 920 sub putresource {
|
Line 950 sub putresource {
|
} |
} |
my $publish_button = (-e $resdir.'/'.$filename) ? &mt('Re-publish') : &mt('Publish'); |
my $publish_button = (-e $resdir.'/'.$filename) ? &mt('Re-publish') : &mt('Publish'); |
my $pub_select = ''; |
my $pub_select = ''; |
&create_pubselect($r,\$pub_select,$udom,$uname,$thisdisfn,$filename,$resdir,$pubstatus,$publish_button,$numres); |
unless (($crsauthor) && ($filename=~ /\.rights$/)) { |
|
&create_pubselect($r,\$pub_select,$udom,$uname,$thisdisfn,$filename,$resdir,$pubstatus,$publish_button,$numres); |
|
} |
$r->print(&Apache::loncommon::start_data_table_row(). |
$r->print(&Apache::loncommon::start_data_table_row(). |
'<td>'.($filename=~/[\#\~]$/?' ': |
'<td>'.($filename=~/[\#\~]$/?' ': |
'<img src="'.&Apache::loncommon::icon($filename).'" alt="" />').'</td>'. |
'<img src="'.&Apache::loncommon::icon($filename).'" alt="" />').'</td>'. |