ci: require js extensions on local imports #77
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
We need to use
.js
when importing local typescript files for ESM compatibility. #76 fixes this, but this PR adds an eslint plugin (thanks solana) to protect against breaking it again.I looked into other options, like libraries that transform extensionless imports to
.js
automatically, but seems like.js
extensions are a common pattern in typescript libraries, and it seems less risky to not muck around with the build process.Example output: