commit: 20a6584d2dd9d5ecaa19a45a0c0c5ffec5a100ff
parent: 155e211dd035992432623a33b809578f8315395f
Author: Eugen Rochko <eugen@zeonfederated.com>
Date: Wed, 13 Dec 2017 12:15:10 +0100
Clean up admin UI for accounts (#6004)
* Add staff filter to admin UI for accounts, remove obsolete columns
* Only display OStatus section in admin UI for accounts when OStatus data
Diffstat:
7 files changed, 17 insertions(+), 20 deletions(-)
diff --git a/app/controllers/admin/accounts_controller.rb b/app/controllers/admin/accounts_controller.rb
@@ -89,7 +89,8 @@ module Admin
:username,
:display_name,
:email,
- :ip
+ :ip,
+ :staff
)
end
end
diff --git a/app/helpers/admin/filter_helper.rb b/app/helpers/admin/filter_helper.rb
@@ -1,7 +1,7 @@
# frozen_string_literal: true
module Admin::FilterHelper
- ACCOUNT_FILTERS = %i(local remote by_domain silenced suspended recent username display_name email ip).freeze
+ ACCOUNT_FILTERS = %i(local remote by_domain silenced suspended recent username display_name email ip staff).freeze
REPORT_FILTERS = %i(resolved account_id target_account_id).freeze
INVITE_FILTER = %i(available expired).freeze
diff --git a/app/models/account_filter.rb b/app/models/account_filter.rb
@@ -45,6 +45,8 @@ class AccountFilter
else
Account.default_scoped
end
+ when 'staff'
+ accounts_with_users.merge User.staff
else
raise "Unknown filter: #{key}"
end
diff --git a/app/views/admin/accounts/_account.html.haml b/app/views/admin/accounts/_account.html.haml
@@ -4,22 +4,11 @@
%td.domain
- unless account.local?
= link_to account.domain, admin_accounts_path(by_domain: account.domain)
- %td.protocol
- - unless account.local?
- = account.protocol.humanize
- %td.confirmed
- - if account.local?
- - if account.user_confirmed?
- %i.fa.fa-check
- - else
- %i.fa.fa-times
- %td.subscribed
+ %td
- if account.local?
- = t('admin.accounts.location.local')
- - elsif account.subscribed?
- %i.fa.fa-check
+ = t("admin.accounts.roles.#{account.user&.role}")
- else
- %i.fa.fa-times
+ = account.protocol.humanize
%td
= table_link_to 'circle', t('admin.accounts.web'), web_path("accounts/#{account.id}")
= table_link_to 'globe', t('admin.accounts.public'), TagManager.instance.url_for(account)
diff --git a/app/views/admin/accounts/index.html.haml b/app/views/admin/accounts/index.html.haml
@@ -31,6 +31,11 @@
- else
= filter_link_to t('admin.accounts.moderation.suspended'), suspended: '1'
.filter-subset
+ %strong= t('admin.accounts.role')
+ %ul
+ %li= filter_link_to t('admin.accounts.moderation.all'), staff: nil
+ %li= filter_link_to t('admin.accounts.roles.staff'), staff: '1'
+ .filter-subset
%strong= t('admin.accounts.order.title')
%ul
%li= filter_link_to t('admin.accounts.order.alphabetic'), recent: nil
@@ -56,9 +61,7 @@
%tr
%th= t('admin.accounts.username')
%th= t('admin.accounts.domain')
- %th= t('admin.accounts.protocol')
- %th= t('admin.accounts.confirmed')
- %th= fa_icon 'paper-plane-o'
+ %th
%th
%tbody
= render @accounts
diff --git a/app/views/admin/accounts/show.html.haml b/app/views/admin/accounts/show.html.haml
@@ -104,7 +104,7 @@
- else
= link_to t('admin.accounts.perform_full_suspension'), admin_account_suspension_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') }, class: 'button' if can?(:suspend, @account)
-- unless @account.local?
+- if !@account.local? && @account.hub_url.present?
%hr
%h3 OStatus
@@ -132,6 +132,7 @@
- if @account.subscribed?
= link_to t('admin.accounts.unsubscribe'), unsubscribe_admin_account_path(@account.id), method: :post, class: 'button negative' if can?(:unsubscribe, @account)
+- if !@account.local? && @account.inbox_url.present?
%hr
%h3 ActivityPub
diff --git a/config/locales/en.yml b/config/locales/en.yml
@@ -116,6 +116,7 @@ en:
roles:
admin: Administrator
moderator: Moderator
+ staff: Staff
user: User
salmon_url: Salmon URL
search: Search