Merge branch 'master' into glitch-soc/merge-upstream
This commit is contained in:
		
						commit
						98bb6815a7
					
				
					 6 changed files with 49 additions and 11 deletions
				
			
		
							
								
								
									
										4
									
								
								Gemfile
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								Gemfile
									
									
									
									
									
								
							|  | @ -5,7 +5,7 @@ ruby '>= 2.3.0', '< 2.6.0' | |||
| 
 | ||||
| gem 'pkg-config', '~> 1.3' | ||||
| 
 | ||||
| gem 'puma', '~> 3.11' | ||||
| gem 'puma', '~> 3.12' | ||||
| gem 'rails', '~> 5.2.1' | ||||
| gem 'thor', '~> 0.20' | ||||
| 
 | ||||
|  | @ -117,7 +117,7 @@ group :test do | |||
|   gem 'rspec-sidekiq', '~> 3.0' | ||||
|   gem 'simplecov', '~> 0.16', require: false | ||||
|   gem 'webmock', '~> 3.4' | ||||
|   gem 'parallel_tests', '~> 2.21' | ||||
|   gem 'parallel_tests', '~> 2.23' | ||||
| end | ||||
| 
 | ||||
| group :development do | ||||
|  |  | |||
							
								
								
									
										12
									
								
								Gemfile.lock
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								Gemfile.lock
									
									
									
									
									
								
							|  | @ -373,7 +373,7 @@ GEM | |||
|       addressable (~> 2.3) | ||||
|       nokogiri (~> 1.5) | ||||
|       omniauth (~> 1.2) | ||||
|     omniauth-saml (1.10.0) | ||||
|     omniauth-saml (1.10.1) | ||||
|       omniauth (~> 1.3, >= 1.3.2) | ||||
|       ruby-saml (~> 1.7) | ||||
|     orm_adapter (0.5.0) | ||||
|  | @ -392,7 +392,7 @@ GEM | |||
|       av (~> 0.9.0) | ||||
|       paperclip (>= 2.5.2) | ||||
|     parallel (1.12.1) | ||||
|     parallel_tests (2.21.3) | ||||
|     parallel_tests (2.23.0) | ||||
|       parallel | ||||
|     parser (2.5.1.2) | ||||
|       ast (~> 2.4.0) | ||||
|  | @ -421,7 +421,7 @@ GEM | |||
|     pry-rails (0.3.6) | ||||
|       pry (>= 0.10.4) | ||||
|     public_suffix (3.0.3) | ||||
|     puma (3.11.4) | ||||
|     puma (3.12.0) | ||||
|     pundit (1.1.0) | ||||
|       activesupport (>= 3.0.0) | ||||
|     raabro (1.1.6) | ||||
|  | @ -535,7 +535,7 @@ GEM | |||
|       ruby-progressbar (~> 1.7) | ||||
|       unicode-display_width (~> 1.0, >= 1.0.1) | ||||
|     ruby-progressbar (1.9.0) | ||||
|     ruby-saml (1.7.2) | ||||
|     ruby-saml (1.9.0) | ||||
|       nokogiri (>= 1.5.10) | ||||
|     rufus-scheduler (3.5.2) | ||||
|       fugit (~> 1.1, >= 1.1.5) | ||||
|  | @ -724,7 +724,7 @@ DEPENDENCIES | |||
|   ox (~> 2.10) | ||||
|   paperclip (~> 6.0) | ||||
|   paperclip-av-transcoder (~> 0.6) | ||||
|   parallel_tests (~> 2.21) | ||||
|   parallel_tests (~> 2.23) | ||||
|   pg (~> 1.1) | ||||
|   pghero (~> 2.2) | ||||
|   pkg-config (~> 1.3) | ||||
|  | @ -733,7 +733,7 @@ DEPENDENCIES | |||
|   private_address_check (~> 0.5) | ||||
|   pry-byebug (~> 3.6) | ||||
|   pry-rails (~> 0.3) | ||||
|   puma (~> 3.11) | ||||
|   puma (~> 3.12) | ||||
|   pundit (~> 1.1) | ||||
|   rack-attack (~> 5.4) | ||||
|   rack-cors (~> 1.0) | ||||
|  |  | |||
|  | @ -36,6 +36,8 @@ const messages = defineMessages({ | |||
|   redraftConfirm: { id: 'confirmations.redraft.confirm', defaultMessage: 'Delete & redraft' }, | ||||
|   redraftMessage: { id: 'confirmations.redraft.message', defaultMessage: 'Are you sure you want to delete this status and re-draft it? Favourites and boosts will be lost, and replies to the original post will be orphaned.' }, | ||||
|   blockConfirm: { id: 'confirmations.block.confirm', defaultMessage: 'Block' }, | ||||
|   replyConfirm: { id: 'confirmations.reply.confirm', defaultMessage: 'Reply' }, | ||||
|   replyMessage: { id: 'confirmations.reply.message', defaultMessage: 'Replying now will overwrite the message you are currently composing. Are you sure you want to proceed?' }, | ||||
| }); | ||||
| 
 | ||||
| const makeMapStateToProps = () => { | ||||
|  | @ -51,7 +53,18 @@ const makeMapStateToProps = () => { | |||
| const mapDispatchToProps = (dispatch, { intl }) => ({ | ||||
| 
 | ||||
|   onReply (status, router) { | ||||
|     dispatch((_, getState) => { | ||||
|       let state = getState(); | ||||
|       if (state.getIn(['compose', 'text']).trim().length !== 0) { | ||||
|         dispatch(openModal('CONFIRM', { | ||||
|           message: intl.formatMessage(messages.replyMessage), | ||||
|           confirm: intl.formatMessage(messages.replyConfirm), | ||||
|           onConfirm: () => dispatch(replyCompose(status, router)), | ||||
|         })); | ||||
|       } else { | ||||
|         dispatch(replyCompose(status, router)); | ||||
|       } | ||||
|     }); | ||||
|   }, | ||||
| 
 | ||||
|   onModalReblog (status) { | ||||
|  |  | |||
|  | @ -54,6 +54,8 @@ const messages = defineMessages({ | |||
|   revealAll: { id: 'status.show_more_all', defaultMessage: 'Show more for all' }, | ||||
|   hideAll: { id: 'status.show_less_all', defaultMessage: 'Show less for all' }, | ||||
|   detailedStatus: { id: 'status.detailed_status', defaultMessage: 'Detailed conversation view' }, | ||||
|   replyConfirm: { id: 'confirmations.reply.confirm', defaultMessage: 'Reply' }, | ||||
|   replyMessage: { id: 'confirmations.reply.message', defaultMessage: 'Replying now will overwrite the message you are currently composing. Are you sure you want to proceed?' }, | ||||
| }); | ||||
| 
 | ||||
| const makeMapStateToProps = () => { | ||||
|  | @ -98,6 +100,7 @@ const makeMapStateToProps = () => { | |||
|       status, | ||||
|       ancestorsIds, | ||||
|       descendantsIds, | ||||
|       askReplyConfirmation: state.getIn(['compose', 'text']).trim().length !== 0, | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|  | @ -119,6 +122,7 @@ class Status extends ImmutablePureComponent { | |||
|     ancestorsIds: ImmutablePropTypes.list, | ||||
|     descendantsIds: ImmutablePropTypes.list, | ||||
|     intl: PropTypes.object.isRequired, | ||||
|     askReplyConfirmation: PropTypes.bool, | ||||
|   }; | ||||
| 
 | ||||
|   state = { | ||||
|  | @ -157,7 +161,16 @@ class Status extends ImmutablePureComponent { | |||
|   } | ||||
| 
 | ||||
|   handleReplyClick = (status) => { | ||||
|     this.props.dispatch(replyCompose(status, this.context.router.history)); | ||||
|     let { askReplyConfirmation, dispatch, intl } = this.props; | ||||
|     if (askReplyConfirmation) { | ||||
|       dispatch(openModal('CONFIRM', { | ||||
|         message: intl.formatMessage(messages.replyMessage), | ||||
|         confirm: intl.formatMessage(messages.replyConfirm), | ||||
|         onConfirm: () => dispatch(replyCompose(status, this.context.router.history)), | ||||
|       })); | ||||
|     } else { | ||||
|       dispatch(replyCompose(status, this.context.router.history)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   handleModalReblog = (status) => { | ||||
|  |  | |||
|  | @ -12,6 +12,7 @@ class LanguageDetector | |||
|   def detect(text, account) | ||||
|     input_text = prepare_text(text) | ||||
|     return if input_text.blank? | ||||
| 
 | ||||
|     detect_language_code(input_text) || default_locale(account) | ||||
|   end | ||||
| 
 | ||||
|  | @ -33,6 +34,7 @@ class LanguageDetector | |||
| 
 | ||||
|   def detect_language_code(text) | ||||
|     return if unreliable_input?(text) | ||||
| 
 | ||||
|     result = @identifier.find_language(text) | ||||
|     iso6391(result.language.to_s).to_sym if result.reliable? | ||||
|   end | ||||
|  | @ -75,6 +77,6 @@ class LanguageDetector | |||
|   end | ||||
| 
 | ||||
|   def default_locale(account) | ||||
|     account.user_locale&.to_sym || I18n.default_locale | ||||
|     return account.user_locale&.to_sym || I18n.default_locale if account.local? | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -42,6 +42,7 @@ describe LanguageDetector do | |||
| 
 | ||||
|   describe 'detect' do | ||||
|     let(:account_without_user_locale) { Fabricate(:user, locale: nil).account } | ||||
|     let(:account_remote) { Fabricate(:account, domain: 'joinmastodon.org') } | ||||
| 
 | ||||
|     it 'detects english language for basic strings' do | ||||
|       strings = [ | ||||
|  | @ -104,6 +105,15 @@ describe LanguageDetector do | |||
|         end | ||||
|       end | ||||
| 
 | ||||
|       describe 'remote user' do | ||||
|         it 'nil for foreign user when language is not present' do | ||||
|           string = '안녕하세요' | ||||
|           result = described_class.instance.detect(string, account_remote) | ||||
| 
 | ||||
|           expect(result).to eq nil | ||||
|         end | ||||
|       end | ||||
| 
 | ||||
|       describe 'with a non-`en` default locale' do | ||||
|         around(:each) do |example| | ||||
|           before = I18n.default_locale | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue