Library order asset weights do not work properly when a large number of javascript files is loaded between two jQuery UI libraries

Created on 5 July 2021, over 3 years ago
Updated 30 September 2023, over 1 year ago

Problem/Motivation

Following the #3113400: Deprecate more jQuery UI library definitions update, this was discovered as the order of jQuery UI assets could change depending on whether there is a sufficiently large library loaded between two jQuery UI dependent libraries, which exposed an underlying problem with how asset weights are interpreted.

The bug is a side-effect of using non-integer weights for assets in libraries.

In particular, this AssetResolver::getJsAssets() logic:

$options['weight'] += count($javascript) / 1000;

Based on @jmickela's findings :

The javascript array is an array of files currently staged to be included, and grows by one with every iteration though the array of libraries. If all the weights were integers this wouldn't have an impact on the loading order, but the weights in the jQuery UI library use decimals now.

If two files are processed far enough apart from each other in the array, but have weights very close to each other, this change is enough to change the order they get loaded.

Widget's weight starts at -11.8, and Controlgroup at -11.7, if there's exactly 100 files in the array between them then they'll end up with the same weight, if there's 101 files then Controlgroup will get loaded before widget. I just checked an on the page I was testing on, I'm getting around 200 individual files.

Note that while this issue was discovered with JS assets, it also occurs with CSS assets, and the test coverage in this issue demonstrates that.

Steps to reproduce

Use a render array similar to:

[
  '#attached' => [
    'library' => [
      'core/drupal.dialog',
      // This library contains at least 100 javascript entries.
      'jqueryui_library_assets_test/many-dependencies',
      'core/drupal.autocomplete',
    ],
  ],
];

Proposed resolution

TBD.

The alternative is to try and revisit the AssetResolver logic and see if it can be made more deterministic without introducing its own subtle bugs e.g. changing the divisor from 1000 to 3000 or higher.

Remaining tasks

Provide an issue fork/patch.

User interface changes

None

API changes

TBD

Release notes snippet

TBD

Workaround:

Disable JavaScript aggregation at /admin/config/development/performance

🐛 Bug report
Status

Fixed

Version

9.5

Component
Asset library 

Last updated 1 day ago

No maintainer
Created by

Live updates comments and jobs are added and updated live.
  • JavaScript

    Affects the content, performance, or handling of Javascript.

Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇧🇪Belgium redseujac

    jrockowitz wrote in #36:

    The latest dev release of the Webform module is running into this issue via translations.

    The issue with CKEditor vs CSS/JS aggregation is NOT fixed in the most recent 6.2.x-dev version.

    Notice this issue has nothing to do with translations, but with incompatibility of CKeditor and CSS/JS aggregation. If aggregation is disabled, you can write text in the textboxes with CKeditor, otherwise you cannot, because there are JS errors blocking CKEditor from working as expected.

    For the errors see #20 @: 🐛 Issues with CKEditor 5, tokens, translations Closed: outdated

    This seems a major issue.

  • 🇦🇹Austria maxilein

    It is a major issue. But the symtoms can differ from site to site depending on which css or js files you load... also in which order they are loaded.
    Having said that: they can cause ALL kinds off issues!
    The difficulty of diagnising this as the problem for any random js or css issue makes it a major issue in my opinion.
    Since it is hard to get from a strange error to this issue ...

    As a workaround until this is fixed: I am using #11 but I am dividing by 7000. Rarely had an issue.

  • 🇺🇸United States bnjmnm Ann Arbor, MI

    The offer in #12 (and the MR comment above it) still stands. Move the tests to not depend on jQuery UI assets, and it's ready for RTBC. Making that requested change will also address the test that is failing on the more recent patches/MRs. That's one of the scenarios I wanted to prevent with that request.

    Here's what I said further up and it still stands:

    I'm concerned about the tests for this fix being integrated into jQuery UI tests. aIt's very possible jQuery UI will be removed before the fixes in this issue are replaced by https://www.drupal.org/project/drupal/issues/1945262 📌 Replace custom weights with dependencies in library declarations; introduce "before" and "after" for conditional ordering Needs work . Since this fix benefits users well beyond those using, jQuery UI, I'd like to be sure the tests aren't accidentally removed with jQuery UI. (even if it means adding tests that are VERY similar to the jQuery UI ones)

    Mentioned in the MR, but I think this is pretty close to RTBC, but I'd like the test coverage for this to not be dependent on jQuery UI since that has an expiration date likely happening before this fix is no longer needed. To be safe, there should probably be a new test-only patch with the refactored tests, while the MR can be the tests+fix.

    Feel free to ping me on Drupal Slack when the test is refactored and I'll re-review, I'll be happy to see this one land.

    Just refactor that test and I think this is good to go.

  • 🇦🇹Austria maxilein

    I agree. to #41
    This is not jQuery specific.

  • 🇩🇪Germany Anybody Porta Westfalica

    Just ran into this with layout_paragraphs on Drupal 9.5.3. Shouldn't we mark this "Critical"?

  • 🇩🇪Germany Anybody Porta Westfalica

    Added

    <h3>Workaround:</h3>
    Disable JavaScript aggregation at <code>/admin/config/development/performance

    to the issue summary.

  • 🇧🇪Belgium gwenweb

    #31 3222107-2.patch worked fine for me.

    Found this issue after having seen this kind of errors in the backoffice page console :

    t / i / e .widget is not a function
    i is not a constructor
    Cannot set properties of undefined (setting 'formResetMixin") / (reading 'mouse)
    $element.dialog is not a function

    with a website using advagg, entity_browser and field_group

  • 🇦🇹Austria maxilein

    Maybe we should rename this issue in order to make it more easily findable for people.
    e.g.
    "Large number of javascript files may cause multiple random script errors due to loading order of js files"

  • 🇫🇷France benjbmc

    The patch #31 works for me too, thanks! I had an error using the ebt_slick_slider module when adding media to the custom block: Uncaught TypeError: $element.dialog is not a function

  • 🇩🇪Germany Anybody Porta Westfalica

    We're running into this issue on several projects again and again in the last weeks with different results / error messages. I'm wondering why this didn't pop up earlier? Have there been related changes in recent core releases?

    At the current state, I think it's important to find a solution here, should we perhaps increase the priority to critical?

    In #10 @larowlan wrote

    When we get to D10, and drop IE support, can we solve this with ES module imports and let the browser sort it out 😈?

    Is that possible? Then we could at least look forward to a solution in 10.1.x (and should target that?!)

  • 🇦🇹Austria agoradesign

    patch #31 works for us as well - had problems on taxonomy term edit pages after switching to ckeditor5

  • 🇭🇺Hungary czigor

    On my node form I have a CKeditor textarea field, a plain file field and a media field with media library widget.

    Due to the broken js the files uploaded to the plain file field are not set to permanent which causes them to be deleted after 6 hours.

  • 🇮🇹Italy finex

    Hi, patch #31 works on my case: before the patch non admin users were not able to open the media library widget and other dialogs (when ckeditor5 was enabled). Thank you.

  • 🇬🇧United Kingdom catch

    Both the patch in #31 and the MR are failing tests. The next step here would be to try to fix that test failure. Agreed this should be critical.

  • 🇬🇧United Kingdom catch

    Given that's a legacy test, just re-doing the MR against 10.1.x might be enough.

  • Status changed to Needs review almost 2 years ago
  • 🇺🇸United States bnjmnm Ann Arbor, MI

    Created tests that aren't dependent on jQuery UI. Those tests also exposed that the same problem exists with CSS, so a fix was provided for that as well.

  • 🇺🇸United States bnjmnm Ann Arbor, MI

    Updated IS to make it clear jQuery UI was where it was discovered, but the issue is not specific to it.

  • Status changed to RTBC almost 2 years ago
  • 🇺🇸United States smustgrave

    I need to give complete kudos for the tests.

    #54 shows this covers the problem for js/css

    So the actual change looks good to me and matches the proposed solution from the summary.

  • Status changed to Needs work almost 2 years ago
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    It pains me to put this back to needs work on the tests only, because its a long-standing critical - but I think we can improve the test in a few ways, and at least one of those changes (asserting a count) feels blocking

    1. +++ b/core/tests/Drupal/FunctionalTests/Libraries/ManyAssetsLoadOrderTest.php
      @@ -0,0 +1,69 @@
      +  public function testLoadOrder() {
      

      If we're touching this, could we add a docblock here (if not can be fixed on commit)

    2. +++ b/core/tests/Drupal/FunctionalTests/Libraries/ManyAssetsLoadOrderTest.php
      @@ -0,0 +1,69 @@
      +      if (str_contains($src, 'weighted_')) {
      +        // The test file filenames have numbers that match their loading weight,
      +        // extract just that number so we can use that to check file loading
      +        // order.
      ...
      +      if (str_contains($src, 'weighted_')) {
      +        // The test file filenames have numbers that match their loading weight,
      +        // extract just that number so we can use that to check file loading
      +        // order.
      

      Library entries support attributes, would it be simpler to add a data-weight attribute in the definitions and then we can use findAll('css', 'script[data-weight]') and similar for links.

      So that would remove the need for:
      * the array_filter
      * the explode, str_contains, substr, strpos

      I think it would make the test easier to read/understand.

    3. +++ b/core/tests/Drupal/FunctionalTests/Libraries/ManyAssetsLoadOrderTest.php
      @@ -0,0 +1,69 @@
      +    $this->assertSame(array_filter($js_files_sorted), array_filter($js_files));
      ...
      +    $this->assertSame(array_filter($css_files_sorted), array_filter($css_files));
      

      Let's assert the count of files here, if both are empty, this will still pass (Same for the css).

      We can probably use ::assertGreaterThan(0, count($js_files))

      So its not a hard-coded number that is subject to fluctuation and therefore more expensive to maintain.

  • Status changed to Needs review almost 2 years ago
  • 🇺🇸United States bnjmnm Ann Arbor, MI

    Addresses all the points in #59, great suggestions.

  • Status changed to RTBC almost 2 years ago
  • 🇺🇸United States smustgrave

    Reviewing the interdiff and looks as all points have addressed from #59

    Neat trick with the data-weight.

  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Updated issue credits

    • larowlan committed 001d5ab5 on 10.1.x
      Issue #3222107 by codebymikey, bnjmnm, chandu7929, Shubham Chandra,...
  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Committed to 10.1.x

    Moving back to 10.0.x for backport once we have a green test-run.

  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    Backported in 10.0.x, needs re-work for 9.5.x because of the .es6.js files 😭 - going to be a lot of them, all empty

  • Status changed to Downport almost 2 years ago
    • larowlan committed 8a0be0e2 on 10.0.x
      Issue #3222107 by codebymikey, bnjmnm, chandu7929, Shubham Chandra,...
  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺
    +++ b/core/lib/Drupal/Core/Asset/AssetResolver.php
    @@ -259,7 +259,7 @@ public function getJsAssets(AttachedAssetsInterface $assets, $optimize, Language
    -            $options['weight'] += count($javascript) / 1000;
    +            $options['weight'] += count($javascript) / 30000;
    

    So was the actual root cause for the problem the division by 1000? i.e. that there was not enough precision?

    In any case: superb work, @bnjmnm! 👏 Plus, this helps make 📌 Replace custom weights with dependencies in library declarations; introduce "before" and "after" for conditional ordering Needs work more feasible, by having better test coverage for our decades old weight-based system before we transition to something better! 🥳

  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update almost 2 years ago
    30,293 pass, 1 fail
  • 🇷🇺Russia Wiktor7
    +++ b/core/lib/Drupal/Core/Asset/AssetResolver.php
    @@ -259,7 +259,7 @@ public function getJsAssets(AttachedAssetsInterface $assets, $optimize, Language
    -            $options['weight'] += count($javascript) / 1000;
    +            $options['weight'] += count($javascript) / 30000;

    Hello, this works in my case.

  • Status changed to Needs work over 1 year ago
  • 🇬🇧United Kingdom catch

    Moving to needs work so it's clearer the patch needs a re-roll, vs. just a delayed cherry-pick.

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Note that per 💬 The block editor menu havent the "editor" Fixed (see #19 + #20 + #21) that this is causing CKEditor 5 to fail to load correctly in certain contexts too. This issue fixed it. It first shipped in a release in 10.0.9.

    … but it's not yet fixed in 9.5.x. So this would appear to still be quite important to backport.

    Caveat: I have not verified if this problem occurred in 9.5.

  • 🇦🇹Austria agoradesign

    I have encountered this problem on any 9.5.x site I've enabled CKE5 without this patch so far - but only on editing a taxonomy term

  • Status changed to Needs review over 1 year ago
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    26:40
    26:11
    Running
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    111 pass, 1 fail
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    111 pass, 1 fail
  • 🇺🇸United States bnjmnm Ann Arbor, MI

    9.5.x reroll

  • 🇧🇪Belgium redseujac

    Wim Leers commented in #70:

    Note that per #3357678: The block editor menu havent the "editor" (see #19 + #20 + #21) that this is causing CKEditor 5 to fail to load correctly in certain contexts too. This issue fixed it. It first shipped in a release in 10.0.9.

    I'm working with 10.0.9 and I'm glad to tell that my problems with Webforms/CKEditor5 are solved now. Before it was impossible to write/edit text in some textboxes managed by CKEditor5 there.

  • Status changed to RTBC over 1 year ago
  • 🇺🇸United States smustgrave

    Reroll for 9.5 looks good.

    • catch committed 8914d3ea on 9.5.x
      Issue #3222107 by codebymikey, bnjmnm, chandu7929, vipin.mittal18,...
  • Status changed to Fixed over 1 year ago
  • 🇬🇧United Kingdom catch

    Committed/pushed the backport to 9.5.x, thanks!

  • Status changed to Needs work over 1 year ago
  • 🇳🇱Netherlands spokje

    Backport breaks HEAD of 9.5.x on PHP 7.3 (https://dispatcher.drupalci.org/job/drupal8_core_regression_tests/82519/...)

    _If_ we decide to not rollback and do a 'hotfix', let's see if attached patch works.

  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 7.3 & MySQL 5.7
    last update over 1 year ago
    CI aborted
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    CI aborted
  • 🇳🇱Netherlands spokje

    Right..., measure twice, code once.
    There are _two_ arrow syntax functions in the test.

    Let's try this again...

  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    Checkout Error
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 7.3 & MySQL 5.7
    last update over 1 year ago
    30,367 pass
  • Open in Jenkins → Open on Drupal.org →
    Environment: PHP 8.1 & MySQL 5.7
    last update over 1 year ago
    30,334 pass
  • Status changed to Needs review over 1 year ago
    • catch committed dfd1b1a2 on 9.5.x
      Issue #3222107 by codebymikey, bnjmnm, chandu7929, Spokje, vipin....
  • Status changed to Fixed over 1 year ago
  • 🇬🇧United Kingdom catch

    Whoops. Committed/pushed to 9.5.x, thanks!

  • 🇨🇷Costa Rica maxmendez

    I'm using 9.5.9 and the problems seems to be solved for the admin user (user 1), but the problems seems to persist on user with low level of permissions.

    ntrolgroup.js:39 Uncaught TypeError: t.widget is not a function
        at controlgroup.js:39:10
        at controlgroup.js:32:3
        at controlgroup.js:19:1
    (anónimo) @ controlgroup.js:39
    (anónimo) @ controlgroup.js:32
    (anónimo) @ controlgroup.js:19
    form-reset-mixin.js:34 Uncaught TypeError: Cannot set properties of undefined (setting 'formResetMixin')
        at form-reset-mixin.js:34:13
        at form-reset-mixin.js:29:3
        at form-reset-mixin.js:15:1
    (anónimo) @ form-reset-mixin.js:34
    (anónimo) @ form-reset-mixin.js:29
    (anónimo) @ form-reset-mixin.js:15
    mouse.js:40 Uncaught TypeError: e.widget is not a function
        at mouse.js:40:10
        at mouse.js:30:3
        at mouse.js:15:1
    (anónimo) @ mouse.js:40
    (anónimo) @ mouse.js:30
    (anónimo) @ mouse.js:15
    checkboxradio.js:40 Uncaught TypeError: Cannot read properties of undefined (reading 'formResetMixin')
        at checkboxradio.js:40:38
        at checkboxradio.js:35:3
        at checkboxradio.js:20:1
    (anónimo) @ checkboxradio.js:40
    (anónimo) @ checkboxradio.js:35
    (anónimo) @ checkboxradio.js:20
    draggable.js:42 Uncaught TypeError: Cannot read properties of undefined (reading 'mouse')
        at draggable.js:42:32
        at draggable.js:37:3
        at draggable.js:17:1
    (anónimo) @ draggable.js:42
    (anónimo) @ draggable.js:37
    (anónimo) @ draggable.js:17
    resizable.js:41 Uncaught TypeError: Cannot read properties of undefined (reading 'mouse')
        at resizable.js:41:32
        at resizable.js:36:3
        at resizable.js:19:1
    (anónimo) @ resizable.js:41
    (anónimo) @ resizable.js:36
    (anónimo) @ resizable.js:19
    button.js:44 Uncaught TypeError: t.widget is not a function
        at button.js:44:3
        at button.js:39:3
        at button.js:19:1
    (anónimo) @ button.js:44
    (anónimo) @ button.js:39
    (anónimo) @ button.js:19
    dialog.js:49 Uncaught TypeError: i.widget is not a function
        at dialog.js:49:3
        at dialog.js:44:3
        at dialog.js:19:1
    (anónimo) @ dialog.js:49
    (anónimo) @ dialog.js:44
    (anónimo) @ dialog.js:19
    widget.js:104 Uncaught TypeError: i is not a constructor
        at t.widget (widget.js:104:18)
        at dialog.jquery-ui.js?v=9.5.9:10:5
        at dialog.jquery-ui.js?v=9.5.9:61:3
    t.widget @ widget.js:104
    (anónimo) @ dialog.jquery-ui.js?v=9.5.9:10
    (anónimo) @ dialog.jquery-ui.js?v=9.5.9:61
    widget.js:81 Uncaught RangeError: Maximum call stack size exceeded
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
        at new t.<computed>.<computed> (widget.js:81:11)
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    t.<computed>.<computed> @ widget.js:81
    drupal.js?v=9.5.9:14 Uncaught TypeError: Cannot read properties of null (reading 'setAttribute')
        at custom-entity-forms.js?v=1.x:7:54
        at NodeList.forEach (<anonymous>)
        at Object.attach (custom-entity-forms.js?v=1.x:4:52)
        at drupal.js?v=9.5.9:24:24
        at Array.forEach (<anonymous>)
        at Drupal.attachBehaviors (drupal.js?v=9.5.9:21:34)
        at drupal.init.js?v=9.5.9:24:12
        at HTMLDocument.listener (drupal.init.js?v=9.5.9:14:7)
    (anónimo) @ custom-entity-forms.js?v=1.x:7
    attach @ custom-entity-forms.js?v=1.x:4
    (anónimo) @ drupal.js?v=9.5.9:24
    Drupal.attachBehaviors @ drupal.js?v=9.5.9:21
    (anónimo) @ drupal.init.js?v=9.5.9:24
    listener @ drupal.init.js?v=9.5.9:14
    setTimeout (asíncrono)
    Drupal.throwError @ drupal.js?v=9.5.9:13
    (anónimo) @ drupal.js?v=9.5.9:26
    Drupal.attachBehaviors @ drupal.js?v=9.5.9:21
    (anónimo) @ drupal.init.js?v=9.5.9:24
    listener @ drupal.init.js?v=9.5.9:14
    drupal.js?v=9.5.9:14 Uncaught TypeError: Cannot read properties of null (reading 'setAttribute')
        at custom-entity-forms.js?v=1.x:7:54
        at NodeList.forEach (<anonymous>)
        at Object.attach (custom-entity-forms.js?v=1.x:4:52)
        at drupal.js?v=9.5.9:24:24
        at Array.forEach (<anonymous>)
        at Drupal.attachBehaviors (drupal.js?v=9.5.9:21:34)
        at big_pipe.js?v=9.5.9:43:14
        at Array.forEach (<anonymous>)
        at bigPipeProcessDocument (big_pipe.js?v=9.5.9:42:55)
        at big_pipe.js?v=9.5.9:56:12
    (anónimo) @ custom-entity-forms.js?v=1.x:7
    attach @ custom-entity-forms.js?v=1.x:4
    (anónimo) @ drupal.js?v=9.5.9:24
    Drupal.attachBehaviors @ drupal.js?v=9.5.9:21
    (anónimo) @ big_pipe.js?v=9.5.9:43
    bigPipeProcessDocument @ big_pipe.js?v=9.5.9:42
    (anónimo) @ big_pipe.js?v=9.5.9:56
    setTimeout (asíncrono)
    Drupal.throwError @ drupal.js?v=9.5.9:13
    (anónimo) @ drupal.js?v=9.5.9:26
    Drupal.attachBehaviors @ drupal.js?v=9.5.9:21
    (anónimo) @ big_pipe.js?v=9.5.9:43
    bigPipeProcessDocument @ big_pipe.js?v=9.5.9:42
    (anónimo) @ big_pipe.js?v=9.5.9:56
    setTimeout (asíncrono)
    bigPipeProcess @ big_pipe.js?v=9.5.9:55
    (anónimo) @ big_pipe.js?v=9.5.9:61
    (anónimo) @ big_pipe.js?v=9.5.9:68
  • 🇨🇷Costa Rica maxmendez

    Sorry, my mistake, it is fixed but has been released core versión with this patch.

  • 🇷🇺Russia mr.pomelov

    #72 work for me (Drupal 9.5.9, MySQL 5.7.30, PHP 8.1.7)

  • 🇩🇪Germany Anybody Porta Westfalica

    Confirming this works fine! Very much looking forward to the next 9.5 patch release with this fix!

  • 🇧🇪Belgium wim leers Ghent 🇧🇪🇪🇺

    Yay!

    Updating title.

  • Automatically closed - issue fixed for 2 weeks with no activity.

  • Status changed to Fixed over 1 year ago
  • 🇦🇹Austria maxilein

    The issue is back with D10.1.
    Since the other issue was postponed to D11.x, can we please make a patch for D10.1.

  • 🇳🇱Netherlands Martijn de Wit 🇳🇱 The Netherlands

    It was already in 10.1 right? see https://www.drupal.org/project/drupal/issues/3222107#comment-15007055 🐛 Library order asset weights do not work properly when a large number of javascript files is loaded between two jQuery UI libraries Fixed

  • 🇦🇺Australia larowlan 🇦🇺🏝.au GMT+10

    It's all the way back to 9.5

  • 🇦🇹Austria maxilein

    Thanks. You are right. Forgive me! Same symptoms ... I'll investigate...

  • 🇦🇹Austria maxilein

    It seems that CKEditor 5 ^36 compatibility — necessary for Drupal 10.1.x was this issue.
    It behaved very much randomly like problems caused by this issue. All kinds of javascript file errors, without any logical source that varied completely from the number of installed and uninstalled modules. So I post it here. It may help someone.

  • 🇦🇹Austria maxilein

    It turned out that it was just a coincidence of multiple contrib modules which did forget to migrate core/jquery to contrib before the upgrade to 10.1 and some missing dependencies in this context. Sorry and thank you.

  • 🇨🇦Canada gwvoigt London, ON 🇨🇦

    Does it work with 9.5.10? None of the patches apply to 9.5.10

  • ivnish Kazakhstan

    Already committed to 9.5, see #77

  • 🇨🇦Canada gwvoigt London, ON 🇨🇦

    Thank you! I'm on 9.5.10 and still having issues when aggregation is on. In random instances the ckeditor don't load properly.

  • 🇺🇸United States cecrs

    @gwvoigt

    Check out this issue: https://www.drupal.org/project/drupal/issues/3370930 🐛 Aggregation URL hashes should be built from normalized list of libraries Fixed

    We were also still seeing problems with missing ckeditor5 toolbars, and it was caused by aggregate files not getting written to disk due to mismatched hashes. There isn't a patch for < D10, but it's minimal changes and easy to generate a patch for if you aren't on D10 yet. Appears to have resolved our issues.

  • 🇦🇹Austria maxilein

    Is it possible that this also affects css at a simliar functionality?
    When I aggregate css files not all styles are used.

Production build 0.71.5 2024