From 9048a14e85fa3e13d24fc722d78c7d53d7ac566b Mon Sep 17 00:00:00 2001 From: Ron S Date: Sun, 3 Oct 2021 17:36:03 -0400 Subject: [PATCH] feat!: Add esm named export support (closes #160 closes #139) Added wrapper for esm over CJS module and removed nonworking separate ESM build (per advice from url below). Note: Essentially a breaking change as `exports` package.json property prevents direct import from files in dist see: https://redfin.engineering/node-modules-at-war-why-commonjs-and-es-modules-cant-get-along-9617135eeca1 --- .eslintignore | 1 + esm/index.js | 9 +++++++++ esm/package.json | 3 +++ package.json | 13 ++++++++----- test/assets/cjs/index.ts | 4 ++++ test/assets/cjs/package.json | 8 ++++++++ test/assets/cjs/tsconfig.json | 9 +++++++++ test/assets/esm/index.ts | 4 ++++ test/assets/esm/package.json | 8 ++++++++ test/assets/esm/tsconfig.json | 9 +++++++++ test/assets/package.json | 9 +++++++++ test/assets/tsconfig.base.json | 7 +++++++ test/import.js | 20 ++++++++++++++++++++ 13 files changed, 99 insertions(+), 5 deletions(-) create mode 100755 esm/index.js create mode 100755 esm/package.json create mode 100755 test/assets/cjs/index.ts create mode 100755 test/assets/cjs/package.json create mode 100755 test/assets/cjs/tsconfig.json create mode 100755 test/assets/esm/index.ts create mode 100755 test/assets/esm/package.json create mode 100755 test/assets/esm/tsconfig.json create mode 100755 test/assets/package.json create mode 100755 test/assets/tsconfig.base.json create mode 100755 test/import.js diff --git a/.eslintignore b/.eslintignore index 6372315..5dff5c2 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,3 +1,4 @@ test/ dist/ node_modules/ +esm/ \ No newline at end of file diff --git a/esm/index.js b/esm/index.js new file mode 100755 index 0000000..a7e6785 --- /dev/null +++ b/esm/index.js @@ -0,0 +1,9 @@ +import nhp from '../dist/index.js' + +export const CommentNode = nhp.CommentNode; +export const HTMLElement = nhp.HTMLElement; +export const parse = nhp.parse; +export const valid = nhp.valid; +export const Node = nhp.Node; +export const TextNode = nhp.TextNode; +export const NodeType = nhp.NodeType; diff --git a/esm/package.json b/esm/package.json new file mode 100755 index 0000000..aead43d --- /dev/null +++ b/esm/package.json @@ -0,0 +1,3 @@ +{ + "type": "module" +} \ No newline at end of file diff --git a/package.json b/package.json index 23e7e52..caee529 100644 --- a/package.json +++ b/package.json @@ -3,7 +3,6 @@ "version": "4.1.5", "description": "A very fast HTML parser, generating a simplified DOM, with basic element query support.", "main": "dist/index.js", - "module": "dist/esm/index.js", "types": "dist/index.d.ts", "scripts": { "test": "mocha", @@ -11,10 +10,9 @@ "clean": "del-cli ./dist/", "ts:cjs": "tsc -m commonjs", "ts:amd": "tsc -t es5 -m amd -d false --outFile ./dist/main.js", - "ts:esm": "tsc -t es2019 -m esnext -d false --outDir ./dist/esm/", - "build": "npm run lint && npm run clean && npm run ts:cjs && npm run ts:amd && npm run ts:esm", + "build": "npm run lint && npm run clean && npm run ts:cjs && npm run ts:amd", "dev": "tsc -w & mocha -w ./test/*.js", - "pretest": "tsc -m commonjs", + "pretest": "tsc -m commonjs && cd test/assets && yarn install", "release": "yarn build && np", "prepare": "npm run build" }, @@ -60,6 +58,7 @@ "should": "latest", "spec": "latest", "travis-cov": "latest", + "ts-node": "^10.2.1", "typescript": "next" }, "config": { @@ -84,5 +83,9 @@ "url": "https://github.com/taoqf/node-fast-html-parser/issues" }, "homepage": "https://github.com/taoqf/node-fast-html-parser", - "sideEffects": false + "sideEffects": false, + "exports": { + "require": "./dist/index.js", + "import": "./esm/index.js" + } } diff --git a/test/assets/cjs/index.ts b/test/assets/cjs/index.ts new file mode 100755 index 0000000..eaca320 --- /dev/null +++ b/test/assets/cjs/index.ts @@ -0,0 +1,4 @@ +import { parse } from 'node-html-parser' + +const res = parse('parse succeeded'); +console.log(res.firstChild.text); \ No newline at end of file diff --git a/test/assets/cjs/package.json b/test/assets/cjs/package.json new file mode 100755 index 0000000..59937a6 --- /dev/null +++ b/test/assets/cjs/package.json @@ -0,0 +1,8 @@ +{ + "name": "cjs-test", + "private": true, + "type": "commonjs", + "peerDependencies": { + "node-html-parser": "*" + } +} diff --git a/test/assets/cjs/tsconfig.json b/test/assets/cjs/tsconfig.json new file mode 100755 index 0000000..4bfd375 --- /dev/null +++ b/test/assets/cjs/tsconfig.json @@ -0,0 +1,9 @@ +{ + "files": [ "index.ts" ], + "extends": "../tsconfig.base.json", + "compilerOptions": { + "noEmit": true, + "module": "CommonJS", + "moduleResolution": "node" + } +} \ No newline at end of file diff --git a/test/assets/esm/index.ts b/test/assets/esm/index.ts new file mode 100755 index 0000000..eaca320 --- /dev/null +++ b/test/assets/esm/index.ts @@ -0,0 +1,4 @@ +import { parse } from 'node-html-parser' + +const res = parse('parse succeeded'); +console.log(res.firstChild.text); \ No newline at end of file diff --git a/test/assets/esm/package.json b/test/assets/esm/package.json new file mode 100755 index 0000000..d1878b7 --- /dev/null +++ b/test/assets/esm/package.json @@ -0,0 +1,8 @@ +{ + "name": "esm-test", + "private": true, + "type": "module", + "peerDependencies": { + "node-html-parser": "*" + } +} diff --git a/test/assets/esm/tsconfig.json b/test/assets/esm/tsconfig.json new file mode 100755 index 0000000..a979782 --- /dev/null +++ b/test/assets/esm/tsconfig.json @@ -0,0 +1,9 @@ +{ + "files": [ "index.ts" ], + "extends": "../tsconfig.base.json", + "compilerOptions": { + "noEmit": true, + "module": "ESNext", + "moduleResolution": "node" + } +} \ No newline at end of file diff --git a/test/assets/package.json b/test/assets/package.json new file mode 100755 index 0000000..a421db9 --- /dev/null +++ b/test/assets/package.json @@ -0,0 +1,9 @@ +{ + "private": true, + "workspaces": [ + "assets/*" + ], + "dependencies": { + "node-html-parser": "link:../.." + } +} \ No newline at end of file diff --git a/test/assets/tsconfig.base.json b/test/assets/tsconfig.base.json new file mode 100755 index 0000000..c82fd8f --- /dev/null +++ b/test/assets/tsconfig.base.json @@ -0,0 +1,7 @@ +{ + "compilerOptions": { + "skipDefaultLibCheck": true, + "skipLibCheck": true, + "noLib": true + } +} \ No newline at end of file diff --git a/test/import.js b/test/import.js new file mode 100755 index 0000000..754bad4 --- /dev/null +++ b/test/import.js @@ -0,0 +1,20 @@ +const { execSync } = require('child_process'); +const path = require('path'); + +describe(`Module Import`, function () { + this.timeout(20000); + + it(`ESM project can import and use named exports`, () => { + execSync('node --loader ts-node/esm index.ts', { + cwd: path.resolve(__dirname, 'assets/esm'), + stdio: "pipe" + }).toString().should.eql('parse succeeded\n') + }); + + it(`CommonJS project can import and use named exports`, () => { + execSync('node -r ts-node/register index.ts', { + cwd: path.resolve(__dirname, 'assets/cjs'), + stdio: "pipe" + }).toString().should.eql('parse succeeded\n') + }); +}); \ No newline at end of file