@angular-devkit/build-angular 16.2.1 → 17.0.0-next.0
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/README.md +14 -10
- package/builders.json +10 -0
- package/package.json +30 -28
- package/src/builders/dev-server/vite-server.d.ts +1 -1
- package/src/builders/dev-server/vite-server.js +11 -8
- package/src/builders/extract-i18n/application-extraction.d.ts +17 -0
- package/src/builders/extract-i18n/application-extraction.js +137 -0
- package/src/builders/extract-i18n/builder.d.ts +17 -0
- package/src/builders/extract-i18n/builder.js +152 -0
- package/src/builders/extract-i18n/index.d.ts +4 -14
- package/src/builders/extract-i18n/index.js +4 -247
- package/src/builders/extract-i18n/options.d.ts +29 -0
- package/src/builders/extract-i18n/options.js +82 -0
- package/src/builders/extract-i18n/webpack-extraction.d.ts +21 -0
- package/src/builders/extract-i18n/webpack-extraction.js +100 -0
- package/src/builders/prerender/index.d.ts +20 -0
- package/src/builders/prerender/index.js +180 -0
- package/src/builders/prerender/render-worker.d.ts +30 -0
- package/src/builders/prerender/render-worker.js +126 -0
- package/src/builders/prerender/schema.d.ts +22 -0
- package/src/builders/prerender/schema.js +5 -0
- package/src/builders/prerender/schema.json +39 -0
- package/src/builders/prerender/utils.d.ts +22 -0
- package/src/builders/prerender/utils.js +79 -0
- package/src/builders/ssr-dev-server/index.d.ts +23 -0
- package/src/builders/ssr-dev-server/index.js +309 -0
- package/src/builders/ssr-dev-server/schema.d.ts +64 -0
- package/src/builders/ssr-dev-server/schema.js +5 -0
- package/src/builders/ssr-dev-server/schema.json +75 -0
- package/src/builders/ssr-dev-server/utils.d.ts +15 -0
- package/src/builders/ssr-dev-server/utils.js +75 -0
- package/src/tools/babel/webpack-loader.js +2 -2
- package/src/tools/esbuild/angular/compilation/angular-compilation.d.ts +7 -2
- package/src/tools/esbuild/angular/compilation/angular-compilation.js +21 -1
- package/src/tools/esbuild/angular/compiler-plugin.js +8 -13
- package/src/tools/esbuild/application-code-bundle.js +3 -5
- package/src/tools/esbuild/utils.js +5 -1
- package/src/tools/sass/rebasing-importer.js +2 -2
- package/src/utils/index-file/inline-critical-css.js +13 -26
- package/src/tools/esbuild/external-packages-plugin.d.ts +0 -17
- package/src/tools/esbuild/external-packages-plugin.js +0 -49
|
@@ -6,253 +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
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
33
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
34
|
-
};
|
|
35
9
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
10
|
exports.execute = void 0;
|
|
37
11
|
const architect_1 = require("@angular-devkit/architect");
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
const webpack_1 = __importDefault(require("webpack"));
|
|
43
|
-
const configs_1 = require("../../tools/webpack/configs");
|
|
44
|
-
const stats_1 = require("../../tools/webpack/utils/stats");
|
|
45
|
-
const i18n_options_1 = require("../../utils/i18n-options");
|
|
46
|
-
const load_esm_1 = require("../../utils/load-esm");
|
|
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 schema_1 = require("../browser/schema");
|
|
51
|
-
const schema_2 = require("./schema");
|
|
52
|
-
function getI18nOutfile(format) {
|
|
53
|
-
switch (format) {
|
|
54
|
-
case 'xmb':
|
|
55
|
-
return 'messages.xmb';
|
|
56
|
-
case 'xlf':
|
|
57
|
-
case 'xlif':
|
|
58
|
-
case 'xliff':
|
|
59
|
-
case 'xlf2':
|
|
60
|
-
case 'xliff2':
|
|
61
|
-
return 'messages.xlf';
|
|
62
|
-
case 'json':
|
|
63
|
-
case 'legacy-migrate':
|
|
64
|
-
return 'messages.json';
|
|
65
|
-
case 'arb':
|
|
66
|
-
return 'messages.arb';
|
|
67
|
-
default:
|
|
68
|
-
throw new Error(`Unsupported format "${format}"`);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
async function getSerializer(localizeToolsModule, format, sourceLocale, basePath, useLegacyIds, diagnostics) {
|
|
72
|
-
const { XmbTranslationSerializer, LegacyMessageIdMigrationSerializer, ArbTranslationSerializer, Xliff1TranslationSerializer, Xliff2TranslationSerializer, SimpleJsonTranslationSerializer, } = localizeToolsModule;
|
|
73
|
-
switch (format) {
|
|
74
|
-
case schema_2.Format.Xmb:
|
|
75
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
76
|
-
return new XmbTranslationSerializer(basePath, useLegacyIds);
|
|
77
|
-
case schema_2.Format.Xlf:
|
|
78
|
-
case schema_2.Format.Xlif:
|
|
79
|
-
case schema_2.Format.Xliff:
|
|
80
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
81
|
-
return new Xliff1TranslationSerializer(sourceLocale, basePath, useLegacyIds, {});
|
|
82
|
-
case schema_2.Format.Xlf2:
|
|
83
|
-
case schema_2.Format.Xliff2:
|
|
84
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
85
|
-
return new Xliff2TranslationSerializer(sourceLocale, basePath, useLegacyIds, {});
|
|
86
|
-
case schema_2.Format.Json:
|
|
87
|
-
return new SimpleJsonTranslationSerializer(sourceLocale);
|
|
88
|
-
case schema_2.Format.LegacyMigrate:
|
|
89
|
-
return new LegacyMessageIdMigrationSerializer(diagnostics);
|
|
90
|
-
case schema_2.Format.Arb:
|
|
91
|
-
const fileSystem = {
|
|
92
|
-
relative(from, to) {
|
|
93
|
-
return path.relative(from, to);
|
|
94
|
-
},
|
|
95
|
-
};
|
|
96
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
97
|
-
return new ArbTranslationSerializer(sourceLocale, basePath, fileSystem);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
function normalizeFormatOption(options) {
|
|
101
|
-
let format = options.format;
|
|
102
|
-
switch (format) {
|
|
103
|
-
case schema_2.Format.Xlf:
|
|
104
|
-
case schema_2.Format.Xlif:
|
|
105
|
-
case schema_2.Format.Xliff:
|
|
106
|
-
format = schema_2.Format.Xlf;
|
|
107
|
-
break;
|
|
108
|
-
case schema_2.Format.Xlf2:
|
|
109
|
-
case schema_2.Format.Xliff2:
|
|
110
|
-
format = schema_2.Format.Xlf2;
|
|
111
|
-
break;
|
|
112
|
-
}
|
|
113
|
-
// Default format is xliff1
|
|
114
|
-
return format ?? schema_2.Format.Xlf;
|
|
115
|
-
}
|
|
116
|
-
class NoEmitPlugin {
|
|
117
|
-
apply(compiler) {
|
|
118
|
-
compiler.hooks.shouldEmit.tap('angular-no-emit', () => false);
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
/**
|
|
122
|
-
* @experimental Direct usage of this function is considered experimental.
|
|
123
|
-
*/
|
|
124
|
-
async function execute(options, context, transforms) {
|
|
125
|
-
// Check Angular version.
|
|
126
|
-
(0, version_1.assertCompatibleAngularVersion)(context.workspaceRoot);
|
|
127
|
-
// Purge old build disk cache.
|
|
128
|
-
await (0, purge_cache_1.purgeStaleBuildCache)(context);
|
|
129
|
-
const browserTarget = (0, architect_1.targetFromTargetString)(options.browserTarget);
|
|
130
|
-
const browserOptions = await context.validateOptions(await context.getTargetOptions(browserTarget), await context.getBuilderNameForTarget(browserTarget));
|
|
131
|
-
const format = normalizeFormatOption(options);
|
|
132
|
-
// We need to determine the outFile name so that AngularCompiler can retrieve it.
|
|
133
|
-
let outFile = options.outFile || getI18nOutfile(format);
|
|
134
|
-
if (options.outputPath) {
|
|
135
|
-
// AngularCompilerPlugin doesn't support genDir so we have to adjust outFile instead.
|
|
136
|
-
outFile = path.join(options.outputPath, outFile);
|
|
137
|
-
}
|
|
138
|
-
outFile = path.resolve(context.workspaceRoot, outFile);
|
|
139
|
-
if (!context.target || !context.target.project) {
|
|
140
|
-
throw new Error('The builder requires a target.');
|
|
141
|
-
}
|
|
142
|
-
try {
|
|
143
|
-
require.resolve('@angular/localize');
|
|
144
|
-
}
|
|
145
|
-
catch {
|
|
146
|
-
return {
|
|
147
|
-
success: false,
|
|
148
|
-
error: `i18n extraction requires the '@angular/localize' package.`,
|
|
149
|
-
outputPath: outFile,
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
const metadata = await context.getProjectMetadata(context.target);
|
|
153
|
-
const i18n = (0, i18n_options_1.createI18nOptions)(metadata);
|
|
154
|
-
let useLegacyIds = true;
|
|
155
|
-
const ivyMessages = [];
|
|
156
|
-
const builderOptions = {
|
|
157
|
-
...browserOptions,
|
|
158
|
-
optimization: false,
|
|
159
|
-
sourceMap: {
|
|
160
|
-
scripts: true,
|
|
161
|
-
styles: false,
|
|
162
|
-
vendor: true,
|
|
163
|
-
},
|
|
164
|
-
buildOptimizer: false,
|
|
165
|
-
aot: true,
|
|
166
|
-
progress: options.progress,
|
|
167
|
-
budgets: [],
|
|
168
|
-
assets: [],
|
|
169
|
-
scripts: [],
|
|
170
|
-
styles: [],
|
|
171
|
-
deleteOutputPath: false,
|
|
172
|
-
extractLicenses: false,
|
|
173
|
-
subresourceIntegrity: false,
|
|
174
|
-
outputHashing: schema_1.OutputHashing.None,
|
|
175
|
-
namedChunks: true,
|
|
176
|
-
allowedCommonJsDependencies: undefined,
|
|
177
|
-
};
|
|
178
|
-
const { config, projectRoot } = await (0, webpack_browser_config_1.generateBrowserWebpackConfigFromContext)(builderOptions, context, (wco) => {
|
|
179
|
-
// Default value for legacy message ids is currently true
|
|
180
|
-
useLegacyIds = wco.tsConfig.options.enableI18nLegacyMessageIdFormat ?? true;
|
|
181
|
-
const partials = [
|
|
182
|
-
{ plugins: [new NoEmitPlugin()] },
|
|
183
|
-
(0, configs_1.getCommonConfig)(wco),
|
|
184
|
-
];
|
|
185
|
-
// Add Ivy application file extractor support
|
|
186
|
-
partials.unshift({
|
|
187
|
-
module: {
|
|
188
|
-
rules: [
|
|
189
|
-
{
|
|
190
|
-
test: /\.[cm]?[tj]sx?$/,
|
|
191
|
-
loader: require.resolve('./ivy-extract-loader'),
|
|
192
|
-
options: {
|
|
193
|
-
messageHandler: (messages) => ivyMessages.push(...messages),
|
|
194
|
-
},
|
|
195
|
-
},
|
|
196
|
-
],
|
|
197
|
-
},
|
|
198
|
-
});
|
|
199
|
-
// Replace all stylesheets with empty content
|
|
200
|
-
partials.push({
|
|
201
|
-
module: {
|
|
202
|
-
rules: [
|
|
203
|
-
{
|
|
204
|
-
test: /\.(css|scss|sass|less)$/,
|
|
205
|
-
loader: require.resolve('./empty-loader'),
|
|
206
|
-
},
|
|
207
|
-
],
|
|
208
|
-
},
|
|
209
|
-
});
|
|
210
|
-
return partials;
|
|
211
|
-
},
|
|
212
|
-
// During extraction we don't need specific browser support.
|
|
213
|
-
{ supportedBrowsers: undefined });
|
|
214
|
-
// All the localize usages are setup to first try the ESM entry point then fallback to the deep imports.
|
|
215
|
-
// This provides interim compatibility while the framework is transitioned to bundled ESM packages.
|
|
216
|
-
const localizeToolsModule = await (0, load_esm_1.loadEsmModule)('@angular/localize/tools');
|
|
217
|
-
const webpackResult = await (0, rxjs_1.lastValueFrom)((0, build_webpack_1.runWebpack)((await transforms?.webpackConfiguration?.(config)) || config, context, {
|
|
218
|
-
logging: (0, stats_1.createWebpackLoggingCallback)(builderOptions, context.logger),
|
|
219
|
-
webpackFactory: webpack_1.default,
|
|
220
|
-
}));
|
|
221
|
-
// Set the outputPath to the extraction output location for downstream consumers
|
|
222
|
-
webpackResult.outputPath = outFile;
|
|
223
|
-
// Complete if Webpack build failed
|
|
224
|
-
if (!webpackResult.success) {
|
|
225
|
-
return webpackResult;
|
|
226
|
-
}
|
|
227
|
-
const basePath = config.context || projectRoot;
|
|
228
|
-
const { checkDuplicateMessages } = localizeToolsModule;
|
|
229
|
-
// The filesystem is used to create a relative path for each file
|
|
230
|
-
// from the basePath. This relative path is then used in the error message.
|
|
231
|
-
const checkFileSystem = {
|
|
232
|
-
relative(from, to) {
|
|
233
|
-
return path.relative(from, to);
|
|
234
|
-
},
|
|
235
|
-
};
|
|
236
|
-
const diagnostics = checkDuplicateMessages(
|
|
237
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
238
|
-
checkFileSystem, ivyMessages, 'warning',
|
|
239
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
240
|
-
basePath);
|
|
241
|
-
if (diagnostics.messages.length > 0) {
|
|
242
|
-
context.logger.warn(diagnostics.formatDiagnostics(''));
|
|
243
|
-
}
|
|
244
|
-
// Serialize all extracted messages
|
|
245
|
-
const serializer = await getSerializer(localizeToolsModule, format, i18n.sourceLocale, basePath, useLegacyIds, diagnostics);
|
|
246
|
-
const content = serializer.serialize(ivyMessages);
|
|
247
|
-
// Ensure directory exists
|
|
248
|
-
const outputPath = path.dirname(outFile);
|
|
249
|
-
if (!fs.existsSync(outputPath)) {
|
|
250
|
-
fs.mkdirSync(outputPath, { recursive: true });
|
|
251
|
-
}
|
|
252
|
-
// Write translation file
|
|
253
|
-
fs.writeFileSync(outFile, content);
|
|
254
|
-
return webpackResult;
|
|
255
|
-
}
|
|
256
|
-
exports.execute = execute;
|
|
257
|
-
exports.default = (0, architect_1.createBuilder)(execute);
|
|
258
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/extract-i18n/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 type { ɵParsedMessage as LocalizeMessage } from '@angular/localize';\nimport type { Diagnostics } from '@angular/localize/tools';\nimport { BuilderContext, createBuilder, targetFromTargetString } from '@angular-devkit/architect';\nimport { BuildResult, runWebpack } from '@angular-devkit/build-webpack';\nimport { JsonObject } from '@angular-devkit/core';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { lastValueFrom } from 'rxjs';\nimport webpack, { Configuration } from 'webpack';\nimport { getCommonConfig } from '../../tools/webpack/configs';\nimport { createWebpackLoggingCallback } from '../../tools/webpack/utils/stats';\nimport { ExecutionTransformer } from '../../transforms';\nimport { createI18nOptions } from '../../utils/i18n-options';\nimport { loadEsmModule } from '../../utils/load-esm';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport { generateBrowserWebpackConfigFromContext } from '../../utils/webpack-browser-config';\nimport { Schema as BrowserBuilderOptions, OutputHashing } from '../browser/schema';\nimport { Format, Schema } from './schema';\n\nexport type ExtractI18nBuilderOptions = Schema;\n\nfunction getI18nOutfile(format: string | undefined) {\n  switch (format) {\n    case 'xmb':\n      return 'messages.xmb';\n    case 'xlf':\n    case 'xlif':\n    case 'xliff':\n    case 'xlf2':\n    case 'xliff2':\n      return 'messages.xlf';\n    case 'json':\n    case 'legacy-migrate':\n      return 'messages.json';\n    case 'arb':\n      return 'messages.arb';\n    default:\n      throw new Error(`Unsupported format \"${format}\"`);\n  }\n}\n\nasync function getSerializer(\n  localizeToolsModule: typeof import('@angular/localize/tools'),\n  format: Format,\n  sourceLocale: string,\n  basePath: string,\n  useLegacyIds: boolean,\n  diagnostics: Diagnostics,\n) {\n  const {\n    XmbTranslationSerializer,\n    LegacyMessageIdMigrationSerializer,\n    ArbTranslationSerializer,\n    Xliff1TranslationSerializer,\n    Xliff2TranslationSerializer,\n    SimpleJsonTranslationSerializer,\n  } = localizeToolsModule;\n\n  switch (format) {\n    case Format.Xmb:\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      return new XmbTranslationSerializer(basePath as any, useLegacyIds);\n    case Format.Xlf:\n    case Format.Xlif:\n    case Format.Xliff:\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      return new Xliff1TranslationSerializer(sourceLocale, basePath as any, useLegacyIds, {});\n    case Format.Xlf2:\n    case Format.Xliff2:\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      return new Xliff2TranslationSerializer(sourceLocale, basePath as any, useLegacyIds, {});\n    case Format.Json:\n      return new SimpleJsonTranslationSerializer(sourceLocale);\n    case Format.LegacyMigrate:\n      return new LegacyMessageIdMigrationSerializer(diagnostics);\n    case Format.Arb:\n      const fileSystem = {\n        relative(from: string, to: string): string {\n          return path.relative(from, to);\n        },\n      };\n\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      return new ArbTranslationSerializer(sourceLocale, basePath as any, fileSystem as any);\n  }\n}\n\nfunction normalizeFormatOption(options: ExtractI18nBuilderOptions): Format {\n  let format = options.format;\n\n  switch (format) {\n    case Format.Xlf:\n    case Format.Xlif:\n    case Format.Xliff:\n      format = Format.Xlf;\n      break;\n    case Format.Xlf2:\n    case Format.Xliff2:\n      format = Format.Xlf2;\n      break;\n  }\n\n  // Default format is xliff1\n  return format ?? Format.Xlf;\n}\n\nclass NoEmitPlugin {\n  apply(compiler: webpack.Compiler): void {\n    compiler.hooks.shouldEmit.tap('angular-no-emit', () => false);\n  }\n}\n\n/**\n * @experimental Direct usage of this function is considered experimental.\n */\nexport async function execute(\n  options: ExtractI18nBuilderOptions,\n  context: BuilderContext,\n  transforms?: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  },\n): Promise<BuildResult> {\n  // Check Angular version.\n  assertCompatibleAngularVersion(context.workspaceRoot);\n\n  // Purge old build disk cache.\n  await purgeStaleBuildCache(context);\n\n  const browserTarget = targetFromTargetString(options.browserTarget);\n  const browserOptions = await context.validateOptions<JsonObject & BrowserBuilderOptions>(\n    await context.getTargetOptions(browserTarget),\n    await context.getBuilderNameForTarget(browserTarget),\n  );\n\n  const format = normalizeFormatOption(options);\n\n  // We need to determine the outFile name so that AngularCompiler can retrieve it.\n  let outFile = options.outFile || getI18nOutfile(format);\n  if (options.outputPath) {\n    // AngularCompilerPlugin doesn't support genDir so we have to adjust outFile instead.\n    outFile = path.join(options.outputPath, outFile);\n  }\n  outFile = path.resolve(context.workspaceRoot, outFile);\n\n  if (!context.target || !context.target.project) {\n    throw new Error('The builder requires a target.');\n  }\n\n  try {\n    require.resolve('@angular/localize');\n  } catch {\n    return {\n      success: false,\n      error: `i18n extraction requires the '@angular/localize' package.`,\n      outputPath: outFile,\n    };\n  }\n\n  const metadata = await context.getProjectMetadata(context.target);\n  const i18n = createI18nOptions(metadata);\n\n  let useLegacyIds = true;\n\n  const ivyMessages: LocalizeMessage[] = [];\n  const builderOptions = {\n    ...browserOptions,\n    optimization: false,\n    sourceMap: {\n      scripts: true,\n      styles: false,\n      vendor: true,\n    },\n    buildOptimizer: false,\n    aot: true,\n    progress: options.progress,\n    budgets: [],\n    assets: [],\n    scripts: [],\n    styles: [],\n    deleteOutputPath: false,\n    extractLicenses: false,\n    subresourceIntegrity: false,\n    outputHashing: OutputHashing.None,\n    namedChunks: true,\n    allowedCommonJsDependencies: undefined,\n  };\n  const { config, projectRoot } = await generateBrowserWebpackConfigFromContext(\n    builderOptions,\n    context,\n    (wco) => {\n      // Default value for legacy message ids is currently true\n      useLegacyIds = wco.tsConfig.options.enableI18nLegacyMessageIdFormat ?? true;\n\n      const partials: (Promise<Configuration> | Configuration)[] = [\n        { plugins: [new NoEmitPlugin()] },\n        getCommonConfig(wco),\n      ];\n\n      // Add Ivy application file extractor support\n      partials.unshift({\n        module: {\n          rules: [\n            {\n              test: /\\.[cm]?[tj]sx?$/,\n              loader: require.resolve('./ivy-extract-loader'),\n              options: {\n                messageHandler: (messages: LocalizeMessage[]) => ivyMessages.push(...messages),\n              },\n            },\n          ],\n        },\n      });\n\n      // Replace all stylesheets with empty content\n      partials.push({\n        module: {\n          rules: [\n            {\n              test: /\\.(css|scss|sass|less)$/,\n              loader: require.resolve('./empty-loader'),\n            },\n          ],\n        },\n      });\n\n      return partials;\n    },\n    // During extraction we don't need specific browser support.\n    { supportedBrowsers: undefined },\n  );\n\n  // All the localize usages are setup to first try the ESM entry point then fallback to the deep imports.\n  // This provides interim compatibility while the framework is transitioned to bundled ESM packages.\n  const localizeToolsModule = await loadEsmModule<typeof import('@angular/localize/tools')>(\n    '@angular/localize/tools',\n  );\n  const webpackResult = await lastValueFrom(\n    runWebpack((await transforms?.webpackConfiguration?.(config)) || config, context, {\n      logging: createWebpackLoggingCallback(builderOptions, context.logger),\n      webpackFactory: webpack,\n    }),\n  );\n\n  // Set the outputPath to the extraction output location for downstream consumers\n  webpackResult.outputPath = outFile;\n\n  // Complete if Webpack build failed\n  if (!webpackResult.success) {\n    return webpackResult;\n  }\n\n  const basePath = config.context || projectRoot;\n\n  const { checkDuplicateMessages } = localizeToolsModule;\n\n  // The filesystem is used to create a relative path for each file\n  // from the basePath.  This relative path is then used in the error message.\n  const checkFileSystem = {\n    relative(from: string, to: string): string {\n      return path.relative(from, to);\n    },\n  };\n  const diagnostics = checkDuplicateMessages(\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    checkFileSystem as any,\n    ivyMessages,\n    'warning',\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    basePath as any,\n  );\n  if (diagnostics.messages.length > 0) {\n    context.logger.warn(diagnostics.formatDiagnostics(''));\n  }\n\n  // Serialize all extracted messages\n  const serializer = await getSerializer(\n    localizeToolsModule,\n    format,\n    i18n.sourceLocale,\n    basePath,\n    useLegacyIds,\n    diagnostics,\n  );\n  const content = serializer.serialize(ivyMessages);\n\n  // Ensure directory exists\n  const outputPath = path.dirname(outFile);\n  if (!fs.existsSync(outputPath)) {\n    fs.mkdirSync(outputPath, { recursive: true });\n  }\n\n  // Write translation file\n  fs.writeFileSync(outFile, content);\n\n  return webpackResult;\n}\n\nexport default createBuilder<ExtractI18nBuilderOptions>(execute);\n"]}
|
|
12
|
+
const builder_1 = require("./builder");
|
|
13
|
+
Object.defineProperty(exports, "execute", { enumerable: true, get: function () { return builder_1.execute; } });
|
|
14
|
+
exports.default = (0, architect_1.createBuilder)(builder_1.execute);
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy9idWlsZGVycy9leHRyYWN0LWkxOG4vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7O0FBRUgseURBQTBEO0FBQzFELHVDQUFvQztBQUdBLHdGQUgzQixpQkFBTyxPQUcyQjtBQUMzQyxrQkFBZSxJQUFBLHlCQUFhLEVBQTRCLGlCQUFPLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgeyBjcmVhdGVCdWlsZGVyIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2FyY2hpdGVjdCc7XG5pbXBvcnQgeyBleGVjdXRlIH0gZnJvbSAnLi9idWlsZGVyJztcbmltcG9ydCB0eXBlIHsgU2NoZW1hIGFzIEV4dHJhY3RJMThuQnVpbGRlck9wdGlvbnMgfSBmcm9tICcuL3NjaGVtYSc7XG5cbmV4cG9ydCB7IEV4dHJhY3RJMThuQnVpbGRlck9wdGlvbnMsIGV4ZWN1dGUgfTtcbmV4cG9ydCBkZWZhdWx0IGNyZWF0ZUJ1aWxkZXI8RXh0cmFjdEkxOG5CdWlsZGVyT3B0aW9ucz4oZXhlY3V0ZSk7XG4iXX0=
|
|
@@ -0,0 +1,29 @@
|
|
|
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 { Schema as ExtractI18nOptions, Format } from './schema';
|
|
10
|
+
export type NormalizedExtractI18nOptions = Awaited<ReturnType<typeof normalizeOptions>>;
|
|
11
|
+
/**
|
|
12
|
+
* Normalize the user provided options by creating full paths for all path based options
|
|
13
|
+
* and converting multi-form options into a single form that can be directly used
|
|
14
|
+
* by the build process.
|
|
15
|
+
*
|
|
16
|
+
* @param context The context for current builder execution.
|
|
17
|
+
* @param projectName The name of the project for the current execution.
|
|
18
|
+
* @param options An object containing the options to use for the build.
|
|
19
|
+
* @returns An object containing normalized options required to perform the build.
|
|
20
|
+
*/
|
|
21
|
+
export declare function normalizeOptions(context: BuilderContext, projectName: string, options: ExtractI18nOptions): Promise<{
|
|
22
|
+
workspaceRoot: string;
|
|
23
|
+
projectRoot: string;
|
|
24
|
+
browserTarget: import("@angular-devkit/architect").Target;
|
|
25
|
+
i18nOptions: import("../../utils/i18n-options").I18nOptions;
|
|
26
|
+
format: Format.Arb | Format.Json | Format.LegacyMigrate | Format.Xliff | Format.Xliff2 | Format.Xmb;
|
|
27
|
+
outFile: string;
|
|
28
|
+
progress: boolean;
|
|
29
|
+
}>;
|
|
@@ -0,0 +1,82 @@
|
|
|
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.io/license
|
|
8
|
+
*/
|
|
9
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
10
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.normalizeOptions = void 0;
|
|
14
|
+
const architect_1 = require("@angular-devkit/architect");
|
|
15
|
+
const node_assert_1 = require("node:assert");
|
|
16
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
17
|
+
const i18n_options_1 = require("../../utils/i18n-options");
|
|
18
|
+
const schema_1 = require("./schema");
|
|
19
|
+
/**
|
|
20
|
+
* Normalize the user provided options by creating full paths for all path based options
|
|
21
|
+
* and converting multi-form options into a single form that can be directly used
|
|
22
|
+
* by the build process.
|
|
23
|
+
*
|
|
24
|
+
* @param context The context for current builder execution.
|
|
25
|
+
* @param projectName The name of the project for the current execution.
|
|
26
|
+
* @param options An object containing the options to use for the build.
|
|
27
|
+
* @returns An object containing normalized options required to perform the build.
|
|
28
|
+
*/
|
|
29
|
+
async function normalizeOptions(context, projectName, options) {
|
|
30
|
+
const workspaceRoot = context.workspaceRoot;
|
|
31
|
+
const projectMetadata = await context.getProjectMetadata(projectName);
|
|
32
|
+
const projectRoot = node_path_1.default.join(workspaceRoot, projectMetadata.root ?? '');
|
|
33
|
+
const browserTarget = (0, architect_1.targetFromTargetString)(options.browserTarget);
|
|
34
|
+
const i18nOptions = (0, i18n_options_1.createI18nOptions)(projectMetadata);
|
|
35
|
+
// Normalize xliff format extensions
|
|
36
|
+
let format = options.format;
|
|
37
|
+
switch (format) {
|
|
38
|
+
case undefined:
|
|
39
|
+
// Default format is xliff1
|
|
40
|
+
case schema_1.Format.Xlf:
|
|
41
|
+
case schema_1.Format.Xlif:
|
|
42
|
+
case schema_1.Format.Xliff:
|
|
43
|
+
format = schema_1.Format.Xliff;
|
|
44
|
+
break;
|
|
45
|
+
case schema_1.Format.Xlf2:
|
|
46
|
+
case schema_1.Format.Xliff2:
|
|
47
|
+
format = schema_1.Format.Xliff2;
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
let outFile = options.outFile || getDefaultOutFile(format);
|
|
51
|
+
if (options.outputPath) {
|
|
52
|
+
outFile = node_path_1.default.join(options.outputPath, outFile);
|
|
53
|
+
}
|
|
54
|
+
outFile = node_path_1.default.resolve(context.workspaceRoot, outFile);
|
|
55
|
+
return {
|
|
56
|
+
workspaceRoot,
|
|
57
|
+
projectRoot,
|
|
58
|
+
browserTarget,
|
|
59
|
+
i18nOptions,
|
|
60
|
+
format,
|
|
61
|
+
outFile,
|
|
62
|
+
progress: options.progress ?? true,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
exports.normalizeOptions = normalizeOptions;
|
|
66
|
+
function getDefaultOutFile(format) {
|
|
67
|
+
switch (format) {
|
|
68
|
+
case schema_1.Format.Xmb:
|
|
69
|
+
return 'messages.xmb';
|
|
70
|
+
case schema_1.Format.Xliff:
|
|
71
|
+
case schema_1.Format.Xliff2:
|
|
72
|
+
return 'messages.xlf';
|
|
73
|
+
case schema_1.Format.Json:
|
|
74
|
+
case schema_1.Format.LegacyMigrate:
|
|
75
|
+
return 'messages.json';
|
|
76
|
+
case schema_1.Format.Arb:
|
|
77
|
+
return 'messages.arb';
|
|
78
|
+
default:
|
|
79
|
+
(0, node_assert_1.fail)(`Invalid Format enum value: ${format}`);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL2J1aWxkZXJzL2V4dHJhY3QtaTE4bi9vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7OztBQUVILHlEQUFtRjtBQUNuRiw2Q0FBbUM7QUFDbkMsMERBQTZCO0FBQzdCLDJEQUE2RDtBQUM3RCxxQ0FBZ0U7QUFJaEU7Ozs7Ozs7OztHQVNHO0FBQ0ksS0FBSyxVQUFVLGdCQUFnQixDQUNwQyxPQUF1QixFQUN2QixXQUFtQixFQUNuQixPQUEyQjtJQUUzQixNQUFNLGFBQWEsR0FBRyxPQUFPLENBQUMsYUFBYSxDQUFDO0lBQzVDLE1BQU0sZUFBZSxHQUFHLE1BQU0sT0FBTyxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3RFLE1BQU0sV0FBVyxHQUFHLG1CQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRyxlQUFlLENBQUMsSUFBMkIsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUVqRyxNQUFNLGFBQWEsR0FBRyxJQUFBLGtDQUFzQixFQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUVwRSxNQUFNLFdBQVcsR0FBRyxJQUFBLGdDQUFpQixFQUFDLGVBQWUsQ0FBQyxDQUFDO0lBRXZELG9DQUFvQztJQUNwQyxJQUFJLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDO0lBQzVCLFFBQVEsTUFBTSxFQUFFO1FBQ2QsS0FBSyxTQUFTLENBQUM7UUFDZiwyQkFBMkI7UUFDM0IsS0FBSyxlQUFNLENBQUMsR0FBRyxDQUFDO1FBQ2hCLEtBQUssZUFBTSxDQUFDLElBQUksQ0FBQztRQUNqQixLQUFLLGVBQU0sQ0FBQyxLQUFLO1lBQ2YsTUFBTSxHQUFHLGVBQU0sQ0FBQyxLQUFLLENBQUM7WUFDdEIsTUFBTTtRQUNSLEtBQUssZUFBTSxDQUFDLElBQUksQ0FBQztRQUNqQixLQUFLLGVBQU0sQ0FBQyxNQUFNO1lBQ2hCLE1BQU0sR0FBRyxlQUFNLENBQUMsTUFBTSxDQUFDO1lBQ3ZCLE1BQU07S0FDVDtJQUVELElBQUksT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLElBQUksaUJBQWlCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0QsSUFBSSxPQUFPLENBQUMsVUFBVSxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxtQkFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0tBQ2xEO0lBQ0QsT0FBTyxHQUFHLG1CQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFFdkQsT0FBTztRQUNMLGFBQWE7UUFDYixXQUFXO1FBQ1gsYUFBYTtRQUNiLFdBQVc7UUFDWCxNQUFNO1FBQ04sT0FBTztRQUNQLFFBQVEsRUFBRSxPQUFPLENBQUMsUUFBUSxJQUFJLElBQUk7S0FDbkMsQ0FBQztBQUNKLENBQUM7QUE1Q0QsNENBNENDO0FBRUQsU0FBUyxpQkFBaUIsQ0FBQyxNQUFjO0lBQ3ZDLFFBQVEsTUFBTSxFQUFFO1FBQ2QsS0FBSyxlQUFNLENBQUMsR0FBRztZQUNiLE9BQU8sY0FBYyxDQUFDO1FBQ3hCLEtBQUssZUFBTSxDQUFDLEtBQUssQ0FBQztRQUNsQixLQUFLLGVBQU0sQ0FBQyxNQUFNO1lBQ2hCLE9BQU8sY0FBYyxDQUFDO1FBQ3hCLEtBQUssZUFBTSxDQUFDLElBQUksQ0FBQztRQUNqQixLQUFLLGVBQU0sQ0FBQyxhQUFhO1lBQ3ZCLE9BQU8sZUFBZSxDQUFDO1FBQ3pCLEtBQUssZUFBTSxDQUFDLEdBQUc7WUFDYixPQUFPLGNBQWMsQ0FBQztRQUN4QjtZQUNFLElBQUEsa0JBQUksRUFBQyw4QkFBOEIsTUFBaUIsRUFBRSxDQUFDLENBQUM7S0FDM0Q7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7IEJ1aWxkZXJDb250ZXh0LCB0YXJnZXRGcm9tVGFyZ2V0U3RyaW5nIH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2FyY2hpdGVjdCc7XG5pbXBvcnQgeyBmYWlsIH0gZnJvbSAnbm9kZTphc3NlcnQnO1xuaW1wb3J0IHBhdGggZnJvbSAnbm9kZTpwYXRoJztcbmltcG9ydCB7IGNyZWF0ZUkxOG5PcHRpb25zIH0gZnJvbSAnLi4vLi4vdXRpbHMvaTE4bi1vcHRpb25zJztcbmltcG9ydCB7IFNjaGVtYSBhcyBFeHRyYWN0STE4bk9wdGlvbnMsIEZvcm1hdCB9IGZyb20gJy4vc2NoZW1hJztcblxuZXhwb3J0IHR5cGUgTm9ybWFsaXplZEV4dHJhY3RJMThuT3B0aW9ucyA9IEF3YWl0ZWQ8UmV0dXJuVHlwZTx0eXBlb2Ygbm9ybWFsaXplT3B0aW9ucz4+O1xuXG4vKipcbiAqIE5vcm1hbGl6ZSB0aGUgdXNlciBwcm92aWRlZCBvcHRpb25zIGJ5IGNyZWF0aW5nIGZ1bGwgcGF0aHMgZm9yIGFsbCBwYXRoIGJhc2VkIG9wdGlvbnNcbiAqIGFuZCBjb252ZXJ0aW5nIG11bHRpLWZvcm0gb3B0aW9ucyBpbnRvIGEgc2luZ2xlIGZvcm0gdGhhdCBjYW4gYmUgZGlyZWN0bHkgdXNlZFxuICogYnkgdGhlIGJ1aWxkIHByb2Nlc3MuXG4gKlxuICogQHBhcmFtIGNvbnRleHQgVGhlIGNvbnRleHQgZm9yIGN1cnJlbnQgYnVpbGRlciBleGVjdXRpb24uXG4gKiBAcGFyYW0gcHJvamVjdE5hbWUgVGhlIG5hbWUgb2YgdGhlIHByb2plY3QgZm9yIHRoZSBjdXJyZW50IGV4ZWN1dGlvbi5cbiAqIEBwYXJhbSBvcHRpb25zIEFuIG9iamVjdCBjb250YWluaW5nIHRoZSBvcHRpb25zIHRvIHVzZSBmb3IgdGhlIGJ1aWxkLlxuICogQHJldHVybnMgQW4gb2JqZWN0IGNvbnRhaW5pbmcgbm9ybWFsaXplZCBvcHRpb25zIHJlcXVpcmVkIHRvIHBlcmZvcm0gdGhlIGJ1aWxkLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbm9ybWFsaXplT3B0aW9ucyhcbiAgY29udGV4dDogQnVpbGRlckNvbnRleHQsXG4gIHByb2plY3ROYW1lOiBzdHJpbmcsXG4gIG9wdGlvbnM6IEV4dHJhY3RJMThuT3B0aW9ucyxcbikge1xuICBjb25zdCB3b3Jrc3BhY2VSb290ID0gY29udGV4dC53b3Jrc3BhY2VSb290O1xuICBjb25zdCBwcm9qZWN0TWV0YWRhdGEgPSBhd2FpdCBjb250ZXh0LmdldFByb2plY3RNZXRhZGF0YShwcm9qZWN0TmFtZSk7XG4gIGNvbnN0IHByb2plY3RSb290ID0gcGF0aC5qb2luKHdvcmtzcGFjZVJvb3QsIChwcm9qZWN0TWV0YWRhdGEucm9vdCBhcyBzdHJpbmcgfCB1bmRlZmluZWQpID8/ICcnKTtcblxuICBjb25zdCBicm93c2VyVGFyZ2V0ID0gdGFyZ2V0RnJvbVRhcmdldFN0cmluZyhvcHRpb25zLmJyb3dzZXJUYXJnZXQpO1xuXG4gIGNvbnN0IGkxOG5PcHRpb25zID0gY3JlYXRlSTE4bk9wdGlvbnMocHJvamVjdE1ldGFkYXRhKTtcblxuICAvLyBOb3JtYWxpemUgeGxpZmYgZm9ybWF0IGV4dGVuc2lvbnNcbiAgbGV0IGZvcm1hdCA9IG9wdGlvbnMuZm9ybWF0O1xuICBzd2l0Y2ggKGZvcm1hdCkge1xuICAgIGNhc2UgdW5kZWZpbmVkOlxuICAgIC8vIERlZmF1bHQgZm9ybWF0IGlzIHhsaWZmMVxuICAgIGNhc2UgRm9ybWF0LlhsZjpcbiAgICBjYXNlIEZvcm1hdC5YbGlmOlxuICAgIGNhc2UgRm9ybWF0LlhsaWZmOlxuICAgICAgZm9ybWF0ID0gRm9ybWF0LlhsaWZmO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBGb3JtYXQuWGxmMjpcbiAgICBjYXNlIEZvcm1hdC5YbGlmZjI6XG4gICAgICBmb3JtYXQgPSBGb3JtYXQuWGxpZmYyO1xuICAgICAgYnJlYWs7XG4gIH1cblxuICBsZXQgb3V0RmlsZSA9IG9wdGlvbnMub3V0RmlsZSB8fCBnZXREZWZhdWx0T3V0RmlsZShmb3JtYXQpO1xuICBpZiAob3B0aW9ucy5vdXRwdXRQYXRoKSB7XG4gICAgb3V0RmlsZSA9IHBhdGguam9pbihvcHRpb25zLm91dHB1dFBhdGgsIG91dEZpbGUpO1xuICB9XG4gIG91dEZpbGUgPSBwYXRoLnJlc29sdmUoY29udGV4dC53b3Jrc3BhY2VSb290LCBvdXRGaWxlKTtcblxuICByZXR1cm4ge1xuICAgIHdvcmtzcGFjZVJvb3QsXG4gICAgcHJvamVjdFJvb3QsXG4gICAgYnJvd3NlclRhcmdldCxcbiAgICBpMThuT3B0aW9ucyxcbiAgICBmb3JtYXQsXG4gICAgb3V0RmlsZSxcbiAgICBwcm9ncmVzczogb3B0aW9ucy5wcm9ncmVzcyA/PyB0cnVlLFxuICB9O1xufVxuXG5mdW5jdGlvbiBnZXREZWZhdWx0T3V0RmlsZShmb3JtYXQ6IEZvcm1hdCkge1xuICBzd2l0Y2ggKGZvcm1hdCkge1xuICAgIGNhc2UgRm9ybWF0LlhtYjpcbiAgICAgIHJldHVybiAnbWVzc2FnZXMueG1iJztcbiAgICBjYXNlIEZvcm1hdC5YbGlmZjpcbiAgICBjYXNlIEZvcm1hdC5YbGlmZjI6XG4gICAgICByZXR1cm4gJ21lc3NhZ2VzLnhsZic7XG4gICAgY2FzZSBGb3JtYXQuSnNvbjpcbiAgICBjYXNlIEZvcm1hdC5MZWdhY3lNaWdyYXRlOlxuICAgICAgcmV0dXJuICdtZXNzYWdlcy5qc29uJztcbiAgICBjYXNlIEZvcm1hdC5BcmI6XG4gICAgICByZXR1cm4gJ21lc3NhZ2VzLmFyYic7XG4gICAgZGVmYXVsdDpcbiAgICAgIGZhaWwoYEludmFsaWQgRm9ybWF0IGVudW0gdmFsdWU6ICR7Zm9ybWF0IGFzIHVua25vd259YCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
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 type { ɵParsedMessage as LocalizeMessage } from '@angular/localize';
|
|
9
|
+
import { BuilderContext } from '@angular-devkit/architect';
|
|
10
|
+
import { BuildResult } from '@angular-devkit/build-webpack';
|
|
11
|
+
import webpack from 'webpack';
|
|
12
|
+
import { ExecutionTransformer } from '../../transforms';
|
|
13
|
+
import { NormalizedExtractI18nOptions } from './options';
|
|
14
|
+
export declare function extractMessages(options: NormalizedExtractI18nOptions, builderName: string, context: BuilderContext, transforms?: {
|
|
15
|
+
webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;
|
|
16
|
+
}): Promise<{
|
|
17
|
+
builderResult: BuildResult;
|
|
18
|
+
basePath: string;
|
|
19
|
+
messages: LocalizeMessage[];
|
|
20
|
+
useLegacyIds: boolean;
|
|
21
|
+
}>;
|
|
@@ -0,0 +1,100 @@
|
|
|
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.io/license
|
|
8
|
+
*/
|
|
9
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
10
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.extractMessages = void 0;
|
|
14
|
+
const build_webpack_1 = require("@angular-devkit/build-webpack");
|
|
15
|
+
const rxjs_1 = require("rxjs");
|
|
16
|
+
const webpack_1 = __importDefault(require("webpack"));
|
|
17
|
+
const configs_1 = require("../../tools/webpack/configs");
|
|
18
|
+
const stats_1 = require("../../tools/webpack/utils/stats");
|
|
19
|
+
const webpack_browser_config_1 = require("../../utils/webpack-browser-config");
|
|
20
|
+
const schema_1 = require("../browser/schema");
|
|
21
|
+
class NoEmitPlugin {
|
|
22
|
+
apply(compiler) {
|
|
23
|
+
compiler.hooks.shouldEmit.tap('angular-no-emit', () => false);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async function extractMessages(options, builderName, context, transforms = {}) {
|
|
27
|
+
const messages = [];
|
|
28
|
+
let useLegacyIds = true;
|
|
29
|
+
const browserOptions = await context.validateOptions(await context.getTargetOptions(options.browserTarget), builderName);
|
|
30
|
+
const builderOptions = {
|
|
31
|
+
...browserOptions,
|
|
32
|
+
optimization: false,
|
|
33
|
+
sourceMap: {
|
|
34
|
+
scripts: true,
|
|
35
|
+
styles: false,
|
|
36
|
+
vendor: true,
|
|
37
|
+
},
|
|
38
|
+
buildOptimizer: false,
|
|
39
|
+
aot: true,
|
|
40
|
+
progress: options.progress,
|
|
41
|
+
budgets: [],
|
|
42
|
+
assets: [],
|
|
43
|
+
scripts: [],
|
|
44
|
+
styles: [],
|
|
45
|
+
deleteOutputPath: false,
|
|
46
|
+
extractLicenses: false,
|
|
47
|
+
subresourceIntegrity: false,
|
|
48
|
+
outputHashing: schema_1.OutputHashing.None,
|
|
49
|
+
namedChunks: true,
|
|
50
|
+
allowedCommonJsDependencies: undefined,
|
|
51
|
+
};
|
|
52
|
+
const { config } = await (0, webpack_browser_config_1.generateBrowserWebpackConfigFromContext)(builderOptions, context, (wco) => {
|
|
53
|
+
// Default value for legacy message ids is currently true
|
|
54
|
+
useLegacyIds = wco.tsConfig.options.enableI18nLegacyMessageIdFormat ?? true;
|
|
55
|
+
const partials = [
|
|
56
|
+
{ plugins: [new NoEmitPlugin()] },
|
|
57
|
+
(0, configs_1.getCommonConfig)(wco),
|
|
58
|
+
];
|
|
59
|
+
// Add Ivy application file extractor support
|
|
60
|
+
partials.unshift({
|
|
61
|
+
module: {
|
|
62
|
+
rules: [
|
|
63
|
+
{
|
|
64
|
+
test: /\.[cm]?[tj]sx?$/,
|
|
65
|
+
loader: require.resolve('./ivy-extract-loader'),
|
|
66
|
+
options: {
|
|
67
|
+
messageHandler: (fileMessages) => messages.push(...fileMessages),
|
|
68
|
+
},
|
|
69
|
+
},
|
|
70
|
+
],
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
// Replace all stylesheets with empty content
|
|
74
|
+
partials.push({
|
|
75
|
+
module: {
|
|
76
|
+
rules: [
|
|
77
|
+
{
|
|
78
|
+
test: /\.(css|scss|sass|less)$/,
|
|
79
|
+
loader: require.resolve('./empty-loader'),
|
|
80
|
+
},
|
|
81
|
+
],
|
|
82
|
+
},
|
|
83
|
+
});
|
|
84
|
+
return partials;
|
|
85
|
+
},
|
|
86
|
+
// During extraction we don't need specific browser support.
|
|
87
|
+
{ supportedBrowsers: undefined });
|
|
88
|
+
const builderResult = await (0, rxjs_1.lastValueFrom)((0, build_webpack_1.runWebpack)((await transforms?.webpackConfiguration?.(config)) || config, context, {
|
|
89
|
+
logging: (0, stats_1.createWebpackLoggingCallback)(builderOptions, context.logger),
|
|
90
|
+
webpackFactory: webpack_1.default,
|
|
91
|
+
}));
|
|
92
|
+
return {
|
|
93
|
+
builderResult,
|
|
94
|
+
basePath: config.context || options.projectRoot,
|
|
95
|
+
messages,
|
|
96
|
+
useLegacyIds,
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
exports.extractMessages = extractMessages;
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"webpack-extraction.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/extract-i18n/webpack-extraction.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 type { ɵParsedMessage as LocalizeMessage } from '@angular/localize';\nimport { BuilderContext } from '@angular-devkit/architect';\nimport { BuildResult, runWebpack } from '@angular-devkit/build-webpack';\nimport { lastValueFrom } from 'rxjs';\nimport webpack, { type Configuration } from 'webpack';\nimport { getCommonConfig } from '../../tools/webpack/configs';\nimport { createWebpackLoggingCallback } from '../../tools/webpack/utils/stats';\nimport { ExecutionTransformer } from '../../transforms';\nimport { generateBrowserWebpackConfigFromContext } from '../../utils/webpack-browser-config';\nimport { OutputHashing, Schema } from '../browser/schema';\nimport { NormalizedExtractI18nOptions } from './options';\n\nclass NoEmitPlugin {\n  apply(compiler: webpack.Compiler): void {\n    compiler.hooks.shouldEmit.tap('angular-no-emit', () => false);\n  }\n}\n\nexport async function extractMessages(\n  options: NormalizedExtractI18nOptions,\n  builderName: string,\n  context: BuilderContext,\n  transforms: {\n    webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;\n  } = {},\n): Promise<{\n  builderResult: BuildResult;\n  basePath: string;\n  messages: LocalizeMessage[];\n  useLegacyIds: boolean;\n}> {\n  const messages: LocalizeMessage[] = [];\n  let useLegacyIds = true;\n\n  const browserOptions = await context.validateOptions(\n    await context.getTargetOptions(options.browserTarget),\n    builderName,\n  );\n\n  const builderOptions = {\n    ...browserOptions,\n    optimization: false,\n    sourceMap: {\n      scripts: true,\n      styles: false,\n      vendor: true,\n    },\n    buildOptimizer: false,\n    aot: true,\n    progress: options.progress,\n    budgets: [],\n    assets: [],\n    scripts: [],\n    styles: [],\n    deleteOutputPath: false,\n    extractLicenses: false,\n    subresourceIntegrity: false,\n    outputHashing: OutputHashing.None,\n    namedChunks: true,\n    allowedCommonJsDependencies: undefined,\n  } as unknown as Schema;\n  const { config } = await generateBrowserWebpackConfigFromContext(\n    builderOptions,\n    context,\n    (wco) => {\n      // Default value for legacy message ids is currently true\n      useLegacyIds = wco.tsConfig.options.enableI18nLegacyMessageIdFormat ?? true;\n\n      const partials: (Promise<Configuration> | Configuration)[] = [\n        { plugins: [new NoEmitPlugin()] },\n        getCommonConfig(wco),\n      ];\n\n      // Add Ivy application file extractor support\n      partials.unshift({\n        module: {\n          rules: [\n            {\n              test: /\\.[cm]?[tj]sx?$/,\n              loader: require.resolve('./ivy-extract-loader'),\n              options: {\n                messageHandler: (fileMessages: LocalizeMessage[]) => messages.push(...fileMessages),\n              },\n            },\n          ],\n        },\n      });\n\n      // Replace all stylesheets with empty content\n      partials.push({\n        module: {\n          rules: [\n            {\n              test: /\\.(css|scss|sass|less)$/,\n              loader: require.resolve('./empty-loader'),\n            },\n          ],\n        },\n      });\n\n      return partials;\n    },\n    // During extraction we don't need specific browser support.\n    { supportedBrowsers: undefined },\n  );\n\n  const builderResult = await lastValueFrom(\n    runWebpack((await transforms?.webpackConfiguration?.(config)) || config, context, {\n      logging: createWebpackLoggingCallback(builderOptions, context.logger),\n      webpackFactory: webpack,\n    }),\n  );\n\n  return {\n    builderResult,\n    basePath: config.context || options.projectRoot,\n    messages,\n    useLegacyIds,\n  };\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
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, BuilderOutput } from '@angular-devkit/architect';
|
|
9
|
+
import { json } from '@angular-devkit/core';
|
|
10
|
+
import { Schema } from './schema';
|
|
11
|
+
type PrerenderBuilderOptions = Schema & json.JsonObject;
|
|
12
|
+
type PrerenderBuilderOutput = BuilderOutput;
|
|
13
|
+
/**
|
|
14
|
+
* Builds the browser and server, then renders each route in options.routes
|
|
15
|
+
* and writes them to prerender/<route>/index.html for each output path in
|
|
16
|
+
* the browser result.
|
|
17
|
+
*/
|
|
18
|
+
export declare function execute(options: PrerenderBuilderOptions, context: BuilderContext): Promise<PrerenderBuilderOutput>;
|
|
19
|
+
declare const _default: import("../../../../architect/src/internal").Builder<Schema & json.JsonObject>;
|
|
20
|
+
export default _default;
|