diff options
author | Mark Wells <mark@freeside.biz> | 2015-11-25 15:08:05 -0800 |
---|---|---|
committer | Mark Wells <mark@freeside.biz> | 2015-11-25 15:08:39 -0800 |
commit | ddebcd39ef2ec217e1c3a3070893c511568ef16d (patch) | |
tree | fa479f7c4a203cb11fe30fb8f62ceb42d62fd587 /rt/share/html/Elements | |
parent | a111293b6aa333fdfe727df17eaf4a66ba9c6672 (diff) |
add service location to RT ticket search, #19154
Diffstat (limited to 'rt/share/html/Elements')
-rw-r--r-- | rt/share/html/Elements/ServiceFields | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/rt/share/html/Elements/ServiceFields b/rt/share/html/Elements/ServiceFields index 9c9a248c8..70eea232f 100644 --- a/rt/share/html/Elements/ServiceFields +++ b/rt/share/html/Elements/ServiceFields @@ -43,6 +43,11 @@ my @service_fields = ( # ordered OrderBy => 'Service.svcpart', }, { + Name => 'ServiceLocation', + Label => 'Service Location', + Display => svc_location_attribute('location'), + }, + { Name => 'ServiceKey', # loosely corresponds to smartsearch/label field Label => '', # not displayable @@ -118,6 +123,37 @@ sub svc_info_attribute { }; } +sub svc_location_attribute { + # Tricky: if the ticket is linked to a service, we want to return the + # service's location, but if it's not, we want to return the customer's + # default service location. + # If it's linked to Customer A and also to Service A, it should return + # Service A's location (and not Customer A's default service location). + # But if it's linked to Service A and also to Customer B, then what? We + # can't satisfy all the constraints here. + my $attribute = shift; + sub { + my @return; + my $Ticket = shift; + my @svc_resolvers = ticket_svc_resolvers($Ticket); + if (@svc_resolvers) { + warn '#' . $Ticket->id . ", service attribute $attribute\n"; + foreach my $s (@svc_resolvers) { + push @return, $s->ServiceInfo->{$attribute}, '<BR>'; + } + } else { + warn '#' . $Ticket->id . ", customer attribute ship_$attribute\n"; + my @cust_resolvers = map $_->TargetURI->Resolver, + @{ $Ticket->Customers->ItemsArrayRef }; + foreach my $c (@cust_resolvers) { + push @return, $c->CustomerInfo->{"ship_$attribute"}, '<BR>'; + } + } + pop @return; #trailing <BR> + @return; + }; +} + </%once> <%init> use Data::Dumper; |