44b2ee3485
* Add customizable user roles * Various fixes and improvements * Add migration for old settings and fix tootctl role management
37 lines
1.5 KiB
Text
37 lines
1.5 KiB
Text
= simple_form_for @role, url: @role.new_record? ? admin_roles_path : admin_role_path(@role) do |f|
|
|
= render 'shared/error_messages', object: @role
|
|
|
|
- if @role.everyone?
|
|
.flash-message.info
|
|
= t('admin.roles.everyone_full_description_html')
|
|
- else
|
|
.fields-group
|
|
= f.input :name, wrapper: :with_label
|
|
|
|
.fields-group
|
|
= f.input :position, wrapper: :with_label
|
|
|
|
.fields-group
|
|
= f.input :color, wrapper: :with_label, input_html: { placeholder: '#000000' }
|
|
|
|
%hr.spacer/
|
|
|
|
.fields-group
|
|
= f.input :highlighted, wrapper: :with_label
|
|
|
|
%hr.spacer/
|
|
|
|
.field-group
|
|
.input.with_block_label
|
|
%label= t('simple_form.labels.user_role.permissions_as_keys')
|
|
%span.hint= t('simple_form.hints.user_role.permissions_as_keys')
|
|
|
|
- (@role.everyone? ? UserRole::Flags::CATEGORIES.slice(:invites) : UserRole::Flags::CATEGORIES).each do |category, permissions|
|
|
%h4= t(category, scope: 'admin.roles.categories')
|
|
|
|
= f.input :permissions_as_keys, collection: permissions, wrapper: :with_block_label, include_blank: false, label_method: lambda { |privilege| safe_join([t("admin.roles.privileges.#{privilege}"), content_tag(:span, t("admin.roles.privileges.#{privilege}_description"), class: 'hint')]) }, required: false, as: :check_boxes, collection_wrapper_tag: 'ul', item_wrapper_tag: 'li', label: false, hint: false
|
|
|
|
%hr.spacer/
|
|
|
|
.actions
|
|
= f.button :button, @role.new_record? ? t('admin.roles.add_new') : t('generic.save_changes'), type: :submit
|