locale.pages.inc 3.19 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
 * Prepares variables for translation status information templates.
 *
 * Translation status information is displayed per language.
 *
 * Default template: locale-translate-edit-form-strings.html.twig.
46 47 48 49 50 51
 *
 * @param array $variables
 *   An associative array containing:
 *   - updates: The projects which have updates.
 *   - not_found: The projects which updates are not found.
 *
52
 * @see \Drupal\locale\Form\TranslationStatusForm
53
 */
54
function template_preprocess_locale_translation_update_info(array &$variables) {
55 56
  // Build output for available updates.
  if (isset($variables['updates'])) {
57
    $variables['available_updates'] = [];
58 59
    if ($variables['updates']) {
      foreach ($variables['updates'] as $update) {
60 61 62 63 64
        $variables['modules'][] = $update['name'];
        // Format date for Twig template.
        $release = $update;
        $release['date'] = \Drupal::service('date.formatter')->format($update['timestamp'], 'html_date');
        $variables['available_updates'][] = $release;
65 66 67 68 69 70
      }
    }
  }
}

/**
71 72 73 74 75 76
 * 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.
77
 *
78
 * Default template: locale-translation-last-check.html.twig.
79
 *
80
 * @param array $variables
81 82 83
 *   An associative array containing:
 *   - last: The timestamp when the site last checked for available updates.
 *
84
 * @see \Drupal\locale\Form\TranslationStatusForm
85
 */
86
function template_preprocess_locale_translation_last_check(array &$variables) {
87
  $last = $variables['last'];
88
  $variables['last_checked'] = ($last != NULL);
89
  $variables['time'] = \Drupal::service('date.formatter')->formatTimeDiffSince($last);
90
  $variables['link'] = \Drupal::l(t('Check manually'), new Url('locale.check_translation', array(), array('query' => \Drupal::destination()->getAsArray())));
91
}