--- loncom/interface/lonpickcourse.pm 2006/05/30 12:46:09 1.47 +++ loncom/interface/lonpickcourse.pm 2006/05/30 20:12:15 1.48 @@ -1,7 +1,7 @@ # The LearningOnline Network # Pick a course # -# $Id: lonpickcourse.pm,v 1.47 2006/05/30 12:46:09 www Exp $ +# $Id: lonpickcourse.pm,v 1.48 2006/05/30 20:12:15 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -52,7 +52,8 @@ sub handler { 'sincefilter','form','cnumelement', 'cdomelement','cnameelement','roleelement', 'pickedcourse','instcodefilter', - 'ownerfilter','coursefilter','multiple']); + 'ownerfilter','coursefilter','multiple', + 'type']); # domain filter and selection my $domainfilter=$env{'form.domainfilter'}; $domainfilter=~s/\W//g; @@ -108,29 +109,46 @@ sub handler { my %sections_count = &Apache::loncommon::get_sections($cdom,$cnum); my @sections = (sort {$a <=> $b} keys(%sections_count)); $seclist = join('","',@sections); - + $num_sections = scalar(@sections); my %curr_groups = &Apache::longroup::coursegroups($cdom,$cnum); $groupslist = join(',',sort(keys(%curr_groups))); } my $jscript; - my $title = 'Selecting a course'; + my $type = $env{'form.type'}; + if (!defined($env{'form.type'})) { + $type = 'Course'; + } + my $typeselectform = '"; + my $title = &mt('Selecting a [_1]',$type); # Setup for multiple course selections, if flag for multiples set. my $multiple = $env{'form.multiple'}; my $multelement; if ($multiple) { - $title = 'Selecting course(s)'; + $title = &mt('Selecting [_1](s)',lc($type)); $jscript = &Apache::loncommon::check_uncheck_jscript(); $multelement = ''; } $r->print(&Apache::loncommon::start_page($title,undef, {'add_entries' => \%loaditem, 'no_nav_bar' => 1, })); - my %lt=&Apache::lonlocal::texthash( - 'cac' => 'Course Activity', - 'cde' => 'Course Description', - 'cdo' => 'Course Domain', - 'cin' => 'Course Institutional Code', - 'cow' => "Course Owner's Username"); + my %lt = ( + 'cac' => &mt('[_1] Activity',$type), + 'cde' => &mt('[_1] Description',$type), + 'cdo' => &mt('[_1] Domain',$type), + 'cin' => &mt('Course Institutional Code'), + 'cow' => &mt("[_1] Owner's Username",$type), + 'cog' => &mt('Course or Group') + ); + 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;"; @@ -151,6 +169,25 @@ sub handler { $submitopener = &Apache::lonroles::processpick(); $autosubmit = 'process_pick("'.$roledom.'")'; } + my $instcodeform; + if ($type eq 'Course') { + $instcodeform = $lt{'cin'}.':
'; + } + + my %elements = ( + Course => { + name => 'coursepick', + total => 'coursetotal', + list => 'courselist', + }, + Group => { + name => 'grouppick', + total => 'grouptotal', + list => 'grouplist', + }, + ); + $r->print(< function gochoose(cname,cdom,cdesc,multiple,caller) { @@ -172,26 +209,26 @@ function gochoose(cname,cdom,cdesc,multi } } } - opener.document.$env{'form.form'}.coursetotal.value = courseCount; - if (typeof(opener.document.$env{'form.form'}.coursepick.length) == + opener.document.$env{'form.form'}.$elements{$type}{'total'}.value = courseCount; + if (typeof(opener.document.$env{'form.form'}.$elements{$type}{'name'}.length) == 'undefined') { - if (opener.document.$env{'form.form'}.coursepick.value == 'specific') { - opener.document.$env{'form.form'}.coursepick.checked = true; + if (opener.document.$env{'form.form'}.$elements{$type}{'name'}.value == 'specific') { + opener.document.$env{'form.form'}.$elements{$type}{'name'}.checked = true; } else { - opener.document.$env{'form.form'}.coursepick.checked = false; + opener.document.$env{'form.form'}.$elements{$type}{'name'}.checked = false; } } else { - for (var j=0; j 0) { courses = courses.substr(0,courses.length-2); - opener.document.$env{'form.form'}.courselist.value = courses; + opener.document.$env{'form.form'}.$elements{$type}{'list'}.value = courses; } } else { $name_code @@ -246,7 +283,7 @@ function setSections() { $jscript $submitopener -
+ $name_input @@ -257,9 +294,9 @@ $lt{'cac'}: $sincefilterform
$lt{'cdo'}: $domainselectform
-$lt{'cin'}: - +$lt{'cog'}: $typeselectform
+$instcodeform $lt{'cow'}:
@@ -278,11 +315,12 @@ ENDSCRIPT unless ($instcodefilter) { $instcodefilter='.'; } unless ($ownerfilter) { $ownerfilter='.'; } unless ($coursefilter) { $coursefilter='.'; } + unless ($type) { $type = '.'; } my $timefilter=($sincefilter==-1?1:time-$sincefilter); my %courses= &Apache::lonnet::courseiddump - ($domainfilter,$descriptfilter,$timefilter,$instcodefilter,$ownerfilter,$coursefilter); - $r->print(''); + ($domainfilter,$descriptfilter,$timefilter,$instcodefilter,$ownerfilter,$coursefilter,undef,undef,$type); + $r->print(''); my %by_descrip; my $numcourses = keys(%courses); foreach my $course (keys(%courses)) { @@ -307,7 +345,7 @@ ENDSCRIPT my $cleandesc=&HTML::Entities::encode($description,'<>&"'); $cleandesc=~s/'/\\'/g; my ($cdom,$cnum)=split(/\_/,$course); - my ($descr,$instcode,$owner) = split/:/,$courses{$course}; + my ($descr,$instcode,$owner,$ttype) = split/:/,$courses{$course}; $r->print(&course_chooser($multiple,$cdom,$cnum,$cleandesc)); $r->print($description.'('. ($Apache::lonnet::domaindescription{$cdom}? @@ -318,6 +356,9 @@ ENDSCRIPT unless ($owner eq '') { $r->print(", owner - ".&unescape($owner)); } + unless ($ttype eq '') { + $r->print('('.&Apache::lonnet::unescape($ttype).')'); + } if ($multiple) { $r->print("\n"); } $r->print("
\n"); } @@ -330,7 +371,8 @@ ENDSCRIPT $r->print(''."\n". ''."\n". ''."\n". - ''."\n"); + ''."\n". + ''."\n"); if ((exists($env{'form.roleelement'})) && ($env{'form.form'} eq 'rolechoice')) { $r->print(''."\n"); }