--- loncom/interface/lonpickcourse.pm 2004/12/28 05:55:11 1.23 +++ loncom/interface/lonpickcourse.pm 2005/04/07 06:56:23 1.27 @@ -1,7 +1,7 @@ # The LearningOnline Network # Pick a course # -# $Id: lonpickcourse.pm,v 1.23 2004/12/28 05:55:11 raeburn Exp $ +# $Id: lonpickcourse.pm,v 1.27 2005/04/07 06:56:23 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -42,8 +42,9 @@ sub handler { return OK if $r->header_only; # ------------------------------------------------------------ Print the screen + my $html=&Apache::lonxml::xmlbegin(); $r->print(< +$html The LearningOnline Network with CAPA @@ -55,25 +56,25 @@ ENDDOCUMENT 'cdomelement','cnameelement','roleelement', 'pickedcourse','instcodefilter','ownerfilter']); # domain filter and selection - my $domainfilter=$ENV{'form.domainfilter'}; + my $domainfilter=$env{'form.domainfilter'}; $domainfilter=~s/\W//g; unless ($domainfilter) { $domainfilter=''; } my $domainselectform=&Apache::loncommon::select_dom_form($domainfilter, 'domainfilter',1); # description filter - my $descriptfilter=$ENV{'form.descriptfilter'}; + my $descriptfilter=$env{'form.descriptfilter'}; unless ($descriptfilter) { $descriptfilter=''; } my $listdescript=&HTML::Entities::encode($descriptfilter,'<>&"'); # institutional code filter - my $instcodefilter=$ENV{'form.instcodefilter'}; + my $instcodefilter=$env{'form.instcodefilter'}; unless ($instcodefilter) { $instcodefilter=''; } my $listinstcode=&HTML::Entities::encode($instcodefilter,'<>&"'); # course owner filter - my $ownerfilter=$ENV{'form.ownerfilter'}; + my $ownerfilter=$env{'form.ownerfilter'}; unless ($ownerfilter) { $ownerfilter=''; } my $listowner=&HTML::Entities::encode($ownerfilter,'<>&"'); # last course activity filter and selection - my $sincefilter=$ENV{'form.sincefilter'}; + my $sincefilter=$env{'form.sincefilter'}; $sincefilter=~s/[^\d-]//g; unless ($sincefilter) { $sincefilter=-1; } my $sincefilterform=&Apache::loncommon::select_form($sincefilter, @@ -90,9 +91,9 @@ ENDDOCUMENT # if called from loncreateuser, report sections, then close my ($loaditem,$seclist); my $num_sections = 0; - if ($ENV{'form.form'} eq 'cu' && $ENV{'form.pickedcourse'}) { + if ($env{'form.form'} eq 'cu' && $env{'form.pickedcourse'}) { $loaditem = 'onLoad="setSections()"'; - my ($cdom,$cnum) = split/_/,$ENV{'form.pickedcourse'}; + my ($cdom,$cnum) = split/_/,$env{'form.pickedcourse'}; my %sections_count = (); $num_sections = &Apache::loncommon::get_sections($cdom,$cnum,\%sections_count); my @sections = (); @@ -109,20 +110,20 @@ ENDDOCUMENT 'cin' => 'Course Institutional Code', 'cow' => "Course Owner's usename"); my ($name_code,$name_input); - if (defined($ENV{'form.cnameelement'}) && $ENV{'form.cnameelement'} ne '') { - $name_code = "opener.document.$ENV{'form.form'}.$ENV{'form.cnameelement'}.value=cdesc;"; + if (defined($env{'form.cnameelement'}) && $env{'form.cnameelement'} ne '') { + $name_code = "opener.document.$env{'form.form'}.$env{'form.cnameelement'}.value=cdesc;"; $name_input =''; + $env{'form.cnameelement'}.'" />'; } my $submitopener = ''; my $autosubmit = ''; my $roleelement = ''; my $lastaction = 'self.close()'; - if ($ENV{'form.form'} eq 'cu') { + if ($env{'form.form'} eq 'cu') { $lastaction = 'document.courselist.pickedcourse.value = cdom+"_"+cname;'."\n". 'document.courselist.submit();'; } - my $roledom = $ENV{'form.roleelement'}; + my $roledom = $env{'form.roleelement'}; if ($roledom) { $roleelement = ''; $submitopener = &Apache::lonroles::processpick($roledom); @@ -132,13 +133,13 @@ ENDDOCUMENT $submitopener
- - + + $name_input - + $roleelement $lt{'cac'}: $sincefilterform
@@ -206,7 +207,7 @@ $lt{'cde'}:
ENDSCRIPT # ---------------------------------------------------------------- Get the data - if ($ENV{'form.gosearch'}) { + if ($env{'form.gosearch'}) { $r->print(&mt('Searching').' ...
 
'); $r->rflush(); unless ($descriptfilter) { $descriptfilter='.'; } @@ -225,24 +226,33 @@ ENDSCRIPT } else { $descr = &Apache::lonnet::unescape($courses{$course}); } - $by_descrip{lc($descr)}=$course; + my $description = lc($descr); + push (@{$by_descrip{$description}}, $course); } foreach my $description (sort(keys(%by_descrip))) { - my $course=$by_descrip{$description}; - my $cleandesc=&HTML::Entities::encode($description,'<>&"'); - $cleandesc=~s/'/\\'/g; - my ($cdom,$cnum)=split(/\_/,$course); - $r->print(' '.$description.' ('. - ($Apache::lonnet::domaindescription{$cdom}? - $Apache::lonnet::domaindescription{$cdom}:$cdom). - ")
\n"); + foreach my $course (@{$by_descrip{$description}}) { + my $cleandesc=&HTML::Entities::encode($description,'<>&"'); + $cleandesc=~s/'/\\'/g; + my ($cdom,$cnum)=split(/\_/,$course); + my ($descr,$instcode,$owner) = split/:/,$courses{$course}; + $r->print(' '.$description.' ('. + ($Apache::lonnet::domaindescription{$cdom}? + $Apache::lonnet::domaindescription{$cdom}:$cdom).")"); + unless ($instcode eq '') { + $r->print(" - ".&Apache::lonnet::unescape($instcode)); + } + unless ($owner eq '') { + $r->print(", owner - ".&Apache::lonnet::unescape($owner)); + } + $r->print("
\n"); + } } if (!%courses) { $r->print(&mt('None found')); } - $r->print(''."\n". + $r->print(''."\n". ''."\n". - ''."\n". - ''."\n". + ''."\n". + ''."\n". '
'); } $r->print('');