From 611b7d1c66ac29d74a65d285be688c3f01bd034c Mon Sep 17 00:00:00 2001 From: Lauri Eskola <lauri.eskola@acquia.com> Date: Mon, 17 Jan 2022 18:09:08 +0200 Subject: [PATCH] Issue #3239134 by hooroomoo, bnjmnm, yogeshmpawar, nod_, Theresa.Grannum, larowlan: Refactor (if feasible) uses of the jQuery val function to use VanillaJS --- core/.eslintrc.jquery.json | 2 +- core/core.libraries.yml | 2 + core/misc/ajax.es6.js | 10 ++-- core/misc/ajax.js | 4 +- core/misc/form.es6.js | 17 +++--- core/misc/form.js | 16 ++++-- core/misc/machine-name.es6.js | 14 ++--- core/misc/machine-name.js | 14 ++--- core/misc/tabledrag.es6.js | 7 ++- core/misc/tabledrag.js | 8 ++- core/misc/timezone.es6.js | 11 ++-- core/misc/timezone.js | 11 ++-- core/misc/vertical-tabs.es6.js | 7 +-- core/misc/vertical-tabs.js | 4 +- core/modules/block/js/block.admin.es6.js | 2 +- core/modules/block/js/block.admin.js | 2 +- core/modules/block/js/block.es6.js | 10 ++-- core/modules/block/js/block.js | 8 +-- core/modules/book/book.es6.js | 2 +- core/modules/book/book.js | 2 +- .../modules/ckeditor/js/ckeditor.admin.es6.js | 2 +- core/modules/ckeditor/js/ckeditor.admin.js | 2 +- .../js/ckeditor.drupalimage.admin.es6.js | 22 +++++--- .../ckeditor/js/ckeditor.drupalimage.admin.js | 10 ++-- .../js/ckeditor.stylescombo.admin.es6.js | 10 ++-- .../ckeditor/js/ckeditor.stylescombo.admin.js | 5 +- core/modules/color/color.es6.js | 4 +- core/modules/color/color.js | 4 +- .../content_translation.admin.es6.js | 2 +- .../content_translation.admin.js | 2 +- core/modules/editor/js/editor.es6.js | 12 ++--- core/modules/editor/js/editor.js | 12 ++--- core/modules/field_ui/field_ui.es6.js | 52 ++++++++++++------- core/modules/field_ui/field_ui.js | 45 ++++++++++++---- core/modules/filter/filter.es6.js | 2 +- .../filter/filter.filter_html.admin.es6.js | 4 +- .../filter/filter.filter_html.admin.js | 2 +- core/modules/filter/filter.js | 2 +- core/modules/image/js/editors/image.es6.js | 5 +- core/modules/image/js/editors/image.js | 2 +- .../layout_builder/js/layout-builder.es6.js | 2 +- .../layout_builder/js/layout-builder.js | 2 +- core/modules/locale/locale.bulk.es6.js | 6 +-- core/modules/locale/locale.bulk.js | 4 +- core/modules/media/js/form.es6.js | 39 +++++++------- core/modules/media/js/form.js | 10 ++-- .../media_library/js/media_library.ui.es6.js | 22 +++++--- .../media_library/js/media_library.ui.js | 12 ++++- .../js/media_library.widget.es6.js | 2 +- .../media_library/js/media_library.widget.js | 2 +- .../media_library/media_library.libraries.yml | 1 + core/modules/menu_ui/menu_ui.admin.es6.js | 18 +++---- core/modules/menu_ui/menu_ui.admin.js | 10 ++-- core/modules/menu_ui/menu_ui.es6.js | 12 ++--- core/modules/menu_ui/menu_ui.js | 12 ++--- core/modules/node/content_types.es6.js | 2 +- core/modules/node/content_types.js | 2 +- core/modules/node/node.es6.js | 7 +-- core/modules/node/node.js | 7 +-- core/modules/path/path.es6.js | 6 ++- core/modules/path/path.js | 3 +- .../quickedit/js/views/EditorView.es6.js | 1 + core/modules/system/js/system.date.es6.js | 2 +- core/modules/system/js/system.date.js | 2 +- core/modules/system/js/system.es6.js | 8 +-- core/modules/system/js/system.js | 8 +-- core/modules/system/js/system.modules.es6.js | 2 +- core/modules/system/js/system.modules.js | 2 +- ...ebassert_test.wait_for_ajax_request.es6.js | 12 +++-- ...js_webassert_test.wait_for_ajax_request.js | 10 ++-- .../js_webassert_test.libraries.yml | 1 - core/modules/text/text.es6.js | 2 +- core/modules/text/text.js | 2 +- .../toolbar/js/views/ToolbarVisualView.es6.js | 6 +-- .../toolbar/js/views/ToolbarVisualView.js | 4 +- core/modules/user/user.es6.js | 16 +++--- core/modules/user/user.js | 12 ++--- core/modules/views_ui/js/ajax.es6.js | 9 +++- core/modules/views_ui/js/ajax.js | 6 ++- core/modules/views_ui/js/views-admin.es6.js | 42 ++++++++------- core/modules/views_ui/js/views-admin.js | 42 ++++++++------- .../views_ui/js/views_ui.listing.es6.js | 2 +- core/modules/views_ui/js/views_ui.listing.js | 2 +- core/themes/bartik/color/preview.es6.js | 30 ++++++----- core/themes/bartik/color/preview.js | 18 +++---- core/themes/claro/js/vertical-tabs.es6.js | 3 +- core/themes/claro/js/vertical-tabs.js | 2 +- 87 files changed, 458 insertions(+), 323 deletions(-) diff --git a/core/.eslintrc.jquery.json b/core/.eslintrc.jquery.json index aa023ca34501..6beae36d73bd 100644 --- a/core/.eslintrc.jquery.json +++ b/core/.eslintrc.jquery.json @@ -49,7 +49,7 @@ "jquery/no-toggle": 0, "jquery/no-trigger": 0, "jquery/no-trim": 2, - "jquery/no-val": 0, + "jquery/no-val": 2, "jquery/no-when": 0, "jquery/no-wrap": 0 } diff --git a/core/core.libraries.yml b/core/core.libraries.yml index 2ddda9f2b8b1..664f6bd6c935 100644 --- a/core/core.libraries.yml +++ b/core/core.libraries.yml @@ -311,6 +311,7 @@ drupal.ajax: - core/jquery - core/drupal - core/drupalSettings + - core/drupal.nodelist.foreach - core/drupal.progress - core/once - core/jquery.once.bc @@ -677,6 +678,7 @@ drupal.timezone: js: misc/timezone.js: {} dependencies: + - core/drupal.nodelist.foreach - core/jquery - core/once - core/jquery.once.bc diff --git a/core/misc/ajax.es6.js b/core/misc/ajax.es6.js index df7a0d5b0c6b..94ff62df5da7 100644 --- a/core/misc/ajax.es6.js +++ b/core/misc/ajax.es6.js @@ -1570,9 +1570,13 @@ * The XMLHttpRequest status. */ update_build_id(ajax, response, status) { - $(`input[name="form_build_id"][value="${response.old}"]`).val( - response.new, - ); + document + .querySelectorAll( + `input[name="form_build_id"][value="${response.old}"]`, + ) + .forEach((item) => { + item.value = response.new; + }); }, /** diff --git a/core/misc/ajax.js b/core/misc/ajax.js index cbfd1a79a9cd..505347666e87 100644 --- a/core/misc/ajax.js +++ b/core/misc/ajax.js @@ -656,7 +656,9 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len $(response.selector).find('> tbody > tr:visible, > tr:visible').removeClass('odd even').filter(':even').addClass('odd').end().filter(':odd').addClass('even'); }, update_build_id: function update_build_id(ajax, response, status) { - $("input[name=\"form_build_id\"][value=\"".concat(response.old, "\"]")).val(response.new); + document.querySelectorAll("input[name=\"form_build_id\"][value=\"".concat(response.old, "\"]")).forEach(function (item) { + item.value = response.new; + }); }, add_css: function add_css(ajax, response, status) { $('head').prepend(response.data); diff --git a/core/misc/form.es6.js b/core/misc/form.es6.js index 6b2663b0bec9..c02220c09973 100644 --- a/core/misc/form.es6.js +++ b/core/misc/form.es6.js @@ -245,11 +245,16 @@ userInfo.forEach((info) => { const $element = $forms.find(`[name=${info}]`); const browserData = localStorage.getItem(`Drupal.visitor.${info}`); - const emptyOrDefault = - $element.val() === '' || - $element.attr('data-drupal-default-value') === $element.val(); - if ($element.length && emptyOrDefault && browserData) { - $element.val(browserData); + if (!$element.length) { + return; + } + const emptyValue = $element[0].value === ''; + const defaultValue = + $element.attr('data-drupal-default-value') === $element[0].value; + if (browserData && (emptyValue || defaultValue)) { + $element.each(function (index, item) { + item.value = browserData; + }); } }); } @@ -257,7 +262,7 @@ userInfo.forEach((info) => { const $element = $forms.find(`[name=${info}]`); if ($element.length) { - localStorage.setItem(`Drupal.visitor.${info}`, $element.val()); + localStorage.setItem(`Drupal.visitor.${info}`, $element[0].value); } }); }); diff --git a/core/misc/form.js b/core/misc/form.js index d85f85f14324..30e20d9ecf18 100644 --- a/core/misc/form.js +++ b/core/misc/form.js @@ -104,10 +104,18 @@ userInfo.forEach(function (info) { var $element = $forms.find("[name=".concat(info, "]")); var browserData = localStorage.getItem("Drupal.visitor.".concat(info)); - var emptyOrDefault = $element.val() === '' || $element.attr('data-drupal-default-value') === $element.val(); - if ($element.length && emptyOrDefault && browserData) { - $element.val(browserData); + if (!$element.length) { + return; + } + + var emptyValue = $element[0].value === ''; + var defaultValue = $element.attr('data-drupal-default-value') === $element[0].value; + + if (browserData && (emptyValue || defaultValue)) { + $element.each(function (index, item) { + item.value = browserData; + }); } }); } @@ -117,7 +125,7 @@ var $element = $forms.find("[name=".concat(info, "]")); if ($element.length) { - localStorage.setItem("Drupal.visitor.".concat(info), $element.val()); + localStorage.setItem("Drupal.visitor.".concat(info), $element[0].value); } }); }); diff --git a/core/misc/machine-name.es6.js b/core/misc/machine-name.es6.js index a8f1f757242d..e890685ec515 100644 --- a/core/misc/machine-name.es6.js +++ b/core/misc/machine-name.es6.js @@ -55,7 +55,7 @@ function machineNameHandler(e) { const data = e.data; const options = data.options; - const baseValue = $(e.target).val(); + const baseValue = e.target.value; const rx = new RegExp(options.replace_pattern, 'g'); const expected = baseValue @@ -119,7 +119,7 @@ // Hide the form item container of the machine name form element. $wrapper.addClass('visually-hidden'); // Initial machine name from the target field default value. - const machine = $target.val(); + const machine = $target[0].value; // Append the machine name preview to the source field. const $preview = $( `<span class="machine-name-value">${ @@ -150,8 +150,8 @@ // If no initial value, determine machine name based on the // human-readable form element value. - if (machine === '' && $source.val() !== '') { - self.transliterate($source.val(), options).done((machineName) => { + if (machine === '' && $source[0].value !== '') { + self.transliterate($source[0].value, options).done((machineName) => { self.showMachineName( machineName.substr(0, options.maxlength), eventData, @@ -170,7 +170,7 @@ // Preview the machine name in realtime when the human-readable name // changes, but only if there is no machine name yet; i.e., only upon // initial creation, not when editing. - if ($target.val() === '') { + if ($target[0].value === '') { $source .on('formUpdated.machineName', eventData, machineNameHandler) // Initialize machine name preview. @@ -188,7 +188,7 @@ // Set the machine name to the transliterated value. if (machine !== '') { if (machine !== settings.replace) { - data.$target.val(machine); + data.$target[0].value = machine; data.$preview.html( settings.field_prefix + Drupal.checkPlain(machine) + @@ -198,7 +198,7 @@ data.$suffix.show(); } else { data.$suffix.hide(); - data.$target.val(machine); + data.$target[0].value = machine; data.$preview.empty(); } }, diff --git a/core/misc/machine-name.js b/core/misc/machine-name.js index 2e0e1614cff0..ece950c73936 100644 --- a/core/misc/machine-name.js +++ b/core/misc/machine-name.js @@ -24,7 +24,7 @@ function machineNameHandler(e) { var data = e.data; var options = data.options; - var baseValue = $(e.target).val(); + var baseValue = e.target.value; var rx = new RegExp(options.replace_pattern, 'g'); var expected = baseValue.toLowerCase().replace(rx, options.replace).substr(0, options.maxlength); @@ -66,7 +66,7 @@ options.maxlength = $target.attr('maxlength'); $wrapper.addClass('visually-hidden'); - var machine = $target.val(); + var machine = $target[0].value; var $preview = $("<span class=\"machine-name-value\">".concat(options.field_prefix).concat(Drupal.checkPlain(machine)).concat(options.field_suffix, "</span>")); $suffix.empty(); @@ -89,8 +89,8 @@ options: options }; - if (machine === '' && $source.val() !== '') { - self.transliterate($source.val(), options).done(function (machineName) { + if (machine === '' && $source[0].value !== '') { + self.transliterate($source[0].value, options).done(function (machineName) { self.showMachineName(machineName.substr(0, options.maxlength), eventData); }); } @@ -98,7 +98,7 @@ var $link = $("<span class=\"admin-link\"><button type=\"button\" class=\"link\">".concat(Drupal.t('Edit'), "</button></span>")).on('click', eventData, clickEditHandler); $suffix.append($link); - if ($target.val() === '') { + if ($target[0].value === '') { $source.on('formUpdated.machineName', eventData, machineNameHandler).trigger('formUpdated.machineName'); } @@ -110,14 +110,14 @@ if (machine !== '') { if (machine !== settings.replace) { - data.$target.val(machine); + data.$target[0].value = machine; data.$preview.html(settings.field_prefix + Drupal.checkPlain(machine) + settings.field_suffix); } data.$suffix.show(); } else { data.$suffix.hide(); - data.$target.val(machine); + data.$target[0].value = machine; data.$preview.empty(); } }, diff --git a/core/misc/tabledrag.es6.js b/core/misc/tabledrag.es6.js index fd6c1c307679..7830c043bf00 100644 --- a/core/misc/tabledrag.es6.js +++ b/core/misc/tabledrag.es6.js @@ -1137,8 +1137,11 @@ }); } else { // Assume a numeric input field. - let weight = - parseInt($(siblings[0]).find(targetClass).val(), 10) || 0; + let weight = 0; + const $siblingTarget = $(siblings[0]).find(targetClass); + if ($siblingTarget.length) { + weight = parseInt($siblingTarget[0].value, 10) || 0; + } $(siblings) .find(targetClass) .each(function () { diff --git a/core/misc/tabledrag.js b/core/misc/tabledrag.js index 3b80baeccfc0..36341d8073e1 100644 --- a/core/misc/tabledrag.js +++ b/core/misc/tabledrag.js @@ -688,7 +688,13 @@ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "functi } }); } else { - var weight = parseInt($(siblings[0]).find(targetClass).val(), 10) || 0; + var weight = 0; + var $siblingTarget = $(siblings[0]).find(targetClass); + + if ($siblingTarget.length) { + weight = parseInt($siblingTarget[0].value, 10) || 0; + } + $(siblings).find(targetClass).each(function () { this.value = weight; weight++; diff --git a/core/misc/timezone.es6.js b/core/misc/timezone.es6.js index e6d79c882989..a8c1a5f7ac58 100644 --- a/core/misc/timezone.es6.js +++ b/core/misc/timezone.es6.js @@ -13,12 +13,13 @@ attach(context, settings) { const timezone = once('timezone', '.timezone-detect', context); if (timezone.length) { - const $timezone = $(timezone); const tz = new Intl.DateTimeFormat().resolvedOptions().timeZone; // Ensure that the timezone value returned by the browser is supported // by the server. - if (tz && $timezone.find(`option[value="${tz}"]`).length) { - $timezone.val(tz); + if (tz && $(timezone).find(`option[value="${tz}"]`).length) { + timezone.forEach((item) => { + item.value = tz; + }); return; } @@ -71,7 +72,9 @@ dataType: 'json', success(data) { if (data) { - $timezone.val(data); + document.querySelectorAll('.timezone-detect').forEach((item) => { + item.value = data; + }); } }, }); diff --git a/core/misc/timezone.js b/core/misc/timezone.js index a77cb96948cf..ea252a113d2d 100644 --- a/core/misc/timezone.js +++ b/core/misc/timezone.js @@ -11,11 +11,12 @@ var timezone = once('timezone', '.timezone-detect', context); if (timezone.length) { - var $timezone = $(timezone); var tz = new Intl.DateTimeFormat().resolvedOptions().timeZone; - if (tz && $timezone.find("option[value=\"".concat(tz, "\"]")).length) { - $timezone.val(tz); + if (tz && $(timezone).find("option[value=\"".concat(tz, "\"]")).length) { + timezone.forEach(function (item) { + item.value = tz; + }); return; } @@ -48,7 +49,9 @@ dataType: 'json', success: function success(data) { if (data) { - $timezone.val(data); + document.querySelectorAll('.timezone-detect').forEach(function (item) { + item.value = data; + }); } } }); diff --git a/core/misc/vertical-tabs.es6.js b/core/misc/vertical-tabs.es6.js index 5a55d880b21c..2a66dd318273 100644 --- a/core/misc/vertical-tabs.es6.js +++ b/core/misc/vertical-tabs.es6.js @@ -64,7 +64,8 @@ once('vertical-tabs', '[data-vertical-tabs-panes]', context).forEach( (verticalTab) => { const $this = $(verticalTab).addClass('vertical-tabs__panes'); - const focusID = $this.find(':hidden.vertical-tabs__active-tab').val(); + const focusID = $this.find(':hidden.vertical-tabs__active-tab')[0] + .value; let tabFocus; // Check if there are some details that can be converted to @@ -180,8 +181,8 @@ }) .end() .show() - .siblings(':hidden.vertical-tabs__active-tab') - .val(this.details.attr('id')); + .siblings(':hidden.vertical-tabs__active-tab')[0].value = + this.details.attr('id'); this.item.addClass('is-selected'); // Mark the active tab for screen readers. $('#active-vertical-tab').remove(); diff --git a/core/misc/vertical-tabs.js b/core/misc/vertical-tabs.js index 9c967675cd98..da366e0dffb2 100644 --- a/core/misc/vertical-tabs.js +++ b/core/misc/vertical-tabs.js @@ -24,7 +24,7 @@ $(once('vertical-tabs-fragments', 'body')).on('formFragmentLinkClickOrHashChange.verticalTabs', handleFragmentLinkClickOrHashChange); once('vertical-tabs', '[data-vertical-tabs-panes]', context).forEach(function (verticalTab) { var $this = $(verticalTab).addClass('vertical-tabs__panes'); - var focusID = $this.find(':hidden.vertical-tabs__active-tab').val(); + var focusID = $this.find(':hidden.vertical-tabs__active-tab')[0].value; var tabFocus; var $details = $this.find('> details'); @@ -93,7 +93,7 @@ var tab = $(this).data('verticalTab'); tab.details.hide(); tab.item.removeClass('is-selected'); - }).end().show().siblings(':hidden.vertical-tabs__active-tab').val(this.details.attr('id')); + }).end().show().siblings(':hidden.vertical-tabs__active-tab')[0].value = this.details.attr('id'); this.item.addClass('is-selected'); $('#active-vertical-tab').remove(); this.link.append("<span id=\"active-vertical-tab\" class=\"visually-hidden\">".concat(Drupal.t('(active tab)'), "</span>")); diff --git a/core/modules/block/js/block.admin.es6.js b/core/modules/block/js/block.admin.es6.js index 360fcf41ff02..42d22546a56e 100644 --- a/core/modules/block/js/block.admin.es6.js +++ b/core/modules/block/js/block.admin.es6.js @@ -33,7 +33,7 @@ * The jQuery event for the keyup event that triggered the filter. */ function filterBlockList(e) { - const query = $(e.target).val().toLowerCase(); + const query = e.target.value.toLowerCase(); /** * Shows or hides the block entry based on the query. diff --git a/core/modules/block/js/block.admin.js b/core/modules/block/js/block.admin.js index 7469333c70ab..51442ea0dd50 100644 --- a/core/modules/block/js/block.admin.js +++ b/core/modules/block/js/block.admin.js @@ -13,7 +13,7 @@ var $filterRows; function filterBlockList(e) { - var query = $(e.target).val().toLowerCase(); + var query = e.target.value.toLowerCase(); function toggleBlockEntry(index, label) { var $label = $(label); diff --git a/core/modules/block/js/block.es6.js b/core/modules/block/js/block.es6.js index eda67f8ac047..a642ce363e6b 100644 --- a/core/modules/block/js/block.es6.js +++ b/core/modules/block/js/block.es6.js @@ -55,7 +55,7 @@ const $pages = $(context).find( 'textarea[name="visibility[request_path][pages]"]', ); - if (!$pages.val()) { + if (!$pages.length || !$pages[0].value) { return Drupal.t('Not restricted'); } @@ -157,13 +157,13 @@ .find(`.region-${region}-message`) .nextUntil('.region-title') .find('select.block-weight') - .val( + .each(function () { // Increment the weight before assigning it to prevent using the // absolute minimum available weight. This way we always have an // unused upper and lower bound, which makes manually setting the // weights easier for users who prefer to do it that way. - () => ++weight, - ); + this.value = ++weight; + }); } const table = $('#blocks'); @@ -211,7 +211,7 @@ weightField .removeClass(`block-weight-${oldRegionName}`) .addClass(`block-weight-${regionName}`); - regionField.val(regionName); + regionField[0].value = regionName; } updateBlockWeights(table, regionName); diff --git a/core/modules/block/js/block.js b/core/modules/block/js/block.js index bc4ac04e0d7e..427efdf61131 100644 --- a/core/modules/block/js/block.js +++ b/core/modules/block/js/block.js @@ -32,7 +32,7 @@ $('[data-drupal-selector="edit-visibility-request-path"]').drupalSetSummary(function (context) { var $pages = $(context).find('textarea[name="visibility[request_path][pages]"]'); - if (!$pages.val()) { + if (!$pages.length || !$pages[0].value) { return Drupal.t('Not restricted'); } @@ -76,8 +76,8 @@ function updateBlockWeights(table, region) { var weight = -Math.round(table.find('.draggable').length / 2); - table.find(".region-".concat(region, "-message")).nextUntil('.region-title').find('select.block-weight').val(function () { - return ++weight; + table.find(".region-".concat(region, "-message")).nextUntil('.region-title').find('select.block-weight').each(function () { + this.value = ++weight; }); } @@ -106,7 +106,7 @@ var oldRegionName = weightField[0].className.replace(/([^ ]+[ ]+)*block-weight-([^ ]+)([ ]+[^ ]+)*/, '$2'); regionField.removeClass("block-region-".concat(oldRegionName)).addClass("block-region-".concat(regionName)); weightField.removeClass("block-weight-".concat(oldRegionName)).addClass("block-weight-".concat(regionName)); - regionField.val(regionName); + regionField[0].value = regionName; } updateBlockWeights(table, regionName); diff --git a/core/modules/book/book.es6.js b/core/modules/book/book.es6.js index 6192834d04fb..c102a5be05c1 100644 --- a/core/modules/book/book.es6.js +++ b/core/modules/book/book.es6.js @@ -18,7 +18,7 @@ .find('.book-outline-form') .drupalSetSummary((context) => { const $select = $(context).find('.book-title-select'); - const val = $select.val(); + const val = $select[0].value; if (val === '0') { return Drupal.t('Not in book'); diff --git a/core/modules/book/book.js b/core/modules/book/book.js index 6c4f5554d847..ba135713b576 100644 --- a/core/modules/book/book.js +++ b/core/modules/book/book.js @@ -10,7 +10,7 @@ attach: function attach(context) { $(context).find('.book-outline-form').drupalSetSummary(function (context) { var $select = $(context).find('.book-title-select'); - var val = $select.val(); + var val = $select[0].value; if (val === '0') { return Drupal.t('Not in book'); diff --git a/core/modules/ckeditor/js/ckeditor.admin.es6.js b/core/modules/ckeditor/js/ckeditor.admin.es6.js index 5390e81f14bd..24dbf45469bd 100644 --- a/core/modules/ckeditor/js/ckeditor.admin.es6.js +++ b/core/modules/ckeditor/js/ckeditor.admin.es6.js @@ -41,7 +41,7 @@ // Create a configuration model. Drupal.ckeditor.models.Model = new Drupal.ckeditor.Model({ $textarea, - activeEditorConfig: JSON.parse($textarea.val()), + activeEditorConfig: JSON.parse($textarea[0].value), hiddenEditorConfig: drupalSettings.ckeditor.hiddenCKEditorConfig, }); diff --git a/core/modules/ckeditor/js/ckeditor.admin.js b/core/modules/ckeditor/js/ckeditor.admin.js index a5eb2d9afc34..d40449fc439c 100644 --- a/core/modules/ckeditor/js/ckeditor.admin.js +++ b/core/modules/ckeditor/js/ckeditor.admin.js @@ -17,7 +17,7 @@ $configurationForm.append(drupalSettings.ckeditor.toolbarAdmin); Drupal.ckeditor.models.Model = new Drupal.ckeditor.Model({ $textarea: $textarea, - activeEditorConfig: JSON.parse($textarea.val()), + activeEditorConfig: JSON.parse($textarea[0].value), hiddenEditorConfig: drupalSettings.ckeditor.hiddenCKEditorConfig }); var viewDefaults = { diff --git a/core/modules/ckeditor/js/ckeditor.drupalimage.admin.es6.js b/core/modules/ckeditor/js/ckeditor.drupalimage.admin.es6.js index 88980358c5b9..f473b957487f 100644 --- a/core/modules/ckeditor/js/ckeditor.drupalimage.admin.es6.js +++ b/core/modules/ckeditor/js/ckeditor.drupalimage.admin.es6.js @@ -19,17 +19,23 @@ const root = 'input[name="editor[settings][plugins][drupalimage][image_upload]'; const $status = $(`${root}[status]"]`); - const $maxFileSize = $(`${root}[max_size]"]`); - const $maxWidth = $(`${root}[max_dimensions][width]"]`); - const $maxHeight = $(`${root}[max_dimensions][height]"]`); + const maxFileSizeElement = document.querySelector( + `${root}[max_size]"]`, + ); + const maxWidth = document.querySelector( + `${root}[max_dimensions][width]"]`, + ); + const maxHeight = document.querySelector( + `${root}[max_dimensions][height]"]`, + ); const $scheme = $(`${root}[scheme]"]:checked`); - const maxFileSize = $maxFileSize.val() - ? $maxFileSize.val() - : $maxFileSize.attr('placeholder'); + const maxFileSize = maxFileSizeElement.value + ? maxFileSizeElement.value + : maxFileSizeElement.getAttribute('placeholder'); const maxDimensions = - $maxWidth.val() && $maxHeight.val() - ? `(${$maxWidth.val()}x${$maxHeight.val()})` + maxWidth.value && maxHeight.value + ? `(${maxWidth.value}x${maxHeight.value})` : ''; if (!$status.is(':checked')) { diff --git a/core/modules/ckeditor/js/ckeditor.drupalimage.admin.js b/core/modules/ckeditor/js/ckeditor.drupalimage.admin.js index 284e0054a745..5ea1cd8cd403 100644 --- a/core/modules/ckeditor/js/ckeditor.drupalimage.admin.js +++ b/core/modules/ckeditor/js/ckeditor.drupalimage.admin.js @@ -11,12 +11,12 @@ $('[data-ckeditor-plugin-id="drupalimage"]').drupalSetSummary(function (context) { var root = 'input[name="editor[settings][plugins][drupalimage][image_upload]'; var $status = $("".concat(root, "[status]\"]")); - var $maxFileSize = $("".concat(root, "[max_size]\"]")); - var $maxWidth = $("".concat(root, "[max_dimensions][width]\"]")); - var $maxHeight = $("".concat(root, "[max_dimensions][height]\"]")); + var maxFileSizeElement = document.querySelector("".concat(root, "[max_size]\"]")); + var maxWidth = document.querySelector("".concat(root, "[max_dimensions][width]\"]")); + var maxHeight = document.querySelector("".concat(root, "[max_dimensions][height]\"]")); var $scheme = $("".concat(root, "[scheme]\"]:checked")); - var maxFileSize = $maxFileSize.val() ? $maxFileSize.val() : $maxFileSize.attr('placeholder'); - var maxDimensions = $maxWidth.val() && $maxHeight.val() ? "(".concat($maxWidth.val(), "x").concat($maxHeight.val(), ")") : ''; + var maxFileSize = maxFileSizeElement.value ? maxFileSizeElement.value : maxFileSizeElement.getAttribute('placeholder'); + var maxDimensions = maxWidth.value && maxHeight.value ? "(".concat(maxWidth.value, "x").concat(maxHeight.value, ")") : ''; if (!$status.is(':checked')) { return Drupal.t('Uploads disabled'); diff --git a/core/modules/ckeditor/js/ckeditor.stylescombo.admin.es6.js b/core/modules/ckeditor/js/ckeditor.stylescombo.admin.es6.js index 26a377bbc1d6..6717a65433ea 100644 --- a/core/modules/ckeditor/js/ckeditor.stylescombo.admin.es6.js +++ b/core/modules/ckeditor/js/ckeditor.stylescombo.admin.es6.js @@ -36,7 +36,7 @@ $context .find('[name="editor[settings][plugins][stylescombo][styles]"]') .on('blur.ckeditorStylesComboSettings', function () { - const styles = $(this).val().trim(); + const styles = this.value.trim(); const stylesSet = that._generateStylesSetSetting(styles); if (!_.isEqual(previousStylesSet, stylesSet)) { previousStylesSet = stylesSet; @@ -116,11 +116,11 @@ attach() { $('[data-ckeditor-plugin-id="stylescombo"]').drupalSetSummary( (context) => { - const styles = $( + const stylesElement = document.querySelector( '[data-drupal-selector="edit-editor-settings-plugins-stylescombo-styles"]', - ) - .val() - .trim(); + ); + const styles = stylesElement ? stylesElement.value.trim() : ''; + if (styles.length === 0) { return Drupal.t('No styles configured'); } diff --git a/core/modules/ckeditor/js/ckeditor.stylescombo.admin.js b/core/modules/ckeditor/js/ckeditor.stylescombo.admin.js index 164d16bc1bbd..3eb9cbb1e100 100644 --- a/core/modules/ckeditor/js/ckeditor.stylescombo.admin.js +++ b/core/modules/ckeditor/js/ckeditor.stylescombo.admin.js @@ -13,7 +13,7 @@ var previousStylesSet = drupalSettings.ckeditor.hiddenCKEditorConfig.stylesSet; var that = this; $context.find('[name="editor[settings][plugins][stylescombo][styles]"]').on('blur.ckeditorStylesComboSettings', function () { - var styles = $(this).val().trim(); + var styles = this.value.trim(); var stylesSet = that._generateStylesSetSetting(styles); @@ -61,7 +61,8 @@ Drupal.behaviors.ckeditorStylesComboSettingsSummary = { attach: function attach() { $('[data-ckeditor-plugin-id="stylescombo"]').drupalSetSummary(function (context) { - var styles = $('[data-drupal-selector="edit-editor-settings-plugins-stylescombo-styles"]').val().trim(); + var stylesElement = document.querySelector('[data-drupal-selector="edit-editor-settings-plugins-stylescombo-styles"]'); + var styles = stylesElement ? stylesElement.value.trim() : ''; if (styles.length === 0) { return Drupal.t('No styles configured'); diff --git a/core/modules/color/color.es6.js b/core/modules/color/color.es6.js index 6cde1cf44301..b0c766aea2d6 100644 --- a/core/modules/color/color.es6.js +++ b/core/modules/color/color.es6.js @@ -139,8 +139,8 @@ }); // Change input value. - if ($(input).val() && $(input).val() !== color) { - $(input).val(color); + if (input.value && input.value !== color) { + input.value = color; // Update locked values. if (propagate) { diff --git a/core/modules/color/color.js b/core/modules/color/color.js index 4bf2091d7992..2b73fcf00110 100644 --- a/core/modules/color/color.js +++ b/core/modules/color/color.js @@ -79,8 +79,8 @@ color: farb.RGBToHSL(farb.unpack(color))[2] > 0.5 ? '#000' : '#fff' }); - if ($(input).val() && $(input).val() !== color) { - $(input).val(color); + if (input.value && input.value !== color) { + input.value = color; if (propagate) { i = input.i; diff --git a/core/modules/content_translation/content_translation.admin.es6.js b/core/modules/content_translation/content_translation.admin.es6.js index 1360ca33474e..d74009ec315b 100644 --- a/core/modules/content_translation/content_translation.admin.es6.js +++ b/core/modules/content_translation/content_translation.admin.es6.js @@ -49,7 +49,7 @@ let column; function filterFieldsList(index, field) { - return $(field).val() === column; + return field.value === column; } // A field that has many different translatable parts can also define one diff --git a/core/modules/content_translation/content_translation.admin.js b/core/modules/content_translation/content_translation.admin.js index 7b243b5f88ad..8a30f6861885 100644 --- a/core/modules/content_translation/content_translation.admin.js +++ b/core/modules/content_translation/content_translation.admin.js @@ -32,7 +32,7 @@ var column; function filterFieldsList(index, field) { - return $(field).val() === column; + return field.value === column; } Object.keys(dependentColumns || {}).forEach(function (index) { diff --git a/core/modules/editor/js/editor.es6.js b/core/modules/editor/js/editor.es6.js index b6deb24b62fd..ccff56bbd444 100644 --- a/core/modules/editor/js/editor.es6.js +++ b/core/modules/editor/js/editor.es6.js @@ -109,10 +109,10 @@ * The text format change event. */ function onTextFormatChange(event) { - const $select = $(event.target); + const select = event.target; const field = event.data.field; const activeFormatID = field.getAttribute('data-editor-active-text-format'); - const newFormatID = $select.val(); + const newFormatID = select.value; // Prevent double-attaching if the change event is triggered manually. if (newFormatID === activeFormatID) { @@ -132,7 +132,7 @@ const message = Drupal.t( 'Changing the text format to %text_format will permanently remove content that is not allowed in that text format.<br><br>Save your changes before switching the text format to avoid losing data.', { - '%text_format': $select.find('option:selected').text(), + '%text_format': $(select).find('option:selected').text(), }, ); const confirmationDialog = Drupal.dialog(`<div>${message}</div>`, { @@ -156,7 +156,7 @@ // cannot simply call event.preventDefault() because jQuery's // change event is only triggered after the change has already // been accepted. - $select.val(activeFormatID); + select.value = activeFormatID; confirmationDialog.close(); }, }, @@ -214,7 +214,7 @@ } // Store the current active format. - const activeFormatID = $this.val(); + const activeFormatID = editor.value; field.setAttribute('data-editor-active-text-format', activeFormatID); // Directly attach this text editor, if the text format is enabled. @@ -268,7 +268,7 @@ editors.forEach((editor) => { const $this = $(editor); - const activeFormatID = $this.val(); + const activeFormatID = editor.value; const field = findFieldForFormatSelector($this); if (field && activeFormatID in settings.editor.formats) { Drupal.editorDetach( diff --git a/core/modules/editor/js/editor.js b/core/modules/editor/js/editor.js index ec247975f77d..b9b834c30aeb 100644 --- a/core/modules/editor/js/editor.js +++ b/core/modules/editor/js/editor.js @@ -52,10 +52,10 @@ } function onTextFormatChange(event) { - var $select = $(event.target); + var select = event.target; var field = event.data.field; var activeFormatID = field.getAttribute('data-editor-active-text-format'); - var newFormatID = $select.val(); + var newFormatID = select.value; if (newFormatID === activeFormatID) { return; @@ -66,7 +66,7 @@ if (hasContent && supportContentFiltering) { var message = Drupal.t('Changing the text format to %text_format will permanently remove content that is not allowed in that text format.<br><br>Save your changes before switching the text format to avoid losing data.', { - '%text_format': $select.find('option:selected').text() + '%text_format': $(select).find('option:selected').text() }); var confirmationDialog = Drupal.dialog("<div>".concat(message, "</div>"), { title: Drupal.t('Change text format?'), @@ -83,7 +83,7 @@ text: Drupal.t('Cancel'), class: 'button', click: function click() { - $select.val(activeFormatID); + select.value = activeFormatID; confirmationDialog.close(); } }], @@ -117,7 +117,7 @@ return; } - var activeFormatID = $this.val(); + var activeFormatID = editor.value; field.setAttribute('data-editor-active-text-format', activeFormatID); if (settings.editor.formats[activeFormatID]) { @@ -157,7 +157,7 @@ editors.forEach(function (editor) { var $this = $(editor); - var activeFormatID = $this.val(); + var activeFormatID = editor.value; var field = findFieldForFormatSelector($this); if (field && activeFormatID in settings.editor.formats) { diff --git a/core/modules/field_ui/field_ui.es6.js b/core/modules/field_ui/field_ui.es6.js index 4779b5f86287..950df384ca7c 100644 --- a/core/modules/field_ui/field_ui.es6.js +++ b/core/modules/field_ui/field_ui.es6.js @@ -43,27 +43,32 @@ // When the user selects a new field type, clear the "existing field" // selection. $newFieldType.on('change', function () { - if ($(this).val() !== '') { + if (this.value !== '') { // Reset the "existing storage name" selection. - $existingStorageName.val('').trigger('change'); + if ($existingStorageName.length) { + $existingStorageName[0].value = ''; + $existingStorageName.trigger('change'); + } } }); // When the user selects an existing storage name, clear the "new field // type" selection and populate the 'existing_storage_label' element. $existingStorageName.on('change', function () { - const value = $(this).val(); + const { value } = this; if (value !== '') { - // Reset the "new field type" selection. - $newFieldType.val('').trigger('change'); + if ($newFieldType.length) { + // Reset the "new field type" selection. + $newFieldType[0].value = ''; + $newFieldType.trigger('change'); + } // Pre-populate the "existing storage label" element. if ( typeof drupalSettings.existingFieldLabels[value] !== 'undefined' ) { - $existingStorageLabel.val( - drupalSettings.existingFieldLabels[value], - ); + $existingStorageLabel[0].value = + drupalSettings.existingFieldLabels[value]; } } }); @@ -152,8 +157,11 @@ // Handle region change. const region = rowHandler.getRegion(); if (region !== rowHandler.region) { - // Remove parenting. - $row.find('select.js-field-parent').val(''); + const $fieldParent = $row.find('select.js-field-parent'); + if ($fieldParent.length) { + // Remove parenting. + $fieldParent[0].value = ''; + } // Let the row handler deal with the region change. $.extend(refreshRows, rowHandler.regionChange(region)); // Update the row region. @@ -258,9 +266,11 @@ if (rowNames.length) { // Add a throbber next each of the ajaxElements. $(ajaxElements).after(Drupal.theme.ajaxProgressThrobber()); - - // Fire the Ajax update. - $('input[name=refresh_rows]').val(rowNames.join(' ')); + const $refreshRows = $('input[name=refresh_rows]'); + if ($refreshRows.length) { + // Fire the Ajax update. + $refreshRows[0].value = rowNames.join(' '); + } $('input[data-drupal-selector="edit-refresh"]').trigger('mousedown'); // Disabled elements do not appear in POST ajax data, so we mark the @@ -318,7 +328,9 @@ * Either 'hidden' or 'content'. */ getRegion() { - return this.$regionSelect.val(); + if (this.$regionSelect.length) { + return this.$regionSelect[0].value; + } }, /** @@ -344,8 +356,10 @@ // Replace dashes with underscores. region = region.replace(/-/g, '_'); - // Set the region of the select list. - this.$regionSelect.val(region); + if (this.$regionSelect.length) { + // Set the region of the select list. + this.$regionSelect[0].value = region; + } // Restore the formatter back to the default formatter only if it was // disabled previously. Pseudo-fields do not have default formatters, @@ -354,10 +368,12 @@ const value = typeof this.defaultPlugin !== 'undefined' ? this.defaultPlugin - : this.$pluginSelect.find('option').val(); + : this.$pluginSelect.find('option')[0].value; if (typeof value !== 'undefined') { - this.$pluginSelect.val(value); + if (this.$pluginSelect.length) { + this.$pluginSelect[0].value = value; + } } } diff --git a/core/modules/field_ui/field_ui.js b/core/modules/field_ui/field_ui.js index ef88cc357b2b..30bdf9af8c1b 100644 --- a/core/modules/field_ui/field_ui.js +++ b/core/modules/field_ui/field_ui.js @@ -17,18 +17,24 @@ var $existingStorageName = $form.find('select[name="existing_storage_name"]'); var $existingStorageLabel = $form.find('input[name="existing_storage_label"]'); $newFieldType.on('change', function () { - if ($(this).val() !== '') { - $existingStorageName.val('').trigger('change'); + if (this.value !== '') { + if ($existingStorageName.length) { + $existingStorageName[0].value = ''; + $existingStorageName.trigger('change'); + } } }); $existingStorageName.on('change', function () { - var value = $(this).val(); + var value = this.value; if (value !== '') { - $newFieldType.val('').trigger('change'); + if ($newFieldType.length) { + $newFieldType[0].value = ''; + $newFieldType.trigger('change'); + } if (typeof drupalSettings.existingFieldLabels[value] !== 'undefined') { - $existingStorageLabel.val(drupalSettings.existingFieldLabels[value]); + $existingStorageLabel[0].value = drupalSettings.existingFieldLabels[value]; } } }); @@ -67,7 +73,12 @@ var region = rowHandler.getRegion(); if (region !== rowHandler.region) { - $row.find('select.js-field-parent').val(''); + var $fieldParent = $row.find('select.js-field-parent'); + + if ($fieldParent.length) { + $fieldParent[0].value = ''; + } + $.extend(refreshRows, rowHandler.regionChange(region)); rowHandler.region = region; } @@ -119,7 +130,12 @@ if (rowNames.length) { $(ajaxElements).after(Drupal.theme.ajaxProgressThrobber()); - $('input[name=refresh_rows]').val(rowNames.join(' ')); + var $refreshRows = $('input[name=refresh_rows]'); + + if ($refreshRows.length) { + $refreshRows[0].value = rowNames.join(' '); + } + $('input[data-drupal-selector="edit-refresh"]').trigger('mousedown'); $(ajaxElements).prop('disabled', true); } @@ -142,17 +158,24 @@ Drupal.fieldUIDisplayOverview.field.prototype = { getRegion: function getRegion() { - return this.$regionSelect.val(); + if (this.$regionSelect.length) { + return this.$regionSelect[0].value; + } }, regionChange: function regionChange(region) { region = region.replace(/-/g, '_'); - this.$regionSelect.val(region); + + if (this.$regionSelect.length) { + this.$regionSelect[0].value = region; + } if (this.region === 'hidden') { - var value = typeof this.defaultPlugin !== 'undefined' ? this.defaultPlugin : this.$pluginSelect.find('option').val(); + var value = typeof this.defaultPlugin !== 'undefined' ? this.defaultPlugin : this.$pluginSelect.find('option')[0].value; if (typeof value !== 'undefined') { - this.$pluginSelect.val(value); + if (this.$pluginSelect.length) { + this.$pluginSelect[0].value = value; + } } } diff --git a/core/modules/filter/filter.es6.js b/core/modules/filter/filter.es6.js index 58b7232cee29..733dc93f3c9c 100644 --- a/core/modules/filter/filter.es6.js +++ b/core/modules/filter/filter.es6.js @@ -16,7 +16,7 @@ attach(context) { function updateFilterGuidelines(event) { const $this = $(event.target); - const value = $this.val(); + const { value } = event.target; $this .closest('.js-filter-wrapper') .find('[data-drupal-format-id]') diff --git a/core/modules/filter/filter.filter_html.admin.es6.js b/core/modules/filter/filter.filter_html.admin.es6.js index 05cb0508c270..599d061b9f6f 100644 --- a/core/modules/filter/filter.filter_html.admin.es6.js +++ b/core/modules/filter/filter.filter_html.admin.es6.js @@ -17,9 +17,9 @@ * An array of filter rules. */ getRules() { - const currentValue = $( + const currentValue = document.querySelector( '#edit-filters-filter-html-settings-allowed-html', - ).val(); + ).value; const rules = Drupal.behaviors.filterFilterHtmlUpdating._parseSetting(currentValue); diff --git a/core/modules/filter/filter.filter_html.admin.js b/core/modules/filter/filter.filter_html.admin.js index 54eed3ff6b25..07c48c97d63c 100644 --- a/core/modules/filter/filter.filter_html.admin.js +++ b/core/modules/filter/filter.filter_html.admin.js @@ -9,7 +9,7 @@ if (Drupal.filterConfiguration) { Drupal.filterConfiguration.liveSettingParsers.filter_html = { getRules: function getRules() { - var currentValue = $('#edit-filters-filter-html-settings-allowed-html').val(); + var currentValue = document.querySelector('#edit-filters-filter-html-settings-allowed-html').value; var rules = Drupal.behaviors.filterFilterHtmlUpdating._parseSetting(currentValue); diff --git a/core/modules/filter/filter.js b/core/modules/filter/filter.js index e8d57f1d79d9..d7964d951991 100644 --- a/core/modules/filter/filter.js +++ b/core/modules/filter/filter.js @@ -10,7 +10,7 @@ attach: function attach(context) { function updateFilterGuidelines(event) { var $this = $(event.target); - var value = $this.val(); + var value = event.target.value; $this.closest('.js-filter-wrapper').find('[data-drupal-format-id]').hide().filter("[data-drupal-format-id=\"".concat(value, "\"]")).show(); } diff --git a/core/modules/image/js/editors/image.es6.js b/core/modules/image/js/editors/image.es6.js index 1710335995e3..30a54f51b821 100644 --- a/core/modules/image/js/editors/image.es6.js +++ b/core/modules/image/js/editors/image.es6.js @@ -18,8 +18,7 @@ Drupal.quickedit.EditorView.prototype.initialize.call(this, options); // Set our original value to our current HTML (for reverting). this.model.set('originalValue', this.$el.html().trim()); - // $.val() callback function for copying input from our custom form to - // the Quick Edit Field Form. + // Copy input from our custom form to the Quick Edit Field Form. this.model.set('currentValue', function (index, value) { const matches = $(this) .attr('name') @@ -33,7 +32,7 @@ `.quickedit-image-field-info input[name="${name}"]`, ); if ($input.length) { - return $input.val(); + return $input[0].value; } } }); diff --git a/core/modules/image/js/editors/image.js b/core/modules/image/js/editors/image.js index 4ca52361d480..9f798849c335 100644 --- a/core/modules/image/js/editors/image.js +++ b/core/modules/image/js/editors/image.js @@ -19,7 +19,7 @@ var $input = $toolgroup.find(".quickedit-image-field-info input[name=\"".concat(name, "\"]")); if ($input.length) { - return $input.val(); + return $input[0].value; } } }); diff --git a/core/modules/layout_builder/js/layout-builder.es6.js b/core/modules/layout_builder/js/layout-builder.es6.js index 149d2bd53a90..77ab574b0466 100644 --- a/core/modules/layout_builder/js/layout-builder.es6.js +++ b/core/modules/layout_builder/js/layout-builder.es6.js @@ -32,7 +32,7 @@ * The jQuery event for the keyup event that triggered the filter. */ const filterBlockList = (e) => { - const query = $(e.target).val().toLowerCase(); + const query = e.target.value.toLowerCase(); /** * Shows or hides the block entry based on the query. diff --git a/core/modules/layout_builder/js/layout-builder.js b/core/modules/layout_builder/js/layout-builder.js index a3fc41e9c2c0..6461c009483a 100644 --- a/core/modules/layout_builder/js/layout-builder.js +++ b/core/modules/layout_builder/js/layout-builder.js @@ -18,7 +18,7 @@ var $filterLinks = $categories.find('.js-layout-builder-block-link'); var filterBlockList = function filterBlockList(e) { - var query = $(e.target).val().toLowerCase(); + var query = e.target.value.toLowerCase(); var toggleBlockEntry = function toggleBlockEntry(index, link) { var $link = $(link); diff --git a/core/modules/locale/locale.bulk.es6.js b/core/modules/locale/locale.bulk.es6.js index 7066baee50bf..1b7d0ff2e556 100644 --- a/core/modules/locale/locale.bulk.es6.js +++ b/core/modules/locale/locale.bulk.es6.js @@ -23,14 +23,12 @@ $form.find('.file-import-input').on('change', function () { // If the filename is fully the language code or the filename // ends with a language code, pre-select that one. - const matches = $(this) - .val() - .match(/([^.][.]*)([\w-]+)\.po$/); + const matches = this.value.match(/([^.][.]*)([\w-]+)\.po$/); if ( matches && $langcode.find(`option[value="${matches[2]}"]`).length ) { - $langcode.val(matches[2]); + $langcode[0].value = matches[2]; } }); } diff --git a/core/modules/locale/locale.bulk.js b/core/modules/locale/locale.bulk.js index 4222a7891a92..80c2841099c3 100644 --- a/core/modules/locale/locale.bulk.js +++ b/core/modules/locale/locale.bulk.js @@ -14,10 +14,10 @@ var $form = $(form); var $langcode = $form.find('.langcode-input'); $form.find('.file-import-input').on('change', function () { - var matches = $(this).val().match(/([^.][.]*)([\w-]+)\.po$/); + var matches = this.value.match(/([^.][.]*)([\w-]+)\.po$/); if (matches && $langcode.find("option[value=\"".concat(matches[2], "\"]")).length) { - $langcode.val(matches[2]); + $langcode[0].value = matches[2]; } }); } diff --git a/core/modules/media/js/form.es6.js b/core/modules/media/js/form.es6.js index 0d17267a60ae..e7ac049cb87e 100644 --- a/core/modules/media/js/form.es6.js +++ b/core/modules/media/js/form.es6.js @@ -14,26 +14,27 @@ */ Drupal.behaviors.mediaFormSummaries = { attach(context) { - const $context = $(context); + $(context) + .find('.media-form-author') + .drupalSetSummary((context) => { + const nameInput = context.querySelector('.field--name-uid input'); + const name = nameInput && nameInput.value; + const dateInput = context.querySelector('.field--name-created input'); + const date = dateInput && dateInput.value; - $context.find('.media-form-author').drupalSetSummary((context) => { - const $authorContext = $(context); - const name = $authorContext.find('.field--name-uid input').val(); - const date = $authorContext.find('.field--name-created input').val(); - - if (name && date) { - return Drupal.t('By @name on @date', { - '@name': name, - '@date': date, - }); - } - if (name) { - return Drupal.t('By @name', { '@name': name }); - } - if (date) { - return Drupal.t('Authored on @date', { '@date': date }); - } - }); + if (name && date) { + return Drupal.t('By @name on @date', { + '@name': name, + '@date': date, + }); + } + if (name) { + return Drupal.t('By @name', { '@name': name }); + } + if (date) { + return Drupal.t('Authored on @date', { '@date': date }); + } + }); }, }; })(jQuery, Drupal); diff --git a/core/modules/media/js/form.js b/core/modules/media/js/form.js index aa2ee237eac1..52f7bdc11f41 100644 --- a/core/modules/media/js/form.js +++ b/core/modules/media/js/form.js @@ -8,11 +8,11 @@ (function ($, Drupal) { Drupal.behaviors.mediaFormSummaries = { attach: function attach(context) { - var $context = $(context); - $context.find('.media-form-author').drupalSetSummary(function (context) { - var $authorContext = $(context); - var name = $authorContext.find('.field--name-uid input').val(); - var date = $authorContext.find('.field--name-created input').val(); + $(context).find('.media-form-author').drupalSetSummary(function (context) { + var nameInput = context.querySelector('.field--name-uid input'); + var name = nameInput && nameInput.value; + var dateInput = context.querySelector('.field--name-created input'); + var date = dateInput && dateInput.value; if (name && date) { return Drupal.t('By @name on @date', { diff --git a/core/modules/media_library/js/media_library.ui.es6.js b/core/modules/media_library/js/media_library.ui.es6.js index d6a730398364..95bc01ac3fe5 100644 --- a/core/modules/media_library/js/media_library.ui.es6.js +++ b/core/modules/media_library/js/media_library.ui.es6.js @@ -342,18 +342,24 @@ currentSelection.splice(position, 1); } - // Set the selection in the hidden form element. - $form - .find('#media-library-modal-selection') - .val(currentSelection.join()) - .trigger('change'); + const mediaLibraryModalSelection = document.querySelector( + '#media-library-modal-selection', + ); + + if (mediaLibraryModalSelection) { + // Set the selection in the hidden form element. + mediaLibraryModalSelection.value = currentSelection.join(); + $(mediaLibraryModalSelection).trigger('change'); + } // Set the selection in the media library add form. Since the form is // not necessarily loaded within the same context, we can't use the // context here. - $('.js-media-library-add-form-current-selection').val( - currentSelection.join(), - ); + document + .querySelectorAll('.js-media-library-add-form-current-selection') + .forEach((item) => { + item.value = currentSelection.join(); + }); }); // The hidden selection form field changes when the selection is updated. diff --git a/core/modules/media_library/js/media_library.ui.js b/core/modules/media_library/js/media_library.ui.js index 320503100125..bf5e93f2f74a 100644 --- a/core/modules/media_library/js/media_library.ui.js +++ b/core/modules/media_library/js/media_library.ui.js @@ -175,8 +175,16 @@ currentSelection.splice(position, 1); } - $form.find('#media-library-modal-selection').val(currentSelection.join()).trigger('change'); - $('.js-media-library-add-form-current-selection').val(currentSelection.join()); + var mediaLibraryModalSelection = document.querySelector('#media-library-modal-selection'); + + if (mediaLibraryModalSelection) { + mediaLibraryModalSelection.value = currentSelection.join(); + $(mediaLibraryModalSelection).trigger('change'); + } + + document.querySelectorAll('.js-media-library-add-form-current-selection').forEach(function (item) { + item.value = currentSelection.join(); + }); }); $(once('media-library-selection-change', $form.find('#media-library-modal-selection'))).on('change', function (e) { updateSelectionCount(settings.media_library.selection_remaining); diff --git a/core/modules/media_library/js/media_library.widget.es6.js b/core/modules/media_library/js/media_library.widget.es6.js index 88ad11fbc717..9c517fe870a3 100644 --- a/core/modules/media_library/js/media_library.widget.es6.js +++ b/core/modules/media_library/js/media_library.widget.es6.js @@ -22,7 +22,7 @@ $(widget) .children() .each((index, child) => { - $(child).find('.js-media-library-item-weight').val(index); + $(child).find('.js-media-library-item-weight')[0].value = index; }); }, }); diff --git a/core/modules/media_library/js/media_library.widget.js b/core/modules/media_library/js/media_library.widget.js index d2e74bab3038..8e996d202d0f 100644 --- a/core/modules/media_library/js/media_library.widget.js +++ b/core/modules/media_library/js/media_library.widget.js @@ -15,7 +15,7 @@ handle: '.js-media-library-item-preview', onEnd: function onEnd() { $(widget).children().each(function (index, child) { - $(child).find('.js-media-library-item-weight').val(index); + $(child).find('.js-media-library-item-weight')[0].value = index; }); } }); diff --git a/core/modules/media_library/media_library.libraries.yml b/core/modules/media_library/media_library.libraries.yml index 28b873879aae..8c2f1b393a0a 100644 --- a/core/modules/media_library/media_library.libraries.yml +++ b/core/modules/media_library/media_library.libraries.yml @@ -32,6 +32,7 @@ ui: dependencies: - core/drupal.ajax - core/drupal.announce + - core/drupal.nodelist.foreach - core/once - core/jquery.once.bc - core/jquery diff --git a/core/modules/menu_ui/menu_ui.admin.es6.js b/core/modules/menu_ui/menu_ui.admin.es6.js index 69b0d6843e3a..57607657c3f0 100644 --- a/core/modules/menu_ui/menu_ui.admin.es6.js +++ b/core/modules/menu_ui/menu_ui.admin.es6.js @@ -32,7 +32,7 @@ $menu.find('input:checked').each(function () { // Get the names of all checked menus. - values.push(Drupal.checkPlain($(this).val())); + values.push(Drupal.checkPlain(this.value)); }); $.ajax({ @@ -45,21 +45,17 @@ success(options) { const $select = $('#edit-menu-parent'); // Save key of last selected element. - const selected = $select.val(); + const selected = $select[0].value; // Remove all existing options from dropdown. $select.children().remove(); // Add new options to dropdown. Keep a count of options for testing later. let totalOptions = 0; Object.keys(options || {}).forEach((machineName) => { - $select.append( - $( - `<option ${ - machineName === selected ? ' selected="selected"' : '' - }></option>`, - ) - .val(machineName) - .text(options[machineName]), - ); + const selectContents = document.createElement('option'); + selectContents.selected = machineName === selected; + selectContents.value = machineName; + selectContents.innerText = options[machineName]; + $select.append(selectContents); totalOptions++; }); diff --git a/core/modules/menu_ui/menu_ui.admin.js b/core/modules/menu_ui/menu_ui.admin.js index 62442f0b2e43..a109502b9daf 100644 --- a/core/modules/menu_ui/menu_ui.admin.js +++ b/core/modules/menu_ui/menu_ui.admin.js @@ -22,7 +22,7 @@ var $menu = $('#edit-menu'); var values = []; $menu.find('input:checked').each(function () { - values.push(Drupal.checkPlain($(this).val())); + values.push(Drupal.checkPlain(this.value)); }); $.ajax({ url: "".concat(window.location.protocol, "//").concat(window.location.host).concat(Drupal.url('admin/structure/menu/parents')), @@ -33,11 +33,15 @@ dataType: 'json', success: function success(options) { var $select = $('#edit-menu-parent'); - var selected = $select.val(); + var selected = $select[0].value; $select.children().remove(); var totalOptions = 0; Object.keys(options || {}).forEach(function (machineName) { - $select.append($("<option ".concat(machineName === selected ? ' selected="selected"' : '', "></option>")).val(machineName).text(options[machineName])); + var selectContents = document.createElement('option'); + selectContents.selected = machineName === selected; + selectContents.value = machineName; + selectContents.innerText = options[machineName]; + $select.append(selectContents); totalOptions++; }); $select.closest('div').toggle(totalOptions > 0).attr('hidden', totalOptions === 0); diff --git a/core/modules/menu_ui/menu_ui.es6.js b/core/modules/menu_ui/menu_ui.es6.js index 5188164f1498..51c417cab14e 100644 --- a/core/modules/menu_ui/menu_ui.es6.js +++ b/core/modules/menu_ui/menu_ui.es6.js @@ -22,7 +22,7 @@ $context.find('.js-form-item-menu-enabled input').is(':checked') ) { return Drupal.checkPlain( - $context.find('.js-form-item-menu-title input').val(), + $context.find('.js-form-item-menu-title input')[0].value, ); } @@ -60,7 +60,7 @@ // If there is a link title already, mark it as overridden. The user // expects that toggling the checkbox twice will take over the node's // title. - if ($checkbox.is(':checked') && $linkTitle.val().length) { + if ($checkbox.is(':checked') && $linkTitle[0].value.length) { $linkTitle.data('menuLinkAutomaticTitleOverridden', true); } // Whenever the value is changed manually, disable this behavior. @@ -71,10 +71,10 @@ $checkbox.on('change', () => { if ($checkbox.is(':checked')) { if (!$linkTitle.data('menuLinkAutomaticTitleOverridden')) { - $linkTitle.val($title.val()); + $linkTitle[0].value = $title[0].value; } } else { - $linkTitle.val(''); + $linkTitle[0].value = ''; $linkTitle.removeData('menuLinkAutomaticTitleOverridden'); } $checkbox.closest('.vertical-tabs-pane').trigger('summaryUpdated'); @@ -86,8 +86,8 @@ !$linkTitle.data('menuLinkAutomaticTitleOverridden') && $checkbox.is(':checked') ) { - $linkTitle.val($title.val()); - $linkTitle.val($title.val()).trigger('formUpdated'); + $linkTitle[0].value = $title[0].value; + $linkTitle.trigger('formUpdated'); } }); }); diff --git a/core/modules/menu_ui/menu_ui.js b/core/modules/menu_ui/menu_ui.js index f5a7fc0c459d..caf4bd108726 100644 --- a/core/modules/menu_ui/menu_ui.js +++ b/core/modules/menu_ui/menu_ui.js @@ -12,7 +12,7 @@ var $context = $(context); if ($context.find('.js-form-item-menu-enabled input').is(':checked')) { - return Drupal.checkPlain($context.find('.js-form-item-menu-title input').val()); + return Drupal.checkPlain($context.find('.js-form-item-menu-title input')[0].value); } return Drupal.t('Not in menu'); @@ -32,7 +32,7 @@ return; } - if ($checkbox.is(':checked') && $linkTitle.val().length) { + if ($checkbox.is(':checked') && $linkTitle[0].value.length) { $linkTitle.data('menuLinkAutomaticTitleOverridden', true); } @@ -42,10 +42,10 @@ $checkbox.on('change', function () { if ($checkbox.is(':checked')) { if (!$linkTitle.data('menuLinkAutomaticTitleOverridden')) { - $linkTitle.val($title.val()); + $linkTitle[0].value = $title[0].value; } } else { - $linkTitle.val(''); + $linkTitle[0].value = ''; $linkTitle.removeData('menuLinkAutomaticTitleOverridden'); } @@ -54,8 +54,8 @@ }); $title.on('keyup', function () { if (!$linkTitle.data('menuLinkAutomaticTitleOverridden') && $checkbox.is(':checked')) { - $linkTitle.val($title.val()); - $linkTitle.val($title.val()).trigger('formUpdated'); + $linkTitle[0].value = $title[0].value; + $linkTitle.trigger('formUpdated'); } }); }); diff --git a/core/modules/node/content_types.es6.js b/core/modules/node/content_types.es6.js index dbfd7a9ddef9..4bb82a5c468b 100644 --- a/core/modules/node/content_types.es6.js +++ b/core/modules/node/content_types.es6.js @@ -19,7 +19,7 @@ $context.find('#edit-submission').drupalSetSummary((context) => { const vals = []; vals.push( - Drupal.checkPlain($(context).find('#edit-title-label').val()) || + Drupal.checkPlain($(context).find('#edit-title-label')[0].value) || Drupal.t('Requires a title'), ); return vals.join(', '); diff --git a/core/modules/node/content_types.js b/core/modules/node/content_types.js index 97258743854e..e456bb371f32 100644 --- a/core/modules/node/content_types.js +++ b/core/modules/node/content_types.js @@ -11,7 +11,7 @@ var $context = $(context); $context.find('#edit-submission').drupalSetSummary(function (context) { var vals = []; - vals.push(Drupal.checkPlain($(context).find('#edit-title-label').val()) || Drupal.t('Requires a title')); + vals.push(Drupal.checkPlain($(context).find('#edit-title-label')[0].value) || Drupal.t('Requires a title')); return vals.join(', '); }); $context.find('#edit-workflow').drupalSetSummary(function (context) { diff --git a/core/modules/node/node.es6.js b/core/modules/node/node.es6.js index 45a670241727..23e6cb44158d 100644 --- a/core/modules/node/node.es6.js +++ b/core/modules/node/node.es6.js @@ -17,9 +17,10 @@ const $context = $(context); $context.find('.node-form-author').drupalSetSummary((context) => { - const $authorContext = $(context); - const name = $authorContext.find('.field--name-uid input').val(); - const date = $authorContext.find('.field--name-created input').val(); + const nameElement = context.querySelector('.field--name-uid input'); + const name = nameElement && nameElement.value; + const dateElement = context.querySelector('.field--name-created input'); + const date = dateElement && dateElement.value; if (name && date) { return Drupal.t('By @name on @date', { diff --git a/core/modules/node/node.js b/core/modules/node/node.js index 52e221e9acde..968d6f786972 100644 --- a/core/modules/node/node.js +++ b/core/modules/node/node.js @@ -10,9 +10,10 @@ attach: function attach(context) { var $context = $(context); $context.find('.node-form-author').drupalSetSummary(function (context) { - var $authorContext = $(context); - var name = $authorContext.find('.field--name-uid input').val(); - var date = $authorContext.find('.field--name-created input').val(); + var nameElement = context.querySelector('.field--name-uid input'); + var name = nameElement && nameElement.value; + var dateElement = context.querySelector('.field--name-created input'); + var date = dateElement && dateElement.value; if (name && date) { return Drupal.t('By @name on @date', { diff --git a/core/modules/path/path.es6.js b/core/modules/path/path.es6.js index f54f53b08d64..9d55741b78d9 100644 --- a/core/modules/path/path.es6.js +++ b/core/modules/path/path.es6.js @@ -16,8 +16,10 @@ $(context) .find('.path-form') .drupalSetSummary((context) => { - const path = $('.js-form-item-path-0-alias input').val(); - + const pathElement = document.querySelector( + '.js-form-item-path-0-alias input', + ); + const path = pathElement && pathElement.value; return path ? Drupal.t('Alias: @alias', { '@alias': path }) : Drupal.t('No alias'); diff --git a/core/modules/path/path.js b/core/modules/path/path.js index d7a3ecfdd22e..500fd5cbe95d 100644 --- a/core/modules/path/path.js +++ b/core/modules/path/path.js @@ -9,7 +9,8 @@ Drupal.behaviors.pathDetailsSummaries = { attach: function attach(context) { $(context).find('.path-form').drupalSetSummary(function (context) { - var path = $('.js-form-item-path-0-alias input').val(); + var pathElement = document.querySelector('.js-form-item-path-0-alias input'); + var path = pathElement && pathElement.value; return path ? Drupal.t('Alias: @alias', { '@alias': path }) : Drupal.t('No alias'); diff --git a/core/modules/quickedit/js/views/EditorView.es6.js b/core/modules/quickedit/js/views/EditorView.es6.js index e3ee331e65cc..cb6b5153a35f 100644 --- a/core/modules/quickedit/js/views/EditorView.es6.js +++ b/core/modules/quickedit/js/views/EditorView.es6.js @@ -198,6 +198,7 @@ const $form = $(`#${backstageId}`).find('form'); // Fill in the value in any <input> that isn't hidden or a submit // button. + // eslint-disable-next-line jquery/no-val $form .find(':input[type!="hidden"][type!="submit"]:not(select)') // Don't mess with the node summary. diff --git a/core/modules/system/js/system.date.es6.js b/core/modules/system/js/system.date.es6.js index 8617d4ae1d1e..8412bd07f021 100644 --- a/core/modules/system/js/system.date.es6.js +++ b/core/modules/system/js/system.date.es6.js @@ -42,7 +42,7 @@ * The jQuery event triggered. */ function dateFormatHandler(e) { - const baseValue = $(e.target).val() || ''; + const baseValue = e.target.value || ''; const dateString = baseValue.replace(/\\?(.?)/gi, (key, value) => dateFormats[key] ? dateFormats[key] : value, ); diff --git a/core/modules/system/js/system.date.js b/core/modules/system/js/system.date.js index 7c083f0bc5c2..903986684791 100644 --- a/core/modules/system/js/system.date.js +++ b/core/modules/system/js/system.date.js @@ -20,7 +20,7 @@ var $preview = $target.find('em'); function dateFormatHandler(e) { - var baseValue = $(e.target).val() || ''; + var baseValue = e.target.value || ''; var dateString = baseValue.replace(/\\?(.?)/gi, function (key, value) { return dateFormats[key] ? dateFormats[key] : value; }); diff --git a/core/modules/system/js/system.es6.js b/core/modules/system/js/system.es6.js index 7717d290b563..7bca481c068b 100644 --- a/core/modules/system/js/system.es6.js +++ b/core/modules/system/js/system.es6.js @@ -58,9 +58,9 @@ * Custom value from jQuery trigger. */ valueTargetCopyHandler(e, value) { - const $target = $(e.target); - if ($target.val() === '') { - $target.val(value); + const { target } = e; + if (target.value === '') { + target.value = value; } }, @@ -74,7 +74,7 @@ * The event triggered. */ valueSourceBlurHandler(e) { - const value = $(e.target).val(); + const { value } = e.target; const targetIds = drupalSettings.copyFieldValue[e.target.id]; $(`#${targetIds.join(', #')}`).trigger('value:copy', value); }, diff --git a/core/modules/system/js/system.js b/core/modules/system/js/system.js index a69e362f7c91..e92564b80c9f 100644 --- a/core/modules/system/js/system.js +++ b/core/modules/system/js/system.js @@ -25,14 +25,14 @@ } }, valueTargetCopyHandler: function valueTargetCopyHandler(e, value) { - var $target = $(e.target); + var target = e.target; - if ($target.val() === '') { - $target.val(value); + if (target.value === '') { + target.value = value; } }, valueSourceBlurHandler: function valueSourceBlurHandler(e) { - var value = $(e.target).val(); + var value = e.target.value; var targetIds = drupalSettings.copyFieldValue[e.target.id]; $("#".concat(targetIds.join(', #'))).trigger('value:copy', value); } diff --git a/core/modules/system/js/system.modules.es6.js b/core/modules/system/js/system.modules.es6.js index 98be18f98905..632d9758de4c 100644 --- a/core/modules/system/js/system.modules.es6.js +++ b/core/modules/system/js/system.modules.es6.js @@ -35,7 +35,7 @@ } function filterModuleList(e) { - const query = $(e.target).val(); + const query = e.target.value; // Case insensitive expression to find query at the beginning of a word. const re = new RegExp(`\\b${query}`, 'i'); diff --git a/core/modules/system/js/system.modules.js b/core/modules/system/js/system.modules.js index 6757f8f0f49c..c18c0ca3d359 100644 --- a/core/modules/system/js/system.modules.js +++ b/core/modules/system/js/system.modules.js @@ -41,7 +41,7 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } } function filterModuleList(e) { - var query = $(e.target).val(); + var query = e.target.value; var re = new RegExp("\\b".concat(query), 'i'); function showModuleRow(index, row) { diff --git a/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.es6.js b/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.es6.js index ccd013ae727f..abea6396e250 100644 --- a/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.es6.js +++ b/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.es6.js @@ -3,7 +3,7 @@ * Testing behavior for JSWebAssertTest. */ -(function ($, Drupal, drupalSettings) { +(function (Drupal, drupalSettings) { /** * @type {Drupal~behavior} * @@ -12,9 +12,13 @@ */ Drupal.behaviors.js_webassert_test_wait_for_ajax_request = { attach(context) { - $('input[name="test_assert_wait_on_ajax_input"]').val( - 'js_webassert_test', + const waitAjaxInput = document.querySelector( + 'input[name="test_assert_wait_on_ajax_input"]', ); + // Confirm the input exists before assigning a value to it. + if (waitAjaxInput) { + waitAjaxInput.value = 'js_webassert_test'; + } }, }; -})(jQuery, Drupal, drupalSettings); +})(Drupal, drupalSettings); diff --git a/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.js b/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.js index 3413846dbf7d..7e65949bcb4c 100644 --- a/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.js +++ b/core/modules/system/tests/modules/js_webassert_test/js/js_webassert_test.wait_for_ajax_request.js @@ -5,10 +5,14 @@ * @preserve **/ -(function ($, Drupal, drupalSettings) { +(function (Drupal, drupalSettings) { Drupal.behaviors.js_webassert_test_wait_for_ajax_request = { attach: function attach(context) { - $('input[name="test_assert_wait_on_ajax_input"]').val('js_webassert_test'); + var waitAjaxInput = document.querySelector('input[name="test_assert_wait_on_ajax_input"]'); + + if (waitAjaxInput) { + waitAjaxInput.value = 'js_webassert_test'; + } } }; -})(jQuery, Drupal, drupalSettings); \ No newline at end of file +})(Drupal, drupalSettings); \ No newline at end of file diff --git a/core/modules/system/tests/modules/js_webassert_test/js_webassert_test.libraries.yml b/core/modules/system/tests/modules/js_webassert_test/js_webassert_test.libraries.yml index 898e6375078a..e7ec966a1625 100644 --- a/core/modules/system/tests/modules/js_webassert_test/js_webassert_test.libraries.yml +++ b/core/modules/system/tests/modules/js_webassert_test/js_webassert_test.libraries.yml @@ -3,7 +3,6 @@ wait_for_ajax_request: js: js/js_webassert_test.wait_for_ajax_request.js: {} dependencies: - - core/jquery - core/drupal wait_for_element: version: VERSION diff --git a/core/modules/text/text.es6.js b/core/modules/text/text.es6.js index 0dfc7f0f4bb4..c584f2dbd132 100644 --- a/core/modules/text/text.es6.js +++ b/core/modules/text/text.es6.js @@ -64,7 +64,7 @@ .appendTo($summaryLabel); // If no summary is set, hide the summary field. - if ($widget.find('.js-text-summary').val() === '') { + if (summary.value === '') { $link.trigger('click'); } }); diff --git a/core/modules/text/text.js b/core/modules/text/text.js index d45bb736b0e2..8b8074cb5487 100644 --- a/core/modules/text/text.js +++ b/core/modules/text/text.js @@ -44,7 +44,7 @@ toggleClick = !toggleClick; }).appendTo($summaryLabel); - if ($widget.find('.js-text-summary').val() === '') { + if (summary.value === '') { $link.trigger('click'); } }); diff --git a/core/modules/toolbar/js/views/ToolbarVisualView.es6.js b/core/modules/toolbar/js/views/ToolbarVisualView.es6.js index c6afbdc0eb27..6f514edfa5d0 100644 --- a/core/modules/toolbar/js/views/ToolbarVisualView.es6.js +++ b/core/modules/toolbar/js/views/ToolbarVisualView.es6.js @@ -287,9 +287,9 @@ const $orientationToggle = this.$el .find('.toolbar-toggle-orientation') .toggle(this.model.get('isTrayToggleVisible')); - $orientationToggle - .find('button') - .val(antiOrientation) + const $orientationToggleButton = $orientationToggle.find('button'); + $orientationToggleButton[0].value = antiOrientation; + $orientationToggleButton .attr('title', this.strings[antiOrientation]) .text(this.strings[antiOrientation]) .removeClass(iconClass) diff --git a/core/modules/toolbar/js/views/ToolbarVisualView.js b/core/modules/toolbar/js/views/ToolbarVisualView.js index 3d65693ca84b..3a82ab710747 100644 --- a/core/modules/toolbar/js/views/ToolbarVisualView.js +++ b/core/modules/toolbar/js/views/ToolbarVisualView.js @@ -135,7 +135,9 @@ var iconClass = "toolbar-icon-toggle-".concat(orientation); var iconAntiClass = "toolbar-icon-toggle-".concat(antiOrientation); var $orientationToggle = this.$el.find('.toolbar-toggle-orientation').toggle(this.model.get('isTrayToggleVisible')); - $orientationToggle.find('button').val(antiOrientation).attr('title', this.strings[antiOrientation]).text(this.strings[antiOrientation]).removeClass(iconClass).addClass(iconAntiClass); + var $orientationToggleButton = $orientationToggle.find('button'); + $orientationToggleButton[0].value = antiOrientation; + $orientationToggleButton.attr('title', this.strings[antiOrientation]).text(this.strings[antiOrientation]).removeClass(iconClass).addClass(iconAntiClass); var dir = document.documentElement.dir; var edge = dir === 'rtl' ? 'right' : 'left'; $trays.removeAttr('data-offset-left data-offset-right data-offset-top'); diff --git a/core/modules/user/user.es6.js b/core/modules/user/user.es6.js index 0b6a6c966aa0..cc8169b44d95 100644 --- a/core/modules/user/user.es6.js +++ b/core/modules/user/user.es6.js @@ -169,12 +169,12 @@ const addWidgetClasses = () => { $passwordWidget .addClass( - $mainInput.val() + $mainInput[0].value ? cssClasses.passwordFilled : cssClasses.passwordEmpty, ) .addClass( - $confirmInput.val() + $confirmInput[0].value ? cssClasses.confirmFilled : cssClasses.confirmEmpty, ); @@ -187,7 +187,7 @@ * The value of the confirm input. */ const passwordCheckMatch = (confirmInputVal) => { - const passwordsAreMatching = $mainInput.val() === confirmInputVal; + const passwordsAreMatching = $mainInput[0].value === confirmInputVal; const confirmClass = passwordsAreMatching ? cssClasses.passwordsMatch : cssClasses.passwordsNotMatch; @@ -216,7 +216,7 @@ if (settings.password.showStrengthIndicator) { // Evaluate the password strength. const result = Drupal.evaluatePasswordStrength( - $mainInput.val(), + $mainInput[0].value, settings.password, ); const $currentPasswordSuggestions = $( @@ -255,8 +255,8 @@ } // Check the value in the confirm input and show results. - if ($confirmInput.val()) { - passwordCheckMatch($confirmInput.val()); + if ($confirmInput[0].value) { + passwordCheckMatch($confirmInput[0].value); $passwordConfirmMessage.css({ visibility: 'visible' }); } else { $passwordConfirmMessage.css({ visibility: 'hidden' }); @@ -310,7 +310,9 @@ // otherwise use value from the database. const $usernameBox = $('input.username'); const username = - $usernameBox.length > 0 ? $usernameBox.val() : passwordSettings.username; + $usernameBox.length > 0 + ? $usernameBox[0].value + : passwordSettings.username; // Lose 5 points for every character less than 12, plus a 30 point penalty. if (password.length < 12) { diff --git a/core/modules/user/user.js b/core/modules/user/user.js index 5e55522cf0a5..659db32c215e 100644 --- a/core/modules/user/user.js +++ b/core/modules/user/user.js @@ -75,11 +75,11 @@ } var addWidgetClasses = function addWidgetClasses() { - $passwordWidget.addClass($mainInput.val() ? cssClasses.passwordFilled : cssClasses.passwordEmpty).addClass($confirmInput.val() ? cssClasses.confirmFilled : cssClasses.confirmEmpty); + $passwordWidget.addClass($mainInput[0].value ? cssClasses.passwordFilled : cssClasses.passwordEmpty).addClass($confirmInput[0].value ? cssClasses.confirmFilled : cssClasses.confirmEmpty); }; var passwordCheckMatch = function passwordCheckMatch(confirmInputVal) { - var passwordsAreMatching = $mainInput.val() === confirmInputVal; + var passwordsAreMatching = $mainInput[0].value === confirmInputVal; var confirmClass = passwordsAreMatching ? cssClasses.passwordsMatch : cssClasses.passwordsNotMatch; var confirmMessage = passwordsAreMatching ? settings.password.confirmSuccess : settings.password.confirmFailure; @@ -94,7 +94,7 @@ var passwordCheck = function passwordCheck() { if (settings.password.showStrengthIndicator) { - var result = Drupal.evaluatePasswordStrength($mainInput.val(), settings.password); + var result = Drupal.evaluatePasswordStrength($mainInput[0].value, settings.password); var $currentPasswordSuggestions = $(Drupal.theme('passwordSuggestions', settings.password, result.messageTips)); if (password.$suggestions.html() !== $currentPasswordSuggestions.html()) { @@ -110,8 +110,8 @@ password.$strengthTextWrapper.html(result.indicatorText); } - if ($confirmInput.val()) { - passwordCheckMatch($confirmInput.val()); + if ($confirmInput[0].value) { + passwordCheckMatch($confirmInput[0].value); $passwordConfirmMessage.css({ visibility: 'visible' }); @@ -149,7 +149,7 @@ var hasNumbers = /[0-9]/.test(password); var hasPunctuation = /[^a-zA-Z0-9]/.test(password); var $usernameBox = $('input.username'); - var username = $usernameBox.length > 0 ? $usernameBox.val() : passwordSettings.username; + var username = $usernameBox.length > 0 ? $usernameBox[0].value : passwordSettings.username; if (password.length < 12) { msg.push(passwordSettings.tooShort); diff --git a/core/modules/views_ui/js/ajax.es6.js b/core/modules/views_ui/js/ajax.es6.js index 560353769504..e98be85b8173 100644 --- a/core/modules/views_ui/js/ajax.es6.js +++ b/core/modules/views_ui/js/ajax.es6.js @@ -194,8 +194,13 @@ const href = $(this).attr('href'); // Cut of #views-tabset. const displayId = href.substr(11); - // Set the form element. - $('#views-live-preview #preview-display-id').val(displayId); + const viewsPreviewId = document.querySelector( + '#views-live-preview #preview-display-id', + ); + if (viewsPreviewId) { + // Set the form element if it is present. + viewsPreviewId.value = displayId; + } }); }, }; diff --git a/core/modules/views_ui/js/ajax.js b/core/modules/views_ui/js/ajax.js index 8de29e682023..fc1bd223b595 100644 --- a/core/modules/views_ui/js/ajax.js +++ b/core/modules/views_ui/js/ajax.js @@ -71,7 +71,11 @@ $(once('views-ajax', '#views-tabset a')).on('click', function () { var href = $(this).attr('href'); var displayId = href.substr(11); - $('#views-live-preview #preview-display-id').val(displayId); + var viewsPreviewId = document.querySelector('#views-live-preview #preview-display-id'); + + if (viewsPreviewId) { + viewsPreviewId.value = displayId; + } }); } }; diff --git a/core/modules/views_ui/js/views-admin.es6.js b/core/modules/views_ui/js/views-admin.es6.js index f91f29e8d9ba..b29af12a4123 100644 --- a/core/modules/views_ui/js/views-admin.es6.js +++ b/core/modules/views_ui/js/views-admin.es6.js @@ -207,7 +207,7 @@ * The source form field value. */ getTransliterated() { - let from = this.source.val(); + let from = this.source.length ? this.source[0].value : ''; if (this.exclude) { from = from.toLowerCase().replace(this.exclude, this.replace); } @@ -223,7 +223,7 @@ this.target.each(function (i) { // Ensure that the maxlength is not exceeded by prepopulating the field. const maxlength = $(this).attr('maxlength') - suffix.length; - $(this).val(transliterated.substr(0, maxlength) + suffix); + this.value = transliterated.substr(0, maxlength) + suffix; }); }, @@ -390,9 +390,9 @@ // placed in an 'Add' dropdown. @todo This assumes English, but so does // $addDisplayDropdown above. Add support for translation. $displayButtons.each(function () { - const label = $(this).val(); + const label = this.value; if (label.substr(0, 4) === 'Add ') { - $(this).val(label.substr(4)); + this.value = label.substr(4); } }); $addDisplayDropdown.appendTo($menu); @@ -559,10 +559,10 @@ handleFilter(event) { // Determine the user's search query. The search text has been converted // to lowercase. - const search = this.$searchBox.val().toLowerCase(); + const search = this.$searchBox[0].value.toLowerCase(); const words = search.split(' '); // Get selected Group - const group = this.$controlGroup.val(); + const group = this.$controlGroup[0].value; // Search through the search texts in the form for matching text. this.options.forEach((option) => { @@ -753,7 +753,7 @@ // When the link is clicked, dynamically click the hidden form // button for adding a new filter group. $( - `<ul class="action-links"><li><a id="views-add-group-link" href="#">${this.addGroupButton.val()}</a></li></ul>`, + `<ul class="action-links"><li><a id="views-add-group-link" href="#">${this.addGroupButton[0].value}</a></li></ul>`, ).prependTo(this.table.parent()), ), ) @@ -896,7 +896,9 @@ const operators = this.dropdowns.find('select').not($target); // Change the other operators to match this new value. - operators.val($target.val()); + operators.each(function (index, item) { + item.value = $target[0].value; + }); }, /** @@ -984,7 +986,7 @@ groupField .removeClass(`views-group-select-${oldGroupName}`) .addClass(`views-group-select-${groupName}`); - groupField.val(groupName); + groupField[0].value = groupName; } }; }, @@ -1236,26 +1238,28 @@ ).forEach((dropdown) => { // Closures! :( const $context = $(context); - const $submit = $context.find('[id^=edit-submit]'); - const oldValue = $submit.val(); + const submit = context.querySelector('[id^=edit-submit]'); + const oldValue = submit ? submit.value : ''; - $(once('views-ui-override-button-text', $submit)).on( + $(once('views-ui-override-button-text', submit)).on( 'mouseup', function () { - $(this).val(oldValue); + this.value = oldValue; return true; }, ); $(dropdown) .on('change', function () { - const $this = $(this); - if ($this.val() === 'default') { - $submit.val(Drupal.t('Apply (all displays)')); - } else if ($this.val() === 'default_revert') { - $submit.val(Drupal.t('Revert to default')); + if (!submit) { + return; + } + if (this.value === 'default') { + submit.value = Drupal.t('Apply (all displays)'); + } else if (this.value === 'default_revert') { + submit.value = Drupal.t('Revert to default'); } else { - $submit.val(Drupal.t('Apply (this display)')); + submit.value = Drupal.t('Apply (this display)'); } const $dialog = $context.closest('.ui-dialog-content'); $dialog.trigger('dialogButtonsChange'); diff --git a/core/modules/views_ui/js/views-admin.js b/core/modules/views_ui/js/views-admin.js index ef21d748a0ff..c8514bde5023 100644 --- a/core/modules/views_ui/js/views-admin.js +++ b/core/modules/views_ui/js/views-admin.js @@ -79,7 +79,7 @@ this.target.on('focus.viewsUi', this.unbind); }, getTransliterated: function getTransliterated() { - var from = this.source.val(); + var from = this.source.length ? this.source[0].value : ''; if (this.exclude) { from = from.toLowerCase().replace(this.exclude, this.replace); @@ -92,7 +92,7 @@ var suffix = this.suffix; this.target.each(function (i) { var maxlength = $(this).attr('maxlength') - suffix.length; - $(this).val(transliterated.substr(0, maxlength) + suffix); + this.value = transliterated.substr(0, maxlength) + suffix; }); }, _unbind: function _unbind() { @@ -170,10 +170,10 @@ var $displayButtons = $menu.nextAll('input.add-display').detach(); $displayButtons.appendTo($addDisplayDropdown.find('.action-list')).wrap('<li>').parent().eq(0).addClass('first').end().eq(-1).addClass('last'); $displayButtons.each(function () { - var label = $(this).val(); + var label = this.value; if (label.substr(0, 4) === 'Add ') { - $(this).val(label.substr(4)); + this.value = label.substr(4); } }); $addDisplayDropdown.appendTo($menu); @@ -253,9 +253,9 @@ return options; }, handleFilter: function handleFilter(event) { - var search = this.$searchBox.val().toLowerCase(); + var search = this.$searchBox[0].value.toLowerCase(); var words = search.split(' '); - var group = this.$controlGroup.val(); + var group = this.$controlGroup[0].value; this.options.forEach(function (option) { function hasWord(word) { return option.searchText.indexOf(word) !== -1; @@ -320,7 +320,7 @@ $.extend(Drupal.viewsUi.RearrangeFilterHandler.prototype, { insertAddRemoveFilterGroupLinks: function insertAddRemoveFilterGroupLinks() { - $(once('views-rearrange-filter-handler', $("<ul class=\"action-links\"><li><a id=\"views-add-group-link\" href=\"#\">".concat(this.addGroupButton.val(), "</a></li></ul>")).prependTo(this.table.parent()))).find('#views-add-group-link').on('click.views-rearrange-filter-handler', $.proxy(this, 'clickAddGroupButton')); + $(once('views-rearrange-filter-handler', $("<ul class=\"action-links\"><li><a id=\"views-add-group-link\" href=\"#\">".concat(this.addGroupButton[0].value, "</a></li></ul>")).prependTo(this.table.parent()))).find('#views-add-group-link').on('click.views-rearrange-filter-handler', $.proxy(this, 'clickAddGroupButton')); var length = this.removeGroupButtons.length; var i; @@ -380,7 +380,9 @@ operatorChangeHandler: function operatorChangeHandler(event) { var $target = $(event.target); var operators = this.dropdowns.find('select').not($target); - operators.val($target.val()); + operators.each(function (index, item) { + item.value = $target[0].value; + }); }, modifyTableDrag: function modifyTableDrag() { var tableDrag = Drupal.tableDrag['views-rearrange-filters']; @@ -423,7 +425,7 @@ if (!groupField.is(".views-group-select-".concat(groupName))) { var oldGroupName = groupField.attr('class').replace(/([^ ]+[ ]+)*views-group-select-([^ ]+)([ ]+[^ ]+)*/, '$2'); groupField.removeClass("views-group-select-".concat(oldGroupName)).addClass("views-group-select-".concat(groupName)); - groupField.val(groupName); + groupField[0].value = groupName; } }; }, @@ -544,21 +546,23 @@ attach: function attach(context) { once('views-ui-override-button-text', '[data-drupal-selector="edit-override-dropdown"]', context).forEach(function (dropdown) { var $context = $(context); - var $submit = $context.find('[id^=edit-submit]'); - var oldValue = $submit.val(); - $(once('views-ui-override-button-text', $submit)).on('mouseup', function () { - $(this).val(oldValue); + var submit = context.querySelector('[id^=edit-submit]'); + var oldValue = submit ? submit.value : ''; + $(once('views-ui-override-button-text', submit)).on('mouseup', function () { + this.value = oldValue; return true; }); $(dropdown).on('change', function () { - var $this = $(this); + if (!submit) { + return; + } - if ($this.val() === 'default') { - $submit.val(Drupal.t('Apply (all displays)')); - } else if ($this.val() === 'default_revert') { - $submit.val(Drupal.t('Revert to default')); + if (this.value === 'default') { + submit.value = Drupal.t('Apply (all displays)'); + } else if (this.value === 'default_revert') { + submit.value = Drupal.t('Revert to default'); } else { - $submit.val(Drupal.t('Apply (this display)')); + submit.value = Drupal.t('Apply (this display)'); } var $dialog = $context.closest('.ui-dialog-content'); diff --git a/core/modules/views_ui/js/views_ui.listing.es6.js b/core/modules/views_ui/js/views_ui.listing.es6.js index a3ba5604e38e..8a9f3195e544 100644 --- a/core/modules/views_ui/js/views_ui.listing.es6.js +++ b/core/modules/views_ui/js/views_ui.listing.es6.js @@ -26,7 +26,7 @@ let $rows; function filterViewList(e) { - const query = $(e.target).val().toLowerCase(); + const query = e.target.value.toLowerCase(); function showViewRow(index, row) { const $row = $(row); diff --git a/core/modules/views_ui/js/views_ui.listing.js b/core/modules/views_ui/js/views_ui.listing.js index d5e848d84eb2..2f2a4181b81b 100644 --- a/core/modules/views_ui/js/views_ui.listing.js +++ b/core/modules/views_ui/js/views_ui.listing.js @@ -32,7 +32,7 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } var $rows; function filterViewList(e) { - var query = $(e.target).val().toLowerCase(); + var query = e.target.value.toLowerCase(); function showViewRow(index, row) { var $row = $(row); diff --git a/core/themes/bartik/color/preview.es6.js b/core/themes/bartik/color/preview.es6.js index 7f91f8fad1b6..914493d7484f 100644 --- a/core/themes/bartik/color/preview.es6.js +++ b/core/themes/bartik/color/preview.es6.js @@ -25,16 +25,22 @@ // Solid background. $colorPreview.css( 'backgroundColor', - $colorPalette.find('input[name="palette[bg]"]').val(), + $colorPalette.find('input[name="palette[bg]"]')[0].value, ); // Text preview. $colorPreview .find('.color-preview-main h2, .color-preview .preview-content') - .css('color', $colorPalette.find('input[name="palette[text]"]').val()); + .css( + 'color', + $colorPalette.find('input[name="palette[text]"]')[0].value, + ); $colorPreview .find('.color-preview-content a') - .css('color', $colorPalette.find('input[name="palette[link]"]').val()); + .css( + 'color', + $colorPalette.find('input[name="palette[link]"]')[0].value, + ); // Sidebar block. const $colorPreviewBlock = $colorPreview.find( @@ -42,11 +48,11 @@ ); $colorPreviewBlock.css( 'background-color', - $colorPalette.find('input[name="palette[sidebar]"]').val(), + $colorPalette.find('input[name="palette[sidebar]"]')[0].value, ); $colorPreviewBlock.css( 'border-color', - $colorPalette.find('input[name="palette[sidebarborders]"]').val(), + $colorPalette.find('input[name="palette[sidebarborders]"]')[0].value, ); // Footer wrapper background. @@ -54,16 +60,14 @@ .find('.color-preview-footer-wrapper') .css( 'background-color', - $colorPalette.find('input[name="palette[footer]"]').val(), + $colorPalette.find('input[name="palette[footer]"]')[0].value, ); // CSS3 Gradients. - const gradientStart = $colorPalette - .find('input[name="palette[top]"]') - .val(); - const gradientEnd = $colorPalette - .find('input[name="palette[bottom]"]') - .val(); + const gradientStart = $colorPalette.find('input[name="palette[top]"]')[0] + .value; + const gradientEnd = $colorPalette.find('input[name="palette[bottom]"]')[0] + .value; $colorPreview .find('.color-preview-header') @@ -76,7 +80,7 @@ .find('.color-preview-site-name') .css( 'color', - $colorPalette.find('input[name="palette[titleslogan]"]').val(), + $colorPalette.find('input[name="palette[titleslogan]"]')[0].value, ); }, }; diff --git a/core/themes/bartik/color/preview.js b/core/themes/bartik/color/preview.js index daf0d9e474b7..e626e7d8e8a3 100644 --- a/core/themes/bartik/color/preview.js +++ b/core/themes/bartik/color/preview.js @@ -20,17 +20,17 @@ var $colorPreview = $form.find('.color-preview'); var $colorPalette = $form.find('.js-color-palette'); - $colorPreview.css('backgroundColor', $colorPalette.find('input[name="palette[bg]"]').val()); - $colorPreview.find('.color-preview-main h2, .color-preview .preview-content').css('color', $colorPalette.find('input[name="palette[text]"]').val()); - $colorPreview.find('.color-preview-content a').css('color', $colorPalette.find('input[name="palette[link]"]').val()); + $colorPreview.css('backgroundColor', $colorPalette.find('input[name="palette[bg]"]')[0].value); + $colorPreview.find('.color-preview-main h2, .color-preview .preview-content').css('color', $colorPalette.find('input[name="palette[text]"]')[0].value); + $colorPreview.find('.color-preview-content a').css('color', $colorPalette.find('input[name="palette[link]"]')[0].value); var $colorPreviewBlock = $colorPreview.find('.color-preview-sidebar .color-preview-block'); - $colorPreviewBlock.css('background-color', $colorPalette.find('input[name="palette[sidebar]"]').val()); - $colorPreviewBlock.css('border-color', $colorPalette.find('input[name="palette[sidebarborders]"]').val()); - $colorPreview.find('.color-preview-footer-wrapper').css('background-color', $colorPalette.find('input[name="palette[footer]"]').val()); - var gradientStart = $colorPalette.find('input[name="palette[top]"]').val(); - var gradientEnd = $colorPalette.find('input[name="palette[bottom]"]').val(); + $colorPreviewBlock.css('background-color', $colorPalette.find('input[name="palette[sidebar]"]')[0].value); + $colorPreviewBlock.css('border-color', $colorPalette.find('input[name="palette[sidebarborders]"]')[0].value); + $colorPreview.find('.color-preview-footer-wrapper').css('background-color', $colorPalette.find('input[name="palette[footer]"]')[0].value); + var gradientStart = $colorPalette.find('input[name="palette[top]"]')[0].value; + var gradientEnd = $colorPalette.find('input[name="palette[bottom]"]')[0].value; $colorPreview.find('.color-preview-header').attr('style', "background-color: ".concat(gradientStart, "; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(").concat(gradientStart, "), to(").concat(gradientEnd, ")); background-image: -moz-linear-gradient(-90deg, ").concat(gradientStart, ", ").concat(gradientEnd, ");")); - $colorPreview.find('.color-preview-site-name').css('color', $colorPalette.find('input[name="palette[titleslogan]"]').val()); + $colorPreview.find('.color-preview-site-name').css('color', $colorPalette.find('input[name="palette[titleslogan]"]')[0].value); } }; })(jQuery, Drupal, drupalSettings); \ No newline at end of file diff --git a/core/themes/claro/js/vertical-tabs.es6.js b/core/themes/claro/js/vertical-tabs.es6.js index 32e7591780d3..28758071d26e 100644 --- a/core/themes/claro/js/vertical-tabs.es6.js +++ b/core/themes/claro/js/vertical-tabs.es6.js @@ -104,7 +104,8 @@ once('vertical-tabs', '[data-vertical-tabs-panes]', context).forEach( (panes) => { const $this = $(panes).addClass('vertical-tabs__items--processed'); - const focusID = $this.find(':hidden.vertical-tabs__active-tab').val(); + const focusID = $this.find(':hidden.vertical-tabs__active-tab')[0] + .value; let tabFocus; // Check if there are some details that can be converted to diff --git a/core/themes/claro/js/vertical-tabs.js b/core/themes/claro/js/vertical-tabs.js index c0e55dfacca7..5daa42bf30f9 100644 --- a/core/themes/claro/js/vertical-tabs.js +++ b/core/themes/claro/js/vertical-tabs.js @@ -17,7 +17,7 @@ $(once('vertical-tabs-fragments', 'body')).on('formFragmentLinkClickOrHashChange.verticalTabs', handleFragmentLinkClickOrHashChange); once('vertical-tabs', '[data-vertical-tabs-panes]', context).forEach(function (panes) { var $this = $(panes).addClass('vertical-tabs__items--processed'); - var focusID = $this.find(':hidden.vertical-tabs__active-tab').val(); + var focusID = $this.find(':hidden.vertical-tabs__active-tab')[0].value; var tabFocus; var $details = $this.find('> details'); -- GitLab