Merge branch 'master' of https://github.com/jgoodman/Freeside
[freeside.git] / rt / share / html / Search / Elements / BuildFormatString
1 %# BEGIN BPS TAGGED BLOCK {{{
2 %#
3 %# COPYRIGHT:
4 %#
5 %# This software is Copyright (c) 1996-2014 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 <%ARGS>
49 $Format => RT->Config->Get('DefaultSearchResultFormat')
50
51 %queues => ()
52
53 $Face => undef
54 $Size => undef
55 $Link => undef
56 $Title => undef
57
58 $AddCol => undef
59 $RemoveCol => undef
60 $ColUp => undef
61 $ColDown => undef
62
63 $SelectDisplayColumns => undef
64 $CurrentDisplayColumns => undef
65 </%ARGS>
66 <%init>
67 # This can't be in a <once> block, because otherwise we return the
68 # same \@fields every request, and keep tacking more CustomFields onto
69 # it -- and it grows per request.
70
71 # All the things we can display in the format string by default
72 # referenced by their ColumnMap keys
73 my @fields = (
74   qw(
75     id QueueName Subject
76   ),
77     
78     $m->comp('/Elements/CustomerFields', 'Names'), #freeside
79     $m->comp('/Elements/ServiceFields', 'Names'), #freeside
80
81   qw(
82     Status ExtendedStatus UpdateStatus
83     Type
84
85     OwnerName Requestors Cc AdminCc CreatedBy LastUpdatedBy
86
87     Priority InitialPriority FinalPriority
88
89     TimeWorked TimeLeft TimeEstimated
90
91     Starts      StartsRelative
92     Started     StartedRelative
93     Created     CreatedRelative
94     LastUpdated LastUpdatedRelative
95     Told        ToldRelative
96     Due         DueRelative
97     WillResolve WillResolveRelative
98     Resolved    ResolvedRelative
99
100     RefersTo    ReferredToBy
101     DependsOn   DependedOnBy
102     MemberOf    Members
103     Parents     Children
104
105     Bookmark
106
107     NEWLINE
108     NBSP
109   )
110 ); # loc_qw
111
112 $m->callback( CallbackOnce => 1, CallbackName => 'SetFieldsOnce', Fields => \@fields );
113
114 my $CustomFields = RT::CustomFields->new( $session{'CurrentUser'});
115 foreach my $id (keys %queues) {
116     # Gotta load up the $queue object, since queues get stored by name now. my $id
117     my $queue = RT::Queue->new($session{'CurrentUser'});
118     $queue->Load($id);
119     $CustomFields->LimitToQueue($queue->Id) if $queue->Id;
120 }
121 $CustomFields->LimitToGlobal;
122
123 while ( my $CustomField = $CustomFields->Next ) {
124     push @fields, "CustomField.{" . $CustomField->Name . "}";
125 }
126
127 $m->callback( Fields => \@fields, ARGSRef => \%ARGS );
128
129 my ( @seen);
130
131 $Format ||= RT->Config->Get('DefaultSearchResultFormat');
132 my @format = $m->comp('/Elements/CollectionAsTable/ParseFormat', Format => $Format);
133 foreach my $field (@format) {
134     # "title" is for columns like NEWLINE, which doesn't have "attribute"
135     $field->{Column} = $field->{attribute} || $field->{title} || '<blank>';
136     push @seen, $field;
137 }
138
139 if ( $RemoveCol ) {
140     # we do this regex match to avoid a non-numeric warning
141     my ($index) = $CurrentDisplayColumns =~ /^(\d+)/;
142     my $column = $seen[$index];
143     if ( defined($index) ) {
144         delete $seen[$index];
145         my @temp = @seen;
146         @seen = ();
147         foreach my $element (@temp) {
148             next unless $element;
149             push @seen, $element;
150         }
151     }
152 }
153 elsif ( $AddCol ) {
154     if ( defined $SelectDisplayColumns ) {
155         my $selected = $SelectDisplayColumns;
156         my @columns;
157         if (ref($selected) eq 'ARRAY') {
158             @columns = @$selected;
159         } else {
160             push @columns, $selected;
161         }
162         foreach my $col (@columns) {
163             my %column = ();
164             $column{Column} = $col;
165
166             if ( $Face eq "Bold" ) {
167                 $column{Prefix} .= "<b>";
168                 $column{Suffix} .= "</b>";
169             }
170             if ( $Face eq "Italic" ) {
171                 $column{Prefix} .= "<i>";
172                 $column{Suffix} .= "</i>";
173             }
174             if ($Size) {
175                 $column{Prefix} .= "<" . $m->interp->apply_escapes( $Size,  'h' ) . ">";
176                 $column{Suffix} .= "</" . $m->interp->apply_escapes( $Size, 'h' ) . ">";
177             }
178             if ( $Link eq "Display" ) {
179                 $column{Prefix} .= q{<a HREF="__WebPath__/Ticket/Display.html?id=__id__">};
180                 $column{Suffix} .= "</a>";
181             }
182             elsif ( $Link eq "Take" ) {
183                 $column{Prefix} .= q{<a HREF="__WebPath__/Ticket/Display.html?Action=Take&id=__id__">};
184                 $column{Suffix} .= "</a>";
185             }
186             elsif ( $Link eq "Respond" ) {
187                 $column{Prefix} .= q{<a HREF="__WebPath__/Ticket/Update.html?Action=Respond&id=__id__">};
188                 $column{Suffix} .= "</a>";
189             }
190             elsif ( $Link eq "Comment" ) {
191                 $column{Prefix} .= q{<a HREF="__WebPath__/Ticket/Update.html?Action=Comment&id=__id__">};
192                 $column{Suffix} .= "</a>";
193             }
194             elsif ( $Link eq "Resolve" ) {
195                 $column{Prefix} .= q{<a HREF="__WebPath__/Ticket/Update.html?Action=Comment&DefaultStatus=resolved&id=__id__">};
196                 $column{Suffix} .= "</a>";
197             }
198
199             if ($Title) {
200                 $column{Suffix} .= "/TITLE:" . $m->interp->apply_escapes( $Title, 'h' );
201             }
202             push @seen, \%column;
203         }
204     }
205 }
206 elsif ( $ColUp ) {
207     my $index = $CurrentDisplayColumns;
208     if ( defined $index && ( $index - 1 ) >= 0 ) {
209         my $column = $seen[$index];
210         $seen[$index]       = $seen[ $index - 1 ];
211         $seen[ $index - 1 ] = $column;
212         $CurrentDisplayColumns     = $index - 1;
213     }
214 }
215 elsif ( $ColDown ) {
216     my $index = $CurrentDisplayColumns;
217     if ( defined $index && ( $index + 1 ) < scalar @seen ) {
218         my $column = $seen[$index];
219         $seen[$index]       = $seen[ $index + 1 ];
220         $seen[ $index + 1 ] = $column;
221         $CurrentDisplayColumns     = $index + 1;
222     }
223 }
224
225
226 my @format_string;
227 foreach my $field (@seen) {
228     next unless $field;
229     my $row = "";
230     if ( $field->{'output'} ) {
231         $row = join '', @{$field->{'output'}};
232     }
233     else {
234         $row .= $field->{'Prefix'} if defined $field->{'Prefix'};
235         $row .= "__$field->{'Column'}__"
236           unless ( $field->{'Column'} eq "<blank>" );
237         $row .= $field->{'Suffix'} if defined $field->{'Suffix'};
238     }
239     $row =~ s!([\\'])!\\$1!g;
240     $row = "'$row'";
241     push( @format_string, $row );
242 }
243
244 $Format = join(",\n", @format_string);
245
246
247 return($Format, \@fields, \@seen);
248
249 </%init>