Я створюю форму, яка використовує '#ajax'
атрибут API форми , і мені потрібно внести зміни, $form_state
коли натискається кнопка з підтримкою AJAX. Ось що я маю:
Всередині моєї функції конструктора форм:
...
$form['some_fieldset']['add_more'] = array(
'#type' => 'button',
'#value' => t('Add more rows'),
'#ajax' => array(
'wrapper' => 'some-fieldset',
'callback' => 'my_module_settings_ajax',
'method' => 'replace',
'effect' => 'fade',
),
);
...
А ось функція зворотного дзвінка:
function my_module_settings_ajax($form, $form_state) {
// Make a change to $form_state
if ($form_state['some_fieldset']['add_more']) {
$form_state['values']['some_fieldset']['table'][] = array('first_field' => '',
'second_field' => '');
}
return $form['some_fieldset'];
}
Зміни, які я зробив, $form_state
здається, втрачені після завершення зворотного дзвінка. Чи є якийсь спосіб змінити $form_state
цю функцію, або якась інша функція я повинна використовувати для цього?
EDIT
Як виявляється, зворотний виклик - це неправильне місце для цієї логіки. Натомість у верхній частині функції побудови форми я додав це:
// Respond to AJAX-triggger:
// Add new row
if ($form_state['triggering_element']['#name'] == 'add_more') {
$form_state['values']['some_fieldset']['table'][] = array('first_field' => '',
'second_field' => '');
}
Звичайно, мені довелося дати ім'я кнопки:
$form['some_fieldset']['add_more'] = array(
'#type' => 'button',
'#name' => 'add_more', // <-- Right here
'#value' => t('Add more rows'),
'#ajax' => array(
'wrapper' => 'some-fieldset',
'callback' => 'my_module_settings_ajax',
'method' => 'replace',
'effect' => 'fade',
),
);
А тепер це працює!