--- loncom/interface/loncommon.pm 2008/11/22 19:08:21 1.694 +++ loncom/interface/loncommon.pm 2008/12/03 13:09:03 1.704 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # a pile of common routines # -# $Id: loncommon.pm,v 1.694 2008/11/22 19:08:21 tempelho Exp $ +# $Id: loncommon.pm,v 1.704 2008/12/03 13:09:03 muellerd Exp $ # # Copyright Michigan State University Board of Trustees # @@ -677,7 +677,7 @@ sub select_datelocale { if ($id ne '') { my $en_terr = $locale->{'en_territory'}; my $native_terr = $locale->{'native_territory'}; - my @languages = &preferred_languages(); + my @languages = &Apache::lonlocal::preferred_languages(); if (grep(/^en$/,@languages) || !@languages) { if ($en_terr ne '') { $locale_names{$id} = '('.$en_terr.')'; @@ -2998,7 +2998,7 @@ sub fileextensions { sub display_languages { my %languages=(); - foreach my $lang (&preferred_languages()) { + foreach my $lang (&Apache::lonlocal::preferred_languages()) { $languages{$lang}=1; } &get_unprocessed_cgi($ENV{'QUERY_STRING'},['displaylanguage']); @@ -3010,59 +3010,9 @@ sub display_languages { return %languages; } -sub preferred_languages { - my @languages=(); - if (($env{'request.role.adv'}) && ($env{'form.languages'})) { - @languages=(@languages,split(/\s*(\,|\;|\:)\s*/,$env{'form.languages'})); - } - if ($env{'course.'.$env{'request.course.id'}.'.languages'}) { - @languages=(@languages,split(/\s*(\,|\;|\:)\s*/, - $env{'course.'.$env{'request.course.id'}.'.languages'})); - } - - if ($env{'environment.languages'}) { - @languages=(@languages, - split(/\s*(\,|\;|\:)\s*/,$env{'environment.languages'})); - } - my $browser=$ENV{'HTTP_ACCEPT_LANGUAGE'}; - if ($browser) { - my @browser = - map { (split(/\s*;\s*/,$_))[0] } (split(/\s*,\s*/,$browser)); - push(@languages,@browser); - } - - foreach my $domtype ($env{'user.domain'},$env{'request.role.domain'}, - $Apache::lonnet::perlvar{'lonDefDomain'}) { - if ($domtype ne '') { - my %domdefs = &Apache::lonnet::get_domain_defaults($domtype); - if ($domdefs{'lang_def'} ne '') { - push(@languages,$domdefs{'lang_def'}); - } - } - } - return &get_genlanguages(@languages); -} - -sub get_genlanguages { - my (@languages) = @_; -# turn "en-ca" into "en-ca,en" - my @genlanguages; - foreach my $lang (@languages) { - unless ($lang=~/\w/) { next; } - push(@genlanguages,$lang); - if ($lang=~/(\-|\_)/) { - push(@genlanguages,(split(/(\-|\_)/,$lang))[0]); - } - } - #uniqueify the languages list - my %count; - @genlanguages = map { $count{$_}++ == 0 ? $_ : () } @genlanguages; - return @genlanguages; -} - sub languages { my ($possible_langs) = @_; - my @preferred_langs = &preferred_languages(); + my @preferred_langs = &Apache::lonlocal::preferred_languages(); if (!ref($possible_langs)) { if( wantarray ) { return @preferred_langs; @@ -3930,7 +3880,14 @@ sub get_domainconf { if (ref($domconfig{'login'}) eq 'HASH') { if (keys(%{$domconfig{'login'}})) { foreach my $key (keys(%{$domconfig{'login'}})) { - $designhash{$udom.'.login.'.$key}=$domconfig{'login'}{$key}; + if (ref($domconfig{'login'}{$key}) eq 'HASH') { + foreach my $img (keys(%{$domconfig{'login'}{$key}})) { + $designhash{$udom.'.login.'.$key.'_'.$img} = + $domconfig{'login'}{$key}{$img}; + } + } else { + $designhash{$udom.'.login.'.$key}=$domconfig{'login'}{$key}; + } } } else { $legacy{'login'} = 1; @@ -4437,6 +4394,8 @@ sub standard_css { my $vlink = &designparm($function.'.vlink', $domain); my $link = &designparm($function.'.link', $domain); + my $loginbg = &designparm('login.sidebg',$domain); + my $sans = 'Verdana,Arial,Helvetica,sans-serif'; my $mono = 'monospace'; my $data_table_head = $tabbg; @@ -4454,6 +4413,7 @@ sub standard_css { my $mail_other_hover = '#669999'; my $table_header = '#DDDDDD'; my $feedback_link_bg = '#BBBBBB'; + my $lg_border_color = '#C8C8C8'; my $border = ($env{'browser.type'} eq 'explorer' || $env{'browser.type'} eq 'safari' ) ? '0px 2px 0px 2px' @@ -4461,22 +4421,35 @@ sub standard_css { return < td, table.LC_aboutme_port tr td { @@ -4774,7 +4744,7 @@ table.LC_nested tr.LC_empty_row td { table.LC_nested_outer tr th { font-weight: bold; background-color: $data_table_head; - font-size: smaller; + font-size: small; border-bottom: 1px solid #000000; } table.LC_nested_outer tr td.LC_subheader { @@ -4813,7 +4783,7 @@ table.LC_createuser { } table.LC_createuser tr.LC_section_row td { - font-size: smaller; + font-size: small; } table.LC_createuser tr.LC_info_row td { @@ -4869,24 +4839,6 @@ table.LC_mail_list tr.LC_mail_even { table.LC_mail_list tr.LC_mail_odd { } - -table#LC_portfolio_actions { - width: auto; - background: $pgbg; - border: 0px; - border-spacing: 2px 2px; - padding: 0px; - margin: 0px; - border-collapse: separate; -} -table#LC_portfolio_actions td.LC_label { - background: $tabbg; - text-align: right; -} -table#LC_portfolio_actions td.LC_value { - background: $tabbg; -} - table#LC_cstr_controls { width: 100%; border-collapse: collapse; @@ -4905,35 +4857,27 @@ table#LC_cstr_controls tr th { font-size: smaller; } -table#LC_browser { - -} -table#LC_browser tr th { - background: $table_header; -} -table#LC_browser tr td { - padding: 2px; -} -table#LC_browser tr.LC_browser_file, -table#LC_browser tr.LC_browser_file_published { +table.LC_data_table tr > td.LC_browser_file, +table.LC_data_table tr > td.LC_browser_file_published { background: #CCFF88; } -table#LC_browser tr.LC_browser_file_locked, -table#LC_browser tr.LC_browser_file_unpublished { +table.LC_data_table tr > td.LC_browser_file_locked, +table.LC_data_table tr > td.LC_browser_file_unpublished { background: #FFAA99; } -table#LC_browser tr.LC_browser_file_obsolete { +table.LC_data_table tr > td.LC_browser_file_obsolete { background: #AAAAAA; } -table#LC_browser tr.LC_browser_file_modified, -table#LC_browser tr.LC_browser_file_metamodified { +table.LC_data_table tr > td.LC_browser_file_modified, +table.LC_data_table tr > td.LC_browser_file_metamodified { background: #FFFF77; } -table#LC_browser tr.LC_browser_folder { +table.LC_data_table tr.LC_browser_folder > td { background: #CCCCFF; } + span.LC_current_location { - font-size: x-large; + font-size:larger; background: $pgbg; } @@ -5441,10 +5385,10 @@ table.LC_scantron_action { width: 100%; } table.LC_scantron_action tr th { - font: normal bold $sans; + font-weight:bold; + font-style:normal; } - -div.LC_edit_problem_header, +.LC_edit_problem_header, div.LC_edit_problem_footer { font: normal medium $sans; margin: 2px; @@ -5527,106 +5471,94 @@ fieldset#LC_mainmenu_fieldset { # changed or removed. # --------------------------*/ - -body { - font-family: Tahoma, Arial,Helvetica,sans-serif; - font-size: 0.85em; - line-height: 130%; - color: RGB(45, 45, 45); +a:hover, +ol.smallMenu a:hover, +ol#MenuBreadcrumbs a:hover, +ul#TabMainMenuContent a:hover, +.FormSectionClearButton input:hover{ + color:#BF2317; + text-decoration:none; } -a:link,a:visited { - /*color: RGB(0, 118, 127);*/ - /*text-decoration: underline;*/ -} - -a:hover{ - text-decoration:none; -} -/*a:hover, -UL.smallMenu A:hover, -UL.MenuBreadcrumbs A:hover, -UL#TabMainMenuContent A:hover{ - color: rgb(200, 10, 50); -}*/ - h1 { - padding:5px 10px 5px 20px; + padding:5px 10px 5px 0px; line-height:130%; } -h2,h4,h6 { - /*color: RGB(0, 118, 127);*/ -} + h2,h3,h4,h5,h6 { margin:5px 0px 5px 0px; line-height:130%; } - -.right { - text-align: right; -} - -.center { - text-align: center; -} - -.left { - text-align: left; -} +.hcell{ + padding:3px 15px 3px 15px; + margin:0px; + background-color:$tabbg; + border-bottom:solid 1px $lg_border_color; +} +.noBorder { + border:0px; +} +/* +.bgLightGrey { background:URL(images/TabMenuBG.png) repeat-x left top; } +.bgLightGreyYellow {background-color:#EFECE0;} +*/ +/* Main Header with discription of Person, Course, etc. */ .HeadRight { text-align: right; float: right; margin: 0px; padding: 0px; - right:0; + right:0; position:absolute; -} - -img { -/* border: 0px; */ -} - -.personalBgColor { - background: RGB(237, 239, 0) url(images/headHighlight.png) repeat-y left top; + overflow:hidden; } p { padding: 10px; + +} +.FormSectionClearButton input { + background-color:transparent; + border:0px; + cursor:pointer; + text-decoration:underline; } -DL,UL,Div,Fieldset { - /*margin: 10px;*/ + + +dl,ul,div,fieldset { + margin: 10px 10px 10px 0px; overflow:hidden; } -OL.smallMenu { - margin: 0px 0px 0px 0px; +ol.smallMenu { + margin: 0px; } -OL.smallMenu li { +ol.smallMenu li { display: inline; padding: 5px 5px 0px 10px; vertical-align: top; } -OL.smallMenu li img { +ol.smallMenu li img { vertical-align: bottom; } -OL.smallMenu A { +ol.smallMenu a { font-size: 90%; color: RGB(80, 80, 80); text-decoration: none; } -OL#TabMainMenuContent { +ol#TabMainMenuContent { margin: 0px 0px 10px 0px; padding: 0px; } -OL#TabMainMenuContent LI { +ol#TabMainMenuContent li { display: inline; vertical-align: bottom; border-bottom: solid 1px RGB(175, 175, 175); @@ -5636,19 +5568,19 @@ OL#TabMainMenuContent LI { line-height: 140%; font-weight: bold; overflow:hidden; - background: RGB(211, 206, 205) URL(images/TabMenuBG.png) repeat-x left top; +/* background: RGB(211, 206, 205) URL(images/TabMenuBG.png) repeat-x left top;*/ } -OL#TabMainMenuContent LI A { +ol#TabMainMenuContent li a{ color: RGB(47, 47, 47); text-decoration: none; } -OL#TabMainMenuContent DIV.columnSection { +ol#TabMainMenuContent div.columnSection { margin-bottom: 0px; } -OL#MenuBreadcrumbs { +ol#MenuBreadcrumbs, ol#PathBreadcrumbs { border-top: solid 1px RGB(255, 255, 255); height: 20px; line-height: 20px; @@ -5656,68 +5588,55 @@ OL#MenuBreadcrumbs { margin: 0px 0px 30px 0px; padding-left: 10px; list-style-position: inside; - background: RGB(211, 206, 205) URL(images/TabMenuBG.png) repeat-x left - top; +/* background: RGB(211, 206, 205) URL(images/TabMenuBG.png) repeat-x left + top;*/ } -OL#MenuBreadcrumbs li { - background: url(images/pfeil_white.png) no-repeat left center; +ol#MenuBreadcrumbs li, ol#PathBreadcrumbs li { +/* background: url(images/pfeil_white.png) no-repeat left center;*/ display: inline; padding: 0px 0px 0px 10px; vertical-align: bottom; overflow:hidden; } -OL#MenuBreadcrumbs LI A { +ol#MenuBreadcrumbs li a { text-decoration: none; font-size:90%; } - -h4.hcell { - padding: 3px 10px 3px 10px; - margin: 0px; - background: RGB(0, 118, 127); - color: white; - border: outset 1px; -} - -DIV.DivContentBoxSpecial -{ - border: solid 1px RGB(100, 100, 100); +ol#PathBreadcrumbs li a{ + text-decoration:none; + font-size:100%; + font-weight:bold; } -FIELDSET +.ContentBoxSpecial { - /*width:78%;*/ -} -DIV.DivContentBox, -DIV.DivContentBoxSpecial { - width: 80%; - margin:10px; + border: solid 1px $lg_border_color; } - -FIELDSET legend,DL DT { - font-weight: bold; - font-size: 110%; - /*padding-left: 0px;*/ -/* margin-left: 0px;*/ +.ContentBox { + padding:10px; } - -DIV.DivImportant { - background: url(images/important.png) no-repeat center top; - padding: 100px 10px 10px 10px; - width: 200px; - border: double 4px RGB(200, 200, 200); +.PopUp +{ + padding:10px; + border-left:solid 1px $lg_border_color; + border-top:solid 1px $lg_border_color; + border-bottom:outset 1px $lg_border_color; + border-right:outset 1px $lg_border_color; + display:none; + position:absolute; + right:0; + background-color:white; + z-index:5; } - - -DL.ListStyleClean DT { +dl.ListStyleClean dt { padding-right: 5px; display: table-header-group; } -DL.ListStyleClean DD { +dl.ListStyleClean dd { display: table-row; } @@ -5728,75 +5647,71 @@ DL.ListStyleClean DD { .ListStyleSpecial { /*display:block; */ - width: 400px; list-style-position: inside; list-style-type: none; overflow: hidden; padding: 0px; } -.ListStyleClean li, .ListStyleSimple li, -.ListStyleSimple DD, +.ListStyleSimple dd, .ListStyleNormal li, -.ListStyleNormal DD, +.ListStyleNormal dd, .ListStyleSpecial li, -.ListStyleSpecial DD +.ListStyleSpecial dd { margin: 0px; padding: 5px 5px 5px 10px; clear: both; - /*display:block;*/ } -.ListStyleClean LI, -.ListStyleClean DD { +.ListStyleClean li, +.ListStyleClean dd { padding-top: 0px; padding-bottom: 0px; } -.ListStyleSimple DD, -.ListStyleSimple LI{ - border-bottom: solid 1px RGB(150, 150, 150); +.ListStyleSimple dd, +.ListStyleSimple li{ + border-bottom: solid 1px $lg_border_color; } -.ListStyleSpecial LI, -.ListStyleSpecial DD { +.ListStyleSpecial li, +.ListStyleSpecial dd { list-style-type: none; background-color: RGB(220, 220, 220); margin-bottom: 4px; } -table.SimpleTable *{ - padding:10px; +table.SimpleTable { + margin:5px; + border:solid 1px $lg_border_color; } -table.SimpleTable td { - vertical-align:top; - border:solid 1px RGB(210,210,210); +table.SimpleTable tr { + padding:0px; + border:solid 1px $lg_border_color; } table.SimpleTable thead{ - background:rgb(210,210,210); + background:rgb(220,220,220); } -DIV.columnSection { +div.columnSection { display: block; clear: both; overflow: hidden; margin:0px; } -DIV.columnSection>* { +div.columnSection>* { float: left; margin: 10px 20px 10px 0px; overflow:hidden; } - -DIV.columnSection>FIELDSET, -DIV.columnSection>DIV.DivContentBox, -DIV.columnSection>DIV.DivContentBoxSpecial +div.columnSection > .ContentBox, +div.columnSection > .ContentBoxSpecial { - width: 480px; + width: 400px; } @@ -5806,7 +5721,8 @@ DIV.columnSection>DIV.DivContentBoxSpeci width:65%; padding: 10px; height: auto; - background-color:#FFFFFF; +# background-color:#FFFFFF; + background-color:$loginbg; border:1px solid #CCCCCC; }