Question Text
-
+
@@ -82,25 +81,48 @@ ENDQUESTION
sub hint {
my $text=$qparms{$prefix.'hinttext'};
+ my $ht=&mt('Hint Text');
+ my $spell_link=
+ &Apache::lonhtmlcommon::spelllink('simpleedit','hinttext');
return (<
-Hint Text
-
+
ENDHINT
}
+sub script {
+ my $text=$qparms{$prefix.'numericalscript'};
+ my $ht=&mt('Scripting (optional)');
+ return (<
+$ht
+
+ |
+
+
+ENDSCRIPT
+}
+
sub foil {
my $number=shift;
- my %values='';
+ my (%values,%defaultvalues,%customvalues);
+ %defaultvalues = &Apache::lonlocal::texthash(
+ 'unused' => 'Not shown, not used'
+ );
if ($qtype eq 'radio') {
- %values=('true' => 'True', 'false' => 'False');
+ %customvalues = &Apache::lonlocal::texthash(
+ 'true' => 'True',
+ 'false' => 'False'
+ );
} elsif ($qtype eq 'option') {
- %values=&evaloptionhash($qparms{$prefix.'options'});
+ %customvalues=&evaloptionhash($qparms{$prefix.'options'});
}
- $values{'unused'}='Not shown, not used';
+ %values = (%defaultvalues,%customvalues);
my $value=$qparms{$prefix.'value'.$number};
unless (defined($value)) { $value='unused'; }
unless ($values{$value}) { $value='unused'; }
@@ -112,23 +134,50 @@ sub foil {
unless ($positions{$position}) {
$position='random';
}
- my $selectvalue=&Apache::loncommon::select_form
- ($value,'value'.$number,%values);
- my $selectposition=&Apache::loncommon::select_form
- ($position,'position'.$number,%positions);
+ my $selectvalue=&Apache::loncommon::select_form(
+ $value,
+ 'value'.$number,
+ \%values);
+ my $selectposition=&Apache::loncommon::select_form(
+ $position,
+ 'position'.$number,
+ {&Apache::lonlocal::texthash(%positions)});
my $text=$qparms{$prefix.'text'.$number};
+ my %lt=&Apache::lonlocal::texthash('foil' => 'Foil',
+ 'value' => 'Value',
+ 'pos' => 'Position',
+ 'text' => 'Text');
+
+ my $spell_link=
+ &Apache::lonhtmlcommon::spelllink('simpleedit',"text$number");
return (<
-Foil |
-Value: $selectvalue | Position: $selectposition |
-Text:
-
+
+$lt{'foil'} |
+$lt{'value'}: $selectvalue | $lt{'pos'}: $selectposition |
+$lt{'text'}:
+
+ $spell_link
|
ENDFOIL
}
+sub get_parent_uri {
+ my ($cur_symb)=@_;
+ my $navmap = Apache::lonnavmaps::navmap->new();
+ if (defined($navmap)) {
+ my $it = $navmap->getIterator(undef, undef, undef, 1);
+ while ( my $res=$it->next()) {
+ if (ref($res) && $res->symb() eq $cur_symb) { last; }
+ }
+ my ($src,$symb,$anchor)=&Apache::lonnavmaps::getLinkForResource($it->getStack());
+ if (defined($anchor)) { $anchor='#'.$anchor; }
+ return $src.'?symb='.&escape($symb).$anchor;
+ }
+ return;
+}
+
sub handler {
my $r = shift;
@@ -139,7 +188,7 @@ sub handler {
}
# -------------------------------------------------------------------- Allowed?
- unless (&Apache::lonnet::allowed('mdc',$ENV{'request.course.id'})) {
+ unless (&Apache::lonnet::allowed('mdc',$env{'request.course.id'})) {
return HTTP_NOT_ACCEPTABLE;
}
# ----------------------------------------------------------------- Send header
@@ -148,74 +197,156 @@ sub handler {
# ----------------------------------------------------- Figure out where we are
my $uri=$r->uri;
$uri=~s/\/smpedit$//;
- my $symb=&Apache::lonnet::symbread($uri);
+ my $symb=&Apache::lonnet::symbread();
# ------------------------------------------------ Prefix for everything stored
- $prefix=$ENV{'request.course.id'}.'.'.$symb.'.0.';
+ $prefix=$env{'request.course.id'}.'.'.$symb.'.0.';
+#------------------------------------------------- Prefix for storing weight of Problem Parts
+ my $weightprefix=$env{'request.course.id'}.'.'.$symb.'.';
+
# ---------------------------------------------------------- Anything to store?
-
- if (($symb) && (defined($ENV{'form.questiontype'}))) {
+ my $storeresult;
+ if (($symb) && (defined($env{'form.questiontype'}))) {
my %storecontent=();
undef %storecontent;
- if ($ENV{'form.questiontype'} eq 'option') {
- my %curoptions=&evaloptionhash($ENV{'form.options'});
- if ($ENV{'form.delopt'}) {
- delete $curoptions{$ENV{'form.delopt'}};
+ if ($env{'form.questiontype'} eq 'option') {
+ my %curoptions=&evaloptionhash($env{'form.options'});
+ if ($env{'form.delopt'}) {
+ delete $curoptions{$env{'form.delopt'}};
}
- if ($ENV{'form.newopt'}) {
- $ENV{'form.newopt'}=~s/\'/\\\'/g;
- $curoptions{$ENV{'form.newopt'}}=$ENV{'form.newopt'};
+ if ($env{'form.newopt'}) {
+ $env{'form.newopt'}=~s/\'/\\\'/g;
+ $curoptions{$env{'form.newopt'}}=$env{'form.newopt'};
}
- $ENV{'form.options'}="('".join("','",keys %curoptions)."')";
+ $env{'form.options'}="('".join("','",keys(%curoptions))."')";
}
- $ENV{'form.hiddenparts'}='!'.$ENV{'form.questiontype'};
- foreach (keys %ENV) {
- if ($_=~/^form\.(\w+)$/) {
+ $env{'form.hiddenparts'}='!'.$env{'form.questiontype'};
+ foreach my $envkey (keys(%env)) {
+ if ($envkey=~/^form\.(\w+)$/) {
my $parm=$1;
- $storecontent{$prefix.$parm}=$ENV{'form.'.$parm};
+ $storecontent{$prefix.$parm}=$env{'form.'.$parm};
$storecontent{$prefix.$parm}=~s/^\s+//s;
$storecontent{$prefix.$parm}=~s/\s+$//s;
}
}
+# ---------------------------------------------------- Set weights of hidden parts to zero
+# ------------------------------------------------------ and used part to 1
+ $storecontent{$weightprefix.'essay.weight'}=0;
+ $storecontent{$weightprefix.'numerical.weight'}=0;
+ $storecontent{$weightprefix.'option.weight'}=0;
+ $storecontent{$weightprefix.'radio.weight'}=0;
+ $storecontent{$weightprefix.'string.weight'}=0;
+ $storecontent{$weightprefix.$env{'form.questiontype'}.'.weight'}=1;
+
+
my $reply=&Apache::lonnet::cput
('resourcedata',\%storecontent,
- $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
- $ENV{'course.'.$ENV{'request.course.id'}.'.num'});
+ $env{'course.'.$env{'request.course.id'}.'.domain'},
+ $env{'course.'.$env{'request.course.id'}.'.num'});
+ &Apache::lonnet::devalidatecourseresdata(
+ $env{'course.'.$env{'request.course.id'}.'.num'},
+ $env{'course.'.$env{'request.course.id'}.'.domain'});
+ if ($reply eq 'ok') {
+ if ($env{'form.forceview'}) {
+ my $dest = &get_parent_uri($symb);
+ if ($dest) {
+ $r->internal_redirect($dest);
+ return OK;
+ }
+ }
+ } else {
+ $storeresult = $reply;
+ }
}
# ------------------------------------------------------------------- Read Data
%qparms=&Apache::lonnet::dump('resourcedata',
- $ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
- $ENV{'course.'.$ENV{'request.course.id'}.'.num'},
- $ENV{'request.course.id'}.'.'.$symb);
+ $env{'course.'.$env{'request.course.id'}.'.domain'},
+ $env{'course.'.$env{'request.course.id'}.'.num'},
+ $env{'request.course.id'}.'.'.$symb);
+
+ my $js = <<"ENDJS";
+
+
+
+ENDJS
# ------------------------------------------------------------ Print the screen
- $r->print(<
-
-The LearningOnline Network with CAPA
-ENDDOCUMENT
- $r->print(&Apache::loncommon::bodytag('Simple Problem Editor'));
+ my $spell_header=&Apache::lonhtmlcommon::spellheader();
+ $r->print(&Apache::loncommon::start_page('Simple Problem Editor',
+ $spell_header.$js));
if ($symb) {
- $r->print(''.&Apache::lonnet::gettitle($symb).'');
- $r->print(''.
- &rawrendering($r,$uri).
- ' |
');
- $r->print(' | | |