Allow users to delete their header and avatar (#13234)
This is achieved by sending a DELETE request to
/settings/profile/pictures/{avatar,header} via a link that is part of
the upload form's hint of the respective picture.
			
			
This commit is contained in:
		
							parent
							
								
									29f5353f8b
								
							
						
					
					
						commit
						679980f77c
					
				
					 4 changed files with 51 additions and 3 deletions
				
			
		
							
								
								
									
										37
									
								
								app/controllers/settings/pictures_controller.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								app/controllers/settings/pictures_controller.rb
									
									
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,37 @@
 | 
			
		|||
# frozen_string_literal: true
 | 
			
		||||
 | 
			
		||||
module Settings
 | 
			
		||||
  class PicturesController < BaseController
 | 
			
		||||
    before_action :authenticate_user!
 | 
			
		||||
    before_action :set_account
 | 
			
		||||
    before_action :set_picture
 | 
			
		||||
 | 
			
		||||
    def destroy
 | 
			
		||||
      if valid_picture
 | 
			
		||||
        account_params = {
 | 
			
		||||
          @picture => nil,
 | 
			
		||||
          (@picture + '_remote_url') => nil,
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        msg = UpdateAccountService.new.call(@account, account_params) ? I18n.t('generic.changes_saved_msg') : nil
 | 
			
		||||
        redirect_to settings_profile_path, notice: msg, status: 303
 | 
			
		||||
      else
 | 
			
		||||
        bad_request
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    private
 | 
			
		||||
 | 
			
		||||
    def set_account
 | 
			
		||||
      @account = current_account
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def set_picture
 | 
			
		||||
      @picture = params[:id]
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def valid_picture
 | 
			
		||||
      @picture == 'avatar' || @picture == 'header'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			@ -105,4 +105,13 @@ module SettingsHelper
 | 
			
		|||
      safe_join([image_tag(account.avatar.url, width: 15, height: 15, alt: display_name(account), class: 'avatar'), content_tag(:span, account.acct, class: 'username')], ' ')
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def picture_hint(hint, picture)
 | 
			
		||||
    if picture.original_filename.nil?
 | 
			
		||||
      hint
 | 
			
		||||
    else
 | 
			
		||||
      link = link_to t('generic.delete'), settings_profile_picture_path(picture.name.to_s), data: { method: :delete }
 | 
			
		||||
      safe_join([hint, link], '<br/>'.html_safe)
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -17,9 +17,9 @@
 | 
			
		|||
      = render 'application/card', account: @account
 | 
			
		||||
 | 
			
		||||
    .fields-row__column.fields-group.fields-row__column-6
 | 
			
		||||
      = f.input :header, wrapper: :with_label, input_html: { accept: AccountHeader::IMAGE_MIME_TYPES.join(',') }, hint: t('simple_form.hints.defaults.header', dimensions: '1500x500', size: number_to_human_size(AccountHeader::LIMIT))
 | 
			
		||||
      = f.input :header, wrapper: :with_label, input_html: { accept: AccountHeader::IMAGE_MIME_TYPES.join(',') }, hint: picture_hint(t('simple_form.hints.defaults.header', dimensions: '1500x500', size: number_to_human_size(AccountHeader::LIMIT)), @account.header)
 | 
			
		||||
 | 
			
		||||
      = f.input :avatar, wrapper: :with_label, input_html: { accept: AccountAvatar::IMAGE_MIME_TYPES.join(',') }, hint: t('simple_form.hints.defaults.avatar', dimensions: '400x400', size: number_to_human_size(AccountAvatar::LIMIT))
 | 
			
		||||
      = f.input :avatar, wrapper: :with_label, input_html: { accept: AccountAvatar::IMAGE_MIME_TYPES.join(',') }, hint: picture_hint(t('simple_form.hints.defaults.avatar', dimensions: '400x400', size: number_to_human_size(AccountAvatar::LIMIT)), @account.avatar)
 | 
			
		||||
 | 
			
		||||
  %hr.spacer/
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -100,7 +100,9 @@ Rails.application.routes.draw do
 | 
			
		|||
  get '/settings', to: redirect('/settings/profile')
 | 
			
		||||
 | 
			
		||||
  namespace :settings do
 | 
			
		||||
    resource :profile, only: [:show, :update]
 | 
			
		||||
    resource :profile, only: [:show, :update] do
 | 
			
		||||
      resources :pictures, only: :destroy
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    get :preferences, to: redirect('/settings/preferences/appearance')
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue