"use strict"; /** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } }); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.i18nInlineEmittedFiles = void 0; const fs = __importStar(require("fs")); const path = __importStar(require("path")); const action_executor_1 = require("./action-executor"); const copy_assets_1 = require("./copy-assets"); const spinner_1 = require("./spinner"); function emittedFilesToInlineOptions(emittedFiles, scriptsEntryPointName, emittedPath, outputPath, es5, missingTranslation) { const options = []; const originalFiles = []; for (const emittedFile of emittedFiles) { if (emittedFile.asset || emittedFile.extension !== '.js' || (emittedFile.name && scriptsEntryPointName.includes(emittedFile.name))) { continue; } const originalPath = path.join(emittedPath, emittedFile.file); const action = { filename: emittedFile.file, code: fs.readFileSync(originalPath, 'utf8'), es5, outputPath, missingTranslation, setLocale: emittedFile.name === 'main' || emittedFile.name === 'vendor', }; originalFiles.push(originalPath); try { const originalMapPath = originalPath + '.map'; action.map = fs.readFileSync(originalMapPath, 'utf8'); originalFiles.push(originalMapPath); } catch (err) { if (err.code !== 'ENOENT') { throw err; } } options.push(action); } return { options, originalFiles }; } async function i18nInlineEmittedFiles(context, emittedFiles, i18n, baseOutputPath, outputPaths, scriptsEntryPointName, emittedPath, es5, missingTranslation) { const executor = new action_executor_1.BundleActionExecutor({ i18n }); let hasErrors = false; const spinner = new spinner_1.Spinner(); spinner.start('Generating localized bundles...'); try { const { options, originalFiles: processedFiles } = emittedFilesToInlineOptions(emittedFiles, scriptsEntryPointName, emittedPath, baseOutputPath, es5, missingTranslation); for await (const result of executor.inlineAll(options)) { for (const diagnostic of result.diagnostics) { spinner.stop(); if (diagnostic.type === 'error') { hasErrors = true; context.logger.error(diagnostic.message); } else { context.logger.warn(diagnostic.message); } spinner.start(); } } // Copy any non-processed files into the output locations await copy_assets_1.copyAssets([ { glob: '**/*', input: emittedPath, output: '', ignore: [...processedFiles].map((f) => path.relative(emittedPath, f)), }, ], outputPaths, ''); } catch (err) { spinner.fail('Localized bundle generation failed: ' + err.message); return false; } finally { executor.stop(); } if (hasErrors) { spinner.fail('Localized bundle generation failed.'); } else { spinner.succeed('Localized bundle generation complete.'); } return !hasErrors; } exports.i18nInlineEmittedFiles = i18nInlineEmittedFiles;