--- loncom/interface/courseprefs.pm 2010/02/22 15:59:28 1.8.2.8
+++ loncom/interface/courseprefs.pm 2009/11/24 13:49:28 1.13
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Handler to set configuration settings for a course
#
-# $Id: courseprefs.pm,v 1.8.2.8 2010/02/22 15:59:28 raeburn Exp $
+# $Id: courseprefs.pm,v 1.13 2009/11/24 13:49:28 bisitz Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -28,185 +28,6 @@
###############################################################
##############################################################
-=pod
-
-=head1 NAME
-
-courseprefs- Handler to set/modify course configuration
-
-=head1 SYNOPSIS
-
-courseprefs provides an interface for setting general course configuration
-
-=head1 DESCRIPTION
-
-This module is used for configuration of a course
-
-=head1 INTERNAL SUBROUTINES
-
-=over
-
-=item get_allitems()
-
-=item print_config_box()
-
-=item process_changes()
-
-=item get_sec_str()
-
-=item check_clone()
-
-=item store_changes()
-
-=item update_env()
-
-=item display_disallowed()
-
-=item get_course()
-
-=item get_jscript()
-
-=item cloners_javascript()
-
-=item print_courseinfo()
-
-=item new_cloners_dom_row()
-
-=item can_modify_catsettings()
-
-=item assign_course_categories()
-
-=item print_localization()
-
-=item get_lang_choices()
-
-=item print_feedback()
-
-=item user_table()
-
-=item select_recipient()
-
-=item select_sections()
-
-=item print_discussion()
-
-=item role_checkboxes()
-
-=item print_classlists()
-
-=item print_appearance()
-
-=item print_grading()
-
-=item print_printouts()
-
-=item print_spreadsheet()
-
-=item print_bridgetasks()
-
-=item print_other()
-
-=item get_other_items()
-
-=item item_table_row_start()
-
-=item item_table_row_end()
-
-=item yes_no_radio()
-
-=item select_from_options()
-
-=item make_item_rows()
-
-Creates table used to display and set course configuration items.
-
-Inputs: $cdom,$items,$ordered,$settings,$rowtotal,$crstype
-where $cdom is course's domain, $items is HASH ref for current config
-item, $ordered is ARRAY ref of items to include in row in
-display order, $settings is HASH ref of current values forrow,
-$rowtotal is SCALAR ref used to accumulate row count, $crstype is
-course type.
-
-Returns: $datatable
-HTML mark-up of data table which accumulates individual rows.
-
-=item nothidepriv_row()
-
-Creates row containing form elements used to display and set
-whether Domain coordinators who are currently included in
-advanced course user .db file for a course are to be hidden (e.g.,
-in syllabus, or from course user lists).
-
-Inputs: $cdom,$item,$settings,$crstype
-where $cdom is course domain, item is nothideprivileged, $settings is
-HASH ref of the current values for nothideprivileged, $crstype is
-course type (Course or Community).
-
-Returns: $datatable
-HTML mark-up for Privileged users (Domain Coordinators) in staff listing.
-
-=item print_hdrfmt_row()
-
-Creates row containing form elements used to display and set
-substitution items and text to be used in the header included
-on printouts.
-
-Inputs: $item,$settings
-where $item is print_header_format, and $settings is a HASH ref
-of the current values stored for print_header_format.
-
-Returns: $output
-HTML mark-up containing Javascript functions: reOrder() and getIndexByName()
-used to dynamically update position selectboxes, and HTML table elements
-for the "Print header format" row.
-
-=item position_selector()
-
-Creates a select box which can be used to reorder substitutions
-and text included in a printout header.
-
-Inputs: $pos,$num,$maxnum
-where $pos is current position, $num is the unique identifier,
-and $maxnum is the total number of items (both substitutions
-and text in the printout header.
-
-Returns: $output
-HTML mark-up for the selectbox and a hidden form element containing
-the current position.
-
-=item substitution_selector()
-
-Creates a combination of select box for choosing an item
-(student name, course ID or assignment note) to substitute,
-and a corresponding size limit in the header used for printouts.
-
-Inputs: $num,$subst,$limit,$crstype
-where $num is the unique identifier, $subst is the current
-substitution (n,c or a, for name, course or note respectively,
-$limit is the current size limit (integer), and $crstype is
-course type - course or community.
-
-Returns: $output
-HTML mark-up for selectbox and textbox (separate table cells).
-
-=item change_clone()
-
-Modifies the list of courses a user can clone (stored
-in the user's environment.db file), called when a
-change is made to the list of users allowed to clone
-a course.
-
-Inputs: $action,$cloner
-where $action is add or drop, and $cloner is identity of
-user for whom cloning ability is to be changed in course.
-
-Returns: nothing
-
-=back
-
-=cut
-
-
package Apache::courseprefs;
use strict;
@@ -272,7 +93,6 @@ sub handler {
gens => 'General community settings',
idnu => 'Community ID or number',
desc => 'Community Description',
- ownr => 'Community Owner',
catg => 'Categorize community',
excc => 'Exclude from community catalog',
clon => 'Users allowed to clone community',
@@ -298,7 +118,6 @@ sub handler {
gens => 'General course settings',
idnu => 'Course ID or number',
desc => 'Course Description',
- ownr => 'Course Owner',
catg => 'Categorize course',
excc => 'Exclude from course catalog',
clon => 'Users allowed to clone course',
@@ -344,11 +163,10 @@ sub handler {
help => 'Course_Environment',
header => [{col1 => 'Setting',
col2 => 'Value'}],
- ordered => ['owner','description','courseid','categories',
+ ordered => ['description','courseid','categories',
'hidefromcat','cloners','externalsyllabus',
'url','rolenames'],
itemtext => {
- owner => $lt{'ownr'},
description => $lt{'desc'},
courseid => $lt{'idnu'},
categories => $lt{'catg'},
@@ -749,14 +567,10 @@ sub process_changes {
my @cloners = split(',',$env{'form.'.$entry});
my @okcloners;
foreach my $cloner (@cloners) {
- $cloner =~ s/^\s+//;
- $cloner =~ s/\s+$//;
- unless ($cloner eq '') {
- my ($uname,$udom) = split(':',$cloner);
- if (&check_clone($udom,$disallowed,$uname) eq 'ok') {
- if (!grep(/^\Q$cloner\E$/,@okcloners)) {
- push(@okcloners,$cloner);
- }
+ my ($uname,$udom) = split(':',$cloner);
+ if (&check_clone($udom,$disallowed,$uname) eq 'ok') {
+ if (!grep(/^\Q$cloner\E$/,@okcloners)) {
+ push(@okcloners,$cloner);
}
}
}
@@ -1046,7 +860,7 @@ sub check_clone {
sub store_changes {
my ($cdom,$cnum,$prefs_order,$actions,$prefs,$values,$changes,$crstype) = @_;
my ($chome,$output);
- my (%storehash,@delkeys,@need_env_update,@oldcloner);
+ my (%storehash,@delkeys,@need_env_update);
if ((ref($values) eq 'HASH') && (ref($changes) eq 'HASH')) {
%storehash = %{$values};
} else {
@@ -1169,9 +983,9 @@ sub store_changes {
$displayname = &mt($text);
}
if (defined($yesno{$key})) {
- $displayval = &mt('No');
+ $displayval = 'no';
if ($changes->{$item}{$key} eq 'yes') {
- $displayval = &mt('Yes');
+ $displayval = 'yes';
}
} elsif (($key =~ /^default_enrollment_(start|end)_date$/) && ($displayval)) {
$displayval = &Apache::lonlocal::locallocaltime($displayval);
@@ -1195,16 +1009,6 @@ sub store_changes {
}
$storehash{$key} = $changes->{$item}{$key};
}
- if ($key eq 'cloners') {
- # Get existing cloners
- my %clonenames =
- &Apache::lonnet::dump('environment',$cdom,$cnum,'cloners');
- if ($clonenames{'cloners'} =~ /,/) {
- @oldcloner = split(/\s*\,\s*/,$clonenames{'cloners'});
- } else {
- $oldcloner[0] = $clonenames{'cloners'};
- }
- }
if (($key eq 'description') || ($key eq 'cloners') ||
($key eq 'hidefromcat') || ($key eq 'categories')) {
push(@need_env_update,$key);
@@ -1224,14 +1028,6 @@ sub store_changes {
}
}
if (&Apache::lonnet::put('environment',\%storehash,$cdom,$cnum) eq 'ok') {
- if (ref($changes) eq 'HASH') {
- if (ref($changes->{'courseinfo'}) eq 'HASH') {
- if (exists($changes->{'courseinfo'}{'cloners'})) {
- &change_clone($cdom,$cnum,$changes->{'courseinfo'}{'cloners'},
- \@oldcloner);
- }
- }
- }
if (@delkeys) {
if (&Apache::lonnet::del('environment',\@delkeys,$cdom,$cnum) ne 'ok') {
$output .= '
';
@@ -1242,10 +1038,6 @@ sub store_changes {
}
$output .= '';
}
- } else {
- foreach my $key (@delkeys) {
- &Apache::lonnet::delenv('course.'.$cdom.'_'.$cnum.'.'.$key);
- }
}
if (@need_env_update) {
$chome = &Apache::lonnet::homeserver($cnum,$cdom);
@@ -1506,7 +1298,7 @@ sub print_courseinfo {
}
}
if (!defined($categoriesform)) {
- $categoriesform = &mt('No categories defined in this domain.');
+ $categoriesform = &mt('No categories defined for this domain');
}
my ($can_toggle_cat,$can_categorize) = &can_modify_catsettings($cdom,$crstype);
@@ -1533,9 +1325,6 @@ sub print_courseinfo {
input => 'textbox',
size => '25',
},
- 'owner' => {
- text => ''.&mt($itemtext->{'owner'}).'',
- },
'courseid' => {
text => ''.&mt($itemtext->{'courseid'}).'
'.'('.
&mt('internal, optional').')',
@@ -1544,7 +1333,7 @@ sub print_courseinfo {
},
'cloners' => {
text => ''.&mt($itemtext->{'cloners'}).'
'.
- &mt('Owner and Coordinators included automatically'),
+ &mt('Coordinators included automatically'),
input => 'textbox',
size => '40',
},
@@ -1616,19 +1405,11 @@ sub print_courseinfo {
if (@entries > 0) {
foreach my $entry (@entries) {
my ($uname,$udom) = split(/:/,$entry);
- my ($uname,$udom) = split(/:/,$entry);
- if ($udom =~ /^$match_domain$/) {
- unless (&Apache::lonnet::domain($udom)) {
- next;
- }
- } else {
- next;
- }
if ($uname eq '*') {
$datatable .=
&Apache::loncommon::start_data_table_row().
'