From 5b8a20cd09bf03fe28dbd9111d0f28bccd559009 Mon Sep 17 00:00:00 2001 From: Romaric Pascal Date: Thu, 21 Nov 2024 12:43:22 +0000 Subject: [PATCH] Add deprecated JavaScript files to package build Because they're not imported by `all.mjs` deprecated JavaScript files were not included in the package (in which they need to remain until the next breaking release). This adds a module to store the list of deprecated JavaScript files and helper functions that are then used: - in the Gulp configuration, to add a new task building each deprecated file individually - in the Rollup configuration, to prevent the bundled output of the deprecated files as all we want is for them to be in the package as a module Co-authored-by: Patrick Cartlidge Co-authored-by: Brett Kyle --- docs/contributing/managing-change.md | 25 +++++++++++ .../govuk-frontend/rollup.publish.config.mjs | 40 ++++++++++++----- .../src/govuk/govuk-frontend-component.mjs | 5 +++ .../tasks/config/deprecated-scripts.mjs | 45 +++++++++++++++++++ packages/govuk-frontend/tasks/scripts.mjs | 19 ++++++++ 5 files changed, 122 insertions(+), 12 deletions(-) create mode 100644 packages/govuk-frontend/tasks/config/deprecated-scripts.mjs diff --git a/docs/contributing/managing-change.md b/docs/contributing/managing-change.md index da640ffb08..7c6eb31c2b 100644 --- a/docs/contributing/managing-change.md +++ b/docs/contributing/managing-change.md @@ -122,6 +122,31 @@ If possible, update the mixin or function to maintain the existing functionality } ``` +### Deprecating a JavaScript file being removed + +Removing a JavaScript file may happen because the module is no longer needed, or has been moved to another place in the project. + +Awaiting for the next breaking, the file needs to remain included in the built package, marked as deprecated. + +1. To ensure the file remains in the package, add its path within `src/govuk` to the list of paths in `packages/tasks/config/deprecated-scripts.mjs`. For example: + +```mjs +export const deprecatedFilesPaths = [ + 'govuk-frontend-component.mjs' +] +``` + +This will build the file individually when creating the package, as it is no longer being discovered automatically by Rollup when building `all.mjs`. + +2. To mark the file as deprecated, add the following JSDoc comment at the top of the file: + +```js +/** + * @deprecated - Optionally describe where the file has been moved to or why it's been removed + * @module + */ +``` + ## Renaming things When renaming things, keep the old name available as an alias and mark it as deprecated, following the steps above to [make sure we remember to remove the deprecated feature](#make-sure-we-remember-to-remove-the-deprecated-feature). diff --git a/packages/govuk-frontend/rollup.publish.config.mjs b/packages/govuk-frontend/rollup.publish.config.mjs index 1e7be8ddf4..5d247b4a90 100644 --- a/packages/govuk-frontend/rollup.publish.config.mjs +++ b/packages/govuk-frontend/rollup.publish.config.mjs @@ -3,6 +3,8 @@ import { babel } from '@rollup/plugin-babel' import replace from '@rollup/plugin-replace' import { defineConfig } from 'rollup' +import { isDeprecated } from './tasks/config/deprecated-scripts.mjs' + /** * Rollup config for npm publish */ @@ -28,26 +30,30 @@ export default defineConfig(({ i: input }) => ({ * ECMAScript (ES) module bundles for browser