@wyw-in-js/esbuild 0.3.0 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,12 +7,14 @@
7
7
  import { readFileSync } from 'fs';
8
8
  import { basename, dirname, isAbsolute, join, parse, posix } from 'path';
9
9
  import { transformSync } from 'esbuild';
10
- import { slugify, transform, TransformCacheCollection } from '@wyw-in-js/transform';
10
+ import { slugify, transform, TransformCacheCollection, createFileReporter } from '@wyw-in-js/transform';
11
11
  const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/;
12
12
  export default function wywInJS({
13
+ debug,
13
14
  sourceMap,
14
15
  preprocessor,
15
16
  esbuildOptions,
17
+ filter = /\.(js|jsx|ts|tsx)$/,
16
18
  ...rest
17
19
  } = {}) {
18
20
  let options = esbuildOptions;
@@ -21,6 +23,10 @@ export default function wywInJS({
21
23
  name: 'wyw-in-js',
22
24
  setup(build) {
23
25
  const cssLookup = new Map();
26
+ const {
27
+ emitter,
28
+ onDone
29
+ } = createFileReporter(debug ?? false);
24
30
  const asyncResolve = async (token, importer) => {
25
31
  const context = isAbsolute(importer) ? dirname(importer) : join(process.cwd(), dirname(importer));
26
32
  const result = await build.resolve(token, {
@@ -32,6 +38,9 @@ export default function wywInJS({
32
38
  }
33
39
  return result.path.replace(/\\/g, posix.sep);
34
40
  };
41
+ build.onEnd(() => {
42
+ onDone(process.cwd());
43
+ });
35
44
  build.onResolve({
36
45
  filter: /\.wyw\.css$/
37
46
  }, args => {
@@ -50,8 +59,9 @@ export default function wywInJS({
50
59
  resolveDir: basename(args.path)
51
60
  };
52
61
  });
62
+ const filterRegexp = typeof filter === 'string' ? new RegExp(filter) : filter;
53
63
  build.onLoad({
54
- filter: /\.(js|jsx|ts|tsx)$/
64
+ filter: filterRegexp
55
65
  }, async args => {
56
66
  const rawCode = readFileSync(args.path, 'utf8');
57
67
  const {
@@ -94,7 +104,8 @@ export default function wywInJS({
94
104
  preprocessor,
95
105
  pluginOptions: rest
96
106
  },
97
- cache
107
+ cache,
108
+ eventEmitter: emitter
98
109
  };
99
110
  const result = await transform(transformServices, code, asyncResolve);
100
111
  if (!result.cssText) {
@@ -126,4 +137,4 @@ export default function wywInJS({
126
137
  }
127
138
  };
128
139
  }
129
- //# sourceMappingURL=index.js.map
140
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":["readFileSync","basename","dirname","isAbsolute","join","parse","posix","transformSync","slugify","transform","TransformCacheCollection","createFileReporter","nodeModulesRegex","wywInJS","debug","sourceMap","preprocessor","esbuildOptions","filter","rest","options","cache","name","setup","build","cssLookup","Map","emitter","onDone","asyncResolve","token","importer","context","process","cwd","result","resolve","resolveDir","kind","errors","length","Error","path","replace","sep","onEnd","onResolve","args","namespace","onLoad","contents","get","loader","filterRegexp","RegExp","rawCode","ext","filename","test","initialOptions","jsxFactory","jsxFragment","transformed","sourcefile","sourcemap","code","esbuildMap","Buffer","from","map","toString","transformServices","root","pluginOptions","eventEmitter","cssText","slug","cssFilename","JSON","stringify","cssSourceMapText","wywMap","set"],"sources":["../src/index.ts"],"sourcesContent":["/**\n * This file contains an esbuild loader for wyw-in-js.\n * It uses the transform.ts function to generate class names from source code,\n * returns transformed code without template literals and attaches generated source maps\n */\n\nimport { readFileSync } from 'fs';\nimport { basename, dirname, isAbsolute, join, parse, posix } from 'path';\n\nimport type { Plugin, TransformOptions, Loader } from 'esbuild';\nimport { transformSync } from 'esbuild';\n\nimport type {\n PluginOptions,\n Preprocessor,\n IFileReporterOptions,\n} from '@wyw-in-js/transform';\nimport {\n slugify,\n transform,\n TransformCacheCollection,\n createFileReporter,\n} from '@wyw-in-js/transform';\n\ntype EsbuildPluginOptions = {\n debug?: IFileReporterOptions | false | null | undefined;\n esbuildOptions?: TransformOptions;\n filter?: RegExp | string;\n preprocessor?: Preprocessor;\n sourceMap?: boolean;\n} & Partial<PluginOptions>;\n\nconst nodeModulesRegex = /^(?:.*[\\\\/])?node_modules(?:[\\\\/].*)?$/;\n\nexport default function wywInJS({\n debug,\n sourceMap,\n preprocessor,\n esbuildOptions,\n filter = /\\.(js|jsx|ts|tsx)$/,\n ...rest\n}: EsbuildPluginOptions = {}): Plugin {\n let options = esbuildOptions;\n const cache = new TransformCacheCollection();\n return {\n name: 'wyw-in-js',\n setup(build) {\n const cssLookup = new Map<string, string>();\n\n const { emitter, onDone } = createFileReporter(debug ?? false);\n\n const asyncResolve = async (\n token: string,\n importer: string\n ): Promise<string> => {\n const context = isAbsolute(importer)\n ? dirname(importer)\n : join(process.cwd(), dirname(importer));\n\n const result = await build.resolve(token, {\n resolveDir: context,\n kind: 'import-statement',\n });\n\n if (result.errors.length > 0) {\n throw new Error(`Cannot resolve ${token}`);\n }\n\n return result.path.replace(/\\\\/g, posix.sep);\n };\n\n build.onEnd(() => {\n onDone(process.cwd());\n });\n\n build.onResolve({ filter: /\\.wyw\\.css$/ }, (args) => {\n return {\n namespace: 'wyw-in-js',\n path: args.path,\n };\n });\n\n build.onLoad({ filter: /.*/, namespace: 'wyw-in-js' }, (args) => {\n return {\n contents: cssLookup.get(args.path),\n loader: 'css',\n resolveDir: basename(args.path),\n };\n });\n\n const filterRegexp =\n typeof filter === 'string' ? new RegExp(filter) : filter;\n\n build.onLoad({ filter: filterRegexp }, async (args) => {\n const rawCode = readFileSync(args.path, 'utf8');\n const { ext, name: filename } = parse(args.path);\n const loader = ext.replace(/^\\./, '') as Loader;\n\n if (nodeModulesRegex.test(args.path)) {\n return {\n loader,\n contents: rawCode,\n };\n }\n\n if (!options) {\n options = {};\n if ('jsxFactory' in build.initialOptions) {\n options.jsxFactory = build.initialOptions.jsxFactory;\n }\n if ('jsxFragment' in build.initialOptions) {\n options.jsxFragment = build.initialOptions.jsxFragment;\n }\n }\n\n const transformed = transformSync(rawCode, {\n ...options,\n sourcefile: args.path,\n sourcemap: sourceMap,\n loader,\n });\n let { code } = transformed;\n\n if (sourceMap) {\n const esbuildMap = Buffer.from(transformed.map).toString('base64');\n code += `/*# sourceMappingURL=data:application/json;base64,${esbuildMap}*/`;\n }\n\n const transformServices = {\n options: {\n filename: args.path,\n root: process.cwd(),\n preprocessor,\n pluginOptions: rest,\n },\n cache,\n eventEmitter: emitter,\n };\n\n const result = await transform(transformServices, code, asyncResolve);\n\n if (!result.cssText) {\n return {\n contents: code,\n loader,\n resolveDir: dirname(args.path),\n };\n }\n\n let { cssText } = result;\n\n const slug = slugify(cssText);\n const cssFilename = `${filename}_${slug}.wyw.css`;\n\n let contents = `import ${JSON.stringify(cssFilename)}; ${result.code}`;\n\n if (sourceMap && result.cssSourceMapText) {\n const map = Buffer.from(result.cssSourceMapText).toString('base64');\n cssText += `/*# sourceMappingURL=data:application/json;base64,${map}*/`;\n const wywMap = Buffer.from(JSON.stringify(result.sourceMap)).toString(\n 'base64'\n );\n contents += `/*# sourceMappingURL=data:application/json;base64,${wywMap}*/`;\n }\n\n cssLookup.set(cssFilename, cssText);\n\n return {\n contents,\n loader,\n resolveDir: dirname(args.path),\n };\n });\n },\n };\n}\n"],"mappings":"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"}
package/lib/index.js CHANGED
@@ -16,9 +16,11 @@ var _transform = require("@wyw-in-js/transform");
16
16
 
17
17
  const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/;
18
18
  function wywInJS({
19
+ debug,
19
20
  sourceMap,
20
21
  preprocessor,
21
22
  esbuildOptions,
23
+ filter = /\.(js|jsx|ts|tsx)$/,
22
24
  ...rest
23
25
  } = {}) {
24
26
  let options = esbuildOptions;
@@ -27,6 +29,10 @@ function wywInJS({
27
29
  name: 'wyw-in-js',
28
30
  setup(build) {
29
31
  const cssLookup = new Map();
32
+ const {
33
+ emitter,
34
+ onDone
35
+ } = (0, _transform.createFileReporter)(debug !== null && debug !== void 0 ? debug : false);
30
36
  const asyncResolve = async (token, importer) => {
31
37
  const context = (0, _path.isAbsolute)(importer) ? (0, _path.dirname)(importer) : (0, _path.join)(process.cwd(), (0, _path.dirname)(importer));
32
38
  const result = await build.resolve(token, {
@@ -38,6 +44,9 @@ function wywInJS({
38
44
  }
39
45
  return result.path.replace(/\\/g, _path.posix.sep);
40
46
  };
47
+ build.onEnd(() => {
48
+ onDone(process.cwd());
49
+ });
41
50
  build.onResolve({
42
51
  filter: /\.wyw\.css$/
43
52
  }, args => {
@@ -56,8 +65,9 @@ function wywInJS({
56
65
  resolveDir: (0, _path.basename)(args.path)
57
66
  };
58
67
  });
68
+ const filterRegexp = typeof filter === 'string' ? new RegExp(filter) : filter;
59
69
  build.onLoad({
60
- filter: /\.(js|jsx|ts|tsx)$/
70
+ filter: filterRegexp
61
71
  }, async args => {
62
72
  const rawCode = (0, _fs.readFileSync)(args.path, 'utf8');
63
73
  const {
@@ -100,7 +110,8 @@ function wywInJS({
100
110
  preprocessor,
101
111
  pluginOptions: rest
102
112
  },
103
- cache
113
+ cache,
114
+ eventEmitter: emitter
104
115
  };
105
116
  const result = await (0, _transform.transform)(transformServices, code, asyncResolve);
106
117
  if (!result.cssText) {
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_fs","require","_path","_esbuild","_transform","nodeModulesRegex","wywInJS","sourceMap","preprocessor","esbuildOptions","rest","options","cache","TransformCacheCollection","name","setup","build","cssLookup","Map","asyncResolve","token","importer","context","isAbsolute","dirname","join","process","cwd","result","resolve","resolveDir","kind","errors","length","Error","path","replace","posix","sep","onResolve","filter","args","namespace","onLoad","contents","get","loader","basename","rawCode","readFileSync","ext","filename","parse","test","initialOptions","jsxFactory","jsxFragment","transformed","transformSync","sourcefile","sourcemap","code","esbuildMap","Buffer","from","map","toString","transformServices","root","pluginOptions","transform","cssText","slug","slugify","cssFilename","JSON","stringify","cssSourceMapText","wywMap","set"],"sources":["../src/index.ts"],"sourcesContent":["/**\n * This file contains an esbuild loader for wyw-in-js.\n * It uses the transform.ts function to generate class names from source code,\n * returns transformed code without template literals and attaches generated source maps\n */\n\nimport { readFileSync } from 'fs';\nimport { basename, dirname, isAbsolute, join, parse, posix } from 'path';\n\nimport type { Plugin, TransformOptions, Loader } from 'esbuild';\nimport { transformSync } from 'esbuild';\n\nimport type { PluginOptions, Preprocessor } from '@wyw-in-js/transform';\nimport {\n slugify,\n transform,\n TransformCacheCollection,\n} from '@wyw-in-js/transform';\n\ntype EsbuildPluginOptions = {\n esbuildOptions?: TransformOptions;\n preprocessor?: Preprocessor;\n sourceMap?: boolean;\n} & Partial<PluginOptions>;\n\nconst nodeModulesRegex = /^(?:.*[\\\\/])?node_modules(?:[\\\\/].*)?$/;\n\nexport default function wywInJS({\n sourceMap,\n preprocessor,\n esbuildOptions,\n ...rest\n}: EsbuildPluginOptions = {}): Plugin {\n let options = esbuildOptions;\n const cache = new TransformCacheCollection();\n return {\n name: 'wyw-in-js',\n setup(build) {\n const cssLookup = new Map<string, string>();\n\n const asyncResolve = async (\n token: string,\n importer: string\n ): Promise<string> => {\n const context = isAbsolute(importer)\n ? dirname(importer)\n : join(process.cwd(), dirname(importer));\n\n const result = await build.resolve(token, {\n resolveDir: context,\n kind: 'import-statement',\n });\n\n if (result.errors.length > 0) {\n throw new Error(`Cannot resolve ${token}`);\n }\n\n return result.path.replace(/\\\\/g, posix.sep);\n };\n\n build.onResolve({ filter: /\\.wyw\\.css$/ }, (args) => {\n return {\n namespace: 'wyw-in-js',\n path: args.path,\n };\n });\n\n build.onLoad({ filter: /.*/, namespace: 'wyw-in-js' }, (args) => {\n return {\n contents: cssLookup.get(args.path),\n loader: 'css',\n resolveDir: basename(args.path),\n };\n });\n\n build.onLoad({ filter: /\\.(js|jsx|ts|tsx)$/ }, async (args) => {\n const rawCode = readFileSync(args.path, 'utf8');\n const { ext, name: filename } = parse(args.path);\n const loader = ext.replace(/^\\./, '') as Loader;\n\n if (nodeModulesRegex.test(args.path)) {\n return {\n loader,\n contents: rawCode,\n };\n }\n\n if (!options) {\n options = {};\n if ('jsxFactory' in build.initialOptions) {\n options.jsxFactory = build.initialOptions.jsxFactory;\n }\n if ('jsxFragment' in build.initialOptions) {\n options.jsxFragment = build.initialOptions.jsxFragment;\n }\n }\n\n const transformed = transformSync(rawCode, {\n ...options,\n sourcefile: args.path,\n sourcemap: sourceMap,\n loader,\n });\n let { code } = transformed;\n\n if (sourceMap) {\n const esbuildMap = Buffer.from(transformed.map).toString('base64');\n code += `/*# sourceMappingURL=data:application/json;base64,${esbuildMap}*/`;\n }\n\n const transformServices = {\n options: {\n filename: args.path,\n root: process.cwd(),\n preprocessor,\n pluginOptions: rest,\n },\n cache,\n };\n\n const result = await transform(transformServices, code, asyncResolve);\n\n if (!result.cssText) {\n return {\n contents: code,\n loader,\n resolveDir: dirname(args.path),\n };\n }\n\n let { cssText } = result;\n\n const slug = slugify(cssText);\n const cssFilename = `${filename}_${slug}.wyw.css`;\n\n let contents = `import ${JSON.stringify(cssFilename)}; ${result.code}`;\n\n if (sourceMap && result.cssSourceMapText) {\n const map = Buffer.from(result.cssSourceMapText).toString('base64');\n cssText += `/*# sourceMappingURL=data:application/json;base64,${map}*/`;\n const wywMap = Buffer.from(JSON.stringify(result.sourceMap)).toString(\n 'base64'\n );\n contents += `/*# sourceMappingURL=data:application/json;base64,${wywMap}*/`;\n }\n\n cssLookup.set(cssFilename, cssText);\n\n return {\n contents,\n loader,\n resolveDir: dirname(args.path),\n };\n });\n },\n };\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","names":["_fs","require","_path","_esbuild","_transform","nodeModulesRegex","wywInJS","debug","sourceMap","preprocessor","esbuildOptions","filter","rest","options","cache","TransformCacheCollection","name","setup","build","cssLookup","Map","emitter","onDone","createFileReporter","asyncResolve","token","importer","context","isAbsolute","dirname","join","process","cwd","result","resolve","resolveDir","kind","errors","length","Error","path","replace","posix","sep","onEnd","onResolve","args","namespace","onLoad","contents","get","loader","basename","filterRegexp","RegExp","rawCode","readFileSync","ext","filename","parse","test","initialOptions","jsxFactory","jsxFragment","transformed","transformSync","sourcefile","sourcemap","code","esbuildMap","Buffer","from","map","toString","transformServices","root","pluginOptions","eventEmitter","transform","cssText","slug","slugify","cssFilename","JSON","stringify","cssSourceMapText","wywMap","set"],"sources":["../src/index.ts"],"sourcesContent":["/**\n * This file contains an esbuild loader for wyw-in-js.\n * It uses the transform.ts function to generate class names from source code,\n * returns transformed code without template literals and attaches generated source maps\n */\n\nimport { readFileSync } from 'fs';\nimport { basename, dirname, isAbsolute, join, parse, posix } from 'path';\n\nimport type { Plugin, TransformOptions, Loader } from 'esbuild';\nimport { transformSync } from 'esbuild';\n\nimport type {\n PluginOptions,\n Preprocessor,\n IFileReporterOptions,\n} from '@wyw-in-js/transform';\nimport {\n slugify,\n transform,\n TransformCacheCollection,\n createFileReporter,\n} from '@wyw-in-js/transform';\n\ntype EsbuildPluginOptions = {\n debug?: IFileReporterOptions | false | null | undefined;\n esbuildOptions?: TransformOptions;\n filter?: RegExp | string;\n preprocessor?: Preprocessor;\n sourceMap?: boolean;\n} & Partial<PluginOptions>;\n\nconst nodeModulesRegex = /^(?:.*[\\\\/])?node_modules(?:[\\\\/].*)?$/;\n\nexport default function wywInJS({\n debug,\n sourceMap,\n preprocessor,\n esbuildOptions,\n filter = /\\.(js|jsx|ts|tsx)$/,\n ...rest\n}: EsbuildPluginOptions = {}): Plugin {\n let options = esbuildOptions;\n const cache = new TransformCacheCollection();\n return {\n name: 'wyw-in-js',\n setup(build) {\n const cssLookup = new Map<string, string>();\n\n const { emitter, onDone } = createFileReporter(debug ?? false);\n\n const asyncResolve = async (\n token: string,\n importer: string\n ): Promise<string> => {\n const context = isAbsolute(importer)\n ? dirname(importer)\n : join(process.cwd(), dirname(importer));\n\n const result = await build.resolve(token, {\n resolveDir: context,\n kind: 'import-statement',\n });\n\n if (result.errors.length > 0) {\n throw new Error(`Cannot resolve ${token}`);\n }\n\n return result.path.replace(/\\\\/g, posix.sep);\n };\n\n build.onEnd(() => {\n onDone(process.cwd());\n });\n\n build.onResolve({ filter: /\\.wyw\\.css$/ }, (args) => {\n return {\n namespace: 'wyw-in-js',\n path: args.path,\n };\n });\n\n build.onLoad({ filter: /.*/, namespace: 'wyw-in-js' }, (args) => {\n return {\n contents: cssLookup.get(args.path),\n loader: 'css',\n resolveDir: basename(args.path),\n };\n });\n\n const filterRegexp =\n typeof filter === 'string' ? new RegExp(filter) : filter;\n\n build.onLoad({ filter: filterRegexp }, async (args) => {\n const rawCode = readFileSync(args.path, 'utf8');\n const { ext, name: filename } = parse(args.path);\n const loader = ext.replace(/^\\./, '') as Loader;\n\n if (nodeModulesRegex.test(args.path)) {\n return {\n loader,\n contents: rawCode,\n };\n }\n\n if (!options) {\n options = {};\n if ('jsxFactory' in build.initialOptions) {\n options.jsxFactory = build.initialOptions.jsxFactory;\n }\n if ('jsxFragment' in build.initialOptions) {\n options.jsxFragment = build.initialOptions.jsxFragment;\n }\n }\n\n const transformed = transformSync(rawCode, {\n ...options,\n sourcefile: args.path,\n sourcemap: sourceMap,\n loader,\n });\n let { code } = transformed;\n\n if (sourceMap) {\n const esbuildMap = Buffer.from(transformed.map).toString('base64');\n code += `/*# sourceMappingURL=data:application/json;base64,${esbuildMap}*/`;\n }\n\n const transformServices = {\n options: {\n filename: args.path,\n root: process.cwd(),\n preprocessor,\n pluginOptions: rest,\n },\n cache,\n eventEmitter: emitter,\n };\n\n const result = await transform(transformServices, code, asyncResolve);\n\n if (!result.cssText) {\n return {\n contents: code,\n loader,\n resolveDir: dirname(args.path),\n };\n }\n\n let { cssText } = result;\n\n const slug = slugify(cssText);\n const cssFilename = `${filename}_${slug}.wyw.css`;\n\n let contents = `import ${JSON.stringify(cssFilename)}; ${result.code}`;\n\n if (sourceMap && result.cssSourceMapText) {\n const map = Buffer.from(result.cssSourceMapText).toString('base64');\n cssText += `/*# sourceMappingURL=data:application/json;base64,${map}*/`;\n const wywMap = Buffer.from(JSON.stringify(result.sourceMap)).toString(\n 'base64'\n );\n contents += `/*# sourceMappingURL=data:application/json;base64,${wywMap}*/`;\n }\n\n cssLookup.set(cssFilename, cssText);\n\n return {\n contents,\n loader,\n resolveDir: dirname(args.path),\n };\n });\n },\n };\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,23 +1,23 @@
1
1
  {
2
2
  "name": "@wyw-in-js/esbuild",
3
- "version": "0.3.0",
3
+ "version": "0.4.1",
4
4
  "dependencies": {
5
- "@wyw-in-js/shared": "0.3.0",
6
- "@wyw-in-js/transform": "0.3.0"
5
+ "@wyw-in-js/shared": "0.4.1",
6
+ "@wyw-in-js/transform": "0.4.1"
7
7
  },
8
8
  "devDependencies": {
9
9
  "@types/node": "^16.18.55",
10
10
  "esbuild": "^0.15.16",
11
- "@wyw-in-js/babel-config": "0.3.0",
12
- "@wyw-in-js/eslint-config": "0.3.0",
13
- "@wyw-in-js/jest-preset": "0.3.0",
14
- "@wyw-in-js/ts-config": "0.3.0"
11
+ "@wyw-in-js/babel-config": "0.4.1",
12
+ "@wyw-in-js/eslint-config": "0.4.1",
13
+ "@wyw-in-js/jest-preset": "0.4.1",
14
+ "@wyw-in-js/ts-config": "0.4.1"
15
15
  },
16
16
  "engines": {
17
17
  "node": ">=16.0.0"
18
18
  },
19
19
  "exports": {
20
- "import": "./esm/index.js",
20
+ "import": "./esm/index.mjs",
21
21
  "require": "./lib/index.js",
22
22
  "types": "./types/index.d.ts"
23
23
  },
@@ -28,7 +28,7 @@
28
28
  ],
29
29
  "license": "MIT",
30
30
  "main": "lib/index.js",
31
- "module": "esm/index.js",
31
+ "module": "esm/index.mjs",
32
32
  "peerDependencies": {
33
33
  "esbuild": ">=0.12.0"
34
34
  },
@@ -37,7 +37,7 @@
37
37
  },
38
38
  "types": "types/index.d.ts",
39
39
  "scripts": {
40
- "build:esm": "babel src --out-dir esm --extensions '.js,.jsx,.ts,.tsx' --source-maps --delete-dir-on-start",
40
+ "build:esm": "babel src --out-dir esm --out-file-extension .mjs --extensions '.js,.jsx,.ts,.tsx' --source-maps --delete-dir-on-start",
41
41
  "build:lib": "cross-env NODE_ENV=legacy babel src --out-dir lib --extensions '.js,.jsx,.ts,.tsx' --source-maps --delete-dir-on-start",
42
42
  "build:types": "tsc --project ./tsconfig.lib.json --baseUrl . --rootDir ./src",
43
43
  "lint": "eslint --ext .js,.ts ."
package/types/index.d.ts CHANGED
@@ -4,11 +4,13 @@
4
4
  * returns transformed code without template literals and attaches generated source maps
5
5
  */
6
6
  import type { Plugin, TransformOptions } from 'esbuild';
7
- import type { PluginOptions, Preprocessor } from '@wyw-in-js/transform';
7
+ import type { PluginOptions, Preprocessor, IFileReporterOptions } from '@wyw-in-js/transform';
8
8
  type EsbuildPluginOptions = {
9
+ debug?: IFileReporterOptions | false | null | undefined;
9
10
  esbuildOptions?: TransformOptions;
11
+ filter?: RegExp | string;
10
12
  preprocessor?: Preprocessor;
11
13
  sourceMap?: boolean;
12
14
  } & Partial<PluginOptions>;
13
- export default function wywInJS({ sourceMap, preprocessor, esbuildOptions, ...rest }?: EsbuildPluginOptions): Plugin;
15
+ export default function wywInJS({ debug, sourceMap, preprocessor, esbuildOptions, filter, ...rest }?: EsbuildPluginOptions): Plugin;
14
16
  export {};
package/types/index.js CHANGED
@@ -10,13 +10,14 @@ const path_1 = require("path");
10
10
  const esbuild_1 = require("esbuild");
11
11
  const transform_1 = require("@wyw-in-js/transform");
12
12
  const nodeModulesRegex = /^(?:.*[\\/])?node_modules(?:[\\/].*)?$/;
13
- function wywInJS({ sourceMap, preprocessor, esbuildOptions, ...rest } = {}) {
13
+ function wywInJS({ debug, sourceMap, preprocessor, esbuildOptions, filter = /\.(js|jsx|ts|tsx)$/, ...rest } = {}) {
14
14
  let options = esbuildOptions;
15
15
  const cache = new transform_1.TransformCacheCollection();
16
16
  return {
17
17
  name: 'wyw-in-js',
18
18
  setup(build) {
19
19
  const cssLookup = new Map();
20
+ const { emitter, onDone } = (0, transform_1.createFileReporter)(debug ?? false);
20
21
  const asyncResolve = async (token, importer) => {
21
22
  const context = (0, path_1.isAbsolute)(importer)
22
23
  ? (0, path_1.dirname)(importer)
@@ -30,6 +31,9 @@ function wywInJS({ sourceMap, preprocessor, esbuildOptions, ...rest } = {}) {
30
31
  }
31
32
  return result.path.replace(/\\/g, path_1.posix.sep);
32
33
  };
34
+ build.onEnd(() => {
35
+ onDone(process.cwd());
36
+ });
33
37
  build.onResolve({ filter: /\.wyw\.css$/ }, (args) => {
34
38
  return {
35
39
  namespace: 'wyw-in-js',
@@ -43,7 +47,8 @@ function wywInJS({ sourceMap, preprocessor, esbuildOptions, ...rest } = {}) {
43
47
  resolveDir: (0, path_1.basename)(args.path),
44
48
  };
45
49
  });
46
- build.onLoad({ filter: /\.(js|jsx|ts|tsx)$/ }, async (args) => {
50
+ const filterRegexp = typeof filter === 'string' ? new RegExp(filter) : filter;
51
+ build.onLoad({ filter: filterRegexp }, async (args) => {
47
52
  const rawCode = (0, fs_1.readFileSync)(args.path, 'utf8');
48
53
  const { ext, name: filename } = (0, path_1.parse)(args.path);
49
54
  const loader = ext.replace(/^\./, '');
@@ -81,6 +86,7 @@ function wywInJS({ sourceMap, preprocessor, esbuildOptions, ...rest } = {}) {
81
86
  pluginOptions: rest,
82
87
  },
83
88
  cache,
89
+ eventEmitter: emitter,
84
90
  };
85
91
  const result = await (0, transform_1.transform)(transformServices, code, asyncResolve);
86
92
  if (!result.cssText) {
package/esm/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["readFileSync","basename","dirname","isAbsolute","join","parse","posix","transformSync","slugify","transform","TransformCacheCollection","nodeModulesRegex","wywInJS","sourceMap","preprocessor","esbuildOptions","rest","options","cache","name","setup","build","cssLookup","Map","asyncResolve","token","importer","context","process","cwd","result","resolve","resolveDir","kind","errors","length","Error","path","replace","sep","onResolve","filter","args","namespace","onLoad","contents","get","loader","rawCode","ext","filename","test","initialOptions","jsxFactory","jsxFragment","transformed","sourcefile","sourcemap","code","esbuildMap","Buffer","from","map","toString","transformServices","root","pluginOptions","cssText","slug","cssFilename","JSON","stringify","cssSourceMapText","wywMap","set"],"sources":["../src/index.ts"],"sourcesContent":["/**\n * This file contains an esbuild loader for wyw-in-js.\n * It uses the transform.ts function to generate class names from source code,\n * returns transformed code without template literals and attaches generated source maps\n */\n\nimport { readFileSync } from 'fs';\nimport { basename, dirname, isAbsolute, join, parse, posix } from 'path';\n\nimport type { Plugin, TransformOptions, Loader } from 'esbuild';\nimport { transformSync } from 'esbuild';\n\nimport type { PluginOptions, Preprocessor } from '@wyw-in-js/transform';\nimport {\n slugify,\n transform,\n TransformCacheCollection,\n} from '@wyw-in-js/transform';\n\ntype EsbuildPluginOptions = {\n esbuildOptions?: TransformOptions;\n preprocessor?: Preprocessor;\n sourceMap?: boolean;\n} & Partial<PluginOptions>;\n\nconst nodeModulesRegex = /^(?:.*[\\\\/])?node_modules(?:[\\\\/].*)?$/;\n\nexport default function wywInJS({\n sourceMap,\n preprocessor,\n esbuildOptions,\n ...rest\n}: EsbuildPluginOptions = {}): Plugin {\n let options = esbuildOptions;\n const cache = new TransformCacheCollection();\n return {\n name: 'wyw-in-js',\n setup(build) {\n const cssLookup = new Map<string, string>();\n\n const asyncResolve = async (\n token: string,\n importer: string\n ): Promise<string> => {\n const context = isAbsolute(importer)\n ? dirname(importer)\n : join(process.cwd(), dirname(importer));\n\n const result = await build.resolve(token, {\n resolveDir: context,\n kind: 'import-statement',\n });\n\n if (result.errors.length > 0) {\n throw new Error(`Cannot resolve ${token}`);\n }\n\n return result.path.replace(/\\\\/g, posix.sep);\n };\n\n build.onResolve({ filter: /\\.wyw\\.css$/ }, (args) => {\n return {\n namespace: 'wyw-in-js',\n path: args.path,\n };\n });\n\n build.onLoad({ filter: /.*/, namespace: 'wyw-in-js' }, (args) => {\n return {\n contents: cssLookup.get(args.path),\n loader: 'css',\n resolveDir: basename(args.path),\n };\n });\n\n build.onLoad({ filter: /\\.(js|jsx|ts|tsx)$/ }, async (args) => {\n const rawCode = readFileSync(args.path, 'utf8');\n const { ext, name: filename } = parse(args.path);\n const loader = ext.replace(/^\\./, '') as Loader;\n\n if (nodeModulesRegex.test(args.path)) {\n return {\n loader,\n contents: rawCode,\n };\n }\n\n if (!options) {\n options = {};\n if ('jsxFactory' in build.initialOptions) {\n options.jsxFactory = build.initialOptions.jsxFactory;\n }\n if ('jsxFragment' in build.initialOptions) {\n options.jsxFragment = build.initialOptions.jsxFragment;\n }\n }\n\n const transformed = transformSync(rawCode, {\n ...options,\n sourcefile: args.path,\n sourcemap: sourceMap,\n loader,\n });\n let { code } = transformed;\n\n if (sourceMap) {\n const esbuildMap = Buffer.from(transformed.map).toString('base64');\n code += `/*# sourceMappingURL=data:application/json;base64,${esbuildMap}*/`;\n }\n\n const transformServices = {\n options: {\n filename: args.path,\n root: process.cwd(),\n preprocessor,\n pluginOptions: rest,\n },\n cache,\n };\n\n const result = await transform(transformServices, code, asyncResolve);\n\n if (!result.cssText) {\n return {\n contents: code,\n loader,\n resolveDir: dirname(args.path),\n };\n }\n\n let { cssText } = result;\n\n const slug = slugify(cssText);\n const cssFilename = `${filename}_${slug}.wyw.css`;\n\n let contents = `import ${JSON.stringify(cssFilename)}; ${result.code}`;\n\n if (sourceMap && result.cssSourceMapText) {\n const map = Buffer.from(result.cssSourceMapText).toString('base64');\n cssText += `/*# sourceMappingURL=data:application/json;base64,${map}*/`;\n const wywMap = Buffer.from(JSON.stringify(result.sourceMap)).toString(\n 'base64'\n );\n contents += `/*# sourceMappingURL=data:application/json;base64,${wywMap}*/`;\n }\n\n cssLookup.set(cssFilename, cssText);\n\n return {\n contents,\n loader,\n resolveDir: dirname(args.path),\n };\n });\n },\n };\n}\n"],"mappings":"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"}