Comment puis-je avoir plusieurs valeurs pour déclencher les # états de l'API Form?
Disons par exemple, je voulais que ce champ soit visible non seulement si la valeur est 5 (fonctionne actuellement ci-dessous), mais je voulais rendre le champ visible si les valeurs sont 3, 4 ou 5.
'#states' => array(
'visible' => array(
':input[name="field_star_rating"]' => array('value' => t('5')),
),
),
En tant que note, j'ai essayé ce qui suit et cela ne fonctionne pas. Cela ne fonctionne que si la valeur est '4'
'#states' => array(
'visible' => array(
':input[name="field_star_rating"]' => array('value' => t('5')),
':input[name="field_star_rating"]' => array('value' => t('4')),
),
),
Cela aussi ne fonctionne pas, cela ne fonctionne que si la valeur est '4':
'#states' => array(
'visible' => array(
':input[name="field_star_rating"]' => array('value' => t('5'), 'value' => t('4')),
),
),
Voici ce dont vous avez besoin:
'#states' => array(
'visible' => array(
':input[name="field_star_rating"]' => array(
array('value' => t('5')),
array('value' => t('4'))
),
),
),
La seule façon de comprendre est d'utiliser #ajax en D7.
Voici quelques conseils utiles que j'aurais aimé savoir avant de commencer.
Voici une version modifiée de l'un des exemples AJAX du module examples).
function plugin_autotextfields($form, &$form_state) {
$form['star_rating'] = array(
'#type' => 'select',
'#title' => t('Star Rating'),
'#options' => array('_none' => '- select -', 5 => '5 Star', 4 => '4 Star', 3 => '3 Star', 2 => '2 Star', 1 => '1 Star'),
'#ajax' => array(
'callback' => 'plugin_autotextfields_callback',
'wrapper' => 'textfields',
'effect' => 'fade',
),
);
$form['textfields'] = array(
'#title' => t("Fieldset Name"),
'#prefix' => '<div id="textfields">',
'#suffix' => '</div>',
'#type' => 'fieldset',
'#description' => t('Where the field will be placed'),
);
if (!empty($form_state['values']['star_rating']) && $form_state['values']['star_rating'] == 5) {
$form['textfields']['review'] = array(
'#type' => 'textfield',
'#title' => t('Message if 5 stars'),
);
} else if (!empty($form_state['values']['star_rating'])) {
$form['textfields']['review'] = array(
'#type' => 'textfield',
'#title' => t('Message if not 5 stars'),
);
}
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Click Me'),
);
return $form;
}
function omfg_autotextfields_callback($form, $form_state) {
return $form['textfields'];
}
J'espère que cela aide quelqu'un qui rencontre le même problème :)
$form['student_type'] = array(
'#type' => 'checkboxes',
'#options' => array(
'high_school' => t('High School'),
'undergraduate' => t('Undergraduate'),
'graduate' => t('Graduate'),
),
'#title' => t('What type of student are you?')
);
// High school information.
$form['high_school']['tests_taken'] = array(
'#type' => 'textfield',
'#title' => t('What standardized tests did you take?'),
'#states' => array(
'visible' => array( // action to take.
':input[name="student_type[high_school]"]' => array('checked' => TRUE),
':input[name="student_type[undergraduate]"]' => array('checked' => TRUE),
':input[name="student_type[graduate]"]' => array('checked' => FALSE),
),
),
);
P.S. Voir le module d'exemples pour plus de fonctionnalités "form_example/form_example_states.inc"