JSPM

  • Created
  • Published
  • Downloads 29206
  • Score
    100M100P100Q148392F
  • License MIT

Make tsc-compiled `es2020/esnext` bundles compatible with esm/mjs requirements

Package Exports

  • tsc-esm-fix

Readme

tsc-esm-fix

Make tsc-compiled es2020/esnext bundles compatible with esm/mjs requirements

CI David Maintainability Test Coverage

Motivation

This workaround is aimed to bypass a pair of tsc and ts-jest issues right here and right now.

Hope one day this library will not be needed.

Features

  • Finds and replaces __dirname and __filename refs with import.meta.
  • Injects extensions to imports/re-exports statements.
    • import {foo} from './foo'import {foo} from './foo.js'
    • import {baz} from 'external/baz'import {baz} from 'external/baz.js'
    • Pays attention to index files: import {bar} from './bar'import {bar} from './bar/index.js'
  • Follows outDir found in tsconfig.json.
  • Changes file extensions if specified by opts.
  • Supports Windows-based runtimes.

Requirements

Node.js >= 14

Install

yarn add -D tsc-esm-fix

Usage

tsc-esm-fix [options]
import { fix } from 'tsc-esm-fix'
await fix({
  dirnameVar: true,
  filenameVar: true,
  ext: true
})

API

CLI

tsc-esm-fix [opts]
Option Description Default
--tsconfig Path to project's ts-config(s) tsconfig.json
--target Entry points where compiled files are placed for modification If not specified inherited from tsconfig.json compilerOptions.outDir
--dirnameVar Replace __dirname usages with import.meta true
--filenameVar Replace __filename var references import.meta true
--ext Append extension to relative imports/re-exports .js
--cwd cwd process.cwd()
--out Output dir. Defaults to cwd, so files would be overwritten process.cwd()
--debug Prints debug notes

JS/TS

import { fix, IFixOptions } from 'tsc-esm-fix'

const fixOptions: IFixOptions = {
  tsconfig: 'tsconfig.build.json',
  dirnameVar: true,
  filenameVar: true,
  ext: true
}

await fix(fixOptions)
export interface IFixOptions {
  cwd: string
  out?: string,
  target?: string | string[]
  tsconfig: string | string[]
  dirnameVar: boolean
  filenameVar: boolean
  ext: boolean | string
}

Alternatives

License

MIT