Diff for /loncom/interface/lonwhatsnew.pm between versions 1.64 and 1.127

version 1.64, 2006/11/23 00:02:38 version 1.127, 2020/03/30 16:26:46
Line 36  use Apache::lonlocal; Line 36  use Apache::lonlocal;
 use Apache::loncoursedata();  use Apache::loncoursedata();
 use Apache::lonnavmaps();  use Apache::lonnavmaps();
 use Apache::lonuserstate;  use Apache::lonuserstate;
   use Apache::lonuserutils; 
 use Apache::Constants qw(:common :http);  use Apache::Constants qw(:common :http);
 use Time::Local;  use Time::Local;
 use GDBM_File;  use GDBM_File;
 use lib '/home/httpd/lib/perl/';  use lib '/home/httpd/lib/perl/';
 use LONCAPA;  use LONCAPA;
   use HTML::Entities;
   
 #----------------------------  #----------------------------
 # handler  # handler
Line 60  sub handler { Line 62  sub handler {
     my $command = $env{'form.command'};      my $command = $env{'form.command'};
     my $refpage = $env{'form.refpage'};      my $refpage = $env{'form.refpage'};
   
     my %checkallowed = ( coursenormalmail => 1,      my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
  coursecritmail => 1, );      my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
   
       my ($isadhoc,%checkallowed);
   
       if ($env{'request.role'} =~ m{^(cc|co)/}) {
           my $rolecode = $1;
           if ($env{"environment.internal.$cdom.$crs.$env{'request.role'}.adhoc"}) {
               $isadhoc = 1;
           }
       } elsif ($env{'request.role'} =~ m{^cr/$cdom/$cdom\-domainconfig/(\w+)\./}) {
           my $rolename = $1;
           if ($env{"environment.internal.$cdom.$crs.cr/$cdom/$cdom-domainconfig/$rolename.adhoc"}) {
               $isadhoc = 1;
           }
       }
       unless ($isadhoc) {
           %checkallowed = ( coursenormalmail => 1,
     coursecritmail => 1,);
       }
     foreach my $perm_check (['whn','whatsnew',1],      foreach my $perm_check (['whn','whatsnew',1],
     ['pch','coursediscussion',1],      ['pch','coursediscussion',1],
     ['mgr','handgrading',1],      ['mgr','handgrading',1],
     ['vgr','abovethreshold',1],      ['vgr','abovethreshold',1],
     ['opa','haserrors',1],      ['vgr','haserrors',1],
     ['mdc','versionchanges',0],      ['whn','versionchanges',1],
                               ['vcl','newroles',1],
                               ['vcl','oldroles',1],
                               ['whn','crslogin',1],
                               ['vcl','sessions',1],
                               ['mgr','resetcounters',1],
     ) {      ) {
  my ($perm,$key,$check_section) = @{ $perm_check };   my ($perm,$key,$check_section) = @{ $perm_check };
  my $scope = $env{'request.course.id'};   my $scope = $env{'request.course.id'};
Line 84  sub handler { Line 109  sub handler {
   
     if ( ! $env{'request.course.fn'} || ! $checkallowed{'whatsnew'}) {      if ( ! $env{'request.course.fn'} || ! $checkallowed{'whatsnew'}) {
         # Not in a course, or no whn priv in course          # Not in a course, or no whn priv in course
         $env{'user.error.msg'}="/adm/whatsnew::whn:0:0:Cannot display what's new page";          $env{'user.error.msg'}="/adm/whatsnew:whn:0:0:Cannot display what's new page";
         return HTTP_NOT_ACCEPTABLE;          return HTTP_NOT_ACCEPTABLE;
     }      }
   
Line 96  sub handler { Line 121  sub handler {
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();
     &Apache::lonhtmlcommon::add_breadcrumb      &Apache::lonhtmlcommon::add_breadcrumb
             ({href=>'/adm/whatsnew',              ({href=>'/adm/whatsnew',
               text=>"Display Action Items"});                text=>"What's New?"});
     if (($command eq 'chgthreshold') && $checkallowed{'abovethreshold'}) {      if (($command eq 'chgthreshold') && $checkallowed{'abovethreshold'}) {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
             ({href=>'/adm/whatsnew?command=chgthreshold&refpage='.$refpage,              ({href=>'/adm/whatsnew?command=chgthreshold&refpage='.$refpage,
               text=>"Change thresholds"});                text=>"Change thresholds"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs          $r->print(&Apache::lonhtmlcommon::breadcrumbs
             ("What's New?",#'Course_Action_Items_Thresholds'              ("What's New?",#'Course_Action_Items_Thresholds'
      ));       ));
     } elsif (($command eq 'chginterval') && $checkallowed{'versionchanges'} ) {      } elsif (($command eq 'chginterval') && $checkallowed{'versionchanges'} ) {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
             ({href=>'/adm/whatsnew?command=chginterval&refpage='.$refpage,              ({href=>'/adm/whatsnew?command=chginterval&refpage='.$refpage,
               text=>"Change interval"});                text=>"Change interval"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs          $r->print(&Apache::lonhtmlcommon::breadcrumbs
             ("What's New?",#'Course_Action_Items_Intervals'              ("What's New?",#'Course_Action_Items_Intervals'
      ));       ));
     } elsif (($command eq 'chgdisc') && $checkallowed{'coursediscussion'}) {      } elsif (($command eq 'chgdisc') && $checkallowed{'coursediscussion'}) {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
             ({href=>'/adm/whatsnew?command=chgdisc&refpage='.$refpage,              ({href=>'/adm/whatsnew?command=chgdisc&refpage='.$refpage,
               text=>"Change discussion display"});                text=>"Change discussion display"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs          $r->print(&Apache::lonhtmlcommon::breadcrumbs
             ("What's New?",#'Course_Action_Items_Intervals'              ("What's New?",#'Course_Action_Items_Intervals'
      ));       ));
     } elsif ($command eq 'courseinit') {      } elsif ($command eq 'courseinit') {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
             ({href=>'/adm/whatsnew?command=courseinit&refpage='.$refpage,              ({href=>'/adm/whatsnew?command=courseinit&refpage='.$refpage,
               text=>"Course initialization preference"});                text=>"Course initialization preference"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs          $r->print(&Apache::lonhtmlcommon::breadcrumbs
             ("What's New?",#'Course_Action_Items_Initialization'              ("What's New?",#'Course_Action_Items_Initialization'
      ));       ));
       } elsif ($command eq 'chgoldroleinterval' && $checkallowed{'oldroles'}) {
           &Apache::lonhtmlcommon::add_breadcrumb
               ({href=>'/adm/whatsnew?command=chgoldroleinterval&refpage='.$refpage,
                 text=>"Change interval"});
           $r->print(&Apache::lonhtmlcommon::breadcrumbs
               ("What's New?",#'Course_Action_Items_Intervals'
                ));
       } elsif ($command eq 'chgnewroleinterval' && $checkallowed{'newroles'}) {
           &Apache::lonhtmlcommon::add_breadcrumb
               ({href=>'/adm/whatsnew?command=chgnewroleinterval&refpage='.$refpage,
                 text=>"Change interval"});
           $r->print(&Apache::lonhtmlcommon::breadcrumbs
               ("What's New?",#'Course_Action_Items_Intervals'
                ));
       } elsif ($command eq 'chgcrslogininterval' && $checkallowed{'crslogin'}) {
           &Apache::lonhtmlcommon::add_breadcrumb
               ({href=>'/adm/whatsnew?command=chgcrslogininterval&refpage='.$refpage,
                 text=>"Change interval"});
           $r->print(&Apache::lonhtmlcommon::breadcrumbs
               ("What's New?",#'Course_Action_Items_Intervals'
                ));
       } elsif ($command eq 'chgsessionlimit' && $checkallowed{'sessions'}) {
           &Apache::lonhtmlcommon::add_breadcrumb
               ({href=>'/adm/whatsnew?command=chgsessionlimit&refpage='.$refpage,
                 text=>"Change session range"});
           $r->print(&Apache::lonhtmlcommon::breadcrumbs
               ("What's New?",#'Course_Action_Items_Sessions'
                ));
     } else {      } else {
         $r->print(&Apache::lonhtmlcommon::breadcrumbs          $r->print(&Apache::lonhtmlcommon::breadcrumbs
             ("What's New?",#'Course_Action_Items_Display'              ("What's New?",#'Course_Action_Items_Display'
      ));       ));
     }      }
     &display_main_box($r,$command,$refpage,\%checkallowed);      &display_main_box($r,$command,$refpage,\%checkallowed,$cdom,$crs);
     return OK;      return OK;
 }  }
   
Line 141  sub handler { Line 194  sub handler {
 #------------------------------  #------------------------------
                                                                                                                                                                   
 sub display_main_box {  sub display_main_box {
     my ($r,$command,$refpage,$checkallowed) = @_;      my ($r,$command,$refpage,$checkallowed,$cdom,$crs) = @_;
     my $domain=&Apache::loncommon::determinedomain();      my $domain=&Apache::loncommon::determinedomain();
     my $function = &Apache::loncommon::get_users_function();      my $function = &Apache::loncommon::get_users_function();
     my $tabbg=&Apache::loncommon::designparm($function.'.tabbg',$domain);  
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
     $r->print('<table width="100%" border="0" cellpadding="5" cellspacing="0"><tr><td width="100%">');      $r->print('<table width="100%" border="0" cellpadding="5" cellspacing="0"><tr><td width="100%">');
   
Line 153  sub display_main_box { Line 205  sub display_main_box {
                          degdiff => 'Degree of difficulty',                           degdiff => 'Degree of difficulty',
                          numstudents => 'Total number of students with submissions',                           numstudents => 'Total number of students with submissions',
     );      );
       my %versions = (
     my %interval_titles = &Apache::lonlocal::texthash (                         -1 => "version changes since start of $lctype",
                             -1 => "since start of $lctype",                    2592000 => 'version changes since last month',
                        2592000 => 'since last month',                     604800 => 'version changes since last week',
                         604800 => 'since last week',                      86400 => 'version changes since yesterday',
                          86400 => 'since yesterday',                     );
       my %newroles = (
                          -1 => "roles which have become active since start of $lctype",
                     2592000 => 'roles which have become active since last month',
                      604800 => 'roles which have become active since last week',
                       86400 => 'roles which have become active since yesterday',
                      );
       my %oldroles = (
                          -1 => "roles which expired since start of $lctype",
                     2592000 => 'roles which expired since last month',
                      604800 => 'roles which expired since last week',
                       86400 => 'roles which expired since yesterday',
                      );
       my %crslogins = (
                          -1 => 'last logins for anyone who has ever logged in',
                     2592000 => 'last logins for users in last 30 days',
                      604800 => 'last logins for users in last 7 days',
                       86400 => 'last logins for users in last 24 hours',
                      );
       my %sessions = (
                        300  => 'course sessions active in the last 5 minutes',
                        600  => 'course sessions active in the last 10 minutes',
                        1800 => 'course sessions active in the last 30 minutes',
                        7200 => 'course sessions active in the last 2 hours',
                       -7200 => 'course sessions with last activity more than 2 hours ago',
                      );
       my %interval_titles = (
           versions => \%versions,
           newroles => \%newroles,
           oldroles => \%oldroles,
           crslogin => \%crslogins,
           sessions => \%sessions,
     );      );
   
     my %initpage = &Apache::lonlocal::texthash (      my %initpage = &Apache::lonlocal::texthash (
                      firstres => "first resource in the $lctype",                       firstres => "first resource in the $lctype",
                      whatsnew => "what's new? page",                       whatsnew => "What's New Page",
                      userpref => 'your general user preferences',                       userpref => 'your general user preferences',
                      coursespecific => "specific setting for this $lctype",                       coursespecific => "specific setting for this $lctype",
                    );                     );
     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};  
     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};  
   
     if (($command eq 'chgthreshold')       if (($command eq 'chgthreshold') 
  && $checkallowed->{'abovethreshold'}) {   && $checkallowed->{'abovethreshold'}) {
         &display_threshold_config($r,$refpage,$tabbg,\%threshold_titles,          &display_threshold_config($r,$refpage,\%threshold_titles,$cdom,$crs);
                                                                    $cdom,$crs);  
     } elsif (($command eq 'chginterval')       } elsif (($command eq 'chginterval') 
      && $checkallowed->{'versionchanges'}) {       && $checkallowed->{'versionchanges'}) {
         &display_interval_config($r,$refpage,\%interval_titles);          &display_interval_config($r,$refpage,\%interval_titles,'versions');
     } elsif (($command eq 'chgdisc')       } elsif (($command eq 'chgdisc') 
      && $checkallowed->{'coursediscussion'}) {       && $checkallowed->{'coursediscussion'}) {
         &display_discussion_config($r,$refpage);          &display_discussion_config($r,$refpage);
     } elsif ($command eq 'courseinit') {      } elsif ($command eq 'courseinit') {
         &courseinit_config($r,$refpage,\%initpage);          &courseinit_config($r,$refpage,\%initpage);
       } elsif (($command eq 'chgnewroleinterval')
                && $checkallowed->{'newroles'}) {
           &display_interval_config($r,$refpage,\%interval_titles,'newroles');
       } elsif (($command eq 'chgoldroleinterval')
                && $checkallowed->{'oldroles'}) {
           &display_interval_config($r,$refpage,\%interval_titles,'oldroles');
       } elsif (($command eq 'chgcrslogininterval')
                && $checkallowed->{'crslogin'}) {
           &display_interval_config($r,$refpage,\%interval_titles,'crslogin');
       } elsif (($command eq 'chgsessionlimit')
                && $checkallowed->{'sessions'}) {
           &display_interval_config($r,$refpage,\%interval_titles,'sessions');
     } else {      } else {
         &display_actions_box($r,$tabbg,$command,$refpage,\%threshold_titles,          &display_actions_box($r,$command,$refpage,\%threshold_titles,
                         \%interval_titles,\%initpage,$cdom,$crs,$checkallowed);                          \%interval_titles,\%initpage,$cdom,$crs,$checkallowed);
     }      }
     my $end_page = &Apache::loncommon::end_page();      my $end_page = &Apache::loncommon::end_page();
Line 206  sub display_header { Line 297  sub display_header {
     my ($command,$checkallowed) = @_;      my ($command,$checkallowed) = @_;
           
     my $scripttag;      my $scripttag;
     unless ($command eq 'chgthreshold' || $command eq 'chginterval') {      unless ($command eq 'chgthreshold' || $command eq 'chginterval' || 
               $command eq 'chgoldroleinterval' ||
               $command eq 'chgnewroleinterval' || $command eq 'chgcrslogininterval') {
        $scripttag = <<"END";         $scripttag = <<"END";
 <script type="text/javascript">  <script type="text/javascript">
   // <![CDATA[
 function change_display(caller,change) {  function change_display(caller,change) {
     caller.value = change;      caller.value = change;
     document.visible.submit();       document.visible.submit();
 }  }
   
 function changeAll(change) {  function changeAll(change) {
Line 223  END Line 317  END
                             "\n";                              "\n";
             }              }
         }          }
         $scripttag.='document.visible.submit();          $scripttag.=<<"ENDTOGG";
       document.visible.submit();
   }
   
   function thresholdreset() {
       document.visible.command.value="reset";
       document.visible.submit();
   }
   
   function toggledetails(prefix) {
       var total = document.visible[prefix+'count'].value;
       var sumrow = document.visible[prefix+'row'].value;
       if (total == 0) {
           return;
       }
       var showdetails = 0;
       for (var i=0; i<document.visible[prefix+'details'].length; i++) {
           if (document.visible[prefix+'details'][i].checked) {
               showdetails = document.visible[prefix+'details'][i].value;
           }
       }
       var detval = "none";
       var sumval = "";
       if (showdetails == 1) {
           detval = "";
           sumval = "none";
       }
       for (var j=0; j<total; j++) {
           var counter = j+1;
           var itemid = prefix+"det_"+counter;
           personele = document.getElementById(itemid);
           if (personele != null) {
               personele.style.display = detval;
           }
       }
       var detheaderele = document.getElementById(prefix+"titledet");
       if (detheaderele != null) {
           detheaderele.style.display = detval;
       }
       for (var k=0; k<sumrow; k++) {
           var counter = k+1;
           var itemid = prefix+"sum_"+counter;
           catele = document.getElementById(itemid);
           if (catele != null) {
               catele.style.display = sumval;
           }
       }
       var sumheaderele = document.getElementById(prefix+"titlesum");
       if (sumheaderele != null) {
           sumheaderele.style.display = sumval;
       }
       return;
 }  }
   // ]]>
 </script>  </script>
 ';  ENDTOGG
     }      }
     my $course_type=&Apache::loncommon::course_type();      my $course_type=&Apache::loncommon::course_type();
     return &Apache::loncommon::start_page($course_type.' Action Items',      return &Apache::loncommon::start_page("What's New?",
   $scripttag);    $scripttag);
 }  }
   
Line 241  END Line 387  END
 #-------------------------------  #-------------------------------
                                                                                                                                                                   
 sub display_actions_box {  sub display_actions_box {
     my ($r,$tabbg,$command,$refpage,$threshold_titles,$interval_titles,      my ($r,$command,$refpage,$threshold_titles,$interval_titles,$initpage,
                                       $initpage,$cdom,$crs,$checkallowed) = @_;          $cdom,$crs,$checkallowed) = @_;
     my $rowColor1 = "#ffffff";  
     my $rowColor2 = "#eeeeee";  
   
     my $udom = $env{'user.domain'};      my $udom = $env{'user.domain'};
     my $uname = $env{'user.name'};      my $uname = $env{'user.name'};
     my $cid = $env{'request.course.id'};      my $cid = $env{'request.course.id'};
Line 253  sub display_actions_box { Line 396  sub display_actions_box {
     my $lctype = lc($crstype);      my $lctype = lc($crstype);
     my %stulabel = (      my %stulabel = (
                     'Course' => 'students',                      'Course' => 'students',
                     'Group' => 'members',                      'Community' => 'members',
                    );                     );
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                  'yacc' => 'You are accessing an invalid course',                   'yacc' => 'You are accessing an invalid course',
Line 275  sub display_actions_box { Line 418  sub display_actions_box {
     my @warnings = ();      my @warnings = ();
     my $msgcount = 0;      my $msgcount = 0;
     my $critmsgcount = 0;      my $critmsgcount = 0;
       my $expirecount;
       my %expired;
       my $activecount;
       my %activated;
       my %loggedin;
       my $logincount;
       my %sessions;
       my $sessioncount;
     my %res_title = ();      my %res_title = ();
     my %show = ();      my %show = ();
     my $needitems = 0;      my $needitems = 0;
Line 289  sub display_actions_box { Line 439  sub display_actions_box {
     my %threshold = ();      my %threshold = ();
     my %pagedesc = &Apache::lonlocal::texthash (      my %pagedesc = &Apache::lonlocal::texthash (
                      firstres => 'First resource',                       firstres => 'First resource',
                      whatsnew => "What's New? page",                       whatsnew => "What's New Page",
                      userpref => 'user preference',                       userpref => 'user preference',
                      coursespecific => $lctype.' only',                       coursespecific => $lctype.' only',
                      default => 'default',                       default => 'default',
Line 299  sub display_actions_box { Line 449  sub display_actions_box {
     my $currinit = $pagedesc{$initdisp}.' ('.$pagedesc{$initcontrol}.')';      my $currinit = $pagedesc{$initdisp}.' ('.$pagedesc{$initcontrol}.')';
   
     unless ($cid) {      unless ($cid) {
         $r->print('<br /><b><center>'.$lt{'yacc'}.'</center></b><br /><br />');          $r->print('<p><span style="text-align: center; font-weight: bold;">'.$lt{'yacc'}.'</span></p>');
         return;          return;
     }      }
   
       my $header = '';
     if ($refpage eq 'start') {      if ($refpage eq 'start') {
         if (tie(my %bighash,'GDBM_File',$env{'request.course.fn'}.'.db',          if (tie(my %bighash,'GDBM_File',$env{'request.course.fn'}.'.db',
             &GDBM_READER(),0640)) {              &GDBM_READER(),0640)) {
             my $furl=$bighash{'first_url'};              my $furl=&HTML::Entities::encode($bighash{'first_url'},'"<>&');
             untie(%bighash);              untie(%bighash);
             $r->print('<font size="+1"><a href="'.$furl.'">'.$lt{'gtfr'}.              $header .= '<b><a href="'.$furl.'">'.$lt{'gtfr'}.
                   '</a></font><br />');                    '</a></b><br />';
         }          }
     }      }
     $r->print(&mt('Page set to be displayed after you have selected a role in this '.$lctype).      $header .= &mt('Page set to be displayed after you have selected a role in this '.$lctype).'.'
               '. <nobr>'.&mt('Currently: <i>[_1]</i>',$currinit).'.&nbsp;&nbsp;'.                .' <span class="LC_nobreak">'
               &mt('<b>Change</b> for just <a href="/adm/whatsnew?command=courseinit&refpage=[_1]">this '.$lctype.'</a>',$refpage).' '.                .&mt('Currently: [_1].','<i>'.$currinit.'</i>')
               &mt('or for all <a href="/adm/preferences?action=changecourseinit&refpage=[_1]">your courses</a>',$refpage).'</nobr><br /><hr />');                .'&nbsp;&nbsp;'
                 .&mt('[_1]Change[_2] for just [_3]this '.$lctype.'[_4] or for [_5]all your courses/communities[_6].'
                     ,'<b>'
                     ,'</b>'
                     ,'<a href="/adm/whatsnew?command=courseinit&amp;refpage='.$refpage.'">'
                     ,'</a>'
                     ,'<a href="/adm/preferences?action=changecourseinit&amp;refpage='.$refpage.'">'
                     ,'</a>')
                 .' </span>';
   
       $r->print(&Apache::loncommon::head_subbox($header));
   
     if ($command eq 'reset') {      if ($command eq 'reset') {
         $result = &process_reset($cdom,$crs);          $result = &process_reset($cdom,$crs,$checkallowed);
     } elsif ($command eq 'update') {      } elsif ($command eq 'update') {
         $result = &process_update($uname,$udom,$threshold_titles);          $result = &process_update($uname,$udom,$threshold_titles);
     } elsif ($command eq 'newinterval') {      } elsif ($command eq 'newinterval') {
Line 330  sub display_actions_box { Line 491  sub display_actions_box {
     my $store_result=&store_display_settings($uname,$udom,$cid,$checkallowed);      my $store_result=&store_display_settings($uname,$udom,$cid,$checkallowed);
   
     unless ($store_result eq 'ok') {       unless ($store_result eq 'ok') { 
         &Apache::lonnet::logthis('Error storing whatsnew settings: '.          &Apache::lonnet::logthis('Error saving whatsnew settings: '.
             $store_result.' for '.'user '.$uname.':'.$udom.' in '.$lctype.' '.$cid);              $store_result.' for '.'user '.$uname.':'.$udom.' in '.$lctype.' '.$cid);
         $result .= &mt('Unable to store visibility settings due to [_1]',          $result .= '<span class="LC_error">'
                        $store_result);                     .&mt('Unable to save visibility settings due to [_1]',
                          $store_result)
                     .'</span>';
     }      }
   
     if ($result) {      if ($result) {
         $r->print($result.'<hr width="100%" />');          $r->print($result.'<hr />');
     }      }
     $r->rflush();      $r->rflush();
   
       my (%timediff,%interval);
     my %display_settings = &get_display_settings($uname,$udom,$cid);      my %display_settings = &get_display_settings($uname,$udom,$cid);
     my $timediff = $display_settings{$cid.':interval'};      $timediff{'versions'} = $display_settings{$cid.':interval'};
     unless (defined($timediff)) { $timediff = 604800; }       unless (defined($timediff{'versions'})) { $timediff{'versions'} = 604800; } 
     my $now = time;      $interval{'versions'} = $interval_titles->{'versions'}->{$timediff{'versions'}};
     my $interval = $$interval_titles{$timediff};  
     if ($timediff == -1) {  
         $timediff = time;  
     }   
     my $starttime = $now - $timediff;  
     my $countunread = $display_settings{$cid.':countunread'};  
     unless (defined($countunread)) {  
         $countunread = 'on';  
     }  
   
     my %headings = &Apache::lonlocal::texthash(      my %headings = &Apache::lonlocal::texthash(
                 coursediscussion =>  'Unread '.$lctype.' discussion posts',                  coursediscussion => 'Unread '.$lctype.' discussion posts',
                 handgrading =>  'Problems requiring handgrading',                  handgrading      => 'Problems requiring handgrading',
                 haserrors => 'Problems with errors',                  haserrors        => 'Problems with errors',
                 versionchanges => 'Resources in '.$lctype.' with version changes '.$interval,  
                 coursenormalmail => 'New '.$lctype.' messages',                  coursenormalmail => 'New '.$lctype.' messages',
                 coursecritmail => 'New critical messages in '.$lctype,                  coursecritmail   => 'New critical messages in '.$lctype,
     );      );
   
       if ($timediff{'versions'} == -1) {
           $headings{'versionchanges'} = &mt('Resources in '.$lctype.' with version changes since start of '.$lctype);
       } elsif ($timediff{'versions'} == 2592000) {
           $headings{'versionchanges'} = &mt('Resources in '.$lctype.' with version changes since last month');
       } elsif ($timediff{'versions'} == 604800) {
           $headings{'versionchanges'} = &mt('Resources in '.$lctype.' with version changes since last week');
       } elsif ($timediff{'versions'} == 86400) {
           $headings{'versionchanges'} = &mt('Resources in '.$lctype.' with version changes since yesterday');
       }
   
       $timediff{'oldroles'} = $display_settings{$cid.':oldroleinterval'};
       unless (defined($timediff{'oldroles'})) { $timediff{'oldroles'} = 604800; }
       $interval{'oldroles'} = $interval_titles->{'oldroles'}->{$timediff{'oldroles'}};
   
       if ($timediff{'oldroles'} == -1) {
           $headings{'oldroles'} = &mt('Roles for which access to '.$lctype.' has expired since start of '.$lctype);
       } elsif ($timediff{'oldroles'} == 2592000) {
           $headings{'oldroles'} = &mt('Roles for which access to '.$lctype.' has expired since last month');
       } elsif ($timediff{'oldroles'} == 604800) {
           $headings{'oldroles'} = &mt('Roles for which access to '.$lctype.' has expired since last week');
       } elsif ($timediff{'oldroles'} == 86400) {
           $headings{'oldroles'} = &mt('Roles for which access to '.$lctype.' has expired since yesterday');
       }
   
       $timediff{'newroles'} = $display_settings{$cid.':newroleinterval'};
       unless (defined($timediff{'newroles'})) { $timediff{'newroles'} = 604800; }
       $interval{'newroles'} = $interval_titles->{'newroles'}->{$timediff{'newroles'}};
   
       if ($timediff{'newroles'} == -1) {
           $headings{'newroles'} = &mt('Roles for which access to '.$lctype.' has become available since start of '.$lctype);
       } elsif ($timediff{'newroles'} == 2592000) {
           $headings{'newroles'} = &mt('Roles for which access to '.$lctype.' has become available since last month');
       } elsif ($timediff{'newroles'} == 604800) {
           $headings{'newroles'} = &mt('Roles for which access to '.$lctype.' has become available since last week');
       } elsif ($timediff{'newroles'} == 86400) {
           $headings{'newroles'} = &mt('Roles for which access to '.$lctype.' has become available since yesterday');
       }
   
       $timediff{'crslogin'} = $display_settings{$cid.':crslogininterval'};
       unless (defined($timediff{'crslogin'})) { $timediff{'crslogin'} = 604800; }
       $interval{'crslogin'} = $interval_titles->{'crslogin'}->{$timediff{'crslogin'}};
   
       if ($timediff{'crslogin'} == -1) {
           $headings{'crslogin'} = &mt('Last login for anyone who has ever logged in');
       } elsif ($timediff{'crslogin'} == 2592000) {
           $headings{'crslogin'} = &mt('Last login for users in last 30 days');
       } elsif ($timediff{'crslogin'} == 604800) {
           $headings{'crslogin'} = &mt('Last login for users in last 7 days');
       } elsif ($timediff{'crslogin'} == 86400) {
           $headings{'crslogin'} = &mt('Last login for users in last 24 hours');
       }
   
       $timediff{'sessions'} = $display_settings{$cid.':sessionactivity'};
       unless (defined($timediff{'sessions'})) { $timediff{'sessions'} = 7200; }
       $interval{'sessions'} = $interval_titles->{'sessions'}->{$timediff{'sessions'}};
   
       if ($timediff{'sessions'} == -7200) {
           $headings{'sessions'} = &mt('Session with activity more than 2 hours ago');
       } elsif ($timediff{'sessions'} == 7200) {
           $headings{'sessions'} = &mt('Session with activity in last 2 hours');
       } elsif ($timediff{'sessions'} == 1800) {
           $headings{'sessions'} = &mt('Session with activity in last 30 minutes');
       } elsif ($timediff{'sessions'} == 600) {
           $headings{'sessions'} = &mt('Session with activity in last 10 minutes');
       } elsif ($timediff{'sessions'} == 300) {
           $headings{'sessions'} = &mt('Session with activity in last 5 minutes');
       }
   
       my ($now,$starttime,$activatedstart,$expiredstart,$crsloginstart);
       $now = time;
   
       if ($timediff{'versions'} == -1) {
           $starttime = 0;
       } else {
           $starttime = $now - $timediff{'versions'};
       }
   
       if ($timediff{'newroles'} == -1) {
           $activatedstart = 0;
       } else {
           $activatedstart = $now - $timediff{'newroles'};
       }
   
       if ($timediff{'oldroles'} == -1) {
           $expiredstart = 0;
       } else {
           $expiredstart = $now - $timediff{'oldroles'};
       }
   
       if ($timediff{'crslogin'} == -1) {
           $crsloginstart = 0;
       } else {
           $crsloginstart = $now - $timediff{'crslogin'};
       }
   
       my $countunread = $display_settings{$cid.':countunread'};
       unless (defined($countunread)) {
           $countunread = 'on';
       }
     if ($$checkallowed{'abovethreshold'}) {      if ($$checkallowed{'abovethreshold'}) {
         &get_curr_thresholds(\%threshold,$uname,$udom,$cid,$cdom,$crs);          &get_curr_thresholds(\%threshold,$uname,$udom,$cid,$cdom,$crs);
     }      }
   
     $headings{'abovethreshold'} =       $headings{'abovethreshold'} = 
  &mt('Problems with av. attempts &ge; [_1] or deg. difficulty &ge; [_2] <br /> and total number of '.$stulabel{$crstype}.' with submissions &ge; [_3]',   &mt('(Problems with av. attempts &ge; [_1] or deg. difficulty &ge; [_2]) [_3] and total number of '.$stulabel{$crstype}.' with submissions &ge; [_4]',
     $threshold{'av_attempts'},$threshold{'degdiff'},      $threshold{'av_attempts'},$threshold{'degdiff'},
     $threshold{'numstudents'});      '<br />',$threshold{'numstudents'});
   
     my @actionorder = ('handgrading','haserrors','abovethreshold','versionchanges','coursediscussion','coursenormalmail','coursecritmail');      my @actionorder = ('handgrading','haserrors','abovethreshold','versionchanges','coursediscussion','coursenormalmail','coursecritmail','newroles','oldroles','crslogin','sessions');
       my %actioncolumn = (
                            handgrading      => 'left',
                            haserrors        => 'left',
                            abovethreshold   => 'left',
                            versionchanges   => 'left',
                            coursediscussion => 'right',
                            coursenormalmail => 'right',
                            coursecritmail   => 'right',
                            newroles         => 'right',
                            oldroles         => 'right',
                            crslogin         => 'right',
                            sessions         => 'right',
                          );
   
     foreach my $key (keys(%{$checkallowed})) {      foreach my $key (keys(%{$checkallowed})) {
  if ($key =~ /_section$/) { next; }   if ($key =~ /_section$/) { next; }
Line 387  sub display_actions_box { Line 652  sub display_actions_box {
     }      }
   
     foreach my $item (@actionorder) {      foreach my $item (@actionorder) {
         unless ($item eq 'coursenormalmail' || $item eq 'coursecritmail') {          unless ($item eq 'coursenormalmail' || $item eq 'coursecritmail' ||
                   $item eq 'newroles' || $item eq 'oldroles' || 
                   $item eq 'crslogin' || $item eq 'sessions') {
             if ($show{$item}) {              if ($show{$item}) {
                 $needitems = 1;                  $needitems = 1;
                 last;                  last;
Line 395  sub display_actions_box { Line 662  sub display_actions_box {
         }          }
     }      }
   
       my $itemserror;
     if ($needitems) {      if ($needitems) {
         &getitems(\%unread,\%ungraded,\%bombed,\%triggered,\%changed,\@newdiscussions,\@tograde,\@bombs,\@warnings,$rowColor1,$rowColor2,\%threshold,$cdom,$crs,\%res_title,\%show,$starttime,$countunread);          $itemserror = &getitems(\%unread,\%ungraded,\%bombed,\%triggered,\%changed,\@newdiscussions,\@tograde,\@bombs,\@warnings,\%threshold,$cdom,$crs,\%res_title,\%show,$starttime,$countunread,$checkallowed);
       }
       my $classlist;
       if ($show{'oldroles'} || $show{'newroles'} || $show{'crslogin'} || $show{'sessions'}) {
           $classlist = &Apache::loncoursedata::get_classlist();
     }      }
     if ($show{'coursenormalmail'}) {      if ($show{'coursenormalmail'}) {
         $msgcount = &getnormalmail(\@newmsgs);          $msgcount = &getnormalmail(\@newmsgs);
Line 404  sub display_actions_box { Line 676  sub display_actions_box {
     if ($show{'coursecritmail'}) {      if ($show{'coursecritmail'}) {
         $critmsgcount = &getcritmail(\@critmsgs);          $critmsgcount = &getcritmail(\@critmsgs);
     }      }
       if ($show{'oldroles'}) {
           $expirecount = &getexpired(\%expired,$expiredstart,'previous',$classlist);
       }
       if ($show{'newroles'}) {
           $activecount = &getactivated(\%activated,$activatedstart,'active',$classlist);
       }
       if ($show{'crslogin'}) {
           $logincount = &getloggedin($cdom,$crs,\%loggedin,$crsloginstart);
       }
       if ($show{'sessions'}) {
           $sessioncount = &getsessions($cdom,$crs,\%sessions,$timediff{'sessions'},$classlist);
       }
     $r->print(qq|<a href="javascript:changeAll('hide');">$lt{'hial'}</a>      $r->print(qq|<a href="javascript:changeAll('hide');">$lt{'hial'}</a>
      &nbsp;&nbsp;<a href="javascript:changeAll('show');">$lt{'shal'}</a>       &nbsp;&nbsp;<a href="javascript:changeAll('show');">$lt{'shal'}</a>
      <form method="post" name="visible" action="/adm/whatsnew">\n|);       <form method="post" name="visible" action="/adm/whatsnew">\n|);
Line 415  sub display_actions_box { Line 698  sub display_actions_box {
         }          }
     }      }
   
     $r->print('<input type="hidden" name="refpage" value="'.$refpage.'"></form><br /><table border="0" width="100%" cellpadding="2" cellspacing="4"><tr><td align="left" valign="top" width="45%">');      $r->print('<input type="hidden" name="refpage" value="'.$refpage.'" /><table class="LC_double_column"><tr><td class="LC_left_col">');
   
     my $displayed = 0;      my $displayed = 0;
     my $totalboxes = 0;      my $totalboxes = 0;
Line 426  sub display_actions_box { Line 709  sub display_actions_box {
             $totalboxes ++;              $totalboxes ++;
         }          }
     }      }
     my $halfway = int($totalboxes/2) + $totalboxes%2;      my $currcolumn = 'left';
   #    my $halfway = int($totalboxes/2) + $totalboxes%2;
     foreach my $actionitem (@actionorder) {      foreach my $actionitem (@actionorder) {
         if ($$checkallowed{$actionitem}) {          if ($checkallowed->{$actionitem}) {
             if ($displayed == $halfway) {              if (($actioncolumn{$actionitem} eq 'right') && ($currcolumn eq 'left')) {
                 $r->print('</td><td width="6%">&nbsp;</td><td align="left" valign="top" width="47%">');                  $r->print('</td><td>&nbsp;</td><td class="LC_right_col" >');
                   $currcolumn = 'right'; 
             }              }
             &display_launcher($r,$actionitem,$refpage,$checkallowed,$tabbg,$rowColor1,$rowColor2,\%show,\%headings,\%res_title,\@tograde,\%ungraded,\@bombs,\%bombed,\%changed,\@warnings,\%triggered,\@newdiscussions,\%unread,$msgcount,\@newmsgs,$critmsgcount,\@critmsgs,$interval,$countunread);              &display_launcher($r,$actionitem,$refpage,$checkallowed,\%show,\%headings,\%res_title,\@tograde,\%ungraded,\@bombs,\%bombed,\%changed,\@warnings,\%triggered,\@newdiscussions,\%unread,$msgcount,\@newmsgs,$critmsgcount,\@critmsgs,\%interval,$countunread,\%expired,$expirecount,\%activated,$activecount,$crstype,$itemserror,\%loggedin,$logincount,\%sessions,$sessioncount,$classlist);
             $displayed ++;               $displayed ++; 
         }          }
     }      }
     $r->print('      $r->print('
            </table>  
           </td>  
          </tr>  
         </table>  
       </td>        </td>
     </tr>      </tr>
    </table>');     </table>
      </form>
   ');
 }  }
   
 #-------------------------------  #-------------------------------
Line 454  sub display_actions_box { Line 737  sub display_actions_box {
 #-------------------------------  #-------------------------------
                                                                                                                                                                   
 sub display_threshold_config {  sub display_threshold_config {
     my ($r,$refpage,$tabbg,$threshold_titles,$cdom,$crs) = @_;      my ($r,$refpage,$threshold_titles,$cdom,$crs) = @_;
     my $uname = $env{'user.name'};      my $uname = $env{'user.name'};
     my $udom = $env{'user.dom'};      my $udom = $env{'user.dom'};
     my $cid = $env{'request.course.id'};      my $cid = $env{'request.course.id'};
Line 471  sub display_threshold_config { Line 754  sub display_threshold_config {
                          );                           );
     &get_curr_thresholds(\%threshold,$uname,$udom,$cid,$cdom,$crs);      &get_curr_thresholds(\%threshold,$uname,$udom,$cid,$cdom,$crs);
   
     $r->print('<br /><form name="thresholdform" method="post" action="/adm/whatsnew">      $r->print('<br /><form name="thresholdform" method="post" action="/adm/whatsnew">'.
         <table border="0" cellpadding="2" cellspacing="4">                &Apache::loncommon::start_data_table().
          <tr>                &Apache::loncommon::start_data_table_header_row().
           <td align="left" valign="top" width="45%">               '<th>'.&mt('Threshold Name').'</th>'."\n".
            <table border="0" cellpadding="0" cellspacing="0" bgcolor="#000000">               '<th>'.&mt('Current value').'</th>'."\n".
             <tr>               '<th>'.&mt('Change?').'</th>'."\n".
              <td>                &Apache::loncommon::end_data_table_header_row());
                <table border="0" cellpadding="1" cellspacing="1" bgcolor="#000000">  
                 <tr>  
                 <td bgcolor="#ffffff">  
                  <table cellspacing="0" cellpadding="4" border="0">  
      <tr bgcolor="'.$tabbg.'">  
       <th>Threshold Name</th>  
       <th>Current value</th>  
       <th>Change?</th>  
      </tr>');  
     my $rowNum =0;  
     foreach my $type (@thresholditems) {      foreach my $type (@thresholditems) {
         my $parameter = $env{'request.course.id'}.':threshold_'.$type;          my $parameter = $env{'request.course.id'}.':threshold_'.$type;
 # onchange is javascript to automatically check the 'Set' button.  # onchange is javascript to automatically check the 'Set' button.
         my $onchange = 'onFocus="javascript:window.document.forms'.          my $onchange = 'onfocus="javascript:window.document.forms'.
               "['thresholdform'].elements['".$parameter."_setparmval']".                "['thresholdform'].elements['".$parameter."_setparmval']".
               '.checked=true;"';                '.checked=true;"';
         if ($rowNum %2 == 1) {          $r->print(&Apache::loncommon::start_data_table_row()."\n".
             $rowColor = $rowColor1;                   '<td>'.$threshold_titles{$type}.'</td>'."\n".
         } else {                   '<td>'.&Apache::lonhtmlcommon::textbox($parameter.'_value',
             $rowColor = $rowColor2;  
         }  
         $r->print('  
      <tr bgcolor="'.$rowColor.'">  
       <td>'.$threshold_titles{$type}.'</td>  
       <td>'.&Apache::lonhtmlcommon::textbox($parameter.'_value',  
                                             $threshold{$type},                                              $threshold{$type},
                                             10,$onchange).'</td>                                              10,$onchange).'</td>'."\n".
       <td>'                   '<td>'.
            .&Apache::lonhtmlcommon::checkbox($parameter.'_setparmval').                   &Apache::lonhtmlcommon::checkbox($parameter.'_setparmval').
       '</td>                   '</td>'."\n".
      </tr>');                   &Apache::loncommon::end_data_table_row());
         $rowNum ++;  
     }      }
     $r->print('</table></td></tr></table></td></tr></table>      $r->print(&Apache::loncommon::end_data_table()."\n".
            <br /><input type="submit" name="threshold" value="Make changes" />            '<br /><input type="submit" name="threshold" value="'.&mt('Save').'" />
                  <input type="hidden" name="command" value="update" />                   <input type="hidden" name="command" value="update" />
                  <input type="hidden" name="refpage" value="'.$refpage.'" />                   <input type="hidden" name="refpage" value="'.$refpage.'" />
                </form>');                 </form>');
Line 526  sub display_threshold_config { Line 792  sub display_threshold_config {
 #-------------------------------  #-------------------------------
                                                                                                                                                                         
 sub display_interval_config {  sub display_interval_config {
     my ($r,$refpage,$interval_titles) = @_;      my ($r,$refpage,$interval_titles,$context) = @_;
       my $setting = 'interval';
       if ($context eq 'oldroles') {
           $setting = 'oldroleinterval';
       } elsif ($context eq 'newroles') {
           $setting = 'newroleinterval'; 
       } elsif ($context eq 'sessions') {
           $setting = 'sessionactivity';
       }
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
     my $current = &get_current($env{'user.name'},$env{'user.domain'},      my $current = &get_current($env{'user.name'},$env{'user.domain'},
                                 $env{'request.course.id'},'interval');                                  $env{'request.course.id'},$setting);
     $r->print('<br />'.&mt('Choose the time window to use for display of version changes for resources in the '.$lctype.'.'));      if ($context eq 'oldroles') {
           $r->print('<br />'.&mt('Choose the time window to use to display roles for which access to the '.$lctype.' expired.').'<br />');
       } elsif ($context eq 'newroles') {
           $r->print('<br />'.&mt('Choose the time window to use to display roles for which access to the '.$lctype.' became available.').'<br />');
       } elsif ($context eq 'crslogin') {
           $r->print('<br />'.&mt('Choose the time window to use to display the last login by a user in the '.$lctype).'<br />');
       } elsif ($context eq 'sessions') {
           $r->print('<br />'.&mt('Choose the time limit to use to display active user sessions in the '.$lctype.'.').'<br />');
       } else {
           $r->print('<br />'.&mt('Choose the time window to use to display resources in the '.$lctype.' with version changes.').'<br />');
       }
     unless ($current eq '') {      unless ($current eq '') {
         $r->print(' '.&mt('Current value is [_1]','<b>'.          if (ref($interval_titles->{$context}) eq 'HASH') {
                   $$interval_titles{$current}.'</b>.'));              $r->print(' '.&mt('Current value is "[_1]".','<b>'.
                         $interval_titles->{$context}->{$current}.'</b>').'<br />');
           }
     }      }
     $r->print('<br /><br />      $r->print('<br />
 <form method="post" name="intervalswitch" action="/adm/whatsnew">  <form method="post" name="intervalswitch" action="/adm/whatsnew">
 <input type="hidden" name="command" value="newinterval" />  <input type="hidden" name="command" value="newinterval" />
 <input type="hidden" name="refpage" value="'.$refpage.'" />  <input type="hidden" name="intervaltype" value="'.$context.'" />
   <input type="hidden" name="refpage" value="'.$refpage.'" />'.
   &mt('Display:').' 
 <select name="interval">  <select name="interval">
   <option value="" selected="selected">'.&mt('Select').'</option>
 ');  ');
     foreach my $key (reverse sort ({$a cmp $b} (keys(%{$interval_titles})))) {      if (ref($interval_titles) eq 'HASH') {
         $r->print('<option value="'.$key.'">Version changes '.$$interval_titles{$key}.          if (ref($interval_titles->{$context}) eq 'HASH') {
                   '</option>'."\n");              my @sorted;
               if ($context eq 'sessions') {
                   @sorted = sort { $a <=> $b } (keys(%{$interval_titles->{$context}}));
                   push(@sorted,shift(@sorted));
               } else {
                   @sorted = reverse sort ({$a cmp $b} (keys(%{$interval_titles->{$context}})));
               }
               foreach my $key (@sorted) {
                   $r->print('<option value="'.$key.'">'.&mt($interval_titles->{$context}->{$key}).
                             '</option>'."\n");
               }
           }
     }      }
     $r->print('</select>&nbsp;&nbsp;      $r->print('</select>&nbsp;&nbsp;
                <input type="submit" name="display" value="'.                 <input type="submit" name="display" value="'.
                &mt('Change interval').'" /></form>');                 &mt('Save').'" /></form>');
     return;      return;
 }  }
   
Line 577  function toggle_countunread(choice) { Line 877  function toggle_countunread(choice) {
     document.discussionswitch.submit();      document.discussionswitch.submit();
 }  }
 </script>');  </script>');
     $r->print('<br />'.&mt('Choose whether or not to display a count of the number of new posts for each resource or bulletin board which has unread posts.').'<br />'.&mt('This can increase the time taken to gather data for the [_1] page by a few seconds.',"<i>What's New?</i>").'&nbsp;&nbsp;'.&mt('Currently set to [_1].','<b>'.$current.'</b>'));      $r->print('<br />'
                .&mt('Choose whether or not to display a count of the number of new posts for each resource or discussion board which has unread posts.')
                .'<br />'
                .&mt("This can increase the time taken to gather data for the [_1]What's New Page[_2] by a few seconds.",'<i>','</i>')
                .'&nbsp;&nbsp;'
                .&mt('Currently set to [_1].','<b>'.$current.'</b>')
       );
     $r->print('<br /><br />      $r->print('<br /><br />
 <form method="post" name="discussionswitch" action="/adm/whatsnew">  <form method="post" name="discussionswitch" action="/adm/whatsnew">
 <input type="hidden" name="command" value="newdiscconf" />  <input type="hidden" name="command" value="newdiscconf" />
Line 586  function toggle_countunread(choice) { Line 892  function toggle_countunread(choice) {
 ');  ');
     $r->print('<br/>      $r->print('<br/>
                <input type="button" name="display" value="'.                 <input type="button" name="display" value="'.
                &mt('Change to [_1]',$opposite{$current}).'"                  &mt('Change to [_1]',&mt($opposite{$current})).'" 
                onclick="javascript:toggle_countunread('."'change'".')" />                 onclick="javascript:toggle_countunread('."'change'".')" />'.
                &nbsp;&nbsp;&nbsp;&nbsp;&nbsp&nbsp;&nbsp;                 ('&nbsp;' x7).
                <input type="button" name="nochange" value="'.                 '<input type="button" name="nochange" value="'.
                &mt("No change").'"                  &mt("No change").'" 
                onclick="javascript:toggle_countunread('."'unchanged'".')" />                 onclick="javascript:toggle_countunread('."'unchanged'".')" />
                </form>');                 </form>');
Line 616  sub courseinit_config { Line 922  sub courseinit_config {
                              'anis' => 'and is set to display',                               'anis' => 'and is set to display',
                              'padc' => 'Page display controlled by',                               'padc' => 'Page display controlled by',
                              'chce' => 'Choose '.$lctype.' entry',                               'chce' => 'Choose '.$lctype.' entry',
                              'moce' => 'Modify '.$lctype.' entry',                               'moce' => 'Save',
     );      );
     $r->print(<<"END");       $r->print(<<"END"); 
 <br />$lt{'chwp'}  <br />$lt{'chwp'}
Line 633  END Line 939  END
         if ($choice eq $control) {          if ($choice eq $control) {
             $chkstring = ' checked="checked" ';              $chkstring = ' checked="checked" ';
         }            }  
         $r->print('<nobr><label><input type="radio" name="courseinit_control" value="'.          $r->print('<span class="LC_nobreak"><label><input type="radio" name="courseinit_control" value="'.
                    $choice.'"'.$chkstring.'/>'.$$initpage{$choice}.                     $choice.'"'.$chkstring.'/>'.$$initpage{$choice}.
                    '&nbsp;&nbsp;</label></nobr>');                     '&nbsp;&nbsp;</label></span>');
     }      }
     $r->print('<br /><br />'.&mt('If').' '.$$initpage{'coursespecific'}.      $r->print('<br /><br />'.&mt('If').' '.$$initpage{'coursespecific'}.
               ' - <br />'.$lt{'chce'}.": \n");                ' - <br />'.$lt{'chce'}.": \n");
Line 644  END Line 950  END
         if (($choice eq $current) && ($control eq 'coursespecific')) {          if (($choice eq $current) && ($control eq 'coursespecific')) {
             $chkstring = ' checked="checked" ';              $chkstring = ' checked="checked" ';
         }          }
         $r->print('<nobr><label><input type="radio" name="courseinit_page" value="'.          $r->print('<span class="LC_nobreak"><label><input type="radio" name="courseinit_page" value="'.
                   $choice.'"'.$chkstring.'/>'.$$initpage{$choice}.                    $choice.'"'.$chkstring.'/>'.$$initpage{$choice}.
                   '&nbsp;&nbsp;</label></nobr>');                    '&nbsp;&nbsp;</label></span>');
     }      }
     $r->print('<br /><br /><input type="submit" name="display" value="'.      $r->print('<br /><br /><input type="submit" name="display" value="'.
                $lt{'moce'}.'" /></form>');                 $lt{'moce'}.'" /></form>');
Line 674  sub curr_courseinit { Line 980  sub curr_courseinit {
 }  }
   
 sub display_launcher {  sub display_launcher {
     my ($r,$action,$refpage,$checkallowed,$tabbg,$rowColor1,$rowColor2,$show,      my ($r,$action,$refpage,$checkallowed,$show,$headings,$res_title,
         $headings,$res_title,$tograde,$ungraded,$bombs,$bombed,$changed,          $tograde,$ungraded,$bombs,$bombed,$changed,$warnings,$triggered,
         $warnings,$triggered,$newdiscussions,$unread,$msgcount,$newmsgs,          $newdiscussions,$unread,$msgcount,$newmsgs,$critmsgcount,$critmsgs,
                           $critmsgcount,$critmsgs,$interval,$countunread) = @_;          $interval,$countunread,$expired,$expirecount,$activated,$activecount,
           $crstype,$itemserror,$loggedin,$logincount,$sessions,$sessioncount,
           $classlist) = @_;
   
     if ($$checkallowed{$action}) {      if ($$checkallowed{$action}) {
         &start_box($r,$tabbg,$show,$headings,$action,$refpage,$action);          &start_box($r,$show,$headings,$action,$refpage);
         if ($$show{$action}) {          if ($$show{$action}) {
             if ($action eq 'handgrading') {    # UNGRADED ITEMS              if ($action eq 'handgrading') {    # UNGRADED ITEMS
                 &display_handgrade($r,$tograde,$rowColor1,$rowColor2,                  &display_handgrade($r,$tograde,$ungraded,$itemserror);
                                                                     $ungraded);  
             } elsif ($action eq 'haserrors') { # BOMBS              } elsif ($action eq 'haserrors') { # BOMBS
                 &display_haserrors($r,$bombs,$rowColor1,$rowColor2,$bombed,                  &display_haserrors($r,$bombs,$bombed,$res_title,$itemserror);
                                                                    $res_title);  
             } elsif ($action eq 'versionchanges') { # VERSION CHANGES              } elsif ($action eq 'versionchanges') { # VERSION CHANGES
                 &display_versionchanges($r,$changed,$res_title,$rowColor1,                  &display_versionchanges($r,$changed,$res_title,$interval->{'versions'},$itemserror);
                                                          $rowColor2,$interval);  
   
             } elsif ($action eq 'abovethreshold') { # DEGDIFF/AV. TRIES TRIGGERS              } elsif ($action eq 'abovethreshold') { # DEGDIFF/AV. TRIES TRIGGERS
                 &display_abovethreshold($r,$refpage,$warnings,$triggered,                  &display_abovethreshold($r,$refpage,$warnings,$triggered,
  $res_title);   $res_title,$itemserror,$checkallowed);
             } elsif ($action eq 'coursediscussion') { # UNREAD COURSE DISCUSSION              } elsif ($action eq 'coursediscussion') { # UNREAD COURSE DISCUSSION
                 &display_coursediscussion($r,$newdiscussions,$unread,                  &display_coursediscussion($r,$newdiscussions,$unread,
                                 $countunread,$res_title,$rowColor1,$rowColor2);                                  $countunread,$res_title,$itemserror);
             } elsif ($action eq 'coursenormalmail') { # NORMAL MESSAGES              } elsif ($action eq 'coursenormalmail') { # NORMAL MESSAGES
                 &display_coursenormalmail($r,$msgcount,$newmsgs,$rowColor1,                  &display_coursenormalmail($r,$msgcount,$newmsgs);
                                                                    $rowColor2);  
             } elsif ($action eq 'coursecritmail') { # CRITICAL MESSAGES              } elsif ($action eq 'coursecritmail') { # CRITICAL MESSAGES
                 &display_coursecritmail($r,$critmsgcount,$critmsgs,$rowColor1,                  &display_coursecritmail($r,$critmsgcount,$critmsgs);
                                                                    $rowColor2);              } elsif ($action eq 'newroles') { # ACTIVATED ROLES
                   &display_rolechanges($r,$activecount,$activated,$interval->{'newroles'},
                                        $crstype,$classlist);
               } elsif ($action eq 'oldroles') { # EXPIRED ROLES
                   &display_rolechanges($r,$expirecount,$expired,$interval->{'oldroles'},
                                        $crstype,$classlist);
               } elsif ($action eq 'crslogin') { #LAST LOGIN
                   &display_activity($r,'logins',$logincount,$loggedin,$interval->{'crslogin'},
                                      $crstype,$classlist);
               } elsif ($action eq 'sessions') { #ACTIVE SESSIONS
                   &display_activity($r,'sessions',$sessioncount,$sessions,$interval->{'sessions'},
                                     $crstype,$classlist);
             }              }
         }          }
         &end_box($r);          &end_box($r);
Line 713  sub display_launcher { Line 1027  sub display_launcher {
   
 sub getitems {  sub getitems {
     my ($unread,$ungraded,$bombed,$triggered,$changed,$newdiscussions,      my ($unread,$ungraded,$bombed,$triggered,$changed,$newdiscussions,
         $tograde,$bombs,$warnings,$rowColor1,$rowColor2,$threshold,$cdom,$crs,          $tograde,$bombs,$warnings,$threshold,$cdom,$crs,$res_title,$show,
                                  $res_title,$show,$starttime,$countunread) = @_;          $starttime,$countunread,$checkallowed) = @_;
     my $navmap = Apache::lonnavmaps::navmap->new();      my $navmap = Apache::lonnavmaps::navmap->new();
       if (!defined($navmap)) {
           my $itemserror = '<span class="LC_warning">'.&mt('An error occurred retrieving information about the course.').'<br />'.&mt('It is recommended that you [_1]re-select the course[_2].','<a href="/adm/roles">','</a>').'</span>';
           return $itemserror;
       }
     # force retrieve Resource to seed the part id cache we'll need it later      # force retrieve Resource to seed the part id cache we'll need it later
     my @allres=$navmap->retrieveResources(undef,      my @allres=$navmap->retrieveResources(undef,
                      sub {if ($_[0]->is_problem) { $_[0]->parts();} return 1;});                       sub {if ($_[0]->is_problem) { $_[0]->parts();} return 1;});
Line 740  sub getitems { Line 1058  sub getitems {
         %{$$ungraded{$symb}} = ();          %{$$ungraded{$symb}} = ();
         %{$$triggered{$symb}} = ();          %{$$triggered{$symb}} = ();
         $$triggered{$symb}{numparts} = 0;          $$triggered{$symb}{numparts} = 0;
           if ($resource->encrypted()) {
               $$triggered{$symb}{'enclink'} = $resource->link();
               $$triggered{$symb}{'encsymb'} = $resource->shown_symb();
           }
         my $title = $resource->compTitle();          my $title = $resource->compTitle();
         $$res_title{$symb} = $title;          $$res_title{$symb} = $title;
         my $ressymb = $resource->wrap_symb();          my $ressymb = $resource->wrap_symb();
Line 766  sub getitems { Line 1088  sub getitems {
 # Maxtries and degree of difficulty for problem parts, unless handgradeable  # Maxtries and degree of difficulty for problem parts, unless handgradeable
         if ($$show{'abovethreshold'}) {            if ($$show{'abovethreshold'}) {  
             &check_thresholds($resource,$symb,\%resourcetracker,              &check_thresholds($resource,$symb,\%resourcetracker,
       $triggered,$threshold,$warnings);        $triggered,$threshold,$warnings,
                                 $checkallowed);
         }          }
   
     }      }
       return; 
 }  }
   
 sub check_discussions {  sub check_discussions {
Line 781  sub check_discussions { Line 1104  sub check_discussions {
     %{$$unread{$ressymb}} = ();      %{$$unread{$ressymb}} = ();
     $$unread{$ressymb}{'title'} = $title;      $$unread{$ressymb}{'title'} = $title;
     $$unread{$ressymb}{'symb'} = $symb;      $$unread{$ressymb}{'symb'} = $symb;
       if ($resource->encrypted()) {
           $$unread{$ressymb}{'enclink'} = $resource->link();
           $$unread{$ressymb}{'encsymb'} = $resource->shown_symb();
       }
     push(@{$newdiscussions}, $ressymb);      push(@{$newdiscussions}, $ressymb);
           
     $$unread{$ressymb}{'lastpost'} = $resource->last_post_time();      $$unread{$ressymb}{'lastpost'} = $resource->last_post_time();
           
     if ($countunread eq 'on') {      if ($countunread eq 'on') {
  $$unread{$ressymb}{'unreadcount'} = $resource->unread_discussion();   $$unread{$ressymb}{'unreadcount'} = 
                               $resource->discussion_info('unread');
     }      }
 }  }
   
Line 807  sub check_handgraded { Line 1135  sub check_handgraded {
             if (@ungraded > 0) {              if (@ungraded > 0) {
                 $$ungraded{$symb}{count} = scalar(@ungraded);                  $$ungraded{$symb}{count} = scalar(@ungraded);
                 $$ungraded{$symb}{title} = $title;                  $$ungraded{$symb}{title} = $title;
                 push(@{$tograde}, $symb);                  if ($resource->encrypted()) {
                       $$ungraded{$symb}{'enclink'} = $resource->link();
                       $$ungraded{$symb}{'encsymb'} = $resource->shown_symb();
                   }
                   push(@{$tograde},$symb);
             }              }
         }          }
     }      }
Line 830  sub check_bombed { Line 1162  sub check_bombed {
 }  }
   
 sub check_thresholds {  sub check_thresholds {
     my ($resource,$symb,$resourcetracker,$triggered,$threshold,$warnings) = @_;      my ($resource,$symb,$resourcetracker,$triggered,$threshold,$warnings,
           $checkallowed) = @_;
 # Compile maxtries and degree of difficulty for problem parts, unless handgradeable  # Compile maxtries and degree of difficulty for problem parts, unless handgradeable
     my @parts = @{$resource->parts()};      my @parts = @{$resource->parts()};
     my %stats;      my %stats;
     my %lastreset = ();      my %lastreset = ();
     my $warning = 0;      my $warning = 0;
     my $rowColor;  
     foreach my $part (@parts) {      foreach my $part (@parts) {
         if ($resource->handgrade($part) eq 'yes') {          if ($resource->handgrade($part) eq 'yes') {
             next;              next;
         }          }
           if ($resource->is_anonsurvey($part)) {
               next;
           }
         if ($resource->is_survey($part)) {          if ($resource->is_survey($part)) {
             next;              next;
         }          }
Line 863  sub check_thresholds { Line 1198  sub check_thresholds {
             $av_attempts = $attempts/$users;              $av_attempts = $attempts/$users;
             $av_attempts = sprintf("%.2f",$av_attempts);              $av_attempts = sprintf("%.2f",$av_attempts);
         }          }
           &Apache::lonnet::statslog($symb,$part,$users,$av_attempts,$degdiff);
         if ((($degdiff ne '' && $degdiff >= $$threshold{'degdiff'}) || ($av_attempts ne '' && $av_attempts >= $$threshold{'av_attempts'})) && ($users >= $$threshold{'numstudents'})) {          if ((($degdiff ne '' && $degdiff >= $$threshold{'degdiff'}) || ($av_attempts ne '' && $av_attempts >= $$threshold{'av_attempts'})) && ($users >= $$threshold{'numstudents'})) {
             $stats{$part}{degdiff} = $degdiff;              $stats{$part}{degdiff} = $degdiff;
             $stats{$part}{attempts} = $av_attempts;              $stats{$part}{attempts} = $av_attempts;
Line 884  sub check_thresholds { Line 1220  sub check_thresholds {
                 my $resettitle = 'title_'.&escape($symb."\0".$part);                  my $resettitle = 'title_'.&escape($symb."\0".$part);
                 if (@parts > 1) {                  if (@parts > 1) {
                     $$triggered{$symb}{text}[$partcount] = '                      $$triggered{$symb}{text}[$partcount] = '
                      <td>part - '.$part.'</td>';                       <td>'.&mt('part - ').$part.'</td>';
                 } else {                  } else {
                     $$triggered{$symb}{text}[$partcount] = '                      $$triggered{$symb}{text}[$partcount] = '
                      <td>single part</td>';                       <td>'.&mt('single part').'</td>';
                 }                  }
                 $$triggered{$symb}{text}[$partcount] .= '                  $$triggered{$symb}{text}[$partcount] .= '
                      <td>'.$stats{$part}{users}.'</td>                       <td>'.$stats{$part}{users}.'</td>
                      <td>'.$stats{$part}{attempts}.'</td>                       <td>'.$stats{$part}{attempts}.'</td>
                      <td>'.$stats{$part}{degdiff}.'</td>                       <td>'.$stats{$part}{degdiff}.'</td>
                      <td>'.$lastreset{$part}.'</td>                       <td>'.$lastreset{$part}.'</td>';
                      <td><input type="checkbox" name="'.$resetname.'" /><input type="hidden" name="'.$resettitle.'" value="'.&escape($$triggered{$symb}{title}).'" /></td>';                  if ($checkallowed->{'resetcounters'}) {
                       $$triggered{$symb}{text}[$partcount] .=
                           '<td><input type="checkbox" name="'.$resetname.'" />'.
                           '<input type="hidden" name="'.$resettitle.'" value="'.&escape($$triggered{$symb}{title}).'" /></td>';
                   }
                 $partcount ++;                  $partcount ++;
             }              }
             $$triggered{$symb}{numparts} = $partcount;              $$triggered{$symb}{numparts} = $partcount;
Line 916  sub get_curr_thresholds { Line 1256  sub get_curr_thresholds {
     my $thresholdcount = 0;      my $thresholdcount = 0;
     my ($tmp) = %thresholdsettings;      my ($tmp) = %thresholdsettings;
     unless ($tmp =~ /^(con_lost|error|no_such_host)/i) {      unless ($tmp =~ /^(con_lost|error|no_such_host)/i) {
         foreach my $item (keys %{$threshold}) {           foreach my $item (keys(%{$threshold})) { 
             if (exists($thresholdsettings{$cid.':threshold_'.$item})) {              if (exists($thresholdsettings{$cid.':threshold_'.$item})) {
                 $$threshold{$item} =                   $$threshold{$item} = 
                              $thresholdsettings{$cid.':threshold_'.$item};                               $thresholdsettings{$cid.':threshold_'.$item};
Line 931  sub get_curr_thresholds { Line 1271  sub get_curr_thresholds {
                                               $cdom,$crs,'internal.threshold');                                                $cdom,$crs,'internal.threshold');
     my ($temp) = %coursesettings;      my ($temp) = %coursesettings;
     unless ($temp =~ /^(con_lost|error|no_such_host)/i) {        unless ($temp =~ /^(con_lost|error|no_such_host)/i) {  
         foreach my $item (keys %{$threshold}) {          foreach my $item (keys(%{$threshold})) {
             unless (exists($thresholdsettings{$cid.':threshold_'.$item})) {              unless (exists($thresholdsettings{$cid.':threshold_'.$item})) {
                 if (exists($coursesettings{'internal.threshold_'.$item})) {                  if (exists($coursesettings{'internal.threshold_'.$item})) {
                     $$threshold{$item} =                       $$threshold{$item} = 
Line 956  sub get_current { Line 1296  sub get_current {
 }  }
   
 sub process_reset {  sub process_reset {
     my ($dom,$crs) = @_;      my ($dom,$crs,$checkallowed) = @_;
       if (!$checkallowed->{'resetcounters'}) {
           return '<b>'.&mt('You do not have the required privileges to reset counters').
                  '</b><br />';
       }
     my $result = '<b>'.&mt('Counters reset for following problems (and parts):').      my $result = '<b>'.&mt('Counters reset for following problems (and parts):').
                            '</b><br />';                             '</b><br />';
     my @agg_types = ('attempts','users','correct');      my @agg_types = ('attempts','users','correct');
Line 997  sub process_reset { Line 1341  sub process_reset {
   
 sub process_update {  sub process_update {
     my ($uname,$udom,$threshold_titles) = @_;      my ($uname,$udom,$threshold_titles) = @_;
     my $setoutput = '<b>Changes to threshold(s) for problem tracking:</b><br />';      my $setoutput = '<b>'.&mt('Changes to threshold(s) for problem tracking:').'</b><br/><br />';
     foreach (keys %env) {      foreach my $key (keys(%env)) {
         next if ($_!~/^form\.(.+)\_setparmval$/);          my $name;
         my $name  = $1;          if ($key =~/^form\.(.+)\_setparmval$/) {
               $name  = $1;
           } else {
               next;
           }
         my $value = $env{'form.'.$name.'_value'};          my $value = $env{'form.'.$name.'_value'};
         if ($name && defined($value)) {          if ($name && defined($value) && ($value ne '')) {
             my $put_result = &Apache::lonnet::put('nohist_whatsnew',              my $put_result = &Apache::lonnet::put('nohist_whatsnew',
                                                   {$name=>$value},$udom,$uname);                                                    {$name=>$value},$udom,$uname);
                         
             my ($shortname) = ($name =~ /^\Q$env{'request.course.id'}\E:threshold_(.+)$/);              my ($shortname) = ($name =~ /^\Q$env{'request.course.id'}\E:threshold_(.+)$/);
             if ($put_result eq 'ok') {              if ($put_result eq 'ok') {
                 $setoutput.=&mt('Set threshold for [_1] to [_2]',                  $setoutput.= &Apache::lonhtmlcommon::confirm_success(&mt('Set threshold for [_1] to [_2]',
  '<b>'.$$threshold_titles{$shortname}.'</b>',   '<b>'.$$threshold_titles{$shortname}.'</b>',
  '<b>'.$value.'</b>').'<br />';   '<b>'.$value.'</b>').'<br />');
     } else {      } else {
                 $setoutput.=&mt('Unable to set threshold for [_1] to [_2] due to [_3].',                  $setoutput.= &Apache::lonhtmlcommon::confirm_success(&mt('Unable to set threshold for [_1] to [_2] due to [_3].',
  '<b>'.$name.'</b>','<b>'.$value.'</b>',   '<b>'.$name.'</b>','<b>'.$value.'</b>',
  '<tt>'.$put_result.'</tt>').'<br />';   '<tt>'.$put_result.'</tt>').'<br />',1);
             }              }
         }          }
     }      }
     return $setoutput;      return &Apache::loncommon::confirmwrapper($setoutput);
 }  }
   
 sub getnormalmail {  sub getnormalmail {
     my ($newmsgs) = @_;      my ($newmsgs) = @_;
 # Check for unread mail in course  # Check for unread messages in user's INBOX (which were sent in context of current course).
     my $msgcount = 0;      my $msgcount = 0;
       my @messages = &Apache::lonnet::getkeys('nohist_email');
     my @messages = sort(&Apache::lonnet::getkeys('nohist_email'));      return $msgcount if (!@messages);
     foreach my $message (@messages) {      my %emailstatus = &Apache::lonnet::dump('email_status');
  my $msgid=&escape($message);      foreach my $msgid (sort(@messages)) {
         my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)=          if ((!$emailstatus{$msgid}) || ($emailstatus{$msgid} eq 'new')) {
             &Apache::lonmsg::unpackmsgid($msgid);              my $skipstatus;
         if (($fromcid) && ($fromcid eq $env{'request.course.id'})) {              if ($emailstatus{$msgid} eq 'new') {
             if (defined($sendtime) && $sendtime!~/error/) {                  $skipstatus = 1;
                 my $numsendtime = $sendtime;              }
                 $sendtime = &Apache::lonlocal::locallocaltime($sendtime);              my $esc_msgid = &escape($msgid);
                 if ($status eq 'new') {              my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)=
                     $msgcount ++;                  &Apache::lonmsg::unpackmsgid($esc_msgid,undef,$skipstatus,undef,
                     if ($shortsubj eq '') {                                               $env{'request.course.id'});
                         $shortsubj = &mt('No subject');              if (($fromcid) && ($fromcid eq $env{'request.course.id'})) {
                   if (defined($sendtime) && $sendtime!~/error/) {
                       if (($emailstatus{$msgid} eq 'new') || ($status eq 'new')) {
                           $sendtime = &Apache::lonlocal::locallocaltime($sendtime);
           $msgcount ++;
                           if ($shortsubj eq '') {
                               $shortsubj = &mt('No subject');
                           }
                           push(@{$newmsgs}, {
                               msgid    => $esc_msgid,
                               sendtime => $sendtime,
                               shortsub => $shortsubj,
                               from     => $fromname,
                               fromdom  => $fromdom
                               });
                     }                      }
                     push(@{$newmsgs}, {  
                         msgid    => $msgid,  
                         sendtime => $sendtime,  
                         shortsub => $shortsubj,  
                         from     => $fromname,  
                         fromdom  => $fromdom  
                         });  
                 }                  }
             }              }
         }          }
Line 1056  sub getnormalmail { Line 1411  sub getnormalmail {
   
 sub getcritmail {  sub getcritmail {
     my ($critmsgs) = @_;       my ($critmsgs) = @_; 
 # Check for critical messages in course  # Check for critical messages which were sent in context of current course.
     my %what=&Apache::lonnet::dump('critical');      my %what=&Apache::lonnet::dump('critical');
     my $result = '';      my $result = '';
     my $critmsgcount = 0;      my $critmsgcount = 0;
     foreach my $msgid (sort(keys(%what))) {      foreach my $msgid (sort(keys(%what))) {
           my $esc_msgid = &escape($msgid);
         my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)=          my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)=
             &Apache::lonmsg::unpackmsgid($msgid);              &Apache::lonmsg::unpackmsgid($esc_msgid,undef,1,undef,
                                            $env{'request.course.id'});
         if (($fromcid) && ($fromcid eq  $env{'request.course.id'})) {          if (($fromcid) && ($fromcid eq  $env{'request.course.id'})) {
             if (defined($sendtime) && $sendtime!~/error/) {              if (defined($sendtime) && $sendtime!~/error/) {
                 my $numsendtime = $sendtime;  
                 $sendtime = &Apache::lonlocal::locallocaltime($sendtime);                  $sendtime = &Apache::lonlocal::locallocaltime($sendtime);
                 $critmsgcount ++;                  $critmsgcount ++;
                 if ($shortsubj eq '') {                  if ($shortsubj eq '') {
                     $shortsubj = &mt('No subject');                      $shortsubj = &mt('No subject');
                 }                  }
                 push(@{$critmsgs}, {                  push(@{$critmsgs}, {
                         msgid    => $msgid,                          msgid    => $esc_msgid,
                         sendtime => $sendtime,                          sendtime => $sendtime,
                         shortsub => $shortsubj,                          shortsub => $shortsubj,
                         from     => $fromname,                          from     => $fromname,
Line 1084  sub getcritmail { Line 1440  sub getcritmail {
     return $critmsgcount;      return $critmsgcount;
 }  }
   
   sub getexpired {
       my ($rolechgs,$rolechgtime,$status,$classlist) = @_;
       my $expirecount = &getrolechanges($rolechgs,$rolechgtime,$status,$classlist);
       return $expirecount;
   }
   
   sub getactivated {
       my ($rolechgs,$rolechgtime,$status,$classlist) = @_;
       my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
       my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
       my $now = time();
       my $context = 'course';
       my ($permission,$allowed) =
           &Apache::lonuserutils::get_permission($context);
       my $viewablesec = &Apache::lonuserutils::viewable_section($permission);
       my %changes=&Apache::lonnet::dump('nohist_rolelog',$cdom,$cnum);
       my (%stucounted,%advcounted);
       my $activatedcount = 0;
       if (keys(%changes) > 0) {
           foreach my $chg (keys(%changes)) {
               if (ref($changes{$chg}) eq 'HASH') {
                   next if ($changes{$chg}{'delflag'});
                   if ($rolechgtime > 0) {
                       next if ($changes{$chg}{'exe_time'} < $rolechgtime);
                   }
                   if ($changes{$chg}{'exe_time'}) {
                       my $timestamp = $changes{$chg}{'exe_time'};
                       if (ref($changes{$chg}{'logentry'}) eq 'HASH') {
                           my $end = $changes{$chg}{'logentry'}{'end'};
                           next if ($end && $end <= $now);
                           my $start = $changes{$chg}{'logentry'}{'start'};
                           next if ($start >= $timestamp);
                           my $section = $changes{$chg}{'logentry'}{'section'};
                           if (($viewablesec ne '') && ($section ne '')) {
                               next if ($viewablesec ne $section);
                           }
                           my $role = $changes{$chg}{'logentry'}{'role'};
                           my $uname = $changes{$chg}{'uname'};
                           my $udom = $changes{$chg}{'udom'};
                           if ($role eq 'st') {
                               $stucounted{$uname.':'.$udom.':'.$section} = $start.':'.$end;
                           } else {
                               $advcounted{$uname.':'.$udom.':'.$role.':'.$section} = $start.':'.$end;
                           }
                           my %chginfo = (
                                          'section' => $section,
                                          'uname'   => $uname,
                                          'udom'    => $udom,
                                          'role'    => $role,
                                          'status'  => $status,
                           );
                           $activatedcount ++;
                           push (@{$rolechgs->{$timestamp}},\%chginfo);
                       }
                   }
               }
           }
       }
       $activatedcount += &getrolechanges($rolechgs,$rolechgtime,$status,$classlist,\%stucounted,
                                          \%advcounted);
       return $activatedcount;
   }
   
   sub getrolechanges {
       my ($rolechgs,$rolechgtime,$status,$classlist,$stucountref,$advcountref) = @_;
       my (%stucounted,%advcounted);
       if (ref($stucountref) eq 'HASH') {
           %stucounted = %{$stucountref};
       }
       if (ref($advcountref) eq 'HASH') {
           %advcounted = %{$advcountref};
       }
       my $withsec = 1;
       my $hidepriv = 1;
       my $context = 'course';
       my @statuses = ($status);
       my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
       my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
       my $now = time();
       my ($permission,$allowed) =
           &Apache::lonuserutils::get_permission($context);
       my $viewablesec = &Apache::lonuserutils::viewable_section($permission);
       my $secidx = &Apache::loncoursedata::CL_SECTION();
       my $startidx = &Apache::loncoursedata::CL_START();
       my $endidx = &Apache::loncoursedata::CL_END();
       my $rolechgcount = 0;
       if (ref($classlist) eq 'HASH') {
           foreach my $key (keys(%{$classlist})) {
               my ($userstatus,$eventtime);   
               my $student = $classlist->{$key};
               if (ref($student) eq 'ARRAY') {
                   my $start = $student->[$startidx];
                   my $end = $student->[$endidx];
                   my $sec = $student->[$secidx]; 
                   my ($stuname,$studom) = split(/:/,$key);
                   if ($status eq 'active') {
                       if (exists($stucounted{$key.':'.$sec})) {
                           next;
                       }
                   }
                   if (($end == 0) || ($end > $start)) {
                       if ($start <= $now) {
                           if ($end && $end < $now) {
                               if ($rolechgtime > 0) {
                                   if ($end > $rolechgtime) {
                                       $userstatus = 'previous';
                                   }
                               } else {
                                   $userstatus = 'previous';
                               }
                           } else {
                               if ($rolechgtime > 0) {
                                   if ($start >= $rolechgtime) {
                                       $userstatus = 'active';
                                   }
                               } else {
                                   $userstatus = 'active';
                               }
                           }
                       }
                   }
                   next if ($userstatus ne $status);
                   if ($status eq 'active') {
                       $eventtime = $start;
                   } else {
                       $eventtime = $end;
                   }
                   if (($viewablesec ne '') && ($sec ne '')) {
                       next if ($viewablesec ne $sec);
                   }
                   my %chginfo = (
                                   'section' => $sec,
                                   'uname'   => $stuname,
                                   'udom'    => $studom,
                                   'role'    => 'st', 
                                   'status'  => $userstatus,
                                 );
                   $rolechgcount ++;
                   push(@{$rolechgs->{$eventtime}},\%chginfo);
               }
           }
       }
       my %advrolehash = &Apache::lonnet::get_my_roles($cnum,$cdom,undef,
                                 \@statuses,undef,undef,$withsec,$hidepriv);
       foreach my $item (keys(%advrolehash)) {
           my ($userstatus,$eventtime);
           my ($uname,$udom,$role,$section) = split(/:/,$item,-1);
           my ($start,$end) = split(/:/,$advrolehash{$item});
           if ($start eq '-1' && $end eq '-1') {
               next;
           } else {
               if ($status eq 'active') {
                   if (exists($advcounted{$item})) {
                       next;
                   }
               }
               if (($end == 0) || ($end > $start)) {
                   if ($start <= $now) {
                       if ($end && $end < $now) {
                           if ($rolechgtime > 0) {
                               if ($end > $rolechgtime) {
                                   $userstatus = 'previous';
                               }
                           } else {
                               $userstatus = 'previous';
                           }
                       } else {
                           if ($rolechgtime > 0) {
                               if ($start >= $rolechgtime) {
                                   $userstatus = 'active';
                               }
                           } else {
                               $userstatus = 'active';
                           }
                       }
                   }
               }
               next if ($userstatus ne $status);
               if ($status eq 'active') {
                   $eventtime = $start;
               } else {
                   $eventtime = $end;
               }
           }
           if (($viewablesec ne '') && ($section ne '')) {
               next if ($viewablesec ne $section);
           }
           my %chginfo = ( 
                           'section' => $section,
                           'uname'   => $uname,
                           'udom'    => $udom,
                           'role'    => $role,
                           'status'  => $userstatus,    
                         );
           $rolechgcount ++; 
           push (@{$rolechgs->{$eventtime}},\%chginfo); 
       }
       return $rolechgcount;
   }
   
   sub getloggedin {
       my ($cdom,$crs,$lastlogins,$starttime) = @_;
       my $context = 'course';
       my ($permission,$allowed) =
           &Apache::lonuserutils::get_permission($context);
       my $viewablesec = &Apache::lonuserutils::viewable_section($permission);
       my %crslogins=&Apache::lonnet::dump('nohist_crslastlogin',$cdom,$crs);
       my $logincount = 0;
       my ($tmp) = keys(%crslogins);
       unless ($tmp =~ /^(con_lost|error|no_such_host)/i) {
           if (keys(%crslogins) > 0) {
               foreach my $key (keys(%crslogins)) {
                   my ($uname,$udom,$section,$role) = split(/:/,$key);
                   my $eventtime = $crslogins{$key};
                   if ($eventtime > $starttime) {
                       if (($viewablesec ne '') && ($section ne '')) {
                           next if ($viewablesec ne $section);
                       }
                       my %chginfo = (
                                      'section' => $section,
                                      'uname'   => $uname,
                                      'udom'    => $udom,
                                      'role'    => $role,
                       );
                       $logincount ++;
                       push (@{$lastlogins->{$eventtime}},\%chginfo);
                   }
               }
           }
       }
       return $logincount;
   }
   
   sub getsessions {
       my ($cdom,$cnum,$sessions,$lastactive,$classlist) = @_;
       my $context = 'course';
       my ($permission,$allowed) =
           &Apache::lonuserutils::get_permission($context);
       my %crs_sessions = &Apache::lonnet::get_course_sessions($cnum,$cdom,$lastactive);
       my $sessioncount = 0;
       if (keys(%crs_sessions) > 0) {
           if (ref($classlist) eq 'HASH') {
               my $viewablesec = &Apache::lonuserutils::viewable_section($permission);
               my $secidx = &Apache::loncoursedata::CL_SECTION();
               my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'_'.$cnum,1);
               my %personnel;
               foreach my $role (sort(keys(%coursepersonnel))) {
                   my ($rolecode,$section);
                   if ($role =~ /:/) {
                       ($rolecode,$section) = split(/:/,$role);
                   } else {
                       $rolecode = $role;
                   }
                   if ($viewablesec ne '') {
                       next if ($viewablesec ne $section);
                   }
                   foreach my $user (split(/\,/,$coursepersonnel{$role})) {
                       push(@{$personnel{$user}{$rolecode}},$section);
                   }
               }
               foreach my $key (keys(%crs_sessions)) {
                   if (exists($classlist->{$key})) {
                       my $student = $classlist->{$key};
                       my $section = $student->[$secidx];
                       my $lastaccess = $crs_sessions{$key};
                       if ($viewablesec ne '') {
                           next if ($viewablesec ne $section);
                       }
                       my ($stuname,$studom) = split(/:/,$key);
                       my %info = (
                                    'section' => $section,
                                    'role'    => 'st',
                                    'uname'   => $stuname,
                                    'udom'    => $studom,
                       );
                       $sessioncount ++;
                       push(@{$sessions->{$lastaccess}},\%info);
                   } elsif (exists($personnel{$key})) {
                       my $lastaccess = $crs_sessions{$key};
                       my ($uname,$udom) = split(/:/,$key);
                       if (ref($personnel{$key}) eq 'HASH') {
                           my ($showrole,$showsec);
                           foreach my $possrole ('cc','co','in','ta','ep','ad','st') {
                               if (exists($personnel{$key}{$possrole})) {
                                   $showrole = $possrole;
                                   $showsec = join(', ',@{$personnel{$key}{$possrole}});
                                   last;
                               }
                           }
                           my %info = (
                                        'section' => $showsec,
                                        'role'    => $showrole,
                                        'uname'   => $uname,
                                        'udom'    => $udom,
                           );
                           $sessioncount ++;
                           push(@{$sessions->{$lastaccess}},\%info);
                       }
                   }
               }
           }
       }
       return $sessioncount;
   }
   
 sub checkversions {  sub checkversions {
     my ($cdom,$crs,$navmap,$changed,$starttime) = @_;      my ($cdom,$crs,$navmap,$changed,$starttime) = @_;
Line 1101  sub checkversions { Line 1761  sub checkversions {
                                                      'lastrevisiondate');                                                       'lastrevisiondate');
                     $revdate =  &Apache::lonlocal::locallocaltime($revdate);                      $revdate =  &Apache::lonlocal::locallocaltime($revdate);
                     my $linkurl=&Apache::lonnet::clutter($key);                      my $linkurl=&Apache::lonnet::clutter($key);
                     my $usedversion=$navmap->usedVersion('version_'.$linkurl);                      my $usedversion=$navmap->usedVersion($linkurl);
                     my @resources = $navmap->getResourceByUrl($linkurl,1);                      my @resources = $navmap->getResourceByUrl($linkurl,1);
                     if (($usedversion) && ($usedversion ne 'mostrecent')) {                      if (($usedversion) && ($usedversion ne 'mostrecent')) {
                         $version = $usedversion;                               $version = $usedversion;     
Line 1126  sub checkversions { Line 1786  sub checkversions {
 }  }
   
 sub display_handgrade {  sub display_handgrade {
     my ($r,$tograde,$rowColor1,$rowColor2,$ungraded) = @_;      my ($r,$tograde,$ungraded,$itemserror) = @_;
     my $rowColor;  
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                         'prna' => 'Problem Name',                          'prna' => 'Problem Name',
                         'nmun' => 'Number ungraded',                          'nmun' => 'Number ungraded',
                         'nopr' => 'No problems require handgrading',                          'nopr' => 'No problems require handgrading',
     );      );
     if (@{$tograde} > 0) {      if (@{$tograde} > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.$lt{'prna'}.'</small></b></td><td align="right"><b><small>'.$lt{'nmun'}.'</small></b></td></tr>');          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
                     $lt{'prna'}.'</td><td class="LC_right_item">'.
                     $lt{'nmun'}.'</td></tr>');
         my $rowNum = 0;          my $rowNum = 0;
         foreach my $res (@{$tograde}) {          foreach my $res (@{$tograde}) {
             if ($rowNum %2 == 1) {              $rowNum ++;
                 $rowColor = $rowColor1;              my $css_class = $rowNum%2?' class="LC_odd_row"':'';
               my $linkurl='/adm/grades';
               if ($$ungraded{$res}{'enclink'}) {
                   $linkurl.='?symb='.$$ungraded{$res}{'encsymb'};
             } else {              } else {
                 $rowColor = $rowColor2;                  $linkurl.='?symb='.&escape($res);
             }              }
             my ($map,$id,$url)=&Apache::lonnet::decode_symb($res);              $linkurl.='&amp;command=ungraded';
             my $linkurl=&Apache::lonnet::clutter($url);              $r->print('<tr'.$css_class.'><td><a href="'.$linkurl.'">'.$$ungraded{$res}{title}.'</a></td><td class="LC_right_item">'.$$ungraded{$res}{count}.'</td></tr>');
             $linkurl .= '?symb='.&escape($res);  
                                                                                  
             $r->print('<tr bgcolor="'.$rowColor.'"><td><a href="'.$linkurl.'"><small>'.$$ungraded{$res}{title}.'</small></a></td><td align="right"><small>'.$$ungraded{$res}{count}.'</small></td></tr>');  
             $rowNum ++;  
         }          }
       } elsif ($itemserror) {
           $r->print('<tr class="LC_empty_row"><td>'.$itemserror.'</td></tr>');
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff"><br><center><i><b><small>&nbsp;&nbsp;'.$lt{'nopr'}.'&nbsp;&nbsp;</small><br><br></b></i></td></tr>');          $r->print('<tr class="LC_empty_row"><td>'.$lt{'nopr'}.'</td></tr>');
     }      }
 }  }
   
 sub display_haserrors {  sub display_haserrors {
     my ($r,$bombs,$rowColor1,$rowColor2,$bombed,$res_title) = @_;      my ($r,$bombs,$bombed,$res_title,$itemserror) = @_;
     my $bombnum = 0;      my $bombnum = 0;
     my $rowColor;  
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                                    reso => 'Resource',                                     reso => 'Resource',
                                    nmer => 'Number of errors',                                     nmer => 'Number of errors',
                                    noer => 'No problems with errors',                                     noer => 'No problems with errors',
     );      );
     if (@{$bombs} > 0) {      if (@{$bombs} > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.$lt{'reso'}.'</small></b></td><td align="right"><b><small>'.$lt{'nmer'}.'</small></b></td></tr>');          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
                     $lt{'reso'}.'</td><td class="LC_right_item">'.
                     $lt{'nmer'}.'</td></tr>');
         @{$bombs} = sort { &cmp_title($a,$b,$res_title) } @{$bombs};          @{$bombs} = sort { &cmp_title($a,$b,$res_title) } @{$bombs};
         foreach my $bomb (@{$bombs}) {          foreach my $bomb (@{$bombs}) {
             if ($bombnum %2 == 1) {  
                 $rowColor = $rowColor1;  
             } else {  
                 $rowColor = $rowColor2;  
             }  
             $r->print('<tr bgcolor="'.$rowColor.'"><td><small>'.$$bombed{$bomb}{errorlink}.'</small></td><td align="right"><small>'.$$bombed{$bomb}{errorcount}.'</small></td></tr>');  
             $bombnum ++;              $bombnum ++;
               my $css_class = $bombnum%2?' class="LC_odd_row"':'';
               $r->print('<tr'.$css_class.'><td>'.$$bombed{$bomb}{errorlink}.
                         '</td><td class="LC_right_item">'.
                         $$bombed{$bomb}{errorcount}.'</td></tr>');
         }          }
       } elsif ($itemserror) {
           $r->print('<tr class="LC_empty_row"><td>'.$itemserror.'</td></tr>');
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff"><br /><center><b><i><small>'.$lt{'noer'}.'</small></i></b></center><br /></td></tr>');          $r->print('<tr class="LC_empty_row"><td>'.$lt{'noer'}.'</td></tr>');
     }      }
     return;      return;
 }  }
   
 sub display_abovethreshold {  sub display_abovethreshold {
     my ($r,$refpage,$warnings,$triggered,$res_title) = @_;      my ($r,$refpage,$warnings,$triggered,$res_title,$itemserror,$checkallowed) = @_;
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                  reso => 'Resource',                   reso => 'Resource',
                  part => 'Part',                   part => 'Part',
Line 1196  sub display_abovethreshold { Line 1859  sub display_abovethreshold {
     );      );
     if (@{$warnings} > 0) {      if (@{$warnings} > 0) {
         @{$warnings} = sort { &cmp_title($a,$b,$res_title) } @{$warnings};          @{$warnings} = sort { &cmp_title($a,$b,$res_title) } @{$warnings};
         $r->print('<form name="reset_tracking" method="post" action="/adm/whatsnew">'.  
                 ' <input type="hidden" name="command" value="reset" />'."\n".  
                 ' <input type="hidden" name="refpage" value="'.$refpage.'" />'.  
                 "\n");  
         $r->print('<tr class="LC_info_row">'.          $r->print('<tr class="LC_info_row">'.
   '<td class="LC_first_item">'.$lt{'reso'}.'</td>'.    '<td class="LC_left_item">'.$lt{'reso'}.
                     '<input type="hidden" name="command" value="" /></td>'.
   '<td>'.$lt{'part'}.'</td><td>'.$lt{'nust'}.'</td>'.    '<td>'.$lt{'part'}.'</td><td>'.$lt{'nust'}.'</td>'.
   '<td>'.$lt{'avat'}.'</td><td>'.$lt{'dedi'}.'</td>'.    '<td>'.$lt{'avat'}.'</td><td>'.$lt{'dedi'}.'</td>'.
   '<td>'.$lt{'lare'}.'</td><td>'.$lt{'reco'}.'</td></tr>');    '<td>'.$lt{'lare'}.'</td>');
           if ($checkallowed->{'resetcounters'}) {
               $r->print('<td  class="LC_right_item">'.$lt{'reco'}.'</td>');
           }
           $r->print('</tr>');
  my $row;   my $row;
         foreach my $res (@{$warnings}) {          foreach my $res (@{$warnings}) {
     $row++;      $row++;
Line 1215  sub display_abovethreshold { Line 1879  sub display_abovethreshold {
                 $rowspan = 'rowspan="'.$$triggered{$res}{numparts}.'"';                  $rowspan = 'rowspan="'.$$triggered{$res}{numparts}.'"';
             }              }
             $linkurl .= '?symb='.&escape($res);              $linkurl .= '?symb='.&escape($res);
             my $css_class = $row%2?'LC_odd_row':'';              if ($$triggered{$res}{'enclink'}) {
             $r->print('<tr class="'.$css_class.'">'.                  $linkurl = 
                     $$triggered{$res}{'enclink'}.'?symb='.$$triggered{$res}{'encsymb'};
               }
               my $css_class = $row%2?' class="LC_odd_row"':'';
               $r->print('<tr'.$css_class.'>'.
       '<td class="LC_first_item" '.$rowspan.'><a href="'.$linkurl.'">'.        '<td class="LC_first_item" '.$rowspan.'><a href="'.$linkurl.'">'.
       $$triggered{$res}{title}.'</a></td>');        $$triggered{$res}{title}.'</a></td>');
                       if (ref($$triggered{$res}{text}) eq 'ARRAY') {                        if (ref($$triggered{$res}{text}) eq 'ARRAY') {
Line 1226  sub display_abovethreshold { Line 1894  sub display_abovethreshold {
             if (ref($$triggered{$res}{text}) eq 'ARRAY') {              if (ref($$triggered{$res}{text}) eq 'ARRAY') {
                 if (@{$$triggered{$res}{text}} > 1) {                  if (@{$$triggered{$res}{text}} > 1) {
                     for (my $i=1; $i<@{$$triggered{$res}{text}}; $i++) {                      for (my $i=1; $i<@{$$triggered{$res}{text}}; $i++) {
                         $r->print('<tr class="'.$css_class.'">'.                          $r->print('<tr '.$css_class.'>'.
                                   $$triggered{$res}{text}[$i].'</tr>');                                    $$triggered{$res}{text}[$i].'</tr>');
                     }                      }
                 }                  }
             }              }
         }          }
         $r->print('<tr class="LC_info_row"><td colspan="7"><br /><input type="submit" name="counters" value="'.$lt{'rese'}.'" /></td></tr></form>');          if ($checkallowed->{'resetcounters'}) {
               $r->print('<tr class="LC_info_row"><td colspan="7" class="LC_right_item"><br /><input type="button" name="counters" value="'.$lt{'rese'}.'" onclick="javascript:thresholdreset();" /></td></tr>');
           }
       } elsif ($itemserror) {
           $r->print('<tr class="LC_empty_row"><td>'.$itemserror.'</td></tr>');
     } else {      } else {
         $r->print('<tr class="LC_empty_row"><td>'.$lt{'nopr'}.'</td></tr>');          $r->print('<tr class="LC_empty_row"><td>'.$lt{'nopr'}.'</td></tr>');
     }      }
 }  }
   
 sub display_versionchanges {  sub display_versionchanges {
     my ($r,$changed,$res_title,$rowColor1,$rowColor2,$interval) = @_;      my ($r,$changed,$res_title,$interval,$itemserror) = @_;
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
         'reso' => 'Resource',          'reso' => 'Resource',
         'revd' => 'Last revised',          'revd' => 'Last revised',
         'newv' => 'New version',          'newv' => 'New version',
         'veru' => 'Version used',          'veru' => 'Version used',
         'noup' => 'No updated versions',   
     );      );
     my $rowColor;  
     if (keys(%{$changed}) > 0) {      if (keys(%{$changed}) > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.$lt{'reso'}.'</small></b></td><td><b><small>'.$lt{'revd'}.'</small></b></td><td><b><small>'.$lt{'newv'}.'</small></b></td><td><b><small>'.$lt{'veru'}.'</small></b></td></tr>');          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
                             $lt{'reso'}.'</td><td>'.$lt{'revd'}.'</td><td>'.
                             $lt{'newv'}.'</td><td class="LC_right_item">'.
                     $lt{'veru'}.'</td></tr>');
         my @changes = sort { &cmp_title($a,$b,$res_title) } keys(%{$changed});          my @changes = sort { &cmp_title($a,$b,$res_title) } keys(%{$changed});
         my $changenum = 0;          my $changenum = 0;
         foreach my $item (@changes) {          foreach my $item (@changes) {
             if ($changenum %2 == 1) {              $changenum ++;
                 $rowColor = $rowColor1;              my $css_class = $changenum%2?' class="LC_odd_row"':'';
             } else {  
                 $rowColor = $rowColor2;  
             }  
             my ($map,$id,$url)=&Apache::lonnet::decode_symb($item);              my ($map,$id,$url)=&Apache::lonnet::decode_symb($item);
             my $linkurl=&Apache::lonnet::clutter($url);              my $linkurl=&Apache::lonnet::clutter($url);
             $linkurl .= '?symb='.&escape($item);              $linkurl .= '?symb='.&escape($item);
   
             $r->print('<tr bgcolor="'.$rowColor.'"><td><small><a href="'.$linkurl.'">'.$$res_title{$item}.'</a></small></td><td><small>'.$$changed{$item}{'revdate'}.'</small></td><td><small>'.$$changed{$item}{'current'}.'</small></td><td><small>'.$$changed{$item}{'version'}.'</small></td></tr>');              $r->print('<tr'.$css_class.'><td><a href="'.$linkurl.'">'.
             $changenum ++;                        $$res_title{$item}.'</a></td><td>'.
                         $$changed{$item}{'revdate'}.'</td><td>'.
                         $$changed{$item}{'current'}.'</td><td>'.
                         $$changed{$item}{'version'}.'</td></tr>');
         }          }
       } elsif ($itemserror) {
           $r->print('<tr class="LC_empty_row"><td>'.$itemserror.'</td></tr>');
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff"><br /><center><b><i><small>'.$lt{'noup'}.' '.$interval.'</small></i></b></center><br /></td></tr>');          $r->print('<tr class="LC_empty_row"><td>'
                    .&mt('No '.$interval).'</td></tr>');
     }      }
     return;      return;
 }  }
    
   sub display_rolechanges {
       my ($r,$chgcount,$changed,$interval,$crstype,$classlist) = @_;
       my $now = time();
       my %lt = &Apache::lonlocal::texthash(
           'user'  => 'User',
           'tich'  => 'Time of change',
           'role'  => 'Role',
           'sec'   => 'Section',
           'status'  => 'Status',
       );
       if ($chgcount) {
           $r->print('<tr class="LC_info_row">'.
                     '<td class="LC_left_item">'.$lt{'tich'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'user'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'role'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'sec'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'status'}.'</td></tr>');
           if (ref($changed) eq 'HASH') {
               my @changes = sort { $b <=> $a } (keys(%{$changed}));
               my $changenum = 0;
               my $fullnameidx = &Apache::loncoursedata::CL_FULLNAME();
               foreach my $item (@changes) {
                   if (ref($changed->{$item}) eq 'ARRAY') {
                       foreach my $chg (@{$changed->{$item}}) {
                           if (ref($chg) eq 'HASH') {
                               my $section;
                               my $role = 
                                   &Apache::lonnet::plaintext($chg->{'role'},$crstype);
                               my $status = &mt($chg->{'status'});
                               if ($chg->{'section'} eq '') {
                                   $section = &mt('none');
                               } else {
                                   $section = $chg->{'section'};
                               }
                               my $uname = $chg->{'uname'};
                               my $udom = $chg->{'udom'};
                               $changenum ++;
                               my $css_class = $changenum%2?' class="LC_odd_row"':'';
                               my $fullname;
                               if (ref($classlist->{$uname.':'.$udom}) eq 'ARRAY') {
                                   $fullname = $classlist->{$uname.':'.$udom}->[$fullnameidx];
                               } else {
                                   $fullname = &Apache::loncommon::plainname($uname,$udom,'lastname');
                               }
                               my $link = 
                                   &Apache::loncommon::aboutmewrapper($fullname,$uname,$udom);
                               $r->print('<tr'.$css_class.'>'.
                                         '<td>'.&Apache::lonlocal::locallocaltime($item).'</td>'.
                                         '<td>'.$link.'</td>'.
                                         '<td>'.$role.'</td>'.
                                         '<td>'.$section.'</td>'.
                                         '<td>'.$status.'</td></tr>');
                           }
                       }
                   }
               }
           }
       } else {
           $r->print('<tr class="LC_empty_row"><td>'
                    .&mt('There are no '.$interval).'</td></tr>');
       }
       return;
   }
   
   sub display_activity {
       my ($r,$context,$count,$details,$interval,$crstype,$classlist) = @_;
       return unless (ref($classlist) eq 'HASH');
       my %lt = &Apache::lonlocal::texthash(
           'user'   => 'User',
           'role'   => 'Role',
           'sec'    => 'Section',
           'number' => 'Total number of logins',
       );
       my $prefix = 'login';
       if ($context eq 'sessions') {
           $lt{'number'} = &mt('Total number of active user sessions');
           $lt{'active'} = &mt('Last active');
           $prefix = 'session';
       }
       if ($count) {
   
           my $hdr = '<tr class="LC_info_row" style="display:none" id="'.$prefix.'titledet">'.
                     '<td class="LC_left_item">'.$lt{'user'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'role'}.'</td>'.
                     '<td class="LC_left_item">'.$lt{'sec'}.'</td>';
           if ($context eq 'sessions') {
               $hdr .= '<td class="LC_left_item">'.$lt{'active'}.'</td>';
           }
           $hdr .= '</tr>'."\n".
                   '<tr class="LC_info_row" id="'.$prefix.'titlesum">'.
                   '<td class="LC_left_item">'.$lt{'number'}.'</td>'.
                   '<td class="LC_left_item">'.$lt{'role'}.'</td>'.
                   '<td class="LC_left_item">'.$lt{'sec'};
           my (%bylastname,%counts);
           if (ref($details) eq 'HASH') {
               my @items = sort { $b <=> $a } (keys(%{$details}));
               my $num = 0;
               my $fullnameidx = &Apache::loncoursedata::CL_FULLNAME();
               foreach my $item (@items) {
                   if (ref($details->{$item}) eq 'ARRAY') {
                       foreach my $user (@{$details->{$item}}) {
                           if (ref($user) eq 'HASH') {
                               my $section;
                               my $role =
                                   &Apache::lonnet::plaintext($user->{'role'},$crstype);
                               if ($user->{'section'} eq '') {
                                   $section = &mt('none');
                               } else {
                                   $section = $user->{'section'};
                               }
                               $counts{$user->{'role'}}{$section} ++;
                               my $uname = $user->{'uname'};
                               my $udom = $user->{'udom'};
                               my $fullname;
                               if (ref($classlist->{$uname.':'.$udom}) eq 'ARRAY') {
                                   $fullname = $classlist->{$uname.':'.$udom}->[$fullnameidx];
                               } else {
                                   $fullname = &Apache::loncommon::plainname($uname,$udom,'lastname');
                               }
                               my $link =
                                   &Apache::loncommon::aboutmewrapper($fullname,$uname,$udom);
                               my $entry = '<td>'.$link.'</td>'.
                                           '<td>'.$role.'</td>'.
                                           '<td>'.$section.'</td>';
                               if ($context eq 'sessions') {
                                   $entry .= '<td>'.&Apache::lonlocal::locallocaltime($item).'</td>';
                               }
                               push(@{$bylastname{$fullname}},$entry);
                           }
                       }
                   }
               }
               my $table;
               foreach my $person (sort(keys(%bylastname))) {
                   if (ref($bylastname{$person}) eq 'ARRAY') {
                       foreach my $item (@{$bylastname{$person}}) {
                           $num ++;
                           my $css_class = $num%2?' class="LC_odd_row"':'';
                           $table .= '<tr'.$css_class.' style="display:none;"  id="'.$prefix.'det_'.$num.'">'.$item.'</tr>';
                       }
                   }
               }
               my $numrow = 0;
               foreach my $role (sort(keys(%counts))) {
                   my $showrole = &Apache::lonnet::plaintext($role,$crstype);
                   if (ref($counts{$role}) eq 'HASH') {
                       foreach my $sec (sort { $b <=> $a } (keys(%{$counts{$role}}))) {
                           $numrow ++;
                           my $css_class = $numrow%2?' class="LC_odd_row"':'';
                           $table .= '<tr '.$css_class.' id="'.$prefix.'sum_'.$numrow.'">'.
                                     '<td>'.$counts{$role}{$sec}.'</td>'.
                                     '<td>'.$showrole.'</td>'.
                                     '<td>'.$sec.'</td></tr>';
                      }
                   }
               }
               $r->print($hdr.'<input type="hidden" name="'.$prefix.'count" value="'.$num.
                         '" /><input type="hidden" name="'.$prefix.'row" value="'.$numrow.
                         '" /></td></tr>'.$table);
           }
       } else {
           $r->print('<tr class="LC_empty_row"><td>'.
                     &mt('There are no '.$interval).
                     '<input type="hidden" name="'.$prefix.'count" value="'.$count.
                     '." /></td></tr>');
       }
       return;
   }
   
 sub display_coursediscussion {  sub display_coursediscussion {
     my ($r,$newdiscussions,$unread,$countunread,$res_title,$rowColor1,      my ($r,$newdiscussions,$unread,$countunread,$res_title,$itemserror) = @_;
                                                               $rowColor2) = @_;  
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
     my %lt = &Apache::lonlocal::texthash(      my %lt = &Apache::lonlocal::texthash(
                 'loca' => 'Location',                  'loca' => 'Location',
Line 1284  sub display_coursediscussion { Line 2126  sub display_coursediscussion {
                 'noun' => 'No unread posts in '.$lctype.' discussions',                  'noun' => 'No unread posts in '.$lctype.' discussions',
                 'tmlp' => 'Time of last post',                   'tmlp' => 'Time of last post', 
     );      );
     my $rowColor;  
     if (@{$newdiscussions} > 0) {      if (@{$newdiscussions} > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.$lt{'loca'}.          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
                   '</small></b></td><td><b><small>'.$lt{'type'}.                    $lt{'loca'}.'</td><td>'.
                   '</small></b>');                    $lt{'type'}.'</td>');
         if ($countunread eq 'on') {          if ($countunread eq 'on') {
             $r->print('<td><b><small>'.$lt{'tmlp'}.'</small></b></td>'.              $r->print('<td>'.$lt{'tmlp'}.'</td>'.
                       '<td align="right"><b><small>'.$lt{'numn'}.                        '<td class="LC_right_item">'.$lt{'numn'}.'</td>');
                       '</small></b></td>');  
         } else {          } else {
             $r->print('<td align="right"><b><small>'.$lt{'tmlp'}.              $r->print('<td class="LC_right_item">'.$lt{'tmlp'}.'</td>');
                          '</small></b></td>');  
         }          }
         $r->print("</tr>\n");          $r->print("</tr>\n");
         @{$newdiscussions} = sort { &cmp_title($a,$b,$res_title) }          @{$newdiscussions} = sort { &cmp_title($a,$b,$res_title) }
                                                             @{$newdiscussions};                                                              @{$newdiscussions};
         my $rowNum = 0;          my $rowNum = 0;
         foreach my $ressymb (@{$newdiscussions}) {          foreach my $ressymb (@{$newdiscussions}) {
               $rowNum ++;
             my $forum_title = $$unread{$ressymb}{'title'};              my $forum_title = $$unread{$ressymb}{'title'};
             my $type = 'Resource';              my $type = 'Resource';
             my $feedurl=&Apache::lonfeedback::get_feedurl($ressymb);              my $feedurl=&Apache::lonfeedback::get_feedurl($ressymb);
               my $disclink = $feedurl.'?symb='. &escape($$unread{$ressymb}{symb});
             if ($feedurl =~ /bulletinboard/) {              if ($feedurl =~ /bulletinboard/) {
                 $type = 'Bulletin Board';                  $type = 'Discussion Board';
             }              }
             if ($rowNum %2 == 1) {              if ($$unread{$ressymb}{'enclink'}) {
                 $rowColor = $rowColor1;                  $disclink = $$unread{$ressymb}{'enclink'}.'?symb='.$$unread{$ressymb}{'encsymb'};
             } else {  
                 $rowColor = $rowColor2;  
             }              }
               my $css_class = $rowNum%2?' class="LC_odd_row"':'';
             my $lastpost = &Apache::lonnavmaps::timeToHumanString(              my $lastpost = &Apache::lonnavmaps::timeToHumanString(
                                                $$unread{$ressymb}{'lastpost'});                                                 $$unread{$ressymb}{'lastpost'});
             $r->print('<tr bgcolor="'.$rowColor.'"><td><small><a href="'.$feedurl.'?symb='.$$unread{$ressymb}{symb}.'">'.$forum_title.'</a>&nbsp;</td><td><small>'.$type.'&nbsp;</small></td>');              $r->print('<tr'.$css_class.'><td><a href="'.$disclink.'">'.$forum_title.'</a>&nbsp;</td><td>'.&mt($type).'&nbsp;</td>');
             if ($countunread eq 'on') {              if ($countunread eq 'on') {
                 my $unreadnum = $$unread{$ressymb}{'unreadcount'};                  my $unreadnum = $$unread{$ressymb}{'unreadcount'};
                 $r->print('<td><small>'.$lastpost.'<small></td><td align="right">'.                  $r->print('<td>'.$lastpost.'</td><td class="LC_right_item">'.
                           '<small>',$unreadnum.'&nbsp;</small></td>');                            $unreadnum.'&nbsp;</td>');
             } else {              } else {
                 $r->print('<td align="right"><small>'.$lastpost.'</small></td>');                  $r->print('<td class="LC_right_item">'.$lastpost.'</td>');
             }              }
             $r->print("</tr>\n");              $r->print("</tr>\n");
             $rowNum ++;  
         }          }
       } elsif ($itemserror) {
           $r->print('<tr class="LC_empty_row"><td>'.$itemserror.'</td></tr>');
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff"><br><center>&nbsp;<i><b><small>'.          $r->print('<tr class="LC_empty_row"><td>'.$lt{'noun'}.'</td></tr>');
                   $lt{'noun'}.'</small></b></i><br><br></td></tr>');  
     }      }
 }  }
   
 sub display_coursenormalmail {  sub display_coursenormalmail {
     my ($r,$msgcount,$newmsgs,$rowColor1,$rowColor2) = @_;      my ($r,$msgcount,$newmsgs) = @_;
     my $rowColor;  
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
     if ($msgcount > 0) {      if ($msgcount > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.&mt('Number').'</small></b></td><td><b><small>'.&mt('Subject').'</small></b></td><td><b><small>'.&mt('Sender').'</small></b></td><td><b><small>'.&mt('Date/Time').'</small></b></td></tr>');          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
         my $rowNum = 0;                    &mt('Number').'</td><td>'.&mt('Subject').'</td><td>'.
         my $mailcount = 1;                    &mt('Sender').'</td><td class="LC_right_item">'.
                     &mt('Date/Time').'</td></tr>');
           my $mailcount = 0;
         foreach my $msg (@{$newmsgs}) {          foreach my $msg (@{$newmsgs}) {
             if ($rowNum %2 == 1) {  
                 $rowColor = $rowColor1;  
             } else {  
                 $rowColor = $rowColor2;  
             }  
             $r->print('<tr bgcolor="'.$rowColor.'"><td valign="top"><small>'.$mailcount.'. &nbsp;</small></td><td valign="top"><small><a href="/adm/communicate">'.$msg->{'shortsub'}.'</a>&nbsp; &nbsp;</small></td><td valign="top"><small>&nbsp;'.$msg->{'from'}.'@'.$msg->{'fromdom'}.'&nbsp;</small></td><td valign="top"><small>'.$msg->{'sendtime'}.'</small></td></tr>');  
             $rowNum ++;  
             $mailcount ++;              $mailcount ++;
               my $css_class = $mailcount%2?' class="LC_odd_row"':'';
               $r->print('<tr'.$css_class.'><td>'.$mailcount
                         .'.&nbsp;</td><td><a href="/adm/email?display='
                         .$msg->{'msgid'}.'">'
                         .$msg->{'shortsub'}.'</a>&nbsp;&nbsp;</td><td>&nbsp;'
                         .$msg->{'from'}.':'.$msg->{'fromdom'}.'&nbsp;</td><td>'
                         .$msg->{'sendtime'}.'</td></tr>');
         }          }
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff" width="100%"><center><br /><b><i><small>'.&mt('No new '.$lctype.' messages').'</small></i></b><br /><br /></center></td></tr>');          $r->print('<tr class="LC_empty_row"><td>'.
                     &mt('No new '.$lctype.' messages').'</td></tr>');
     }      }
 }  }
   
 sub display_coursecritmail {  sub display_coursecritmail {
     my ($r,$critmsgcount,$critmsgs,$rowColor1,$rowColor2) = @_;      my ($r,$critmsgcount,$critmsgs) = @_;
     my $rowColor;  
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
     if ($critmsgcount > 0) {      if ($critmsgcount > 0) {
         $r->print('<tr bgcolor="#cccccc"><td><b><small>'.&mt('Number').'</small></b></td><td><b><small>'.&mt('Subject').'</small></b></td><td><b><small>'.&mt('Sender').'</small></b></td><td><b><small>'.&mt('Date/Time').'</small></b></td></tr>');          $r->print('<tr class="LC_info_row"><td class="LC_left_item">'.
         my $rowNum = 0;                    &mt('Number').'</td><td>'.&mt('Subject').'</td><td>'.
         my $mailcount = 1;                    &mt('Sender').'</td><td class="LC_right_item">'.
                     &mt('Date/Time').'</td></tr>');
           my $mailcount = 0;
         foreach my $msg (@{$critmsgs}) {          foreach my $msg (@{$critmsgs}) {
             if ($rowNum %2 == 1) {  
                 $rowColor = $rowColor1;  
             } else {  
                 $rowColor = $rowColor2;  
             }  
             $r->print('<tr bgcolor="'.$rowColor.'"><td valign="top"><small>'.$mailcount.'. &nbsp;<small></td><td valign="top"><small><a href="/adm/email?folder=critical">'.$msg->{'shortsub'}.'</a>&nbsp; &nbsp;</small></td><td valign="top"><small>&nbsp;'.$msg->{'from'}.'@'.$msg->{'fromdom'}.'&nbsp;</small></td><td valign="top"><small>'.$msg->{'sendtime'}.'</small></td></tr>');  
             $rowNum ++;  
             $mailcount ++;              $mailcount ++;
               my $css_class = $mailcount%2?' class="LC_odd_row"':'';
               $r->print('<tr'.$css_class.'><td>'.$mailcount.
                         '. &nbsp;</td><td><a href="/adm/email?folder=critical">'.
                         $msg->{'shortsub'}.'</a>&nbsp; &nbsp;</td><td>&nbsp;'.
                         $msg->{'from'}.':'.$msg->{'fromdom'}.'&nbsp;</td><td>'.
                         $msg->{'sendtime'}.'</td></tr>');
         }          }
     } else {      } else {
         $r->print('<tr><td bgcolor="#ffffff" width="100%"><center><br /><b><i><small>'.&mt('No unread critical messages in '.$lctype).'</small></i></b><br /><br /></center></td></tr>');          $r->print('<tr class="LC_empty_row"><td>'.
                     &mt('No unread critical messages in '.$lctype).
                     '</td></tr>');
     }      }
 }  }
   
Line 1426  sub store_interval_setting { Line 2270  sub store_interval_setting {
     my ($uname,$udom,$cid,$interval_titles) = @_;      my ($uname,$udom,$cid,$interval_titles) = @_;
     my %interval_settings = ();      my %interval_settings = ();
     my $result;      my $result;
     if (defined($env{'form.interval'})) {      my $context = $env{'form.intervaltype'};
         $interval_settings{$cid.':interval'} = $env{'form.interval'};      if ($env{'form.interval'} ne '') {
           if ($context eq 'oldroles') {
               $interval_settings{$cid.':oldroleinterval'} = $env{'form.interval'};
           } elsif ($context eq 'newroles') {
               $interval_settings{$cid.':newroleinterval'} = $env{'form.interval'};
           } elsif ($context eq 'crslogin') {
               $interval_settings{$cid.':crslogininterval'} = $env{'form.interval'};
           } elsif ($context eq 'sessions') {
               $interval_settings{$cid.':sessionactivity'} = $env{'form.interval'};
           } else {
               $interval_settings{$cid.':interval'} = $env{'form.interval'};
           }
         my $outcome = &Apache::lonnet::put('nohist_whatsnew',          my $outcome = &Apache::lonnet::put('nohist_whatsnew',
                                              \%interval_settings,$udom,$uname);                                               \%interval_settings,$udom,$uname);
         if ($outcome eq 'ok') {          if ($outcome eq 'ok') {
             $result = &mt('Interval set to version changes [_1]',              if (ref($interval_titles->{$context}) eq 'HASH') {
                   '<b>'.$$interval_titles{$env{'form.interval'}}.'</b><br />');                  $result = &Apache::lonhtmlcommon::confirm_success(&mt('New filter setting: [_1].','<b>'. 
                                 $interval_titles->{$context}->{$env{'form.interval'}}.'</b>').'<br />');
               }
         } else {          } else {
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
             &Apache::lonnet::logthis('Error storing whatsnew interval setting'.              &Apache::lonnet::logthis('Error saving whatsnew '.$context.' interval setting'.
                 ' '.$outcome.' for '.$uname.':'.$udom.' in '.$lctype.' '.$cid);                  ' '.$outcome.' for '.$uname.':'.$udom.' in '.$lctype.' '.$cid);
             $result = &mt('Unable to set interval to [_1] due to [_2].',              $result = &Apache::lonhtmlcommon::confirm_success(&mt('Unable to set interval to [_1] due to [_2].',
                          '<b>'.$$interval_titles{$env{'form.interval'}}.'</b>',                           '<b>'.$interval_titles->{$context}->{$env{'form.interval'}}.'</b>',
                          '<tt>'.$outcome.'</tt>.<br />');                           '<tt>'.$outcome.'</tt>'),1);
         }          }
     }      }
     return $result;      return &Apache::loncommon::confirmwrapper($result);
 }  }
   
 sub store_discussion_setting {  sub store_discussion_setting {
Line 1455  sub store_discussion_setting { Line 2311  sub store_discussion_setting {
         my $outcome = &Apache::lonnet::put('nohist_whatsnew',          my $outcome = &Apache::lonnet::put('nohist_whatsnew',
                                              \%discussion_settings,$udom,$uname);                                               \%discussion_settings,$udom,$uname);
         if ($outcome eq 'ok') {          if ($outcome eq 'ok') {
             $result = &mt('Count unread posts in discussions display set to [_1]',              $result = &Apache::lonhtmlcommon::confirm_success(&mt('Count unread posts in discussions display set to [_1]',
                   '<b>'.$env{'form.countunread'}.'</b><br />');                    '<b>'.&mt($env{'form.countunread'}).'</b>').'<br />');
                                                                                                                                                                       
         } else {          } else {
     my $lctype = lc(&Apache::loncommon::course_type());      my $lctype = lc(&Apache::loncommon::course_type());
             &Apache::lonnet::logthis('Error storing whatsnew countunread setting'.              &Apache::lonnet::logthis('Error saving whatsnew countunread setting'.
                 ' '.$outcome.' for '.$uname.':'.$udom.' in '.$lctype.' '.$cid);                  ' '.$outcome.' for '.$uname.':'.$udom.' in '.$lctype.' '.$cid);
             $result = &mt('Unable to set "number unread posts display" to [_1]'.              $result = &Apache::lonhtmlcommon::confirm_success(&mt('Unable to set "number unread posts display" to [_1]'.
                           ' due to [_2].',                            ' due to [_2].',
                          '<b>'.$env{'form.countunread'}.'</b>',                           '<b>'.&mt($env{'form.countunread'}).'</b>',
                          '<tt>'.$outcome.'</tt>.<br />');                           '<tt>'.$outcome.'</tt>'),1);
         }          }
     }      }
     return $result;      return &Apache::loncommon::confirmwrapper($result);
 }  }
   
 sub store_courseinit_setting {  sub store_courseinit_setting {
Line 1493  sub store_courseinit_setting { Line 2349  sub store_courseinit_setting {
                                            \%courseinit_settings,$udom,$uname);                                             \%courseinit_settings,$udom,$uname);
             if ($outcome eq 'ok') {              if ($outcome eq 'ok') {
                 if ($page_control eq 'global preferences') {                  if ($page_control eq 'global preferences') {
                     $result = &mt("Page displayed after role selection in $lctype now set by <b>user's global preferences</b>.");                      $result = &Apache::lonhtmlcommon::confirm_success(&mt("Page displayed after role selection in $lctype now set by [_1]user's global preferences[_2].",'<b>','</b>'));
                 } else {                  } else {
                     $result = &mt('Page displayed after role selection in this '.$lctype.' set to <b>[_2]</b>',$lctype,$$initpage{$env{'form.courseinit_page'}});                      $result = &Apache::lonhtmlcommon::confirm_success(&mt('Page displayed after role selection in this '.$lctype.' set to [_1].'
                                    ,'<b>'.$$initpage{$env{'form.courseinit_page'}}.'</b>'));
                 }                  }
             } else {              } else {
                 &Apache::lonnet::logthis('Error storing whatsnew courseinit '.                  &Apache::lonnet::logthis('Error saving whatsnew courseinit '.
                                          'setting: '.$outcome.' for '.$uname.                                           'setting: '.$outcome.' for '.$uname.
                                          ':'.$udom.' in '.$lctype.' '.$cid);                                           ':'.$udom.' in '.$lctype.' '.$cid);
                 if ($page_control eq 'global preferences') {                  if ($page_control eq 'global preferences') {
                     $result = &mt('Unable to set control of page display to [_1]'.                      $result = &Apache::lonhtmlcommon::confirm_success(&mt('Unable to set control of page display to [_1]'.
                           ' due to [_2].',                            ' due to [_2].',
                          '<b>'.$page_control.'</b>',                           '<b>'.$page_control.'</b>',
                          '<tt>'.$outcome.'</tt>.<br />');                           '<tt>'.$outcome.'</tt>'),1);
                 } else {                  } else {
                     $result = &mt('Unable to set page display, after role selection, for this '.$lctype.' to <b>[_2]</b> due to <tt>[_3]</tt>.<br />',                      $result = &Apache::lonhtmlcommon::confirm_success(&mt('Unable to set page display, after role selection, for this '.$lctype.' to [_1] due to [_2].'
                          $$initpage{$env{'form.courseinit_page'}},$outcome);                                   ,'<b>'.$$initpage{$env{'form.courseinit_page'}}.'</b>'
                                    ,'<tt>'.$outcome.'</tt>'),1);
                 }                  }
             }              }
         }          }
     }      }
     return $result;      return &Apache::loncommon::confirmwrapper($result);
 }  }
   
 sub start_box {  sub start_box {
     my ($r,$tabbg,$show,$heading,$caller,$refpage) = @_;      my ($r,$show,$heading,$caller,$refpage) = @_;
     my %lt = &Apache::lonlocal::texthash(       my %lt = &Apache::lonlocal::texthash( 
                        chth => 'Change thresholds?',                         chth => 'Change thresholds?',
                        chin => 'Change interval?',                         chin => 'Change interval?',
                        chop => 'Change options?',                         chop => 'Change options?',
     );      );
     my ($showhide,$class);      my $showhide;
     if ($$show{$caller}) {      if ($$show{$caller}) {
         $showhide = '<b><a href="javascript:change_display(document.visible.'.          $showhide = '<b><a href="javascript:change_display(document.visible.'.
                                'display_'.$caller.",'hide'".');">Hide</a></b>';                                 'display_'.$caller.",'hide'".');">'.
                                  &mt('Hide').'</a></b>';
         
     } else {      } else {
         $showhide = '<b><a href="javascript:change_display(document.visible.'.          $showhide = '<b><a href="javascript:change_display(document.visible.'.
                                'display_'.$caller.",'show'".');">Show</a></b>';                                 'display_'.$caller.",'show'".');">'.
                                  &mt('Show').'</a></b>';
     }      }
           
     $r->print('      $r->print('
          <table border="0" cellpadding="0" cellspacing="0" bgcolor="#000000" width="100%">           <table class="LC_nested_outer">
           <tr>            <tr>
            <td>             <th class="LC_left_item">'.$$heading{$caller}.'</th>
             <table border="0" cellpadding="1" cellspacing="1" bgcolor="#000000" width="100%">             <th class="LC_right_item">'.$showhide.'</th>
               <tr>            </tr>');
                <td bgcolor="'.$tabbg.'">  
                 <table width="100%" border="0" cellspacing="0" cellpadding="0">  
                  <tr>  
                   <td><b>'.$$heading{$caller}.'</b></td>  
                   <td valign="top" align="right">'.$showhide.'</td>  
                  </tr>  
                 </table>  
                </td>  
               </tr>');  
      if (($caller eq 'abovethreshold') && ($$show{$caller})) {       if (($caller eq 'abovethreshold') && ($$show{$caller})) {
          if ($$show{$caller}) {           if ($$show{$caller}) {
              $r->print('               $r->print('
               <tr>                <tr>
                 <td bgcolor="'.$tabbg.'" align="right"><a href="/adm/whatsnew?command=chgthreshold&refpage='.$refpage.'"><b><small>'.$lt{'chth'}.'</small></b></a></td>                  <td class="LC_subheader" colspan="2"><a href="/adm/whatsnew?command=chgthreshold&amp;refpage='.$refpage.'">'.$lt{'chth'}.'</a></td>
               </tr>');                </tr>');
          }           }
  $class='class="LC_whatsnew"';  
      } elsif (($caller eq 'versionchanges') && ($$show{$caller})) {       } elsif (($caller eq 'versionchanges') && ($$show{$caller})) {
          if ($$show{$caller}) {           if ($$show{$caller}) {
              $r->print('               $r->print('
               <tr>                <tr>
                 <td bgcolor="'.$tabbg.'" align="right"><a href="/adm/whatsnew?command=chginterval&refpage='.$refpage.'"><b><small>'.$lt{'chin'}.'</small></b></a></td>                  <td class="LC_subheader" colspan="2"><a href="/adm/whatsnew?command=chginterval&amp;refpage='.$refpage.'">'.$lt{'chin'}.'</a></td>
               </tr>');                </tr>');
          }           }
      } elsif ($caller eq 'coursediscussion') {       } elsif ($caller eq 'coursediscussion') {
          if ($$show{$caller}) {           if ($$show{$caller}) {
              $r->print('               $r->print('
               <tr>                <tr>
                 <td bgcolor="'.$tabbg.'" align="right"><a href="/adm/whatsnew?command=chgdisc&refpage='.$refpage.'"><b><small>'.$lt{'chop'}.'</small></b></a></td>                  <td class="LC_subheader" colspan="2"><a href="/adm/whatsnew?command=chgdisc&amp;refpage='.$refpage.'">'.$lt{'chop'}.'</a></td>
                 </tr>');
            }
        } elsif (($caller eq 'newroles') && ($$show{$caller})) {
            if ($$show{$caller}) {
                $r->print('
                 <tr>
                   <td class="LC_subheader" colspan="2"><a href="/adm/whatsnew?command=chgnewroleinterval&amp;refpage='.$refpage.'">'.$lt{'chin'}.'</a></td>
                 </tr>');
            }
        } elsif (($caller eq 'oldroles') && ($$show{$caller})) {
            if ($$show{$caller}) {
                $r->print('
                 <tr>
                   <td class="LC_subheader" colspan="2"><a href="/adm/whatsnew?command=chgoldroleinterval&amp;refpage='.$refpage.'">'.$lt{'chin'}.'</a></td>
               </tr>');                </tr>');
          }           }
      }      } elsif (($caller eq 'crslogin') && ($$show{$caller})) {
           if ($$show{$caller}) {
               $r->print('
                 <tr>
                   <td class="LC_subheader" align="left"><span class="LC_nobreak"><label><input type="radio" name="logindetails" value="0" checked="checked" onclick="javascript:toggledetails('."'login'".');" />&nbsp;'.&mt('Summary').'</label><label><input type="radio" name="logindetails" value="1" onclick="javascript:toggledetails('."'login'".');" />&nbsp;'.&mt('Details').'</label></span></td><td class="LC_subheader"><a href="/adm/whatsnew?command=chgcrslogininterval&amp;refpage='.$refpage.'">'.$lt{'chin'}.'</a></td>
                 </tr>');
           }
       } elsif (($caller eq 'sessions') && ($$show{$caller})) {
           if ($$show{$caller}) {
               $r->print('
                 <tr>
                   <td class="LC_subheader" align="left"><span class="LC_nobreak"><label><input type="radio" name="sessiondetails" value="0" checked="checked" onclick="javascript:toggledetails('."'session'".');" />&nbsp;'.&mt('Summary').'</label><label><input type="radio" name="sessiondetails" value="1" onclick="javascript:toggledetails('."'session'".');" />&nbsp;'.&mt('Details').'</label></span></td><td class="LC_subheader"><a href="/adm/whatsnew?command=chgsessionlimit&amp;refpage='.$refpage.'">'.$lt{'chin'}.'</a></td>
                 </tr>');
           }
       }
     $r->print('      $r->print('
               <tr>                <tr>
                <td bgcolor="#ffffff">                 <td colspan="2">
                 <table cellpadding="2" cellspacing="0" border="0" width="100%" '.$class.'>                  <table class="LC_nested">
 ');  ');
     return;      return;
 }  }
Line 1582  sub start_box { Line 2460  sub start_box {
 sub end_box {  sub end_box {
     my ($r) = shift;      my ($r) = shift;
     $r->print('      $r->print('
       </table>  
      </td>  
     </tr>  
    </table>     </table>
   </td>    </td>
  </tr>   </tr>

Removed from v.1.64  
changed lines
  Added in v.1.127


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>
500 Internal Server Error

Internal Server Error

The server encountered an internal error or misconfiguration and was unable to complete your request.

Please contact the server administrator at root@localhost to inform them of the time this error occurred, and the actions you performed just before this error.

More information about this error may be available in the server error log.