source: trip-planner-front/node_modules/@angular/compiler/src/render3/view/i18n/context.js@ 6a3a178

Last change on this file since 6a3a178 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 31.2 KB
Line 
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(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler/src/render3/view/i18n/context", ["require", "exports", "tslib", "@angular/compiler/src/render3/view/i18n/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.I18nContext = void 0;
20 var tslib_1 = require("tslib");
21 var util_1 = require("@angular/compiler/src/render3/view/i18n/util");
22 var TagType;
23 (function (TagType) {
24 TagType[TagType["ELEMENT"] = 0] = "ELEMENT";
25 TagType[TagType["TEMPLATE"] = 1] = "TEMPLATE";
26 })(TagType || (TagType = {}));
27 /**
28 * Generates an object that is used as a shared state between parent and all child contexts.
29 */
30 function setupRegistry() {
31 return { getUniqueId: util_1.getSeqNumberGenerator(), icus: new Map() };
32 }
33 /**
34 * I18nContext is a helper class which keeps track of all i18n-related aspects
35 * (accumulates placeholders, bindings, etc) between i18nStart and i18nEnd instructions.
36 *
37 * When we enter a nested template, the top-level context is being passed down
38 * to the nested component, which uses this context to generate a child instance
39 * of I18nContext class (to handle nested template) and at the end, reconciles it back
40 * with the parent context.
41 *
42 * @param index Instruction index of i18nStart, which initiates this context
43 * @param ref Reference to a translation const that represents the content if thus context
44 * @param level Nestng level defined for child contexts
45 * @param templateIndex Instruction index of a template which this context belongs to
46 * @param meta Meta information (id, meaning, description, etc) associated with this context
47 */
48 var I18nContext = /** @class */ (function () {
49 function I18nContext(index, ref, level, templateIndex, meta, registry) {
50 if (level === void 0) { level = 0; }
51 if (templateIndex === void 0) { templateIndex = null; }
52 this.index = index;
53 this.ref = ref;
54 this.level = level;
55 this.templateIndex = templateIndex;
56 this.meta = meta;
57 this.registry = registry;
58 this.bindings = new Set();
59 this.placeholders = new Map();
60 this.isEmitted = false;
61 this._unresolvedCtxCount = 0;
62 this._registry = registry || setupRegistry();
63 this.id = this._registry.getUniqueId();
64 }
65 I18nContext.prototype.appendTag = function (type, node, index, closed) {
66 if (node.isVoid && closed) {
67 return; // ignore "close" for void tags
68 }
69 var ph = node.isVoid || !closed ? node.startName : node.closeName;
70 var content = { type: type, index: index, ctx: this.id, isVoid: node.isVoid, closed: closed };
71 util_1.updatePlaceholderMap(this.placeholders, ph, content);
72 };
73 Object.defineProperty(I18nContext.prototype, "icus", {
74 get: function () {
75 return this._registry.icus;
76 },
77 enumerable: false,
78 configurable: true
79 });
80 Object.defineProperty(I18nContext.prototype, "isRoot", {
81 get: function () {
82 return this.level === 0;
83 },
84 enumerable: false,
85 configurable: true
86 });
87 Object.defineProperty(I18nContext.prototype, "isResolved", {
88 get: function () {
89 return this._unresolvedCtxCount === 0;
90 },
91 enumerable: false,
92 configurable: true
93 });
94 I18nContext.prototype.getSerializedPlaceholders = function () {
95 var result = new Map();
96 this.placeholders.forEach(function (values, key) { return result.set(key, values.map(serializePlaceholderValue)); });
97 return result;
98 };
99 // public API to accumulate i18n-related content
100 I18nContext.prototype.appendBinding = function (binding) {
101 this.bindings.add(binding);
102 };
103 I18nContext.prototype.appendIcu = function (name, ref) {
104 util_1.updatePlaceholderMap(this._registry.icus, name, ref);
105 };
106 I18nContext.prototype.appendBoundText = function (node) {
107 var _this = this;
108 var phs = util_1.assembleBoundTextPlaceholders(node, this.bindings.size, this.id);
109 phs.forEach(function (values, key) { return util_1.updatePlaceholderMap.apply(void 0, tslib_1.__spreadArray([_this.placeholders, key], tslib_1.__read(values))); });
110 };
111 I18nContext.prototype.appendTemplate = function (node, index) {
112 // add open and close tags at the same time,
113 // since we process nested templates separately
114 this.appendTag(TagType.TEMPLATE, node, index, false);
115 this.appendTag(TagType.TEMPLATE, node, index, true);
116 this._unresolvedCtxCount++;
117 };
118 I18nContext.prototype.appendElement = function (node, index, closed) {
119 this.appendTag(TagType.ELEMENT, node, index, closed);
120 };
121 I18nContext.prototype.appendProjection = function (node, index) {
122 // Add open and close tags at the same time, since `<ng-content>` has no content,
123 // so when we come across `<ng-content>` we can register both open and close tags.
124 // Note: runtime i18n logic doesn't distinguish `<ng-content>` tag placeholders and
125 // regular element tag placeholders, so we generate element placeholders for both types.
126 this.appendTag(TagType.ELEMENT, node, index, false);
127 this.appendTag(TagType.ELEMENT, node, index, true);
128 };
129 /**
130 * Generates an instance of a child context based on the root one,
131 * when we enter a nested template within I18n section.
132 *
133 * @param index Instruction index of corresponding i18nStart, which initiates this context
134 * @param templateIndex Instruction index of a template which this context belongs to
135 * @param meta Meta information (id, meaning, description, etc) associated with this context
136 *
137 * @returns I18nContext instance
138 */
139 I18nContext.prototype.forkChildContext = function (index, templateIndex, meta) {
140 return new I18nContext(index, this.ref, this.level + 1, templateIndex, meta, this._registry);
141 };
142 /**
143 * Reconciles child context into parent one once the end of the i18n block is reached (i18nEnd).
144 *
145 * @param context Child I18nContext instance to be reconciled with parent context.
146 */
147 I18nContext.prototype.reconcileChildContext = function (context) {
148 var _this = this;
149 // set the right context id for open and close
150 // template tags, so we can use it as sub-block ids
151 ['start', 'close'].forEach(function (op) {
152 var key = context.meta[op + "Name"];
153 var phs = _this.placeholders.get(key) || [];
154 var tag = phs.find(findTemplateFn(_this.id, context.templateIndex));
155 if (tag) {
156 tag.ctx = context.id;
157 }
158 });
159 // reconcile placeholders
160 var childPhs = context.placeholders;
161 childPhs.forEach(function (values, key) {
162 var phs = _this.placeholders.get(key);
163 if (!phs) {
164 _this.placeholders.set(key, values);
165 return;
166 }
167 // try to find matching template...
168 var tmplIdx = phs.findIndex(findTemplateFn(context.id, context.templateIndex));
169 if (tmplIdx >= 0) {
170 // ... if found - replace it with nested template content
171 var isCloseTag = key.startsWith('CLOSE');
172 var isTemplateTag = key.endsWith('NG-TEMPLATE');
173 if (isTemplateTag) {
174 // current template's content is placed before or after
175 // parent template tag, depending on the open/close atrribute
176 phs.splice.apply(phs, tslib_1.__spreadArray([tmplIdx + (isCloseTag ? 0 : 1), 0], tslib_1.__read(values)));
177 }
178 else {
179 var idx = isCloseTag ? values.length - 1 : 0;
180 values[idx].tmpl = phs[tmplIdx];
181 phs.splice.apply(phs, tslib_1.__spreadArray([tmplIdx, 1], tslib_1.__read(values)));
182 }
183 }
184 else {
185 // ... otherwise just append content to placeholder value
186 phs.push.apply(phs, tslib_1.__spreadArray([], tslib_1.__read(values)));
187 }
188 _this.placeholders.set(key, phs);
189 });
190 this._unresolvedCtxCount--;
191 };
192 return I18nContext;
193 }());
194 exports.I18nContext = I18nContext;
195 //
196 // Helper methods
197 //
198 function wrap(symbol, index, contextId, closed) {
199 var state = closed ? '/' : '';
200 return util_1.wrapI18nPlaceholder("" + state + symbol + index, contextId);
201 }
202 function wrapTag(symbol, _a, closed) {
203 var index = _a.index, ctx = _a.ctx, isVoid = _a.isVoid;
204 return isVoid ? wrap(symbol, index, ctx) + wrap(symbol, index, ctx, true) :
205 wrap(symbol, index, ctx, closed);
206 }
207 function findTemplateFn(ctx, templateIndex) {
208 return function (token) { return typeof token === 'object' && token.type === TagType.TEMPLATE &&
209 token.index === templateIndex && token.ctx === ctx; };
210 }
211 function serializePlaceholderValue(value) {
212 var element = function (data, closed) { return wrapTag('#', data, closed); };
213 var template = function (data, closed) { return wrapTag('*', data, closed); };
214 var projection = function (data, closed) { return wrapTag('!', data, closed); };
215 switch (value.type) {
216 case TagType.ELEMENT:
217 // close element tag
218 if (value.closed) {
219 return element(value, true) + (value.tmpl ? template(value.tmpl, true) : '');
220 }
221 // open element tag that also initiates a template
222 if (value.tmpl) {
223 return template(value.tmpl) + element(value) +
224 (value.isVoid ? template(value.tmpl, true) : '');
225 }
226 return element(value);
227 case TagType.TEMPLATE:
228 return template(value, value.closed);
229 default:
230 return value;
231 }
232 }
233});
234//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/render3/view/i18n/context.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 {AST} from '../../../expression_parser/ast';\nimport * as i18n from '../../../i18n/i18n_ast';\nimport * as o from '../../../output/output_ast';\n\nimport {assembleBoundTextPlaceholders, getSeqNumberGenerator, updatePlaceholderMap, wrapI18nPlaceholder} from './util';\n\nenum TagType {\n  ELEMENT,\n  TEMPLATE,\n}\n\n/**\n * Generates an object that is used as a shared state between parent and all child contexts.\n */\nfunction setupRegistry() {\n  return {getUniqueId: getSeqNumberGenerator(), icus: new Map<string, any[]>()};\n}\n\n/**\n * I18nContext is a helper class which keeps track of all i18n-related aspects\n * (accumulates placeholders, bindings, etc) between i18nStart and i18nEnd instructions.\n *\n * When we enter a nested template, the top-level context is being passed down\n * to the nested component, which uses this context to generate a child instance\n * of I18nContext class (to handle nested template) and at the end, reconciles it back\n * with the parent context.\n *\n * @param index Instruction index of i18nStart, which initiates this context\n * @param ref Reference to a translation const that represents the content if thus context\n * @param level Nestng level defined for child contexts\n * @param templateIndex Instruction index of a template which this context belongs to\n * @param meta Meta information (id, meaning, description, etc) associated with this context\n */\nexport class I18nContext {\n  public readonly id: number;\n  public bindings = new Set<AST>();\n  public placeholders = new Map<string, any[]>();\n  public isEmitted: boolean = false;\n\n  private _registry!: any;\n  private _unresolvedCtxCount: number = 0;\n\n  constructor(\n      readonly index: number, readonly ref: o.ReadVarExpr, readonly level: number = 0,\n      readonly templateIndex: number|null = null, readonly meta: i18n.I18nMeta,\n      private registry?: any) {\n    this._registry = registry || setupRegistry();\n    this.id = this._registry.getUniqueId();\n  }\n\n  private appendTag(type: TagType, node: i18n.TagPlaceholder, index: number, closed?: boolean) {\n    if (node.isVoid && closed) {\n      return;  // ignore \"close\" for void tags\n    }\n    const ph = node.isVoid || !closed ? node.startName : node.closeName;\n    const content = {type, index, ctx: this.id, isVoid: node.isVoid, closed};\n    updatePlaceholderMap(this.placeholders, ph, content);\n  }\n\n  get icus() {\n    return this._registry.icus;\n  }\n  get isRoot() {\n    return this.level === 0;\n  }\n  get isResolved() {\n    return this._unresolvedCtxCount === 0;\n  }\n\n  getSerializedPlaceholders() {\n    const result = new Map<string, any[]>();\n    this.placeholders.forEach(\n        (values, key) => result.set(key, values.map(serializePlaceholderValue)));\n    return result;\n  }\n\n  // public API to accumulate i18n-related content\n  appendBinding(binding: AST) {\n    this.bindings.add(binding);\n  }\n  appendIcu(name: string, ref: o.Expression) {\n    updatePlaceholderMap(this._registry.icus, name, ref);\n  }\n  appendBoundText(node: i18n.I18nMeta) {\n    const phs = assembleBoundTextPlaceholders(node, this.bindings.size, this.id);\n    phs.forEach((values, key) => updatePlaceholderMap(this.placeholders, key, ...values));\n  }\n  appendTemplate(node: i18n.I18nMeta, index: number) {\n    // add open and close tags at the same time,\n    // since we process nested templates separately\n    this.appendTag(TagType.TEMPLATE, node as i18n.TagPlaceholder, index, false);\n    this.appendTag(TagType.TEMPLATE, node as i18n.TagPlaceholder, index, true);\n    this._unresolvedCtxCount++;\n  }\n  appendElement(node: i18n.I18nMeta, index: number, closed?: boolean) {\n    this.appendTag(TagType.ELEMENT, node as i18n.TagPlaceholder, index, closed);\n  }\n  appendProjection(node: i18n.I18nMeta, index: number) {\n    // Add open and close tags at the same time, since `<ng-content>` has no content,\n    // so when we come across `<ng-content>` we can register both open and close tags.\n    // Note: runtime i18n logic doesn't distinguish `<ng-content>` tag placeholders and\n    // regular element tag placeholders, so we generate element placeholders for both types.\n    this.appendTag(TagType.ELEMENT, node as i18n.TagPlaceholder, index, false);\n    this.appendTag(TagType.ELEMENT, node as i18n.TagPlaceholder, index, true);\n  }\n\n  /**\n   * Generates an instance of a child context based on the root one,\n   * when we enter a nested template within I18n section.\n   *\n   * @param index Instruction index of corresponding i18nStart, which initiates this context\n   * @param templateIndex Instruction index of a template which this context belongs to\n   * @param meta Meta information (id, meaning, description, etc) associated with this context\n   *\n   * @returns I18nContext instance\n   */\n  forkChildContext(index: number, templateIndex: number, meta: i18n.I18nMeta) {\n    return new I18nContext(index, this.ref, this.level + 1, templateIndex, meta, this._registry);\n  }\n\n  /**\n   * Reconciles child context into parent one once the end of the i18n block is reached (i18nEnd).\n   *\n   * @param context Child I18nContext instance to be reconciled with parent context.\n   */\n  reconcileChildContext(context: I18nContext) {\n    // set the right context id for open and close\n    // template tags, so we can use it as sub-block ids\n    ['start', 'close'].forEach((op: string) => {\n      const key = (context.meta as any)[`${op}Name`];\n      const phs = this.placeholders.get(key) || [];\n      const tag = phs.find(findTemplateFn(this.id, context.templateIndex));\n      if (tag) {\n        tag.ctx = context.id;\n      }\n    });\n\n    // reconcile placeholders\n    const childPhs = context.placeholders;\n    childPhs.forEach((values: any[], key: string) => {\n      const phs = this.placeholders.get(key);\n      if (!phs) {\n        this.placeholders.set(key, values);\n        return;\n      }\n      // try to find matching template...\n      const tmplIdx = phs.findIndex(findTemplateFn(context.id, context.templateIndex));\n      if (tmplIdx >= 0) {\n        // ... if found - replace it with nested template content\n        const isCloseTag = key.startsWith('CLOSE');\n        const isTemplateTag = key.endsWith('NG-TEMPLATE');\n        if (isTemplateTag) {\n          // current template's content is placed before or after\n          // parent template tag, depending on the open/close atrribute\n          phs.splice(tmplIdx + (isCloseTag ? 0 : 1), 0, ...values);\n        } else {\n          const idx = isCloseTag ? values.length - 1 : 0;\n          values[idx].tmpl = phs[tmplIdx];\n          phs.splice(tmplIdx, 1, ...values);\n        }\n      } else {\n        // ... otherwise just append content to placeholder value\n        phs.push(...values);\n      }\n      this.placeholders.set(key, phs);\n    });\n    this._unresolvedCtxCount--;\n  }\n}\n\n//\n// Helper methods\n//\n\nfunction wrap(symbol: string, index: number, contextId: number, closed?: boolean): string {\n  const state = closed ? '/' : '';\n  return wrapI18nPlaceholder(`${state}${symbol}${index}`, contextId);\n}\n\nfunction wrapTag(symbol: string, {index, ctx, isVoid}: any, closed?: boolean): string {\n  return isVoid ? wrap(symbol, index, ctx) + wrap(symbol, index, ctx, true) :\n                  wrap(symbol, index, ctx, closed);\n}\n\nfunction findTemplateFn(ctx: number, templateIndex: number|null) {\n  return (token: any) => typeof token === 'object' && token.type === TagType.TEMPLATE &&\n      token.index === templateIndex && token.ctx === ctx;\n}\n\nfunction serializePlaceholderValue(value: any): string {\n  const element = (data: any, closed?: boolean) => wrapTag('#', data, closed);\n  const template = (data: any, closed?: boolean) => wrapTag('*', data, closed);\n  const projection = (data: any, closed?: boolean) => wrapTag('!', data, closed);\n\n  switch (value.type) {\n    case TagType.ELEMENT:\n      // close element tag\n      if (value.closed) {\n        return element(value, true) + (value.tmpl ? template(value.tmpl, true) : '');\n      }\n      // open element tag that also initiates a template\n      if (value.tmpl) {\n        return template(value.tmpl) + element(value) +\n            (value.isVoid ? template(value.tmpl, true) : '');\n      }\n      return element(value);\n\n    case TagType.TEMPLATE:\n      return template(value, value.closed);\n\n    default:\n      return value;\n  }\n}\n"]}
Note: See TracBrowser for help on using the repository browser.