Diff for /loncom/homework/functionplotresponse.pm between versions 1.13 and 1.14

version 1.13, 2010/10/10 00:14:15 version 1.14, 2010/10/17 22:32:19
Line 224  sub axes_script { Line 224  sub axes_script {
 ENDAXESSCRIPT  ENDAXESSCRIPT
 }  }
   
   sub axes_label {
       my ($id,$xlabel,$ylabel)=@_;
       unless ($xlabel || $ylabel) { return ''; }
       my $return='document.ggbApplet_'.$id.'.evalCommand("topRight=Corner[3]");';
       if ($xlabel) {
          $return.=(<<ENDXAXISLABELSCRIPT);
   document.ggbApplet_$id.evalCommand("Xlabel=(x(topRight)-AxisStepX[],AxisStepY[]/6)");
   document.ggbApplet_$id.setVisible("Xlabel",false);
   document.ggbApplet_$id.evalCommand("Text[\\"$xlabel\\", Xlabel]");
   ENDXAXISLABELSCRIPT
       }
       if ($ylabel) {
          $return.=(<<ENDYAXISLABELSCRIPT);
   document.ggbApplet_$id.evalCommand("Ylabel=(AxisStepX[]/6,y(topRight)-AxisStepY[]/3)");
   document.ggbApplet_$id.setVisible("Ylabel",false);
   document.ggbApplet_$id.evalCommand("Text[\\"$ylabel\\", Ylabel]");
   ENDYAXISLABELSCRIPT
       }
       return $return;
   }
   
 sub plot_script {  sub plot_script {
    my ($id,$function,$fixed)=@_;     my ($id,$function,$fixed)=@_;
    if ($fixed) {     if ($fixed) {
 # Use stupid trick to nail this to a location  # Use stupid trick to nail this to a location
   # Oddly, it seems like only one plot cannot be nailed to a location
   # Non-nailed-down plots apparently get overwritten
       return (<<ENDPLOTSCRIPT);        return (<<ENDPLOTSCRIPT);
             document.ggbApplet_$id.evalCommand("a=1");              document.ggbApplet_$id.evalCommand("a=1");
             document.ggbApplet_$id.setVisible("a",false);              document.ggbApplet_$id.setVisible("a",false);
Line 367  sub start_spline { Line 390  sub start_spline {
    } elsif ($target eq 'edit') {     } elsif ($target eq 'edit') {
         $result=&Apache::edit::tag_start($target,$token,'Spline').          $result=&Apache::edit::tag_start($target,$token,'Spline').
              &Apache::edit::text_arg('Label:','label',               &Apache::edit::text_arg('Label:','label',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::select_arg('Order:','order',               &Apache::edit::select_arg('Order:','order',
                                   ['2','3','4','5','6','7','8','9'],$token).                                    ['2','3','4','5','6','7','8','9'],$token).'&nbsp;'.
              &Apache::edit::text_arg('Initial x-value:','initx',               &Apache::edit::text_arg('Initial x-value:','initx',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::text_arg('Initial y-value:','inity',               &Apache::edit::text_arg('Initial y-value:','inity',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::text_arg('Scale x:','scalex',               &Apache::edit::text_arg('Scale x:','scalex',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::text_arg('Scale y:','scaley',               &Apache::edit::text_arg('Scale y:','scaley',
                                      $token,'4').                                       $token,'4').
              &Apache::edit::end_row();               &Apache::edit::end_row();
Line 463  sub start_functionplotresponse { Line 486  sub start_functionplotresponse {
   my $xaxisvisible=(&Apache::lonxml::get_param('xaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');    my $xaxisvisible=(&Apache::lonxml::get_param('xaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
   my $yaxisvisible=(&Apache::lonxml::get_param('yaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');    my $yaxisvisible=(&Apache::lonxml::get_param('yaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
   my $gridvisible=(&Apache::lonxml::get_param('gridvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');    my $gridvisible=(&Apache::lonxml::get_param('gridvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
     my $xlabel=&Apache::lonxml::get_param('xlabel',$parstack,$safeeval);
     my $ylabel=&Apache::lonxml::get_param('ylabel',$parstack,$safeeval);
   if ($target eq 'edit') {    if ($target eq 'edit') {
     $result.=&Apache::edit::start_table($token)      $result.=&Apache::edit::start_table($token)
        .'<tr><td><span class="LC_nobreak">'.&mt('Function Plot Question').'</span></td>'         .'<tr><td><span class="LC_nobreak">'.&mt('Function Plot Question').'</span></td>'
Line 473  sub start_functionplotresponse { Line 498  sub start_functionplotresponse {
        .&Apache::edit::end_row()         .&Apache::edit::end_row()
        .&Apache::edit::start_spanning_row()         .&Apache::edit::start_spanning_row()
        ."\n";         ."\n";
     $result.=&Apache::edit::text_arg('Minimum x-value:','xmin',      $result.=&Apache::edit::text_arg('Label x-axis:','xlabel',
                                      $token,'4').                                       $token,'6').'&nbsp;'.
                &Apache::edit::text_arg('Minimum x-value:','xmin',
                                        $token,'4').'&nbsp;'.
              &Apache::edit::text_arg('Maximum x-value:','xmax',               &Apache::edit::text_arg('Maximum x-value:','xmax',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::select_arg('x-axis visible:','xaxisvisible',               &Apache::edit::select_arg('x-axis visible:','xaxisvisible',
                                   ['yes','no'],$token).                                    ['yes','no'],$token).'&nbsp;&nbsp;'.
                &Apache::edit::text_arg('Label y-axis:','ylabel',
                                        $token,'6').'&nbsp;'.
              &Apache::edit::text_arg('Minimum y-value:','ymin',               &Apache::edit::text_arg('Minimum y-value:','ymin',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::text_arg('Maximum y-value:','ymax',               &Apache::edit::text_arg('Maximum y-value:','ymax',
                                      $token,'4').                                       $token,'4').'&nbsp;'.
              &Apache::edit::select_arg('y-axis visible:','yaxisvisible',               &Apache::edit::select_arg('y-axis visible:','yaxisvisible',
                                   ['yes','no'],$token).                                    ['yes','no'],$token).'&nbsp;&nbsp;'.
              &Apache::edit::select_arg('Grid visible:','gridvisible',               &Apache::edit::select_arg('Grid visible:','gridvisible',
                                   ['yes','no'],$token).                                    ['yes','no'],$token).
              &Apache::edit::end_row().&Apache::edit::start_spanning_row();               &Apache::edit::end_row().&Apache::edit::start_spanning_row();
   } elsif ($target eq 'modified') {    } elsif ($target eq 'modified') {
     my $constructtag=&Apache::edit::get_new_args($token,$parstack,      my $constructtag=&Apache::edit::get_new_args($token,$parstack,
                                                  $safeeval,'xmin','xmax','ymin','ymax',                                                   $safeeval,'xlabel','xmin','xmax','ylabel','ymin','ymax',
                                                            'xaxisvisible','yaxisvisible','gridvisible');                                                             'xaxisvisible','yaxisvisible','gridvisible');
     if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); }      if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); }
   
Line 503  sub start_functionplotresponse { Line 532  sub start_functionplotresponse {
      $result.=&start_init_script($internalid);       $result.=&start_init_script($internalid);
 # put the axis commands inside  # put the axis commands inside
      $result.=&axes_script($internalid,$xmin,$xmax,$ymin,$ymax,$xaxisvisible,$yaxisvisible,$gridvisible);       $result.=&axes_script($internalid,$xmin,$xmax,$ymin,$ymax,$xaxisvisible,$yaxisvisible,$gridvisible);
        $result.=&axes_label($internalid,$xlabel,$ylabel);
 # init script is left open  # init script is left open
   }    }
   return $result;    return $result;

Removed from v.1.13  
changed lines
  Added in v.1.14


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>