]>
Commit | Line | Data |
---|---|---|
84fb5b46 MKG |
1 | %# BEGIN BPS TAGGED BLOCK {{{ |
2 | %# | |
3 | %# COPYRIGHT: | |
4 | %# | |
5 | %# This software is Copyright (c) 1996-2012 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 $name = $queue->{Name}; | |
62 | $name =~ s/(['\\])/\\$1/g; | |
63 | my $queue_cond = "Queue = '$name' AND "; | |
64 | my $lifecycle = $lifecycle{ lc $queue->{'Lifecycle'} }; | |
65 | my $all_q = $queue_cond . '(' . join( " OR ", map "Status = '$_'", grep $lifecycle->IsValid($_), @statuses ) . ')'; | |
66 | </%PERL> | |
67 | <tr class="<% $i%2 ? 'oddline' : 'evenline'%>" > | |
68 | ||
69 | <td> | |
70 | <a href="<% RT->Config->Get('WebPath') %>/Search/Results.html?Query=<% $all_q |u,n %>" title="<% $queue->{Description} %>"><% $queue->{Name} %></a> | |
71 | </td> | |
72 | ||
73 | <%perl> | |
74 | for my $status (@statuses) { | |
75 | if ( $lifecycle->IsValid( $status ) ) { | |
76 | </%perl> | |
77 | <td align="right"> | |
78 | <a href="<% RT->Config->Get('WebPath') %>/Search/Results.html?Query=<% $queue_cond ."Status = '$status'" |u,n %>"><% $data->{$queue->{id}}->{$status } || '-' %></a> | |
79 | </td> | |
80 | % } else { | |
81 | <td align="right">-</td> | |
82 | % } | |
83 | % } | |
84 | </tr> | |
85 | % } | |
86 | </table> | |
87 | <%INIT> | |
88 | ||
89 | my $Queues = RT::Queues->new( $session{'CurrentUser'} ); | |
90 | $Queues->UnLimit(); | |
91 | $m->callback( CallbackName => 'SQLFilter', Queues => $Queues ); | |
92 | ||
93 | my @queues = grep $queue_filter->($_), @{ $Queues->ItemsArrayRef }; | |
94 | $m->callback( CallbackName => 'Filter', Queues => \@queues ); | |
95 | ||
96 | @queues = map { | |
97 | { id => $_->Id, | |
98 | Name => $_->Name, | |
99 | Description => $_->Description || '', | |
100 | Lifecycle => $_->Lifecycle->Name, | |
101 | } | |
102 | } grep $_, @queues; | |
103 | ||
104 | my %lifecycle; | |
105 | ||
106 | for my $queue (@queues) { | |
107 | my $cycle = RT::Lifecycle->Load( $queue->{'Lifecycle'} ); | |
108 | $lifecycle{ lc $cycle->Name } = $cycle; | |
109 | } | |
110 | ||
111 | unless (@statuses) { | |
112 | my %seen; | |
113 | foreach my $set ( 'initial', 'active' ) { | |
114 | foreach my $lifecycle ( map $lifecycle{$_}, sort keys %lifecycle ) { | |
115 | push @statuses, grep !$seen{ lc $_ }++, $lifecycle->Valid($set); | |
116 | } | |
117 | } | |
118 | } | |
119 | ||
120 | my $data = {}; | |
121 | my $statuses = {}; | |
122 | ||
123 | use RT::Report::Tickets; | |
124 | my $report = RT::Report::Tickets->new( RT->SystemUser ); | |
125 | my $query = @queues | |
126 | ? join(' OR ', map "Queue = ".$_->{id}, @queues) | |
127 | : 'id < 0'; | |
128 | $report->SetupGroupings( Query => $query, GroupBy => [qw(Status Queue)] ); | |
129 | ||
130 | while ( my $entry = $report->Next ) { | |
131 | $data->{ $entry->__Value("Queue") }->{ $entry->__Value("Status") } | |
132 | = $entry->__Value('id'); | |
133 | $statuses->{ $entry->__Value("Status") } = 1; | |
134 | } | |
135 | </%INIT> | |
136 | <%ARGS> | |
137 | $queue_filter => undef | |
138 | @statuses => () | |
139 | </%ARGS> |