diff --git a/PATCH_LIST.md b/PATCH_LIST.md
index 0dde4cca..17005240 100644
--- a/PATCH_LIST.md
+++ b/PATCH_LIST.md
@@ -12,16 +12,16 @@ contentadminrelink
entityreference
feedback
filter_path_alias
-termreferencetree
-?? views
-wysiwyg
-views_rss_media (https://www.drupal.org/node/2472409)
-node_export :
- - https://www.drupal.org/node/1869918
- - https://www.drupal.org/node/1911638
+flag_lists
+ - https://www.drupal.org/project/flag_lists/issues/2114731
login_tobogan (pd with field permission et donc field collection)
- https://www.drupal.org/node/1365764#comment-10286257
- logintoboggan-exempting_lt_preauth_role_from_user_permissions_js-1365764-52.patch
- interdiff-1365764-23-52-do-not-test.diff
-flag_lists
- - https://www.drupal.org/project/flag_lists/issues/2114731
+node_export :
+ - https://www.drupal.org/node/1869918
+ - https://www.drupal.org/node/1911638
+termreferencetree
+?? views
+views_rss_media (https://www.drupal.org/node/2472409)
+wysiwyg
diff --git a/sites/all/modules/contrib/fields/field_group/CHANGELOG.txt b/sites/all/modules/contrib/fields/field_group/CHANGELOG.txt
index ea037d87..5798162a 100644
--- a/sites/all/modules/contrib/fields/field_group/CHANGELOG.txt
+++ b/sites/all/modules/contrib/fields/field_group/CHANGELOG.txt
@@ -1,6 +1,37 @@
/* $Id*/
CHANGELOG for field_group for Drupal 7
+Field Group origin/7.x-1.x, 2017-11-04
+--------------------------------------
+- Tests fail after new 'administer fields' permission.
+- Update CHANGELOG.txt to 7.x-1.5 Release.
+- Revert "Issue #2646106 by jribeiro: Update CHANGELOG.txt to 7.x-1.5 Release".
+- Update CHANGELOG.txt to 7.x-1.5 Release.
+- Fix whitespace between "&" and parameters for some functions.
+- Avoid bad code pattern (that is picked up by security scanners) when getting hash.
+- Should #array_parents be updated in field_group_fields_nest()?.
+- "Show" appears in horizontal tab title if node form submitted through ajax.
+- CSS breaks i18n string translation interface.
+- "uncaught exception: Syntax error, unrecognized expression: #" after 7.x-1.4 update.
+- PHP7 - Uniform Variable Syntax updates are causing exported field_groups to not have names.
+
+Field_group 7.x-1.5
+ o Added extra formatting on html element attributes.
+ o Fixed bug on automatic ID generation in javascript.
+ o Issue #2511960 by rrfegade: spelling errors in D7.
+ o Issue #2194279 by Georgique: Export translatables (label and descriptions) in Features.
+ o Issue #2386335 by Dubs: Integer Group Array Keys can create empty node forms.
+ o Issue #2269133 by sammuell: Accordion is always closed when using jQuery update module.
+ o Issue #2258939 by Snipon: Fixed Change to preventDefault on multipage controls.
+ o Issue #2173937 by jantoine, omerida | Bernieman: Fixed Accordion Element has fixed height in HTML.
+ o Issue #2311789 by eelkeblok: Fixed Group is incorrectly determined to be empty with nested form elements.
+ o Issue #2272003 by karolrybak | Kwb: Fixed Fieldgroup no longer renders after using more than one 'HTML Element' on the same level.
+ o Issue #2309219 by czigor: Fixed Proper CTools exportable loading.
+ o Issue #2283245 by stefan.r | jrb: Fixed New id functionality breaks tests and CSS on existing field groups.
+ o Issue #2295133 by boyan.borisov, interX: Fixed field_group_update_7007 error.
+ o Remove field_group.css, the css is not needed anymore.
+ o Fix horiziontal tabs when used as standalone element.
+
Field_group 7.x-1.4
o Issue #2129805 by RaF: Incorrect markup when open div & custom classes provided.
o Issue #2037731 by maximpodorov, Zach Harkey: Remove id attribute from HTML elements.
diff --git a/sites/all/modules/contrib/fields/field_group/field_group.api.php b/sites/all/modules/contrib/fields/field_group/field_group.api.php
index cef5b0a8..fdcbe031 100644
--- a/sites/all/modules/contrib/fields/field_group/field_group.api.php
+++ b/sites/all/modules/contrib/fields/field_group/field_group.api.php
@@ -220,7 +220,7 @@ function hook_field_group_format_settings($group) {
* @param Array $elements by address.
* @param Object $group The Field group info.
*/
-function hook_field_group_pre_render(& $element, $group, & $form) {
+function hook_field_group_pre_render(&$element, $group, &$form) {
// You can prepare some variables to use in the logic.
$view_mode = isset($form['#view_mode']) ? $form['#view_mode'] : 'form';
@@ -268,7 +268,7 @@ function hook_field_group_pre_render(& $element, $group, & $form) {
*
* Function that fungates as last resort to alter the pre_render build.
*/
-function hook_field_group_pre_render_alter(&$element, $group, & $form) {
+function hook_field_group_pre_render_alter(&$element, $group, &$form) {
if ($group->format_type == 'htab') {
$element['#theme_wrappers'] = array('my_horizontal_tab');
@@ -285,7 +285,7 @@ function hook_field_group_pre_render_alter(&$element, $group, & $form) {
*
* @param Array $elements by address.
*/
-function hook_field_group_build_pre_render_alter(& $element) {
+function hook_field_group_build_pre_render_alter(&$element) {
// Prepare variables.
$display = isset($element['#view_mode']);
diff --git a/sites/all/modules/contrib/fields/field_group/field_group.field_ui.inc b/sites/all/modules/contrib/fields/field_group/field_group.field_ui.inc
index 8872e386..dbd26d0e 100644
--- a/sites/all/modules/contrib/fields/field_group/field_group.field_ui.inc
+++ b/sites/all/modules/contrib/fields/field_group/field_group.field_ui.inc
@@ -99,10 +99,10 @@ function field_group_field_ui_overview_form_alter(&$form, &$form_state, $display
// Play around with form_state so we only need to hold things
// between requests, until the save button was hit.
if (isset($form_state['field_group'][$name])) {
- $group = & $form_state['field_group'][$name];
+ $group = &$form_state['field_group'][$name];
}
else {
- $group = & $params->groups[$name];
+ $group = &$params->groups[$name];
}
// Check the currently selected formatter, and merge persisted values for
@@ -456,7 +456,7 @@ function field_group_format_settings_label_validate($element, &$form_state) {
* @param Object $group
* @param array $settings
*/
-function field_group_formatter_row_update(& $group, $settings) {
+function field_group_formatter_row_update(&$group, $settings) {
// if the row has changed formatter type, update the group object
if (!empty($settings['format']['type']) && $settings['format']['type'] != $group->format_type) {
$group->format_type = $settings['format']['type'];
@@ -469,7 +469,7 @@ function field_group_formatter_row_update(& $group, $settings) {
* @param Object $group The group object
* @param Array $settings Configuration settings
*/
-function field_group_formatter_settings_update(& $group, $settings) {
+function field_group_formatter_settings_update(&$group, $settings) {
// for format changes we load the defaults.
if (empty($settings['format_settings']['settings'])) {
diff --git a/sites/all/modules/contrib/fields/field_group/field_group.info b/sites/all/modules/contrib/fields/field_group/field_group.info
index 912b55f7..49eae8dd 100644
--- a/sites/all/modules/contrib/fields/field_group/field_group.info
+++ b/sites/all/modules/contrib/fields/field_group/field_group.info
@@ -6,9 +6,9 @@ dependencies[] = ctools
core = 7.x
files[] = tests/field_group.ui.test
files[] = tests/field_group.display.test
-; Information added by Drupal.org packaging script on 2016-02-28
-version = "7.x-1.5+2-dev"
+; Information added by Drupal.org packaging script on 2017-11-03
+version = "7.x-1.6"
core = "7.x"
project = "field_group"
-datestamp = "1456658044"
+datestamp = "1509751991"
diff --git a/sites/all/modules/contrib/fields/field_group/field_group.module b/sites/all/modules/contrib/fields/field_group/field_group.module
index 4061519f..4fe2547a 100644
--- a/sites/all/modules/contrib/fields/field_group/field_group.module
+++ b/sites/all/modules/contrib/fields/field_group/field_group.module
@@ -258,8 +258,6 @@ function field_group_field_attach_delete_bundle($entity_type, $bundle) {
* Implements hook_field_attach_form().
*/
function field_group_field_attach_form($entity_type, $entity, &$form, &$form_state, $langcode) {
-
- $form['#attached']['css'][] = drupal_get_path('module', 'field_group') . '/field_group.field_ui.css';
field_group_attach_groups($form, 'form', $form_state);
$form['#pre_render'][] = 'field_group_form_pre_render';
}
@@ -1110,7 +1108,7 @@ function field_group_pre_render_tab(&$element, $group, &$form) {
* Implements hook_field_group_build_pre_render_alter().
* @param Array $elements by address.
*/
-function field_group_field_group_build_pre_render_alter(& $element) {
+function field_group_field_group_build_pre_render_alter(&$element) {
// Someone is doing a node view, in a node view. Reset content.
// TODO Check if this breaks something else.
@@ -2027,6 +2025,19 @@ function field_group_fields_nest(&$element, &$vars = NULL) {
// Construct own weight, as some fields (for example preprocess fields) don't have weight set.
$element[$group_name] = array();
$group_references[$group_name] = &$element[$group_name];
+ // Get group parents
+ $parents = array();
+ $current_group = $group;
+ while (!empty($current_group)) {
+ array_unshift($parents, $current_group->group_name);
+ $current_group = isset($element['#fieldgroups'][$current_group->parent_name]) ?
+ $element['#fieldgroups'][$current_group->parent_name] : NULL;
+ }
+ $group_references[$group_name]['#array_parents'] = $parents;
+ $element['#fieldgroups'][$group_name]->array_parents = $parents;
+ // Remove self from parents and set #field_parents
+ array_pop($parents);
+ $group_references[$group_name]['#field_parents'] = $parents;
}
}
@@ -2077,6 +2088,19 @@ function field_group_fields_nest(&$element, &$vars = NULL) {
// list intact (but if it is a field we don't mind).
$group_references[$parent_name][$child_name] = &$element[$child_name];
$group_references[$parent_name]['#weight'] = $element['#fieldgroups'][$parent_name]->weight;
+ // Prepend #array_parents & #field_parents of group child element & its element_children
+ // if those keys are set, and don't already include the group parents
+ $group_child = &$group_references[$parent_name][$child_name];
+ $group_parents = $group_references[$parent_name]['#array_parents'];
+ $process_elements = array_merge(array(&$group_child), _field_group_element_children_recursive_ref($group_child));
+ foreach ($process_elements as $key => $current_element) {
+ if (isset($current_element['#array_parents']) && !in_array($group_parents[0], $current_element['#array_parents'])) {
+ $process_elements[$key]['#array_parents'] = array_merge($group_parents, $current_element['#array_parents']);
+ }
+ if (isset($current_element['#field_parents']) && !in_array($group_parents[0], $current_element['#field_parents'])) {
+ $process_elements[$key]['#field_parents'] = array_merge($group_parents, $current_element['#field_parents']);
+ }
+ }
}
// The child has been copied to its parent: remove it from the root element.
@@ -2093,6 +2117,23 @@ function field_group_fields_nest(&$element, &$vars = NULL) {
}
+/**
+ * Recursive element_children, returns children by reference
+ */
+function _field_group_element_children_recursive_ref(&$element) {
+ $results = array();
+ $children = element_children($element);
+ foreach ($children as $key) {
+ $child = &$element[$key];
+ if (is_array($child)) {
+ $results[] = &$child;
+ $results = array_merge($results, _field_group_element_children_recursive_ref($child));
+ }
+ unset($child);
+ }
+ return $results;
+}
+
/**
* Function to pre render the field group element.
*
diff --git a/sites/all/modules/contrib/fields/field_group/horizontal-tabs/horizontal-tabs.js b/sites/all/modules/contrib/fields/field_group/horizontal-tabs/horizontal-tabs.js
index 977e1b6c..6429f90f 100644
--- a/sites/all/modules/contrib/fields/field_group/horizontal-tabs/horizontal-tabs.js
+++ b/sites/all/modules/contrib/fields/field_group/horizontal-tabs/horizontal-tabs.js
@@ -29,8 +29,10 @@ Drupal.behaviors.horizontalTabs = {
// Transform each fieldset into a tab.
$fieldsets.each(function (i) {
+ var $legend = $('> legend', this);
+ $('.element-invisible', $legend).remove();
var horizontal_tab = new Drupal.horizontalTab({
- title: $('> legend', this).text(),
+ title: $legend.text(),
fieldset: $(this)
});
horizontal_tab.item.addClass('horizontal-tab-button-' + i);
@@ -52,7 +54,7 @@ Drupal.behaviors.horizontalTabs = {
// element that matches the URL fragment, activate that tab.
var hash = window.location.hash.replace(/[=%;,\/]/g, "");
if (hash !== '#' && $(hash, this).length) {
- tab_focus = $(window.location.hash, this).closest('.horizontal-tabs-pane');
+ tab_focus = $(hash, this).closest('.horizontal-tabs-pane');
}
else {
tab_focus = $('> .horizontal-tabs-pane:first', this);
diff --git a/sites/all/modules/contrib/fields/field_group/tests/field_group.ui.test b/sites/all/modules/contrib/fields/field_group/tests/field_group.ui.test
index 55fa595b..6c4436a9 100644
--- a/sites/all/modules/contrib/fields/field_group/tests/field_group.ui.test
+++ b/sites/all/modules/contrib/fields/field_group/tests/field_group.ui.test
@@ -22,7 +22,7 @@ class GroupUITestCase extends DrupalWebTestCase {
parent::setUp('field_test', 'field_group', 'field_group_test');
// Create test user.
- $admin_user = $this->drupalCreateUser(array('administer content types', 'administer nodes', 'access administration pages', 'bypass node access'));
+ $admin_user = $this->drupalCreateUser(array('administer content types', 'administer nodes', 'access administration pages', 'bypass node access', 'administer fields'));
$this->drupalLogin($admin_user);
}
diff --git a/sites/all/modules/contrib/fields/field_group/tests/field_group_test.info b/sites/all/modules/contrib/fields/field_group/tests/field_group_test.info
index 4391b929..22bd9219 100644
--- a/sites/all/modules/contrib/fields/field_group/tests/field_group_test.info
+++ b/sites/all/modules/contrib/fields/field_group/tests/field_group_test.info
@@ -5,9 +5,9 @@ package = Fields
hidden = TRUE
-; Information added by Drupal.org packaging script on 2016-02-28
-version = "7.x-1.5+2-dev"
+; Information added by Drupal.org packaging script on 2017-11-03
+version = "7.x-1.6"
core = "7.x"
project = "field_group"
-datestamp = "1456658044"
+datestamp = "1509751991"
diff --git a/sites/all/modules/contrib/files/imagestyleflush/README.txt b/sites/all/modules/contrib/files/imagestyleflush/README.txt
index 6b784545..8c170d7c 100644
--- a/sites/all/modules/contrib/files/imagestyleflush/README.txt
+++ b/sites/all/modules/contrib/files/imagestyleflush/README.txt
@@ -11,6 +11,7 @@ Features
- Flush all image styles
- Flush each individual image style
+ - Integrates with the admin_menu module
Dependencies
@@ -29,6 +30,8 @@ Install
2) In your Drupal site, enable the module under Administration -> Modules
(/admin/modules).
+3) Visit the Administration -> People -> Permissions page to give the
+ appropriate roles access to flush image styles.
Usage
-----
@@ -36,6 +39,8 @@ Usage
You can flush image styles under Administration -> Configuration -> Media
-> Image styles
+Note that this module only flushes images. It does not rebuild them.
+
Known problems
--------------
diff --git a/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.info b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.info
index ee1a7b66..259ae7c1 100644
--- a/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.info
+++ b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.info
@@ -4,9 +4,9 @@ package = Media
core = 7.x
configure = admin/config/media/image-styles
-; Information added by Drupal.org packaging script on 2015-11-07
-version = "7.x-1.3"
+; Information added by Drupal.org packaging script on 2017-12-09
+version = "7.x-1.5"
core = "7.x"
project = "imagestyleflush"
-datestamp = "1446884340"
+datestamp = "1512780486"
diff --git a/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.install b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.install
new file mode 100644
index 00000000..8c004816
--- /dev/null
+++ b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.install
@@ -0,0 +1,39 @@
+fields('rp', array('rid'))
+ ->condition('permission', 'administer image styles')
+ ->execute()
+ ->fetchCol();
+
+ // Add the permissions for each role.
+ foreach ($rids as $rid) {
+ foreach ($permissions as $name) {
+ db_merge('role_permission')
+ ->key(array(
+ 'rid' => $rid,
+ 'permission' => $name,
+ ))
+ ->fields(array(
+ 'module' => 'imagestyleflush',
+ ))
+ ->execute();
+ }
+ }
+}
diff --git a/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.module b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.module
index a02a6631..1e5f518c 100644
--- a/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.module
+++ b/sites/all/modules/contrib/files/imagestyleflush/imagestyleflush.module
@@ -14,7 +14,7 @@ function imagestyleflush_menu() {
'description' => 'Flush all image styles.',
'page callback' => 'drupal_get_form',
'page arguments' => array('imagestyleflush_form'),
- 'access arguments' => array('administer image styles'),
+ 'access arguments' => array('flush image styles'),
'type' => MENU_LOCAL_ACTION,
'weight' => 3,
);
@@ -23,12 +23,24 @@ function imagestyleflush_menu() {
'description' => 'Flush an image style.',
'page callback' => 'drupal_get_form',
'page arguments' => array('imagestyleflush_form', 5),
- 'access arguments' => array('administer image styles'),
+ 'access arguments' => array('flush image styles'),
);
return $items;
}
+/**
+ * Implements hook_permission().
+ */
+function imagestyleflush_permission() {
+ return array(
+ 'flush image styles' => array(
+ 'title' => t('Flush image styles'),
+ 'description' => t('Allow users to flush image styles.'),
+ ),
+ );
+}
+
/**
* Implements hook_theme_registry_alter().
*/
@@ -44,7 +56,10 @@ function imagestyleflush_theme_registry_alter(&$theme_registry) {
function imagestyleflush_image_style_list($variables) {
$styles = $variables['styles'];
- $header = array(t('Style name'), t('Settings'), array('data' => t('Operations'), 'colspan' => 3));
+ // Account for an extra column added by the image_styles_admin submodule of
+ // the imagecache_actions module.
+ $colspan = module_exists('image_styles_admin') ? 4 : 3;
+ $header = array(t('Style name'), t('Settings'), array('data' => t('Operations'), 'colspan' => $colspan));
$rows = array();
foreach ($styles as $style) {
$row = array();
@@ -77,7 +92,7 @@ function imagestyleflush_image_style_list($variables) {
if (empty($rows)) {
$rows[] = array(array(
- 'colspan' => 4,
+ 'colspan' => $colspan,
'data' => t('There are currently no styles. Add a new one.', array('!url' => url('admin/config/media/image-styles/add'))),
));
}
@@ -105,7 +120,8 @@ function imagestyleflush_form($form, &$form_state, $style = NULL) {
),
t('Are you sure you want to flush the %style image style?', array('%style' => $style['label'])),
'admin/config/media/image-styles',
- t('This action cannot be undone.'),
+ '' . t('Note: this will only flush the images. It will not rebuild them.')
+ . '
' . t('This action cannot be undone.'),
t('Flush'), t('Cancel')
);
}
@@ -114,7 +130,8 @@ function imagestyleflush_form($form, &$form_state, $style = NULL) {
NULL,
t('Are you sure you want to flush all image styles?'),
'admin/config/media/image-styles',
- t('This action cannot be undone.'),
+ '' . t('Note: this will only flush the images. It will not rebuild them.')
+ . '
' . t('This action cannot be undone.'),
t('Flush'), t('Cancel')
);
}
@@ -138,6 +155,12 @@ function imagestyleflush_form_submit($form, &$form_state) {
}
}
+ // Redirect to the destination URL.
+ $destination = drupal_get_destination();
+ if ($destination['destination'] != current_path()) {
+ $operations[] = array('imagestyleflush_batch_destination_redirect', $destination);
+ }
+
$batch = array(
'operations' => $operations,
'finished' => 'imagestyleflush_batch_finished',
@@ -146,6 +169,15 @@ function imagestyleflush_form_submit($form, &$form_state) {
batch_set($batch);
}
+/**
+ * Batch operation. Redirect the batch operation if it was called from the
+ * admin_menu item.
+ */
+function imagestyleflush_batch_destination_redirect($destination, &$context) {
+ // Set the destination redirect.
+ $context['results']['redirect'] = $destination;
+}
+
/**
* Batch message.
*/
@@ -156,5 +188,51 @@ function imagestyleflush_batch_finished($success, $results, $operations) {
else {
drupal_set_message(t('An error occurred while flushing the image caches.'), 'error');
}
- drupal_goto('admin/config/media/image-styles');
+
+ if (!empty($results['redirect'])) {
+ drupal_goto($results['redirect']);
+ }
+ else {
+ // Send the user to the right place depending on their access.
+ if (user_access('administer image styles')) {
+ drupal_goto('admin/config/media/image-styles');
+ }
+ else {
+ drupal_goto();
+ }
+ }
+}
+
+/**
+ * Implements hook_admin_menu_output_build().
+ */
+function imagestyleflush_admin_menu_output_build(&$content) {
+ // Add link to the icon menu to flush image styles.
+ if (isset($content['icon'])) {
+ $styles = image_styles();
+ $access = user_access('flush image styles');
+ $destination = drupal_get_destination();
+
+ $style_links = array();
+ foreach ($styles as $style) {
+ $style_links[$style['name']] = array(
+ '#title' => $style['label'],
+ '#href' => 'admin/config/media/image-styles/flush/' . $style['name'],
+ '#access' => $access,
+ '#options' => array(
+ 'query' => $destination,
+ ),
+ );
+ }
+
+ $content['icon']['icon']['flush-image-styles'] = array(
+ '#title' => t('Flush all image styles'),
+ '#access' => $access,
+ '#href' => 'admin/config/media/image-styles/flush',
+ '#options' => array(
+ 'query' => $destination,
+ ),
+ '#weight' => 25,
+ ) + $style_links;
+ }
}
diff --git a/sites/all/modules/contrib/localisation/i18n/README.txt b/sites/all/modules/contrib/localisation/i18n/README.txt
index 5a8a4f14..060563bb 100644
--- a/sites/all/modules/contrib/localisation/i18n/README.txt
+++ b/sites/all/modules/contrib/localisation/i18n/README.txt
@@ -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
====================================================================
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n.info b/sites/all/modules/contrib/localisation/i18n/i18n.info
index 335533f9..46f21698 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n.module b/sites/all/modules/contrib/localisation/i18n/i18n.module
index b65061dc..4985271f 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n.module
@@ -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);
}
/**
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n.test b/sites/all/modules/contrib/localisation/i18n/i18n.test
index 8e979100..2a82e17a 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n.test
+++ b/sites/all/modules/contrib/localisation/i18n/i18n.test
@@ -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);
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_block/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_block/README.txt
new file mode 100644
index 00000000..a4e80ad9
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_block/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.info b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.info
index 5497d05b..89cf38b8 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.module b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.module
index 5328a5fc..6c8c79bb 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.module
@@ -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',
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.test b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.test
index b1e46809..e33d99ef 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.test
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_block/i18n_block.test
@@ -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.');
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_contact/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_contact/README.txt
new file mode 100644
index 00000000..73d94a3f
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_contact/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_contact/i18n_contact.info b/sites/all/modules/contrib/localisation/i18n/i18n_contact/i18n_contact.info
index 225e780a..76978ff1 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_contact/i18n_contact.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_contact/i18n_contact.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_field/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_field/README.txt
new file mode 100644
index 00000000..04d038ef
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_field/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.i18n.inc b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.i18n.inc
index 1e31c483..c1e6e9c4 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.i18n.inc
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.i18n.inc
@@ -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;
}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.info b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.info
index c5596edc..b3596f9c 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.module b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.module
index eadd2f5c..6f97006b 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_field/i18n_field.module
@@ -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;
+ }
+}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_forum/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_forum/README.txt
new file mode 100644
index 00000000..8b0a0cdf
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_forum/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_forum/i18n_forum.info b/sites/all/modules/contrib/localisation/i18n/i18n_forum/i18n_forum.info
index 5c0f0a10..17e7f0e5 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_forum/i18n_forum.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_forum/i18n_forum.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_menu/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_menu/README.txt
new file mode 100644
index 00000000..4f5c935b
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_menu/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.info b/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.info
index 98938d5e..6b03ca65 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.module b/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.module
index b7bd7374..46ce7388 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_menu/i18n_menu.module
@@ -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;
}
}
}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_node/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_node/README.txt
new file mode 100644
index 00000000..c65e1c13
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_node/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.info b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.info
index b5b50289..45c78290 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.module b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.module
index 8f14bcd9..b6957e8f 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.module
@@ -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.
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.variable.inc b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.variable.inc
index 9362fc3f..b9b0495f 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.variable.inc
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_node/i18n_node.variable.inc
@@ -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'),
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_path/i18n_path.info b/sites/all/modules/contrib/localisation/i18n/i18n_path/i18n_path.info
index 3fec36ec..cba9b1fa 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_path/i18n_path.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_path/i18n_path.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_redirect/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_redirect/README.txt
new file mode 100644
index 00000000..fd262af1
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_redirect/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_redirect/i18n_redirect.info b/sites/all/modules/contrib/localisation/i18n/i18n_redirect/i18n_redirect.info
index 978e695e..7d6567de 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_redirect/i18n_redirect.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_redirect/i18n_redirect.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_select/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_select/README.txt
new file mode 100644
index 00000000..ba8c432c
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_select/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.info b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.info
index ded2059c..25902957 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.module b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.module
index bcba5782..9063fe9d 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.module
@@ -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;
}
}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.test b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.test
index b46fb986..5af85431 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.test
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_select/i18n_select.test
@@ -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');
+ }
+
+}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_string/README.txt
new file mode 100644
index 00000000..673a3f3e
--- /dev/null
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/README.txt
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.inc b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.inc
index 33fa444d..65b4efa7 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.inc
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.inc
@@ -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;
}
}
}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.info b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.info
index 06152042..fec3d948 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.install b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.install
index 30e8cd26..23987920 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.install
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.install
@@ -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
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.module b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.module
index 9c232c08..1fe45d6b 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.module
@@ -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));
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.pages.inc b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.pages.inc
index 4d0da59c..fd657b5a 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.pages.inc
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.pages.inc
@@ -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);
}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.test b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.test
index d4563405..9e52dfa0 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.test
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.test
@@ -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;
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.variable.inc b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.variable.inc
index cb677e3c..932751f1 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.variable.inc
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_string/i18n_string.variable.inc
@@ -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());
-}
\ No newline at end of file
+}
+
+/**
+ * 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);
+}
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_sync/README.txt b/sites/all/modules/contrib/localisation/i18n/i18n_sync/README.txt
index ce7ea6aa..c106dcb6 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_sync/README.txt
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_sync/README.txt
@@ -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:
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.info b/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.info
index c22a68ad..b42a9d92 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.info
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.info
@@ -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"
diff --git a/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.module b/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.module
index 8aaadbec..8a5ec5c3 100644
--- a/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.module
+++ b/sites/all/modules/contrib/localisation/i18n/i18n_sync/i18n_sync.module
@@ -33,7 +33,7 @@ function i18n_sync($status = NULL) {
function i18n_sync_help($path, $arg) {
switch ($path) {
case 'admin/help#i18n_sync' :
- $output = '
' . t('This module synchronizes content taxonomy and fields accross translations:') . '
'; + $output = '' . t('This module synchronizes content taxonomy and fields across translations:') . '
'; $output .= '' . 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:') . '
'; $output .= '