--- loncom/interface/lonsyllabus.pm 2009/04/21 17:54:27 1.87 +++ loncom/interface/lonsyllabus.pm 2013/05/19 15:48:51 1.128 @@ -1,7 +1,7 @@ # The LearningOnline Network # Syllabus # -# $Id: lonsyllabus.pm,v 1.87 2009/04/21 17:54:27 neumanie Exp $ +# $Id: lonsyllabus.pm,v 1.128 2013/05/19 15:48:51 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -52,37 +52,110 @@ sub handler { my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri); # ------------------------------------------------------------ Get query string &Apache::loncommon::get_unprocessed_cgi - ($ENV{'QUERY_STRING'},['forcestudent','register','forceedit','wrapperdisplay']); + ($ENV{'QUERY_STRING'},['register','forceedit','todocs', + 'folderpath','title']); # ----------------------------------------------------- Is this even a course? my $homeserver=&Apache::lonnet::homeserver($cnum,$cdom); if ($homeserver eq 'no_host') { &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; - &Apache::loncommon::simple_error_page($r,'No syllabus available', - 'No syllabus available'); + &Apache::loncommon::simple_error_page($r,'No syllabus available', + 'No syllabus available'); + return OK; + } elsif (!&Apache::lonnet::is_course($cdom,$cnum)) { + &Apache::loncommon::content_type($r,'text/html'); + $r->send_http_header; + &Apache::loncommon::simple_error_page($r,'No syllabus available', + 'The course/community for which the syllabus was requested does not exist.'); return OK; } # ------------------------------------- There is such a course, get environment my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum); + my $crstype = &Apache::loncommon::course_type(); # ------------------------------------------------------------ Print the screen if ($target eq 'tex') { - $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'})); + $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'})); + } + +# --------------------------------------------------------------- Force Student + my ($forceedit,$forcestudent); + if ($env{'form.forceedit'}) { $forceedit=1; } + if (!$forceedit) { + $forcestudent=1; + } + +# --------------------------------------------------------------- Check Privileges + my $allowed = 0; + if ($env{'user.environment'}) { +# does this user have privileges to post, etc? + if ($env{'request.course.id'} + && $cdom eq $env{'course.'.$env{'request.course.id'}.'.domain'} + && $cnum eq $env{'course.'.$env{'request.course.id'}.'.num'}) { + $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'}); + if ($forcestudent or $target eq 'tex') { $allowed=0; } + } } -# -------------------------------------------------- Let's see who handles this - my $externalsyllabus=$courseenv{'externalsyllabus'}; - if ($externalsyllabus=~/\w/) { +# -------------------------------------------------- Let's see who handles this + my $external=$courseenv{'externalsyllabus'}; + my $uploaded=$courseenv{'uploadedsyllabus'}; + my $minimal=$courseenv{'minimalsyllabus'}; + + if (($minimal =~/\w/) || ($uploaded =~/\w/)) { + my $item; + if ($minimal =~/\w/) { + if ($external =~ m{\Q$minimal\E$}) { + undef($external); + } + $item = $minimal; + } elsif ($uploaded =~/\w/) { + if ($external =~ m{\Q$uploaded\E$}) { + undef($external); + } + $item = $uploaded; + } + unless ($allowed && $forceedit) { + my $file=&Apache::lonnet::filelocation("",$item); + if ($file =~ /\.(tex|x?html?)$/) { + my $filetype = $1; + my $filecontents=&Apache::lonnet::getfile($file); + if ($filecontents eq -1) { + $r->print(&mt('Syllabus file unavailable')); + } elsif ($filetype eq 'tex') { + my $result = &Apache::lontexconvert::converted(\$filecontents, + $env{'form.texengine'}); + my %args; + &get_breadcrumbs($cdom,$cnum,$crstype,\%args); + $r->print(&Apache::loncommon::start_page("Syllabus",undef,\%args). + $result. + &Apache::loncommon::end_page()); + } else { + my %mystyle; + &Apache::structuretags::reset_problem_globals(); + my $oldfile = $env{'request.filename'}; + $env{'request.filename'} = $item; + my $result = &Apache::lonxml::xmlparse($r,'web',$filecontents, + '',%mystyle); + &Apache::structuretags::reset_problem_globals(); + &Apache::lonhomework::finished_parsing(); + $env{'request.filename'} = $oldfile; + &Apache::lonxml::add_messages(\$result); + $r->print($result); + } + } else { + $r->print(&Apache::lonwrapper::wrapper($item)); + } + return OK; + } + } elsif ($external=~/\w/) { + unless ($allowed && $forceedit) { + $r->print(&Apache::lonwrapper::wrapper($external)); + return OK; + } + } - if ($env{'form.wrapperdisplay'} eq 'menu') { - $r->print(&Apache::lonwrapper::simple_menu()); - } else { - $r->print(&Apache::lonwrapper::wrapper("/public/$cdom/$cnum/syllabus?wrapperdisplay=menu", - $externalsyllabus)); - } - return OK; - } # ------------------------------ The buck stops here: internal syllabus display # --------------------------------------------------------- The syllabus fields @@ -102,27 +175,327 @@ sub handler { 'jjj_weblinks' => 'Web Links', 'kkk_textbook' => 'Textbook', 'lll_includeurl' => 'URLs To Include in Syllabus'); -# --------------------------------------------------------------- Force Student - my $forcestudent=''; - if ($env{'form.forcestudent'}) { $forcestudent='student'; }; - my $forceedit=''; - if ($env{'form.forceedit'}) { $forceedit='edit'; } +# ---------------------------------------------------------- Load syllabus info + my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum); + my ($output,%displayfields,%noshow); -# ----------------------------------------------------------------- Make header +# This handler might be called anonymously ... +# ----------------------------------------------------- Only if not public call + if ($allowed) { + if (($env{'form.choice'} =~ /^(template|minimal|url|file)$/) || + ($env{'form.phase'} =~ /^(upload|check)_embedded$/)) { + my $earlyout; + ($earlyout,$uploaded,$external,$minimal,$output) = + &save_changes($cnum,$cdom,$uploaded,$external,$minimal, + \%syllabus,\%syllabusfields,\%courseenv); + if (($env{'form.choice'} eq 'minimal') && + ($minimal eq "/uploaded/$cdom/$cnum/portfolio/syllabus/loncapa.html")) { + delete($env{'form.symb'}); + delete($env{'request.symb'}); + $r->internal_redirect("$minimal?editmode=1&forceedit=1"); + return OK; + } + if ($earlyout) { + if ($target ne 'tex') { + &print_header($r,$cnum,$cdom,$crstype,$allowed,$forceedit, + \%syllabus,\%syllabusfields); + $r->print($output. + &Apache::loncommon::end_page()); + } + return OK; + } + } + } + if ($target ne 'tex') { + &print_header($r,$cnum,$cdom,$crstype,$allowed,$forceedit,\%syllabus, + \%syllabusfields); + $r->print($output); + } + +# -------------------------------------------- Determine which fields are shown + + if ($syllabus{'uploaded.fields'}) { + if ($syllabus{'uploaded.fields'} eq 'none') { + foreach my $field (keys(%syllabusfields)) { + $displayfields{$field} = ' style="display:none;"'; + $noshow{$field} = 1; + } + } else { + my %included; + map { $included{$_} = 1; } split(/,/,$syllabus{'uploaded.fields'}); + foreach my $field (keys(%syllabusfields)) { + my ($prefix) = split(/_/,$field); + if ($included{$prefix}) { + $displayfields{$field} = ' style="display:block;"'; + } else { + $displayfields{$field} = ' style="display:none;"'; + $noshow{$field} = 1; + } + } + } + } else { + foreach my $field (keys(%syllabusfields)) { + if ($syllabus{$field} ne '') { + $displayfields{$field} = ' style="display:block;"'; + } else { + $displayfields{$field} = ' style="display:none;"'; + } + } + } + + if ($allowed) { +#---------------------------------- Print External URL Syllabus Info if editing + if ($target ne 'tex') { + my $protocol = $Apache::lonnet::protocol{$homeserver}; + $protocol = 'http' if ($protocol ne 'https'); + my $link = $protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri; + $r->print('
'. + &mt('All feeds currently hidden'). + $msg. + '
'); + } else { + $r->print(''. + &mt('No current feeds'). + $msg. + '
'); + } + $rsslinktext = &mt('Manage Course RSS Feeds/Blogs'); + if ($crstype eq 'Community') { + $rsslinktext = &mt('Manage Communiity RSS Feeds/Blogs'); + } + } + my $editurl= &Apache::lonnet::absolute_url().'/adm/'.$cdom.'/'.$cnum.'/_rss.html'; + $r->print( ''.$rsslinktext.''); + &Apache::lontemplate::print_end_template($r); + } else { + unless ($hidefeeds) { + my $feeds = &Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit); + if ($feeds ne '') { + &Apache::lontemplate::print_start_template($r,&mt('RSS Feeds and Blogs'),'LC_Box'); + $r->print($feeds); + &Apache::lontemplate::print_end_template($r); + } + } + } + } else { + $r->print(&Apache::lonxml::xmlparse($r,'tex',$day)); + } +# ---------------------------------------------------------------- Get syllabus + if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) { + if ($allowed) { + $r->print(''. + &Apache::lonhtmlcommon::htmlareaselectactive()); + } + } else { + if ($target ne 'tex') {$r->print('');} else {$r->print('\par ');} + $r->print(&mt('No syllabus information provided.')); + if ($target ne 'tex') {$r->print('
');} + } if ($target ne 'tex') { - my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom); - my $js; if ($env{'form.backto'} eq 'coursecatalog') { - $js .= <<"ENDSCRIPT"; + $r->print(''); + } + $r->print(&Apache::loncommon::end_page()); + } else { + $r->print('\end{document}'); + } + return OK; +} + +sub print_header { + my ($r,$cnum,$cdom,$crstype,$allowed,$forceedit,$syllabus,$syllabusfields) = @_; + return unless ((ref($syllabus) eq 'HASH') || (ref($syllabusfields) eq 'HASH')); +# ----------------------------------------------------------------- Make header + my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom); + my $js; + if ($env{'form.backto'} eq 'coursecatalog') { + $js .= <<"ENDSCRIPT"; ENDSCRIPT + } + if ($allowed && $forceedit) { + my $check_uncheck = &Apache::loncommon::check_uncheck_jscript(); + my @fieldnames = sort(keys(%{$syllabusfields})); + unshift(@fieldnames,'000_showpeople','111_showrssfeeds'); + my (@checked,@unchecked); + if ($syllabus->{'uploaded.fields'} eq 'none') { + my $lastidx = scalar(@fieldnames)-1; + @unchecked = (0..$lastidx); + } elsif ($syllabus->{'uploaded.fields'}) { + my %included; + map { $included{$_} = 1; } split(/,/,$syllabus->{'uploaded.fields'}); + for (my $i=0; $i<@fieldnames; $i++) { + my ($prefix) = split(/_/,$fieldnames[$i]); + if ($included{$prefix}) { + push(@checked,$i); + } else { + push(@unchecked,$i); + } + } + } else { + @checked = (0,1); + for (my $i=2; $i<@fieldnames; $i++) { + if ($syllabus->{$fieldnames[$i]}) { + push(@checked,$i); + } else { + push(@unchecked,$i); + } + } } - my $start_page = - &Apache::loncommon::start_page("Syllabus", $rss_link.$js, - {'function' => $forcestudent, - 'domain' => $cdom, - 'force_register' => - $env{'form.register'},}); + my $fieldstr = "var fields = new Array('".join("','",@fieldnames)."');"; + my $checkedstr = "var include = new Array('".join("','",@checked)."');"; + my $uncheckedstr = "var exclude = new Array('".join("','",@unchecked)."');"; + my $invurl = &mt('Invalid URL'); + my $urlregexp = <<'ENDREGEXP'; +/^([a-z]([a-z]|\d|\+|-|\.)*):(\/\/(((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?((\[(|(v[\da-f]{1,}\.(([a-z]|\d|-|\.|_|~)|[!\$&'\(\)\*\+,;=]|:)+))\])|((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=])*)(:\d*)?)(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*|(\/((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)|((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)|((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)){0})(\?((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/i +ENDREGEXP - $r->print($start_page); - if ($env{'form.backto'} eq 'coursecatalog') { - &Apache::lonhtmlcommon::clear_breadcrumbs(); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:ToCatalog()", - text=>"Course Catalog"}); - if ($env{'form.coursenum'} ne '') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:ToCatalog('details')", - text=>"Course details"}); + $js .= <<"ENDSCRIPT"; + + + +ENDSCRIPT + } + my $args = {'function' => undef, + 'domain' => $cdom}; + my $forcereg; + if ($env{'form.register'}) { + $forcereg = 1; + $args->{'force_register'} = $forcereg; + } + if ($env{'form.backto'} eq 'coursecatalog') { + &Apache::lonhtmlcommon::clear_breadcrumbs(); + my $brcrum = [{href=>"javascript:ToCatalog();", + text=>&mt('Course/Community Catalog'), + no_mt=>1} + ]; + if ($env{'form.coursenum'} ne '') { + push(@{$brcrum}, + {href=>"javascript:ToCatalog('details')", + text=>"Course details"}); + } + push(@{$brcrum}, + {href=>$r->uri, text=>"Course syllabus"}); - $r->print(&Apache::lonhtmlcommon::breadcrumbs()); + $args->{'bread_crumbs'} = $brcrum; + } else { + &get_breadcrumbs($cdom,$cnum,$crstype,$args); + } + if ($allowed) { + my %loaditem = ( + onload => 'setTemplateBoxes();', + ); + $args->{'add_entries'} = \%loaditem; + } + my $start_page = + &Apache::loncommon::start_page("Syllabus", $rss_link.$js,$args); + if ($start_page) { + $r->print($start_page); + } +} + +sub get_breadcrumbs{ + my ($cdom,$cnum,$crstype,$args) = @_; + return unless (ref($args) eq 'HASH'); + if ($env{'form.folderpath'} =~ /^supplemental/) { + my $title = $env{'form.title'}; + if ($title eq '') { + $title = &mt('Syllabus'); + } + my $brcrum = + &Apache::lonhtmlcommon::docs_breadcrumbs(undef,$crstype,undef,$title,1); + if (ref($brcrum) eq 'ARRAY') { + $args->{'bread_crumbs'} = $brcrum; + } + } else { + if ((&Apache::lonnet::is_on_map("public/$cdom/$cnum/syllabus")) + && (($env{'form.symb'}) || ($env{'form.register'}))) { + &Apache::lonhtmlcommon::clear_breadcrumbs(); + } else { + $args->{'bread_crumbs'} = [ + {'href' => "/public/$cdom/$cnum/syllabus", + 'text' => 'Syllabus'}, + ]; } + } + return; +} +sub chooser { + my ($external,$uploaded,$minimal,$cdom,$cnum,$lonhost,$fields,$values) = @_; + my %lt = &Apache::lonlocal::texthash( + 'type' => 'Syllabus Type', + 'url' => 'External URL', + 'file' => 'Uploaded file', + 'minimal' => 'Minimal template', + 'template' => 'Standard template', + 'templateboxes' => 'Choose template items ... ', + 'curr' => 'Current:', + 'rep' => 'Replace:', + 'upl' => 'Upload:', + 'pr' => 'Preview', + 'save' => 'Save', + 'sved' => 'Save and Edit', + 'chourl' => 'External URL', + 'chofile' => 'Uploaded syllabus file', + 'parse' => 'Upload embedded images/multimedia files if HTML file', + ); + my %checked = ( + file => '', + minimal => '', + url => '', + template => '', + ); + my %display = ( + file => 'none', + minimal => 'none', + url => 'none', + templatebox => 'none', + ); + my $check = ' checked="checked" '; + if ($uploaded) { + $checked{'file'} = $check; + $display{'file'} = 'block'; + } elsif ($external) { + $checked{'url'} = $check; + $display{'url'} = 'block'; + } elsif ($minimal) { + $checked{'minimal'} = $check; + $display{'minimal'} = 'block'; + } else { + $checked{'template'} = $check; + $checked{'templatebox'} = $check; + $display{'templatebox'} = 'block'; } -# ---------------------------------------------------------- Load syllabus info - my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum); - my $allowed=0; - my $privileged=0; -# This handler might be called anonymously ... -# ----------------------------------------------------- Only if not public call - if ($env{'user.environment'}) { -# does this user have privileges to post, etc? - if ($env{'request.course.id'} - && $cdom eq $env{'course.'.$env{'request.course.id'}.'.domain'} - && $cnum eq $env{'course.'.$env{'request.course.id'}.'.num'}) { - $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'}); - $privileged=$allowed; - if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) { - $forcestudent='student'; - } - if ($forcestudent or $target eq 'tex') { $allowed=0; } - } - if (($allowed) && ($env{'form.storesyl'})) { - foreach my $syl_field (keys(%syllabusfields)) { - my $field=$env{'form.'.$syl_field}; - chomp($field); - $field=~s/\s+$//s; - $field=~s/^\s+//s; - $field=~s/\' - .&mt('This syllabus can be publicly viewed at [_1]' - ,''.$protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri.'') - .' '.&Apache::loncommon::help_open_topic('Syllabus_ExtLink') - .'
' - .'' - .&mt('Instead of using this template you can specify an external URL as Syllabus in the [_1]Course Parameters[_2].' - ,'','') - .'
' - ); -} - -#-Print Help Text -if ($target ne 'tex') { - if($allowed){ - $r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes'))); - } -} -#--------Functions -if ($target ne 'tex') { - if($allowed || $privileged){ - $r->print(&Apache::lontemplate::start_functionslist()); - if($allowed){ - $r->print(&Apache::lontemplate::item_functionslist( - ''.&mt('Show Public View').'' - .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView'))); - }elsif($privileged){ - $r->print(&Apache::lontemplate::item_functionslist( - ''.&mt('Edit').'')); - } - $r->print(&Apache::lontemplate::end_functionslist()); - } - } -#----------------------------Print Headtitle -if($target ne 'tex'){ - $r->print('