You are here

themekey_redirect_admin.inc in ThemeKey 7.3

File

themekey_redirect/themekey_redirect_admin.inc
View source
<?php

/**
 * @file
 * Contains all form manipulations required by ThemeKey Redirect.
 *
 * @author Markus Kalkbrenner | bio.logis GmbH
 *   @see http://drupal.org/user/124705
 */
require_once DRUPAL_ROOT . '/' . drupal_get_path('module', 'themekey_redirect') . '/themekey_redirect_build.inc';
require_once DRUPAL_ROOT . '/' . drupal_get_path('module', 'themekey') . '/themekey_admin.inc';

/**
 * Form builder for the rule chain.
 *
 * The form will not be validated. All changes will be saved immediately.
 * Validation will happen when the form displays the stored configuration.
 * Otherwise all the drag'n'drop stuff will not work.
 *
 * @see themekey_form_alter()
 * @see themekey_rule_chain_form_submit()
 * @see themekey_rule_chain_form_set_error()
 *
 * @ingroup forms
 */
function themekey_redirect_rule_chain_form($form, &$form_state) {
  $form = themekey_abstract_rule_chain_form($form, $form_state, array(
    'load_rules_callback' => 'themekey_redirect_load_rules',
    'themes' => themekey_redirect_options(),
    'rule_delete_path' => 'admin/config/user-interface/themekey/redirects/delete/',
  ));
  $items = themekey_redirect_load_rules();
  if (!empty($form['old_items'])) {
    foreach ($form['old_items'] as $id => &$old_item) {
      $old_item['theme']['#type'] = 'textfield';
      unset($old_item['theme']['#options']);
      $old_item['append_path'] = array(
        '#type' => 'checkbox',
        '#title' => t('append path'),
        '#default_value' => isset($items[$id]['append_path']) ? $items[$id]['append_path'] : TRUE,
      );
    }
  }
  $form['new_item']['theme']['#type'] = 'textfield';
  $form['new_item']['theme']['#default_value'] = 'http://';
  unset($form['new_item']['theme']['#options']);
  $form['new_item']['append_path'] = array(
    '#type' => 'checkbox',
    '#title' => t('append path'),
    '#default_value' => TRUE,
  );
  return $form;
}

/**
 * Validation of
 * @see themekey_rule_chain_form()
 */
function themekey_redirect_rule_chain_form_validate(&$form, $form_state) {
  themekey_abstract_rule_chain_form_validate($form, $form_state, array(
    'check_enabled_callback' => 'themekey_redirect_check_url',
    'not_enabled_message' => t('Not a valid URL'),
  ));
}

/**
 * Form submission handler for themekey_rule_chain_form().
 *
 * @see themekey_rule_chain_form()
 */
function themekey_redirect_rule_chain_form_submit($form, &$form_state) {
  themekey_abstract_rule_chain_form_submit($form, $form_state, array(
    'rule_set_callback' => 'themekey_redirect_rule_set',
  ));
}
function themekey_redirect_check_url($url) {
  return preg_match('@http(|s)://.+@', $url);
}

/**
 * Menu callback -- ask for confirmation of ThemeKey rule deletion
 */
function themekey_redirect_admin_delete_rule_confirm($form, &$form_state, $arg, $themekey_property_id) {
  $form['themekey_property_id'] = array(
    '#type' => 'value',
    '#value' => $themekey_property_id,
  );
  $title = themekey_redirect_format_rule_as_string($themekey_property_id);
  return confirm_form($form, t('Are you sure you want to delete the ThemeKey rule, %title?', array(
    '%title' => $title,
  )), 'admin/config/user-interface/themekey/redirects', t('This action cannot be undone.'), t('Delete'), t('Cancel'));
}

/**
 * Execute ThemeKey rule deletion
 */
function themekey_redirect_admin_delete_rule_confirm_submit($form, &$form_state) {
  if ($form_state['values']['confirm']) {
    themekey_redirect_rule_del($form_state['values']['themekey_property_id']);
  }
  $form_state['redirect'] = 'admin/config/user-interface/themekey/redirects';
}

/**
 * Themes themekey_redirect_rule_chain_form() and adds drag'n'drop features.
 *
 * @ingroup themeable
 */
function theme_themekey_redirect_rule_chain_form($variables) {
  return theme_themekey_abstract_rule_chain_form($variables, array(
    'header' => array(
      t('Redirecting Rule Chain'),
      t('Target'),
      t('Enabled'),
      t('Operation'),
      t('Parent'),
      t('Weight'),
      t('Page<br />Cache'),
    ),
  ));
}

/**
 * Form builder for the redirect settings form.
 *
 * @ingroup forms
 */
function themekey_redirect_settings_form() {
  $form = array();
  $form['themekey_redirect'] = array(
    '#type' => 'fieldset',
    '#title' => t('Redirect Settings'),
    '#collapsible' => FALSE,
    '#collapsed' => FALSE,
  );
  $form['themekey_redirect']['themekey_redirect_check_once'] = array(
    '#type' => 'checkbox',
    '#title' => t('Only evaluate once.'),
    '#default_value' => variable_get('themekey_redirect_check_once', FALSE),
    '#description' => t('Only evaluate the rule chain for one time. The evaluation happens immediately when the user hits the site and never again util the user closes the browser.'),
  );
  $form['themekey_redirect']['themekey_redirect_redirect_once'] = array(
    '#type' => 'checkbox',
    '#title' => t("Don't evaluate if the user comes back."),
    '#default_value' => variable_get('themekey_redirect_redirect_once', FALSE),
    '#description' => t("Don't evaluate the rule chain again if the user comes back after a redirect. This state is saved until the user closes the browser."),
  );
  $form['themekey_redirect']['themekey_redirect_compatible_path'] = array(
    '#type' => 'checkbox',
    '#title' => t("Append drupal compatible path."),
    '#default_value' => variable_get('themekey_redirect_compatible_path', FALSE),
    '#description' => t('Uses urls like index.php?q=node/1 instead of clean urls or translated paths.'),
  );
  return system_settings_form($form);
}

Functions

Namesort descending Description
themekey_redirect_admin_delete_rule_confirm Menu callback -- ask for confirmation of ThemeKey rule deletion
themekey_redirect_admin_delete_rule_confirm_submit Execute ThemeKey rule deletion
themekey_redirect_check_url
themekey_redirect_rule_chain_form Form builder for the rule chain.
themekey_redirect_rule_chain_form_submit Form submission handler for themekey_rule_chain_form().
themekey_redirect_rule_chain_form_validate Validation of
themekey_redirect_settings_form Form builder for the redirect settings form.
theme_themekey_redirect_rule_chain_form Themes themekey_redirect_rule_chain_form() and adds drag'n'drop features.