X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FTicket%2FModify.html;h=fef7acc8c3221b599dbadc475eecb4c05f9e4ec1;hp=8884c19ee7e24d5e86f9fae9eb3fd224b2f47cbf;hb=de9d037528895f7151a9aead6724ce2df95f9586;hpb=45d35d5739d05e602bc317739485693e0e9ff0b5 diff --git a/rt/share/html/Ticket/Modify.html b/rt/share/html/Ticket/Modify.html index 8884c19ee..fef7acc8c 100755 --- a/rt/share/html/Ticket/Modify.html +++ b/rt/share/html/Ticket/Modify.html @@ -2,7 +2,7 @@ %# %# COPYRIGHT: %# -%# This software is Copyright (c) 1996-2014 Best Practical Solutions, LLC +%# This software is Copyright (c) 1996-2017 Best Practical Solutions, LLC %# %# %# (Except where explicitly superseded by other copyright notices) @@ -56,36 +56,61 @@ <&| /Widgets/TitleBox, title => loc('Modify ticket #[_1]',$TicketObj->Id), class=>'ticket-info-basics' &> -<& Elements/EditBasics, TicketObj => $TicketObj &> -<& Elements/EditCustomFields, TicketObj => $TicketObj, DefaultsFromTopArguments => 0 &> + +<& Elements/EditBasics, TicketObj => $TicketObj, defaults => \%ARGS, InTable => 1 &> +<& /Elements/EditCustomFields, Object => $TicketObj, Grouping => 'Basics', InTable => 1, DefaultsFromTopArguments => 0 &> +
% $m->callback( CallbackName => 'AfterBasics', Ticket => $TicketObj ); +<& /Elements/EditCustomFieldCustomGroupings, Object => $TicketObj, AsTable => !!RT->Config->Get('EditCustomFieldsSingleColumn', $session{'CurrentUser'}) &> + <& /Elements/Submit, Name => 'SubmitTicket', Label => loc('Save Changes'), Caption => loc("If you've updated anything above, be sure to"), color => "#993333" &> + +% $m->callback(CallbackName => 'AfterForm', ARGSRef => \%ARGS, Ticket => $TicketObj); <%INIT> - + my $TicketObj = LoadTicket($id); my $CustomFields = $TicketObj->CustomFields; -# call this to show up hints of valid cf values. -$m->comp( - '/Elements/ValidateCustomFields', - CustomFields => $CustomFields, - ARGSRef => {}, -); +my @results; +my $skip_update = 0; # Now let callbacks have a chance at editing %ARGS -$m->callback( TicketObj => $TicketObj, CustomFields => $CustomFields, ARGSRef => \%ARGS ); +$m->callback( TicketObj => $TicketObj, CustomFields => $CustomFields, ARGSRef => \%ARGS, skip_update => \$skip_update, results => \@results ); -my @results; -push @results, ProcessTicketBasics(TicketObj => $TicketObj, ARGSRef => \%ARGS); -push @results, ProcessObjectCustomFieldUpdates(Object => $TicketObj, ARGSRef => \%ARGS); push @results, ProcessTicketStatus(TicketObj => $TicketObj, ARGSRef => \%ARGS); # for WillResolve push @results, ProcessTicketDates( TicketObj => $TicketObj, ARGSRef => \%ARGS); -$TicketObj->ApplyTransactionBatch; +{ + my ($status, @msg) = $m->comp( + '/Elements/ValidateCustomFields', + Object => $TicketObj, + CustomFields => $CustomFields, + ARGSRef => \%ARGS, + ); + unless ($status) { + push @results, @msg; + $skip_update = 1; + } +} + +unless ($skip_update) { + push @results, ProcessTicketBasics(TicketObj => $TicketObj, ARGSRef => \%ARGS); + push @results, ProcessObjectCustomFieldUpdates(Object => $TicketObj, ARGSRef => \%ARGS); + $m->callback( CallbackName => 'ProcessUpdates', TicketObj => $TicketObj, + ARGSRef => \%ARGS, Results => \@results ); + + $TicketObj->ApplyTransactionBatch; + + MaybeRedirectForResults( + Actions => \@results, + Path => "/Ticket/Modify.html", + Arguments => { id => $TicketObj->id }, + ); +} unless ($TicketObj->CurrentUserHasRight('ShowTicket')) { if (@results) {