You are here

variable.form.inc in Variable 7.2

Same filename and directory in other branches
  1. 6 variable.form.inc
  2. 7 variable.form.inc

Variable API module. Form library.

File

variable.form.inc
View source
<?php

/**
 * @file
 * Variable API module. Form library.
 */

/**
 * Build form element for a variable
 */
function variable_form_element($variable, $options = array()) {
  $variable = variable_build($variable);
  $variable = variable_build_options($variable, $options);
  if (!empty($variable['element callback'])) {
    $element = call_user_func($variable['element callback'], $variable, $options);
  }
  elseif (isset($variable['options'])) {
    $element = variable_form_element_options($variable, $options);
  }
  else {
    $element = variable_form_element_default($variable, $options);
  }
  if (!empty($variable['validate callback'])) {
    $element['#element_validate'][] = 'variable_form_element_validate';
  }
  if (!empty($options['form parents'])) {
    $element['#parents'] = $options['form parents'];
    $element['#parents'][] = $variable['name'];
  }
  $element += array(
    '#access' => variable_access($variable),
  );
  if (!empty($variable['required'])) {
    $element += array(
      '#required' => TRUE,
    );
  }

  // Add variable data to element so we can use it later fo validation, etc..
  $element['#variable'] = $variable;
  return $element;
}

/**
 * Build array form element
 */
function variable_form_element_array($variable, $options = array()) {

  // This will be possibly a fieldset with tree value
  $element = variable_form_element_default($variable, $options);

  // We may have a multiple element base that will default to plain textfield
  $item = $variable['repeat'];
  $value = variable_get_value($variable, $options);

  // Compile names and defaults for all elements
  $names = $defaults = array();
  if (!empty($variable['multiple'])) {

    // If we've got a multiple value, it will be an array with known elements
    $names = $variable['multiple'];
  }
  else {

    // Array with unknown elements, we add an element for each existing one
    $names = $value ? array_combine(array_keys($value), array_keys($value)) : array();
  }

  // Now build elements with the right names
  foreach ($names as $key => $title) {
    if (isset($value[$key]) && is_array($value[$key])) {

      // This element is an array, we cannot edit it but we need to add it to the form
      $element[$key] = array(
        '#type' => 'value',
        '#value' => $value[$key],
      );
      $element['variable_element_array_' . $key] = array(
        '#type' => 'item',
        '#title' => $title,
        '#markup' => variable_format_array($value[$key]),
      );
    }
    else {
      $element[$key] = $item['element'] + array(
        '#title' => $title,
        '#default_value' => isset($value[$key]) ? $value[$key] : '',
      );
    }
  }
  return $element;
}

/**
 * Build multiple form element
 */
function variable_form_element_multiple($variable, $options = array()) {
  $variable += array(
    'element' => array(),
    'title' => '',
    'description' => '',
  );
  $element = $variable['element'] + array(
    '#type' => 'fieldset',
    '#title' => $variable['title'],
    '#description' => $variable['description'],
  );
  foreach ($variable['children'] as $name => $item) {
    $element[$name] = variable_form_element($item, $options);
  }
  return $element;
}

/**
 * Build default form element
 */
function variable_form_element_default($variable, $options = array()) {
  $variable += array(
    'element' => array(),
    'title' => '',
    'description' => '',
  );
  $type = variable_get_type($variable['type']) + array(
    'element' => array(),
  );
  $element = $variable['element'] + array(
    '#title' => $variable['title'],
    '#description' => $variable['description'],
  ) + $type['element'];
  $value = variable_get_value($variable, $options);
  if (isset($value)) {
    $element['#default_value'] = $value;
  }
  return $element;
}

/**
 * Build form element for unknown variable.
 *
 * This is not an editable form element but a form item.
 */
function variable_form_element_unknown($variable, $options = array()) {
  $variable += array(
    'element' => array(),
    'title' => '',
    'description' => '',
  );
  $type = variable_get_type($variable['type']) + array(
    'element' => array(),
  );
  $element = $variable['element'] + array(
    '#title' => $variable['title'],
    '#description' => $variable['description'],
    '#markup' => variable_format_value($variable, $options),
  ) + $type['element'];
  return $element;
}

/**
 * Build form element for text_format variable.
 */
function variable_form_element_text_format($variable, $options = array()) {
  $variable += array(
    'element' => array(),
    'title' => '',
    'description' => '',
  );
  $type = variable_get_type($variable['type']) + array(
    'element' => array(),
  );
  $element = $variable['element'] + array(
    '#title' => $variable['title'],
    '#description' => $variable['description'],
  ) + $type['element'];
  $value = variable_get_value($variable, $options);
  if (isset($value) && is_array($value)) {
    if (isset($value['value'])) {
      $element['#default_value'] = $value['value'];
    }
    if (isset($value['format'])) {
      $element['#format'] = $value['format'];
    }
  }
  return $element;
}

/**
 * Build options variables
 */
function variable_form_element_options($variable, $options = array()) {
  $element = variable_form_element_default($variable, $options);
  $element['#options'] = $variable['options'];

  // Depending on the number of options this may be radios or a drop-down.
  // However if there are nested options (an option is an array) it should be always a drop-down.
  if (empty($element['#type'])) {
    $element['#type'] = count($variable['options']) > 4 || array_filter(array_map('is_array', $variable['options'])) ? 'select' : 'radios';
  }
  return $element;
}

/**
 * Execute submit callbacks for variables in form.
 */
function variable_form_submit_callback($form, &$form_state) {
  if (isset($form['#variable_edit_form'])) {

    // This may contain some realm options.
    $options = isset($form['#variable_options']) ? $form['#variable_options'] : array();
    foreach ($form['#variable_edit_form'] as $name) {
      $variable = variable_get_info($name);
      if ($variable && isset($variable['submit callback'])) {
        variable_include($variable);
        $variable['submit callback']($variable, $options, $form, $form_state);
      }
    }
  }
}

/**
 * Form to select variables
 */
function theme_variable_table_select($variables) {
  $element = $variables['element'];
  $header = isset($element['#header']) ? $element['#header'] : array(
    'element' => '',
    'title' => t('Name'),
    'description' => t('Description'),
  );
  $fields = array_keys($header);
  $rows = array();
  foreach (element_children($element) as $name) {
    if (isset($element[$name]['#variable_name'])) {
      $variable_name = $element[$name]['#variable_name'];
    }
    else {
      $variable_name = str_replace(array(
        '<',
        '>',
      ), array(
        '[',
        ']',
      ), $name);
    }
    $variable = _variable_variable($variable_name);
    $row = array();
    foreach ($fields as $field) {
      if ($field == 'element') {
        $row[] = drupal_render($element[$name]);
      }
      else {
        $row[] = isset($variable[$field]) ? $variable[$field] : '';
      }
    }
    $rows[] = $row;
  }

  // Add a "Select all" checkbox.
  drupal_add_js('misc/tableselect.js');
  $header['element'] = array(
    'class' => array(
      'select-all',
    ),
  );
  return theme('table', array(
    'header' => array_values($header),
    'rows' => $rows,
  ));
}

Functions

Namesort descending Description
theme_variable_table_select Form to select variables
variable_form_element Build form element for a variable
variable_form_element_array Build array form element
variable_form_element_default Build default form element
variable_form_element_multiple Build multiple form element
variable_form_element_options Build options variables
variable_form_element_text_format Build form element for text_format variable.
variable_form_element_unknown Build form element for unknown variable.
variable_form_submit_callback Execute submit callbacks for variables in form.