You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The ESM builds are outputting CommonJS code. You can see an example in decap-cms-core's ESM build which uses CommonJS-style exports despite being in the ESM directory.
Root Cause
By default, @babel/preset-env transforms ES modules to CommonJS for compatibility. This transformation needs to be explicitly disabled for ESM builds.
The issue likely went unnoticed because most users consume the main bundles through decap-cms or decap-cms-app rather than using the ESM versions of individual packages directly.
Additional Problems
While fixing the issue, I noticed that the CommonJS build fails when the ESM build was not run before and the Nx cache is empty as it tries to build decap-cms and decap-cms-app in parallel, alltough decap-cms-app depends on decap-cms.
This can be fixed by telling Nx to build the dependencies first in nx.json:
This is problematic as it bypasses the proper package entry points and makes the code fragile.
Impact
ESM builds aren't truly ESM, making it impossible to use modern ES module features
Packages advertise ESM support through the 'dist/esm' directory but don't actually provide it
Clean builds fail unless run through the npm script that enforces sequential execution
Code contains fragile imports that bypass proper package entry points
Solution
Configure Babel to preserve ES modules for ESM builds by setting 'modules: false', which tells Babel to keep the original import/export syntax instead of transforming it to require/exports:
* fix: leave modules untouched in ESM build
This prevents Babel from converting the ESM module syntax to CommonJS.
* fix: include clearing the Nx cache in the clean script
Otherwise a "clean" build will still use old artefacts from the cache.
* fix: don't build dependant packages in parallel
This ensures that any local dependencies are built first.
* fix: don't import from dist/esm
Thanks to the other changes in this PR, we can now safely import from the decap-cms-app.
* fix(ci): use actions/setup-node cache option
This will hopefully fix the error we get on Windows during `npm install`
* chore(ci): fix typo and output matrix.node-version
* ci: run e2e tests in same container
* ci: fail fast to reduce build time and save cpu cycles
* ci: run on all branches
* ci: set IS_FORK=true if the repo owner is not decaporg
* ci: use afterEach hook to fail fast
* fix(app): add module field to package.json
* fix(app): add missing decap-cms-backend-gitea dependency
---------
Co-authored-by: Martin Jagodic <[email protected]>
Problem
The ESM builds are outputting CommonJS code. You can see an example in decap-cms-core's ESM build which uses CommonJS-style exports despite being in the ESM directory.
Root Cause
By default,
@babel/preset-env
transforms ES modules to CommonJS for compatibility. This transformation needs to be explicitly disabled for ESM builds.The issue likely went unnoticed because most users consume the main bundles through
decap-cms
ordecap-cms-app
rather than using the ESM versions of individual packages directly.Additional Problems
While fixing the issue, I noticed that the CommonJS build fails when the ESM build was not run before and the Nx cache is empty as it tries to build
decap-cms
anddecap-cms-app
in parallel, alltoughdecap-cms-app
depends ondecap-cms
.This can be fixed by telling Nx to build the dependencies first in
nx.json
:It looks as if someone tried to fix this before by importing from the ESM build directly:
This is problematic as it bypasses the proper package entry points and makes the code fragile.
Impact
Solution
nx.json
to ensure correct build order regardless of cache state:This ensures:
I will open a PR with these changes.
The text was updated successfully, but these errors were encountered: