Diff for /loncom/interface/courseprefs.pm between versions 1.121 and 1.122

version 1.121, 2023/06/01 20:04:36 version 1.122, 2023/06/03 02:29:57
Line 1661  sub process_linkprot { Line 1661  sub process_linkprot {
         } elsif (exists($env{$urlparamname})) {          } elsif (exists($env{$urlparamname})) {
             $env{$urlparamname} = '';              $env{$urlparamname} = '';
         }          }
           my $passback = 'form.linkprot_passback_'.$idx;
           my $passbackparamname = 'form.linkprot_passbackformat_'.$idx;
           if ($env{$passback} == 1) {
               unless ($env{$passbackparamname} =~ /^1\.(0|1)$/) {
                   $env{$passbackparamname} = '';
               }
           } elsif (exists($env{$passbackparamname})) {
               $env{$passbackparamname} = '';
           }
         unless ($idx eq 'add') {          unless ($idx eq 'add') {
             if ((!$current{'returnurl'} && ($env{$urlparamname} ne '')) ||              if ((!$current{'returnurl'} && ($env{$urlparamname} ne '')) ||
                 ($current{'returnurl'} && ($env{$urlparamname} eq ''))) {                  ($current{'returnurl'} && ($env{$urlparamname} eq ''))) {
                 $haschanges{$itemid} = 1;                  $haschanges{$itemid} = 1;
             }              }
               if ((!$current{'passback'} && ($env{$passbackparamname} ne '')) ||
                   ($current{'passback'} && ($env{$passbackparamname} eq ''))) {
                   $haschanges{$itemid} = 1;
               }
         }          }
         if ($env{$urlparamname} ne '') {          if ($env{$passbackparamname} ne '') {
             $linkprot{$itemid}{'returnurl'} = $env{$urlparamname};              $linkprot{$itemid}{'passback'} = 1;
               $linkprot{$itemid}{'passbackformat'} = $env{$passbackparamname};
         }          }
         if ($ltiauth) {          if ($ltiauth) {
             my $reqitem = 'form.linkprot_requser_'.$idx;              my $reqitem = 'form.linkprot_requser_'.$idx;
Line 3088  sub store_linkprot { Line 3102  sub store_linkprot {
                     my %values = %{$changes->{$id}};                      my %values = %{$changes->{$id}};
                     my %desc = &linkprot_names();                      my %desc = &linkprot_names();
                     my $display;                      my $display;
                     foreach my $title ('name','lifetime','version','key','secret','returnurl') {                      foreach my $title ('name','lifetime','version','key','secret','returnurl','passbackformat') {
                         if (($title eq 'key') || ($title eq 'secret')) {                          if (($title eq 'key') || ($title eq 'secret')) {
                             if (ref($ltienc{$id}) eq 'HASH') {                              if (ref($ltienc{$id}) eq 'HASH') {
                                 if (exists($ltienc{$id}{$title})) {                                  if (exists($ltienc{$id}{$title})) {
Line 3108  sub store_linkprot { Line 3122  sub store_linkprot {
                             if ($values{$title}) {                              if ($values{$title}) {
                                 $display .= &mt('Return URL parameter').': '.$values{$title}.', ';                                   $display .= &mt('Return URL parameter').': '.$values{$title}.', '; 
                             }                              }
                           } elsif ($title eq 'passbackformat') {
                               if ($values{$title} eq '1.0') {
                                   $display .= &mt('Can return grades to Launcher with Outcomes Service 1.0 format').', ';
                               } elsif ($values{$title} eq '1.1') {
                                   $display .= &mt('Can return grades to Launcher with Outcomes Service 1.1 format').', ';
                               }
                         } else {                          } else {
                             $display .= $desc{$title}.': '.$values{$title}.', ';                              $display .= $desc{$title}.': '.$values{$title}.', ';
                         }                          }
Line 7316  sub print_linkprotection { Line 7336  sub print_linkprotection {
                     '<tr '.$css_class.'><td><span class="LC_nobreak">'.                      '<tr '.$css_class.'><td><span class="LC_nobreak">'.
                     '<label><input type="checkbox" name="linkprot_del" value="'.$i.'"'.$disabled.' />'.                      '<label><input type="checkbox" name="linkprot_del" value="'.$i.'"'.$disabled.' />'.
                     &mt('Delete?').'</label></span></td><td>';                      &mt('Delete?').'</label></span></td><td>';
                 my ($usersty,$onclickrequser,%checkedrequser,$onclickreturnurl,%checkedreturnurl);                  my ($usersty,$onclickrequser,%checkedrequser,$onclickreturnurl,%checkedreturnurl,
                       $onclickpassback,%checkedpassback,$passbacksty,%checkedpassbackfmt);
                   $passbacksty = 'none';
                   $onclickpassback = ' onclick="toggleLinkProtExtra(this.form,'."'passback','passbackparam','1','inline-block','$i'".');"';
                   %checkedpassback = (
                       'no' => ' checked="checked"',
                       'yes' => '',
                   );                
                   %checkedpassbackfmt = (
                       '1p1' => ' checked="checked"',
                       '1p0' => '',
                   );
                   if ($values{'passback'} ne '') {
                       $passbacksty = 'inline-block';
                       $checkedpassback{'yes'} = ' checked="checked"';
                       $checkedpassback{'no'} = '';
                       if ($values{'passbackformat'} eq '1.0') {
                           $checkedpassbackfmt{'1p0'} = ' checked="checked"';
                           $checkedpassbackfmt{'1p1'} = '';
                       }
                   }
                 if ($ltiauth) {                  if ($ltiauth) {
                     $usersty = 'display:none';                      $usersty = 'display:none';
                     $onclickrequser = ' onclick="toggleLinkProtExtra(this.form,'."'requser','optional','1','block','$i'".');"';                      $onclickrequser = ' onclick="toggleLinkProtExtra(this.form,'."'requser','optional','1','block','$i'".');"';
Line 7405  sub print_linkprotection { Line 7445  sub print_linkprotection {
                     }                      }
                 }                  }
                 $datatable .= '<br /><br />'.                  $datatable .= '<br /><br />'.
                                 '<span class="LC_nobreak">'.$desc{'passback'}.'?'.
                                 '<label><input type="radio" name="linkprot_passback_'.$i.'" value="0"'.
                                 $onclickpassback.$checkedpassback{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.
                                 '<label><input type="radio" name="linkprot_passback_'.$i.'" value="1"'.
                                 $onclickpassback.$checkedpassback{'yes'}.$disabled.' />'.&mt('Yes').'</label></span><br />'.
                                 '<div id="linkprot_passbackparam_'.$i.'" class="LC_floatleft" style="display:'.$passbacksty.'" />'.
                                 '<span class="LC_nobreak">'.&mt('Grade format').
                                 '<label><input type="radio" name="linkprot_passbackformat_'.$i.'" value="1.1"'.$checkedpassbackfmt{'1p1'}.' />'.
                                 &mt('Outcomes Service (1.1)').'</label>'.('&nbsp;'x2).
                                 '<label><input type="radio" name="linkprot_passbackformat_'.$i.'" value="1.0"'.$checkedpassbackfmt{'1p0'}.'/>'.
                                 &mt('Outcomes Extension (1.0)').'</label></span></div>'.
                                 '<div style="padding:0;clear:both;margin:0;border:0"></div>'.
                                 '<br />'.
                               '<span class="LC_nobreak">'.$desc{'returnurl'}.'?'.                                '<span class="LC_nobreak">'.$desc{'returnurl'}.'?'.
                               '<label><input type="radio" name="linkprot_returnurl_'.$i.'" value="0"'.                                '<label><input type="radio" name="linkprot_returnurl_'.$i.'" value="0"'.
                               $onclickreturnurl.$checkedreturnurl{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.                                $onclickreturnurl.$checkedreturnurl{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.
Line 7435  sub print_linkprotection { Line 7488  sub print_linkprotection {
                   '<input type="hidden" name="linkprot_maxnum" value="'.$next.'" />'."\n".                    '<input type="hidden" name="linkprot_maxnum" value="'.$next.'" />'."\n".
                   '<input type="checkbox" name="linkprot_add" value="1"'.$disabled.' />'.&mt('Add').'</span></td>'."\n".                    '<input type="checkbox" name="linkprot_add" value="1"'.$disabled.' />'.&mt('Add').'</span></td>'."\n".
                   '<td width="100%">';                    '<td width="100%">';
     my ($usersty,$onclickrequser,%checkedrequser,$onclickreturnurl,%checkedreturnurl);      my ($usersty,$onclickrequser,%checkedrequser,$onclickreturnurl,%checkedreturnurl,
          $onclickpassback,%checkedpassback,%checkedpassbackfmt);
     if ($ltiauth) {      if ($ltiauth) {
         $usersty = 'display:none';          $usersty = 'display:none';
         $onclickrequser = ' onclick="toggleLinkProtExtra(this.form,'."'requser','optional','1','block','add'".');"';          $onclickrequser = ' onclick="toggleLinkProtExtra(this.form,'."'requser','optional','1','block','add'".');"';
Line 7445  sub print_linkprotection { Line 7499  sub print_linkprotection {
         );          );
         $datatable .= '<fieldset><legend>'.$lt{'requ'}.'</legend>';          $datatable .= '<fieldset><legend>'.$lt{'requ'}.'</legend>';
     }      }
       $onclickpassback = ' onclick="toggleLinkProtExtra(this.form,'."'passback','passbackparam','1','inline-block','add'".');"';
       %checkedpassback = (
           'no' => ' checked="checked"',
           'yes' => '',
       );
       %checkedpassbackfmt = (
           '1p1' => ' checked="checked"',
           '1p0' => '',
       );
     $onclickreturnurl = ' onclick="toggleLinkProtExtra(this.form,'."'returnurl','divurlparam','1','inline-block','add'".');"';      $onclickreturnurl = ' onclick="toggleLinkProtExtra(this.form,'."'returnurl','divurlparam','1','inline-block','add'".');"';
     %checkedreturnurl = (      %checkedreturnurl = (
         no => ' checked="checked"',          no => ' checked="checked"',
Line 7467  sub print_linkprotection { Line 7530  sub print_linkprotection {
                       '<label><input type="checkbox" name="linkprot_visible_add" id="linkprot_visible_add" onclick="if (this.checked) { this.form.linkprot_secret_add.type='."'text'".' } else { this.form.linkprot_secret_add.type='."'password'".' }"'.$disabled.' />'.&mt('Visible input').'</label></span> '."\n";                        '<label><input type="checkbox" name="linkprot_visible_add" id="linkprot_visible_add" onclick="if (this.checked) { this.form.linkprot_secret_add.type='."'text'".' } else { this.form.linkprot_secret_add.type='."'password'".' }"'.$disabled.' />'.&mt('Visible input').'</label></span> '."\n";
     }      }
     $datatable .= '<br /><br />'.      $datatable .= '<br /><br />'.
                     '<span class="LC_nobreak">'.$desc{'passback'}.'?'.
                     '<label><input type="radio" name="linkprot_passback_add" value="0"'.
                     $onclickpassback.$checkedpassback{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.
                     '<label><input type="radio" name="linkprot_passback_add" value="1"'.
                     $onclickpassback.$checkedpassback{'yes'}.$disabled.' />'.&mt('Yes').'</label></span>'.
                     '<br /><div id="linkprot_passbackparam_add" class="LC_floatleft" style="display:none" />'.
                     '<span class="LC_nobreak">'.&mt('Grade format').
                     '<label><input type="radio" name="linkprot_passbackformat_add" value="1.1"'.$checkedpassbackfmt{'1p1'}.$disabled.' />'.
                     &mt('Outcomes Service (1.1)').'</label>'.('&nbsp;'x2).
                     '<label><input type="radio" name="linkprot_passbackformat_add" value="1.0"'.$checkedpassbackfmt{'1p0'}.$disabled.' />'.
                     &mt('Outcomes Extension (1.0)').'</label></span></div>'.
                     '<div style="padding:0;clear:both;margin:0;border:0"></div>'.
                     '<br />'.
                   '<span class="LC_nobreak">'.$desc{'returnurl'}.'?'.                    '<span class="LC_nobreak">'.$desc{'returnurl'}.'?'.
                   '<label><input type="radio" name="linkprot_returnurl_add" value="0"'.                    '<label><input type="radio" name="linkprot_returnurl_add" value="0"'.
                   $onclickreturnurl.$checkedreturnurl{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.                    $onclickreturnurl.$checkedreturnurl{'no'}.$disabled.' />'.&mt('No').'</label>&nbsp;'.
Line 7499  sub linkprot_names { Line 7575  sub linkprot_names {
                                           'lifetime'  => 'Nonce lifetime (s)',                                            'lifetime'  => 'Nonce lifetime (s)',
                                           'name'      => 'Launcher Application',                                            'name'      => 'Launcher Application',
                                           'secret'    => 'Secret',                                            'secret'    => 'Secret',
                                             'passback'  => 'Can return grades to Launcher',
                                           'returnurl' => 'Launcher return URL',                                            'returnurl' => 'Launcher return URL',
                                           'requser'   => 'Use identity',                                            'requser'   => 'Use identity',
                                           'email'     => 'Email address',                                            'email'     => 'Email address',

Removed from v.1.121  
changed lines
  Added in v.1.122


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