Remove jQuery UI Library's Core dependency and Add module dependency

Created on 12 March 2024, about 1 year ago

As jquery.ui is removed from Core in Drupal 10 and is replaced with contrib module. We are updating the dependencies of existing core libraries with contrib modules in libraries, info and composer files.

🐛 Bug report
Status

Active

Version

3.0

Component

Code

Created by

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @mnk-0210
  • Merge request !36#3427365: Update jquery_ui dependencies → (Merged) created by mnk-0210
  • Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    Waiting for branch to pass
  • 🇮🇳India siddharthjain

    The above patch applies smoothly and the dependencies has been updated as per this article: https://www.drupal.org/docs/upgrading-drupal/upgrading-from-drupal-8-or-...

  • Status changed to Needs review 12 months ago
  • Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 12 months ago
    Waiting for branch to pass
  • Pipeline finished with Skipped
    10 months ago
    #205051
  • First commit to issue fork.
  • Status changed to Fixed 10 months ago
  • Status changed to Needs work 10 months ago
  • 🇵🇹Portugal jcnventura

    I think this may need a 2nd commit. This change only moved the libraries from core to the contrib modules, but it doesn't enable the modules. Which means that the newly added libraries are not enabled now, but the theme depends on them.

    This may need the following changes:
    * Make the theme depend on these modules in bootstrap.info.yml (see [#2937955])
    * Create a hook_update_n() to enable these modules during install
    * Also add the missing libraries from the jquery_ui module (see https://git.drupalcode.org/project/jquery_ui/-/blob/8.x-1.x/jquery_ui.li...):
    ** jquery_ui/widget
    ** jquery_ui/mouse
    ** jquery_ui/position

  • Merge request !42adds jquery ui dependencies → (Merged) created by shelane
  • 🇺🇸United States shelane

    @jcnventura, yes, you're right. I've added the dependencies to the info file and added an update hook to enable the modules. I'm not sure what to do about the missing jquery libraries that you mentioned though.

  • 🇵🇹Portugal jcnventura

    They were declared before in bootstrap.libraries.yml and were removed when the MR was merged. They should be able to be trivially added back, as they are now all provided by the (non-core) jquery_ui module.

  • Pipeline finished with Success
    9 months ago
    Total: 149s
    #210115
  • 🇦🇺Australia elc

    Adding these are dependencies inside the .info.yml means that the update can never be run - Drupal complains that dependencies are missing, and get stuck in "Verifying requirements" preventing updates from running.

    I also can't get the theme's hook_update_N to detect. Is it meant to be named something different because it's a base theme? I had to install the 3x modules manually after patching in.

  • 🇦🇺Australia elc

    The name of the module is jquery_ui_resizable and NOT jquery_ui_resizeable

  • First commit to issue fork.
  • Pipeline finished with Success
    9 months ago
    Total: 138s
    #222804
  • Status changed to Needs review 9 months ago
  • 🇺🇸United States shelane
  • 🇫🇷France Grimreaper France 🇫🇷

    Hi,

    Here is a patch from the MR for Composer usage.

    I don't have a modal on my website to test just want to apply the patch to have the modules enabled.

  • Status changed to Needs work 9 months ago
  • 🇫🇷France Grimreaper France 🇫🇷

    On Core 10.3.1, the update is not detected. After applying the patch, drush cr, then drush updb does not detect that there is a pending update.

  • 🇩🇪Germany lmoeni

    I ran into this issue when I created an newsletter (Simplenews) which threw the warnings that the jquery_ui modules are missing:

     User warning: The following theme is missing from the file system: jquery_ui in Drupal\Core\Extension\ExtensionPathResolver->getPathname() (line 63 of core/lib/Drupal/Core/Extension/ExtensionPathResolver.php).
        Deprecated function: dirname(): Passing null to parameter #1 ($path) of type string is deprecated in Drupal\Core\Extension\ExtensionPathResolver->getPath() (line 85 of core/lib/Drupal/Core/Extension/ExtensionPathResolver.php).

    Sadly, update hooks do not work in themes as themes do not have the install file like modules do. That's why the update is not detected.
    Defining the dependencies in the info.yml breaks the installation process for me:
    Unable to install theme: 'theme_name' due to unmet module dependencies: 'jquery_ui, jquery_ui_draggable, jquery_ui_resizable'.
    Tested with Drupal 10.2.3 and 10.3.1 + Bootstrap 3.31. I would not recommend using the patch. Instead I would install the modules in your own profile/module till there is a working solution for this issue.

  • Pipeline finished with Skipped
    8 months ago
    #247207
    • shelane committed b50c58fa on 8.x-3.x
      Issue #3427365 by mnk-0210: Remove jQuery UI Library's Core dependency...
  • 🇺🇸United States shelane

    I'm going to go ahead and do a release with this and include in the notes that users must enable these modules since the theme cannot do it through an update hook.

  • Status changed to Fixed 8 months ago
  • 🇳🇿New Zealand RoSk0 Wellington

    Marking as fixed as this was released in the 8.x-3.32 and I was able to run updates without issues, status report shows nothing related as well - tested on the latest Drupal core 10.3.2.

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

  • 🇺🇸United States loopy1492

    We have upgraded to the most recent version of 3.x and we are also getting this:

    User warning: The following theme is missing from the file system: jquery_ui_resizable in Drupal\Core\Extension\ExtensionPathResolver->getPathname() (line 63 of core/lib/Drupal/Core/Extension/ExtensionPathResolver.php).
    Drupal\Core\Extension\ExtensionPathResolver->getPathname() (Line: 85)
    Drupal\Core\Extension\ExtensionPathResolver->getPath() (Line: 154)
    Drupal\Core\Asset\LibraryDiscoveryParser->buildByExtension() (Line: 87)
    Drupal\Core\Asset\LibraryDiscoveryCollector->getLibraryDefinitions() (Line: 66)
    Drupal\Core\Asset\LibraryDiscoveryCollector->resolveCacheMiss() (Line: 149)
    Drupal\Core\Cache\CacheCollector->get() (Line: 44)
    Drupal\Core\Asset\LibraryDiscovery->getLibrariesByExtension() (Line: 58)
    Drupal\Core\Asset\LibraryDiscovery->getLibraryByName() (Line: 68)
    Drupal\Core\Asset\LibraryDependencyResolver->doGetDependencies() (Line: 70)
    Drupal\Core\Asset\LibraryDependencyResolver->doGetDependencies() (Line: 70)
    Drupal\Core\Asset\LibraryDependencyResolver->doGetDependencies() (Line: 70)
    Drupal\Core\Asset\LibraryDependencyResolver->doGetDependencies() (Line: 41)
    Drupal\Core\Asset\LibraryDependencyResolver->getLibrariesWithDependencies() (Line: 116)
    Drupal\Core\Asset\AssetResolver->getLibrariesToLoad() (Line: 175)
    Drupal\Core\Asset\AssetResolver->getCssAssets() (Line: 323)
    Drupal\Core\Render\HtmlResponseAttachmentsProcessor->processAssetLibraries() (Line: 167)
    Drupal\Core\Render\HtmlResponseAttachmentsProcessor->processAttachments() (Line: 97)
    Drupal\big_pipe\Render\BigPipeResponseAttachmentsProcessor->processAttachments() (Line: 45)
    Drupal\Core\EventSubscriber\HtmlResponseSubscriber->onRespond()
    call_user_func() (Line: 111)
    Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch() (Line: 214)
    Symfony\Component\HttpKernel\HttpKernel->filterResponse() (Line: 202)
    Symfony\Component\HttpKernel\HttpKernel->handleRaw() (Line: 76)
    Symfony\Component\HttpKernel\HttpKernel->handle() (Line: 53)
    Drupal\Core\StackMiddleware\Session->handle() (Line: 48)
    Drupal\Core\StackMiddleware\KernelPreHandle->handle() (Line: 28)
    Drupal\Core\StackMiddleware\ContentLength->handle() (Line: 32)
    Drupal\big_pipe\StackMiddleware\ContentLength->handle() (Line: 263)
    Drupal\shield\ShieldMiddleware->bypass() (Line: 130)
    Drupal\shield\ShieldMiddleware->handle() (Line: 48)
    Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle() (Line: 51)
    Drupal\Core\StackMiddleware\NegotiationMiddleware->handle() (Line: 36)
    Drupal\Core\StackMiddleware\AjaxPageState->handle() (Line: 51)
    Drupal\Core\StackMiddleware\StackedHttpKernel->handle() (Line: 741)
    Drupal\Core\DrupalKernel->handle() (Line: 19)

Production build 0.71.5 2024