version 1.115, 2016/05/30 04:50:39
|
version 1.121, 2017/02/20 18:29:33
|
Line 184 sub handler {
|
Line 184 sub handler {
|
if (($env{'request.course.fn'}) && (!$env{'form.forceselect'})) { |
if (($env{'request.course.fn'}) && (!$env{'form.forceselect'})) { |
my $fn=$env{'request.course.fn'}; |
my $fn=$env{'request.course.fn'}; |
if (-e "$fn.db") { |
if (-e "$fn.db") { |
|
my %buttonshide; |
if (tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER(),0640)) { |
if (tie(%hash,'GDBM_File',"$fn.db",&GDBM_READER(),0640)) { |
# ------------------------------------------------------------------- Hash tied |
# ------------------------------------------------------------------- Hash tied |
my $firstres=$hash{'map_start_'.$requrl}; |
my $firstres=$hash{'map_start_'.$requrl}; |
Line 300 sub handler {
|
Line 301 sub handler {
|
$lcm*=($#colcont+1)/euclid($lcm,($#colcont+1)); |
$lcm*=($#colcont+1)/euclid($lcm,($#colcont+1)); |
foreach (@colcont) { |
foreach (@colcont) { |
my $src=$hash{'src_'.$_}; |
my $src=$hash{'src_'.$_}; |
|
my $plainsrc = $src; |
my ($extension)=($src=~/\.(\w+)$/); |
my ($extension)=($src=~/\.(\w+)$/); |
$cellexternal{$_}=($hash{'ext_'.$_} eq 'true:'); |
$cellexternal{$_}=($hash{'ext_'.$_} eq 'true:'); |
if ($hash{'encrypted_'.$_}) { |
if ($hash{'encrypted_'.$_}) { |
$src=&Apache::lonenc::encrypted($src); |
$src=&Apache::lonenc::encrypted($src); |
} |
} |
|
my ($mapid,$resid)=split(/\./,$_); |
|
my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid},$resid,$src); |
|
unless ($env{'request.role.adv'}) { |
|
$buttonshide{$symb} = &Apache::lonnet::EXT("resource.0.buttonshide",$symb); |
|
} |
$cellemb{$_}= |
$cellemb{$_}= |
&Apache::loncommon::fileembstyle($extension); |
&Apache::loncommon::fileembstyle($extension); |
if ($cellexternal{$_}) { |
if ($cellexternal{$_}) { |
Line 315 ENDEXT
|
Line 322 ENDEXT
|
} |
} |
} elsif ($cellemb{$_} eq 'ssi') { |
} elsif ($cellemb{$_} eq 'ssi') { |
# --------------------------------------------------------- This is an SSI cell |
# --------------------------------------------------------- This is an SSI cell |
my ($mapid,$resid)=split(/\./,$_); |
|
my $symb=&Apache::lonnet::encode_symb($hash{'map_id_'.$mapid},$resid,$src); |
|
|
|
my $prefix=$_.'_'; |
my $prefix=$_.'_'; |
my $idprefix= join('_',($mapid,$resid,'')); |
my $idprefix= join('_',($mapid,$resid,'')); |
my %posthash=('request.prefix' => $prefix, |
my %posthash=('request.prefix' => $prefix, |
Line 355 ENDEXT
|
Line 359 ENDEXT
|
my $output=Apache::lonnet::ssi($src,%posthash); |
my $output=Apache::lonnet::ssi($src,%posthash); |
$output=~s|//(\s*<!--)? BEGIN LON-CAPA Internal.+?// END LON-CAPA Internal\s*(-->)?\s||gs; |
$output=~s|//(\s*<!--)? BEGIN LON-CAPA Internal.+?// END LON-CAPA Internal\s*(-->)?\s||gs; |
if (($target eq 'tex') || ($target eq 'tex_answer')) { |
if (($target eq 'tex') || ($target eq 'tex_answer')) { |
$output =~ s/^([^&]+)\\begin{document}//; |
$output =~ s/^([^&]+)\\begin\{document}//; |
$output =~ s/\\end{document}//; |
$output =~ s/\\end\{document}//; |
# $output = '\parbox{\minipagewidth}{ '.$output.' }'; |
# $output = '\parbox{\minipagewidth}{ '.$output.' }'; |
#some additional cleanup necessary for LateX (due to limitations of table environment |
#some additional cleanup necessary for LateX (due to limitations of table environment |
$output =~ s/(\\vskip\s*\d+mm)\s*(\\\\)+/$1/g; |
$output =~ s/(\\vskip\s*\d+mm)\s*(\\\\)+/$1/g; |
Line 471 ENDEXT
|
Line 475 ENDEXT
|
$output=~ |
$output=~ |
s/\<(input[^\>]+\Qonfocus=\"javascript:disableAutoComplete\E)\(\'([^\']+)\'\)(;\")/\<$1('$idprefix$2')$3/gsi; |
s/\<(input[^\>]+\Qonfocus=\"javascript:disableAutoComplete\E)\(\'([^\']+)\'\)(;\")/\<$1('$idprefix$2')$3/gsi; |
unless ($hastimer) { |
unless ($hastimer) { |
if ($src =~ /$LONCAPA::assess_re/) { |
if ($plainsrc =~ /$LONCAPA::assess_re/) { |
%Apache::lonhomework::history = |
%Apache::lonhomework::history = |
&Apache::lonnet::restore($symb,$courseid,$domain,$name); |
&Apache::lonnet::restore($symb,$courseid,$domain,$name); |
my $type = 'problem'; |
my $type = 'problem'; |
if ($src =~ /\.task$/) { |
if ($extension eq 'task') { |
$type = 'Task'; |
$type = 'Task'; |
} |
} |
my ($status,$accessmsg,$slot_name,$slot) = |
my ($status,$accessmsg,$slot_name,$slot) = |
&Apache::lonhomework::check_slot_access('0',$type,$symb,$pagesymb); |
&Apache::lonhomework::check_slot_access('0',$type,$symb); |
undef(%Apache::lonhomework::history); |
undef(%Apache::lonhomework::history); |
my $probstatus = &Apache::lonnet::EXT("resource.0.problemstatus",$symb); |
my $probstatus = &Apache::lonnet::EXT("resource.0.problemstatus",$symb); |
if (($status eq 'CAN_ANSWER') || (($status eq 'CANNOT_ANSWER') && |
if (($status eq 'CAN_ANSWER') || (($status eq 'CANNOT_ANSWER') && |
Line 676 ENDEXT
|
Line 680 ENDEXT
|
&add_countdown_timer($currdisp,$donebuttontime,$donebuttonextras); |
&add_countdown_timer($currdisp,$donebuttontime,$donebuttonextras); |
} |
} |
} |
} |
|
my $pagebuttonshide; |
|
if (keys(%buttonshide)) { |
|
my %uniquebuttonhide; |
|
foreach my $item (values(%buttonshide)) { |
|
if (exists($uniquebuttonhide{$item})) { |
|
$uniquebuttonhide{$item} ++; |
|
} else { |
|
$uniquebuttonhide{$item} = 1; |
|
} |
|
} |
|
if (keys(%uniquebuttonhide) == 1) { |
|
if (lc((keys(%uniquebuttonhide))[0]) eq 'yes') { |
|
$pagebuttonshide = 'yes'; |
|
} |
|
} |
|
} |
# ------------------------------------------------------------------ Start body |
# ------------------------------------------------------------------ Start body |
$r->print(&Apache::loncommon::start_page(undef,$allscript, |
$r->print(&Apache::loncommon::start_page(undef,$allscript, |
{'force_register' => 1, |
{'force_register' => 1, |
'bgcolor' => '#ffffff',})); |
'bgcolor' => '#ffffff', |
|
'hide_buttons' => $pagebuttonshide})); |
# ------------------------------------------------------------------ Start form |
# ------------------------------------------------------------------ Start form |
if ($nforms) { |
if ($nforms) { |
my $fmtag = '<form name="lonhomework" method="post" enctype="multipart/form-data"'; |
my $fmtag = '<form name="lonhomework" method="post" enctype="multipart/form-data"'; |
Line 725 ENDEXT
|
Line 746 ENDEXT
|
my $avespan=$lcm/($#colcont+1); |
my $avespan=$lcm/($#colcont+1); |
for ($j=0;$j<=$#colcont;$j++) { |
for ($j=0;$j<=$#colcont;$j++) { |
my $rid=$colcont[$j]; |
my $rid=$colcont[$j]; |
my $metainfo =&get_buttons(\%hash,$rid).'<br />'; |
my $metainfo =&get_buttons(\%hash,$rid,\%buttonshide).'<br />'; |
unless (($target eq 'tex') || ($target eq 'tex_answer')) { |
unless (($target eq 'tex') || ($target eq 'tex_answer')) { |
$r->print('<td colspan="'.$avespan.'"'); |
$r->print('<td colspan="'.$avespan.'"'); |
} |
} |
Line 853 ENDEXT
|
Line 874 ENDEXT
|
} |
} |
|
|
sub get_buttons { |
sub get_buttons { |
my ($hash,$rid) = @_; |
my ($hash,$rid,$buttonshide) = @_; |
|
|
my $metainfo = ''; |
my $metainfo = ''; |
my $esrc=&Apache::lonnet::declutter($hash->{'src_'.$rid}); |
my $esrc=&Apache::lonnet::declutter($hash->{'src_'.$rid}); |
Line 862 sub get_buttons {
|
Line 883 sub get_buttons {
|
$resid, |
$resid, |
$hash->{'src_'.$rid}); |
$hash->{'src_'.$rid}); |
unless ($env{'request.role.adv'}) { |
unless ($env{'request.role.adv'}) { |
if (&Apache::lonnet::EXT('resource.0.buttonshide',$symb)) { |
if ($buttonshide->{$symb} eq 'yes') { |
return; |
return; |
} |
} |
} |
} |
Line 930 sub get_buttons {
|
Line 951 sub get_buttons {
|
my ($cfile,$home,$switchserver,$forceedit,$forceview) = |
my ($cfile,$home,$switchserver,$forceedit,$forceview) = |
&Apache::lonnet::can_edit_resource($file,$cnum,$cdom,$hash->{'src_'.$rid},$symb); |
&Apache::lonnet::can_edit_resource($file,$cnum,$cdom,$hash->{'src_'.$rid},$symb); |
if ($cfile ne '') { |
if ($cfile ne '') { |
|
my $hostname = $r->hostname(); |
my $jscall = &Apache::lonhtmlcommon::jump_to_editres($cfile,$home,$switchserver, |
my $jscall = &Apache::lonhtmlcommon::jump_to_editres($cfile,$home,$switchserver, |
$forceedit,1,$symb,undef, |
$forceedit,1,$symb,undef, |
&escape($env{'form.title'})); |
&escape($env{'form.title'}), |
|
$hostname); |
if ($jscall) { |
if ($jscall) { |
my $icon = 'pcstr.png'; |
my $icon = 'pcstr.png'; |
my $label = &mt('Edit'); |
my $label = &mt('Edit'); |
Line 962 sub add_countdown_timer {
|
Line 985 sub add_countdown_timer {
|
$type = $donebuttonextras->{'type'}; |
$type = $donebuttonextras->{'type'}; |
} else { |
} else { |
$donebuttontext = &mt('Done'); |
$donebuttontext = &mt('Done'); |
|
$type = 'map'; |
} |
} |
$donebutton = |
$donebutton = |
&Apache::lonmenu::done_button_js($type,'','',$proctor,$donebuttontext); |
&Apache::lonmenu::done_button_js($type,'','',$proctor,$donebuttontext); |