$strings['item'], '!items' => $strings['items'], '!entity' => $strings['entity'], '!entities' => $strings['entities'], '!hierarchy' => $strings['hierarchy'], '!hierarchies' => $strings['hierarchies'] ); $form = array( '#tree' => TRUE, '#type' => 'fieldset', '#title' => t('Hierarchical Select configuration'), '#attributes' => array( 'class' => array('hierarchical-select-config-form'), 'id' => 'hierarchical-select-config-form-' . $config_id, ), '#attached' => array( 'css' => array( drupal_get_path('module', 'hierarchical_select') . '/includes/common_config_form.css' ), 'js' => array( array( 'type' => 'file', 'data' => drupal_get_path('module', 'hierarchical_select') . '/includes/common_config_form.js', ), array( 'type' => 'setting', 'data' => array('HierarchicalSelect' => array('configForm' => array($config_id))), ), ), ) ); $form['config_id'] = array('#type' => 'value', '#value' => $config_id); // TODO: really make this a *live* preview, i.e. refresh the preview on each // change in the form. This cannot be done easily in Drupal 5 or 6, so let's // do so in Drupal 7. See cfg.livePreview in common_config_form.js. $form['live_preview'] = array( '#type' => 'fieldset', '#title' => t('Preview'), '#description' => t('This is what the Hierarchical Select will look like with your current configuration.'), '#collapsible' => FALSE, '#attributes' => array('class' => array('live-preview')), ); $form['live_preview']['example'] = array( '#type' => 'hierarchical_select', '#required' => $preview_is_required, '#title' => t('Preview'), '#description' => t('The description.'), // Skip al validation for this form element: the data collected through it // is always discarded, it's merely here for illustrative purposes. '#validated' => TRUE, ); hierarchical_select_common_config_apply($form['live_preview']['example'], $config_id, array_merge($defaults_override, array('module' => $module, 'params' => $params))); $form['save_lineage'] = array( '#type' => 'radios', '#title' => t('Save lineage'), '#options' => array( 1 => t('Save !item lineage', $args), 0 => t('Save only the deepest !item', $args), ), '#default_value' => (isset($config['save_lineage'])) ? $config['save_lineage'] : NULL, '#description' => t( 'Saving the !item lineage means saving the the !item itself and all its ancestors.', $args ), ); $form['enforce_deepest'] = array( '#type' => 'radios', '#title' => t('Level choice'), '#options' => array( 1 => t('Force the user to choose a !item from a deepest level', $args), 0 => t('Allow the user to choose a !item from any level', $args), ), '#default_value' => (isset($config['enforce_deepest'])) ? $config['enforce_deepest'] : NULL, '#description' => t( 'This setting determines from which level in the !hierarchy tree a user can select a !item.', $args ), '#attributes' => array('class' => array('enforce-deepest')), ); if (module_hook($module, 'hierarchical_select_entity_count')) { $form['entity_count'] = array( '#type' => 'radios', '#title' => t('Display the !entity count', $args), '#description' => t( 'When enabled, the user will see the number of !entities that match the current !item listed between brackets.', $args ), '#options' => array( 0 => t('Disabled'), 1 => t('Enabled'), ), '#default_value' => (isset($config['entity_count'])) ? $config['entity_count'] : NULL, '#attributes' => array('class' => array('entity-count')), ); $form['require_entity'] = array( '#type' => 'radios', '#title' => t('Require associated !entity', $args), '#description' => t( 'When enabled, !items will only be displayed when they are associated with at least one !entity, or if one of their child !items are associated with at least one !entity.', $args ), '#options' => array( 0 => t('Disabled'), 1 => t('Enabled'), ), '#default_value' => (isset($config['require_entity'])) ? $config['require_entity'] : NULL, '#attributes' => array('class' => array('require-entity')), ); } $form['resizable'] = array( '#type' => 'radios', '#title' => t('Resizable'), '#description' => t( "When enabled, a handle appears below the Hierarchical Select to allow the user to dynamically resize it. Double clicking will toggle between the smallest and a sane 'big size'." ), '#options' => array( 0 => t('Disabled'), 1 => t('Enabled'), ), '#default_value' => (isset($config['resizable'])) ? $config['resizable'] : NULL, '#attributes' => array('class' => array('resizable')), ); $form['level_labels'] = array( '#tree' => TRUE, '#type' => 'fieldset', '#title' => t('Level labels'), '#description' => t( 'When the user is allowed to choose a !item from any level in the Level choice setting, you can enter a label for each level.
However, when the user is only allowed to choose a !item from the deepest level, then you can only enter a label for the root level.', $args ), '#collapsible' => TRUE, ); $form['level_labels']['status'] = array( '#type' => 'checkbox', '#title' => t('Enable level labels'), '#default_value' => (isset($config['level_labels']['status'])) ? $config['level_labels']['status'] : NULL, '#attributes' => array('class' => array('level-labels-status')), ); for ($depth = 0; $depth <= $max_hierarchy_depth; $depth++) { $form['level_labels']['labels'][$depth] = array( '#type' => 'textfield', '#size' => 20, '#maxlength' => 255, '#default_value' => (isset($config['level_labels']['labels'][$depth])) ? $config['level_labels']['labels'][$depth] : NULL, '#attributes' => array('class' => array('level-label')), ); } $form['level_labels']['#theme'] = 'hierarchical_select_common_config_form_level_labels'; $form['level_labels']['#strings'] = $strings; $form['dropbox'] = array( '#type' => 'fieldset', '#title' => t('Dropbox settings'), '#description' => t('The dropbox allows the user to make multiple selections.'), '#collapsible' => TRUE, ); $form['dropbox']['status'] = array( '#type' => 'checkbox', '#title' => t('Enable the dropbox'), '#default_value' => (isset($config['dropbox']['status'])) ? $config['dropbox']['status'] : NULL, '#attributes' => array('class' => array('dropbox-status')), ); $form['dropbox']['title'] = array( '#type' => 'textfield', '#title' => t('Title'), '#description' => t('The title you enter here appears above the dropbox.'), '#size' => 20, '#maxlength' => 255, '#default_value' => (isset($config['dropbox']['title'])) ? $config['dropbox']['title'] : NULL, '#attributes' => array('class' => array('dropbox-title')), ); $form['dropbox']['limit'] = array( '#type' => 'textfield', '#title' => t('Limit the number of selections'), '#description' => t( 'Limits the number of selections that can be added to the dropbox. 0 means no limit.
Note: the "Save !item lineage" option has no effect on this, even if a lineage consists of 3 !items, this will count as only one selection in the dropbox.', $args ), '#size' => 5, '#maxlength' => 5, '#default_value' => (isset($config['dropbox']['limit'])) ? $config['dropbox']['limit'] : NULL, '#attributes' => array('class' => array('dropbox-limit')), ); $form['dropbox']['reset_hs'] = array( '#type' => 'radios', '#title' => t('Reset selection of hierarchical select'), '#description' => t( 'This setting determines what will happen to the hierarchical select when the user has added a selection to the dropbox.' ), '#options' => array( 0 => t('Disabled'), 1 => t('Enabled'), ), '#default_value' => (isset($config['dropbox']['reset_hs'])) ? $config['dropbox']['reset_hs'] : NULL, '#attributes' => array('class' => array('dropbox-reset-hs')), ); if (module_hook($module, 'hierarchical_select_create_item')) { $form['editability'] = array( '#type' => 'fieldset', '#title' => t('Editability settings'), '#description' => t( 'You can allow the user to add new !items to this !hierarchy through Hierarchical Select.', $args ), '#collapsible' => TRUE, ); $form['editability']['status'] = array( '#type' => 'checkbox', '#title' => t('Allow creation of new !items', $args), '#options' => array( 0 => t('Disabled'), 1 => t('Enabled'), ), '#default_value' => (isset($config['editability']['status'])) ? $config['editability']['status'] : NULL, '#attributes' => array('class' => array('editability-status')), ); for ($depth = 0; $depth <= $max_hierarchy_depth; $depth++) { $form['editability']['item_types'][$depth] = array( '#type' => 'textfield', '#size' => 20, '#maxlength' => 255, '#default_value' => (isset($config['editability']['item_types'][$depth])) ? $config['editability']['item_types'][$depth] : NULL, '#attributes' => array('class' => array('editability-item-type')), ); } for ($depth = 0; $depth <= $max_hierarchy_depth; $depth++) { $form['editability']['allowed_levels'][$depth] = array( '#type' => 'checkbox', '#default_value' => (isset($config['editability']['allowed_levels'][$depth])) ? $config['editability']['allowed_levels'][$depth] : 1, ); } $form['editability']['allow_new_levels'] = array( '#type' => 'checkbox', '#title' => t('Allow creation of new levels'), '#default_value' => $config['editability']['allow_new_levels'], '#description' => t( 'Allow the user to create child !items for !items that do not yet have children.', $args ), '#attributes' => array('class' => array('editability-allow-new-levels')), ); $form['editability']['max_levels'] = array( '#type' => 'select', '#title' => t('Maximum number of levels allowed'), '#options' => array( 0 => t('0 (no limit)'), 1, 2, 3, 4, 5, 6, 7, 8, 9 ), '#default_value' => (isset($config['editability']['max_levels'])) ? $config['editability']['max_levels'] : NULL, '#description' => t( 'When the user is allowed to create new levels, this option prevents the user from creating extremely deep !hierarchies.', $args ), '#attributes' => array('class' => array('editability-max-levels')), ); $form['editability']['#theme'] = 'hierarchical_select_common_config_form_editability'; $form['editability']['#strings'] = $strings; } return $form; } /** * Submit callback for the hierarchical_select_common_config_form form. */ function hierarchical_select_common_config_form_submit($form, &$form_state) { $config = _hierarchical_select_get_form_item_by_parents($form_state['values'], $form['#hs_common_config_form_parents']); // Don't include the value of the live preview in the config. unset($config['live_preview']); hierarchical_select_common_config_set($config['config_id'], $config); } /** * Get the form element of a form that has a certain lineage of parents. * * @param $form * A structured array for use in the Forms API. * @param $parents * An array of parent form element names. * @return * The form element that has the specified lineage of parents. */ function _hierarchical_select_get_form_item_by_parents($form, $parents) { if (count($parents)) { $parent = array_shift($parents); return _hierarchical_select_get_form_item_by_parents($form[$parent], $parents); } else { return $form; } }