mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-15 21:44:06 +01:00
f26f1145ac
Conflicts: Dockerfile app/javascript/packs/common.js config/webpack/loaders/sass.js config/webpack/shared.js db/schema.rb package.json yarn.lock A lot of the conflicts come from updating webpack. Even though upstream deleted app/javascript/packs/common.js, I kept glitch-soc's version as it unifies JS/CSS packs behavior across flavours. Ported glitch changes to webpack 4.x
64 lines
2.5 KiB
Ruby
64 lines
2.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class InitialStateSerializer < ActiveModel::Serializer
|
|
attributes :meta, :compose, :accounts,
|
|
:media_attachments, :settings,
|
|
:max_toot_chars
|
|
|
|
has_one :push_subscription, serializer: REST::WebPushSubscriptionSerializer
|
|
|
|
def max_toot_chars
|
|
StatusLengthValidator::MAX_CHARS
|
|
end
|
|
|
|
def meta
|
|
store = {
|
|
streaming_api_base_url: Rails.configuration.x.streaming_api_base_url,
|
|
access_token: object.token,
|
|
locale: I18n.locale,
|
|
domain: Rails.configuration.x.local_domain,
|
|
admin: object.admin&.id&.to_s,
|
|
search_enabled: Chewy.enabled?,
|
|
version: Mastodon::Version.to_s,
|
|
invites_enabled: Setting.min_invite_role == 'user',
|
|
}
|
|
|
|
if object.current_account
|
|
store[:me] = object.current_account.id.to_s
|
|
store[:unfollow_modal] = object.current_account.user.setting_unfollow_modal
|
|
store[:boost_modal] = object.current_account.user.setting_boost_modal
|
|
store[:favourite_modal] = object.current_account.user.setting_favourite_modal
|
|
store[:delete_modal] = object.current_account.user.setting_delete_modal
|
|
store[:auto_play_gif] = object.current_account.user.setting_auto_play_gif
|
|
store[:display_sensitive_media] = object.current_account.user.setting_display_sensitive_media
|
|
store[:reduce_motion] = object.current_account.user.setting_reduce_motion
|
|
end
|
|
|
|
store
|
|
end
|
|
|
|
def compose
|
|
store = {}
|
|
|
|
if object.current_account
|
|
store[:me] = object.current_account.id.to_s
|
|
store[:default_privacy] = object.current_account.user.setting_default_privacy
|
|
store[:default_sensitive] = object.current_account.user.setting_default_sensitive
|
|
end
|
|
|
|
store[:text] = object.text if object.text
|
|
|
|
store
|
|
end
|
|
|
|
def accounts
|
|
store = {}
|
|
store[object.current_account.id.to_s] = ActiveModelSerializers::SerializableResource.new(object.current_account, serializer: REST::AccountSerializer) if object.current_account
|
|
store[object.admin.id.to_s] = ActiveModelSerializers::SerializableResource.new(object.admin, serializer: REST::AccountSerializer) if object.admin
|
|
store
|
|
end
|
|
|
|
def media_attachments
|
|
{ accept_content_types: MediaAttachment::IMAGE_FILE_EXTENSIONS + MediaAttachment::VIDEO_FILE_EXTENSIONS + MediaAttachment::AUDIO_FILE_EXTENSIONS + MediaAttachment::IMAGE_MIME_TYPES + MediaAttachment::VIDEO_MIME_TYPES + MediaAttachment::AUDIO_MIME_TYPES }
|
|
end
|
|
end
|