Diff for /loncom/interface/courseprefs.pm between versions 1.84 and 1.88

version 1.84, 2017/02/07 15:44:23 version 1.88, 2018/09/01 22:28:55
Line 367  sub handler { Line 367  sub handler {
     my %values=&Apache::lonnet::dump('environment',$cdom,$cnum);      my %values=&Apache::lonnet::dump('environment',$cdom,$cnum);
     my @prefs_order = ('courseinfo','localization','feedback','discussion',      my @prefs_order = ('courseinfo','localization','feedback','discussion',
                        'classlists','appearance','grading','printouts',                         'classlists','appearance','grading','printouts',
                        'spreadsheet','bridgetasks','other');                         'spreadsheet','bridgetasks','lti','other');
   
     my %prefs = (      my %prefs = (
         'courseinfo' =>          'courseinfo' =>
Line 375  sub handler { Line 375  sub handler {
                      help => 'Course_Prefs_General',                       help => 'Course_Prefs_General',
                      ordered => ['owner','co-owners','loncaparev','description',                       ordered => ['owner','co-owners','loncaparev','description',
                                  'clonedfrom','courseid','uniquecode','categories',                                   'clonedfrom','courseid','uniquecode','categories',
                                  'hidefromcat','externalsyllabus','cloners','url',                                   'hidefromcat','syllabus','cloners','url',
                                  'rolenames'],                                   'rolenames'],
                      itemtext => {                       itemtext => {
                                    'owner'            => $lt{'ownr'},                                     'owner'            => $lt{'ownr'},
Line 386  sub handler { Line 386  sub handler {
                                    'categories'       => $lt{'catg'},                                     'categories'       => $lt{'catg'},
                                    'hidefromcat'      => $lt{'excc'},                                     'hidefromcat'      => $lt{'excc'},
                                    'cloners'          => $lt{'clon'},                                      'cloners'          => $lt{'clon'}, 
                                    'externalsyllabus' => 'Syllabus status',                                     'syllabus'         => 'Syllabus status',
                                    'url'              => 'Top Level Map',                                     'url'              => 'Top Level Map',
                                    'rolenames'        => $lt{'rept'},                                     'rolenames'        => $lt{'rept'},
                                    'loncaparev'       => $lt{'lcrv'},                                     'loncaparev'       => $lt{'lcrv'},
Line 530  sub handler { Line 530  sub handler {
                         suppress_embed_prompt => 'Hide upload references prompt if uploading file to portfolio',                          suppress_embed_prompt => 'Hide upload references prompt if uploading file to portfolio',
                                 },                                  },
                   },                    },
           'lti' =>
                     {
                       text => 'LTI provider settings',
                       help => 'Course_Prefs_LTIProvider',
                       ordered => ['lti.override','lti.topmenu','lti.inlinemenu','lti.lcmenu'],
                       itemtext => {
                            'lti.override'   => 'Override domain defaults',
                            'lti.topmenu'    => 'Display LON-CAPA page header',
                            'lti.inlinemenu' => 'Display LON-CAPA inline menu',
                            'lti.lcmenu'     => 'Menu items',
                                   },
                     },
         'other' =>          'other' =>
                   { text => 'Other settings',                    { text => 'Other settings',
                     help => 'Course_Prefs_Other',                      help => 'Course_Prefs_Other',
Line 725  sub print_config_box { Line 737  sub print_config_box {
         $output .= &print_spreadsheet($cdom,$settings,$ordered,$itemtext,\$rowtotal,$crstype,$noedit);          $output .= &print_spreadsheet($cdom,$settings,$ordered,$itemtext,\$rowtotal,$crstype,$noedit);
     } elsif ($action eq 'bridgetasks') {      } elsif ($action eq 'bridgetasks') {
         $output .= &print_bridgetasks($cdom,$settings,$ordered,$itemtext,\$rowtotal,$crstype,$noedit);          $output .= &print_bridgetasks($cdom,$settings,$ordered,$itemtext,\$rowtotal,$crstype,$noedit);
       } elsif ($action eq 'lti') {
           $output .= &print_lti($cdom,$settings,$ordered,$itemtext,\$rowtotal,$crstype,$noedit);
     } elsif ($action eq 'other') {      } elsif ($action eq 'other') {
         $output .= &print_other($cdom,$settings,$allitems,\$rowtotal,$crstype,$noedit);          $output .= &print_other($cdom,$settings,$allitems,\$rowtotal,$crstype,$noedit);
     }      }
Line 766  sub process_changes { Line 780  sub process_changes {
                                  (!$can_categorize));                                   (!$can_categorize));
                         next if (($entry eq 'loncaparev') ||                           next if (($entry eq 'loncaparev') || 
                                 ($entry eq 'owner') ||                                  ($entry eq 'owner') ||
                                 ($entry eq 'clonedfrom'));                                  ($entry eq 'clonedfrom') ||
                                   ($entry eq 'syllabus'));
                         push(@ordered,$entry);                          push(@ordered,$entry);
                     }                      }
                 } elsif ($action eq 'classlists') {                  } elsif ($action eq 'classlists') {
Line 1257  sub process_changes { Line 1272  sub process_changes {
                                 $settings =~ s/,$//;                                  $settings =~ s/,$//;
                             }                              }
                             $newvalues{$entry} = $settings;                              $newvalues{$entry} = $settings;
                           } elsif ($action eq 'lti') {
                               if ($entry eq 'lti.override') {
                                   $newvalues{$entry} = $env{'form.'.$entry};
                               } elsif (($entry eq 'lti.topmenu') || ($entry eq 'lti.inlinemenu')) {
                                   if ($env{'form.lti.override'}) {
                                       $newvalues{$entry} = $env{'form.'.$entry};
                                   } else {
                                       $newvalues{$entry} = '';
                                   }
                               } elsif ($entry eq 'lti.lcmenu') {
                                   if (($env{'form.lti.override'}) &&
                                       (($env{'form.lti.topmenu'}) || ($env{'form.lti.inlinemenu'}))) {
                                       my @lcmenu = &Apache::loncommon::get_env_multiple('form.lti.lcmenu');
                                       my @newlcmenu;
                                       if (@lcmenu) {
                                           my @menuitems = ('fullname','coursetitle','role','logout','grades');
                                           foreach my $item (@menuitems) {
                                               next if (($item eq 'grades') && (!$newvalues{'lti.inlinemenu'}));
                                               if (grep(/^\Q$item\E$/,@lcmenu)) {
                                                   push(@newlcmenu,$item);
                                               }
                                           }
                                       }
                                       if (@newlcmenu) {
                                           $newvalues{$entry} = join(',',@newlcmenu);
                                       } else {
                                           $newvalues{$entry} = 'none';
                                       }
                                   } else {
                                       $newvalues{$entry} = '';
                                   }
                               }
                         } else {                          } else {
                             $newvalues{$entry} = $env{'form.'.$entry};                              $newvalues{$entry} = $env{'form.'.$entry};
                         }                          }
Line 1467  sub store_changes { Line 1514  sub store_changes {
                                             }                                              }
                                         }                                          }
                                         $displayname = &mt($text);                                          $displayname = &mt($text);
                                       } elsif ($item eq 'lti') {
                                           if ($key eq 'lti.lcmenu') {
                                               if ($changes->{$item}{$key} eq 'none') {
                                                   $displayval = &mt('None of the configurable menu items displayed');
                                               } else {
                                                   my %ltititles = &ltimenu_titles();
                                                   $displayval = join(', ', map { $ltititles{$_}; } split(/,/,$changes->{$item}{$key}));
                                               }
                                           } else {
                                               if ($changes->{$item}{$key} eq '1') {
                                                   $displayval = &mt('Yes');
                                               } elsif ($changes->{$item}{$key} eq '') {
                                                   $displayval = &mt('No');
                                               }
                                           }
                                           $displayname = &mt($text);
                                     } else {                                      } else {
                                         $displayname = &mt($text);                                          $displayname = &mt($text);
                                     }                                      }
Line 1529  sub store_changes { Line 1592  sub store_changes {
                                         }                                          }
                                     } elsif ($changes->{$item}{$key} eq '') {                                      } elsif ($changes->{$item}{$key} eq '') {
                                         push(@delkeys,$key);                                          push(@delkeys,$key);
                                         $output .= '<li>'.&Apache::lonhtmlcommon::confirm_success(&mt('Deleted setting for [_1]',                                          if ($item eq 'lti') {
                                                    '<i>'.$displayname.'</i>')).'</li>';                                              if (($key eq 'lti.override') || (($key ne 'lti.override') && ($env{'form.lti.override'} ne ''))) {
                                                   if (($key eq 'lti.lcmenu') &&
                                                       ((!$env{'form.lti.topmenu'}) && (!$env{'form.lti.inlinemenu'}))) {
                                                       $output .= '<li>'.&mt('LTI settings for menu items only saved if page header and/or inline menu is set to be displayed').'</li>';
                                                   } else {
                                                       $output .= '<li>'.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',
                                                                  '<i>'.$displayname.'</i>',
                                                                  "'<b>$displayval</b>'")).'</li>';
                                                   }
                                               } elsif (!exists($changes->{$item}{'lti.override'})) {
                                                   $output .= '<li>'.&mt('LTI settings only saved if Override is set to "Yes"').'</li>';
                                               }
                                           } else {
                                               $output .= '<li>'.&Apache::lonhtmlcommon::confirm_success(&mt('Deleted setting for [_1]',
                                                          '<i>'.$displayname.'</i>')).'</li>';
                                           }
                                     } else {                                      } else {
                                         $output .= '<li>'.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',                                          $output .= '<li>'.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',
                                                    '<i>'.$displayname.'</i>',                                                     '<i>'.$displayname.'</i>',
Line 1569  sub store_changes { Line 1647  sub store_changes {
                                 }                                  }
                                 if (($key eq 'description') || ($key eq 'cloners') ||                                  if (($key eq 'description') || ($key eq 'cloners') ||
                                     ($key eq 'hidefromcat') || ($key eq 'categories') ||                                      ($key eq 'hidefromcat') || ($key eq 'categories') ||
                                     ($key eq 'co-owners')) {                                      ($key eq 'co-owners') || ($key eq 'lti.override') ||
                                       ($key eq 'lti.topmenu') || ($key eq 'lti.inlinemenu') ||
                                       ($key eq 'lti.lcmenu')) {
                                     push(@need_env_update,$key);                                      push(@need_env_update,$key);
                                 }                                  }
                             }                              }
Line 1653  sub update_env { Line 1733  sub update_env {
                     my @coowners = split(',',$storehash->{'internal.'.$key});                      my @coowners = split(',',$storehash->{'internal.'.$key});
                     $crsinfo{$env{'request.course.id'}}{'co-owners'} = \@coowners;                      $crsinfo{$env{'request.course.id'}}{'co-owners'} = \@coowners;
                     $count ++;                      $count ++;
                   } elsif ($key =~ /^lti\./) {
                       &Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.'.$key => $storehash->{$key}});
                 }                  }
             }              }
             if ($count) {              if ($count) {
Line 2112  sub print_courseinfo { Line 2194  sub print_courseinfo {
                    size  => '20',                     size  => '20',
                    advanced => 1                     advanced => 1
                         },                          },
         'externalsyllabus' => {          'syllabus' => {
                    text => '<b>'.&mt($itemtext->{'externalsyllabus'}).'</b><br />'.                     text => '<b>'.&mt($itemtext->{'syllabus'}).'</b><br />'.
                            &mt('(Syllabus type in use)').('&nbsp;' x2).                             &mt('(Syllabus type in use)').('&nbsp;' x2).
                            $editsyllabus,                             $editsyllabus,
                         },                          },
Line 2358  sub print_courseinfo { Line 2440  sub print_courseinfo {
                     $datatable .= &manage_coownership($cnum,$cdom,\@currcoown,$noedit);                      $datatable .= &manage_coownership($cnum,$cdom,\@currcoown,$noedit);
                 }                  }
             }              }
         } elsif ($item eq 'externalsyllabus') {          } elsif ($item eq 'syllabus') {
             my $external = $env{'course.'.$env{'request.course.id'}.'.externalsyllabus'};              my $external = $env{'course.'.$env{'request.course.id'}.'.externalsyllabus'};
             my $uploaded = $env{'course.'.$env{'request.course.id'}.'.uploadedsyllabus'};              my $uploaded = $env{'course.'.$env{'request.course.id'}.'.uploadedsyllabus'};
             my $minimal =  $env{'course.'.$env{'request.course.id'}.'.minimalsyllabus'};              my $minimal =  $env{'course.'.$env{'request.course.id'}.'.minimalsyllabus'};
Line 2580  sub display_loncaparev_constraints { Line 2662  sub display_loncaparev_constraints {
                               $Apache::lonrelrequtils::checkcrstypes{$crstype}).'</h4>';                                $Apache::lonrelrequtils::checkcrstypes{$crstype}).'</h4>';
     }      }
     my (%fromparam,%rowspan,%bymap,%byresource,@scopeorder,%toshow,%allmaps,      my (%fromparam,%rowspan,%bymap,%byresource,@scopeorder,%toshow,%allmaps,
         %byresponsetype,%bysubmission,%fromblocks);          %byresponsetype,%bysubmission,%fromblocks,%bycrsrestype);
     @scopeorder = ('all','section/group','user');      @scopeorder = ('all','section/group','user');
     my $now = time;      my $now = time;
     my $resourcedata = &Apache::lonparmset::readdata($cnum,$cdom);      my $resourcedata = &Apache::lonparmset::readdata($cnum,$cdom);
Line 2854  sub display_loncaparev_constraints { Line 2936  sub display_loncaparev_constraints {
         my $rev_anonsurv=$Apache::lonnet::needsrelease{'parameter:type:anonsurvey::'};          my $rev_anonsurv=$Apache::lonnet::needsrelease{'parameter:type:anonsurvey::'};
         my %randtrysubms=&Apache::lonnet::dump('nohist_randomizetry',$cdom,$cnum);          my %randtrysubms=&Apache::lonnet::dump('nohist_randomizetry',$cdom,$cnum);
         my $rev_randtry=$Apache::lonnet::needsrelease{'parameter:type:randomizetry::'};          my $rev_randtry=$Apache::lonnet::needsrelease{'parameter:type:randomizetry::'};
           my $rev_exttool=$Apache::lonnet::needsrelease{'course:courserestype:exttool'};
         my $stdtype=&Apache::lonparmset::standard_parameter_types('type');          my $stdtype=&Apache::lonparmset::standard_parameter_types('type');
         my $stdname=&Apache::lonparmset::standard_parameter_names('type');          my $stdname=&Apache::lonparmset::standard_parameter_names('type');
         my $valanon=&get_param_description($stdtype,'anonsurvey');          my $valanon=&get_param_description($stdtype,'anonsurvey');
         my $valrandtry=&get_param_description($stdtype,'randomizetry');          my $valrandtry=&get_param_description($stdtype,'randomizetry');
         my %checkedrev;          my %checkedrev;
         foreach my $res ($navmap->retrieveResources(undef,sub { $_[0]->is_problem() },1,0)) {          foreach my $res ($navmap->retrieveResources(undef,sub { $_[0]->is_problem() || $_[0]->is_tool() },1,0)) {
             my @parts = @{$res->parts()};              my @parts = @{$res->parts()};
             my $symb = $res->symb();              my $symb = $res->symb();
             my $enclosing_map = &Apache::lonnet::declutter($res->enclosing_map_src());              my $enclosing_map = &Apache::lonnet::declutter($res->enclosing_map_src());
               if ($res->is_tool()) {
                   my $rev = $rev_exttool;
                   $bycrsrestype{$symb}{$rev} = &mt('External Tool');
                   $allmaps{$enclosing_map} = 1;
                   next;
               }
             foreach my $part (@parts) {              foreach my $part (@parts) {
                 if (exists($anonsubms{$symb."\0".$part})) {                  if (exists($anonsubms{$symb."\0".$part})) {
                     my $rev = $rev_anonsurv;                      my $rev = $rev_anonsurv;
Line 2950  sub display_loncaparev_constraints { Line 3039  sub display_loncaparev_constraints {
             }              }
         }          }
     }      }
       my $suppmap = 'supplemental.sequence';
       my ($suppcount,$supptools,$errors) = (0,0,0);
       ($suppcount,$supptools,$errors) = &Apache::loncommon::recurse_supplemental($cnum,$cdom,
                                                         $suppmap,$suppcount,$supptools,$errors);
     my $mapres_header = '<h4>'.      my $mapres_header = '<h4>'.
                         &mt('Requirements for specific folders or resources').                          &mt('Requirements for specific folders or resources').
                         '</h4>';                          '</h4>';
Line 2964  sub display_loncaparev_constraints { Line 3057  sub display_loncaparev_constraints {
     $r->print($start_page.$top_header);      $r->print($start_page.$top_header);
     if ($output) {      if ($output) {
         $r->print($output);          $r->print($output);
         if (defined($navmap)) {          if (defined($navmap) || $supptools) {
             &show_contents_view($r,$navmap,$cid,\%toshow,\%bymap,\%byresource,\%bysubmission,              &show_contents_view($r,$navmap,$cid,\%toshow,\%bymap,\%byresource,\%bysubmission,
                                 \%byresponsetype,\@scopeorder,\%lt);                                  \%byresponsetype,\%bycrsrestype,\@scopeorder,\%lt,$supptools);
         }          }
         $r->print('<br /><br />');           $r->print('<br /><br />'); 
     } else {      } else {
Line 2984  sub display_loncaparev_constraints { Line 3077  sub display_loncaparev_constraints {
   
 sub show_contents_view {  sub show_contents_view {
     my ($r,$navmap,$cid,$toshow,$bymap,$byresource,$bysubmission,$byresponsetype,      my ($r,$navmap,$cid,$toshow,$bymap,$byresource,$bysubmission,$byresponsetype,
         $scopeorder,$lt) = @_;          $bycrsrestype,$scopeorder,$lt,$supptools) = @_;
     if ((keys(%{$toshow}) > 0) || (keys(%{$byresource}) > 0) ||       my $location=&Apache::loncommon::lonhttpdurl("/adm/lonIcons");
         (keys(%{$bysubmission}) > 0) || (keys(%{$byresponsetype}) > 0)) {      my $whitespace = '<img src="'.$location.'/whitespace_21.gif" alt="" />';
         my $location=&Apache::loncommon::lonhttpdurl("/adm/lonIcons");      my $showmaincontent;
         my $whitespace = '<img src="'.$location.'/whitespace_21.gif" alt="" />';      if ((ref($navmap)) &&
         my $icon =  '<img src="'.$location.'/navmap.folder.open.gif" alt="" />';          ((keys(%{$toshow}) > 0) || (keys(%{$byresource}) > 0) ||
            (keys(%{$bysubmission}) > 0) || (keys(%{$byresponsetype}) > 0) ||
            (keys(%{$bycrsrestype}) > 0))) {
           $showmaincontent = 1;
       }
       if ($showmaincontent || $supptools) {
           $r->print(&Apache::loncommon::start_data_table());
       }
       if ($showmaincontent) {
           my $icon = '<img src="'.$location.'/navmap.folder.open.gif" alt="" />';
         my $topmap = $env{'course.'.$cid.'.url'};          my $topmap = $env{'course.'.$cid.'.url'};
         $r->print(&Apache::loncommon::start_data_table().          $r->print(&Apache::loncommon::start_data_table_header_row().
                   &Apache::loncommon::start_data_table_header_row().  
                   '<th>'.&mt('Location').'</th><th>'.&mt('Release').'</th>'.                    '<th>'.&mt('Location').'</th><th>'.&mt('Release').'</th>'.
                   '<th>'.&mt('Attribute/Setting').'</th>'.                    '<th>'.&mt('Attribute/Setting').'</th>'.
                   &Apache::loncommon::end_data_table_header_row().                    &Apache::loncommon::end_data_table_header_row().
                   &Apache::loncommon::start_data_table_row().                    &Apache::loncommon::start_data_table_row().
                   '<td>&nbsp;'.$icon.'&nbsp;'.&mt('Main Content').'</td>');                    '<td>&nbsp;'.$icon.'&nbsp;'.&mt('Main Content').'</td>');
                   &releases_by_map($r,$bymap,$topmap,$scopeorder,$lt);          &releases_by_map($r,$bymap,$topmap,$scopeorder,$lt);
                   $r->print(&Apache::loncommon::end_data_table_row());          $r->print(&Apache::loncommon::end_data_table_row());
         my $it=$navmap->getIterator(undef,undef,undef,1,1,undef);          my $it=$navmap->getIterator(undef,undef,undef,1,1,undef);
         my $curRes;          my $curRes;
         my $depth = 0;          my $depth = 0;
Line 3050  sub show_contents_view { Line 3151  sub show_contents_view {
                     if (ref($byresponsetype->{$symb}) eq 'HASH') {                      if (ref($byresponsetype->{$symb}) eq 'HASH') {
                         $rowspan += scalar(keys(%{$byresponsetype->{$symb}}));                          $rowspan += scalar(keys(%{$byresponsetype->{$symb}}));
                     }                      }
                       if (ref($bycrsrestype->{$symb}) eq 'HASH') {
                           $rowspan += scalar(keys(%{$bycrsrestype->{$symb}}));
                       }
                     next if (!$rowspan);                      next if (!$rowspan);
                     $icon = '<img class="LC_contentImage" src="'.$location.'/problem.gif" alt="'.                      $icon = '<img class="LC_contentImage" src="'.$location.'/problem.gif" alt="'.
                             &mt('Problem').'" />';                              &mt('Problem').'" />';
Line 3114  sub show_contents_view { Line 3218  sub show_contents_view {
                             $r->print('</td>');                              $r->print('</td>');
                         }                          }
                         $r->print(&Apache::loncommon::end_data_table_row());                          $r->print(&Apache::loncommon::end_data_table_row());
                           $newrow = 1;
                       }
                       if (ref($bycrsrestype->{$symb}) eq 'HASH') {
                           foreach my $rev (sort(keys(%{$bycrsrestype->{$symb}}))) {
                               if ($newrow) {
                                   $r->print(&Apache::loncommon::continue_data_table_row());
                               }
                               $r->print('<td>'.$rev.'</td><td>'.$bycrsrestype->{$symb}{$rev}.'</td>');
                           }
                           $r->print(&Apache::loncommon::end_data_table_row());
                     }                      }
                 }                  }
             }              }
         }          }
       }
       if ($supptools) {
           my $icon = '<img src="'.$location.'/navmap.folder.open.gif" alt="" />';
           $r->print(&Apache::loncommon::start_data_table_header_row().
                     '<th>'.&mt('Location').'</th><th>'.&mt('Release').'</th>'.
                     '<th>'.&mt('Resource Type').'</th>'.
                     &Apache::loncommon::end_data_table_header_row().
                     &Apache::loncommon::start_data_table_row().
                     '<td>&nbsp;'.$icon.'&nbsp;'.&mt('Supplemental Content').'</td>'.
                     '<td valign="middle">'.
                     $Apache::lonrelrequtils::exttool{'major'}.'.'.
                     $Apache::lonrelrequtils::exttool{'minor'}.
                     '</td><td>'.&mt('[quant,_1,External Tool,External Tools]',
                                     $supptools).'</td>'.
                     &Apache::loncommon::end_data_table_row());
       }
       if ($showmaincontent || $supptools) {
         $r->print(&Apache::loncommon::end_data_table());          $r->print(&Apache::loncommon::end_data_table());
     }      }
     return;      return;
Line 4326  sub print_bridgetasks { Line 4457  sub print_bridgetasks {
     return &make_item_rows($cdom,\%items,$ordered,$settings,$rowtotal,$crstype,'bridgetasks',$noedit);      return &make_item_rows($cdom,\%items,$ordered,$settings,$rowtotal,$crstype,'bridgetasks',$noedit);
 }  }
   
   sub print_lti {
       my ($cdom,$settings,$ordered,$itemtext,$rowtotal,$crstype,$noedit) = @_;
       unless ((ref($settings) eq 'HASH') && (ref($ordered) eq 'ARRAY') && (ref($itemtext) eq 'HASH')) {
           return;
       }
       my @menuitems = ('fullname','coursetitle','role','logout','grades');
       my %menutitles = &ltimenu_titles();
       my ($domdefs,$displaydefs);
       if ($env{'request.lti.login'}) {
           my %lti = &Apache::lonnet::get_domain_lti($cdom,'provider');
           my @domdefsmenu;
           if (ref($lti{$env{'request.lti.login'}}) eq 'HASH') {
               if ($lti{$env{'request.lti.login'}}{'topmenu'}) {
                   $domdefs = &mt('Header shown').', ';
               }
               if ($lti{$env{'request.lti.login'}}{'inlinemenu'}) {
                   $domdefs .= &mt('Inline menu shown');
               }
               $domdefs =~ s/,\s$//;
               if (!$domdefs) {
                   $domdefs = &mt('No header or inline menu shown');
               }
               $domdefs = ' ('.&mt('Domain default').': '.$domdefs.')';
               if (ref($lti{$env{'request.lti.login'}}{'lcmenu'}) eq 'ARRAY') {
                   @domdefsmenu = @{$lti{$env{'request.lti.login'}}{'lcmenu'}};
               }
           }
           $displaydefs = &mt('Domain defaults');
           if (@domdefsmenu) {
               my @diffs = &Apache::loncommon::compare_arrays(\@menuitems,\@domdefsmenu);
               if (@diffs) {
                   my $missing;
                   foreach my $item (@menuitems) {
                       unless (grep(/^\Q$item\E$/,@domdefsmenu)) {
                           $missing .= ' '.$menutitles{$item}.',';
                       }
                   }
                   $missing =~ s/,$//;
                   $displaydefs .= ': '.&mt('Not shown').' --'.$missing;
               } else {
                   $displaydefs .= ': '.&mt('All shown');
               }
           } else {
               $displaydefs .= ': '.&mt('Not shown').' -- '.join(', ', map { $menutitles{$_}; } @menuitems);
           }
       } else {
           $displaydefs = &mt('Domain defaults only available in LTI context');
       }
       my %items = (
           'lti.override' => {
               text => '<b>'.&mt($itemtext->{'lti.override'}).'</b>'.$domdefs,
               input => 'radio',
                      },
           'lti.topmenu' => {
               text => '<b>'.&mt($itemtext->{'lti.topmenu'}).'</b>',
               input => 'radio',
                      },
           'lti.inlinemenu' => {
               text => '<b>'.&mt($itemtext->{'lti.inlinemenu'}).'</b>',
               input => 'radio',
                         },
           'lti.lcmenu' => {
               text => '<b>'.&mt($itemtext->{'lti.lcmenu'}).'</b><br />'.$displaydefs,
               input => 'custom',
                     },
                   );
       return &make_item_rows($cdom,\%items,$ordered,$settings,$rowtotal,$crstype,'lti',$noedit);
   }
   
   sub lcmenu_checkboxes {
       my ($cdom,$caller,$settings,$crstype,$noedit) = @_;
       my @menuitems = ('fullname','coursetitle','role','logout','grades');
       my %menutitles = &ltimenu_titles();
       my (@current,@domdefs);
       if ($env{'request.lti.login'}) {
           my %lti = &Apache::lonnet::get_domain_lti($cdom,'provider');
           if (ref($lti{$env{'request.lti.login'}}) eq 'HASH') {
               if (ref($lti{$env{'request.lti.login'}}{'lcmenu'}) eq 'ARRAY') {
                   @domdefs = @{$lti{$env{'request.lti.login'}}{'lcmenu'}};
               }
           }
       }
       if (ref($settings) eq 'HASH') {
           if ($settings->{'lti.lcmenu'}) {
               unless ($settings->{'lti.lcmenu'} eq 'none') {
                   @current = split(',',$settings->{'lti.lcmenu'});
               }
           } else {
               @current = @domdefs;
           }
       } else {
           @current = @domdefs;
       }
       my $numinrow = 3;
       my $count = 0;
       my $disabled;
       if ($noedit) {
           $disabled = ' disabled="disabled"';
       }
       my $output = '<table>';
       foreach my $item (@menuitems) {
           my $checked = '';
           if (grep(/^\Q$item\E$/,@current)) {
               $checked = ' checked="checked" ';
           }
           my $rem = $count%($numinrow);
           if ($rem == 0) {
               if ($count > 0) {
                   $output .= '</tr>';
               }
               $output .= '<tr>';
           }
           $output .= '<td align="left"><span class="LC_nobreak"><label><input type="checkbox" '.
                      'name="lti.lcmenu" value="'.$item.'"'.$checked.$disabled.'/>&nbsp;'.
                      $menutitles{$item}.'</label></span></td>';
           $count ++;
       }
       my $rem = $count%($numinrow);
       my $colsleft = $numinrow - $rem;
       if ($colsleft > 1 ) {
           $output .= '<td colspan="'.$colsleft.'" class="LC_left_item">'.
                      '&nbsp;</td>';
       } elsif ($colsleft == 1) {
           $output .= '<td class="LC_left_item">&nbsp;</td>';
       }
       $output .= '</tr></table>';
   }
   
   sub ltimenu_titles {
       return &Apache::lonlocal::texthash(
                                           fullname    => 'Full name',
                                           coursetitle => 'Course title',
                                           role        => 'Role',
                                           logout      => 'Logout',
                                           grades      => 'Grades',
       );
   }
   
 sub print_other {  sub print_other {
     my ($cdom,$settings,$allitems,$rowtotal,$crstype,$noedit) = @_;      my ($cdom,$settings,$allitems,$rowtotal,$crstype,$noedit) = @_;
     unless ((ref($settings) eq 'HASH') && (ref($allitems) eq 'ARRAY')) {      unless ((ref($settings) eq 'HASH') && (ref($allitems) eq 'ARRAY')) {
Line 4508  sub make_item_rows { Line 4777  sub make_item_rows {
                 $datatable .= &checkforpriv_row($cdom,$item,$settings,$crstype,$noedit);                  $datatable .= &checkforpriv_row($cdom,$item,$settings,$crstype,$noedit);
             } elsif ($item eq 'print_header_format') {              } elsif ($item eq 'print_header_format') {
                 $datatable .= &print_hdrfmt_row($item,$settings,$noedit);                  $datatable .= &print_hdrfmt_row($item,$settings,$noedit);
               } elsif ($item eq 'lti.lcmenu') {
                   $datatable .= &lcmenu_checkboxes($cdom,$item,$settings,$crstype,$noedit);
             } elsif ($items->{$item}{input} eq 'dates') {              } elsif ($items->{$item}{input} eq 'dates') {
                my $disabled;                 my $disabled;
                if ($noedit) {                 if ($noedit) {
Line 4525  sub make_item_rows { Line 4796  sub make_item_rows {
                      }                       }
                      $valueyes = "1";                       $valueyes = "1";
                      $valueno = "0";                       $valueno = "0";
                   } elsif (($item eq 'lti.topmenu') || ($item eq 'lti.inlinemenu')) {
                       $valueyes = '1';
                 }                  }
                 $datatable .= &yesno_radio($item,$settings,$unsetdefault,$valueyes,$valueno,$noedit);                  $datatable .= &yesno_radio($item,$settings,$unsetdefault,$valueyes,$valueno,$noedit);
             } elsif ($items->{$item}{input} eq 'selectbox') {              } elsif ($items->{$item}{input} eq 'selectbox') {

Removed from v.1.84  
changed lines
  Added in v.1.88


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