@decaf-ts/for-angular 0.0.16 → 0.0.18

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.
Files changed (65) hide show
  1. package/assets/i18n/en.json +9 -69
  2. package/assets/i18n/pt.json +80 -0
  3. package/assets/icons/icon-128.webp +0 -0
  4. package/assets/icons/icon-192.webp +0 -0
  5. package/assets/icons/icon-256.webp +0 -0
  6. package/assets/icons/icon-48.webp +0 -0
  7. package/assets/icons/icon-512.webp +0 -0
  8. package/assets/icons/icon-72.webp +0 -0
  9. package/assets/icons/icon-96.webp +0 -0
  10. package/assets/images/apple-touch-icon.png +0 -0
  11. package/assets/images/favicon.png +0 -0
  12. package/assets/images/favicon.svg +29 -0
  13. package/components/component-renderer/component-renderer.component.d.ts +5 -4
  14. package/components/crud-field/crud-field.component.d.ts +186 -22
  15. package/components/crud-form/crud-form.component.d.ts +194 -8
  16. package/components/empty-state/empty-state.component.d.ts +9 -10
  17. package/components/fieldset/fieldset.component.d.ts +383 -36
  18. package/components/filter/filter.component.d.ts +11 -2
  19. package/components/list/list.component.d.ts +1 -1
  20. package/components/list-item/list-item.component.d.ts +2 -2
  21. package/components/model-renderer/model-renderer.component.d.ts +1 -5
  22. package/directives/collapsable.directive.d.ts +1 -0
  23. package/engine/NgxBaseComponent.d.ts +43 -43
  24. package/engine/NgxCrudFormField.d.ts +7 -3
  25. package/engine/NgxFormService.d.ts +113 -12
  26. package/engine/NgxRenderingEngine.d.ts +178 -25
  27. package/engine/constants.d.ts +11 -6
  28. package/engine/decorators.d.ts +2 -2
  29. package/engine/index.d.ts +4 -2
  30. package/engine/interfaces.d.ts +271 -0
  31. package/engine/types.d.ts +11 -206
  32. package/esm2022/components/component-renderer/component-renderer.component.mjs +13 -11
  33. package/esm2022/components/crud-field/crud-field.component.mjs +213 -8
  34. package/esm2022/components/crud-form/crud-form.component.mjs +133 -13
  35. package/esm2022/components/empty-state/empty-state.component.mjs +13 -12
  36. package/esm2022/components/fieldset/fieldset.component.mjs +485 -43
  37. package/esm2022/components/filter/filter.component.mjs +16 -6
  38. package/esm2022/components/layout/layout.component.mjs +3 -3
  39. package/esm2022/components/list/list.component.mjs +4 -5
  40. package/esm2022/components/list-item/list-item.component.mjs +10 -10
  41. package/esm2022/components/model-renderer/model-renderer.component.mjs +9 -8
  42. package/esm2022/components/pagination/pagination.component.mjs +7 -7
  43. package/esm2022/components/searchbar/searchbar.component.mjs +3 -3
  44. package/esm2022/directives/collapsable.directive.mjs +3 -2
  45. package/esm2022/engine/NgxBaseComponent.mjs +64 -63
  46. package/esm2022/engine/NgxCrudFormField.mjs +14 -4
  47. package/esm2022/engine/NgxFormService.mjs +239 -27
  48. package/esm2022/engine/NgxRenderingEngine.mjs +218 -46
  49. package/esm2022/engine/ValidatorFactory.mjs +6 -4
  50. package/esm2022/engine/constants.mjs +14 -9
  51. package/esm2022/engine/decorators.mjs +6 -6
  52. package/esm2022/engine/index.mjs +5 -3
  53. package/esm2022/engine/interfaces.mjs +4 -0
  54. package/esm2022/engine/types.mjs +1 -3
  55. package/esm2022/helpers/utils.mjs +53 -32
  56. package/esm2022/i18n/Loader.mjs +82 -0
  57. package/fesm2022/decaf-ts-for-angular.mjs +3030 -2097
  58. package/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
  59. package/helpers/utils.d.ts +42 -16
  60. package/i18n/Loader.d.ts +48 -0
  61. package/package.json +11 -1
  62. package/engine/NgxRenderingEngine2.d.ts +0 -250
  63. package/esm2022/engine/NgxRenderingEngine2.mjs +0 -332
  64. package/esm2022/interfaces.mjs +0 -2
  65. package/interfaces.d.ts +0 -28
@@ -1,332 +0,0 @@
1
- import { RenderingEngine } from '@decaf-ts/ui-decorators';
2
- import { AngularEngineKeys } from './constants';
3
- import { InternalError } from '@decaf-ts/db-decorators';
4
- import { reflectComponentType, } from '@angular/core';
5
- import { NgxFormService } from './NgxFormService';
6
- /**
7
- * @description Angular implementation of the RenderingEngine with enhanced features
8
- * @summary This class extends the base RenderingEngine to provide Angular-specific rendering capabilities
9
- * with additional features compared to NgxRenderingEngine. It handles the conversion of field definitions
10
- * to Angular components, manages component registration, and provides utilities for component creation
11
- * and input handling. This implementation uses Angular's newer component APIs.
12
- *
13
- * @template AngularFieldDefinition - Type for Angular-specific field definitions
14
- * @template AngularDynamicOutput - Type for Angular-specific component output
15
- *
16
- * @class NgxRenderingEngine2
17
- * @example
18
- * ```typescript
19
- * const engine = NgxRenderingEngine2.get();
20
- * engine.initialize();
21
- * const output = engine.render(myModel, {}, viewContainerRef, injector, templateRef);
22
- * ```
23
- *
24
- * @mermaid
25
- * sequenceDiagram
26
- * participant Client
27
- * participant Engine as NgxRenderingEngine2
28
- * participant Components as RegisteredComponents
29
- *
30
- * Client->>Engine: get()
31
- * Client->>Engine: initialize()
32
- * Client->>Engine: render(model, props, vcr, injector, tpl)
33
- * Engine->>Engine: toFieldDefinition(model, props)
34
- * Engine->>Engine: fromFieldDefinition(fieldDef, vcr, injector, tpl)
35
- * Engine->>Components: components(fieldDef.tag)
36
- * Components-->>Engine: component constructor
37
- * Engine->>Engine: createComponent(component, inputs, metadata, vcr, injector, template)
38
- * Engine-->>Client: return AngularDynamicOutput
39
- */
40
- export class NgxRenderingEngine2 extends RenderingEngine {
41
- /**
42
- * @description Creates a new instance of NgxRenderingEngine2
43
- * @summary Initializes the rendering engine with the 'angular' engine type.
44
- * This constructor sets up the base configuration needed for Angular-specific rendering.
45
- */
46
- constructor() {
47
- super('angular');
48
- }
49
- /**
50
- * @description Converts a field definition to an Angular component output
51
- * @summary This private method takes a field definition and creates the corresponding Angular component.
52
- * It handles component instantiation, input property mapping, and child component rendering.
53
- * The method validates input properties against the component's metadata and processes
54
- * child components recursively.
55
- *
56
- * @param {FieldDefinition<AngularFieldDefinition>} fieldDef - The field definition to convert
57
- * @param {ViewContainerRef} vcr - The view container reference for component creation
58
- * @param {Injector} injector - The Angular injector for dependency injection
59
- * @param {TemplateRef<any>} tpl - The template reference for content projection
60
- * @param {string} registryFormId - Form identifier for the component renderer
61
- * @return {AngularDynamicOutput} The Angular component output with component reference and inputs
62
- *
63
- * @mermaid
64
- * sequenceDiagram
65
- * participant Method as fromFieldDefinition
66
- * participant Components as NgxRenderingEngine2.components
67
- * participant Angular as Angular Core
68
- * participant Process as processChild
69
- *
70
- * Method->>Components: components(fieldDef.tag)
71
- * Components-->>Method: component constructor
72
- * Method->>Angular: reflectComponentType(component)
73
- * Angular-->>Method: componentMetadata
74
- * Method->>Method: Validate input properties
75
- * Method->>Method: Create result object
76
- * alt Has children
77
- * Method->>Process: Process children recursively
78
- * Process->>Method: Return processed children
79
- * Method->>Angular: Create embedded view
80
- * Method->>Method: Create component instance
81
- * end
82
- * Method-->>Caller: return AngularDynamicOutput
83
- */
84
- fromFieldDefinition(fieldDef, vcr, injector, tpl, registryFormId = Date.now().toString(36).toUpperCase()) {
85
- const cmp = fieldDef?.['component'] || NgxRenderingEngine2.components(fieldDef.tag);
86
- const component = cmp.constructor;
87
- const componentMetadata = reflectComponentType(component);
88
- if (!componentMetadata) {
89
- throw new InternalError(`Metadata for component ${fieldDef.tag} not found.`);
90
- }
91
- const { inputs: possibleInputs } = componentMetadata;
92
- const inputs = { ...fieldDef.props };
93
- const unmappedKeys = Object.keys(inputs).filter(input => {
94
- const isMapped = possibleInputs.find(({ propName }) => propName === input);
95
- if (!isMapped)
96
- delete inputs[input];
97
- return !isMapped;
98
- });
99
- if (unmappedKeys.length > 0)
100
- console.warn(`Unmapped input properties for component ${fieldDef.tag}: ${unmappedKeys.join(', ')}`);
101
- const result = {
102
- component,
103
- inputs,
104
- injector,
105
- };
106
- if (fieldDef.rendererId)
107
- result.inputs['rendererId'] = fieldDef.rendererId;
108
- // process children
109
- if (fieldDef.children?.length) {
110
- result.children = fieldDef.children.map((child) => {
111
- // create a child form and add its controls as properties of child.props
112
- NgxFormService.addControlFromProps(registryFormId, child.props);
113
- return this.fromFieldDefinition(child, vcr, injector, tpl, registryFormId);
114
- });
115
- }
116
- // generating DOM
117
- vcr.clear();
118
- const template = vcr.createEmbeddedView(tpl, injector).rootNodes;
119
- const componentInstance = NgxRenderingEngine2.createComponent(component, { ...inputs, model: this._model }, componentMetadata, vcr, injector, template);
120
- result.instance = NgxRenderingEngine2._instance = componentInstance.instance;
121
- return result;
122
- }
123
- /**
124
- * @description Creates an Angular component instance
125
- * @summary This static utility method creates an Angular component instance with the specified
126
- * inputs and template. It uses Angular's component creation API to instantiate the component
127
- * and then sets the input properties using the provided metadata.
128
- *
129
- * @param {Type<unknown>} component - The component type to create
130
- * @param {KeyValue} [inputs={}] - The input properties to set on the component
131
- * @param {ComponentMirror<unknown>} metadata - The component metadata for input validation
132
- * @param {ViewContainerRef} vcr - The view container reference for component creation
133
- * @param {Injector} injector - The Angular injector for dependency injection
134
- * @param {Node[]} [template=[]] - The template nodes to project into the component
135
- * @return {ComponentRef<unknown>} The created component reference
136
- */
137
- static createComponent(component, inputs = {}, metadata, vcr, injector, template = []) {
138
- const componentInstance = vcr.createComponent(component, {
139
- environmentInjector: injector,
140
- projectableNodes: [template],
141
- });
142
- this.setInputs(componentInstance, inputs, metadata);
143
- return componentInstance;
144
- }
145
- /**
146
- * @description Extracts decorator metadata from a model
147
- * @summary This method provides access to the field definition generated from a model's
148
- * decorators. It's a convenience wrapper around the toFieldDefinition method that
149
- * converts a model to a field definition based on its decorators and the provided
150
- * global properties.
151
- *
152
- * @param {Model} model - The model to extract decorators from
153
- * @param {Record<string, unknown>} globalProps - Global properties to include in the field definition
154
- * @return {FieldDefinition<AngularFieldDefinition>} The field definition generated from the model
155
- */
156
- getDecorators(model, globalProps) {
157
- return this.toFieldDefinition(model, globalProps);
158
- }
159
- /**
160
- * @description Destroys the current engine instance
161
- * @summary This static method clears the current instance reference, effectively
162
- * destroying the singleton instance of the rendering engine. This can be used
163
- * to reset the engine state or to prepare for a new instance creation.
164
- *
165
- * @return {Promise<void>} A promise that resolves when the instance is destroyed
166
- */
167
- static async destroy() {
168
- NgxRenderingEngine2._instance = undefined;
169
- }
170
- /**
171
- * @description Renders a model into an Angular component output
172
- * @summary This method takes a model and converts it to an Angular component output.
173
- * It first stores a reference to the model, then converts it to a field definition
174
- * using the base RenderingEngine's toFieldDefinition method, and finally converts
175
- * that field definition to an Angular component output using fromFieldDefinition.
176
- *
177
- * @template M - Type extending Model
178
- * @param {M} model - The model to render
179
- * @param {Record<string, unknown>} globalProps - Global properties to pass to the component
180
- * @param {ViewContainerRef} vcr - The view container reference for component creation
181
- * @param {Injector} injector - The Angular injector for dependency injection
182
- * @param {TemplateRef<any>} tpl - The template reference for content projection
183
- * @return {AngularDynamicOutput} The Angular component output with component reference and inputs
184
- *
185
- * @mermaid
186
- * sequenceDiagram
187
- * participant Client as Client Code
188
- * participant Render as render method
189
- * participant ToField as toFieldDefinition
190
- * participant FromField as fromFieldDefinition
191
- *
192
- * Client->>Render: render(model, globalProps, vcr, injector, tpl)
193
- * Render->>Render: Store model reference
194
- * Render->>ToField: toFieldDefinition(model, globalProps)
195
- * ToField-->>Render: fieldDef
196
- * Render->>FromField: fromFieldDefinition(fieldDef, vcr, injector, tpl)
197
- * FromField-->>Render: AngularDynamicOutput
198
- * Render-->>Client: return AngularDynamicOutput
199
- */
200
- render(model, globalProps, vcr, injector, tpl) {
201
- let result;
202
- try {
203
- this._model = model;
204
- const formId = Date.now().toString(36).toUpperCase();
205
- const fieldDef = this.toFieldDefinition(model, globalProps);
206
- result = this.fromFieldDefinition(fieldDef, vcr, injector, tpl, formId);
207
- result.instance['formGroup'] = NgxFormService.getControlFromForm(formId);
208
- NgxFormService.removeRegistry(formId);
209
- }
210
- catch (e) {
211
- throw new InternalError(`Failed to render Model ${model.constructor.name}: ${e}`);
212
- }
213
- return result;
214
- }
215
- /**
216
- * @description Initializes the rendering engine
217
- * @summary This method initializes the rendering engine. It checks if the engine is already initialized
218
- * and sets the initialized flag to true. This method is called before the engine is used
219
- * to ensure it's properly set up for rendering operations.
220
- *
221
- * @return {Promise<void>} A promise that resolves when initialization is complete
222
- */
223
- async initialize() {
224
- if (this.initialized)
225
- return;
226
- // ValidatableByType[]
227
- this.initialized = true;
228
- }
229
- /**
230
- * @description Registers a component with the rendering engine
231
- * @summary This static method registers a component constructor with the rendering engine
232
- * under a specific name. It initializes the components registry if needed and throws
233
- * an error if a component is already registered under the same name to prevent
234
- * accidental overrides.
235
- *
236
- * @param {string} name - The name to register the component under
237
- * @param {Constructor<unknown>} constructor - The component constructor
238
- * @return {void}
239
- */
240
- static registerComponent(name, constructor) {
241
- if (!this._components)
242
- this._components = {};
243
- if (name in this._components)
244
- throw new InternalError(`Component already registered under ${name}`);
245
- this._components[name] = {
246
- constructor: constructor,
247
- };
248
- }
249
- /**
250
- * @description Retrieves registered components from the rendering engine
251
- * @summary This static method retrieves either all registered components or a specific component
252
- * by its selector. When called without a selector, it returns an array of all registered
253
- * components. When called with a selector, it returns the specific component if found,
254
- * or throws an error if the component is not registered.
255
- *
256
- * @param {string} [selector] - Optional selector to retrieve a specific component
257
- * @return {Object|Array} Either a specific component or an array of all components
258
- */
259
- static components(selector) {
260
- if (!selector)
261
- return Object.values(this._components);
262
- if (!(selector in this._components))
263
- throw new InternalError(`No Component registered under ${selector}`);
264
- return this._components[selector];
265
- }
266
- /**
267
- * @description Generates a key for reflection metadata
268
- * @summary This static method generates a key for reflection metadata by prefixing the input key
269
- * with the Angular engine's reflection prefix. This is used for storing and retrieving
270
- * metadata in a namespaced way to avoid conflicts with other metadata.
271
- *
272
- * @param {string} key - The base key to prefix
273
- * @return {string} The prefixed key for reflection metadata
274
- */
275
- static key(key) {
276
- return `${AngularEngineKeys.REFLECT}${key}`;
277
- }
278
- /**
279
- * @description Sets input properties on a component instance
280
- * @summary This static utility method sets input properties on a component instance
281
- * based on the provided inputs object and component metadata. It handles both simple
282
- * values and nested objects, recursively processing object properties. The method
283
- * validates each input against the component's metadata to ensure only valid inputs
284
- * are set.
285
- *
286
- * @param {ComponentRef<unknown>} component - The component reference to set inputs on
287
- * @param {KeyValue} inputs - The input properties to set
288
- * @param {ComponentMirror<unknown>} metadata - The component metadata for input validation
289
- * @return {void}
290
- *
291
- * @mermaid
292
- * sequenceDiagram
293
- * participant Caller
294
- * participant SetInputs as setInputs
295
- * participant Parse as parseInputValue
296
- * participant Component as ComponentRef
297
- *
298
- * Caller->>SetInputs: setInputs(component, inputs, metadata)
299
- * SetInputs->>SetInputs: Iterate through inputs
300
- * loop For each input
301
- * SetInputs->>SetInputs: Check if input exists in metadata
302
- * alt Input is 'props'
303
- * SetInputs->>Parse: parseInputValue(component, value)
304
- * Parse->>Parse: Recursively process nested objects
305
- * Parse->>Component: setInput(key, value)
306
- * else Input is valid
307
- * SetInputs->>Component: setInput(key, value)
308
- * end
309
- * end
310
- */
311
- static setInputs(component, inputs, metadata) {
312
- function parseInputValue(component, input) {
313
- Object.keys(input).forEach(key => {
314
- const value = input[key];
315
- if (typeof value === 'object' && !!value)
316
- return parseInputValue(component, value);
317
- component.setInput(key, value);
318
- });
319
- }
320
- Object.entries(inputs).forEach(([key, value]) => {
321
- const prop = metadata.inputs.find((item) => item.propName === key);
322
- if (prop) {
323
- if (key === 'props')
324
- parseInputValue(component, value);
325
- // if(key === 'locale' && !value)
326
- // value = getLocaleFromClassName(this._componentName);
327
- component.setInput(key, value);
328
- }
329
- });
330
- }
331
- }
332
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTmd4UmVuZGVyaW5nRW5naW5lMi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvZW5naW5lL05neFJlbmRlcmluZ0VuZ2luZTIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFtQixlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUUzRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3hELE9BQU8sRUFLTCxvQkFBb0IsR0FJckIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRWxEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQ0c7QUFDSCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsZUFBNkQ7SUErQnBHOzs7O09BSUc7SUFDSDtRQUNFLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7T0FrQ0c7SUFDSyxtQkFBbUIsQ0FDekIsUUFBaUQsRUFDakQsR0FBcUIsRUFDckIsUUFBa0IsRUFDbEIsR0FBeUIsRUFDekIsaUJBQXlCLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsV0FBVyxFQUFFO1FBRTlELE1BQU0sR0FBRyxHQUFJLFFBQXFCLEVBQUUsQ0FBQyxXQUFXLENBQUMsSUFBSSxtQkFBbUIsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2xHLE1BQU0sU0FBUyxHQUFHLEdBQUcsQ0FBQyxXQUF1QyxDQUFDO1FBRTlELE1BQU0saUJBQWlCLEdBQUcsb0JBQW9CLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDMUQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDdkIsTUFBTSxJQUFJLGFBQWEsQ0FBQywwQkFBMEIsUUFBUSxDQUFDLEdBQUcsYUFBYSxDQUFDLENBQUM7UUFDL0UsQ0FBQztRQUVELE1BQU0sRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLEdBQUcsaUJBQWlCLENBQUM7UUFDckQsTUFBTSxNQUFNLEdBQUcsRUFBRSxHQUFHLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUVyQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN0RCxNQUFNLFFBQVEsR0FBRyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLENBQUMsUUFBUSxLQUFLLEtBQUssQ0FBQyxDQUFDO1lBQzNFLElBQUksQ0FBQyxRQUFRO2dCQUFFLE9BQU8sTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3BDLE9BQU8sQ0FBQyxRQUFRLENBQUM7UUFDbkIsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLFlBQVksQ0FBQyxNQUFNLEdBQUcsQ0FBQztZQUN6QixPQUFPLENBQUMsSUFBSSxDQUFDLDJDQUEyQyxRQUFRLENBQUMsR0FBRyxLQUFLLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRXRHLE1BQU0sTUFBTSxHQUF5QjtZQUNuQyxTQUFTO1lBQ1QsTUFBTTtZQUNOLFFBQVE7U0FDVCxDQUFDO1FBRUYsSUFBSSxRQUFRLENBQUMsVUFBVTtZQUNwQixNQUFNLENBQUMsTUFBa0MsQ0FBQyxZQUFZLENBQUMsR0FBRyxRQUFRLENBQUMsVUFBVSxDQUFDO1FBRWpGLG1CQUFtQjtRQUNuQixJQUFJLFFBQVEsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDOUIsTUFBTSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO2dCQUNoRCx3RUFBd0U7Z0JBQ3hFLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxjQUFjLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO2dCQUNoRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxHQUFHLEVBQUUsY0FBYyxDQUFDLENBQUM7WUFDN0UsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBRUQsaUJBQWlCO1FBQ2pCLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNaLE1BQU0sUUFBUSxHQUFHLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLENBQUMsU0FBUyxDQUFDO1FBQ2pFLE1BQU0saUJBQWlCLEdBQUcsbUJBQW1CLENBQUMsZUFBZSxDQUMzRCxTQUFTLEVBQ1QsRUFBRSxHQUFHLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUNqQyxpQkFBaUIsRUFDakIsR0FBRyxFQUNILFFBQVEsRUFDUixRQUFRLENBQ1QsQ0FBQztRQUVGLE1BQU0sQ0FBQyxRQUFRLEdBQUcsbUJBQW1CLENBQUMsU0FBUyxHQUFHLGlCQUFpQixDQUFDLFFBQXlCLENBQUM7UUFFOUYsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUdEOzs7Ozs7Ozs7Ozs7O09BYUc7SUFDSCxNQUFNLENBQUMsZUFBZSxDQUFDLFNBQXdCLEVBQUUsU0FBbUIsRUFBRSxFQUFFLFFBQWtDLEVBQUUsR0FBcUIsRUFBRSxRQUFrQixFQUFFLFdBQW1CLEVBQUU7UUFDMUssTUFBTSxpQkFBaUIsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDLFNBQTBCLEVBQUU7WUFDeEUsbUJBQW1CLEVBQUUsUUFBK0I7WUFDcEQsZ0JBQWdCLEVBQUUsQ0FBQyxRQUFRLENBQUM7U0FDN0IsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFDcEQsT0FBTyxpQkFBaUIsQ0FBQztJQUMzQixDQUFDO0lBRUQ7Ozs7Ozs7Ozs7T0FVRztJQUNILGFBQWEsQ0FBQyxLQUFZLEVBQUUsV0FBb0M7UUFDOUQsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3BELENBQUM7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPO1FBQ2xCLG1CQUFtQixDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDNUMsQ0FBQztJQUdEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQTZCRztJQUNNLE1BQU0sQ0FDYixLQUFRLEVBQ1IsV0FBb0MsRUFDcEMsR0FBcUIsRUFDckIsUUFBa0IsRUFDbEIsR0FBeUI7UUFFekIsSUFBSSxNQUE0QixDQUFDO1FBQ2pDLElBQUksQ0FBQztZQUNILElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1lBQ3BCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztZQUM1RCxNQUFNLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztZQUV2RSxNQUFPLENBQUMsUUFBc0IsQ0FBQyxXQUFXLENBQUMsR0FBRyxjQUFjLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDekYsY0FBYyxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUN4QyxDQUFDO1FBQUMsT0FBTyxDQUFVLEVBQUUsQ0FBQztZQUNwQixNQUFNLElBQUksYUFBYSxDQUNyQiwwQkFBMEIsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQ3pELENBQUM7UUFDSixDQUFDO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDTSxLQUFLLENBQUMsVUFBVTtRQUN2QixJQUFJLElBQUksQ0FBQyxXQUFXO1lBQ2xCLE9BQU87UUFDVCxzQkFBc0I7UUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDMUIsQ0FBQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSCxNQUFNLENBQUMsaUJBQWlCLENBQUMsSUFBWSxFQUFFLFdBQWlDO1FBQ3RFLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVztZQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBQzdDLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxXQUFXO1lBQzFCLE1BQU0sSUFBSSxhQUFhLENBQUMsc0NBQXNDLElBQUksRUFBRSxDQUFDLENBQUM7UUFDeEUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRztZQUN2QixXQUFXLEVBQUUsV0FBVztTQUN6QixDQUFDO0lBQ0osQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILE1BQU0sQ0FBQyxVQUFVLENBQUMsUUFBaUI7UUFDakMsSUFBSSxDQUFDLFFBQVE7WUFBRSxPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQ2pDLE1BQU0sSUFBSSxhQUFhLENBQUMsaUNBQWlDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDdkUsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7Ozs7Ozs7T0FRRztJQUNILE1BQU0sQ0FBVSxHQUFHLENBQUMsR0FBVztRQUM3QixPQUFPLEdBQUcsaUJBQWlCLENBQUMsT0FBTyxHQUFHLEdBQUcsRUFBRSxDQUFDO0lBQzlDLENBQUM7SUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7T0FnQ0c7SUFDSCxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQWdDLEVBQUUsTUFBZ0IsRUFBRSxRQUFrQztRQUNyRyxTQUFTLGVBQWUsQ0FBQyxTQUFnQyxFQUFFLEtBQWU7WUFDeEUsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQy9CLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDekIsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksQ0FBQyxDQUFDLEtBQUs7b0JBQ3RDLE9BQU8sZUFBZSxDQUFDLFNBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQztnQkFDM0MsU0FBUyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDakMsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBRUQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQzlDLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBMEIsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsS0FBSyxHQUFHLENBQUMsQ0FBQztZQUN6RixJQUFJLElBQUksRUFBRSxDQUFDO2dCQUNULElBQUksR0FBRyxLQUFLLE9BQU87b0JBQ2pCLGVBQWUsQ0FBQyxTQUFTLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQ3BDLGlDQUFpQztnQkFDakMseURBQXlEO2dCQUN6RCxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUNqQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWVsZERlZmluaXRpb24sIFJlbmRlcmluZ0VuZ2luZSB9IGZyb20gJ0BkZWNhZi10cy91aS1kZWNvcmF0b3JzJztcbmltcG9ydCB7IEFuZ3VsYXJEeW5hbWljT3V0cHV0LCBBbmd1bGFyRmllbGREZWZpbml0aW9uLCBLZXlWYWx1ZSB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgQW5ndWxhckVuZ2luZUtleXMgfSBmcm9tICcuL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3RvciwgTW9kZWwgfSBmcm9tICdAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb24nO1xuaW1wb3J0IHsgSW50ZXJuYWxFcnJvciB9IGZyb20gJ0BkZWNhZi10cy9kYi1kZWNvcmF0b3JzJztcbmltcG9ydCB7XG4gIENvbXBvbmVudE1pcnJvcixcbiAgQ29tcG9uZW50UmVmLFxuICBFbnZpcm9ubWVudEluamVjdG9yLFxuICBJbmplY3RvcixcbiAgcmVmbGVjdENvbXBvbmVudFR5cGUsXG4gIFRlbXBsYXRlUmVmLFxuICBUeXBlLFxuICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5neEZvcm1TZXJ2aWNlIH0gZnJvbSAnLi9OZ3hGb3JtU2VydmljZSc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEFuZ3VsYXIgaW1wbGVtZW50YXRpb24gb2YgdGhlIFJlbmRlcmluZ0VuZ2luZSB3aXRoIGVuaGFuY2VkIGZlYXR1cmVzXG4gKiBAc3VtbWFyeSBUaGlzIGNsYXNzIGV4dGVuZHMgdGhlIGJhc2UgUmVuZGVyaW5nRW5naW5lIHRvIHByb3ZpZGUgQW5ndWxhci1zcGVjaWZpYyByZW5kZXJpbmcgY2FwYWJpbGl0aWVzXG4gKiB3aXRoIGFkZGl0aW9uYWwgZmVhdHVyZXMgY29tcGFyZWQgdG8gTmd4UmVuZGVyaW5nRW5naW5lLiBJdCBoYW5kbGVzIHRoZSBjb252ZXJzaW9uIG9mIGZpZWxkIGRlZmluaXRpb25zXG4gKiB0byBBbmd1bGFyIGNvbXBvbmVudHMsIG1hbmFnZXMgY29tcG9uZW50IHJlZ2lzdHJhdGlvbiwgYW5kIHByb3ZpZGVzIHV0aWxpdGllcyBmb3IgY29tcG9uZW50IGNyZWF0aW9uXG4gKiBhbmQgaW5wdXQgaGFuZGxpbmcuIFRoaXMgaW1wbGVtZW50YXRpb24gdXNlcyBBbmd1bGFyJ3MgbmV3ZXIgY29tcG9uZW50IEFQSXMuXG4gKlxuICogQHRlbXBsYXRlIEFuZ3VsYXJGaWVsZERlZmluaXRpb24gLSBUeXBlIGZvciBBbmd1bGFyLXNwZWNpZmljIGZpZWxkIGRlZmluaXRpb25zXG4gKiBAdGVtcGxhdGUgQW5ndWxhckR5bmFtaWNPdXRwdXQgLSBUeXBlIGZvciBBbmd1bGFyLXNwZWNpZmljIGNvbXBvbmVudCBvdXRwdXRcbiAqXG4gKiBAY2xhc3MgTmd4UmVuZGVyaW5nRW5naW5lMlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGNvbnN0IGVuZ2luZSA9IE5neFJlbmRlcmluZ0VuZ2luZTIuZ2V0KCk7XG4gKiBlbmdpbmUuaW5pdGlhbGl6ZSgpO1xuICogY29uc3Qgb3V0cHV0ID0gZW5naW5lLnJlbmRlcihteU1vZGVsLCB7fSwgdmlld0NvbnRhaW5lclJlZiwgaW5qZWN0b3IsIHRlbXBsYXRlUmVmKTtcbiAqIGBgYFxuICpcbiAqIEBtZXJtYWlkXG4gKiBzZXF1ZW5jZURpYWdyYW1cbiAqICAgcGFydGljaXBhbnQgQ2xpZW50XG4gKiAgIHBhcnRpY2lwYW50IEVuZ2luZSBhcyBOZ3hSZW5kZXJpbmdFbmdpbmUyXG4gKiAgIHBhcnRpY2lwYW50IENvbXBvbmVudHMgYXMgUmVnaXN0ZXJlZENvbXBvbmVudHNcbiAqXG4gKiAgIENsaWVudC0+PkVuZ2luZTogZ2V0KClcbiAqICAgQ2xpZW50LT4+RW5naW5lOiBpbml0aWFsaXplKClcbiAqICAgQ2xpZW50LT4+RW5naW5lOiByZW5kZXIobW9kZWwsIHByb3BzLCB2Y3IsIGluamVjdG9yLCB0cGwpXG4gKiAgIEVuZ2luZS0+PkVuZ2luZTogdG9GaWVsZERlZmluaXRpb24obW9kZWwsIHByb3BzKVxuICogICBFbmdpbmUtPj5FbmdpbmU6IGZyb21GaWVsZERlZmluaXRpb24oZmllbGREZWYsIHZjciwgaW5qZWN0b3IsIHRwbClcbiAqICAgRW5naW5lLT4+Q29tcG9uZW50czogY29tcG9uZW50cyhmaWVsZERlZi50YWcpXG4gKiAgIENvbXBvbmVudHMtLT4+RW5naW5lOiBjb21wb25lbnQgY29uc3RydWN0b3JcbiAqICAgRW5naW5lLT4+RW5naW5lOiBjcmVhdGVDb21wb25lbnQoY29tcG9uZW50LCBpbnB1dHMsIG1ldGFkYXRhLCB2Y3IsIGluamVjdG9yLCB0ZW1wbGF0ZSlcbiAqICAgRW5naW5lLS0+PkNsaWVudDogcmV0dXJuIEFuZ3VsYXJEeW5hbWljT3V0cHV0XG4gKi9cbmV4cG9ydCBjbGFzcyBOZ3hSZW5kZXJpbmdFbmdpbmUyIGV4dGVuZHMgUmVuZGVyaW5nRW5naW5lPEFuZ3VsYXJGaWVsZERlZmluaXRpb24sIEFuZ3VsYXJEeW5hbWljT3V0cHV0PiB7XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZWdpc3RyeSBvZiByZWdpc3RlcmVkIGNvbXBvbmVudHNcbiAgICogQHN1bW1hcnkgU3RhdGljIHJlZ2lzdHJ5IHRoYXQgbWFwcyBjb21wb25lbnQgbmFtZXMgdG8gdGhlaXIgY29uc3RydWN0b3JzLlxuICAgKiBUaGlzIGFsbG93cyB0aGUgZW5naW5lIHRvIGxvb2sgdXAgY29tcG9uZW50cyBieSBuYW1lIHdoZW4gcmVuZGVyaW5nLlxuICAgKiBAdHlwZSB7UmVjb3JkPHN0cmluZywgeyBjb25zdHJ1Y3RvcjogQ29uc3RydWN0b3I8dW5rbm93bj4gfT59XG4gICAqL1xuICBwcml2YXRlIHN0YXRpYyBfY29tcG9uZW50czogUmVjb3JkPHN0cmluZywgeyBjb25zdHJ1Y3RvcjogQ29uc3RydWN0b3I8dW5rbm93bj4gfT47XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBDb2xsZWN0aW9uIG9mIGNoaWxkIGNvbXBvbmVudCBvdXRwdXRzXG4gICAqIEBzdW1tYXJ5IFN0b3JlcyB0aGUgb3V0cHV0cyBvZiBjaGlsZCBjb21wb25lbnRzIGR1cmluZyByZW5kZXJpbmcuXG4gICAqIEB0eXBlIHtBbmd1bGFyRHluYW1pY091dHB1dFtdfVxuICAgKi9cbiAgcHJpdmF0ZSBfY2hpbGRzITogQW5ndWxhckR5bmFtaWNPdXRwdXRbXTtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgbW9kZWwgYmVpbmcgcmVuZGVyZWRcbiAgICogQHN1bW1hcnkgUmVmZXJlbmNlIHRvIHRoZSBtb2RlbCBjdXJyZW50bHkgYmVpbmcgcHJvY2Vzc2VkIGJ5IHRoZSByZW5kZXJpbmcgZW5naW5lLlxuICAgKiBAdHlwZSB7TW9kZWx9XG4gICAqL1xuICBwcml2YXRlIF9tb2RlbCE6IE1vZGVsO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gU3RhdGljIHJlZmVyZW5jZSB0byB0aGUgY3VycmVudCBpbnN0YW5jZVxuICAgKiBAc3VtbWFyeSBTaW5nbGV0b24gaW5zdGFuY2UgcmVmZXJlbmNlIGZvciB0aGUgcmVuZGVyaW5nIGVuZ2luZS5cbiAgICogQHR5cGUge1R5cGU8dW5rbm93bj4gfCB1bmRlZmluZWR9XG4gICAqL1xuICBwcml2YXRlIHN0YXRpYyBfaW5zdGFuY2U6IFR5cGU8dW5rbm93bj4gfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBDcmVhdGVzIGEgbmV3IGluc3RhbmNlIG9mIE5neFJlbmRlcmluZ0VuZ2luZTJcbiAgICogQHN1bW1hcnkgSW5pdGlhbGl6ZXMgdGhlIHJlbmRlcmluZyBlbmdpbmUgd2l0aCB0aGUgJ2FuZ3VsYXInIGVuZ2luZSB0eXBlLlxuICAgKiBUaGlzIGNvbnN0cnVjdG9yIHNldHMgdXAgdGhlIGJhc2UgY29uZmlndXJhdGlvbiBuZWVkZWQgZm9yIEFuZ3VsYXItc3BlY2lmaWMgcmVuZGVyaW5nLlxuICAgKi9cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ2FuZ3VsYXInKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQ29udmVydHMgYSBmaWVsZCBkZWZpbml0aW9uIHRvIGFuIEFuZ3VsYXIgY29tcG9uZW50IG91dHB1dFxuICAgKiBAc3VtbWFyeSBUaGlzIHByaXZhdGUgbWV0aG9kIHRha2VzIGEgZmllbGQgZGVmaW5pdGlvbiBhbmQgY3JlYXRlcyB0aGUgY29ycmVzcG9uZGluZyBBbmd1bGFyIGNvbXBvbmVudC5cbiAgICogSXQgaGFuZGxlcyBjb21wb25lbnQgaW5zdGFudGlhdGlvbiwgaW5wdXQgcHJvcGVydHkgbWFwcGluZywgYW5kIGNoaWxkIGNvbXBvbmVudCByZW5kZXJpbmcuXG4gICAqIFRoZSBtZXRob2QgdmFsaWRhdGVzIGlucHV0IHByb3BlcnRpZXMgYWdhaW5zdCB0aGUgY29tcG9uZW50J3MgbWV0YWRhdGEgYW5kIHByb2Nlc3Nlc1xuICAgKiBjaGlsZCBjb21wb25lbnRzIHJlY3Vyc2l2ZWx5LlxuICAgKlxuICAgKiBAcGFyYW0ge0ZpZWxkRGVmaW5pdGlvbjxBbmd1bGFyRmllbGREZWZpbml0aW9uPn0gZmllbGREZWYgLSBUaGUgZmllbGQgZGVmaW5pdGlvbiB0byBjb252ZXJ0XG4gICAqIEBwYXJhbSB7Vmlld0NvbnRhaW5lclJlZn0gdmNyIC0gVGhlIHZpZXcgY29udGFpbmVyIHJlZmVyZW5jZSBmb3IgY29tcG9uZW50IGNyZWF0aW9uXG4gICAqIEBwYXJhbSB7SW5qZWN0b3J9IGluamVjdG9yIC0gVGhlIEFuZ3VsYXIgaW5qZWN0b3IgZm9yIGRlcGVuZGVuY3kgaW5qZWN0aW9uXG4gICAqIEBwYXJhbSB7VGVtcGxhdGVSZWY8YW55Pn0gdHBsIC0gVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSBmb3IgY29udGVudCBwcm9qZWN0aW9uXG4gICAqIEBwYXJhbSB7c3RyaW5nfSByZWdpc3RyeUZvcm1JZCAtIEZvcm0gaWRlbnRpZmllciBmb3IgdGhlIGNvbXBvbmVudCByZW5kZXJlclxuICAgKiBAcmV0dXJuIHtBbmd1bGFyRHluYW1pY091dHB1dH0gVGhlIEFuZ3VsYXIgY29tcG9uZW50IG91dHB1dCB3aXRoIGNvbXBvbmVudCByZWZlcmVuY2UgYW5kIGlucHV0c1xuICAgKlxuICAgKiBAbWVybWFpZFxuICAgKiBzZXF1ZW5jZURpYWdyYW1cbiAgICogICBwYXJ0aWNpcGFudCBNZXRob2QgYXMgZnJvbUZpZWxkRGVmaW5pdGlvblxuICAgKiAgIHBhcnRpY2lwYW50IENvbXBvbmVudHMgYXMgTmd4UmVuZGVyaW5nRW5naW5lMi5jb21wb25lbnRzXG4gICAqICAgcGFydGljaXBhbnQgQW5ndWxhciBhcyBBbmd1bGFyIENvcmVcbiAgICogICBwYXJ0aWNpcGFudCBQcm9jZXNzIGFzIHByb2Nlc3NDaGlsZFxuICAgKlxuICAgKiAgIE1ldGhvZC0+PkNvbXBvbmVudHM6IGNvbXBvbmVudHMoZmllbGREZWYudGFnKVxuICAgKiAgIENvbXBvbmVudHMtLT4+TWV0aG9kOiBjb21wb25lbnQgY29uc3RydWN0b3JcbiAgICogICBNZXRob2QtPj5Bbmd1bGFyOiByZWZsZWN0Q29tcG9uZW50VHlwZShjb21wb25lbnQpXG4gICAqICAgQW5ndWxhci0tPj5NZXRob2Q6IGNvbXBvbmVudE1ldGFkYXRhXG4gICAqICAgTWV0aG9kLT4+TWV0aG9kOiBWYWxpZGF0ZSBpbnB1dCBwcm9wZXJ0aWVzXG4gICAqICAgTWV0aG9kLT4+TWV0aG9kOiBDcmVhdGUgcmVzdWx0IG9iamVjdFxuICAgKiAgIGFsdCBIYXMgY2hpbGRyZW5cbiAgICogICAgIE1ldGhvZC0+PlByb2Nlc3M6IFByb2Nlc3MgY2hpbGRyZW4gcmVjdXJzaXZlbHlcbiAgICogICAgIFByb2Nlc3MtPj5NZXRob2Q6IFJldHVybiBwcm9jZXNzZWQgY2hpbGRyZW5cbiAgICogICAgIE1ldGhvZC0+PkFuZ3VsYXI6IENyZWF0ZSBlbWJlZGRlZCB2aWV3XG4gICAqICAgICBNZXRob2QtPj5NZXRob2Q6IENyZWF0ZSBjb21wb25lbnQgaW5zdGFuY2VcbiAgICogICBlbmRcbiAgICogICBNZXRob2QtLT4+Q2FsbGVyOiByZXR1cm4gQW5ndWxhckR5bmFtaWNPdXRwdXRcbiAgICovXG4gIHByaXZhdGUgZnJvbUZpZWxkRGVmaW5pdGlvbihcbiAgICBmaWVsZERlZjogRmllbGREZWZpbml0aW9uPEFuZ3VsYXJGaWVsZERlZmluaXRpb24+LFxuICAgIHZjcjogVmlld0NvbnRhaW5lclJlZixcbiAgICBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgdHBsOiBUZW1wbGF0ZVJlZjx1bmtub3duPixcbiAgICByZWdpc3RyeUZvcm1JZDogc3RyaW5nID0gRGF0ZS5ub3coKS50b1N0cmluZygzNikudG9VcHBlckNhc2UoKSxcbiAgKTogQW5ndWxhckR5bmFtaWNPdXRwdXQge1xuICAgIGNvbnN0IGNtcCA9IChmaWVsZERlZiBhcyBLZXlWYWx1ZSk/LlsnY29tcG9uZW50J10gfHwgTmd4UmVuZGVyaW5nRW5naW5lMi5jb21wb25lbnRzKGZpZWxkRGVmLnRhZyk7XG4gICAgY29uc3QgY29tcG9uZW50ID0gY21wLmNvbnN0cnVjdG9yIGFzIHVua25vd24gYXMgVHlwZTx1bmtub3duPjtcblxuICAgIGNvbnN0IGNvbXBvbmVudE1ldGFkYXRhID0gcmVmbGVjdENvbXBvbmVudFR5cGUoY29tcG9uZW50KTtcbiAgICBpZiAoIWNvbXBvbmVudE1ldGFkYXRhKSB7XG4gICAgICB0aHJvdyBuZXcgSW50ZXJuYWxFcnJvcihgTWV0YWRhdGEgZm9yIGNvbXBvbmVudCAke2ZpZWxkRGVmLnRhZ30gbm90IGZvdW5kLmApO1xuICAgIH1cblxuICAgIGNvbnN0IHsgaW5wdXRzOiBwb3NzaWJsZUlucHV0cyB9ID0gY29tcG9uZW50TWV0YWRhdGE7XG4gICAgY29uc3QgaW5wdXRzID0geyAuLi5maWVsZERlZi5wcm9wcyB9O1xuXG4gICAgY29uc3QgdW5tYXBwZWRLZXlzID0gT2JqZWN0LmtleXMoaW5wdXRzKS5maWx0ZXIoaW5wdXQgPT4ge1xuICAgICAgY29uc3QgaXNNYXBwZWQgPSBwb3NzaWJsZUlucHV0cy5maW5kKCh7IHByb3BOYW1lIH0pID0+IHByb3BOYW1lID09PSBpbnB1dCk7XG4gICAgICBpZiAoIWlzTWFwcGVkKSBkZWxldGUgaW5wdXRzW2lucHV0XTtcbiAgICAgIHJldHVybiAhaXNNYXBwZWQ7XG4gICAgfSk7XG5cbiAgICBpZiAodW5tYXBwZWRLZXlzLmxlbmd0aCA+IDApXG4gICAgICBjb25zb2xlLndhcm4oYFVubWFwcGVkIGlucHV0IHByb3BlcnRpZXMgZm9yIGNvbXBvbmVudCAke2ZpZWxkRGVmLnRhZ306ICR7dW5tYXBwZWRLZXlzLmpvaW4oJywgJyl9YCk7XG5cbiAgICBjb25zdCByZXN1bHQ6IEFuZ3VsYXJEeW5hbWljT3V0cHV0ID0ge1xuICAgICAgY29tcG9uZW50LFxuICAgICAgaW5wdXRzLFxuICAgICAgaW5qZWN0b3IsXG4gICAgfTtcblxuICAgIGlmIChmaWVsZERlZi5yZW5kZXJlcklkKVxuICAgICAgKHJlc3VsdC5pbnB1dHMgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4pWydyZW5kZXJlcklkJ10gPSBmaWVsZERlZi5yZW5kZXJlcklkO1xuXG4gICAgLy8gcHJvY2VzcyBjaGlsZHJlblxuICAgIGlmIChmaWVsZERlZi5jaGlsZHJlbj8ubGVuZ3RoKSB7XG4gICAgICByZXN1bHQuY2hpbGRyZW4gPSBmaWVsZERlZi5jaGlsZHJlbi5tYXAoKGNoaWxkKSA9PiB7XG4gICAgICAgIC8vIGNyZWF0ZSBhIGNoaWxkIGZvcm0gYW5kIGFkZCBpdHMgY29udHJvbHMgYXMgcHJvcGVydGllcyBvZiBjaGlsZC5wcm9wc1xuICAgICAgICBOZ3hGb3JtU2VydmljZS5hZGRDb250cm9sRnJvbVByb3BzKHJlZ2lzdHJ5Rm9ybUlkLCBjaGlsZC5wcm9wcyk7XG4gICAgICAgIHJldHVybiB0aGlzLmZyb21GaWVsZERlZmluaXRpb24oY2hpbGQsIHZjciwgaW5qZWN0b3IsIHRwbCwgcmVnaXN0cnlGb3JtSWQpO1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8gZ2VuZXJhdGluZyBET01cbiAgICB2Y3IuY2xlYXIoKTtcbiAgICBjb25zdCB0ZW1wbGF0ZSA9IHZjci5jcmVhdGVFbWJlZGRlZFZpZXcodHBsLCBpbmplY3Rvcikucm9vdE5vZGVzO1xuICAgIGNvbnN0IGNvbXBvbmVudEluc3RhbmNlID0gTmd4UmVuZGVyaW5nRW5naW5lMi5jcmVhdGVDb21wb25lbnQoXG4gICAgICBjb21wb25lbnQsXG4gICAgICB7IC4uLmlucHV0cywgbW9kZWw6IHRoaXMuX21vZGVsIH0sXG4gICAgICBjb21wb25lbnRNZXRhZGF0YSxcbiAgICAgIHZjcixcbiAgICAgIGluamVjdG9yLFxuICAgICAgdGVtcGxhdGUsXG4gICAgKTtcblxuICAgIHJlc3VsdC5pbnN0YW5jZSA9IE5neFJlbmRlcmluZ0VuZ2luZTIuX2luc3RhbmNlID0gY29tcG9uZW50SW5zdGFuY2UuaW5zdGFuY2UgYXMgVHlwZTx1bmtub3duPjtcblxuICAgIHJldHVybiByZXN1bHQ7XG4gIH1cblxuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gQ3JlYXRlcyBhbiBBbmd1bGFyIGNvbXBvbmVudCBpbnN0YW5jZVxuICAgKiBAc3VtbWFyeSBUaGlzIHN0YXRpYyB1dGlsaXR5IG1ldGhvZCBjcmVhdGVzIGFuIEFuZ3VsYXIgY29tcG9uZW50IGluc3RhbmNlIHdpdGggdGhlIHNwZWNpZmllZFxuICAgKiBpbnB1dHMgYW5kIHRlbXBsYXRlLiBJdCB1c2VzIEFuZ3VsYXIncyBjb21wb25lbnQgY3JlYXRpb24gQVBJIHRvIGluc3RhbnRpYXRlIHRoZSBjb21wb25lbnRcbiAgICogYW5kIHRoZW4gc2V0cyB0aGUgaW5wdXQgcHJvcGVydGllcyB1c2luZyB0aGUgcHJvdmlkZWQgbWV0YWRhdGEuXG4gICAqXG4gICAqIEBwYXJhbSB7VHlwZTx1bmtub3duPn0gY29tcG9uZW50IC0gVGhlIGNvbXBvbmVudCB0eXBlIHRvIGNyZWF0ZVxuICAgKiBAcGFyYW0ge0tleVZhbHVlfSBbaW5wdXRzPXt9XSAtIFRoZSBpbnB1dCBwcm9wZXJ0aWVzIHRvIHNldCBvbiB0aGUgY29tcG9uZW50XG4gICAqIEBwYXJhbSB7Q29tcG9uZW50TWlycm9yPHVua25vd24+fSBtZXRhZGF0YSAtIFRoZSBjb21wb25lbnQgbWV0YWRhdGEgZm9yIGlucHV0IHZhbGlkYXRpb25cbiAgICogQHBhcmFtIHtWaWV3Q29udGFpbmVyUmVmfSB2Y3IgLSBUaGUgdmlldyBjb250YWluZXIgcmVmZXJlbmNlIGZvciBjb21wb25lbnQgY3JlYXRpb25cbiAgICogQHBhcmFtIHtJbmplY3Rvcn0gaW5qZWN0b3IgLSBUaGUgQW5ndWxhciBpbmplY3RvciBmb3IgZGVwZW5kZW5jeSBpbmplY3Rpb25cbiAgICogQHBhcmFtIHtOb2RlW119IFt0ZW1wbGF0ZT1bXV0gLSBUaGUgdGVtcGxhdGUgbm9kZXMgdG8gcHJvamVjdCBpbnRvIHRoZSBjb21wb25lbnRcbiAgICogQHJldHVybiB7Q29tcG9uZW50UmVmPHVua25vd24+fSBUaGUgY3JlYXRlZCBjb21wb25lbnQgcmVmZXJlbmNlXG4gICAqL1xuICBzdGF0aWMgY3JlYXRlQ29tcG9uZW50KGNvbXBvbmVudDogVHlwZTx1bmtub3duPiwgaW5wdXRzOiBLZXlWYWx1ZSA9IHt9LCBtZXRhZGF0YTogQ29tcG9uZW50TWlycm9yPHVua25vd24+LCB2Y3I6IFZpZXdDb250YWluZXJSZWYsIGluamVjdG9yOiBJbmplY3RvciwgdGVtcGxhdGU6IE5vZGVbXSA9IFtdKTogQ29tcG9uZW50UmVmPHVua25vd24+IHtcbiAgICBjb25zdCBjb21wb25lbnRJbnN0YW5jZSA9IHZjci5jcmVhdGVDb21wb25lbnQoY29tcG9uZW50IGFzIFR5cGU8dW5rbm93bj4sIHtcbiAgICAgIGVudmlyb25tZW50SW5qZWN0b3I6IGluamVjdG9yIGFzIEVudmlyb25tZW50SW5qZWN0b3IsXG4gICAgICBwcm9qZWN0YWJsZU5vZGVzOiBbdGVtcGxhdGVdLFxuICAgIH0pO1xuICAgIHRoaXMuc2V0SW5wdXRzKGNvbXBvbmVudEluc3RhbmNlLCBpbnB1dHMsIG1ldGFkYXRhKTtcbiAgICByZXR1cm4gY29tcG9uZW50SW5zdGFuY2U7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEV4dHJhY3RzIGRlY29yYXRvciBtZXRhZGF0YSBmcm9tIGEgbW9kZWxcbiAgICogQHN1bW1hcnkgVGhpcyBtZXRob2QgcHJvdmlkZXMgYWNjZXNzIHRvIHRoZSBmaWVsZCBkZWZpbml0aW9uIGdlbmVyYXRlZCBmcm9tIGEgbW9kZWwnc1xuICAgKiBkZWNvcmF0b3JzLiBJdCdzIGEgY29udmVuaWVuY2Ugd3JhcHBlciBhcm91bmQgdGhlIHRvRmllbGREZWZpbml0aW9uIG1ldGhvZCB0aGF0XG4gICAqIGNvbnZlcnRzIGEgbW9kZWwgdG8gYSBmaWVsZCBkZWZpbml0aW9uIGJhc2VkIG9uIGl0cyBkZWNvcmF0b3JzIGFuZCB0aGUgcHJvdmlkZWRcbiAgICogZ2xvYmFsIHByb3BlcnRpZXMuXG4gICAqXG4gICAqIEBwYXJhbSB7TW9kZWx9IG1vZGVsIC0gVGhlIG1vZGVsIHRvIGV4dHJhY3QgZGVjb3JhdG9ycyBmcm9tXG4gICAqIEBwYXJhbSB7UmVjb3JkPHN0cmluZywgdW5rbm93bj59IGdsb2JhbFByb3BzIC0gR2xvYmFsIHByb3BlcnRpZXMgdG8gaW5jbHVkZSBpbiB0aGUgZmllbGQgZGVmaW5pdGlvblxuICAgKiBAcmV0dXJuIHtGaWVsZERlZmluaXRpb248QW5ndWxhckZpZWxkRGVmaW5pdGlvbj59IFRoZSBmaWVsZCBkZWZpbml0aW9uIGdlbmVyYXRlZCBmcm9tIHRoZSBtb2RlbFxuICAgKi9cbiAgZ2V0RGVjb3JhdG9ycyhtb2RlbDogTW9kZWwsIGdsb2JhbFByb3BzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPik6IEZpZWxkRGVmaW5pdGlvbjxBbmd1bGFyRmllbGREZWZpbml0aW9uPiB7XG4gICAgcmV0dXJuIHRoaXMudG9GaWVsZERlZmluaXRpb24obW9kZWwsIGdsb2JhbFByb3BzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gRGVzdHJveXMgdGhlIGN1cnJlbnQgZW5naW5lIGluc3RhbmNlXG4gICAqIEBzdW1tYXJ5IFRoaXMgc3RhdGljIG1ldGhvZCBjbGVhcnMgdGhlIGN1cnJlbnQgaW5zdGFuY2UgcmVmZXJlbmNlLCBlZmZlY3RpdmVseVxuICAgKiBkZXN0cm95aW5nIHRoZSBzaW5nbGV0b24gaW5zdGFuY2Ugb2YgdGhlIHJlbmRlcmluZyBlbmdpbmUuIFRoaXMgY2FuIGJlIHVzZWRcbiAgICogdG8gcmVzZXQgdGhlIGVuZ2luZSBzdGF0ZSBvciB0byBwcmVwYXJlIGZvciBhIG5ldyBpbnN0YW5jZSBjcmVhdGlvbi5cbiAgICpcbiAgICogQHJldHVybiB7UHJvbWlzZTx2b2lkPn0gQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2hlbiB0aGUgaW5zdGFuY2UgaXMgZGVzdHJveWVkXG4gICAqL1xuICBzdGF0aWMgYXN5bmMgZGVzdHJveSgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBOZ3hSZW5kZXJpbmdFbmdpbmUyLl9pbnN0YW5jZSA9IHVuZGVmaW5lZDtcbiAgfVxuXG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZW5kZXJzIGEgbW9kZWwgaW50byBhbiBBbmd1bGFyIGNvbXBvbmVudCBvdXRwdXRcbiAgICogQHN1bW1hcnkgVGhpcyBtZXRob2QgdGFrZXMgYSBtb2RlbCBhbmQgY29udmVydHMgaXQgdG8gYW4gQW5ndWxhciBjb21wb25lbnQgb3V0cHV0LlxuICAgKiBJdCBmaXJzdCBzdG9yZXMgYSByZWZlcmVuY2UgdG8gdGhlIG1vZGVsLCB0aGVuIGNvbnZlcnRzIGl0IHRvIGEgZmllbGQgZGVmaW5pdGlvblxuICAgKiB1c2luZyB0aGUgYmFzZSBSZW5kZXJpbmdFbmdpbmUncyB0b0ZpZWxkRGVmaW5pdGlvbiBtZXRob2QsIGFuZCBmaW5hbGx5IGNvbnZlcnRzXG4gICAqIHRoYXQgZmllbGQgZGVmaW5pdGlvbiB0byBhbiBBbmd1bGFyIGNvbXBvbmVudCBvdXRwdXQgdXNpbmcgZnJvbUZpZWxkRGVmaW5pdGlvbi5cbiAgICpcbiAgICogQHRlbXBsYXRlIE0gLSBUeXBlIGV4dGVuZGluZyBNb2RlbFxuICAgKiBAcGFyYW0ge019IG1vZGVsIC0gVGhlIG1vZGVsIHRvIHJlbmRlclxuICAgKiBAcGFyYW0ge1JlY29yZDxzdHJpbmcsIHVua25vd24+fSBnbG9iYWxQcm9wcyAtIEdsb2JhbCBwcm9wZXJ0aWVzIHRvIHBhc3MgdG8gdGhlIGNvbXBvbmVudFxuICAgKiBAcGFyYW0ge1ZpZXdDb250YWluZXJSZWZ9IHZjciAtIFRoZSB2aWV3IGNvbnRhaW5lciByZWZlcmVuY2UgZm9yIGNvbXBvbmVudCBjcmVhdGlvblxuICAgKiBAcGFyYW0ge0luamVjdG9yfSBpbmplY3RvciAtIFRoZSBBbmd1bGFyIGluamVjdG9yIGZvciBkZXBlbmRlbmN5IGluamVjdGlvblxuICAgKiBAcGFyYW0ge1RlbXBsYXRlUmVmPGFueT59IHRwbCAtIFRoZSB0ZW1wbGF0ZSByZWZlcmVuY2UgZm9yIGNvbnRlbnQgcHJvamVjdGlvblxuICAgKiBAcmV0dXJuIHtBbmd1bGFyRHluYW1pY091dHB1dH0gVGhlIEFuZ3VsYXIgY29tcG9uZW50IG91dHB1dCB3aXRoIGNvbXBvbmVudCByZWZlcmVuY2UgYW5kIGlucHV0c1xuICAgKlxuICAgKiBAbWVybWFpZFxuICAgKiBzZXF1ZW5jZURpYWdyYW1cbiAgICogICBwYXJ0aWNpcGFudCBDbGllbnQgYXMgQ2xpZW50IENvZGVcbiAgICogICBwYXJ0aWNpcGFudCBSZW5kZXIgYXMgcmVuZGVyIG1ldGhvZFxuICAgKiAgIHBhcnRpY2lwYW50IFRvRmllbGQgYXMgdG9GaWVsZERlZmluaXRpb25cbiAgICogICBwYXJ0aWNpcGFudCBGcm9tRmllbGQgYXMgZnJvbUZpZWxkRGVmaW5pdGlvblxuICAgKlxuICAgKiAgIENsaWVudC0+PlJlbmRlcjogcmVuZGVyKG1vZGVsLCBnbG9iYWxQcm9wcywgdmNyLCBpbmplY3RvciwgdHBsKVxuICAgKiAgIFJlbmRlci0+PlJlbmRlcjogU3RvcmUgbW9kZWwgcmVmZXJlbmNlXG4gICAqICAgUmVuZGVyLT4+VG9GaWVsZDogdG9GaWVsZERlZmluaXRpb24obW9kZWwsIGdsb2JhbFByb3BzKVxuICAgKiAgIFRvRmllbGQtLT4+UmVuZGVyOiBmaWVsZERlZlxuICAgKiAgIFJlbmRlci0+PkZyb21GaWVsZDogZnJvbUZpZWxkRGVmaW5pdGlvbihmaWVsZERlZiwgdmNyLCBpbmplY3RvciwgdHBsKVxuICAgKiAgIEZyb21GaWVsZC0tPj5SZW5kZXI6IEFuZ3VsYXJEeW5hbWljT3V0cHV0XG4gICAqICAgUmVuZGVyLS0+PkNsaWVudDogcmV0dXJuIEFuZ3VsYXJEeW5hbWljT3V0cHV0XG4gICAqL1xuICBvdmVycmlkZSByZW5kZXI8TSBleHRlbmRzIE1vZGVsPihcbiAgICBtb2RlbDogTSxcbiAgICBnbG9iYWxQcm9wczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gICAgdmNyOiBWaWV3Q29udGFpbmVyUmVmLFxuICAgIGluamVjdG9yOiBJbmplY3RvcixcbiAgICB0cGw6IFRlbXBsYXRlUmVmPHVua25vd24+LFxuICApOiBBbmd1bGFyRHluYW1pY091dHB1dCB7XG4gICAgbGV0IHJlc3VsdDogQW5ndWxhckR5bmFtaWNPdXRwdXQ7XG4gICAgdHJ5IHtcbiAgICAgIHRoaXMuX21vZGVsID0gbW9kZWw7XG4gICAgICBjb25zdCBmb3JtSWQgPSBEYXRlLm5vdygpLnRvU3RyaW5nKDM2KS50b1VwcGVyQ2FzZSgpO1xuICAgICAgY29uc3QgZmllbGREZWYgPSB0aGlzLnRvRmllbGREZWZpbml0aW9uKG1vZGVsLCBnbG9iYWxQcm9wcyk7XG4gICAgICByZXN1bHQgPSB0aGlzLmZyb21GaWVsZERlZmluaXRpb24oZmllbGREZWYsIHZjciwgaW5qZWN0b3IsIHRwbCwgZm9ybUlkKTtcblxuICAgICAgKHJlc3VsdCEuaW5zdGFuY2UhIGFzIEtleVZhbHVlKVsnZm9ybUdyb3VwJ10gPSBOZ3hGb3JtU2VydmljZS5nZXRDb250cm9sRnJvbUZvcm0oZm9ybUlkKTtcbiAgICAgIE5neEZvcm1TZXJ2aWNlLnJlbW92ZVJlZ2lzdHJ5KGZvcm1JZCk7XG4gICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXG4gICAgICAgIGBGYWlsZWQgdG8gcmVuZGVyIE1vZGVsICR7bW9kZWwuY29uc3RydWN0b3IubmFtZX06ICR7ZX1gLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBJbml0aWFsaXplcyB0aGUgcmVuZGVyaW5nIGVuZ2luZVxuICAgKiBAc3VtbWFyeSBUaGlzIG1ldGhvZCBpbml0aWFsaXplcyB0aGUgcmVuZGVyaW5nIGVuZ2luZS4gSXQgY2hlY2tzIGlmIHRoZSBlbmdpbmUgaXMgYWxyZWFkeSBpbml0aWFsaXplZFxuICAgKiBhbmQgc2V0cyB0aGUgaW5pdGlhbGl6ZWQgZmxhZyB0byB0cnVlLiBUaGlzIG1ldGhvZCBpcyBjYWxsZWQgYmVmb3JlIHRoZSBlbmdpbmUgaXMgdXNlZFxuICAgKiB0byBlbnN1cmUgaXQncyBwcm9wZXJseSBzZXQgdXAgZm9yIHJlbmRlcmluZyBvcGVyYXRpb25zLlxuICAgKlxuICAgKiBAcmV0dXJuIHtQcm9taXNlPHZvaWQ+fSBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB3aGVuIGluaXRpYWxpemF0aW9uIGlzIGNvbXBsZXRlXG4gICAqL1xuICBvdmVycmlkZSBhc3luYyBpbml0aWFsaXplKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLmluaXRpYWxpemVkKVxuICAgICAgcmV0dXJuO1xuICAgIC8vIFZhbGlkYXRhYmxlQnlUeXBlW11cbiAgICB0aGlzLmluaXRpYWxpemVkID0gdHJ1ZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb24gUmVnaXN0ZXJzIGEgY29tcG9uZW50IHdpdGggdGhlIHJlbmRlcmluZyBlbmdpbmVcbiAgICogQHN1bW1hcnkgVGhpcyBzdGF0aWMgbWV0aG9kIHJlZ2lzdGVycyBhIGNvbXBvbmVudCBjb25zdHJ1Y3RvciB3aXRoIHRoZSByZW5kZXJpbmcgZW5naW5lXG4gICAqIHVuZGVyIGEgc3BlY2lmaWMgbmFtZS4gSXQgaW5pdGlhbGl6ZXMgdGhlIGNvbXBvbmVudHMgcmVnaXN0cnkgaWYgbmVlZGVkIGFuZCB0aHJvd3NcbiAgICogYW4gZXJyb3IgaWYgYSBjb21wb25lbnQgaXMgYWxyZWFkeSByZWdpc3RlcmVkIHVuZGVyIHRoZSBzYW1lIG5hbWUgdG8gcHJldmVudFxuICAgKiBhY2NpZGVudGFsIG92ZXJyaWRlcy5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IG5hbWUgLSBUaGUgbmFtZSB0byByZWdpc3RlciB0aGUgY29tcG9uZW50IHVuZGVyXG4gICAqIEBwYXJhbSB7Q29uc3RydWN0b3I8dW5rbm93bj59IGNvbnN0cnVjdG9yIC0gVGhlIGNvbXBvbmVudCBjb25zdHJ1Y3RvclxuICAgKiBAcmV0dXJuIHt2b2lkfVxuICAgKi9cbiAgc3RhdGljIHJlZ2lzdGVyQ29tcG9uZW50KG5hbWU6IHN0cmluZywgY29uc3RydWN0b3I6IENvbnN0cnVjdG9yPHVua25vd24+KTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLl9jb21wb25lbnRzKSB0aGlzLl9jb21wb25lbnRzID0ge307XG4gICAgaWYgKG5hbWUgaW4gdGhpcy5fY29tcG9uZW50cylcbiAgICAgIHRocm93IG5ldyBJbnRlcm5hbEVycm9yKGBDb21wb25lbnQgYWxyZWFkeSByZWdpc3RlcmVkIHVuZGVyICR7bmFtZX1gKTtcbiAgICB0aGlzLl9jb21wb25lbnRzW25hbWVdID0ge1xuICAgICAgY29uc3RydWN0b3I6IGNvbnN0cnVjdG9yLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFJldHJpZXZlcyByZWdpc3RlcmVkIGNvbXBvbmVudHMgZnJvbSB0aGUgcmVuZGVyaW5nIGVuZ2luZVxuICAgKiBAc3VtbWFyeSBUaGlzIHN0YXRpYyBtZXRob2QgcmV0cmlldmVzIGVpdGhlciBhbGwgcmVnaXN0ZXJlZCBjb21wb25lbnRzIG9yIGEgc3BlY2lmaWMgY29tcG9uZW50XG4gICAqIGJ5IGl0cyBzZWxlY3Rvci4gV2hlbiBjYWxsZWQgd2l0aG91dCBhIHNlbGVjdG9yLCBpdCByZXR1cm5zIGFuIGFycmF5IG9mIGFsbCByZWdpc3RlcmVkXG4gICAqIGNvbXBvbmVudHMuIFdoZW4gY2FsbGVkIHdpdGggYSBzZWxlY3RvciwgaXQgcmV0dXJucyB0aGUgc3BlY2lmaWMgY29tcG9uZW50IGlmIGZvdW5kLFxuICAgKiBvciB0aHJvd3MgYW4gZXJyb3IgaWYgdGhlIGNvbXBvbmVudCBpcyBub3QgcmVnaXN0ZXJlZC5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IFtzZWxlY3Rvcl0gLSBPcHRpb25hbCBzZWxlY3RvciB0byByZXRyaWV2ZSBhIHNwZWNpZmljIGNvbXBvbmVudFxuICAgKiBAcmV0dXJuIHtPYmplY3R8QXJyYXl9IEVpdGhlciBhIHNwZWNpZmljIGNvbXBvbmVudCBvciBhbiBhcnJheSBvZiBhbGwgY29tcG9uZW50c1xuICAgKi9cbiAgc3RhdGljIGNvbXBvbmVudHMoc2VsZWN0b3I/OiBzdHJpbmcpOiBvYmplY3QgfCBzdHJpbmdbXSB7XG4gICAgaWYgKCFzZWxlY3RvcikgcmV0dXJuIE9iamVjdC52YWx1ZXModGhpcy5fY29tcG9uZW50cyk7XG4gICAgaWYgKCEoc2VsZWN0b3IgaW4gdGhpcy5fY29tcG9uZW50cykpXG4gICAgICB0aHJvdyBuZXcgSW50ZXJuYWxFcnJvcihgTm8gQ29tcG9uZW50IHJlZ2lzdGVyZWQgdW5kZXIgJHtzZWxlY3Rvcn1gKTtcbiAgICByZXR1cm4gdGhpcy5fY29tcG9uZW50c1tzZWxlY3Rvcl07XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIEdlbmVyYXRlcyBhIGtleSBmb3IgcmVmbGVjdGlvbiBtZXRhZGF0YVxuICAgKiBAc3VtbWFyeSBUaGlzIHN0YXRpYyBtZXRob2QgZ2VuZXJhdGVzIGEga2V5IGZvciByZWZsZWN0aW9uIG1ldGFkYXRhIGJ5IHByZWZpeGluZyB0aGUgaW5wdXQga2V5XG4gICAqIHdpdGggdGhlIEFuZ3VsYXIgZW5naW5lJ3MgcmVmbGVjdGlvbiBwcmVmaXguIFRoaXMgaXMgdXNlZCBmb3Igc3RvcmluZyBhbmQgcmV0cmlldmluZ1xuICAgKiBtZXRhZGF0YSBpbiBhIG5hbWVzcGFjZWQgd2F5IHRvIGF2b2lkIGNvbmZsaWN0cyB3aXRoIG90aGVyIG1ldGFkYXRhLlxuICAgKlxuICAgKiBAcGFyYW0ge3N0cmluZ30ga2V5IC0gVGhlIGJhc2Uga2V5IHRvIHByZWZpeFxuICAgKiBAcmV0dXJuIHtzdHJpbmd9IFRoZSBwcmVmaXhlZCBrZXkgZm9yIHJlZmxlY3Rpb24gbWV0YWRhdGFcbiAgICovXG4gIHN0YXRpYyBvdmVycmlkZSBrZXkoa2V5OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHtBbmd1bGFyRW5naW5lS2V5cy5SRUZMRUNUfSR7a2V5fWA7XG4gIH1cblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIFNldHMgaW5wdXQgcHJvcGVydGllcyBvbiBhIGNvbXBvbmVudCBpbnN0YW5jZVxuICAgKiBAc3VtbWFyeSBUaGlzIHN0YXRpYyB1dGlsaXR5IG1ldGhvZCBzZXRzIGlucHV0IHByb3BlcnRpZXMgb24gYSBjb21wb25lbnQgaW5zdGFuY2VcbiAgICogYmFzZWQgb24gdGhlIHByb3ZpZGVkIGlucHV0cyBvYmplY3QgYW5kIGNvbXBvbmVudCBtZXRhZGF0YS4gSXQgaGFuZGxlcyBib3RoIHNpbXBsZVxuICAgKiB2YWx1ZXMgYW5kIG5lc3RlZCBvYmplY3RzLCByZWN1cnNpdmVseSBwcm9jZXNzaW5nIG9iamVjdCBwcm9wZXJ0aWVzLiBUaGUgbWV0aG9kXG4gICAqIHZhbGlkYXRlcyBlYWNoIGlucHV0IGFnYWluc3QgdGhlIGNvbXBvbmVudCdzIG1ldGFkYXRhIHRvIGVuc3VyZSBvbmx5IHZhbGlkIGlucHV0c1xuICAgKiBhcmUgc2V0LlxuICAgKlxuICAgKiBAcGFyYW0ge0NvbXBvbmVudFJlZjx1bmtub3duPn0gY29tcG9uZW50IC0gVGhlIGNvbXBvbmVudCByZWZlcmVuY2UgdG8gc2V0IGlucHV0cyBvblxuICAgKiBAcGFyYW0ge0tleVZhbHVlfSBpbnB1dHMgLSBUaGUgaW5wdXQgcHJvcGVydGllcyB0byBzZXRcbiAgICogQHBhcmFtIHtDb21wb25lbnRNaXJyb3I8dW5rbm93bj59IG1ldGFkYXRhIC0gVGhlIGNvbXBvbmVudCBtZXRhZGF0YSBmb3IgaW5wdXQgdmFsaWRhdGlvblxuICAgKiBAcmV0dXJuIHt2b2lkfVxuICAgKlxuICAgKiBAbWVybWFpZFxuICAgKiBzZXF1ZW5jZURpYWdyYW1cbiAgICogICBwYXJ0aWNpcGFudCBDYWxsZXJcbiAgICogICBwYXJ0aWNpcGFudCBTZXRJbnB1dHMgYXMgc2V0SW5wdXRzXG4gICAqICAgcGFydGljaXBhbnQgUGFyc2UgYXMgcGFyc2VJbnB1dFZhbHVlXG4gICAqICAgcGFydGljaXBhbnQgQ29tcG9uZW50IGFzIENvbXBvbmVudFJlZlxuICAgKlxuICAgKiAgIENhbGxlci0+PlNldElucHV0czogc2V0SW5wdXRzKGNvbXBvbmVudCwgaW5wdXRzLCBtZXRhZGF0YSlcbiAgICogICBTZXRJbnB1dHMtPj5TZXRJbnB1dHM6IEl0ZXJhdGUgdGhyb3VnaCBpbnB1dHNcbiAgICogICBsb29wIEZvciBlYWNoIGlucHV0XG4gICAqICAgICBTZXRJbnB1dHMtPj5TZXRJbnB1dHM6IENoZWNrIGlmIGlucHV0IGV4aXN0cyBpbiBtZXRhZGF0YVxuICAgKiAgICAgYWx0IElucHV0IGlzICdwcm9wcydcbiAgICogICAgICAgU2V0SW5wdXRzLT4+UGFyc2U6IHBhcnNlSW5wdXRWYWx1ZShjb21wb25lbnQsIHZhbHVlKVxuICAgKiAgICAgICBQYXJzZS0+PlBhcnNlOiBSZWN1cnNpdmVseSBwcm9jZXNzIG5lc3RlZCBvYmplY3RzXG4gICAqICAgICAgIFBhcnNlLT4+Q29tcG9uZW50OiBzZXRJbnB1dChrZXksIHZhbHVlKVxuICAgKiAgICAgZWxzZSBJbnB1dCBpcyB2YWxpZFxuICAgKiAgICAgICBTZXRJbnB1dHMtPj5Db21wb25lbnQ6IHNldElucHV0KGtleSwgdmFsdWUpXG4gICAqICAgICBlbmRcbiAgICogICBlbmRcbiAgICovXG4gIHN0YXRpYyBzZXRJbnB1dHMoY29tcG9uZW50OiBDb21wb25lbnRSZWY8dW5rbm93bj4sIGlucHV0czogS2V5VmFsdWUsIG1ldGFkYXRhOiBDb21wb25lbnRNaXJyb3I8dW5rbm93bj4pOiB2b2lkIHtcbiAgICBmdW5jdGlvbiBwYXJzZUlucHV0VmFsdWUoY29tcG9uZW50OiBDb21wb25lbnRSZWY8dW5rbm93bj4sIGlucHV0OiBLZXlWYWx1ZSkge1xuICAgICAgT2JqZWN0LmtleXMoaW5wdXQpLmZvckVhY2goa2V5ID0+IHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBpbnB1dFtrZXldO1xuICAgICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiAhIXZhbHVlKVxuICAgICAgICAgIHJldHVybiBwYXJzZUlucHV0VmFsdWUoY29tcG9uZW50LCB2YWx1ZSk7XG4gICAgICAgIGNvbXBvbmVudC5zZXRJbnB1dChrZXksIHZhbHVlKTtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIE9iamVjdC5lbnRyaWVzKGlucHV0cykuZm9yRWFjaCgoW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBjb25zdCBwcm9wID0gbWV0YWRhdGEuaW5wdXRzLmZpbmQoKGl0ZW06IHsgcHJvcE5hbWU6IHN0cmluZyB9KSA9PiBpdGVtLnByb3BOYW1lID09PSBrZXkpO1xuICAgICAgaWYgKHByb3ApIHtcbiAgICAgICAgaWYgKGtleSA9PT0gJ3Byb3BzJylcbiAgICAgICAgICBwYXJzZUlucHV0VmFsdWUoY29tcG9uZW50LCB2YWx1ZSk7XG4gICAgICAgIC8vIGlmKGtleSA9PT0gJ2xvY2FsZScgJiYgIXZhbHVlKVxuICAgICAgICAvLyAgIHZhbHVlID0gZ2V0TG9jYWxlRnJvbUNsYXNzTmFtZSh0aGlzLl9jb21wb25lbnROYW1lKTtcbiAgICAgICAgY29tcG9uZW50LnNldElucHV0KGtleSwgdmFsdWUpO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvaW50ZXJmYWNlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIGNvbXBvbmVudHMgdGhhdCBob2xkIGFuIEVsZW1lbnRSZWZcbiAqIEBzdW1tYXJ5IERlZmluZXMgYSBjb21wb25lbnQgaG9sZGVyIGludGVyZmFjZSB0aGF0IHByb3ZpZGVzIGFjY2VzcyB0byB0aGUgdW5kZXJseWluZyBET00gZWxlbWVudCB0aHJvdWdoIEVsZW1lbnRSZWZcbiAqIEBpbnRlcmZhY2UgQ29tcG9uZW50SG9sZGVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmZvci1hbmd1bGFyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcG9uZW50SG9sZGVyIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZWZlcmVuY2UgdG8gdGhlIGNvbXBvbmVudCdzIERPTSBlbGVtZW50XG4gICAqIEBwcm9wZXJ0eSB7RWxlbWVudFJlZn0gY29tcG9uZW50IC0gVGhlIEVsZW1lbnRSZWYgaW5zdGFuY2UgcHJvdmlkaW5nIGFjY2VzcyB0byB0aGUgbmF0aXZlIERPTSBlbGVtZW50XG4gICAqL1xuICBjb21wb25lbnQ6IEVsZW1lbnRSZWY7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgZm9ybSBjb21wb25lbnRzIHRoYXQgaG9sZCBib3RoIGFuIEVsZW1lbnRSZWYgYW5kIGEgRm9ybUdyb3VwXG4gKiBAc3VtbWFyeSBFeHRlbmRzIENvbXBvbmVudEhvbGRlciB0byBpbmNsdWRlIGEgRm9ybUdyb3VwIGZvciBmb3JtIGhhbmRsaW5nIGNhcGFiaWxpdGllc1xuICogQGludGVyZmFjZSBGb3JtRWxlbWVudFxuICogQG1lbWJlck9mIG1vZHVsZTpmb3ItYW5ndWxhclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZvcm1FbGVtZW50IGV4dGVuZHMgQ29tcG9uZW50SG9sZGVyIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBUaGUgQW5ndWxhciBGb3JtR3JvdXAgYXNzb2NpYXRlZCB3aXRoIHRoaXMgZm9ybSBlbGVtZW50XG4gICAqIEBwcm9wZXJ0eSB7Rm9ybUdyb3VwfHVuZGVmaW5lZH0gZm9ybUdyb3VwIC0gVGhlIGZvcm0gZ3JvdXAgaW5zdGFuY2UgZm9yIG1hbmFnaW5nIGZvcm0gY29udHJvbHMgYW5kIHZhbGlkYXRpb25cbiAgICovXG4gIGZvcm1Hcm91cDogRm9ybUdyb3VwIHwgdW5kZWZpbmVkO1xufVxuIl19
package/interfaces.d.ts DELETED
@@ -1,28 +0,0 @@
1
- import { FormGroup } from '@angular/forms';
2
- import { ElementRef } from '@angular/core';
3
- /**
4
- * @description Interface for components that hold an ElementRef
5
- * @summary Defines a component holder interface that provides access to the underlying DOM element through ElementRef
6
- * @interface ComponentHolder
7
- * @memberOf module:for-angular
8
- */
9
- export interface ComponentHolder {
10
- /**
11
- * @description Reference to the component's DOM element
12
- * @property {ElementRef} component - The ElementRef instance providing access to the native DOM element
13
- */
14
- component: ElementRef;
15
- }
16
- /**
17
- * @description Interface for form components that hold both an ElementRef and a FormGroup
18
- * @summary Extends ComponentHolder to include a FormGroup for form handling capabilities
19
- * @interface FormElement
20
- * @memberOf module:for-angular
21
- */
22
- export interface FormElement extends ComponentHolder {
23
- /**
24
- * @description The Angular FormGroup associated with this form element
25
- * @property {FormGroup|undefined} formGroup - The form group instance for managing form controls and validation
26
- */
27
- formGroup: FormGroup | undefined;
28
- }