--- loncom/interface/lonsupportreq.pm 2006/12/06 22:22:37 1.39 +++ loncom/interface/lonsupportreq.pm 2006/12/12 16:04:40 1.40 @@ -1,5 +1,5 @@ # -# $Id: lonsupportreq.pm,v 1.39 2006/12/06 22:22:37 albertel Exp $ +# $Id: lonsupportreq.pm,v 1.40 2006/12/12 16:04:40 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -83,20 +83,59 @@ sub print_request_form { $usec = $env{'request.course.sec'}; $cid = $env{'request.course.id'}; $formname = 'logproblem'; - if ($origurl =~ m-^http://-) { + my $machine = &Apache::lonnet::absolute_url(); + if ($origurl =~ m-^https?://-) { $server = $origurl; } else { - $server = 'http://'.$ENV{'SERVER_NAME'}.$origurl; + $server = $machine.$origurl; } - my $scripttag = (<<'END'); + my %lt = &Apache::lonlocal::texthash ( + email => 'The e-mail address you entered', + notv => 'is not a valid e-mail address', + rsub => 'You must include a subject', + rdes => 'You must include a description', + name => 'Name', + subm => 'Submit Request', + emad => 'E-mail address', + unme => 'username', + doma => 'domain', + entr => 'Enter the username you use to log-in to your LON-CAPA system, and choose your domain.', + urlp => 'URL of page', + phon => 'Phone', + crsd => 'Course Details', + enin => 'Enter institutional course code', + pick => 'Pick', + enct => 'Enter course title', + secn => 'Section Number', + sele => 'Select', + titl => 'Title', + lsec => 'LON-CAPA sec', + subj => 'Subject', + detd => 'Detailed Description', + opfi => 'Optional file upload', + uplf => 'Upload a file (e.g., a screenshot) relevant to your support request (128 KB max. size)', + fini => 'Finish', + clfm => 'Clear Form', + ); + my $scripttag = (<<"END"); function validate() { if (validmail(document.logproblem.email) == false) { - alert("The e-mail address you entered: "+document.logproblem.email.value+" is not a valid e-mail address."); + alert("$lt{'email'}: "+document.logproblem.email.value+" $lt{'notv'}."); + return; + } + if (document.logproblem.subject.value == '') { + alert("$lt{'rsub'}."); + return; + } + if (document.logproblem.description.value == '') { + alert("$lt{'rdes'}."); return; } document.logproblem.submit(); } +END + $scripttag .= <<'END'; function validmail(field) { var str = field.value; if (window.RegExp) { @@ -120,7 +159,7 @@ function validmail(field) { END if ($cid =~ m/_/) { - ($cdom,$cnum) = split/_/,$cid; + ($cdom,$cnum) = split(/_/,$cid); } if ($cdom && $cnum) { my %csettings = &Apache::lonnet::get('environment',['description','internal.coursecode','internal.sectionnums'],$cdom,$cnum); @@ -140,10 +179,10 @@ END if ($env{'environment.firstname'}) { $firstname = $env{'environment.firstname'}; } - my @sections = split/,/,$sectionlist; - my %groupid = (); - foreach (@sections) { - my ($sec,$grp) = split/:/,$_; + my @sections = split(/,/,$sectionlist); + my %groupid; + foreach my $section (@sections) { + my ($sec,$grp) = split(/:/,$section); $groupid{$sec} = $grp; } my $codedom = $Apache::lonnet::perlvar{'lonDefDomain'}; @@ -155,14 +194,14 @@ END if ($codedom) { $details_title = '
('.$codedom.')'; } - my %coursecodes = (); - my %codes = (); - my @codetitles = (); - my %cat_titles = (); - my %cat_order = (); - my %idlist = (); - my %idnums = (); - my %idlist_titles = (); + my %coursecodes; + my %codes; + my @codetitles; + my %cat_titles; + my %cat_order; + my %idlist; + my %idnums; + my %idlist_titles; my $caller = 'global'; my $totcodes = 0; my $format_reply; @@ -236,7 +275,7 @@ function initialize_codes() { -
Name: + $lt{'name'}:
@@ -259,7 +298,7 @@ END $r->print(''); } $r->print(<  +        @@ -274,7 +313,7 @@ END -
E-mail address: + $lt{'emad'}:
@@ -298,7 +337,7 @@ END -
username/domain: + $lt{'unme'}/$lt{'doma'}:
@@ -311,23 +350,23 @@ END my $udom_input = ''; my $uname_input = ''; if (defined($uname) && defined($udom)) { - $r->print('username: '.$uname.'  domain: '.$udom.$udom_input.$uname_input); + $r->print(''.$lt{'unme'}.': '.$uname.'  '.$lt{'doma'}.': '.$udom.$udom_input.$uname_input); } else { my $udomform = ''; my $unameform = ''; if (defined($udom)) { - $udomform = 'domain: '.$udom.$udom_input; + $udomform = ''.$lt{'doma'}.': '.$udom.$udom_input; } elsif (defined($uname)) { - $unameform = 'username: '.$uname.'  '.$uname_input; + $unameform = ''.$lt{'unme'}.': '.$uname.'  '.$uname_input; } if ($udomform eq '') { - $udomform = 'domain: '; + $udomform = ''.$lt{'doma'}.': '; $udomform .= &Apache::loncommon::select_dom_form($codedom,'udom'); } if ($unameform eq '') { - $unameform= 'username  '; + $unameform= ''.$lt{'unme'}.'  '; } - $r->print($unameform.$udomform.'
Enter the username you use to log-in to your LON-CAPA system, and choose your domain.'); + $r->print($unameform.$udomform.'
'.$lt{'entr'}); } $r->print(< @@ -344,7 +383,7 @@ END -
URL of page: + $lt{'urlp'}:
@@ -368,7 +407,7 @@ END -
Phone #: + $lt{'phon'} #:
@@ -392,7 +431,7 @@ END -
Course Details:$details_title + $lt{'crsd'}:$details_title
@@ -404,19 +443,19 @@ END END if ($cnum) { if ($coursecodes{$cnum}) { - foreach (@codetitles) { - $r->print(''.$_.': '.$codes{$cnum}{$_}.'; '); + foreach my $item (@codetitles) { + $r->print(''.$item.': '.$codes{$cnum}{$item}.'; '); } $r->print(' '); } else { - $r->print('Enter institutional course code:  + $r->print($lt{'enin'}.':  '); } } else { if ($totcodes > 0) { my $numtitles = @codetitles; if ($numtitles == 0) { - $r->print('Enter institutional course code:  + $r->print($lt{'enin'}.':  '); } else { my $lasttitle = $numtitles; @@ -425,17 +464,17 @@ END } $r->print('' ); @@ -463,19 +502,19 @@ END if ($numtitles > 4) { $r->print('

'.$codetitles[$numtitles].'
'."\n". ''."\n"); } } } else { - $r->print('Enter institutional course code:  + $r->print($lt{'enin'}.':  '); } } if ($ctitle) { - $r->print('
Title: '.$ctitle.''); + $r->print('
'.$lt{'titl'}.': '.$ctitle.''); } else { - $r->print('
Enter course title:  + $r->print('
'.$lt{'enct'}.':  '); } $r->print(<
'.$codetitles[0].'
'."\n". '
'.$codetitles[$i].'
'."\n". ''."\n". '
-
Section Number: + $lt{'secn'}:
@@ -505,12 +544,12 @@ END END if ($sectionlist) { $r->print(""); @@ -532,7 +571,7 @@ END -
Subject + $lt{'subj'}
@@ -556,7 +595,7 @@ END -
Detailed description: + $lt{'detd'}:
@@ -583,7 +622,7 @@ END -
Optional file upload: + $lt{'opfi'}:
@@ -592,7 +631,7 @@ END
-
Upload a file (e.g., a screenshot) relevant to your support request (128 KB max. size). +
$lt{'uplf'}
@@ -611,7 +650,7 @@ END -
Finish: + $lt{'fini'}:
@@ -621,11 +660,11 @@ END -   +     - + @@ -679,30 +718,48 @@ sub print_request_receipt { $coursecode .= $env{'form.Number'}; } } + my %lt = &Apache::lonlocal::texthash ( + name => 'Name', + email => 'Email', + unme => 'Username/domain', + tel => 'Tel', + crsi => 'Course Information', + subj => 'Subject', + desc => 'Description', + date => 'Date/Time', + secn => 'Section', + asup => 'A support request has been sent to', + warn => 'Warning: Problem with support e-mail address', + your => 'Your support request contained the following information', + sect => 'section', + info => 'Information supplied', + adin => 'Additional information recorded', + ); + my $supportmsg = qq| -Name: $env{'form.username'} -Email: $env{'form.email'} -Username/domain: $env{'form.uname'} - $env{'form.udom'} -Tel: $env{'form.phone'} -Course Information: $env{'form.title'} - $coursecode - section: $env{'form.section'} -Subject: $env{'form.subject'} -Description: $env{'form.description'} +$lt{'name'}: $env{'form.username'} +$lt{'email'}: $env{'form.email'} +$lt{'unme'}: $env{'form.uname'} - $env{'form.udom'} +$lt{'tel'}: $env{'form.phone'} +$lt{'crsi'}: env{'form.title'} - $coursecode - $lt{'secn'}: $env{'form.section'} +$lt{'subj'}: $env{'form.subject'} +$lt{'desc'}: $env{'form.description'} URL: $env{'form.sourceurl'} -Date/Time: $reporttime +$lt{'date'}: $reporttime |; my $descrip = $env{'form.description'}; $descrip =~ s#\n#
#g; my $displaymsg = qq| -Name: $env{'form.username'}
-Email: $env{'form.email'}
-Username/domain: $env{'form.uname'} - $env{'form.udom'}
-Tel: $env{'form.phone'}
-Course Information: $env{'form.title'} - $coursecode - section: $env{'form.section'}
-Subject: $env{'form.subject'}
-Description: $descrip
+$lt{'name'}: $env{'form.username'}
+$lt{'email'}: $env{'form.email'}
+$lt{'unme'}: $env{'form.uname'} - $env{'form.udom'}
+$lt{'tel'}: $env{'form.phone'}
+$lt{'crsi'}: $env{'form.title'} - $coursecode - $lt{'sect'}: $env{'form.section'}
+$lt{'subj'}: $env{'form.subject'}
+$lt{'desc'}: $descrip
URL: $env{'form.sourceurl'}
-Date/Time: $reporttime
+$lt{'date'}: $reporttime
|; my $start_page = @@ -724,17 +781,15 @@ END &print_header($r,$url,'process'); } if ($to =~ m/^[^\@]+\@[^\@]+$/) { - $r->print("

A support request has been sent to $to

"); + $r->print('

'.$lt{'asup'}.' '.$to.'

'); } else { $to = $admin; if ($to =~ m/^[^\@]+\@[^\@]+$/) { - $r->print("

A support request has been sent to $to

"); -END + $r->print('

'.$lt{'asup'}.' '.$to.'

'); } else { - $r->print(<Warning: Problem with support e-mail address -As the e-mail address provided for this LON-CAPA server ($to) does not appear to be a valid e-mail address, your support request has not been sent to the LON-CAPA support staff or administrator at your institution. Instead a copy has been sent to the LON-CAPA support team at Michigan State University. -END + $r->print(' +

'.$lt{'warn'}.'

'. +&mt('As the e-mail address provided for this LON-CAPA server ([_1]) does not appear to be a valid e-mail address, your support request has not been sent to the LON-CAPA support staff or administrator at your institution.',$to).' '.&mt('Instead a copy has been sent to the LON-CAPA support team at Michigan State University.')); $to = 'helpdesk@lon-capa.org'; } } @@ -759,14 +814,14 @@ END if ($env{'form.screenshot.filename'}) { $attachmentsize = length($env{'form.screenshot'}); if ($attachmentsize > 131072) { - $displaymsg .= "
The uploaded screenshot file ($attachmentsize bytes) included with your request exceeded the maximum allowed size - 128 KB, and has therefore been discarded."; + $displaymsg .= '
'.&mt('The uploaded screenshot file ([_1] bytes) included with your request exceeded the maximum allowed size - 128 KB, and has therefore been discarded.',$attachmentsize); } else { $attachmentpath=&Apache::lonnet::userfileupload('screenshot',undef,'helprequests'); } } } - my %cookies = (); + my %cookies; my $cookie=CGI::Cookie->parse($r->header_in('Cookie')); if ($$cookie{'lonID'} =~ /lonID=($LONCAPA::handle_re);/) { $cookies{'lonID'} = $1; @@ -774,16 +829,16 @@ END if ($attachmentpath =~ m-/([^/]+)$-) { $fname = $1; - $displaymsg .= "
An uploaded screenshot file - $fname ($attachmentsize bytes) was included in the request sent by $env{'user.name'} from LON-CAPA domain: $env{'user.domain'}"; + $displaymsg .= '
'.&mt('An uploaded screenshot file - [_1] ([_2] bytes) was included in the request sent by [_3] from LON-CAPA domain',$fname,$attachmentsize,$env{'user.name'}.': '.$env{'user.domain'}); $supportmsg .= "\n"; - foreach (@cookievars) { - $supportmsg .= "$_: $cookies{$_}\n"; + foreach my $var (@cookievars) { + $supportmsg .= "$var: $cookies{$var}\n"; } - foreach (@ENVvars) { - $supportmsg .= "$_: $ENV{$_}\n"; + foreach my $var(@ENVvars) { + $supportmsg .= "$var: $ENV{$var}\n"; } - foreach (@envvars) { - $supportmsg .= "$_: $env{$_}\n"; + foreach my $var (@envvars) { + $supportmsg .= "$var: $env{$var}\n"; } } @@ -804,17 +859,17 @@ END } else { my $envdata = ''; - foreach (@cookievars) { - $envdata .= "$_: $cookies{$_}\n"; + foreach my $var (@cookievars) { + $envdata .= "$var: $cookies{$var}\n"; } - foreach (@ENVvars) { - $envdata .= "$_: $ENV{$_}\n"; + foreach my $var (@ENVvars) { + $envdata .= "$var: $ENV{$var}\n"; } - foreach (@envvars) { - $envdata .= "$_: $env{$_}\n"; + foreach my $var (@envvars) { + $envdata .= "$var: $env{$var}\n"; } - foreach (@loncvars) { - $envdata .= "$_: $env{$_}\n"; + foreach my $var (@loncvars) { + $envdata .= "$var: $env{$var}\n"; } $msg->attach(Type => 'TEXT', Data => $envdata); @@ -827,7 +882,7 @@ END unlink($attachmentpath); } $r->print(qq| - Your support request contained the following information:

+ $lt{'your'}:

@@ -842,7 +897,7 @@ END -
Information supplied + $lt{'info'}
@@ -864,7 +919,7 @@ END
-
Additional information recorded + $lt{'adin'}
@@ -874,19 +929,19 @@ END
|); - foreach (@cookievars) { - unless($cookies{$_} eq '') { - $r->print("$_: $cookies{$_}, "); + foreach my $var (@cookievars) { + unless($cookies{$var} eq '') { + $r->print("$var: $cookies{$var}, "); } } - foreach (@ENVvars) { - unless($ENV{$_} eq '') { - $r->print("$_: $ENV{$_}, "); + foreach my $var (@ENVvars) { + unless($ENV{$var} eq '') { + $r->print("$var: $ENV{$var}, "); } } - foreach (@envvars) { - unless($env{$_} eq '') { - $r->print("$_: $env{$_}, "); + foreach my $var (@envvars) { + unless($env{$var} eq '') { + $r->print("$var: $env{$var}, "); } } $r->print(" @@ -944,9 +999,9 @@ sub print_header { - - $getstartlink - + + $getstartlink +
(Login help) $lt{'login'} $helpdesk_link(Ask helpdesk) $lt{'ask'}  (Back to last location) $lt{'back'} ($lt{'login'}) $lt{'login'} $helpdesk_link($lt{'ask'}) $lt{'ask'}  ($lt{'back'}) $lt{'back'}