@angular-devkit/build-angular 16.2.0 → 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/application/execute-build.js +2 -2
- package/src/builders/browser-esbuild/builder-status-warnings.js +2 -1
- package/src/builders/dev-server/vite-server.d.ts +1 -1
- package/src/builders/dev-server/vite-server.js +89 -52
- 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 +4 -6
- package/src/tools/esbuild/utils.js +5 -1
- package/src/tools/sass/rebasing-importer.js +15 -8
- package/src/utils/index-file/inline-critical-css.js +13 -26
- package/src/utils/index-file/inline-fonts.js +1 -2
- package/src/utils/package-chunk-sort.js +1 -1
- package/src/utils/server-rendering/esm-in-memory-file-loader.d.ts +4 -2
- package/src/utils/server-rendering/esm-in-memory-file-loader.js +28 -5
- package/src/utils/server-rendering/prerender.d.ts +1 -1
- package/src/utils/server-rendering/prerender.js +6 -3
- package/src/tools/esbuild/external-packages-plugin.d.ts +0 -17
- package/src/tools/esbuild/external-packages-plugin.js +0 -49
|
@@ -0,0 +1,152 @@
|
|
|
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 __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.execute = void 0;
|
|
37
|
+
const node_fs_1 = __importDefault(require("node:fs"));
|
|
38
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
39
|
+
const load_esm_1 = require("../../utils/load-esm");
|
|
40
|
+
const purge_cache_1 = require("../../utils/purge-cache");
|
|
41
|
+
const version_1 = require("../../utils/version");
|
|
42
|
+
const options_1 = require("./options");
|
|
43
|
+
const schema_1 = require("./schema");
|
|
44
|
+
/**
|
|
45
|
+
* @experimental Direct usage of this function is considered experimental.
|
|
46
|
+
*/
|
|
47
|
+
async function execute(options, context, transforms) {
|
|
48
|
+
// Determine project name from builder context target
|
|
49
|
+
const projectName = context.target?.project;
|
|
50
|
+
if (!projectName) {
|
|
51
|
+
context.logger.error(`The 'extract-i18n' builder requires a target to be specified.`);
|
|
52
|
+
return { success: false };
|
|
53
|
+
}
|
|
54
|
+
// Check Angular version.
|
|
55
|
+
(0, version_1.assertCompatibleAngularVersion)(context.workspaceRoot);
|
|
56
|
+
// Load the Angular localize package.
|
|
57
|
+
// The package is a peer dependency and might not be present
|
|
58
|
+
let localizeToolsModule;
|
|
59
|
+
try {
|
|
60
|
+
localizeToolsModule = await (0, load_esm_1.loadEsmModule)('@angular/localize/tools');
|
|
61
|
+
}
|
|
62
|
+
catch {
|
|
63
|
+
return {
|
|
64
|
+
success: false,
|
|
65
|
+
error: `i18n extraction requires the '@angular/localize' package.` +
|
|
66
|
+
` You can add it by using 'ng add @angular/localize'.`,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
// Normalize options
|
|
70
|
+
const normalizedOptions = await (0, options_1.normalizeOptions)(context, projectName, options);
|
|
71
|
+
const builderName = await context.getBuilderNameForTarget(normalizedOptions.browserTarget);
|
|
72
|
+
// Extract messages based on configured builder
|
|
73
|
+
let extractionResult;
|
|
74
|
+
if (builderName === '@angular-devkit/build-angular:application' ||
|
|
75
|
+
builderName === '@angular-devkit/build-angular:browser-esbuild') {
|
|
76
|
+
const { extractMessages } = await Promise.resolve().then(() => __importStar(require('./application-extraction')));
|
|
77
|
+
extractionResult = await extractMessages(normalizedOptions, builderName, context, localizeToolsModule.MessageExtractor);
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
// Purge old build disk cache.
|
|
81
|
+
// Other build systems handle stale cache purging directly.
|
|
82
|
+
await (0, purge_cache_1.purgeStaleBuildCache)(context);
|
|
83
|
+
const { extractMessages } = await Promise.resolve().then(() => __importStar(require('./webpack-extraction')));
|
|
84
|
+
extractionResult = await extractMessages(normalizedOptions, builderName, context, transforms);
|
|
85
|
+
}
|
|
86
|
+
// Return the builder result if it failed
|
|
87
|
+
if (!extractionResult.builderResult.success) {
|
|
88
|
+
return extractionResult.builderResult;
|
|
89
|
+
}
|
|
90
|
+
// Perform duplicate message checks
|
|
91
|
+
const { checkDuplicateMessages } = localizeToolsModule;
|
|
92
|
+
// The filesystem is used to create a relative path for each file
|
|
93
|
+
// from the basePath. This relative path is then used in the error message.
|
|
94
|
+
const checkFileSystem = {
|
|
95
|
+
relative(from, to) {
|
|
96
|
+
return node_path_1.default.relative(from, to);
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
const diagnostics = checkDuplicateMessages(
|
|
100
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
101
|
+
checkFileSystem, extractionResult.messages, 'warning',
|
|
102
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
103
|
+
extractionResult.basePath);
|
|
104
|
+
if (diagnostics.messages.length > 0) {
|
|
105
|
+
context.logger.warn(diagnostics.formatDiagnostics(''));
|
|
106
|
+
}
|
|
107
|
+
// Serialize all extracted messages
|
|
108
|
+
const serializer = await createSerializer(localizeToolsModule, normalizedOptions.format, normalizedOptions.i18nOptions.sourceLocale, extractionResult.basePath, extractionResult.useLegacyIds, diagnostics);
|
|
109
|
+
const content = serializer.serialize(extractionResult.messages);
|
|
110
|
+
// Ensure directory exists
|
|
111
|
+
const outputPath = node_path_1.default.dirname(normalizedOptions.outFile);
|
|
112
|
+
if (!node_fs_1.default.existsSync(outputPath)) {
|
|
113
|
+
node_fs_1.default.mkdirSync(outputPath, { recursive: true });
|
|
114
|
+
}
|
|
115
|
+
// Write translation file
|
|
116
|
+
node_fs_1.default.writeFileSync(normalizedOptions.outFile, content);
|
|
117
|
+
if (normalizedOptions.progress) {
|
|
118
|
+
context.logger.info(`Extraction Complete. (Messages: ${extractionResult.messages.length})`);
|
|
119
|
+
}
|
|
120
|
+
return { success: true, outputPath: normalizedOptions.outFile };
|
|
121
|
+
}
|
|
122
|
+
exports.execute = execute;
|
|
123
|
+
async function createSerializer(localizeToolsModule, format, sourceLocale, basePath, useLegacyIds, diagnostics) {
|
|
124
|
+
const { XmbTranslationSerializer, LegacyMessageIdMigrationSerializer, ArbTranslationSerializer, Xliff1TranslationSerializer, Xliff2TranslationSerializer, SimpleJsonTranslationSerializer, } = localizeToolsModule;
|
|
125
|
+
switch (format) {
|
|
126
|
+
case schema_1.Format.Xmb:
|
|
127
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
128
|
+
return new XmbTranslationSerializer(basePath, useLegacyIds);
|
|
129
|
+
case schema_1.Format.Xlf:
|
|
130
|
+
case schema_1.Format.Xlif:
|
|
131
|
+
case schema_1.Format.Xliff:
|
|
132
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
133
|
+
return new Xliff1TranslationSerializer(sourceLocale, basePath, useLegacyIds, {});
|
|
134
|
+
case schema_1.Format.Xlf2:
|
|
135
|
+
case schema_1.Format.Xliff2:
|
|
136
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
137
|
+
return new Xliff2TranslationSerializer(sourceLocale, basePath, useLegacyIds, {});
|
|
138
|
+
case schema_1.Format.Json:
|
|
139
|
+
return new SimpleJsonTranslationSerializer(sourceLocale);
|
|
140
|
+
case schema_1.Format.LegacyMigrate:
|
|
141
|
+
return new LegacyMessageIdMigrationSerializer(diagnostics);
|
|
142
|
+
case schema_1.Format.Arb:
|
|
143
|
+
const fileSystem = {
|
|
144
|
+
relative(from, to) {
|
|
145
|
+
return node_path_1.default.relative(from, to);
|
|
146
|
+
},
|
|
147
|
+
};
|
|
148
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
149
|
+
return new ArbTranslationSerializer(sourceLocale, basePath, fileSystem);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/extract-i18n/builder.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 { Diagnostics } from '@angular/localize/tools';\nimport type { BuilderContext, BuilderOutput } from '@angular-devkit/architect';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport type webpack from 'webpack';\nimport type { ExecutionTransformer } from '../../transforms';\nimport { loadEsmModule } from '../../utils/load-esm';\nimport { purgeStaleBuildCache } from '../../utils/purge-cache';\nimport { assertCompatibleAngularVersion } from '../../utils/version';\nimport { normalizeOptions } from './options';\nimport { Schema as ExtractI18nBuilderOptions, Format } from './schema';\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<BuilderOutput> {\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'extract-i18n' builder requires a target to be specified.`);\n\n    return { success: false };\n  }\n\n  // Check Angular version.\n  assertCompatibleAngularVersion(context.workspaceRoot);\n\n  // Load the Angular localize package.\n  // The package is a peer dependency and might not be present\n  let localizeToolsModule;\n  try {\n    localizeToolsModule = await loadEsmModule<typeof import('@angular/localize/tools')>(\n      '@angular/localize/tools',\n    );\n  } catch {\n    return {\n      success: false,\n      error:\n        `i18n extraction requires the '@angular/localize' package.` +\n        ` You can add it by using 'ng add @angular/localize'.`,\n    };\n  }\n\n  // Normalize options\n  const normalizedOptions = await normalizeOptions(context, projectName, options);\n  const builderName = await context.getBuilderNameForTarget(normalizedOptions.browserTarget);\n\n  // Extract messages based on configured builder\n  let extractionResult;\n  if (\n    builderName === '@angular-devkit/build-angular:application' ||\n    builderName === '@angular-devkit/build-angular:browser-esbuild'\n  ) {\n    const { extractMessages } = await import('./application-extraction');\n    extractionResult = await extractMessages(\n      normalizedOptions,\n      builderName,\n      context,\n      localizeToolsModule.MessageExtractor,\n    );\n  } else {\n    // Purge old build disk cache.\n    // Other build systems handle stale cache purging directly.\n    await purgeStaleBuildCache(context);\n\n    const { extractMessages } = await import('./webpack-extraction');\n    extractionResult = await extractMessages(normalizedOptions, builderName, context, transforms);\n  }\n\n  // Return the builder result if it failed\n  if (!extractionResult.builderResult.success) {\n    return extractionResult.builderResult;\n  }\n\n  // Perform duplicate message checks\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    extractionResult.messages,\n    'warning',\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    extractionResult.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 createSerializer(\n    localizeToolsModule,\n    normalizedOptions.format,\n    normalizedOptions.i18nOptions.sourceLocale,\n    extractionResult.basePath,\n    extractionResult.useLegacyIds,\n    diagnostics,\n  );\n  const content = serializer.serialize(extractionResult.messages);\n\n  // Ensure directory exists\n  const outputPath = path.dirname(normalizedOptions.outFile);\n  if (!fs.existsSync(outputPath)) {\n    fs.mkdirSync(outputPath, { recursive: true });\n  }\n\n  // Write translation file\n  fs.writeFileSync(normalizedOptions.outFile, content);\n\n  if (normalizedOptions.progress) {\n    context.logger.info(`Extraction Complete. (Messages: ${extractionResult.messages.length})`);\n  }\n\n  return { success: true, outputPath: normalizedOptions.outFile };\n}\n\nasync function createSerializer(\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"]}
|
|
@@ -5,18 +5,8 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
import
|
|
12
|
-
import { ExecutionTransformer } from '../../transforms';
|
|
13
|
-
import { Schema } from './schema';
|
|
14
|
-
export type ExtractI18nBuilderOptions = Schema;
|
|
15
|
-
/**
|
|
16
|
-
* @experimental Direct usage of this function is considered experimental.
|
|
17
|
-
*/
|
|
18
|
-
export declare function execute(options: ExtractI18nBuilderOptions, context: BuilderContext, transforms?: {
|
|
19
|
-
webpackConfiguration?: ExecutionTransformer<webpack.Configuration>;
|
|
20
|
-
}): Promise<BuildResult>;
|
|
21
|
-
declare const _default: import("../../../../architect/src/internal").Builder<Schema & JsonObject>;
|
|
8
|
+
import { execute } from './builder';
|
|
9
|
+
import type { Schema as ExtractI18nBuilderOptions } from './schema';
|
|
10
|
+
export { ExtractI18nBuilderOptions, execute };
|
|
11
|
+
declare const _default: import("../../../../architect/src/internal").Builder<ExtractI18nBuilderOptions & import("../../../../core/src").JsonObject>;
|
|
22
12
|
export default _default;
|
|
@@ -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
|
+
}>;
|