--- loncom/interface/lonwhatsnew.pm 2012/02/08 17:07:02 1.101.2.1.2.1 +++ loncom/interface/lonwhatsnew.pm 2011/04/15 13:57:18 1.104 @@ -1,5 +1,5 @@ # -# $Id: lonwhatsnew.pm,v 1.101.2.1.2.1 2012/02/08 17:07:02 raeburn Exp $ +# $Id: lonwhatsnew.pm,v 1.104 2011/04/15 13:57:18 bisitz Exp $ # # Copyright Michigan State University Board of Trustees # @@ -72,7 +72,6 @@ sub handler { ['mdc','versionchanges',0], ['vcl','newroles',1], ['vcl','oldroles',1], - ['whn','crslogin',1], ) { my ($perm,$key,$check_section) = @{ $perm_check }; my $scope = $env{'request.course.id'}; @@ -144,13 +143,6 @@ sub handler { $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' - )); } else { $r->print(&Apache::lonhtmlcommon::breadcrumbs ("What's New?",#'Course_Action_Items_Display' @@ -196,17 +188,10 @@ sub display_main_box { 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 %interval_titles = ( versions => \%versions, newroles => \%newroles, oldroles => \%oldroles, - crslogin => \%crslogins, ); my %initpage = &Apache::lonlocal::texthash ( firstres => "first resource in the $lctype", @@ -235,9 +220,6 @@ sub display_main_box { } 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'); } else { &display_actions_box($r,$command,$refpage,\%threshold_titles, \%interval_titles,\%initpage,$cdom,$crs,$checkallowed); @@ -263,11 +245,9 @@ sub display_header { my $scripttag; unless ($command eq 'chgthreshold' || $command eq 'chginterval' || - $command eq 'chgoldroleinterval' || - $command eq 'chgnewroleinterval' || $command eq 'chgcrslogininterval') { + $command eq 'chgoldroleinterval' || $command eq 'chgnewroleinterval') { $scripttag = <<"END"; '; } @@ -381,8 +315,6 @@ sub display_actions_box { my %expired; my $activecount; my %activated; - my %loggedin; - my $logincount; my %res_title = (); my %show = (); my $needitems = 0; @@ -513,20 +445,6 @@ sub display_actions_box { $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'); - } - my $now = time; if ($timediff{'versions'} == -1) { $timediff{'versions'} = time; @@ -543,12 +461,6 @@ sub display_actions_box { } my $expiredstart = $now - $timediff{'oldroles'}; - if ($timediff{'crslogin'} == -1) { - $timediff{'crslogin'} = time; - } - - my $crsloginstart = $now - $timediff{'crslogin'}; - my $countunread = $display_settings{$cid.':countunread'}; unless (defined($countunread)) { $countunread = 'on'; @@ -562,7 +474,7 @@ sub display_actions_box { $threshold{'av_attempts'},$threshold{'degdiff'}, '
',$threshold{'numstudents'}); - my @actionorder = ('handgrading','haserrors','abovethreshold','versionchanges','coursediscussion','coursenormalmail','coursecritmail','newroles','oldroles','crslogin'); + my @actionorder = ('handgrading','haserrors','abovethreshold','versionchanges','coursediscussion','coursenormalmail','coursecritmail','newroles','oldroles'); foreach my $key (keys(%{$checkallowed})) { if ($key =~ /_section$/) { next; } @@ -600,9 +512,6 @@ sub display_actions_box { if ($show{'newroles'}) { $activecount = &getactivated(\%activated,$activatedstart,'active'); } - if ($show{'crslogin'}) { - $logincount = &getloggedin($cdom,$crs,\%loggedin,$crsloginstart); - } $r->print(qq|$lt{'hial'}   $lt{'shal'}
\n|); @@ -631,7 +540,7 @@ sub display_actions_box { if ($displayed == $halfway) { $r->print(' '); } - &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); + &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); $displayed ++; } } @@ -719,8 +628,6 @@ sub display_interval_config { $r->print('
'.&mt('Choose the time window to use to display roles for which access to the '.$lctype.' expired.').'
'); } elsif ($context eq 'newroles') { $r->print('
'.&mt('Choose the time window to use to display roles for which access to the '.$lctype.' became available.').'
'); - } elsif ($context eq 'crslogin') { - $r->print('
'.&mt('Choose the time window to use to display the last login by a user in the '.$lctype).'
'); } else { $r->print('
'.&mt('Choose the time window to use to display resources in the '.$lctype.' with version changes.').'
'); } @@ -886,7 +793,7 @@ sub display_launcher { $tograde,$ungraded,$bombs,$bombed,$changed,$warnings,$triggered, $newdiscussions,$unread,$msgcount,$newmsgs,$critmsgcount,$critmsgs, $interval,$countunread,$expired,$expirecount,$activated,$activecount, - $crstype,$itemserror,$loggedin,$logincount) = @_; + $crstype,$itemserror) = @_; if ($$checkallowed{$action}) { &start_box($r,$show,$headings,$action,$refpage,$action); @@ -913,10 +820,6 @@ sub display_launcher { } elsif ($action eq 'oldroles') { # EXPIRED ROLES &display_rolechanges($r,$expirecount,$expired,$interval->{'oldroles'}, $crstype); - } elsif ($action eq 'crslogin') { #LAST LOGIN - &display_crslogins($r,$logincount,$loggedin,$interval->{'crslogin'}, - $crstype); - } } &end_box($r); @@ -1515,39 +1418,6 @@ sub getrolechanges { 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 checkversions { my ($cdom,$crs,$navmap,$changed,$starttime) = @_; my %changes=&Apache::lonnet::dump('versionupdate',$cdom,$crs); @@ -1603,13 +1473,13 @@ sub display_handgrade { foreach my $res (@{$tograde}) { $rowNum ++; my $css_class = $rowNum%2?' class="LC_odd_row"':''; - my ($map,$id,$url)=&Apache::lonnet::decode_symb($res); - my $linkurl=&Apache::lonnet::clutter($url); - $linkurl .= '?symb='.&escape($res); + my $linkurl='/adm/grades'; if ($$ungraded{$res}{'enclink'}) { - $linkurl = - $$ungraded{$res}{'enclink'}.'?symb='.$$ungraded{$res}{'encsymb'}; - } + $linkurl.='?symb='.$$ungraded{$res}{'encsymb'}; + } else { + $linkurl.='?symb='.&escape($res); + } + $linkurl.='&command=ungraded'; $r->print(''.$$ungraded{$res}{title}.''.$$ungraded{$res}{count}.''); } } elsif ($itemserror) { @@ -1804,92 +1674,6 @@ sub display_rolechanges { } return; } - -sub display_crslogins { - my ($r,$logincount,$loggedin,$interval,$crstype) = @_; - my %lt = &Apache::lonlocal::texthash( - 'user' => 'User', - 'role' => 'Role', - 'sec' => 'Section', - 'number' => 'Total number of logins', - ); - if ($logincount) { - - my $hdr = ''. - ''.$lt{'user'}.''. - ''.$lt{'role'}.''. - ''.$lt{'sec'}.''. - ''. - ''.$lt{'number'}.''. - ''.$lt{'role'}.''. - ''.$lt{'sec'}; - my (%bylastname,%counts); - if (ref($loggedin) eq 'HASH') { - my @logins = sort { $b <=> $a } (keys(%{$loggedin})); - my $numlogin = 0; - foreach my $item (@logins) { - if (ref($loggedin->{$item}) eq 'ARRAY') { - foreach my $user (@{$loggedin->{$item}}) { - if (ref($user) eq 'HASH') { - my $section; - my $role = - &Apache::lonnet::plaintext($user->{'role'},$crstype); - my $status = &mt($user->{'status'}); - 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 = &Apache::loncommon::plainname($uname,$udom,'lastname'); - my $link = - &Apache::loncommon::aboutmewrapper($fullname,$uname,$udom); - push(@{$bylastname{$fullname}}, - ''.$link.''. - ''.$role.''. - ''.$section.''); - } - } - } - } - my $table; - foreach my $person (sort(keys(%bylastname))) { - if (ref($bylastname{$person}) eq 'ARRAY') { - foreach my $item (@{$bylastname{$person}}) { - $numlogin ++; - my $css_class = $numlogin%2?' class="LC_odd_row"':''; - $table .= '