File: TicketList

package info (click to toggle)
request-tracker4 4.4.3-2%2Bdeb10u2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 43,364 kB
  • sloc: perl: 61,929; javascript: 22,938; sh: 1,084; makefile: 467; php: 15
file content (128 lines) | stat: -rw-r--r-- 4,077 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
%# BEGIN BPS TAGGED BLOCK {{{
%#
%# COPYRIGHT:
%#
%# This software is Copyright (c) 1996-2018 Best Practical Solutions, LLC
%#                                          <sales@bestpractical.com>
%#
%# (Except where explicitly superseded by other copyright notices)
%#
%#
%# LICENSE:
%#
%# This work is made available to you under the terms of Version 2 of
%# the GNU General Public License. A copy of that license should have
%# been provided with this software, but in any event can be snarfed
%# from www.gnu.org.
%#
%# This work is distributed in the hope that it will be useful, but
%# WITHOUT ANY WARRANTY; without even the implied warranty of
%# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
%# General Public License for more details.
%#
%# You should have received a copy of the GNU General Public License
%# along with this program; if not, write to the Free Software
%# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
%# 02110-1301 or visit their web page on the internet at
%# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
%#
%#
%# CONTRIBUTION SUBMISSION POLICY:
%#
%# (The following paragraph is not intended to limit the rights granted
%# to you to modify and distribute this software under the terms of
%# the GNU General Public License and is only of importance to you if
%# you choose to contribute your changes and enhancements to the
%# community by submitting them to Best Practical Solutions, LLC.)
%#
%# By intentionally submitting any modifications, corrections or
%# derivatives to this work, or any other work intended for use with
%# Request Tracker, to Best Practical Solutions, LLC, you confirm that
%# you are the copyright holder for those contributions and you grant
%# Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
%# royalty-free, perpetual, license to use, copy, create derivative
%# works based on those contributions, and sublicense and distribute
%# those contributions and any derivatives thereof.
%#
%# END BPS TAGGED BLOCK }}}
% if ( $TitleBox ) {
    <& /Widgets/TitleBoxStart, title => $Title, title_raw => $title_raw, title_href => $url, class => $Class &>
% } else {
    <span class="label"><a href="<% $url %>"><% $Title %>:</a></span>
% }

<& /Elements/CollectionList,
    %QueryProperties,

    Class          => 'RT::Tickets',
    Page           => 1,
    AllowSorting   => 0,
    ShowNavigation => 0,
&>

% if ( $TitleBox ) {
    <& /Widgets/TitleBoxEnd &>
% }
<%INIT>

my $sql = '';

$sql = join(' OR ', map { "$_.id = ".$User->Id } @WatcherTypes );
$sql = "( $sql )";

$m->callback( CallbackName => 'ModifyWatcherSQL',
        %ARGS,
        sql => \$sql,
);

if (@$conditions) {
    $sql .= " AND (".join( " OR ", map $_->{cond}, @$conditions).")";
}

my %QueryProperties = (
    Query      => $sql,
    OrderBy    => 'Priority|id',
    Order      => 'DESC|DESC',
    Rows       => $Rows || 10,
    ShowHeader => $ShowHeader,
    Format     => $Format,
);

$m->callback( CallbackName => 'ModifyQueryProperties',
    %ARGS,
    QueryProperties => \%QueryProperties,
);

my $url  = RT->Config->Get('WebPath') . '/Search/Results.html?';
   $url .= $m->comp('/Elements/QueryString',
                    Query       => $QueryProperties{'Query'},
                    OrderBy     => $QueryProperties{'OrderBy'},
                    Order       => $QueryProperties{'Order'},
           );

my $title_raw;
if ($ShowCount) {
    my $tickets = RT::Tickets->new( $session{'CurrentUser'} );
    $tickets->FromSQL($QueryProperties{Query});
    my $count = $tickets->CountAll();

    $title_raw = '<span class="results-count">' . loc('(Found [quant,_1,ticket,tickets])', $count) . '</span>';

    # don't repeat the search in CollectionList
    $QueryProperties{Collection} = $tickets;
    $QueryProperties{TotalFound} = $count;
}
</%INIT>
<%ARGS>
$Title => ''
$Class => ''
@WatcherTypes => (qw(Watcher))
$User => undef
$conditions
$Rows => 10
$Description => ''
$TitleBox => 0
$Format => ''
$ShowHeader => 0
$ShowCount => RT->Config->Get('ShowSearchResultCount')
</%ARGS>