Fix end-user-facing uses of inline CSS (#13438)
* Move some inline styles to CSS files * Move default_account_display_name span to fix useless tags with duplicate id * Change handling of public pages spoiler text from inline CSS to dataset attribute * Use the `dir` HTML attribute instead of inline CSS * Move status action bar inline CSS to CSS file * Hide logo resources from CSS file, not inline CSS Fixes #11601 * Move translation prompt styling from inline CSS to CSS file * Move “invited by” styling on registration form from inline to CSS file * Use the progress tag to display poll results in JS fallback * Fix poll results JS-less fallback when the user has voted for an option * Change account public page “moved” notice to use img tags instead of inline CSS * Move OTP hint inline CSS to SCSS file * Hide JS-less fallback vote progressbars from accessibility tools Co-authored-by: Eugen Rochko <eugen@zeonfederated.com>
This commit is contained in:
		| @ -15,12 +15,12 @@ | ||||
|  | ||||
|   = account_action_button(status.account) | ||||
|  | ||||
|   .status__content.emojify< | ||||
|   .status__content.emojify{ :data => ({ spoiler: current_account&.user&.setting_expand_spoilers ? 'expanded' : 'folded' } if status.spoiler_text?) }< | ||||
|     - if status.spoiler_text? | ||||
|       %p{ :style => ('margin-bottom: 0' unless current_account&.user&.setting_expand_spoilers) }< | ||||
|       %p< | ||||
|         %span.p-summary> #{Formatter.instance.format_spoiler(status, autoplay: autoplay)}  | ||||
|         %button.status__content__spoiler-link= t('statuses.show_more') | ||||
|     .e-content{ style: "display: #{!current_account&.user&.setting_expand_spoilers && status.spoiler_text? ? 'none' : 'block'}; direction: #{rtl_status?(status) ? 'rtl' : 'ltr'}" } | ||||
|     .e-content{ dir: rtl_status?(status) ? 'rtl' : 'ltr' } | ||||
|       = Formatter.instance.format(status, custom_emojify: true, autoplay: autoplay) | ||||
|       - if status.preloadable_poll | ||||
|         = react_component :poll, disabled: true, poll: ActiveModelSerializers::SerializableResource.new(status.preloadable_poll, serializer: REST::PollSerializer, scope: current_user, scope_name: :current_user).as_json do | ||||
|  | ||||
| @ -10,13 +10,15 @@ | ||||
|           - percent = total_votes_count > 0 ? 100 * option.votes_count / total_votes_count : 0 | ||||
|           %label.poll__option>< | ||||
|             %span.poll__number>< | ||||
|               - if own_votes.include?(index) | ||||
|                 %i.poll__voted__mark.fa.fa-check | ||||
|               = "#{percent.round}%" | ||||
|             %span.poll__option__text | ||||
|               = Formatter.instance.format_poll_option(status, option, autoplay: autoplay) | ||||
|             - if own_votes.include?(index) | ||||
|               %span.poll__voted | ||||
|                 %i.poll__voted__mark.fa.fa-check | ||||
|  | ||||
|           %span.poll__chart{ style: "width: #{percent}%" } | ||||
|           %progress{ max: 100, value: percent < 1 ? 1 : percent, 'aria-hidden': 'true' } | ||||
|             %span.poll__chart | ||||
|         - else | ||||
|           %label.poll__option>< | ||||
|             %span.poll__input{ class: poll.multiple? ? 'checkbox' : nil}>< | ||||
|  | ||||
| @ -19,12 +19,12 @@ | ||||
|           %span.display-name__account | ||||
|             = acct(status.account) | ||||
|             = fa_icon('lock') if status.account.locked? | ||||
|   .status__content.emojify< | ||||
|   .status__content.emojify{ :data => ({ spoiler: current_account&.user&.setting_expand_spoilers ? 'expanded' : 'folded' } if status.spoiler_text?) }< | ||||
|     - if status.spoiler_text? | ||||
|       %p{ :style => ('margin-bottom: 0' unless current_account&.user&.setting_expand_spoilers) }< | ||||
|       %p< | ||||
|         %span.p-summary> #{Formatter.instance.format_spoiler(status, autoplay: autoplay)}  | ||||
|         %button.status__content__spoiler-link= t('statuses.show_more') | ||||
|     .e-content{ style: "display: #{!current_account&.user&.setting_expand_spoilers && status.spoiler_text? ? 'none' : 'block'}; direction: #{rtl_status?(status) ? 'rtl' : 'ltr'}" } | ||||
|     .e-content{ dir: rtl_status?(status) ? 'rtl' : 'ltr' } | ||||
|       = Formatter.instance.format(status, custom_emojify: true, autoplay: autoplay) | ||||
|       - if status.preloadable_poll | ||||
|         = react_component :poll, disabled: true, poll: ActiveModelSerializers::SerializableResource.new(status.preloadable_poll, serializer: REST::PollSerializer, scope: current_user, scope_name: :current_user).as_json do | ||||
| @ -51,18 +51,18 @@ | ||||
|  | ||||
|   .status__action-bar | ||||
|     .status__action-bar__counter | ||||
|       = link_to remote_interaction_path(status, type: :reply), class: 'status__action-bar-button icon-button modal-button', style: 'font-size: 18px; width: 23.1429px; height: 23.1429px; line-height: 23.15px;' do | ||||
|       = link_to remote_interaction_path(status, type: :reply), class: 'status__action-bar-button icon-button modal-button' do | ||||
|         - if status.in_reply_to_id.nil? | ||||
|           = fa_icon 'reply fw' | ||||
|         - else | ||||
|           = fa_icon 'reply-all fw' | ||||
|       .status__action-bar__counter__label= obscured_counter status.replies_count | ||||
|     = link_to remote_interaction_path(status, type: :reblog), class: 'status__action-bar-button icon-button modal-button', style: 'font-size: 18px; width: 23.1429px; height: 23.1429px; line-height: 23.15px;' do | ||||
|     = link_to remote_interaction_path(status, type: :reblog), class: 'status__action-bar-button icon-button modal-button' do | ||||
|       - if status.distributable? | ||||
|         = fa_icon 'retweet fw' | ||||
|       - elsif status.private_visibility? || status.limited_visibility? | ||||
|         = fa_icon 'lock fw' | ||||
|       - else | ||||
|         = fa_icon 'envelope fw' | ||||
|     = link_to remote_interaction_path(status, type: :favourite), class: 'status__action-bar-button icon-button modal-button', style: 'font-size: 18px; width: 23.1429px; height: 23.1429px; line-height: 23.15px;' do | ||||
|     = link_to remote_interaction_path(status, type: :favourite), class: 'status__action-bar-button icon-button modal-button' do | ||||
|       = fa_icon 'star fw' | ||||
|  | ||||
		Reference in New Issue
	
	Block a user