Migrate glitch-soc's exclusive user settings

This commit is contained in:
Claire
2023-03-31 21:37:57 +02:00
parent 01d6f7529f
commit 3dcba94e68
6 changed files with 103 additions and 17 deletions

View File

@ -21,18 +21,8 @@ class Settings::FlavoursController < Settings::BaseController
end
def update
user_settings.update(user_settings_params)
current_user.settings.update(flavour: params.require(:flavour), skin: params.dig(:user, :setting_skin))
current_user.save
redirect_to action: 'show', flavour: params[:flavour]
end
private
def user_settings
UserSettingsDecorator.new(current_user)
end
def user_settings_params
{ setting_flavour: params.require(:flavour),
setting_skin: params.dig(:user, :setting_skin) }.with_indifferent_access
end
end

View File

@ -28,7 +28,7 @@ module AccountsHelper
end
def hide_followers_count?(account)
Setting.hide_followers_count || account.user&.setting_hide_followers_count
Setting.hide_followers_count || account.user&.settings['hide_followers_count']
end
def account_description(account)

View File

@ -39,6 +39,10 @@ module HasUserSettings
settings['web.delete_modal']
end
def setting_favourite_modal
settings['web.favourite_modal']
end
def setting_reduce_motion
settings['web.reduce_motion']
end
@ -47,12 +51,20 @@ module HasUserSettings
settings['web.use_system_font']
end
def setting_system_emoji_font
settings['web.use_system_emoji_font']
end
def setting_noindex
settings['noindex']
end
def setting_theme
settings['theme']
def setting_flavour
settings['flavour']
end
def setting_skin
settings['skin']
end
def setting_display_media
@ -107,6 +119,14 @@ module HasUserSettings
settings['default_privacy'] || (account.locked? ? 'private' : 'public')
end
def setting_default_content_type
settings['default_content_type']
end
def setting_hide_followers_count
settings['hide_followers_count']
end
def allows_report_emails?
settings['notification_emails.report']
end
@ -123,6 +143,18 @@ module HasUserSettings
settings['notification_emails.trends']
end
def allows_trending_tags_review_emails?
settings['notification_emails.trends']
end
def allows_trending_links_review_emails?
settings['notification_emails.link_trends']
end
def allows_trending_statuses_review_emails?
settings['notification_emails.status_trends']
end
def aggregates_reblogs?
settings['aggregate_reblogs']
end

View File

@ -9,12 +9,15 @@ class UserSettings
setting :always_send_emails, default: false
setting :aggregate_reblogs, default: true
setting :theme, default: -> { ::Setting.theme }
setting :flavour, default: -> { ::Setting.flavour }
setting :skin, default: -> { ::Setting.skin }
setting :noindex, default: -> { ::Setting.noindex }
setting :show_application, default: true
setting :default_language, default: nil
setting :default_sensitive, default: false
setting :default_privacy, default: nil
setting :default_content_type, default: 'text/plain'
setting :hide_followers_count, default: false
namespace :web do
setting :crop_images, default: true
@ -27,10 +30,12 @@ class UserSettings
setting :delete_modal, default: true
setting :reblog_modal, default: false
setting :unfollow_modal, default: true
setting :favourite_modal, default: false
setting :reduce_motion, default: false
setting :expand_content_warnings, default: false
setting :display_media, default: 'default', in: %w(default show_all hide_all)
setting :auto_play, default: false
setting :use_system_emoji_font, default: false
end
namespace :notification_emails do
@ -42,6 +47,8 @@ class UserSettings
setting :report, default: true
setting :pending_account, default: true
setting :trends, default: true
setting :link_trends, default: false
setting :status_trends, default: false
setting :appeal, default: true
end