--- loncom/interface/lonpickcourse.pm 2006/11/03 18:42:11 1.53
+++ loncom/interface/lonpickcourse.pm 2007/10/06 04:32:49 1.65
@@ -1,7 +1,7 @@
# The LearningOnline Network
# Pick a course
#
-# $Id: lonpickcourse.pm,v 1.53 2006/11/03 18:42:11 raeburn Exp $
+# $Id: lonpickcourse.pm,v 1.65 2007/10/06 04:32:49 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -35,7 +35,6 @@ use Apache::loncoursedata;
use Apache::lonnet;
use Apache::lonlocal;
use Apache::longroup;
-use lib '/home/httpd/lib/perl/';
use LONCAPA;
sub handler {
@@ -46,454 +45,409 @@ sub handler {
# ------------------------------------------------------------ Print the screen
-# Get parameters from query string
+ # Get parameters from query string
&Apache::loncommon::get_unprocessed_cgi
- ($ENV{'QUERY_STRING'},['domainfilter','descriptfilter',
- 'sincefilter','form','cnumelement',
+ ($ENV{'QUERY_STRING'},['domainfilter','form','cnumelement',
'cdomelement','cnameelement','roleelement',
- 'pickedcourse','instcodefilter',
- 'ownerfilter','coursefilter','multiple',
- 'type','ownerdomfilter']);
-# domain filter and selection
- 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'};
- unless ($descriptfilter) { $descriptfilter=''; }
- my $listdescript=&HTML::Entities::encode($descriptfilter,'<>&"');
-# institutional code filter
- my $instcodefilter=$env{'form.instcodefilter'};
- unless ($instcodefilter) { $instcodefilter=''; }
- my $listinstcode=&HTML::Entities::encode($instcodefilter,'<>&"');
-# course owner filter
- my $ownerfilter=$env{'form.ownerfilter'};
- $ownerfilter=~s/\W//g;
- my $listowner=&HTML::Entities::encode($ownerfilter,'<>&"');
-# course ownerdomain filter
- my $ownerdomfilter=$env{'form.ownerdomfilter'};
- $ownerdomfilter=~s/\W//g;
- my $ownerdomselectform=
- &Apache::loncommon::select_dom_form($ownerdomfilter,'ownerdomfilter',1);
-# course ID filter for DCs only
- my ($courseidtag,$coursefilter);
- if ($env{'user.adv'} && $domainfilter && exists($env{'user.role.dc./'.
- $domainfilter.'/'})) {
- $coursefilter=$env{'form.coursefilter'};
- unless ($coursefilter) { $coursefilter=''; }
- my $listcourseid=&HTML::Entities::encode($coursefilter,'<>&"');
- $courseidtag = &mt('LON-CAPA course ID');
- $courseidtag .= qq|:
-
- |;
- }
-# last course activity filter and selection
- my $sincefilter=$env{'form.sincefilter'};
- $sincefilter=~s/[^\d-]//g;
- unless ($sincefilter) { $sincefilter=-1; }
- my $sincefilterform=&Apache::loncommon::select_form($sincefilter,
- 'sincefilter',('-1'=>'',
- '86400' => 'today',
- '604800' => 'last week',
- '2592000' => 'last month',
- '7776000' => 'last three months',
- '15552000' => 'last six months',
- '31104000' => 'last year',
- 'select_form_order' =>
- ['-1','86400','604800','2592000','7776000',
- '15552000','31104000']));
-# if called from loncreateuser, report sections, then close
- my (%loaditem,$seclist,$groupslist,$roleslist,$rolesnameslist,
- $accesslist,$accessnameslist);
- my $sec_element = 'currsec';
- my $grplist_element = 'groups';
- my $num_sections = 0;
- my $num_groups = 0;
- my $num_roles = 0;
- my $num_access = 0;
- my ($cdom,$cnum);
- if ($env{'form.pickedcourse'}) {
- ($cdom,$cnum) = split/_/,$env{'form.pickedcourse'};
- }
- my $type = $env{'form.type'};
+ 'multiple','type','setroles']);
+
+ my ($type,$title,$jscript,$multelement,$multiple,$roleelement,
+ $lastaction,$autosubmit,$submitopener);
+
+ # Get course type - Course or Non-standard Course.
+ $type = $env{'form.type'};
if (!defined($env{'form.type'})) {
$type = 'Course';
}
+ $title = &mt('Selecting a [_1]',$type);
+
+ # Setup for multiple course selections, if flag for multiples set.
+ $multiple = $env{'form.multiple'};
+ if ($multiple) {
+ ($jscript,$multelement) = &multiples_tag();
+ $title = &mt('Selecting [_1](s)',lc($type));
+ }
+
+ # if called when a DC is selecting a course
+ my $roledom = $env{'form.roleelement'};
+ if ($roledom) {
+ $roleelement = '';
+ $submitopener = &Apache::lonroles::processpick();
+ $autosubmit = 'process_pick("'.$roledom.'")';
+ }
+
+ my $onlyown = 0;
+ # if called to assign course-based portfolio access control
+ if ((($env{'form.form'} eq 'portform') && (!$env{'user.adv'}))) {
+ $onlyown = 1;
+ }
+
+ my %loaditem;
if ($env{'form.form'} eq 'cu' && $env{'form.pickedcourse'}) {
$loaditem{'onload'} ="setSections()";
- ($seclist,$num_sections,$groupslist,$num_groups) =
- &build_selection_lists($cdom,$cnum,$type,undef,undef,
- $env{'form.form'});
- }
-# if called from portfolio, report roles, sections, groups and close
- my ($roles_element,$groups_element,$status_element,$setitems_function);
- if ($env{'form.form'} eq 'portform' && $env{'form.pickedcourse'}) {
- my ($row_id) = ($env{'form.cnumelement'} =~ /^crsnum_(\d+)$/);
- $roles_element = 'role_'.$row_id.'_1';
- $groups_element = 'group_'.$row_id.'_1';
- $sec_element = 'section_'.$row_id.'_1';
- $status_element = 'access_'.$row_id.'_1';
- $grplist_element = 'grplist_'.$row_id.'_1';
- $loaditem{'onload'} ="setItems()";
- ($seclist,$num_sections,$groupslist,$num_groups,$roleslist,$num_roles,
- $rolesnameslist,$accesslist,$num_access,$accessnameslist) =
- &build_selection_lists($cdom,$cnum,$type,1,1,$env{'form.form'});
- $setitems_function = qq|
-function setItems() {
- opener.document.$env{"form.form"}.activate.checked = true;
- setRoles();
- setGroups();
- setStatus();
- setSections();
-}
+ }
+ $r->print(&Apache::loncommon::start_page($title,undef,
+ {'add_entries' => \%loaditem,
+ 'no_nav_bar' => 1, }));
-function setRoles() {
- var numRoles = $num_roles
- var rolesArray = new Array("$roleslist");
- var roleNamesArray = new Array("$rolesnameslist");
- opener.document.$env{"form.form"}.$roles_element.length = 0;
- if (numRoles == 0) {
- opener.document.$env{"form.form"}.$roles_element.multiple=false;
- opener.document.$env{"form.form"}.$roles_element.size=1;
- opener.document.$env{"form.form"}.$roles_element.options[0] = new Option('No existing roles','',false,false);
+ if ($env{'form.form'} eq 'portform') {
+ $lastaction = 'document.courselist.submit()';
+ } elsif ($env{'form.form'} eq 'cu') {
+ $lastaction =
+ 'document.courselist.pickedcourse.value = cdom+"_"+cname;'."\n".
+ 'document.courselist.submit();';
} else {
- if (numRoles == 1) {
- opener.document.$env{"form.form"}.$roles_element.multiple=false;
- opener.document.$env{"form.form"}.$roles_element.size=1;
- opener.document.$env{"form.form"}.$roles_element.options[0] = new Option('Select','',true,true);
- opener.document.$env{"form.form"}.$roles_element.options[1] = new Option(roleNamesArray[0],rolesArray[0],false,false);
- } else {
- for (var i=0; iprint(&create_user_javascript($type));
+ }
+
+ # print javascript functions for choosing a course
+ if ($env{'form.gosearch'} || $onlyown) {
+ $r->print(&gochoose_javascript($type,$multiple,$autosubmit,$lastaction));
+ }
+ $r->print('');
+ $r->print($submitopener);
+
+# ------------------------------------------ Display of filters to limit search
+ my $filter = {};
+ my $action = '/adm/pickcourse';
+ if (!$onlyown) {
+ my $filterlist = ['domainfilter','descriptfilter',
+ 'instcodefilter','ownerfilter',
+ 'ownerdomfilter'];
+ # course ID filter for DCs only
+ if ($env{'user.adv'} && $env{'form.domainfilter'} &&
+ exists($env{'user.role.dc./'.$env{'form.domainfilter'}.'/'})) {
+ push(@{$filterlist},'coursefilter');
}
+ $r->print(&build_filters($filterlist,$type,$roleelement,$multelement,
+ $filter,$action));
}
+
+# ---------------------------------------------------------------- Get the data
+ if ($env{'form.gosearch'} || $onlyown) {
+ my %courses = &search_courses($r,$type,$onlyown,$filter);
+ &display_matched_courses($r,$type,$multiple,$action,%courses);
+ }
+ $r->print(&Apache::loncommon::end_page());
+ return OK;
}
-function setStatus() {
- var numStatus = $num_access;
- var statusArray = new Array("$accesslist");
- var statusNamesArray = new Array("$accessnameslist");
- opener.document.$env{"form.form"}.$status_element.multiple=true;
- opener.document.$env{"form.form"}.$status_element.size=3;
- for (var i=0; i
+function setSections() {
+ opener.document.$env{"form.form"}.$grplist_element.value='$groupslist';
+ window.opener.setSect('$seclist');
+ self.close()
+}
+
+|;
+;
}
+ return $output;
}
-function setGroups() {
- var numGroups = $num_groups;
- var groupsArray = new Array("$groupslist");
- opener.document.$env{"form.form"}.$groups_element.length = 0;
- if (numGroups == 0) {
- opener.document.$env{"form.form"}.$groups_element.multiple=false;
- opener.document.$env{"form.form"}.$groups_element.size=1;
- opener.document.$env{"form.form"}.$groups_element.options[0] = new Option('No existing groups','',false,false);
- } else {
- if (numGroups == 1) {
- opener.document.$env{"form.form"}.$groups_element.multiple=false;
- opener.document.$env{"form.form"}.$groups_element.size=1;
- opener.document.$env{"form.form"}.$groups_element.options[0] = new Option('Select','',true,true);
- opener.document.$env{"form.form"}.$groups_element.options[1] = new Option('No group','',false,false);
- opener.document.$env{"form.form"}.$groups_element.options[2] = new Option(groupsArray[0],groupsArray[0],false,false);
+sub display_matched_courses {
+ my ($r,$type,$multiple,$action,%courses) = @_;
+ if ($env{'form.form'} eq 'portform') {
+ $action = '/adm/portfolio';
+ }
+ $r->print('\n");
+ return;
}
-|;
- }
- my $jscript;
- 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 = &mt('Selecting [_1](s)',lc($type));
- $jscript = &Apache::loncommon::check_uncheck_jscript();
- $multelement = '';
+ my ($domainselectform,$sincefilterform,$ownerdomselectform,
+ $instcodeform,$typeselectform);
+ foreach my $item (@{$filterlist}) {
+ $filter->{$item} = $env{'form.'.$item};
+ if ($item ne 'descriptfilter' && $item ne 'instcodefilter') {
+ if ($item eq 'domainfilter' || $item eq 'ownerdomfilter') {
+ $filter->{$item} = &LONCAPA::clean_domain($filter->{$item});
+ } elsif ($item eq 'coursefilter') {
+ $filter->{$item} = &LONCAPA::clean_courseid($filter->{$item});
+ } elsif ($item eq 'ownerfilter') {
+ $filter->{$item} = &LONCAPA::clean_username($filter->{$item});
+ } else {
+ $filter->{$item} =~ s/\W//g;
+ }
+ if (!$filter->{$item}) {
+ $filter->{$item} = '';
+ }
+ }
+ if ($item eq 'domainfilter') {
+ my $allow_blank = 1;
+ if ($formname eq 'portform') {
+ $filter->{$item} ||= $env{'user.domain'};
+ $allow_blank=0;
+ }
+ $domainselectform =
+ &Apache::loncommon::select_dom_form($filter->{$item},
+ 'domainfilter',
+ $allow_blank);
+ } elsif ($item eq 'ownerdomfilter') {
+ $ownerdomselectform =
+ &Apache::loncommon::select_dom_form($filter->{$item},'ownerdomfilter',1);
+ } else {
+ $list->{$item} = &HTML::Entities::encode($filter->{$item},'<>&"');
+ }
}
- $r->print(&Apache::loncommon::start_page($title,undef,
- {'add_entries' => \%loaditem,
- 'no_nav_bar' => 1, }));
+
+ # last course activity filter and selection
+ $filter->{'sincefilter'} = $env{'form.sincefilter'};
+ $filter->{'sincefilter'} =~ s/[^\d-]//g;
+ if (!$filter->{'sincefilter'}) { $filter->{'sincefilter'}=-1; }
+ $sincefilterform=&Apache::loncommon::select_form($filter->{'sincefilter'},
+ 'sincefilter',('-1'=>'',
+ '86400' => 'today',
+ '604800' => 'last week',
+ '2592000' => 'last month',
+ '7776000' => 'last three months',
+ '15552000' => 'last six months',
+ '31104000' => 'last year',
+ 'select_form_order' =>
+ ['-1','86400','604800','2592000','7776000',
+ '15552000','31104000']));
+
my %lt = (
- 'cac' => &mt('[_1] Activity',$type),
- 'cde' => &mt('[_1] Description',$type),
- 'cdo' => &mt('[_1] Domain',$type),
+ '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),
'cod' => &mt("[_1] Owner's Domain", $type),
'cog' => &mt('Course Type')
);
-
- 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;";
- $name_input ='';
- }
- my $submitopener = '';
- my $autosubmit = '';
- my $roleelement = '';
- my $lastaction = 'self.close()';
- if ($env{'form.form'} eq 'cu') {
- $lastaction = 'document.courselist.pickedcourse.value = cdom+"_"+cname;'."\n".
- 'document.courselist.submit();';
- }
- if ($env{'form.form'} eq 'portform') {
- $lastaction = 'document.courselist.pickedcourse.value = cdom+"_"+cname;'."\n".
- 'document.courselist.submit();';
- }
- my $roledom = $env{'form.roleelement'};
- if ($roledom) {
- $roleelement = '';
- $submitopener = &Apache::lonroles::processpick();
- $autosubmit = 'process_pick("'.$roledom.'")';
- }
- my $instcodeform;
+
+ $typeselectform = '