Здравствуйте, не знаю, как это объяснить, но я сделаю это как можно лучше.
У меня есть такая модель
class Answer < ActiveRecord::Base
EMPLOYMENT_TYPE = [
['Employed', I18n.t('self_evaluation.self_evaluation_form.employment_status.employed')],
['Self-Employed', I18n.t('self_evaluation.self_evaluation_form.employment_status.self_employed')],
['Unemployed / Retired', I18n.t('self_evaluation.self_evaluation_form.employment_status.unemployed')]
]
end
У меня также есть вспомогательный метод, который вызывает это
module AnswerHelper
def get_employment_type_list
return Answer::EMPLOYMENT_TYPE
end
end
И частичное представление, в котором должны отображаться следующие значения:
_step_1.html.erb
<% employment_list = get_employment_type_list %>
<%= employment_list %>
<div class="flex_center flex_column button-wrap">
<%= collection_radio_buttons("application[answer_attributes]", :employment_type, employment_list, :first, :last, item_wrapper_tag: false, checked: @selected_employment_type) do |b|
b.label(class: 'employment_type_radio') { b.radio_button(:onchange => "return_employment_type(value)", class:'radio-label') + b.label(class:'button-label'){b.text}}
end %>
</div>
_step_2.html.erb
<% employer_list = get_employer_list(chosen_employment_type(@decoded_self_evaluation)) %>
<% employer_type = @decoded_self_evaluation.try(:loan_application).try(:kyc_answer).try(:employer_type) %>
<div class="flex_center flex_column button-wrap">
<%= collection_radio_buttons("loan_application[kyc_answer_attributes]", :employer_type, employer_list, :first, :last, item_wrapper_tag: false, checked: employer_type) do |b|
b.label(class: 'employer_type_radio') { b.radio_button(:onchange => "is_business_registered(value)", class:'radio-label') + b.label(class:'button-label'){b.text}}
end %>
</div>
identity.js
$.ajax({
url:'/self_evaluations/' + self_evaluation_id + '/employment_type',
method:"POST",
data:JSON.stringify({employment_type: employment_type, key: $('#token_key').val()}),
contentType:"application/json; charset=utf-8",
dataType:"script",
async: false,
success: function(data) {
$valid = true;
}
})
loyment_list.js.erb
$('#id_employer').empty();
$('#id_employer').append("<%=j render 'self_evaluations/self_evaluation_partials/step_2' %>");
Теперь проблема в том, что я уже добавил все, что нужно для перевода I18n в Rails и дляТексты, которые переводятся в html-представлении, работают правильно, когда я переключаюсь с разных языков, но для текстов, получаемых с помощью вспомогательного метода, подобного этому.Исходя из первоначальной справки, при начальной загрузке все страницы работают нормально, но если я меняю язык и затем запускаю ajax-вызов, который загружает job_list.js.erb, моя локаль все еще остается основным языком, значения соответственно не меняются
Не уверен, почему это происходит, кто-нибудь сталкивался с чем-то подобным раньше?