Я использую cocoon gem в своем приложении rails, и у меня есть два вложенных поля внутри формы (категории, подкатегории). Изначально я показываю только первый, а второй скрыт. Каждый раз, когда первые выбранные поля имеют подкатегории, второе поле заполняется и отображается.
Вложенные поля:
<div class="nested-fields">
<%= form.input :category, collection: @categories, as: :grouped_select, group_method: :children, :label => false, :include_blank => true, input_html: { id: "first_dropdown" } %>
<div class="show_hide">
<%= form.input :subcategories, label: false, :collection => [], :label_method => :name, :value_method => :id, required: true, input_html: { multiple: true, id: "second_dropdown" } %>
</div>
<div class="links">
<%= link_to_remove_association "Remove", form %>
</div>
</div>
Это код, который изначально скрывает второе поле
$('#first_dropdown').keyup(function() {
if ($(this).val().length == 0) {
$('.show_hide').hide();
}
}).keyup();
Этот код показывает второй вход выбора, когда первый вход выбора имеет подкатегории:
def select_item
category = Category.find params[:category_id]
render json: category.children
end
$('#first_dropdown').on('change', function() {
$.ajax({
url: 'categories/select_item?category_id=' + $(this).val(),
dataType: 'json',
success: function(data) {
let childElement = $('#second_dropdown');
if( data.length === 0 ) {
$('.show_hide').hide();
} else {
$('.show_hide').show();
}
childElement.html('');
data.forEach(function(v) {
let id = v.id;
let name = v.name;
childElement.append('<option value="' + id + '">' + name + '</option>');
});
}
});
});
Все работает хорошо для начального открытого поля. Но когда я добавляю больше полей и выбираю значение в любом из первых полей выбора, он заполняет все вторые поля в соответствии с этим значением. Я думаю, это потому, что я использую указанные c идентификаторы для этого, и когда я добавляю больше полей, все они имеют одинаковые идентификаторы. Как это настроить, чтобы я правильно заполнял второе поле выбора каждый раз, когда добавлял в форму больше вложенных полей?