| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408 | <?php/** * @file * Administrative page callbacks for the Filter module. *//** * Page callback: Form constructor for a form to list and reorder text formats. * * @ingroup forms * @see filter_menu() * @see filter_admin_overview_submit() */function filter_admin_overview($form) {  // Overview of all formats.  $formats = filter_formats();  $fallback_format = filter_fallback_format();  $form['#tree'] = TRUE;  foreach ($formats as $id => $format) {    // Check whether this is the fallback text format. This format is available    // to all roles and cannot be disabled via the admin interface.    $form['formats'][$id]['#is_fallback'] = ($id == $fallback_format);    if ($form['formats'][$id]['#is_fallback']) {      $form['formats'][$id]['name'] = array('#markup' => drupal_placeholder($format->name));      $roles_markup = drupal_placeholder(t('All roles may use this format'));    }    else {      $form['formats'][$id]['name'] = array('#markup' => check_plain($format->name));      $roles = array_map('check_plain', filter_get_roles_by_format($format));      $roles_markup = $roles ? implode(', ', $roles) : t('No roles may use this format');    }    $form['formats'][$id]['roles'] = array('#markup' => $roles_markup);    $form['formats'][$id]['configure'] = array('#type' => 'link', '#title' => t('configure'), '#href' => 'admin/config/content/formats/' . $id);    $form['formats'][$id]['disable'] = array('#type' => 'link', '#title' => t('disable'), '#href' => 'admin/config/content/formats/' . $id . '/disable', '#access' => !$form['formats'][$id]['#is_fallback']);    $form['formats'][$id]['weight'] = array(      '#type' => 'weight',      '#title' => t('Weight for @title', array('@title' => $format->name)),      '#title_display' => 'invisible',      '#default_value' => $format->weight,    );  }  $form['actions'] = array('#type' => 'actions');  $form['actions']['submit'] = array('#type' => 'submit', '#value' => t('Save changes'));  return $form;}/** * Form submission handler for filter_admin_overview(). */function filter_admin_overview_submit($form, &$form_state) {  foreach ($form_state['values']['formats'] as $id => $data) {    if (is_array($data) && isset($data['weight'])) {      // Only update if this is a form element with weight.      db_update('filter_format')        ->fields(array('weight' => $data['weight']))        ->condition('format', $id)        ->execute();    }  }  filter_formats_reset();  drupal_set_message(t('The text format ordering has been saved.'));}/** * Returns HTML for the text format administration overview form. * * @param $variables *   An associative array containing: *   - form: A render element representing the form. * * @ingroup themeable */function theme_filter_admin_overview($variables) {  $form = $variables['form'];  $rows = array();  foreach (element_children($form['formats']) as $id) {    $form['formats'][$id]['weight']['#attributes']['class'] = array('text-format-order-weight');    $rows[] = array(      'data' => array(        drupal_render($form['formats'][$id]['name']),        drupal_render($form['formats'][$id]['roles']),        drupal_render($form['formats'][$id]['weight']),        drupal_render($form['formats'][$id]['configure']),        drupal_render($form['formats'][$id]['disable']),      ),      'class' => array('draggable'),    );  }  $header = array(t('Name'), t('Roles'), t('Weight'), array('data' => t('Operations'), 'colspan' => 2));  $output = theme('table', array('header' => $header, 'rows' => $rows, 'attributes' => array('id' => 'text-format-order')));  $output .= drupal_render_children($form);  drupal_add_tabledrag('text-format-order', 'order', 'sibling', 'text-format-order-weight');  return $output;}/** * Page callback: Displays the text format add/edit form. * * @param object|null $format *   (optional) An object representing a format, with the following properties: *   - format: A machine-readable name representing the ID of the text format *     to save. If this corresponds to an existing text format, that format *     will be updated; otherwise, a new format will be created. *   - name: The title of the text format. *   - cache: (optional) An integer indicating whether the text format is *     cacheable (1) or not (0). Defaults to 1. *   - status: (optional) An integer indicating whether the text format is *     enabled (1) or not (0). Defaults to 1. *   - weight: (optional) The weight of the text format, which controls its *     placement in text format lists. If omitted, the weight is set to 0. *     Defaults to NULL. * * @return *   A form array. * * @see filter_menu() */function filter_admin_format_page($format = NULL) {  if (!isset($format->name)) {    drupal_set_title(t('Add text format'));    $format = (object) array(      'format' => NULL,      'name' => '',    );  }  return drupal_get_form('filter_admin_format_form', $format);}/** * Form constructor for the text format add/edit form. * * @param $format *   A format object having the properties: *   - format: A machine-readable name representing the ID of the text format to *     save. If this corresponds to an existing text format, that format will be *     updated; otherwise, a new format will be created. *   - name: The title of the text format. *   - cache: An integer indicating whether the text format is cacheable (1) or *     not (0). Defaults to 1. *   - status: (optional) An integer indicating whether the text format is *     enabled (1) or not (0). Defaults to 1. *   - weight: (optional) The weight of the text format, which controls its *     placement in text format lists. If omitted, the weight is set to 0. * * @see filter_admin_format_form_validate() * @see filter_admin_format_form_submit() * @ingroup forms */function filter_admin_format_form($form, &$form_state, $format) {  $is_fallback = ($format->format == filter_fallback_format());  $form['#format'] = $format;  $form['#tree'] = TRUE;  $form['#attached']['js'][] = drupal_get_path('module', 'filter') . '/filter.admin.js';  $form['#attached']['css'][] = drupal_get_path('module', 'filter') . '/filter.css';  $form['name'] = array(    '#type' => 'textfield',    '#title' => t('Name'),    '#default_value' => $format->name,    '#required' => TRUE,  );  $form['format'] = array(    '#type' => 'machine_name',    '#required' => TRUE,    '#default_value' => $format->format,    '#maxlength' => 255,    '#machine_name' => array(      'exists' => 'filter_format_exists',    ),    '#disabled' => !empty($format->format),  );  // Add user role access selection.  $form['roles'] = array(    '#type' => 'checkboxes',    '#title' => t('Roles'),    '#options' => array_map('check_plain', user_roles()),    '#disabled' => $is_fallback,  );  if ($is_fallback) {    $form['roles']['#description'] = t('All roles for this text format must be enabled and cannot be changed.');  }  if (!empty($format->format)) {    // If editing an existing text format, pre-select its current permissions.    $form['roles']['#default_value'] = array_keys(filter_get_roles_by_format($format));  }  elseif ($admin_role = variable_get('user_admin_role', 0)) {    // If adding a new text format and the site has an administrative role,    // pre-select that role so as to grant administrators access to the new    // text format permission by default.    $form['roles']['#default_value'] = array($admin_role);  }  // Retrieve available filters and load all configured filters for existing  // text formats.  $filter_info = filter_get_filters();  $filters = !empty($format->format) ? filter_list_format($format->format) : array();  // Prepare filters for form sections.  foreach ($filter_info as $name => $filter) {    // Create an empty filter object for new/unconfigured filters.    if (!isset($filters[$name])) {      $filters[$name] = new stdClass();      $filters[$name]->format = $format->format;      $filters[$name]->module = $filter['module'];      $filters[$name]->name = $name;      $filters[$name]->status = 0;      $filters[$name]->weight = $filter['weight'];      $filters[$name]->settings = array();    }  }  $form['#filters'] = $filters;  // Filter status.  $form['filters']['status'] = array(    '#type' => 'item',    '#title' => t('Enabled filters'),    '#prefix' => '<div id="filters-status-wrapper">',    '#suffix' => '</div>',  );  foreach ($filter_info as $name => $filter) {    $form['filters']['status'][$name] = array(      '#type' => 'checkbox',      '#title' => $filter['title'],      '#default_value' => $filters[$name]->status,      '#parents' => array('filters', $name, 'status'),      '#description' => $filter['description'],      '#weight' => $filter['weight'],    );  }  // Filter order (tabledrag).  $form['filters']['order'] = array(    '#type' => 'item',    '#title' => t('Filter processing order'),    '#theme' => 'filter_admin_format_filter_order',  );  foreach ($filter_info as $name => $filter) {    $form['filters']['order'][$name]['filter'] = array(      '#markup' => $filter['title'],    );    $form['filters']['order'][$name]['weight'] = array(      '#type' => 'weight',      '#title' => t('Weight for @title', array('@title' => $filter['title'])),      '#title_display' => 'invisible',      '#delta' => 50,      '#default_value' => $filters[$name]->weight,      '#parents' => array('filters', $name, 'weight'),    );    $form['filters']['order'][$name]['#weight'] = $filters[$name]->weight;  }  // Filter settings.  $form['filter_settings_title'] = array(    '#type' => 'item',    '#title' => t('Filter settings'),  );  $form['filter_settings'] = array(    '#type' => 'vertical_tabs',  );  foreach ($filter_info as $name => $filter) {    if (isset($filter['settings callback']) && function_exists($filter['settings callback'])) {      $function = $filter['settings callback'];      // Pass along stored filter settings and default settings, but also the      // format object and all filters to allow for complex implementations.      $defaults = (isset($filter['default settings']) ? $filter['default settings'] : array());      $settings_form = $function($form, $form_state, $filters[$name], $format, $defaults, $filters);      if (!empty($settings_form)) {        $form['filters']['settings'][$name] = array(          '#type' => 'fieldset',          '#title' => $filter['title'],          '#parents' => array('filters', $name, 'settings'),          '#weight' => $filter['weight'],          '#group' => 'filter_settings',        );        $form['filters']['settings'][$name] += $settings_form;      }    }  }  $form['actions'] = array('#type' => 'actions');  $form['actions']['submit'] = array('#type' => 'submit', '#value' => t('Save configuration'));  return $form;}/** * Returns HTML for a text format's filter order form. * * @param $variables *   An associative array containing: *   - element: A render element representing the form. * * @ingroup themeable */function theme_filter_admin_format_filter_order($variables) {  $element = $variables['element'];  // Filter order (tabledrag).  $rows = array();  foreach (element_children($element, TRUE) as $name) {    $element[$name]['weight']['#attributes']['class'][] = 'filter-order-weight';    $rows[] = array(      'data' => array(        drupal_render($element[$name]['filter']),        drupal_render($element[$name]['weight']),      ),      'class' => array('draggable'),    );  }  $output = drupal_render_children($element);  $output .= theme('table', array('rows' => $rows, 'attributes' => array('id' => 'filter-order')));  drupal_add_tabledrag('filter-order', 'order', 'sibling', 'filter-order-weight', NULL, NULL, TRUE);  return $output;}/** * Form validation handler for filter_admin_format_form(). * * @see filter_admin_format_form_submit() */function filter_admin_format_form_validate($form, &$form_state) {  $format_format = trim($form_state['values']['format']);  $format_name = trim($form_state['values']['name']);  // Ensure that the values to be saved later are exactly the ones validated.  form_set_value($form['format'], $format_format, $form_state);  form_set_value($form['name'], $format_name, $form_state);  $result = db_query("SELECT format FROM {filter_format} WHERE name = :name AND format <> :format", array(':name' => $format_name, ':format' => $format_format))->fetchField();  if ($result) {    form_set_error('name', t('Text format names must be unique. A format named %name already exists.', array('%name' => $format_name)));  }}/** * Form submission handler for filter_admin_format_form(). * * @see filter_admin_format_form_validate() */function filter_admin_format_form_submit($form, &$form_state) {  // Remove unnecessary values.  form_state_values_clean($form_state);  // Add the submitted form values to the text format, and save it.  $format = $form['#format'];  foreach ($form_state['values'] as $key => $value) {    $format->$key = $value;  }  $status = filter_format_save($format);  // Save user permissions.  if ($permission = filter_permission_name($format)) {    foreach ($format->roles as $rid => $enabled) {      user_role_change_permissions($rid, array($permission => $enabled));    }  }  switch ($status) {    case SAVED_NEW:      drupal_set_message(t('Added text format %format.', array('%format' => $format->name)));      break;    case SAVED_UPDATED:      drupal_set_message(t('The text format %format has been updated.', array('%format' => $format->name)));      break;  }}/** * Form constructor for the text format deletion confirmation form. * * @param $format *   An object representing a text format. * * @see filter_menu() * @see filter_admin_disable_submit() * @ingroup forms */function filter_admin_disable($form, &$form_state, $format) {  $form['#format'] = $format;  return confirm_form($form,    t('Are you sure you want to disable the text format %format?', array('%format' => $format->name)),    'admin/config/content/formats',    t('Disabled text formats are completely removed from the administrative interface, and any content stored with that format will not be displayed. This action cannot be undone.'),    t('Disable')  );}/** * Form submission handler for filter_admin_disable(). */function filter_admin_disable_submit($form, &$form_state) {  $format = $form['#format'];  filter_format_disable($format);  drupal_set_message(t('Disabled text format %format.', array('%format' => $format->name)));  $form_state['redirect'] = 'admin/config/content/formats';}
 |