@common-stack/rollup-vite-utils 4.0.1-alpha.49 → 4.0.1-alpha.51

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.
@@ -1,7 +1,9 @@
1
- export default function addJsExtensionToImportsPlugin(packages: any): {
1
+ import * as t from '@babel/types';
2
+ import { NodePath } from '@babel/traverse';
3
+ declare const addJsExtensionToImportsPlugin: (packages: string[] | '*', needToAddIndexJs?: string[]) => {
2
4
  name: string;
3
- transform(code: any, id: any): {
4
- code: any;
5
- map: any;
5
+ visitor: {
6
+ ImportDeclaration(path: NodePath<t.ImportDeclaration>): void;
6
7
  };
7
8
  };
9
+ export default addJsExtensionToImportsPlugin;
@@ -1,39 +1,45 @@
1
- import {parse}from'@babel/parser';import generateSource from'@babel/generator';import traverseSource from'@babel/traverse';// to support esm default
2
- // https://github.com/babel/babel/issues/15269#issuecomment-1505804243
3
- const traverse = traverseSource.default ?? traverseSource;
4
- const generate = generateSource.default ?? generateSource;
5
- function addJsExtensionToImportsPlugin(packages) {
1
+ const addJsExtensionToImportsPlugin = (packages, needToAddIndexJs = []) => {
2
+ // Add known packages that need `/index.js` if they are not already included
3
+ const knownNeedToAddIndexJs = ['@apollo/client'];
4
+ needToAddIndexJs = Array.from(new Set([...needToAddIndexJs, ...knownNeedToAddIndexJs]));
6
5
  return {
7
6
  name: 'add-js-extension-to-imports',
8
- transform(code, id) {
9
- // Only apply the transformation to TypeScript and JavaScript files
10
- if (!/\.tsx?$/.test(id))
11
- return null;
12
- const ast = parse(code, {
13
- sourceType: 'module',
14
- plugins: ['typescript', 'jsx'], // Adjusted to 'typescript' for .tsx files
15
- });
16
- traverse(ast, {
17
- ImportDeclaration(path) {
18
- const source = path.node.source.value;
19
- packages.forEach(pkg => {
20
- // Append ".js" to imports from specified packages if not already present
21
- if (source.startsWith(pkg) && !source.endsWith('.js')) {
22
- if (pkg === '@apollo/client' && (source === pkg || source === `${pkg}/`)) {
23
- path.node.source.value = source.endsWith('/') ? `${source}index.js` : `${source}/index.js`;
24
- }
25
- else {
26
- path.node.source.value = `${source}.js`;
27
- }
28
- }
29
- });
30
- },
31
- });
32
- const output = generate(ast, {}, code);
33
- return {
34
- code: output.code,
35
- map: output.map,
36
- };
7
+ visitor: {
8
+ ImportDeclaration(path) {
9
+ const source = path.node.source.value;
10
+ // Function to extract package name from the import source
11
+ const getPackageName = (importPath) => {
12
+ if (importPath.startsWith('@')) {
13
+ // Scoped package
14
+ const match = importPath.match(/^(@[^/]+\/[^/]+)/);
15
+ return match ? match[1] : null;
16
+ }
17
+ else {
18
+ // Normal package
19
+ const match = importPath.match(/^([^/]+)/);
20
+ return match ? match[1] : null;
21
+ }
22
+ };
23
+ const packageName = getPackageName(source);
24
+ // Determine if we should transform the import based on the package patterns
25
+ !source.startsWith('@');
26
+ const isInExceptionList = packageName && needToAddIndexJs.includes(packageName);
27
+ const isModularPackage = source.startsWith('@');
28
+ const hasAdditionalSlashes = isModularPackage && source.split('/').length > 2;
29
+ const shouldTransform = (packages === '*' && source.includes('/') && !isModularPackage) ||
30
+ (packages === '*' && isModularPackage && hasAdditionalSlashes) ||
31
+ (isModularPackage && isInExceptionList) ||
32
+ (packageName && packages.includes(packageName));
33
+ // Append ".js" or "/index.js" to imports if they match the criteria and don't already end with ".js"
34
+ if (shouldTransform && !source.endsWith('.js')) {
35
+ if (isInExceptionList) {
36
+ path.node.source.value = `${source}/index.js`;
37
+ }
38
+ else {
39
+ path.node.source.value = `${source}.js`;
40
+ }
41
+ }
42
+ },
37
43
  },
38
44
  };
39
- }export{addJsExtensionToImportsPlugin as default};//# sourceMappingURL=rollupPluginAddJsExtension.js.map
45
+ };export{addJsExtensionToImportsPlugin as default};//# sourceMappingURL=rollupPluginAddJsExtension.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"rollupPluginAddJsExtension.js","sources":["../../src/rollup/rollupPluginAddJsExtension.ts"],"sourcesContent":[null],"names":[],"mappings":"2HAIA;AACA;AACA,MAAM,QAAQ,GAAI,cAAsB,CAAC,OAAO,IAAI,cAAc,CAAC;AACnE,MAAM,QAAQ,GAAI,cAAsB,CAAC,OAAO,IAAI,cAAc,CAAC;AAE3C,SAAA,6BAA6B,CAAC,QAAQ,EAAA;IAC1D,OAAO;AACH,QAAA,IAAI,EAAE,6BAA6B;QACnC,SAAS,CAAC,IAAI,EAAE,EAAE,EAAA;;AAEd,YAAA,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;AAAE,gBAAA,OAAO,IAAI,CAAC;AAErC,YAAA,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,EAAE;AACpB,gBAAA,UAAU,EAAE,QAAQ;AACpB,gBAAA,OAAO,EAAE,CAAC,YAAY,EAAE,KAAK,CAAC;AACjC,aAAA,CAAC,CAAC;YAEH,QAAQ,CAAC,GAAG,EAAE;AACV,gBAAA,iBAAiB,CAAC,IAAI,EAAA;oBAClB,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;AAEtC,oBAAA,QAAQ,CAAC,OAAO,CAAC,GAAG,IAAG;;AAEnB,wBAAA,IAAI,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;AACnD,4BAAA,IAAI,GAAG,KAAK,gBAAgB,KAAK,MAAM,KAAK,GAAG,IAAI,MAAM,KAAK,CAAG,EAAA,GAAG,CAAG,CAAA,CAAA,CAAC,EAAE;gCACtE,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAA,EAAG,MAAM,CAAA,QAAA,CAAU,GAAG,CAAA,EAAG,MAAM,CAAA,SAAA,CAAW,CAAC;6BAC9F;iCAAM;gCACH,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAA,EAAG,MAAM,CAAA,GAAA,CAAK,CAAC;6BAC3C;yBACJ;AACL,qBAAC,CAAC,CAAC;iBACN;AACJ,aAAA,CAAC,CAAC;YAEH,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;YACvC,OAAO;gBACH,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,GAAG,EAAE,MAAM,CAAC,GAAG;aAClB,CAAC;SACL;KACJ,CAAC;AACN"}
1
+ {"version":3,"file":"rollupPluginAddJsExtension.js","sources":["../../src/rollup/rollupPluginAddJsExtension.ts"],"sourcesContent":[null],"names":[],"mappings":"AAGM,MAAA,6BAA6B,GAAG,CAAC,QAAwB,EAAE,gBAA6B,GAAA,EAAE,KAAI;;AAEhG,IAAA,MAAM,qBAAqB,GAAG,CAAC,gBAAgB,CAAC,CAAC;AACjD,IAAA,gBAAgB,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,gBAAgB,EAAE,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAExF,OAAO;AACH,QAAA,IAAI,EAAE,6BAA6B;AACnC,QAAA,OAAO,EAAE;AACL,YAAA,iBAAiB,CAAC,IAAmC,EAAA;gBACjD,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;;AAGtC,gBAAA,MAAM,cAAc,GAAG,CAAC,UAAkB,KAAI;AAC1C,oBAAA,IAAI,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;;wBAE5B,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;AACnD,wBAAA,OAAO,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;qBAClC;yBAAM;;wBAEH,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;AAC3C,wBAAA,OAAO,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;qBAClC;AACL,iBAAC,CAAC;AAEF,gBAAA,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;;gBAGnB,CAAC,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBAChD,MAAM,iBAAiB,GAAG,WAAW,IAAI,gBAAgB,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;gBAChF,MAAM,gBAAgB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AAChD,gBAAA,MAAM,oBAAoB,GAAG,gBAAgB,IAAI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;AAE9E,gBAAA,MAAM,eAAe,GACjB,CAAC,QAAQ,KAAK,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB;AAC9D,qBAAC,QAAQ,KAAK,GAAG,IAAI,gBAAgB,IAAI,oBAAoB,CAAC;qBAC7D,gBAAgB,IAAI,iBAAiB,CAAC;qBACtC,WAAW,IAAI,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC;;gBAGpD,IAAI,eAAe,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;oBAC5C,IAAI,iBAAiB,EAAE;wBACnB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAA,EAAG,MAAM,CAAA,SAAA,CAAW,CAAC;qBACjD;yBAAM;wBACH,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAA,EAAG,MAAM,CAAA,GAAA,CAAK,CAAC;qBAC3C;iBACJ;aACJ;AACJ,SAAA;KACJ,CAAC;AACN"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@common-stack/rollup-vite-utils",
3
- "version": "4.0.1-alpha.49",
3
+ "version": "4.0.1-alpha.51",
4
4
  "description": "Client Module for react app",
5
5
  "homepage": "https://github.com/cdmbase/fullstack-pro#readme",
6
6
  "bugs": {
@@ -54,5 +54,5 @@
54
54
  "typescript": {
55
55
  "definition": "lib/index.d.ts"
56
56
  },
57
- "gitHead": "ef0042cfecdbb351d2c044370135f5fbb746c543"
57
+ "gitHead": "e03f5976e7390fb98a898aedf97ad692ef54f78b"
58
58
  }