Hide options when permission is not given.

git-svn-id: http://svn.redmine.org/redmine/trunk@15468 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang
2016-06-05 17:45:41 +00:00
parent 2691613c55
commit bfd5b919ba
2 changed files with 13 additions and 18 deletions

View File

@@ -7,17 +7,17 @@
<% end %> <% end %>
<% unless @role.anonymous? %> <% unless @role.anonymous? %>
<p><%= f.select :issues_visibility, Role::ISSUES_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]} %></p> <p class="view_issues_shown"><%= f.select :issues_visibility, Role::ISSUES_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]} %></p>
<% end %> <% end %>
<% unless @role.anonymous? %> <% unless @role.anonymous? %>
<p><%= f.select :time_entries_visibility, Role::TIME_ENTRIES_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]} %></p> <p class="view_time_entries_shown"><%= f.select :time_entries_visibility, Role::TIME_ENTRIES_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]}, {}, :class => "view_time_entries_enabled" %></p>
<% end %> <% end %>
<p><%= f.select :users_visibility, Role::USERS_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]} %></p> <p><%= f.select :users_visibility, Role::USERS_VISIBILITY_OPTIONS.collect {|v| [l(v.last), v.first]} %></p>
<% unless @role.builtin? %> <% unless @role.builtin? %>
<p id="manage_members_options"> <p class="manage_members_shown">
<label><%= l(:label_member_management) %></label> <label><%= l(:label_member_management) %></label>
<label class="block"> <label class="block">
<%= radio_button_tag 'role[all_roles_managed]', 1, @role.all_roles_managed?, :id => 'role_all_roles_managed_on', <%= radio_button_tag 'role[all_roles_managed]', 1, @role.all_roles_managed?, :id => 'role_all_roles_managed_on',
@@ -52,7 +52,8 @@
<% perms_by_module[mod].each do |permission| %> <% perms_by_module[mod].each do |permission| %>
<label class="floating"> <label class="floating">
<%= check_box_tag 'role[permissions][]', permission.name, (@role.permissions.include? permission.name), <%= check_box_tag 'role[permissions][]', permission.name, (@role.permissions.include? permission.name),
:id => "role_permissions_#{permission.name}" %> :id => "role_permissions_#{permission.name}",
:data => {:shows => ".#{permission.name}_shown"} %>
<%= l_or_humanize(permission.name, :prefix => 'permission_') %> <%= l_or_humanize(permission.name, :prefix => 'permission_') %>
</label> </label>
<% end %> <% end %>
@@ -62,7 +63,7 @@
<%= hidden_field_tag 'role[permissions][]', '' %> <%= hidden_field_tag 'role[permissions][]', '' %>
</div> </div>
<div id="role-permissions-trackers"> <div id="role-permissions-trackers" class="view_issues_shown">
<h3><%= l(:label_issue_tracking) %></h3> <h3><%= l(:label_issue_tracking) %></h3>
<% permissions = %w(view_issues add_issues edit_issues add_issue_notes delete_issues) %> <% permissions = %w(view_issues add_issues edit_issues add_issue_notes delete_issues) %>
@@ -72,18 +73,19 @@
<tr> <tr>
<th><%= l(:label_tracker) %></th> <th><%= l(:label_tracker) %></th>
<% permissions.each do |permission| %> <% permissions.each do |permission| %>
<th><%= l("permission_#{permission}") %></th> <th class="<%= "#{permission}_shown" %>"><%= l("permission_#{permission}") %></th>
<% end %> <% end %>
</thead> </thead>
<tbody> <tbody>
<tr> <tr>
<td class="name"><b><%= l(:label_tracker_all) %></b></td> <td class="name"><b><%= l(:label_tracker_all) %></b></td>
<% permissions.each do |permission| %> <% permissions.each do |permission| %>
<td> <td class="<%= "#{permission}_shown" %>">
<%= hidden_field_tag "role[permissions_all_trackers][#{permission}]", '0', :id => nil %> <%= hidden_field_tag "role[permissions_all_trackers][#{permission}]", '0', :id => nil %>
<%= check_box_tag "role[permissions_all_trackers][#{permission}]", <%= check_box_tag "role[permissions_all_trackers][#{permission}]",
'1', '1',
@role.permissions_all_trackers?(permission), @role.permissions_all_trackers?(permission),
:class => "#{permission}_shown",
:data => {:disables => ".#{permission}_tracker"} %> :data => {:disables => ".#{permission}_tracker"} %>
</td> </td>
<% end %> <% end %>
@@ -92,7 +94,7 @@
<tr class="<%= cycle("odd", "even") %>"> <tr class="<%= cycle("odd", "even") %>">
<td class="name"><%= tracker.name %></td> <td class="name"><%= tracker.name %></td>
<% permissions.each do |permission| %> <% permissions.each do |permission| %>
<td><%= check_box_tag "role[permissions_tracker_ids][#{permission}][]", <td class="<%= "#{permission}_shown" %>"><%= check_box_tag "role[permissions_tracker_ids][#{permission}][]",
tracker.id, tracker.id,
@role.permissions_tracker_ids?(permission, tracker.id), @role.permissions_tracker_ids?(permission, tracker.id),
:class => "#{permission}_tracker", :class => "#{permission}_tracker",
@@ -108,11 +110,3 @@
<%= hidden_field_tag "role[permissions_tracker_ids][#{permission}][]", '' %> <%= hidden_field_tag "role[permissions_tracker_ids][#{permission}][]", '' %>
<% end %> <% end %>
</div> </div>
<%= javascript_tag do %>
$(document).ready(function(){
$("#role_permissions_manage_members").change(function(){
$("#manage_members_options").toggle($(this).is(":checked"));
}).change();
});
<% end %>

View File

@@ -719,9 +719,10 @@ function toggleDisabledOnChange() {
var checked = $(this).is(':checked'); var checked = $(this).is(':checked');
$($(this).data('disables')).attr('disabled', checked); $($(this).data('disables')).attr('disabled', checked);
$($(this).data('enables')).attr('disabled', !checked); $($(this).data('enables')).attr('disabled', !checked);
$($(this).data('shows')).toggle(checked);
} }
function toggleDisabledInit() { function toggleDisabledInit() {
$('input[data-disables], input[data-enables]').each(toggleDisabledOnChange); $('input[data-disables], input[data-enables], input[data-shows]').each(toggleDisabledOnChange);
} }
(function ( $ ) { (function ( $ ) {
@@ -751,7 +752,7 @@ function toggleDisabledInit() {
}( jQuery )); }( jQuery ));
$(document).ready(function(){ $(document).ready(function(){
$('#content').on('change', 'input[data-disables], input[data-enables]', toggleDisabledOnChange); $('#content').on('change', 'input[data-disables], input[data-enables], input[data-shows]', toggleDisabledOnChange);
toggleDisabledInit(); toggleDisabledInit();
}); });