--- loncom/interface/lonpickstudent.pm 2008/10/10 15:37:46 1.25 +++ loncom/interface/lonpickstudent.pm 2011/06/07 20:18:59 1.30 @@ -1,7 +1,7 @@ # The LearningOnline Network # Pick a student from the classlist # -# $Id: lonpickstudent.pm,v 1.25 2008/10/10 15:37:46 bisitz Exp $ +# $Id: lonpickstudent.pm,v 1.30 2011/06/07 20:18:59 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -50,7 +50,7 @@ sub handler { &Apache::loncommon::get_unprocessed_cgi ($ENV{'QUERY_STRING'},['filter','form','unameelement','udomelement', - 'roles']); + 'roles','courseadvonly','clicker']); # Allowed? my $allowed; my $scope = $env{'request.course.id'}; @@ -83,27 +83,22 @@ FILTER HIDDEN } - $filtermsg = '
'. - &mt('Showing users with a name starting with [_1]', - $filterbutton).'
'; + unless ($env{'form.courseadvonly'}) { + $filtermsg = '
'. + &mt('Showing users with a name starting with [_1]', + $filterbutton).'
'; + } if ($filter eq '') { $filter = '.' } - 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 = &Apache::longroup::coursegroups($cdom,$cnum); - # --------------------------------------- There is such a user, get environment $r->print(< function gochoose(uname,udom) { - opener.document.$env{'form.form'}.$env{'form.unameelement'}.value=uname; - var slct=opener.document.$env{'form.form'}.$env{'form.udomelement'}; + opener.document.$env{'form.form'}.elements['$env{'form.unameelement'}'].value=uname; + var slct=opener.document.$env{'form.form'}.elements['$env{'form.udomelement'}']; var i; for (i=0;iprint(&Apache::loncommon::start_data_table_row(). ''. 'print('

'.&mt('Clicker: [_1]',$clicker).'

'); + my $clicklength=length($clicker); + my $maxlength=$clicklength-1; + if ($maxlength>2) { + my $minlength=$maxlength-2; + if ($minlength<2) { $minlength=2; } + for (my $length=$maxlength;$length>=$minlength;$length--) { + for (my $startidx=0; $startidx<=$clicklength-$length; $startidx++) { + push(@fragments,substr($clicker,$startidx,$length)); + } + } + } + } + + my $result; + 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 = &Apache::longroup::coursegroups($cdom,$cnum); + + 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/,$//; + my $markedupclicker; + if ($clicker) { + $markedupclicker=(&Apache::lonnet::userenvironment($udom,$uname,'clickers'))[1]; + if ($markedupclicker!~/\w/) { + $markedupclicker='-'; + } else { + foreach my $frag (@fragments) { + if ($markedupclicker=~/\Q$frag\E/is) { + $markedupclicker=~s/(\Q$frag\E)/$1<\/b><\/font>/gis; + last; + } + } + } + } + $result .=&Apache::loncommon::start_data_table_row(). + ''. + ''. + ''.$uname.' '.$udom. + ''. + &Apache::loncommon::aboutmewrapper($fullname, + $uname,$udom). + ''.$id.''.$section. + ''.$grouplist.''. + ($clicker?''.$markedupclicker.'':''). + &Apache::loncommon::end_data_table_row(); } - $grouplist =~ s/,$//; - $result .=&Apache::loncommon::start_data_table_row(). - ''. - ''. - ''.$uname.' '.$udom. - ''. - &Apache::loncommon::aboutmewrapper($fullname, - $uname,$udom). - ''.$id.''.$section. - ''.$grouplist.''. - &Apache::loncommon::end_data_table_row(); - } + } } - } - if (!$result) { - $r->print('

'.&mt('No students found.').'

'); - } else { - $r->print(&Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - &Apache::loncommon::end_data_table_header_row(). - ' '. - ''.&mt('username').''. - ''.&mt('domain').''. - ''.&mt('Name').''. - ''.&mt('ID').''. - ''.&mt('section').''. - ''.&mt('active group(s)').''. - &Apache::loncommon::end_data_table_header_row(). - $result. - &Apache::loncommon::end_data_table()); - } + if (!$result) { + $r->print('

'.&mt('No students found.').'

'); + } else { + $r->print(&Apache::loncommon::start_data_table(). + &Apache::loncommon::start_data_table_header_row(). + &Apache::loncommon::end_data_table_header_row(). + ' '. + ''.&mt('username').''. + ''.&mt('domain').''. + ''.&mt('Name').''. + ''.&mt('ID').''. + ''.&mt('section').''. + ''.&mt('active group(s)').''. + ($clicker?''.&mt('clicker').'':''). + &Apache::loncommon::end_data_table_header_row(). + $result. + &Apache::loncommon::end_data_table()); + } + } } else { $r->print('

'.&mt('Users with Roles Assigned by').' '. &Apache::loncommon::plainname($env{'user.name'}, $env{'user.domain'}).'

'); $r->print($filtermsg); + $r->rflush(); $r->print('

'.&Apache::loncommon::start_data_table()); my %user_role=&Apache::lonnet::get_my_roles();