@taiga-ui/addon-commerce 4.33.0-canary.a0e1504 → 4.34.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.
@@ -12,6 +12,7 @@ export declare class TuiInputCard implements OnInit {
12
12
  private readonly accessor;
13
13
  protected readonly mask: import("@angular/core").WritableSignal<import("@maskito/core").MaskitoOptions | null>;
14
14
  protected readonly image: import("@angular/core").Signal<string | null>;
15
+ /** @deprecated apparently "off" doesn't disable autocomplete */
15
16
  autocomplete: boolean;
16
17
  readonly binChange: import("rxjs").Observable<string | null>;
17
18
  set iconValue(icon: string | null);
@@ -2,6 +2,7 @@ import type { Provider } from '@angular/core';
2
2
  import type { TuiPaymentSystem } from '@taiga-ui/addon-commerce/types';
3
3
  import type { TuiHandler } from '@taiga-ui/cdk/types';
4
4
  export interface TuiInputCardOptions {
5
+ /** @deprecated apparently "off" doesn't disable autocomplete */
5
6
  readonly autocomplete: boolean;
6
7
  readonly icon: string | null;
7
8
  readonly paymentSystemHandler: TuiHandler<string | null | undefined, TuiPaymentSystem | null>;
@@ -1,4 +1,4 @@
1
- import type { Signal } from '@angular/core';
1
+ import type { AfterViewInit, Signal } from '@angular/core';
2
2
  import { EventEmitter } from '@angular/core';
3
3
  import { TuiControl } from '@taiga-ui/cdk/classes';
4
4
  import type { TuiBooleanHandler } from '@taiga-ui/cdk/types';
@@ -14,10 +14,12 @@ export interface TuiCard {
14
14
  cvc: string;
15
15
  expire: string;
16
16
  }
17
- export declare class TuiInputCardGroup extends TuiControl<TuiCard | null> implements TuiDataListHost<Partial<TuiCard>> {
17
+ export declare class TuiInputCardGroup extends TuiControl<TuiCard | null> implements TuiDataListHost<Partial<TuiCard>>, AfterViewInit {
18
18
  private readonly inputCard?;
19
19
  private readonly inputExpire?;
20
20
  private readonly inputCVC?;
21
+ private readonly doc;
22
+ private readonly isServer;
21
23
  private readonly focus$;
22
24
  private expirePrefilled;
23
25
  private readonly paymentSystems;
@@ -28,6 +30,8 @@ export declare class TuiInputCardGroup extends TuiControl<TuiCard | null> implem
28
30
  protected exampleTextCVC: string;
29
31
  protected cvcHidden: boolean;
30
32
  protected maskCVC: import("@maskito/core").MaskitoOptions;
33
+ protected readonly isMobile: boolean;
34
+ protected readonly isWebkit: boolean;
31
35
  protected readonly dropdown: TuiDropdownDirective;
32
36
  protected readonly maskCard: import("@maskito/core").MaskitoOptions;
33
37
  protected readonly maskExpire: Required<import("@maskito/core").MaskitoOptions>;
@@ -50,10 +54,12 @@ export declare class TuiInputCardGroup extends TuiControl<TuiCard | null> implem
50
54
  cardValidator: TuiBooleanHandler<string>;
51
55
  icon: PolymorpheusContent;
52
56
  id: string;
57
+ /** @deprecated apparently "off" doesn't disable autocomplete */
53
58
  autocomplete: boolean;
54
59
  readonly binChange: EventEmitter<string | null>;
55
60
  set codeLength(length: 3 | 4);
56
61
  get bin(): string | null;
62
+ ngAfterViewInit(): void;
57
63
  writeValue(value: TuiCard | null): void;
58
64
  /** Public API for manual focus management */
59
65
  focusCard(): void;
@@ -4,6 +4,7 @@ import * as i1 from "@maskito/angular";
4
4
  import * as i2 from "@taiga-ui/core/components/textfield";
5
5
  export declare class TuiInputCVC implements OnChanges {
6
6
  private readonly mask;
7
+ /** @deprecated apparently "off" doesn't disable autocomplete */
7
8
  autocomplete: boolean;
8
9
  hidden: boolean;
9
10
  length: 3 | 4;
@@ -3,6 +3,7 @@ import * as i1 from "@maskito/angular";
3
3
  import * as i2 from "@taiga-ui/core/components/textfield";
4
4
  export declare class TuiInputExpire {
5
5
  protected readonly mask: import("@angular/core").WritableSignal<import("@maskito/core").MaskitoOptions | null>;
6
+ /** @deprecated apparently "off" doesn't disable autocomplete */
6
7
  autocomplete: boolean;
7
8
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputExpire, never>;
8
9
  static ɵdir: i0.ɵɵDirectiveDeclaration<TuiInputExpire, "input[tuiInputExpire]", never, { "autocomplete": { "alias": "autocomplete"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.MaskitoDirective; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiWithTextfield; inputs: {}; outputs: {}; }]>;
@@ -32,6 +32,7 @@ class TuiInputCard {
32
32
  const url = this.icon() || icon;
33
33
  return url && this.icon() !== '' ? url : null;
34
34
  });
35
+ /** @deprecated apparently "off" doesn't disable autocomplete */
35
36
  this.autocomplete = this.options.autocomplete;
36
37
  this.binChange = toObservable(this.value).pipe(map((value) => (value.length < 6 ? null : value.replace(' ', '').slice(0, 6))), startWith(null), distinctUntilChanged(), skip(1));
37
38
  }
@@ -46,7 +47,7 @@ class TuiInputCard {
46
47
  this.accessor.onChange = (value) => onChanges(value.replaceAll(' ', ''));
47
48
  }
48
49
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputCard, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
49
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputCard, isStandalone: true, selector: "input[tuiInputCard]", inputs: { autocomplete: "autocomplete", iconValue: ["icon", "iconValue"] }, outputs: { binChange: "binChange" }, host: { attributes: { "inputmode": "numeric", "placeholder": "0000 0000 0000 0000", "ngSkipHydration": "true" }, properties: { "autocomplete": "autocomplete ? \"cc-number\" : \"off\"" } }, hostDirectives: [{ directive: i1.MaskitoDirective }, { directive: i2.TuiWithTextfield }], ngImport: i0, template: `
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputCard, isStandalone: true, selector: "input[tuiInputCard]", inputs: { autocomplete: "autocomplete", iconValue: ["icon", "iconValue"] }, outputs: { binChange: "binChange" }, host: { attributes: { "inputmode": "numeric", "placeholder": "0000 0000 0000 0000", "ngSkipHydration": "true", "autocomplete": "cc-number" } }, hostDirectives: [{ directive: i1.MaskitoDirective }, { directive: i2.TuiWithTextfield }], ngImport: i0, template: `
50
51
  <img
51
52
  *tuiTextfieldContent
52
53
  alt=""
@@ -71,7 +72,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
71
72
  inputmode: 'numeric',
72
73
  placeholder: '0000 0000 0000 0000',
73
74
  ngSkipHydration: 'true',
74
- '[autocomplete]': 'autocomplete ? "cc-number" : "off"',
75
+ autocomplete: 'cc-number',
75
76
  }, styles: ["tui-textfield .t-payment-system{order:-1;inline-size:1.5rem}tui-textfield[data-size=l] .t-payment-system{inline-size:2rem}\n"] }]
76
77
  }], propDecorators: { autocomplete: [{
77
78
  type: Input
@@ -81,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
81
82
  type: Input,
82
83
  args: ['icon']
83
84
  }] } });
84
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {OnInit} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    Output,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toObservable, toSignal} from '@angular/core/rxjs-interop';\nimport {DefaultValueAccessor, NgControl} from '@angular/forms';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {TUI_MASK_CARD} from '@taiga-ui/addon-commerce/constants';\nimport {TUI_PAYMENT_SYSTEM_ICONS} from '@taiga-ui/addon-commerce/tokens';\nimport {tuiControlValue} from '@taiga-ui/cdk/observables';\nimport {TuiTextfieldContent, TuiWithTextfield} from '@taiga-ui/core/components/textfield';\nimport {tuiInjectIconResolver} from '@taiga-ui/core/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\nimport {distinctUntilChanged, map, skip, startWith, switchMap, timer} from 'rxjs';\n\nimport {TUI_INPUT_CARD_OPTIONS} from './input-card.options';\n\n@Component({\n    standalone: true,\n    selector: 'input[tuiInputCard]',\n    imports: [TuiTextfieldContent],\n    template: `\n        <img\n            *tuiTextfieldContent\n            alt=\"\"\n            class=\"t-payment-system\"\n            [hidden]=\"!image()\"\n            [src]=\"image()\"\n        />\n    `,\n    styleUrls: ['./input-card.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [MaskitoDirective, TuiWithTextfield],\n    host: {\n        inputmode: 'numeric',\n        placeholder: '0000 0000 0000 0000',\n        ngSkipHydration: 'true',\n        '[autocomplete]': 'autocomplete ? \"cc-number\" : \"off\"',\n    },\n})\nexport class TuiInputCard implements OnInit {\n    private readonly icons = inject(TUI_PAYMENT_SYSTEM_ICONS);\n    private readonly options = inject(TUI_INPUT_CARD_OPTIONS);\n    private readonly resolver = tuiInjectIconResolver();\n    private readonly control = inject(NgControl);\n    private readonly value = toSignal(\n        timer(0).pipe(switchMap(() => tuiControlValue<string>(this.control))),\n        {initialValue: ''},\n    );\n\n    private readonly icon = signal<string | null>(this.options.icon);\n\n    private readonly accessor = inject(DefaultValueAccessor, {\n        self: true,\n        optional: true,\n    });\n\n    protected readonly mask = tuiMaskito(TUI_MASK_CARD);\n    protected readonly image = computed(() => {\n        const system = this.options.paymentSystemHandler(this.value());\n        const icon = system && this.icons[system] && this.resolver(this.icons[system]);\n        const url = this.icon() || icon;\n\n        return url && this.icon() !== '' ? url : null;\n    });\n\n    @Input()\n    public autocomplete = this.options.autocomplete;\n\n    @Output()\n    public readonly binChange = toObservable(this.value).pipe(\n        map((value) => (value.length < 6 ? null : value.replace(' ', '').slice(0, 6))),\n        startWith(null),\n        distinctUntilChanged(),\n        skip(1),\n    );\n\n    @Input('icon')\n    public set iconValue(icon: string | null) {\n        this.icon.set(icon);\n    }\n\n    public ngOnInit(): void {\n        if (!this.accessor) {\n            return;\n        }\n\n        const onChanges = this.accessor.onChange.bind(this.accessor);\n\n        this.accessor.onChange = (value: string) => onChanges(value.replaceAll(' ', ''));\n    }\n}\n"]}
85
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-card.component.js","sourceRoot":"","sources":["../../../../../projects/addon-commerce/components/input-card/input-card.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {OnInit} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    Output,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toObservable, toSignal} from '@angular/core/rxjs-interop';\nimport {DefaultValueAccessor, NgControl} from '@angular/forms';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {TUI_MASK_CARD} from '@taiga-ui/addon-commerce/constants';\nimport {TUI_PAYMENT_SYSTEM_ICONS} from '@taiga-ui/addon-commerce/tokens';\nimport {tuiControlValue} from '@taiga-ui/cdk/observables';\nimport {TuiTextfieldContent, TuiWithTextfield} from '@taiga-ui/core/components/textfield';\nimport {tuiInjectIconResolver} from '@taiga-ui/core/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\nimport {distinctUntilChanged, map, skip, startWith, switchMap, timer} from 'rxjs';\n\nimport {TUI_INPUT_CARD_OPTIONS} from './input-card.options';\n\n@Component({\n    standalone: true,\n    selector: 'input[tuiInputCard]',\n    imports: [TuiTextfieldContent],\n    template: `\n        <img\n            *tuiTextfieldContent\n            alt=\"\"\n            class=\"t-payment-system\"\n            [hidden]=\"!image()\"\n            [src]=\"image()\"\n        />\n    `,\n    styleUrls: ['./input-card.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [MaskitoDirective, TuiWithTextfield],\n    host: {\n        inputmode: 'numeric',\n        placeholder: '0000 0000 0000 0000',\n        ngSkipHydration: 'true',\n        autocomplete: 'cc-number',\n    },\n})\nexport class TuiInputCard implements OnInit {\n    private readonly icons = inject(TUI_PAYMENT_SYSTEM_ICONS);\n    private readonly options = inject(TUI_INPUT_CARD_OPTIONS);\n    private readonly resolver = tuiInjectIconResolver();\n    private readonly control = inject(NgControl);\n    private readonly value = toSignal(\n        timer(0).pipe(switchMap(() => tuiControlValue<string>(this.control))),\n        {initialValue: ''},\n    );\n\n    private readonly icon = signal<string | null>(this.options.icon);\n\n    private readonly accessor = inject(DefaultValueAccessor, {\n        self: true,\n        optional: true,\n    });\n\n    protected readonly mask = tuiMaskito(TUI_MASK_CARD);\n    protected readonly image = computed(() => {\n        const system = this.options.paymentSystemHandler(this.value());\n        const icon = system && this.icons[system] && this.resolver(this.icons[system]);\n        const url = this.icon() || icon;\n\n        return url && this.icon() !== '' ? url : null;\n    });\n\n    /** @deprecated apparently \"off\" doesn't disable autocomplete */\n    @Input()\n    public autocomplete = this.options.autocomplete;\n\n    @Output()\n    public readonly binChange = toObservable(this.value).pipe(\n        map((value) => (value.length < 6 ? null : value.replace(' ', '').slice(0, 6))),\n        startWith(null),\n        distinctUntilChanged(),\n        skip(1),\n    );\n\n    @Input('icon')\n    public set iconValue(icon: string | null) {\n        this.icon.set(icon);\n    }\n\n    public ngOnInit(): void {\n        if (!this.accessor) {\n            return;\n        }\n\n        const onChanges = this.accessor.onChange.bind(this.accessor);\n\n        this.accessor.onChange = (value: string) => onChanges(value.replaceAll(' ', ''));\n    }\n}\n"]}
@@ -9,4 +9,4 @@ export const TUI_INPUT_CARD_OPTIONS = tuiCreateToken(TUI_INPUT_CARD_DEFAULT_OPTI
9
9
  export function tuiInputCardOptionsProvider(options) {
10
10
  return tuiProvideOptions(TUI_INPUT_CARD_OPTIONS, options, TUI_INPUT_CARD_DEFAULT_OPTIONS);
11
11
  }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY2FyZC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY29tbWVyY2UvY29tcG9uZW50cy9pbnB1dC1jYXJkL2lucHV0LWNhcmQub3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUVuRSxPQUFPLEVBQUMsY0FBYyxFQUFFLGlCQUFpQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFXcEYsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQXdCO0lBQy9ELElBQUksRUFBRSxJQUFJO0lBQ1Ysb0JBQW9CLEVBQUUsbUJBQW1CO0lBQ3pDLFlBQVksRUFBRSxLQUFLO0NBQ3RCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxjQUFjLENBQUMsOEJBQThCLENBQUMsQ0FBQztBQUVyRixNQUFNLFVBQVUsMkJBQTJCLENBQ3ZDLE9BQXFDO0lBRXJDLE9BQU8saUJBQWlCLENBQ3BCLHNCQUFzQixFQUN0QixPQUFPLEVBQ1AsOEJBQThCLENBQ2pDLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1Byb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtUdWlQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdHlwZXMnO1xuaW1wb3J0IHt0dWlHZXRQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdXRpbHMnO1xuaW1wb3J0IHR5cGUge1R1aUhhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvdHlwZXMnO1xuaW1wb3J0IHt0dWlDcmVhdGVUb2tlbiwgdHVpUHJvdmlkZU9wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpSW5wdXRDYXJkT3B0aW9ucyB7XG4gICAgcmVhZG9ubHkgYXV0b2NvbXBsZXRlOiBib29sZWFuO1xuICAgIHJlYWRvbmx5IGljb246IHN0cmluZyB8IG51bGw7XG4gICAgcmVhZG9ubHkgcGF5bWVudFN5c3RlbUhhbmRsZXI6IFR1aUhhbmRsZXI8XG4gICAgICAgIHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQsXG4gICAgICAgIFR1aVBheW1lbnRTeXN0ZW0gfCBudWxsXG4gICAgPjtcbn1cblxuZXhwb3J0IGNvbnN0IFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUzogVHVpSW5wdXRDYXJkT3B0aW9ucyA9IHtcbiAgICBpY29uOiBudWxsLFxuICAgIHBheW1lbnRTeXN0ZW1IYW5kbGVyOiB0dWlHZXRQYXltZW50U3lzdGVtLFxuICAgIGF1dG9jb21wbGV0ZTogZmFsc2UsXG59O1xuXG5leHBvcnQgY29uc3QgVFVJX0lOUFVUX0NBUkRfT1BUSU9OUyA9IHR1aUNyZWF0ZVRva2VuKFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUyk7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlJbnB1dENhcmRPcHRpb25zUHJvdmlkZXIoXG4gICAgb3B0aW9uczogUGFydGlhbDxUdWlJbnB1dENhcmRPcHRpb25zPixcbik6IFByb3ZpZGVyIHtcbiAgICByZXR1cm4gdHVpUHJvdmlkZU9wdGlvbnMoXG4gICAgICAgIFRVSV9JTlBVVF9DQVJEX09QVElPTlMsXG4gICAgICAgIG9wdGlvbnMsXG4gICAgICAgIFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUyxcbiAgICApO1xufVxuIl19
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtY2FyZC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY29tbWVyY2UvY29tcG9uZW50cy9pbnB1dC1jYXJkL2lucHV0LWNhcmQub3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUVuRSxPQUFPLEVBQUMsY0FBYyxFQUFFLGlCQUFpQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFZcEYsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQXdCO0lBQy9ELElBQUksRUFBRSxJQUFJO0lBQ1Ysb0JBQW9CLEVBQUUsbUJBQW1CO0lBQ3pDLFlBQVksRUFBRSxLQUFLO0NBQ3RCLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxjQUFjLENBQUMsOEJBQThCLENBQUMsQ0FBQztBQUVyRixNQUFNLFVBQVUsMkJBQTJCLENBQ3ZDLE9BQXFDO0lBRXJDLE9BQU8saUJBQWlCLENBQ3BCLHNCQUFzQixFQUN0QixPQUFPLEVBQ1AsOEJBQThCLENBQ2pDLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1Byb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtUdWlQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdHlwZXMnO1xuaW1wb3J0IHt0dWlHZXRQYXltZW50U3lzdGVtfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY29tbWVyY2UvdXRpbHMnO1xuaW1wb3J0IHR5cGUge1R1aUhhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvdHlwZXMnO1xuaW1wb3J0IHt0dWlDcmVhdGVUb2tlbiwgdHVpUHJvdmlkZU9wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpSW5wdXRDYXJkT3B0aW9ucyB7XG4gICAgLyoqIEBkZXByZWNhdGVkIGFwcGFyZW50bHkgXCJvZmZcIiBkb2Vzbid0IGRpc2FibGUgYXV0b2NvbXBsZXRlICovXG4gICAgcmVhZG9ubHkgYXV0b2NvbXBsZXRlOiBib29sZWFuO1xuICAgIHJlYWRvbmx5IGljb246IHN0cmluZyB8IG51bGw7XG4gICAgcmVhZG9ubHkgcGF5bWVudFN5c3RlbUhhbmRsZXI6IFR1aUhhbmRsZXI8XG4gICAgICAgIHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQsXG4gICAgICAgIFR1aVBheW1lbnRTeXN0ZW0gfCBudWxsXG4gICAgPjtcbn1cblxuZXhwb3J0IGNvbnN0IFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUzogVHVpSW5wdXRDYXJkT3B0aW9ucyA9IHtcbiAgICBpY29uOiBudWxsLFxuICAgIHBheW1lbnRTeXN0ZW1IYW5kbGVyOiB0dWlHZXRQYXltZW50U3lzdGVtLFxuICAgIGF1dG9jb21wbGV0ZTogZmFsc2UsXG59O1xuXG5leHBvcnQgY29uc3QgVFVJX0lOUFVUX0NBUkRfT1BUSU9OUyA9IHR1aUNyZWF0ZVRva2VuKFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUyk7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlJbnB1dENhcmRPcHRpb25zUHJvdmlkZXIoXG4gICAgb3B0aW9uczogUGFydGlhbDxUdWlJbnB1dENhcmRPcHRpb25zPixcbik6IFByb3ZpZGVyIHtcbiAgICByZXR1cm4gdHVpUHJvdmlkZU9wdGlvbnMoXG4gICAgICAgIFRVSV9JTlBVVF9DQVJEX09QVElPTlMsXG4gICAgICAgIG9wdGlvbnMsXG4gICAgICAgIFRVSV9JTlBVVF9DQVJEX0RFRkFVTFRfT1BUSU9OUyxcbiAgICApO1xufVxuIl19