1 %# BEGIN BPS TAGGED BLOCK {{{
5 %# This software is Copyright (c) 1996-2012 Best Practical Solutions, LLC
6 %# <sales@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 }}}
49 % foreach ($tickets, $group_tickets) {
50 % while (my $ticket = $_->Next() ) {
51 % next if !$ARGS{'ShowDependent'} and $ticket->HasUnresolvedDependencies( Type => 'approval' );
52 % next if $done{$ticket->Id}++; # don't show duplicate tickets
53 <& Approve, ticket => $ticket &>
57 <&| /Widgets/TitleBox, title => loc("Search for approvals") &>
58 <input type="checkbox" class="checkbox" value="1" name="ShowPending"
59 <%((!$ARGS{'ShowRejected'} && !$ARGS{'ShowResolved'}) ||
61 && qq[checked="checked"] |n%> /> <&|/l&>Show pending requests</&><br />
62 <input type="checkbox" class="checkbox" value="1" name="ShowResolved" <% defined($ARGS{'ShowResolved'}) && $ARGS{'ShowResolved'} && qq[checked="checked"] |n%> /> <&|/l&>Show approved requests</&><br />
63 <input type="checkbox" class="checkbox" value="1" name="ShowRejected" <% defined($ARGS{'ShowRejected'}) && $ARGS{'ShowRejected'} && qq[checked="checked"] |n%> /> <&|/l&>Show denied requests</&><br />
64 <input type="checkbox" class="checkbox" value="1" name="ShowDependent" <% defined($ARGS{'ShowDependent'}) && $ARGS{'ShowDependent'} && qq[checked="checked"] |n%> /> <&|/l&>Show requests awaiting other approvals</&><br />
66 <&|/l_unsafe, qq{<input size='15' class="ui-datepicker" value='}.($created_before->Unix > 0 &&$created_before->ISO(Timezone => 'user'))."' name='CreatedBefore' id='CreatedBefore' />"&>Only show approvals for requests created before [_1]</&><br />
68 <&|/l_unsafe, qq{<input size='15' class="ui-datepicker" value='}.( $created_after->Unix >0 && $created_after->ISO(Timezone => 'user'))."' name='CreatedAfter' id='CreatedAfter' />"&>Only show approvals for requests created after [_1]</&>
72 my $tickets = RT::Tickets->new( $session{'CurrentUser'} );
73 $tickets->LimitOwner( VALUE => $session{'CurrentUser'}->Id );
75 # also consider AdminCcs as potential approvers.
76 my $group_tickets = RT::Tickets->new( $session{'CurrentUser'} );
77 $group_tickets->LimitWatcher( VALUE => $session{'CurrentUser'}->UserObj->EmailAddress, TYPE => 'AdminCc' );
79 my $created_before = RT::Date->new( $session{'CurrentUser'} );
80 my $created_after = RT::Date->new( $session{'CurrentUser'} );
82 foreach ($tickets, $group_tickets) {
83 $_->Limit( FIELD => 'Type', VALUE => 'approval' );
85 if ( $ARGS{'ShowResolved'} ) {
86 $_->LimitStatus( VALUE => 'resolved' );
88 if ( $ARGS{'ShowRejected'} ) {
89 $_->LimitStatus( VALUE => 'rejected' );
91 if ( $ARGS{'ShowPending'} || ( !$ARGS{'ShowRejected'} && !$ARGS{'Resolved'} ) ) {
92 $_->LimitStatus( VALUE => 'open' );
93 $_->LimitStatus( VALUE => 'new' );
94 $_->LimitStatus( VALUE => 'stalled' );
97 if ( $ARGS{'CreatedBefore'} ) {
98 $created_before->Set( Format => 'unknown', Value => $ARGS{'CreatedBefore'} );
99 $_->LimitCreated( OPERATOR => "<=", VALUE => $created_before->ISO );
101 if ( $ARGS{'CreatedAfter'} ) {
102 $created_after->Set( Format => 'unknown', Value => $ARGS{'CreatedAfter'} );
103 $_->LimitCreated( OPERATOR => ">=", VALUE => $created_after->ISO );
105 $_->OrderBy( FIELD => 'id' );