]>
Commit | Line | Data |
---|---|---|
1 | %# BEGIN BPS TAGGED BLOCK {{{ | |
2 | %# | |
3 | %# COPYRIGHT: | |
4 | %# | |
5 | %# This software is Copyright (c) 1996-2013 Best Practical Solutions, LLC | |
6 | %# <sales@bestpractical.com> | |
7 | %# | |
8 | %# (Except where explicitly superseded by other copyright notices) | |
9 | %# | |
10 | %# | |
11 | %# LICENSE: | |
12 | %# | |
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 | |
16 | %# from www.gnu.org. | |
17 | %# | |
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. | |
22 | %# | |
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. | |
28 | %# | |
29 | %# | |
30 | %# CONTRIBUTION SUBMISSION POLICY: | |
31 | %# | |
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.) | |
37 | %# | |
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. | |
46 | %# | |
47 | %# END BPS TAGGED BLOCK }}} | |
48 | <table border="0" cellspacing="0" cellpadding="1" width="100%" class="queue-summary"> | |
49 | ||
50 | <tr> | |
51 | <th class="collection-as-table"><&|/l&>Queue</&></th> | |
52 | % for my $status ( @statuses ) { | |
53 | <th class="collection-as-table"><% loc($status) %></th> | |
54 | % } | |
55 | </tr> | |
56 | ||
57 | <%PERL> | |
58 | my $i = 0; | |
59 | for my $queue (@queues) { | |
60 | $i++; | |
61 | my $lifecycle = $lifecycle{ lc $queue->{'Lifecycle'} }; | |
62 | my @queue_statuses = grep { $lifecycle->IsValid($_) } @statuses; | |
63 | </%PERL> | |
64 | <tr class="<% $i%2 ? 'oddline' : 'evenline'%>" > | |
65 | ||
66 | <td> | |
67 | <a href="<% $link_all->($queue, \@queue_statuses) %>" title="<% $queue->{Description} %>"><% $queue->{Name} %></a> | |
68 | </td> | |
69 | ||
70 | <%perl> | |
71 | for my $status (@statuses) { | |
72 | if ( $lifecycle->IsValid( $status ) ) { | |
73 | </%perl> | |
74 | <td align="right"> | |
75 | <a href="<% $link_status->($queue, $status) %>"><% $data->{$queue->{id}}->{$status } || '-' %></a> | |
76 | </td> | |
77 | % } else { | |
78 | <td align="right">-</td> | |
79 | % } | |
80 | % } | |
81 | </tr> | |
82 | % } | |
83 | </table> | |
84 | <%INIT> | |
85 | my $build_search_link = sub { | |
86 | my ($queue_name, $extra_query) = @_; | |
87 | $queue_name =~ s/(['\\])/\\$1/g; #' | |
88 | ||
89 | return RT->Config->Get('WebPath') | |
90 | . "/Search/Results.html?Query=" | |
91 | . $m->interp->apply_escapes("Queue = '$queue_name' AND $extra_query", 'u'); | |
92 | }; | |
93 | ||
94 | my $link_all = sub { | |
95 | my ($queue, $all_statuses) = @_; | |
96 | return $build_search_link->($queue->{Name}, "(".join(" OR ", map "Status = '$_'", @$all_statuses).")"); | |
97 | }; | |
98 | ||
99 | my $link_status = sub { | |
100 | my ($queue, $status) = @_; | |
101 | return $build_search_link->($queue->{Name}, "Status = '$status'"); | |
102 | }; | |
103 | ||
104 | $m->callback( | |
105 | CallbackName => 'LinkBuilders', | |
106 | build_search_link => \$build_search_link, | |
107 | link_all => \$link_all, | |
108 | link_status => \$link_status, | |
109 | ); | |
110 | ||
111 | my $Queues = RT::Queues->new( $session{'CurrentUser'} ); | |
112 | $Queues->UnLimit(); | |
113 | $m->callback( CallbackName => 'SQLFilter', Queues => $Queues ); | |
114 | ||
115 | my @queues = grep $queue_filter->($_), @{ $Queues->ItemsArrayRef }; | |
116 | $m->callback( CallbackName => 'Filter', Queues => \@queues ); | |
117 | ||
118 | @queues = map { | |
119 | { id => $_->Id, | |
120 | Name => $_->Name, | |
121 | Description => $_->Description || '', | |
122 | Lifecycle => $_->Lifecycle->Name, | |
123 | } | |
124 | } grep $_, @queues; | |
125 | ||
126 | my %lifecycle; | |
127 | ||
128 | for my $queue (@queues) { | |
129 | my $cycle = RT::Lifecycle->Load( $queue->{'Lifecycle'} ); | |
130 | $lifecycle{ lc $cycle->Name } = $cycle; | |
131 | } | |
132 | ||
133 | unless (@statuses) { | |
134 | my %seen; | |
135 | foreach my $set ( 'initial', 'active' ) { | |
136 | foreach my $lifecycle ( map $lifecycle{$_}, sort keys %lifecycle ) { | |
137 | push @statuses, grep !$seen{ lc $_ }++, $lifecycle->Valid($set); | |
138 | } | |
139 | } | |
140 | } | |
141 | ||
142 | my $data = {}; | |
143 | my $statuses = {}; | |
144 | ||
145 | use RT::Report::Tickets; | |
146 | my $report = RT::Report::Tickets->new( RT->SystemUser ); | |
147 | my $query = | |
148 | "(". | |
149 | join(" OR ", map {s{(['\\])}{\\$1}g; "Status = '$_'"} @statuses) #' | |
150 | .") AND (". | |
151 | join(' OR ', map "Queue = ".$_->{id}, @queues) | |
152 | .")"; | |
153 | $query = 'id < 0' unless @queues; | |
154 | $report->SetupGroupings( Query => $query, GroupBy => [qw(Status Queue)] ); | |
155 | ||
156 | while ( my $entry = $report->Next ) { | |
157 | $data->{ $entry->__Value("Queue") }->{ $entry->__Value("Status") } | |
158 | = $entry->__Value('id'); | |
159 | $statuses->{ $entry->__Value("Status") } = 1; | |
160 | } | |
161 | </%INIT> | |
162 | <%ARGS> | |
163 | $queue_filter => undef | |
164 | @statuses => () | |
165 | </%ARGS> |