Sto creando un modulo che utilizza l' '#ajax'
attributo API del modulo e devo apportare modifiche $form_state
quando viene premuto il pulsante abilitato AJAX. Ecco cosa ho:
All'interno della mia funzione di generatore di moduli:
...
$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',
),
);
...
Ed ecco la funzione di callback:
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'];
}
La modifica che ho apportato $form_state
sembra essere persa una volta terminata la richiamata. Esiste un modo per apportare una modifica $form_state
in questa funzione o c'è un'altra funzione che dovrei usare per questo invece?
MODIFICARE
A quanto pare, il callback è il posto sbagliato per fare questa logica. Invece, nella parte superiore della funzione di creazione del modulo, ho aggiunto questo:
// 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' => '');
}
Certo, ho dovuto dare al pulsante il nome:
$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',
),
);
E ora funziona!