summaryrefslogtreecommitdiffstats
path: root/app/helpers/accounts_helper.rb
diff options
context:
space:
mode:
authorTakeshi Umeda <noel.yoshiba@gmail.com>2019-10-25 05:50:09 +0900
committerEugen Rochko <eugen@zeonfederated.com>2019-10-24 22:50:09 +0200
commita6269b2f83e3eed1a8ab545f5756cd7b582075f5 (patch)
tree5f8ce4899be4f972f9b255e86bff4d17544368c7 /app/helpers/accounts_helper.rb
parenta9530e29a2813ed8cf4c8f13fe60dd9fad245466 (diff)
Split AccountsHelper from StatusesHelper (#12078)
Diffstat (limited to 'app/helpers/accounts_helper.rb')
-rw-r--r--app/helpers/accounts_helper.rb106
1 files changed, 106 insertions, 0 deletions
diff --git a/app/helpers/accounts_helper.rb b/app/helpers/accounts_helper.rb
new file mode 100644
index 00000000000..5b060a18170
--- /dev/null
+++ b/app/helpers/accounts_helper.rb
@@ -0,0 +1,106 @@
+# frozen_string_literal: true
+
+module AccountsHelper
+ def display_name(account, **options)
+ if options[:custom_emojify]
+ Formatter.instance.format_display_name(account, options)
+ else
+ account.display_name.presence || account.username
+ end
+ end
+
+ def acct(account)
+ if account.local?
+ "@#{account.acct}@#{Rails.configuration.x.local_domain}"
+ else
+ "@#{account.acct}"
+ end
+ end
+
+ def account_action_button(account)
+ if user_signed_in?
+ if account.id == current_user.account_id
+ link_to settings_profile_url, class: 'button logo-button' do
+ safe_join([svg_logo, t('settings.edit_profile')])
+ end
+ elsif current_account.following?(account) || current_account.requested?(account)
+ link_to account_unfollow_path(account), class: 'button logo-button button--destructive', data: { method: :post } do
+ safe_join([svg_logo, t('accounts.unfollow')])
+ end
+ elsif !(account.memorial? || account.moved?)
+ link_to account_follow_path(account), class: "button logo-button#{account.blocking?(current_account) ? ' disabled' : ''}", data: { method: :post } do
+ safe_join([svg_logo, t('accounts.follow')])
+ end
+ end
+ elsif !(account.memorial? || account.moved?)
+ link_to account_remote_follow_path(account), class: 'button logo-button modal-button', target: '_new' do
+ safe_join([svg_logo, t('accounts.follow')])
+ end
+ end
+ end
+
+ def minimal_account_action_button(account)
+ if user_signed_in?
+ return if account.id == current_user.account_id
+
+ if current_account.following?(account) || current_account.requested?(account)
+ link_to account_unfollow_path(account), class: 'icon-button active', data: { method: :post }, title: t('accounts.unfollow') do
+ fa_icon('user-times fw')
+ end
+ elsif !(account.memorial? || account.moved?)
+ link_to account_follow_path(account), class: "icon-button#{account.blocking?(current_account) ? ' disabled' : ''}", data: { method: :post }, title: t('accounts.follow') do
+ fa_icon('user-plus fw')
+ end
+ end
+ elsif !(account.memorial? || account.moved?)
+ link_to account_remote_follow_path(account), class: 'icon-button modal-button', target: '_new', title: t('accounts.follow') do
+ fa_icon('user-plus fw')
+ end
+ end
+ end
+
+ def account_badge(account, all: false)
+ if account.bot?
+ content_tag(:div, content_tag(:div, t('accounts.roles.bot'), class: 'account-role bot'), class: 'roles')
+ elsif (Setting.show_staff_badge && account.user_staff?) || all
+ content_tag(:div, class: 'roles') do
+ if all && !account.user_staff?
+ content_tag(:div, t('admin.accounts.roles.user'), class: 'account-role')
+ elsif account.user_admin?
+ content_tag(:div, t('accounts.roles.admin'), class: 'account-role admin')
+ elsif account.user_moderator?
+ content_tag(:div, t('accounts.roles.moderator'), class: 'account-role moderator')
+ end
+ end
+ end
+ end
+
+ def account_description(account)
+ prepend_str = [
+ [
+ number_to_human(account.statuses_count, strip_insignificant_zeros: true),
+ I18n.t('accounts.posts', count: account.statuses_count),
+ ].join(' '),
+
+ [
+ number_to_human(account.following_count, strip_insignificant_zeros: true),
+ I18n.t('accounts.following', count: account.following_count),
+ ].join(' '),
+
+ [
+ number_to_human(account.followers_count, strip_insignificant_zeros: true),
+ I18n.t('accounts.followers', count: account.followers_count),
+ ].join(' '),
+ ].join(', ')
+
+ [prepend_str, account.note].join(' · ')
+ end
+
+ def svg_logo
+ content_tag(:svg, tag(:use, 'xlink:href' => '#mastodon-svg-logo'), 'viewBox' => '0 0 216.4144 232.00976')
+ end
+
+ def svg_logo_full
+ content_tag(:svg, tag(:use, 'xlink:href' => '#mastodon-svg-logo-full'), 'viewBox' => '0 0 713.35878 175.8678')
+ end
+end