mirror of
https://github.com/lunaisnotaboy/mastodon.git
synced 2025-01-25 05:59:18 +00:00
67e77f230e
Conflicts: app/serializers/initial_state_serializer.rb The glitch flavour isn't yet pulling custom emoji data on its own (see https://github.com/tootsuite/mastodon/pull/7047). Once that gets into the glitch flavour, we can eliminate the custom_emojis load.
111 lines
3.4 KiB
Ruby
111 lines
3.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class UserSettingsDecorator
|
|
attr_reader :user, :settings
|
|
|
|
def initialize(user)
|
|
@user = user
|
|
end
|
|
|
|
def update(settings)
|
|
@settings = settings
|
|
process_update
|
|
end
|
|
|
|
private
|
|
|
|
def process_update
|
|
user.settings['notification_emails'] = merged_notification_emails if change?('notification_emails')
|
|
user.settings['interactions'] = merged_interactions if change?('interactions')
|
|
user.settings['default_privacy'] = default_privacy_preference if change?('setting_default_privacy')
|
|
user.settings['default_sensitive'] = default_sensitive_preference if change?('setting_default_sensitive')
|
|
user.settings['unfollow_modal'] = unfollow_modal_preference if change?('setting_unfollow_modal')
|
|
user.settings['boost_modal'] = boost_modal_preference if change?('setting_boost_modal')
|
|
user.settings['favourite_modal'] = favourite_modal_preference if change?('setting_favourite_modal')
|
|
user.settings['delete_modal'] = delete_modal_preference if change?('setting_delete_modal')
|
|
user.settings['auto_play_gif'] = auto_play_gif_preference if change?('setting_auto_play_gif')
|
|
user.settings['display_sensitive_media'] = display_sensitive_media_preference if change?('setting_display_sensitive_media')
|
|
user.settings['reduce_motion'] = reduce_motion_preference if change?('setting_reduce_motion')
|
|
user.settings['system_font_ui'] = system_font_ui_preference if change?('setting_system_font_ui')
|
|
user.settings['noindex'] = noindex_preference if change?('setting_noindex')
|
|
user.settings['flavour'] = flavour_preference if change?('setting_flavour')
|
|
user.settings['skin'] = skin_preference if change?('setting_skin')
|
|
end
|
|
|
|
def merged_notification_emails
|
|
user.settings['notification_emails'].merge coerced_settings('notification_emails').to_h
|
|
end
|
|
|
|
def merged_interactions
|
|
user.settings['interactions'].merge coerced_settings('interactions').to_h
|
|
end
|
|
|
|
def default_privacy_preference
|
|
settings['setting_default_privacy']
|
|
end
|
|
|
|
def default_sensitive_preference
|
|
boolean_cast_setting 'setting_default_sensitive'
|
|
end
|
|
|
|
def unfollow_modal_preference
|
|
boolean_cast_setting 'setting_unfollow_modal'
|
|
end
|
|
|
|
def boost_modal_preference
|
|
boolean_cast_setting 'setting_boost_modal'
|
|
end
|
|
|
|
def favourite_modal_preference
|
|
boolean_cast_setting 'setting_favourite_modal'
|
|
end
|
|
|
|
def delete_modal_preference
|
|
boolean_cast_setting 'setting_delete_modal'
|
|
end
|
|
|
|
def system_font_ui_preference
|
|
boolean_cast_setting 'setting_system_font_ui'
|
|
end
|
|
|
|
def auto_play_gif_preference
|
|
boolean_cast_setting 'setting_auto_play_gif'
|
|
end
|
|
|
|
def display_sensitive_media_preference
|
|
boolean_cast_setting 'setting_display_sensitive_media'
|
|
end
|
|
|
|
def reduce_motion_preference
|
|
boolean_cast_setting 'setting_reduce_motion'
|
|
end
|
|
|
|
def noindex_preference
|
|
boolean_cast_setting 'setting_noindex'
|
|
end
|
|
|
|
def flavour_preference
|
|
settings['setting_flavour']
|
|
end
|
|
|
|
def skin_preference
|
|
settings['setting_skin']
|
|
end
|
|
|
|
def boolean_cast_setting(key)
|
|
ActiveModel::Type::Boolean.new.cast(settings[key])
|
|
end
|
|
|
|
def coerced_settings(key)
|
|
coerce_values settings.fetch(key, {})
|
|
end
|
|
|
|
def coerce_values(params_hash)
|
|
params_hash.transform_values { |x| ActiveModel::Type::Boolean.new.cast(x) }
|
|
end
|
|
|
|
def change?(key)
|
|
!settings[key].nil?
|
|
end
|
|
end
|