@taiga-ui/addon-commerce 3.25.0 → 3.26.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.
Files changed (35) hide show
  1. package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js +34 -87
  2. package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js.map +1 -1
  3. package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js +143 -71
  4. package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js.map +1 -1
  5. package/bundles/taiga-ui-addon-commerce-enums.umd.js +1 -0
  6. package/bundles/taiga-ui-addon-commerce-enums.umd.js.map +1 -1
  7. package/bundles/taiga-ui-addon-commerce-utils.umd.js +1 -1
  8. package/bundles/taiga-ui-addon-commerce-utils.umd.js.map +1 -1
  9. package/components/input-card/abstract-input-card.d.ts +29 -0
  10. package/components/input-card/index.d.ts +2 -0
  11. package/components/input-card/input-card.component.d.ts +9 -16
  12. package/components/input-card/input-card.providers.d.ts +13 -0
  13. package/components/input-card-grouped/input-card-grouped.component.d.ts +8 -15
  14. package/components/input-card-grouped/input-card-grouped.module.d.ts +1 -1
  15. package/components/input-card-grouped/input-card-grouped.providers.d.ts +11 -1
  16. package/esm2015/components/input-card/abstract-input-card.js +68 -0
  17. package/esm2015/components/input-card/index.js +3 -1
  18. package/esm2015/components/input-card/input-card.component.js +26 -50
  19. package/esm2015/components/input-card/input-card.providers.js +20 -0
  20. package/esm2015/components/input-card-grouped/input-card-grouped.component.js +22 -68
  21. package/esm2015/components/input-card-grouped/input-card-grouped.module.js +5 -2
  22. package/esm2015/components/input-card-grouped/input-card-grouped.providers.js +11 -1
  23. package/esm2015/enums/currency.js +2 -1
  24. package/esm2015/utils/get-currency-by-code.js +1 -1
  25. package/esm2015/utils/get-payment-system.js +2 -2
  26. package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js +31 -66
  27. package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js.map +1 -1
  28. package/fesm2015/taiga-ui-addon-commerce-components-input-card.js +107 -52
  29. package/fesm2015/taiga-ui-addon-commerce-components-input-card.js.map +1 -1
  30. package/fesm2015/taiga-ui-addon-commerce-enums.js +1 -0
  31. package/fesm2015/taiga-ui-addon-commerce-enums.js.map +1 -1
  32. package/fesm2015/taiga-ui-addon-commerce-utils.js +1 -1
  33. package/fesm2015/taiga-ui-addon-commerce-utils.js.map +1 -1
  34. package/package.json +4 -4
  35. package/utils/get-payment-system.d.ts +1 -1
@@ -1,36 +1,27 @@
1
1
  import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Optional, Self, ViewChild, } from '@angular/core';
3
3
  import { NgControl } from '@angular/forms';
4
4
  import { TUI_CARD_MASK } from '@taiga-ui/addon-commerce/constants';
5
- import { tuiGetPaymentSystem } from '@taiga-ui/addon-commerce/utils';
6
- import { AbstractTuiControl, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, } from '@taiga-ui/cdk';
5
+ import { tuiAsControl, tuiAsFocusableItemAccessor, tuiPure } from '@taiga-ui/cdk';
7
6
  import { TuiPrimitiveTextfieldComponent } from '@taiga-ui/core';
7
+ import { AbstractTuiInputCard } from './abstract-input-card';
8
+ import { TUI_INPUT_CARD_OPTIONS } from './input-card.providers';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@taiga-ui/core";
10
11
  import * as i2 from "@taiga-ui/kit";
11
12
  import * as i3 from "@angular/forms";
12
- const icons = {
13
- mir: 'tuiIconMir',
14
- visa: 'tuiIconVisa',
15
- electron: 'tuiIconElectron',
16
- mastercard: 'tuiIconMastercard',
17
- maestro: 'tuiIconMaestro',
18
- };
19
- export class TuiInputCardComponent extends AbstractTuiControl {
20
- constructor(control, cdr) {
21
- super(control, cdr);
22
- this.cardSrc = '';
23
- this.autocompleteEnabled = false;
24
- this.binChange = new EventEmitter();
13
+ export class TuiInputCardComponent extends AbstractTuiInputCard {
14
+ constructor(control, cdr, options) {
15
+ super(control, cdr, options);
25
16
  this.textMaskOptions = {
26
17
  mask: TUI_CARD_MASK,
27
18
  guide: false,
28
19
  pipe: conformedValue => conformedValue.trim(),
29
20
  };
30
21
  }
31
- get defaultCardIcon() {
32
- const { paymentSystem } = this;
33
- return paymentSystem ? icons[paymentSystem] : null;
22
+ get card() {
23
+ var _a;
24
+ return (_a = this.value) !== null && _a !== void 0 ? _a : '';
34
25
  }
35
26
  get nativeFocusableElement() {
36
27
  return this.input ? this.input.nativeFocusableElement : null;
@@ -38,23 +29,8 @@ export class TuiInputCardComponent extends AbstractTuiControl {
38
29
  get focused() {
39
30
  return !!this.input && this.input.focused;
40
31
  }
41
- get icon() {
42
- return this.cardSrc || this.defaultCardIcon;
43
- }
44
- get autocomplete() {
45
- return this.autocompleteEnabled ? 'cc-number' : 'off';
46
- }
47
- get paymentSystem() {
48
- return tuiGetPaymentSystem(this.value);
49
- }
50
- get bin() {
51
- return this.value.length < 6 ? null : this.value.slice(0, 6);
52
- }
53
32
  get formattedCard() {
54
- return this.value
55
- .split('')
56
- .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))
57
- .join('');
33
+ return this.getFormattedCard(this.card);
58
34
  }
59
35
  onValueChange(value) {
60
36
  const parsed = value.split(' ').join('');
@@ -79,18 +55,21 @@ export class TuiInputCardComponent extends AbstractTuiControl {
79
55
  getFallbackValue() {
80
56
  return '';
81
57
  }
58
+ getFormattedCard(cardNumber) {
59
+ return cardNumber
60
+ .split('')
61
+ .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))
62
+ .join('');
63
+ }
82
64
  }
83
- TuiInputCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
84
- TuiInputCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputCardComponent, selector: "tui-input-card", inputs: { cardSrc: "cardSrc", autocompleteEnabled: "autocompleteEnabled" }, outputs: { binChange: "binChange" }, providers: [
65
+ TuiInputCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_INPUT_CARD_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
66
+ TuiInputCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputCardComponent, selector: "tui-input-card", providers: [
85
67
  tuiAsFocusableItemAccessor(TuiInputCardComponent),
86
68
  tuiAsControl(TuiInputCardComponent),
87
69
  ], viewQueries: [{ propertyName: "input", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n tuiValueAccessor\n class=\"t-input\"\n [tuiTextfieldCustomContent]=\"icon\"\n [readOnly]=\"readOnly\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [nativeId]=\"nativeId\"\n [invalid]=\"computedInvalid\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"pseudoFocus\"\n [textMask]=\"textMaskOptions\"\n [value]=\"formattedCard\"\n (valueChange)=\"onValueChange($event)\"\n (focusedChange)=\"onFocused($event)\"\n>\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n</tui-primitive-textfield>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-input{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i2.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { type: i1.TuiTextfieldCustomContentDirective, selector: "[tuiTextfieldCustomContent]", inputs: ["tuiTextfieldCustomContent"] }, { type: i2.MaskedInputDirective, selector: "[textMask]", inputs: ["textMask"], exportAs: ["textMask"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
88
70
  __decorate([
89
- tuiDefaultProp()
90
- ], TuiInputCardComponent.prototype, "cardSrc", void 0);
91
- __decorate([
92
- tuiDefaultProp()
93
- ], TuiInputCardComponent.prototype, "autocompleteEnabled", void 0);
71
+ tuiPure
72
+ ], TuiInputCardComponent.prototype, "getFormattedCard", null);
94
73
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputCardComponent, decorators: [{
95
74
  type: Component,
96
75
  args: [{
@@ -113,14 +92,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
113
92
  }] }, { type: i0.ChangeDetectorRef, decorators: [{
114
93
  type: Inject,
115
94
  args: [ChangeDetectorRef]
95
+ }] }, { type: undefined, decorators: [{
96
+ type: Inject,
97
+ args: [TUI_INPUT_CARD_OPTIONS]
116
98
  }] }]; }, propDecorators: { input: [{
117
99
  type: ViewChild,
118
100
  args: [TuiPrimitiveTextfieldComponent]
119
- }], cardSrc: [{
120
- type: Input
121
- }], autocompleteEnabled: [{
122
- type: Input
123
- }], binChange: [{
124
- type: Output
125
- }] } });
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts","../../../../../projects/addon-commerce/components/input-card/input-card.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {TUI_CARD_MASK} from '@taiga-ui/addon-commerce/constants';\nimport {TuiPaymentSystem} from '@taiga-ui/addon-commerce/types';\nimport {tuiGetPaymentSystem} from '@taiga-ui/addon-commerce/utils';\nimport {\n    AbstractTuiControl,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiAutofillFieldName,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n} from '@taiga-ui/cdk';\nimport {TuiPrimitiveTextfieldComponent, TuiTextMaskOptions} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\nconst icons: Record<TuiPaymentSystem, string> = {\n    mir: 'tuiIconMir',\n    visa: 'tuiIconVisa',\n    electron: 'tuiIconElectron',\n    mastercard: 'tuiIconMastercard',\n    maestro: 'tuiIconMaestro',\n};\n\n@Component({\n    selector: 'tui-input-card',\n    templateUrl: './input-card.template.html',\n    styleUrls: ['./input-card.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputCardComponent),\n        tuiAsControl(TuiInputCardComponent),\n    ],\n})\nexport class TuiInputCardComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly input?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    cardSrc: PolymorpheusContent = '';\n\n    @Input()\n    @tuiDefaultProp()\n    autocompleteEnabled = false;\n\n    @Output()\n    readonly binChange = new EventEmitter<string | null>();\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: TUI_CARD_MASK,\n        guide: false,\n        pipe: conformedValue => conformedValue.trim(),\n    };\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n    ) {\n        super(control, cdr);\n    }\n\n    private get defaultCardIcon(): string | null {\n        const {paymentSystem} = this;\n\n        return paymentSystem ? icons[paymentSystem] : null;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.input ? this.input.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.input && this.input.focused;\n    }\n\n    get icon(): PolymorpheusContent {\n        return this.cardSrc || this.defaultCardIcon;\n    }\n\n    get autocomplete(): TuiAutofillFieldName {\n        return this.autocompleteEnabled ? 'cc-number' : 'off';\n    }\n\n    get paymentSystem(): TuiPaymentSystem | null {\n        return tuiGetPaymentSystem(this.value);\n    }\n\n    get bin(): string | null {\n        return this.value.length < 6 ? null : this.value.slice(0, 6);\n    }\n\n    get formattedCard(): string {\n        return this.value\n            .split('')\n            .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))\n            .join('');\n    }\n\n    onValueChange(value: string): void {\n        const parsed = value.split(' ').join('');\n        const currentBin = this.bin;\n\n        this.value = parsed;\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override writeValue(value: string | null): void {\n        const currentBin = this.bin;\n\n        super.writeValue(value);\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n}\n","<tui-primitive-textfield\n    tuiValueAccessor\n    class=\"t-input\"\n    [tuiTextfieldCustomContent]=\"icon\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [invalid]=\"computedInvalid\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [textMask]=\"textMaskOptions\"\n    [value]=\"formattedCard\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n"]}
101
+ }], getFormattedCard: [] } });
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts","../../../../../projects/addon-commerce/components/input-card/input-card.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {TUI_CARD_MASK} from '@taiga-ui/addon-commerce/constants';\nimport {tuiAsControl, tuiAsFocusableItemAccessor, tuiPure} from '@taiga-ui/cdk';\nimport {TuiPrimitiveTextfieldComponent, TuiTextMaskOptions} from '@taiga-ui/core';\n\nimport {AbstractTuiInputCard} from './abstract-input-card';\nimport {TUI_INPUT_CARD_OPTIONS, TuiInputCardOptions} from './input-card.providers';\n\n@Component({\n    selector: 'tui-input-card',\n    templateUrl: './input-card.template.html',\n    styleUrls: ['./input-card.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputCardComponent),\n        tuiAsControl(TuiInputCardComponent),\n    ],\n})\nexport class TuiInputCardComponent extends AbstractTuiInputCard<string> {\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly input?: TuiPrimitiveTextfieldComponent;\n\n    readonly textMaskOptions: TuiTextMaskOptions = {\n        mask: TUI_CARD_MASK,\n        guide: false,\n        pipe: conformedValue => conformedValue.trim(),\n    };\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_INPUT_CARD_OPTIONS) options: TuiInputCardOptions,\n    ) {\n        super(control, cdr, options);\n    }\n\n    get card(): string {\n        return this.value ?? '';\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.input ? this.input.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.input && this.input.focused;\n    }\n\n    get formattedCard(): string {\n        return this.getFormattedCard(this.card);\n    }\n\n    onValueChange(value: string): void {\n        const parsed = value.split(' ').join('');\n        const currentBin = this.bin;\n\n        this.value = parsed;\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override writeValue(value: string | null): void {\n        const currentBin = this.bin;\n\n        super.writeValue(value);\n\n        const newBin = this.bin;\n\n        if (currentBin !== newBin) {\n            this.binChange.emit(newBin);\n        }\n    }\n\n    protected override getFallbackValue(): string {\n        return '';\n    }\n\n    @tuiPure\n    private getFormattedCard(cardNumber: string): string {\n        return cardNumber\n            .split('')\n            .map((char, index) => (index && index % 4 === 0 ? ` ${char}` : char))\n            .join('');\n    }\n}\n","<tui-primitive-textfield\n    tuiValueAccessor\n    class=\"t-input\"\n    [tuiTextfieldCustomContent]=\"icon\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"disabled\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [invalid]=\"computedInvalid\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [textMask]=\"textMaskOptions\"\n    [value]=\"formattedCard\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n"]}
@@ -0,0 +1,20 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ import { tuiGetPaymentSystem } from '@taiga-ui/addon-commerce/utils';
3
+ export const TUI_INPUT_CARD_DEFAULT_OPTIONS = {
4
+ icons: {
5
+ mir: `tuiIconMir`,
6
+ visa: `tuiIconVisa`,
7
+ electron: `tuiIconElectron`,
8
+ mastercard: `tuiIconMastercard`,
9
+ maestro: `tuiIconMaestro`,
10
+ },
11
+ cardSrc: ``,
12
+ paymentSystemHandler: tuiGetPaymentSystem,
13
+ autocompleteEnabled: false,
14
+ };
15
+ export const TUI_INPUT_CARD_OPTIONS = new InjectionToken(`[TUI_INPUT_CARD_OPTIONS]`, { factory: () => TUI_INPUT_CARD_DEFAULT_OPTIONS });
16
+ export const tuiInputCardOptionsProvider = (options) => ({
17
+ provide: TUI_INPUT_CARD_OPTIONS,
18
+ useValue: Object.assign(Object.assign({}, TUI_INPUT_CARD_DEFAULT_OPTIONS), options),
19
+ });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY2FyZC5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jb21tZXJjZS9jb21wb25lbnRzL2lucHV0LWNhcmQvaW5wdXQtY2FyZC5wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBZ0IsTUFBTSxlQUFlLENBQUM7QUFFNUQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFjbkUsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQXdCO0lBQy9ELEtBQUssRUFBRTtRQUNILEdBQUcsRUFBRSxZQUFZO1FBQ2pCLElBQUksRUFBRSxhQUFhO1FBQ25CLFFBQVEsRUFBRSxpQkFBaUI7UUFDM0IsVUFBVSxFQUFFLG1CQUFtQjtRQUMvQixPQUFPLEVBQUUsZ0JBQWdCO0tBQzVCO0lBQ0QsT0FBTyxFQUFFLEVBQUU7SUFDWCxvQkFBb0IsRUFBRSxtQkFBbUI7SUFDekMsbUJBQW1CLEVBQUUsS0FBSztDQUM3QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELDBCQUEwQixFQUMxQixFQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw4QkFBOEIsRUFBQyxDQUNsRCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBRW5CLENBQUMsT0FBcUMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3RCxPQUFPLEVBQUUsc0JBQXNCO0lBQy9CLFFBQVEsa0NBQU0sOEJBQThCLEdBQUssT0FBTyxDQUFDO0NBQzVELENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW4sIFZhbHVlUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdHlwZXMnO1xuaW1wb3J0IHt0dWlHZXRQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdXRpbHMnO1xuaW1wb3J0IHtUdWlIYW5kbGVyfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuZXhwb3J0IGludGVyZmFjZSBUdWlJbnB1dENhcmRPcHRpb25zIHtcbiAgICBjYXJkU3JjOiBQb2x5bW9ycGhldXNDb250ZW50O1xuICAgIHJlYWRvbmx5IGF1dG9jb21wbGV0ZUVuYWJsZWQ6IGJvb2xlYW47XG4gICAgcmVhZG9ubHkgaWNvbnM6IFJlY29yZDxUdWlQYXltZW50U3lzdGVtLCBzdHJpbmc+O1xuICAgIHJlYWRvbmx5IHBheW1lbnRTeXN0ZW1IYW5kbGVyOiBUdWlIYW5kbGVyPFxuICAgICAgICBzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkLFxuICAgICAgICBUdWlQYXltZW50U3lzdGVtIHwgbnVsbFxuICAgID47XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfSU5QVVRfQ0FSRF9ERUZBVUxUX09QVElPTlM6IFR1aUlucHV0Q2FyZE9wdGlvbnMgPSB7XG4gICAgaWNvbnM6IHtcbiAgICAgICAgbWlyOiBgdHVpSWNvbk1pcmAsXG4gICAgICAgIHZpc2E6IGB0dWlJY29uVmlzYWAsXG4gICAgICAgIGVsZWN0cm9uOiBgdHVpSWNvbkVsZWN0cm9uYCxcbiAgICAgICAgbWFzdGVyY2FyZDogYHR1aUljb25NYXN0ZXJjYXJkYCxcbiAgICAgICAgbWFlc3RybzogYHR1aUljb25NYWVzdHJvYCxcbiAgICB9LFxuICAgIGNhcmRTcmM6IGBgLFxuICAgIHBheW1lbnRTeXN0ZW1IYW5kbGVyOiB0dWlHZXRQYXltZW50U3lzdGVtLFxuICAgIGF1dG9jb21wbGV0ZUVuYWJsZWQ6IGZhbHNlLFxufTtcblxuZXhwb3J0IGNvbnN0IFRVSV9JTlBVVF9DQVJEX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHVpSW5wdXRDYXJkT3B0aW9ucz4oXG4gICAgYFtUVUlfSU5QVVRfQ0FSRF9PUFRJT05TXWAsXG4gICAge2ZhY3Rvcnk6ICgpID0+IFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OU30sXG4pO1xuXG5leHBvcnQgY29uc3QgdHVpSW5wdXRDYXJkT3B0aW9uc1Byb3ZpZGVyOiAoXG4gICAgb3B0aW9uczogUGFydGlhbDxUdWlJbnB1dENhcmRPcHRpb25zPixcbikgPT4gVmFsdWVQcm92aWRlciA9IChvcHRpb25zOiBQYXJ0aWFsPFR1aUlucHV0Q2FyZE9wdGlvbnM+KSA9PiAoe1xuICAgIHByb3ZpZGU6IFRVSV9JTlBVVF9DQVJEX09QVElPTlMsXG4gICAgdXNlVmFsdWU6IHsuLi5UVUlfSU5QVVRfQ0FSRF9ERUZBVUxUX09QVElPTlMsIC4uLm9wdGlvbnN9LFxufSk7XG4iXX0=