@angular/build 19.0.0-next.2 → 19.0.0-next.4

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 (42) hide show
  1. package/package.json +10 -10
  2. package/src/builders/application/execute-post-bundle.js +29 -18
  3. package/src/builders/application/i18n.js +2 -11
  4. package/src/builders/application/options.d.ts +11 -0
  5. package/src/builders/application/options.js +23 -1
  6. package/src/builders/application/setup-bundling.js +7 -7
  7. package/src/builders/dev-server/internal.d.ts +0 -1
  8. package/src/builders/dev-server/internal.js +1 -3
  9. package/src/builders/dev-server/vite-server.d.ts +7 -2
  10. package/src/builders/dev-server/vite-server.js +27 -12
  11. package/src/tools/angular/compilation/parallel-compilation.d.ts +1 -1
  12. package/src/tools/angular/compilation/parallel-compilation.js +5 -0
  13. package/src/tools/esbuild/angular/file-reference-tracker.d.ts +1 -1
  14. package/src/tools/esbuild/application-code-bundle.d.ts +1 -6
  15. package/src/tools/esbuild/application-code-bundle.js +105 -70
  16. package/src/tools/esbuild/bundler-context.js +14 -10
  17. package/src/tools/esbuild/cache.d.ts +1 -1
  18. package/src/tools/esbuild/javascript-transformer.js +6 -0
  19. package/src/tools/esbuild/utils.d.ts +9 -0
  20. package/src/tools/esbuild/utils.js +14 -0
  21. package/src/tools/sass/sass-service.js +15 -4
  22. package/src/tools/sass/worker.d.ts +13 -32
  23. package/src/tools/sass/worker.js +1 -0
  24. package/src/tools/vite/angular-memory-plugin.js +2 -2
  25. package/src/tools/vite/middlewares/ssr-middleware.d.ts +1 -4
  26. package/src/tools/vite/middlewares/ssr-middleware.js +25 -38
  27. package/src/typings.d.ts +7 -0
  28. package/src/utils/normalize-cache.js +1 -1
  29. package/src/utils/server-rendering/fetch-patch.js +4 -5
  30. package/src/utils/server-rendering/load-esm-from-memory.d.ts +12 -2
  31. package/src/utils/server-rendering/manifest.d.ts +44 -0
  32. package/src/utils/server-rendering/manifest.js +86 -0
  33. package/src/utils/server-rendering/prerender.d.ts +22 -2
  34. package/src/utils/server-rendering/prerender.js +51 -40
  35. package/src/utils/server-rendering/render-worker.d.ts +7 -8
  36. package/src/utils/server-rendering/render-worker.js +10 -13
  37. package/src/utils/server-rendering/routes-extractor-worker.d.ts +2 -6
  38. package/src/utils/server-rendering/routes-extractor-worker.js +3 -34
  39. package/src/utils/server-rendering/main-bundle-exports.d.ts +0 -27
  40. package/src/utils/server-rendering/main-bundle-exports.js +0 -9
  41. package/src/utils/server-rendering/render-page.d.ts +0 -26
  42. package/src/utils/server-rendering/render-page.js +0 -114
@@ -1,114 +0,0 @@
1
- "use strict";
2
- /**
3
- * @license
4
- * Copyright Google LLC All Rights Reserved.
5
- *
6
- * Use of this source code is governed by an MIT-style license that can be
7
- * found in the LICENSE file at https://angular.dev/license
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
- var __importDefault = (this && this.__importDefault) || function (mod) {
33
- return (mod && mod.__esModule) ? mod : { "default": mod };
34
- };
35
- Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.renderPage = renderPage;
37
- const node_assert_1 = __importDefault(require("node:assert"));
38
- const node_path_1 = require("node:path");
39
- const load_esm_from_memory_1 = require("./load-esm-from-memory");
40
- /**
41
- * Renders each route in routes and writes them to <outputPath>/<route>/index.html.
42
- */
43
- async function renderPage({ route, serverContext, document, inlineCriticalCss, outputFiles, loadBundle = load_esm_from_memory_1.loadEsmModuleFromMemory, }) {
44
- const { default: bootstrapAppFnOrModule } = await loadBundle('./main.server.mjs');
45
- const { ɵSERVER_CONTEXT, renderModule, renderApplication, ɵresetCompiledComponents, ɵConsole } = await loadBundle('./render-utils.server.mjs');
46
- // Need to clean up GENERATED_COMP_IDS map in `@angular/core`.
47
- // Otherwise an incorrect component ID generation collision detected warning will be displayed in development.
48
- // See: https://github.com/angular/angular-cli/issues/25924
49
- ɵresetCompiledComponents?.();
50
- const platformProviders = [
51
- {
52
- provide: ɵSERVER_CONTEXT,
53
- useValue: serverContext,
54
- },
55
- {
56
- provide: ɵConsole,
57
- /** An Angular Console Provider that does not print a set of predefined logs. */
58
- useFactory: () => {
59
- class Console extends ɵConsole {
60
- ignoredLogs = new Set(['Angular is running in development mode.']);
61
- log(message) {
62
- if (!this.ignoredLogs.has(message)) {
63
- super.log(message);
64
- }
65
- }
66
- }
67
- return new Console();
68
- },
69
- },
70
- ];
71
- (0, node_assert_1.default)(bootstrapAppFnOrModule, 'The file "./main.server.mjs" does not have a default export for an AppServerModule or a bootstrapping function.');
72
- let renderAppPromise;
73
- if (isBootstrapFn(bootstrapAppFnOrModule)) {
74
- renderAppPromise = renderApplication(bootstrapAppFnOrModule, {
75
- document,
76
- url: route,
77
- platformProviders,
78
- });
79
- }
80
- else {
81
- renderAppPromise = renderModule(bootstrapAppFnOrModule, {
82
- document,
83
- url: route,
84
- extraProviders: platformProviders,
85
- });
86
- }
87
- // The below should really handled by the framework!!!.
88
- // See: https://github.com/angular/angular/issues/51549
89
- let timer;
90
- const renderingTimeout = new Promise((_, reject) => (timer = setTimeout(() => reject(new Error(`Page ${new URL(route, 'resolve://').pathname} did not render in 30 seconds.`)), 30_000)));
91
- const html = await Promise.race([renderAppPromise, renderingTimeout]).finally(() => clearTimeout(timer));
92
- if (inlineCriticalCss) {
93
- const { InlineCriticalCssProcessor } = await Promise.resolve().then(() => __importStar(require('../../utils/index-file/inline-critical-css')));
94
- const inlineCriticalCssProcessor = new InlineCriticalCssProcessor({
95
- minify: false, // CSS has already been minified during the build.
96
- readAsset: async (filePath) => {
97
- filePath = (0, node_path_1.basename)(filePath);
98
- const content = outputFiles[filePath];
99
- if (content === undefined) {
100
- throw new Error(`Output file does not exist: ${filePath}`);
101
- }
102
- return content;
103
- },
104
- });
105
- return inlineCriticalCssProcessor.process(html, { outputPath: '' });
106
- }
107
- return {
108
- content: html,
109
- };
110
- }
111
- function isBootstrapFn(value) {
112
- // We can differentiate between a module and a bootstrap function by reading compiler-generated `ɵmod` static property:
113
- return typeof value === 'function' && !('ɵmod' in value);
114
- }