Added PODs.
Removed a bunch of trailing whitespace. Fixed &mkheadr to match the documentation.
This commit is contained in:
parent
cf30cc742c
commit
01e1912093
1 changed files with 373 additions and 71 deletions
444
C4/Output.pm
444
C4/Output.pm
|
@ -56,10 +56,10 @@ printable string.
|
|||
=cut
|
||||
|
||||
@ISA = qw(Exporter);
|
||||
@EXPORT = qw(&startpage &endpage
|
||||
@EXPORT = qw(&startpage &endpage
|
||||
&mktablehdr &mktableft &mktablerow &mklink
|
||||
&startmenu &endmenu &mkheadr
|
||||
¢er &endcenter
|
||||
&startmenu &endmenu &mkheadr
|
||||
¢er &endcenter
|
||||
&mkform &mkform2 &bold
|
||||
&gotopage &mkformnotable &mkform3
|
||||
&getkeytableselectoptions
|
||||
|
@ -152,7 +152,7 @@ sub picktemplate {
|
|||
#(next) unless (/\.tmpl$/);
|
||||
(next) unless (-e "$includes/templates/$_/$base");
|
||||
$templates->{$_}=1;
|
||||
}
|
||||
}
|
||||
my $sth=$dbh->prepare("select value from systempreferences where
|
||||
variable='template'");
|
||||
$sth->execute;
|
||||
|
@ -164,9 +164,74 @@ sub picktemplate {
|
|||
} else {
|
||||
return 'default';
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
=item pathtotemplate
|
||||
|
||||
%values = &pathtotemplate(template => $template,
|
||||
theme => $themename,
|
||||
language => $language,
|
||||
type => $ptype,
|
||||
path => $includedir);
|
||||
|
||||
Finds a directory containing the desired template. The C<template>
|
||||
argument specifies the template you're looking for (this should be the
|
||||
name of the script you're using to generate an HTML page, without the
|
||||
C<.pl> extension). Only the C<template> argument is required; the
|
||||
others are optional.
|
||||
|
||||
C<theme> specifies the name of the theme to use. This will be used
|
||||
only if it is allowed by the C<allowthemeoverride> system preference
|
||||
option (in the C<systempreferences> table of the Koha database).
|
||||
|
||||
C<language> specifies the desired language. If not specified,
|
||||
C<&pathtotemplate> will use the list of acceptable languages specified
|
||||
by the browser, then C<all>, and finally C<en> as fallback options.
|
||||
|
||||
C<type> may be C<intranet>, C<opac>, C<none>, or some other value.
|
||||
C<intranet> and C<opac> specify that you want a template for the
|
||||
internal web site or the public OPAC, respectively. C<none> specifies
|
||||
that the template you're looking for is at the top level of one of the
|
||||
include directories. Any other value is taken as-is, as a subdirectory
|
||||
of one of the include directories.
|
||||
|
||||
C<path> specifies an include directory.
|
||||
|
||||
C<&pathtotemplate> searches first in the directory given by the
|
||||
C<path> argument, if any, then in the directories given by the
|
||||
C<templatedirectory> and C<includes> directives in F</etc/koha.conf>,
|
||||
in that order.
|
||||
|
||||
C<&pathtotemplate> returns a hash with the following keys:
|
||||
|
||||
=over 4
|
||||
|
||||
=item C<path>
|
||||
|
||||
The full pathname to the desired template.
|
||||
|
||||
=item C<foundlanguage>
|
||||
|
||||
The value is set to 1 if a template in the desired language was found,
|
||||
or 0 otherwise.
|
||||
|
||||
=item C<foundtheme>
|
||||
|
||||
The value is set to 1 if a template of the desired theme was found, or
|
||||
0 otherwise.
|
||||
|
||||
=back
|
||||
|
||||
If C<&pathtotemplate> cannot find an acceptable template, it returns 0.
|
||||
|
||||
Note that if a template of the desired language or theme cannot be
|
||||
found, C<&pathtotemplate> will print a warning message. Unless you've
|
||||
set C<$SIG{__WARN__}>, though, this won't show up in the output HTML
|
||||
document.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub pathtotemplate {
|
||||
my %params = @_;
|
||||
my $template = $params{'template'};
|
||||
|
@ -174,12 +239,14 @@ sub pathtotemplate {
|
|||
my $languageor = lc($params{'language'});
|
||||
my $ptype = lc($params{'type'} or 'intranet');
|
||||
|
||||
# FIXME - Make sure $params{'template'} was given. Or else assume
|
||||
# "default".
|
||||
my $type;
|
||||
if ($ptype eq 'opac') {$type = 'opac-tmpl/'; }
|
||||
elsif ($ptype eq 'none') {$type = ''; }
|
||||
elsif ($ptype eq 'intranet') {$type = 'intranet-tmpl/'; }
|
||||
else {$type = $ptype . '/'; }
|
||||
|
||||
|
||||
my %returns;
|
||||
my %prefs= systemprefs();
|
||||
my $theme= $prefs{'theme'} || 'default';
|
||||
|
@ -194,6 +261,7 @@ sub pathtotemplate {
|
|||
|
||||
my ($edir, $etheme, $elanguage, $epath);
|
||||
|
||||
# FIXME - Use 'foreach my $var (...)'
|
||||
CHECK: foreach (@tmpldirs) {
|
||||
$edir= $_;
|
||||
foreach ($theme, 'all', 'default') {
|
||||
|
@ -207,12 +275,12 @@ sub pathtotemplate {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
unless ($epath) {
|
||||
warn "Could not find $template in @tmpldirs";
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
if ($language eq $elanguage) {
|
||||
$returns{'foundlanguage'} = 1;
|
||||
} else {
|
||||
|
@ -228,13 +296,25 @@ sub pathtotemplate {
|
|||
|
||||
$returns{'path'} = $epath;
|
||||
|
||||
return (%returns);
|
||||
return (%returns);
|
||||
}
|
||||
|
||||
=item getlanguageorder
|
||||
|
||||
@languages = &getlanguageorder();
|
||||
|
||||
Returns the list of languages that the user will accept, and returns
|
||||
them in order of decreasing preference. This is retrieved from the
|
||||
browser's headers, if possible; otherwise, C<&getlanguageorder> uses
|
||||
the C<languageorder> setting from the C<systempreferences> table in
|
||||
the Koha database. If neither is set, it defaults to C<en> (English).
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub getlanguageorder () {
|
||||
my @languageorder;
|
||||
my %prefs = systemprefs();
|
||||
|
||||
|
||||
if ($ENV{'HTTP_ACCEPT_LANGUAGE'}) {
|
||||
@languageorder = split (/,/ ,lc($ENV{'HTTP_ACCEPT_LANGUAGE'}));
|
||||
} elsif ($prefs{'languageorder'}) {
|
||||
|
@ -246,11 +326,29 @@ sub getlanguageorder () {
|
|||
return (@languageorder);
|
||||
}
|
||||
|
||||
=item startpage
|
||||
|
||||
$str = &startpage();
|
||||
print $str;
|
||||
|
||||
Returns a string of HTML, the beginning of a new HTML document.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub startpage() {
|
||||
return("<html>\n");
|
||||
}
|
||||
|
||||
=item gotopage
|
||||
|
||||
$str = &gotopage("//opac.koha.org/index.html");
|
||||
print $str;
|
||||
|
||||
Generates a snippet of HTML code that will redirect to the given URL
|
||||
(which should not include the initial C<http:>), and returns it.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub gotopage($) {
|
||||
my ($target) = shift;
|
||||
#print "<br>goto target = $target<br>";
|
||||
|
@ -258,7 +356,20 @@ sub gotopage($) {
|
|||
return $string;
|
||||
}
|
||||
|
||||
=item startmenu
|
||||
|
||||
@lines = &startmenu($type);
|
||||
print join("", @lines);
|
||||
|
||||
Given a page type, or category, returns a set of lines of HTML which,
|
||||
when concatenated, generate the menu at the top of the web page.
|
||||
|
||||
C<$type> may be one of C<issue>, C<opac>, C<member>, C<acquisitions>,
|
||||
C<report>, C<circulation>, or something else, in which case the menu
|
||||
will be for the catalog pages.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub startmenu($) {
|
||||
# edit the paths in here
|
||||
my ($type)=shift;
|
||||
|
@ -323,14 +434,46 @@ sub endmenu {
|
|||
return @string;
|
||||
}
|
||||
|
||||
=item mktablehdr
|
||||
|
||||
$str = &mktablehdr();
|
||||
print $str;
|
||||
|
||||
Returns a string of HTML, which generates the beginning of a table
|
||||
declaration.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub mktablehdr() {
|
||||
return("<table border=0 cellspacing=0 cellpadding=5>\n");
|
||||
}
|
||||
|
||||
=item mktablerow
|
||||
|
||||
$str = &mktablerow($columns, $color, @column_data, $bgimage);
|
||||
print $str;
|
||||
|
||||
Returns a string of HTML, which generates a row of data inside a table
|
||||
(see also C<&mktablehdr>, C<&mktableft>).
|
||||
|
||||
C<$columns> specifies the number of columns in this row of data.
|
||||
|
||||
C<$color> specifies the background color for the row, e.g., C<"white">
|
||||
or C<"#ffacac">.
|
||||
|
||||
C<@column_data> is an array of C<$columns> elements, each one a string
|
||||
of HTML. These are the contents of the row.
|
||||
|
||||
The optional C<$bgimage> argument specifies the pathname to an image
|
||||
to use as the background for each cell in the row. This pathname will
|
||||
used as is in the output, so it should be relative to the HTTP
|
||||
document root.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub mktablerow {
|
||||
#the last item in data may be a backgroundimage
|
||||
|
||||
|
||||
# FIXME
|
||||
# should this be a foreach (1..$cols) loop?
|
||||
|
||||
|
@ -348,24 +491,35 @@ sub mktablerow {
|
|||
$string.=" </td>";
|
||||
} else {
|
||||
$string.="$data[$i]</td>";
|
||||
}
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
$string=$string."</tr>\n";
|
||||
return($string);
|
||||
}
|
||||
|
||||
=item mktableft
|
||||
|
||||
$str = &mktableft();
|
||||
print $str;
|
||||
|
||||
Returns a string of HTML, which generates the end of a table
|
||||
declaration.
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub mktableft() {
|
||||
return("</table>\n");
|
||||
}
|
||||
|
||||
# FIXME - This is never used.
|
||||
sub mkform{
|
||||
my ($action,%inputs)=@_;
|
||||
my $string="<form action=$action method=post>\n";
|
||||
$string=$string.mktablehdr();
|
||||
my $key;
|
||||
my @keys=sort keys %inputs;
|
||||
|
||||
|
||||
my $count=@keys;
|
||||
my $i2=0;
|
||||
while ( $i2<$count) {
|
||||
|
@ -379,7 +533,7 @@ sub mkform{
|
|||
if ($data[0] eq 'radio') {
|
||||
$text="<input type=radio name=$keys[$i2] value=$data[1]>$data[1]
|
||||
<input type=radio name=$keys[$i2] value=$data[2]>$data[2]";
|
||||
}
|
||||
}
|
||||
if ($data[0] eq 'text') {
|
||||
$text="<input type=$data[0] name=$keys[$i2] value=\"$data[1]\">";
|
||||
}
|
||||
|
@ -395,7 +549,7 @@ sub mkform{
|
|||
$i = $i+2;
|
||||
}
|
||||
$text=$text."</select>";
|
||||
}
|
||||
}
|
||||
$string=$string.mktablerow(2,'white',$keys[$i2],$text);
|
||||
#@order[$posn] =mktablerow(2,'white',$keys[$i2],$text);
|
||||
}
|
||||
|
@ -407,17 +561,87 @@ sub mkform{
|
|||
$string=$string."</form>";
|
||||
}
|
||||
|
||||
=item mkform3
|
||||
|
||||
$str = &mkform3($action,
|
||||
$fieldname => "$fieldtype\t$fieldvalue\t$fieldpos",
|
||||
...
|
||||
);
|
||||
print $str;
|
||||
|
||||
Takes a set of arguments that define an input form, generates an HTML
|
||||
string for the form, and returns the string.
|
||||
|
||||
C<$action> is the action for the form, usually the URL of the script
|
||||
that will process it.
|
||||
|
||||
The remaining arguments define the fields in the form. C<$fieldname>
|
||||
is the field's name. This is for the script's benefit, and will not be
|
||||
shown to the user.
|
||||
|
||||
C<$fieldpos> is an integer; fields will be output in order of
|
||||
increasing C<$fieldpos>. This number must be unique: if two fields
|
||||
have the same C<$fieldpos>, one will be picked at random, and the
|
||||
other will be ignored. See below for special considerations, however.
|
||||
|
||||
C<$fieldtype> specifies the type of the input field. It may be one of
|
||||
the following:
|
||||
|
||||
=over 4
|
||||
|
||||
=item C<hidden>
|
||||
|
||||
Generates a hidden field, used to pass data to the script without
|
||||
showing it to the user. C<$fieldvalue> is the value.
|
||||
|
||||
=item C<radio>
|
||||
|
||||
Generates a pair of radio buttons, with values C<$fieldvalue> and
|
||||
C<$fieldpos>. In both cases, C<$fieldvalue> and C<$fieldpos> will be
|
||||
shown to the user.
|
||||
|
||||
=item C<text>
|
||||
|
||||
Generates a one-line text input field. It initially contains
|
||||
C<$fieldvalue>.
|
||||
|
||||
=item C<textarea>
|
||||
|
||||
Generates a four-line text input area. The initial text (which, of
|
||||
course, may not contain any tabs) is C<$fieldvalue>.
|
||||
|
||||
=item C<select>
|
||||
|
||||
Generates a list of items, from which the user may choose one. This is
|
||||
somewhat different from other input field types, and should be
|
||||
specified as:
|
||||
"myselectfield" => "select\t<label0>\t<text0>\t<label1>\t<text1>...",
|
||||
where the C<text>N strings are the choices that will be presented to
|
||||
the user, and C<label>N are the labels that will be passed to the
|
||||
script.
|
||||
|
||||
However, C<text0> should be an integer, since it will be used to
|
||||
determine the order in which this field appears in the form. If any of
|
||||
the C<label>Ns are empty, the rest of the list will be ignored.
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub mkform3 {
|
||||
my ($action, %inputs) = @_;
|
||||
my $string = "<form action=\"$action\" method=\"post\">\n";
|
||||
$string .= mktablehdr();
|
||||
my $key;
|
||||
my @keys = sort(keys(%inputs));
|
||||
my @keys = sort(keys(%inputs)); # FIXME - Why do these need to be
|
||||
# sorted?
|
||||
my @order;
|
||||
my $count = @keys;
|
||||
my $i2 = 0;
|
||||
while ($i2 < $count) {
|
||||
my $value=$inputs{$keys[$i2]};
|
||||
# FIXME - Why use a tab-separated string? Why not just use an
|
||||
# anonymous array?
|
||||
my @data=split('\t',$value);
|
||||
my $posn = $data[2];
|
||||
if ($data[0] eq 'hidden'){
|
||||
|
@ -445,7 +669,7 @@ sub mkform3 {
|
|||
$i = $i+2; # FIXME - Use $i += 2.
|
||||
}
|
||||
$text=$text."</select>";
|
||||
}
|
||||
}
|
||||
# $string=$string.mktablerow(2,'white',$keys[$i2],$text);
|
||||
$order[$posn]=mktablerow(2,'white',$keys[$i2],$text);
|
||||
}
|
||||
|
@ -460,7 +684,67 @@ sub mkform3 {
|
|||
# FIXME - A return statement, while not strictly necessary, would be nice.
|
||||
}
|
||||
|
||||
# XXX - POD
|
||||
=item mkformnotable
|
||||
|
||||
$str = &mkformnotable($action, @inputs);
|
||||
print $str;
|
||||
|
||||
Takes a set of arguments that define an input form, generates an HTML
|
||||
string for the form, and returns the string. Unlike C<&mkform2> and
|
||||
C<&mkform3>, it does not put the form inside a table.
|
||||
|
||||
C<$action> is the action for the form, usually the URL of the script
|
||||
that will process it.
|
||||
|
||||
The remaining arguments define the fields in the form. Each is an
|
||||
anonymous array, e.g.:
|
||||
|
||||
&mkformnotable("/cgi-bin/foo",
|
||||
[ "hidden", "hiddenvar", "value" ],
|
||||
[ "text", "username", "" ]);
|
||||
|
||||
The first element of each argument defines its type. The remaining
|
||||
ones are type-dependent. The supported types are:
|
||||
|
||||
=over 4
|
||||
|
||||
=item C<[ "hidden", $name, $value]>
|
||||
|
||||
Generates a hidden field, for passing information to a script without
|
||||
showing it to the user. C<$name> is the name of the field, and
|
||||
C<$value> is the value to pass.
|
||||
|
||||
=item C<[ "radio", $groupname, $value ]>
|
||||
|
||||
Generates a radio button. Its name (or button group name) is C<$name>.
|
||||
C<$value> is the value associated with the button; this is both the
|
||||
value that will be shown to the user, and that which will be passed on
|
||||
to the C<$action> script.
|
||||
|
||||
=item C<[ "text", $name, $inittext ]>
|
||||
|
||||
Generates a text input field. C<$name> specifies its name, and
|
||||
C<$inittext> specifies the text that the field should initially
|
||||
contain.
|
||||
|
||||
=item C<[ "textarea", $name ]>
|
||||
|
||||
Creates a 40x4 text area, named C<$name>.
|
||||
|
||||
=item C<[ "reset", $name, $label ]>
|
||||
|
||||
Generates a reset button, with name C<$name>. C<$label> specifies the
|
||||
text for the button.
|
||||
|
||||
=item C<[ "submit", $name, $label ]>
|
||||
|
||||
Generates a submit button, with name C<$name>. C<$label> specifies the
|
||||
text for the button.
|
||||
|
||||
=back
|
||||
|
||||
=cut
|
||||
#'
|
||||
sub mkformnotable{
|
||||
my ($action,@inputs)=@_;
|
||||
my $string="<form action=$action method=post>\n";
|
||||
|
@ -471,7 +755,7 @@ sub mkformnotable{
|
|||
}
|
||||
if ($inputs[$i][0] eq 'radio') {
|
||||
$string.="<input type=radio name=$inputs[1] value=$inputs[$i][2]>$inputs[$i][2]";
|
||||
}
|
||||
}
|
||||
if ($inputs[$i][0] eq 'text') {
|
||||
$string.="<input type=$inputs[$i][0] name=$inputs[$i][1] value=\"$inputs[$i][2]\">";
|
||||
}
|
||||
|
@ -480,10 +764,10 @@ sub mkformnotable{
|
|||
}
|
||||
if ($inputs[$i][0] eq 'reset'){
|
||||
$string.="<input type=reset name=$inputs[$i][1] value=\"$inputs[$i][2]\">";
|
||||
}
|
||||
}
|
||||
if ($inputs[$i][0] eq 'submit'){
|
||||
$string.="<input type=submit name=$inputs[$i][1] value=\"$inputs[$i][2]\">";
|
||||
}
|
||||
}
|
||||
}
|
||||
$string=$string."</form>";
|
||||
}
|
||||
|
@ -578,7 +862,7 @@ sub mkform2{
|
|||
my @data=split('\t',$value);
|
||||
my $posn = shift(@data);
|
||||
my $reqd = shift(@data);
|
||||
my $ltext = shift(@data);
|
||||
my $ltext = shift(@data);
|
||||
if ($data[0] eq 'hidden'){
|
||||
$string=$string."<input type=hidden name=$key value=\"$data[1]\">\n";
|
||||
} else {
|
||||
|
@ -608,7 +892,7 @@ sub mkform2{
|
|||
$text = $text."<option value=\"$data[$i]\"";
|
||||
if ($data[$i] eq $sel) {
|
||||
$text = $text." selected";
|
||||
}
|
||||
}
|
||||
$text = $text.">$val";
|
||||
$i = $i+2;
|
||||
}
|
||||
|
@ -626,60 +910,49 @@ sub mkform2{
|
|||
$string=$string."</form>";
|
||||
}
|
||||
|
||||
=pod
|
||||
=item endpage
|
||||
|
||||
=head2 &endpage
|
||||
$str = &endpage();
|
||||
print $str;
|
||||
|
||||
&endpage does not expect any arguments, it returns the string:
|
||||
</body></html>\n
|
||||
Returns a string of HTML, the end of an HTML document.
|
||||
|
||||
=cut
|
||||
|
||||
#'
|
||||
sub endpage() {
|
||||
return("</body></html>\n");
|
||||
}
|
||||
|
||||
=pod
|
||||
=item mklink
|
||||
|
||||
=head2 &mklink
|
||||
$str = &mklink($url, $text);
|
||||
print $str;
|
||||
|
||||
&mklink expects two arguments, the url to link to and the text of the link.
|
||||
It returns this string:
|
||||
<a href="$url">$text</a>
|
||||
where $url is the first argument and $text is the second.
|
||||
Returns an HTML string, where C<$text> is a link to C<$url>.
|
||||
|
||||
=cut
|
||||
|
||||
#'
|
||||
sub mklink($$) {
|
||||
my ($url,$text)=@_;
|
||||
my $string="<a href=\"$url\">$text</a>";
|
||||
return ($string);
|
||||
}
|
||||
|
||||
=pod
|
||||
=item mkheadr
|
||||
|
||||
=head2 &mkheadr
|
||||
$str = &mkheadr($type, $text);
|
||||
print $str;
|
||||
|
||||
&mkeadr expects two strings, a type and the text to use in the header.
|
||||
types are:
|
||||
Takes a header type and header text, and returns a string of HTML,
|
||||
where C<$text> is rendered with emphasis in a large font size (not an
|
||||
actual HTML header).
|
||||
|
||||
=over
|
||||
|
||||
=item 1 ends with <br>
|
||||
|
||||
=item 2 no special ending tag
|
||||
|
||||
=item 3 ends with <p>
|
||||
|
||||
=back
|
||||
|
||||
Other than this, the return value is the same:
|
||||
<FONT SIZE=6><em>$text</em></FONT>$string
|
||||
Where $test is the text passed in and $string is the tag generated from
|
||||
the type value.
|
||||
C<$type> may be 1, 2, or 3. A type 1 "header" ends with a line break;
|
||||
Type 2 has no special tag at the end; Type 3 ends with a paragraph
|
||||
break.
|
||||
|
||||
=cut
|
||||
|
||||
#'
|
||||
sub mkheadr {
|
||||
# FIXME
|
||||
# would it be better to make this more generic by accepting an optional
|
||||
|
@ -691,7 +964,7 @@ sub mkheadr {
|
|||
$string="<FONT SIZE=6><em>$text</em></FONT><br>";
|
||||
}
|
||||
if ($type eq '2'){
|
||||
$string="<FONT SIZE=6><em>$text</em></FONT><br>";
|
||||
$string="<FONT SIZE=6><em>$text</em></FONT>";
|
||||
}
|
||||
if ($type eq '3'){
|
||||
$string="<FONT SIZE=6><em>$text</em></FONT><p>";
|
||||
|
@ -699,37 +972,66 @@ sub mkheadr {
|
|||
return ($string);
|
||||
}
|
||||
|
||||
=pod
|
||||
=item center and endcenter
|
||||
|
||||
=head2 ¢er and &endcenter
|
||||
print ¢er(), "This is a line of centered text.", &endcenter();
|
||||
|
||||
¢er and &endcenter take no arguments and return html tags <CENTER> and
|
||||
</CENTER> respectivley.
|
||||
C<¢er> and C<&endcenter> take no arguments and return HTML tags
|
||||
<CENTER> and </CENTER> respectively.
|
||||
|
||||
=cut
|
||||
|
||||
#'
|
||||
sub center() {
|
||||
return ("<CENTER>\n");
|
||||
}
|
||||
}
|
||||
|
||||
sub endcenter() {
|
||||
return ("</CENTER>\n");
|
||||
}
|
||||
}
|
||||
|
||||
=pod
|
||||
=item bold
|
||||
|
||||
=head2 &bold
|
||||
$str = &bold($text);
|
||||
print $str;
|
||||
|
||||
&bold requires that a single string be passed in by the caller. &bold
|
||||
will return "<b>$text</b>" where $text is the string passed in.
|
||||
Returns a string of HTML that renders C<$text> in bold.
|
||||
|
||||
=cut
|
||||
|
||||
#'
|
||||
sub bold($) {
|
||||
my ($text)=shift;
|
||||
return("<b>$text</b>");
|
||||
}
|
||||
|
||||
=item getkeytableselectoptions
|
||||
|
||||
$str = &getkeytableselectoptions($dbh, $tablename,
|
||||
$keyfieldname, $descfieldname,
|
||||
$showkey, $default);
|
||||
print $str;
|
||||
|
||||
Builds an HTML selection box from a database table. Returns a string
|
||||
of HTML that implements this.
|
||||
|
||||
C<$dbh> is a DBI::db database handle.
|
||||
|
||||
C<$tablename> is the database table in which to look up the possible
|
||||
values for the selection box.
|
||||
|
||||
C<$keyfieldname> is field in C<$tablename>. It will be used as the
|
||||
internal label for the selection.
|
||||
|
||||
C<$descfieldname> is a field in C<$tablename>. It will be used as the
|
||||
option shown to the user.
|
||||
|
||||
If C<$showkey> is true, then both the key and value will be shown to
|
||||
the user.
|
||||
|
||||
If the C<$default> argument is given, then if a value (from
|
||||
C<$keyfieldname>) matches C<$default>, it will be selected by default.
|
||||
|
||||
=cut
|
||||
#'
|
||||
#---------------------------------------------
|
||||
# Create an HTML option list for a <SELECT> form tag by using
|
||||
# values from a DB file
|
||||
|
@ -747,7 +1049,7 @@ sub getkeytableselectoptions {
|
|||
my $selectclause; # return value
|
||||
|
||||
my (
|
||||
$sth, $query,
|
||||
$sth, $query,
|
||||
$key, $desc, $orderfieldname,
|
||||
);
|
||||
my $debug=0;
|
||||
|
@ -762,7 +1064,7 @@ sub getkeytableselectoptions {
|
|||
$query= "select $keyfieldname,$descfieldname
|
||||
from $tablename
|
||||
order by $orderfieldname ";
|
||||
print "<PRE>Query=$query </PRE>\n" if $debug;
|
||||
print "<PRE>Query=$query </PRE>\n" if $debug;
|
||||
$sth=$dbh->prepare($query);
|
||||
$sth->execute;
|
||||
while ( ($key, $desc) = $sth->fetchrow) {
|
||||
|
@ -772,7 +1074,7 @@ sub getkeytableselectoptions {
|
|||
$selectclause.=" selected";
|
||||
}
|
||||
$selectclause.=" value='$key'>$desc\n";
|
||||
print "<PRE>Sel=$selectclause </PRE>\n" if $debug;
|
||||
print "<PRE>Sel=$selectclause </PRE>\n" if $debug;
|
||||
}
|
||||
return $selectclause;
|
||||
} # sub getkeytableselectoptions
|
||||
|
|
Loading…
Reference in a new issue