@angular-devkit/build-angular 16.0.0-next.4 → 16.0.0-next.6
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.
- package/package.json +15 -15
- package/src/builders/browser-esbuild/css-plugin.d.ts +4 -0
- package/src/builders/browser-esbuild/css-plugin.js +10 -3
- package/src/builders/browser-esbuild/execution-result.d.ts +21 -0
- package/src/builders/browser-esbuild/execution-result.js +10 -0
- package/src/builders/browser-esbuild/index.d.ts +7 -2
- package/src/builders/browser-esbuild/index.js +148 -81
- package/src/builders/browser-esbuild/options.d.ts +5 -0
- package/src/builders/browser-esbuild/options.js +53 -44
- package/src/builders/browser-esbuild/stylesheet-plugin.d.ts +0 -0
- package/src/builders/browser-esbuild/stylesheet-plugin.js +46 -0
- package/src/builders/browser-esbuild/stylesheets.d.ts +4 -0
- package/src/builders/browser-esbuild/stylesheets.js +2 -1
- package/src/builders/dev-server/builder.d.ts +27 -0
- package/src/builders/dev-server/builder.js +68 -0
- package/src/builders/dev-server/index.d.ts +4 -2
- package/src/builders/dev-server/index.js +6 -5
- package/src/builders/dev-server/options.d.ts +45 -0
- package/src/builders/dev-server/options.js +61 -0
- package/src/builders/dev-server/webpack-server.d.ts +3 -5
- package/src/builders/dev-server/webpack-server.js +9 -53
- package/src/index.d.ts +1 -1
- package/src/index.js +2 -2
- package/src/utils/copy-assets.d.ts +4 -1
- package/src/utils/copy-assets.js +4 -1
- package/src/utils/index-file/index-html-generator.js +13 -2
- package/src/utils/index-file/inline-critical-css.js +90 -1
- package/src/utils/index-file/style-nonce.d.ts +12 -0
- package/src/utils/index-file/style-nonce.js +54 -0
- package/src/utils/service-worker.d.ts +20 -4
- package/src/utils/service-worker.js +63 -30
|
@@ -6,29 +6,6 @@
|
|
|
6
6
|
* Use of this source code is governed by an MIT-style license that can be
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
12
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
13
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
14
|
-
}
|
|
15
|
-
Object.defineProperty(o, k2, desc);
|
|
16
|
-
}) : (function(o, m, k, k2) {
|
|
17
|
-
if (k2 === undefined) k2 = k;
|
|
18
|
-
o[k2] = m[k];
|
|
19
|
-
}));
|
|
20
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
-
}) : function(o, v) {
|
|
23
|
-
o["default"] = v;
|
|
24
|
-
});
|
|
25
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
-
if (mod && mod.__esModule) return mod;
|
|
27
|
-
var result = {};
|
|
28
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
-
__setModuleDefault(result, mod);
|
|
30
|
-
return result;
|
|
31
|
-
};
|
|
32
9
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
10
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
11
|
};
|
|
@@ -36,8 +13,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
36
13
|
exports.buildEsbuildBrowser = void 0;
|
|
37
14
|
const architect_1 = require("@angular-devkit/architect");
|
|
38
15
|
const node_assert_1 = __importDefault(require("node:assert"));
|
|
39
|
-
const
|
|
40
|
-
const
|
|
16
|
+
const node_fs_1 = require("node:fs");
|
|
17
|
+
const promises_1 = __importDefault(require("node:fs/promises"));
|
|
18
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
41
19
|
const utils_1 = require("../../utils");
|
|
42
20
|
const copy_assets_1 = require("../../utils/copy-assets");
|
|
43
21
|
const error_1 = require("../../utils/error");
|
|
@@ -58,15 +36,26 @@ const watcher_1 = require("./watcher");
|
|
|
58
36
|
* Represents the result of a single builder execute call.
|
|
59
37
|
*/
|
|
60
38
|
class ExecutionResult {
|
|
61
|
-
constructor(
|
|
62
|
-
this.success = success;
|
|
39
|
+
constructor(codeRebuild, globalStylesRebuild, codeBundleCache) {
|
|
63
40
|
this.codeRebuild = codeRebuild;
|
|
64
41
|
this.globalStylesRebuild = globalStylesRebuild;
|
|
65
42
|
this.codeBundleCache = codeBundleCache;
|
|
43
|
+
this.outputFiles = [];
|
|
44
|
+
this.assetFiles = [];
|
|
45
|
+
}
|
|
46
|
+
addOutputFile(path, content) {
|
|
47
|
+
this.outputFiles.push(createOutputFileFromText(path, content));
|
|
66
48
|
}
|
|
67
49
|
get output() {
|
|
68
50
|
return {
|
|
69
|
-
success: this.
|
|
51
|
+
success: this.outputFiles.length > 0,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
get outputWithFiles() {
|
|
55
|
+
return {
|
|
56
|
+
success: this.outputFiles.length > 0,
|
|
57
|
+
outputFiles: this.outputFiles,
|
|
58
|
+
assetFiles: this.assetFiles,
|
|
70
59
|
};
|
|
71
60
|
}
|
|
72
61
|
createRebuildState(fileChanges) {
|
|
@@ -79,12 +68,12 @@ class ExecutionResult {
|
|
|
79
68
|
};
|
|
80
69
|
}
|
|
81
70
|
async dispose() {
|
|
82
|
-
await Promise.
|
|
71
|
+
await Promise.allSettled([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);
|
|
83
72
|
}
|
|
84
73
|
}
|
|
85
74
|
async function execute(options, context, rebuildState) {
|
|
86
75
|
const startTime = process.hrtime.bigint();
|
|
87
|
-
const { projectRoot, workspaceRoot, optimizationOptions,
|
|
76
|
+
const { projectRoot, workspaceRoot, optimizationOptions, assets, serviceWorkerOptions, indexHtmlOptions, } = options;
|
|
88
77
|
const browsers = (0, supported_browsers_1.getSupportedBrowsers)(projectRoot, context.logger);
|
|
89
78
|
const target = (0, esbuild_targets_1.transformSupportedBrowsersToTargets)(browsers);
|
|
90
79
|
// Reuse rebuild state or create new bundle contexts for code and global stylesheets
|
|
@@ -106,19 +95,16 @@ async function execute(options, context, rebuildState) {
|
|
|
106
95
|
errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],
|
|
107
96
|
warnings: [...codeResults.warnings, ...styleResults.warnings],
|
|
108
97
|
});
|
|
109
|
-
|
|
110
|
-
if
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
// Return if the global stylesheet bundling has errors
|
|
114
|
-
if (styleResults.errors) {
|
|
115
|
-
return new ExecutionResult(false, codeBundleContext, globalStylesBundleContext, codeBundleCache);
|
|
98
|
+
const executionResult = new ExecutionResult(codeBundleContext, globalStylesBundleContext, codeBundleCache);
|
|
99
|
+
// Return if the bundling has errors
|
|
100
|
+
if (codeResults.errors || styleResults.errors) {
|
|
101
|
+
return executionResult;
|
|
116
102
|
}
|
|
117
103
|
// Filter global stylesheet initial files
|
|
118
104
|
styleResults.initialFiles = styleResults.initialFiles.filter(({ name }) => options.globalStyles.find((style) => style.name === name)?.initial);
|
|
119
105
|
// Combine the bundling output files
|
|
120
106
|
const initialFiles = [...codeResults.initialFiles, ...styleResults.initialFiles];
|
|
121
|
-
|
|
107
|
+
executionResult.outputFiles.push(...codeResults.outputFiles, ...styleResults.outputFiles);
|
|
122
108
|
// Combine metafiles used for the stats option as well as bundle budgets and console output
|
|
123
109
|
const metafile = {
|
|
124
110
|
inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },
|
|
@@ -143,12 +129,12 @@ async function execute(options, context, rebuildState) {
|
|
|
143
129
|
const virtualOutputPath = '/';
|
|
144
130
|
indexHtmlGenerator.readAsset = async function (filePath) {
|
|
145
131
|
// Remove leading directory separator
|
|
146
|
-
const relativefilePath =
|
|
147
|
-
const file = outputFiles.find((file) => file.path === relativefilePath);
|
|
132
|
+
const relativefilePath = node_path_1.default.relative(virtualOutputPath, filePath);
|
|
133
|
+
const file = executionResult.outputFiles.find((file) => file.path === relativefilePath);
|
|
148
134
|
if (file) {
|
|
149
135
|
return file.text;
|
|
150
136
|
}
|
|
151
|
-
throw new Error(`Output file does not exist: ${
|
|
137
|
+
throw new Error(`Output file does not exist: ${node_path_1.default}`);
|
|
152
138
|
};
|
|
153
139
|
const { content, warnings, errors } = await indexHtmlGenerator.process({
|
|
154
140
|
baseHref: options.baseHref,
|
|
@@ -162,36 +148,64 @@ async function execute(options, context, rebuildState) {
|
|
|
162
148
|
for (const warning of warnings) {
|
|
163
149
|
context.logger.warn(warning);
|
|
164
150
|
}
|
|
165
|
-
|
|
151
|
+
executionResult.addOutputFile(indexHtmlOptions.output, content);
|
|
166
152
|
}
|
|
167
153
|
// Copy assets
|
|
168
154
|
if (assets) {
|
|
169
|
-
|
|
155
|
+
// The webpack copy assets helper is used with no base paths defined. This prevents the helper
|
|
156
|
+
// from directly writing to disk. This should eventually be replaced with a more optimized helper.
|
|
157
|
+
executionResult.assetFiles.push(...(await (0, copy_assets_1.copyAssets)(assets, [], workspaceRoot)));
|
|
170
158
|
}
|
|
171
|
-
// Write output files
|
|
172
|
-
await Promise.all(outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)));
|
|
173
159
|
// Write metafile if stats option is enabled
|
|
174
160
|
if (options.stats) {
|
|
175
|
-
|
|
161
|
+
executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));
|
|
176
162
|
}
|
|
177
163
|
// Extract and write licenses for used packages
|
|
178
164
|
if (options.extractLicenses) {
|
|
179
|
-
|
|
165
|
+
executionResult.addOutputFile('3rdpartylicenses.txt', await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot));
|
|
180
166
|
}
|
|
181
167
|
// Augment the application with service worker support
|
|
182
|
-
// TODO: This should eventually operate on the in-memory files prior to writing the output files
|
|
183
168
|
if (serviceWorkerOptions) {
|
|
184
169
|
try {
|
|
185
|
-
await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorkerOptions,
|
|
170
|
+
const serviceWorkerResult = await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorkerOptions, options.baseHref || '/', executionResult.outputFiles, executionResult.assetFiles);
|
|
171
|
+
executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);
|
|
172
|
+
executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);
|
|
186
173
|
}
|
|
187
174
|
catch (error) {
|
|
188
175
|
context.logger.error(error instanceof Error ? error.message : `${error}`);
|
|
189
|
-
return
|
|
176
|
+
return executionResult;
|
|
190
177
|
}
|
|
191
178
|
}
|
|
192
179
|
const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;
|
|
193
180
|
context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);
|
|
194
|
-
return
|
|
181
|
+
return executionResult;
|
|
182
|
+
}
|
|
183
|
+
async function writeResultFiles(outputFiles, assetFiles, outputPath) {
|
|
184
|
+
const directoryExists = new Set();
|
|
185
|
+
await Promise.all(outputFiles.map(async (file) => {
|
|
186
|
+
// Ensure output subdirectories exist
|
|
187
|
+
const basePath = node_path_1.default.dirname(file.path);
|
|
188
|
+
if (basePath && !directoryExists.has(basePath)) {
|
|
189
|
+
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
190
|
+
directoryExists.add(basePath);
|
|
191
|
+
}
|
|
192
|
+
// Write file contents
|
|
193
|
+
await promises_1.default.writeFile(node_path_1.default.join(outputPath, file.path), file.contents);
|
|
194
|
+
}));
|
|
195
|
+
if (assetFiles?.length) {
|
|
196
|
+
await Promise.all(assetFiles.map(async ({ source, destination }) => {
|
|
197
|
+
// Ensure output subdirectories exist
|
|
198
|
+
const basePath = node_path_1.default.dirname(destination);
|
|
199
|
+
if (basePath && !directoryExists.has(basePath)) {
|
|
200
|
+
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
201
|
+
directoryExists.add(basePath);
|
|
202
|
+
}
|
|
203
|
+
// Copy file contents
|
|
204
|
+
await promises_1.default.copyFile(source, node_path_1.default.join(outputPath, destination),
|
|
205
|
+
// This is not yet available from `fs/promises` in Node.js v16.13
|
|
206
|
+
node_fs_1.constants.COPYFILE_FICLONE);
|
|
207
|
+
}));
|
|
208
|
+
}
|
|
195
209
|
}
|
|
196
210
|
function createOutputFileFromText(path, text) {
|
|
197
211
|
return {
|
|
@@ -203,8 +217,8 @@ function createOutputFileFromText(path, text) {
|
|
|
203
217
|
};
|
|
204
218
|
}
|
|
205
219
|
function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
|
|
206
|
-
const { workspaceRoot, entryPoints, optimizationOptions, sourcemapOptions, tsconfig, outputNames, fileReplacements, externalDependencies, preserveSymlinks, stylePreprocessorOptions, advancedOptimizations, inlineStyleLanguage, jit, } = options;
|
|
207
|
-
|
|
220
|
+
const { workspaceRoot, entryPoints, polyfills, optimizationOptions, sourcemapOptions, tsconfig, outputNames, fileReplacements, externalDependencies, preserveSymlinks, stylePreprocessorOptions, advancedOptimizations, inlineStyleLanguage, jit, tailwindConfiguration, } = options;
|
|
221
|
+
const buildOptions = {
|
|
208
222
|
absWorkingDir: workspaceRoot,
|
|
209
223
|
bundle: true,
|
|
210
224
|
format: 'esm',
|
|
@@ -256,6 +270,7 @@ function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
|
|
|
256
270
|
target,
|
|
257
271
|
inlineStyleLanguage,
|
|
258
272
|
browsers,
|
|
273
|
+
tailwindConfiguration,
|
|
259
274
|
}),
|
|
260
275
|
],
|
|
261
276
|
define: {
|
|
@@ -266,6 +281,35 @@ function createCodeBundleOptions(options, target, browsers, sourceFileCache) {
|
|
|
266
281
|
'ngJitMode': jit ? 'true' : 'false',
|
|
267
282
|
},
|
|
268
283
|
};
|
|
284
|
+
if (polyfills?.length) {
|
|
285
|
+
const namespace = 'angular:polyfills';
|
|
286
|
+
buildOptions.entryPoints = {
|
|
287
|
+
...buildOptions.entryPoints,
|
|
288
|
+
['polyfills']: namespace,
|
|
289
|
+
};
|
|
290
|
+
buildOptions.plugins?.unshift({
|
|
291
|
+
name: 'angular-polyfills',
|
|
292
|
+
setup(build) {
|
|
293
|
+
build.onResolve({ filter: /^angular:polyfills$/ }, (args) => {
|
|
294
|
+
if (args.kind !== 'entry-point') {
|
|
295
|
+
return null;
|
|
296
|
+
}
|
|
297
|
+
return {
|
|
298
|
+
path: 'entry',
|
|
299
|
+
namespace,
|
|
300
|
+
};
|
|
301
|
+
});
|
|
302
|
+
build.onLoad({ filter: /./, namespace }, () => {
|
|
303
|
+
return {
|
|
304
|
+
contents: polyfills.map((file) => `import '${file.replace(/\\/g, '/')}';`).join('\n'),
|
|
305
|
+
loader: 'js',
|
|
306
|
+
resolveDir: workspaceRoot,
|
|
307
|
+
};
|
|
308
|
+
});
|
|
309
|
+
},
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
return buildOptions;
|
|
269
313
|
}
|
|
270
314
|
/**
|
|
271
315
|
* Generates a syntax feature object map for Angular applications based on a list of targets.
|
|
@@ -318,7 +362,7 @@ function getFeatureSupport(target) {
|
|
|
318
362
|
return supported;
|
|
319
363
|
}
|
|
320
364
|
function createGlobalStylesBundleOptions(options, target, browsers) {
|
|
321
|
-
const { workspaceRoot, optimizationOptions, sourcemapOptions, outputNames, globalStyles, preserveSymlinks, externalDependencies, stylePreprocessorOptions, } = options;
|
|
365
|
+
const { workspaceRoot, optimizationOptions, sourcemapOptions, outputNames, globalStyles, preserveSymlinks, externalDependencies, stylePreprocessorOptions, tailwindConfiguration, } = options;
|
|
322
366
|
const buildOptions = (0, stylesheets_1.createStylesheetBundleOptions)({
|
|
323
367
|
workspaceRoot,
|
|
324
368
|
optimization: !!optimizationOptions.styles.minify,
|
|
@@ -329,6 +373,7 @@ function createGlobalStylesBundleOptions(options, target, browsers) {
|
|
|
329
373
|
outputNames,
|
|
330
374
|
includePaths: stylePreprocessorOptions?.includePaths,
|
|
331
375
|
browsers,
|
|
376
|
+
tailwindConfiguration,
|
|
332
377
|
});
|
|
333
378
|
buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';
|
|
334
379
|
const namespace = 'angular:styles/global';
|
|
@@ -364,54 +409,67 @@ function createGlobalStylesBundleOptions(options, target, browsers) {
|
|
|
364
409
|
/**
|
|
365
410
|
* Main execution function for the esbuild-based application builder.
|
|
366
411
|
* The options are compatible with the Webpack-based builder.
|
|
367
|
-
* @param
|
|
412
|
+
* @param userOptions The browser builder options to use when setting up the application build
|
|
368
413
|
* @param context The Architect builder context object
|
|
369
414
|
* @returns An async iterable with the builder result output
|
|
370
415
|
*/
|
|
371
|
-
async function* buildEsbuildBrowser(
|
|
416
|
+
async function* buildEsbuildBrowser(userOptions, context, infrastructureSettings) {
|
|
372
417
|
// Inform user of experimental status of builder and options
|
|
373
|
-
(0, experimental_warnings_1.logExperimentalWarnings)(
|
|
418
|
+
(0, experimental_warnings_1.logExperimentalWarnings)(userOptions, context);
|
|
374
419
|
// Determine project name from builder context target
|
|
375
420
|
const projectName = context.target?.project;
|
|
376
421
|
if (!projectName) {
|
|
377
422
|
context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);
|
|
378
423
|
return;
|
|
379
424
|
}
|
|
380
|
-
const normalizedOptions = await (0, options_1.normalizeOptions)(context, projectName,
|
|
381
|
-
//
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
425
|
+
const normalizedOptions = await (0, options_1.normalizeOptions)(context, projectName, userOptions);
|
|
426
|
+
// Writing the result to the filesystem is the default behavior
|
|
427
|
+
const shouldWriteResult = infrastructureSettings?.write !== false;
|
|
428
|
+
if (shouldWriteResult) {
|
|
429
|
+
// Clean output path if enabled
|
|
430
|
+
if (userOptions.deleteOutputPath) {
|
|
431
|
+
(0, utils_1.deleteOutputDir)(normalizedOptions.workspaceRoot, userOptions.outputPath);
|
|
432
|
+
}
|
|
433
|
+
// Create output directory if needed
|
|
434
|
+
try {
|
|
435
|
+
await promises_1.default.mkdir(normalizedOptions.outputPath, { recursive: true });
|
|
436
|
+
}
|
|
437
|
+
catch (e) {
|
|
438
|
+
(0, error_1.assertIsError)(e);
|
|
439
|
+
context.logger.error('Unable to create output directory: ' + e.message);
|
|
440
|
+
return;
|
|
441
|
+
}
|
|
393
442
|
}
|
|
394
443
|
// Initial build
|
|
395
444
|
let result;
|
|
396
445
|
try {
|
|
397
446
|
result = await execute(normalizedOptions, context);
|
|
398
|
-
|
|
447
|
+
if (shouldWriteResult) {
|
|
448
|
+
// Write output files
|
|
449
|
+
await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.outputPath);
|
|
450
|
+
yield result.output;
|
|
451
|
+
}
|
|
452
|
+
else {
|
|
453
|
+
// Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
|
|
454
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
455
|
+
yield result.outputWithFiles;
|
|
456
|
+
}
|
|
399
457
|
// Finish if watch mode is not enabled
|
|
400
|
-
if (!
|
|
458
|
+
if (!userOptions.watch) {
|
|
401
459
|
return;
|
|
402
460
|
}
|
|
403
461
|
}
|
|
404
462
|
finally {
|
|
405
463
|
// Ensure Sass workers are shutdown if not watching
|
|
406
|
-
if (!
|
|
464
|
+
if (!userOptions.watch) {
|
|
407
465
|
(0, sass_plugin_1.shutdownSassWorkerPool)();
|
|
408
466
|
}
|
|
409
467
|
}
|
|
410
468
|
context.logger.info('Watch mode enabled. Watching for file changes...');
|
|
411
469
|
// Setup a watcher
|
|
412
470
|
const watcher = (0, watcher_1.createWatcher)({
|
|
413
|
-
polling: typeof
|
|
414
|
-
interval:
|
|
471
|
+
polling: typeof userOptions.poll === 'number',
|
|
472
|
+
interval: userOptions.poll,
|
|
415
473
|
// Ignore the output and cache paths to avoid infinite rebuild cycles
|
|
416
474
|
ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],
|
|
417
475
|
});
|
|
@@ -419,18 +477,27 @@ async function* buildEsbuildBrowser(initialOptions, context) {
|
|
|
419
477
|
watcher.add(normalizedOptions.projectRoot);
|
|
420
478
|
// Watch workspace root node modules
|
|
421
479
|
// Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
|
|
422
|
-
watcher.add(
|
|
423
|
-
watcher.add(
|
|
424
|
-
watcher.add(
|
|
480
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, 'node_modules'));
|
|
481
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));
|
|
482
|
+
watcher.add(node_path_1.default.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));
|
|
425
483
|
// Wait for changes and rebuild as needed
|
|
426
484
|
try {
|
|
427
485
|
for await (const changes of watcher) {
|
|
428
486
|
context.logger.info('Changes detected. Rebuilding...');
|
|
429
|
-
if (
|
|
487
|
+
if (userOptions.verbose) {
|
|
430
488
|
context.logger.info(changes.toDebugString());
|
|
431
489
|
}
|
|
432
490
|
result = await execute(normalizedOptions, context, result.createRebuildState(changes));
|
|
433
|
-
|
|
491
|
+
if (shouldWriteResult) {
|
|
492
|
+
// Write output files
|
|
493
|
+
await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.outputPath);
|
|
494
|
+
yield result.output;
|
|
495
|
+
}
|
|
496
|
+
else {
|
|
497
|
+
// Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
|
|
498
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
499
|
+
yield result.outputWithFiles;
|
|
500
|
+
}
|
|
434
501
|
}
|
|
435
502
|
}
|
|
436
503
|
finally {
|
|
@@ -443,4 +510,4 @@ async function* buildEsbuildBrowser(initialOptions, context) {
|
|
|
443
510
|
}
|
|
444
511
|
exports.buildEsbuildBrowser = buildEsbuildBrowser;
|
|
445
512
|
exports.default = (0, architect_1.createBuilder)(buildEsbuildBrowser);
|
|
446
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildOptions, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { deleteOutputDir } from '../../utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { extractLicenses } from './license-extractor';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport { ChangedFiles, createWatcher } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BundlerContext;\n  globalStylesRebuild?: BundlerContext;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  constructor(\n    private success: boolean,\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  get output() {\n    return {\n      success: this.success,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.all([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    outputPath,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n  const codeBundleContext =\n    rebuildState?.codeRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createCodeBundleOptions(options, target, browsers, codeBundleCache),\n    );\n  const globalStylesBundleContext =\n    rebuildState?.globalStylesRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalStylesBundleOptions(options, target, browsers),\n    );\n\n  const [codeResults, styleResults] = await Promise.all([\n    // Execute esbuild to bundle the application code\n    codeBundleContext.bundle(),\n    // Execute esbuild to bundle the global stylesheets\n    globalStylesBundleContext.bundle(),\n  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  // Return if the bundling failed to generate output files or there are errors\n  if (codeResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Return if the global stylesheet bundling has errors\n  if (styleResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Filter global stylesheet initial files\n  styleResults.initialFiles = styleResults.initialFiles.filter(\n    ({ name }) => options.globalStyles.find((style) => style.name === name)?.initial,\n  );\n\n  // Combine the bundling output files\n  const initialFiles: FileInfo[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  const outputFiles: OutputFile[] = [...codeResults.outputFiles, ...styleResults.outputFiles];\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\n  };\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  // Generate index HTML file\n  if (indexHtmlOptions) {\n    // Create an index HTML generator that reads from the in-memory output files\n    const indexHtmlGenerator = new IndexHtmlGenerator({\n      indexPath: indexHtmlOptions.input,\n      entrypoints: indexHtmlOptions.insertionOrder,\n      sri: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.readAsset = async function (filePath: string): Promise<string> {\n      // Remove leading directory separator\n      const relativefilePath = path.relative(virtualOutputPath, filePath);\n      const file = outputFiles.find((file) => file.path === relativefilePath);\n      if (file) {\n        return file.text;\n      }\n\n      throw new Error(`Output file does not exist: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\n    for (const error of errors) {\n      context.logger.error(error);\n    }\n    for (const warning of warnings) {\n      context.logger.warn(warning);\n    }\n\n    outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));\n  }\n\n  // Copy assets\n  if (assets) {\n    await copyAssets(assets, [outputPath], workspaceRoot);\n  }\n\n  // Write output files\n  await Promise.all(\n    outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)),\n  );\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    await fs.writeFile(path.join(outputPath, 'stats.json'), JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    await fs.writeFile(\n      path.join(outputPath, '3rdpartylicenses.txt'),\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  // TODO: This should eventually operate on the in-memory files prior to writing the output files\n  if (serviceWorkerOptions) {\n    try {\n      await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\n        outputPath,\n        options.baseHref || '/',\n      );\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return new ExecutionResult(\n        false,\n        codeBundleContext,\n        globalStylesBundleContext,\n        codeBundleCache,\n      );\n    }\n  }\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);\n}\n\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n    jit,\n  } = options;\n\n  return {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    legalComments: options.extractLicenses ? 'none' : 'eof',\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          jit,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n          browsers,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      'ngJitMode': jit ? 'true' : 'false',\n    },\n  };\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nfunction getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions({\n    workspaceRoot,\n    optimization: !!optimizationOptions.styles.minify,\n    sourcemap: !!sourcemapOptions.styles,\n    preserveSymlinks,\n    target,\n    externalDependencies,\n    outputNames,\n    includePaths: stylePreprocessorOptions?.includePaths,\n    browsers,\n  });\n  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param initialOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  initialOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n): AsyncIterable<BuilderOutput> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(initialOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, initialOptions);\n\n  // Clean output path if enabled\n  if (initialOptions.deleteOutputPath) {\n    deleteOutputDir(normalizedOptions.workspaceRoot, initialOptions.outputPath);\n  }\n\n  // Create output directory if needed\n  try {\n    await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n  } catch (e) {\n    assertIsError(e);\n    context.logger.error('Unable to create output directory: ' + e.message);\n\n    return;\n  }\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n    yield result.output;\n\n    // Finish if watch mode is not enabled\n    if (!initialOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!initialOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof initialOptions.poll === 'number',\n    interval: initialOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (initialOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n      yield result.output;\n    }\n  } finally {\n    // Stop the watcher\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    await result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n"]}
|
|
513
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { BuilderContext, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildOptions, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { deleteOutputDir } from '../../utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { extractLicenses } from './license-extractor';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport { ChangedFiles, createWatcher } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BundlerContext;\n  globalStylesRebuild?: BundlerContext;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  readonly outputFiles: OutputFile[] = [];\n  readonly assetFiles: { source: string; destination: string }[] = [];\n\n  constructor(\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  addOutputFile(path: string, content: string): void {\n    this.outputFiles.push(createOutputFileFromText(path, content));\n  }\n\n  get output() {\n    return {\n      success: this.outputFiles.length > 0,\n    };\n  }\n\n  get outputWithFiles() {\n    return {\n      success: this.outputFiles.length > 0,\n      outputFiles: this.outputFiles,\n      assetFiles: this.assetFiles,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.allSettled([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n  const codeBundleContext =\n    rebuildState?.codeRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createCodeBundleOptions(options, target, browsers, codeBundleCache),\n    );\n  const globalStylesBundleContext =\n    rebuildState?.globalStylesRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalStylesBundleOptions(options, target, browsers),\n    );\n\n  const [codeResults, styleResults] = await Promise.all([\n    // Execute esbuild to bundle the application code\n    codeBundleContext.bundle(),\n    // Execute esbuild to bundle the global stylesheets\n    globalStylesBundleContext.bundle(),\n  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  const executionResult = new ExecutionResult(\n    codeBundleContext,\n    globalStylesBundleContext,\n    codeBundleCache,\n  );\n\n  // Return if the bundling has errors\n  if (codeResults.errors || styleResults.errors) {\n    return executionResult;\n  }\n\n  // Filter global stylesheet initial files\n  styleResults.initialFiles = styleResults.initialFiles.filter(\n    ({ name }) => options.globalStyles.find((style) => style.name === name)?.initial,\n  );\n\n  // Combine the bundling output files\n  const initialFiles: FileInfo[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  executionResult.outputFiles.push(...codeResults.outputFiles, ...styleResults.outputFiles);\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\n  };\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  // Generate index HTML file\n  if (indexHtmlOptions) {\n    // Create an index HTML generator that reads from the in-memory output files\n    const indexHtmlGenerator = new IndexHtmlGenerator({\n      indexPath: indexHtmlOptions.input,\n      entrypoints: indexHtmlOptions.insertionOrder,\n      sri: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.readAsset = async function (filePath: string): Promise<string> {\n      // Remove leading directory separator\n      const relativefilePath = path.relative(virtualOutputPath, filePath);\n      const file = executionResult.outputFiles.find((file) => file.path === relativefilePath);\n      if (file) {\n        return file.text;\n      }\n\n      throw new Error(`Output file does not exist: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\n    for (const error of errors) {\n      context.logger.error(error);\n    }\n    for (const warning of warnings) {\n      context.logger.warn(warning);\n    }\n\n    executionResult.addOutputFile(indexHtmlOptions.output, content);\n  }\n\n  // Copy assets\n  if (assets) {\n    // The webpack copy assets helper is used with no base paths defined. This prevents the helper\n    // from directly writing to disk. This should eventually be replaced with a more optimized helper.\n    executionResult.assetFiles.push(...(await copyAssets(assets, [], workspaceRoot)));\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    executionResult.addOutputFile(\n      '3rdpartylicenses.txt',\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  if (serviceWorkerOptions) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\n        options.baseHref || '/',\n        executionResult.outputFiles,\n        executionResult.assetFiles,\n      );\n      executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);\n      executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return executionResult;\n    }\n  }\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return executionResult;\n}\n\nasync function writeResultFiles(\n  outputFiles: OutputFile[],\n  assetFiles: { source: string; destination: string }[] | undefined,\n  outputPath: string,\n) {\n  const directoryExists = new Set<string>();\n  await Promise.all(\n    outputFiles.map(async (file) => {\n      // Ensure output subdirectories exist\n      const basePath = path.dirname(file.path);\n      if (basePath && !directoryExists.has(basePath)) {\n        await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n        directoryExists.add(basePath);\n      }\n      // Write file contents\n      await fs.writeFile(path.join(outputPath, file.path), file.contents);\n    }),\n  );\n\n  if (assetFiles?.length) {\n    await Promise.all(\n      assetFiles.map(async ({ source, destination }) => {\n        // Ensure output subdirectories exist\n        const basePath = path.dirname(destination);\n        if (basePath && !directoryExists.has(basePath)) {\n          await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n          directoryExists.add(basePath);\n        }\n        // Copy file contents\n        await fs.copyFile(\n          source,\n          path.join(outputPath, destination),\n          // This is not yet available from `fs/promises` in Node.js v16.13\n          fsConstants.COPYFILE_FICLONE,\n        );\n      }),\n    );\n  }\n}\n\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    polyfills,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n    jit,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions: BuildOptions = {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    legalComments: options.extractLicenses ? 'none' : 'eof',\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          jit,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n          browsers,\n          tailwindConfiguration,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      'ngJitMode': jit ? 'true' : 'false',\n    },\n  };\n\n  if (polyfills?.length) {\n    const namespace = 'angular:polyfills';\n    buildOptions.entryPoints = {\n      ...buildOptions.entryPoints,\n      ['polyfills']: namespace,\n    };\n\n    buildOptions.plugins?.unshift({\n      name: 'angular-polyfills',\n      setup(build) {\n        build.onResolve({ filter: /^angular:polyfills$/ }, (args) => {\n          if (args.kind !== 'entry-point') {\n            return null;\n          }\n\n          return {\n            path: 'entry',\n            namespace,\n          };\n        });\n        build.onLoad({ filter: /./, namespace }, () => {\n          return {\n            contents: polyfills.map((file) => `import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n            loader: 'js',\n            resolveDir: workspaceRoot,\n          };\n        });\n      },\n    });\n  }\n\n  return buildOptions;\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nfunction getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  browsers: string[],\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    tailwindConfiguration,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions({\n    workspaceRoot,\n    optimization: !!optimizationOptions.styles.minify,\n    sourcemap: !!sourcemapOptions.styles,\n    preserveSymlinks,\n    target,\n    externalDependencies,\n    outputNames,\n    includePaths: stylePreprocessorOptions?.includePaths,\n    browsers,\n    tailwindConfiguration,\n  });\n  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param userOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  userOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n  infrastructureSettings?: {\n    write?: boolean;\n  },\n): AsyncIterable<BuilderOutput & { outputFiles?: OutputFile[] }> {\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(userOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, userOptions);\n  // Writing the result to the filesystem is the default behavior\n  const shouldWriteResult = infrastructureSettings?.write !== false;\n\n  if (shouldWriteResult) {\n    // Clean output path if enabled\n    if (userOptions.deleteOutputPath) {\n      deleteOutputDir(normalizedOptions.workspaceRoot, userOptions.outputPath);\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      context.logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n\n    if (shouldWriteResult) {\n      // Write output files\n      await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.outputPath);\n\n      yield result.output;\n    } else {\n      // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      yield result.outputWithFiles as any;\n    }\n\n    // Finish if watch mode is not enabled\n    if (!userOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!userOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof userOptions.poll === 'number',\n    interval: userOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (userOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n\n      if (shouldWriteResult) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, normalizedOptions.outputPath);\n\n        yield result.output;\n      } else {\n        // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        yield result.outputWithFiles as any;\n      }\n    }\n  } finally {\n    // Stop the watcher\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    await result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n"]}
|
|
@@ -29,6 +29,7 @@ export declare function normalizeOptions(context: BuilderContext, projectName: s
|
|
|
29
29
|
inlineStyleLanguage: string;
|
|
30
30
|
jit: boolean;
|
|
31
31
|
stats: boolean;
|
|
32
|
+
polyfills: string[] | undefined;
|
|
32
33
|
poll: number | undefined;
|
|
33
34
|
preserveSymlinks: boolean;
|
|
34
35
|
stylePreprocessorOptions: import("./schema").StylePreprocessorOptions | undefined;
|
|
@@ -59,4 +60,8 @@ export declare function normalizeOptions(context: BuilderContext, projectName: s
|
|
|
59
60
|
output: string;
|
|
60
61
|
insertionOrder: import("../../utils/package-chunk-sort").EntryPointsType[];
|
|
61
62
|
} | undefined;
|
|
63
|
+
tailwindConfiguration: {
|
|
64
|
+
file: string;
|
|
65
|
+
package: string;
|
|
66
|
+
} | undefined;
|
|
62
67
|
}>;
|