ministryofjustice / moj-frontend

Use the MoJ Design System to design, build, and deliver accessible and consistent services.
https://design-patterns.service.justice.gov.uk/
MIT License
33 stars 21 forks source link

Remove dependency on jQuery #134

Open gregtyler opened 3 years ago

gregtyler commented 3 years ago

Summary

It would be nice to eliminate our dependency on jQuery, instead using native browser functionality (e.g. setAttribute instead of attr, querySelector rather than find).

Motivation

There are a few reasons I think this is beneficial:

Describe alternatives you've considered

We can just keep using jQuery and accept the concerns above for now.

Additional context

We'll need to add polyfills for functionality that isn't available in all browsers > IE8. (e.g. Opera Mini and IE9/10 don't support HTMLElement.dataset) We may be able to detect and polyfill automatically as part of the build process.

We may also need to bulk out the IE8 polyfill if that's not already done by the GOV.UK Design system polyfill.

We shouldn't attempt this without unit tests (#132) as it would be difficult to spot regressions.

DanCorder commented 3 years ago

If this is going to take some time (it doesn't sound trivial) then in the meantime it would be nice to make the dependency on jQuery explicit. (I can't see it mentioned in the docs or the package.json)

gregtyler commented 3 years ago

Good point @DanCorder, we should add it to the installing with NPM documentation.

Edit: this has now been added in #187

gregtyler commented 2 years ago

GDS are considering removing jQuery from the prototype kit, which would mean that (until we remove jQuery ourselves) we'd need to bundle jQuery in the package and add it to the extension config file.

yndajas commented 9 months ago

Does this need adding to the package.json file until the dependency is removed? I tried removing jQuery per https://github.com/ministryofjustice/hmpps-template-typescript/pull/303/commits/eec17bba26095971c9dd3c352115b9fd238283e9 but then found that the sortable tables from this repo need it

gregtyler commented 9 months ago

jQuery is listed as a peer dependency in package.json so, from what I understand of peer dependencies, your package manager should either auto-install it (this is what npm seems to do) or warn you to install it manually.

yndajas commented 9 months ago

your package manager should either auto-install it (this is what npm seems to do) or warn you to install it manually.

As far as I can tell it didn't do that. npm install output after removing it as a direct dependency on our app but retaining the @ministryofjustice/frontend dependency:

up to date, audited 1177 packages in 785ms

191 packages are looking for funding
  run `npm fund` for details

found 0 vulnerabilities