sisko
sisko

Reputation: 9900

Drupal 7 hook_menu checkboxes issue

I am trying to put together a module which will have it's own configuration page. For that purpose, I am using the following code as my menu page-callback:

function webform_customizations_customize() {
    $form = array();
  // Text field for the e-mail subject.
  $form['webform_customizations']['user_warn_e-mail_subject'] = array(

        '#type' => 'textfield',
        '#title' => t('Warning e-mail subject'),
        '#description' => t('The subject of the e-mail which will be sent 
    to users.'),
          '#size' => 40,
          '#maxlength' => 120,
          '#required' => TRUE,
    );
    $options = array('A', 'B', 'C');
    $form['test'] = array(
        '#type' => 'radios',
        '#options' => array(
                'one' => t('one'),
                'two' => t('two'),
            ),
        '#title' => t('roles that should see a minimal webforms setting area'),
        '#title_display' => t('testing'),
    );
  $form['high_school']['tests_taken'] = array(

    '#type' => 'checkboxes', 

    '#options' => drupal_map_assoc(array(t('SAT'), t('ACT'))), 
    '#title' => t('What standardized tests did you take?'),
    '#states' => array(
      'visible' => array(// action to take.
        ':input[name="student_type"]' => array('value' => 'high_school'),
      ),
    ),
  );
return $form;
}

My problem is my attempts to display checkboxes are failing. The first field shows a textfield successfully. But the next two are checkboxes which never show on my configuration page - and the tests_taken checkbox code is lifted directly from this drupal doc page without any amendments.

I tried a single checkbox and that works.

Upvotes: 0

Views: 359

Answers (1)

SebCorbin
SebCorbin

Reputation: 1723

You should have read the comments that were along with the code you took:

    // This #states rule says that this checkboxes array will be visible only
    // when $form['student_type'] is set to t('High School').
    // It uses the jQuery selector :input[name=student_type] to choose the
    // element which triggers the behavior, and then defines the "High School"
    // value as the one that triggers visibility. 

Simply remove the #states element, and it should work. Happy drupaling!

Upvotes: 0

Related Questions