mirror of
https://github.com/funamitech/mastodon
synced 2025-01-07 10:23:57 +09:00
7c48688d85
* Do not animate account header art if user's GIF autoplay setting is off Fixes #9472 * Honour currently logged-in user's GIF autoplay setting for account avatars Fixes #9467 * Fix avatar display on some public pages when data is stored on a different host * Use ternary operator instead of if/else for avatar/header URL
60 lines
2.3 KiB
Ruby
60 lines
2.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module HomeHelper
|
|
def default_props
|
|
{
|
|
locale: I18n.locale,
|
|
}
|
|
end
|
|
|
|
def account_link_to(account, button = '', size: 36, path: nil)
|
|
content_tag(:div, class: 'account') do
|
|
content_tag(:div, class: 'account__wrapper') do
|
|
section = if account.nil?
|
|
content_tag(:div, class: 'account__display-name') do
|
|
content_tag(:div, class: 'account__avatar-wrapper') do
|
|
content_tag(:div, '', class: 'account__avatar', style: "width: #{size}px; height: #{size}px; background-size: #{size}px #{size}px; background-image: url(#{full_asset_url('avatars/original/missing.png', skip_pipeline: true)})")
|
|
end +
|
|
content_tag(:span, class: 'display-name') do
|
|
content_tag(:strong, t('about.contact_missing')) +
|
|
content_tag(:span, t('about.contact_unavailable'), class: 'display-name__account')
|
|
end
|
|
end
|
|
else
|
|
link_to(path || TagManager.instance.url_for(account), class: 'account__display-name') do
|
|
content_tag(:div, class: 'account__avatar-wrapper') do
|
|
content_tag(:div, '', class: 'account__avatar', style: "width: #{size}px; height: #{size}px; background-size: #{size}px #{size}px; background-image: url(#{full_asset_url(current_account&.user&.setting_auto_play_gif ? account.avatar_original_url : account.avatar_static_url)})")
|
|
end +
|
|
content_tag(:span, class: 'display-name') do
|
|
content_tag(:bdi) do
|
|
content_tag(:strong, display_name(account, custom_emojify: true), class: 'display-name__html emojify')
|
|
end +
|
|
content_tag(:span, "@#{account.acct}", class: 'display-name__account')
|
|
end
|
|
end
|
|
end
|
|
|
|
section + button
|
|
end
|
|
end
|
|
end
|
|
|
|
def obscured_counter(count)
|
|
if count <= 0
|
|
0
|
|
elsif count == 1
|
|
1
|
|
else
|
|
'1+'
|
|
end
|
|
end
|
|
|
|
def custom_field_classes(field)
|
|
if field.verified?
|
|
'verified'
|
|
else
|
|
'emojify'
|
|
end
|
|
end
|
|
end
|