';
if (($action eq 'feedback') || ($action eq 'classlists')) {
$output .= '
-
-
-
-
+ ';
+ if (exists $item->{'header'}->[0]->{'col1'} ||
+ exists $item->{'header'}->[0]->{'col2'}) {
+ $output .= '
+
'.&mt($item->{'header'}->[0]->{'col1'}).' |
'.&mt($item->{'header'}->[0]->{'col2'}).' |
- ';
+ ';
+ }
$rowtotal ++;
if ($action eq 'feedback') {
$output .= &print_feedback('top',$cdom,$settings,$ordered,$itemtext,\$rowtotal);
@@ -573,10 +372,6 @@ sub print_config_box {
}
$output .= '
-
-
-
-
'.&mt($item->{'header'}->[1]->{'col1'}).' | ';
@@ -587,25 +382,27 @@ sub print_config_box {
$output .= &print_classlists('middle',$cdom,$settings,$itemtext,\$rowtotal,$crstype).
'
- |
-
-
-
-
-
- '.&mt($item->{'header'}->[2]->{'col1'}).' |
- '.&mt($item->{'header'}->[2]->{'col2'}).' |
- ';
+ ';
+ if (exists $item->{'header'}->[0]->{'col1'} ||
+ exists $item->{'header'}->[0]->{'col2'}) {
+ $output .= '
+
+ '.&mt($item->{'header'}->[0]->{'col1'}).' |
+ '.&mt($item->{'header'}->[0]->{'col2'}).' |
+ ';
+ }
}
} else {
$output .= '
-
-
-
-
+ ';
+ if (exists $item->{'header'}->[0]->{'col1'} ||
+ exists $item->{'header'}->[0]->{'col2'}) {
+ $output .= '
+
'.&mt($item->{'header'}->[0]->{'col1'}).' |
'.&mt($item->{'header'}->[0]->{'col2'}).' |
- ';
+ ';
+ }
}
$rowtotal ++;
if ($action eq 'courseinfo') {
@@ -633,9 +430,7 @@ sub print_config_box {
}
$output .= '
-
-
- ';
+';
return ($output,$rowtotal);
}
@@ -752,14 +547,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);
}
}
}
@@ -780,80 +571,6 @@ sub process_changes {
}
}
}
- } elsif ($entry eq 'co-owners') {
- my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
- my $coowners = $values->{'internal.co-owners'};
- my @currcoown;
- if ($coowners) {
- @currcoown = split(',',$coowners);
- }
- if (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- my $autocoowner;
- if (($crstype eq 'Course') &&
- ($values->{'internal.coursecode'})) {
- my %domconf =
- &Apache::lonnet::get_dom('configuration',['autoenroll'],$cdom);
- if (ref($domconf{'autoenroll'}) eq 'HASH') {
- $autocoowner = $domconf{'autoenroll'}{'co-owners'};
- }
- }
- unless ($autocoowner) {
- my @keepcoowners = &Apache::loncommon::get_env_multiple('form.coowners');
- my @pendingcoowners = &Apache::loncommon::get_env_multiple('form.pendingcoowners');
- my @invitecoowners = &Apache::loncommon::get_env_multiple('form.invitecoowners');
- if (@invitecoowners) {
- push(@pendingcoowners,@invitecoowners);
- }
- $newvalues{'pendingco-owners'} = join(',',sort(@pendingcoowners));
- $newvalues{'co-owners'} = join(',',sort(@keepcoowners));
- if ($newvalues{'co-owners'} ne $values->{'internal.co-owners'}) {
- $changes->{$entry}{'co-owners'} = $newvalues{'co-owners'};
- push(@{$changes->{$entry}{'changed'}},'co-owners');
- }
- if ($newvalues{'pendingco-owners'} ne $values->{'internal.pendingco-owners'}) {
- $changes->{$entry}{'pendingco-owners'} = $newvalues{'pendingco-owners'};
- push(@{$changes->{$entry}{'changed'}},'pendingco-owners');
- }
- }
- } else {
- my (@newpending,@newcoown);
- my $uname = $env{'user.name'};
- my $udom = $env{'user.domain'};
- my $pendingcoowners = $values->{'internal.pendingco-owners'};
- my @pendingcoown = split(',',$pendingcoowners);
- if ($env{'form.pending_coowoner'}) {
- foreach my $item (@pendingcoown) {
- unless ($item eq $uname.':'.$udom) {
- push(@newpending,$item);
- }
- }
- @newcoown = @currcoown;
- if ($env{'form.pending_coowoner'} eq 'accept') {
- unless (grep(/^\Q$uname\E:\Q$udom\E$/,@currcoown)) {
- push(@newcoown,$uname.':'.$udom);
- }
- }
- } elsif ($env{'form.remove_coowoner'}) {
- foreach my $item (@currcoown) {
- unless ($item eq $uname.':'.$udom) {
- push(@newcoown,$item);
- }
- }
- if ($pendingcoowners ne '') {
- @newpending = @pendingcoown;
- }
- }
- $newvalues{'pendingco-owners'} = join(',',sort(@newpending));
- $newvalues{'co-owners'} = join(',',sort(@newcoown));
- if ($newvalues{'co-owners'} ne $values->{'internal.co-owners'}) {
- $changes->{$entry}{'co-owners'} = $newvalues{'co-owners'};
- push(@{$changes->{$entry}{'changed'}},'co-owners');
- }
- if ($newvalues{'pendingco-owners'} ne $values->{'internal.pendingco-owners'}) {
- $changes->{$entry}{'pendingco-owners'} = $newvalues{'pendingco-owners'};
- push(@{$changes->{$entry}{'changed'}},'pendingco-owners');
- }
- }
} elsif ($entry =~ /^default_enrollment_(start|end)_date$/) {
$newvalues{$entry}=&Apache::lonhtmlcommon::get_date_from_form($entry);
} elsif ($entry eq 'rolenames') {
@@ -1070,10 +787,8 @@ sub process_changes {
} else {
$newvalues{$entry} = $env{'form.'.$entry};
}
- unless ($entry eq 'co-owners') {
- if ($newvalues{$entry} ne $values->{$entry}) {
- $changes->{$entry} = $newvalues{$entry};
- }
+ if ($newvalues{$entry} ne $values->{$entry}) {
+ $changes->{$entry} = $newvalues{$entry};
}
}
}
@@ -1125,7 +840,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 {
@@ -1196,10 +911,7 @@ sub store_changes {
next if (!exists($changes->{$item}{$key}));
my ($displayname,$text);
$text = $prefs->{$item}->{'itemtext'}{$key};
- my $displayval;
- unless ($key eq 'co-owners') {
- $displayval = $changes->{$item}{$key};
- }
+ my $displayval = $changes->{$item}{$key};
if ($item eq 'feedback') {
if ($key =~ /^(question|policy|comment)(\.email)\.text$/) {
$text = $prefs->{$item}->{'itemtext'}{$1.$2};
@@ -1253,62 +965,27 @@ sub store_changes {
if (defined($yesno{$key})) {
$displayval = &mt('No');
if ($changes->{$item}{$key} eq 'yes') {
- $displayval = &mt('Yes');
+ $displayval = &mt('Yes');
}
} elsif (($key =~ /^default_enrollment_(start|end)_date$/) && ($displayval)) {
$displayval = &Apache::lonlocal::locallocaltime($displayval);
} elsif ($key eq 'categories') {
$displayval = $env{'form.categories_display'};
- }
- if ($key eq 'co-owners') {
- if (ref($changes->{$item}{$key}) eq 'HASH') {
- if (ref($changes->{$item}{$key}{'changed'}) eq 'ARRAY') {
- foreach my $type ('co-owners','pendingco-owners') {
- next unless (grep(/^\Q$type\E$/,@{$changes->{$item}{$key}{'changed'}}));
- if ($type eq 'pendingco-owners') {
- if (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- $displayname = &mt('Invited as co-owners, pending acceptance');
- }
- }
- if ($changes->{$item}{$key}{$type} eq '') {
- push(@delkeys,'internal.'.$type);
- if (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('Deleted setting for [_1]',
- ''.$displayname.'')).'';
- }
- } elsif (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- $displayval = join(', ',map { &Apache::loncommon::plainname(split(':',$_)); } split(',',$changes->{$item}{$key}{$type}));
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',
- ''.$displayname.'',
- "'$displayval'")).'';
- }
- }
- }
- unless (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- if ($env{'form.pending_coowoner'} eq 'accept') {
- $displayval = &mt('on');
- } elsif ($env{'form.pending_coowoner'} eq 'decline') {
- $displayval = '';
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('Invitation to be co-owner declined')).'';
- } elsif ($env{'form.remove_coowoner'}) {
- $displayval = &mt('off');
- }
- if ($displayval) {
- $displayname = &mt('Your co-ownership status');
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',
- ''.$displayname.'',
- "'$displayval'")).'';
- }
- }
+ } elsif ($key eq 'canuse_pdfforms') {
+ if ($changes->{$item}{$key} eq '1') {
+ $displayval = &mt('Yes');
+ } elsif ($changes->{$item}{$key} eq '0') {
+ $displayval = &mt('No');
}
- } elsif ($changes->{$item}{$key} eq '') {
+ }
+ if ($changes->{$item}{$key} eq '') {
push(@delkeys,$key);
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('Deleted setting for [_1]',
- ''.$displayname.'')).'';
+ $output .= ''.&mt('Deleted setting for [_1]',
+ ''.$displayname.'').'';
} else {
- $output .= ''.&Apache::lonhtmlcommon::confirm_success(&mt('[_1] set to [_2]',
+ $output .= ''.&mt('[_1] set to [_2]',
''.$displayname.'',
- "'$displayval'"));
+ "'$displayval'");
if ($key eq 'url') {
my $bkuptime=time;
$output .= (' 'x2).&mt('(Previous URL backed up)').': '.
@@ -1316,32 +993,10 @@ sub store_changes {
}
$output .= '';
}
- if ($key eq 'co-owners') {
- if (ref($changes->{$item}{$key}) eq 'HASH') {
- if (ref($changes->{$item}{$key}{'changed'}) eq 'ARRAY') {
- foreach my $type ('co-owners','pendingco-owners') {
- next unless (grep(/^\Q$type\E$/,@{$changes->{$item}{$key}{'changed'}}));
- $storehash{'internal.'.$type} = $changes->{$item}{$key}{$type};
- }
- }
- }
- } else {
- $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'};
- }
+ $storehash{$key} = $changes->{$item}{$key};
}
if (($key eq 'description') || ($key eq 'cloners') ||
- ($key eq 'hidefromcat') || ($key eq 'categories') ||
- ($key eq 'co-owners')) {
+ ($key eq 'hidefromcat') || ($key eq 'categories')) {
push(@need_env_update,$key);
}
}
@@ -1359,14 +1014,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 .= ' ';
@@ -1376,10 +1023,10 @@ sub store_changes {
$output .= &mt('An error occurred when removing course settings which are no longer in use.');
}
$output .= '';
- }
- } else {
- foreach my $key (@delkeys) {
- &Apache::lonnet::delenv('course.'.$cdom.'_'.$cnum.'.'.$key);
+ } else {
+ foreach my $key (@delkeys) {
+ &Apache::lonnet::delenv('course.'.$cdom.'_'.$cnum.'.'.$key);
+ }
}
}
if (@need_env_update) {
@@ -1415,16 +1062,6 @@ sub update_env {
&Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.'.$key => $storehash->{$key}});
$crsinfo{$env{'request.course.id'}}{$key} = $storehash->{$key};
$count ++;
- } elsif ($key eq 'co-owners') {
- if ($storehash->{'internal.co-owners'} ne '') {
- &Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.internal.co-owners' => $storehash->{'internal.co-owners'}});
- }
- if ($storehash->{'internal.pendingco-owners'} ne '') {
- &Apache::lonnet::appenv({'course.'.$env{'request.course.id'}.'.internal.pendingco-owners' => $storehash->{'internal.pendingco-owners'}});
- }
- my @coowners = split(',',$storehash->{'internal.'.$key});
- $crsinfo{$env{'request.course.id'}}{'co-owners'} = \@coowners;
- $count ++;
}
}
if ($count) {
@@ -1639,9 +1276,9 @@ sub print_courseinfo {
unless ((ref($settings) eq 'HASH') && (ref($ordered) eq 'ARRAY') && (ref($itemtext) eq 'HASH')) {
return;
}
- my ($cathash,$categoriesform,$autocoowner);
+ my ($cathash,$categoriesform);
my %domconf =
- &Apache::lonnet::get_dom('configuration',['coursecategories','autoenroll'],$cdom);
+ &Apache::lonnet::get_dom('configuration',['coursecategories'],$cdom);
if (ref($domconf{'coursecategories'}) eq 'HASH') {
$cathash = $domconf{'coursecategories'}{'cats'};
if (ref($cathash) eq 'HASH') {
@@ -1650,9 +1287,6 @@ sub print_courseinfo {
$settings->{'categories'},$crstype)."\n";
}
}
- if (ref($domconf{'autoenroll'}) eq 'HASH') {
- $autocoowner = $domconf{'autoenroll'}{'co-owners'};
- }
if (!defined($categoriesform)) {
$categoriesform = &mt('No categories defined in this domain.');
}
@@ -1675,18 +1309,13 @@ sub print_courseinfo {
'',
input => 'textbox',
size => '40',
+ advanced => 1
},
'description' => {
text => ''.&mt($itemtext->{'description'}).'',
input => 'textbox',
size => '25',
},
- 'owner' => {
- text => ''.&mt($itemtext->{'owner'}).'',
- },
- 'co-owners' => {
- text => ''.&mt($itemtext->{'co-owners'}).'',
- },
'courseid' => {
text => ''.&mt($itemtext->{'courseid'}).' '.'('.
&mt('internal, optional').')',
@@ -1695,15 +1324,17 @@ sub print_courseinfo {
},
'cloners' => {
text => ''.&mt($itemtext->{'cloners'}).' '.
- &mt('Owner and Coordinators included automatically'),
+ &mt('Coordinators included automatically'),
input => 'textbox',
size => '40',
+ advanced => 1
},
'rolenames' => {
text => ''.&mt($itemtext->{'rolenames'}).' '.
'('.$replace.')',
input => 'textbox',
size => '20',
+ advanced => 1
},
'externalsyllabus' => {
text => ''.&mt($itemtext->{'externalsyllabus'}).' ('.
@@ -1732,7 +1363,11 @@ sub print_courseinfo {
next if (!$can_categorize);
}
$count ++;
- $datatable .= &item_table_row_start($items{$item}{text},$count);
+ if (exists $items{$item}{advanced} && $items{$item}{advanced} == 1) {
+ $datatable .= &item_table_row_start($items{$item}{text},$count,"advanced");
+ } else {
+ $datatable .= &item_table_row_start($items{$item}{text},$count);
+ }
if ($items{$item}{input} eq 'radio') {
$datatable .= &yesno_radio($item,$settings);
} elsif ($item eq 'cloners') {
@@ -1767,18 +1402,11 @@ sub print_courseinfo {
if (@entries > 0) {
foreach my $entry (@entries) {
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().
' | '.
- &mt('Any user in domain:').' '.$udom.
+ &mt('Domain:').' '.$udom.
' '.
' | '.
&Apache::loncommon::end_data_table_row();
$num ++;
- } elsif (&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') {
- unless (grep(/^\Q$entry\E$/,@cloners)) {
- push(@cloners,$entry);
- }
+ } else {
+ push(@cloners,$entry);
}
}
}
@@ -1845,38 +1471,6 @@ sub print_courseinfo {
$datatable .= ''.
&Apache::lonhtmlcommon::textbox($item.'_display',$settings->{$item},
$items{$item}{size},$launcher);
- } elsif ($item eq 'owner') {
- my $owner = $env{'course.'.$env{'request.course.id'}.'.internal.courseowner'};
- if ($owner =~ /:/) {
- my ($ownername,$ownerdom) = split(':',$owner);
- $owner = &Apache::loncommon::plainname($ownername,$ownerdom);
- } elsif ($owner ne '') {
- $owner = &Apache::loncommon::plainname($owner,$cdom);
- } else {
- $owner = &mt('None specified');
- }
- my $domdesc = &Apache::lonnet::domain($cdom,'description');
- $datatable .= $owner;
- } elsif ($item eq 'co-owners') {
- my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
- my $coowners = $env{'course.'.$env{'request.course.id'}.'.internal.co-owners'};
- my @currcoown;
- if ($coowners) {
- @currcoown = split(',',$coowners);
- }
- if (&Apache::lonnet::is_course_owner($cdom,$cnum)) {
- if (($crstype eq 'Course') && ($env{'course.'.$env{'request.course.id'}.'.internal.coursecode'}) && ($autocoowner)) {
- $datatable .= &show_autocoowners(@currcoown);
- } else {
- $datatable .= &coowner_invitations($cnum,$cdom,@currcoown);
- }
- } else {
- if (($crstype eq 'Course') && ($env{'course.'.$env{'request.course.id'}.'.internal.coursecode'}) && ($autocoowner)) {
- $datatable .= &show_autocoowners(@currcoown);
- } else {
- $datatable .= &manage_coownership($cnum,$cdom,@currcoown);
- }
- }
} else {
$datatable .= &Apache::lonhtmlcommon::textbox($item,$settings->{$item},$items{$item}{size});
}
@@ -2034,128 +1628,6 @@ ENDSCRIPT
return;
}
-sub show_autocoowners {
- my (@currcoown) = @_;
- my $output = ''.&mt('Co-ownership is set automatically when a Course Coordinator role is assigned to official course personnel (from institutional data).').'';
- if (@currcoown > 0) {
- $output .= ' '.&mt('Current co-owners are:').' '.
- join(', ',map { &Apache::loncommon::plainname(split(':',$_)); } (@currcoown));
- } else {
- $output .= ' '.&mt('Currently no co-owners.');
- }
- return $output;
-}
-
-sub coowner_invitations {
- my ($cnum,$cdom,@currcoown) = @_;
- my ($output,@pendingcoown,@othercoords);
- my $pendingcoowners =
- $env{'course.'.$env{'request.course.id'}.'.internal.pendingco-owners'};
- if ($pendingcoowners) {
- @pendingcoown = split(',',$pendingcoowners);
- }
- my $ccrole = 'cc';
- my %ccroles = &Apache::lonnet::get_my_roles($cnum,$cdom,undef,undef,[$ccrole]);
- foreach my $key (sort(keys(%ccroles))) {
- my ($ccname,$ccdom,$role) = split(':',$key);
- next if ($key eq $env{'user.name'}.':'.$env{'user.domain'}.':'.$ccrole);
- unless (grep(/^\Q$ccname\E:\Q$ccdom\E$/,@currcoown,@pendingcoown)) {
- push(@othercoords,$ccname.':'.$ccdom);
- }
- }
- my $coowner_rows = @currcoown + @pendingcoown + @othercoords;
- if ($coowner_rows) {
- $output .= &Apache::loncommon::start_data_table();
- if (@currcoown) {
- $output .= &Apache::loncommon::start_data_table_row().
- ''.&mt('Current co-owners').' | ';
- foreach my $person (@currcoown) {
- my ($co_uname,$co_dom) = split(':',$person);
- $output .= ''.(' 'x2).' ';
- }
- $output .= ' | '.
- &Apache::loncommon::end_data_table_row();
- }
- if ($pendingcoowners) {
- $output .= &Apache::loncommon::start_data_table_row().
- ''.&mt('Invited as co-owners [_1](agreement pending)',' ').' | ';
- foreach my $person (@pendingcoown) {
- my ($co_uname,$co_dom) = split(':',$person);
- $output .= ''.(' 'x2).' ';
- }
- $output .= ' | '.
- &Apache::loncommon::end_data_table_row();
- }
- if (@othercoords) {
- $output .= &Apache::loncommon::start_data_table_row().
- ''.&mt('Invite other Coordinators [_1]to become co-owners',' ').' | ';
- foreach my $person (@othercoords) {
- my ($co_uname,$co_dom) = split(':',$person);
- $output .= ''.(' 'x2).' ';
- }
- $output .= ' | '.
- &Apache::loncommon::end_data_table_row();
- }
- $output .= &Apache::loncommon::end_data_table();
- } else {
- $output = &mt('There are no coordinators to select as co-owners');
- }
- return $output;
-}
-
-sub manage_coownership {
- my ($cnum,$cdom,@currcoown) = @_;
- my (@pendingcoown);
- my $pendingcoowners =
- $env{'course.'.$env{'request.course.id'}.'.internal.pendingco-owners'};
- if ($pendingcoowners) {
- @pendingcoown = split(',',$pendingcoowners);
- }
- my ($is_coowner,$is_pending,$output);
- my $uname = $env{'user.name'};
- my $udom = $env{'user.domain'};
- if (grep(/^\Q$uname\E:\Q$udom\E$/,@currcoown)) {
- $is_coowner = 1;
- }
- if (grep(/^\Q$uname\E:\Q$udom\E$/,@pendingcoown)) {
- $is_pending = 1;
- }
- if (@currcoown && ($is_coowner || $is_pending)) {
- $output = &Apache::loncommon::start_data_table();
- }
- if (@currcoown) {
- if ($is_coowner || $is_pending) {
- $output .= &Apache::loncommon::start_data_table().
- &Apache::loncommon::start_data_table_row().'';
- }
- $output .= &mt('Current co-owners are:').' '.
- join(', ', map { &Apache::loncommon::plainname(split(':',$_)); } (@currcoown));
- if ($is_coowner || $is_pending) {
- $output .= ' | '.&Apache::loncommon::end_data_table_row();
- }
- }
- if ($is_coowner || $is_pending) {
- if (@currcoown) {
- $output .= &Apache::loncommon::start_data_table_row().'';
- }
- $output .= '';
- if ($is_coowner) {
- $output .= &mt('You are currently a co-owner:').' ';
- } else {
- $output .= &mt('The course owner has invited you to become a co-owner:').' '.(' 'x2).
- '';
- }
- $output .= '';
- if (@currcoown) {
- $output .= ' | '.&Apache::loncommon::end_data_table_row();
- }
- }
- if (@currcoown && ($is_coowner || $is_pending)) {
- $output .= &Apache::loncommon::end_data_table();
- }
- return $output;
-}
-
sub print_localization {
my ($cdom,$settings,$ordered,$itemtext,$rowtotal) = @_;
unless ((ref($settings) eq 'HASH') && (ref($ordered) eq 'ARRAY') && (ref($itemtext) eq 'HASH')) {
@@ -2163,16 +1635,16 @@ sub print_localization {
}
my %items = (
languages => {
- text => &mt($itemtext->{'languages'}).' '.
- &mt("(will override user's preference)"),
+ text => ''.&mt($itemtext->{'languages'}).' '.
+ &mt("(overrides individual user preference)"),
input => 'selectbox',
},
timezone => {
- text => &mt($itemtext->{'timezone'}),
+ text => ''.&mt($itemtext->{'timezone'}).'',
input => 'selectbox',
},
datelocale => {
- text => &mt($itemtext->{'datelocale'}),
+ text => ''.&mt($itemtext->{'datelocale'}).'',
input => 'selectbox',
},
);
@@ -2281,11 +1753,11 @@ sub print_feedback {
my %sections = &Apache::loncommon::get_sections($cdom,$cnum);
my @sections = sort( { $a <=> $b } keys(%sections));
my %lt = &Apache::lonlocal::texthash (
- currone => 'Current recipient:',
- currmult => 'Current recipients:',
- add => 'Additional recipient:',
- del => 'Delete?',
- sec => 'Sections:',
+ currone => 'Current recipient:',
+ curmult => 'Current recipients:',
+ add => 'Additional recipient:',
+ del => 'Delete?',
+ sec => 'Sections:',
);
foreach my $item (@{$ordered}) {
@@ -2346,7 +1818,7 @@ sub user_table {
if ($num) {
$output .= ' '.
'';
- if ($num == 1) {
+ if ($num > 1) {
$output .= $lt->{'currone'};
} else {
$output .= $lt->{'currmult'};
@@ -2466,11 +1938,11 @@ sub print_discussion {
my %sections = &Apache::loncommon::get_sections($cdom,$cnum);
my @sections = sort( { $a <=> $b } keys(%sections));
my %lt = &Apache::lonlocal::texthash (
- currone => 'Disallowed:',
- currmult => 'Disallowed:',
- add => 'Disallow more:',
- del => 'Delete?',
- sec => 'Sections:',
+ currone => 'Disallowed:',
+ curmult => 'Disallowed:',
+ add => 'Disallow more:',
+ del => 'Delete?',
+ sec => 'Sections:',
);
foreach my $item (@{$ordered}) {
@@ -2629,8 +2101,7 @@ sub print_classlists {
@ordered = ('nothideprivileged');
} else {
@ordered = ('student_classlist_view',
- 'student_classlist_opt_in',
- 'student_classlist_portfiles');
+ 'student_opt_in','student_classlist_portfiles');
}
my %lt;
@@ -2669,8 +2140,8 @@ sub print_classlists {
options => \%lt,
order => ['disabled','all','section'],
},
- 'student_classlist_opt_in' => {
- text => ''.&mt($itemtext->{'student_classlist_opt_in'}).'',
+ 'student_opt_in' => {
+ text => ''.&mt($itemtext->{'student_opt_in'}).'',
input => 'radio',
},
@@ -2755,7 +2226,7 @@ sub print_grading {
},
'rndseed' => {
text => ''.&mt($itemtext->{'rndseed'}).''.
- ''.' '.
+ ''.' '.
&mt('Modifying this will make problems have different numbers and answers!').
'',
input => 'selectbox',
@@ -2827,6 +2298,16 @@ sub print_printouts {
text => ''.&mt($itemtext->{'disableexampointprint'}).'',
input => 'radio',
},
+ canuse_pdfforms => {
+ text => ''.&mt($itemtext->{'canuse_pdfforms'}).'',
+ input => 'selectbox',
+ options => {
+ 1 => &mt('Yes'),
+ 0 => &mt('No'),
+ },
+ order => ['1','0'],
+ nullval => 'None specified - use domain default',
+ }
);
return &make_item_rows($cdom,\%items,$ordered,$settings,$rowtotal,$crstype);
}
@@ -2957,15 +2438,13 @@ sub get_other_items {
}
sub item_table_row_start {
- my ($text,$count) = @_;
+ my ($text,$count,$add_class) = @_;
my $output;
- if ($count%2) {
- $output .= '';
- } else {
- $output .= ' ';
- }
+ my $css_class = ($count % 2) ? 'LC_odd_row' : 'LC_even_row';
+ $css_class = (join(' ',$css_class,$add_class)) unless ($add_class eq '');
+ $output .= ' '."\n";;
$output .= ''.$text.
- ' | ';
+ ' | ';
return $output;
}
@@ -3161,9 +2640,9 @@ sub print_hdrfmt_row {
$currstr .= ''.&mt('Current print header:').' '.
$settings->{$item}.' ';
my @current = split(/(%\d*[nca])/,$settings->{$item});
- foreach my $val (@current) {
- unless ($val eq '') {
- push(@curr,$val);
+ foreach my $item (@current) {
+ unless ($item eq '') {
+ push(@curr,$item);
}
}
$currnum = @curr;
@@ -3316,66 +2795,4 @@ sub substitution_selector {
return $output;
}
-sub change_clone {
- my ($cdom,$cnum,$clonelist,$oldcloner) = @_;
- my $clone_crs = $cnum.':'.$cdom;
- if ($cnum && $cdom) {
- my $clone_crs = $cnum.':'.$cdom;
- my @allowclone;
- if ($clonelist =~ /,/) {
- @allowclone = split(',',$clonelist);
- } else {
- $allowclone[0] = $clonelist;
- }
- foreach my $currclone (@allowclone) {
- if (!grep(/^$currclone$/,@$oldcloner)) {
- if ($currclone ne '*') {
- my ($uname,$udom) = split(/:/,$currclone);
- if ($uname && $udom && $uname ne '*') {
- if (&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') {
- my %currclonecrs = &Apache::lonnet::dump('environment',$udom,$uname,'cloneable');
- if ($currclonecrs{'cloneable'} !~ /\Q$clone_crs\E/) {
- if ($currclonecrs{'cloneable'} eq '') {
- $currclonecrs{'cloneable'} = $clone_crs;
- } else {
- $currclonecrs{'cloneable'} .= ','.$clone_crs;
- }
- &Apache::lonnet::put('environment',\%currclonecrs,$udom,$uname);
- }
- }
- }
- }
- }
- }
- foreach my $oldclone (@$oldcloner) {
- if (!grep(/^\Q$oldclone\E$/,@allowclone)) {
- if ($oldclone ne '*') {
- my ($uname,$udom) = split(/:/,$oldclone);
- if ($uname && $udom && $uname ne '*' ) {
- if (&Apache::lonnet::homeserver($uname,$udom) ne 'no_host') {
- my %currclonecrs = &Apache::lonnet::dump('environment',$udom,$uname,'cloneable');
- my %newclonecrs = ();
- if ($currclonecrs{'cloneable'} =~ /\Q$clone_crs\E/) {
- if ($currclonecrs{'cloneable'} =~ /,/) {
- my @currclonecrs = split/,/,$currclonecrs{'cloneable'};
- foreach my $crs (@currclonecrs) {
- if ($crs ne $clone_crs) {
- $newclonecrs{'cloneable'} .= $crs.',';
- }
- }
- $newclonecrs{'cloneable'} =~ s/,$//;
- } else {
- $newclonecrs{'cloneable'} = '';
- }
- &Apache::lonnet::put('environment',\%newclonecrs,$udom,$uname);
- }
- }
- }
- }
- }
- }
- }
- return;
-}
-
1;
| | | |