diff --git a/lib/phraseapp-in-context-editor-ruby/adapters/i18n.rb b/lib/phraseapp-in-context-editor-ruby/adapters/i18n.rb index b153268..d6e300b 100644 --- a/lib/phraseapp-in-context-editor-ruby/adapters/i18n.rb +++ b/lib/phraseapp-in-context-editor-ruby/adapters/i18n.rb @@ -1,8 +1,8 @@ if defined?(I18n) module I18n class << self - def translate_with_phraseapp(*args) - PhraseApp::InContextEditor.backend.translate(*args) + def translate_with_phraseapp(...) + PhraseApp::InContextEditor.backend.translate(...) end alias_method :translate_without_phraseapp, :translate alias_method :translate, :translate_with_phraseapp diff --git a/lib/phraseapp-in-context-editor-ruby/backend_service.rb b/lib/phraseapp-in-context-editor-ruby/backend_service.rb index ead93b2..9cee319 100644 --- a/lib/phraseapp-in-context-editor-ruby/backend_service.rb +++ b/lib/phraseapp-in-context-editor-ruby/backend_service.rb @@ -9,41 +9,21 @@ def initialize(args = {}) self end - def translate(*args) - if to_be_translated_without_phraseapp?(args) - # *Ruby 2.7+ keyword arguments warning* - # - # This method uses keyword arguments. - # There is a breaking change in ruby that produces warning with ruby 2.7 and won't work as expected with ruby 3.0 - # The "hash" parameter must be passed as keyword argument. - # - # Good: - # I18n.t(:salutation, :gender => 'w', :name => 'Smith') - # I18n.t(:salutation, **{ :gender => 'w', :name => 'Smith' }) - # I18n.t(:salutation, **any_hash) - # - # Bad: - # I18n.t(:salutation, { :gender => 'w', :name => 'Smith' }) - # I18n.t(:salutation, any_hash) - # - kw_args = args[1] - if kw_args.present? - I18n.translate_without_phraseapp(args[0], **kw_args) - else - I18n.translate_without_phraseapp(args[0]) - end + def translate(...) + if to_be_translated_without_phraseapp?(...) + I18n.translate_without_phraseapp(...) else - phraseapp_delegate_for(args) + phraseapp_delegate_for(...) end end protected - def to_be_translated_without_phraseapp?(args) - PhraseApp::InContextEditor.disabled? || has_been_forced_to_resolve_with_phraseapp?(args) + def to_be_translated_without_phraseapp?(...) + PhraseApp::InContextEditor.disabled? || has_been_forced_to_resolve_with_phraseapp?(...) end - def has_been_forced_to_resolve_with_phraseapp?(args) + def has_been_forced_to_resolve_with_phraseapp?(*args) (args.last.is_a?(Hash) && args.last[:resolve] == false) end @@ -51,7 +31,7 @@ def given_key_from_args(args) extract_normalized_key_from_args(args) end - def phraseapp_delegate_for(args) + def phraseapp_delegate_for(*args) key = given_key_from_args(args) return nil unless present?(key) diff --git a/spec/phraseapp-in-context-editor-ruby/backend_service_spec.rb b/spec/phraseapp-in-context-editor-ruby/backend_service_spec.rb index 8fe351a..6cb2fbf 100644 --- a/spec/phraseapp-in-context-editor-ruby/backend_service_spec.rb +++ b/spec/phraseapp-in-context-editor-ruby/backend_service_spec.rb @@ -16,15 +16,13 @@ allow(I18n).to receive(:translate_without_phraseapp).with(key_name).and_return(i18n_translation) end - subject { phraseapp_service.translate(*args) } - context "phrase is enabled" do before(:each) do PhraseApp::InContextEditor.enabled = true end context "resolve: false given as argument" do - let(:args) { [key_name, resolve: false] } + subject { phraseapp_service.translate(key_name, resolve: false) } before(:each) do allow(I18n).to receive(:translate_without_phraseapp).with(key_name, resolve: false).and_return(i18n_translation) @@ -34,7 +32,7 @@ end context "resolve: true given as argument" do - let(:args) { [key_name, resolve: true] } + subject { phraseapp_service.translate(key_name, resolve: true) } it { is_expected.to be_a String } it { is_expected.to eql "{{__phrase_foo.bar__}}" } @@ -42,19 +40,20 @@ describe "different arguments given" do context "default array given", vcr: {cassette_name: "fetch list of keys filtered by fallback key names"} do - let(:args) { [:key, {default: [:first_fallback, :second_fallback]}] } + subject { phraseapp_service.translate(:key, default: [:first_fallback, :second_fallback]) } + it { is_expected.to eql "{{__phrase_key__}}" } end context "default string given" do - let(:args) { [:key, {default: "first fallback"}] } + subject { phraseapp_service.translate(:key, default: "first fallback") } it { is_expected.to eql "{{__phrase_key__}}" } end context "scope array given" do + subject { phraseapp_service.translate(:key, scope: [:context]) } let(:context_key_translation) { double } - let(:args) { [:key, {scope: [:context]}] } it { is_expected.to eql "{{__phrase_context.key__}}" } end @@ -62,7 +61,7 @@ end context "phrase is disabled" do - let(:args) { [key_name] } + subject { phraseapp_service.translate(key_name) } before(:each) do PhraseApp::InContextEditor.enabled = false @@ -71,7 +70,7 @@ it { is_expected.to eql i18n_translation } context "given arguments other than key_name" do - let(:args) { [key_name, locale: :ru] } + subject { phraseapp_service.translate(key_name, locale: :ru) } let(:ru_translation) { double } before(:each) do @@ -87,27 +86,26 @@ end context "default array given" do - let(:args) { [:key, {default: [:first_fallback, :second_fallback]}] } + subject { phraseapp_service.translate(:key, default: [:first_fallback, :second_fallback]) } it { is_expected.to eql "Translation missing. Options considered were:\n- en.key\n- en.first_fallback\n- en.second_fallback" } end context "default string given" do - let(:args) { [:key, {default: "first fallback"}] } + subject { phraseapp_service.translate(:key, default: "first fallback") } it { is_expected.to eql "first fallback" } end - context "scope array given" do - let(:context_key_translation) { double } - let(:args) { [:key, {scope: [:context]}] } + context "default string given without key" do + subject { phraseapp_service.translate(default: "first fallback") } - it { is_expected.to eql "Translation missing: en.context.key" } + it { is_expected.to eql "first fallback" } end - context "scope array given in rails 3 style" do + context "scope array given" do + subject { phraseapp_service.translate(:key, scope: [:context]) } let(:context_key_translation) { double } - let(:args) { [:key, scope: [:context]] } it { is_expected.to eql "Translation missing: en.context.key" } end