locale.module 20.3 KB
Newer Older
Dries's avatar
   
Dries committed
1
<?php
2
// $Id$
Dries's avatar
   
Dries committed
3

Dries's avatar
   
Dries committed
4
5
6
7
8
9
/**
 * @file
 * Enables administrators to manage the site interface languages.
 *
 * When enabled, the site interface can be displayed in different
 * languages. The setup of languages and translations is completely
10
 * web based. Gettext portable object files are supported.
Dries's avatar
   
Dries committed
11
12
13
14
 */

// ---------------------------------------------------------------------------------
// Hook implementations (needed on all page loads)
Dries's avatar
   
Dries committed
15

Dries's avatar
   
Dries committed
16
17
18
/**
 * Implementation of hook_help().
 */
19
function locale_help($section) {
Dries's avatar
   
Dries committed
20
  switch ($section) {
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
    case 'admin/help#locale':
      $output = '<p>'. t('The locale module allows you to present your Drupal site in a language other than the default English. You can use it to set up a multi-lingual web site or replace given <em>built-in</em> text with text which has been customized for your site. Whenever the locale module encounters text which needs to be displayed, it tries to translate it into the currently selected language. If a translation is not available, then the string is remembered, so you can look up untranslated strings easily.') .'</p>';
      $output .= '<p>'. t('The locale module provides two options for providing translations. The first is the integrated web interface, via which you can search for untranslated strings, and specify their translations. An easier and less time-consuming method is to import existing translations for your language.  These translations are available as <em>GNU gettext Portable Object files</em> (<em>.po</em> files for short).  Translations for many languages are available for download from the translation page.') .'</p>';
      $output .= '<p>'. t('If an existing translation does not meet your needs, the <em>.po</em> files are easily edited with special editing tools. The locale module\'s import feature allows you to add strings from such files into your site\'s database. The export functionality enables you to share your translations with others, generating Portable Object files from your site strings.') .'</p>';
      $output .= t('<p>You can</p>
<ul>
<li>administer localization at <a href="%admin-locale">administer &gt;&gt; localization</a>.</li>
<li>manage strings for the localization: <a href="%admin-locale-string-search">administer &gt;&gt; localization &gt;&gt; manage strings</a>.</li>
<li>add a locale language: <a href="%admin-locale-language-add">administer &gt;&gt; localization &gt;&gt; add language</a>.</li>
<li>download translation files from the <a href="%external-http-drupal-org-project-Translations">Drupal translations page</a>.
</li>
</ul>
', array('%admin-locale' => url('admin/locale'), '%admin-locale-string-search' => url('admin/locale/string/search'), '%admin-locale-language-add' => url('admin/locale/language/add'), '%external-http-drupal-org-project-Translations' => 'http://drupal.org/project/Translations'));
      $output .= '<p>'. t('For more information please read the configuration and customization handbook <a href="%locale">Locale page</a>.', array('%locale' => 'http://www.drupal.org/handbook/modules/locale/')) .'</p>';
      return $output;
Dries's avatar
   
Dries committed
36
37
38
39
    case 'admin/modules#description':
      return t('Enables the translation of the user interface to languages other than English.');
    case 'admin/locale':
    case 'admin/locale/language/overview':
40
      return t("<p>Drupal provides support for the translation of its interface text into different languages.  This page provides an overview of the installed languages. You can add a language on the <a href=\"%add-language\">add language page</a>, or directly by <a href=\"%import\">importing a translation</a>. If multiple languages are enabled, registered users will be able to set their preferred language.  The site default will be used for anonymous visitors and for users without their own settings.</p><p>Drupal interface translations may be added or extended by several courses: by <a href=\"%import\">importing</a> an existing translation, by <a href=\"%search\">translating everything</a> from scratch, or by a combination of these approaches.</p>", array("%search" => url("admin/locale/string/search"), "%import" => url("admin/locale/language/import"), "%add-language" => url("admin/locale/language/add")));
Dries's avatar
   
Dries committed
41
    case 'admin/locale/language/add':
42
      return t("<p>You need to add all languages in which you would like to display the site interface. If you can't find the desired language in the quick-add dropdown, then you will need to provide the proper language code yourself. The language code may be used to negotiate with browsers and to present flags, etc., so it is important to pick a code that is standardised for the desired language. You can also add a language by <a href=\"%import\">importing a translation</a>.</p>", array("%import" => url("admin/locale/language/import")));
Dries's avatar
   
Dries committed
43
    case 'admin/locale/language/import':
44
      return t("<p>This page allows you to import a translation provided in the gettext Portable Object (.po) format.  The easiest way to get your site translated is to obtain an existing Drupal translation and to import it.  You can find existing translations on the <a href=\"%url\">Drupal translation page</a>. Note that importing a translation file might take a while.</p>", array('%url' => 'http://drupal.org/project/translations'));
Dries's avatar
   
Dries committed
45
    case 'admin/locale/language/export':
46
      return t("<p>This page allows you to export Drupal strings. The first option is to export a translation so it can be shared.  The second option generates a translation template, which contains all Drupal strings, but without their translations. You can use this template to start a new translation using various software packages designed for this task.</p>");
Dries's avatar
   
Dries committed
47
    case 'admin/locale/string/search':
48
      return t("<p>It is often convenient to get the strings from your setup on the <a href=\"%export\">export page</a>, and use a desktop Gettext translation editor to edit the translations.  On this page you can search in the translated and untranslated strings, and the default English texts provided by Drupal.</p>", array("%export" => url("admin/locale/language/export")));
Dries's avatar
   
Dries committed
49
  }
Dries's avatar
   
Dries committed
50
51
}

Dries's avatar
   
Dries committed
52
/**
Dries's avatar
   
Dries committed
53
 * Implementation of hook_menu().
Dries's avatar
   
Dries committed
54
 */
Dries's avatar
   
Dries committed
55
function locale_menu($may_cache) {
Dries's avatar
   
Dries committed
56
  $items = array();
Dries's avatar
   
Dries committed
57

Dries's avatar
   
Dries committed
58
59
60
61
62
63
  if ($may_cache) {
    $access = user_access('administer locales');

    // Main admin menu item
    $items[] = array('path' => 'admin/locale', 'title' => t('localization'),
      'callback' => 'locale_admin_manage', 'access' => $access);
Dries's avatar
   
Dries committed
64

Dries's avatar
   
Dries committed
65
66
67
68
69
70
    // Top level tabs
    $items[] = array('path' => 'admin/locale/language', 'title' => t('manage languages'),
      'access' => $access, 'weight' => -10, 'type' => MENU_DEFAULT_LOCAL_TASK);
    $items[] = array('path' => 'admin/locale/string/search', 'title' => t('manage strings'),
      'callback' => 'locale_admin_string', 'access' => $access, 'weight' => 10,
      'type' => MENU_LOCAL_TASK);
Dries's avatar
   
Dries committed
71

Dries's avatar
   
Dries committed
72
73
74
75
76
77
78
79
80
81
82
83
84
    // Manage languages subtabs
    $items[] = array('path' => 'admin/locale/language/overview', 'title' => t('list'),
      'callback' => 'locale_admin_manage', 'access' => $access, "weight" => 0,
      'type' => MENU_DEFAULT_LOCAL_TASK);
    $items[] = array('path' => 'admin/locale/language/add', 'title' => t('add language'),
      'callback' => 'locale_admin_manage_add', 'access' => $access, "weight" => 5,
      'type' => MENU_LOCAL_TASK);
    $items[] = array('path' => 'admin/locale/language/import', 'title' => t('import'),
      'callback' => 'locale_admin_import', 'access' => $access, 'weight' => 10,
      'type' => MENU_LOCAL_TASK);
    $items[] = array('path' => 'admin/locale/language/export', 'title' => t('export'),
      'callback' => 'locale_admin_export', 'access' => $access, 'weight' => 20,
      'type' => MENU_LOCAL_TASK);
Dries's avatar
   
Dries committed
85

Dries's avatar
   
Dries committed
86
87
88
89
90
91
92
93
94
95
96
    // Language related callbacks
    $items[] = array('path' => 'admin/locale/language/delete', 'title' => t('confirm'),
      'callback' => 'locale_admin_manage_delete_screen', 'access' => $access,
      'type' => MENU_CALLBACK);

    // String related callbacks
    $items[] = array('path' => 'admin/locale/string/edit', 'title' => t('edit'),
      'callback' => 'locale_admin_string', 'access' => $access, 'type' => MENU_CALLBACK);
    $items[] = array('path' => 'admin/locale/string/delete', 'title' => t('delete'),
      'callback' => 'locale_admin_string', 'access' => $access, 'type' => MENU_CALLBACK);
  }
Dries's avatar
   
Dries committed
97

Dries's avatar
   
Dries committed
98
  return $items;
Dries's avatar
   
Dries committed
99
100
}

Dries's avatar
   
Dries committed
101
/**
Dries's avatar
   
Dries committed
102
 * Implementation of hook_perm().
Dries's avatar
   
Dries committed
103
 */
Dries's avatar
   
Dries committed
104
105
106
107
108
109
110
111
112
113
114
115
116
function locale_perm() {
  return array('administer locales');
}

/**
 * Implementation of hook_user().
 */
function locale_user($type, $edit, &$user, $category = NULL) {
  $languages = locale_supported_languages();
  if ($type == 'form' && $category == 'account' && count($languages['name']) > 1) {
    if ($user->language == '') {
      $user->language = key($languages['name']);
    }
117
    $languages['name'] = array_map('check_plain', $languages['name']);
118
119
120
    $form['locale'] = array('#title' => t('Interface language settings'), '#type' => 'fieldset', '#weight' => 1);
    $form['locale']['language'] = array('#type' => 'radios', '#title' => t('Language'), '#default_value' => $user->language, '#options' => $languages['name'], '#description' => t('Selecting a different locale will change the interface language of the site.'));
    return $form;
Dries's avatar
   
Dries committed
121
122
123
  }
}

Dries's avatar
   
Dries committed
124
125
// ---------------------------------------------------------------------------------
// Locale core functionality (needed on all page loads)
Dries's avatar
   
Dries committed
126

Dries's avatar
   
Dries committed
127
128
129
130
131
132
133
134
/**
 * Provides interface translation services
 *
 * This function is called from t() to translate a string if needed.
 */
function locale($string) {
  global $locale;
  static $locale_t;
Dries's avatar
   
Dries committed
135

Dries's avatar
   
Dries committed
136
137
138
  // Store database cached translations in a static var
  if (!isset($locale_t)) {
    $cache = cache_get("locale:$locale");
Dries's avatar
   
Dries committed
139

Dries's avatar
   
Dries committed
140
141
142
143
144
    if ($cache == 0) {
      locale_refresh_cache();
      $cache = cache_get("locale:$locale");
    }
    $locale_t = unserialize($cache->data);
Dries's avatar
   
Dries committed
145
146
  }

Dries's avatar
   
Dries committed
147
148
149
150
151
  // We have the translation cached (if it is TRUE, then there is no
  // translation, so there is no point in checking the database)
  if (isset($locale_t[$string])) {
    $string = ($locale_t[$string] === TRUE ? $string : $locale_t[$string]);
  }
Dries's avatar
   
Dries committed
152

Dries's avatar
   
Dries committed
153
154
155
156
157
158
159
160
  // We don't have this translation cached, so get it from the DB
  else {
    $result = db_query("SELECT s.lid, t.translation FROM {locales_source} s INNER JOIN {locales_target} t ON s.lid = t.lid WHERE s.source = '%s' AND t.locale = '%s'", $string, $locale);
    // Translation found
    if ($trans = db_fetch_object($result)) {
      if (!empty($trans->translation)) {
        $locale_t[$string] = $trans->translation;
        $string = $trans->translation;
161
      }
Dries's avatar
   
Dries committed
162
    }
Dries's avatar
   
Dries committed
163

Dries's avatar
   
Dries committed
164
165
166
167
168
169
170
171
172
173
    // Either we have no such source string, or no translation
    else {
      $result = db_query("SELECT lid, source FROM {locales_source} WHERE source = '%s'", $string);
      // We have no such translation
      if ($obj = db_fetch_object($result)) {
        if ($locale) {
          db_query("INSERT INTO {locales_target} (lid, locale) VALUES (%d, '%s')", $obj->lid, $locale);
        }
      }
      // We have no such source string
174
      else {
Dries's avatar
   
Dries committed
175
176
        db_query("INSERT INTO {locales_source} (location, source) VALUES ('%s', '%s')", request_uri(), $string);
        if ($locale) {
177
          $lid = db_fetch_object(db_query("SELECT lid FROM {locales_source} WHERE source = '%s'", $string));
Dries's avatar
   
Dries committed
178
179
          db_query("INSERT INTO {locales_target} (lid, locale) VALUES (%d, '%s')", $lid->lid, $locale);
        }
180
      }
Dries's avatar
   
Dries committed
181
182
      // Clear locale cache in DB
      cache_clear_all("locale:$locale");
Dries's avatar
   
Dries committed
183
    }
Dries's avatar
   
Dries committed
184
185
  }

Dries's avatar
   
Dries committed
186
187
  return $string;
}
Dries's avatar
   
Dries committed
188

Dries's avatar
   
Dries committed
189
190
191
192
193
194
195
/**
 * Refreshes database stored cache of translations
 *
 * We only store short strings to improve performance and consume less memory.
 */
function locale_refresh_cache() {
  $languages = locale_supported_languages();
Dries's avatar
   
Dries committed
196

Dries's avatar
   
Dries committed
197
198
199
200
  foreach (array_keys($languages['name']) as $locale) {
    $result = db_query("SELECT s.source, t.translation, t.locale FROM {locales_source} s INNER JOIN {locales_target} t ON s.lid = t.lid WHERE t.locale = '%s' AND LENGTH(s.source) < 75", $locale);
    while ($data = db_fetch_object($result)) {
      $t[$data->source] = (empty($data->translation) ? TRUE : $data->translation);
Dries's avatar
   
Dries committed
201
    }
Dries's avatar
   
Dries committed
202
    cache_set("locale:$locale", serialize($t));
Dries's avatar
   
Dries committed
203
204
205
  }
}

Dries's avatar
   
Dries committed
206
207
208
209
210
211
212
213
214
/**
 * Returns list of languages supported on this site
 *
 * @param $reset Refresh cached language list
 * @param $getall Return all languages (even disabled ones)
 */
function locale_supported_languages($reset = FALSE, $getall = FALSE) {
  static $enabled = NULL;
  static $all = NULL;
Dries's avatar
   
Dries committed
215

Dries's avatar
   
Dries committed
216
217
  if ($reset) {
    unset($enabled); unset($all);
Dries's avatar
   
Dries committed
218
219
  }

Dries's avatar
   
Dries committed
220
221
222
223
224
225
  if (is_null($enabled)) {
    $enabled = $all = array();
    $all['name'] = $all['formula'] = $enabled['name'] = $enabled['formula'] = array();
    $result = db_query('SELECT locale, name, formula, enabled FROM {locales_meta} ORDER BY isdefault DESC, enabled DESC, name ASC');
    while ($row = db_fetch_object($result)) {
      $all['name'][$row->locale] = $row->name;
Dries's avatar
   
Dries committed
226
      $all['formula'][$row->locale] = $row->formula;
Dries's avatar
   
Dries committed
227
228
229
      if ($row->enabled) {
        $enabled['name'][$row->locale] = $row->name;
        $enabled['formula'][$row->locale] = $row->formula;
230
231
      }
    }
Kjartan's avatar
Kjartan committed
232
  }
Dries's avatar
   
Dries committed
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
  return $getall ? $all : $enabled;
}

/**
 * Returns plural form index for a specific number
 *
 * The index is computed from the formula of this language
 */
function locale_get_plural($count) {
  global $locale;
  static $locale_formula, $plurals = array();

  if (!isset($plurals[$count])) {
    if (!isset($locale_formula)) {
      $languages = locale_supported_languages();
      $locale_formula = $languages['formula'][$locale];
    }
    if ($locale_formula) {
      $n = $count;
      $plurals[$count] = @eval("return intval($locale_formula);");
      return $plurals[$count];
    }
    else {
      $plurals[$count] = -1;
      return -1;
258
    }
Dries's avatar
   
Dries committed
259
  }
Dries's avatar
   
Dries committed
260
  return $plurals[$count];
261
}
Dries's avatar
   
Dries committed
262

Dries's avatar
   
Dries committed
263
// ---------------------------------------------------------------------------------
264
// Language management functionality (administration only)
Dries's avatar
   
Dries committed
265

Dries's avatar
   
Dries committed
266
267
268
269
/**
 * Page handler for the language management screen
 */
function locale_admin_manage() {
270
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
271
272
  $edit = &$_POST['edit'];

273
  if ($_POST['op'] == t('Save configuration')) {
Dries's avatar
   
Dries committed
274
    // Save changes to existing languages
275
276
277
278
    $languages = locale_supported_languages(FALSE, TRUE);
    foreach($languages['name'] as $key => $value) {
      if ($edit['sitedefault'] == $key) {
        $edit['enabled'][$key] = 1; // autoenable the default language
Dries's avatar
   
Dries committed
279
      }
280
281
      if ($key == 'en') {
        // Disallow name change for English locale
282
        db_query("UPDATE {locales_meta} SET isdefault = %d, enabled = %d WHERE locale = 'en'", ($edit['sitedefault'] == $key), isset($edit['enabled'][$key]));
283
284
      }
      else {
285
        db_query("UPDATE {locales_meta} SET name = '%s', isdefault = %d, enabled = %d WHERE locale = '%s'", $edit['name'][$key], ($edit['sitedefault'] == $key), isset($edit['enabled'][$key]), $key);
Dries's avatar
   
Dries committed
286
      }
287
    }
Dries's avatar
   
Dries committed
288

289
290
    // Changing the locale settings impacts the interface:
    cache_clear_all();
Dries's avatar
   
Dries committed
291

292
    drupal_goto('admin/locale/language/overview');
Dries's avatar
   
Dries committed
293
  }
294

Dries's avatar
   
Dries committed
295
  return _locale_admin_manage_screen();
Dries's avatar
   
Dries committed
296
}
Dries's avatar
   
Dries committed
297

Dries's avatar
   
Dries committed
298
299
300
301
/**
 * User interface for the language deletion confirmation screen
 */
function locale_admin_manage_delete_screen() {
302
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
303
  $langcode = arg(4);
304
305
306
307
308
309
310
311
  $edit = $_POST['edit'];

  // Check confirmation and if so, delete language
  if ($edit['confirm']) {
    $languages = locale_supported_languages(FALSE, TRUE);
    if (isset($languages['name'][$edit['langcode']])) {
      db_query("DELETE FROM {locales_meta} WHERE locale = '%s'", $edit['langcode']);
      db_query("DELETE FROM {locales_target} WHERE locale = '%s'", $edit['langcode']);
312
      $message = t('The language %locale has been removed.', array('%locale' => theme('placeholder', t($languages['name'][$edit['langcode']]))));
313
314
315
316
317
318
319
320
      drupal_set_message($message);
      watchdog('locale', $message);
    }

    // Changing the locale settings impacts the interface:
    cache_clear_all();
    drupal_goto('admin/locale/language/overview');
  }
Dries's avatar
   
Dries committed
321

Dries's avatar
   
Dries committed
322
323
324
325
326
  // Do not allow deletion of English locale
  if ($langcode == 'en') {
    drupal_goto('admin/locale/language/overview');
    return;
  }
Dries's avatar
   
Dries committed
327

Dries's avatar
   
Dries committed
328
329
  // For other locales, warn user that data loss is ahead
  $languages = locale_supported_languages(FALSE, TRUE);
330

331
  $form['langcode'] = array('#type' => 'hidden', '#value' => $langcode);
332
  return confirm_form('locale_admin_manage_delete_screen', $form,
333
                  t('Are you sure you want to delete the language %name?', array('%name' => theme('placeholder', t($languages['name'][$langcode])))),
334
335
                  'admin/locale/language/overview',
                  t('Deleting a language will remove all data associated with it. This action cannot be undone.'),
336
                  t('Delete'), t('Cancel'));
Dries's avatar
   
Dries committed
337
}
Dries's avatar
   
Dries committed
338

Dries's avatar
   
Dries committed
339
340
341
342
/**
 * Page handler for the language addition screen
 */
function locale_admin_manage_add() {
343
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
344
345
346
  $edit = &$_POST['edit'];
  $isocodes = _locale_get_iso639_list();

347
348
349
350
351
  // Check for duplicates
  if ($duplicate = db_num_rows(db_query("SELECT locale FROM {locales_meta} WHERE locale = '%s'", $edit['langcode'])) == 0) {
    switch ($_POST['op']) {
      // Try to add new language
      case t('Add language'):
Dries's avatar
   
Dries committed
352
353
354
355
356
        // Set language name from the available list if needed
        if ($edit['langcode'] && !$edit['langname'] && isset($isocodes[$edit['langcode']])) {
          _locale_add_language($edit['langcode'], $isocodes[$edit['langcode']][0]);
          drupal_goto('admin/locale');
        }
357
358
        break;
      case t('Add custom language'):
Dries's avatar
   
Dries committed
359
        // Add language, if we have the details
360
        if ($edit['langcode'] && $edit['langname']) {
Dries's avatar
   
Dries committed
361
362
363
364
          _locale_add_language($edit['langcode'], $edit['langname']);
          drupal_goto('admin/locale');
        }
        // Seems like we have not received some data
365
        drupal_set_message(t('The language code and the English name of the new language must be specified.'), 'error');
366
367
368
369
370
371
372
        break;
      default:
        break;
    }
  }
  else {
    drupal_set_message(t('The language %language (%code) already exists.', array('%language' => theme('placeholder', check_plain($edit['langname'])), '%code' => theme('placeholder', $edit['langcode']))), 'error');
Dries's avatar
   
Dries committed
373
  }
Dries's avatar
   
Dries committed
374
  return _locale_admin_manage_add_screen();
Dries's avatar
   
Dries committed
375
}
376

Dries's avatar
   
Dries committed
377
// ---------------------------------------------------------------------------------
378
// Gettext Portable Object import functionality (administration only)
Dries's avatar
   
Dries committed
379

Dries's avatar
   
Dries committed
380
381
382
383
/**
 * Page handler for the translation import screen
 */
function locale_admin_import() {
384
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
385
386
387
  $edit = &$_POST['edit'];
  switch ($_POST['op']) {
    case t('Import'):
Dries's avatar
   
Dries committed
388

Dries's avatar
   
Dries committed
389
390
391
392
393
394
      // Add language, if not yet supported
      $languages = locale_supported_languages(TRUE, TRUE);
      if (!isset($languages['name'][$edit['langcode']])) {
        $isocodes = _locale_get_iso639_list();
        _locale_add_language($edit['langcode'], $isocodes[$edit['langcode']][0], FALSE);
      }
Dries's avatar
   
Dries committed
395

Dries's avatar
   
Dries committed
396
397
      // Now import strings into the language
      $file = file_check_upload('file');
398
      if ($ret = _locale_import_po($file, $edit['langcode'], $edit['mode']) == FALSE) {
399
        $message = t('The translation import of %filename failed.', array('%filename' => theme('placeholder', $file->filename)));
400
401
        drupal_set_message($message, 'error');
        watchdog('locale', $message, WATCHDOG_ERROR);
Dries's avatar
   
Dries committed
402
      }
403

Dries's avatar
   
Dries committed
404
405
      drupal_goto('admin/locale');
      break;
Kjartan's avatar
Kjartan committed
406
  }
Dries's avatar
   
Dries committed
407
  return _locale_admin_import_screen();
Dries's avatar
   
Dries committed
408
}
Dries's avatar
   
Dries committed
409

Dries's avatar
   
Dries committed
410

Dries's avatar
   
Dries committed
411
412
// ---------------------------------------------------------------------------------
// Gettext Portable Object export functionality (administration only)
Kjartan's avatar
Kjartan committed
413

Dries's avatar
   
Dries committed
414
415
416
417
/**
 * Page handler for the translation export screen
 */
function locale_admin_export() {
418
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
419
420
421
422
423
  switch ($_POST['op']) {
    case t('Export'):
      _locale_export_po($_POST['edit']['langcode']);
      break;
  }
Dries's avatar
   
Dries committed
424
  return _locale_admin_export_screen();
Kjartan's avatar
Kjartan committed
425
426
}

Dries's avatar
   
Dries committed
427

Dries's avatar
   
Dries committed
428
// ---------------------------------------------------------------------------------
429
// String search and editing functionality (administration only)
Dries's avatar
   
Dries committed
430
431
432
433
434

/**
 * Page handler for the string search and administration screen
 */
function locale_admin_string() {
435
  include_once './includes/locale.inc';
Dries's avatar
   
Dries committed
436
437
  $op = ($_POST['op'] ? $_POST['op'] : arg(3));
  $edit =& $_POST['edit'];
Dries's avatar
   
Dries committed
438

Dries's avatar
   
Dries committed
439
440
  switch ($op) {
    case 'delete':
441
      $output .= _locale_string_delete(arg(4));
Dries's avatar
   
Dries committed
442
      $output .= _locale_string_seek();
Dries's avatar
   
Dries committed
443
444
      break;
    case 'edit':
445
      $output .= _locale_string_edit(arg(4));
Dries's avatar
   
Dries committed
446
      $output .= _locale_string_seek();
Dries's avatar
   
Dries committed
447
448
      break;
    case t('Search'):
Dries's avatar
   
Dries committed
449
450
451
    case 'search':
      $output = _locale_string_seek();
      $output .= _locale_string_seek_form();
Dries's avatar
   
Dries committed
452
453
      break;
    case t('Save translations'):
454
      $output .= _locale_string_save(arg(4));
Dries's avatar
   
Dries committed
455
      drupal_goto('admin/locale/string/search');
Dries's avatar
   
Dries committed
456
457
      break;
    default:
Dries's avatar
   
Dries committed
458
  }
Dries's avatar
   
Dries committed
459
  return $output;
Dries's avatar
   
Dries committed
460
461
}

462