Replace OEmbed and initial state Rabl templates with serializers (#4110)
* Replace OEmbed Rabl template with serializer * Replace initial state rabl with serializermaster
parent
102466ac58
commit
864e3f8d9c
@ -0,0 +1,5 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class InitialStatePresenter < ActiveModelSerializers::Model |
||||
attributes :settings, :token, :current_account, :admin |
||||
end |
@ -0,0 +1,39 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class InitialStateSerializer < ActiveModel::Serializer |
||||
attributes :meta, :compose, :accounts, |
||||
:media_attachments, :settings |
||||
|
||||
def meta |
||||
{ |
||||
streaming_api_base_url: Rails.configuration.x.streaming_api_base_url, |
||||
access_token: object.token, |
||||
locale: I18n.locale, |
||||
domain: Rails.configuration.x.local_domain, |
||||
me: object.current_account.id, |
||||
admin: object.admin&.id, |
||||
boost_modal: object.current_account.user.setting_boost_modal, |
||||
delete_modal: object.current_account.user.setting_delete_modal, |
||||
auto_play_gif: object.current_account.user.setting_auto_play_gif, |
||||
system_font_ui: object.current_account.user.setting_system_font_ui, |
||||
} |
||||
end |
||||
|
||||
def compose |
||||
{ |
||||
me: object.current_account.id, |
||||
default_privacy: object.current_account.user.setting_default_privacy, |
||||
} |
||||
end |
||||
|
||||
def accounts |
||||
store = {} |
||||
store[object.current_account.id] = ActiveModelSerializers::SerializableResource.new(object.current_account, serializer: REST::AccountSerializer) |
||||
store[object.admin.id] = ActiveModelSerializers::SerializableResource.new(object.admin, serializer: REST::AccountSerializer) unless object.admin.nil? |
||||
store |
||||
end |
||||
|
||||
def media_attachments |
||||
{ accept_content_types: MediaAttachment::IMAGE_MIME_TYPES + MediaAttachment::VIDEO_MIME_TYPES } |
||||
end |
||||
end |
@ -0,0 +1,56 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class OEmbedSerializer < ActiveModel::Serializer |
||||
include RoutingHelper |
||||
include ActionView::Helpers::TagHelper |
||||
|
||||
attributes :type, :version, :title, :author_name, |
||||
:author_url, :provider_name, :provider_url, |
||||
:cache_age, :html, :width, :height |
||||
|
||||
def type |
||||
'rich' |
||||
end |
||||
|
||||
def version |
||||
'1.0' |
||||
end |
||||
|
||||
def author_name |
||||
object.account.display_name.presence || object.account.username |
||||
end |
||||
|
||||
def author_url |
||||
account_url(object.account) |
||||
end |
||||
|
||||
def provider_name |
||||
Rails.configuration.x.local_domain |
||||
end |
||||
|
||||
def provider_url |
||||
root_url |
||||
end |
||||
|
||||
def cache_age |
||||
86_400 |
||||
end |
||||
|
||||
def html |
||||
tag :iframe, |
||||
src: embed_account_stream_entry_url(object.account, object), |
||||
style: 'width: 100%; overflow: hidden', |
||||
frameborder: '0', |
||||
scrolling: 'no', |
||||
width: width, |
||||
height: height |
||||
end |
||||
|
||||
def width |
||||
instance_options[:width] |
||||
end |
||||
|
||||
def height |
||||
instance_options[:height] |
||||
end |
||||
end |
@ -1,14 +0,0 @@ |
||||
# frozen_string_literal: true |
||||
object @stream_entry |
||||
|
||||
node(:type) { 'rich' } |
||||
node(:version) { '1.0' } |
||||
node(:title, &:title) |
||||
node(:author_name) { |entry| entry.account.display_name.blank? ? entry.account.username : entry.account.display_name } |
||||
node(:author_url) { |entry| account_url(entry.account) } |
||||
node(:provider_name) { site_hostname } |
||||
node(:provider_url) { root_url } |
||||
node(:cache_age) { 86_400 } |
||||
node(:html) { |entry| "<iframe src=\"#{embed_account_stream_entry_url(entry.account, entry)}\" style=\"width: 100%; overflow: hidden\" frameborder=\"0\" width=\"#{@width}\" height=\"#{@height}\" scrolling=\"no\"></iframe>" } |
||||
node(:width) { @width } |
||||
node(:height) { @height } |
@ -1,38 +0,0 @@ |
||||
object false |
||||
|
||||
node(:meta) do |
||||
{ |
||||
streaming_api_base_url: @streaming_api_base_url, |
||||
access_token: @token, |
||||
locale: I18n.locale, |
||||
domain: site_hostname, |
||||
me: current_account.id, |
||||
admin: @admin.try(:id), |
||||
boost_modal: current_account.user.setting_boost_modal, |
||||
delete_modal: current_account.user.setting_delete_modal, |
||||
auto_play_gif: current_account.user.setting_auto_play_gif, |
||||
system_font_ui: current_account.user.setting_system_font_ui, |
||||
} |
||||
end |
||||
|
||||
node(:compose) do |
||||
{ |
||||
me: current_account.id, |
||||
default_privacy: current_account.user.setting_default_privacy, |
||||
} |
||||
end |
||||
|
||||
node(:accounts) do |
||||
store = {} |
||||
store[current_account.id] = ActiveModelSerializers::SerializableResource.new(current_account, serializer: REST::AccountSerializer) |
||||
store[@admin.id] = ActiveModelSerializers::SerializableResource.new(@admin, serializer: REST::AccountSerializer) unless @admin.nil? |
||||
store |
||||
end |
||||
|
||||
node(:media_attachments) do |
||||
{ |
||||
accept_content_types: MediaAttachment::IMAGE_MIME_TYPES + MediaAttachment::VIDEO_MIME_TYPES |
||||
} |
||||
end |
||||
|
||||
node(:settings) { @web_settings } |
Loading…
Reference in new issue