--- loncom/interface/loncommon.pm 2002/07/01 15:24:44 1.42 +++ loncom/interface/loncommon.pm 2002/07/05 16:12:31 1.44 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # a pile of common routines # -# $Id: loncommon.pm,v 1.42 2002/07/01 15:24:44 matthew Exp $ +# $Id: loncommon.pm,v 1.44 2002/07/05 16:12:31 bowersj2 Exp $ # # Copyright Michigan State University Board of Trustees # @@ -33,6 +33,7 @@ # 12/25,12/28 Gerd Kortemeyer # YEAR=2002 # 1/4 Gerd Kortemeyer +# 6/24,7/2 H. K. Ng # Makes a table out of the previous attempts # Inputs result_from_symbread, user, domain, course_id @@ -427,6 +428,49 @@ END ############################################################### + +=item help_open_topic($topic, $stayOnPage, $width, $height) + +Returns a string corresponding to an HTML link to the given help $topic, where $topic corresponds to the name of a .tex file in /home/httpd/html/adm/help/tex, with underscores replaced by spaces. + +$stayOnPage is a value that will be interpreted as a boolean. If true, the link will not open a new window. If false, the link will open a new window using Javascript. (Default is false.) + +$width and $height are optional numerical parameters that will override the width and height of the popped up window, which may be useful for certain help topics with big pictures included. + +=cut + +sub help_open_topic { + my ($topic, $stayOnPage, $width, $height) = @_; + $stayOnPage = 0 if (not defined $stayOnPage); + $width = 350 if (not defined $width); + $height = 400 if (not defined $height); + my $filename = $topic; + $filename =~ s/ /_/g; + + my $template; + + if (!$stayOnPage) + { + $template = <<"ENDTEMPLATE"; +(Help: $topic) +ENDTEMPLATE + } + else + { + $template = <<"ENDTEMPLATE"; +(Help: $topic) +ENDTEMPLATE + } + + return $template; + +} + =item csv_translate($text) Translate $text to allow it to be output as a 'comma seperated values' @@ -864,13 +908,16 @@ sub filedescriptionex { # $username,$domain - that of the student # $course - course name # $getattempt - leave blank if want all attempts, else put something. +# $regexp - regular expression. If string matches regexp send to +# $gradesub - routine that process the string if it matches regexp # # output # formatted as a table all the attempts, if any. # sub get_previous_attempt { - my ($symb,$username,$domain,$course,$getattempt)=@_; + my ($symb,$username,$domain,$course,$getattempt,$regexp,$gradesub)=@_; my $prevattempts=''; + no strict 'refs'; if ($symb) { my (%returnhash)= &Apache::lonnet::restore($symb,$course,$domain,$username); @@ -882,7 +929,7 @@ sub get_previous_attempt { $lasthash{$_}=$returnhash{$version.':'.$_}; } } - $prevattempts='
'; + $prevattempts='
'; $prevattempts.=''; foreach (sort(keys %lasthash)) { my ($ign,@parts) = split(/\./,$_); @@ -920,6 +967,7 @@ sub get_previous_attempt { } else { $value=$lasthash{$_}; } + if ($_ =~/$regexp$/) {$value = &$gradesub($value)} $prevattempts.=''; } $prevattempts.='
History'.$value.' 
';