X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FDashboards%2FModify.html;h=8c41d4bab9b25885d87408503ac1a57bb344e185;hb=44dd00a3ff974a17999e86e64488e996edc71e3c;hp=11fc1791a1503a8938901643017367a9386df4a5;hpb=fc6209f398899f0211cfcedeb81a3cd65e04a941;p=freeside.git diff --git a/rt/share/html/Dashboards/Modify.html b/rt/share/html/Dashboards/Modify.html index 11fc1791a..8c41d4bab 100755 --- a/rt/share/html/Dashboards/Modify.html +++ b/rt/share/html/Dashboards/Modify.html @@ -2,7 +2,7 @@ %# %# COPYRIGHT: %# -%# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +%# This software is Copyright (c) 1996-2019 Best Practical Solutions, LLC %# %# %# (Except where explicitly superseded by other copyright notices) @@ -46,59 +46,55 @@ %# %# END BPS TAGGED BLOCK }}} <& /Elements/Header, Title => $title &> -<& /Dashboards/Elements/Tabs, - current_subtab => $current_subtab, - Title => $title, - $Create ? () : (DashboardObj => $Dashboard), -&> +<& /Elements/Tabs &> <& /Elements/ListActions, actions => \@results &> -
+ %unless ($Dashboard->Id) { % } else { % } + +<&|/Widgets/TitleBox, title => loc('Basics') &> - - + + + + + + + -
-<&|/l&>Name: -
<&|/l&>Name:
<&|/l&>Privacy:<& /Dashboards/Elements/SelectPrivacy, Name => "Privacy", Objects => \@privacies, Default => $Dashboard->Privacy &>
-<&|/l&>Privacy: - -<& /Dashboards/Elements/SelectPrivacy, Name => "Privacy", Objects => \@privacies, Default => $Dashboard->Privacy &> -
-% if ( $Create ) { -<& /Elements/Submit, Name => 'Save', Label => loc('Create') &> -% } else { -<& /Elements/Submit, Name => 'Save', Label => loc('Save Changes') &> -% } + +<& /Elements/Submit, Name => 'Save', Label =>( $Create ? loc('Create') : loc('Save Changes') ) &> + % if ($Dashboard->Id && $can_delete) { <& /Elements/Submit, Name => 'Delete', Label => loc('Delete') &> % }
<%INIT> -my $current_subtab; my ($title, @results); my $tried_create = 0; # user went directly to Modify.html $Create = 1 if !$id; + +my $redirect_to ='/Dashboards/Modify.html'; + use RT::Dashboard; my $Dashboard = RT::Dashboard->new($session{'CurrentUser'}); -my @privacies = $Dashboard->_PrivacyObjects(($Create ? 'Create' : 'Modify') => 1); +my $method = $Create ? 'ObjectsForCreating' : 'ObjectsForModifying'; +my @privacies = $Dashboard->$method; -Abort(loc("Permission denied")) if @privacies == 0; +Abort(loc("Permission Denied")) if @privacies == 0; if ($Create) { - $current_subtab = 'Dashboards/Modify.html?Create=1'; $title = loc("Create a new dashboard"); } else { @@ -116,20 +112,22 @@ else { push @results, $msg; $id = $Dashboard->Id; + if (!$Dashboard->id || ! $Dashboard->CurrentUserCanSee) { + $redirect_to='/Dashboards/index.html'; + + } } else { my ($ok, $msg) = $Dashboard->LoadById($id); - $ok || Abort($msg); + $ok || Abort(loc("Couldn't load dashboard [_1]: [_2]", $id, $msg)); } if ($id) { $title = loc("Modify the dashboard [_1]", $Dashboard->Name); - $current_subtab = 'Dashboards/Modify.html?id=' . $id; - } + } # If the create failed else { $Create = 1; - $current_subtab = 'Dashboards/Modify.html?Create=1'; $title = loc("Create a new dashboard"); } } @@ -139,24 +137,34 @@ if (!$Create && !$tried_create && $id && $ARGS{'Save'}) { Name => $ARGS{'Name'}); if ($ok) { - push @results, loc("Dashboard updated"); + push @results, loc("Dashboard [_1] updated", $Dashboard->Name); } else { - push @results, loc("Dashboard could not be updated: [_1]", $msg); + push @results, loc("Dashboard [_1] could not be updated: [_2]", $Dashboard->Name, $msg); } } + my $can_delete = $Dashboard->CurrentUserCanDelete; if (!$Create && !$tried_create && $id && $ARGS{'Delete'}) { my ($ok, $msg) = $Dashboard->Delete(); - $ok || Abort(loc("Couldn't delete dashboard [_1]: [_2]", $id, $msg)); - - # put the user back into a useful place with a message - RT::Interface::Web::Redirect(RT->Config->Get('WebURL')."Dashboards/index.html?Deleted=$id"); + if (!$ok) { + Abort(loc("Couldn't delete dashboard [_1]: [_2]", $id, $msg)); + } + push @results, $msg; + $redirect_to = '/Dashboards/index.html'; } + +# This code does automatic redirection if any updates happen. +MaybeRedirectForResults( + Actions => \@results, + Path => $redirect_to, + Arguments => { id => $id }, +); + <%ARGS>