@nx/vite 21.0.0-beta.8 → 21.0.0-beta.9

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.
Files changed (26) hide show
  1. package/migrations.json +0 -90
  2. package/package.json +3 -3
  3. package/src/migrations/update-17-1-0/move-target-defaults.d.ts +0 -2
  4. package/src/migrations/update-17-1-0/move-target-defaults.js +0 -77
  5. package/src/migrations/update-17-1-0/move-target-defaults.js.map +0 -1
  6. package/src/migrations/update-17-2-0/lib/add-file-replacements.d.ts +0 -2
  7. package/src/migrations/update-17-2-0/lib/add-file-replacements.js +0 -67
  8. package/src/migrations/update-17-2-0/lib/add-file-replacements.js.map +0 -1
  9. package/src/migrations/update-17-2-0/lib/edit-build-config.d.ts +0 -2
  10. package/src/migrations/update-17-2-0/lib/edit-build-config.js +0 -120
  11. package/src/migrations/update-17-2-0/lib/edit-build-config.js.map +0 -1
  12. package/src/migrations/update-17-2-0/lib/edit-test-config.d.ts +0 -2
  13. package/src/migrations/update-17-2-0/lib/edit-test-config.js +0 -82
  14. package/src/migrations/update-17-2-0/lib/edit-test-config.js.map +0 -1
  15. package/src/migrations/update-17-2-0/lib/vite-config-with-additional-js.fixture.d.ts +0 -1
  16. package/src/migrations/update-17-2-0/lib/vite-config-with-additional-js.fixture.js +0 -73
  17. package/src/migrations/update-17-2-0/lib/vite-config-with-additional-js.fixture.js.map +0 -1
  18. package/src/migrations/update-17-2-0/update-vite-config.d.ts +0 -5
  19. package/src/migrations/update-17-2-0/update-vite-config.js +0 -70
  20. package/src/migrations/update-17-2-0/update-vite-config.js.map +0 -1
  21. package/src/migrations/update-17-3-0/lib/fix-coverage-and-reporters.d.ts +0 -3
  22. package/src/migrations/update-17-3-0/lib/fix-coverage-and-reporters.js +0 -119
  23. package/src/migrations/update-17-3-0/lib/fix-coverage-and-reporters.js.map +0 -1
  24. package/src/migrations/update-17-3-0/vitest-coverage-and-reporters.d.ts +0 -2
  25. package/src/migrations/update-17-3-0/vitest-coverage-and-reporters.js +0 -45
  26. package/src/migrations/update-17-3-0/vitest-coverage-and-reporters.js.map +0 -1
package/migrations.json CHANGED
@@ -1,20 +1,5 @@
1
1
  {
2
2
  "generators": {
3
- "move-target-defaults": {
4
- "version": "17.1.0-beta.2",
5
- "description": "Move target defaults",
6
- "implementation": "./src/migrations/update-17-1-0/move-target-defaults"
7
- },
8
- "update-vite-config": {
9
- "version": "17.2.0-beta.10",
10
- "description": "Update vite config.",
11
- "implementation": "./src/migrations/update-17-2-0/update-vite-config"
12
- },
13
- "vitest-coverage-and-reporters": {
14
- "version": "17.3.0-beta.0",
15
- "description": "Move the vitest coverage thresholds in their own object if exists and add reporters.",
16
- "implementation": "./src/migrations/update-17-3-0/vitest-coverage-and-reporters"
17
- },
18
3
  "update-19-6-0-add-depends-on-for-preview-server": {
19
4
  "version": "19.6.0-beta.0",
20
5
  "description": "Add dependsOn: [build] to preview targets using preview-server",
@@ -77,81 +62,6 @@
77
62
  "alwaysAddToPackageJson": false
78
63
  }
79
64
  }
80
- },
81
- "18.1.0": {
82
- "version": "18.1.0-beta.1",
83
- "packages": {
84
- "vitest": {
85
- "version": "^1.3.1",
86
- "alwaysAddToPackageJson": false
87
- },
88
- "@vitest/coverage-v8": {
89
- "version": "^1.3.1",
90
- "alwaysAddToPackageJson": false
91
- },
92
- "@vitest/ui": {
93
- "version": "^1.3.1",
94
- "alwaysAddToPackageJson": false
95
- },
96
- "@vitest/coverage-istanbul": {
97
- "version": "^1.3.1",
98
- "alwaysAddToPackageJson": false
99
- }
100
- }
101
- },
102
- "17.3.0": {
103
- "version": "17.3.0-beta.0",
104
- "packages": {
105
- "vitest": {
106
- "version": "^1.0.4",
107
- "alwaysAddToPackageJson": false
108
- },
109
- "@vitest/coverage-v8": {
110
- "version": "^1.0.4",
111
- "alwaysAddToPackageJson": false
112
- },
113
- "@vitest/ui": {
114
- "version": "^1.0.4",
115
- "alwaysAddToPackageJson": false
116
- },
117
- "@vitest/coverage-istanbul": {
118
- "version": "^1.0.4",
119
- "alwaysAddToPackageJson": false
120
- }
121
- }
122
- },
123
- "17.2.0": {
124
- "version": "17.2.0-beta.2",
125
- "packages": {
126
- "vite": {
127
- "version": "^5.0.0",
128
- "alwaysAddToPackageJson": false
129
- },
130
- "@vitejs/plugin-react": {
131
- "version": "^4.2.0",
132
- "alwaysAddToPackageJson": false
133
- },
134
- "@vitejs/plugin-react-swc": {
135
- "version": "^3.5.0",
136
- "alwaysAddToPackageJson": false
137
- },
138
- "vitest": {
139
- "version": "~0.34.6",
140
- "alwaysAddToPackageJson": false
141
- },
142
- "@vitest/coverage-v8": {
143
- "version": "~0.34.6",
144
- "alwaysAddToPackageJson": false
145
- },
146
- "@vitest/ui": {
147
- "version": "~0.34.6",
148
- "alwaysAddToPackageJson": false
149
- },
150
- "@vitest/coverage-istanbul": {
151
- "version": "~0.34.6",
152
- "alwaysAddToPackageJson": false
153
- }
154
- }
155
65
  }
156
66
  }
157
67
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nx/vite",
3
- "version": "21.0.0-beta.8",
3
+ "version": "21.0.0-beta.9",
4
4
  "private": false,
5
5
  "description": "The Nx Plugin for building and testing applications using Vite",
6
6
  "repository": {
@@ -30,11 +30,11 @@
30
30
  "migrations": "./migrations.json"
31
31
  },
32
32
  "dependencies": {
33
- "@nx/devkit": "21.0.0-beta.8",
33
+ "@nx/devkit": "21.0.0-beta.9",
34
34
  "@phenomnomnominal/tsquery": "~5.0.1",
35
35
  "@swc/helpers": "~0.5.0",
36
36
  "enquirer": "~2.3.6",
37
- "@nx/js": "21.0.0-beta.8",
37
+ "@nx/js": "21.0.0-beta.9",
38
38
  "tsconfig-paths": "^4.1.2",
39
39
  "minimatch": "9.0.3",
40
40
  "semver": "^7.6.3"
@@ -1,2 +0,0 @@
1
- import { Tree } from '@nx/devkit';
2
- export default function update(tree: Tree): Promise<void>;
@@ -1,77 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "default", {
3
- enumerable: true,
4
- get: function() {
5
- return update;
6
- }
7
- });
8
- const _devkit = require("@nx/devkit");
9
- const _executoroptionsutils = require("@nx/devkit/src/generators/executor-options-utils");
10
- const _projectconfigurationutils = require("nx/src/project-graph/utils/project-configuration-utils");
11
- async function update(tree) {
12
- var _nxJson_targetDefaults, _nxJson_namedInputs;
13
- var _nxJson, _vitestDefaults, _vitestDefaults1;
14
- const nxJson = (0, _devkit.readNxJson)(tree);
15
- // Don't override anything if there are already target defaults for vitest
16
- if ((_nxJson_targetDefaults = nxJson.targetDefaults) == null ? void 0 : _nxJson_targetDefaults['@nx/vite:test']) {
17
- return;
18
- }
19
- var _targetDefaults;
20
- (_targetDefaults = (_nxJson = nxJson).targetDefaults) != null ? _targetDefaults : _nxJson.targetDefaults = {};
21
- /**
22
- * A set of targets which does not use any other executors
23
- */ const vitestTargets = new Set();
24
- const graph = await (0, _devkit.createProjectGraphAsync)();
25
- const projectMap = (0, _devkit.getProjects)(tree);
26
- (0, _executoroptionsutils.forEachExecutorOptionsInGraph)(graph, '@nx/vite:test', (value, proj, targetName)=>{
27
- vitestTargets.add(targetName);
28
- });
29
- // Workspace does not use vitest
30
- if (vitestTargets.size === 0) {
31
- return;
32
- }
33
- // Use the project graph nodes so that targets which are inferred are considered
34
- const projects = graph.nodes;
35
- const vitestDefaults = nxJson.targetDefaults['@nx/vite:test'] = {};
36
- // All vitest targets have the same name
37
- if (vitestTargets.size === 1) {
38
- const targetName = Array.from(vitestTargets)[0];
39
- if (nxJson.targetDefaults[targetName]) {
40
- Object.assign(vitestDefaults, nxJson.targetDefaults[targetName]);
41
- }
42
- }
43
- var _cache;
44
- (_cache = (_vitestDefaults = vitestDefaults).cache) != null ? _cache : _vitestDefaults.cache = true;
45
- const inputs = [
46
- 'default'
47
- ];
48
- inputs.push(((_nxJson_namedInputs = nxJson.namedInputs) == null ? void 0 : _nxJson_namedInputs.production) ? '^production' : '^default');
49
- var _inputs;
50
- (_inputs = (_vitestDefaults1 = vitestDefaults).inputs) != null ? _inputs : _vitestDefaults1.inputs = inputs;
51
- // Cleanup old target defaults
52
- for (const [targetDefaultKey, targetDefault] of Object.entries(nxJson.targetDefaults)){
53
- if (!isTargetDefaultUsed(targetDefault, nxJson.targetDefaults, projects, projectMap)) {
54
- delete nxJson.targetDefaults[targetDefaultKey];
55
- }
56
- }
57
- (0, _devkit.updateNxJson)(tree, nxJson);
58
- await (0, _devkit.formatFiles)(tree);
59
- }
60
- /**
61
- * Checks every target on every project to see if one of them uses the target default
62
- */ function isTargetDefaultUsed(targetDefault, targetDefaults, projects, projectMap) {
63
- for (const p of Object.values(projects)){
64
- var _p_data;
65
- var _p_data_targets;
66
- for(const targetName in (_p_data_targets = (_p_data = p.data) == null ? void 0 : _p_data.targets) != null ? _p_data_targets : {}){
67
- var // It might seem like we should use the graph here too but we don't want to pass an executor which was processed in the graph
68
- _projectMap_get_targets_targetName, _projectMap_get_targets;
69
- if ((0, _projectconfigurationutils.readTargetDefaultsForTarget)(targetName, targetDefaults, (_projectMap_get_targets = projectMap.get(p.name).targets) == null ? void 0 : (_projectMap_get_targets_targetName = _projectMap_get_targets[targetName]) == null ? void 0 : _projectMap_get_targets_targetName.executor) === targetDefault) {
70
- return true;
71
- }
72
- }
73
- }
74
- return false;
75
- }
76
-
77
- //# sourceMappingURL=move-target-defaults.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../packages/vite/src/migrations/update-17-1-0/move-target-defaults.ts"],"sourcesContent":["import {\n createProjectGraphAsync,\n formatFiles,\n getProjects,\n ProjectConfiguration,\n ProjectGraphProjectNode,\n readNxJson,\n TargetConfiguration,\n TargetDefaults,\n Tree,\n updateNxJson,\n} from '@nx/devkit';\nimport { forEachExecutorOptionsInGraph } from '@nx/devkit/src/generators/executor-options-utils';\nimport { VitestExecutorOptions } from '../../executors/test/schema';\nimport { readTargetDefaultsForTarget } from 'nx/src/project-graph/utils/project-configuration-utils';\n\nexport default async function update(tree: Tree) {\n const nxJson = readNxJson(tree);\n\n // Don't override anything if there are already target defaults for vitest\n if (nxJson.targetDefaults?.['@nx/vite:test']) {\n return;\n }\n\n nxJson.targetDefaults ??= {};\n\n /**\n * A set of targets which does not use any other executors\n */\n const vitestTargets = new Set<string>();\n const graph = await createProjectGraphAsync();\n const projectMap = getProjects(tree);\n\n forEachExecutorOptionsInGraph(\n graph,\n '@nx/vite:test',\n (value, proj, targetName) => {\n vitestTargets.add(targetName);\n }\n );\n\n // Workspace does not use vitest\n if (vitestTargets.size === 0) {\n return;\n }\n\n // Use the project graph nodes so that targets which are inferred are considered\n const projects = graph.nodes;\n\n const vitestDefaults: TargetConfiguration<Partial<VitestExecutorOptions>> =\n (nxJson.targetDefaults['@nx/vite:test'] = {});\n\n // All vitest targets have the same name\n if (vitestTargets.size === 1) {\n const targetName = Array.from(vitestTargets)[0];\n if (nxJson.targetDefaults[targetName]) {\n Object.assign(vitestDefaults, nxJson.targetDefaults[targetName]);\n }\n }\n\n vitestDefaults.cache ??= true;\n\n const inputs = ['default'];\n inputs.push(nxJson.namedInputs?.production ? '^production' : '^default');\n vitestDefaults.inputs ??= inputs;\n\n // Cleanup old target defaults\n for (const [targetDefaultKey, targetDefault] of Object.entries(\n nxJson.targetDefaults\n )) {\n if (\n !isTargetDefaultUsed(\n targetDefault,\n nxJson.targetDefaults,\n projects,\n projectMap\n )\n ) {\n delete nxJson.targetDefaults[targetDefaultKey];\n }\n }\n\n updateNxJson(tree, nxJson);\n\n await formatFiles(tree);\n}\n\n/**\n * Checks every target on every project to see if one of them uses the target default\n */\nfunction isTargetDefaultUsed(\n targetDefault: Partial<TargetConfiguration>,\n targetDefaults: TargetDefaults,\n projects: Record<string, ProjectGraphProjectNode>,\n projectMap: Map<string, ProjectConfiguration>\n) {\n for (const p of Object.values(projects)) {\n for (const targetName in p.data?.targets ?? {}) {\n if (\n readTargetDefaultsForTarget(\n targetName,\n targetDefaults,\n // It might seem like we should use the graph here too but we don't want to pass an executor which was processed in the graph\n projectMap.get(p.name).targets?.[targetName]?.executor\n ) === targetDefault\n ) {\n return true;\n }\n }\n }\n return false;\n}\n"],"names":["update","tree","nxJson","vitestDefaults","readNxJson","targetDefaults","vitestTargets","Set","graph","createProjectGraphAsync","projectMap","getProjects","forEachExecutorOptionsInGraph","value","proj","targetName","add","size","projects","nodes","Array","from","Object","assign","cache","inputs","push","namedInputs","production","targetDefaultKey","targetDefault","entries","isTargetDefaultUsed","updateNxJson","formatFiles","p","values","data","targets","readTargetDefaultsForTarget","get","name","executor"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";+BAgBA;;;eAA8BA;;;wBALvB;sCACuC;2CAEF;AAE7B,eAAeA,OAAOC,IAAU;QAIzCC,wBA2CQA;QAvCZA,SAoCAC,iBAIAA;IA/CA,MAAMD,SAASE,IAAAA,kBAAU,EAACH;IAE1B,0EAA0E;IAC1E,KAAIC,yBAAAA,OAAOG,cAAc,qBAArBH,sBAAuB,CAAC,gBAAgB,EAAE;QAC5C;IACF;;IAEAA,oBAAAA,UAAAA,QAAOG,4CAAPH,QAAOG,iBAAmB,CAAC;IAE3B;;GAEC,GACD,MAAMC,gBAAgB,IAAIC;IAC1B,MAAMC,QAAQ,MAAMC,IAAAA,+BAAuB;IAC3C,MAAMC,aAAaC,IAAAA,mBAAW,EAACV;IAE/BW,IAAAA,mDAA6B,EAC3BJ,OACA,iBACA,CAACK,OAAOC,MAAMC;QACZT,cAAcU,GAAG,CAACD;IACpB;IAGF,gCAAgC;IAChC,IAAIT,cAAcW,IAAI,KAAK,GAAG;QAC5B;IACF;IAEA,gFAAgF;IAChF,MAAMC,WAAWV,MAAMW,KAAK;IAE5B,MAAMhB,iBACHD,OAAOG,cAAc,CAAC,gBAAgB,GAAG,CAAC;IAE7C,wCAAwC;IACxC,IAAIC,cAAcW,IAAI,KAAK,GAAG;QAC5B,MAAMF,aAAaK,MAAMC,IAAI,CAACf,cAAc,CAAC,EAAE;QAC/C,IAAIJ,OAAOG,cAAc,CAACU,WAAW,EAAE;YACrCO,OAAOC,MAAM,CAACpB,gBAAgBD,OAAOG,cAAc,CAACU,WAAW;QACjE;IACF;;IAEAZ,WAAAA,kBAAAA,gBAAeqB,0BAAfrB,gBAAeqB,QAAU;IAEzB,MAAMC,SAAS;QAAC;KAAU;IAC1BA,OAAOC,IAAI,CAACxB,EAAAA,sBAAAA,OAAOyB,WAAW,qBAAlBzB,oBAAoB0B,UAAU,IAAG,gBAAgB;;IAC7DzB,YAAAA,mBAAAA,gBAAesB,4BAAftB,iBAAesB,SAAWA;IAE1B,8BAA8B;IAC9B,KAAK,MAAM,CAACI,kBAAkBC,cAAc,IAAIR,OAAOS,OAAO,CAC5D7B,OAAOG,cAAc,EACpB;QACD,IACE,CAAC2B,oBACCF,eACA5B,OAAOG,cAAc,EACrBa,UACAR,aAEF;YACA,OAAOR,OAAOG,cAAc,CAACwB,iBAAiB;QAChD;IACF;IAEAI,IAAAA,oBAAY,EAAChC,MAAMC;IAEnB,MAAMgC,IAAAA,mBAAW,EAACjC;AACpB;AAEA;;CAEC,GACD,SAAS+B,oBACPF,aAA2C,EAC3CzB,cAA8B,EAC9Ba,QAAiD,EACjDR,UAA6C;IAE7C,KAAK,MAAMyB,KAAKb,OAAOc,MAAM,CAAClB,UAAW;YACdiB;YAAAA;QAAzB,IAAK,MAAMpB,cAAcoB,CAAAA,mBAAAA,UAAAA,EAAEE,IAAI,qBAANF,QAAQG,OAAO,YAAfH,kBAAmB,CAAC,EAAG;gBAK1C,6HAA6H;YAC7HzB,oCAAAA;YALJ,IACE6B,IAAAA,sDAA2B,EACzBxB,YACAV,iBAEAK,0BAAAA,WAAW8B,GAAG,CAACL,EAAEM,IAAI,EAAEH,OAAO,sBAA9B5B,qCAAAA,uBAAgC,CAACK,WAAW,qBAA5CL,mCAA8CgC,QAAQ,MAClDZ,eACN;gBACA,OAAO;YACT;QACF;IACF;IACA,OAAO;AACT"}
@@ -1,2 +0,0 @@
1
- import { FileReplacement } from '../../../../plugins/rollup-replace-files.plugin';
2
- export declare function addFileReplacements(configContents: string, fileReplacements: FileReplacement[], configPath: string): string;
@@ -1,67 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "addFileReplacements", {
3
- enumerable: true,
4
- get: function() {
5
- return addFileReplacements;
6
- }
7
- });
8
- const _devkit = require("@nx/devkit");
9
- const _tsquery = require("@phenomnomnominal/tsquery");
10
- const _updateviteconfig = require("../update-vite-config");
11
- function addFileReplacements(configContents, fileReplacements, configPath) {
12
- var _tsquery_query, _tsquery_query1, _tsquery_query2;
13
- const configNode = (0, _updateviteconfig.getConfigNode)(configContents);
14
- if (!configNode) {
15
- (0, _updateviteconfig.notFoundWarning)(configPath);
16
- return configContents;
17
- }
18
- const pluginsObject = (_tsquery_query = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="plugins"])`)) == null ? void 0 : _tsquery_query[0];
19
- const replaceFilesPlugin = (_tsquery_query1 = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="plugins"]) CallExpression:has(Identifier[name="replaceFiles"])`)) == null ? void 0 : _tsquery_query1[0];
20
- const firstImportDeclaration = (_tsquery_query2 = _tsquery.tsquery.query(configContents, 'ImportDeclaration')) == null ? void 0 : _tsquery_query2[0];
21
- if (pluginsObject) {
22
- if (replaceFilesPlugin) {
23
- return configContents;
24
- } else {
25
- return (0, _devkit.applyChangesToString)(configContents, [
26
- {
27
- type: _devkit.ChangeType.Insert,
28
- index: pluginsObject.getStart() + `plugins: [`.length + 1,
29
- text: `replaceFiles(${JSON.stringify(fileReplacements)}),`
30
- },
31
- firstImportDeclaration ? {
32
- type: _devkit.ChangeType.Insert,
33
- index: firstImportDeclaration.getStart(),
34
- text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';\n`
35
- } : {
36
- type: _devkit.ChangeType.Insert,
37
- index: 0,
38
- text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';\n`
39
- }
40
- ]);
41
- }
42
- } else {
43
- var _tsquery_query3;
44
- const foundDefineConfig = (_tsquery_query3 = _tsquery.tsquery.query(configContents, 'CallExpression:has(Identifier[name="defineConfig"])')) == null ? void 0 : _tsquery_query3[0];
45
- if (!foundDefineConfig) {
46
- return;
47
- }
48
- return (0, _devkit.applyChangesToString)(configContents, [
49
- {
50
- type: _devkit.ChangeType.Insert,
51
- index: configNode.getStart() + 1,
52
- text: `plugins: [replaceFiles(${JSON.stringify(fileReplacements)})],`
53
- },
54
- firstImportDeclaration ? {
55
- type: _devkit.ChangeType.Insert,
56
- index: firstImportDeclaration.getStart(),
57
- text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';`
58
- } : {
59
- type: _devkit.ChangeType.Insert,
60
- index: 0,
61
- text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';`
62
- }
63
- ]);
64
- }
65
- }
66
-
67
- //# sourceMappingURL=add-file-replacements.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../../packages/vite/src/migrations/update-17-2-0/lib/add-file-replacements.ts"],"sourcesContent":["import { ChangeType, applyChangesToString } from '@nx/devkit';\nimport { FileReplacement } from '../../../../plugins/rollup-replace-files.plugin';\nimport { tsquery } from '@phenomnomnominal/tsquery';\nimport { getConfigNode, notFoundWarning } from '../update-vite-config';\n\nexport function addFileReplacements(\n configContents: string,\n fileReplacements: FileReplacement[],\n configPath: string\n): string {\n const configNode = getConfigNode(configContents);\n if (!configNode) {\n notFoundWarning(configPath);\n return configContents;\n }\n const pluginsObject = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"plugins\"])`\n )?.[0];\n const replaceFilesPlugin = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"plugins\"]) CallExpression:has(Identifier[name=\"replaceFiles\"])`\n )?.[0];\n\n const firstImportDeclaration = tsquery.query(\n configContents,\n 'ImportDeclaration'\n )?.[0];\n\n if (pluginsObject) {\n if (replaceFilesPlugin) {\n return configContents;\n } else {\n return applyChangesToString(configContents, [\n {\n type: ChangeType.Insert,\n index: pluginsObject.getStart() + `plugins: [`.length + 1,\n text: `replaceFiles(${JSON.stringify(fileReplacements)}),`,\n },\n firstImportDeclaration\n ? {\n type: ChangeType.Insert,\n index: firstImportDeclaration.getStart(),\n text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';\\n`,\n }\n : {\n type: ChangeType.Insert,\n index: 0,\n text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';\\n`,\n },\n ]);\n }\n } else {\n const foundDefineConfig = tsquery.query(\n configContents,\n 'CallExpression:has(Identifier[name=\"defineConfig\"])'\n )?.[0];\n\n if (!foundDefineConfig) {\n return;\n }\n return applyChangesToString(configContents, [\n {\n type: ChangeType.Insert,\n index: configNode.getStart() + 1,\n text: `plugins: [replaceFiles(${JSON.stringify(fileReplacements)})],`,\n },\n firstImportDeclaration\n ? {\n type: ChangeType.Insert,\n index: firstImportDeclaration.getStart(),\n text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';`,\n }\n : {\n type: ChangeType.Insert,\n index: 0,\n text: `import replaceFiles from '@nx/vite/plugins/rollup-replace-files.plugin';`,\n },\n ]);\n }\n}\n"],"names":["addFileReplacements","configContents","fileReplacements","configPath","tsquery","configNode","getConfigNode","notFoundWarning","pluginsObject","query","replaceFilesPlugin","firstImportDeclaration","applyChangesToString","type","ChangeType","Insert","index","getStart","length","text","JSON","stringify","foundDefineConfig"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";+BAKgBA;;;eAAAA;;;wBALiC;yBAEzB;kCACuB;AAExC,SAASA,oBACdC,cAAsB,EACtBC,gBAAmC,EACnCC,UAAkB;QAOIC,gBAIKA,iBAKIA;IAd/B,MAAMC,aAAaC,IAAAA,+BAAa,EAACL;IACjC,IAAI,CAACI,YAAY;QACfE,IAAAA,iCAAe,EAACJ;QAChB,OAAOF;IACT;IACA,MAAMO,iBAAgBJ,iBAAAA,gBAAO,CAACK,KAAK,CACjCJ,YACA,CAAC,kDAAkD,CAAC,sBAFhCD,cAGnB,CAAC,EAAE;IACN,MAAMM,sBAAqBN,kBAAAA,gBAAO,CAACK,KAAK,CACtCJ,YACA,CAAC,sGAAsG,CAAC,sBAF/ED,eAGxB,CAAC,EAAE;IAEN,MAAMO,0BAAyBP,kBAAAA,gBAAO,CAACK,KAAK,CAC1CR,gBACA,yCAF6BG,eAG5B,CAAC,EAAE;IAEN,IAAII,eAAe;QACjB,IAAIE,oBAAoB;YACtB,OAAOT;QACT,OAAO;YACL,OAAOW,IAAAA,4BAAoB,EAACX,gBAAgB;gBAC1C;oBACEY,MAAMC,kBAAU,CAACC,MAAM;oBACvBC,OAAOR,cAAcS,QAAQ,KAAK,CAAC,UAAU,CAAC,CAACC,MAAM,GAAG;oBACxDC,MAAM,CAAC,aAAa,EAAEC,KAAKC,SAAS,CAACnB,kBAAkB,EAAE,CAAC;gBAC5D;gBACAS,yBACI;oBACEE,MAAMC,kBAAU,CAACC,MAAM;oBACvBC,OAAOL,uBAAuBM,QAAQ;oBACtCE,MAAM,CAAC,0EAA0E,CAAC;gBACpF,IACA;oBACEN,MAAMC,kBAAU,CAACC,MAAM;oBACvBC,OAAO;oBACPG,MAAM,CAAC,0EAA0E,CAAC;gBACpF;aACL;QACH;IACF,OAAO;YACqBf;QAA1B,MAAMkB,qBAAoBlB,kBAAAA,gBAAO,CAACK,KAAK,CACrCR,gBACA,2EAFwBG,eAGvB,CAAC,EAAE;QAEN,IAAI,CAACkB,mBAAmB;YACtB;QACF;QACA,OAAOV,IAAAA,4BAAoB,EAACX,gBAAgB;YAC1C;gBACEY,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOX,WAAWY,QAAQ,KAAK;gBAC/BE,MAAM,CAAC,uBAAuB,EAAEC,KAAKC,SAAS,CAACnB,kBAAkB,GAAG,CAAC;YACvE;YACAS,yBACI;gBACEE,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOL,uBAAuBM,QAAQ;gBACtCE,MAAM,CAAC,wEAAwE,CAAC;YAClF,IACA;gBACEN,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAO;gBACPG,MAAM,CAAC,wEAAwE,CAAC;YAClF;SACL;IACH;AACF"}
@@ -1,2 +0,0 @@
1
- import { ProjectConfiguration, Tree } from '@nx/devkit';
2
- export declare function updateBuildOutDirAndRoot(options: Record<string, any>, configContents: string, projectConfig: ProjectConfiguration, targetName: string, tree: Tree, projectName: string, configPath: string): string;
@@ -1,120 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "updateBuildOutDirAndRoot", {
3
- enumerable: true,
4
- get: function() {
5
- return updateBuildOutDirAndRoot;
6
- }
7
- });
8
- const _devkit = require("@nx/devkit");
9
- const _tsquery = require("@phenomnomnominal/tsquery");
10
- const _updateviteconfig = require("../update-vite-config");
11
- function updateBuildOutDirAndRoot(options, configContents, projectConfig, targetName, tree, projectName, configPath) {
12
- var _tsquery_query;
13
- const foundDefineConfig = (_tsquery_query = _tsquery.tsquery.query(configContents, 'CallExpression:has(Identifier[name="defineConfig"])')) == null ? void 0 : _tsquery_query[0];
14
- if (!foundDefineConfig) {
15
- (0, _updateviteconfig.notFoundWarning)(configPath);
16
- return;
17
- }
18
- configContents = fixBuild(options, configContents, projectConfig, targetName, tree, projectName, configPath);
19
- configContents = addRoot(configContents, configPath);
20
- return configContents;
21
- }
22
- function fixBuild(options, configContents, projectConfig, targetName, tree, projectName, configPath) {
23
- var _tsquery_query;
24
- const configNode = (0, _updateviteconfig.getConfigNode)(configContents);
25
- if (!configNode) {
26
- (0, _updateviteconfig.notFoundWarning)(configPath);
27
- return configContents;
28
- }
29
- let outputPath = '';
30
- // In vite.config.ts, we want to keep the path relative to workspace root
31
- if (options.outputPath) {
32
- outputPath = (0, _devkit.joinPathFragments)((0, _devkit.offsetFromRoot)(projectConfig.root), options.outputPath);
33
- } else {
34
- outputPath = (0, _devkit.joinPathFragments)((0, _devkit.offsetFromRoot)(projectConfig.root), 'dist', projectConfig.root);
35
- }
36
- // In project.json, we want to keep the path starting from workspace root
37
- projectConfig.targets[targetName].options.outputPath = options.outputPath ? options.outputPath : (0, _devkit.joinPathFragments)('dist', projectConfig.root);
38
- (0, _devkit.updateProjectConfiguration)(tree, projectName, projectConfig);
39
- const buildObject = (_tsquery_query = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="build"])`)) == null ? void 0 : _tsquery_query[0];
40
- if (buildObject) {
41
- var _tsquery_query1, _tsquery_query2, _tsquery_query3;
42
- const reportCompressedSizeExists = ((_tsquery_query1 = _tsquery.tsquery.query(buildObject, `PropertyAssignment:has(Identifier[name="reportCompressedSize"])`)) == null ? void 0 : _tsquery_query1.length) > 0;
43
- const commonjsOptionsExists = ((_tsquery_query2 = _tsquery.tsquery.query(buildObject, `PropertyAssignment:has(Identifier[name="commonjsOptions"])`)) == null ? void 0 : _tsquery_query2.length) > 0;
44
- const buildOutDir = (_tsquery_query3 = _tsquery.tsquery.query(buildObject, `PropertyAssignment:has(Identifier[name="outDir"])`)) == null ? void 0 : _tsquery_query3.length;
45
- // Array to store changes
46
- let changes = [];
47
- // Add outDir if not present
48
- if (!buildOutDir) {
49
- changes.push({
50
- type: _devkit.ChangeType.Insert,
51
- index: buildObject.getStart() + `build: {`.length + 1,
52
- text: `outDir: '${outputPath}',`
53
- });
54
- }
55
- // Add reportCompressedSize if not present
56
- if (!reportCompressedSizeExists) {
57
- changes.push({
58
- type: _devkit.ChangeType.Insert,
59
- index: buildObject.getStart() + `build: {`.length + 1,
60
- text: `reportCompressedSize: true,`
61
- });
62
- }
63
- // Add commonjsOptions if not present
64
- if (!commonjsOptionsExists) {
65
- changes.push({
66
- type: _devkit.ChangeType.Insert,
67
- index: buildObject.getStart() + `build: {`.length + 1,
68
- text: `commonjsOptions: { transformMixedEsModules: true },`
69
- });
70
- }
71
- if (changes.length > 0) {
72
- return (0, _devkit.applyChangesToString)(configContents, changes);
73
- }
74
- } else {
75
- return addBuildProperty(configContents, outputPath, configPath);
76
- }
77
- return configContents;
78
- }
79
- function addRoot(configFileContents, configPath) {
80
- var _tsquery_query;
81
- const configNode = (0, _updateviteconfig.getConfigNode)(configFileContents);
82
- if (!configNode) {
83
- (0, _updateviteconfig.notFoundWarning)(configPath);
84
- return configFileContents;
85
- }
86
- const rootOption = (_tsquery_query = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="root"]) Identifier[name="__dirname"]`)) == null ? void 0 : _tsquery_query[0];
87
- if (rootOption) {
88
- return configFileContents;
89
- } else {
90
- return (0, _devkit.applyChangesToString)(configFileContents, [
91
- {
92
- type: _devkit.ChangeType.Insert,
93
- index: configNode.getStart() + 1,
94
- text: `root: __dirname,`
95
- }
96
- ]);
97
- }
98
- }
99
- function addBuildProperty(configFileContents, outputPath, configPath) {
100
- const configNode = (0, _updateviteconfig.getConfigNode)(configFileContents);
101
- if (!configNode) {
102
- (0, _updateviteconfig.notFoundWarning)(configPath);
103
- return configFileContents;
104
- }
105
- return (0, _devkit.applyChangesToString)(configFileContents, [
106
- {
107
- type: _devkit.ChangeType.Insert,
108
- index: configNode.getStart() + 1,
109
- text: `build: {
110
- outDir: '${outputPath}',
111
- reportCompressedSize: true,
112
- commonjsOptions: {
113
- transformMixedEsModules: true,
114
- },
115
- },`
116
- }
117
- ]);
118
- }
119
-
120
- //# sourceMappingURL=edit-build-config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../../packages/vite/src/migrations/update-17-2-0/lib/edit-build-config.ts"],"sourcesContent":["import {\n ChangeType,\n ProjectConfiguration,\n Tree,\n applyChangesToString,\n joinPathFragments,\n offsetFromRoot,\n updateProjectConfiguration,\n} from '@nx/devkit';\nimport { tsquery } from '@phenomnomnominal/tsquery';\nimport ts = require('typescript');\nimport { getConfigNode, notFoundWarning } from '../update-vite-config';\n\nexport function updateBuildOutDirAndRoot(\n options: Record<string, any>,\n configContents: string,\n projectConfig: ProjectConfiguration,\n targetName: string,\n tree: Tree,\n projectName: string,\n configPath: string\n): string {\n const foundDefineConfig = tsquery.query(\n configContents,\n 'CallExpression:has(Identifier[name=\"defineConfig\"])'\n )?.[0];\n\n if (!foundDefineConfig) {\n notFoundWarning(configPath);\n return;\n }\n\n configContents = fixBuild(\n options,\n configContents,\n projectConfig,\n targetName,\n tree,\n projectName,\n configPath\n );\n\n configContents = addRoot(configContents, configPath);\n\n return configContents;\n}\n\nfunction fixBuild(\n options: Record<string, any>,\n configContents: string,\n projectConfig: ProjectConfiguration,\n targetName: string,\n tree: Tree,\n projectName: string,\n configPath: string\n) {\n const configNode = getConfigNode(configContents);\n if (!configNode) {\n notFoundWarning(configPath);\n return configContents;\n }\n\n let outputPath = '';\n\n // In vite.config.ts, we want to keep the path relative to workspace root\n if (options.outputPath) {\n outputPath = joinPathFragments(\n offsetFromRoot(projectConfig.root),\n options.outputPath\n );\n } else {\n outputPath = joinPathFragments(\n offsetFromRoot(projectConfig.root),\n 'dist',\n projectConfig.root\n );\n }\n\n // In project.json, we want to keep the path starting from workspace root\n projectConfig.targets[targetName].options.outputPath = options.outputPath\n ? options.outputPath\n : joinPathFragments('dist', projectConfig.root);\n updateProjectConfiguration(tree, projectName, projectConfig);\n\n const buildObject = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"build\"])`\n )?.[0];\n\n if (buildObject) {\n const reportCompressedSizeExists =\n tsquery.query(\n buildObject,\n `PropertyAssignment:has(Identifier[name=\"reportCompressedSize\"])`\n )?.length > 0;\n\n const commonjsOptionsExists =\n tsquery.query(\n buildObject,\n `PropertyAssignment:has(Identifier[name=\"commonjsOptions\"])`\n )?.length > 0;\n\n const buildOutDir = tsquery.query(\n buildObject,\n `PropertyAssignment:has(Identifier[name=\"outDir\"])`\n )?.length;\n\n // Array to store changes\n let changes = [];\n\n // Add outDir if not present\n if (!buildOutDir) {\n changes.push({\n type: ChangeType.Insert,\n index: buildObject.getStart() + `build: {`.length + 1,\n text: `outDir: '${outputPath}',`,\n });\n }\n\n // Add reportCompressedSize if not present\n if (!reportCompressedSizeExists) {\n changes.push({\n type: ChangeType.Insert,\n index: buildObject.getStart() + `build: {`.length + 1,\n text: `reportCompressedSize: true,`,\n });\n }\n\n // Add commonjsOptions if not present\n if (!commonjsOptionsExists) {\n changes.push({\n type: ChangeType.Insert,\n index: buildObject.getStart() + `build: {`.length + 1,\n text: `commonjsOptions: { transformMixedEsModules: true },`,\n });\n }\n\n if (changes.length > 0) {\n return applyChangesToString(configContents, changes);\n }\n } else {\n return addBuildProperty(configContents, outputPath, configPath);\n }\n\n return configContents;\n}\n\nfunction addRoot(configFileContents: string, configPath: string): string {\n const configNode = getConfigNode(configFileContents);\n\n if (!configNode) {\n notFoundWarning(configPath);\n return configFileContents;\n }\n\n const rootOption = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"root\"]) Identifier[name=\"__dirname\"]`\n )?.[0];\n\n if (rootOption) {\n return configFileContents;\n } else {\n return applyChangesToString(configFileContents, [\n {\n type: ChangeType.Insert,\n index: configNode.getStart() + 1,\n text: `root: __dirname,`,\n },\n ]);\n }\n}\n\nfunction addBuildProperty(\n configFileContents: string,\n outputPath: string,\n configPath: string\n): string {\n const configNode = getConfigNode(configFileContents);\n if (!configNode) {\n notFoundWarning(configPath);\n return configFileContents;\n }\n\n return applyChangesToString(configFileContents, [\n {\n type: ChangeType.Insert,\n index: configNode.getStart() + 1,\n text: `build: {\n outDir: '${outputPath}',\n reportCompressedSize: true,\n commonjsOptions: {\n transformMixedEsModules: true,\n },\n },`,\n },\n ]);\n}\n"],"names":["updateBuildOutDirAndRoot","options","configContents","projectConfig","targetName","tree","projectName","configPath","tsquery","foundDefineConfig","query","notFoundWarning","fixBuild","addRoot","configNode","getConfigNode","outputPath","joinPathFragments","offsetFromRoot","root","targets","updateProjectConfiguration","buildObject","reportCompressedSizeExists","length","commonjsOptionsExists","buildOutDir","changes","push","type","ChangeType","Insert","index","getStart","text","applyChangesToString","addBuildProperty","configFileContents","rootOption"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";+BAagBA;;;eAAAA;;;wBALT;yBACiB;kCAEuB;AAExC,SAASA,yBACdC,OAA4B,EAC5BC,cAAsB,EACtBC,aAAmC,EACnCC,UAAkB,EAClBC,IAAU,EACVC,WAAmB,EACnBC,UAAkB;QAEQC;IAA1B,MAAMC,qBAAoBD,iBAAAA,gBAAO,CAACE,KAAK,CACrCR,gBACA,2EAFwBM,cAGvB,CAAC,EAAE;IAEN,IAAI,CAACC,mBAAmB;QACtBE,IAAAA,iCAAe,EAACJ;QAChB;IACF;IAEAL,iBAAiBU,SACfX,SACAC,gBACAC,eACAC,YACAC,MACAC,aACAC;IAGFL,iBAAiBW,QAAQX,gBAAgBK;IAEzC,OAAOL;AACT;AAEA,SAASU,SACPX,OAA4B,EAC5BC,cAAsB,EACtBC,aAAmC,EACnCC,UAAkB,EAClBC,IAAU,EACVC,WAAmB,EACnBC,UAAkB;QA8BEC;IA5BpB,MAAMM,aAAaC,IAAAA,+BAAa,EAACb;IACjC,IAAI,CAACY,YAAY;QACfH,IAAAA,iCAAe,EAACJ;QAChB,OAAOL;IACT;IAEA,IAAIc,aAAa;IAEjB,yEAAyE;IACzE,IAAIf,QAAQe,UAAU,EAAE;QACtBA,aAAaC,IAAAA,yBAAiB,EAC5BC,IAAAA,sBAAc,EAACf,cAAcgB,IAAI,GACjClB,QAAQe,UAAU;IAEtB,OAAO;QACLA,aAAaC,IAAAA,yBAAiB,EAC5BC,IAAAA,sBAAc,EAACf,cAAcgB,IAAI,GACjC,QACAhB,cAAcgB,IAAI;IAEtB;IAEA,yEAAyE;IACzEhB,cAAciB,OAAO,CAAChB,WAAW,CAACH,OAAO,CAACe,UAAU,GAAGf,QAAQe,UAAU,GACrEf,QAAQe,UAAU,GAClBC,IAAAA,yBAAiB,EAAC,QAAQd,cAAcgB,IAAI;IAChDE,IAAAA,kCAA0B,EAAChB,MAAMC,aAAaH;IAE9C,MAAMmB,eAAcd,iBAAAA,gBAAO,CAACE,KAAK,CAC/BI,YACA,CAAC,gDAAgD,CAAC,sBAFhCN,cAGjB,CAAC,EAAE;IAEN,IAAIc,aAAa;YAEbd,iBAMAA,iBAKkBA;QAZpB,MAAMe,6BACJf,EAAAA,kBAAAA,gBAAO,CAACE,KAAK,CACXY,aACA,CAAC,+DAA+D,CAAC,sBAFnEd,gBAGGgB,MAAM,IAAG;QAEd,MAAMC,wBACJjB,EAAAA,kBAAAA,gBAAO,CAACE,KAAK,CACXY,aACA,CAAC,0DAA0D,CAAC,sBAF9Dd,gBAGGgB,MAAM,IAAG;QAEd,MAAME,eAAclB,kBAAAA,gBAAO,CAACE,KAAK,CAC/BY,aACA,CAAC,iDAAiD,CAAC,sBAFjCd,gBAGjBgB,MAAM;QAET,yBAAyB;QACzB,IAAIG,UAAU,EAAE;QAEhB,4BAA4B;QAC5B,IAAI,CAACD,aAAa;YAChBC,QAAQC,IAAI,CAAC;gBACXC,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOV,YAAYW,QAAQ,KAAK,CAAC,QAAQ,CAAC,CAACT,MAAM,GAAG;gBACpDU,MAAM,CAAC,SAAS,EAAElB,WAAW,EAAE,CAAC;YAClC;QACF;QAEA,0CAA0C;QAC1C,IAAI,CAACO,4BAA4B;YAC/BI,QAAQC,IAAI,CAAC;gBACXC,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOV,YAAYW,QAAQ,KAAK,CAAC,QAAQ,CAAC,CAACT,MAAM,GAAG;gBACpDU,MAAM,CAAC,2BAA2B,CAAC;YACrC;QACF;QAEA,qCAAqC;QACrC,IAAI,CAACT,uBAAuB;YAC1BE,QAAQC,IAAI,CAAC;gBACXC,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOV,YAAYW,QAAQ,KAAK,CAAC,QAAQ,CAAC,CAACT,MAAM,GAAG;gBACpDU,MAAM,CAAC,mDAAmD,CAAC;YAC7D;QACF;QAEA,IAAIP,QAAQH,MAAM,GAAG,GAAG;YACtB,OAAOW,IAAAA,4BAAoB,EAACjC,gBAAgByB;QAC9C;IACF,OAAO;QACL,OAAOS,iBAAiBlC,gBAAgBc,YAAYT;IACtD;IAEA,OAAOL;AACT;AAEA,SAASW,QAAQwB,kBAA0B,EAAE9B,UAAkB;QAQ1CC;IAPnB,MAAMM,aAAaC,IAAAA,+BAAa,EAACsB;IAEjC,IAAI,CAACvB,YAAY;QACfH,IAAAA,iCAAe,EAACJ;QAChB,OAAO8B;IACT;IAEA,MAAMC,cAAa9B,iBAAAA,gBAAO,CAACE,KAAK,CAC9BI,YACA,CAAC,4EAA4E,CAAC,sBAF7DN,cAGhB,CAAC,EAAE;IAEN,IAAI8B,YAAY;QACd,OAAOD;IACT,OAAO;QACL,OAAOF,IAAAA,4BAAoB,EAACE,oBAAoB;YAC9C;gBACER,MAAMC,kBAAU,CAACC,MAAM;gBACvBC,OAAOlB,WAAWmB,QAAQ,KAAK;gBAC/BC,MAAM,CAAC,gBAAgB,CAAC;YAC1B;SACD;IACH;AACF;AAEA,SAASE,iBACPC,kBAA0B,EAC1BrB,UAAkB,EAClBT,UAAkB;IAElB,MAAMO,aAAaC,IAAAA,+BAAa,EAACsB;IACjC,IAAI,CAACvB,YAAY;QACfH,IAAAA,iCAAe,EAACJ;QAChB,OAAO8B;IACT;IAEA,OAAOF,IAAAA,4BAAoB,EAACE,oBAAoB;QAC9C;YACER,MAAMC,kBAAU,CAACC,MAAM;YACvBC,OAAOlB,WAAWmB,QAAQ,KAAK;YAC/BC,MAAM,CAAC;yBACY,EAAElB,WAAW;;;;;gBAKtB,CAAC;QACb;KACD;AACH"}
@@ -1,2 +0,0 @@
1
- import { ProjectConfiguration } from '@nx/devkit';
2
- export declare function updateTestConfig(configContents: string, projectConfig: ProjectConfiguration, configPath: string): string;
@@ -1,82 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "updateTestConfig", {
3
- enumerable: true,
4
- get: function() {
5
- return updateTestConfig;
6
- }
7
- });
8
- const _devkit = require("@nx/devkit");
9
- const _tsquery = require("@phenomnomnominal/tsquery");
10
- const _updateviteconfig = require("../update-vite-config");
11
- function updateTestConfig(configContents, projectConfig, configPath) {
12
- var _tsquery_query, _projectConfig_targets_test_options, _projectConfig_targets_test, _projectConfig_targets;
13
- const configNode = (0, _updateviteconfig.getConfigNode)(configContents);
14
- if (!configNode) {
15
- (0, _updateviteconfig.notFoundWarning)(configPath);
16
- return configContents;
17
- }
18
- const testObject = (_tsquery_query = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="test"])`)) == null ? void 0 : _tsquery_query[0];
19
- let testCoverageDir;
20
- let testCoverage;
21
- let provider;
22
- let reporters;
23
- if (testObject) {
24
- var _tsquery_query1, _tsquery_query2;
25
- testCoverage = (_tsquery_query1 = _tsquery.tsquery.query(testObject, `PropertyAssignment:has(Identifier[name="coverage"])`)) == null ? void 0 : _tsquery_query1[0];
26
- reporters = (_tsquery_query2 = _tsquery.tsquery.query(testObject, `PropertyAssignment:has(Identifier[name="reporters"])`)) == null ? void 0 : _tsquery_query2[0];
27
- if (testCoverage) {
28
- var _tsquery_query3, _tsquery_query4;
29
- testCoverageDir = (_tsquery_query3 = _tsquery.tsquery.query(testCoverage, `PropertyAssignment:has(Identifier[name="reportsDirectory"])`)) == null ? void 0 : _tsquery_query3[0];
30
- provider = (_tsquery_query4 = _tsquery.tsquery.query(testCoverage, `PropertyAssignment:has(Identifier[name="provider"])`)) == null ? void 0 : _tsquery_query4[0];
31
- }
32
- }
33
- let coverageDir = '';
34
- if ((_projectConfig_targets = projectConfig.targets) == null ? void 0 : (_projectConfig_targets_test = _projectConfig_targets.test) == null ? void 0 : (_projectConfig_targets_test_options = _projectConfig_targets_test.options) == null ? void 0 : _projectConfig_targets_test_options.reportsDirectory) {
35
- var _projectConfig_targets_test_options1, _projectConfig_targets_test1, _projectConfig_targets1;
36
- coverageDir = (_projectConfig_targets1 = projectConfig.targets) == null ? void 0 : (_projectConfig_targets_test1 = _projectConfig_targets1.test) == null ? void 0 : (_projectConfig_targets_test_options1 = _projectConfig_targets_test1.options) == null ? void 0 : _projectConfig_targets_test_options1.reportsDirectory;
37
- } else {
38
- coverageDir = (0, _devkit.joinPathFragments)((0, _devkit.offsetFromRoot)(projectConfig.root), 'coverage', projectConfig.root);
39
- }
40
- let changes = [];
41
- if (!reporters && testObject) {
42
- changes.push({
43
- type: _devkit.ChangeType.Insert,
44
- index: testObject.getStart() + `test: {`.length + 1,
45
- text: `reporters: ['default'],`
46
- });
47
- }
48
- if (testCoverageDir) {
49
- // Do nothing
50
- } else if (testCoverage) {
51
- // has test.coverage, has no reportsDirectory
52
- // so add reportsDirectory
53
- changes.push({
54
- type: _devkit.ChangeType.Insert,
55
- index: testCoverage.getStart() + `coverage: {`.length + 1,
56
- text: `reportsDirectory: '${coverageDir}',`
57
- });
58
- if (!provider) {
59
- changes.push({
60
- type: _devkit.ChangeType.Insert,
61
- index: testCoverage.getStart() + `coverage: {`.length + 1,
62
- text: `provider: 'v8' as const,`
63
- });
64
- }
65
- } else if (testObject) {
66
- changes.push({
67
- type: _devkit.ChangeType.Insert,
68
- index: testObject.getStart() + `test: {`.length + 1,
69
- text: `coverage: {
70
- reportsDirectory: '${coverageDir}',
71
- provider: 'v8' as const,
72
- },`
73
- });
74
- }
75
- if (changes.length > 0) {
76
- return (0, _devkit.applyChangesToString)(configContents, changes);
77
- } else {
78
- return configContents;
79
- }
80
- }
81
-
82
- //# sourceMappingURL=edit-test-config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../../packages/vite/src/migrations/update-17-2-0/lib/edit-test-config.ts"],"sourcesContent":["import {\n ChangeType,\n ProjectConfiguration,\n applyChangesToString,\n joinPathFragments,\n offsetFromRoot,\n} from '@nx/devkit';\nimport { tsquery } from '@phenomnomnominal/tsquery';\nimport ts = require('typescript');\nimport { getConfigNode, notFoundWarning } from '../update-vite-config';\n\nexport function updateTestConfig(\n configContents: string,\n projectConfig: ProjectConfiguration,\n configPath: string\n): string {\n const configNode = getConfigNode(configContents);\n if (!configNode) {\n notFoundWarning(configPath);\n return configContents;\n }\n\n const testObject = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"test\"])`\n )?.[0];\n let testCoverageDir: ts.Node;\n let testCoverage: ts.Node;\n let provider: ts.Node;\n let reporters: ts.Node;\n\n if (testObject) {\n testCoverage = tsquery.query(\n testObject,\n `PropertyAssignment:has(Identifier[name=\"coverage\"])`\n )?.[0];\n reporters = tsquery.query(\n testObject,\n `PropertyAssignment:has(Identifier[name=\"reporters\"])`\n )?.[0];\n if (testCoverage) {\n testCoverageDir = tsquery.query(\n testCoverage,\n `PropertyAssignment:has(Identifier[name=\"reportsDirectory\"])`\n )?.[0];\n provider = tsquery.query(\n testCoverage,\n `PropertyAssignment:has(Identifier[name=\"provider\"])`\n )?.[0];\n }\n }\n\n let coverageDir = '';\n\n if (projectConfig.targets?.test?.options?.reportsDirectory) {\n coverageDir = projectConfig.targets?.test?.options?.reportsDirectory;\n } else {\n coverageDir = joinPathFragments(\n offsetFromRoot(projectConfig.root),\n 'coverage',\n projectConfig.root\n );\n }\n\n let changes = [];\n\n if (!reporters && testObject) {\n changes.push({\n type: ChangeType.Insert,\n index: testObject.getStart() + `test: {`.length + 1,\n text: `reporters: ['default'],`,\n });\n }\n\n if (testCoverageDir) {\n // Do nothing\n } else if (testCoverage) {\n // has test.coverage, has no reportsDirectory\n // so add reportsDirectory\n changes.push({\n type: ChangeType.Insert,\n index: testCoverage.getStart() + `coverage: {`.length + 1,\n text: `reportsDirectory: '${coverageDir}',`,\n });\n if (!provider) {\n changes.push({\n type: ChangeType.Insert,\n index: testCoverage.getStart() + `coverage: {`.length + 1,\n text: `provider: 'v8' as const,`,\n });\n }\n } else if (testObject) {\n changes.push({\n type: ChangeType.Insert,\n index: testObject.getStart() + `test: {`.length + 1,\n text: `coverage: {\n reportsDirectory: '${coverageDir}',\n provider: 'v8' as const,\n },`,\n });\n }\n\n if (changes.length > 0) {\n return applyChangesToString(configContents, changes);\n } else {\n return configContents;\n }\n}\n"],"names":["updateTestConfig","configContents","projectConfig","configPath","tsquery","configNode","getConfigNode","notFoundWarning","testObject","query","testCoverageDir","testCoverage","provider","reporters","coverageDir","targets","test","options","reportsDirectory","joinPathFragments","offsetFromRoot","root","changes","push","type","ChangeType","Insert","index","getStart","length","text","applyChangesToString"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -1 +0,0 @@
1
- export declare const viteConfigFixture = "/// <reference types=\"vitest\" />\nimport react from '@vitejs/plugin-react';\nimport dns from 'dns';\nimport { PluginOption, defineConfig } from 'vite';\nimport { nxViteTsPaths } from '@nx/vite/plugins/nx-tsconfig-paths.plugin';\n\ndns.setDefaultResultOrder('verbatim');\nconst BASE_HREF = '/app';\n\n/**\n * Adds <base href=\"/app\">` to the head of the index.html\n * The reason why the `base` configuration property doesn't work is because it makes\n * all assets served under `/app` of `/` and this impacts the download zip service worker\n * We only want to the service worker to listen to events related to downloads, but not capture any other events\n * and the only way to do this is make sure all assets are served from the root, but we still want our app path to be `/app`\n *\n * This mimics the same behavior we had with webpack before migrating to vite\n */\nconst baseHrefPlugin: () => PluginOption = () => {\n return {\n name: 'html-transform',\n transformIndexHtml(html) {\n return html.replace('<head>', `<head>\\n <base href=\"${BASE_HREF}\">`);\n },\n };\n};\n\nexport default defineConfig({\n cacheDir: '../../node_modules/.vite/jetstream',\n envPrefix: 'NX',\n\n server: {\n port: 4200,\n host: 'localhost',\n },\n\n build: {\n // Put all assets at the root of the app instead of under /assets\n assetsDir: './',\n sourcemap: true,\n rollupOptions: {\n output: {\n sourcemap: true,\n },\n },\n },\n\n plugins: [\n react({\n jsxImportSource: '@emotion/react',\n babel: {\n plugins: ['@emotion/babel-plugin'],\n },\n }),\n nxViteTsPaths(),\n baseHrefPlugin(),\n ],\n\n worker: {\n plugins: [\n nxViteTsPaths(),\n ],\n },\n});";
@@ -1,73 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "viteConfigFixture", {
3
- enumerable: true,
4
- get: function() {
5
- return viteConfigFixture;
6
- }
7
- });
8
- const viteConfigFixture = `/// <reference types="vitest" />
9
- import react from '@vitejs/plugin-react';
10
- import dns from 'dns';
11
- import { PluginOption, defineConfig } from 'vite';
12
- import { nxViteTsPaths } from '@nx/vite/plugins/nx-tsconfig-paths.plugin';
13
-
14
- dns.setDefaultResultOrder('verbatim');
15
- const BASE_HREF = '/app';
16
-
17
- /**
18
- * Adds <base href="/app">\` to the head of the index.html
19
- * The reason why the \`base\` configuration property doesn't work is because it makes
20
- * all assets served under \`/app\` of \`/\` and this impacts the download zip service worker
21
- * We only want to the service worker to listen to events related to downloads, but not capture any other events
22
- * and the only way to do this is make sure all assets are served from the root, but we still want our app path to be \`/app\`
23
- *
24
- * This mimics the same behavior we had with webpack before migrating to vite
25
- */
26
- const baseHrefPlugin: () => PluginOption = () => {
27
- return {
28
- name: 'html-transform',
29
- transformIndexHtml(html) {
30
- return html.replace('<head>', \`<head>\\n <base href="\${BASE_HREF}">\`);
31
- },
32
- };
33
- };
34
-
35
- export default defineConfig({
36
- cacheDir: '../../node_modules/.vite/jetstream',
37
- envPrefix: 'NX',
38
-
39
- server: {
40
- port: 4200,
41
- host: 'localhost',
42
- },
43
-
44
- build: {
45
- // Put all assets at the root of the app instead of under /assets
46
- assetsDir: './',
47
- sourcemap: true,
48
- rollupOptions: {
49
- output: {
50
- sourcemap: true,
51
- },
52
- },
53
- },
54
-
55
- plugins: [
56
- react({
57
- jsxImportSource: '@emotion/react',
58
- babel: {
59
- plugins: ['@emotion/babel-plugin'],
60
- },
61
- }),
62
- nxViteTsPaths(),
63
- baseHrefPlugin(),
64
- ],
65
-
66
- worker: {
67
- plugins: [
68
- nxViteTsPaths(),
69
- ],
70
- },
71
- });`;
72
-
73
- //# sourceMappingURL=vite-config-with-additional-js.fixture.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../../packages/vite/src/migrations/update-17-2-0/lib/vite-config-with-additional-js.fixture.ts"],"sourcesContent":["export const viteConfigFixture = `/// <reference types=\"vitest\" />\nimport react from '@vitejs/plugin-react';\nimport dns from 'dns';\nimport { PluginOption, defineConfig } from 'vite';\nimport { nxViteTsPaths } from '@nx/vite/plugins/nx-tsconfig-paths.plugin';\n\ndns.setDefaultResultOrder('verbatim');\nconst BASE_HREF = '/app';\n\n/**\n * Adds <base href=\"/app\">\\` to the head of the index.html\n * The reason why the \\`base\\` configuration property doesn't work is because it makes\n * all assets served under \\`/app\\` of \\`/\\` and this impacts the download zip service worker\n * We only want to the service worker to listen to events related to downloads, but not capture any other events\n * and the only way to do this is make sure all assets are served from the root, but we still want our app path to be \\`/app\\`\n *\n * This mimics the same behavior we had with webpack before migrating to vite\n */\nconst baseHrefPlugin: () => PluginOption = () => {\n return {\n name: 'html-transform',\n transformIndexHtml(html) {\n return html.replace('<head>', \\`<head>\\\\n <base href=\"\\${BASE_HREF}\">\\`);\n },\n };\n};\n\nexport default defineConfig({\n cacheDir: '../../node_modules/.vite/jetstream',\n envPrefix: 'NX',\n\n server: {\n port: 4200,\n host: 'localhost',\n },\n\n build: {\n // Put all assets at the root of the app instead of under /assets\n assetsDir: './',\n sourcemap: true,\n rollupOptions: {\n output: {\n sourcemap: true,\n },\n },\n },\n\n plugins: [\n react({\n jsxImportSource: '@emotion/react',\n babel: {\n plugins: ['@emotion/babel-plugin'],\n },\n }),\n nxViteTsPaths(),\n baseHrefPlugin(),\n ],\n\n worker: {\n plugins: [\n nxViteTsPaths(),\n ],\n },\n});`;\n"],"names":["viteConfigFixture"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";+BAAaA;;;eAAAA;;;AAAN,MAAMA,oBAAoB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+D/B,CAAC"}
@@ -1,5 +0,0 @@
1
- import { Tree } from '@nx/devkit';
2
- import ts = require('typescript');
3
- export default function updateBuildDir(tree: Tree): Promise<void>;
4
- export declare function getConfigNode(configFileContents: string): ts.Node | undefined;
5
- export declare function notFoundWarning(configPath: string): void;
@@ -1,70 +0,0 @@
1
- "use strict";
2
- function _export(target, all) {
3
- for(var name in all)Object.defineProperty(target, name, {
4
- enumerable: true,
5
- get: all[name]
6
- });
7
- }
8
- _export(exports, {
9
- default: function() {
10
- return updateBuildDir;
11
- },
12
- getConfigNode: function() {
13
- return getConfigNode;
14
- },
15
- notFoundWarning: function() {
16
- return notFoundWarning;
17
- }
18
- });
19
- const _devkit = require("@nx/devkit");
20
- const _executoroptionsutils = require("@nx/devkit/src/generators/executor-options-utils");
21
- const _editbuildconfig = require("./lib/edit-build-config");
22
- const _edittestconfig = require("./lib/edit-test-config");
23
- const _addfilereplacements = require("./lib/add-file-replacements");
24
- const _tsquery = require("@phenomnomnominal/tsquery");
25
- const _findviteconfig = require("../../utils/find-vite-config");
26
- async function updateBuildDir(tree) {
27
- const projects = (0, _devkit.getProjects)(tree);
28
- (0, _executoroptionsutils.forEachExecutorOptions)(tree, '@nx/vite:build', (options, projectName, targetName)=>{
29
- var _options_fileReplacements;
30
- const projectConfig = projects.get(projectName);
31
- const config = options.configFile || (0, _findviteconfig.findViteConfig)(tree, projectConfig.root);
32
- if (!config || !tree.exists(config)) {
33
- return;
34
- }
35
- let configContents = tree.read(config, 'utf-8');
36
- configContents = (0, _editbuildconfig.updateBuildOutDirAndRoot)(options, configContents, projectConfig, targetName, tree, projectName, config);
37
- configContents = (0, _edittestconfig.updateTestConfig)(configContents, projectConfig, config);
38
- if (((_options_fileReplacements = options['fileReplacements']) == null ? void 0 : _options_fileReplacements.length) > 0) {
39
- configContents = (0, _addfilereplacements.addFileReplacements)(configContents, options['fileReplacements'], config);
40
- }
41
- tree.write(config, configContents);
42
- });
43
- await (0, _devkit.formatFiles)(tree);
44
- }
45
- function getConfigNode(configFileContents) {
46
- var _tsquery_query;
47
- if (!configFileContents) {
48
- return;
49
- }
50
- let configNode = (_tsquery_query = _tsquery.tsquery.query(configFileContents, `CallExpression:has(Identifier[name=defineConfig]) > ObjectLiteralExpression`)) == null ? void 0 : _tsquery_query[0];
51
- if (!configNode) {
52
- var _tsquery_query1;
53
- const arrowFunctionReturnStatement = (_tsquery_query1 = _tsquery.tsquery.query(configFileContents, `ArrowFunction Block ReturnStatement ObjectLiteralExpression`)) == null ? void 0 : _tsquery_query1[0];
54
- if (arrowFunctionReturnStatement) {
55
- configNode = arrowFunctionReturnStatement;
56
- }
57
- }
58
- return configNode;
59
- }
60
- function notFoundWarning(configPath) {
61
- _devkit.logger.warn(`
62
- Could not migrate your ${configPath} file.
63
- Please add the build.outDir and root options in your ${configPath} file.
64
- You can find more information on how to configure vite for Nx here:
65
-
66
- https://nx.dev/recipes/vite/configure-vite
67
- `);
68
- }
69
-
70
- //# sourceMappingURL=update-vite-config.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../packages/vite/src/migrations/update-17-2-0/update-vite-config.ts"],"sourcesContent":["import {\n Tree,\n formatFiles,\n getProjects,\n joinPathFragments,\n logger,\n} from '@nx/devkit';\nimport { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils';\nimport { ViteBuildExecutorOptions } from '../../executors/build/schema';\nimport { updateBuildOutDirAndRoot } from './lib/edit-build-config';\nimport { updateTestConfig } from './lib/edit-test-config';\nimport { addFileReplacements } from './lib/add-file-replacements';\nimport { tsquery } from '@phenomnomnominal/tsquery';\nimport ts = require('typescript');\nimport { findViteConfig } from '../../utils/find-vite-config';\n\nexport default async function updateBuildDir(tree: Tree) {\n const projects = getProjects(tree);\n forEachExecutorOptions<ViteBuildExecutorOptions>(\n tree,\n '@nx/vite:build',\n (options, projectName, targetName) => {\n const projectConfig = projects.get(projectName);\n const config =\n options.configFile || findViteConfig(tree, projectConfig.root);\n if (!config || !tree.exists(config)) {\n return;\n }\n let configContents = tree.read(config, 'utf-8');\n\n configContents = updateBuildOutDirAndRoot(\n options,\n configContents,\n projectConfig,\n targetName,\n tree,\n projectName,\n config\n );\n\n configContents = updateTestConfig(configContents, projectConfig, config);\n\n if (options['fileReplacements']?.length > 0) {\n configContents = addFileReplacements(\n configContents,\n options['fileReplacements'],\n config\n );\n }\n\n tree.write(config, configContents);\n }\n );\n\n await formatFiles(tree);\n}\n\nexport function getConfigNode(configFileContents: string): ts.Node | undefined {\n if (!configFileContents) {\n return;\n }\n let configNode = tsquery.query(\n configFileContents,\n `CallExpression:has(Identifier[name=defineConfig]) > ObjectLiteralExpression`\n )?.[0];\n\n if (!configNode) {\n const arrowFunctionReturnStatement = tsquery.query(\n configFileContents,\n `ArrowFunction Block ReturnStatement ObjectLiteralExpression`\n )?.[0];\n\n if (arrowFunctionReturnStatement) {\n configNode = arrowFunctionReturnStatement;\n }\n }\n\n return configNode;\n}\n\nexport function notFoundWarning(configPath: string) {\n logger.warn(`\n Could not migrate your ${configPath} file.\n Please add the build.outDir and root options in your ${configPath} file.\n You can find more information on how to configure vite for Nx here:\n \n https://nx.dev/recipes/vite/configure-vite\n `);\n}\n"],"names":["updateBuildDir","getConfigNode","notFoundWarning","tree","projects","getProjects","forEachExecutorOptions","options","projectName","targetName","projectConfig","get","config","configFile","findViteConfig","root","exists","configContents","read","updateBuildOutDirAndRoot","updateTestConfig","length","addFileReplacements","write","formatFiles","configFileContents","tsquery","configNode","query","arrowFunctionReturnStatement","configPath","logger","warn"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";;;;;;;;IAgBA,OAuCC;eAvC6BA;;IAyCdC,aAAa;eAAbA;;IAuBAC,eAAe;eAAfA;;;wBA1ET;sCACgC;iCAEE;gCACR;qCACG;yBACZ;gCAEO;AAEhB,eAAeF,eAAeG,IAAU;IACrD,MAAMC,WAAWC,IAAAA,mBAAW,EAACF;IAC7BG,IAAAA,4CAAsB,EACpBH,MACA,kBACA,CAACI,SAASC,aAAaC;YAqBjBF;QApBJ,MAAMG,gBAAgBN,SAASO,GAAG,CAACH;QACnC,MAAMI,SACJL,QAAQM,UAAU,IAAIC,IAAAA,8BAAc,EAACX,MAAMO,cAAcK,IAAI;QAC/D,IAAI,CAACH,UAAU,CAACT,KAAKa,MAAM,CAACJ,SAAS;YACnC;QACF;QACA,IAAIK,iBAAiBd,KAAKe,IAAI,CAACN,QAAQ;QAEvCK,iBAAiBE,IAAAA,yCAAwB,EACvCZ,SACAU,gBACAP,eACAD,YACAN,MACAK,aACAI;QAGFK,iBAAiBG,IAAAA,gCAAgB,EAACH,gBAAgBP,eAAeE;QAEjE,IAAIL,EAAAA,4BAAAA,OAAO,CAAC,mBAAmB,qBAA3BA,0BAA6Bc,MAAM,IAAG,GAAG;YAC3CJ,iBAAiBK,IAAAA,wCAAmB,EAClCL,gBACAV,OAAO,CAAC,mBAAmB,EAC3BK;QAEJ;QAEAT,KAAKoB,KAAK,CAACX,QAAQK;IACrB;IAGF,MAAMO,IAAAA,mBAAW,EAACrB;AACpB;AAEO,SAASF,cAAcwB,kBAA0B;QAIrCC;IAHjB,IAAI,CAACD,oBAAoB;QACvB;IACF;IACA,IAAIE,cAAaD,iBAAAA,gBAAO,CAACE,KAAK,CAC5BH,oBACA,CAAC,2EAA2E,CAAC,sBAF9DC,cAGd,CAAC,EAAE;IAEN,IAAI,CAACC,YAAY;YACsBD;QAArC,MAAMG,gCAA+BH,kBAAAA,gBAAO,CAACE,KAAK,CAChDH,oBACA,CAAC,2DAA2D,CAAC,sBAF1BC,eAGlC,CAAC,EAAE;QAEN,IAAIG,8BAA8B;YAChCF,aAAaE;QACf;IACF;IAEA,OAAOF;AACT;AAEO,SAASzB,gBAAgB4B,UAAkB;IAChDC,cAAM,CAACC,IAAI,CAAC,CAAC;yBACU,EAAEF,WAAW;uDACiB,EAAEA,WAAW;;;;EAIlE,CAAC;AACH"}
@@ -1,3 +0,0 @@
1
- import ts = require('typescript');
2
- export declare function fixCoverageAndRerporters(configContents: string): string | undefined;
3
- export declare function getConfigNode(configFileContents: string): ts.Node | undefined;
@@ -1,119 +0,0 @@
1
- "use strict";
2
- function _export(target, all) {
3
- for(var name in all)Object.defineProperty(target, name, {
4
- enumerable: true,
5
- get: all[name]
6
- });
7
- }
8
- _export(exports, {
9
- fixCoverageAndRerporters: function() {
10
- return fixCoverageAndRerporters;
11
- },
12
- getConfigNode: function() {
13
- return getConfigNode;
14
- }
15
- });
16
- const _devkit = require("@nx/devkit");
17
- const _tsquery = require("@phenomnomnominal/tsquery");
18
- const ts = require("typescript");
19
- function fixCoverageAndRerporters(configContents) {
20
- var _tsquery_query, _tsquery_query1;
21
- const configNode = getConfigNode(configContents);
22
- if (!configNode) {
23
- return;
24
- }
25
- const testHasCoverage = (_tsquery_query = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="test"]):has(PropertyAssignment:has(Identifier[name="coverage"]))`)) == null ? void 0 : _tsquery_query[0];
26
- let changes = [];
27
- if (testHasCoverage) {
28
- var _tsquery_query2, _tsquery_query3, _tsquery_query4, _tsquery_query5, _tsquery_query6;
29
- const testObjectLiteralExpressionNode = (_tsquery_query2 = _tsquery.tsquery.query(testHasCoverage, `ObjectLiteralExpression:has(Identifier[name="coverage"])`)) == null ? void 0 : _tsquery_query2[0];
30
- const coverageNode = findCoverageNode(testObjectLiteralExpressionNode);
31
- if (!coverageNode) {
32
- return;
33
- }
34
- const linesNode = (_tsquery_query3 = _tsquery.tsquery.query(coverageNode, `PropertyAssignment:has(Identifier[name="lines"])`)) == null ? void 0 : _tsquery_query3[0];
35
- const statementsNode = (_tsquery_query4 = _tsquery.tsquery.query(coverageNode, `PropertyAssignment:has(Identifier[name="statements"])`)) == null ? void 0 : _tsquery_query4[0];
36
- const functionsNode = (_tsquery_query5 = _tsquery.tsquery.query(coverageNode, `PropertyAssignment:has(Identifier[name="functions"])`)) == null ? void 0 : _tsquery_query5[0];
37
- const branchesNode = (_tsquery_query6 = _tsquery.tsquery.query(coverageNode, `PropertyAssignment:has(Identifier[name="branches"])`)) == null ? void 0 : _tsquery_query6[0];
38
- if (linesNode) {
39
- changes.push({
40
- type: _devkit.ChangeType.Delete,
41
- start: linesNode.getStart(),
42
- length: linesNode.getWidth() + 1
43
- });
44
- }
45
- if (statementsNode) {
46
- changes.push({
47
- type: _devkit.ChangeType.Delete,
48
- start: statementsNode.getStart(),
49
- length: statementsNode.getWidth() + 1
50
- });
51
- }
52
- if (functionsNode) {
53
- changes.push({
54
- type: _devkit.ChangeType.Delete,
55
- start: functionsNode.getStart(),
56
- length: functionsNode.getWidth() + 1
57
- });
58
- }
59
- if (branchesNode) {
60
- changes.push({
61
- type: _devkit.ChangeType.Delete,
62
- start: branchesNode.getStart(),
63
- length: branchesNode.getWidth() + 1
64
- });
65
- }
66
- if (branchesNode || functionsNode || statementsNode || linesNode) {
67
- changes.push({
68
- type: _devkit.ChangeType.Insert,
69
- index: coverageNode.getStart() + 1,
70
- text: `thresholds: {
71
- ${linesNode ? linesNode.getText() + ',' : ''}
72
- ${statementsNode ? statementsNode.getText() + ',' : ''}
73
- ${functionsNode ? functionsNode.getText() + ',' : ''}
74
- ${branchesNode ? branchesNode.getText() + ',' : ''}
75
- },`
76
- });
77
- }
78
- }
79
- const testHasReporters = (_tsquery_query1 = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="test"]):has(PropertyAssignment:has(Identifier[name="reporters"]))`)) == null ? void 0 : _tsquery_query1[0];
80
- if (!testHasReporters) {
81
- var _tsquery_query7;
82
- const testObject = (_tsquery_query7 = _tsquery.tsquery.query(configNode, `PropertyAssignment:has(Identifier[name="test"])`)) == null ? void 0 : _tsquery_query7[0];
83
- if (testObject) {
84
- changes.push({
85
- type: _devkit.ChangeType.Insert,
86
- index: testObject.getStart() + `test: {`.length + 1,
87
- text: `reporters: ['default'],`
88
- });
89
- }
90
- }
91
- if (changes.length > 0) {
92
- return (0, _devkit.applyChangesToString)(configContents, changes);
93
- } else {
94
- return;
95
- }
96
- }
97
- function getConfigNode(configFileContents) {
98
- var _tsquery_query, _tsquery_query1;
99
- if (!configFileContents) {
100
- return;
101
- }
102
- let configNode = (_tsquery_query = _tsquery.tsquery.query(configFileContents, `ObjectLiteralExpression`)) == null ? void 0 : _tsquery_query[0];
103
- const arrowFunctionReturnStatement = (_tsquery_query1 = _tsquery.tsquery.query(configFileContents, `ArrowFunction Block ReturnStatement ObjectLiteralExpression`)) == null ? void 0 : _tsquery_query1[0];
104
- if (arrowFunctionReturnStatement) {
105
- configNode = arrowFunctionReturnStatement;
106
- }
107
- return configNode;
108
- }
109
- function findCoverageNode(testNode) {
110
- let coverageNode;
111
- testNode.forEachChild((child)=>{
112
- if (ts.isPropertyAssignment(child) && child.name.getText() === 'coverage') {
113
- coverageNode = child.initializer;
114
- }
115
- });
116
- return coverageNode;
117
- }
118
-
119
- //# sourceMappingURL=fix-coverage-and-reporters.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../../packages/vite/src/migrations/update-17-3-0/lib/fix-coverage-and-reporters.ts"],"sourcesContent":["import { ChangeType, applyChangesToString } from '@nx/devkit';\nimport { tsquery } from '@phenomnomnominal/tsquery';\nimport ts = require('typescript');\n\nexport function fixCoverageAndRerporters(\n configContents: string\n): string | undefined {\n const configNode = getConfigNode(configContents);\n if (!configNode) {\n return;\n }\n\n const testHasCoverage = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"test\"]):has(PropertyAssignment:has(Identifier[name=\"coverage\"]))`\n )?.[0];\n let changes = [];\n\n if (testHasCoverage) {\n const testObjectLiteralExpressionNode = tsquery.query(\n testHasCoverage,\n `ObjectLiteralExpression:has(Identifier[name=\"coverage\"])`\n )?.[0];\n const coverageNode = findCoverageNode(testObjectLiteralExpressionNode);\n\n if (!coverageNode) {\n return;\n }\n\n const linesNode = tsquery.query(\n coverageNode,\n `PropertyAssignment:has(Identifier[name=\"lines\"])`\n )?.[0];\n\n const statementsNode = tsquery.query(\n coverageNode,\n `PropertyAssignment:has(Identifier[name=\"statements\"])`\n )?.[0];\n\n const functionsNode = tsquery.query(\n coverageNode,\n `PropertyAssignment:has(Identifier[name=\"functions\"])`\n )?.[0];\n\n const branchesNode = tsquery.query(\n coverageNode,\n `PropertyAssignment:has(Identifier[name=\"branches\"])`\n )?.[0];\n\n if (linesNode) {\n changes.push({\n type: ChangeType.Delete,\n start: linesNode.getStart(),\n length: linesNode.getWidth() + 1,\n });\n }\n if (statementsNode) {\n changes.push({\n type: ChangeType.Delete,\n start: statementsNode.getStart(),\n length: statementsNode.getWidth() + 1,\n });\n }\n\n if (functionsNode) {\n changes.push({\n type: ChangeType.Delete,\n start: functionsNode.getStart(),\n length: functionsNode.getWidth() + 1,\n });\n }\n\n if (branchesNode) {\n changes.push({\n type: ChangeType.Delete,\n start: branchesNode.getStart(),\n length: branchesNode.getWidth() + 1,\n });\n }\n\n if (branchesNode || functionsNode || statementsNode || linesNode) {\n changes.push({\n type: ChangeType.Insert,\n index: coverageNode.getStart() + 1,\n text: `thresholds: {\n ${linesNode ? linesNode.getText() + ',' : ''}\n ${statementsNode ? statementsNode.getText() + ',' : ''}\n ${functionsNode ? functionsNode.getText() + ',' : ''}\n ${branchesNode ? branchesNode.getText() + ',' : ''}\n },`,\n });\n }\n }\n\n const testHasReporters = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"test\"]):has(PropertyAssignment:has(Identifier[name=\"reporters\"]))`\n )?.[0];\n\n if (!testHasReporters) {\n const testObject = tsquery.query(\n configNode,\n `PropertyAssignment:has(Identifier[name=\"test\"])`\n )?.[0];\n\n if (testObject) {\n changes.push({\n type: ChangeType.Insert,\n index: testObject.getStart() + `test: {`.length + 1,\n text: `reporters: ['default'],`,\n });\n }\n }\n\n if (changes.length > 0) {\n return applyChangesToString(configContents, changes);\n } else {\n return;\n }\n}\n\nexport function getConfigNode(configFileContents: string): ts.Node | undefined {\n if (!configFileContents) {\n return;\n }\n let configNode = tsquery.query(\n configFileContents,\n `ObjectLiteralExpression`\n )?.[0];\n\n const arrowFunctionReturnStatement = tsquery.query(\n configFileContents,\n `ArrowFunction Block ReturnStatement ObjectLiteralExpression`\n )?.[0];\n\n if (arrowFunctionReturnStatement) {\n configNode = arrowFunctionReturnStatement;\n }\n\n return configNode;\n}\n\nfunction findCoverageNode(testNode: ts.Node) {\n let coverageNode: ts.Node | undefined;\n testNode.forEachChild((child) => {\n if (ts.isPropertyAssignment(child) && child.name.getText() === 'coverage') {\n coverageNode = child.initializer;\n }\n });\n return coverageNode;\n}\n"],"names":["fixCoverageAndRerporters","getConfigNode","ts","configContents","tsquery","configNode","testHasCoverage","query","changes","testObjectLiteralExpressionNode","coverageNode","findCoverageNode","linesNode","statementsNode","functionsNode","branchesNode","push","type","ChangeType","Delete","start","getStart","length","getWidth","Insert","index","text","getText","testHasReporters","testObject","applyChangesToString","configFileContents","arrowFunctionReturnStatement","testNode","forEachChild","child","isPropertyAssignment","name","initializer"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
@@ -1,2 +0,0 @@
1
- import { Tree } from '@nx/devkit';
2
- export default function fixCoverageThreshold(tree: Tree): Promise<void>;
@@ -1,45 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "default", {
3
- enumerable: true,
4
- get: function() {
5
- return fixCoverageThreshold;
6
- }
7
- });
8
- const _devkit = require("@nx/devkit");
9
- const _executoroptionsutils = require("@nx/devkit/src/generators/executor-options-utils");
10
- const _fixcoverageandreporters = require("./lib/fix-coverage-and-reporters");
11
- async function fixCoverageThreshold(tree) {
12
- const projects = (0, _devkit.getProjects)(tree);
13
- (0, _executoroptionsutils.forEachExecutorOptions)(tree, '@nx/vite:test', (_options, projectName)=>{
14
- const projectConfig = projects.get(projectName);
15
- const configPath = findViteConfig(tree, projectConfig.root);
16
- if (!configPath || !tree.exists(configPath)) {
17
- return;
18
- }
19
- const configContents = tree.read(configPath, 'utf-8');
20
- const updatedConfigContents = (0, _fixcoverageandreporters.fixCoverageAndRerporters)(configContents);
21
- if (updatedConfigContents) {
22
- tree.write(configPath, updatedConfigContents);
23
- }
24
- });
25
- await (0, _devkit.formatFiles)(tree);
26
- }
27
- function findViteConfig(tree, searchRoot) {
28
- const allowsExt = [
29
- 'js',
30
- 'mjs',
31
- 'ts',
32
- 'cjs',
33
- 'mts',
34
- 'cts'
35
- ];
36
- for (const ext of allowsExt){
37
- if (tree.exists((0, _devkit.joinPathFragments)(searchRoot, `vite.config.${ext}`))) {
38
- return (0, _devkit.joinPathFragments)(searchRoot, `vite.config.${ext}`);
39
- } else if (tree.exists((0, _devkit.joinPathFragments)(searchRoot, `vitest.config.${ext}`))) {
40
- return (0, _devkit.joinPathFragments)(searchRoot, `vitest.config.${ext}`);
41
- }
42
- }
43
- }
44
-
45
- //# sourceMappingURL=vitest-coverage-and-reporters.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../../../packages/vite/src/migrations/update-17-3-0/vitest-coverage-and-reporters.ts"],"sourcesContent":["import {\n ProjectConfiguration,\n Tree,\n formatFiles,\n getProjects,\n joinPathFragments,\n} from '@nx/devkit';\nimport { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils';\nimport { fixCoverageAndRerporters } from './lib/fix-coverage-and-reporters';\n\nexport default async function fixCoverageThreshold(tree: Tree) {\n const projects = getProjects(tree);\n forEachExecutorOptions(tree, '@nx/vite:test', (_options, projectName) => {\n const projectConfig: ProjectConfiguration = projects.get(\n projectName\n ) as ProjectConfiguration;\n const configPath = findViteConfig(tree, projectConfig.root);\n if (!configPath || !tree.exists(configPath)) {\n return;\n }\n const configContents = tree.read(configPath, 'utf-8') as string;\n const updatedConfigContents = fixCoverageAndRerporters(configContents);\n if (updatedConfigContents) {\n tree.write(configPath, updatedConfigContents);\n }\n });\n\n await formatFiles(tree);\n}\n\nfunction findViteConfig(tree: Tree, searchRoot: string) {\n const allowsExt = ['js', 'mjs', 'ts', 'cjs', 'mts', 'cts'];\n\n for (const ext of allowsExt) {\n if (tree.exists(joinPathFragments(searchRoot, `vite.config.${ext}`))) {\n return joinPathFragments(searchRoot, `vite.config.${ext}`);\n } else if (\n tree.exists(joinPathFragments(searchRoot, `vitest.config.${ext}`))\n ) {\n return joinPathFragments(searchRoot, `vitest.config.${ext}`);\n }\n }\n}\n"],"names":["fixCoverageThreshold","tree","projects","getProjects","forEachExecutorOptions","_options","projectName","projectConfig","get","configPath","findViteConfig","root","exists","configContents","read","updatedConfigContents","fixCoverageAndRerporters","write","formatFiles","searchRoot","allowsExt","ext","joinPathFragments"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":";+BAUA;;;eAA8BA;;;wBAJvB;sCACgC;yCACE;AAE1B,eAAeA,qBAAqBC,IAAU;IAC3D,MAAMC,WAAWC,IAAAA,mBAAW,EAACF;IAC7BG,IAAAA,4CAAsB,EAACH,MAAM,iBAAiB,CAACI,UAAUC;QACvD,MAAMC,gBAAsCL,SAASM,GAAG,CACtDF;QAEF,MAAMG,aAAaC,eAAeT,MAAMM,cAAcI,IAAI;QAC1D,IAAI,CAACF,cAAc,CAACR,KAAKW,MAAM,CAACH,aAAa;YAC3C;QACF;QACA,MAAMI,iBAAiBZ,KAAKa,IAAI,CAACL,YAAY;QAC7C,MAAMM,wBAAwBC,IAAAA,iDAAwB,EAACH;QACvD,IAAIE,uBAAuB;YACzBd,KAAKgB,KAAK,CAACR,YAAYM;QACzB;IACF;IAEA,MAAMG,IAAAA,mBAAW,EAACjB;AACpB;AAEA,SAASS,eAAeT,IAAU,EAAEkB,UAAkB;IACpD,MAAMC,YAAY;QAAC;QAAM;QAAO;QAAM;QAAO;QAAO;KAAM;IAE1D,KAAK,MAAMC,OAAOD,UAAW;QAC3B,IAAInB,KAAKW,MAAM,CAACU,IAAAA,yBAAiB,EAACH,YAAY,CAAC,YAAY,EAAEE,IAAI,CAAC,IAAI;YACpE,OAAOC,IAAAA,yBAAiB,EAACH,YAAY,CAAC,YAAY,EAAEE,IAAI,CAAC;QAC3D,OAAO,IACLpB,KAAKW,MAAM,CAACU,IAAAA,yBAAiB,EAACH,YAAY,CAAC,cAAc,EAAEE,IAAI,CAAC,IAChE;YACA,OAAOC,IAAAA,yBAAiB,EAACH,YAAY,CAAC,cAAc,EAAEE,IAAI,CAAC;QAC7D;IACF;AACF"}