@angular-devkit/build-angular 16.0.0-next.1 → 16.0.0-next.3
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 +9 -9
- package/src/babel/plugins/adjust-static-class-members.js +36 -1
- package/src/builders/app-shell/render-worker.js +3 -5
- package/src/builders/browser/index.d.ts +0 -8
- package/src/builders/browser/index.js +1 -3
- package/src/builders/browser-esbuild/angular/jit-resource-transformer.js +1 -1
- package/src/builders/browser-esbuild/angular-compilation.js +1 -1
- package/src/builders/dev-server/index.d.ts +4 -32
- package/src/builders/dev-server/index.js +4 -321
- package/src/builders/dev-server/webpack-server.d.ts +37 -0
- package/src/builders/dev-server/webpack-server.js +331 -0
- package/src/builders/protractor/index.js +2 -3
- package/src/builders/server/index.d.ts +0 -7
- package/src/builders/server/index.js +1 -3
- package/src/utils/spinner.js +1 -1
- package/src/webpack/utils/stats.js +3 -4
|
@@ -6,327 +6,10 @@
|
|
|
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
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
33
10
|
exports.serveWebpackBrowser = void 0;
|
|
34
11
|
const architect_1 = require("@angular-devkit/architect");
|
|
35
|
-
const
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const url = __importStar(require("url"));
|
|
40
|
-
const utils_1 = require("../../utils");
|
|
41
|
-
const check_port_1 = require("../../utils/check-port");
|
|
42
|
-
const color_1 = require("../../utils/color");
|
|
43
|
-
const i18n_options_1 = require("../../utils/i18n-options");
|
|
44
|
-
const load_translations_1 = require("../../utils/load-translations");
|
|
45
|
-
const normalize_cache_1 = require("../../utils/normalize-cache");
|
|
46
|
-
const package_chunk_sort_1 = require("../../utils/package-chunk-sort");
|
|
47
|
-
const purge_cache_1 = require("../../utils/purge-cache");
|
|
48
|
-
const version_1 = require("../../utils/version");
|
|
49
|
-
const webpack_browser_config_1 = require("../../utils/webpack-browser-config");
|
|
50
|
-
const webpack_diagnostics_1 = require("../../utils/webpack-diagnostics");
|
|
51
|
-
const configs_1 = require("../../webpack/configs");
|
|
52
|
-
const index_html_webpack_plugin_1 = require("../../webpack/plugins/index-html-webpack-plugin");
|
|
53
|
-
const service_worker_plugin_1 = require("../../webpack/plugins/service-worker-plugin");
|
|
54
|
-
const stats_1 = require("../../webpack/utils/stats");
|
|
55
|
-
const schema_1 = require("../browser/schema");
|
|
56
|
-
/**
|
|
57
|
-
* Reusable implementation of the Angular Webpack development server builder.
|
|
58
|
-
* @param options Dev Server options.
|
|
59
|
-
* @param context The build context.
|
|
60
|
-
* @param transforms A map of transforms that can be used to hook into some logic (such as
|
|
61
|
-
* transforming webpack configuration before passing it to webpack).
|
|
62
|
-
*
|
|
63
|
-
* @experimental Direct usage of this function is considered experimental.
|
|
64
|
-
*/
|
|
65
|
-
// eslint-disable-next-line max-lines-per-function
|
|
66
|
-
function serveWebpackBrowser(options, context, transforms = {}) {
|
|
67
|
-
// Check Angular version.
|
|
68
|
-
const { logger, workspaceRoot } = context;
|
|
69
|
-
(0, version_1.assertCompatibleAngularVersion)(workspaceRoot);
|
|
70
|
-
const browserTarget = (0, architect_1.targetFromTargetString)(options.browserTarget);
|
|
71
|
-
async function setup() {
|
|
72
|
-
const projectName = context.target?.project;
|
|
73
|
-
if (!projectName) {
|
|
74
|
-
throw new Error('The builder requires a target.');
|
|
75
|
-
}
|
|
76
|
-
// Purge old build disk cache.
|
|
77
|
-
await (0, purge_cache_1.purgeStaleBuildCache)(context);
|
|
78
|
-
options.port = await (0, check_port_1.checkPort)(options.port ?? 4200, options.host || 'localhost');
|
|
79
|
-
if (options.hmr) {
|
|
80
|
-
logger.warn(core_1.tags.stripIndents `NOTICE: Hot Module Replacement (HMR) is enabled for the dev server.
|
|
81
|
-
See https://webpack.js.org/guides/hot-module-replacement for information on working with HMR for Webpack.`);
|
|
82
|
-
}
|
|
83
|
-
if (!options.disableHostCheck &&
|
|
84
|
-
options.host &&
|
|
85
|
-
!/^127\.\d+\.\d+\.\d+/g.test(options.host) &&
|
|
86
|
-
options.host !== 'localhost') {
|
|
87
|
-
logger.warn(core_1.tags.stripIndent `
|
|
88
|
-
Warning: This is a simple server for use in testing or debugging Angular applications
|
|
89
|
-
locally. It hasn't been reviewed for security issues.
|
|
90
|
-
|
|
91
|
-
Binding this server to an open connection can result in compromising your application or
|
|
92
|
-
computer. Using a different host than the one passed to the "--host" flag might result in
|
|
93
|
-
websocket connection issues. You might need to use "--disable-host-check" if that's the
|
|
94
|
-
case.
|
|
95
|
-
`);
|
|
96
|
-
}
|
|
97
|
-
if (options.disableHostCheck) {
|
|
98
|
-
logger.warn(core_1.tags.oneLine `
|
|
99
|
-
Warning: Running a server with --disable-host-check is a security risk.
|
|
100
|
-
See https://medium.com/webpack/webpack-dev-server-middleware-security-issues-1489d950874a
|
|
101
|
-
for more information.
|
|
102
|
-
`);
|
|
103
|
-
}
|
|
104
|
-
// Get the browser configuration from the target name.
|
|
105
|
-
const rawBrowserOptions = (await context.getTargetOptions(browserTarget));
|
|
106
|
-
if (rawBrowserOptions.outputHashing && rawBrowserOptions.outputHashing !== schema_1.OutputHashing.None) {
|
|
107
|
-
// Disable output hashing for dev build as this can cause memory leaks
|
|
108
|
-
// See: https://github.com/webpack/webpack-dev-server/issues/377#issuecomment-241258405
|
|
109
|
-
rawBrowserOptions.outputHashing = schema_1.OutputHashing.None;
|
|
110
|
-
logger.warn(`Warning: 'outputHashing' option is disabled when using the dev-server.`);
|
|
111
|
-
}
|
|
112
|
-
const metadata = await context.getProjectMetadata(projectName);
|
|
113
|
-
const cacheOptions = (0, normalize_cache_1.normalizeCacheOptions)(metadata, context.workspaceRoot);
|
|
114
|
-
const browserName = await context.getBuilderNameForTarget(browserTarget);
|
|
115
|
-
// Issue a warning that the dev-server does not currently support the experimental esbuild-
|
|
116
|
-
// based builder and will use Webpack.
|
|
117
|
-
if (browserName === '@angular-devkit/build-angular:browser-esbuild') {
|
|
118
|
-
logger.warn('WARNING: The experimental esbuild-based builder is not currently supported ' +
|
|
119
|
-
'by the dev-server. The stable Webpack-based builder will be used instead.');
|
|
120
|
-
}
|
|
121
|
-
const browserOptions = (await context.validateOptions({
|
|
122
|
-
...rawBrowserOptions,
|
|
123
|
-
watch: options.watch,
|
|
124
|
-
verbose: options.verbose,
|
|
125
|
-
// In dev server we should not have budgets because of extra libs such as socks-js
|
|
126
|
-
budgets: undefined,
|
|
127
|
-
}, browserName));
|
|
128
|
-
const { styles, scripts } = (0, utils_1.normalizeOptimization)(browserOptions.optimization);
|
|
129
|
-
if (scripts || styles.minify) {
|
|
130
|
-
logger.error(core_1.tags.stripIndents `
|
|
131
|
-
****************************************************************************************
|
|
132
|
-
This is a simple server for use in testing or debugging Angular applications locally.
|
|
133
|
-
It hasn't been reviewed for security issues.
|
|
134
|
-
|
|
135
|
-
DON'T USE IT FOR PRODUCTION!
|
|
136
|
-
****************************************************************************************
|
|
137
|
-
`);
|
|
138
|
-
}
|
|
139
|
-
const { config, projectRoot, i18n } = await (0, webpack_browser_config_1.generateI18nBrowserWebpackConfigFromContext)(browserOptions, context, (wco) => [(0, configs_1.getDevServerConfig)(wco), (0, configs_1.getCommonConfig)(wco), (0, configs_1.getStylesConfig)(wco)], options);
|
|
140
|
-
if (!config.devServer) {
|
|
141
|
-
throw new Error('Webpack Dev Server configuration was not set.');
|
|
142
|
-
}
|
|
143
|
-
let locale;
|
|
144
|
-
if (i18n.shouldInline) {
|
|
145
|
-
// Dev-server only supports one locale
|
|
146
|
-
locale = [...i18n.inlineLocales][0];
|
|
147
|
-
}
|
|
148
|
-
else if (i18n.hasDefinedSourceLocale) {
|
|
149
|
-
// use source locale if not localizing
|
|
150
|
-
locale = i18n.sourceLocale;
|
|
151
|
-
}
|
|
152
|
-
let webpackConfig = config;
|
|
153
|
-
// If a locale is defined, setup localization
|
|
154
|
-
if (locale) {
|
|
155
|
-
if (i18n.inlineLocales.size > 1) {
|
|
156
|
-
throw new Error('The development server only supports localizing a single locale per build.');
|
|
157
|
-
}
|
|
158
|
-
await setupLocalize(locale, i18n, browserOptions, webpackConfig, cacheOptions, context);
|
|
159
|
-
}
|
|
160
|
-
if (transforms.webpackConfiguration) {
|
|
161
|
-
webpackConfig = await transforms.webpackConfiguration(webpackConfig);
|
|
162
|
-
}
|
|
163
|
-
webpackConfig.plugins ?? (webpackConfig.plugins = []);
|
|
164
|
-
if (browserOptions.index) {
|
|
165
|
-
const { scripts = [], styles = [], baseHref } = browserOptions;
|
|
166
|
-
const entrypoints = (0, package_chunk_sort_1.generateEntryPoints)({
|
|
167
|
-
scripts,
|
|
168
|
-
styles,
|
|
169
|
-
// The below is needed as otherwise HMR for CSS will break.
|
|
170
|
-
// styles.js and runtime.js needs to be loaded as a non-module scripts as otherwise `document.currentScript` will be null.
|
|
171
|
-
// https://github.com/webpack-contrib/mini-css-extract-plugin/blob/90445dd1d81da0c10b9b0e8a17b417d0651816b8/src/hmr/hotModuleReplacement.js#L39
|
|
172
|
-
isHMREnabled: !!webpackConfig.devServer?.hot,
|
|
173
|
-
});
|
|
174
|
-
webpackConfig.plugins.push(new index_html_webpack_plugin_1.IndexHtmlWebpackPlugin({
|
|
175
|
-
indexPath: path.resolve(workspaceRoot, (0, webpack_browser_config_1.getIndexInputFile)(browserOptions.index)),
|
|
176
|
-
outputPath: (0, webpack_browser_config_1.getIndexOutputFile)(browserOptions.index),
|
|
177
|
-
baseHref,
|
|
178
|
-
entrypoints,
|
|
179
|
-
deployUrl: browserOptions.deployUrl,
|
|
180
|
-
sri: browserOptions.subresourceIntegrity,
|
|
181
|
-
cache: cacheOptions,
|
|
182
|
-
postTransform: transforms.indexHtml,
|
|
183
|
-
optimization: (0, utils_1.normalizeOptimization)(browserOptions.optimization),
|
|
184
|
-
crossOrigin: browserOptions.crossOrigin,
|
|
185
|
-
lang: locale,
|
|
186
|
-
}));
|
|
187
|
-
}
|
|
188
|
-
if (browserOptions.serviceWorker) {
|
|
189
|
-
webpackConfig.plugins.push(new service_worker_plugin_1.ServiceWorkerPlugin({
|
|
190
|
-
baseHref: browserOptions.baseHref,
|
|
191
|
-
root: context.workspaceRoot,
|
|
192
|
-
projectRoot,
|
|
193
|
-
ngswConfigPath: browserOptions.ngswConfigPath,
|
|
194
|
-
}));
|
|
195
|
-
}
|
|
196
|
-
return {
|
|
197
|
-
browserOptions,
|
|
198
|
-
webpackConfig,
|
|
199
|
-
projectRoot,
|
|
200
|
-
};
|
|
201
|
-
}
|
|
202
|
-
return (0, rxjs_1.from)(setup()).pipe((0, rxjs_1.switchMap)(({ browserOptions, webpackConfig }) => {
|
|
203
|
-
return (0, build_webpack_1.runWebpackDevServer)(webpackConfig, context, {
|
|
204
|
-
logging: transforms.logging || (0, stats_1.createWebpackLoggingCallback)(browserOptions, logger),
|
|
205
|
-
webpackFactory: require('webpack'),
|
|
206
|
-
webpackDevServerFactory: require('webpack-dev-server'),
|
|
207
|
-
}).pipe((0, rxjs_1.concatMap)(async (buildEvent, index) => {
|
|
208
|
-
const webpackRawStats = buildEvent.webpackStats;
|
|
209
|
-
if (!webpackRawStats) {
|
|
210
|
-
throw new Error('Webpack stats build result is required.');
|
|
211
|
-
}
|
|
212
|
-
// Resolve serve address.
|
|
213
|
-
const publicPath = webpackConfig.devServer?.devMiddleware?.publicPath;
|
|
214
|
-
const serverAddress = url.format({
|
|
215
|
-
protocol: options.ssl ? 'https' : 'http',
|
|
216
|
-
hostname: options.host === '0.0.0.0' ? 'localhost' : options.host,
|
|
217
|
-
port: buildEvent.port,
|
|
218
|
-
pathname: typeof publicPath === 'string' ? publicPath : undefined,
|
|
219
|
-
});
|
|
220
|
-
if (index === 0) {
|
|
221
|
-
logger.info('\n' +
|
|
222
|
-
core_1.tags.oneLine `
|
|
223
|
-
**
|
|
224
|
-
Angular Live Development Server is listening on ${options.host}:${buildEvent.port},
|
|
225
|
-
open your browser on ${serverAddress}
|
|
226
|
-
**
|
|
227
|
-
` +
|
|
228
|
-
'\n');
|
|
229
|
-
if (options.open) {
|
|
230
|
-
const open = (await Promise.resolve().then(() => __importStar(require('open')))).default;
|
|
231
|
-
await open(serverAddress);
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
if (buildEvent.success) {
|
|
235
|
-
logger.info(`\n${color_1.colors.greenBright(color_1.colors.symbols.check)} Compiled successfully.`);
|
|
236
|
-
}
|
|
237
|
-
else {
|
|
238
|
-
logger.info(`\n${color_1.colors.redBright(color_1.colors.symbols.cross)} Failed to compile.`);
|
|
239
|
-
}
|
|
240
|
-
return {
|
|
241
|
-
...buildEvent,
|
|
242
|
-
baseUrl: serverAddress,
|
|
243
|
-
stats: (0, stats_1.generateBuildEventStats)(webpackRawStats, browserOptions),
|
|
244
|
-
};
|
|
245
|
-
}));
|
|
246
|
-
}));
|
|
247
|
-
}
|
|
248
|
-
exports.serveWebpackBrowser = serveWebpackBrowser;
|
|
249
|
-
async function setupLocalize(locale, i18n, browserOptions, webpackConfig, cacheOptions, context) {
|
|
250
|
-
const localeDescription = i18n.locales[locale];
|
|
251
|
-
// Modify main entrypoint to include locale data
|
|
252
|
-
if (localeDescription?.dataPath &&
|
|
253
|
-
typeof webpackConfig.entry === 'object' &&
|
|
254
|
-
!Array.isArray(webpackConfig.entry) &&
|
|
255
|
-
webpackConfig.entry['main']) {
|
|
256
|
-
if (Array.isArray(webpackConfig.entry['main'])) {
|
|
257
|
-
webpackConfig.entry['main'].unshift(localeDescription.dataPath);
|
|
258
|
-
}
|
|
259
|
-
else {
|
|
260
|
-
webpackConfig.entry['main'] = [
|
|
261
|
-
localeDescription.dataPath,
|
|
262
|
-
webpackConfig.entry['main'],
|
|
263
|
-
];
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
let missingTranslationBehavior = browserOptions.i18nMissingTranslation || 'ignore';
|
|
267
|
-
let translation = localeDescription?.translation || {};
|
|
268
|
-
if (locale === i18n.sourceLocale) {
|
|
269
|
-
missingTranslationBehavior = 'ignore';
|
|
270
|
-
translation = {};
|
|
271
|
-
}
|
|
272
|
-
const i18nLoaderOptions = {
|
|
273
|
-
locale,
|
|
274
|
-
missingTranslationBehavior,
|
|
275
|
-
translation: i18n.shouldInline ? translation : undefined,
|
|
276
|
-
translationFiles: localeDescription?.files.map((file) => path.resolve(context.workspaceRoot, file.path)),
|
|
277
|
-
};
|
|
278
|
-
const i18nRule = {
|
|
279
|
-
test: /\.[cm]?[tj]sx?$/,
|
|
280
|
-
enforce: 'post',
|
|
281
|
-
use: [
|
|
282
|
-
{
|
|
283
|
-
loader: require.resolve('../../babel/webpack-loader'),
|
|
284
|
-
options: {
|
|
285
|
-
cacheDirectory: (cacheOptions.enabled && path.join(cacheOptions.path, 'babel-dev-server-i18n')) ||
|
|
286
|
-
false,
|
|
287
|
-
cacheIdentifier: JSON.stringify({
|
|
288
|
-
locale,
|
|
289
|
-
translationIntegrity: localeDescription?.files.map((file) => file.integrity),
|
|
290
|
-
}),
|
|
291
|
-
i18n: i18nLoaderOptions,
|
|
292
|
-
},
|
|
293
|
-
},
|
|
294
|
-
],
|
|
295
|
-
};
|
|
296
|
-
// Get the rules and ensure the Webpack configuration is setup properly
|
|
297
|
-
const rules = webpackConfig.module?.rules || [];
|
|
298
|
-
if (!webpackConfig.module) {
|
|
299
|
-
webpackConfig.module = { rules };
|
|
300
|
-
}
|
|
301
|
-
else if (!webpackConfig.module.rules) {
|
|
302
|
-
webpackConfig.module.rules = rules;
|
|
303
|
-
}
|
|
304
|
-
rules.push(i18nRule);
|
|
305
|
-
// Add a plugin to reload translation files on rebuilds
|
|
306
|
-
const loader = await (0, load_translations_1.createTranslationLoader)();
|
|
307
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
308
|
-
webpackConfig.plugins.push({
|
|
309
|
-
apply: (compiler) => {
|
|
310
|
-
compiler.hooks.thisCompilation.tap('build-angular', (compilation) => {
|
|
311
|
-
if (i18n.shouldInline && i18nLoaderOptions.translation === undefined) {
|
|
312
|
-
// Reload translations
|
|
313
|
-
(0, i18n_options_1.loadTranslations)(locale, localeDescription, context.workspaceRoot, loader, {
|
|
314
|
-
warn(message) {
|
|
315
|
-
(0, webpack_diagnostics_1.addWarning)(compilation, message);
|
|
316
|
-
},
|
|
317
|
-
error(message) {
|
|
318
|
-
(0, webpack_diagnostics_1.addError)(compilation, message);
|
|
319
|
-
},
|
|
320
|
-
}, undefined, browserOptions.i18nDuplicateTranslation);
|
|
321
|
-
i18nLoaderOptions.translation = localeDescription.translation ?? {};
|
|
322
|
-
}
|
|
323
|
-
compilation.hooks.finishModules.tap('build-angular', () => {
|
|
324
|
-
// After loaders are finished, clear out the now unneeded translations
|
|
325
|
-
i18nLoaderOptions.translation = undefined;
|
|
326
|
-
});
|
|
327
|
-
});
|
|
328
|
-
},
|
|
329
|
-
});
|
|
330
|
-
}
|
|
331
|
-
exports.default = (0, architect_1.createBuilder)(serveWebpackBrowser);
|
|
332
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/dev-server/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, createBuilder, targetFromTargetString } from '@angular-devkit/architect';\nimport {\n  DevServerBuildOutput,\n  WebpackLoggingCallback,\n  runWebpackDevServer,\n} from '@angular-devkit/build-webpack';\nimport { json, tags } from '@angular-devkit/core';\nimport * as path from 'path';\nimport { Observable, concatMap, from, switchMap } from 'rxjs';\nimport * as url from 'url';\nimport webpack from 'webpack';\nimport webpackDevServer from 'webpack-dev-server';\nimport { ExecutionTransformer } from '../../transforms';\nimport { normalizeOptimization } from '../../utils';\nimport { checkPort } from '../../utils/check-port';\nimport { colors } from '../../utils/color';\nimport { I18nOptions, loadTranslations } from '../../utils/i18n-options';\nimport { IndexHtmlTransform } from '../../utils/index-file/index-html-generator';\nimport { createTranslationLoader } from '../../utils/load-translations';\nimport { NormalizedCachedOptions, normalizeCacheOptions } from '../../utils/normalize-cache';\nimport { generateEntryPoints } from '../../utils/package-chunk-sort';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport {\n  generateI18nBrowserWebpackConfigFromContext,\n  getIndexInputFile,\n  getIndexOutputFile,\n} from '../../utils/webpack-browser-config';\nimport { addError, addWarning } from '../../utils/webpack-diagnostics';\nimport { getCommonConfig, getDevServerConfig, getStylesConfig } from '../../webpack/configs';\nimport { IndexHtmlWebpackPlugin } from '../../webpack/plugins/index-html-webpack-plugin';\nimport { ServiceWorkerPlugin } from '../../webpack/plugins/service-worker-plugin';\nimport {\n  BuildEventStats,\n  createWebpackLoggingCallback,\n  generateBuildEventStats,\n} from '../../webpack/utils/stats';\nimport { Schema as BrowserBuilderSchema, OutputHashing } from '../browser/schema';\nimport { Schema } from './schema';\n\nexport type DevServerBuilderOptions = Schema;\n\n/**\n * @experimental Direct usage of this type is considered experimental.\n */\nexport type DevServerBuilderOutput = DevServerBuildOutput & {\n  baseUrl: string;\n  stats: BuildEventStats;\n};\n\n/**\n * Reusable implementation of the Angular Webpack development server builder.\n * @param options Dev Server options.\n * @param context The build context.\n * @param transforms A map of transforms that can be used to hook into some logic (such as\n *     transforming webpack configuration before passing it to webpack).\n *\n * @experimental Direct usage of this function is considered experimental.\n */\n// eslint-disable-next-line max-lines-per-function\nexport function serveWebpackBrowser(\n  options: DevServerBuilderOptions,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n    logging?: WebpackLoggingCallback;\n    indexHtml?: IndexHtmlTransform;\n  } = {},\n): Observable<DevServerBuilderOutput> {\n  // Check Angular version.\n  const { logger, workspaceRoot } = context;\n  assertCompatibleAngularVersion(workspaceRoot);\n\n  const browserTarget = targetFromTargetString(options.browserTarget);\n\n  async function setup(): Promise<{\n    browserOptions: BrowserBuilderSchema;\n    webpackConfig: webpack.Configuration;\n    projectRoot: string;\n  }> {\n    const projectName = context.target?.project;\n    if (!projectName) {\n      throw new Error('The builder requires a target.');\n    }\n\n    // Purge old build disk cache.\n    await purgeStaleBuildCache(context);\n\n    options.port = await checkPort(options.port ?? 4200, options.host || 'localhost');\n\n    if (options.hmr) {\n      logger.warn(tags.stripIndents`NOTICE: Hot Module Replacement (HMR) is enabled for the dev server.\n      See https://webpack.js.org/guides/hot-module-replacement for information on working with HMR for Webpack.`);\n    }\n\n    if (\n      !options.disableHostCheck &&\n      options.host &&\n      !/^127\\.\\d+\\.\\d+\\.\\d+/g.test(options.host) &&\n      options.host !== 'localhost'\n    ) {\n      logger.warn(tags.stripIndent`\n        Warning: This is a simple server for use in testing or debugging Angular applications\n        locally. It hasn't been reviewed for security issues.\n\n        Binding this server to an open connection can result in compromising your application or\n        computer. Using a different host than the one passed to the \"--host\" flag might result in\n        websocket connection issues. You might need to use \"--disable-host-check\" if that's the\n        case.\n      `);\n    }\n\n    if (options.disableHostCheck) {\n      logger.warn(tags.oneLine`\n        Warning: Running a server with --disable-host-check is a security risk.\n        See https://medium.com/webpack/webpack-dev-server-middleware-security-issues-1489d950874a\n        for more information.\n      `);\n    }\n    // Get the browser configuration from the target name.\n    const rawBrowserOptions = (await context.getTargetOptions(browserTarget)) as json.JsonObject &\n      BrowserBuilderSchema;\n\n    if (rawBrowserOptions.outputHashing && rawBrowserOptions.outputHashing !== OutputHashing.None) {\n      // Disable output hashing for dev build as this can cause memory leaks\n      // See: https://github.com/webpack/webpack-dev-server/issues/377#issuecomment-241258405\n      rawBrowserOptions.outputHashing = OutputHashing.None;\n      logger.warn(`Warning: 'outputHashing' option is disabled when using the dev-server.`);\n    }\n\n    const metadata = await context.getProjectMetadata(projectName);\n    const cacheOptions = normalizeCacheOptions(metadata, context.workspaceRoot);\n\n    const browserName = await context.getBuilderNameForTarget(browserTarget);\n\n    // Issue a warning that the dev-server does not currently support the experimental esbuild-\n    // based builder and will use Webpack.\n    if (browserName === '@angular-devkit/build-angular:browser-esbuild') {\n      logger.warn(\n        'WARNING: The experimental esbuild-based builder is not currently supported ' +\n          'by the dev-server. The stable Webpack-based builder will be used instead.',\n      );\n    }\n\n    const browserOptions = (await context.validateOptions(\n      {\n        ...rawBrowserOptions,\n        watch: options.watch,\n        verbose: options.verbose,\n        // In dev server we should not have budgets because of extra libs such as socks-js\n        budgets: undefined,\n      } as json.JsonObject & BrowserBuilderSchema,\n      browserName,\n    )) as json.JsonObject & BrowserBuilderSchema;\n\n    const { styles, scripts } = normalizeOptimization(browserOptions.optimization);\n    if (scripts || styles.minify) {\n      logger.error(tags.stripIndents`\n        ****************************************************************************************\n        This is a simple server for use in testing or debugging Angular applications locally.\n        It hasn't been reviewed for security issues.\n\n        DON'T USE IT FOR PRODUCTION!\n        ****************************************************************************************\n      `);\n    }\n\n    const { config, projectRoot, i18n } = await generateI18nBrowserWebpackConfigFromContext(\n      browserOptions,\n      context,\n      (wco) => [getDevServerConfig(wco), getCommonConfig(wco), getStylesConfig(wco)],\n      options,\n    );\n\n    if (!config.devServer) {\n      throw new Error('Webpack Dev Server configuration was not set.');\n    }\n\n    let locale: string | undefined;\n    if (i18n.shouldInline) {\n      // Dev-server only supports one locale\n      locale = [...i18n.inlineLocales][0];\n    } else if (i18n.hasDefinedSourceLocale) {\n      // use source locale if not localizing\n      locale = i18n.sourceLocale;\n    }\n\n    let webpackConfig = config;\n\n    // If a locale is defined, setup localization\n    if (locale) {\n      if (i18n.inlineLocales.size > 1) {\n        throw new Error(\n          'The development server only supports localizing a single locale per build.',\n        );\n      }\n\n      await setupLocalize(locale, i18n, browserOptions, webpackConfig, cacheOptions, context);\n    }\n\n    if (transforms.webpackConfiguration) {\n      webpackConfig = await transforms.webpackConfiguration(webpackConfig);\n    }\n\n    webpackConfig.plugins ??= [];\n\n    if (browserOptions.index) {\n      const { scripts = [], styles = [], baseHref } = browserOptions;\n      const entrypoints = generateEntryPoints({\n        scripts,\n        styles,\n        // The below is needed as otherwise HMR for CSS will break.\n        // styles.js and runtime.js needs to be loaded as a non-module scripts as otherwise `document.currentScript` will be null.\n        // https://github.com/webpack-contrib/mini-css-extract-plugin/blob/90445dd1d81da0c10b9b0e8a17b417d0651816b8/src/hmr/hotModuleReplacement.js#L39\n        isHMREnabled: !!webpackConfig.devServer?.hot,\n      });\n\n      webpackConfig.plugins.push(\n        new IndexHtmlWebpackPlugin({\n          indexPath: path.resolve(workspaceRoot, getIndexInputFile(browserOptions.index)),\n          outputPath: getIndexOutputFile(browserOptions.index),\n          baseHref,\n          entrypoints,\n          deployUrl: browserOptions.deployUrl,\n          sri: browserOptions.subresourceIntegrity,\n          cache: cacheOptions,\n          postTransform: transforms.indexHtml,\n          optimization: normalizeOptimization(browserOptions.optimization),\n          crossOrigin: browserOptions.crossOrigin,\n          lang: locale,\n        }),\n      );\n    }\n\n    if (browserOptions.serviceWorker) {\n      webpackConfig.plugins.push(\n        new ServiceWorkerPlugin({\n          baseHref: browserOptions.baseHref,\n          root: context.workspaceRoot,\n          projectRoot,\n          ngswConfigPath: browserOptions.ngswConfigPath,\n        }),\n      );\n    }\n\n    return {\n      browserOptions,\n      webpackConfig,\n      projectRoot,\n    };\n  }\n\n  return from(setup()).pipe(\n    switchMap(({ browserOptions, webpackConfig }) => {\n      return runWebpackDevServer(webpackConfig, context, {\n        logging: transforms.logging || createWebpackLoggingCallback(browserOptions, logger),\n        webpackFactory: require('webpack') as typeof webpack,\n        webpackDevServerFactory: require('webpack-dev-server') as typeof webpackDevServer,\n      }).pipe(\n        concatMap(async (buildEvent, index) => {\n          const webpackRawStats = buildEvent.webpackStats;\n          if (!webpackRawStats) {\n            throw new Error('Webpack stats build result is required.');\n          }\n\n          // Resolve serve address.\n          const publicPath = webpackConfig.devServer?.devMiddleware?.publicPath;\n\n          const serverAddress = url.format({\n            protocol: options.ssl ? 'https' : 'http',\n            hostname: options.host === '0.0.0.0' ? 'localhost' : options.host,\n            port: buildEvent.port,\n            pathname: typeof publicPath === 'string' ? publicPath : undefined,\n          });\n\n          if (index === 0) {\n            logger.info(\n              '\\n' +\n                tags.oneLine`\n              **\n              Angular Live Development Server is listening on ${options.host}:${buildEvent.port},\n              open your browser on ${serverAddress}\n              **\n            ` +\n                '\\n',\n            );\n\n            if (options.open) {\n              const open = (await import('open')).default;\n              await open(serverAddress);\n            }\n          }\n\n          if (buildEvent.success) {\n            logger.info(`\\n${colors.greenBright(colors.symbols.check)} Compiled successfully.`);\n          } else {\n            logger.info(`\\n${colors.redBright(colors.symbols.cross)} Failed to compile.`);\n          }\n\n          return {\n            ...buildEvent,\n            baseUrl: serverAddress,\n            stats: generateBuildEventStats(webpackRawStats, browserOptions),\n          } as DevServerBuilderOutput;\n        }),\n      );\n    }),\n  );\n}\n\nasync function setupLocalize(\n  locale: string,\n  i18n: I18nOptions,\n  browserOptions: BrowserBuilderSchema,\n  webpackConfig: webpack.Configuration,\n  cacheOptions: NormalizedCachedOptions,\n  context: BuilderContext,\n) {\n  const localeDescription = i18n.locales[locale];\n\n  // Modify main entrypoint to include locale data\n  if (\n    localeDescription?.dataPath &&\n    typeof webpackConfig.entry === 'object' &&\n    !Array.isArray(webpackConfig.entry) &&\n    webpackConfig.entry['main']\n  ) {\n    if (Array.isArray(webpackConfig.entry['main'])) {\n      webpackConfig.entry['main'].unshift(localeDescription.dataPath);\n    } else {\n      webpackConfig.entry['main'] = [\n        localeDescription.dataPath,\n        webpackConfig.entry['main'] as string,\n      ];\n    }\n  }\n\n  let missingTranslationBehavior = browserOptions.i18nMissingTranslation || 'ignore';\n  let translation = localeDescription?.translation || {};\n\n  if (locale === i18n.sourceLocale) {\n    missingTranslationBehavior = 'ignore';\n    translation = {};\n  }\n\n  const i18nLoaderOptions = {\n    locale,\n    missingTranslationBehavior,\n    translation: i18n.shouldInline ? translation : undefined,\n    translationFiles: localeDescription?.files.map((file) =>\n      path.resolve(context.workspaceRoot, file.path),\n    ),\n  };\n\n  const i18nRule: webpack.RuleSetRule = {\n    test: /\\.[cm]?[tj]sx?$/,\n    enforce: 'post',\n    use: [\n      {\n        loader: require.resolve('../../babel/webpack-loader'),\n        options: {\n          cacheDirectory:\n            (cacheOptions.enabled && path.join(cacheOptions.path, 'babel-dev-server-i18n')) ||\n            false,\n          cacheIdentifier: JSON.stringify({\n            locale,\n            translationIntegrity: localeDescription?.files.map((file) => file.integrity),\n          }),\n          i18n: i18nLoaderOptions,\n        },\n      },\n    ],\n  };\n\n  // Get the rules and ensure the Webpack configuration is setup properly\n  const rules = webpackConfig.module?.rules || [];\n  if (!webpackConfig.module) {\n    webpackConfig.module = { rules };\n  } else if (!webpackConfig.module.rules) {\n    webpackConfig.module.rules = rules;\n  }\n\n  rules.push(i18nRule);\n\n  // Add a plugin to reload translation files on rebuilds\n  const loader = await createTranslationLoader();\n  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n  webpackConfig.plugins!.push({\n    apply: (compiler: webpack.Compiler) => {\n      compiler.hooks.thisCompilation.tap('build-angular', (compilation) => {\n        if (i18n.shouldInline && i18nLoaderOptions.translation === undefined) {\n          // Reload translations\n          loadTranslations(\n            locale,\n            localeDescription,\n            context.workspaceRoot,\n            loader,\n            {\n              warn(message) {\n                addWarning(compilation, message);\n              },\n              error(message) {\n                addError(compilation, message);\n              },\n            },\n            undefined,\n            browserOptions.i18nDuplicateTranslation,\n          );\n\n          i18nLoaderOptions.translation = localeDescription.translation ?? {};\n        }\n\n        compilation.hooks.finishModules.tap('build-angular', () => {\n          // After loaders are finished, clear out the now unneeded translations\n          i18nLoaderOptions.translation = undefined;\n        });\n      });\n    },\n  });\n}\n\nexport default createBuilder<DevServerBuilderOptions, DevServerBuilderOutput>(serveWebpackBrowser);\n"]}
|
|
12
|
+
const webpack_server_1 = require("./webpack-server");
|
|
13
|
+
Object.defineProperty(exports, "serveWebpackBrowser", { enumerable: true, get: function () { return webpack_server_1.serveWebpackBrowser; } });
|
|
14
|
+
exports.default = (0, architect_1.createBuilder)(webpack_server_1.serveWebpackBrowser);
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy9idWlsZGVycy9kZXYtc2VydmVyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUVILHlEQUEwRDtBQUUxRCxxREFBK0U7QUFFckIsb0dBRnpCLG9DQUFtQixPQUV5QjtBQUM3RSxrQkFBZSxJQUFBLHlCQUFhLEVBQWtELG9DQUFtQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHsgY3JlYXRlQnVpbGRlciB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9hcmNoaXRlY3QnO1xuaW1wb3J0IHsgU2NoZW1hIGFzIERldlNlcnZlckJ1aWxkZXJPcHRpb25zIH0gZnJvbSAnLi9zY2hlbWEnO1xuaW1wb3J0IHsgRGV2U2VydmVyQnVpbGRlck91dHB1dCwgc2VydmVXZWJwYWNrQnJvd3NlciB9IGZyb20gJy4vd2VicGFjay1zZXJ2ZXInO1xuXG5leHBvcnQgeyBEZXZTZXJ2ZXJCdWlsZGVyT3B0aW9ucywgRGV2U2VydmVyQnVpbGRlck91dHB1dCwgc2VydmVXZWJwYWNrQnJvd3NlciB9O1xuZXhwb3J0IGRlZmF1bHQgY3JlYXRlQnVpbGRlcjxEZXZTZXJ2ZXJCdWlsZGVyT3B0aW9ucywgRGV2U2VydmVyQnVpbGRlck91dHB1dD4oc2VydmVXZWJwYWNrQnJvd3Nlcik7XG4iXX0=
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { BuilderContext } from '@angular-devkit/architect';
|
|
9
|
+
import { DevServerBuildOutput, WebpackLoggingCallback } from '@angular-devkit/build-webpack';
|
|
10
|
+
import { Observable } from 'rxjs';
|
|
11
|
+
import webpack from 'webpack';
|
|
12
|
+
import { ExecutionTransformer } from '../../transforms';
|
|
13
|
+
import { IndexHtmlTransform } from '../../utils/index-file/index-html-generator';
|
|
14
|
+
import { BuildEventStats } from '../../webpack/utils/stats';
|
|
15
|
+
import { Schema } from './schema';
|
|
16
|
+
export type DevServerBuilderOptions = Schema;
|
|
17
|
+
/**
|
|
18
|
+
* @experimental Direct usage of this type is considered experimental.
|
|
19
|
+
*/
|
|
20
|
+
export type DevServerBuilderOutput = DevServerBuildOutput & {
|
|
21
|
+
baseUrl: string;
|
|
22
|
+
stats: BuildEventStats;
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Reusable implementation of the Angular Webpack development server builder.
|
|
26
|
+
* @param options Dev Server options.
|
|
27
|
+
* @param context The build context.
|
|
28
|
+
* @param transforms A map of transforms that can be used to hook into some logic (such as
|
|
29
|
+
* transforming webpack configuration before passing it to webpack).
|
|
30
|
+
*
|
|
31
|
+
* @experimental Direct usage of this function is considered experimental.
|
|
32
|
+
*/
|
|
33
|
+
export declare function serveWebpackBrowser(options: DevServerBuilderOptions, context: BuilderContext, transforms?: {
|
|
34
|
+
webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;
|
|
35
|
+
logging?: WebpackLoggingCallback;
|
|
36
|
+
indexHtml?: IndexHtmlTransform;
|
|
37
|
+
}): Observable<DevServerBuilderOutput>;
|