--- loncom/interface/lonpreferences.pm 2006/06/22 23:22:41 1.91 +++ loncom/interface/lonpreferences.pm 2006/06/26 18:56:50 1.93 @@ -1,7 +1,7 @@ # The LearningOnline Network # Preferences # -# $Id: lonpreferences.pm,v 1.91 2006/06/22 23:22:41 albertel Exp $ +# $Id: lonpreferences.pm,v 1.93 2006/06/26 18:56:50 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -307,6 +307,9 @@ sub rolesprefchanger { my %frozen_roles = &Apache::lonhtmlcommon::get_recent_frozen('roles',$env{'environment.recentrolesn'}); + my %role_text = &rolespref_get_role_text([keys(%recent_roles)]); + my @sorted_roles = sort {$role_text{$a} cmp $role_text{$b}} keys(%role_text); + $roles_check_list .= &Apache::loncommon::start_data_table(). &Apache::loncommon::start_data_table_header_row(). @@ -315,31 +318,12 @@ sub rolesprefchanger { &Apache::loncommon::end_data_table_header_row(). "\n"; my $count; - foreach $role_key (sort(keys(%recent_roles))) { + foreach $role_key (@sorted_roles) { my $checked = ""; my $value = $recent_roles{$role_key}; if ($frozen_roles{$role_key}) { $checked = "checked=\"checked\""; } -# get course information - my ($role,$rest) = split(/\./, $role_key); - my $trole = &Apache::lonnet::plaintext($role); - my ($tdomain,$other,$tsection)= - split(/\//,Apache::lonnet::declutter($rest)); - my $tother = '-'; - if ($role =~ /cc|st|in|ta/ ) { - my %newhash=&Apache::lonnet::coursedescription($tdomain."_".$other); - $tother = " - ".$newhash{'description'}; - } elsif ($role =~ /dc/) { - $tother = ""; - } else { - $tother = " - $other"; - } - - my $section=""; - if ($tsection) { - $section = " - Section/Group: $tsection"; - } $count++; $roles_check_list .= &Apache::loncommon::start_data_table_row(). @@ -347,7 +331,7 @@ sub rolesprefchanger { "". "". + "$role_text{$role_key}". &Apache::loncommon::end_data_table_row(). "\n"; } $roles_check_list .= "\n"; @@ -372,6 +356,36 @@ sub rolesprefchanger { '); } +sub rolespref_get_role_text { +# Get a line of text for each role + my ($roles) = @_; + my %roletext = (); + + foreach my $item (@$roles) { +# get course information + my ($role,$rest) = split(/\./, $item); + my $trole = ""; + $trole = &Apache::lonnet::plaintext($role); + my ($tdomain,$other,$tsection)= split(/\//,Apache::lonnet::declutter($rest)); + my $tother = '-'; + if ($role =~ /^(cc|st|in|ta|ep|cr)/ ) { + my %newhash=&Apache::lonnet::coursedescription($tdomain."_".$other); + $tother = " - ".$newhash{'description'}; + } elsif ($role =~ /dc/) { + $tother = ""; + } else { + $tother = " - $other"; + } + + my $section=""; + if ($tsection) { + $section = " - Section/Group: $tsection"; + } + $roletext{$item} = $tdomain." - ".$trole.$tother.$section; + } + return %roletext; +} + sub verify_and_change_rolespref { my $r = shift; my $user = $env{'user.name'}; @@ -401,20 +415,22 @@ sub verify_and_change_rolespref { # Get list of froze roles and list of recent roles my @freeze_list = &Apache::loncommon::get_env_multiple('form.freezeroles'); my %freeze = (); + my %roletext = (); + foreach my $key (@freeze_list) { $freeze{$key}='1'; } - + my %recent_roles = &Apache::lonhtmlcommon::get_recent('roles',$env{'environment.recentrolesn'}); my %frozen_roles = &Apache::lonhtmlcommon::get_recent_frozen('roles',$env{'environment.recentrolesn'}); + my %role_text = &rolespref_get_role_text([keys(%recent_roles)]); # Unset any roles that were previously frozen but aren't in list - foreach my $role_key (sort(keys(%recent_roles))) { if (($frozen_roles{$role_key}) && (!exists($freeze{$role_key}))) { - $message .= "
".&mt('Unfreezing Role: [_1]',$role_key)."\n"; + $message .= "
".&mt('Unfreezing Role: [_1]',$role_text{$role_key})."\n"; &Apache::lonhtmlcommon::store_recent('roles',$role_key,' ',0); } } @@ -422,7 +438,7 @@ sub verify_and_change_rolespref { # Freeze selected roles foreach my $role_key (@freeze_list) { if (!$frozen_roles{$role_key}) { - $message .= "
".&mt('Freezing Role: [_1]',$role_key)."\n"; + $message .= "
".&mt('Freezing Role: [_1]',$role_text{$role_key})."\n"; &Apache::lonhtmlcommon::store_recent('roles', $role_key,' ',1); }