Conflicts:
- `.github/dependabot.yml`:
  Updated upstream, we deleted it to not be flooded by Depandabot.
  Kept deleted.
- `Gemfile.lock`:
  Puma updated on both sides, went for the most recent version.
- `app/controllers/api/v1/mutes_controller.rb`:
  Upstream updated the serializer to support timed mutes, while
  glitch-soc added a custom API ages ago to get information that
  is already available elsewhere.
  Dropped the glitch-soc-specific API, went with upstream changes.
- `app/javascript/core/admin.js`:
  Conflict due to changing how assets are loaded. Went with upstream.
- `app/javascript/packs/public.js`:
  Conflict due to changing how assets are loaded. Went with upstream.
- `app/models/mute.rb`:
  🤷
- `app/models/user.rb`:
  New user setting added upstream while we have glitch-soc-specific
  user settings. Added upstream's user setting.
- `config/settings.yml`:
  Upstream added a new user setting close to a user setting we had
  changed the defaults for. Added the new upstream setting.
- `package.json`:
  Upstream dependency updated “too close” to a glitch-soc-specific
  dependency. No real conflict. Updated the dependency.
		
	
			
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
class Settings::PreferencesController < Settings::BaseController
 | 
						|
  def show; end
 | 
						|
 | 
						|
  def update
 | 
						|
    user_settings.update(user_settings_params.to_h)
 | 
						|
 | 
						|
    if current_user.update(user_params)
 | 
						|
      I18n.locale = current_user.locale
 | 
						|
      redirect_to after_update_redirect_path, notice: I18n.t('generic.changes_saved_msg')
 | 
						|
    else
 | 
						|
      render :show
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  private
 | 
						|
 | 
						|
  def after_update_redirect_path
 | 
						|
    settings_preferences_path
 | 
						|
  end
 | 
						|
 | 
						|
  def user_settings
 | 
						|
    UserSettingsDecorator.new(current_user)
 | 
						|
  end
 | 
						|
 | 
						|
  def user_params
 | 
						|
    params.require(:user).permit(
 | 
						|
      :locale,
 | 
						|
      chosen_languages: []
 | 
						|
    )
 | 
						|
  end
 | 
						|
 | 
						|
  def user_settings_params
 | 
						|
    params.require(:user).permit(
 | 
						|
      :setting_default_privacy,
 | 
						|
      :setting_default_sensitive,
 | 
						|
      :setting_default_language,
 | 
						|
      :setting_unfollow_modal,
 | 
						|
      :setting_boost_modal,
 | 
						|
      :setting_favourite_modal,
 | 
						|
      :setting_delete_modal,
 | 
						|
      :setting_auto_play_gif,
 | 
						|
      :setting_display_media,
 | 
						|
      :setting_expand_spoilers,
 | 
						|
      :setting_reduce_motion,
 | 
						|
      :setting_disable_swiping,
 | 
						|
      :setting_system_font_ui,
 | 
						|
      :setting_system_emoji_font,
 | 
						|
      :setting_noindex,
 | 
						|
      :setting_hide_network,
 | 
						|
      :setting_hide_followers_count,
 | 
						|
      :setting_aggregate_reblogs,
 | 
						|
      :setting_show_application,
 | 
						|
      :setting_advanced_layout,
 | 
						|
      :setting_default_content_type,
 | 
						|
      :setting_use_blurhash,
 | 
						|
      :setting_use_pending_items,
 | 
						|
      :setting_trends,
 | 
						|
      :setting_crop_images,
 | 
						|
      notification_emails: %i(follow follow_request reblog favourite mention digest report pending_account trending_tag),
 | 
						|
      interactions: %i(must_be_follower must_be_following must_be_following_dm)
 | 
						|
    )
 | 
						|
  end
 | 
						|
end
 |