--- loncom/interface/domainprefs.pm 2007/03/01 17:54:13 1.2 +++ loncom/interface/domainprefs.pm 2007/04/04 00:10:01 1.7 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Handler to set domain-wide configuration settings # -# $Id: domainprefs.pm,v 1.2 2007/03/01 17:54:13 albertel Exp $ +# $Id: domainprefs.pm,v 1.7 2007/04/04 00:10:01 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -37,6 +37,7 @@ use Apache::loncommon(); use Apache::lonhtmlcommon(); use Apache::lonlocal; use LONCAPA(); +use LONCAPA::Enrollment; sub handler { my $r=shift; @@ -47,7 +48,7 @@ sub handler { } my $dom = $env{'request.role.domain'}; - my $domdesc = $Apache::lonnet::domaindescription{$dom}; + my $domdesc = &Apache::lonnet::domain($dom,'description'); if (&Apache::lonnet::allowed('mau',$dom)) { &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; @@ -59,211 +60,876 @@ sub handler { &Apache::lonhtmlcommon::clear_breadcrumbs(); &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, ['phase']); - my $phase = $env{'form.phase'}; - if ($phase eq '' || $phase eq 'start') { + my $phase = "display"; + if ( exists($env{'form.phase'}) ) { + $phase = $env{'form.phase'}; + } + my %domconfig = + &Apache::lonnet::get_dom('configuration',['login','rolecolors', + 'quotas','autoenroll','autoupdate'],$dom); + my @prefs = ( + { text => 'Default color schemes', + help => 'Default_Color_Schemes', + action => 'rolecolors', + header => [{col1 => 'Student Settings', + col2 => '',}, + {col1 => 'Coordinator Settings', + col2 => '',}, + {col1 => 'Author Settings', + col2 => '',}, + {col1 => 'Administrator Settings', + col2 => '',}], + }, + { text => 'Log-in page options', + help => 'Domain_Log-in_Page', + action => 'login', + header => [{col1 => 'Item', + col2 => '',}], + }, + { text => 'Default quotas for user portfolios', + help => 'Default_User_Quota', + action => 'quotas', + header => [{col1 => 'User type', + col2 => 'Default quota'}], + }, + { text => 'Auto-enrollment settings', + help => 'Domain_Auto_Enrollment', + action => 'autoenroll', + header => [{col1 => 'Configuration setting', + col2 => 'Value(s)'}], + }, + { text => 'Auto-update settings', + help => 'Domain_Auto_Update', + action => 'autoupdate', + header => [{col1 => 'Setting', + col2 => 'Value',}, + {col1 => 'User Population', + col2 => 'Updataeable user data'}], + }, + ); + my @roles = ('student','coordinator','author','admin'); + &Apache::lonhtmlcommon::add_breadcrumb + ({href=>"javascript:changePage(document.$phase,'display')", + text=>"Domain Configuration"}); + if ($phase eq 'process') { &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'start')", - text=>"Choose an action"}); - &print_main_menu($r,$dom,$domdesc); + ({href=>"javascript:changePage(document.$phase,'$phase')", + text=>"Updated"}); + &print_header($r,$phase); + foreach my $item (@prefs) { + $r->print('

'.&mt($item->{'text'}).'

'. + &process_changes($r,$dom,$item->{'action'},\@roles,%domconfig)); + } + $r->print('

'); + &print_footer($r,$phase,'display','Back to actions menu'); + $r->print('

'); } else { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'start')", - text=>"Choose an action"}); - if ($phase eq 'login') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Configure Log-in page"}); - &print_login($r,$phase,$dom) - } elsif ($phase eq 'configlogin') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'login')", - text=>"Configure Log-in page"}); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Result"}); - &modify_login($r,$phase,$dom,$domdesc); - } elsif ($phase eq 'quotas') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Default user quotas"}); - &print_quotas($r,$phase,$dom); - } elsif ($phase eq 'configquotas') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'quotas')", - text=>"Default user quotas"}); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Result"}); - &modify_quotas($r,$phase,$dom,$domdesc); - } elsif ($phase eq 'autoenroll') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Configure Auto-enrollment"}); - &print_autoenroll($r,$phase,$dom); - } elsif ($phase eq 'configenroll') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'autoenroll')", - text=>"Configure Auto-enrollment"}); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Result"}); - &modify_autoenroll($r,$phase,$dom,$domdesc); - } elsif ($phase eq 'autoupdate') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Configure Auto-update"}); - &print_autoupdate($r,$phase,$dom); - } elsif ($phase eq 'configupdate') { - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'quotas')", - text=>"Change settings"}); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"javascript:changePage(document.$phase,'$phase')", - text=>"Result"}); - &modify_autoupdate($r,$phase,$dom,$domdesc); - } - } - &print_footer($r); -} - -sub print_main_menu { - my ($r,$dom,$domdesc) = @_; - my @menu = - ( - { text => 'Log-in page options', - help => 'Domain_Log-in_Page', - phase => 'login', - }, - { text => 'Default quotas for user portfolios', - help => 'Default_User_Quota', - phase => 'quotas', - }, - { text => 'Auto-enrollment settings', - help => 'Domain_Auto_Enrollment', - phase => 'autoenroll', - }, - { text => 'Auto-update settings', - help => 'Domain_Auto_Update', - phase => 'autoupdate', - }, - ); - my $menu_html = ''; - foreach my $menu_item (@menu) { - $menu_html.='

'; - $menu_html.=''; - if (exists($menu_item->{'url'})) { - $menu_html.=qq{}; - } else { - $menu_html.= - qq{}; - } - $menu_html.= &mt($menu_item->{'text'}).''; - if (exists($menu_item->{'help'})) { - $menu_html.= - &Apache::loncommon::help_open_topic($menu_item->{'help'}); + if ($phase eq '') { + $phase = 'display'; + } + my %helphash; + my $numprefs = @prefs; + &print_header($r,$phase); + $r->print('
'); + foreach my $item (@prefs) { + if ($item->{'action'} eq 'login') { + $r->print(' '); + } + &print_config_box($r,$dom,$phase,$item->{'action'}, + $item,$domconfig{$item->{'action'}}); } - $menu_html.='

'.$/; + $r->print(' +
+ + + + + + '); + &print_footer($r,$phase,'process','Store changes'); + } + return OK; +} + +sub process_changes { + my ($r,$dom,$action,$roles,%domconfig) = @_; + my $output; + if ($action eq 'login') { + $output = &modify_login($r,$dom,%domconfig); + } elsif ($action eq 'rolecolors') { + $output = &modify_rolecolors($r,$dom,$roles,%domconfig); + } elsif ($action eq 'quotas') { + $output = &modify_quotas($dom,%domconfig); + } elsif ($action eq 'autoenroll') { + $output = &modify_autoenroll($dom,%domconfig); + } elsif ($action eq 'autoupdate') { + $output = &modify_autoupdate($dom,%domconfig); } - &print_header($r); - $r->print($menu_html); + return $output; +} + +sub print_config_box { + my ($r,$dom,$phase,$action,$item,$settings) = @_; + $r->print(' + + + + '); + if (($action eq 'autoupdate') || ($action eq 'rolecolors')) { + my $colspan = ($action eq 'rolecolors')?' colspan="2"':''; + $r->print(' + + + + + + + + + + + '. + ''; + $itemcount ++; + $css_class = $itemcount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''. + ''; + $itemcount ++; + $datatable .= &display_color_options($dom,$phase,'login',$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text); + $datatable .= '
'.&mt($item->{text}).' '. + &Apache::loncommon::help_open_topic($item->{'help'}).'
+ + + + + '); + if ($action eq 'autoupdate') { + $r->print(&print_autoupdate('top',$dom,$settings)); + } else { + $r->print(&print_rolecolors($phase,'student',$dom,$settings)); + } + $r->print(' +
'.$item->{'header'}->[0]->{'col1'}.''.$item->{'header'}->[0]->{'col2'}.'
+
+ + + + + '); + if ($action eq 'autoupdate') { + $r->print(&print_autoupdate('bottom',$dom,$settings)); + } else { + $r->print(&print_rolecolors($phase,'coordinator',$dom,$settings).' +
'.$item->{'header'}->[1]->{'col1'}.''.$item->{'header'}->[1]->{'col2'}.'
+
+ + + + + '. + &print_rolecolors($phase,'author',$dom,$settings).' +
'.$item->{'header'}->[2]->{'col1'}.''.$item->{'header'}->[2]->{'col2'}.'
+
+ + + + + '. + &print_rolecolors($phase,'admin',$dom,$settings)); + } + } else { + $r->print(' + + + +
'.$item->{'header'}->[3]->{'col1'}.''.$item->{'header'}->[3]->{'col2'}.'
+ + '); + if ($action eq 'login') { + $r->print(' + '); + } else { + $r->print(' + '); + } + $r->print(' + + '); + if ($action eq 'login') { + $r->print(&print_login($dom,$phase,$settings)); + } elsif ($action eq 'quotas') { + $r->print(&print_quotas($dom,$settings)); + } elsif ($action eq 'autoenroll') { + $r->print(&print_autoenroll($dom,$settings)); + } + } + $r->print(' +
'.$item->{'header'}->[0]->{'col1'}.''.$item->{'header'}->[0]->{'col1'}.''.$item->{'header'}->[0]->{'col2'}.'
+

'); return; } sub print_header { - my ($r,$javascript_validations) = @_; - my $phase = "start"; - if ( exists($env{'form.phase'}) ) { - $phase = $env{'form.phase'}; - } - my $js = qq| + my ($r,$phase) = @_; + my $js = ' -|; +'; $r->print(&Apache::loncommon::start_page('View/Modify Domain Settings', - $js)); - my $bread_text = "Domain Settings"; - $r->print(&Apache::lonhtmlcommon::breadcrumbs($bread_text)); + $js)); + $r->print(&Apache::lonhtmlcommon::breadcrumbs('Domain Settings')); + $r->print(' +
+ + + +
+'); + $r->print('
'); return; } sub print_footer { - my ($r) = @_; + my ($r,$phase,$newphase,$button_text) = @_; + $button_text = &mt($button_text); + $r->print(''); + my $dest='"javascript:changePage(document.'.$phase.','."'$newphase'".')"'; + if ($phase eq 'process') { + $r->print(''.$button_text.''); + } else { + $r->print(''); + } + $r->print('
'); $r->print('
'.&Apache::loncommon::end_page()); return; } -sub print_login { - my ($r,$phase,$dom) = @_; - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['login'],$dom); - my $catalogon = ' checked="checked" '; - my $catalogoff; - my $adminmailon = ' '; - my $adminmailoff = ' checked="checked" '; - if (ref($domconfig{'login'}) eq 'HASH') { - if ($domconfig{'login'}{'coursecatalog'} eq '0') { +sub print_login { + my ($dom,$phase,$settings) = @_; + my %choices = &login_choices(); + my ($catalogon,$catalogoff,$adminmailon,$adminmailoff); + $catalogon = ' checked="checked" '; + $adminmailoff = ' checked="checked" '; + my @images = ('img','logo','domlogo'); + my @bgs = ('pgbg','mainbg','sidebg'); + my @links = ('link','alink','vlink'); + my %designhash = &Apache::loncommon::get_domainconf($dom); + my %defaultdesign = %Apache::loncommon::defaultdesign; + my (%is_custom,%designs); + my %defaults = ( + font => $defaultdesign{'login.font'}, + ); + foreach my $item (@images) { + $defaults{$item} = $defaultdesign{'login.'.$item}; + } + foreach my $item (@bgs) { + $defaults{'bgs'}{$item} = $defaultdesign{'login.'.$item}; + } + foreach my $item (@links) { + $defaults{'links'}{$item} = $defaultdesign{'login.'.$item}; + } + if (ref($settings) eq 'HASH') { + if ($settings->{'coursecatalog'} eq '0') { $catalogoff = $catalogon; $catalogon = ' '; } - if ($domconfig{'login'}{'adminmail'} eq '1') { + if ($settings->{'adminmail'} eq '1') { $adminmailon = $adminmailoff; $adminmailoff = ' '; } + foreach my $item (@images) { + if ($settings->{$item} ne '') { + $designs{$item} = $settings->{$item}; + $is_custom{$item} = 1; + } + } + if ($settings->{'font'} ne '') { + $designs{'font'} = $settings->{'font'}; + $is_custom{'font'} = 1; + } + foreach my $item (@bgs) { + if ($settings->{$item} ne '') { + $designs{'bgs'}{$item} = $settings->{$item}; + $is_custom{$item} = 1; + } + } + foreach my $item (@links) { + if ($settings->{$item} ne '') { + $designs{'links'}{$item} = $settings->{$item}; + $is_custom{$item} = 1; + } + } + } else { + $designs{'domlogo'} = ''; + if (-e '/home/httpd/html/adm/lonDomLogos/'.$dom.'.gif') { + $designs{'domlogo'} = '/home/httpd/html/adm/lonDomLogos/'.$dom.'.gif'; + $is_custom{'domlogo'} = 1; + } + if ($designhash{$dom.'.login.img'} ne '') { + $designs{'img'} = $designhash{$dom.'.login.img'}; + $is_custom{'img'} = 1; + } + if ($designhash{$dom.'.login.logo'} ne '') { + $designs{'logo'} = $designhash{$dom.'.login.logo'}; + $is_custom{'logo'} = 1; + } + if ($designhash{$dom.'.login.font'} ne '') { + $designs{'font'} = $designhash{$dom.'.login.font'}; + $is_custom{'font'} = 1; + } + foreach my $item (@bgs) { + if ($designhash{$dom.'.login.'.$item} ne '') { + $designs{'bgs'}{$item} = $designhash{$dom.'.login.'.$item}; + $is_custom{$item} = 1; + } + } + foreach my $item (@links) { + if ($designhash{$dom.'.login.'.$item} ne '') { + $designs{'links'}{$item} = $designhash{$dom.'.login.'.$item}; + $is_custom{$item} = 1; + } + } + } + my %alt_text = &Apache::lonlocal::texthash ( img => 'Log-in banner', + logo => 'Institution Logo', + domlogo => 'Domain Logo'); + my $itemcount = 1; + my $css_class = $itemcount%2?' class="LC_odd_row"':''; + my $datatable = + '
'.$choices{'coursecatalog'}. + ''. + ''.&mt('Yes').' '. + ''.&mt('No').'
'.$choices{'adminmail'}.''. + ''.&mt('Yes').' '. + ''.&mt('No').'
'; + return $datatable; +} + +sub login_choices { + my %choices = + &Apache::lonlocal::texthash ( + coursecatalog => 'Display Course Catalog link?', + adminmail => "Display Administrator's E-mail Address?", + img => "Header", + logo => "Main Logo", + domlogo => "Domain Logo", + bgs => "Background colors", + links => "Link colors", + font => "Font color", + pgbg => "Page", + mainbg => "Main panel", + sidebg => "Side panel", + link => "Link", + alink => "Active link", + vlink => "Visited link", + ); + return %choices; +} + +sub print_rolecolors { + my ($phase,$role,$dom,$settings) = @_; + my %choices = &color_font_choices(); + my @bgs = ('pgbg','tabbg','sidebg'); + my @links = ('link','alink','vlink'); + my @images = ('img'); + my %alt_text = &Apache::lonlocal::texthash(img => "Banner for $role role"); + my %designhash = &Apache::loncommon::get_domainconf($dom); + my %defaultdesign = %Apache::loncommon::defaultdesign; + my (%is_custom,%designs); + my %defaults = ( + img => $defaultdesign{$role.'.img'}, + font => $defaultdesign{$role.'.font'}, + ); + foreach my $item (@bgs) { + $defaults{'bgs'}{$item} = $defaultdesign{$role.'.'.$item}; + } + foreach my $item (@links) { + $defaults{'links'}{$item} = $defaultdesign{$role.'.'.$item}; + } + if (ref($settings) eq 'HASH') { + if (ref($settings->{$role}) eq 'HASH') { + if ($settings->{$role}->{'img'} ne '') { + $designs{'img'} = $settings->{$role}->{'img'}; + $is_custom{'img'} = 1; + } + if ($settings->{$role}->{'font'} ne '') { + $designs{'font'} = $settings->{$role}->{'font'}; + $is_custom{'font'} = 1; + } + foreach my $item (@bgs) { + if ($settings->{$role}->{$item} ne '') { + $designs{'bgs'}{$item} = $settings->{$role}->{$item}; + $is_custom{$item} = 1; + } + } + foreach my $item (@links) { + if ($settings->{$role}->{$item} ne '') { + $designs{'links'}{$item} = $settings->{$role}->{$item}; + $is_custom{$item} = 1; + } + } + } + } else { + if ($designhash{$dom.'.'.$role.'.img'} ne '') { + $designs{img} = $designhash{$dom.'.'.$role.'.img'}; + $is_custom{'img'} = 1; + } + if ($designhash{$dom.'.'.$role.'.font'} ne '') { + $designs{font} = $designhash{$dom.'.'.$role.'.font'}; + $is_custom{'font'} = 1; + } + foreach my $item (@bgs) { + if ($designhash{$dom.'.'.$role.'.'.$item} ne '') { + $designs{'bgs'}{$item} = $designhash{$dom.'.'.$role.'.'.$item}; + $is_custom{$item} = 1; + + } + } + foreach my $item (@links) { + if ($designhash{$dom.'.'.$role.'.'.$item} ne '') { + $designs{'links'}{$item} = $designhash{$dom.'.'.$role.'.'.$item}; + $is_custom{$item} = 1; + } + } + } + my $itemcount = 1; + my $datatable = display_color_options($dom,$phase,$role,$itemcount,\%choices,\%is_custom,\%defaults,\%designs,\@images,\@bgs,\@links,\%alt_text); + $datatable .= ''; + return $datatable; +} + +sub display_color_options { + my ($dom,$phase,$role,$itemcount,$choices,$is_custom,$defaults,$designs, + $images,$bgs,$links,$alt_text) = @_; + my $configuname = $dom.'-domainconfig'; + my $css_class = $itemcount%2?' class="LC_odd_row"':''; + my $datatable = ''. + ''.$choices->{'font'}.''; + if (!$is_custom->{'font'}) { + $datatable .= ''.&mt('Default in use:').' '.$defaults->{'font'}.''; + } else { + $datatable .= ' '; + } + my $fontlink = &color_pick($phase,$role,'font',$choices->{'font'},$designs->{'font'}); + $datatable .= ''. + ' '.$fontlink. + ''; + foreach my $img (@{$images}) { + $itemcount ++; + $css_class = $itemcount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''.$choices->{$img}.''; + my $imgfile; + if ($designs->{$img} ne '') { + $imgfile = $designs->{$img}; + } else { + $imgfile = $defaults->{$img}; + } + if ($imgfile) { + my $showfile; + if ($imgfile =~ m-^(/uploaded/\Q$dom\E/\Q$configuname\E/portfolio.*)/([^/]+)$-) { + my $urldir = $1; + my $filename = $2; + my @info = &Apache::lonnet::stat_file($designs->{$img}); + if (@info) { + my $thumbfile = 'tn-'.$filename; + my @thumb=&Apache::lonnet::stat_file($urldir.'/'.$thumbfile); + if (@thumb) { + $showfile = $urldir.'/'.$thumbfile; + } else { + $showfile = $imgfile; + } + } else { + $showfile = ''; + } + } elsif ($imgfile =~ m-^/(adm/[^/]+)/([^/]+)$-) { + my $imgdir = $1; + my $filename = $2; + if (-e "/home/httpd/html/$imgdir/tn-".$filename) { + $showfile = "/$imgdir/tn-".$filename; + } else { + my $input = "/home/httpd/html".$imgfile; + my $output = '/home/httpd/html/'.$imgdir.'/tn-'.$filename; + if (!-e $output) { + system("convert -sample 200x50 $input $output"); + } + $showfile = '/'.$imgdir.'/tn-'.$filename; + } + } + if ($showfile) { + $datatable.= ''; + if (!$is_custom->{$img}) { + $datatable .= &mt('Default in use:').'
'; + } + $datatable.= ''.
+                             $alt_text->{$img}.''; + if ($is_custom->{$img}) { + $datatable.=''. + &mt('Delete?').' '.&mt('Replace:').'
'; + } else { + $datatable.=''.&mt('Upload:').'
'; + } + } else { + $datatable .= '
'. + &mt('Upload:'); + } + } else { + $datatable .= '
'. + &mt('Upload:'); + } + $datatable .= ' '; + } + $itemcount ++; + $css_class = $itemcount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''.$choices->{'bgs'}.''; + my $bgs_def; + foreach my $item (@{$bgs}) { + if (!$is_custom->{$item}) { + $bgs_def .= ''.$choices->{$item}.'
'.$defaults->{'bgs'}{$item}.''; + } + } + if ($bgs_def) { + $datatable .= ''.&mt('Default(s) in use').'
'.$bgs_def.'
'; + } else { + $datatable .= ' '; + } + $datatable .= ''. + ''; + foreach my $item (@{$bgs}) { + my $link = &color_pick($phase,$role,$item,$choices->{$item},$designs->{'bgs'}{$item}); + $datatable .= ''; + } + $datatable .= '
'.$link; + if ($designs->{'bgs'}{$item}) { + $datatable .= ' '; + } + $datatable .= '
'; + $itemcount ++; + $css_class = $itemcount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''.$choices->{'links'}.''; + my $links_def; + foreach my $item (@{$links}) { + if (!$is_custom->{$item}) { + $links_def .= ''.$choices->{$item}.'
'.$defaults->{'links'}{$item}.''; + } + } + if ($links_def) { + $datatable .= ''.&mt('Default(s) in use').'
'.$links_def.'
'; + } else { + $datatable .= ' '; + } + $datatable .= ''. + ''; + foreach my $item (@{$links}) { + $datatable .= ''; + } + return $datatable; +} + +sub color_pick { + my ($phase,$role,$item,$desc,$curcol) = @_; + my $link = ''.$desc.''; + return $link; +} + +sub color_pick_js { + my $pjump_def = &Apache::lonhtmlcommon::pjump_javascript_definition(); + my $output = <<"ENDCOL"; + function pclose() { + parmwin=window.open("/adm/rat/empty.html","LONCAPAparms","height=350,width=350,scrollbars=no,menubar=no"); + parmwin.close(); + } + + $pjump_def + + function psub() { + pclose(); + if (document.parmform.pres_marker.value!='') { + if (document.parmform.pres_type.value!='') { + eval('document.display.'+ + document.parmform.pres_marker.value+ + '.value=document.parmform.pres_value.value;'); + } + } else { + document.parmform.pres_value.value=''; + document.parmform.pres_marker.value=''; + } + } +ENDCOL + return $output; +} + +sub print_quotas { + my ($dom,$settings) = @_; + my $datatable; + my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); + my $othertitle = "All users"; + my @types; + if (ref($order) eq 'ARRAY') { + @types = @{$order}; + } + if (@types == 0) { + if (ref($usertypes) eq 'HASH') { + @types = sort(keys(%{$usertypes})); + } + } + my $typecount = 0; + my $css_class; + if (@types > 0) { + foreach my $type (@types) { + if (defined($usertypes->{$type})) { + $typecount ++; + $css_class = $typecount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''. + ''; + } + } + $othertitle = "Other users"; + } + my $defaultquota = '20'; + if (ref($settings) eq 'HASH') { + if (defined($settings->{'default'})) { + $defaultquota = $settings->{'default'}; + } + } + $typecount ++; + $css_class = $typecount%2?' class="LC_odd_row"':''; + $datatable .= ''. + ''. + ''; + return $datatable; +} + +sub print_autoenroll { + my ($dom,$settings) = @_; + my $defdom = $dom; + my $autorun = &Apache::lonnet::auto_run(undef,$dom), + my ($runon,$runoff); + if (ref($settings) eq 'HASH') { + if (exists($settings->{'run'})) { + if ($settings->{'run'} eq '0') { + $runoff = ' checked="checked" '; + $runon = ' '; + } else { + $runon = ' checked="checked" '; + $runoff = ' '; + } + } else { + if ($autorun) { + $runon = ' checked="checked" '; + $runoff = ' '; + } else { + $runoff = ' checked="checked" '; + $runon = ' '; + } + } + if (exists($settings->{'sender_domain'})) { + $defdom = $settings->{'sender_domain'}; + } } - &print_header($r); - my $datatable=&Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - ''. - &Apache::loncommon::end_data_table_header_row(). - &Apache::loncommon::start_data_table_row(). - ''. - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::start_data_table_row(). - ''. - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::start_data_table(); - &print_form($r,$datatable,$phase,'configlogin','Change'); + my $domform = &Apache::loncommon::select_dom_form($defdom,'sender_domain',1); + my $datatable=''. + ''. + ''. + ''. + ''; + return $datatable; +} + +sub print_autoupdate { + my ($position,$dom,$settings) = @_; + my $datatable; + if ($position eq 'top') { + my $updateon = ' '; + my $updateoff = ' checked="checked" '; + my $classlistson = ' '; + my $classlistsoff = ' checked="checked" '; + if (ref($settings) eq 'HASH') { + if ($settings->{'run'} eq '1') { + $updateon = $updateoff; + $updateoff = ' '; + } + if ($settings->{'classlists'} eq '1') { + $classlistson = $classlistsoff; + $classlistsoff = ' '; + } + } + my %title = ( + run => 'Auto-update active?', + classlists => 'Update information in classlists?', + ); + $datatable = ''. + ''. + ''. + ''. + ''. + ''. + ''; + } else { + my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); + my @types; + if (ref($order) eq 'ARRAY') { + @types = @{$order}; + } + if (@types == 0) { + if (ref($usertypes) eq 'HASH') { + @types = sort(keys(%{$usertypes})); + } + } + my $othertitle = &mt('All users'); + if (keys(%{$usertypes}) > 0) { + $othertitle = &mt('Other users'); + } + my @fields = ('lastname','firstname','middlename','gen','email','id'); + my %fieldtitles = &Apache::lonlocal::texthash ( + id => 'Student/Employee ID', + email => 'E-mail address', + lastname => 'Last Name', + firstname => 'First Name', + middlename => 'Middle Name', + gen => 'Generation', + ); + my $numrows = 0; + if (@types > 0) { + $datatable = + &usertype_update_row($settings,$usertypes,\%fieldtitles, + \@fields,\@types,\$numrows); + } + $datatable .= + &usertype_update_row($settings,{'default' => $othertitle}, + \%fieldtitles,\@fields,['default'], + \$numrows); + } + return $datatable; +} + +sub usertype_update_row { + my ($settings,$usertypes,$fieldtitles,$fields,$types,$rownums) = @_; + my $datatable; + my $numinrow = 4; + foreach my $type (@{$types}) { + if (defined($usertypes->{$type})) { + $$rownums ++; + my $css_class = $$rownums%2?' class="LC_odd_row"':''; + $datatable .= ''; + } + } + return $datatable; } sub modify_login { - my ($r,$phase,$dom,$domdesc) = @_; - my ($resulttext,%changes); - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['login'],$dom); + my ($r,$dom,%domconfig) = @_; + my ($resulttext,$errors,$colchgtext,%changes,%colchanges); my %title = ( coursecatalog => 'Display course catalog', adminmail => 'Display administrator E-mail address'); - my @offon = ('off','on'); - my %loginhash = ( - login => { coursecatalog => $env{'form.coursecatalog'}, - adminmail => $env{'form.adminmail'}, - } - ); + my @offon = ('off','on'); + my %loginhash; + ($errors,%colchanges) = &modify_colors($r,$dom,['login'],\%domconfig, + \%loginhash); + $loginhash{login}{coursecatalog} = $env{'form.coursecatalog'}; + $loginhash{login}{adminmail} = $env{'form.adminmail'}; + if (ref($colchanges{'login'}) eq 'HASH') { + $colchgtext = &display_colorchgs($dom,\%colchanges,['login'], + \%loginhash); + } my $putresult = &Apache::lonnet::put_dom('configuration',\%loginhash, $dom); if ($putresult eq 'ok') { - if (($domconfig{'login'}{'coursecatalog'} eq '0') && + if (($domconfig{'login'}{'coursecatalog'} eq '0') && ($env{'form.coursecatalog'} eq '1')) { $changes{'coursecatalog'} = 1; - } elsif (($domconfig{'login'}{'coursecatalog'} eq '' || - $domconfig{'login'}{'coursecatalog'} eq '1') && + } elsif (($domconfig{'login'}{'coursecatalog'} eq '' || + $domconfig{'login'}{'coursecatalog'} eq '1') && ($env{'form.coursecatalog'} eq '0')) { $changes{'coursecatalog'} = 1; } - if (($domconfig{'login'}{'adminmail'} eq '1') && + if (($domconfig{'login'}{'adminmail'} eq '1') && ($env{'form.adminmail'} eq '0')) { $changes{'adminmail'} = 1; } elsif (($domconfig{'login'}{'adminmail'} eq '' || @@ -271,79 +937,256 @@ sub modify_login { ($env{'form.adminmail'} eq '1')) { $changes{'adminmail'} = 1; } - if (keys(%changes) > 0) { + if (keys(%changes) > 0 || $colchgtext) { $resulttext = &mt('Changes made:').'
    '; foreach my $item (sort(keys(%changes))) { $resulttext .= '
  • '.&mt("$title{$item} set to $offon[$env{'form.'.$item}]").'
  • '; } - $resulttext .= '
'; + $resulttext .= $colchgtext.''; } else { $resulttext = &mt('No changes made to log-in page settings'); } } else { $resulttext = &mt('An error occurred: [_1]',$putresult); } - &print_header($r); - &print_form($r,$resulttext,$phase,'start','Back to actions menu'); + if ($errors) { + $resulttext .= &mt('The following errors occurred: ').'
    '. + $errors.'
'; + } + return $resulttext; } -sub print_quotas { - my ($r,$phase,$dom) = @_; - my %currquota; - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['quotas'],$dom); - if (ref($domconfig{'quotas'}) eq 'HASH') { - foreach my $key (keys(%{$domconfig{'quotas'}})) { - $currquota{$key} = $domconfig{'quotas'}{$key}; +sub color_font_choices { + my %choices = + &Apache::lonlocal::texthash ( + img => "Header", + bgs => "Background colors", + links => "Link colors", + font => "Font color", + pgbg => "Page", + tabbg => "Header", + sidebg => "Border", + link => "Link", + alink => "Active link", + vlink => "Visited link", + ); + return %choices; +} + +sub modify_rolecolors { + my ($r,$dom,$roles,%domconfig) = @_; + my ($resulttext,%rolehash); + $rolehash{'rolecolors'} = {}; + my ($errors,%changes) = &modify_colors($r,$dom,$roles, + $domconfig{'rolecolors'},$rolehash{'rolecolors'}); + my $putresult = &Apache::lonnet::put_dom('configuration',\%rolehash, + $dom); + if ($putresult eq 'ok') { + if (keys(%changes) > 0) { + $resulttext = &display_colorchgs($dom,\%changes,$roles, + $rolehash{'rolecolors'}); + } else { + $resulttext = &mt('No changes made to default color schemes'); } + } else { + $resulttext = &mt('An error occurred: [_1]',$putresult); } - my $datatable=&Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - ''. - &Apache::loncommon::end_data_table_header_row(); - my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); - my $othertitle = "All users"; - my @types; - if (ref($order) eq 'ARRAY') { - @types = @{$order}; + if ($errors) { + $resulttext .= &mt('The following errors occurred: ').'
    '. + $errors.'
'; } - if (@types == 0) { - if (ref($usertypes) eq 'HASH') { - @types = sort(keys(%{$usertypes})); + return $resulttext; +} + +sub modify_colors { + my ($r,$dom,$roles,$domconfig,$confhash) = @_; + my %changes; + my @bgs = ('pgbg','mainbg','sidebg'); + my @links = ('link','alink','vlink'); + my @images; + my $configuname = $dom.'-domainconfig'; + my $servadm = $r->dir_config('lonAdmEMail'); + my $errors; + foreach my $role (@{$roles}) { + if ($role eq 'login') { + @images = ('img','logo','domlogo'); + } else { + @images = ('img'); } - } - if (@types > 0) { - foreach my $type (@types) { - if (defined($usertypes->{$type})) { - $datatable .= &Apache::loncommon::start_data_table_row(). - ''; + $confhash->{$role}{'font'} = $env{'form.'.$role.'_font'}; + foreach my $item (@bgs,@links) { + $confhash->{$role}{$item} = $env{'form.'.$role.'_'.$item}; + } + foreach my $img (@images) { + if ($env{'form.'.$role.'_'.$img.'.filename'} ne '') { + my $configuserok; + if (&Apache::lonnet::homeserver($configuname,$dom) eq 'no_host') { + srand( time() ^ ($$ + ($$ << 15)) ); # Seed rand. + my $configpass = &LONCAPA::Enrollment::create_password(); + $configuserok = &Apache::lonnet::modifyuser($dom,$configuname,'','internal',$configpass,'','','','','',undef,$servadm); + } else { + $configuserok = 'ok'; + } + if ($configuserok eq 'ok') { + my $result = + &Apache::lonnet::userfileupload($role.'_'.$img,'', + 'portfolio/'.$img,'','','',$configuname,$dom,'200','50'); + if ($result =~ m|(^/uploaded/.+)/([^/]+)$|) { + my $urldir = $1; + my $filename = $2; + my $allowresult = &Apache::lonnet::make_public_indefinitely($result); + if ($allowresult eq 'ok') { + &Apache::lonnet::make_public_indefinitely($urldir.'/tn-'.$filename); + $confhash->{$role}{$img} = $result; + $changes{$role}{$img} = 1; + } + } + } else { + my $error = &mt("Upload of image [_1] for $role page(s) failed because a Domain Configuation user ([_2]) could not be created in domain: [_3]. Error was: [_4].",$img,$configuname,$dom,$configuserok); + &Apache::lonnet::logthis($error); + $errors .= '
  • '.$error.'
  • '; + } } } - $othertitle = "Other users"; + if (ref($domconfig) eq 'HASH') { + if (ref($domconfig->{$role}) eq 'HASH') { + foreach my $img (@images) { + if ($domconfig->{$role}{$img} ne '') { + if ($env{'form.'.$role.'_del_'.$img}) { + $confhash->{$role}{$img} = ''; + $changes{$role}{$img} = 1; + } else { + $confhash->{$role}{$img} = $domconfig->{$role}{$img}; + } + } else { + if ($env{'form.'.$role.'_del_'.$img}) { + $confhash->{$role}{$img} = ''; + $changes{$role}{$img} = 1; + } + } + } + if ($domconfig->{$role}{'font'} ne '') { + if ($confhash->{$role}{'font'} ne $domconfig->{$role}{'font'}) { + $changes{$role}{'font'} = 1; + } + } else { + if ($confhash->{$role}{'font'}) { + $changes{$role}{'font'} = 1; + } + } + foreach my $item (@bgs) { + if ($domconfig->{$role}{$item} ne '') { + if ($confhash->{$role}{$item} ne $domconfig->{$role}{$item}) { + $changes{$role}{'bgs'}{$item} = 1; + } + } else { + if ($confhash->{$role}{$item}) { + $changes{$role}{'bgs'}{$item} = 1; + } + } + } + foreach my $item (@links) { + if ($domconfig->{$role}{$item} ne '') { + if ($confhash->{$role}{$item} ne $domconfig->{$role}{$item}) { + $changes{$role}{'links'}{$item} = 1; + } + } else { + if ($confhash->{$role}{$item}) { + $changes{$role}{'links'}{$item} = 1; + } + } + } + } else { + &default_change_checker($role,\@images,\@links,\@bgs, + $confhash,\%changes); + } + } else { + &default_change_checker($role,\@images,\@links,\@bgs, + $confhash,\%changes); + } } - my $defaultquota = '20'; - if (defined($currquota{'default'})) { - $defaultquota = $currquota{'default'}; + return ($errors,%changes); +} + +sub default_change_checker { + my ($role,$images,$links,$bgs,$confhash,$changes) = @_; + foreach my $item (@{$links}) { + if ($confhash->{$role}{$item}) { + $changes->{$role}{'links'}{$item} = 1; + } } - $datatable .= &Apache::loncommon::start_data_table_row(). - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::end_data_table(); - &print_header($r); - &print_form($r,$datatable,$phase,'configquotas','Change'); + foreach my $item (@{$bgs}) { + if ($confhash->{$role}{$item}) { + $changes->{$role}{'bgs'}{$item} = 1; + } + } + foreach my $img (@{$images}) { + if ($env{'form.'.$role.'_del_'.$img}) { + $confhash->{$role}{$img} = ''; + $changes->{$role}{$img} = 1; + } + } + if ($confhash->{$role}{'font'}) { + $changes->{$role}{'font'} = 1; + } +} + +sub display_colorchgs { + my ($dom,$changes,$roles,$confhash) = @_; + my (%choices,$resulttext); + &Apache::loncommon::devalidate_domconfig_cache($dom); + if (!grep(/^login$/,@{$roles})) { + $resulttext = &mt('Changes made:').'
    '; + } + foreach my $role (@{$roles}) { + if ($role eq 'login') { + %choices = &login_choices(); + } else { + %choices = &color_font_choices(); + } + if (ref($changes->{$role}) eq 'HASH') { + if ($role ne 'login') { + $resulttext .= '

    '.&mt($role).'

    '; + } + foreach my $key (sort(keys(%{$changes->{$role}}))) { + if ($role ne 'login') { + $resulttext .= '
      '; + } + if (ref($changes->{$role}{$key}) eq 'HASH') { + if ($role ne 'login') { + $resulttext .= '
    • '.&mt($choices{$key}).':
        '; + } + foreach my $item (sort(keys(%{$changes->{$role}{$key}}))) { + if ($confhash->{$role}{$item} eq '') { + $resulttext .= '
      • '.&mt("$choices{$item} set to default").'
      • '; + } else { + $resulttext .= '
      • '.&mt("$choices{$item} set to [_1]",$confhash->{$role}{$item}).'
      • '; + } + } + if ($role ne 'login') { + $resulttext .= '
    • '; + } + } else { + if ($confhash->{$role}{$key} eq '') { + $resulttext .= '
    • '.&mt("$choices{$key} set to default").'
    • '; + } else { + $resulttext .= '
    • '.&mt("$choices{$key} set to [_1]",$confhash->{$role}{$key}).'
    • '; + } + } + if ($role ne 'login') { + $resulttext .= '
    '; + } + } + } + } + return $resulttext; } sub modify_quotas { - my ($r,$phase,$dom,$domdesc) = @_; + my ($dom,%domconfig) = @_; my ($resulttext,%changes); - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['quotas'],$dom); - my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); + my ($usertypes,$order) = + &Apache::lonnet::retrieve_inst_usertypes($dom); my %formhash; foreach my $key (keys(%env)) { if ($key =~ /^form\.quota_(.+)$/) { @@ -363,13 +1206,13 @@ sub modify_quotas { } foreach my $key (keys(%formhash)) { if ($formhash{$key} ne '') { - if (!exists($domconfig{$key})) { + if (!exists($domconfig{'quotas'}{$key})) { $changes{$key} = 1; } } } my %quotahash = ( - quotas => {%formhash}, + quotas => {%formhash}, ); my $putresult = &Apache::lonnet::put_dom('configuration',\%quotahash, $dom); @@ -386,70 +1229,13 @@ sub modify_quotas { } else { $resulttext = &mt('An error occurred: [_1]',$putresult); } - &print_header($r); - &print_form($r,$resulttext,$phase,'start','Back to actions menu'); -} - -sub print_autoenroll { - my ($r,$phase,$dom) = @_; - my %currautoenroll; - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['autoenroll'],$dom); - if (ref($domconfig{'autoenroll'}) eq 'HASH') { - foreach my $key (keys(%{$domconfig{'autoenroll'}})) { - $currautoenroll{$key} = $domconfig{'autoenroll'}{$key}; - } - } - my $autorun = &Apache::lonnet::auto_run(undef,$dom), - my ($runon,$runoff); - if (exists($currautoenroll{'run'})) { - if ($currautoenroll{'run'} eq '0') { - $runoff = ' checked="checked" '; - $runon = ' '; - } else { - $runon = ' checked="checked" '; - $runoff = ' '; - } - } else { - if ($autorun) { - $runon = ' checked="checked" '; - $runoff = ' '; - } else { - $runoff = ' checked="checked" '; - $runon = ' '; - } - } - my $defdom = $dom; - if (exists($currautoenroll{'sender_domain'})) { - $defdom = $currautoenroll{'sender_domain'}; - } - my $domform = &Apache::loncommon::select_dom_form($defdom,'sender_domain',1); - my $datatable=&Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - ''. - &Apache::loncommon::end_data_table_header_row(). - &Apache::loncommon::start_data_table_row(). - ''. ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::start_data_table_row(). - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::end_data_table(); - &print_header($r); - &print_form($r,$datatable,$phase,'configenroll','Change'); + return $resulttext; } -sub modify_autoenroll { - my ($r,$phase,$dom,$domdesc) = @_; +sub modify_autoenroll { + my ($dom,%domconfig) = @_; my ($resulttext,%changes); my %currautoenroll; - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['autoenroll'],$dom); if (ref($domconfig{'autoenroll'}) eq 'HASH') { foreach my $key (keys(%{$domconfig{'autoenroll'}})) { $currautoenroll{$key} = $domconfig{'autoenroll'}{$key}; @@ -494,7 +1280,7 @@ sub modify_autoenroll { } if (keys(%changes) > 0) { $resulttext = &mt('Changes made:').'
      '; - if ($changes{'run'}) { + if ($changes{'run'}) { $resulttext .= '
    • '.&mt("$title{'run'} set to $offon[$env{'form.autoenroll_run'}]").'
    • '; } if ($changes{'sender'}) { @@ -507,167 +1293,12 @@ sub modify_autoenroll { } else { $resulttext = &mt('An error occurred: [_1]',$putresult); } - &print_header($r); - &print_form($r,$resulttext,$phase,'start','Back to actions menu'); -} - -sub print_autoupdate { - my ($r,$phase,$dom) = @_; - my (%currautoupdate,$datatable); - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['autoupdate'],$dom); - if (ref($domconfig{'autoupdate'}) eq 'HASH') { - foreach my $key (keys(%{$domconfig{'autoupdate'}})) { - $currautoupdate{$key} = $domconfig{'autoupdate'}{$key}; - } - } - my $updateon = ' '; - my $updateoff = ' checked="checked" '; - if ($currautoupdate{'run'} eq '1') { - $updateon = $updateoff; - $updateoff = ' '; - } - my $classlistson = ' '; - my $classlistsoff = ' checked="checked" '; - if ($currautoupdate{'classlists'} eq '1') { - $classlistson = $classlistsoff; - $classlistsoff = ' '; - } - my %title = ( - run => 'Auto-update enabled?', - classlists => 'Update information in classlists?', - ); - $datatable = &Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - '
    '. - &Apache::loncommon::end_data_table_header_row(). - &Apache::loncommon::start_data_table_row(). - ''. - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::start_data_table_row(). - ''. - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::end_data_table().'

    '; - my ($usertypes,$order) = &Apache::lonnet::retrieve_inst_usertypes($dom); - my @types; - if (ref($order) eq 'ARRAY') { - @types = @{$order}; - } - if (@types == 0) { - if (ref($usertypes) eq 'HASH') { - @types = sort(keys(%{$usertypes})); - } - } - my $othertitle = &mt('All users'); - if (keys(%{$usertypes}) > 0) { - $othertitle = &mt('Other users'); - } - my @fields = ('lastname','firstname','middlename','gen','email','id'); - my $numinrow = 4; - my %fieldtitles = &Apache::lonlocal::texthash ( - id => 'Student/Employee ID', - email => 'E-mail address', - lastname => 'Last Name', - firstname => 'First Name', - middlename => 'Middle Name', - gen => 'Generation', - ); - $datatable .= &Apache::loncommon::start_data_table(). - &Apache::loncommon::start_data_table_header_row(). - ''. - &Apache::loncommon::end_data_table_header_row(); - if (@types > 0) { - foreach my $type (@types) { - if (defined($usertypes->{$type})) { - $datatable .= &Apache::loncommon::start_data_table_row(). - ''.&Apache::loncommon::end_data_table_row(); - } - } - } - $datatable .= &Apache::loncommon::start_data_table_row(). - ''. - &Apache::loncommon::end_data_table_row(). - &Apache::loncommon::end_data_table(); - &print_header($r); - &print_form($r,$datatable,$phase,'configupdate','Change'); + return $resulttext; } sub modify_autoupdate { - my ($r,$phase,$dom,$domdesc) = @_; + my ($dom,%domconfig) = @_; my ($resulttext,%currautoupdate,%fields,%changes); - my %domconfig = &Apache::lonnet::get_dom('configuration', - ['autoupdate'],$dom); if (ref($domconfig{'autoupdate'}) eq 'HASH') { foreach my $key (keys(%{$domconfig{'autoupdate'}})) { $currautoupdate{$key} = $domconfig{'autoupdate'}{$key}; @@ -752,7 +1383,12 @@ sub modify_autoupdate { foreach my $type (@{$fields{$item}}) { push(@newvalues,$fieldtitles{$type}); } - my $newvaluestr = join(', ',@newvalues); + my $newvaluestr; + if (@newvalues > 0) { + $newvaluestr = join(', ',@newvalues); + } else { + $newvaluestr = &mt('none'); + } if ($item eq 'default') { $resulttext .= '
  • '.&mt("Updates for $othertitle set to: [_1]",$newvaluestr).'
  • '; } else { @@ -765,34 +1401,19 @@ sub modify_autoupdate { $newvalue = $offon[$env{'form.autoupdate_run'}]; } else { $newvalue = $offon[$env{'form.'.$key}]; - } + } $resulttext .= '
  • '.&mt("[_1] set to $newvalue",$title{$key}).'
  • '; } } $resulttext .= ''; } else { - $resulttext = &mt('No changes made to default quotas'); + $resulttext = &mt('No changes made to autoupdates'); } } else { $resulttext = &mt('An error occurred: [_1]',$putresult); } - &print_header($r); - &print_form($r,$resulttext,$phase,'start','Back to actions menu'); -} - -sub print_form { - my ($r,$datatable,$phase,$newphase,$button_text) = @_; - my $button_text = &mt($button_text); - $r->print(< -
    -$datatable -
    - - - -ENDDOCUMENT - return; + return $resulttext; } 1; +
    '; + my $link = &color_pick($phase,$role,$item,$choices->{$item},$designs->{'links'}{$item}); + if ($designs->{'links'}{$item}) { + $datatable.=''. + $link.''; + } else { + $datatable .= $link; + } + $datatable .= '
    '.$usertypes->{$type}.''. + ' Mb
    '.&mt($othertitle).''. + ' Mb
    '.&mt('Item').''.&mt('Selection').''.&mt('Display Course Catalog link?').''.&mt('Yes').' '. - ''.&mt('No').''.&mt("Display Administrator's E-mail Address?").''.&mt('Yes').' '. - ''.&mt('No').'
    '.&mt('Auto-enrollment active?').''. + ''.&mt('Yes').' '. + ''.&mt('No').'
    '.&mt('Notification messages - sender'). + ''. + &mt('username').': '. + '  '.&mt('domain'). + ': '.$domform.'
    '.&mt($title{'run'}).''. + ''.&mt('Yes').' '. + ''.&mt('No').'
    '.&mt($title{'classlists'}).''. + ''.&mt('Yes').' '. + ''.&mt('No').'
    '.$usertypes->{$type}. + ''; + for (my $i=0; $i<@{$fields}; $i++) { + my $rem = $i%($numinrow); + if ($rem == 0) { + if ($i > 0) { + $datatable .= ''; + } + $datatable .= ''; + } + my $check = ' '; + if (ref($settings->{'fields'}) eq 'HASH') { + if (ref($settings->{'fields'}{$type}) eq 'ARRAY') { + if (grep(/^\Q$fields->[$i]\E$/,@{$settings->{'fields'}{$type}})) { + $check = ' checked="checked" '; + } + } + } + + if ($i == @{$fields}-1) { + my $colsleft = $numinrow - $rem; + if ($colsleft > 1) { + $datatable .= ''; + } + $datatable .= '
    '; + } else { + $datatable .= ''; + } + } else { + $datatable .= ''; + } + $datatable .= ''. + $fieldtitles->{$fields->[$i]}.'
    '.&mt('User type').''.&mt('Default quota').''.$usertypes->{$type}.''. - ' Mb'.&mt($othertitle).''. - ' Mb'.&mt('Configuration setting').''.&mt('Value(s)').''.&mt('Auto-enrollment active?').''.&mt('Yes').' '. - ''.&mt('No').''.&mt('Notification messages - sender').''. - &mt('username').':   '.&mt('domain').': '.$domform.''.&mt('Setting').''.&mt('Value').''.&mt($title{'run'}).''.&mt('Yes').' '. - ''.&mt('No').''.&mt($title{'classlists'}).''.&mt('Yes').' '. - ''.&mt('No').''.&mt('User Population').''.&mt('Updateable user data').''.$usertypes->{$type}.''; - for (my $i=0; $i<@fields; $i++) { - my $rem = $i%($numinrow); - if ($rem == 0) { - if ($i > 0) { - $datatable .= ''; - } - $datatable .= ''; - } - my $check = ' '; - if (ref($currautoupdate{'fields'}) eq 'HASH') { - if (ref($currautoupdate{'fields'}{$type}) eq 'ARRAY') { - if (grep(/^\Q$fields[$i]\E$/,@{$currautoupdate{'fields'}{$type}})) { - $check = ' checked="checked" '; - } - } - } - if ($i == @fields-1) { - my $colsleft = $numinrow - $rem; - if ($colsleft > 1) { - $datatable .= ''; - } - $datatable .= '
    '; - } else { - $datatable .= ''; - } - } else { - $datatable .= ''; - } - $datatable .= ''. - $fieldtitles{$fields[$i]}.'
    '.&mt($othertitle).''; - for (my $i=0; $i<@fields; $i++) { - my $rem = $i%($numinrow); - if ($rem == 0) { - if ($i > 0) { - $datatable .= ''; - } - $datatable .= ''; - } - my $check = ' '; - if (ref($currautoupdate{'fields'}) eq 'HASH') { - if (ref($currautoupdate{'fields'}{'default'}) eq 'ARRAY') { - if (grep(/^\Q$fields[$i]\E$/,@{$currautoupdate{'fields'}{'default'}})) { - $check = ' checked="checked" '; - } - } - } - if ($i == @fields-1) { - my $colsleft = $numinrow - $rem; - if ($colsleft > 1) { - $datatable .= ''; - } - $datatable .= '
    '; - } else { - $datatable .= ''; - } - } else { - $datatable .= ''; - } - $datatable .= ''. - $fieldtitles{$fields[$i]}.'