locale.pages.inc 5.59 KB
Newer Older
1 2 3
<?php

/**
4 5
 * @file
 * Interface translation summary, editing and deletion user interfaces.
6 7
 */

8
use Drupal\Component\Utility\SafeMarkup;
9
use Drupal\Core\Url;
10
use Drupal\Core\Render\Element;
11 12
use Drupal\locale\SourceString;
use Drupal\locale\TranslationString;
13
use Symfony\Component\HttpFoundation\RedirectResponse;
14 15
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;

16
/**
17
 * Page callback: Checks for translation updates and displays the status.
18
 *
19
 * Manually checks the translation status without the use of cron.
20 21
 *
 * @see locale_menu()
22
 */
23 24
function locale_translation_manual_status() {
  module_load_include('compare.inc', 'locale');
25

26 27 28 29 30
  // Check the translation status of all translatable projects in all languages.
  // First we clear the cached list of projects. Although not strictly
  // necessary, this is helpful in case the project list is out of sync.
  locale_translation_flush_projects();
  locale_translation_check_projects();
31

32 33 34 35
  // Execute a batch if required. A batch is only used when remote files
  // are checked.
  if (batch_get()) {
    return batch_process('admin/reports/translations');
36
  }
37
  return new RedirectResponse(\Drupal::url('locale.translate_status', array(), array('absolute' => TRUE)));
38 39
}

40 41 42 43 44 45 46 47 48
/**
 * Returns HTML for translation edit form.
 *
 * @param array $variables
 *   An associative array containing:
 *   - form: The form that contains the language information.
 *
 * @see locale_translate_edit_form()
 * @ingroup themeable
49
 */
50 51 52 53 54 55 56 57
function theme_locale_translate_edit_form_strings($variables) {
  $output = '';
  $form = $variables['form'];
  $header = array(
    t('Source string'),
    t('Translation for @language', array('@language' => $form['#language'])),
  );
  $rows = array();
58
  foreach (Element::children($form) as $lid) {
59 60 61 62 63 64 65 66 67
    $string = $form[$lid];
    if ($string['plural']['#value']) {
      $source = drupal_render($string['original_singular']) . '<br />' . drupal_render($string['original_plural']);
    }
    else {
      $source = drupal_render($string['original']);
    }
    $source .= empty($string['context']) ? '' : '<br /><small>' . t('In Context') . ':&nbsp;' . $string['context']['#value'] . '</small>';
    $rows[] = array(
68
      array('data' => SafeMarkup::set($source)),
69 70
      array('data' => $string['translations']),
    );
71
  }
72
  $table = array(
73
    '#type' => 'table',
74 75 76 77 78 79 80 81
    '#header' => $header,
    '#rows' => $rows,
    '#empty' => t('No strings available.'),
    '#attributes' => array('class' => array('locale-translate-edit-table')),
  );
  $output .= drupal_render($table);
  $pager = array('#theme' => 'pager');
  $output .= drupal_render($pager);
82
  return $output;
83
}
84 85

/**
86 87 88 89 90
 * Prepares variables for translation status information templates.
 *
 * Translation status information is displayed per language.
 *
 * Default template: locale-translate-edit-form-strings.html.twig.
91 92 93 94 95 96
 *
 * @param array $variables
 *   An associative array containing:
 *   - updates: The projects which have updates.
 *   - not_found: The projects which updates are not found.
 *
97
 * @see \Drupal\locale\Form\TranslationStatusForm
98
 */
99 100
function template_preprocess_locale_translation_update_info(&$variables) {
  $details = array();
101 102 103

  // Build output for available updates.
  if (isset($variables['updates'])) {
104
    $releases = array();
105 106 107 108 109
    if ($variables['updates']) {
      foreach ($variables['updates'] as $update) {
        $modules[] = $update['name'];
        $releases[] = t('@module (@date)', array('@module' => $update['name'], '@date' => format_date($update['timestamp'], 'html_date')));
      }
110
      $variables['modules'] = $modules;
111
    }
112 113 114 115
    $details['available_updates_list'] = array(
      '#theme' => 'item_list',
      '#items' => $releases,
    );
116 117 118 119
  }

  // Build output for updates not found.
  if (isset($variables['not_found'])) {
120
    $releases = array();
121
    $variables['missing_updates_status'] = format_plural(count($variables['not_found']), 'Missing translations for one project', 'Missing translations for @count projects');
122 123 124 125 126 127
    if ($variables['not_found']) {
      foreach ($variables['not_found'] as $update) {
        $version = $update['version'] ? $update['version'] : t('no version');
        $releases[] = t('@module (@version).', array('@module' => $update['name'], '@version' => $version)) . ' ' . $update['info'];
      }
    }
128 129 130 131 132 133 134 135
    $details['missing_updates_list'] = array(
      '#theme' => 'item_list',
      '#items' => $releases,
    );
    // Prefix the missing updates list if there is an available updates lists
    // before it.
    if (!empty($details['available_updates_list']['#items'])) {
      $details['missing_updates_list']['#prefix'] = t('Missing translations for:');
136 137
    }
  }
138
  $variables['details'] = $details;
139 140 141
}

/**
142 143 144 145 146 147
 * Prepares variables for most recent translation update templates.
 *
 * Displays the last time we checked for locale update data. In addition to
 * properly formatting the given timestamp, this function also provides a "Check
 * manually" link that refreshes the available update and redirects back to the
 * same page.
148
 *
149
 * Default template: locale-translation-last-check.html.twig.
150 151 152 153 154
 *
 * @param $variables
 *   An associative array containing:
 *   - last: The timestamp when the site last checked for available updates.
 *
155
 * @see \Drupal\locale\Form\TranslationStatusForm
156
 */
157
function template_preprocess_locale_translation_last_check(&$variables) {
158
  $last = $variables['last'];
159
  $variables['last_checked'] = ($last != NULL);
160
  $variables['time'] = \Drupal::service('date.formatter')->formatInterval(REQUEST_TIME - $last);
161
  $variables['link'] = \Drupal::l(t('Check manually'), new Url('locale.check_translation', array(), array('query' => drupal_get_destination())));
162
}