You are here

stringoverrides.admin.inc in String Overrides 7

Same filename and directory in other branches
  1. 5 stringoverrides.admin.inc
  2. 6 stringoverrides.admin.inc

Admin page callbacks for the String Overrides module.

File

stringoverrides.admin.inc
View source
<?php

/**
 * @file
 * Admin page callbacks for the String Overrides module.
 */

/**
 * Menu callback for the String Overrides module to display its administration
 */
function stringoverrides_admin($form, $form_state, $lang = NULL) {

  // See which language we're modifying
  if (empty($lang)) {
    $language = language_default();
    $lang = $language->language;
  }

  // Setup the form
  $form['#cache'] = TRUE;
  $form['#attached']['css'][drupal_get_path('module', 'stringoverrides') . '/stringoverrides.admin.css'] = array();
  $form['lang'] = array(
    '#type' => 'hidden',
    '#value' => $lang,
  );
  $form['string'] = array(
    '#tree' => TRUE,
    '#theme' => 'stringoverrides_strings',
  );

  // Retrieve the string overrides from the variables table.
  $words = array(
    FALSE => variable_get("locale_custom_disabled_strings_{$lang}", array()),
    TRUE => variable_get("locale_custom_strings_{$lang}", array()),
  );
  $strings = array();
  foreach ($words as $enabled => $custom_strings) {
    foreach ($custom_strings as $context => $translations) {
      foreach ($translations as $source => $translation) {
        $strings[] = array(
          'enabled' => $enabled,
          'context' => $context,
          'source' => $source,
          'translation' => $translation,
        );
      }
    }
  }

  // See how many string rows there should be.
  $string_count = 0;
  if (isset($form_state['string_count'])) {
    $string_count = $form_state['string_count'];
  }
  else {
    $string_count = count($strings) + 1;
  }

  // Sort the strings and display them in the form.
  usort($strings, 'stringoverrides_admin_word_sort');
  for ($index = 0; $index < $string_count; $index++) {
    if (isset($strings[$index])) {
      $string = $strings[$index];
      $form['string'][$index] = stringoverrides_textbox_combo($index, $string['enabled'], $string['context'], $string['source'], $string['translation']);
    }
    else {
      $form['string'][$index] = stringoverrides_textbox_combo($index, -1);
    }
  }

  // Add the buttons to the form.
  $form['actions'] = array(
    '#type' => 'container',
    '#attributes' => array(
      'class' => array(
        'form-actions',
        'container-inline',
      ),
    ),
  );
  $form['actions']['more_strings'] = array(
    '#type' => 'submit',
    '#value' => t('Add row'),
    '#description' => t("If the amount of boxes above isn't enough, click here to add more choices."),
    '#weight' => 2,
    '#submit' => array(
      'stringoverrides_more_strings_submit',
    ),
    '#ajax' => array(
      'callback' => 'stringoverrides_ajax',
      'wrapper' => 'stringoverrides-wrapper',
      'method' => 'replace',
      'effect' => 'none',
    ),
  );
  $form['actions']['save'] = array(
    '#type' => 'submit',
    '#value' => t('Save configuration'),
    '#weight' => 3,
  );
  $form['actions']['remove'] = array(
    '#type' => 'submit',
    '#value' => t('Remove disabled strings'),
    '#weight' => 4,
    '#access' => !empty($strings),
  );
  return $form;
}

/**
 * Triggered when the user submits the administration page.
 */
function stringoverrides_admin_submit($form, &$form_state) {
  if (!in_array($form_state['clicked_button']['#id'], array(
    'edit-save',
    'edit-remove',
  ))) {

    // Submit the form only for save and remove buttons.
    return;
  }

  // Format the words correctly so that they're put into the database correctly.
  $words = array(
    FALSE => array(),
    TRUE => array(),
  );
  foreach ($form_state['values']['string'] as $index => $string) {
    if (!empty($string['source'])) {
      $context = check_plain($string['context']);

      // Get rid of carriage returns.
      list($source, $translation) = str_replace("\r", '', array(
        $string['source'],
        $string['translation'],
      ));
      $words[$string['enabled']][$context][$source] = $translation;
    }
  }

  // Save into the correct language definition.
  $lang = $form['lang']['#value'];
  if (empty($lang)) {
    $language = language_default();
    $lang = $language->language;
  }
  variable_set("locale_custom_strings_{$lang}", $words[1]);

  // Save the values and display a message to the user depend.
  switch ($form_state['clicked_button']['#id']) {
    case 'edit-save':
      variable_set("locale_custom_disabled_strings_{$lang}", $words[0]);
      drupal_set_message(t('Your changes have been saved.'));
      break;
    case 'edit-remove':
      variable_del("locale_custom_disabled_strings_{$lang}");
      drupal_set_message(t('The disabled strings have been removed.'));
      break;
  }
}

/**
 * Function to return a textbox combo form.
 */
function stringoverrides_textbox_combo($delta = 0, $enabled = TRUE, $context = '', $source = '', $translation = '') {
  $form['#tree'] = TRUE;
  $form['enabled'] = array(
    '#type' => 'checkbox',
    '#default_value' => $enabled == -1 ? TRUE : $enabled,
    // Have access if it's not a placeholder value.
    '#access' => $enabled != -1,
    '#attributes' => array(
      'title' => t('Flag whether this override should be active.'),
    ),
  );
  $form['source'] = array(
    '#type' => 'textarea',
    '#default_value' => $source,
    '#rows' => 1,
    '#attributes' => array(
      'title' => t('The original source text to be replaced.'),
    ),
  );
  $form['translation'] = array(
    '#type' => 'textarea',
    '#default_value' => $translation,
    '#rows' => 1,
    '#attributes' => array(
      'title' => t('The text to replace the original source text.'),
    ),
    // Hide the translation when the source is empty.
    '#states' => array(
      'invisible' => array(
        "#edit-string-{$delta}-source" => array(
          'empty' => TRUE,
        ),
      ),
    ),
  );
  $form['context'] = array(
    '#type' => 'textfield',
    '#default_value' => $context,
    '#size' => 5,
    '#maxlength' => 255,
    '#attributes' => array(
      'title' => t('Strings sometimes can have context applied to them. Most cases, this is not the case.'),
    ),
    // Hide the context when the source is empty.
    '#states' => array(
      'invisible' => array(
        "#edit-string-{$delta}-source" => array(
          'empty' => TRUE,
        ),
      ),
    ),
  );
  return $form;
}

/**
 * Theme the enabled box and the two text box strings
 */
function theme_stringoverrides_strings($variables) {
  $form = $variables['form'];
  $rows = array();
  foreach (element_children($form) as $key) {

    // Build the table row.
    $rows[$key] = array(
      'data' => array(
        array(
          'data' => drupal_render($form[$key]['enabled']),
          'class' => 'stringoverrides-enabled',
        ),
        array(
          'data' => drupal_render($form[$key]['source']),
          'class' => 'stringoverrides-source',
        ),
        array(
          'data' => drupal_render($form[$key]['translation']),
          'class' => 'stringoverrides-translation',
        ),
        array(
          'data' => drupal_render($form[$key]['context']),
          'class' => 'stringoverrides-context',
        ),
      ),
    );

    // Add any attributes on the element to the row, such as the ahah class.
    if (array_key_exists('#attributes', $form[$key])) {
      $rows[$key] = array_merge($rows[$key], $form[$key]['#attributes']);
    }
  }
  $header = array(
    $form[0]['enabled']['#access'] ? array(
      'data' => t('Enabled'),
      'title' => t('Flag whether the given override should be active.'),
    ) : NULL,
    array(
      'data' => t('Original'),
      'title' => t('The original source text to be replaced.'),
    ),
    array(
      'data' => t('Replacement'),
      'title' => t('The text to replace the original source text.'),
    ),
    array(
      'data' => t('Context'),
      'title' => t('Some strings have context applied to them. In those cases, you can provide the context in this column.'),
    ),
  );
  $output = theme('table', array(
    'header' => $header,
    'rows' => $rows,
    'attributes' => array(
      'id' => 'stringoverrides-wrapper',
    ),
  ));
  $output .= drupal_render_children($form);
  return $output;
}

/**
 * Menu callback; Display a new string override.
 */
function stringoverrides_ajax($form, &$form_state) {
  return $form['string'];
}

/**
 * Submit handler; The "Add row" button.
 */
function stringoverrides_more_strings_submit($form, &$form_state) {
  $form_state['string_count'] = count($form_state['values']['string']) + 1;
  $form_state['rebuild'] = TRUE;
}

/**
 * Sorts two words based on their source text.
 */
function stringoverrides_admin_word_sort($word1, $word2) {
  return strcasecmp($word1['source'], $word2['source']);
}

Functions

Namesort descending Description
stringoverrides_admin Menu callback for the String Overrides module to display its administration
stringoverrides_admin_submit Triggered when the user submits the administration page.
stringoverrides_admin_word_sort Sorts two words based on their source text.
stringoverrides_ajax Menu callback; Display a new string override.
stringoverrides_more_strings_submit Submit handler; The "Add row" button.
stringoverrides_textbox_combo Function to return a textbox combo form.
theme_stringoverrides_strings Theme the enabled box and the two text box strings