@taiga-ui/kit 4.39.2 → 4.40.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 (71) hide show
  1. package/components/calendar-range/calendar-range.component.d.ts +4 -1
  2. package/components/combo-box/combo-box.directive.d.ts +13 -9
  3. package/components/data-list-wrapper/data-list-wrapper.component.d.ts +4 -1
  4. package/components/files/file/file.component.d.ts +1 -0
  5. package/components/files/file/file.options.d.ts +1 -1
  6. package/components/files/files.utils.d.ts +1 -1
  7. package/components/index.d.ts +1 -0
  8. package/components/input-date/index.d.ts +0 -1
  9. package/components/input-date/input-date.d.ts +1 -2
  10. package/components/input-date/input-date.directive.d.ts +14 -3
  11. package/components/input-date-range/index.d.ts +3 -0
  12. package/components/input-date-range/input-date-range.d.ts +3 -0
  13. package/components/input-date-range/input-date-range.directive.d.ts +20 -0
  14. package/components/input-date-range/input-date-range.options.d.ts +9 -0
  15. package/components/input-phone-international/input-phone-international.component.d.ts +1 -0
  16. package/esm2022/components/calendar-range/calendar-range.component.mjs +44 -27
  17. package/esm2022/components/combo-box/combo-box.directive.mjs +60 -37
  18. package/esm2022/components/data-list-wrapper/data-list-wrapper.component.mjs +16 -4
  19. package/esm2022/components/files/file/file.component.mjs +4 -3
  20. package/esm2022/components/files/file/file.options.mjs +1 -1
  21. package/esm2022/components/files/files.utils.mjs +3 -3
  22. package/esm2022/components/index.mjs +2 -1
  23. package/esm2022/components/input-date/index.mjs +1 -2
  24. package/esm2022/components/input-date/input-date.directive.mjs +49 -37
  25. package/esm2022/components/input-date/input-date.mjs +1 -3
  26. package/esm2022/components/input-date-range/index.mjs +4 -0
  27. package/esm2022/components/input-date-range/input-date-range.directive.mjs +75 -0
  28. package/esm2022/components/input-date-range/input-date-range.mjs +4 -0
  29. package/esm2022/components/input-date-range/input-date-range.options.mjs +10 -0
  30. package/esm2022/components/input-date-range/taiga-ui-kit-components-input-date-range.mjs +5 -0
  31. package/esm2022/components/input-month/input-month.directive.mjs +2 -3
  32. package/esm2022/components/input-month-range/input-month-range.directive.mjs +2 -3
  33. package/esm2022/components/input-number/input-number.directive.mjs +2 -4
  34. package/esm2022/components/input-phone-international/input-phone-international.component.mjs +2 -1
  35. package/esm2022/components/input-pin/input-pin.component.mjs +3 -3
  36. package/esm2022/components/input-slider/input-slider.directive.mjs +3 -2
  37. package/esm2022/components/segmented/segmented.component.mjs +2 -2
  38. package/esm2022/components/select/select.directive.mjs +2 -3
  39. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +43 -26
  40. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
  41. package/fesm2022/taiga-ui-kit-components-combo-box.mjs +61 -38
  42. package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
  43. package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs +15 -3
  44. package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs.map +1 -1
  45. package/fesm2022/taiga-ui-kit-components-files.mjs +5 -4
  46. package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
  47. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +89 -0
  48. package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -0
  49. package/fesm2022/taiga-ui-kit-components-input-date.mjs +50 -63
  50. package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
  51. package/fesm2022/taiga-ui-kit-components-input-month-range.mjs +1 -2
  52. package/fesm2022/taiga-ui-kit-components-input-month-range.mjs.map +1 -1
  53. package/fesm2022/taiga-ui-kit-components-input-month.mjs +1 -2
  54. package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
  55. package/fesm2022/taiga-ui-kit-components-input-number.mjs +1 -3
  56. package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
  57. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs +1 -0
  58. package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs.map +1 -1
  59. package/fesm2022/taiga-ui-kit-components-input-pin.mjs +2 -2
  60. package/fesm2022/taiga-ui-kit-components-input-pin.mjs.map +1 -1
  61. package/fesm2022/taiga-ui-kit-components-input-slider.mjs +2 -1
  62. package/fesm2022/taiga-ui-kit-components-input-slider.mjs.map +1 -1
  63. package/fesm2022/taiga-ui-kit-components-segmented.mjs +2 -2
  64. package/fesm2022/taiga-ui-kit-components-segmented.mjs.map +1 -1
  65. package/fesm2022/taiga-ui-kit-components-select.mjs +1 -2
  66. package/fesm2022/taiga-ui-kit-components-select.mjs.map +1 -1
  67. package/fesm2022/taiga-ui-kit-components.mjs +1 -0
  68. package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
  69. package/package.json +136 -130
  70. package/components/input-date/input-date.validator.d.ts +0 -10
  71. package/esm2022/components/input-date/input-date.validator.mjs +0 -31
@@ -12,13 +12,15 @@ export declare class TuiCalendarRange implements OnInit, OnChanges {
12
12
  * @deprecated use `item`
13
13
  */
14
14
  private selectedPeriod;
15
- protected value: TuiDay | TuiDayRange | null;
15
+ private readonly cdr;
16
+ protected currentValue: TuiDay | TuiDayRange | null;
16
17
  protected previousValue: TuiDay | TuiDayRange | null;
17
18
  protected hoveredItem: TuiDay | null;
18
19
  protected month: TuiMonth;
19
20
  protected readonly otherDateText$: Observable<string>;
20
21
  protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
21
22
  protected readonly capsMapper: TuiMapper<[TuiDay | null, TuiDay | TuiDayRange | null, TuiDayLike | null, boolean], TuiDay>;
23
+ protected readonly mobile: boolean;
22
24
  disabledItemHandler: TuiBooleanHandler<TuiDay>;
23
25
  markerHandler: TuiMarkerHandler | null;
24
26
  items: readonly TuiDayRangePeriod[];
@@ -32,6 +34,7 @@ export declare class TuiCalendarRange implements OnInit, OnChanges {
32
34
  constructor();
33
35
  set valueSetter(value: TuiDayRange | null);
34
36
  set defaultViewedMonth(month: TuiMonth);
37
+ set value(value: TuiDayRange | null);
35
38
  get defaultViewedMonth(): TuiMonth;
36
39
  /**
37
40
  * @deprecated use `item`
@@ -8,20 +8,24 @@ export declare class TuiComboBox<T> extends TuiControl<T | string | null> implem
8
8
  private readonly host;
9
9
  private readonly textfield;
10
10
  private readonly open;
11
+ private readonly dropdownEnabled;
11
12
  private readonly dropdown;
12
13
  private readonly itemsHandlers;
14
+ private readonly matcher;
15
+ private readonly strict;
13
16
  private readonly datalist;
14
- protected readonly dropdownEnabled: import("@angular/core").Signal<boolean>;
15
- protected readonly valueEffect: import("@angular/core").EffectRef;
17
+ private readonly options;
18
+ protected readonly nonStrictValueEffect: import("@angular/core").EffectRef;
19
+ protected readonly matchingEffect: import("@angular/core").EffectRef;
16
20
  protected readonly blurEffect: import("@angular/core").EffectRef;
17
- strict: boolean;
18
- matcher: TuiStringMatcher<T> | null;
19
- setValue(value: T): void;
21
+ set strictSetter(x: boolean);
22
+ set matcherSetter(x: TuiStringMatcher<T> | null);
23
+ setValue(value: T | null): void;
24
+ writeValue(value: T | string | null): void;
20
25
  protected toggleDropdown(open?: boolean): void;
21
- protected onInput(value: string): void;
26
+ protected onInput(): void;
22
27
  protected keydownEnter(event: KeyboardEvent): void;
23
- private get options();
24
- private match;
28
+ private stringify;
25
29
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiComboBox<any>, never>;
26
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiComboBox<any>, "input[tuiComboBox]", never, { "strict": { "alias": "strict"; "required": false; }; "matcher": { "alias": "matcher"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }]>;
30
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiComboBox<any>, "input[tuiComboBox]", never, { "strictSetter": { "alias": "strict"; "required": false; }; "matcherSetter": { "alias": "matcher"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }]>;
27
31
  }
@@ -2,11 +2,12 @@ import type { ElementRef, QueryList } from '@angular/core';
2
2
  import { EventEmitter } from '@angular/core';
3
3
  import type { TuiBooleanHandler } from '@taiga-ui/cdk/types';
4
4
  import type { TuiDataListAccessor } from '@taiga-ui/core/components/data-list';
5
- import { TuiOption, TuiOptionWithValue } from '@taiga-ui/core/components/data-list';
5
+ import { TuiDataListComponent, TuiOption, TuiOptionWithValue } from '@taiga-ui/core/components/data-list';
6
6
  import type { TuiValueContentContext } from '@taiga-ui/core/types';
7
7
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TuiDataListWrapperComponent<T, K = T> implements TuiDataListAccessor<T> {
10
+ private readonly datalist;
10
11
  private readonly itemsHandlers;
11
12
  private readonly itemsHandlersLegacy;
12
13
  protected readonly legacyOptionsQuery: QueryList<TuiOption<T>>;
@@ -17,9 +18,11 @@ export declare class TuiDataListWrapperComponent<T, K = T> implements TuiDataLis
17
18
  emptyContent: PolymorpheusContent;
18
19
  size: "m" | "l" | "s";
19
20
  readonly itemClick: EventEmitter<T>;
21
+ readonly options: import("@angular/core").Signal<readonly T[]>;
20
22
  itemContent: PolymorpheusContent<TuiValueContentContext<T>>;
21
23
  getContext($implicit: T, { nativeElement }: ElementRef<HTMLElement>): TuiValueContentContext<T>;
22
24
  getOptions(includeDisabled?: boolean): readonly T[];
25
+ protected set datalistSetter(x: TuiDataListComponent<T>);
23
26
  protected $cast(items: readonly K[]): readonly T[];
24
27
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDataListWrapperComponent<any, any>, never>;
25
28
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiDataListWrapperComponent<any, any>, "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", never, { "items": { "alias": "items"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "emptyContent": { "alias": "emptyContent"; "required": false; }; "size": { "alias": "size"; "required": false; }; "itemContent": { "alias": "itemContent"; "required": false; }; }, { "itemClick": "itemClick"; }, never, never, true, never>;
@@ -10,6 +10,7 @@ import * as i1 from "@taiga-ui/core/directives/appearance";
10
10
  export declare class TuiFile {
11
11
  private readonly sanitizer;
12
12
  private readonly options;
13
+ private readonly locale;
13
14
  private readonly units$;
14
15
  private readonly win;
15
16
  protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
@@ -4,7 +4,7 @@ import type { TuiSizeL } from '@taiga-ui/core/types';
4
4
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
5
5
  import type { TuiFileState } from '../files.types';
6
6
  export interface TuiFileOptions extends TuiAppearanceOptions {
7
- readonly formatSize: (units: readonly [string, string, string], size?: number) => string | null;
7
+ readonly formatSize: (units: readonly [string, string, string], size?: number, locale?: string) => string | null;
8
8
  readonly icons: Record<Exclude<TuiFileState, 'loading'>, PolymorpheusContent<TuiContext<TuiSizeL>>>;
9
9
  }
10
10
  export declare const TUI_FILE_DEFAULT_OPTIONS: TuiFileOptions;
@@ -1,4 +1,4 @@
1
1
  import type { AbstractControl } from '@angular/forms';
2
2
  export declare function tuiFilesRejected(control?: AbstractControl | null): File[];
3
3
  export declare function tuiFilesAccepted(control?: AbstractControl | null): File[];
4
- export declare function tuiFormatSize(units: readonly [string, string, string], size?: number): string | null;
4
+ export declare function tuiFormatSize(units: readonly [string, string, string], size?: number, locale?: string): string | null;
@@ -23,6 +23,7 @@ export * from '@taiga-ui/kit/components/files';
23
23
  export * from '@taiga-ui/kit/components/filter';
24
24
  export * from '@taiga-ui/kit/components/floating-container';
25
25
  export * from '@taiga-ui/kit/components/input-date';
26
+ export * from '@taiga-ui/kit/components/input-date-range';
26
27
  export * from '@taiga-ui/kit/components/input-inline';
27
28
  export * from '@taiga-ui/kit/components/input-month';
28
29
  export * from '@taiga-ui/kit/components/input-month-range';
@@ -2,4 +2,3 @@ export * from './input-date';
2
2
  export * from './input-date.component';
3
3
  export * from './input-date.directive';
4
4
  export * from './input-date.options';
5
- export * from './input-date.validator';
@@ -1,5 +1,4 @@
1
1
  import { TuiCalendar } from '@taiga-ui/core/components/calendar';
2
2
  import { TuiInputDateComponent } from './input-date.component';
3
3
  import { TuiInputDateDirective } from './input-date.directive';
4
- import { TuiInputDateValidator } from './input-date.validator';
5
- export declare const TuiInputDate: readonly [typeof TuiInputDateDirective, typeof TuiInputDateComponent, typeof TuiInputDateValidator, typeof TuiCalendar];
4
+ export declare const TuiInputDate: readonly [typeof TuiInputDateDirective, typeof TuiInputDateComponent, typeof TuiCalendar];
@@ -1,11 +1,16 @@
1
+ import type { MaskitoDateMode } from '@maskito/kit';
1
2
  import { TuiControl } from '@taiga-ui/cdk/classes';
3
+ import type { TuiDateMode, TuiDayRange } from '@taiga-ui/cdk/date-time';
2
4
  import { TuiDay } from '@taiga-ui/cdk/date-time';
5
+ import { TuiCalendar } from '@taiga-ui/core/components/calendar';
6
+ import { TuiCalendarRange } from '@taiga-ui/kit/components/calendar-range';
3
7
  import * as i0 from "@angular/core";
4
8
  import * as i1 from "@taiga-ui/core/components/textfield";
5
9
  import * as i2 from "@taiga-ui/core/directives/dropdown";
6
- import * as i3 from "./input-date.validator";
10
+ import * as i3 from "@taiga-ui/core/directives/items-handlers";
7
11
  import * as i4 from "@maskito/angular";
8
- export declare class TuiInputDateDirective extends TuiControl<TuiDay | null> {
12
+ export declare const TUI_DATE_ADAPTER: Record<TuiDateMode, MaskitoDateMode>;
13
+ export declare abstract class TuiInputDateBase<T extends TuiDay | TuiDayRange> extends TuiControl<T | null> {
9
14
  private readonly el;
10
15
  private readonly mobile;
11
16
  private readonly options;
@@ -25,10 +30,16 @@ export declare class TuiInputDateDirective extends TuiControl<TuiDay | null> {
25
30
  readonly native: boolean;
26
31
  readonly min: import("@angular/core").WritableSignal<TuiDay>;
27
32
  readonly max: import("@angular/core").WritableSignal<TuiDay>;
33
+ protected abstract onValueChange(value: string): void;
28
34
  set minSetter(min: TuiDay | null);
29
35
  set maxSetter(max: TuiDay | null);
36
+ protected processCalendar(calendar: TuiCalendar | TuiCalendarRange): void;
30
37
  protected onClick(): void;
38
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputDateBase<any>, never>;
39
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiInputDateBase<any>, never, never, { "minSetter": { "alias": "min"; "required": false; }; "maxSetter": { "alias": "max"; "required": false; }; }, {}, never, never, true, never>;
40
+ }
41
+ export declare class TuiInputDateDirective extends TuiInputDateBase<TuiDay> {
31
42
  protected onValueChange(value: string): void;
32
43
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputDateDirective, never>;
33
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiInputDateDirective, "input[tuiInputDate]", never, { "minSetter": { "alias": "min"; "required": false; }; "maxSetter": { "alias": "max"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiDropdownAuto; inputs: {}; outputs: {}; }, { directive: typeof i3.TuiInputDateValidator; inputs: {}; outputs: {}; }, { directive: typeof i4.MaskitoDirective; inputs: {}; outputs: {}; }]>;
44
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiInputDateDirective, "input[tuiInputDate]", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiDropdownAuto; inputs: {}; outputs: {}; }, { directive: typeof i3.TuiItemsHandlersValidator; inputs: {}; outputs: {}; }, { directive: typeof i4.MaskitoDirective; inputs: {}; outputs: {}; }]>;
34
45
  }
@@ -0,0 +1,3 @@
1
+ export * from './input-date-range';
2
+ export * from './input-date-range.directive';
3
+ export * from './input-date-range.options';
@@ -0,0 +1,3 @@
1
+ import { TuiCalendarRange } from '@taiga-ui/kit/components/calendar-range';
2
+ import { TuiInputDateRangeDirective } from './input-date-range.directive';
3
+ export declare const TuiInputDateRange: readonly [typeof TuiInputDateRangeDirective, typeof TuiCalendarRange];
@@ -0,0 +1,20 @@
1
+ import type { TuiDayLike } from '@taiga-ui/cdk/date-time';
2
+ import { TuiDayRange } from '@taiga-ui/cdk/date-time';
3
+ import type { TuiCalendarRange } from '@taiga-ui/kit/components/calendar-range';
4
+ import { TuiInputDateBase } from '@taiga-ui/kit/components/input-date';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@taiga-ui/core/components/textfield";
7
+ import * as i2 from "@taiga-ui/core/directives/dropdown";
8
+ import * as i3 from "@maskito/angular";
9
+ export declare class TuiInputDateRangeDirective extends TuiInputDateBase<TuiDayRange> {
10
+ protected readonly rangeFiller: import("@angular/core").Signal<string>;
11
+ protected readonly mask: import("@angular/core").Signal<import("@maskito/core").MaskitoOptions | null>;
12
+ readonly minLength: import("@angular/core").WritableSignal<TuiDayLike | null>;
13
+ readonly maxLength: import("@angular/core").WritableSignal<TuiDayLike | null>;
14
+ set minLengthSetter(minLength: TuiDayLike | null);
15
+ set maxLengthSetter(maxLength: TuiDayLike | null);
16
+ protected processCalendar(calendar: TuiCalendarRange): void;
17
+ protected onValueChange(value: string): void;
18
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputDateRangeDirective, never>;
19
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiInputDateRangeDirective, "input[tuiInputDateRange]", never, { "minLengthSetter": { "alias": "minLength"; "required": false; }; "maxLengthSetter": { "alias": "maxLength"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiDropdownAuto; inputs: {}; outputs: {}; }, { directive: typeof i3.MaskitoDirective; inputs: {}; outputs: {}; }]>;
20
+ }
@@ -0,0 +1,9 @@
1
+ import type { FactoryProvider } from '@angular/core';
2
+ import type { TuiValueTransformer } from '@taiga-ui/cdk/classes';
3
+ import type { TuiDayRange } from '@taiga-ui/cdk/date-time';
4
+ import type { TuiInputDateOptionsNew } from '@taiga-ui/kit/components/input-date';
5
+ export interface TuiInputDateRangeOptions extends Omit<TuiInputDateOptionsNew, 'valueTransformer'> {
6
+ readonly valueTransformer: TuiValueTransformer<TuiDayRange | null, any>;
7
+ }
8
+ export declare const TUI_INPUT_DATE_RANGE_OPTIONS: import("@angular/core").InjectionToken<TuiInputDateRangeOptions>;
9
+ export declare const tuiInputDateRangeOptionsProvider: (options: Partial<TuiInputDateRangeOptions>) => FactoryProvider;
@@ -7,6 +7,7 @@ import type { MetadataJson } from 'libphonenumber-js/core';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@taiga-ui/core/directives/group";
9
9
  import * as i2 from "@taiga-ui/core/directives/dropdown";
10
+ /** @deprecated use version from experimental package instead */
10
11
  export declare class TuiInputPhoneInternational extends TuiControl<string> {
11
12
  private readonly input?;
12
13
  private readonly filter?;
@@ -1,16 +1,17 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { AsyncPipe, NgForOf, NgIf } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
3
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
4
4
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
5
  import { TUI_FALSE_HANDLER } from '@taiga-ui/cdk/constants';
6
6
  import { TUI_FIRST_DAY, TUI_LAST_DAY, TuiDay, TuiDayRange, TuiMonth, } from '@taiga-ui/cdk/date-time';
7
7
  import { tuiWatch } from '@taiga-ui/cdk/observables';
8
8
  import { TuiMapperPipe } from '@taiga-ui/cdk/pipes/mapper';
9
+ import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
9
10
  import { tuiIsString, tuiNullableSame, tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
10
11
  import { TuiCalendar, tuiCalendarSheetOptionsProvider, } from '@taiga-ui/core/components/calendar';
11
12
  import { TuiDataList } from '@taiga-ui/core/components/data-list';
12
13
  import { TuiIcon } from '@taiga-ui/core/components/icon';
13
- import { TUI_COMMON_ICONS } from '@taiga-ui/core/tokens';
14
+ import { TUI_COMMON_ICONS, tuiAsAuxiliary } from '@taiga-ui/core/tokens';
14
15
  import { TUI_CALENDAR_DATE_STREAM, TUI_OTHER_DATE_TEXT } from '@taiga-ui/kit/tokens';
15
16
  import { calculateDisabledItemHandler } from './calculate-disabled-item-handler';
16
17
  import { TUI_DAY_CAPS_MAPPER } from './day-caps-mapper';
@@ -22,13 +23,15 @@ class TuiCalendarRange {
22
23
  * @deprecated use `item`
23
24
  */
24
25
  this.selectedPeriod = null;
25
- this.value = null;
26
+ this.cdr = inject(ChangeDetectorRef);
27
+ this.currentValue = null;
26
28
  this.previousValue = null;
27
29
  this.hoveredItem = null;
28
30
  this.month = TuiMonth.currentLocal();
29
31
  this.otherDateText$ = inject(TUI_OTHER_DATE_TEXT);
30
32
  this.icons = inject(TUI_COMMON_ICONS);
31
33
  this.capsMapper = TUI_DAY_CAPS_MAPPER;
34
+ this.mobile = inject(TUI_IS_MOBILE);
32
35
  this.disabledItemHandler = TUI_FALSE_HANDLER;
33
36
  this.markerHandler = null;
34
37
  this.items = [];
@@ -53,18 +56,23 @@ class TuiCalendarRange {
53
56
  inject(TUI_CALENDAR_DATE_STREAM, { optional: true })
54
57
  ?.pipe(tuiWatch(), takeUntilDestroyed())
55
58
  .subscribe((value) => {
56
- this.value = value;
59
+ this.currentValue = value;
57
60
  this.initDefaultViewedMonth();
58
61
  });
59
62
  }
60
63
  set valueSetter(value) {
61
- this.value = value;
64
+ this.currentValue = value;
62
65
  }
63
66
  set defaultViewedMonth(month) {
64
- if (!this.value) {
67
+ if (!this.currentValue) {
65
68
  this.month = month;
66
69
  }
67
70
  }
71
+ set value(value) {
72
+ this.cdr.markForCheck();
73
+ this.currentValue = value;
74
+ this.initDefaultViewedMonth();
75
+ }
68
76
  get defaultViewedMonth() {
69
77
  return this.month;
70
78
  }
@@ -81,7 +89,7 @@ class TuiCalendarRange {
81
89
  this.selectedPeriod = period;
82
90
  }
83
91
  ngOnChanges() {
84
- if (!this.value) {
92
+ if (!this.currentValue) {
85
93
  this.initDefaultViewedMonth();
86
94
  }
87
95
  }
@@ -89,14 +97,14 @@ class TuiCalendarRange {
89
97
  this.initDefaultViewedMonth();
90
98
  }
91
99
  get calculatedDisabledItemHandler() {
92
- return this.calculateDisabledItemHandler(this.disabledItemHandler, this.value, this.minLength);
100
+ return this.calculateDisabledItemHandler(this.disabledItemHandler, this.currentValue, this.minLength);
93
101
  }
94
102
  onEsc(event) {
95
- if (event.key !== 'Escape' || !(this.value instanceof TuiDay)) {
103
+ if (event.key !== 'Escape' || !(this.currentValue instanceof TuiDay)) {
96
104
  return;
97
105
  }
98
106
  event.stopPropagation();
99
- this.value = this.previousValue;
107
+ this.currentValue = this.previousValue;
100
108
  }
101
109
  isItemActive(item) {
102
110
  const { activePeriod } = this;
@@ -121,28 +129,28 @@ class TuiCalendarRange {
121
129
  this.month = month;
122
130
  }
123
131
  onDayClick(day) {
124
- this.previousValue = this.value;
132
+ this.previousValue = this.currentValue;
125
133
  this.selectedActivePeriod = null;
126
- if (this.value instanceof TuiDay) {
127
- const range = TuiDayRange.sort(this.value, day);
128
- this.value = range;
134
+ if (this.currentValue instanceof TuiDay) {
135
+ const range = TuiDayRange.sort(this.currentValue, day);
136
+ this.currentValue = range;
129
137
  this.itemChange.emit(this.findItemByDayRange(range));
130
138
  this.updateValue(range);
131
139
  }
132
140
  else {
133
- this.value = day;
141
+ this.currentValue = day;
134
142
  }
135
143
  }
136
144
  updateValue(value) {
137
- this.value = value;
145
+ this.currentValue = value;
138
146
  this.valueChange.emit(value);
139
147
  }
140
148
  get activePeriod() {
141
149
  return (this.item ??
142
150
  this.selectedActivePeriod ??
143
- (this.items.find((item) => tuiNullableSame(this.value instanceof TuiDay
144
- ? new TuiDayRange(this.value, this.value)
145
- : this.value, item.range, (a, b) => a.from.daySame(b.from.dayLimit(this.min, this.max)) &&
151
+ (this.items.find((item) => tuiNullableSame(this.currentValue instanceof TuiDay
152
+ ? new TuiDayRange(this.currentValue, this.currentValue)
153
+ : this.currentValue, item.range, (a, b) => a.from.daySame(b.from.dayLimit(this.min, this.max)) &&
146
154
  a.to.daySame(b.to.dayLimit(this.min, this.max)))) ||
147
155
  null));
148
156
  }
@@ -150,11 +158,13 @@ class TuiCalendarRange {
150
158
  return calculateDisabledItemHandler(disabledItemHandler, value, minLength);
151
159
  }
152
160
  initDefaultViewedMonth() {
153
- if (this.value instanceof TuiDay) {
154
- this.month = this.value;
161
+ if (this.currentValue instanceof TuiDay) {
162
+ this.month = this.currentValue;
155
163
  }
156
- else if (this.value) {
157
- this.month = this.items.length ? this.value.to : this.value.from;
164
+ else if (this.currentValue) {
165
+ this.month = this.items.length
166
+ ? this.currentValue.to
167
+ : this.currentValue.from;
158
168
  }
159
169
  else if (this.max && this.month.monthSameOrAfter(this.max)) {
160
170
  this.month = this.items.length ? this.max : this.max.append({ month: -1 });
@@ -167,7 +177,10 @@ class TuiCalendarRange {
167
177
  return this.items.find((item) => dayRange.daySame(item.range)) ?? null;
168
178
  }
169
179
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarRange, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
170
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarRange, isStandalone: true, selector: "tui-calendar-range", inputs: { disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", items: "items", min: "min", max: "max", minLength: "minLength", maxLength: "maxLength", item: "item", valueSetter: ["value", "valueSetter"], defaultViewedMonth: "defaultViewedMonth" }, outputs: { valueChange: "valueChange", itemChange: "itemChange" }, host: { listeners: { "document:keydown.capture": "onEsc($event)" } }, providers: [tuiCalendarSheetOptionsProvider({ rangeMode: true })], usesOnChanges: true, ngImport: i0, template: "<tui-calendar\n automation-id=\"tui-calendar-range__calendar\"\n class=\"t-calendar\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n [maxViewedMonth]=\"items.length ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n [month]=\"defaultViewedMonth\"\n [showAdjacent]=\"!!items.length\"\n [value]=\"value\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<tui-calendar\n *ngIf=\"!items.length; else presets\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [showAdjacent]=\"false\"\n [value]=\"value\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<ng-template #presets>\n <tui-data-list\n automation-id=\"tui-calendar-range__menu\"\n role=\"menu\"\n [style.flex]=\"1\"\n >\n <button\n *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n automation-id=\"tui-calendar-range__menu__item\"\n role=\"menuitemradio\"\n tuiOption\n type=\"button\"\n [attr.aria-checked]=\"isItemActive(item)\"\n (click)=\"onItemSelect(item)\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ item }}\n <tui-icon\n *ngIf=\"isItemActive(item)\"\n automation-id=\"tui-calendar-range__checkmark\"\n [icon]=\"icons.check\"\n [style.font-size.rem]=\"1\"\n />\n </button>\n </tui-data-list>\n</ng-template>\n", styles: [":host{display:flex;min-inline-size:30rem}.t-calendar{border-inline-end:1px solid var(--tui-border-normal)}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCalendar, selector: "tui-calendar", inputs: ["month", "disabledItemHandler", "min", "max", "minViewedMonth", "maxViewedMonth", "hoveredItem", "showAdjacent", "markerHandler", "value", "initialView"], outputs: ["dayClick", "monthChange", "hoveredItemChange"] }, { kind: "component", type: i1.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i1.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
180
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarRange, isStandalone: true, selector: "tui-calendar-range", inputs: { disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", items: "items", min: "min", max: "max", minLength: "minLength", maxLength: "maxLength", item: "item", valueSetter: ["value", "valueSetter"], defaultViewedMonth: "defaultViewedMonth" }, outputs: { valueChange: "valueChange", itemChange: "itemChange" }, host: { listeners: { "document:keydown.capture": "onEsc($event)" }, properties: { "class._mobile": "mobile" } }, providers: [
181
+ tuiAsAuxiliary(TuiCalendarRange),
182
+ tuiCalendarSheetOptionsProvider({ rangeMode: true }),
183
+ ], usesOnChanges: true, ngImport: i0, template: "<tui-calendar\n automation-id=\"tui-calendar-range__calendar\"\n [class.t-calendar]=\"!mobile\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n [maxViewedMonth]=\"items.length || mobile ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n [month]=\"defaultViewedMonth\"\n [showAdjacent]=\"!!items.length || mobile\"\n [value]=\"currentValue\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n/>\n<tui-calendar\n *ngIf=\"!items.length && !mobile; else presets\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [showAdjacent]=\"false\"\n [value]=\"currentValue\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n/>\n<ng-template #presets>\n <tui-data-list\n *ngIf=\"!mobile\"\n automation-id=\"tui-calendar-range__menu\"\n role=\"menu\"\n [style.flex]=\"1\"\n >\n <button\n *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n automation-id=\"tui-calendar-range__menu__item\"\n role=\"menuitemradio\"\n tuiOption\n type=\"button\"\n [attr.aria-checked]=\"isItemActive(item)\"\n (click)=\"onItemSelect(item)\"\n (pointerdown.prevent.zoneless)=\"(0)\"\n >\n {{ item }}\n <tui-icon\n *ngIf=\"isItemActive(item)\"\n automation-id=\"tui-calendar-range__checkmark\"\n [icon]=\"icons.check\"\n [style.font-size.rem]=\"1\"\n />\n </button>\n </tui-data-list>\n</ng-template>\n", styles: [":host:not(._mobile){display:flex;min-inline-size:30rem}.t-calendar{border-inline-end:1px solid var(--tui-border-normal)}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCalendar, selector: "tui-calendar", inputs: ["month", "disabledItemHandler", "min", "max", "minViewedMonth", "maxViewedMonth", "hoveredItem", "showAdjacent", "markerHandler", "value", "initialView"], outputs: ["dayClick", "monthChange", "hoveredItemChange"] }, { kind: "component", type: i1.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i1.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
171
184
  }
172
185
  __decorate([
173
186
  tuiPure
@@ -175,9 +188,13 @@ __decorate([
175
188
  export { TuiCalendarRange };
176
189
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarRange, decorators: [{
177
190
  type: Component,
178
- args: [{ standalone: true, selector: 'tui-calendar-range', imports: [AsyncPipe, NgForOf, NgIf, TuiCalendar, TuiDataList, TuiIcon, TuiMapperPipe], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiCalendarSheetOptionsProvider({ rangeMode: true })], host: {
191
+ args: [{ standalone: true, selector: 'tui-calendar-range', imports: [AsyncPipe, NgForOf, NgIf, TuiCalendar, TuiDataList, TuiIcon, TuiMapperPipe], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
192
+ tuiAsAuxiliary(TuiCalendarRange),
193
+ tuiCalendarSheetOptionsProvider({ rangeMode: true }),
194
+ ], host: {
195
+ '[class._mobile]': 'mobile',
179
196
  '(document:keydown.capture)': 'onEsc($event)',
180
- }, template: "<tui-calendar\n automation-id=\"tui-calendar-range__calendar\"\n class=\"t-calendar\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n [maxViewedMonth]=\"items.length ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n [month]=\"defaultViewedMonth\"\n [showAdjacent]=\"!!items.length\"\n [value]=\"value\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<tui-calendar\n *ngIf=\"!items.length; else presets\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [showAdjacent]=\"false\"\n [value]=\"value\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<ng-template #presets>\n <tui-data-list\n automation-id=\"tui-calendar-range__menu\"\n role=\"menu\"\n [style.flex]=\"1\"\n >\n <button\n *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n automation-id=\"tui-calendar-range__menu__item\"\n role=\"menuitemradio\"\n tuiOption\n type=\"button\"\n [attr.aria-checked]=\"isItemActive(item)\"\n (click)=\"onItemSelect(item)\"\n (mousedown.prevent.zoneless)=\"(0)\"\n >\n {{ item }}\n <tui-icon\n *ngIf=\"isItemActive(item)\"\n automation-id=\"tui-calendar-range__checkmark\"\n [icon]=\"icons.check\"\n [style.font-size.rem]=\"1\"\n />\n </button>\n </tui-data-list>\n</ng-template>\n", styles: [":host{display:flex;min-inline-size:30rem}.t-calendar{border-inline-end:1px solid var(--tui-border-normal)}\n"] }]
197
+ }, template: "<tui-calendar\n automation-id=\"tui-calendar-range__calendar\"\n [class.t-calendar]=\"!mobile\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n [maxViewedMonth]=\"items.length || mobile ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n [month]=\"defaultViewedMonth\"\n [showAdjacent]=\"!!items.length || mobile\"\n [value]=\"currentValue\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n/>\n<tui-calendar\n *ngIf=\"!items.length && !mobile; else presets\"\n [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n [showAdjacent]=\"false\"\n [value]=\"currentValue\"\n [(hoveredItem)]=\"hoveredItem\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n/>\n<ng-template #presets>\n <tui-data-list\n *ngIf=\"!mobile\"\n automation-id=\"tui-calendar-range__menu\"\n role=\"menu\"\n [style.flex]=\"1\"\n >\n <button\n *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n automation-id=\"tui-calendar-range__menu__item\"\n role=\"menuitemradio\"\n tuiOption\n type=\"button\"\n [attr.aria-checked]=\"isItemActive(item)\"\n (click)=\"onItemSelect(item)\"\n (pointerdown.prevent.zoneless)=\"(0)\"\n >\n {{ item }}\n <tui-icon\n *ngIf=\"isItemActive(item)\"\n automation-id=\"tui-calendar-range__checkmark\"\n [icon]=\"icons.check\"\n [style.font-size.rem]=\"1\"\n />\n </button>\n </tui-data-list>\n</ng-template>\n", styles: [":host:not(._mobile){display:flex;min-inline-size:30rem}.t-calendar{border-inline-end:1px solid var(--tui-border-normal)}\n"] }]
181
198
  }], ctorParameters: function () { return []; }, propDecorators: { disabledItemHandler: [{
182
199
  type: Input
183
200
  }], markerHandler: [{
@@ -204,4 +221,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
204
221
  }], defaultViewedMonth: [{
205
222
  type: Input
206
223
  }], calculateDisabledItemHandler: [] } });
207
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/calendar-range/calendar-range.component.ts","../../../../../projects/kit/components/calendar-range/calendar-range.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAEzD,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EACH,aAAa,EACb,YAAY,EACZ,MAAM,EACN,WAAW,EACX,QAAQ,GACX,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAC,QAAQ,EAAC,MAAM,2BAA2B,CAAC;AACnD,OAAO,EAAC,aAAa,EAAC,MAAM,4BAA4B,CAAC;AAEzD,OAAO,EAAC,WAAW,EAAE,eAAe,EAAE,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAExF,OAAO,EACH,WAAW,EACX,+BAA+B,GAClC,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAC,WAAW,EAAC,MAAM,qCAAqC,CAAC;AAChE,OAAO,EAAC,OAAO,EAAC,MAAM,gCAAgC,CAAC;AACvD,OAAO,EAAC,gBAAgB,EAAC,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAC,wBAAwB,EAAE,mBAAmB,EAAC,MAAM,sBAAsB,CAAC;AAGnF,OAAO,EAAC,4BAA4B,EAAC,MAAM,mCAAmC,CAAC;AAC/E,OAAO,EAAC,mBAAmB,EAAC,MAAM,mBAAmB,CAAC;;;AAGtD,MAYa,gBAAgB;IA6CzB;QA5CA;;WAEG;QACK,mBAAc,GAA6B,IAAI,CAAC;QAE9C,UAAK,GAAgC,IAAI,CAAC;QAC1C,kBAAa,GAAgC,IAAI,CAAC;QAClD,gBAAW,GAAkB,IAAI,CAAC;QAClC,UAAK,GAAa,QAAQ,CAAC,YAAY,EAAE,CAAC;QAEjC,mBAAc,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAC7C,UAAK,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACjC,eAAU,GAAG,mBAAmB,CAAC;QAG7C,wBAAmB,GAA8B,iBAAiB,CAAC;QAGnE,kBAAa,GAA4B,IAAI,CAAC;QAG9C,UAAK,GAAiC,EAAE,CAAC;QAGzC,QAAG,GAAkB,aAAa,CAAC;QAGnC,QAAG,GAAkB,YAAY,CAAC;QAGlC,cAAS,GAAsB,IAAI,CAAC;QAGpC,cAAS,GAAsB,IAAI,CAAC;QAGpC,SAAI,GAA6B,IAAI,CAAC;QAG7B,gBAAW,GAAG,IAAI,YAAY,EAAsB,CAAC;QAGrD,eAAU,GAAG,IAAI,YAAY,EAA4B,CAAC;QAoEvD,gBAAW,GAA4C,CACtE,KAAK,EACL,KAAK,EACP,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC;QAER,WAAM,GASrB,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,aAAa,EAAE,EAAE,CAAC;YAC/C,GAAG,KAAK,CAAC,MAAM,CACX,CAAC,IAAI,EAAE,EAAE,CACL,CAAC,SAAS,KAAK,IAAI;gBACf,IAAI,CAAC,KAAK,CAAC,IAAI;qBACV,MAAM,CAAC,SAAS,CAAC;qBACjB,MAAM,CAAC,EAAC,GAAG,EAAE,CAAC,CAAC,EAAC,CAAC;qBACjB,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBACxC,CAAC,GAAG,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;gBACnD,CAAC,GAAG,KAAK,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAC7D;YACD,aAAa,IAAI,EAAE;SACtB,CAAC;QA3FE,MAAM,CAAiC,wBAAwB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC;YAC9E,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,kBAAkB,EAAE,CAAC;aACvC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC;IACX,CAAC;IAED,IACW,WAAW,CAAC,KAAyB;QAC5C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,IACW,kBAAkB,CAAC,KAAe;QACzC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;SACtB;IACL,CAAC;IAED,IAAW,kBAAkB;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,IAAW,oBAAoB;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,IAAW,oBAAoB,CAAC,MAAgC;QAC5D,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IACjC,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAED,IAAc,6BAA6B;QACvC,OAAO,IAAI,CAAC,4BAA4B,CACpC,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAES,KAAK,CAAC,KAAoB;QAChC,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,YAAY,MAAM,CAAC,EAAE;YAC3D,OAAO;SACV;QAED,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;IACpC,CAAC;IA8BS,YAAY,CAAC,IAAgC;QACnD,MAAM,EAAC,YAAY,EAAC,GAAG,IAAI,CAAC;QAE5B,OAAO,CACH,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,YAAY,KAAK,IAAI,CAAC;YAC5C,YAAY,KAAK,IAAI;YACrB,YAAY,EAAE,QAAQ,EAAE,KAAK,IAAI,CAAC,QAAQ,EAAE,CAC/C,CAAC;IACN,CAAC;IAES,YAAY,CAAC,IAAgC;QACnD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YACpB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;SAC7D;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;YACnC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;SAC1B;QAED,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAES,aAAa,CAAC,KAAe;QACnC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAES,UAAU,CAAC,GAAW;QAC5B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QAEjC,IAAI,IAAI,CAAC,KAAK,YAAY,MAAM,EAAE;YAC9B,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YAEhD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC;YACrD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SAC3B;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;SACpB;IACL,CAAC;IAES,WAAW,CAAC,KAAyB;QAC3C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAY,YAAY;QACpB,OAAO,CACH,IAAI,CAAC,IAAI;YACT,IAAI,CAAC,oBAAoB;YACzB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CACtB,eAAe,CACX,IAAI,CAAC,KAAK,YAAY,MAAM;gBACxB,CAAC,CAAC,IAAI,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC;gBACzC,CAAC,CAAC,IAAI,CAAC,KAAK,EAChB,IAAI,CAAC,KAAK,EACV,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CACL,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;gBACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CACtD,CACJ;gBACG,IAAI,CAAC,CACZ,CAAC;IACN,CAAC;IAGO,4BAA4B,CAChC,mBAA8C,EAC9C,KAAkC,EAClC,SAA4B;QAE5B,OAAO,4BAA4B,CAAC,mBAAmB,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IAC/E,CAAC;IAEO,sBAAsB;QAC1B,IAAI,IAAI,CAAC,KAAK,YAAY,MAAM,EAAE;YAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;SAC3B;aAAM,IAAI,IAAI,CAAC,KAAK,EAAE;YACnB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;SACpE;aAAM,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YAC1D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAC,KAAK,EAAE,CAAC,CAAC,EAAC,CAAC,CAAC;SAC5E;aAAM,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;YAC3D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC;SACzB;IACL,CAAC;IAEO,kBAAkB,CAAC,QAAqB;QAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC;IAC3E,CAAC;+GArOQ,gBAAgB;mGAAhB,gBAAgB,ydALd,CAAC,+BAA+B,CAAC,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC,+CC9CnE,ivEAyDA,iKDfc,SAAS,8CAAE,OAAO,mHAAE,IAAI,6FAAE,WAAW,qjBAAe,OAAO,gFAAE,aAAa;;AAwN5E;IADP,OAAO;oEAOP;SArNQ,gBAAgB;4FAAhB,gBAAgB;kBAZ5B,SAAS;iCACM,IAAI,YACN,oBAAoB,WACrB,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,OAAO,EAAE,aAAa,CAAC,mBAGpE,uBAAuB,CAAC,MAAM,aACpC,CAAC,+BAA+B,CAAC,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAC,QACzD;wBACF,4BAA4B,EAAE,eAAe;qBAChD;0EAkBM,mBAAmB;sBADzB,KAAK;gBAIC,aAAa;sBADnB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,GAAG;sBADT,KAAK;gBAIC,GAAG;sBADT,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIU,WAAW;sBAD1B,MAAM;gBAIS,UAAU;sBADzB,MAAM;gBAaI,WAAW;sBADrB,KAAK;uBAAC,OAAO;gBAMH,kBAAkB;sBAD5B,KAAK;gBAoJE,4BAA4B","sourcesContent":["import {AsyncPipe, NgForOf, NgIf} from '@angular/common';\nimport type {OnChanges, OnInit} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport type {TuiDayLike} from '@taiga-ui/cdk/date-time';\nimport {\n    TUI_FIRST_DAY,\n    TUI_LAST_DAY,\n    TuiDay,\n    TuiDayRange,\n    TuiMonth,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport type {TuiBooleanHandler, TuiMapper} from '@taiga-ui/cdk/types';\nimport {tuiIsString, tuiNullableSame, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiMarkerHandler} from '@taiga-ui/core/components/calendar';\nimport {\n    TuiCalendar,\n    tuiCalendarSheetOptionsProvider,\n} from '@taiga-ui/core/components/calendar';\nimport {TuiDataList} from '@taiga-ui/core/components/data-list';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport {TUI_CALENDAR_DATE_STREAM, TUI_OTHER_DATE_TEXT} from '@taiga-ui/kit/tokens';\nimport type {Observable} from 'rxjs';\n\nimport {calculateDisabledItemHandler} from './calculate-disabled-item-handler';\nimport {TUI_DAY_CAPS_MAPPER} from './day-caps-mapper';\nimport type {TuiDayRangePeriod} from './day-range-period';\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-range',\n    imports: [AsyncPipe, NgForOf, NgIf, TuiCalendar, TuiDataList, TuiIcon, TuiMapperPipe],\n    templateUrl: './calendar-range.template.html',\n    styleUrls: ['./calendar-range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiCalendarSheetOptionsProvider({rangeMode: true})],\n    host: {\n        '(document:keydown.capture)': 'onEsc($event)',\n    },\n})\nexport class TuiCalendarRange implements OnInit, OnChanges {\n    /**\n     * @deprecated use `item`\n     */\n    private selectedPeriod: TuiDayRangePeriod | null = null;\n\n    protected value: TuiDay | TuiDayRange | null = null;\n    protected previousValue: TuiDay | TuiDayRange | null = null;\n    protected hoveredItem: TuiDay | null = null;\n    protected month: TuiMonth = TuiMonth.currentLocal();\n\n    protected readonly otherDateText$ = inject(TUI_OTHER_DATE_TEXT);\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n    protected readonly capsMapper = TUI_DAY_CAPS_MAPPER;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> = TUI_FALSE_HANDLER;\n\n    @Input()\n    public markerHandler: TuiMarkerHandler | null = null;\n\n    @Input()\n    public items: readonly TuiDayRangePeriod[] = [];\n\n    @Input()\n    public min: TuiDay | null = TUI_FIRST_DAY;\n\n    @Input()\n    public max: TuiDay | null = TUI_LAST_DAY;\n\n    @Input()\n    public minLength: TuiDayLike | null = null;\n\n    @Input()\n    public maxLength: TuiDayLike | null = null;\n\n    @Input()\n    public item: TuiDayRangePeriod | null = null;\n\n    @Output()\n    public readonly valueChange = new EventEmitter<TuiDayRange | null>();\n\n    @Output()\n    public readonly itemChange = new EventEmitter<TuiDayRangePeriod | null>();\n\n    constructor() {\n        inject<Observable<TuiDayRange | null>>(TUI_CALENDAR_DATE_STREAM, {optional: true})\n            ?.pipe(tuiWatch(), takeUntilDestroyed())\n            .subscribe((value) => {\n                this.value = value;\n                this.initDefaultViewedMonth();\n            });\n    }\n\n    @Input('value')\n    public set valueSetter(value: TuiDayRange | null) {\n        this.value = value;\n    }\n\n    @Input()\n    public set defaultViewedMonth(month: TuiMonth) {\n        if (!this.value) {\n            this.month = month;\n        }\n    }\n\n    public get defaultViewedMonth(): TuiMonth {\n        return this.month;\n    }\n\n    /**\n     * @deprecated use `item`\n     */\n    public get selectedActivePeriod(): TuiDayRangePeriod | null {\n        return this.selectedPeriod;\n    }\n\n    /**\n     * @deprecated use `item`\n     */\n    public set selectedActivePeriod(period: TuiDayRangePeriod | null) {\n        this.selectedPeriod = period;\n    }\n\n    public ngOnChanges(): void {\n        if (!this.value) {\n            this.initDefaultViewedMonth();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.initDefaultViewedMonth();\n    }\n\n    protected get calculatedDisabledItemHandler(): TuiBooleanHandler<TuiDay> {\n        return this.calculateDisabledItemHandler(\n            this.disabledItemHandler,\n            this.value,\n            this.minLength,\n        );\n    }\n\n    protected onEsc(event: KeyboardEvent): void {\n        if (event.key !== 'Escape' || !(this.value instanceof TuiDay)) {\n            return;\n        }\n\n        event.stopPropagation();\n        this.value = this.previousValue;\n    }\n\n    protected readonly monthOffset: TuiMapper<[TuiMonth, number], TuiMonth> = (\n        value,\n        month,\n    ) => value.append({month});\n\n    protected readonly mapper: TuiMapper<\n        [\n            readonly TuiDayRangePeriod[],\n            TuiDay | null,\n            TuiDay | null,\n            TuiDayLike | null,\n            string | null | undefined,\n        ],\n        ReadonlyArray<TuiDayRangePeriod | string>\n    > = (items, min, max, minLength, otherDateText) => [\n        ...items.filter(\n            (item) =>\n                (minLength === null ||\n                    item.range.from\n                        .append(minLength)\n                        .append({day: -1})\n                        .daySameOrBefore(item.range.to)) &&\n                (min === null || item.range.to.daySameOrAfter(min)) &&\n                (max === null || item.range.from.daySameOrBefore(max)),\n        ),\n        otherDateText || '',\n    ];\n\n    protected isItemActive(item: TuiDayRangePeriod | string): boolean {\n        const {activePeriod} = this;\n\n        return (\n            (tuiIsString(item) && activePeriod === null) ||\n            activePeriod === item ||\n            activePeriod?.toString() === item.toString()\n        );\n    }\n\n    protected onItemSelect(item: TuiDayRangePeriod | string): void {\n        if (!tuiIsString(item)) {\n            this.selectedActivePeriod = item;\n            this.itemChange.emit(item);\n            this.updateValue(item.range.dayLimit(this.min, this.max));\n        } else if (this.activePeriod !== null) {\n            this.selectedActivePeriod = null;\n            this.itemChange.emit(null);\n            this.updateValue(null);\n        }\n\n        this.initDefaultViewedMonth();\n    }\n\n    protected onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    protected onDayClick(day: TuiDay): void {\n        this.previousValue = this.value;\n        this.selectedActivePeriod = null;\n\n        if (this.value instanceof TuiDay) {\n            const range = TuiDayRange.sort(this.value, day);\n\n            this.value = range;\n            this.itemChange.emit(this.findItemByDayRange(range));\n            this.updateValue(range);\n        } else {\n            this.value = day;\n        }\n    }\n\n    protected updateValue(value: TuiDayRange | null): void {\n        this.value = value;\n        this.valueChange.emit(value);\n    }\n\n    private get activePeriod(): TuiDayRangePeriod | null {\n        return (\n            this.item ??\n            this.selectedActivePeriod ??\n            (this.items.find((item) =>\n                tuiNullableSame<TuiDayRange>(\n                    this.value instanceof TuiDay\n                        ? new TuiDayRange(this.value, this.value)\n                        : this.value,\n                    item.range,\n                    (a, b) =>\n                        a.from.daySame(b.from.dayLimit(this.min, this.max)) &&\n                        a.to.daySame(b.to.dayLimit(this.min, this.max)),\n                ),\n            ) ||\n                null)\n        );\n    }\n\n    @tuiPure\n    private calculateDisabledItemHandler(\n        disabledItemHandler: TuiBooleanHandler<TuiDay>,\n        value: TuiDay | TuiDayRange | null,\n        minLength: TuiDayLike | null,\n    ): TuiBooleanHandler<TuiDay> {\n        return calculateDisabledItemHandler(disabledItemHandler, value, minLength);\n    }\n\n    private initDefaultViewedMonth(): void {\n        if (this.value instanceof TuiDay) {\n            this.month = this.value;\n        } else if (this.value) {\n            this.month = this.items.length ? this.value.to : this.value.from;\n        } else if (this.max && this.month.monthSameOrAfter(this.max)) {\n            this.month = this.items.length ? this.max : this.max.append({month: -1});\n        } else if (this.min && this.month.monthSameOrBefore(this.min)) {\n            this.month = this.min;\n        }\n    }\n\n    private findItemByDayRange(dayRange: TuiDayRange): TuiDayRangePeriod | null {\n        return this.items.find((item) => dayRange.daySame(item.range)) ?? null;\n    }\n}\n","<tui-calendar\n    automation-id=\"tui-calendar-range__calendar\"\n    class=\"t-calendar\"\n    [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n    [markerHandler]=\"markerHandler\"\n    [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n    [maxViewedMonth]=\"items.length ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n    [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n    [month]=\"defaultViewedMonth\"\n    [showAdjacent]=\"!!items.length\"\n    [value]=\"value\"\n    [(hoveredItem)]=\"hoveredItem\"\n    (dayClick)=\"onDayClick($event)\"\n    (monthChange)=\"onMonthChange($event)\"\n    (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<tui-calendar\n    *ngIf=\"!items.length; else presets\"\n    [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n    [markerHandler]=\"markerHandler\"\n    [max]=\"max | tuiMapper: capsMapper : value : maxLength : false\"\n    [min]=\"min | tuiMapper: capsMapper : value : maxLength : true\"\n    [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n    [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n    [showAdjacent]=\"false\"\n    [value]=\"value\"\n    [(hoveredItem)]=\"hoveredItem\"\n    (dayClick)=\"onDayClick($event)\"\n    (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n    (mousedown.prevent.zoneless)=\"(0)\"\n/>\n<ng-template #presets>\n    <tui-data-list\n        automation-id=\"tui-calendar-range__menu\"\n        role=\"menu\"\n        [style.flex]=\"1\"\n    >\n        <button\n            *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n            automation-id=\"tui-calendar-range__menu__item\"\n            role=\"menuitemradio\"\n            tuiOption\n            type=\"button\"\n            [attr.aria-checked]=\"isItemActive(item)\"\n            (click)=\"onItemSelect(item)\"\n            (mousedown.prevent.zoneless)=\"(0)\"\n        >\n            {{ item }}\n            <tui-icon\n                *ngIf=\"isItemActive(item)\"\n                automation-id=\"tui-calendar-range__checkmark\"\n                [icon]=\"icons.check\"\n                [style.font-size.rem]=\"1\"\n            />\n        </button>\n    </tui-data-list>\n</ng-template>\n"]}
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/calendar-range/calendar-range.component.ts","../../../../../projects/kit/components/calendar-range/calendar-range.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgForOf, NgIf} from '@angular/common';\nimport type {OnChanges, OnInit} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport type {TuiDayLike} from '@taiga-ui/cdk/date-time';\nimport {\n    TUI_FIRST_DAY,\n    TUI_LAST_DAY,\n    TuiDay,\n    TuiDayRange,\n    TuiMonth,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport type {TuiBooleanHandler, TuiMapper} from '@taiga-ui/cdk/types';\nimport {tuiIsString, tuiNullableSame, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiMarkerHandler} from '@taiga-ui/core/components/calendar';\nimport {\n    TuiCalendar,\n    tuiCalendarSheetOptionsProvider,\n} from '@taiga-ui/core/components/calendar';\nimport {TuiDataList} from '@taiga-ui/core/components/data-list';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TUI_COMMON_ICONS, tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {TUI_CALENDAR_DATE_STREAM, TUI_OTHER_DATE_TEXT} from '@taiga-ui/kit/tokens';\nimport type {Observable} from 'rxjs';\n\nimport {calculateDisabledItemHandler} from './calculate-disabled-item-handler';\nimport {TUI_DAY_CAPS_MAPPER} from './day-caps-mapper';\nimport type {TuiDayRangePeriod} from './day-range-period';\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-range',\n    imports: [AsyncPipe, NgForOf, NgIf, TuiCalendar, TuiDataList, TuiIcon, TuiMapperPipe],\n    templateUrl: './calendar-range.template.html',\n    styleUrls: ['./calendar-range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsAuxiliary(TuiCalendarRange),\n        tuiCalendarSheetOptionsProvider({rangeMode: true}),\n    ],\n    host: {\n        '[class._mobile]': 'mobile',\n        '(document:keydown.capture)': 'onEsc($event)',\n    },\n})\nexport class TuiCalendarRange implements OnInit, OnChanges {\n    /**\n     * @deprecated use `item`\n     */\n    private selectedPeriod: TuiDayRangePeriod | null = null;\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    protected currentValue: TuiDay | TuiDayRange | null = null;\n    protected previousValue: TuiDay | TuiDayRange | null = null;\n    protected hoveredItem: TuiDay | null = null;\n    protected month: TuiMonth = TuiMonth.currentLocal();\n\n    protected readonly otherDateText$ = inject(TUI_OTHER_DATE_TEXT);\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n    protected readonly capsMapper = TUI_DAY_CAPS_MAPPER;\n    protected readonly mobile = inject(TUI_IS_MOBILE);\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> = TUI_FALSE_HANDLER;\n\n    @Input()\n    public markerHandler: TuiMarkerHandler | null = null;\n\n    @Input()\n    public items: readonly TuiDayRangePeriod[] = [];\n\n    @Input()\n    public min: TuiDay | null = TUI_FIRST_DAY;\n\n    @Input()\n    public max: TuiDay | null = TUI_LAST_DAY;\n\n    @Input()\n    public minLength: TuiDayLike | null = null;\n\n    @Input()\n    public maxLength: TuiDayLike | null = null;\n\n    @Input()\n    public item: TuiDayRangePeriod | null = null;\n\n    @Output()\n    public readonly valueChange = new EventEmitter<TuiDayRange | null>();\n\n    @Output()\n    public readonly itemChange = new EventEmitter<TuiDayRangePeriod | null>();\n\n    constructor() {\n        inject<Observable<TuiDayRange | null>>(TUI_CALENDAR_DATE_STREAM, {optional: true})\n            ?.pipe(tuiWatch(), takeUntilDestroyed())\n            .subscribe((value) => {\n                this.currentValue = value;\n                this.initDefaultViewedMonth();\n            });\n    }\n\n    @Input('value')\n    public set valueSetter(value: TuiDayRange | null) {\n        this.currentValue = value;\n    }\n\n    @Input()\n    public set defaultViewedMonth(month: TuiMonth) {\n        if (!this.currentValue) {\n            this.month = month;\n        }\n    }\n\n    public set value(value: TuiDayRange | null) {\n        this.cdr.markForCheck();\n        this.currentValue = value;\n        this.initDefaultViewedMonth();\n    }\n\n    public get defaultViewedMonth(): TuiMonth {\n        return this.month;\n    }\n\n    /**\n     * @deprecated use `item`\n     */\n    public get selectedActivePeriod(): TuiDayRangePeriod | null {\n        return this.selectedPeriod;\n    }\n\n    /**\n     * @deprecated use `item`\n     */\n    public set selectedActivePeriod(period: TuiDayRangePeriod | null) {\n        this.selectedPeriod = period;\n    }\n\n    public ngOnChanges(): void {\n        if (!this.currentValue) {\n            this.initDefaultViewedMonth();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.initDefaultViewedMonth();\n    }\n\n    protected get calculatedDisabledItemHandler(): TuiBooleanHandler<TuiDay> {\n        return this.calculateDisabledItemHandler(\n            this.disabledItemHandler,\n            this.currentValue,\n            this.minLength,\n        );\n    }\n\n    protected onEsc(event: KeyboardEvent): void {\n        if (event.key !== 'Escape' || !(this.currentValue instanceof TuiDay)) {\n            return;\n        }\n\n        event.stopPropagation();\n        this.currentValue = this.previousValue;\n    }\n\n    protected readonly monthOffset: TuiMapper<[TuiMonth, number], TuiMonth> = (\n        value,\n        month,\n    ) => value.append({month});\n\n    protected readonly mapper: TuiMapper<\n        [\n            readonly TuiDayRangePeriod[],\n            TuiDay | null,\n            TuiDay | null,\n            TuiDayLike | null,\n            string | null | undefined,\n        ],\n        ReadonlyArray<TuiDayRangePeriod | string>\n    > = (items, min, max, minLength, otherDateText) => [\n        ...items.filter(\n            (item) =>\n                (minLength === null ||\n                    item.range.from\n                        .append(minLength)\n                        .append({day: -1})\n                        .daySameOrBefore(item.range.to)) &&\n                (min === null || item.range.to.daySameOrAfter(min)) &&\n                (max === null || item.range.from.daySameOrBefore(max)),\n        ),\n        otherDateText || '',\n    ];\n\n    protected isItemActive(item: TuiDayRangePeriod | string): boolean {\n        const {activePeriod} = this;\n\n        return (\n            (tuiIsString(item) && activePeriod === null) ||\n            activePeriod === item ||\n            activePeriod?.toString() === item.toString()\n        );\n    }\n\n    protected onItemSelect(item: TuiDayRangePeriod | string): void {\n        if (!tuiIsString(item)) {\n            this.selectedActivePeriod = item;\n            this.itemChange.emit(item);\n            this.updateValue(item.range.dayLimit(this.min, this.max));\n        } else if (this.activePeriod !== null) {\n            this.selectedActivePeriod = null;\n            this.itemChange.emit(null);\n            this.updateValue(null);\n        }\n\n        this.initDefaultViewedMonth();\n    }\n\n    protected onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    protected onDayClick(day: TuiDay): void {\n        this.previousValue = this.currentValue;\n        this.selectedActivePeriod = null;\n\n        if (this.currentValue instanceof TuiDay) {\n            const range = TuiDayRange.sort(this.currentValue, day);\n\n            this.currentValue = range;\n            this.itemChange.emit(this.findItemByDayRange(range));\n            this.updateValue(range);\n        } else {\n            this.currentValue = day;\n        }\n    }\n\n    protected updateValue(value: TuiDayRange | null): void {\n        this.currentValue = value;\n        this.valueChange.emit(value);\n    }\n\n    private get activePeriod(): TuiDayRangePeriod | null {\n        return (\n            this.item ??\n            this.selectedActivePeriod ??\n            (this.items.find((item) =>\n                tuiNullableSame<TuiDayRange>(\n                    this.currentValue instanceof TuiDay\n                        ? new TuiDayRange(this.currentValue, this.currentValue)\n                        : this.currentValue,\n                    item.range,\n                    (a, b) =>\n                        a.from.daySame(b.from.dayLimit(this.min, this.max)) &&\n                        a.to.daySame(b.to.dayLimit(this.min, this.max)),\n                ),\n            ) ||\n                null)\n        );\n    }\n\n    @tuiPure\n    private calculateDisabledItemHandler(\n        disabledItemHandler: TuiBooleanHandler<TuiDay>,\n        value: TuiDay | TuiDayRange | null,\n        minLength: TuiDayLike | null,\n    ): TuiBooleanHandler<TuiDay> {\n        return calculateDisabledItemHandler(disabledItemHandler, value, minLength);\n    }\n\n    private initDefaultViewedMonth(): void {\n        if (this.currentValue instanceof TuiDay) {\n            this.month = this.currentValue;\n        } else if (this.currentValue) {\n            this.month = this.items.length\n                ? this.currentValue.to\n                : this.currentValue.from;\n        } else if (this.max && this.month.monthSameOrAfter(this.max)) {\n            this.month = this.items.length ? this.max : this.max.append({month: -1});\n        } else if (this.min && this.month.monthSameOrBefore(this.min)) {\n            this.month = this.min;\n        }\n    }\n\n    private findItemByDayRange(dayRange: TuiDayRange): TuiDayRangePeriod | null {\n        return this.items.find((item) => dayRange.daySame(item.range)) ?? null;\n    }\n}\n","<tui-calendar\n    automation-id=\"tui-calendar-range__calendar\"\n    [class.t-calendar]=\"!mobile\"\n    [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n    [markerHandler]=\"markerHandler\"\n    [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n    [maxViewedMonth]=\"items.length || mobile ? null : (defaultViewedMonth | tuiMapper: monthOffset : -1)\"\n    [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n    [month]=\"defaultViewedMonth\"\n    [showAdjacent]=\"!!items.length || mobile\"\n    [value]=\"currentValue\"\n    [(hoveredItem)]=\"hoveredItem\"\n    (dayClick)=\"onDayClick($event)\"\n    (monthChange)=\"onMonthChange($event)\"\n/>\n<tui-calendar\n    *ngIf=\"!items.length && !mobile; else presets\"\n    [disabledItemHandler]=\"calculatedDisabledItemHandler\"\n    [markerHandler]=\"markerHandler\"\n    [max]=\"max | tuiMapper: capsMapper : currentValue : maxLength : false\"\n    [min]=\"min | tuiMapper: capsMapper : currentValue : maxLength : true\"\n    [minViewedMonth]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n    [month]=\"defaultViewedMonth | tuiMapper: monthOffset : 1\"\n    [showAdjacent]=\"false\"\n    [value]=\"currentValue\"\n    [(hoveredItem)]=\"hoveredItem\"\n    (dayClick)=\"onDayClick($event)\"\n    (monthChange)=\"onMonthChange($event.append({month: -1}))\"\n/>\n<ng-template #presets>\n    <tui-data-list\n        *ngIf=\"!mobile\"\n        automation-id=\"tui-calendar-range__menu\"\n        role=\"menu\"\n        [style.flex]=\"1\"\n    >\n        <button\n            *ngFor=\"let item of items | tuiMapper: mapper : min : max : minLength : (otherDateText$ | async)\"\n            automation-id=\"tui-calendar-range__menu__item\"\n            role=\"menuitemradio\"\n            tuiOption\n            type=\"button\"\n            [attr.aria-checked]=\"isItemActive(item)\"\n            (click)=\"onItemSelect(item)\"\n            (pointerdown.prevent.zoneless)=\"(0)\"\n        >\n            {{ item }}\n            <tui-icon\n                *ngIf=\"isItemActive(item)\"\n                automation-id=\"tui-calendar-range__checkmark\"\n                [icon]=\"icons.check\"\n                [style.font-size.rem]=\"1\"\n            />\n        </button>\n    </tui-data-list>\n</ng-template>\n"]}