--- loncom/interface/lonpickstudent.pm 2006/03/16 21:34:04 1.13
+++ loncom/interface/lonpickstudent.pm 2007/07/21 00:48:55 1.21
@@ -1,7 +1,7 @@
# The LearningOnline Network
# Pick a student from the classlist
#
-# $Id: lonpickstudent.pm,v 1.13 2006/03/16 21:34:04 albertel Exp $
+# $Id: lonpickstudent.pm,v 1.21 2007/07/21 00:48:55 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -34,6 +34,8 @@ use Apache::loncommon;
use Apache::loncoursedata;
use Apache::lonnet;
use Apache::lonlocal;
+use Apache::longroup;
+use LONCAPA;
sub handler {
my $r = shift;
@@ -66,26 +68,40 @@ sub handler {
}
# See if filter present
-
my $filter=$env{'form.filter'};
- $filter=~s/\W//g;
- unless ($filter) { $filter='.'; }
+ my $filtermsg;
+ if ($filter eq '') {
+ $filter = '.'
+ } else {
+ my $encoded_filter = &HTML::Entities::encode($filter,'<>&"');
+ $filter = quotemeta($filter);
+ my $change = &mt('Change');
+ my $filterbutton =<
'.
+ &mt('Showing users with a name starting with [_1]',
+ $filterbutton).'
';
+ }
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
my $classlist=&Apache::loncoursedata::get_classlist();
my %grouplist=&Apache::lonnet::get_group_membership($cdom,$cnum);
my $now = time;
- my %allgroups;
- my @coursegroups = ();
- if (&Apache::loncommon::coursegroups(\%allgroups,$cdom,$cnum)) {
- @coursegroups = keys(%allgroups);
- }
+ my %allgroups = &Apache::longroup::coursegroups($cdom,$cnum);
# --------------------------------------- There is such a user, get environment
$r->print(<
'. - ' | '. - ''.$uname.' | '.$udom. - ' | '. - &Apache::loncommon::aboutmewrapper( - $fullname, - $uname,$udom).' | '. - &Apache::lonnet::plaintext($urole). - ' | '. + ' | '.&mt('username').' | '. + ''.&mt('domain').' | '. + ''.&mt('Name').' | '. + ''.&mt('ID').' | '. + ''.&mt('section').' | '. + ''.&mt('active group(s)').' | '. + &Apache::loncommon::end_data_table_header_row()); +# ------------------------------------------------------------------ Students + foreach my $user (sort(keys(%$classlist))) { + # the following undefs are for 'domain', and 'username' respectively. + my (undef,undef,$end,$start,$id,$section,$fullname,$status)= + @{$classlist->{$user}}; + if ($allowed eq 'section' && $section ne $env{'request.course.sec'}) { + next; + } + if ($user=~/^($LONCAPA::username_re)\:($LONCAPA::domain_re)$/) { + my ($uname,$udom)=($1,$2); + if (($uname=~/^$filter/) || + ($fullname=~/^$filter/i)) { + my $grouplist = ''; + foreach my $group (sort(keys(%allgroups))) { + if (exists($grouplist{$group.':'.$uname.':'.$udom})) { + my ($end,$start) = split(/:/,$grouplist{$group.':'.$uname.':'.$udom}); + if (($end!=0) && ($end<$now)) { next; } + if (($start!=0) && ($start>$now)) {next; } + $grouplist .= " $group,"; + } + } + $grouplist =~ s/,$//; + $r->print(&Apache::loncommon::start_data_table_row(). + ''. + ' | '. + ''.$uname.' | '.$udom. + ' | '. + &Apache::loncommon::aboutmewrapper($fullname, + $uname,$udom). + ' | '.$id.' | '.$section. + ' | '.$grouplist.' | '. + &Apache::loncommon::end_data_table_row()); + } + } + } + + $r->print(&Apache::loncommon::end_data_table().''); + } else { + $r->print(''. + ' | '. + ''.$uname.' | '.$udom. + ' | '. + &Apache::loncommon::aboutmewrapper( + $fullname, + $uname,$udom).' | '. + &Apache::lonnet::plaintext($urole). + ' | '. + &Apache::loncommon::end_data_table_row()); + } + } + } + $r->print(&Apache::loncommon::end_data_table().''); } - $r->print('
---|