From b8e8b143751d61b710ff6df33ec69f09cccf3adf Mon Sep 17 00:00:00 2001 From: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> Date: Tue, 20 Aug 2024 17:23:03 +0100 Subject: [PATCH] Move `type:module` declaration into package.json. (#4355) * Rename `switch_package_to_release.js` to `.cjs` Slightly surprisingly, the symlink is enough to make `node switch_package_to_release.js` work. * Rename .eslintrc.js to .cjs Again, declare this as commonjs * Move `type:module` declaration into package.json. matrix-js-sdk is built into ECMAScript modules, and we should declare it as such. See https://nodejs.org/api/packages.html#type. Failure to do so causes problems for javascript projects attempting to build against matrix-js-sdk: see https://github.com/matrix-org/matrix-js-sdk/issues/4347. Previously, we did this as part of the package.json switcheroo, but that is unnecessarily fragile. matrix-react-sdk, element-web, etc are unaffected by this, because they use the typescript files directly, by importing `matrix-js-sdk/src/...`. --- .eslintrc.js => .eslintrc.cjs | 0 package.json | 1 + scripts/release/pre-release.sh | 3 --- scripts/switch_package_to_release.cjs | 18 ++++++++++++++++++ scripts/switch_package_to_release.js | 23 +---------------------- 5 files changed, 20 insertions(+), 25 deletions(-) rename .eslintrc.js => .eslintrc.cjs (100%) create mode 100755 scripts/switch_package_to_release.cjs mode change 100755 => 120000 scripts/switch_package_to_release.js diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 100% rename from .eslintrc.js rename to .eslintrc.cjs diff --git a/package.json b/package.json index 075d821ec9a..29624b30b0a 100644 --- a/package.json +++ b/package.json @@ -31,6 +31,7 @@ "keywords": [ "matrix-org" ], + "type": "module", "main": "./src/index.ts", "browser": "./src/browser-index.ts", "matrix_src_main": "./src/index.ts", diff --git a/scripts/release/pre-release.sh b/scripts/release/pre-release.sh index 19319fb6105..6b47ef180ff 100755 --- a/scripts/release/pre-release.sh +++ b/scripts/release/pre-release.sh @@ -12,6 +12,3 @@ do jq ".$i = .matrix_lib_$i" package.json > package.json.new && mv package.json.new package.json && yarn prettier --write package.json fi done - -# Ensure that "type": "module" is present -jq '.type = "module"' package.json > package.json.new && mv package.json.new package.json && yarn prettier --write package.json diff --git a/scripts/switch_package_to_release.cjs b/scripts/switch_package_to_release.cjs new file mode 100755 index 00000000000..6d857a4070a --- /dev/null +++ b/scripts/switch_package_to_release.cjs @@ -0,0 +1,18 @@ +#!/usr/bin/env node + +const fsProm = require("fs/promises"); + +const PKGJSON = "package.json"; + +async function main() { + const pkgJson = JSON.parse(await fsProm.readFile(PKGJSON, "utf8")); + for (const field of ["main", "typings"]) { + if (pkgJson["matrix_lib_" + field] !== undefined) { + pkgJson[field] = pkgJson["matrix_lib_" + field]; + } + } + + await fsProm.writeFile(PKGJSON, JSON.stringify(pkgJson, null, 2)); +} + +main(); diff --git a/scripts/switch_package_to_release.js b/scripts/switch_package_to_release.js deleted file mode 100755 index 353840d4d92..00000000000 --- a/scripts/switch_package_to_release.js +++ /dev/null @@ -1,22 +0,0 @@ -#!/usr/bin/env node - -const fsProm = require("fs/promises"); - -const PKGJSON = "package.json"; - -async function main() { - const pkgJson = JSON.parse(await fsProm.readFile(PKGJSON, "utf8")); - for (const field of ["main", "typings"]) { - if (pkgJson["matrix_lib_" + field] !== undefined) { - pkgJson[field] = pkgJson["matrix_lib_" + field]; - } - } - - // matrix-js-sdk is built into ECMAScript modules. Make sure we declare it as such. - // See https://nodejs.org/api/packages.html#type. - pkgJson["type"] = "module"; - - await fsProm.writeFile(PKGJSON, JSON.stringify(pkgJson, null, 2)); -} - -main(); diff --git a/scripts/switch_package_to_release.js b/scripts/switch_package_to_release.js new file mode 120000 index 00000000000..27f1619c9a2 --- /dev/null +++ b/scripts/switch_package_to_release.js @@ -0,0 +1 @@ +switch_package_to_release.cjs \ No newline at end of file