From 96b6421039b2c1e57208cc602cba1723c42bbf9a Mon Sep 17 00:00:00 2001 From: Westin Wrzesinski Date: Wed, 29 Jun 2022 19:22:53 -0500 Subject: [PATCH] chore!: move to typescript and vitest - Codebase is migrated to TypeScript by using https://github.com/Khan/flow-to-ts - Dist folder now outputs esm folder - Package.json update for types & modules - Flowgen is used to generate flow types from dist/*.d.ts --- .eslintrc.js | 10 ++- .flowconfig | 15 ---- .github/workflows/main.yml | 3 - babel.config.js | 4 + babel.config.json | 3 - karma.conf.js | 15 ---- package.json | 47 +++++++----- src/{index.js => index.ts} | 2 - src/{native.js => native.ts} | 4 - src/util.js | 20 ----- src/util.ts | 18 +++++ src/{weakmap.js => weakmap.ts} | 34 +++++---- test/index.js | 5 -- test/tests/index.js | 3 - test/util.js | 11 --- test/{tests/weakmap.js => weakmap.test.ts} | 85 ++++------------------ tsconfig.json | 3 + vite.config.js | 31 ++++++++ webpack.config.js => webpack.config.ts | 4 + 19 files changed, 131 insertions(+), 186 deletions(-) delete mode 100644 .flowconfig create mode 100644 babel.config.js delete mode 100644 babel.config.json delete mode 100644 karma.conf.js rename src/{index.js => index.ts} (82%) rename src/{native.js => native.ts} (97%) delete mode 100644 src/util.js create mode 100644 src/util.ts rename src/{weakmap.js => weakmap.ts} (87%) delete mode 100644 test/index.js delete mode 100644 test/tests/index.js delete mode 100644 test/util.js rename test/{tests/weakmap.js => weakmap.test.ts} (96%) create mode 100644 tsconfig.json create mode 100644 vite.config.js rename webpack.config.js => webpack.config.ts (91%) diff --git a/.eslintrc.js b/.eslintrc.js index dcb7bff..51d0ae5 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -1,5 +1,9 @@ -/* @flow */ - module.exports = { - extends: "./node_modules/@krakenjs/grumbler-scripts/config/.eslintrc.js", + extends: + "./node_modules/@krakenjs/grumbler-scripts/config/.eslintrc-typescript.js", + + rules: { + // off for initial ts conversion + "@typescript-eslint/no-implicit-any-catch": "off", + }, }; diff --git a/.flowconfig b/.flowconfig deleted file mode 100644 index a87ef3f..0000000 --- a/.flowconfig +++ /dev/null @@ -1,15 +0,0 @@ -[ignore] -.*/node_modules/babel-plugin-flow-runtime -.*/node_modules/flow-runtime -.*/node_modules/cross-domain-utils/dist -.*/node_modules/cross-domain-utils/test -.*/node_modules/npm -.*/node_modules/resolve -.*/dist/module -[include] -[libs] -flow-typed -node_modules/@krakenjs/grumbler-scripts/declarations.js -[options] -module.name_mapper='^src\(.*\)$' -> '/src/\1' -experimental.const_params=false diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 80619fc..527d944 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -27,9 +27,6 @@ jobs: - name: 👕 Lint commit messages uses: wagoid/commitlint-github-action@v4 - - name: ▶️ Run flow-typed script - run: npm run flow-typed - - name: ▶️ Run build script run: npm run build diff --git a/babel.config.js b/babel.config.js new file mode 100644 index 0000000..9bf8100 --- /dev/null +++ b/babel.config.js @@ -0,0 +1,4 @@ +module.exports = { + extends: "@krakenjs/grumbler-scripts/config/.babelrc-browser", + presets: ["@krakenjs/grumbler-scripts/config/flow-ts-babel-preset"], +}; diff --git a/babel.config.json b/babel.config.json deleted file mode 100644 index c55c063..0000000 --- a/babel.config.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "extends": "@krakenjs/grumbler-scripts/config/.babelrc-browser" -} diff --git a/karma.conf.js b/karma.conf.js deleted file mode 100644 index d56c811..0000000 --- a/karma.conf.js +++ /dev/null @@ -1,15 +0,0 @@ -/* @flow */ -/* eslint import/no-nodejs-modules: off, import/no-default-export: off */ - -import { getKarmaConfig } from "@krakenjs/grumbler-scripts/config/karma.conf"; - -import { WEBPACK_CONFIG_TEST } from "./webpack.config"; - -export default function configKarma(karma: Object) { - const karmaConfig = getKarmaConfig(karma, { - basePath: __dirname, - webpack: WEBPACK_CONFIG_TEST, - }); - - karma.set(karmaConfig); -} diff --git a/package.json b/package.json index d683401..f91ac7b 100644 --- a/package.json +++ b/package.json @@ -3,25 +3,28 @@ "version": "2.0.3", "description": "Cross domain safe WeakMap.", "main": "dist/cross-domain-safe-weakmap.js", + "module": "dist/index.js", + "types": "dist/types/index.d.ts", "scripts": { - "setup": "npm install && npm run flow-typed", - "lint": "eslint src/ test/ *.js", - "flow-typed": "rm -rf ./flow-typed && flow-typed install", - "flow": "flow", - "karma": "cross-env NODE_ENV=test babel-node --plugins=transform-es2015-modules-commonjs ./node_modules/.bin/karma start", - "babel": "babel src/ --out-dir dist/module", - "webpack": "babel-node --plugins=transform-es2015-modules-commonjs ./node_modules/.bin/webpack --progress", + "build": "npm run test && npm run babel && npm run webpack && npm run build:types", + "build:flow": "find ./dist -type f -not -path './node_modules/*' -name '*.d.ts' -exec sh -c 'flowgen --add-flow-header $1 -o ${1%.*.*}.js.flow' _ '{}' \\;", + "build:tsc": "tsc src/* --outDir ./dist/esm --declaration --emitDeclarationOnly", + "build:types": "npm run build:tsc && npm run build:flow", + "webpack": "cross-env NODE_ENV=production babel-node --plugins=transform-es2015-modules-commonjs ./node_modules/.bin/webpack --progress", + "babel": "cross-env NODE_ENV=production babel src/ --out-dir ./dist/esm/ --extensions .ts,.tsx", + "tsc": "tsc", "format": "prettier --write --ignore-unknown .", "format:check": "prettier --check .", - "test": "npm run format:check && npm run lint && npm run flow-typed && npm run flow && npm run karma", - "build": "npm run test && npm run babel && npm run webpack", + "test": "npm run format:check && npm run lint && npm run tsc --no-emit && npm run vitest", + "lint": "eslint --ext ts,tsx,js,jsx src/ test/", + "clean": "rimraf dist coverage", "prerelease": "npm run clean && npm run build && git add dist && git commit -m 'ci: check in dist folder' || echo 'Nothing to distribute'", "release": "standard-version", "postrelease": "git push && git push --follow-tags && npm publish", - "clean": "rimraf dist coverage", - "reinstall": "rimraf flow-typed && rimraf node_modules && npm install && flow-typed install", "debug": "cross-env NODE_ENV=debug", - "prepare": "husky install" + "prepare": "husky install", + "vitest": "vitest run --dom --coverage", + "vitest:watch": "vitest watch --dom --coverage --ui" }, "repository": { "type": "git", @@ -72,24 +75,30 @@ ], "license": "Apache-2.0", "files": [ - "dist/", - "src/", - "postinstall.js" + "dist/" ], "readmeFilename": "README.md", "devDependencies": { "@commitlint/cli": "^16.2.1", "@commitlint/config-conventional": "^16.2.1", "@krakenjs/grumbler-scripts": "^7.0.0", - "flow-bin": "0.155.0", + "@types/webpack": "^5.28.0", + "@typescript-eslint/eslint-plugin": "^5.20.0", + "@typescript-eslint/parser": "^5.20.0", + "@vitest/ui": "^0.16.0", + "c8": "^7.11.0", + "flowgen": "^1.16.0", + "happy-dom": "^2.55.0", "husky": "^7.0.0", "lint-staged": "^12.4.0", - "mocha": "^4", "prettier": "^2.6.2", - "standard-version": "^9.3.2" + "standard-version": "^9.3.2", + "ts-node": "^10.8.1", + "typescript": "4.6.3", + "vitest": "^0.16.0" }, "dependencies": { - "@krakenjs/cross-domain-utils": "^3.0.2" + "@krakenjs/cross-domain-utils": "^4.0.0-alpha.2" }, "lint-staged": { "*": "prettier --write --ignore-unknown" diff --git a/src/index.js b/src/index.ts similarity index 82% rename from src/index.js rename to src/index.ts index f21cb1b..790b85c 100644 --- a/src/index.js +++ b/src/index.ts @@ -1,3 +1 @@ -/* @flow */ - export { CrossDomainSafeWeakMap as WeakMap } from "./weakmap"; diff --git a/src/native.js b/src/native.ts similarity index 97% rename from src/native.js rename to src/native.ts index 404d263..5593299 100644 --- a/src/native.js +++ b/src/native.ts @@ -1,5 +1,3 @@ -/* @flow */ - export function hasNativeWeakMap(): boolean { if (typeof WeakMap === "undefined") { return false; @@ -13,9 +11,7 @@ export function hasNativeWeakMap(): boolean { const testWeakMap = new WeakMap(); const testKey = {}; const testValue = "__testvalue__"; - Object.freeze(testKey); - testWeakMap.set(testKey, testValue); if (testWeakMap.get(testKey) === testValue) { diff --git a/src/util.js b/src/util.js deleted file mode 100644 index 371d6a4..0000000 --- a/src/util.js +++ /dev/null @@ -1,20 +0,0 @@ -/* @flow */ - -export function safeIndexOf(collection: $ReadOnlyArray, item: T): number { - for (let i = 0; i < collection.length; i++) { - try { - if (collection[i] === item) { - return i; - } - } catch (err) { - // pass - } - } - - return -1; -} - -// eslint-disable-next-line no-unused-vars -export function noop(...args: $ReadOnlyArray) { - // pass -} diff --git a/src/util.ts b/src/util.ts new file mode 100644 index 0000000..81492dd --- /dev/null +++ b/src/util.ts @@ -0,0 +1,18 @@ +export function safeIndexOf(collection: ReadonlyArray, item: T): number { + for (let i = 0; i < collection.length; i++) { + try { + if (collection[i] === item) { + return i; + } + } catch (err) { + // pass + } + } + + return -1; +} + +// eslint-disable-next-line @typescript-eslint/no-unused-vars +export function noop(...args: ReadonlyArray): void { + // pass +} diff --git a/src/weakmap.js b/src/weakmap.ts similarity index 87% rename from src/weakmap.js rename to src/weakmap.ts index 86c3606..f21c26a 100644 --- a/src/weakmap.js +++ b/src/weakmap.ts @@ -1,16 +1,15 @@ -/* @flow */ - -import { isWindow, isWindowClosed } from "@krakenjs/cross-domain-utils/src"; +import { + isWindow, + isWindowClosed, +} from "@krakenjs/cross-domain-utils/dist/esm"; import { hasNativeWeakMap } from "./native"; import { noop, safeIndexOf } from "./util"; -export class CrossDomainSafeWeakMap { +export class CrossDomainSafeWeakMap, V> { name: string; - weakmap: ?WeakMap; - // eslint-disable-next-line flowtype/no-mutable-array + weakmap: WeakMap | null | undefined; keys: Array; - // eslint-disable-next-line flowtype/no-mutable-array values: Array; constructor() { @@ -29,13 +28,14 @@ export class CrossDomainSafeWeakMap { this.values = []; } - _cleanupClosedWindows() { + _cleanupClosedWindows(): void { const weakmap = this.weakmap; const keys = this.keys; for (let i = 0; i < keys.length; i++) { const value = keys[i]; + // @ts-ignore `isWindowClosed` takes window which V is not if (isWindow(value) && isWindowClosed(value)) { if (weakmap) { try { @@ -47,7 +47,6 @@ export class CrossDomainSafeWeakMap { keys.splice(i, 1); this.values.splice(i, 1); - i -= 1; } } @@ -68,7 +67,7 @@ export class CrossDomainSafeWeakMap { return true; } - set(key: K, value: V) { + set(key: K, value: V): void { if (!key) { throw new Error(`WeakMap expected key`); } @@ -88,7 +87,9 @@ export class CrossDomainSafeWeakMap { const name = this.name; const entry = key[name]; + // @ts-ignore if (entry && entry[0] === key) { + // @ts-ignore entry[1] = value; } else { Object.defineProperty(key, name, { @@ -117,7 +118,7 @@ export class CrossDomainSafeWeakMap { } } - get(key: K): V | void { + get(key: K): V | undefined { if (!key) { throw new Error(`WeakMap expected key`); } @@ -138,8 +139,10 @@ export class CrossDomainSafeWeakMap { try { const entry = key[this.name]; + // @ts-ignore if (entry && entry[0] === key) { - return entry[1]; + // @ts-ignore + return entry[1] as V; } return; @@ -160,7 +163,7 @@ export class CrossDomainSafeWeakMap { return this.values[index]; } - delete(key: K) { + delete(key: K): void { if (!key) { throw new Error(`WeakMap expected key`); } @@ -179,7 +182,9 @@ export class CrossDomainSafeWeakMap { try { const entry = key[this.name]; + // @ts-ignore if (entry && entry[0] === key) { + // @ts-ignore entry[0] = entry[1] = undefined; } } catch (err) { @@ -219,6 +224,7 @@ export class CrossDomainSafeWeakMap { try { const entry = key[this.name]; + // @ts-ignore if (entry && entry[0] === key) { return true; } @@ -237,7 +243,7 @@ export class CrossDomainSafeWeakMap { getOrSet(key: K, getter: () => V): V { if (this.has(key)) { - // $FlowFixMe + // @ts-ignore return this.get(key); } diff --git a/test/index.js b/test/index.js deleted file mode 100644 index f5d7518..0000000 --- a/test/index.js +++ /dev/null @@ -1,5 +0,0 @@ -/* @flow */ - -import "./util"; - -import "./tests"; diff --git a/test/tests/index.js b/test/tests/index.js deleted file mode 100644 index cf20ac7..0000000 --- a/test/tests/index.js +++ /dev/null @@ -1,3 +0,0 @@ -/* @flow */ - -import "./weakmap"; diff --git a/test/util.js b/test/util.js deleted file mode 100644 index fbee482..0000000 --- a/test/util.js +++ /dev/null @@ -1,11 +0,0 @@ -/* @flow */ - -window.console.karma = (...args) => { - const karma = - window.karma || - (window.top && window.top.karma) || - (window.opener && window.opener.karma); - karma.log("debug", args); - // eslint-disable-next-line no-console - console.log(...args); -}; diff --git a/test/tests/weakmap.js b/test/weakmap.test.ts similarity index 96% rename from test/tests/weakmap.js rename to test/weakmap.test.ts index f566b8f..d7b1218 100644 --- a/test/tests/weakmap.js +++ b/test/weakmap.test.ts @@ -1,10 +1,9 @@ -/* @flow */ -/* eslint max-lines: 0 */ +import { describe, it } from "vitest"; -import { WeakMap } from "../../src"; +import { WeakMap } from "../src"; -function getWindow(): Object { - const win = {}; +function getWindow(): Record { + const win: Record = {}; win.self = win; win.closed = false; win.parent = win; @@ -17,9 +16,7 @@ describe("weakmap standard cases", () => { const map = new WeakMap(); const obj = {}; const val = "foo"; - map.set(obj, val); - const result = map.get(obj); if (result !== val) { @@ -30,7 +27,6 @@ describe("weakmap standard cases", () => { it("should get a non-existant key", () => { const map = new WeakMap(); const obj = {}; - const result = map.get(obj); if (result !== undefined) { @@ -43,10 +39,8 @@ describe("weakmap standard cases", () => { const obj = {}; const val1 = "foo"; const val2 = "bar"; - map.set(obj, val1); map.set(obj, val2); - const result = map.get(obj); if (result !== val2) { @@ -58,9 +52,7 @@ describe("weakmap standard cases", () => { const map = new WeakMap(); const obj = {}; const val = "foo"; - map.set(obj, val); - const result = map.has(obj); if (!result) { @@ -71,7 +63,6 @@ describe("weakmap standard cases", () => { it("should check for a non-existant key", () => { const map = new WeakMap(); const obj = {}; - const result = map.has(obj); if (result) { @@ -83,10 +74,8 @@ describe("weakmap standard cases", () => { const map = new WeakMap(); const obj = {}; const val = "foo"; - map.set(obj, val); map.delete(obj); - const result = map.has(obj); if (result) { @@ -102,9 +91,7 @@ describe("weakmap cross-origin cases", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.get(obj); if (result !== val) { @@ -115,7 +102,6 @@ describe("weakmap cross-origin cases", () => { it("should get a non-existant key", () => { const map = new WeakMap(); const obj = win; - const result = map.get(obj); if (result !== undefined) { @@ -128,10 +114,8 @@ describe("weakmap cross-origin cases", () => { const obj = win; const val1 = "foo"; const val2 = "bar"; - map.set(obj, val1); map.set(obj, val2); - const result = map.get(obj); if (result !== val2) { @@ -143,9 +127,7 @@ describe("weakmap cross-origin cases", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.has(obj); if (!result) { @@ -156,7 +138,6 @@ describe("weakmap cross-origin cases", () => { it("should check for a non-existant key", () => { const map = new WeakMap(); const obj = win; - const result = map.has(obj); if (result) { @@ -168,10 +149,8 @@ describe("weakmap cross-origin cases", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); map.delete(obj); - const result = map.has(obj); if (result) { @@ -182,8 +161,6 @@ describe("weakmap cross-origin cases", () => { describe("weakmap cross-origin cases with IE erroring window", () => { const win = getWindow(); - - // $FlowFixMe Object.defineProperty(win, "self", { get() { throw new Error("Rargh can't do that I'm IE ph34r me"); @@ -194,9 +171,7 @@ describe("weakmap cross-origin cases with IE erroring window", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.get(obj); if (result !== val) { @@ -207,7 +182,6 @@ describe("weakmap cross-origin cases with IE erroring window", () => { it("should get a non-existant key", () => { const map = new WeakMap(); const obj = win; - const result = map.get(obj); if (result !== undefined) { @@ -220,10 +194,8 @@ describe("weakmap cross-origin cases with IE erroring window", () => { const obj = win; const val1 = "foo"; const val2 = "bar"; - map.set(obj, val1); map.set(obj, val2); - const result = map.get(obj); if (result !== val2) { @@ -235,9 +207,7 @@ describe("weakmap cross-origin cases with IE erroring window", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.has(obj); if (!result) { @@ -248,7 +218,6 @@ describe("weakmap cross-origin cases with IE erroring window", () => { it("should check for a non-existant key", () => { const map = new WeakMap(); const obj = win; - const result = map.has(obj); if (result) { @@ -260,10 +229,8 @@ describe("weakmap cross-origin cases with IE erroring window", () => { const map = new WeakMap(); const obj = win; const val = "foo"; - map.set(obj, val); map.delete(obj); - const result = map.has(obj); if (result) { @@ -275,15 +242,13 @@ describe("weakmap cross-origin cases with IE erroring window", () => { describe("weakmap standard cases with no native WeakMap", () => { it("should set and get a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; const val = "foo"; - map.set(obj, val); - const result = map.get(obj); if (result !== val) { @@ -293,12 +258,11 @@ describe("weakmap standard cases with no native WeakMap", () => { it("should get a non-existant key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; - const result = map.get(obj); if (result !== undefined) { @@ -308,17 +272,15 @@ describe("weakmap standard cases with no native WeakMap", () => { it("should set over an existing key, and get a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; const val1 = "foo"; const val2 = "bar"; - map.set(obj, val1); map.set(obj, val2); - const result = map.get(obj); if (result !== val2) { @@ -328,15 +290,13 @@ describe("weakmap standard cases with no native WeakMap", () => { it("should set and check for a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; const val = "foo"; - map.set(obj, val); - const result = map.has(obj); if (!result) { @@ -346,12 +306,11 @@ describe("weakmap standard cases with no native WeakMap", () => { it("should check for a non-existant key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; - const result = map.has(obj); if (result) { @@ -361,16 +320,14 @@ describe("weakmap standard cases with no native WeakMap", () => { it("should set, delete, and check for a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = {}; const val = "foo"; - map.set(obj, val); map.delete(obj); - const result = map.has(obj); if (result) { @@ -384,15 +341,13 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should set and get a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.get(obj); if (result !== val) { @@ -402,12 +357,11 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should get a non-existant key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; - const result = map.get(obj); if (result !== undefined) { @@ -417,17 +371,15 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should set over an existing key, and get a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; const val1 = "foo"; const val2 = "bar"; - map.set(obj, val1); map.set(obj, val2); - const result = map.get(obj); if (result !== val2) { @@ -437,15 +389,13 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should set and check for a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; const val = "foo"; - map.set(obj, val); - const result = map.has(obj); if (!result) { @@ -455,12 +405,11 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should check for a non-existant key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; - const result = map.has(obj); if (result) { @@ -470,16 +419,14 @@ describe("weakmap cross-origin cases with no native WeakMap", () => { it("should set, delete, and check for a key", () => { const weakMap = window.WeakMap; + // @ts-ignore delete window.WeakMap; const map = new WeakMap(); window.WeakMap = weakMap; - const obj = win; const val = "foo"; - map.set(obj, val); map.delete(obj); - const result = map.has(obj); if (result) { diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..a071093 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,3 @@ +{ + "extends": "@krakenjs/grumbler-scripts/config/tsconfig.json" +} diff --git a/vite.config.js b/vite.config.js new file mode 100644 index 0000000..7950db1 --- /dev/null +++ b/vite.config.js @@ -0,0 +1,31 @@ +/* eslint-disable eslint-comments/disable-enable-pair */ +/* eslint-disable spaced-comment */ +/// + +// Configure Vitest (https://vitest.dev/config/) + +import path from "path"; + +import { defineConfig } from "vite"; + +// eslint-disable-next-line import/no-default-export +export default defineConfig({ + build: { + lib: { + entry: path.resolve(__dirname, "src/index.ts"), + name: "crossDomainSafeWeakMap", + fileName: (format) => `cross-domain-safe-weakmap.${format}.js`, + formats: ["es", "umd"], + }, + sourcemap: true, + rollupOptions: { + ouput: { + preserveModules: true, + }, + }, + }, + test: { + /* for example, use global to avoid globals imports (describe, test, expect): */ + // globals: true, + }, +}); diff --git a/webpack.config.js b/webpack.config.ts similarity index 91% rename from webpack.config.js rename to webpack.config.ts index 88ef6a1..3eb3f1a 100644 --- a/webpack.config.js +++ b/webpack.config.ts @@ -2,12 +2,14 @@ /* eslint import/no-nodejs-modules: off, import/no-default-export: off */ import type { WebpackConfig } from "@krakenjs/grumbler-scripts/config/types"; +// @ts-ignore import { getWebpackConfig } from "@krakenjs/grumbler-scripts/config/webpack.config"; export const FILE_NAME = "cross-domain-safe-weakmap"; export const MODULE_NAME = "xdsweakmap"; export const WEBPACK_CONFIG: WebpackConfig = getWebpackConfig({ + entry: "./src/index.ts", filename: `${FILE_NAME}.js`, modulename: MODULE_NAME, vars: { @@ -17,6 +19,7 @@ export const WEBPACK_CONFIG: WebpackConfig = getWebpackConfig({ }); export const WEBPACK_CONFIG_MIN: WebpackConfig = getWebpackConfig({ + entry: "./src/index.ts", filename: `${FILE_NAME}.min.js`, modulename: MODULE_NAME, minify: true, @@ -27,6 +30,7 @@ export const WEBPACK_CONFIG_MIN: WebpackConfig = getWebpackConfig({ }); export const WEBPACK_CONFIG_TEST: WebpackConfig = getWebpackConfig({ + entry: "./src/index.ts", modulename: MODULE_NAME, options: { devtool: "inline-source-map",