--- loncom/homework/edit.pm 2003/05/09 22:10:12 1.50 +++ loncom/homework/edit.pm 2003/09/08 21:10:53 1.61 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # edit mode helpers # -# $Id: edit.pm,v 1.50 2003/05/09 22:10:12 albertel Exp $ +# $Id: edit.pm,v 1.61 2003/09/08 21:10:53 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -63,10 +63,17 @@ sub tag_start { &deletelist($target,$token) ."</td> <td>". - &insertlist($target,$token).&end_row().&start_spanning_row(); + &insertlist($target,$token); #<td>". # &movebuttons($target,$token). # "</tr><tr><td colspan=\"3\">\n"; + my @help;# = Apache::lonxml::helpinfo($token); + if ($help[0]) { + $result .= '<td align="right" valign="top">' . + Apache::loncommon::help_open_topic(@help) . + '</td>'; + } else { $result .= "<td> </td>"; } + $result .= &end_row().&start_spanning_row(); } return $result; } @@ -75,13 +82,7 @@ sub tag_end { my ($target,$token,$description) = @_; my $result=''; if ($target eq 'edit') { - my $tag=$token->[1]; - if (!defined($description)) { - $result.="</td></tr><tr><td></$tag></td><td colspan=\"2\"> </td>"; - } else { - if ($description ne '') { $result.="</td></tr><tr><td>$description</td><td colspan=\"2\"> </td>"; } - } - $result.="</tr>".&end_table()."\n"; + $result.="</td></tr>".&end_table()."\n"; } return $result; } @@ -125,7 +126,7 @@ sub end_table { return $result; } -sub start_spanning_row { return '<tr><td colspan="3" bgcolor="#DDDDDD">';} +sub start_spanning_row { return '<tr><td colspan="4" bgcolor="#DDDDDD">';} sub start_row { return '<tr><td bgcolor="#DDDDDD">'; } sub end_row { return '</td></tr>'; } @@ -310,6 +311,16 @@ sub insert_essayresponse { </essayresponse>'; } +sub insert_imageresponse { + return ' +<imageresponse max="1"> + <foilgroup> + </foilgroup> + <hintgroup> + </hintgroup> +</imageresponse>'; +} + sub insert_optionresponse { return ' <optionresponse max="10"> @@ -404,9 +415,11 @@ sub textarea_sizes { my ($data)=@_; my $count=0; my $maxlength=-1; - foreach (split ("\n", $$data)) { $count++; - if (length($_) > $maxlength) { $maxlength = length($_); } - } + foreach (split ("\n", $$data)) { + $count+=int(length($_)/79); + $count++; + if (length($_) > $maxlength) { $maxlength = length($_); } + } my $rows = $count; my $cols = $maxlength; return ($rows,$cols); @@ -452,17 +465,21 @@ sub modifiedfield { # Returns a 1 if the token has been modified and you should rebuild the tag # side-effects, will modify the $token if new values are found sub get_new_args { - my ($token,$parstack,$safeeval,@args)=@_; - my $rebuild=0; - foreach my $arg (@args) { + my ($token,$parstack,$safeeval,@args)=@_; + my $rebuild=0; + foreach my $arg (@args) { #just want the string that it was set to my $value=$token->[2]->{$arg}; my $element=&html_element_name($arg); my $newvalue=$ENV{"form.$element"}; &Apache::lonxml::debug(" for:$arg: cur is :$value: new is :$newvalue:"); - if ($value ne $newvalue) { - $token->[2]->{$arg}=$newvalue; - $rebuild=1; + if (defined($newvalue) && $value ne $newvalue) { + if (ref($newvalue) eq 'ARRAY') { + $token->[2]->{$arg}=join(',',@$newvalue); + } else { + $token->[2]->{$arg}=$newvalue; + } + $rebuild=1; } } return $rebuild; @@ -505,6 +522,36 @@ sub hidden_arg { return $result; } +sub checked_arg { + my ($description,$name,$list,$token) = @_; + my $result; + my $optionlist=""; + my $allselected=$token->[2]{$name}; + $result=$description; + foreach my $option (@$list) { + my ($value,$text); + if ( ref($option) eq 'ARRAY') { + $value='value="'.$$option[0].'"'; + $text=$$option[1]; + $option=$$option[0]; + } else { + $text=$option; + $value='value="'.$option.'"'; + } + $result.="<nobr><input type='checkbox' $value name='". + &html_element_name($name)."'"; + foreach my $selected (split(/,/,$allselected)) { + &Apache::lonxml::error("wha $selected $option<br />"); + if ( $selected eq $option ) { + $result.=" checked='on' "; + last; + } + } + $result.=" />$text</nobr>\n"; + } + return $result; +} + sub text_arg { my ($description,$name,$token,$size) = @_; my $result; @@ -512,7 +559,7 @@ sub text_arg { my $arg=$token->[2]{$name}; $result=$description.' <input name="'.&html_element_name($name). '" type="text" value="'.$arg.'" size="'.$size.'" />'; - return $result; + return '<nobr>'.$result.'</nobr>'; } sub select_arg { @@ -534,10 +581,10 @@ sub select_arg { $optionlist.="<option $value >$option</option>\n"; } } - $result.=$description.' <select name="'.&html_element_name($name). - '"> + $result.='<nobr>'.$description.' <select name="'. + &html_element_name($name).'"> '.$optionlist.' - </select>'; + </select></nobr>'; return $result; } @@ -562,16 +609,36 @@ sub select_or_text_arg { $optionlist.="<option $value>$option</option>\n"; } } - $optionlist.="<option value=\"TYPEDINVALUE\">Type in value</option>\n"; - if (($found) || (!$selected)) { - $result.=$description.' <select name="'.&html_element_name($name) - .'"> - '.$optionlist.' - </select>'; - } else { - $result.=&text_arg($description,$name,$token,$size); - } - return $result; + $optionlist.="<option value=\"TYPEDINVALUE\"". + ((!$found)?' selected="on"':''). + ">Type in value</option>\n"; +# + my $element=&html_element_name($name); + my $selectelement='select_list_'.$element; + my $typeinelement='type_in_'.$element; + my $typeinvalue=($found?'':$selected); +# + my $hiddenvalue='this.form.'.$element.'.value'; + my $selectedindex='this.form.'.$selectelement.'.selectedIndex'; + my $selectedvalue='this.form.'.$selectelement. + '.options['.$selectedindex.'].value'; + my $typedinvalue='this.form.'.$typeinelement.'.value'; + my $selecttypeinindex='this.form.'.$selectelement.'.options.length'; +# + return (<<ENDSELECTORTYPE); +<nobr> +$description + <select name="$selectelement" +onChange="if ($selectedvalue!='TYPEDINVALUE') { $hiddenvalue=$selectedvalue; $typedinvalue=''; }" +$optionlist +</select> +<input type="text" size="$size" name="$typeinelement" + value="$typeinvalue" +onChange="$hiddenvalue=$typedinvalue;" +onFocus="$selectedindex=$selecttypeinindex-1;" /> +<input type="hidden" name="$element" value="$selected" /> +</nobr> +ENDSELECTORTYPE } #----------------------------------------------------- image coordinates @@ -627,7 +694,7 @@ sub entercoordpair { $formwidth='&formwidth='.$width.'_'.$Apache::edit::bgimgsrccurdepth; } my $result = <<"ENDBUTTON"; -<a href="/cgi-bin/imagechoice.pl?mode=pair&formname=$form&file=$bgfile$formheight$formwidth" +<a href="/cgi-bin/imagechoice.pl?mode=pair&formname=$form&file=$bgfile$formheight$formwidth&formcoord=$element" target="imagechoice">Click Coordinate Pair</a> ENDBUTTON return $result; @@ -645,7 +712,7 @@ sub browse { $Apache::lonxml::curdepth); } my $result = <<"ENDBUTTON"; -<a href=\"javascript:openbrowser('$form','$element')\"\>Browse</a> +<a href=\"javascript:openbrowser('$form','$element')\"\>Select</a> ENDBUTTON return $result; }