[Rt-commit] rt branch, 4.6/core-customrole-visibility, created. rt-5.0.0alpha1-17-g2f1c758ef

Blaine Motsinger blaine at bestpractical.com
Wed Mar 4 18:17:51 EST 2020


The branch, 4.6/core-customrole-visibility has been created
        at  2f1c758effc389d966667f4a6bac839d3ab5ad84 (commit)

- Log -----------------------------------------------------------------
commit a05a8d0315d88dfeffc22cb0e56ae05c6aa0426f
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Tue Dec 24 12:35:06 2019 -0600

    Core RT-Extension-CustomRole-Visibility

diff --git a/lib/RT/CustomRole.pm b/lib/RT/CustomRole.pm
index 5d1bfb3d6..230ecbae4 100644
--- a/lib/RT/CustomRole.pm
+++ b/lib/RT/CustomRole.pm
@@ -704,6 +704,34 @@ sub SetDisabled {
     }
 }
 
+sub HiddenForURLs {
+    my $self = shift;
+    my $attr = $self->FirstAttribute('HiddenForURLs');
+    return {} if !$attr;
+    return $attr->Content;
+}
+
+sub SetHiddenForURLs {
+    my $self   = shift;
+    my $hidden = shift;
+
+    return $self->SetAttribute(
+        Name    => 'HiddenForURLs',
+        Content => $hidden,
+    );
+}
+
+sub IsHiddenForURL {
+    my $self = shift;
+    my $url  = shift;
+
+    my $current_url = $HTML::Mason::Commands::r->path_info;
+    $current_url =~ s!/{2,}!/!g;
+
+    $url //= $current_url;
+    return $self->HiddenForURLs->{$url};
+}
+
 sub _CoreAccessible {
     {
         id =>
diff --git a/lib/RT/Interface/Web/MenuBuilder.pm b/lib/RT/Interface/Web/MenuBuilder.pm
index 565f74512..885211260 100644
--- a/lib/RT/Interface/Web/MenuBuilder.pm
+++ b/lib/RT/Interface/Web/MenuBuilder.pm
@@ -1199,6 +1199,11 @@ sub _BuildAdminMenu {
             if ( $obj and $obj->id ) {
                 $page->child( basics       => title => loc('Basics'),       path => "/Admin/CustomRoles/Modify.html?id=".$id );
                 $page->child( 'applies-to' => title => loc('Applies to'),   path => "/Admin/CustomRoles/Objects.html?id=" . $id );
+
+                if ( $current_user->HasRight( Object => $obj, Right => 'AdminCustomRoles' ) ) {
+                    $page->child( 'visibility' => title => loc('Visibility'), path => "/Admin/CustomRoles/Visibility.html?id=" . $id );
+                }
+
             }
         }
     }
diff --git a/lib/RT/Queue.pm b/lib/RT/Queue.pm
index 14d66885f..2b4d04706 100644
--- a/lib/RT/Queue.pm
+++ b/lib/RT/Queue.pm
@@ -1264,6 +1264,82 @@ sub SetSLA {
     return ($status, $self->loc("Queue's default service level has been changed"));
 }
 
+sub InitialPriority {
+    my $self = shift;
+    RT->Deprecated( Instead => "DefaultValue('InitialPriority')", Remove => '4.6' );
+    return $self->DefaultValue('InitialPriority');
+}
+
+sub FinalPriority {
+    my $self = shift;
+    RT->Deprecated( Instead => "DefaultValue('FinalPriority')", Remove => '4.6' );
+    return $self->DefaultValue('FinalPriority');
+}
+
+sub DefaultDueIn {
+    my $self = shift;
+    RT->Deprecated( Instead => "DefaultValue('Due')", Remove => '4.6' );
+
+    # DefaultDueIn used to be a number of days; so if the DefaultValue is,
+    # say, "3 days" then return 3
+    my $due = $self->DefaultValue('Due');
+    if (defined($due) && $due =~ /^(\d+) days?$/i) {
+        return $1;
+    }
+
+    return $due;
+}
+
+sub SetInitialPriority {
+    my $self = shift;
+    my $value = shift;
+    RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+    return $self->SetDefaultValue(
+        Name => 'InitialPriority',
+        Value => $value,
+    );
+}
+
+sub SetFinalPriority {
+    my $self = shift;
+    my $value = shift;
+    RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+    return $self->SetDefaultValue(
+        Name => 'FinalPriority',
+        Value => $value,
+    );
+}
+
+sub SetDefaultDueIn {
+    my $self = shift;
+    my $value = shift;
+
+    # DefaultDueIn used to be a number of days; so if we're setting to,
+    # say, "3" then add the word "days" to match the way the new
+    # DefaultValues works
+    $value .= " days" if defined($value) && $value =~ /^\d+$/;
+
+    RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+    return $self->SetDefaultValue(
+        Name => 'Due',
+        Value => $value,
+    );
+}
+
+sub HiddenCustomRoleIDsForURL {
+    my $self = shift;
+    my $url  = shift;
+
+    my $roles = $self->CustomRoles;
+    my @ids;
+
+    while (my $role = $roles->Next) {
+        push @ids, $role->Id if $role->IsHiddenForURL($url);
+    }
+
+    return @ids;
+}
+
 RT::Base->_ImportOverlays();
 
 1;
diff --git a/share/html/Admin/CustomRoles/Visibility.html b/share/html/Admin/CustomRoles/Visibility.html
new file mode 100644
index 000000000..f739866dd
--- /dev/null
+++ b/share/html/Admin/CustomRoles/Visibility.html
@@ -0,0 +1,127 @@
+%# BEGIN BPS TAGGED BLOCK {{{
+%#
+%# COPYRIGHT:
+%#
+%# This software is Copyright (c) 1996-2019 Best Practical Solutions, LLC
+%#                                          <sales at bestpractical.com>
+%#
+%# (Except where explicitly superseded by other copyright notices)
+%#
+%#
+%# LICENSE:
+%#
+%# This work is made available to you under the terms of Version 2 of
+%# the GNU General Public License. A copy of that license should have
+%# been provided with this software, but in any event can be snarfed
+%# from www.gnu.org.
+%#
+%# This work is distributed in the hope that it will be useful, but
+%# WITHOUT ANY WARRANTY; without even the implied warranty of
+%# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+%# General Public License for more details.
+%#
+%# You should have received a copy of the GNU General Public License
+%# along with this program; if not, write to the Free Software
+%# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+%# 02110-1301 or visit their web page on the internet at
+%# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
+%#
+%#
+%# CONTRIBUTION SUBMISSION POLICY:
+%#
+%# (The following paragraph is not intended to limit the rights granted
+%# to you to modify and distribute this software under the terms of
+%# the GNU General Public License and is only of importance to you if
+%# you choose to contribute your changes and enhancements to the
+%# community by submitting them to Best Practical Solutions, LLC.)
+%#
+%# By intentionally submitting any modifications, corrections or
+%# derivatives to this work, or any other work intended for use with
+%# Request Tracker, to Best Practical Solutions, LLC, you confirm that
+%# you are the copyright holder for those contributions and you grant
+%# Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
+%# royalty-free, perpetual, license to use, copy, create derivative
+%# works based on those contributions, and sublicense and distribute
+%# those contributions and any derivatives thereof.
+%#
+%# END BPS TAGGED BLOCK }}}
+<& /Admin/Elements/Header, Title => $title &>
+<& /Elements/Tabs &>
+<& /Elements/ListActions &>
+
+<form action="Visibility.html" method="post" name="Visibility">
+<input type="hidden" class="hidden" name="id" value="<% $id %>" />
+
+<h2><&|/l, $role->Name &>Visibility for [_1]</&></h2>
+<table cellspacing=10>
+% for (@pages) {
+%     my ($label, $url) = @$_;
+    <tr>
+        <td align="left"><% $label %></td>
+        <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>show</&></label></td>
+        <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="1" <%  $hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>hide</&></label></td>
+    </tr>
+% }
+</table>
+
+<& /Elements/Submit, Name => 'Update' &>
+
+</form>
+
+<%ARGS>
+$id     => undef
+$Update => 0
+</%ARGS>
+<%INIT>
+my $role = RT::CustomRole->new( $session{'CurrentUser'} );
+$role->Load($id) or Abort(loc("Could not load custom role #[_1]", $id));
+$id = $role->id;
+
+if ($role->Disabled) {
+    Abort(loc("Cannot modify objects of disabled custom role #[_1]", $id));
+}
+
+my %hidden = %{ $role->HiddenForURLs };
+
+if ( $Update ) {
+    my (@results);
+
+    for my $key (%ARGS) {
+        if (my ($url) = $key =~ /^hide-(.*)$/) {
+            $hidden{$url} = $ARGS{$key};
+        }
+    }
+
+    my ($ok, $msg) = $role->SetHiddenForURLs(\%hidden);
+    if ($ok) {
+        push @results, loc('Updated visibility');
+    }
+    else {
+        push @results, loc('Unable to update visibility: [_1]', $msg);
+        %hidden = $role->HiddenForURLs;
+    }
+
+    MaybeRedirectForResults(
+        Actions   => \@results,
+        Arguments => {
+            id   => $id,
+        },
+    );
+}
+
+my @pages = (
+    [loc('Ticket create') => '/Ticket/Create.html'],
+    [loc('Ticket display') => '/Ticket/Display.html'],
+    [loc('Ticket modify people') => '/Ticket/ModifyPeople.html'],
+    [loc('Ticket jumbo') => '/Ticket/ModifyAll.html'],
+);
+
+if ($role->SingleValue) {
+    push @pages, (
+        [loc('Ticket modify basics') => '/Ticket/Modify.html'],
+        [loc('Ticket reply/comment') => '/Ticket/Update.html'],
+    );
+}
+
+my $title = loc('Modify visibility for [_1]', $role->Name);
+</%INIT>
diff --git a/share/html/Elements/SelectWatcherType b/share/html/Elements/SelectWatcherType
index 0fe850d0b..dcc966573 100644
--- a/share/html/Elements/SelectWatcherType
+++ b/share/html/Elements/SelectWatcherType
@@ -67,6 +67,17 @@ else {
     @types = $Queue->Roles(Single => 0);
 }
 
+my @NewTypes;
+for my $name (@types) {
+    if (my ($id) = $name =~ /^RT::CustomRole-(\d+)$/) {
+        my $role = RT::CustomRole->new($session{CurrentUser});
+        $role->Load($id);
+        next if $role->IsHiddenForURL;
+    }
+    push @NewTypes, $name;
+}
+ at types = @NewTypes;
+
 $m->callback( Types => \@types, %ARGS, CallbackName => 'ModifyWatcherTypes' );
 </%INIT>
 <%ARGS>
diff --git a/share/html/Ticket/Create.html b/share/html/Ticket/Create.html
index e11f9fb6b..b26ec6bd0 100644
--- a/share/html/Ticket/Create.html
+++ b/share/html/Ticket/Create.html
@@ -176,6 +176,10 @@
 
 % my $roles = $QueueObj->CustomRoles;
 % $roles->LimitToMultipleValue;
+
+% my @hidden = $QueueObj->HiddenCustomRoleIDsForURL;
+% $roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
 % $m->callback( CallbackName => 'ModifyCustomRoles', ARGSRef => \%ARGS, CustomRoles => $roles );
 % while (my $role = $roles->Next) {
 <div class="form-row">
diff --git a/share/html/Ticket/Elements/EditBasics b/share/html/Ticket/Elements/EditBasics
index 7f1551288..2ece8b3cd 100644
--- a/share/html/Ticket/Elements/EditBasics
+++ b/share/html/Ticket/Elements/EditBasics
@@ -141,6 +141,10 @@ my @role_fields;
 unless ($ExcludeCustomRoles) {
     my $roles = $QueueObj->CustomRoles;
     $roles->LimitToSingleValue;
+
+    my @hidden = $QueueObj->HiddenCustomRoleIDsForURL;
+    $roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
     $m->callback( CallbackName => 'ModifyCustomRoles', %ARGS, CustomRoles => $roles);
     while (my $role = $roles->Next) {
         push @role_fields, {
diff --git a/share/html/Ticket/Elements/EditPeople b/share/html/Ticket/Elements/EditPeople
index 862d5ed29..7899187d4 100644
--- a/share/html/Ticket/Elements/EditPeople
+++ b/share/html/Ticket/Elements/EditPeople
@@ -81,6 +81,10 @@
 % my @role_fields;
 % my $single_roles = $Ticket->QueueObj->CustomRoles;
 % $single_roles->LimitToSingleValue;
+
+% my @hidden = $Ticket->QueueObj->HiddenCustomRoleIDsForURL;
+% $single_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
 % $m->callback( CustomRoles => $single_roles, SingleRoles => 1, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
 % while (my $role = $single_roles->Next) {
 <div class="form-row">
@@ -125,6 +129,9 @@
 
 % my $multi_roles = $Ticket->QueueObj->CustomRoles;
 % $multi_roles->LimitToMultipleValue;
+
+% $multi_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
 % $m->callback( CustomRoles => $multi_roles, SingleRoles => 0, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
 % while (my $role = $multi_roles->Next) {
 % my $group = $Ticket->RoleGroup($role->GroupType);
diff --git a/share/html/Ticket/Elements/ShowPeople b/share/html/Ticket/Elements/ShowPeople
index e9fe45a89..953cd807a 100644
--- a/share/html/Ticket/Elements/ShowPeople
+++ b/share/html/Ticket/Elements/ShowPeople
@@ -57,6 +57,10 @@
 
 % my $single_roles = $Ticket->QueueObj->CustomRoles;
 % $single_roles->LimitToSingleValue;
+
+% my @hidden = $Ticket->QueueObj->HiddenCustomRoleIDsForURL;
+% $single_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
 % $m->callback( CustomRoles => $single_roles, SingleRoles => 1, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
 % while (my $role = $single_roles->Next) {
 %     my $group = $Ticket->RoleGroup($role->GroupType);
@@ -88,6 +92,9 @@
 
 % my $multi_roles = $Ticket->QueueObj->CustomRoles;
 % $multi_roles->LimitToMultipleValue;
+
+% $multi_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
 % $m->callback( CustomRoles => $multi_roles, SingleRoles => 0, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
 % while (my $role = $multi_roles->Next) {
   <div class="form-row">

commit bacdc9b257e588730971f51580b418d88088c656
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Thu Dec 26 17:19:24 2019 -0600

    Migrate Visibility.html to elevator themes

diff --git a/share/html/Admin/CustomRoles/Visibility.html b/share/html/Admin/CustomRoles/Visibility.html
index f739866dd..607624b9d 100644
--- a/share/html/Admin/CustomRoles/Visibility.html
+++ b/share/html/Admin/CustomRoles/Visibility.html
@@ -53,16 +53,33 @@
 <input type="hidden" class="hidden" name="id" value="<% $id %>" />
 
 <h2><&|/l, $role->Name &>Visibility for [_1]</&></h2>
-<table cellspacing=10>
+
+<div class="col-md-6">
 % for (@pages) {
 %     my ($label, $url) = @$_;
-    <tr>
-        <td align="left"><% $label %></td>
-        <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>show</&></label></td>
-        <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="1" <%  $hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>hide</&></label></td>
-    </tr>
+  <div class="form-row boolean">
+    <div class="col-md-3 label">
+      <% $label %>:
+    </div>
+    <div class="col-md-9 value">
+      <div class="form-row">
+        <div class="col-md-auto">
+          <div class="custom-control custom-radio">
+            <input type="radio" class="custom-control-input" id="show-<% $url %>" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>>
+            <label class="custom-control-label" for="show-<% $url %>"><&|/l&>show</&></label>
+          </div>
+        </div>
+        <div class="col-md-auto">
+          <div class="custom-control custom-radio">
+            <input type="radio" class="custom-control-input" id="hide-<% $url %>" name="hide-<% $url %>" value="1" <%  $hidden{$url} ? qq[checked="checked"] : qq[] |n %>>
+            <label class="custom-control-label" for="hide-<% $url %>"><&|/l&>hide</&></label>
+          </div>
+        </div>
+      </div>
+    </div>
+  </div>
 % }
-</table>
+</div>
 
 <& /Elements/Submit, Name => 'Update' &>
 

commit 2b85d5ee697be216bee669b0a2af54eb68af862e
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Fri Dec 27 19:52:06 2019 -0600

    Add test for customrole visibility

diff --git a/t/web/customrole_visibility.t b/t/web/customrole_visibility.t
new file mode 100644
index 000000000..a9fcec5cc
--- /dev/null
+++ b/t/web/customrole_visibility.t
@@ -0,0 +1,105 @@
+use strict;
+use warnings;
+
+use RT::Test tests => undef;
+
+my ( $baseurl, $m ) = RT::Test->started_ok;
+ok $m->login, 'logged in as root';
+
+my $customrole_name = 'test customrole';
+
+diag( 'Create custom role' );
+
+# create custom role
+$m->follow_link_ok({ id => 'admin-custom-roles-create' }, "Followed link to 'Admin > Custom Roles > Create'" );
+$m->submit_form(
+    form_name => 'ModifyCustomRole',
+    fields => {
+        Name => $customrole_name,
+    },
+);
+$m->content_contains( 'Custom role created', 'Created customrole' );
+
+my $customrole_id = $m->form_name( 'ModifyCustomRole' )->value( 'id' );
+
+# set applies to
+$m->follow_link_ok({ id => 'page-applies-to' }, "Followed link to 'Applies to'" );
+$m->form_name( 'AddRemoveCustomRole' );
+$m->current_form->find_input( 'AddRole-1' )->check;
+$m->click_ok( 'Update', "Added '$customrole_name' to General queue" );
+$m->content_contains( "$customrole_name added to queue General" );
+
+diag( 'Verify visibility is shown by default' );
+
+# ensure all pages are set visible by default
+$m->follow_link_ok({ id => 'page-visibility' }, "Followed link to 'Visibility'" );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/Create.html' ), 'Ticket create is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/Display.html' ), 'Ticket display is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyPeople.html' ), 'Ticket modify people is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyAll.html' ), 'Ticket jumbo is set visible by default' );
+
+# confirm each page is visible by default
+$m->get_ok( '/Ticket/Create.html?Queue=1' );
+$m->content_contains( "$customrole_name" );
+
+$m->submit_form(
+    form_name => 'TicketCreate',
+    fields => {
+        Subject => 'test ticket',
+    },
+);
+$m->content_contains( 'Ticket 1 created in queue', 'Created ticket' );
+
+$m->get_ok( '/Ticket/Display.html?id=1' );
+$m->content_contains( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyPeople.html?id=1' );
+$m->content_contains( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyAll.html?id=1' );
+$m->content_contains( "$customrole_name" );
+
+diag( 'Remove visibility' );
+
+# set each visibility to hidden
+$m->follow_link_ok({ id => 'admin-custom-roles-select' }, "Followed link to 'Admin > Custom Roles > Select'" );
+$m->follow_link_ok({ text => $customrole_name }, "Followed link to '$customrole_name'" );
+$m->follow_link_ok({ id => 'page-visibility' }, "Followed link to 'Visibility'" );
+$m->form_name( 'Visibility' );
+$m->current_form->find_input( 'hide-/Ticket/Create.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/Display.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/ModifyPeople.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/ModifyAll.html' )->check;
+$m->click_ok( 'Update', 'Set visibility to hide for all pages' );
+$m->content_contains( 'Updated visibility' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/Create.html' ), 'Ticket create is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/Display.html' ), 'Ticket display is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyPeople.html' ), 'Ticket modify people is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyAll.html' ), 'Ticket jumbo is set hidden' );
+
+diag( 'Verify visibility is hidden' );
+
+# confirm hidden on each page
+$m->get_ok( '/Ticket/Create.html?Queue=1' );
+$m->content_lacks( "$customrole_name" );
+
+$m->submit_form(
+    form_name => 'TicketCreate',
+    fields => {
+        Subject => 'test ticket 2',
+    },
+);
+$m->content_contains( 'Ticket 2 created in queue', 'Created ticket' );
+
+$m->get_ok( '/Ticket/Display.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyPeople.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyAll.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+
+# TODO:
+# create customrole not for multiple users
+# verify additional pages customrole is visible for a single user
+# - Ticket modify basics
+# - Ticket reply/comment
+
+done_testing();

commit 255821d424b60738df60007606d0696e9eb49280
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Tue Jan 7 18:47:10 2020 -0600

    Update role entry hints to tooltips
    
    For the custom role display in EditBasics, the ShowEntryHint arg is
    set to 0 to keep the hint from displaying below the input.

diff --git a/share/html/Ticket/Elements/EditBasics b/share/html/Ticket/Elements/EditBasics
index 2ece8b3cd..bd6302b53 100644
--- a/share/html/Ticket/Elements/EditBasics
+++ b/share/html/Ticket/Elements/EditBasics
@@ -154,6 +154,7 @@ unless ($ExcludeCustomRoles) {
                 role    => $role,
                 Ticket  => $TicketObj,
                 Default => $defaults{$role->GroupType},
+                ShowEntryHint => 0,
             }
         };
     }
diff --git a/share/html/Ticket/Elements/EditPeople b/share/html/Ticket/Elements/EditPeople
index 7899187d4..e2b390b04 100644
--- a/share/html/Ticket/Elements/EditPeople
+++ b/share/html/Ticket/Elements/EditPeople
@@ -88,8 +88,12 @@
 % $m->callback( CustomRoles => $single_roles, SingleRoles => 1, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
 % while (my $role = $single_roles->Next) {
 <div class="form-row">
-  <div class="col-md-3 label"><% $role->Name %>:</div>
-  <div class="col-md-6 value"><& /Elements/SingleUserRoleInput, role => $role, Ticket => $Ticket &></div>
+  <div class="form-group col-md-3 label"><% $role->Name %>:
+% if ($role->EntryHint) {
+    <span class="far fa-question-circle icon-helper" data-toggle="tooltip" data-placement="top" data-original-title="<% $role->EntryHint %>"></span>
+% }
+  </div>
+  <div class="col-md-6 value"><& /Elements/SingleUserRoleInput, role => $role, Ticket => $Ticket, ShowEntryHint => 0 &></div>
 </div>
 
 % }

commit d129efddf5b9f6be445068e9ae62a74ed0ec4865
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Wed Mar 4 14:15:31 2020 -0600

    Add CustomRole::Visibility to %CORED_PLUGINS

diff --git a/lib/RT.pm b/lib/RT.pm
index 6116333a4..cc32f730c 100644
--- a/lib/RT.pm
+++ b/lib/RT.pm
@@ -767,6 +767,7 @@ our %CORED_PLUGINS = (
     'RT::Extension::AdminConditionsAndActions' => '4.4.2',
     'RT::Extension::RightsInspector' => '5.0',
     'RT::Extension::ConfigInDatabase' => '5.0',
+    'RT::Extension::CustomRole::Visibility' => '5.0',
 );
 
 sub InitPlugins {

commit 2f1c758effc389d966667f4a6bac839d3ab5ad84
Author: Blaine Motsinger <blaine at bestpractical.com>
Date:   Wed Mar 4 17:14:30 2020 -0600

    Add titlebox to CustomRoles Visibility page

diff --git a/share/html/Admin/CustomRoles/Visibility.html b/share/html/Admin/CustomRoles/Visibility.html
index 607624b9d..e3650db49 100644
--- a/share/html/Admin/CustomRoles/Visibility.html
+++ b/share/html/Admin/CustomRoles/Visibility.html
@@ -49,19 +49,17 @@
 <& /Elements/Tabs &>
 <& /Elements/ListActions &>
 
-<form action="Visibility.html" method="post" name="Visibility">
+<form action="Visibility.html" method="post" name="Visibility" class="mx-auto max-width-lg">
 <input type="hidden" class="hidden" name="id" value="<% $id %>" />
 
-<h2><&|/l, $role->Name &>Visibility for [_1]</&></h2>
-
-<div class="col-md-6">
+<&| /Widgets/TitleBox, class => 'custom-role-info-visibility', content_class => 'mx-auto width-sm' &>
 % for (@pages) {
 %     my ($label, $url) = @$_;
   <div class="form-row boolean">
-    <div class="col-md-3 label">
+    <div class="col-md-4 label">
       <% $label %>:
     </div>
-    <div class="col-md-9 value">
+    <div class="col-md-8 value">
       <div class="form-row">
         <div class="col-md-auto">
           <div class="custom-control custom-radio">
@@ -79,10 +77,8 @@
     </div>
   </div>
 % }
-</div>
-
-<& /Elements/Submit, Name => 'Update' &>
-
+</&>
+<& /Elements/Submit, Name => loc('Update') &>
 </form>
 
 <%ARGS>

-----------------------------------------------------------------------


More information about the rt-commit mailing list