@taiga-ui/kit 3.10.0 → 3.11.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 (67) hide show
  1. package/bundles/taiga-ui-kit-components-input-date-time.umd.js +3 -1
  2. package/bundles/taiga-ui-kit-components-input-date-time.umd.js.map +1 -1
  3. package/bundles/taiga-ui-kit-components-input-date.umd.js +3 -1
  4. package/bundles/taiga-ui-kit-components-input-date.umd.js.map +1 -1
  5. package/bundles/taiga-ui-kit-components-input-files.umd.js +246 -69
  6. package/bundles/taiga-ui-kit-components-input-files.umd.js.map +1 -1
  7. package/bundles/taiga-ui-kit-components-input-month-range.umd.js +16 -2
  8. package/bundles/taiga-ui-kit-components-input-month-range.umd.js.map +1 -1
  9. package/bundles/taiga-ui-kit-components-input-month.umd.js +17 -3
  10. package/bundles/taiga-ui-kit-components-input-month.umd.js.map +1 -1
  11. package/bundles/taiga-ui-kit-components-stepper.umd.js +20 -13
  12. package/bundles/taiga-ui-kit-components-stepper.umd.js.map +1 -1
  13. package/bundles/taiga-ui-kit-components-tiles.umd.js +619 -0
  14. package/bundles/taiga-ui-kit-components-tiles.umd.js.map +1 -0
  15. package/bundles/taiga-ui-kit-components.umd.js +10 -4
  16. package/bundles/taiga-ui-kit-components.umd.js.map +1 -1
  17. package/components/index.d.ts +1 -0
  18. package/components/input-files/index.d.ts +2 -0
  19. package/components/input-files/input-files.component.d.ts +19 -5
  20. package/components/input-files/input-files.directive.d.ts +20 -0
  21. package/components/input-files/input-files.module.d.ts +8 -7
  22. package/components/input-files/input-files.options.d.ts +17 -0
  23. package/components/input-month/input-month.component.d.ts +4 -2
  24. package/components/input-month-range/input-month-range.component.d.ts +4 -2
  25. package/components/stepper/stepper.component.d.ts +3 -2
  26. package/components/tiles/index.d.ts +4 -0
  27. package/components/tiles/package.json +10 -0
  28. package/components/tiles/taiga-ui-kit-components-tiles.d.ts +5 -0
  29. package/components/tiles/tile-handle.directive.d.ts +13 -0
  30. package/components/tiles/tile.component.d.ts +30 -0
  31. package/components/tiles/tiles.component.d.ts +12 -0
  32. package/components/tiles/tiles.module.d.ts +10 -0
  33. package/esm2015/components/index.js +2 -1
  34. package/esm2015/components/input-date/input-date.component.js +5 -3
  35. package/esm2015/components/input-date-time/input-date-time.component.js +5 -3
  36. package/esm2015/components/input-files/index.js +3 -1
  37. package/esm2015/components/input-files/input-files.component.js +75 -26
  38. package/esm2015/components/input-files/input-files.directive.js +77 -0
  39. package/esm2015/components/input-files/input-files.module.js +12 -3
  40. package/esm2015/components/input-files/input-files.options.js +16 -0
  41. package/esm2015/components/input-month/input-month.component.js +15 -5
  42. package/esm2015/components/input-month-range/input-month-range.component.js +14 -4
  43. package/esm2015/components/stepper/step/step.component.js +1 -1
  44. package/esm2015/components/stepper/stepper.component.js +12 -9
  45. package/esm2015/components/tiles/index.js +5 -0
  46. package/esm2015/components/tiles/taiga-ui-kit-components-tiles.js +5 -0
  47. package/esm2015/components/tiles/tile-handle.directive.js +53 -0
  48. package/esm2015/components/tiles/tile.component.js +101 -0
  49. package/esm2015/components/tiles/tiles.component.js +77 -0
  50. package/esm2015/components/tiles/tiles.module.js +20 -0
  51. package/fesm2015/taiga-ui-kit-components-input-date-time.js +4 -2
  52. package/fesm2015/taiga-ui-kit-components-input-date-time.js.map +1 -1
  53. package/fesm2015/taiga-ui-kit-components-input-date.js +4 -2
  54. package/fesm2015/taiga-ui-kit-components-input-date.js.map +1 -1
  55. package/fesm2015/taiga-ui-kit-components-input-files.js +167 -29
  56. package/fesm2015/taiga-ui-kit-components-input-files.js.map +1 -1
  57. package/fesm2015/taiga-ui-kit-components-input-month-range.js +13 -3
  58. package/fesm2015/taiga-ui-kit-components-input-month-range.js.map +1 -1
  59. package/fesm2015/taiga-ui-kit-components-input-month.js +14 -4
  60. package/fesm2015/taiga-ui-kit-components-input-month.js.map +1 -1
  61. package/fesm2015/taiga-ui-kit-components-stepper.js +12 -9
  62. package/fesm2015/taiga-ui-kit-components-stepper.js.map +1 -1
  63. package/fesm2015/taiga-ui-kit-components-tiles.js +241 -0
  64. package/fesm2015/taiga-ui-kit-components-tiles.js.map +1 -0
  65. package/fesm2015/taiga-ui-kit-components.js +1 -0
  66. package/fesm2015/taiga-ui-kit-components.js.map +1 -1
  67. package/package.json +4 -4
@@ -1,7 +1,7 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
3
3
  import { NgControl } from '@angular/forms';
4
- import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, tuiAsControl, tuiAsFocusableItemAccessor, TuiDay, tuiDefaultProp, } from '@taiga-ui/cdk';
4
+ import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, tuiAsControl, tuiAsFocusableItemAccessor, tuiDateClamp, TuiDay, tuiDefaultProp, } from '@taiga-ui/cdk';
5
5
  import { TuiMonthPipe, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
6
6
  import { TUI_MONTH_FORMATTER_PROVIDER } from '@taiga-ui/kit/providers';
7
7
  import { TUI_INPUT_DATE_OPTIONS, TUI_MONTH_FORMATTER, } from '@taiga-ui/kit/tokens';
@@ -19,12 +19,17 @@ export class TuiInputMonthComponent extends AbstractTuiNullableControl {
19
19
  this.min = this.options.min;
20
20
  this.max = this.options.max;
21
21
  this.disabledItemHandler = ALWAYS_FALSE_HANDLER;
22
+ this.defaultActiveYear = TuiDay.currentLocal();
22
23
  this.open = false;
23
- this.activeYear = this.value || TuiDay.currentLocal();
24
24
  }
25
25
  get nativeFocusableElement() {
26
26
  return this.textfield ? this.textfield.nativeFocusableElement : null;
27
27
  }
28
+ get computedDefaultActiveYear() {
29
+ return (this.activeYear ||
30
+ this.value ||
31
+ tuiDateClamp(this.defaultActiveYear, this.min, this.max));
32
+ }
28
33
  get focused() {
29
34
  return !!this.textfield && this.textfield.focused;
30
35
  }
@@ -60,12 +65,12 @@ export class TuiInputMonthComponent extends AbstractTuiNullableControl {
60
65
  }
61
66
  }
62
67
  TuiInputMonthComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiInputMonthComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_MONTH_FORMATTER }, { token: TUI_INPUT_DATE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
63
- TuiInputMonthComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiInputMonthComponent, selector: "tui-input-month", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler" }, providers: [
68
+ TuiInputMonthComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiInputMonthComponent, selector: "tui-input-month", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler", defaultActiveYear: "defaultActiveYear" }, providers: [
64
69
  tuiAsFocusableItemAccessor(TuiInputMonthComponent),
65
70
  tuiAsControl(TuiInputMonthComponent),
66
71
  TUI_MONTH_FORMATTER_PROVIDER,
67
72
  TuiMonthPipe,
68
- ], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"dropdown\"\n [open]=\"open && interactive\"\n (openChange)=\"onOpenChange($event)\"\n>\n <tui-primitive-textfield\n class=\"t-textfield\"\n [editable]=\"false\"\n [disabled]=\"computedDisabled\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [invalid]=\"computedInvalid\"\n [value]=\"(value | tuiMapper: formatter | async) || ''\"\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\n <ng-template #dropdown>\n <tui-calendar-month\n tuiPreventDefault=\"mousedown\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [min]=\"min\"\n [max]=\"max\"\n [value]=\"value\"\n [(year)]=\"activeYear\"\n (monthClick)=\"onMonthClick($event)\"\n ></tui-calendar-month>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiCalendarMonthComponent, selector: "tui-calendar-month", inputs: ["value", "year", "disabledItemHandler", "min", "max"], outputs: ["monthClick", "hoveredItemChange", "yearChange"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]" }], pipes: { "async": i4.AsyncPipe, "tuiMapper": i3.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
73
+ ], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"dropdown\"\n [open]=\"open && interactive\"\n (openChange)=\"onOpenChange($event)\"\n>\n <tui-primitive-textfield\n class=\"t-textfield\"\n [editable]=\"false\"\n [disabled]=\"computedDisabled\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [invalid]=\"computedInvalid\"\n [value]=\"(value | tuiMapper: formatter | async) || ''\"\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\n <ng-template #dropdown>\n <tui-calendar-month\n tuiPreventDefault=\"mousedown\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [min]=\"min\"\n [max]=\"max\"\n [value]=\"value\"\n [year]=\"computedDefaultActiveYear\"\n (yearChange)=\"activeYear = $event\"\n (monthClick)=\"onMonthClick($event)\"\n ></tui-calendar-month>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiCalendarMonthComponent, selector: "tui-calendar-month", inputs: ["value", "year", "disabledItemHandler", "min", "max"], outputs: ["monthClick", "hoveredItemChange", "yearChange"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]" }], pipes: { "async": i4.AsyncPipe, "tuiMapper": i3.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
69
74
  __decorate([
70
75
  tuiDefaultProp()
71
76
  ], TuiInputMonthComponent.prototype, "min", void 0);
@@ -75,6 +80,9 @@ __decorate([
75
80
  __decorate([
76
81
  tuiDefaultProp()
77
82
  ], TuiInputMonthComponent.prototype, "disabledItemHandler", void 0);
83
+ __decorate([
84
+ tuiDefaultProp()
85
+ ], TuiInputMonthComponent.prototype, "defaultActiveYear", void 0);
78
86
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiInputMonthComponent, decorators: [{
79
87
  type: Component,
80
88
  args: [{
@@ -114,5 +122,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
114
122
  type: Input
115
123
  }], disabledItemHandler: [{
116
124
  type: Input
125
+ }], defaultActiveYear: [{
126
+ type: Input
117
127
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-month.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-month/input-month.component.ts","../../../../../projects/kit/components/input-month/input-month.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    TuiDay,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiHandler,\n    TuiMonth,\n    TuiYear,\n} from '@taiga-ui/cdk';\nimport {\n    TuiMonthPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TUI_MONTH_FORMATTER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MONTH_FORMATTER,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: `tui-input-month`,\n    templateUrl: `./input-month.template.html`,\n    styleUrls: [`./input-month.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputMonthComponent),\n        tuiAsControl(TuiInputMonthComponent),\n        TUI_MONTH_FORMATTER_PROVIDER,\n        TuiMonthPipe,\n    ],\n})\nexport class TuiInputMonthComponent\n    extends AbstractTuiNullableControl<TuiMonth>\n    implements TuiWithOptionalMinMax<TuiMonth>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    min: TuiMonth = this.options.min;\n\n    @Input()\n    @tuiDefaultProp()\n    max: TuiMonth = this.options.max;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<TuiMonth> = ALWAYS_FALSE_HANDLER;\n\n    open = false;\n    activeYear: TuiYear = this.value || TuiDay.currentLocal();\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_MONTH_FORMATTER)\n        readonly formatter: TuiHandler<TuiMonth | null, Observable<string>>,\n        @Inject(TUI_INPUT_DATE_OPTIONS)\n        private readonly options: TuiInputDateOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    onValueChange(value: string): void {\n        if (value) {\n            return;\n        }\n\n        this.updateValue(null);\n        this.onOpenChange(true);\n    }\n\n    onMonthClick(month: TuiMonth): void {\n        this.updateValue(month);\n        this.close();\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    onOpenChange(open: boolean): void {\n        if (open && this.value) {\n            this.activeYear = this.value;\n        }\n\n        this.open = open;\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-primitive-textfield\n        class=\"t-textfield\"\n        [editable]=\"false\"\n        [disabled]=\"computedDisabled\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldIcon]=\"calendarIcon\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [invalid]=\"computedInvalid\"\n        [value]=\"(value | tuiMapper: formatter | async) || ''\"\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\n    <ng-template #dropdown>\n        <tui-calendar-month\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [min]=\"min\"\n            [max]=\"max\"\n            [value]=\"value\"\n            [(year)]=\"activeYear\"\n            (monthClick)=\"onMonthClick($event)\"\n        ></tui-calendar-month>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-month.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-month/input-month.component.ts","../../../../../projects/kit/components/input-month/input-month.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    tuiDateClamp,\n    TuiDay,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiHandler,\n    TuiMonth,\n    TuiYear,\n} from '@taiga-ui/cdk';\nimport {\n    TuiMonthPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TUI_MONTH_FORMATTER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MONTH_FORMATTER,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: `tui-input-month`,\n    templateUrl: `./input-month.template.html`,\n    styleUrls: [`./input-month.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputMonthComponent),\n        tuiAsControl(TuiInputMonthComponent),\n        TUI_MONTH_FORMATTER_PROVIDER,\n        TuiMonthPipe,\n    ],\n})\nexport class TuiInputMonthComponent\n    extends AbstractTuiNullableControl<TuiMonth>\n    implements TuiWithOptionalMinMax<TuiMonth>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    min: TuiMonth = this.options.min;\n\n    @Input()\n    @tuiDefaultProp()\n    max: TuiMonth = this.options.max;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandler<TuiMonth> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    defaultActiveYear: TuiYear = TuiDay.currentLocal();\n\n    activeYear?: TuiYear;\n\n    open = false;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_MONTH_FORMATTER)\n        readonly formatter: TuiHandler<TuiMonth | null, Observable<string>>,\n        @Inject(TUI_INPUT_DATE_OPTIONS)\n        private readonly options: TuiInputDateOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get computedDefaultActiveYear(): TuiYear {\n        return (\n            this.activeYear ||\n            this.value ||\n            tuiDateClamp(this.defaultActiveYear, this.min, this.max)\n        );\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    onValueChange(value: string): void {\n        if (value) {\n            return;\n        }\n\n        this.updateValue(null);\n        this.onOpenChange(true);\n    }\n\n    onMonthClick(month: TuiMonth): void {\n        this.updateValue(month);\n        this.close();\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    onOpenChange(open: boolean): void {\n        if (open && this.value) {\n            this.activeYear = this.value;\n        }\n\n        this.open = open;\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-primitive-textfield\n        class=\"t-textfield\"\n        [editable]=\"false\"\n        [disabled]=\"computedDisabled\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldIcon]=\"calendarIcon\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [invalid]=\"computedInvalid\"\n        [value]=\"(value | tuiMapper: formatter | async) || ''\"\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\n    <ng-template #dropdown>\n        <tui-calendar-month\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [min]=\"min\"\n            [max]=\"max\"\n            [value]=\"value\"\n            [year]=\"computedDefaultActiveYear\"\n            (yearChange)=\"activeYear = $event\"\n            (monthClick)=\"onMonthClick($event)\"\n        ></tui-calendar-month>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
@@ -1,7 +1,7 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
3
3
  import { NgControl } from '@angular/forms';
4
- import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, CHAR_EN_DASH, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, TuiMonthRange, } from '@taiga-ui/cdk';
4
+ import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, CHAR_EN_DASH, tuiAsControl, tuiAsFocusableItemAccessor, tuiDateClamp, TuiDay, tuiDefaultProp, TuiMonthRange, } from '@taiga-ui/cdk';
5
5
  import { TuiMonthPipe, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
6
6
  import { TUI_MONTH_FORMATTER_PROVIDER } from '@taiga-ui/kit/providers';
7
7
  import { TUI_INPUT_DATE_OPTIONS, TUI_MONTH_FORMATTER, } from '@taiga-ui/kit/tokens';
@@ -19,11 +19,16 @@ export class TuiInputMonthRangeComponent extends AbstractTuiNullableControl {
19
19
  this.min = this.options.min;
20
20
  this.max = this.options.max;
21
21
  this.disabledItemHandler = ALWAYS_FALSE_HANDLER;
22
+ this.defaultActiveYear = TuiDay.currentLocal();
22
23
  this.open = false;
23
24
  }
24
25
  get nativeFocusableElement() {
25
26
  return this.textfield ? this.textfield.nativeFocusableElement : null;
26
27
  }
28
+ get computedDefaultActiveYear() {
29
+ var _a;
30
+ return (((_a = this.value) === null || _a === void 0 ? void 0 : _a.from) || tuiDateClamp(this.defaultActiveYear, this.min, this.max));
31
+ }
27
32
  get focused() {
28
33
  return !!this.textfield && this.textfield.focused;
29
34
  }
@@ -71,12 +76,12 @@ export class TuiInputMonthRangeComponent extends AbstractTuiNullableControl {
71
76
  }
72
77
  }
73
78
  TuiInputMonthRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiInputMonthRangeComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_MONTH_FORMATTER }, { token: TUI_INPUT_DATE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
74
- TuiInputMonthRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiInputMonthRangeComponent, selector: "tui-input-month-range", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler" }, providers: [
79
+ TuiInputMonthRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiInputMonthRangeComponent, selector: "tui-input-month-range", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler", defaultActiveYear: "defaultActiveYear" }, providers: [
75
80
  tuiAsFocusableItemAccessor(TuiInputMonthRangeComponent),
76
81
  tuiAsControl(TuiInputMonthRangeComponent),
77
82
  TUI_MONTH_FORMATTER_PROVIDER,
78
83
  TuiMonthPipe,
79
- ], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"dropdown\"\n [open]=\"open && interactive\"\n (openChange)=\"onOpenChange($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n class=\"t-textfield\"\n [editable]=\"false\"\n [disabled]=\"computedDisabled\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [invalid]=\"computedInvalid\"\n [value]=\"\n value\n ? computeValue(value.from | tuiMapper: formatter | async, value.to | tuiMapper: formatter | async)\n : ''\n \"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n </tui-primitive-textfield>\n\n <ng-template #dropdown>\n <tui-calendar-month\n tuiPreventDefault=\"mousedown\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [min]=\"min\"\n [max]=\"max\"\n [value]=\"value\"\n (monthClick)=\"onMonthClick($event)\"\n ></tui-calendar-month>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiCalendarMonthComponent, selector: "tui-calendar-month", inputs: ["value", "year", "disabledItemHandler", "min", "max"], outputs: ["monthClick", "hoveredItemChange", "yearChange"] }], directives: [{ type: i3.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]" }], pipes: { "async": i4.AsyncPipe, "tuiMapper": i3.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
84
+ ], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"dropdown\"\n [open]=\"open && interactive\"\n (openChange)=\"onOpenChange($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n class=\"t-textfield\"\n [editable]=\"false\"\n [disabled]=\"computedDisabled\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [invalid]=\"computedInvalid\"\n [value]=\"\n value\n ? computeValue(value.from | tuiMapper: formatter | async, value.to | tuiMapper: formatter | async)\n : ''\n \"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n </tui-primitive-textfield>\n\n <ng-template #dropdown>\n <tui-calendar-month\n tuiPreventDefault=\"mousedown\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [min]=\"min\"\n [max]=\"max\"\n [value]=\"value\"\n [year]=\"computedDefaultActiveYear\"\n (monthClick)=\"onMonthClick($event)\"\n ></tui-calendar-month>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiCalendarMonthComponent, selector: "tui-calendar-month", inputs: ["value", "year", "disabledItemHandler", "min", "max"], outputs: ["monthClick", "hoveredItemChange", "yearChange"] }], directives: [{ type: i3.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]" }], pipes: { "async": i4.AsyncPipe, "tuiMapper": i3.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
80
85
  __decorate([
81
86
  tuiDefaultProp()
82
87
  ], TuiInputMonthRangeComponent.prototype, "min", void 0);
@@ -86,6 +91,9 @@ __decorate([
86
91
  __decorate([
87
92
  tuiDefaultProp()
88
93
  ], TuiInputMonthRangeComponent.prototype, "disabledItemHandler", void 0);
94
+ __decorate([
95
+ tuiDefaultProp()
96
+ ], TuiInputMonthRangeComponent.prototype, "defaultActiveYear", void 0);
89
97
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiInputMonthRangeComponent, decorators: [{
90
98
  type: Component,
91
99
  args: [{
@@ -125,5 +133,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
125
133
  type: Input
126
134
  }], disabledItemHandler: [{
127
135
  type: Input
136
+ }], defaultActiveYear: [{
137
+ type: Input
128
138
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-month-range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-month-range/input-month-range.component.ts","../../../../../projects/kit/components/input-month-range/input-month-range.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    CHAR_EN_DASH,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiHandler,\n    TuiMonth,\n    TuiMonthRange,\n} from '@taiga-ui/cdk';\nimport {\n    TuiMonthPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiMonthContext} from '@taiga-ui/kit/interfaces';\nimport {TUI_MONTH_FORMATTER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MONTH_FORMATTER,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {TuiBooleanHandlerWithContext} from '@taiga-ui/kit/types';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: `tui-input-month-range`,\n    templateUrl: `./input-month-range.template.html`,\n    styleUrls: [`./input-month-range.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputMonthRangeComponent),\n        tuiAsControl(TuiInputMonthRangeComponent),\n        TUI_MONTH_FORMATTER_PROVIDER,\n        TuiMonthPipe,\n    ],\n})\nexport class TuiInputMonthRangeComponent\n    extends AbstractTuiNullableControl<TuiMonthRange>\n    implements TuiWithOptionalMinMax<TuiMonth>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    min: TuiMonth = this.options.min;\n\n    @Input()\n    @tuiDefaultProp()\n    max: TuiMonth = this.options.max;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandlerWithContext<TuiMonth, TuiMonthContext> =\n        ALWAYS_FALSE_HANDLER;\n\n    open = false;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_MONTH_FORMATTER)\n        readonly formatter: TuiHandler<TuiMonth | null, Observable<string>>,\n        @Inject(TUI_INPUT_DATE_OPTIONS)\n        private readonly options: TuiInputDateOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    computeValue(from: string | null, to: string | null): string {\n        const formattedTo = from === to && this.focused && !this.readOnly ? `` : to;\n\n        return `${from} ${CHAR_EN_DASH} ${formattedTo}`;\n    }\n\n    onValueChange(value: string): void {\n        if (value) {\n            return;\n        }\n\n        this.updateValue(null);\n        this.onOpenChange(true);\n    }\n\n    onMonthClick(month: TuiMonth): void {\n        if (this.value === null || !this.value.isSingleMonth) {\n            this.writeValue(new TuiMonthRange(month, month));\n\n            return;\n        }\n\n        this.updateValue(TuiMonthRange.sort(this.value.from, month));\n        this.close();\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onActiveZone(focused: boolean): void {\n        this.updateFocused(focused);\n\n        if (focused) {\n            return;\n        }\n\n        if (this.value?.isSingleMonth) {\n            this.updateValue(new TuiMonthRange(this.value.from, this.value.from));\n        }\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive\"\n    (openChange)=\"onOpenChange($event)\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        class=\"t-textfield\"\n        [editable]=\"false\"\n        [disabled]=\"computedDisabled\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldIcon]=\"calendarIcon\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [invalid]=\"computedInvalid\"\n        [value]=\"\n            value\n                ? computeValue(value.from | tuiMapper: formatter | async, value.to | tuiMapper: formatter | async)\n                : ''\n        \"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n\n    <ng-template #dropdown>\n        <tui-calendar-month\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [min]=\"min\"\n            [max]=\"max\"\n            [value]=\"value\"\n            (monthClick)=\"onMonthClick($event)\"\n        ></tui-calendar-month>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-month-range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-month-range/input-month-range.component.ts","../../../../../projects/kit/components/input-month-range/input-month-range.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    ALWAYS_FALSE_HANDLER,\n    CHAR_EN_DASH,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    tuiDateClamp,\n    TuiDay,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiHandler,\n    TuiMonth,\n    TuiMonthRange,\n    TuiYear,\n} from '@taiga-ui/cdk';\nimport {\n    TuiMonthPipe,\n    TuiPrimitiveTextfieldComponent,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiMonthContext} from '@taiga-ui/kit/interfaces';\nimport {TUI_MONTH_FORMATTER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MONTH_FORMATTER,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {TuiBooleanHandlerWithContext} from '@taiga-ui/kit/types';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: `tui-input-month-range`,\n    templateUrl: `./input-month-range.template.html`,\n    styleUrls: [`./input-month-range.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputMonthRangeComponent),\n        tuiAsControl(TuiInputMonthRangeComponent),\n        TUI_MONTH_FORMATTER_PROVIDER,\n        TuiMonthPipe,\n    ],\n})\nexport class TuiInputMonthRangeComponent\n    extends AbstractTuiNullableControl<TuiMonthRange>\n    implements TuiWithOptionalMinMax<TuiMonth>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    min: TuiMonth = this.options.min;\n\n    @Input()\n    @tuiDefaultProp()\n    max: TuiMonth = this.options.max;\n\n    @Input()\n    @tuiDefaultProp()\n    disabledItemHandler: TuiBooleanHandlerWithContext<TuiMonth, TuiMonthContext> =\n        ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    @tuiDefaultProp()\n    defaultActiveYear: TuiYear = TuiDay.currentLocal();\n\n    open = false;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_MONTH_FORMATTER)\n        readonly formatter: TuiHandler<TuiMonth | null, Observable<string>>,\n        @Inject(TUI_INPUT_DATE_OPTIONS)\n        private readonly options: TuiInputDateOptions,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get computedDefaultActiveYear(): TuiYear {\n        return (\n            this.value?.from || tuiDateClamp(this.defaultActiveYear, this.min, this.max)\n        );\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    computeValue(from: string | null, to: string | null): string {\n        const formattedTo = from === to && this.focused && !this.readOnly ? `` : to;\n\n        return `${from} ${CHAR_EN_DASH} ${formattedTo}`;\n    }\n\n    onValueChange(value: string): void {\n        if (value) {\n            return;\n        }\n\n        this.updateValue(null);\n        this.onOpenChange(true);\n    }\n\n    onMonthClick(month: TuiMonth): void {\n        if (this.value === null || !this.value.isSingleMonth) {\n            this.writeValue(new TuiMonthRange(month, month));\n\n            return;\n        }\n\n        this.updateValue(TuiMonthRange.sort(this.value.from, month));\n        this.close();\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onActiveZone(focused: boolean): void {\n        this.updateFocused(focused);\n\n        if (focused) {\n            return;\n        }\n\n        if (this.value?.isSingleMonth) {\n            this.updateValue(new TuiMonthRange(this.value.from, this.value.from));\n        }\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.close();\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive\"\n    (openChange)=\"onOpenChange($event)\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        class=\"t-textfield\"\n        [editable]=\"false\"\n        [disabled]=\"computedDisabled\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldIcon]=\"calendarIcon\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [invalid]=\"computedInvalid\"\n        [value]=\"\n            value\n                ? computeValue(value.from | tuiMapper: formatter | async, value.to | tuiMapper: formatter | async)\n                : ''\n        \"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n\n    <ng-template #dropdown>\n        <tui-calendar-month\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [min]=\"min\"\n            [max]=\"max\"\n            [value]=\"value\"\n            [year]=\"computedDefaultActiveYear\"\n            (monthClick)=\"onMonthClick($event)\"\n        ></tui-calendar-month>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
@@ -44,7 +44,7 @@ export class TuiStepComponent {
44
44
  }
45
45
  }
46
46
  TuiStepComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiStepComponent, deps: [{ token: TuiFocusVisibleService }, { token: TuiRouterLinkActiveService }, { token: TuiStepperComponent }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Component });
47
- TuiStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiStepComponent, selector: "button[tuiStep], a[tuiStep]:not([routerLink]), a[tuiStep][routerLink][routerLinkActive]", inputs: { stepState: "stepState", icon: "icon" }, host: { attributes: { "type": "button" }, listeners: { "click": "activate()" }, properties: { "attr.data-state": "this.stepState", "class._focus-visible": "this.focusVisible", "class._active": "this.isActive", "class._vertical": "this.isVertical", "tabIndex": "this.tabIndex" } }, providers: [TuiDestroyService, TuiRouterLinkActiveService, TuiFocusVisibleService], ngImport: i0, template: "<tui-svg\n *ngIf=\"icon\"\n class=\"t-marker t-marker_custom\"\n [src]=\"icon\"\n></tui-svg>\n<tui-svg\n src=\"tuiIconWarningLarge\"\n class=\"t-marker t-marker_error\"\n></tui-svg>\n<tui-svg\n src=\"tuiIconCheckLarge\"\n class=\"t-marker t-marker_pass\"\n></tui-svg>\n<div class=\"t-marker t-marker_index\"></div>\n<ng-content></ng-content>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;position:relative;display:flex;align-items:center;flex-shrink:0;color:var(--tui-link);margin-right:2rem;outline:none;cursor:pointer;text-decoration:none;counter-increment:steps}:host:disabled{pointer-events:none;color:var(--tui-base-07)}:host:hover{color:var(--tui-link-hover)}:host:not(:last-of-type)._vertical{margin-bottom:1.25rem}:host._active,:host._active:hover{color:var(--tui-text-01);cursor:default}:host._focus-visible:before{content:\"\";position:absolute;left:2.75rem;right:0;top:50%;height:1.5rem;margin-top:-.75rem;background:var(--tui-selection)}.t-marker{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;width:2rem;height:2rem;border-radius:100%;margin-right:.75rem;flex-shrink:0;align-items:center;justify-content:center;background:var(--tui-secondary);color:var(--tui-link)}:host:disabled .t-marker{background:var(--tui-base-03);color:var(--tui-base-07)}.t-marker_index:before{content:counter(steps)}:host:hover .t-marker_index{color:var(--tui-link-hover);background:var(--tui-secondary-hover)}:host._active .t-marker_index{color:var(--tui-primary-text);background:var(--tui-primary)}:host:not([data-state=\"normal\"]):not(._active) .t-marker_index,:host:not(._active) .t-marker_custom~.t-marker_index{display:none}.t-marker_error{background:var(--tui-error-bg);color:var(--tui-error-fill)}:host:hover .t-marker_error{background:var(--tui-error-bg-hover);color:var(--tui-error-fill)}:host:not([data-state=\"error\"]) .t-marker_error,:host._active .t-marker_error{display:none}:host:not([data-state=\"pass\"]) .t-marker_pass,:host._active .t-marker_pass{display:none}:host:not([data-state=\"normal\"]) .t-marker_custom,:host._active .t-marker_custom{display:none}:host:hover .t-marker_custom{color:var(--tui-link-hover);background:var(--tui-secondary-hover)}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
47
+ TuiStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiStepComponent, selector: "button[tuiStep], a[tuiStep]:not([routerLink]), a[tuiStep][routerLink][routerLinkActive]", inputs: { stepState: "stepState", icon: "icon" }, host: { attributes: { "type": "button" }, listeners: { "click": "activate()" }, properties: { "attr.data-state": "this.stepState", "class._focus-visible": "this.focusVisible", "class._active": "this.isActive", "class._vertical": "this.isVertical", "tabIndex": "this.tabIndex" } }, providers: [TuiDestroyService, TuiRouterLinkActiveService, TuiFocusVisibleService], ngImport: i0, template: "<tui-svg\n *ngIf=\"icon\"\n class=\"t-marker t-marker_custom\"\n [src]=\"icon\"\n></tui-svg>\n<tui-svg\n src=\"tuiIconWarningLarge\"\n class=\"t-marker t-marker_error\"\n></tui-svg>\n<tui-svg\n src=\"tuiIconCheckLarge\"\n class=\"t-marker t-marker_pass\"\n></tui-svg>\n<div class=\"t-marker t-marker_index\"></div>\n<ng-content></ng-content>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;position:relative;display:flex;align-items:center;flex-shrink:0;color:var(--tui-link);margin-right:1.5rem;outline:none;cursor:pointer;text-decoration:none;counter-increment:steps}:host:disabled{pointer-events:none;color:var(--tui-base-07)}:host:hover{color:var(--tui-link-hover)}:host:not(:last-of-type)._vertical{margin-bottom:1.25rem}:host._active,:host._active:hover{color:var(--tui-text-01);cursor:default}:host._focus-visible:before{content:\"\";position:absolute;left:2.75rem;right:0;top:50%;height:1.5rem;margin-top:-.75rem;background:var(--tui-selection)}.t-marker{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;width:2rem;height:2rem;border-radius:100%;margin-right:.75rem;flex-shrink:0;align-items:center;justify-content:center;background:var(--tui-secondary);color:var(--tui-link)}:host:disabled .t-marker{background:var(--tui-base-03);color:var(--tui-base-07)}.t-marker_index:before{content:counter(steps)}:host:hover .t-marker_index{color:var(--tui-link-hover);background:var(--tui-secondary-hover)}:host._active .t-marker_index{color:var(--tui-primary-text);background:var(--tui-primary)}:host:not([data-state=\"normal\"]):not(._active) .t-marker_index,:host:not(._active) .t-marker_custom~.t-marker_index{display:none}.t-marker_error{background:var(--tui-error-bg);color:var(--tui-error-fill)}:host:hover .t-marker_error{background:var(--tui-error-bg-hover);color:var(--tui-error-fill)}:host:not([data-state=\"error\"]) .t-marker_error,:host._active .t-marker_error{display:none}:host:not([data-state=\"pass\"]) .t-marker_pass,:host._active .t-marker_pass{display:none}:host:not([data-state=\"normal\"]) .t-marker_custom,:host._active .t-marker_custom{display:none}:host:hover .t-marker_custom{color:var(--tui-link-hover);background:var(--tui-secondary-hover)}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
48
48
  __decorate([
49
49
  tuiDefaultProp()
50
50
  ], TuiStepComponent.prototype, "stepState", void 0);
@@ -19,8 +19,12 @@ export class TuiStepperComponent {
19
19
  constructor() {
20
20
  this.steps = EMPTY_QUERY;
21
21
  this.orientation = `horizontal`;
22
- this.activeItemIndex = 0;
23
22
  this.activeItemIndexChange = new EventEmitter();
23
+ this.activeItemIndex = 0;
24
+ }
25
+ set activeIndex(index) {
26
+ this.activeItemIndex = index;
27
+ this.scrollIntoView(index);
24
28
  }
25
29
  get changes$() {
26
30
  // Delay is required to trigger change detection after steps are rendered
@@ -67,19 +71,17 @@ export class TuiStepperComponent {
67
71
  tuiMoveFocus(index, stepElements, step);
68
72
  }
69
73
  scrollIntoView(targetStepIndex) {
70
- this.getNativeElements(this.steps)[targetStepIndex].scrollIntoView(this.orientation === `vertical`
74
+ var _a;
75
+ (_a = this.getNativeElements(this.steps)[targetStepIndex]) === null || _a === void 0 ? void 0 : _a.scrollIntoView(this.orientation === `vertical`
71
76
  ? ONLY_VERTICAL_SCROLL
72
77
  : ONLY_HORIZONTAL_SCROLL);
73
78
  }
74
79
  }
75
80
  TuiStepperComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiStepperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
76
- TuiStepperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiStepperComponent, selector: "tui-stepper, nav[tuiStepper]", inputs: { orientation: "orientation", activeItemIndex: "activeItemIndex" }, outputs: { activeItemIndexChange: "activeItemIndexChange" }, host: { listeners: { "keydown.arrowRight": "onHorizontal($event,1)", "keydown.arrowLeft": "onHorizontal($event,-1)", "keydown.arrowDown": "onVertical($event,1)", "keydown.arrowUp": "onVertical($event,-1)" }, properties: { "attr.data-orientation": "this.orientation" } }, queries: [{ propertyName: "steps", predicate: i0.forwardRef(function () { return TuiStepComponent; }), read: ElementRef }], ngImport: i0, template: "<ng-container *ngIf=\"changes$ | async\"></ng-container>\n<ng-content></ng-content>\n", styles: [":host{scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;display:flex;overflow:auto;counter-reset:steps}:host::-webkit-scrollbar,:host::-webkit-scrollbar-thumb{background:transparent;width:0;height:0}@media screen and (prefers-reduced-motion: reduce){:host{scroll-behavior:auto}}:host[data-orientation=vertical]{flex-direction:column}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
81
+ TuiStepperComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiStepperComponent, selector: "tui-stepper, nav[tuiStepper]", inputs: { orientation: "orientation", activeIndex: ["activeItemIndex", "activeIndex"] }, outputs: { activeItemIndexChange: "activeItemIndexChange" }, host: { listeners: { "keydown.arrowRight": "onHorizontal($event,1)", "keydown.arrowLeft": "onHorizontal($event,-1)", "keydown.arrowDown": "onVertical($event,1)", "keydown.arrowUp": "onVertical($event,-1)" }, properties: { "attr.data-orientation": "this.orientation" } }, queries: [{ propertyName: "steps", predicate: i0.forwardRef(function () { return TuiStepComponent; }), read: ElementRef }], ngImport: i0, template: "<ng-container *ngIf=\"changes$ | async\"></ng-container>\n<ng-content></ng-content>\n", styles: [":host{scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;display:flex;overflow:auto;counter-reset:steps}:host::-webkit-scrollbar,:host::-webkit-scrollbar-thumb{background:transparent;width:0;height:0}@media screen and (prefers-reduced-motion: reduce){:host{scroll-behavior:auto}}:host[data-orientation=vertical]{flex-direction:column}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
77
82
  __decorate([
78
83
  tuiDefaultProp()
79
84
  ], TuiStepperComponent.prototype, "orientation", void 0);
80
- __decorate([
81
- tuiDefaultProp()
82
- ], TuiStepperComponent.prototype, "activeItemIndex", void 0);
83
85
  __decorate([
84
86
  tuiPure
85
87
  ], TuiStepperComponent.prototype, "changes$", null);
@@ -102,8 +104,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
102
104
  }, {
103
105
  type: HostBinding,
104
106
  args: [`attr.data-orientation`]
105
- }], activeItemIndex: [{
106
- type: Input
107
+ }], activeIndex: [{
108
+ type: Input,
109
+ args: [`activeItemIndex`]
107
110
  }], activeItemIndexChange: [{
108
111
  type: Output
109
112
  }], changes$: [], onHorizontal: [{
@@ -119,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
119
122
  type: HostListener,
120
123
  args: [`keydown.arrowUp`, [`$event`, `-1`]]
121
124
  }], getNativeElements: [] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/stepper/stepper.component.ts","../../../../../projects/kit/components/stepper/stepper.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    QueryList,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiGetOriginalArrayFromQueryList,\n    tuiIsElement,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiOrientation} from '@taiga-ui/core';\nimport {Observable} from 'rxjs';\nimport {delay} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiStepComponent} from './step/step.component';\n\nconst ONLY_HORIZONTAL_SCROLL: ScrollIntoViewOptions = {\n    block: `nearest`,\n    inline: `center`,\n};\n\nconst ONLY_VERTICAL_SCROLL: ScrollIntoViewOptions = {\n    block: `center`,\n    inline: `nearest`,\n};\n\n@Component({\n    selector: `tui-stepper, nav[tuiStepper]`,\n    templateUrl: `./stepper.template.html`,\n    styleUrls: [`./stepper.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiStepperComponent {\n    @ContentChildren(forwardRef(() => TuiStepComponent), {read: ElementRef})\n    private readonly steps: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    @Input()\n    @HostBinding(`attr.data-orientation`)\n    @tuiDefaultProp()\n    orientation: TuiOrientation = `horizontal`;\n\n    @Input()\n    @tuiDefaultProp()\n    activeItemIndex = 0;\n\n    @Output()\n    readonly activeItemIndexChange = new EventEmitter<number>();\n\n    @tuiPure\n    get changes$(): Observable<unknown> {\n        // Delay is required to trigger change detection after steps are rendered\n        // so they can update their \"active\" status\n        return tuiItemsQueryListObservable(this.steps).pipe(delay(0));\n    }\n\n    @HostListener(`keydown.arrowRight`, [`$event`, `1`])\n    @HostListener(`keydown.arrowLeft`, [`$event`, `-1`])\n    onHorizontal(event: Event, step: number): void {\n        if (this.orientation !== `horizontal` || !event.target) {\n            return;\n        }\n\n        event.preventDefault();\n        this.moveFocus(event.target, step);\n    }\n\n    @HostListener(`keydown.arrowDown`, [`$event`, `1`])\n    @HostListener(`keydown.arrowUp`, [`$event`, `-1`])\n    onVertical(event: Event, step: number): void {\n        if (this.orientation !== `vertical` || !event.target) {\n            return;\n        }\n\n        event.preventDefault();\n        this.moveFocus(event.target, step);\n    }\n\n    indexOf(step: HTMLElement): number {\n        return tuiGetOriginalArrayFromQueryList(this.steps).findIndex(\n            ({nativeElement}) => nativeElement === step,\n        );\n    }\n\n    isActive(index: number): boolean {\n        return index === this.activeItemIndex;\n    }\n\n    activate(index: number): void {\n        if (this.activeItemIndex === index) {\n            return;\n        }\n\n        this.activeItemIndex = index;\n        this.activeItemIndexChange.emit(index);\n        this.scrollIntoView(index);\n    }\n\n    @tuiPure\n    private getNativeElements(\n        queryList: QueryList<ElementRef<HTMLElement>>,\n    ): HTMLElement[] {\n        return queryList.map(({nativeElement}) => nativeElement);\n    }\n\n    private moveFocus(current: EventTarget, step: number): void {\n        if (!tuiIsElement(current)) {\n            return;\n        }\n\n        const stepElements = this.getNativeElements(this.steps);\n        const index = stepElements.findIndex(item => item === current);\n\n        tuiMoveFocus(index, stepElements, step);\n    }\n\n    private scrollIntoView(targetStepIndex: number): void {\n        this.getNativeElements(this.steps)[targetStepIndex].scrollIntoView(\n            this.orientation === `vertical`\n                ? ONLY_VERTICAL_SCROLL\n                : ONLY_HORIZONTAL_SCROLL,\n        );\n    }\n}\n","<ng-container *ngIf=\"changes$ | async\"></ng-container>\n<ng-content></ng-content>\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/stepper/stepper.component.ts","../../../../../projects/kit/components/stepper/stepper.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    QueryList,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiGetOriginalArrayFromQueryList,\n    tuiIsElement,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiOrientation} from '@taiga-ui/core';\nimport {Observable} from 'rxjs';\nimport {delay} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiStepComponent} from './step/step.component';\n\nconst ONLY_HORIZONTAL_SCROLL: ScrollIntoViewOptions = {\n    block: `nearest`,\n    inline: `center`,\n};\n\nconst ONLY_VERTICAL_SCROLL: ScrollIntoViewOptions = {\n    block: `center`,\n    inline: `nearest`,\n};\n\n@Component({\n    selector: `tui-stepper, nav[tuiStepper]`,\n    templateUrl: `./stepper.template.html`,\n    styleUrls: [`./stepper.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiStepperComponent {\n    @ContentChildren(forwardRef(() => TuiStepComponent), {read: ElementRef})\n    private readonly steps: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    @Input()\n    @HostBinding(`attr.data-orientation`)\n    @tuiDefaultProp()\n    orientation: TuiOrientation = `horizontal`;\n\n    @Input(`activeItemIndex`)\n    set activeIndex(index: number) {\n        this.activeItemIndex = index;\n        this.scrollIntoView(index);\n    }\n\n    @Output()\n    readonly activeItemIndexChange = new EventEmitter<number>();\n\n    activeItemIndex = 0;\n\n    @tuiPure\n    get changes$(): Observable<unknown> {\n        // Delay is required to trigger change detection after steps are rendered\n        // so they can update their \"active\" status\n        return tuiItemsQueryListObservable(this.steps).pipe(delay(0));\n    }\n\n    @HostListener(`keydown.arrowRight`, [`$event`, `1`])\n    @HostListener(`keydown.arrowLeft`, [`$event`, `-1`])\n    onHorizontal(event: Event, step: number): void {\n        if (this.orientation !== `horizontal` || !event.target) {\n            return;\n        }\n\n        event.preventDefault();\n        this.moveFocus(event.target, step);\n    }\n\n    @HostListener(`keydown.arrowDown`, [`$event`, `1`])\n    @HostListener(`keydown.arrowUp`, [`$event`, `-1`])\n    onVertical(event: Event, step: number): void {\n        if (this.orientation !== `vertical` || !event.target) {\n            return;\n        }\n\n        event.preventDefault();\n        this.moveFocus(event.target, step);\n    }\n\n    indexOf(step: HTMLElement): number {\n        return tuiGetOriginalArrayFromQueryList(this.steps).findIndex(\n            ({nativeElement}) => nativeElement === step,\n        );\n    }\n\n    isActive(index: number): boolean {\n        return index === this.activeItemIndex;\n    }\n\n    activate(index: number): void {\n        if (this.activeItemIndex === index) {\n            return;\n        }\n\n        this.activeItemIndex = index;\n        this.activeItemIndexChange.emit(index);\n        this.scrollIntoView(index);\n    }\n\n    @tuiPure\n    private getNativeElements(\n        queryList: QueryList<ElementRef<HTMLElement>>,\n    ): HTMLElement[] {\n        return queryList.map(({nativeElement}) => nativeElement);\n    }\n\n    private moveFocus(current: EventTarget, step: number): void {\n        if (!tuiIsElement(current)) {\n            return;\n        }\n\n        const stepElements = this.getNativeElements(this.steps);\n        const index = stepElements.findIndex(item => item === current);\n\n        tuiMoveFocus(index, stepElements, step);\n    }\n\n    private scrollIntoView(targetStepIndex: number): void {\n        this.getNativeElements(this.steps)[targetStepIndex]?.scrollIntoView(\n            this.orientation === `vertical`\n                ? ONLY_VERTICAL_SCROLL\n                : ONLY_HORIZONTAL_SCROLL,\n        );\n    }\n}\n","<ng-container *ngIf=\"changes$ | async\"></ng-container>\n<ng-content></ng-content>\n"]}
@@ -0,0 +1,5 @@
1
+ export * from './tile.component';
2
+ export * from './tile-handle.directive';
3
+ export * from './tiles.component';
4
+ export * from './tiles.module';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90aWxlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90aWxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RpbGUtaGFuZGxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RpbGVzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RpbGVzLm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtdGlsZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90aWxlcy90YWlnYS11aS1raXQtY29tcG9uZW50cy10aWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,53 @@
1
+ import { Directive, HostListener, Inject } from '@angular/core';
2
+ import { tuiIsElement } from '@taiga-ui/cdk';
3
+ import { TuiTileComponent } from './tile.component';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "./tile.component";
6
+ export class TuiTileHandleDirective {
7
+ constructor(tile) {
8
+ this.tile = tile;
9
+ this.x = NaN;
10
+ this.y = NaN;
11
+ }
12
+ onStart({ x, y, pointerId, target }) {
13
+ if (tuiIsElement(target)) {
14
+ target.releasePointerCapture(pointerId);
15
+ }
16
+ this.onPointer(x, y);
17
+ }
18
+ onPointer(x = NaN, y = NaN) {
19
+ this.x = x - this.tile.element.offsetLeft;
20
+ this.y = y - this.tile.element.offsetTop;
21
+ this.tile.onDrag(!Number.isNaN(x));
22
+ this.tile.offset$.next([0, 0]);
23
+ }
24
+ onMove(x, y) {
25
+ if (!Number.isNaN(this.x)) {
26
+ this.tile.offset$.next([x - this.x, y - this.y]);
27
+ }
28
+ }
29
+ }
30
+ TuiTileHandleDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiTileHandleDirective, deps: [{ token: TuiTileComponent }], target: i0.ɵɵFactoryTarget.Directive });
31
+ TuiTileHandleDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: TuiTileHandleDirective, selector: "[tuiTileHandle]", host: { listeners: { "pointerdown.silent.prevent": "onStart($event)", "document:pointerup.silent": "onPointer()", "document:pointermove.silent": "onMove($event.x,$event.y)" }, properties: { "style.touchAction": "\"none\"" } }, ngImport: i0 });
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiTileHandleDirective, decorators: [{
33
+ type: Directive,
34
+ args: [{
35
+ selector: `[tuiTileHandle]`,
36
+ host: {
37
+ '[style.touchAction]': `"none"`,
38
+ },
39
+ }]
40
+ }], ctorParameters: function () { return [{ type: i1.TuiTileComponent, decorators: [{
41
+ type: Inject,
42
+ args: [TuiTileComponent]
43
+ }] }]; }, propDecorators: { onStart: [{
44
+ type: HostListener,
45
+ args: [`pointerdown.silent.prevent`, [`$event`]]
46
+ }], onPointer: [{
47
+ type: HostListener,
48
+ args: [`document:pointerup.silent`]
49
+ }], onMove: [{
50
+ type: HostListener,
51
+ args: [`document:pointermove.silent`, [`$event.x`, `$event.y`]]
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdGlsZXMvdGlsZS1oYW5kbGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGtCQUFrQixDQUFDOzs7QUFRbEQsTUFBTSxPQUFPLHNCQUFzQjtJQUkvQixZQUF1RCxJQUFzQjtRQUF0QixTQUFJLEdBQUosSUFBSSxDQUFrQjtRQUhyRSxNQUFDLEdBQUcsR0FBRyxDQUFDO1FBQ1IsTUFBQyxHQUFHLEdBQUcsQ0FBQztJQUVnRSxDQUFDO0lBR2pGLE9BQU8sQ0FBQyxFQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBZTtRQUMzQyxJQUFJLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QixNQUFNLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUFDLENBQUM7U0FDM0M7UUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBR0QsU0FBUyxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxHQUFHLEdBQUc7UUFDdEIsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO1FBQzFDLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztRQUN6QyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBR0QsTUFBTSxDQUFDLENBQVMsRUFBRSxDQUFTO1FBQ3ZCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDcEQ7SUFDTCxDQUFDOztvSEE1QlEsc0JBQXNCLGtCQUlYLGdCQUFnQjt3R0FKM0Isc0JBQXNCOzRGQUF0QixzQkFBc0I7a0JBTmxDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsSUFBSSxFQUFFO3dCQUNGLHFCQUFxQixFQUFFLFFBQVE7cUJBQ2xDO2lCQUNKOzswQkFLZ0IsTUFBTTsyQkFBQyxnQkFBZ0I7NENBR3BDLE9BQU87c0JBRE4sWUFBWTt1QkFBQyw0QkFBNEIsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFVdEQsU0FBUztzQkFEUixZQUFZO3VCQUFDLDJCQUEyQjtnQkFTekMsTUFBTTtzQkFETCxZQUFZO3VCQUFDLDZCQUE2QixFQUFFLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIsIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R1aUlzRWxlbWVudH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbmltcG9ydCB7VHVpVGlsZUNvbXBvbmVudH0gZnJvbSAnLi90aWxlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiBgW3R1aVRpbGVIYW5kbGVdYCxcbiAgICBob3N0OiB7XG4gICAgICAgICdbc3R5bGUudG91Y2hBY3Rpb25dJzogYFwibm9uZVwiYCxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlUaWxlSGFuZGxlRGlyZWN0aXZlIHtcbiAgICBwcml2YXRlIHggPSBOYU47XG4gICAgcHJpdmF0ZSB5ID0gTmFOO1xuXG4gICAgY29uc3RydWN0b3IoQEluamVjdChUdWlUaWxlQ29tcG9uZW50KSBwcml2YXRlIHJlYWRvbmx5IHRpbGU6IFR1aVRpbGVDb21wb25lbnQpIHt9XG5cbiAgICBASG9zdExpc3RlbmVyKGBwb2ludGVyZG93bi5zaWxlbnQucHJldmVudGAsIFtgJGV2ZW50YF0pXG4gICAgb25TdGFydCh7eCwgeSwgcG9pbnRlcklkLCB0YXJnZXR9OiBQb2ludGVyRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgaWYgKHR1aUlzRWxlbWVudCh0YXJnZXQpKSB7XG4gICAgICAgICAgICB0YXJnZXQucmVsZWFzZVBvaW50ZXJDYXB0dXJlKHBvaW50ZXJJZCk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLm9uUG9pbnRlcih4LCB5KTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKGBkb2N1bWVudDpwb2ludGVydXAuc2lsZW50YClcbiAgICBvblBvaW50ZXIoeCA9IE5hTiwgeSA9IE5hTik6IHZvaWQge1xuICAgICAgICB0aGlzLnggPSB4IC0gdGhpcy50aWxlLmVsZW1lbnQub2Zmc2V0TGVmdDtcbiAgICAgICAgdGhpcy55ID0geSAtIHRoaXMudGlsZS5lbGVtZW50Lm9mZnNldFRvcDtcbiAgICAgICAgdGhpcy50aWxlLm9uRHJhZyghTnVtYmVyLmlzTmFOKHgpKTtcbiAgICAgICAgdGhpcy50aWxlLm9mZnNldCQubmV4dChbMCwgMF0pO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoYGRvY3VtZW50OnBvaW50ZXJtb3ZlLnNpbGVudGAsIFtgJGV2ZW50LnhgLCBgJGV2ZW50LnlgXSlcbiAgICBvbk1vdmUoeDogbnVtYmVyLCB5OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgaWYgKCFOdW1iZXIuaXNOYU4odGhpcy54KSkge1xuICAgICAgICAgICAgdGhpcy50aWxlLm9mZnNldCQubmV4dChbeCAtIHRoaXMueCwgeSAtIHRoaXMueV0pO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -0,0 +1,101 @@
1
+ import { __decorate } from "tslib";
2
+ import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, HostListener, Inject, Input, NgZone, } from '@angular/core';
3
+ import { MutationObserverService } from '@ng-web-apis/mutation-observer';
4
+ import { tuiArrayShallowEquals, tuiDefaultProp, TuiResizeService, tuiZonefull, } from '@taiga-ui/cdk';
5
+ import { BehaviorSubject, combineLatest } from 'rxjs';
6
+ import { distinctUntilChanged, map, startWith } from 'rxjs/operators';
7
+ import { TuiTilesComponent } from './tiles.component';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/common";
10
+ import * as i2 from "./tiles.component";
11
+ import * as i3 from "rxjs";
12
+ export class TuiTileComponent {
13
+ constructor(ngZone, elementRef, tiles, resize$, mutation$) {
14
+ this.ngZone = ngZone;
15
+ this.elementRef = elementRef;
16
+ this.tiles = tiles;
17
+ this.resize$ = resize$;
18
+ this.mutation$ = mutation$;
19
+ this.width = 0;
20
+ this.height = 0;
21
+ this.dragged = false;
22
+ this.offset$ = new BehaviorSubject([0, 0]);
23
+ this.position$ = combineLatest([
24
+ this.offset$.pipe(distinctUntilChanged(tuiArrayShallowEquals)),
25
+ this.resize$.pipe(startWith(null)),
26
+ this.mutation$.pipe(startWith(null)),
27
+ ]).pipe(map(([[left, top]]) => ({
28
+ top: top || this.element.offsetTop,
29
+ left: left || this.element.offsetLeft,
30
+ width: this.element.clientWidth,
31
+ height: this.element.clientHeight,
32
+ })), tuiZonefull(this.ngZone));
33
+ }
34
+ get column() {
35
+ return `span ${this.width}`;
36
+ }
37
+ get row() {
38
+ return `span ${this.height}`;
39
+ }
40
+ get element() {
41
+ return this.elementRef.nativeElement;
42
+ }
43
+ onEnter() {
44
+ this.tiles.reorder(this.element);
45
+ }
46
+ onDrag(dragged) {
47
+ this.dragged = this.dragged || dragged;
48
+ this.tiles.element = dragged ? this.element : null;
49
+ }
50
+ onTransitionEnd() {
51
+ this.dragged = false;
52
+ }
53
+ }
54
+ TuiTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiTileComponent, deps: [{ token: NgZone }, { token: ElementRef }, { token: TuiTilesComponent }, { token: TuiResizeService }, { token: MutationObserverService }], target: i0.ɵɵFactoryTarget.Component });
55
+ TuiTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiTileComponent, selector: "tui-tile", inputs: { width: "width", height: "height" }, host: { listeners: { "pointerenter": "onEnter()" }, properties: { "class._dragged": "this.dragged", "style.gridColumn": "this.column", "style.gridRow": "this.row" } }, ngImport: i0, template: "<div\n *ngIf=\"position$ | async as position\"\n class=\"t-wrapper\"\n [style.top.px]=\"position.top\"\n [style.left.px]=\"position.left\"\n [style.width.px]=\"position.width\"\n [style.height.px]=\"position.height\"\n (transitionend.self)=\"onTransitionEnd()\"\n>\n <ng-content></ng-content>\n</div>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
+ __decorate([
57
+ tuiDefaultProp()
58
+ ], TuiTileComponent.prototype, "width", void 0);
59
+ __decorate([
60
+ tuiDefaultProp()
61
+ ], TuiTileComponent.prototype, "height", void 0);
62
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiTileComponent, decorators: [{
63
+ type: Component,
64
+ args: [{
65
+ selector: `tui-tile`,
66
+ templateUrl: `tile.template.html`,
67
+ changeDetection: ChangeDetectionStrategy.OnPush,
68
+ }]
69
+ }], ctorParameters: function () { return [{ type: i0.NgZone, decorators: [{
70
+ type: Inject,
71
+ args: [NgZone]
72
+ }] }, { type: i0.ElementRef, decorators: [{
73
+ type: Inject,
74
+ args: [ElementRef]
75
+ }] }, { type: i2.TuiTilesComponent, decorators: [{
76
+ type: Inject,
77
+ args: [TuiTilesComponent]
78
+ }] }, { type: i3.Observable, decorators: [{
79
+ type: Inject,
80
+ args: [TuiResizeService]
81
+ }] }, { type: i3.Observable, decorators: [{
82
+ type: Inject,
83
+ args: [MutationObserverService]
84
+ }] }]; }, propDecorators: { width: [{
85
+ type: Input
86
+ }], height: [{
87
+ type: Input
88
+ }], dragged: [{
89
+ type: HostBinding,
90
+ args: [`class._dragged`]
91
+ }], column: [{
92
+ type: HostBinding,
93
+ args: [`style.gridColumn`]
94
+ }], row: [{
95
+ type: HostBinding,
96
+ args: [`style.gridRow`]
97
+ }], onEnter: [{
98
+ type: HostListener,
99
+ args: [`pointerenter`]
100
+ }] } });
101
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy90aWxlcy90aWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3RpbGVzL3RpbGUudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsVUFBVSxFQUNWLFdBQVcsRUFDWCxZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkUsT0FBTyxFQUNILHFCQUFxQixFQUNyQixjQUFjLEVBQ2QsZ0JBQWdCLEVBQ2hCLFdBQVcsR0FDZCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsZUFBZSxFQUFFLGFBQWEsRUFBYSxNQUFNLE1BQU0sQ0FBQztBQUNoRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRXBFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLG1CQUFtQixDQUFDOzs7OztBQU9wRCxNQUFNLE9BQU8sZ0JBQWdCO0lBNEJ6QixZQUNxQyxNQUFjLEVBQ1YsVUFBbUMsRUFDNUIsS0FBaUMsRUFDbEMsT0FBNEIsRUFDckIsU0FBOEI7UUFKL0MsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNWLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQzVCLFVBQUssR0FBTCxLQUFLLENBQTRCO1FBQ2xDLFlBQU8sR0FBUCxPQUFPLENBQXFCO1FBQ3JCLGNBQVMsR0FBVCxTQUFTLENBQXFCO1FBOUJwRixVQUFLLEdBQUcsQ0FBQyxDQUFDO1FBSVYsV0FBTSxHQUFHLENBQUMsQ0FBQztRQUdY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Y3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgRWxlbWVudFJlZixcbiAgICBIb3N0QmluZGluZyxcbiAgICBIb3N0TGlzdGVuZXIsXG4gICAgSW5qZWN0LFxuICAgIElucHV0LFxuICAgIE5nWm9uZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge011dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlfSBmcm9tICdAbmctd2ViLWFwaXMvbXV0YXRpb24tb2JzZXJ2ZXInO1xuaW1wb3J0IHtcbiAgICB0dWlBcnJheVNoYWxsb3dFcXVhbHMsXG4gICAgdHVpRGVmYXVsdFByb3AsXG4gICAgVHVpUmVzaXplU2VydmljZSxcbiAgICB0dWlab25lZnVsbCxcbn0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgY29tYmluZUxhdGVzdCwgT2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge2Rpc3RpbmN0VW50aWxDaGFuZ2VkLCBtYXAsIHN0YXJ0V2l0aH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge1R1aVRpbGVzQ29tcG9uZW50fSBmcm9tICcuL3RpbGVzLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBgdHVpLXRpbGVgLFxuICAgIHRlbXBsYXRlVXJsOiBgdGlsZS50ZW1wbGF0ZS5odG1sYCxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpVGlsZUNvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIHdpZHRoID0gMDtcblxuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBoZWlnaHQgPSAwO1xuXG4gICAgQEhvc3RCaW5kaW5nKGBjbGFzcy5fZHJhZ2dlZGApXG4gICAgZHJhZ2dlZCA9IGZhbHNlO1xuXG4gICAgcmVhZG9ubHkgb2Zmc2V0JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8W251bWJlciwgbnVtYmVyXT4oWzAsIDBdKTtcblxuICAgIHJlYWRvbmx5IHBvc2l0aW9uJCA9IGNvbWJpbmVMYXRlc3QoW1xuICAgICAgICB0aGlzLm9mZnNldCQucGlwZShkaXN0aW5jdFVudGlsQ2hhbmdlZCh0dWlBcnJheVNoYWxsb3dFcXVhbHMpKSxcbiAgICAgICAgdGhpcy5yZXNpemUkLnBpcGUoc3RhcnRXaXRoKG51bGwpKSxcbiAgICAgICAgdGhpcy5tdXRhdGlvbiQucGlwZShzdGFydFdpdGgobnVsbCkpLFxuICAgIF0pLnBpcGUoXG4gICAgICAgIG1hcCgoW1tsZWZ0LCB0b3BdXSkgPT4gKHtcbiAgICAgICAgICAgIHRvcDogdG9wIHx8IHRoaXMuZWxlbWVudC5vZmZzZXRUb3AsXG4gICAgICAgICAgICBsZWZ0OiBsZWZ0IHx8IHRoaXMuZWxlbWVudC5vZmZzZXRMZWZ0LFxuICAgICAgICAgICAgd2lkdGg6IHRoaXMuZWxlbWVudC5jbGllbnRXaWR0aCxcbiAgICAgICAgICAgIGhlaWdodDogdGhpcy5lbGVtZW50LmNsaWVudEhlaWdodCxcbiAgICAgICAgfSkpLFxuICAgICAgICB0dWlab25lZnVsbCh0aGlzLm5nWm9uZSksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KE5nWm9uZSkgcHJpdmF0ZSByZWFkb25seSBuZ1pvbmU6IE5nWm9uZSxcbiAgICAgICAgQEluamVjdChFbGVtZW50UmVmKSBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxuICAgICAgICBASW5qZWN0KFR1aVRpbGVzQ29tcG9uZW50KSBwcml2YXRlIHJlYWRvbmx5IHRpbGVzOiBUdWlUaWxlc0NvbXBvbmVudDx1bmtub3duPixcbiAgICAgICAgQEluamVjdChUdWlSZXNpemVTZXJ2aWNlKSBwcml2YXRlIHJlYWRvbmx5IHJlc2l6ZSQ6IE9ic2VydmFibGU8dW5rbm93bj4sXG4gICAgICAgIEBJbmplY3QoTXV0YXRpb25PYnNlcnZlclNlcnZpY2UpIHByaXZhdGUgcmVhZG9ubHkgbXV0YXRpb24kOiBPYnNlcnZhYmxlPHVua25vd24+LFxuICAgICkge31cblxuICAgIEBIb3N0QmluZGluZyhgc3R5bGUuZ3JpZENvbHVtbmApXG4gICAgZ2V0IGNvbHVtbigpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYHNwYW4gJHt0aGlzLndpZHRofWA7XG4gICAgfVxuXG4gICAgQEhvc3RCaW5kaW5nKGBzdHlsZS5ncmlkUm93YClcbiAgICBnZXQgcm93KCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiBgc3BhbiAke3RoaXMuaGVpZ2h0fWA7XG4gICAgfVxuXG4gICAgZ2V0IGVsZW1lbnQoKTogSFRNTEVsZW1lbnQge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcihgcG9pbnRlcmVudGVyYClcbiAgICBvbkVudGVyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnRpbGVzLnJlb3JkZXIodGhpcy5lbGVtZW50KTtcbiAgICB9XG5cbiAgICBvbkRyYWcoZHJhZ2dlZDogYm9vbGVhbik6IHZvaWQge1xuICAgICAgICB0aGlzLmRyYWdnZWQgPSB0aGlzLmRyYWdnZWQgfHwgZHJhZ2dlZDtcbiAgICAgICAgdGhpcy50aWxlcy5lbGVtZW50ID0gZHJhZ2dlZCA/IHRoaXMuZWxlbWVudCA6IG51bGw7XG4gICAgfVxuXG4gICAgb25UcmFuc2l0aW9uRW5kKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRyYWdnZWQgPSBmYWxzZTtcbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgKm5nSWY9XCJwb3NpdGlvbiQgfCBhc3luYyBhcyBwb3NpdGlvblwiXG4gICAgY2xhc3M9XCJ0LXdyYXBwZXJcIlxuICAgIFtzdHlsZS50b3AucHhdPVwicG9zaXRpb24udG9wXCJcbiAgICBbc3R5bGUubGVmdC5weF09XCJwb3NpdGlvbi5sZWZ0XCJcbiAgICBbc3R5bGUud2lkdGgucHhdPVwicG9zaXRpb24ud2lkdGhcIlxuICAgIFtzdHlsZS5oZWlnaHQucHhdPVwicG9zaXRpb24uaGVpZ2h0XCJcbiAgICAodHJhbnNpdGlvbmVuZC5zZWxmKT1cIm9uVHJhbnNpdGlvbkVuZCgpXCJcbj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj5cbiJdfQ==