[LON-CAPA-cvs] cvs: loncom(version_2_11_X) /interface lonmenu.pm
raeburn
raeburn at source.lon-capa.org
Tue Jul 2 14:35:28 EDT 2024
raeburn Tue Jul 2 18:35:28 2024 EDT
Modified files: (Branch: version_2_11_X)
/loncom/interface lonmenu.pm
Log:
- For 2.11
Backport 1.523, 1.527, 1.544, 1.547, 1.548
Index: loncom/interface/lonmenu.pm
diff -u loncom/interface/lonmenu.pm:1.369.2.83 loncom/interface/lonmenu.pm:1.369.2.84
--- loncom/interface/lonmenu.pm:1.369.2.83 Mon Dec 13 23:26:32 2021
+++ loncom/interface/lonmenu.pm Tue Jul 2 18:35:28 2024
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Routines to control the menu
#
-# $Id: lonmenu.pm,v 1.369.2.83 2021/12/13 23:26:32 raeburn Exp $
+# $Id: lonmenu.pm,v 1.369.2.84 2024/07/02 18:35:28 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -789,12 +789,8 @@
@mapcrumbs = $navmap->recursed_crumbs($mapurl,$restitle);
}
}
- unless (($forcereg) &&
- ($env{'request.noversionuri'} eq '/adm/navmaps') &&
- ($mapurl eq $env{'course.'.$env{'request.course.id'}.'.url'})) {
- @crumbs = ({text => $crstype.' Contents',
- href => "Javascript:gopost('/adm/navmaps','')"});
- }
+ @crumbs = ({text => $crstype.' Contents',
+ href => "Javascript:gopost('/adm/navmaps','')"});
if ($mapurl ne $env{'course.'.$env{'request.course.id'}.'.url'}) {
if (@mapcrumbs) {
push(@crumbs, at mapcrumbs);
@@ -989,13 +985,31 @@
s&6&2&rtrv.png&Retrieve&version[_1]&gocstr('/adm/retrieve','/priv/$udom/$uname/$cleandisfn')&Retrieve old version
s&6&3&pub.png&Publish&resource[_3]&gocstr('/adm/publish','/priv/$udom/$uname/$cleandisfn')&Publish this resource
s&7&1&del.png&Delete&resource[_2]&gocstr('/adm/cfile?action=delete','/priv/$udom/$uname/$cleandisfn')&Delete this resource
+ENDMENUITEMS
+#
+# Print only makes sense for certain mime types
+#
+ if ($thisdisfn=~/\.(xml|html|htm|xhtml|xhtm|tex)$/ || $thisdisfn=~/$LONCAPA::assess_re/) {
+ $menuitems .= (<<ENDMENUITEMS);
s&7&2&prt.png&Print&printout[_1]&gocstr('/adm/printout','/priv/$udom/$uname/$cleandisfn')&Prepare a printable document
ENDMENUITEMS
+ }
unless ($noremote) {
$cstritems = $menuitems;
undef($menuitems);
}
}
+#
+# Editing options usually accessed via "Settings" in inline menu need to be
+# accessed in a different way, when Authoring Space is accessed in course
+# context
+#
+ if ($env{'request.role'} !~/^(aa|ca|au)/) {
+ my $privfile = &Apache::loncommon::escape_single("/priv/$udom/$uname/$thisdisfn");
+ $menuitems .= (<<ENDMENUITEMS);
+s&7&5&editops.png&Options&edit[_1]&gocstr('/adm/preferences?action=authorsettings','$privfile')&Authoring Space Options
+ENDMENUITEMS
+ }
if (ref($bread_crumbs) eq 'ARRAY') {
&Apache::lonhtmlcommon::clear_breadcrumbs();
foreach my $crumb (@{$bread_crumbs}){
@@ -1152,6 +1166,12 @@
'tools', $inlineremote[63]);
}
&advtools_crumbs(@inlineremote);
+ #options link/icon in constructions space viewed with course role
+ if (($env{'request.state'} eq 'construct') &&
+ ($env{'request.role'} !~/^(aa|ca|au)/)) {
+ &Apache::lonhtmlcommon::add_breadcrumb_tool(
+ 'advtools', $inlineremote[75]);
+ }
}
}
my ($topic_help,$topic_help_text);
@@ -1498,8 +1518,12 @@
if ($env{'form.folderpath'}) {
$suppanchor = $env{'form.anchor'};
}
+ my $shownsymb;
+ if ($env{'request.symb'}) {
+ $shownsymb = &Apache::lonenc::check_encrypt($env{'request.symb'});
+ }
$jscall = &Apache::lonhtmlcommon::jump_to_editres($cfile,$home,$switchserver,
- $forceedit,$forcereg,$env{'request.symb'},
+ $forceedit,$forcereg,$env{'request.symb'},$shownsymb,
&escape($env{'form.folderpath'}),
&escape($env{'form.title'}),$hostname,
$env{'form.idx'},&escape($env{'form.suppurl'}),
@@ -1630,7 +1654,14 @@
} elsif (($resurl !~ m{^/?adm/($match_domain)/($match_username)/aboutme$}) &&
($resurl ne '/cgi-bin/printout.pl')) {
if ($env{'request.filename'}) {
- my $file=&Apache::lonnet::declutter($env{'request.filename'});
+ my $file;
+ my $londocroot = $Apache::lonnet::perlvar{'lonDocRoot'};
+ if ($env{'request.filename'} =~ m{^\Q$londocroot\E/priv/}) {
+ $file = $env{'request.filename'};
+ $file =~ s{^\Q$londocroot\E/}{};
+ } else {
+ $file=&Apache::lonnet::declutter($env{'request.filename'});
+ }
($cfile,$home,$switchserver,$forceedit,$forceview) =
&Apache::lonnet::can_edit_resource($file,$cnum,$cdom,
&Apache::lonnet::clutter($resurl),$env{'request.symb'},$group);
@@ -2353,6 +2384,10 @@
this.document.cstrprint.submit();
return;
}
+ if (url == '/adm/preferences?action=authorsettings') {
+ document.location.href=url+'&returnurl='+filename;
+ return;
+ }
if (url !='') {
this.document.constspace.filename.value = filename;
this.document.constspace.action = url;
More information about the LON-CAPA-cvs
mailing list