1 %# BEGIN BPS TAGGED BLOCK {{{
5 %# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC
6 %# <jesse@bestpractical.com>
8 %# (Except where explicitly superseded by other copyright notices)
13 %# This work is made available to you under the terms of Version 2 of
14 %# the GNU General Public License. A copy of that license should have
15 %# been provided with this software, but in any event can be snarfed
18 %# This work is distributed in the hope that it will be useful, but
19 %# WITHOUT ANY WARRANTY; without even the implied warranty of
20 %# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 %# General Public License for more details.
23 %# You should have received a copy of the GNU General Public License
24 %# along with this program; if not, write to the Free Software
25 %# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26 %# 02110-1301 or visit their web page on the internet at
27 %# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
30 %# CONTRIBUTION SUBMISSION POLICY:
32 %# (The following paragraph is not intended to limit the rights granted
33 %# to you to modify and distribute this software under the terms of
34 %# the GNU General Public License and is only of importance to you if
35 %# you choose to contribute your changes and enhancements to the
36 %# community by submitting them to Best Practical Solutions, LLC.)
38 %# By intentionally submitting any modifications, corrections or
39 %# derivatives to this work, or any other work intended for use with
40 %# Request Tracker, to Best Practical Solutions, LLC, you confirm that
41 %# you are the copyright holder for those contributions and you grant
42 %# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
43 %# royalty-free, perpetual, license to use, copy, create derivative
44 %# works based on those contributions, and sublicense and distribute
45 %# those contributions and any derivatives thereof.
47 %# END BPS TAGGED BLOCK }}}
48 <table border="0" cellspacing="0" cellpadding="1" width="100%">
51 <& /Elements/CollectionAsTable/Header,
53 FormatString => $Format,
54 AllowSorting => $AllowSorting,
61 maxitems => $maxitems &>
65 % while (my $record = $Collection->Next) {
67 % # Every ten rows, flush the buffer and put something on the page.
68 % # hun, this flushes things out out-of-order for me on "RT at a glance"...?
69 % # $m->flush_buffer() unless ($i % 10);
70 <& /Elements/CollectionAsTable/Row, Format => \@Format, i => $i, record => $record, maxitems => $maxitems &>
75 % if ($Rows && $ShowNavigation) {
78 % if (($TotalFound % $Rows) == 0) {
80 % } else { $oddRows = 1; }
81 % my $pages = int($TotalFound/$Rows)+$oddRows;
82 % $pages = 1 if $pages < 1;
83 <&|/l, $Page, $pages &>Page [_1] of [_2]</&>
87 '/Elements/QueryString',
96 '/Elements/QueryString',
102 Page => ( $Page + 1 )
106 <a href="<%$BaseURL%><%$prev%>"><&|/l&>Previous Page</&></a>
108 % if (($Page * $Rows) < $TotalFound) {
109 <a href="<%$BaseURL%><%$next%>"><&|/l&>Next Page</&></a>
115 $Format ||= $RT::DefaultSearchResultFormat;
117 # DisplayFormat lets us use a "temporary" format for display, while
118 # still using our original format for next/prev page links.
119 # bulk update uses this feature to add checkboxes
122 $DisplayFormat ||= $Format;
124 # Scrub the html of the format string to remove any potential nasties.
125 $Format = $m->comp('/Elements/ScrubHTML', Content => $Format);
126 $DisplayFormat = $m->comp('/Elements/ScrubHTML', Content => $DisplayFormat);
129 unless ($Collection) {
130 $Collection = RT::Tickets->new($session{'CurrentUser'});
131 $Collection->FromSQL($Query);
134 my (@Format) = $m->comp('/Elements/CollectionAsTable/ParseFormat', Format => $DisplayFormat);
136 # Find the maximum number of items in any row, so we can pad the table.
138 foreach my $col (@Format) {
140 if ( $col->{title} && ($col->{title} eq 'NEWLINE') ) {
144 $maxitems = $item if $item > $maxitems;
148 if ($OrderBy =~ /\|/) {
150 my @OrderBy = split /\|/,$OrderBy;
151 my @Order = split /\|/,$Order;
152 $Collection->OrderByCols(
153 map { { FIELD => $OrderBy[$_], ORDER => $Order[$_] } } ( 0
156 $Collection->OrderBy(FIELD => $OrderBy, ORDER => $Order);
159 $Collection->RowsPerPage($Rows) if ($Rows);
160 $Page = 1 unless $Page > 0; # workaround problems with Page = '' or undef
161 $Collection->GotoPage( $Page - 1 ); # SB uses page 0 as the first page
162 my $TotalFound = $Collection->CountAll();
169 $Title => 'Ticket Search'
171 $AllowSorting => undef
175 $Format => $RT::DefaultSearchResultFormat
176 $DisplayFormat => undef