--- loncom/interface/lonpickstudent.pm 2002/12/30 14:10:58 1.2 +++ loncom/interface/lonpickstudent.pm 2006/01/09 20:38:52 1.10 @@ -1,7 +1,7 @@ # The LearningOnline Network # Pick a student from the classlist # -# $Id: lonpickstudent.pm,v 1.2 2002/12/30 14:10:58 www Exp $ +# $Id: lonpickstudent.pm,v 1.10 2006/01/09 20:38:52 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,43 +33,51 @@ use Apache::Constants qw(:common); use Apache::loncommon; use Apache::loncoursedata; use Apache::lonnet; +use Apache::lonlocal; sub handler { my $r = shift; - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; # ------------------------------------------------------------ Print the screen + my $html=&Apache::lonxml::xmlbegin(); $r->print(< +$html The LearningOnline Network with CAPA ENDDOCUMENT -# Is this even in a course? - unless ($ENV{'request.course.id'}) { - $r->print('Not in a course'); - return OK; + + + + &Apache::loncommon::get_unprocessed_cgi + ($ENV{'QUERY_STRING'},['filter','form','unameelement','udomelement', + 'roles']); +# Allowed? + my $allowed; + my $scope = $env{'request.course.id'}; + if (!($allowed = &Apache::lonnet::allowed('srm',$scope))) { + $scope .= '/'.$env{'request.course.sec'}; + $allowed = &Apache::lonnet::allowed('srm',$scope); + if ($allowed) { $allowed = 'section'; } } - - unless (&Apache::lonnet::allowed('srm',$ENV{'request.course.id'})) { - $r->print('No course listing'); + + unless (($env{'form.roles'}) || + (($env{'request.course.id'}) && ($allowed))) { + $r->print('No context.'); return OK; } +# See if filter present - - &Apache::loncommon::get_unprocessed_cgi - ($ENV{'QUERY_STRING'},['filter','form','unameelement','udomelement']); - my $filter=$ENV{'form.filter'}; + my $filter=$env{'form.filter'}; $filter=~s/\W//g; unless ($filter) { $filter='.'; } - my $classlist=&Apache::loncoursedata::DownloadClasslist - ($ENV{'request.course.id'}, - 'Not downloaded',$r->connection); + my $classlist=&Apache::loncoursedata::get_classlist(); # --------------------------------------- There is such a user, get environment @@ -77,45 +85,99 @@ ENDDOCUMENT $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'}.$env{'form.unameelement'}.value=uname; + var slct=opener.document.$env{'form.form'}.$env{'form.udomelement'}; var i; for (i=0;i ENDSCRIPT - $r->print('

'.$ENV{'course.'.$ENV{'request.course.id'}.'.description'}. + $r->print('
'); + if ($allowed && (!$env{'form.roles'})) { +# -------------------------------------------------------- Get course personnel + $r->print('

'.$env{'course.'.$env{'request.course.id'}.'.description'}. '

'); + my %coursepersonnel= + &Apache::lonnet::get_course_adv_roles(); + $r->print(''); + foreach my $role (sort keys %coursepersonnel) { + foreach (split(/\,/,$coursepersonnel{$role})) { + my ($puname,$pudom)=split(/\:/,$_); + $r->print(''); + } + } + $r->print('
'. + ''.$role.''. + &Apache::loncommon::aboutmewrapper( + &Apache::loncommon::plainname($puname, + $pudom),$puname,$pudom).'

 '); if ($filter ne '.') { - $r->print('Name starting with "'.$filter.'"
'); + $r->print('
'.&mt('Name starting with').' "'.$filter.'"
'); } - $r->print(''); + $r->print('

'); + # ------------------------------------------------------------------ Students foreach (sort keys %$classlist) { - if ($_=~/^(\w+)\:(\w+)\:studentInformation$/) { + # the following undefs are for 'domain', and 'username' respectively. + my (undef,undef,$end,$start,$id,$section,$fullname,$status)= + @{$classlist->{$_}}; + if ($allowed eq 'section' && $section ne $env{'request.course.sec'}) { + next; + } + if ($_=~/^(\w+)\:(\w+)$/) { my ($uname,$udom)=($1,$2); if (($uname=~/^$filter/) || - ($classlist->{$_}->{'lastname'}=~/^$filter/i)) { + ($fullname=~/^$filter/i)) { + $r->print(''. + ''); + } + } + } + + $r->print('
'. + ''.$uname.' '.$udom. + ''. + &Apache::loncommon::aboutmewrapper( + $fullname, + $uname,$udom).''.$id.''.$section. + '

'); + } else { + $r->print('

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

'); + if ($filter ne '.') { + $r->print('
'.&mt('Name starting with').' "'.$filter.'"
'); + } + $r->print('

'); + my %users=&Apache::lonnet::get_my_roles(); + foreach (sort keys %users) { + if ($_=~/^(\w+)\:(\w+)\:(\w+)$/) { + my ($uname,$udom,$urole)=($1,$2,$3); + my $fullname=&Apache::loncommon::plainname($uname,$udom); + if (($uname=~/^$filter/) || + ($fullname=~/^$filter/i)) { $r->print(''. ''); + $fullname, + $uname,$udom).''); } } } - - $r->print('
'. ''.$uname.''.$udom. ''. &Apache::loncommon::aboutmewrapper( - $classlist->{$_}->{'lastname'}.', '. - $classlist->{$_}->{'firstname'}.' '. - $classlist->{$_}->{'middlename'}.' '. - $classlist->{$_}->{'generation'}, - $uname,$udom).'
'. + &Apache::lonnet::plaintext($urole). + '

'); - return OK; + $r->print('

'); + } + $r->print(''); + return OK; } 1;