Chris@0: /**
Chris@0: * DO NOT EDIT THIS FILE.
Chris@0: * See the following change record for more information,
Chris@0: * https://www.drupal.org/node/2815083
Chris@0: * @preserve
Chris@0: **/
Chris@0:
Chris@0: (function ($, Drupal, drupalSettings) {
Chris@0: Drupal.behaviors.machineName = {
Chris@0: attach: function attach(context, settings) {
Chris@0: var self = this;
Chris@0: var $context = $(context);
Chris@0: var timeout = null;
Chris@0: var xhr = null;
Chris@0:
Chris@0: function clickEditHandler(e) {
Chris@0: var data = e.data;
Chris@0: data.$wrapper.removeClass('visually-hidden');
Chris@0: data.$target.trigger('focus');
Chris@0: data.$suffix.hide();
Chris@0: data.$source.off('.machineName');
Chris@0: }
Chris@0:
Chris@0: function machineNameHandler(e) {
Chris@0: var data = e.data;
Chris@0: var options = data.options;
Chris@0: var baseValue = $(e.target).val();
Chris@0:
Chris@0: var rx = new RegExp(options.replace_pattern, 'g');
Chris@0: var expected = baseValue.toLowerCase().replace(rx, options.replace).substr(0, options.maxlength);
Chris@0:
Chris@0: if (xhr && xhr.readystate !== 4) {
Chris@0: xhr.abort();
Chris@0: xhr = null;
Chris@0: }
Chris@0:
Chris@0: if (timeout) {
Chris@0: clearTimeout(timeout);
Chris@0: timeout = null;
Chris@0: }
Chris@0: if (baseValue.toLowerCase() !== expected) {
Chris@0: timeout = setTimeout(function () {
Chris@0: xhr = self.transliterate(baseValue, options).done(function (machine) {
Chris@0: self.showMachineName(machine.substr(0, options.maxlength), data);
Chris@0: });
Chris@0: }, 300);
Chris@0: } else {
Chris@0: self.showMachineName(expected, data);
Chris@0: }
Chris@0: }
Chris@0:
Chris@14: Object.keys(settings.machineName).forEach(function (sourceId) {
Chris@0: var machine = '';
Chris@14: var options = settings.machineName[sourceId];
Chris@0:
Chris@14: var $source = $context.find(sourceId).addClass('machine-name-source').once('machine-name');
Chris@0: var $target = $context.find(options.target).addClass('machine-name-target');
Chris@0: var $suffix = $context.find(options.suffix);
Chris@0: var $wrapper = $target.closest('.js-form-item');
Chris@0:
Chris@0: if (!$source.length || !$target.length || !$suffix.length || !$wrapper.length) {
Chris@0: return;
Chris@0: }
Chris@0:
Chris@0: if ($target.hasClass('error')) {
Chris@0: return;
Chris@0: }
Chris@0:
Chris@0: options.maxlength = $target.attr('maxlength');
Chris@0:
Chris@0: $wrapper.addClass('visually-hidden');
Chris@0:
Chris@0: if ($target.is(':disabled') || $target.val() !== '') {
Chris@0: machine = $target.val();
Chris@0: } else if ($source.val() !== '') {
Chris@0: machine = self.transliterate($source.val(), options);
Chris@0: }
Chris@0:
Chris@0: var $preview = $('' + options.field_prefix + Drupal.checkPlain(machine) + options.field_suffix + '');
Chris@0: $suffix.empty();
Chris@0: if (options.label) {
Chris@0: $suffix.append('' + options.label + ': ');
Chris@0: }
Chris@0: $suffix.append($preview);
Chris@0:
Chris@0: if ($target.is(':disabled')) {
Chris@0: return;
Chris@0: }
Chris@0:
Chris@14: var eventData = {
Chris@0: $source: $source,
Chris@0: $target: $target,
Chris@0: $suffix: $suffix,
Chris@0: $wrapper: $wrapper,
Chris@0: $preview: $preview,
Chris@0: options: options
Chris@0: };
Chris@0:
Chris@0: var $link = $('').on('click', eventData, clickEditHandler);
Chris@0: $suffix.append($link);
Chris@0:
Chris@0: if ($target.val() === '') {
Chris@0: $source.on('formUpdated.machineName', eventData, machineNameHandler).trigger('formUpdated.machineName');
Chris@0: }
Chris@0:
Chris@0: $target.on('invalid', eventData, clickEditHandler);
Chris@0: });
Chris@0: },
Chris@0: showMachineName: function showMachineName(machine, data) {
Chris@0: var settings = data.options;
Chris@0:
Chris@0: if (machine !== '') {
Chris@0: if (machine !== settings.replace) {
Chris@0: data.$target.val(machine);
Chris@0: data.$preview.html(settings.field_prefix + Drupal.checkPlain(machine) + settings.field_suffix);
Chris@0: }
Chris@0: data.$suffix.show();
Chris@0: } else {
Chris@0: data.$suffix.hide();
Chris@0: data.$target.val(machine);
Chris@0: data.$preview.empty();
Chris@0: }
Chris@0: },
Chris@0: transliterate: function transliterate(source, settings) {
Chris@0: return $.get(Drupal.url('machine_name/transliterate'), {
Chris@0: text: source,
Chris@0: langcode: drupalSettings.langcode,
Chris@0: replace_pattern: settings.replace_pattern,
Chris@0: replace_token: settings.replace_token,
Chris@0: replace: settings.replace,
Chris@0: lowercase: true
Chris@0: });
Chris@0: }
Chris@0: };
Chris@0: })(jQuery, Drupal, drupalSettings);