5 #package to deal with marking up output
6 #You will need to edit parts of this pm
7 #set the value of path to be where your html lives
10 # Copyright 2000-2002 Katipo Communications
12 # This file is part of Koha.
14 # Koha is free software; you can redistribute it and/or modify it under the
15 # terms of the GNU General Public License as published by the Free Software
16 # Foundation; either version 2 of the License, or (at your option) any later
19 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
20 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
21 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
23 # You should have received a copy of the GNU General Public License along with
24 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
25 # Suite 330, Boston, MA 02111-1307 USA
27 # NOTE: I'm pretty sure this module is deprecated in favor of
37 use vars qw($VERSION @ISA @EXPORT);
39 # set the version for version checking
44 C4::Output - Functions for managing templates
54 &themelanguage &gettemplate setlanguagecookie pagination_bar
57 #FIXME: this is a quick fix to stop rc1 installing broken
58 #Still trying to figure out the correct fix.
59 my $path = C4::Context->config('intrahtdocs')."/default/en/includes/";
61 #---------------------------------------------------------------------------------------------------------
64 my ($tmplbase, $opac, $query) = @_;
66 warn "no query in gettemplate";
69 if ($opac ne "intranet") {
70 $htdocs = C4::Context->config('opachtdocs');
72 $htdocs = C4::Context->config('intrahtdocs');
75 my ($theme, $lang) = themelanguage($htdocs, $tmplbase, $opac, $query);
76 my $opacstylesheet = C4::Context->preference('opacstylesheet');
77 my $template = HTML::Template->new(filename => "$htdocs/$theme/$lang/$tmplbase",
78 die_on_bad_params => 0,
80 path => ["$htdocs/$theme/$lang/includes"]);
82 $template->param(themelang => ($opac ne 'intranet'? '/opac-tmpl': '/intranet-tmpl') . "/$theme/$lang",
83 interface => ($opac ne 'intranet'? '/opac-tmpl': '/intranet-tmpl'),
85 opacstylesheet => $opacstylesheet,
86 opaccolorstylesheet => C4::Context->preference('opaccolorstylesheet'),
87 opacsmallimage => C4::Context->preference('opacsmallimage'),
94 #---------------------------------------------------------------------------------------------------------
97 my ($htdocs, $tmpl, $section, $query) = @_;
101 my $dbh = C4::Context->dbh;
104 if ( $section eq "intranet")
106 @languages = split " ", C4::Context->preference("opaclanguages");
107 @themes = split " ", C4::Context->preference("template");
111 # we are in the opac here, what im trying to do is let the individual user
112 # set the theme they want to use.
113 # and perhaps the them as well.
114 my $lang=$query->cookie('KohaOpacLanguage');
117 push @languages,$lang;
118 @themes = split " ", C4::Context->preference("opacthemes");
121 @languages = split " ", C4::Context->preference("opaclanguages");
122 @themes = split " ", C4::Context->preference("opacthemes");
127 # searches through the themes and languages. First template it find it returns.
128 # Priority is for getting the theme right.
130 foreach my $th (@themes) {
131 foreach my $la (@languages) {
132 for (my $pass = 1; $pass <= 2; $pass += 1) {
133 $la =~ s/([-_])/ $1 eq '-'? '_': '-' /eg if $pass == 2;
134 if (-e "$htdocs/$th/$la/$tmpl") {
139 last unless $la =~ /[-_]/;
143 if ($theme and $lang) {
144 return ($theme, $lang);
146 return ('default', 'en');
151 sub setlanguagecookie {
152 my ($query,$language,$uri)=@_;
153 my $cookie=$query->cookie(-name => 'KohaOpacLanguage',
156 print $query->redirect(-uri=>$uri,
162 pagination_bar($base_url, $nb_pages, $current_page, $startfrom_name)
164 Build an HTML pagination bar based on the number of page to display, the
165 current page and the url to give to each page link.
167 C<$base_url> is the URL for each page link. The
168 C<$startfrom_name>=page_number is added at the end of the each URL.
170 C<$nb_pages> is the total number of pages available.
172 C<$current_page> is the current page number. This page number won't become a
175 This function returns HTML, without any language dependency.
180 my ($base_url, $nb_pages, $current_page, $startfrom_name) = @_;
182 # how many pages to show before and after the current page?
183 my $pages_around = 2;
187 .($base_url =~ m/&/ ? '&' : '?')
191 my $pagination_bar = '';
193 # current page detection
194 if (not defined $current_page) {
198 # navigation bar useful only if more than one page to display !
200 # link to first page?
201 if ($current_page > 1) {
204 .'<a href="'.$url.'1" rel="start">'
211 "\n".' <span class="inactive"><<</span>';
214 # link on previous page ?
215 if ($current_page > 1) {
216 my $previous = $current_page - 1;
229 "\n".' <span class="inactive"><</span>';
232 my $min_to_display = $current_page - $pages_around;
233 my $max_to_display = $current_page + $pages_around;
234 my $last_displayed_page = undef;
236 for my $page_number (1..$nb_pages) {
237 if ($page_number == 1
238 or $page_number == $nb_pages
239 or ($page_number >= $min_to_display and $page_number <= $max_to_display)
241 if (defined $last_displayed_page
242 and $last_displayed_page != $page_number - 1
245 "\n".' <span class="inactive">...</span>'
249 if ($page_number == $current_page) {
252 .'<span class="currentPage">'.$page_number.'</span>'
258 .'<a href="'.$url.$page_number.'">'.$page_number.'</a>'
261 $last_displayed_page = $page_number;
266 if ($current_page < $nb_pages) {
267 my $next = $current_page + 1;
270 "\n".' <a href="'.$url.$next.'" rel="next">'
277 "\n".' <span class="inactive">></span>'
282 if ($current_page != $nb_pages) {
284 "\n".' <a href="'.$url.$nb_pages.'" rel="last">'
291 "\n".' <span class="inactive">>></span>';
295 return $pagination_bar;
299 END { } # module clean-up code here (global destructor)
308 Koha Developement team <info@koha.org>