@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.
- package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js +34 -87
- package/bundles/taiga-ui-addon-commerce-components-input-card-grouped.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js +143 -71
- package/bundles/taiga-ui-addon-commerce-components-input-card.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-commerce-enums.umd.js +1 -0
- package/bundles/taiga-ui-addon-commerce-enums.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-commerce-utils.umd.js +1 -1
- package/bundles/taiga-ui-addon-commerce-utils.umd.js.map +1 -1
- package/components/input-card/abstract-input-card.d.ts +29 -0
- package/components/input-card/index.d.ts +2 -0
- package/components/input-card/input-card.component.d.ts +9 -16
- package/components/input-card/input-card.providers.d.ts +13 -0
- package/components/input-card-grouped/input-card-grouped.component.d.ts +8 -15
- package/components/input-card-grouped/input-card-grouped.module.d.ts +1 -1
- package/components/input-card-grouped/input-card-grouped.providers.d.ts +11 -1
- package/esm2015/components/input-card/abstract-input-card.js +68 -0
- package/esm2015/components/input-card/index.js +3 -1
- package/esm2015/components/input-card/input-card.component.js +26 -50
- package/esm2015/components/input-card/input-card.providers.js +20 -0
- package/esm2015/components/input-card-grouped/input-card-grouped.component.js +22 -68
- package/esm2015/components/input-card-grouped/input-card-grouped.module.js +5 -2
- package/esm2015/components/input-card-grouped/input-card-grouped.providers.js +11 -1
- package/esm2015/enums/currency.js +2 -1
- package/esm2015/utils/get-currency-by-code.js +1 -1
- package/esm2015/utils/get-payment-system.js +2 -2
- package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js +31 -66
- package/fesm2015/taiga-ui-addon-commerce-components-input-card-grouped.js.map +1 -1
- package/fesm2015/taiga-ui-addon-commerce-components-input-card.js +107 -52
- package/fesm2015/taiga-ui-addon-commerce-components-input-card.js.map +1 -1
- package/fesm2015/taiga-ui-addon-commerce-enums.js +1 -0
- package/fesm2015/taiga-ui-addon-commerce-enums.js.map +1 -1
- package/fesm2015/taiga-ui-addon-commerce-utils.js +1 -1
- package/fesm2015/taiga-ui-addon-commerce-utils.js.map +1 -1
- package/package.json +4 -4
- package/utils/get-payment-system.d.ts +1 -1
|
@@ -1,36 +1,27 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component,
|
|
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 {
|
|
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
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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
|
|
32
|
-
|
|
33
|
-
return
|
|
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.
|
|
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",
|
|
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
|
-
|
|
90
|
-
], TuiInputCardComponent.prototype, "
|
|
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
|
-
}],
|
|
120
|
-
|
|
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=
|