mirror of
https://github.com/glitch-soc/mastodon.git
synced 2024-11-25 01:24:02 -05:00
bea0bb39d6
* Add shortcuts to blacklist a user's e-mail domain in admin UI * Add option to blacklist resolved MX and IP records for e-mail domains
236 lines
12 KiB
Plaintext
236 lines
12 KiB
Plaintext
- content_for :page_title do
|
|
= @account.acct
|
|
|
|
= render 'application/card', account: @account
|
|
|
|
- account = @account
|
|
- proofs = account.identity_proofs.active
|
|
- fields = account.fields
|
|
- unless fields.empty? && proofs.empty? && account.note.blank?
|
|
.admin-account-bio
|
|
- unless fields.empty? && proofs.empty?
|
|
%div
|
|
.account__header__fields
|
|
- proofs.each do |proof|
|
|
%dl
|
|
%dt= proof.provider.capitalize
|
|
%dd.verified
|
|
= link_to fa_icon('check'), proof.badge.proof_url, class: 'verified__mark', title: t('accounts.link_verified_on', date: l(proof.updated_at))
|
|
= link_to proof.provider_username, proof.badge.profile_url
|
|
|
|
- fields.each do |field|
|
|
%dl
|
|
%dt.emojify{ title: field.name }= Formatter.instance.format_field(account, field.name, custom_emojify: true)
|
|
%dd{ title: field.value, class: custom_field_classes(field) }
|
|
- if field.verified?
|
|
%span.verified__mark{ title: t('accounts.link_verified_on', date: l(field.verified_at)) }
|
|
= fa_icon 'check'
|
|
= Formatter.instance.format_field(account, field.value, custom_emojify: true)
|
|
|
|
- if account.note.present?
|
|
%div
|
|
.account__header__content.emojify= Formatter.instance.simplified_format(account, custom_emojify: true)
|
|
|
|
.dashboard__counters{ style: 'margin-top: 10px' }
|
|
%div
|
|
= link_to admin_account_statuses_path(@account.id) do
|
|
.dashboard__counters__num= number_with_delimiter @account.statuses_count
|
|
.dashboard__counters__label= t 'admin.accounts.statuses'
|
|
%div
|
|
= link_to admin_account_statuses_path(@account.id, { media: true }) do
|
|
.dashboard__counters__num= number_to_human_size @account.media_attachments.sum('file_file_size')
|
|
.dashboard__counters__label= t 'admin.accounts.media_attachments'
|
|
%div
|
|
= link_to admin_account_relationships_path(@account.id, location: 'local', relationship: 'followed_by') do
|
|
.dashboard__counters__num= number_with_delimiter @account.local_followers_count
|
|
.dashboard__counters__label= t 'admin.accounts.followers'
|
|
%div
|
|
= link_to admin_reports_path(account_id: @account.id) do
|
|
.dashboard__counters__num= number_with_delimiter @account.reports.count
|
|
.dashboard__counters__label= t '.created_reports'
|
|
%div
|
|
= link_to admin_reports_path(target_account_id: @account.id) do
|
|
.dashboard__counters__num= number_with_delimiter @account.targeted_reports.count
|
|
.dashboard__counters__label= t '.targeted_reports'
|
|
%div
|
|
%div
|
|
.dashboard__counters__text
|
|
- if @account.local? && @account.user.nil?
|
|
%span.neutral= t('admin.accounts.deleted')
|
|
- elsif @account.suspended?
|
|
%span.red= t('admin.accounts.suspended')
|
|
- elsif @account.silenced?
|
|
%span.red= t('admin.accounts.silenced')
|
|
- elsif @account.local? && @account.user&.disabled?
|
|
%span.red= t('admin.accounts.disabled')
|
|
- elsif @account.local? && !@account.user&.confirmed?
|
|
%span.neutral= t('admin.accounts.confirming')
|
|
- elsif @account.local? && !@account.user_approved?
|
|
%span.neutral= t('admin.accounts.pending')
|
|
- else
|
|
%span.neutral= t('admin.accounts.no_limits_imposed')
|
|
.dashboard__counters__label= t 'admin.accounts.login_status'
|
|
|
|
- unless @account.local? && @account.user.nil?
|
|
.table-wrapper
|
|
%table.table.inline-table
|
|
%tbody
|
|
- if @account.local?
|
|
- if @account.avatar?
|
|
%tr
|
|
%th= t('admin.accounts.avatar')
|
|
%td= table_link_to 'trash', t('admin.accounts.remove_avatar'), remove_avatar_admin_account_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') } if can?(:remove_avatar, @account)
|
|
%td
|
|
|
|
- if @account.header?
|
|
%tr
|
|
%th= t('admin.accounts.header')
|
|
%td= table_link_to 'trash', t('admin.accounts.remove_header'), remove_header_admin_account_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') } if can?(:remove_header, @account)
|
|
%td
|
|
|
|
%tr
|
|
%th= t('admin.accounts.role')
|
|
%td= t("admin.accounts.roles.#{@account.user&.role}")
|
|
%td
|
|
= table_link_to 'angle-double-up', t('admin.accounts.promote'), promote_admin_account_role_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') } if can?(:promote, @account.user)
|
|
= table_link_to 'angle-double-down', t('admin.accounts.demote'), demote_admin_account_role_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') } if can?(:demote, @account.user)
|
|
|
|
%tr
|
|
%th{ rowspan: can?(:create, :email_domain_block) ? 3 : 2 }= t('admin.accounts.email')
|
|
%td{ rowspan: can?(:create, :email_domain_block) ? 3 : 2 }= @account.user_email
|
|
%td= table_link_to 'edit', t('admin.accounts.change_email.label'), admin_account_change_email_path(@account.id) if can?(:change_email, @account.user)
|
|
|
|
%tr
|
|
%td= table_link_to 'search', t('admin.accounts.search_same_email_domain'), admin_accounts_path(email: "%@#{@account.user_email.split('@').last}")
|
|
|
|
- if can?(:create, :email_domain_block)
|
|
%tr
|
|
%td= table_link_to 'ban', t('admin.accounts.add_email_domain_block'), new_admin_email_domain_block_path(_domain: @account.user_email.split('@').last)
|
|
|
|
- if @account.user_unconfirmed_email.present?
|
|
%tr
|
|
%th= t('admin.accounts.unconfirmed_email')
|
|
%td= @account.user_unconfirmed_email
|
|
%td
|
|
|
|
%tr
|
|
%th= t('admin.accounts.email_status')
|
|
%td
|
|
- if @account.user&.confirmed?
|
|
= t('admin.accounts.confirmed')
|
|
- else
|
|
= t('admin.accounts.confirming')
|
|
%td= table_link_to 'refresh', t('admin.accounts.resend_confirmation.send'), resend_admin_account_confirmation_path(@account.id), method: :post if can?(:confirm, @account.user)
|
|
|
|
%tr
|
|
%th= t('admin.accounts.login_status')
|
|
%td
|
|
- if @account.user&.disabled?
|
|
= t('admin.accounts.disabled')
|
|
- else
|
|
= t('admin.accounts.enabled')
|
|
%td
|
|
- if @account.user&.disabled?
|
|
= table_link_to 'unlock', t('admin.accounts.enable'), enable_admin_account_path(@account.id), method: :post if can?(:enable, @account.user)
|
|
- elsif @account.user_approved?
|
|
= table_link_to 'lock', t('admin.accounts.disable'), new_admin_account_action_path(@account.id, type: 'disable') if can?(:disable, @account.user)
|
|
|
|
%tr
|
|
%th= t('simple_form.labels.defaults.locale')
|
|
%td= @account.user_locale
|
|
%td
|
|
|
|
%tr
|
|
%th= t('admin.accounts.joined')
|
|
%td
|
|
%time.formatted{ datetime: @account.created_at.iso8601, title: l(@account.created_at) }= l @account.created_at
|
|
%td
|
|
|
|
- @account.user.recent_ips.each_with_index do |(_, ip), i|
|
|
%tr
|
|
- if i.zero?
|
|
%th{ rowspan: @account.user.recent_ips.size }= t('admin.accounts.most_recent_ip')
|
|
%td= ip
|
|
%td= table_link_to 'search', t('admin.accounts.search_same_ip'), admin_accounts_path(ip: ip)
|
|
|
|
%tr
|
|
%th= t('admin.accounts.most_recent_activity')
|
|
%td
|
|
- if @account.user_current_sign_in_at
|
|
%time.formatted{ datetime: @account.user_current_sign_in_at.iso8601, title: l(@account.user_current_sign_in_at) }= l @account.user_current_sign_in_at
|
|
%td
|
|
|
|
- if @account.user&.invited?
|
|
%tr
|
|
%th= t('admin.accounts.invited_by')
|
|
%td= admin_account_link_to @account.user.invite.user.account
|
|
%td
|
|
|
|
- else
|
|
%tr
|
|
%th= t('admin.accounts.inbox_url')
|
|
%td
|
|
= @account.inbox_url
|
|
= fa_icon DeliveryFailureTracker.unavailable?(@account.inbox_url) ? 'times' : 'check'
|
|
%tr
|
|
%th= t('admin.accounts.shared_inbox_url')
|
|
%td
|
|
= @account.shared_inbox_url
|
|
= fa_icon DeliveryFailureTracker.unavailable?(@account.shared_inbox_url) ? 'times' : 'check'
|
|
|
|
%div{ style: 'overflow: hidden' }
|
|
%div{ style: 'float: right' }
|
|
- if @account.local?
|
|
= link_to t('admin.accounts.reset_password'), admin_account_reset_path(@account.id), method: :create, class: 'button' if can?(:reset_password, @account.user)
|
|
- if @account.user&.otp_required_for_login?
|
|
= link_to t('admin.accounts.disable_two_factor_authentication'), admin_user_two_factor_authentication_path(@account.user.id), method: :delete, class: 'button' if can?(:disable_2fa, @account.user)
|
|
- if !@account.memorial? && @account.user_approved?
|
|
= link_to t('admin.accounts.memorialize'), memorialize_admin_account_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') }, class: 'button button--destructive' if can?(:memorialize, @account)
|
|
- else
|
|
= link_to t('admin.accounts.redownload'), redownload_admin_account_path(@account.id), method: :post, class: 'button' if can?(:redownload, @account)
|
|
|
|
%div{ style: 'float: left' }
|
|
- if @account.local? && @account.user_approved?
|
|
= link_to t('admin.accounts.warn'), new_admin_account_action_path(@account.id, type: 'none'), class: 'button' if can?(:warn, @account)
|
|
- if @account.silenced?
|
|
= link_to t('admin.accounts.undo_silenced'), unsilence_admin_account_path(@account.id), method: :post, class: 'button' if can?(:unsilence, @account)
|
|
- elsif !@account.local? || @account.user_approved?
|
|
= link_to t('admin.accounts.silence'), new_admin_account_action_path(@account.id, type: 'silence'), class: 'button button--destructive' if can?(:silence, @account)
|
|
|
|
- if @account.local?
|
|
- if @account.user_pending?
|
|
= link_to t('admin.accounts.approve'), approve_admin_account_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') }, class: 'button' if can?(:approve, @account.user)
|
|
= link_to t('admin.accounts.reject'), reject_admin_account_path(@account.id), method: :post, data: { confirm: t('admin.accounts.are_you_sure') }, class: 'button button--destructive' if can?(:reject, @account.user)
|
|
|
|
- unless @account.user_confirmed?
|
|
= link_to t('admin.accounts.confirm'), admin_account_confirmation_path(@account.id), method: :post, class: 'button' if can?(:confirm, @account.user)
|
|
|
|
- if @account.suspended?
|
|
= link_to t('admin.accounts.undo_suspension'), unsuspend_admin_account_path(@account.id), method: :post, class: 'button' if can?(:unsuspend, @account)
|
|
- elsif !@account.local? || @account.user_approved?
|
|
= link_to t('admin.accounts.perform_full_suspension'), new_admin_account_action_path(@account.id, type: 'suspend'), class: 'button button--destructive' if can?(:suspend, @account)
|
|
|
|
- unless @account.local?
|
|
- if DomainBlock.rule_for(@account.domain)
|
|
= link_to t('admin.domain_blocks.view'), admin_instance_path(@account.domain), class: 'button'
|
|
- else
|
|
= link_to t('admin.domain_blocks.add_new'), new_admin_domain_block_path(_domain: @account.domain), class: 'button button--destructive'
|
|
|
|
%hr.spacer/
|
|
|
|
- unless @warnings.empty?
|
|
= render @warnings
|
|
|
|
%hr.spacer/
|
|
|
|
= render @moderation_notes
|
|
|
|
= simple_form_for @account_moderation_note, url: admin_account_moderation_notes_path do |f|
|
|
= render 'shared/error_messages', object: @account_moderation_note
|
|
|
|
= f.input :content, placeholder: t('admin.reports.notes.placeholder'), rows: 6
|
|
= f.hidden_field :target_account_id
|
|
|
|
.actions
|
|
= f.button :button, t('admin.account_moderation_notes.create'), type: :submit
|