updated i18n, views, imagestyleflush, field_group
patch views_rss_media
This commit is contained in:
@@ -20,7 +20,7 @@ For support, please create a support request for this module's project:
|
||||
|
||||
Support questions by email to the module maintainer will be simply ignored. Use the issue tracker.
|
||||
|
||||
Now if you want professional (paid) support the module maintainer may be available occassionally.
|
||||
Now if you want professional (paid) support the module maintainer may be available occasionally.
|
||||
Drop me a message to check availability and hourly rates, http://reyero.net/en/contact
|
||||
|
||||
====================================================================
|
||||
|
@@ -8,9 +8,8 @@ files[] = i18n_object.inc
|
||||
files[] = i18n.test
|
||||
configure = admin/config/regional/i18n
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -198,7 +198,8 @@ function i18n_language_field_extra() {
|
||||
*/
|
||||
function i18n_language_list($field = 'name', $mode = NULL) {
|
||||
$mode = isset($mode) ? $mode : variable_get('i18n_language_list', I18N_LANGUAGE_ENABLED);
|
||||
return locale_language_list($field, I18N_LANGUAGE_EXTENDED & $mode);
|
||||
$all = I18N_LANGUAGE_EXTENDED & $mode;
|
||||
return locale_language_list($field, $all);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -11,7 +11,7 @@ class Drupali18nTestCase extends DrupalWebTestCase {
|
||||
|
||||
function setUpLanguages($admin_permissions = array()) {
|
||||
// Setup admin user.
|
||||
$this->admin_user = $this->drupalCreateUser(array_merge(array('bypass node access', 'administer nodes', 'administer languages', 'administer content types', 'administer blocks', 'access administration pages', 'translate interface'), $admin_permissions));
|
||||
$this->admin_user = $this->drupalCreateUser(array_merge(array('bypass node access', 'administer nodes', 'administer languages', 'administer content types', 'administer fields', 'administer blocks', 'access administration pages', 'translate interface'), $admin_permissions));
|
||||
|
||||
$this->drupalLogin($this->admin_user);
|
||||
|
||||
|
@@ -0,0 +1,92 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Troubleshooting
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Block languages module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, allows the user to configure
|
||||
for which languages each block is visible.
|
||||
|
||||
* For a full description of the module,
|
||||
visit https://www.drupal.org/node/1279698.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
The settings for visibility per language are provided under Visibility
|
||||
Settings via the Languages tab when configuring a block.
|
||||
|
||||
The Languages tab also provides a setting for whether the block is translatable.
|
||||
For custom blocks, the block title and the block content will be translatable.
|
||||
For blocks defined by modules, only the block title will be translatable. If
|
||||
"Make this block translatable" is selected, a Translate tab will appear for that
|
||||
block. This tab provides a UI for adding translations of the block in each
|
||||
available language.
|
||||
|
||||
|
||||
TROUBLESHOOTING
|
||||
---------------
|
||||
|
||||
Conflicts with Context
|
||||
|
||||
The Block languages module conflicts with the Context module, which alters how
|
||||
blocks are rendered. This issue can be tracked in the Internationalization
|
||||
issue queue: http://drupal.org/node/1343044
|
||||
|
||||
String Errors
|
||||
|
||||
The user must allow your used string format to be translated on
|
||||
admin/config/regional/i18n/strings or you are going to have an error message
|
||||
like "The string blocks:block:1:body for textgroup blocks is not allowed for
|
||||
translation because of its text format."
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -8,9 +8,8 @@ files[] = i18n_block.inc
|
||||
files[] = i18n_block.test
|
||||
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -37,6 +37,17 @@ function i18n_block_menu() {
|
||||
return $items;
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_permission().
|
||||
*/
|
||||
function i18n_block_permission() {
|
||||
return array(
|
||||
'translate blocks' => array(
|
||||
'title' => t('Translate Blocks'),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implement hook_menu_alter().
|
||||
*
|
||||
@@ -59,7 +70,7 @@ function i18n_block_menu_alter(&$items) {
|
||||
*/
|
||||
function i18n_block_translate_tab_access($module, $delta) {
|
||||
$block = block_load($module, $delta);
|
||||
return user_access('translate interface') && $block && isset($block->i18n_mode) && ($block->i18n_mode == I18N_MODE_LOCALIZE);
|
||||
return (user_access('translate interface') || user_access('translate blocks')) && $block && isset($block->i18n_mode) && ($block->i18n_mode == I18N_MODE_LOCALIZE);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -226,7 +237,7 @@ function i18n_block_form_block_admin_configure_alter(&$form, &$form_state, $form
|
||||
'#options' => i18n_language_list(),
|
||||
'#description' => t('If no language is selected, block will show regardless of language.'),
|
||||
);
|
||||
if (user_access('translate interface')) {
|
||||
if (user_access('translate interface') || user_access('translate blocks')) {
|
||||
$form['actions']['translate'] = array(
|
||||
'#type' => 'submit',
|
||||
'#name' => 'save_translate',
|
||||
|
@@ -72,15 +72,16 @@ class i18nBlocksTestCase extends Drupali18nTestCase {
|
||||
|
||||
$this->clickLink(t('translate'));
|
||||
|
||||
// Title is a textarea, body is a text_format.
|
||||
$this->assertFieldByName('strings[blocks:block:' . $box2['delta'] . ':title]', $translations['title']['es']);
|
||||
$this->assertFieldByName('strings[blocks:block:' . $box2['delta'] . ':body]', $translations['body']['es']);
|
||||
$this->assertFieldByName('strings[blocks:block:' . $box2['delta'] . ':body][value]', $translations['body']['es']);
|
||||
|
||||
// Update the translation.
|
||||
$translations['title']['es'] = $this->randomName(10);
|
||||
$translations['body']['es'] = $this->randomName(20);
|
||||
$edit = array(
|
||||
'strings[blocks:block:' . $box2['delta'] . ':title]' => $translations['title']['es'],
|
||||
'strings[blocks:block:' . $box2['delta'] . ':body]' => $translations['body']['es'],
|
||||
'strings[blocks:block:' . $box2['delta'] . ':body][value]' => $translations['body']['es'],
|
||||
);
|
||||
$this->drupalPost(NULL, $edit, t('Save translation'));
|
||||
$this->i18nAssertTranslations($translations['title'], '', 'Updated block title translation displayed.');
|
||||
|
@@ -0,0 +1,76 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Contact translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, helps with the multilingual
|
||||
configuration of the site contact forms. This module makes contact categories
|
||||
and replies available for translation.
|
||||
|
||||
* For a full description of the module, visit
|
||||
https://www.drupal.org/node/1396984.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes,
|
||||
visit https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
1. Enable the Contact translation module included with the Internationalization
|
||||
module.
|
||||
2. Go to Administration > Structure > Contact form.
|
||||
3. Select edit for the form to configure.
|
||||
4. Select the Translate tab.
|
||||
5. Select the translate link for a language.
|
||||
6. Translate the Category and Auto-reply text.
|
||||
7. Select Save translation.
|
||||
8. Repeat steps 5 to 7 for each language.
|
||||
9. Repeat steps 2 to 8 for all forms.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -5,9 +5,8 @@ dependencies[] = i18n_string
|
||||
package = Multilingual - Internationalization
|
||||
core = 7.x
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -0,0 +1,78 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Field translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, allows for translation of text
|
||||
associated with a field's settings including the label, help text, default
|
||||
value, and list options.
|
||||
|
||||
* For a full description of the module, visit this page
|
||||
https://www.drupal.org/node/1279346.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
1. Enable the Field translation module included with Internationalization.
|
||||
2. Go to Administration > Configuration > Regional and language > Translate
|
||||
interface.
|
||||
3. Select the Filter Translatable Strings field set and limit search to fields.
|
||||
4. Edit the desired field and Save.
|
||||
|
||||
For the translation to be displayed, the user needs to use some of the Field
|
||||
Formatters provided by this module whose name usually ends up in 'translated'.
|
||||
For most core fields it is Default translated.
|
||||
|
||||
Note: The Field Translation module does not provide content translation for
|
||||
fields. This functionality is provided by the Entity Translation (ET) module.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -72,7 +72,7 @@ function i18n_field_i18n_string_info() {
|
||||
'description' => t('Configurable fields descriptions, defaults, options, etc.'),
|
||||
'format' => FALSE, // This group doesn't have formatted strings
|
||||
'list' => TRUE, // This group can list all strings
|
||||
'class' => 'i18n_string_textgroup_cached',
|
||||
'class' => variable_get('i18n_string_textgroup_class_field', 'i18n_string_textgroup_cached'),
|
||||
);
|
||||
return $groups;
|
||||
}
|
||||
|
@@ -6,9 +6,8 @@ package = Multilingual - Internationalization
|
||||
core = 7.x
|
||||
files[] = i18n_field.inc
|
||||
files[] = i18n_field.test
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -194,6 +194,9 @@ function i18n_field_field_widget_form_alter(&$element, &$form_state, $context) {
|
||||
// Single-value file fields and image fields.
|
||||
$alter_element = &$element[0];
|
||||
}
|
||||
elseif ($field['type'] == 'url' && $field['module'] == 'url' && $field['cardinality'] == 1) {
|
||||
$alter_element = &$element;
|
||||
}
|
||||
elseif (isset($element['value'])) {
|
||||
// Number fields. Single-value text fields.
|
||||
$alter_element = &$element['value'];
|
||||
@@ -202,6 +205,10 @@ function i18n_field_field_widget_form_alter(&$element, &$form_state, $context) {
|
||||
// Entityreference fields using the entityreference_autocomplete widget.
|
||||
$alter_element = &$element['target_id'];
|
||||
}
|
||||
elseif ($field['type'] == 'node_reference' && isset($element['nid'])) {
|
||||
// The node_reference fields using the entityreference_autocomplete widget.
|
||||
$alter_element = &$element['nid'];
|
||||
}
|
||||
else {
|
||||
// All other fields.
|
||||
$alter_element = &$element;
|
||||
@@ -446,3 +453,120 @@ function i18n_field_type_info($type = NULL, $property = NULL) {
|
||||
return $info;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_field_info_alter().
|
||||
*/
|
||||
function i18n_field_field_info_alter(&$field_info) {
|
||||
foreach(array_keys($field_info) as $type) {
|
||||
$field_info[$type]['property_callbacks'][] = 'i18n_field_entity_property_callback';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Prime the cache to avoid single db queries for entity fields / properties.
|
||||
*
|
||||
* This is mainly uses when large operations are occuring like a flush of the
|
||||
* entity_property_infos().
|
||||
*/
|
||||
function i18n_field_prime_caches() {
|
||||
global $language;
|
||||
static $cache_primed;
|
||||
|
||||
// Fill the cache. This should avoid single db queries when filling the
|
||||
// properties.
|
||||
if (empty($cache_primed)) {
|
||||
$cache_primed = TRUE;
|
||||
$text_group = i18n_string_textgroup('field');
|
||||
// Load all strings at once to avoid callbacks for each individual string.
|
||||
$text_group->load_strings();
|
||||
$text_group->multiple_translation_search(array('type' => '*', 'objectid' => '*', 'property' => '*'), $language->language);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback to translate entity property info for a fields.
|
||||
*
|
||||
* @see entity_metadata_field_entity_property_info()
|
||||
* @see entity_metadata_field_default_property_callback()
|
||||
* @see i18n_field_i18n_object_info_alter()
|
||||
* @see hook_module_implements_alter()
|
||||
*/
|
||||
function i18n_field_entity_property_callback(&$info, $entity_type, $field, $instance, $field_type) {
|
||||
global $language;
|
||||
|
||||
// This could create a endless recursion if it's called during rebuilding the
|
||||
// cache for i18n_object_info(). So if the cache of i18n_object_info isn't
|
||||
// available yet we assume the worst case, leave the info alone but trigger a
|
||||
// rebuild of the property when hook_i18n_object_info_alter is invoked. At
|
||||
// that point the info is available and we can rely on it.
|
||||
if (!$info = &drupal_static('i18n_object_info')) {
|
||||
$i18n_field_entity_property_callback_fallback = &drupal_static(__FUNCTION__);
|
||||
$i18n_field_entity_property_callback_fallback = TRUE;
|
||||
return;
|
||||
}
|
||||
|
||||
i18n_field_prime_caches();
|
||||
$name = $field['field_name'];
|
||||
$property = &$info[$entity_type]['bundles'][$instance['bundle']]['properties'][$name];
|
||||
$property['label'] = i18n_field_translate_property($instance, 'label', $language->language);
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_i18n_object_info_alter().
|
||||
*/
|
||||
function i18n_field_i18n_object_info_alter(&$info) {
|
||||
if (drupal_static('i18n_field_entity_property_callback')) {
|
||||
if ($info = drupal_static('i18n_object_info')) {
|
||||
// Clean static and permanent cache of the data and then re-run the property
|
||||
// building.
|
||||
// Use a lock to avoid stampeding.
|
||||
$lock_name = 'i18n_field_entity_property_callback_fallback:' . $GLOBALS['language']->language;
|
||||
// See if another request is already doing this. If so we bail out here as
|
||||
// we won't help with anything at the moment.
|
||||
if (!lock_may_be_available($lock_name)) {
|
||||
return;
|
||||
}
|
||||
if (lock_acquire($lock_name)) {
|
||||
i18n_field_prime_caches();
|
||||
// Inject translated properties.
|
||||
$entity_property_info = entity_get_property_info();
|
||||
foreach ($entity_property_info as $entity_type => $properties) {
|
||||
if (isset($properties['bundles'])) {
|
||||
foreach ($properties['bundles'] as $bundle => $bundle_properties) {
|
||||
if ($bundle_properties['properties']) {
|
||||
foreach ($bundle_properties['properties'] as $bundle_property => $bundle_property_info) {
|
||||
if ($instance = field_info_instance($entity_type, $bundle_property, $bundle)) {
|
||||
$property = &$entity_property_info[$entity_type]['bundles'][$instance['bundle']]['properties'][$bundle_property];
|
||||
$property['label'] = i18n_field_translate_property($instance, 'label', $GLOBALS['language']->language);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// Inject into static cache.
|
||||
$entity_get_property_info = &drupal_static('entity_get_property_info', array());
|
||||
$entity_get_property_info = $entity_property_info;
|
||||
// Write permanent cache.
|
||||
cache_set('entity_property_info:' . $GLOBALS['language']->language, $entity_property_info);
|
||||
lock_release($lock_name);
|
||||
}
|
||||
}
|
||||
else {
|
||||
watchdog('i18n_field', 'Unable to run fall-back handling for entity property translation due missing "i18n_object_info" cache', array(), WATCHDOG_WARNING);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_module_implements_alter().
|
||||
*/
|
||||
function i18n_field_module_implements_alter(&$implementations, $hook) {
|
||||
if ($hook == 'i18n_object_info_alter') {
|
||||
// Move our hook implementation to the bottom.
|
||||
$group = $implementations['i18n_field'];
|
||||
unset($implementations['i18n_field']);
|
||||
$implementations['i18n_field'] = $group;
|
||||
}
|
||||
}
|
||||
|
@@ -0,0 +1,86 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Multilingual forum module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, helps with the multilingual
|
||||
configuration of the site’s forums.
|
||||
|
||||
* For a full description of the module visit
|
||||
https://www.drupal.org/node/1396988.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
To configure forum vocabulary
|
||||
|
||||
1. Enable the Multilingual forum module included with Internationalization.
|
||||
2. Go to Administration > Structure > Taxonomy.
|
||||
3. Select the "edit vocabulary" for the Forums vocabulary.
|
||||
4. Choose the translation mode (Localize or Translate).
|
||||
5. Select the "Save and translate" button.
|
||||
6. Select the "translate" link for a language.
|
||||
7. Translate the "Name" and "Description" for the forum.
|
||||
8. Select the "Save translation" button.
|
||||
9. Repeat steps 6 to 8 for each language.
|
||||
|
||||
To configure forum terms
|
||||
|
||||
1. Go to Administration > Structure > Forums.
|
||||
2. Select the "edit" link for a forum or container.
|
||||
3. Select the "Translate" tab.
|
||||
4. Select the "translate" link for a language.
|
||||
5. Translate the "Name" and "Description" for the term.
|
||||
6. Select the "Save translation" button.
|
||||
7. Repeat steps 4 to 6 for each language.
|
||||
8. Repeat all steps for all terms.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -7,9 +7,8 @@ package = Multilingual - Internationalization
|
||||
core = 7.x
|
||||
files[] = i18n_forum.test
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
111
sites/all/modules/contrib/localisation/i18n/i18n_menu/README.txt
Normal file
111
sites/all/modules/contrib/localisation/i18n/i18n_menu/README.txt
Normal file
@@ -0,0 +1,111 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Troubleshooting
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Menu translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, allows users to select a
|
||||
translation mode for each menu.
|
||||
|
||||
* For a full description of the module, visit this page:
|
||||
https://www.drupal.org/node/1113982.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes:
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
To link menu item menus to nodes, it is useful to have the following modules:
|
||||
|
||||
* Entity translation i18n menu module, a submodule of Entity translation -
|
||||
https://www.drupal.org/project/entity_translation
|
||||
* Menu translation node module - https://www.drupal.org/project/i18n_menu_node
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
Language-specific menus
|
||||
1. To create or edit a menu, navigate to Structure > Menus > (menu to edit) >
|
||||
Edit.
|
||||
2. In the Translation mode section, choose Fixed Language and a Language field
|
||||
will appear.
|
||||
3. Select a language, select Save, and add or update the menu items as needed.
|
||||
The menu block will only appear when viewing content in the same language.
|
||||
|
||||
There are three modes available: Translate and Localize, Fixed Language, and No
|
||||
Multilingual Options.
|
||||
|
||||
Translate and Localize:
|
||||
The user can create one menu for all languages, and translate or localize each
|
||||
menu item. There are two ways that menu items will be translated.
|
||||
1. The user can set a language when creating a custom menu item so that the menu
|
||||
item will only show up for that language. Menu items that link to nodes in a
|
||||
particular language will be treated this way.
|
||||
2. The user can localize other custom menu items without a language
|
||||
(for example, menu items linking to Views pages). Use the Translate tab to
|
||||
translate the menu item title and description. Translators can also use the
|
||||
"Translate interface" pages to translate these menu items.
|
||||
|
||||
Fixed Language:
|
||||
If the user chooses Fixed Language, they'll have to set up a separate menu in
|
||||
each language. This could become tedious if have a lot of languages enabled on
|
||||
the site, but is useful if the content or menu structure is different for each
|
||||
language.
|
||||
|
||||
No Multilingual Options:
|
||||
Only the menu will be translatable.
|
||||
|
||||
TROUBLESHOOTING
|
||||
---------------
|
||||
|
||||
A menu item linked to a node will be displayed only when the node language
|
||||
matches the page language. This is due to how the menu system works and the
|
||||
"Language selection" feature in i18n. Therefore, to get translated menus items
|
||||
that link to nodes, you first need translated content. For more information
|
||||
visit https://www.drupal.org/docs/7/multilingual/translating-content.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -10,9 +10,8 @@ core = 7.x
|
||||
files[] = i18n_menu.inc
|
||||
files[] = i18n_menu.test
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -53,6 +53,24 @@ function i18n_menu_menu_alter(&$items) {
|
||||
$items['admin/structure/menu/item/%menu_link'] = $items['admin/structure/menu/item/%menu_link/edit'];
|
||||
$items['admin/structure/menu/item/%menu_link']['type'] = MENU_CALLBACK;
|
||||
$items['admin/structure/menu/item/%menu_link/edit']['type'] = MENU_DEFAULT_LOCAL_TASK;
|
||||
$items['admin/structure/menu/manage/%menu']['title callback'] = 'i18n_menu_menu_overview_title';
|
||||
}
|
||||
|
||||
/**
|
||||
* Preprocess theme_menu_admin_overview to translate menu name and description
|
||||
*
|
||||
* @param $variables
|
||||
*/
|
||||
function i18n_menu_preprocess_menu_admin_overview(&$variables) {
|
||||
$variables['title'] = i18n_string(array('menu', 'menu', $variables['name'], 'title'), $variables['title'], array('sanitize' => FALSE));
|
||||
$variables['description'] = i18n_string(array('menu', 'menu', $variables['name'], 'description'), $variables['description'], array('sanitize' => FALSE));
|
||||
}
|
||||
|
||||
/**
|
||||
* Title callback for the menu overview page and links.
|
||||
*/
|
||||
function i18n_menu_menu_overview_title($menu) {
|
||||
return i18n_string(array('menu', 'menu', $menu['menu_name'], 'title'), $menu['title']);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -379,7 +397,7 @@ function i18n_menu_localize_tree($tree, $langcode = NULL) {
|
||||
if (_i18n_menu_link_process($item['link'])) {
|
||||
if (!_i18n_menu_link_is_visible($item['link'], $langcode)) {
|
||||
// Remove links for other languages than current.
|
||||
// Links with language wont be localized.
|
||||
// Links with language won't be localized.
|
||||
unset($tree[$index]);
|
||||
// @todo Research whether the above has any advantage over:
|
||||
// $item['hidden'] = TRUE;
|
||||
@@ -504,7 +522,7 @@ function _i18n_menu_link_localize(&$link, $langcode = NULL) {
|
||||
function _i18n_menu_link_description($link, $langcode = NULL) {
|
||||
if (!empty($link['options']['attributes']['title'])) {
|
||||
$key = i18n_object_info('menu_link', 'key');
|
||||
return i18n_string_translate(array('menu', 'item', $link[$key], 'description'), $link['options']['attributes']['title'], array('langcode' => $langcode));
|
||||
return i18n_string_translate(array('menu', 'item', $link[$key], 'description'), $link['options']['attributes']['title'], array('langcode' => $langcode, 'sanitize' => FALSE));
|
||||
}
|
||||
else {
|
||||
return NULL;
|
||||
@@ -515,9 +533,11 @@ function _i18n_menu_link_description($link, $langcode = NULL) {
|
||||
* Check whether this link is to be processed by i18n_menu and start processing.
|
||||
*/
|
||||
function _i18n_menu_link_process(&$link) {
|
||||
// Only visible links that have a language property and haven't been processed
|
||||
// before. We also check that they belong to a menu with language options.
|
||||
if (empty($link['i18n_menu']) && !empty($link['language']) && !empty($link['access']) && empty($link['hidden']) && i18n_menu_mode($link['menu_name'])) {
|
||||
// Only links that have a language property and haven't been processed before.
|
||||
// We also translate links marked as hidden because core breadcrumbs ignore
|
||||
// that flag and excluding them would basically interfere with core behaviour.
|
||||
// We also check that they belong to a menu with language options.
|
||||
if (empty($link['i18n_menu']) && !empty($link['language']) && !empty($link['access']) && i18n_menu_mode($link['menu_name'])) {
|
||||
// Mark so it won't be processed twice.
|
||||
$link['i18n_menu'] = TRUE;
|
||||
// Skip if administering this menu or this menu item.
|
||||
@@ -579,7 +599,7 @@ function _i18n_menu_link_is_visible($link, $langcode = NULL) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get localizable properties for menu link checking agains the router item.
|
||||
* Get localizable properties for menu link checking against the router item.
|
||||
*/
|
||||
function _i18n_menu_link_localizable_properties($link) {
|
||||
$props = array();
|
||||
@@ -723,15 +743,19 @@ function i18n_menu_form_menu_edit_item_alter(&$form, &$form_state) {
|
||||
* Add a "translate" link in operations column for each menu item.
|
||||
*/
|
||||
function i18n_menu_form_menu_overview_form_alter(&$form, &$form_state) {
|
||||
foreach (element_children($form) as $element) {
|
||||
if (substr($element, 0, 5) == 'mlid:') {
|
||||
$mlid = $form[$element]['#item']['mlid'];
|
||||
if (i18n_get_object('menu', $mlid)->get_translate_access()) {
|
||||
$form[$element]['operations']['translate'] = array(
|
||||
'#type' => 'link',
|
||||
'#title' => t('translate'),
|
||||
'#href' => "admin/structure/menu/item/{$mlid}/translate",
|
||||
);
|
||||
if (i18n_menu_mode($form['#menu']['menu_name'], I18N_MODE_MULTIPLE)) {
|
||||
foreach (element_children($form) as $element) {
|
||||
if (substr($element, 0, 5) == 'mlid:') {
|
||||
$item = $form[$element]["#item"];
|
||||
$mlid = $form[$element]['#item']['mlid'];
|
||||
if (i18n_get_object('menu', $mlid)->get_translate_access()) {
|
||||
$form[$element]['operations']['translate'] = array(
|
||||
'#type' => 'link',
|
||||
'#title' => t('translate'),
|
||||
'#href' => "admin/structure/menu/item/{$mlid}/translate",
|
||||
);
|
||||
$form[$element]['title']['#markup'] = l(_i18n_menu_link_title($item), $item['href'], $item['localized_options']);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -898,93 +922,25 @@ function i18n_menu_query_features_menu_link_alter($query) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_init().
|
||||
* Implements hook_query_TAG_alter()
|
||||
*
|
||||
* Using tag 'preferred_menu_links' added in menu_link_get_preferred().
|
||||
* See http://drupal.org/node/1854134
|
||||
*/
|
||||
function i18n_menu_init() {
|
||||
function i18n_menu_query_preferred_menu_links_alter(QueryAlterableInterface $query) {
|
||||
global $language;
|
||||
// Get queried tables.
|
||||
$tables = $query->getTables();
|
||||
|
||||
// The only way to override the default preferred menu link for a path is to
|
||||
// inject it into the static cache of the function menu_link_get_preferred().
|
||||
|
||||
// The problem with the default implementation is that it does not take the
|
||||
// language of a menu link into account. Whe having different menu trees for
|
||||
// different menus, this means that the active trail will not work for all but
|
||||
// one language.
|
||||
|
||||
// The code below is identical to the mentioned function except the added
|
||||
// language condition on the query.
|
||||
|
||||
// TODO: Adding an alter tag to the query would allow to do this with a simple
|
||||
// hook_query_alter() implementation.
|
||||
|
||||
$preferred_links = &drupal_static('menu_link_get_preferred');
|
||||
|
||||
$path = $_GET['q'];
|
||||
|
||||
// Look for the correct menu link by building a list of candidate paths,
|
||||
// which are ordered by priority (translated hrefs are preferred over
|
||||
// untranslated paths). Afterwards, the most relevant path is picked from
|
||||
// the menus, ordered by menu preference.
|
||||
$item = menu_get_item($path);
|
||||
$path_candidates = array();
|
||||
// 1. The current item href.
|
||||
$path_candidates[$item['href']] = $item['href'];
|
||||
// 2. The tab root href of the current item (if any).
|
||||
if ($item['tab_parent'] && ($tab_root = menu_get_item($item['tab_root_href']))) {
|
||||
$path_candidates[$tab_root['href']] = $tab_root['href'];
|
||||
}
|
||||
// 3. The current item path (with wildcards).
|
||||
$path_candidates[$item['path']] = $item['path'];
|
||||
// 4. The tab root path of the current item (if any).
|
||||
if (!empty($tab_root)) {
|
||||
$path_candidates[$tab_root['path']] = $tab_root['path'];
|
||||
}
|
||||
// Retrieve a list of menu names, ordered by preference.
|
||||
$menu_names = menu_get_active_menu_names();
|
||||
// Use an illegal menu name as the key for the preferred menu link.
|
||||
$selected_menu = MENU_PREFERRED_LINK;
|
||||
// Put the selected menu at the front of the list.
|
||||
array_unshift($menu_names, $selected_menu);
|
||||
|
||||
$query = db_select('menu_links', 'ml', array('fetch' => PDO::FETCH_ASSOC));
|
||||
$query->leftJoin('menu_router', 'm', 'm.path = ml.router_path');
|
||||
$query->fields('ml');
|
||||
// Weight must be taken from {menu_links}, not {menu_router}.
|
||||
$query->addField('ml', 'weight', 'link_weight');
|
||||
$query->fields('m');
|
||||
$query->condition('ml.link_path', $path_candidates, 'IN');
|
||||
|
||||
// Only look menu links with none or the current language.
|
||||
$query->condition('ml.language', array(LANGUAGE_NONE, i18n_language_interface()->language), 'IN');
|
||||
|
||||
// Sort candidates by link path and menu name.
|
||||
$candidates = array();
|
||||
foreach ($query->execute() as $candidate) {
|
||||
$candidate['weight'] = $candidate['link_weight'];
|
||||
$candidates[$candidate['link_path']][$candidate['menu_name']] = $candidate;
|
||||
// Add any menus not already in the menu name search list.
|
||||
if (!in_array($candidate['menu_name'], $menu_names)) {
|
||||
$menu_names[] = $candidate['menu_name'];
|
||||
}
|
||||
}
|
||||
|
||||
// Store the most specific link for each menu. Also save the most specific
|
||||
// link of the most preferred menu in $preferred_link.
|
||||
foreach ($path_candidates as $link_path) {
|
||||
if (isset($candidates[$link_path])) {
|
||||
foreach ($menu_names as $menu_name) {
|
||||
if (empty($preferred_links[$path][$menu_name]) && isset($candidates[$link_path][$menu_name])) {
|
||||
$candidate_item = $candidates[$link_path][$menu_name];
|
||||
$map = explode('/', $path);
|
||||
_menu_translate($candidate_item, $map);
|
||||
if ($candidate_item['access']) {
|
||||
$preferred_links[$path][$menu_name] = $candidate_item;
|
||||
if (empty($preferred_links[$path][MENU_PREFERRED_LINK])) {
|
||||
// Store the most specific link.
|
||||
$preferred_links[$path][MENU_PREFERRED_LINK] = $candidate_item;
|
||||
}
|
||||
}
|
||||
}
|
||||
foreach ($tables as $alias => $table) {
|
||||
if ($table['table'] == 'menu_links') {
|
||||
// Add language filter, ensuring that we don't have any collision when
|
||||
// determining the active menu trail when there are multiple menu items
|
||||
// with same link path but different languages.
|
||||
if ($language) {
|
||||
$query->condition('language', array($language->language, LANGUAGE_NONE), 'IN');
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -0,0 +1,96 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Multilingual content module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, provides extended multilingual
|
||||
options for nodes. These options help accommodate a variety of translation
|
||||
workflows by controlling how the language for nodes is set.
|
||||
|
||||
Note that the Multilingual content module lives in the i18n_node directory
|
||||
in the Internationalization package. Don't confuse this module with the core
|
||||
Content translation module.
|
||||
|
||||
* For a full description of the module visit:
|
||||
https://www.drupal.org/node/1279644.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
For each content type, the following Extended language options are available
|
||||
under the Multilingual Settings tab.
|
||||
1. "Set current language as default for new content" can be useful for content
|
||||
that is community-generated.
|
||||
2. "Require language" prevents users from creating 'Language neutral' nodes.
|
||||
3. "Lock language" prevents users from changing the language of a node after
|
||||
it's created.
|
||||
|
||||
Site-wide Settings for Node Translation
|
||||
1. There are also site-wide settings provided to help streamline how
|
||||
multilingual content is created. Navigate to Config > Regional and language >
|
||||
Multilingual settings > Node Options.
|
||||
2. "Switch interface for translating" switches the language of the user
|
||||
interface to the chosen language when a user translates a node. This is
|
||||
useful if users speak the language in which the translation is written. It
|
||||
means that after the node translation is saved, the language of the UI will
|
||||
match the language of the node.
|
||||
3. "Hide content translation links" will prevent the language switcher links
|
||||
from appearing in nodes and teasers. This is useful if a language switcher
|
||||
block is enabled on the site.
|
||||
4. The user can also select the default language for new nodes if the
|
||||
corresponding content type doesn't have language support. By default, it is
|
||||
set to be in the default language of the site, but this can be changed to be
|
||||
language neutral. This is a useful option when thinking about forward
|
||||
compatibility for adding multilingual support to these content types in the
|
||||
future.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -9,9 +9,8 @@ configure = admin/config/regional/i18n/node
|
||||
files[]=i18n_node.test
|
||||
files[]=i18n_node.variable.inc
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -222,8 +222,16 @@ function i18n_node_language_mode($type) {
|
||||
function i18n_node_node_prepare($node) {
|
||||
$options = variable_get('i18n_node_options_' . $node->type, array());
|
||||
if (i18n_node_type_enabled($node) && empty($node->nid) && !i18n_object_langcode($node) && in_array('current', $options)) {
|
||||
$default = variable_get('i18n_node_default_language_for_' . $node->type, '-- current --');
|
||||
|
||||
// Set current language for new nodes if option enabled
|
||||
$node->language = i18n_language_content()->language;
|
||||
if ($default === '-- current --') {
|
||||
$node->language = i18n_language_content()->language;
|
||||
}
|
||||
// If a custom language was specified, apply it.
|
||||
else {
|
||||
$node->language = $default;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -249,13 +257,16 @@ function i18n_node_permission() {
|
||||
/**
|
||||
* Implements hook_node_view()
|
||||
*/
|
||||
function i18n_node_node_view($node) {
|
||||
function i18n_node_node_view($node, $view_mode, $langcode) {
|
||||
if (i18n_node_type_enabled($node)) {
|
||||
$node->content['language'] = array(
|
||||
'#type' => 'item',
|
||||
'#title' => t('Language'),
|
||||
'#markup' => i18n_language_name($node->language),
|
||||
);
|
||||
$extra_fields_display_settings = field_extra_fields_get_display('node', $node->type, $view_mode);
|
||||
if ($extra_fields_display_settings['language']['visible']) {
|
||||
$node->content['language'] = array(
|
||||
'#type' => 'item',
|
||||
'#title' => t('Language'),
|
||||
'#markup' => i18n_language_name($node->language),
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -265,7 +276,9 @@ function i18n_node_node_view($node) {
|
||||
* Handles links for extended languages. Sets current interface language.
|
||||
*/
|
||||
function i18n_node_node_view_alter(&$build) {
|
||||
$node = $build['#node'];
|
||||
if (isset($build['#node'])) {
|
||||
$node = $build['#node'];
|
||||
}
|
||||
// Hide node translation links.
|
||||
if (variable_get('i18n_hide_translation_links', 0)) {
|
||||
if (isset($build['links']['translation'])) {
|
||||
@@ -417,7 +430,16 @@ function i18n_node_form_node_type_form_alter(&$form, &$form_state) {
|
||||
// Some settings about node languages. Add variables for node type from variable definition
|
||||
if ($form['#node_type']->type) {
|
||||
variable_type_include('node_type');
|
||||
$form['i18n'] += node_variable_type_subform($form['#node_type']->type, array('i18n_node_options', 'i18n_node_extended'));
|
||||
$form['i18n'] += node_variable_type_subform($form['#node_type']->type, array('i18n_node_options', 'i18n_node_default_language_for', 'i18n_node_extended'));
|
||||
// Only show custom default language field if "current" is checked.
|
||||
$form['i18n']['i18n_node_default_language_for']['#states'] = array(
|
||||
'visible' => array(
|
||||
':input[name="i18n_node_options[current]"]' => array('checked' => TRUE),
|
||||
),
|
||||
'required' => array(
|
||||
':input[name="i18n_node_options[current]"]' => array('checked' => TRUE),
|
||||
),
|
||||
);
|
||||
}
|
||||
// Add disabled message
|
||||
if ($disabled) {
|
||||
@@ -506,8 +528,6 @@ function _i18n_node_form_node_form_alter($form, &$form_state) {
|
||||
}
|
||||
}
|
||||
elseif (variable_get('i18n_node_default_language_none', 0) && !isset($form['#node']->nid)) {
|
||||
// Override locale module setting default language to nodes. It is already in form_state.
|
||||
// $form['language']['#value'] = $form_state['values']['language'] = LANGUAGE_NONE;
|
||||
// Only do this if the language is really disabled
|
||||
if (variable_get('language_content_type_' . $node->type, 0) == 0) {
|
||||
// Override locale module setting default language to nodes. It is already in form_state.
|
||||
|
@@ -45,13 +45,30 @@ function i18n_node_variable_info($options = array()) {
|
||||
'repeat' => array(
|
||||
'type' => 'options',
|
||||
'options' => array(
|
||||
'current' => t('Set current language as default for new content.', array(), $options),
|
||||
// Note: this was previously used only to mark new, translatable nodes
|
||||
// with the current language of the user. Now, this setting is extended
|
||||
// to allow a specific language to be chosen (defaulting to the current
|
||||
// language). This was done for backwards compatibility reasons.
|
||||
'current' => t('Set custom language as default for new content.', array(), $options),
|
||||
'required' => t('Require language (Do not allow Language Neutral).', array(), $options),
|
||||
'lock' => t('Lock language (Cannot be changed).', array(), $options),
|
||||
),
|
||||
),
|
||||
'group' => 'i18n',
|
||||
);
|
||||
// This field will only be displayed if "current" is checked above.
|
||||
$variables['i18n_node_default_language_for_[node_type]'] = array(
|
||||
'type' => 'multiple',
|
||||
'title' => t('Custom default language', array(), $options),
|
||||
'repeat' => array(
|
||||
'type' => 'select',
|
||||
'options' => array_merge(array(
|
||||
'-- current --' => t('Current language')
|
||||
), locale_language_list('name')),
|
||||
'default' => '-- current --',
|
||||
),
|
||||
'group' => 'i18n',
|
||||
);
|
||||
$variables['i18n_node_extended_[node_type]'] = array(
|
||||
'type' => 'multiple',
|
||||
'title' => t('Extended language support'),
|
||||
|
@@ -6,9 +6,8 @@ core = 7.x
|
||||
|
||||
files[] = i18n_path.inc
|
||||
files[] = i18n_path.test
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -0,0 +1,82 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Redirect translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, improves search engine
|
||||
optimization (SEO) for multilingual websites.
|
||||
|
||||
It redirects anonymous users (including web crawlers) to the translation of the
|
||||
page in the requested language, if it exists, using a 301 redirect code.
|
||||
|
||||
* For a full description of the module, visit this page:
|
||||
https://www.drupal.org/node/1280468.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes:
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
The Translation redirect module requires the implementation of
|
||||
hook_i18n_translate_path by another module for the redirect page to be
|
||||
determined. Currently, the Multilingual content, Path translation, and Taxonomy
|
||||
translation modules implement this hook.
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
No configuration is necessary.
|
||||
|
||||
For node translation, enable the Multilingual content and the Translation
|
||||
redirect modules. For non-node pages, the redirection hook must be implemented
|
||||
by the relevant module.
|
||||
For example, for taxonomy pages, you should enable the Taxonomy translation
|
||||
module because the module provides the necessary hook code. If you are using the
|
||||
Path translation module to create translation sets for non-node pages, then it
|
||||
implements the hook code for determining the redirection page.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -4,9 +4,8 @@ dependencies[] = i18n
|
||||
package = Multilingual - Internationalization
|
||||
core = 7.x
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -0,0 +1,82 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Multilingual select module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, allows the user to define whether
|
||||
content is filtered by language on pages provided by Drupal core.
|
||||
|
||||
* For a full description of the module visit:
|
||||
https://www.drupal.org/node/1279512.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
* Variable - https://www.drupal.org/project/variable
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
The module allows the user to configure whether or not to filter pages by the
|
||||
current language. If the Taxonomy translation submodule is also enabled, an
|
||||
option will be available for how taxonomy term pages are filtered. It also
|
||||
allows the exclusion of the module’s language selection handling for some
|
||||
elements and certain paths.
|
||||
|
||||
1. Enable the Multilingual select module included with Internationalization.
|
||||
2. Navigate to Configuration > Regional and language > Multilingual settings >
|
||||
Selection.
|
||||
3. Select nodes and taxonomy can be filtered by language in the Content to
|
||||
Filter by Language field set.
|
||||
4. The "Content Selection Mode" allows content with specific tags to be skipped
|
||||
by entering a list of tags.
|
||||
5. The "Enable for Specific Pages" field set allows specific pages to be
|
||||
included by path.
|
||||
6. After making choices, Save configuration.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -6,9 +6,8 @@ core = 7.x
|
||||
configure = admin/config/regional/i18n/select
|
||||
files[] = i18n_select.test
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -82,11 +82,11 @@ function i18n_select_mode($type = NULL) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Check current path to enable selection
|
||||
* Check current path to enable selection.
|
||||
*
|
||||
* This works pretty much like block visibility
|
||||
* This works pretty much like block visibility.
|
||||
*
|
||||
* @return boolean
|
||||
* @return bool
|
||||
* TRUE if content selection should be enabled for this page.
|
||||
*/
|
||||
function i18n_select_page() {
|
||||
@@ -100,8 +100,11 @@ function i18n_select_page() {
|
||||
// with different case. Ex: /Page, /page, /PAGE.
|
||||
$pages = drupal_strtolower($pages);
|
||||
if ($visibility < I18N_SELECT_PAGE_PHP) {
|
||||
// Convert the Drupal path to lowercase
|
||||
$path = drupal_strtolower(drupal_get_path_alias($_GET['q']));
|
||||
// @see views_ajax()
|
||||
// @see I18NSelectAdminViewsAjax::testViewsAjaxWithoutSkippingTags()
|
||||
$path = isset($_REQUEST['view_path']) ? $_REQUEST['view_path'] : $_GET['q'];
|
||||
// Convert the Drupal path to lowercase.
|
||||
$path = drupal_strtolower(drupal_get_path_alias($path));
|
||||
// Compare the lowercase internal and lowercase path alias (if any).
|
||||
$page_match = drupal_match_path($path, $pages);
|
||||
if ($path != $_GET['q']) {
|
||||
@@ -109,8 +112,8 @@ function i18n_select_page() {
|
||||
}
|
||||
// When $visibility has a value of 0 (I18N_SELECT_PAGE_NOTLISTED),
|
||||
// the block is displayed on all pages except those listed in $pages.
|
||||
// When set to 1 (I18N_SELECT_PAGE_LISTED), it is displayed only on those
|
||||
// pages listed in $pages.
|
||||
// When set to 1 (I18N_SELECT_PAGE_LISTED), it is displayed only on
|
||||
// those pages listed in $pages.
|
||||
$mode = !($visibility xor $page_match);
|
||||
}
|
||||
elseif (module_exists('php')) {
|
||||
@@ -121,7 +124,7 @@ function i18n_select_page() {
|
||||
}
|
||||
}
|
||||
else {
|
||||
// No pages defined, still respect the setting (unlike blocks)
|
||||
// No pages defined, still respect the setting (unlike blocks).
|
||||
$mode = $visibility == I18N_SELECT_PAGE_NOTLISTED;
|
||||
}
|
||||
}
|
||||
|
@@ -84,3 +84,87 @@ class i18nSelectTestCase extends Drupali18nTestCase {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test case for AJAX queries on "views/ajax" when view on admin page.
|
||||
*/
|
||||
class I18NSelectAdminViewsAjax extends Drupali18nTestCase {
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public static function getInfo() {
|
||||
return array(
|
||||
'name' => t('I18N select Admin Views (AJAX)'),
|
||||
'group' => 'Internationalization',
|
||||
'description' => t('Test AJAX requests to the "views/ajax" when view located on "admin/*" and list of skipping tags is empty.'),
|
||||
// Skip this test when "admin_views" module does not exists.
|
||||
'dependencies' => array('admin_views'),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
protected function setUp() {
|
||||
parent::setUp('translation', 'i18n_variable', 'i18n_select', 'admin_views');
|
||||
parent::setUpLanguages(array('access content overview'));
|
||||
parent::setUpContentTranslation();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test AJAX of a view without skipping tags for selection.
|
||||
*
|
||||
* @see i18n_select_page()
|
||||
*/
|
||||
public function testViewsAjaxWithoutSkippingTags() {
|
||||
// If this variable will have the "views" value then this test will not
|
||||
// have sense. For instance, we want apply language selection filter
|
||||
// for views and remove "views" from "i18n_select_skip_tags" variable.
|
||||
// In this case all AJAX for views, on administration part of the site,
|
||||
// will be broken because the "i18n_select_page()" function will work
|
||||
// with "views/ajax" path instead of, for example, "admin/content".
|
||||
variable_set('i18n_select_skip_tags', '');
|
||||
|
||||
// Create one hundred of nodes.
|
||||
for ($i = 1; $i <= 100; $i++) {
|
||||
// Create every second node on Spanish language and
|
||||
// every first - on English.
|
||||
$node = $this->createNode('page', "Node $i", '', $i % 2 ? $this->default_language : $this->secondary_language);
|
||||
|
||||
// Update "changed" in order to sort the content by updating date. In
|
||||
// other case all nodes will be with the same date and not arranged in
|
||||
// order.
|
||||
db_update('node')
|
||||
->fields(array('changed' => strtotime("+ $i minute")))
|
||||
->condition('nid', $node->nid)
|
||||
->execute();
|
||||
}
|
||||
|
||||
$this->drupalGet('admin/content');
|
||||
|
||||
// Check that latest node exists at the top.
|
||||
$this->assertText('Node 100');
|
||||
// Check that our page contains fifty nodes (the latest must be 51).
|
||||
$this->assertNoText('Node 50');
|
||||
|
||||
// Test $_REQUEST['view_path']. There's no form to submit to, so
|
||||
// drupalPost() won't work here. This just tests a direct $_POST
|
||||
// request instead.
|
||||
$this->curlExec(array(
|
||||
CURLOPT_URL => $this->getAbsoluteUrl('views/ajax'),
|
||||
CURLOPT_POST => TRUE,
|
||||
CURLOPT_POSTFIELDS => http_build_query(array(
|
||||
'page' => 1,
|
||||
'view_path' => 'admin/content',
|
||||
'view_name' => 'admin_views_node',
|
||||
'view_display_id' => 'system_1',
|
||||
)),
|
||||
));
|
||||
|
||||
// Check that we are successfully switched to a new page of content.
|
||||
$this->assertText('Node 50');
|
||||
$this->assertNoText('Node 100');
|
||||
}
|
||||
|
||||
}
|
||||
|
@@ -0,0 +1,94 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The String translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, provides support for other
|
||||
modules to translate user-defined strings. This is an API module that must be
|
||||
enabled only when required by other modules in the i18n package.
|
||||
|
||||
|
||||
* For a full description of the module, visit this page:
|
||||
https://www.drupal.org/node/1279668
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes:
|
||||
https://www.drupal.org/project/issues/i18n
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
Strings will be translated from the source languages. By default the source
|
||||
language is the site's default language, so changing the default language could
|
||||
break these translations.
|
||||
|
||||
1. The user can set which language is used as the source language via
|
||||
Administration > Configuration > Regional and language > Multilingual
|
||||
settings > Strings. By default, only plain strings are enabled, so regular
|
||||
blocks are not fully translatable.
|
||||
2. To allow Filtered HTML, Full HTML or Plain text select the appropriate radio
|
||||
box(es) and Save configuration.
|
||||
3. To select the strings to be translated navigate to Administration >
|
||||
Configuration > Regional and language > Translate interface and select on
|
||||
Stings vertical tab. From here the user can select which text groups to
|
||||
translate and select the Refresh strings tab.
|
||||
|
||||
|
||||
FAQ
|
||||
---
|
||||
|
||||
The String translation module allows you to configure which text formats are
|
||||
translatable. Formats like PHP Filter and Full HTML are translated before they
|
||||
are processed, so allowing a translator to edit these can be a security risk.
|
||||
This is particularly problematic when importing translations in bulk from a CSV
|
||||
file, since the translator's access to the import formats isn't verified by
|
||||
Drupal. After updating this setting, be sure to refresh the strings via
|
||||
Administration > Configuration > Regional and language > Translate interface >
|
||||
Strings so that strings in forbidden formats are deleted.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -703,9 +703,19 @@ class i18n_string_textgroup_default {
|
||||
// Create source string so we get an lid
|
||||
$this->save_source($string);
|
||||
}
|
||||
|
||||
// Convert objectid to objectkey if it's numeric.
|
||||
if (!isset($string->objectkey)) {
|
||||
$string->objectkey = (int)$string->objectid;
|
||||
if (is_numeric($string->objectid)) {
|
||||
$string->objectkey = (int)$string->objectid;
|
||||
}
|
||||
}
|
||||
|
||||
// Make sure objectkey is numeric.
|
||||
if (!is_numeric($string->objectkey)) {
|
||||
$string->objectkey = 0;
|
||||
}
|
||||
|
||||
if (!isset($string->format)) {
|
||||
$string->format = '';
|
||||
}
|
||||
@@ -1166,10 +1176,17 @@ class i18n_string_object_wrapper extends i18n_object_wrapper {
|
||||
$info = is_array($info) ? $info : array('title' => $info);
|
||||
$field_name = isset($info['field']) ? $info['field'] : $field;
|
||||
$value = $this->get_field($field_name);
|
||||
if (is_array($value) && isset($value['value'])) {
|
||||
$format = isset($value['format']) ? $value['format'] : NULL;
|
||||
$value = $value['value'];
|
||||
}
|
||||
else {
|
||||
$format = isset($info['format']) ? $this->get_field($info['format']) : NULL;
|
||||
}
|
||||
$strings[$this->get_textgroup()][$string_type][$object_id][$field] = array(
|
||||
'string' => is_array($value) || isset($info['empty']) && $value === $info['empty'] ? NULL : $value,
|
||||
'title' => $info['title'],
|
||||
'format' => isset($info['format']) ? $this->get_field($info['format']) : NULL,
|
||||
'format' => $format,
|
||||
'name' => array_merge($object_keys, array($field)),
|
||||
);
|
||||
}
|
||||
@@ -1481,7 +1498,12 @@ class i18n_string_textgroup_cached extends i18n_string_textgroup_default {
|
||||
foreach ($context as $key => $value) {
|
||||
if ($value != '*') {
|
||||
$try = array_merge($context, array($key => '*'));
|
||||
return $this->multiple_cache_get($try);
|
||||
$cached_results = $this->multiple_cache_get($try);
|
||||
// Now filter the ones that actually match.
|
||||
if (!empty($cached_results)) {
|
||||
$cached_results = $this->string_filter($cached_results, $context);
|
||||
}
|
||||
return $cached_results;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -10,9 +10,8 @@ files[] = i18n_string.inc
|
||||
files[] = i18n_string.test
|
||||
configure = admin/config/regional/i18n/strings
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -94,6 +94,7 @@ function i18n_string_schema() {
|
||||
),
|
||||
'objectindex' => array(
|
||||
'type' => 'int',
|
||||
'size' => 'big',
|
||||
'not null' => TRUE,
|
||||
'default' => 0,
|
||||
'description' => 'Integer value of Object ID.',
|
||||
@@ -245,6 +246,24 @@ function i18n_string_update_7002() {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Removed due to buggy upgrade for #2200647.
|
||||
*/
|
||||
function i18n_string_update_7003() {
|
||||
}
|
||||
|
||||
/**
|
||||
* Change objectindex from int to bigint.
|
||||
*/
|
||||
function i18n_string_update_7004() {
|
||||
db_change_field('i18n_string', 'objectindex', 'objectindex', array(
|
||||
'type' => 'int',
|
||||
'size' => 'big',
|
||||
'not null' => TRUE,
|
||||
'default' => 0,
|
||||
'description' => 'Integer value of Object ID.',
|
||||
));
|
||||
}
|
||||
|
||||
/**
|
||||
* Notes for update script
|
||||
|
@@ -118,13 +118,14 @@ function i18n_string_menu() {
|
||||
'file' => 'i18n_string.admin.inc',
|
||||
'access arguments' => array('translate interface'),
|
||||
);
|
||||
|
||||
$items['admin/config/regional/i18n/strings'] = array(
|
||||
'title' => 'Strings',
|
||||
'description' => 'Options for user defined strings.',
|
||||
'weight' => 20,
|
||||
'type' => MENU_LOCAL_TASK,
|
||||
'page callback' => 'drupal_get_form',
|
||||
'page arguments' => array('variable_edit_form', array('i18n_string_allowed_formats', 'i18n_string_source_language')),
|
||||
'page arguments' => array('variable_edit_form', array('i18n_string_allowed_formats', 'i18n_string_source_language', 'i18n_string_textgroup_class_[textgroup]')),
|
||||
'access arguments' => array('administer site configuration'),
|
||||
);
|
||||
// AJAX callback path for strings.
|
||||
@@ -258,6 +259,34 @@ function i18n_string_locale_translate_import_form_submit($form, &$form_state) {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_element_info_alter().
|
||||
*
|
||||
* We need to do this on the element info level as wysiwyg also does so and form
|
||||
* API (incorrectly) does not merge in the defaults for values that are arrays.
|
||||
*/
|
||||
function i18n_string_element_info_alter(&$types) {
|
||||
$types['text_format']['#pre_render'][] = 'i18n_string_pre_render_text_format';
|
||||
}
|
||||
|
||||
/**
|
||||
* The '#pre_render' function to alter the text format element in a translation.
|
||||
* The text format for a translation is taken form the original, so the text
|
||||
* format drop down should be disabled.
|
||||
*
|
||||
* @param array $element
|
||||
* The text_format element which will be rendered.
|
||||
*
|
||||
* @return array
|
||||
* The altered text_format element with a disabled "Text format" select.
|
||||
*/
|
||||
function i18n_string_pre_render_text_format($element) {
|
||||
if (!empty($element['#i18n_string_is_translation'])) {
|
||||
$element['format']['format']['#attributes']['disabled'] = TRUE;
|
||||
}
|
||||
return $element;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if translation is required for this language code.
|
||||
*
|
||||
@@ -334,7 +363,10 @@ function i18n_string_update_context($oldname, $newname) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Get textgroup handler
|
||||
* Get textgroup handler.
|
||||
*
|
||||
* @return i18n_string_textgroup_default
|
||||
*
|
||||
*/
|
||||
function i18n_string_textgroup($textgroup) {
|
||||
$groups = &drupal_static(__FUNCTION__);
|
||||
@@ -488,6 +520,19 @@ function i18n_string_group_info($group = NULL, $property = NULL, $default = NULL
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_i18n_string_info_alter().
|
||||
*
|
||||
* Set determined classes to use for the text group.
|
||||
*/
|
||||
function i18n_string_i18n_string_info_alter(&$info) {
|
||||
foreach (array_keys($info) as $name) {
|
||||
// If class is not defined. Classes from other modules, fixed classes and etc.
|
||||
if (!isset($info[$name]['class'])) {
|
||||
$info[$name]['class'] = variable_get('i18n_string_textgroup_class_' . $name, 'i18n_string_textgroup_default');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Translate / update multiple strings
|
||||
@@ -519,11 +564,12 @@ function i18n_string_multiple($operation, $name, $strings, $options = array()) {
|
||||
*
|
||||
* This function is intended to return translations for plain strings that have NO text format
|
||||
*
|
||||
* @param $name
|
||||
* @param array|string name
|
||||
* Array or string concatenated with ':' that contains textgroup and string context
|
||||
* @param $string
|
||||
* String in default language or array of strings to be translated
|
||||
* @param $options
|
||||
* @param array|string $string
|
||||
* A string in the default language, a string wth format (array with keys
|
||||
* value and format),or an array of strings (without format) to be translated.
|
||||
* @param array $options
|
||||
* An associative array of additional options, with the following keys:
|
||||
* - 'langcode' (defaults to the current language) The language code to translate to a language other than what is used to display the page.
|
||||
* - 'filter' Filtering callback to apply to the translated string only
|
||||
@@ -531,8 +577,13 @@ function i18n_string_multiple($operation, $name, $strings, $options = array()) {
|
||||
* - 'callback' Callback to apply to the result (both to translated or untranslated string
|
||||
* - 'sanitize' Whether to filter the translation applying the text format if any, default is TRUE
|
||||
* - 'sanitize default' Whether to filter the default value if no translation found, default is FALSE
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
function i18n_string_translate($name, $string, $options = array()) {
|
||||
if (is_array($string) && isset($string['value'])) {
|
||||
$string = $string['value'];
|
||||
}
|
||||
if (is_array($string)) {
|
||||
return i18n_string_translate_list($name, $string, $options);
|
||||
}
|
||||
@@ -583,10 +634,17 @@ function i18n_string_translate_access($string_format, $account = NULL) {
|
||||
* Message if the user cannot translate that string.
|
||||
*/
|
||||
function i18n_string_translate_check_string($i18nstring, $account = NULL) {
|
||||
if (!user_access('translate interface', $account) || !user_access('translate user-defined strings', $account)) {
|
||||
// Check block translation permissions.
|
||||
if ($i18nstring->textgroup == 'blocks') {
|
||||
if (!user_access('translate interface', $account) && !user_access('translate blocks', $account)) {
|
||||
return t('This is a user-defined string within a block. You are not allowed to translate blocks.');
|
||||
}
|
||||
}
|
||||
elseif (!user_access('translate interface', $account) || !user_access('translate user-defined strings', $account)) {
|
||||
return t('This is a user-defined string. You are not allowed to translate these strings.');
|
||||
}
|
||||
elseif (!empty($i18nstring->format)) {
|
||||
|
||||
if (!empty($i18nstring->format)) {
|
||||
if (!i18n_string_allowed_format($i18nstring->format)) {
|
||||
$format = filter_format_load($i18nstring->format);
|
||||
return t('This string uses the %name text format. Strings with this format are not allowed for translation.', array('%name' => $format->name));
|
||||
|
@@ -170,14 +170,16 @@ function i18n_string_translate_page_form_base($form, $langcode, $redirect = NULL
|
||||
|
||||
/**
|
||||
* Create field elements for strings
|
||||
*
|
||||
* @param i18n_string_object[] $strings
|
||||
* @param string $langcode
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
function i18n_string_translate_page_form_strings($strings, $langcode) {
|
||||
$formats = filter_formats();
|
||||
global $user;
|
||||
$form = array();
|
||||
foreach ($strings as $item) {
|
||||
// We may have a source or not. Load it, our string may get the format from it.
|
||||
$source = $item->get_source();
|
||||
$format_id = $source ? $source->format : $item->format;
|
||||
$description = '';
|
||||
// Check permissions to translate this string, depends on format, etc..
|
||||
if ($message = $item->check_translate_access()) {
|
||||
// We'll display a disabled element with the reason it cannot be translated.
|
||||
@@ -188,27 +190,31 @@ function i18n_string_translate_page_form_strings($strings, $langcode) {
|
||||
$disabled = FALSE;
|
||||
$description = '';
|
||||
// If we don't have a source and it can be translated, we create it.
|
||||
if (!$source) {
|
||||
if (!$item->get_source()) {
|
||||
// Enable messages just as a reminder these strings are not being updated properly.
|
||||
$status = $item->update(array('messages' => TRUE));
|
||||
if ($status === FALSE || $status === SAVED_DELETED) {
|
||||
// We don't have a source string so nothing to translate here
|
||||
$disabled = TRUE;
|
||||
}
|
||||
else {
|
||||
$source = $item->get_source();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$default_value = $item->format_translation($langcode, array('langcode' => $langcode, 'sanitize' => FALSE, 'debug' => FALSE));
|
||||
$available_formats = array_keys(filter_formats($user));
|
||||
if (!in_array($item->format, $available_formats)) {
|
||||
$item->format = NULL;
|
||||
}
|
||||
$form[$item->get_name()] = array(
|
||||
'#title' => $item->get_title(),
|
||||
'#type' => 'textarea',
|
||||
'#type' => $item->format ? 'text_format' : 'textarea',
|
||||
'#default_value' => $default_value,
|
||||
'#format' => $item->format,
|
||||
// This will trigger i18n_string_pre_render_text_format() to actually
|
||||
// alter the element.
|
||||
'#i18n_string_is_translation' => TRUE,
|
||||
'#disabled' => $disabled,
|
||||
'#description' => $description . _i18n_string_translate_format_help($format_id),
|
||||
//'#i18n_string_format' => $source ? $source->format : 0,
|
||||
'#description' => $description,
|
||||
// If disabled, provide smaller textarea (that can be expanded anyway).
|
||||
'#rows' => $disabled ? 1 : min(ceil(str_word_count($default_value) / 12), 10),
|
||||
// Change the parent for disabled strings so we don't get empty values later
|
||||
@@ -226,6 +232,16 @@ function i18n_string_translate_page_form_submit($form, &$form_state) {
|
||||
foreach ($form_state['values']['strings'] as $name => $value) {
|
||||
$count++;
|
||||
list($textgroup, $context) = i18n_string_context(explode(':', $name));
|
||||
if (is_array($value)) {
|
||||
if (isset($value['value'])) {
|
||||
$value = $value['value'];
|
||||
$form_state['values']['strings'][$name] = $value;
|
||||
}
|
||||
else {
|
||||
form_set_error("strings][$name", t('Unable to get the translated string value.'));
|
||||
watchdog('locale', 'Unable to get the translated string value, string array is: %string', array('%string' => var_dump($value)), WATCHDOG_WARNING);
|
||||
}
|
||||
}
|
||||
$result = i18n_string_textgroup($textgroup)->update_translation($context, $form_state['values']['langcode'], $value);
|
||||
$success += ($result ? 1 : 0);
|
||||
}
|
||||
|
@@ -65,7 +65,7 @@ class i18nStringTestCase extends Drupali18nTestCase {
|
||||
$this->drupalPost('admin/config/regional/translate/translate', $search, t('Filter'));
|
||||
$this->clickLink(t('edit'));
|
||||
// Just add a random translation.
|
||||
$translation = $this->randomString();
|
||||
$translation = $this->randomName();
|
||||
$edit = array();
|
||||
foreach ($this->getOtherLanguages() as $language) {
|
||||
$langcode = $language->language;
|
||||
|
@@ -34,9 +34,32 @@ function i18n_string_variable_info($options = array()) {
|
||||
'default' => 0,
|
||||
'group' => 'debug',
|
||||
);
|
||||
$variables['i18n_string_textgroup_class_[textgroup]'] = array(
|
||||
'title' => t('Class to use for the text group'),
|
||||
'description' => t('Determines which the class will be use for string translation in the text group.', array(), $options),
|
||||
'repeat' => array(
|
||||
'type' => 'select',
|
||||
'default' => 'i18n_string_textgroup_default',
|
||||
'options callback' => 'i18n_string_variable_textgroup_class_list',
|
||||
),
|
||||
'submit callback' => 'i18n_string_variable_textgroup_class_submit_callback',
|
||||
'group' => 'i18n',
|
||||
);
|
||||
return $variables;
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_variable_type_info().
|
||||
*/
|
||||
function i18n_string_variable_type_info() {
|
||||
$type['textgroup'] = array(
|
||||
'title' => t('Text group'),
|
||||
'type' => 'select',
|
||||
'options callback' => 'i18n_string_variable_textgroup_list',
|
||||
);
|
||||
return $type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Options callback, format list
|
||||
*/
|
||||
@@ -54,4 +77,33 @@ function i18n_string_variable_format_list() {
|
||||
*/
|
||||
function i18n_string_variable_format_default() {
|
||||
return array(filter_fallback_format());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Options callback, text groups list.
|
||||
*/
|
||||
function i18n_string_variable_textgroup_list() {
|
||||
$groups = array();
|
||||
foreach (i18n_string_group_info() as $name => $info) {
|
||||
$groups[$name] = $info['title'];
|
||||
}
|
||||
return $groups;
|
||||
}
|
||||
|
||||
/**
|
||||
* Options callback, text group classes list.
|
||||
*/
|
||||
function i18n_string_variable_textgroup_class_list($variable, $options = array()) {
|
||||
return array(
|
||||
'i18n_string_textgroup_default' => t('Text group handler default.', array(), $options),
|
||||
'i18n_string_textgroup_cached' => t('Text group handler which include persistent caching.', array(), $options),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Submit callback. Execute Reset the persistent caches after save the text group class variables.
|
||||
*/
|
||||
function i18n_string_variable_textgroup_class_submit_callback($variable, $options, $form, $form_state) {
|
||||
// Reset the persistent caches.
|
||||
cache_clear_all('i18n:string:' , 'cache', TRUE);
|
||||
}
|
||||
|
@@ -3,7 +3,7 @@ README.txt
|
||||
==========
|
||||
Drupal module: i18n_sync (Synchronization)
|
||||
|
||||
This module will handle content synchronization accross translations.
|
||||
This module will handle content synchronization across translations.
|
||||
|
||||
The available list of fields to synchronize will include standard node fields and cck fields.
|
||||
To have aditional fields, add the list in a variable in the settings.php file, like this:
|
||||
|
@@ -1,5 +1,5 @@
|
||||
name = Synchronize translations
|
||||
description = Synchronizes taxonomy and fields accross translations of the same content.
|
||||
description = Synchronizes taxonomy and fields across translations of the same content.
|
||||
dependencies[] = i18n
|
||||
dependencies[] = translation
|
||||
package = Multilingual - Internationalization
|
||||
@@ -10,9 +10,8 @@ files[] = i18n_sync.install
|
||||
files[] = i18n_sync.module.inc
|
||||
files[] = i18n_sync.node.inc
|
||||
files[] = i18n_sync.test
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -33,7 +33,7 @@ function i18n_sync($status = NULL) {
|
||||
function i18n_sync_help($path, $arg) {
|
||||
switch ($path) {
|
||||
case 'admin/help#i18n_sync' :
|
||||
$output = '<p>' . t('This module synchronizes content taxonomy and fields accross translations:') . '</p>';
|
||||
$output = '<p>' . t('This module synchronizes content taxonomy and fields across translations:') . '</p>';
|
||||
$output .= '<p>' . t('First you need to select which fields should be synchronized. Then, after a node has been updated, all enabled vocabularies and fields will be synchronized as follows:') . '</p>';
|
||||
$output .= '<ul>';
|
||||
$output .= '<li>' . t('All the node fields selected for synchronization will be set to the same value for all translations.') . '</li>';
|
||||
@@ -91,6 +91,7 @@ function i18n_sync_form_node_type_form_alter(&$form, &$form_state) {
|
||||
|
||||
$form['i18n_sync']['i18n_sync_node_type'] = array(
|
||||
'#tree' => TRUE,
|
||||
'#weight' => 1,
|
||||
);
|
||||
|
||||
// Each set provides title and options. We build a big checkboxes control for it to be
|
||||
@@ -121,6 +122,21 @@ function i18n_sync_form_node_type_form_alter(&$form, &$form_state) {
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
// Add option to restrict syncing only when editing the translation source.
|
||||
$form['i18n_sync']['i18n_sync_source_description'] = array(
|
||||
'#prefix' => '<div>', '#suffix' => '</div>',
|
||||
'#markup' => t('Restrict synchronization to the translation source.'),
|
||||
'#weight' => 2,
|
||||
);
|
||||
$form['i18n_sync']['i18n_sync_source'] = array(
|
||||
'#type' => 'checkbox',
|
||||
'#title' => t('Synchronize translations only when saving the translation source'),
|
||||
'#default_value' => variable_get('i18n_sync_source_' . $type, FALSE),
|
||||
'#disabled' => $disabled,
|
||||
'#weight' => 3,
|
||||
'#description' => t('If not checked each node will trigger the synchronization, whether it\'s the source or not.'),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -167,9 +183,17 @@ function i18n_sync_node_insert($node) {
|
||||
*/
|
||||
function i18n_sync_node_update($node) {
|
||||
// Let's go with field synchronization.
|
||||
if (i18n_sync_node_check($node) && !empty($node->tnid) && ($fields = i18n_sync_node_fields($node->type)) && ($translations = i18n_sync_node_get_translations($node, TRUE))) {
|
||||
module_load_include('node.inc', 'i18n_sync');
|
||||
i18n_sync_node_translation($node, $translations, $fields, 'update');
|
||||
if (i18n_sync_node_check($node) && !empty($node->tnid) && (!variable_get('i18n_sync_source_' . $node->type, TRUE) || $node->tnid == $node->nid) && ($fields = i18n_sync_node_fields($node->type)) && ($translations = i18n_sync_node_get_translations($node, TRUE))) {
|
||||
$do_sync = TRUE;
|
||||
if (module_exists('entity_translation')) {
|
||||
if (entity_translation_enabled_bundle('node', $node->type)) {
|
||||
$do_sync = FALSE;
|
||||
}
|
||||
}
|
||||
if ($do_sync) {
|
||||
module_load_include('node.inc', 'i18n_sync');
|
||||
i18n_sync_node_translation($node, $translations, $fields, 'update');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -98,7 +98,7 @@ function i18n_sync_node_translation_nodereference_field(&$node, &$translation, $
|
||||
* Example:
|
||||
* English A references English B and English C.
|
||||
* English A and B are translated to German A and B, but English C is not.
|
||||
* The syncronization from English A to German A would it German B and English C.
|
||||
* The synchronization from English A to German A would it German B and English C.
|
||||
*/
|
||||
function i18n_sync_node_translation_reference_field(&$reference_node, $default_value, $langcode) {
|
||||
if (isset($reference_node->tnid) && translation_supported_type($reference_node->type)) {
|
||||
|
@@ -0,0 +1,103 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Taxonomy translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, provides multiple options to
|
||||
translate taxonomy vocabularies and terms. For each vocabulary, there are four
|
||||
types of behaviors to choose from: Language-independent terms, Language-specific
|
||||
terms, Localized terms, and Mixed-language vocabulary.
|
||||
|
||||
* For a full description of the module visit:
|
||||
https://www.drupal.org/node/1114016
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit:
|
||||
https://www.drupal.org/project/issues/i18n
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
Language-independent terms - only vocabulary will be translatable.
|
||||
1. Navigate to Structure > Taxonomy.
|
||||
2. Select the "edit vocabulary" link.
|
||||
3. Select the "No multilingual options for terms".
|
||||
|
||||
Language-specific terms - vocabulary is only used for content in that language.
|
||||
The terms will only be available if the term language matches the UI language.
|
||||
1. Navigate to Structure > Taxonomy and select the "edit vocabulary link".
|
||||
2. Choose "Fixed Language" and a Language drop-down field will be displayed.
|
||||
3. Select the language.
|
||||
4. Select "Fixed Language" and Save.
|
||||
|
||||
Localized terms - Terms are common for all languages, but their name and
|
||||
description may be localized.
|
||||
1. Navigate to Structure > Taxonomy > vocabulary-to-edit > Edit.
|
||||
2. Select "Localize" and select Save.
|
||||
3. Edit a term and there will be a Translate tab. Select this tab.
|
||||
4. Select Translate, translate the Name and Description, select
|
||||
"Save translation", and repeat for all languages.
|
||||
5. Repeat the process for all terms.
|
||||
6. Navigate to Structure > Content types > term-to-edit > Manage display.
|
||||
7. By default, the term reference is set to Link. Change this to "Link
|
||||
(localized)" and Save.
|
||||
The vocabulary will be appropriate for the language.
|
||||
|
||||
Mixed-language vocabulary - Use for vocabularies with terms in multiple
|
||||
languages.
|
||||
1. Navigate to Structure > Taxonomy > vocabulary-to-edit > Edit.
|
||||
2. Select the Translate radio button and Save.
|
||||
3. Edit a vocabulary term and there will be a new Language field. Choose a
|
||||
language and then select Save and translate.
|
||||
4. There are two options, the user can either select "Add translation link" or
|
||||
the user can select an existing term in the Select translations form.
|
||||
5. Create translations for the terms and add terms for specific languages only.
|
||||
Now if the user edits a node associated with this vocabulary, only the relevant
|
||||
terms will appear.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -11,9 +11,8 @@ files[] = i18n_taxonomy.pages.inc
|
||||
files[] = i18n_taxonomy.admin.inc
|
||||
files[] = i18n_taxonomy.test
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -213,7 +213,12 @@ function i18n_taxonomy_field_formatter_view($entity_type, $entity, $field, $inst
|
||||
);
|
||||
}
|
||||
else {
|
||||
$term = $item['taxonomy_term'];
|
||||
if (isset($item['taxonomy_term'])) {
|
||||
$term = $item['taxonomy_term'];
|
||||
}
|
||||
else {
|
||||
$term = taxonomy_term_load($item['tid']);
|
||||
}
|
||||
$uri = entity_uri('taxonomy_term', $term);
|
||||
$element[$delta] = array(
|
||||
'#type' => 'link',
|
||||
@@ -372,10 +377,19 @@ function i18n_taxonomy_field_prepare_translation($entity_type, $entity, $field,
|
||||
* The array of valid terms for this field, keyed by term id.
|
||||
*/
|
||||
function i18n_taxonomy_allowed_values($field) {
|
||||
global $language;
|
||||
$options = array();
|
||||
foreach ($field['settings']['allowed_values'] as $tree) {
|
||||
if ($vocabulary = taxonomy_vocabulary_machine_name_load($tree['vocabulary'])) {
|
||||
if ($terms = taxonomy_get_tree($vocabulary->vid, $tree['parent'])) {
|
||||
if (i18n_taxonomy_vocabulary_mode($vocabulary->vid) == I18N_MODE_TRANSLATE) {
|
||||
$parent = i18n_taxonomy_translation_term_tid($tree['parent'], NULL, $tree['parent']);
|
||||
$language = i18n_language_context();
|
||||
$terms = i18n_taxonomy_get_tree($vocabulary->vid, $language->language, $parent);
|
||||
}
|
||||
else {
|
||||
$terms = taxonomy_get_tree($vocabulary->vid, $tree['parent']);
|
||||
}
|
||||
if ($terms) {
|
||||
foreach ($terms as $term) {
|
||||
$options[$term->tid] = str_repeat('-', $term->depth) . i18n_taxonomy_term_name($term);
|
||||
}
|
||||
@@ -742,6 +756,28 @@ function i18n_taxonomy_form_taxonomy_form_term_alter(&$form, &$form_state) {
|
||||
// Add language field or not depending on taxonomy mode.
|
||||
switch (i18n_taxonomy_vocabulary_mode($vocabulary->vid)) {
|
||||
case I18N_MODE_TRANSLATE:
|
||||
// Set $form_state['storage'] default as empty array because we will add
|
||||
// the translation and target from $_GET. So we still have it when the
|
||||
// page partially reloads with ajax.
|
||||
if(!isset($form_state['storage'])) {
|
||||
$form_state['storage'] = array();
|
||||
}
|
||||
// get translation from $_GET or $form_state['storage']
|
||||
$translation = null;
|
||||
if(isset($_GET['translation'])) {
|
||||
$translation = $_GET['translation'];
|
||||
$form_state['storage']['translation'] = $translation;
|
||||
} else if(isset($form_state['storage']) && isset($form_state['storage']['translation'])){
|
||||
$translation = $form_state['storage']['translation'];
|
||||
}
|
||||
// get target from $_GET or $form_state['storage']
|
||||
$target = null;
|
||||
if(isset($_GET['target'])) {
|
||||
$target = $_GET['target'];
|
||||
$form_state['storage']['target'] = $target;
|
||||
} else if(isset($form_state['storage']) && isset($form_state['storage']['target'])){
|
||||
$target = $form_state['storage']['target'];
|
||||
}
|
||||
$form['language'] = array(
|
||||
'#description' => t('This term belongs to a multilingual vocabulary. You can set a language for it.'),
|
||||
) + i18n_element_language_select($term);
|
||||
@@ -749,7 +785,7 @@ function i18n_taxonomy_form_taxonomy_form_term_alter(&$form, &$form_state) {
|
||||
// If the term to be added will be a translation of a source term,
|
||||
// set the default value of the option list to the target language and
|
||||
// create a form element for storing the translation set of the source term.
|
||||
if (empty($term->tid) && isset($_GET['translation']) && isset($_GET['target']) && ($source_term = taxonomy_term_load($_GET['translation'])) && ($target_language = i18n_language_object($_GET['target']))) {
|
||||
if (empty($term->tid) && isset($translation) && isset($target) && ($source_term = taxonomy_term_load($translation)) && ($target_language = i18n_language_object($target))) {
|
||||
// Set context language to target language.
|
||||
i18n_language_context($target_language);
|
||||
|
||||
@@ -991,7 +1027,7 @@ function i18n_taxonomy_translate_terms($taxonomy, $langcode, $fullterms = TRUE)
|
||||
}
|
||||
elseif ($term->language && $term->language != $langcode) {
|
||||
$translation_set = i18n_translation_set_load($term->i18n_tsid);
|
||||
$translations = $translation_set->get_translations();
|
||||
$translations = ($translation_set) ? $translation_set->get_translations() : NULL;
|
||||
|
||||
if ($translations && !empty($translations[$langcode])) {
|
||||
$newterm = $translations[$langcode];
|
||||
@@ -1020,6 +1056,10 @@ function i18n_taxonomy_localize_terms($terms) {
|
||||
if (!i18n_string_translate_langcode()) {
|
||||
return $terms;
|
||||
}
|
||||
// $terms is not a valid array or term.
|
||||
if (empty($terms)) {
|
||||
return $terms;
|
||||
}
|
||||
$object_info = i18n_object_info('taxonomy_term');
|
||||
$list = is_array($terms) ? $terms : array($terms);
|
||||
foreach ($list as $index => $term) {
|
||||
@@ -1087,7 +1127,7 @@ function i18n_taxonomy_get_tree($vid, $langcode, $parent = 0, $max_depth = NULL,
|
||||
$query->join('taxonomy_term_hierarchy', 'h', 'h.tid = t.tid');
|
||||
$result = $query
|
||||
->addTag('translatable')
|
||||
->addTag('term_access')
|
||||
->addTag('taxonomy_term_access')
|
||||
->fields('t')
|
||||
->fields('h', array('parent'))
|
||||
->condition('t.vid', $vid)
|
||||
@@ -1216,6 +1256,11 @@ function i18n_taxonomy_field_uuid_presave($entity_type, $entity, $field, $instan
|
||||
* Implements hook_entity_info_alter().
|
||||
*/
|
||||
function i18n_taxonomy_entity_info_alter(&$entity_info) {
|
||||
if (isset($entity_info['taxonomy_vocabulary'])) {
|
||||
// Add altered vocabulary schema fields.
|
||||
$entity_info['taxonomy_vocabulary']['schema_fields_sql']['base table'][] = 'i18n_mode';
|
||||
$entity_info['taxonomy_vocabulary']['schema_fields_sql']['base table'][] = 'language';
|
||||
}
|
||||
if (isset($entity_info['taxonomy_term'])) {
|
||||
// Core doesn't provide a label callback for taxonomy terms. By setting one
|
||||
// we can use it to return the correct localized term name.
|
||||
@@ -1261,3 +1306,22 @@ function i18n_taxonomy_modules_enabled($modules) {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Implements hook_views_pre_render().
|
||||
*/
|
||||
function i18n_taxonomy_views_pre_render(&$view) {
|
||||
if($view->base_table !== 'rules_scheduler') {
|
||||
global $language;
|
||||
|
||||
foreach ($view->result as $delta => $term){
|
||||
if (isset($term->tid)) {
|
||||
i18n_string_translate_langcode($language->language);
|
||||
$localized_term = i18n_taxonomy_localize_terms(taxonomy_term_load($term->tid));
|
||||
$term->tid = $localized_term->tid;
|
||||
$term->taxonomy_term_data_name = $localized_term->name;
|
||||
$term->taxonomy_term_data_description = $localized_term->description;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -100,7 +100,7 @@ function _i18n_taxonomy_autocomplete($langcode, $vids, $tags_typed = '') {
|
||||
$query = db_select('taxonomy_term_data', 't')
|
||||
->fields('t', array('tid', 'name'));
|
||||
$query->addTag('translatable');
|
||||
$query->addTag('term_access');
|
||||
$query->addTag('taxonomy_term_access');
|
||||
// Disable i18n_select for this query
|
||||
$query->addTag('i18n_select');
|
||||
// Add language condition
|
||||
|
@@ -15,6 +15,10 @@ function i18n_taxonomy_token_info() {
|
||||
'name' => t("Name (localized)"),
|
||||
'description' => t("The name of the taxonomy term."),
|
||||
);
|
||||
$term['localized-name'] = array(
|
||||
'name' => t("Name in current language"),
|
||||
'description' => t("The name of the taxonomy term in current language."),
|
||||
);
|
||||
$term['i18n-description'] = array(
|
||||
'name' => t("Description (localized)"),
|
||||
'description' => t("The optional description of the taxonomy term."),
|
||||
@@ -69,6 +73,12 @@ function i18n_taxonomy_tokens($type, $tokens, array $data = array(), array $opti
|
||||
$replacements[$original] = $sanitize ? check_plain($name) : $name;
|
||||
break;
|
||||
|
||||
case 'localized-name':
|
||||
$translated_term = i18n_taxonomy_term_get_translation($term, $langcode);
|
||||
$name = i18n_taxonomy_term_name($translated_term, $langcode);
|
||||
$replacements[$original] = $sanitize ? check_plain($name) : $name;
|
||||
break;
|
||||
|
||||
case 'i18n-description':
|
||||
$replacements[$original] = i18n_string_text(array('taxonomy', 'term', $term->tid, 'description'), $term->description, array('langcode' => $langcode, 'format' => $term->format, 'sanitize' => $sanitize, 'cache' => TRUE));
|
||||
break;
|
||||
|
@@ -6,9 +6,8 @@ core = 7.x
|
||||
|
||||
files[] = i18n_translation.inc
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -20,7 +20,7 @@ class I18nTranslationSetController extends DrupalDefaultEntityController {
|
||||
* @param $queried_entities
|
||||
* Associative array of query results, keyed on the entity ID.
|
||||
* @param $revision_id
|
||||
* ID of the revision that was loaded, or FALSE if teh most current revision
|
||||
* ID of the revision that was loaded, or FALSE if the most current revision
|
||||
* was loaded.
|
||||
*/
|
||||
protected function attachLoad(&$queried_entities, $revision_id = FALSE) {
|
||||
|
@@ -0,0 +1,70 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The User mail translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, translates emails sent from the
|
||||
User module.
|
||||
|
||||
* For a full description of the module, visit this page:
|
||||
https://www.drupal.org/node/133977.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes:
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following module:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
To configure email translations
|
||||
1. Navigate to Administration > Configuration > Regional and language >
|
||||
Multilingual settings and select the variables tab.
|
||||
2. Select the "User emails" tab. Select the variables to be translated. Save
|
||||
configuration.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -4,9 +4,8 @@ core = 7.x
|
||||
package = Multilingual - Internationalization
|
||||
dependencies[] = i18n_variable
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -9,7 +9,14 @@
|
||||
*/
|
||||
function i18n_user_mail_alter(&$message) {
|
||||
if ($message['module'] == 'user') {
|
||||
$language = $message['language'];
|
||||
$message['language'] = language_default();
|
||||
if (isset($message['params']['account'])) {
|
||||
$user_preferred = user_preferred_language($message['params']['account']);
|
||||
if (isset($user_preferred)) {
|
||||
$message['language'] = $user_preferred;
|
||||
}
|
||||
}
|
||||
$language = (isset($message['language']) ? $message['language'] : language_default());
|
||||
$variables = array('user' => $message['params']['account']);
|
||||
$key = $message['key'];
|
||||
|
||||
|
@@ -0,0 +1,84 @@
|
||||
CONTENTS OF THIS FILE
|
||||
---------------------
|
||||
|
||||
* Introduction
|
||||
* Requirements
|
||||
* Recommended modules
|
||||
* Installation
|
||||
* Configuration
|
||||
* Maintainers
|
||||
|
||||
|
||||
INTRODUCTION
|
||||
------------
|
||||
|
||||
The Variable translation module, part of the Internationalization
|
||||
(https://www.drupal.org/project/i18n) package, allows the user to translate text
|
||||
and settings that are stored in Drupal as variables. These variables include
|
||||
text such as 'site name' and 'site slogan', as well as settings like 'Default
|
||||
front page' and 'Default 404 page'.
|
||||
|
||||
* For a full description of the module, visit:
|
||||
https://www.drupal.org/node/1113374.
|
||||
|
||||
* To submit bug reports and feature suggestions, or to track changes visit:
|
||||
https://www.drupal.org/project/issues/i18n.
|
||||
|
||||
|
||||
REQUIREMENTS
|
||||
------------
|
||||
|
||||
This module requires the following modules:
|
||||
|
||||
* Internationalization - https://www.drupal.org/project/i18n
|
||||
* Variable - https://www.drupal.org/project/variable
|
||||
|
||||
|
||||
RECOMMENDED MODULES
|
||||
-------------------
|
||||
|
||||
* Internationalization Views - https://www.drupal.org/project/i18nviews
|
||||
* Language Icons - https://www.drupal.org/project/languageicons
|
||||
* Translation Overview - https://www.drupal.org/project/translation_overview
|
||||
* Localization Client - https://www.drupal.org/project/l10n_client
|
||||
* Internationalization contributions -
|
||||
https://www.drupal.org/project/i18n_contrib
|
||||
|
||||
|
||||
INSTALLATION
|
||||
------------
|
||||
|
||||
This is a submodule of the Internationalization module. Install the
|
||||
Internationalization module as you would normally install a contributed Drupal
|
||||
module. Visit https://www.drupal.org/node/895232 for further information.
|
||||
|
||||
|
||||
CONFIGURATION
|
||||
-------------
|
||||
|
||||
To enable multilingual variables
|
||||
|
||||
1. Enable the Variable translation module included with the Internationalization
|
||||
package.
|
||||
2. Go to Administration > Configuration > Regional and language > Multilingual
|
||||
settings.
|
||||
3. Select on the Variables tab.
|
||||
4. Select the variables that will be multilingual.
|
||||
5. Save configuration.
|
||||
|
||||
Once the user has the correct settings, they'll be marked with "This is a
|
||||
multilingual variable" when the user navigates to the corresponding
|
||||
administration pages. The user must switch the site language while in the
|
||||
administration pages to set the variables for each language. A language switcher
|
||||
link will appear at the top of each administrative page that has multilingual
|
||||
variables.
|
||||
|
||||
|
||||
MAINTAINERS
|
||||
-----------
|
||||
|
||||
* Jose Reyero - https://www.drupal.org/u/jose-reyero
|
||||
* Florian Weber (webflo) - https://www.drupal.org/u/webflo
|
||||
* Peter Philipp - https://www.drupal.org/u/das-peter
|
||||
* Joseph Olstad - https://www.drupal.org/u/joseph.olstad
|
||||
* Nathaniel Catchpole - https://www.drupal.org/u/catch
|
@@ -10,9 +10,8 @@ configure = admin/config/regional/i18n/variable
|
||||
files[] = i18n_variable.class.inc
|
||||
files[] = i18n_variable.test
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -7,9 +7,8 @@ package = Testing
|
||||
core = 6.x
|
||||
hidden = TRUE
|
||||
|
||||
; Information added by Drupal.org packaging script on 2015-05-07
|
||||
version = "7.x-1.13"
|
||||
; Information added by Drupal.org packaging script on 2018-08-17
|
||||
version = "7.x-1.26"
|
||||
core = "7.x"
|
||||
project = "i18n"
|
||||
datestamp = "1430999922"
|
||||
|
||||
datestamp = "1534531985"
|
||||
|
@@ -40,7 +40,7 @@ function i18n_test_i18n_string_info() {
|
||||
'title' => t('Test Cached Strings'),
|
||||
'description' => t('Translatable items of a textgroup with caching enabled.'),
|
||||
'format' => FALSE, // This group doesn't have strings with format
|
||||
'class' => 'i18n_string_textgroup_cached_logged',
|
||||
'class' => variable_get('i18n_string_textgroup_class_test_cached', 'i18n_string_textgroup_cached_logged'),
|
||||
);
|
||||
return $groups;
|
||||
}
|
||||
|
Reference in New Issue
Block a user