@taiga-ui/kit 4.37.0 → 4.38.0-canary.507d44d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/action-bar/action-bar.component.d.ts +2 -2
- package/components/badge-notification/badge-notification.component.d.ts +2 -2
- package/components/calendar-range/day-caps-mapper.d.ts +2 -2
- package/components/drawer/drawer.component.d.ts +3 -6
- package/components/input-month/input-month.directive.d.ts +3 -2
- package/components/input-month-range/input-month-range.directive.d.ts +3 -2
- package/components/input-number/input-number.directive.d.ts +3 -2
- package/components/input-number/step/input-number-step.component.d.ts +4 -3
- package/components/line-clamp/line-clamp-box.component.d.ts +2 -1
- package/components/pdf-viewer/pdf-viewer.component.d.ts +2 -2
- package/components/preview/preview-dialog/preview-dialog.component.d.ts +2 -8
- package/components/pulse/pulse.component.d.ts +2 -2
- package/components/push/push-alert.component.d.ts +2 -2
- package/components/select/native-select/native-select.component.d.ts +2 -0
- package/components/select/select.directive.d.ts +2 -1
- package/esm2022/components/action-bar/action-bar.component.mjs +8 -12
- package/esm2022/components/badge-notification/badge-notification.component.mjs +6 -9
- package/esm2022/components/calendar-range/calendar-range.component.mjs +4 -4
- package/esm2022/components/calendar-range/day-caps-mapper.mjs +10 -4
- package/esm2022/components/drawer/drawer.component.mjs +13 -16
- package/esm2022/components/input-month/input-month.directive.mjs +8 -7
- package/esm2022/components/input-month-range/input-month-range.directive.mjs +13 -8
- package/esm2022/components/input-number/input-number.directive.mjs +15 -19
- package/esm2022/components/input-number/step/input-number-step.component.mjs +14 -13
- package/esm2022/components/line-clamp/line-clamp-box.component.mjs +7 -6
- package/esm2022/components/pdf-viewer/pdf-viewer.component.mjs +8 -11
- package/esm2022/components/preview/preview-dialog/preview-dialog.component.mjs +10 -20
- package/esm2022/components/preview/preview.component.mjs +3 -4
- package/esm2022/components/pulse/pulse.component.mjs +6 -10
- package/esm2022/components/push/push-alert.component.mjs +8 -21
- package/esm2022/components/select/native-select/native-select.component.mjs +9 -5
- package/esm2022/components/select/select.directive.mjs +10 -5
- package/esm2022/components/slider/helpers/slider-key-steps.directive.mjs +3 -3
- package/fesm2022/taiga-ui-kit-components-action-bar.mjs +7 -11
- package/fesm2022/taiga-ui-kit-components-action-bar.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-badge-notification.mjs +5 -8
- package/fesm2022/taiga-ui-kit-components-badge-notification.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +12 -6
- package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-drawer.mjs +12 -15
- package/fesm2022/taiga-ui-kit-components-drawer.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-month-range.mjs +12 -7
- package/fesm2022/taiga-ui-kit-components-input-month-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-month.mjs +7 -6
- package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-number.mjs +26 -29
- package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-line-clamp.mjs +8 -7
- package/fesm2022/taiga-ui-kit-components-line-clamp.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-pdf-viewer.mjs +7 -10
- package/fesm2022/taiga-ui-kit-components-pdf-viewer.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-preview-preview-dialog.mjs +9 -19
- package/fesm2022/taiga-ui-kit-components-preview-preview-dialog.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-preview.mjs +10 -20
- package/fesm2022/taiga-ui-kit-components-preview.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-pulse.mjs +5 -9
- package/fesm2022/taiga-ui-kit-components-pulse.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-push.mjs +6 -18
- package/fesm2022/taiga-ui-kit-components-push.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-select.mjs +14 -6
- package/fesm2022/taiga-ui-kit-components-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-slider.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-slider.mjs.map +1 -1
- package/package.json +46 -46
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import type { TuiButtonOptions } from '@taiga-ui/core/components/button';
|
|
2
2
|
import type { TuiSizeS } from '@taiga-ui/core/types';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
4
5
|
export declare class TuiActionBarComponent implements TuiButtonOptions {
|
|
5
|
-
protected readonly animation: import("@angular/animations").AnimationOptions;
|
|
6
6
|
expanded: boolean;
|
|
7
7
|
size: TuiSizeS;
|
|
8
8
|
readonly appearance = "secondary-grayscale";
|
|
9
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiActionBarComponent, never>;
|
|
10
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiActionBarComponent, "tui-action-bar", never, { "expanded": { "alias": "expanded"; "required": false; }; "size": { "alias": "size"; "required": false; }; }, {}, never, ["tui-data-list,[tuiMenu]", "*", "a,button,[tuiAction]"], true,
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiActionBarComponent, "tui-action-bar", never, { "expanded": { "alias": "expanded"; "required": false; }; "size": { "alias": "size"; "required": false; }; }, {}, never, ["tui-data-list,[tuiMenu]", "*", "a,button,[tuiAction]"], true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
11
11
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import type { TuiSizeL, TuiSizeXS } from '@taiga-ui/core/types';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
3
4
|
export declare class TuiBadgeNotification {
|
|
4
|
-
protected readonly options: import("@angular/animations").AnimationOptions;
|
|
5
5
|
size: TuiSizeL | TuiSizeXS;
|
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiBadgeNotification, never>;
|
|
7
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiBadgeNotification, "tui-badge-notification", never, { "size": { "alias": "size"; "required": false; }; }, {}, never, ["*"], true,
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiBadgeNotification, "tui-badge-notification", never, { "size": { "alias": "size"; "required": false; }; }, {}, never, ["*"], true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
8
8
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { TuiDayLike
|
|
2
|
-
import { TuiDay } from '@taiga-ui/cdk/date-time';
|
|
1
|
+
import type { TuiDayLike } from '@taiga-ui/cdk/date-time';
|
|
2
|
+
import { TuiDay, TuiDayRange } from '@taiga-ui/cdk/date-time';
|
|
3
3
|
import type { TuiMapper } from '@taiga-ui/cdk/types';
|
|
4
4
|
export declare const TUI_DAY_CAPS_MAPPER: TuiMapper<[
|
|
5
5
|
TuiDay | null,
|
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import type { AnimationOptions } from '@angular/animations';
|
|
2
1
|
import type { TuiHorizontalDirection } from '@taiga-ui/core/types';
|
|
3
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
4
4
|
export declare class TuiDrawer {
|
|
5
|
-
protected readonly options: AnimationOptions;
|
|
6
5
|
direction: TuiHorizontalDirection;
|
|
7
6
|
overlay: boolean;
|
|
8
|
-
|
|
9
|
-
value: string;
|
|
10
|
-
};
|
|
7
|
+
get from(): string;
|
|
11
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDrawer, never>;
|
|
12
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDrawer, "tui-drawer", never, { "direction": { "alias": "direction"; "required": false; }; "overlay": { "alias": "overlay"; "required": false; }; }, {}, never, ["header", "*", "footer"], true,
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDrawer, "tui-drawer", never, { "direction": { "alias": "direction"; "required": false; }; "overlay": { "alias": "overlay"; "required": false; }; }, {}, never, ["header", "*", "footer"], true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
13
10
|
}
|
|
@@ -5,11 +5,12 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
6
6
|
import * as i2 from "@taiga-ui/core/directives/dropdown";
|
|
7
7
|
export declare class TuiInputMonthDirective extends TuiControl<TuiMonth | null> {
|
|
8
|
-
private readonly
|
|
8
|
+
private readonly textfield;
|
|
9
9
|
private readonly formatter;
|
|
10
|
+
private readonly open;
|
|
10
11
|
protected readonly icon: import("@angular/core").Signal<string>;
|
|
11
12
|
protected readonly dropdownEnabled: import("@angular/core").Signal<boolean>;
|
|
12
|
-
protected readonly
|
|
13
|
+
protected readonly valueEffect: import("@angular/core").EffectRef;
|
|
13
14
|
protected readonly calendarSync: import("@angular/core").EffectRef;
|
|
14
15
|
protected onMonthClickEffect: import("@angular/core").EffectRef;
|
|
15
16
|
readonly calendar: import("@angular/core").Signal<TuiCalendarMonth | null>;
|
|
@@ -4,13 +4,14 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
5
5
|
import * as i2 from "@taiga-ui/core/directives/dropdown";
|
|
6
6
|
export declare class TuiInputMonthRangeDirective extends TuiControl<TuiMonthRange | null> {
|
|
7
|
+
private readonly textfield;
|
|
8
|
+
private readonly formatter;
|
|
7
9
|
private readonly open;
|
|
8
10
|
private readonly intermediateValue;
|
|
9
11
|
private readonly calendar;
|
|
10
|
-
private readonly formatter;
|
|
11
12
|
protected readonly icon: import("@angular/core").Signal<string>;
|
|
12
13
|
protected readonly dropdownEnabled: import("@angular/core").Signal<boolean>;
|
|
13
|
-
protected readonly
|
|
14
|
+
protected readonly valueEffect: import("@angular/core").EffectRef;
|
|
14
15
|
protected readonly calendarInit: import("@angular/core").EffectRef;
|
|
15
16
|
protected readonly calendarSync: import("@angular/core").EffectRef;
|
|
16
17
|
protected readonly resetIntermediateValue: import("@angular/core").EffectRef;
|
|
@@ -4,14 +4,15 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
5
5
|
import * as i2 from "@maskito/angular";
|
|
6
6
|
export declare class TuiInputNumberDirective extends TuiControl<number | null> {
|
|
7
|
+
private readonly textfield;
|
|
7
8
|
private readonly isIOS;
|
|
8
9
|
private readonly numberFormat;
|
|
10
|
+
private readonly formatted;
|
|
9
11
|
private readonly precision;
|
|
10
|
-
private readonly
|
|
12
|
+
private readonly unfinished;
|
|
11
13
|
protected readonly onChangeEffect: import("@angular/core").EffectRef;
|
|
12
14
|
protected readonly options: import("./input-number.options").TuiInputNumberOptions;
|
|
13
15
|
protected readonly element: HTMLInputElement;
|
|
14
|
-
protected readonly textfieldValue: import("@angular/core").WritableSignal<string>;
|
|
15
16
|
protected readonly inputMode: import("@angular/core").Signal<"text" | "decimal" | "numeric">;
|
|
16
17
|
protected readonly defaultMaxLength: import("@angular/core").Signal<number>;
|
|
17
18
|
protected readonly mask: import("@angular/core").Signal<MaskitoOptions | null>;
|
|
@@ -4,11 +4,12 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
export declare class TuiInputNumberStep {
|
|
5
5
|
private readonly destroyRef;
|
|
6
6
|
private readonly zone;
|
|
7
|
-
protected readonly
|
|
8
|
-
protected readonly
|
|
7
|
+
protected readonly el: HTMLInputElement;
|
|
8
|
+
protected readonly appearance: import("@angular/core").WritableSignal<string>;
|
|
9
9
|
protected readonly options: TuiInputNumberOptions;
|
|
10
|
-
protected readonly
|
|
10
|
+
protected readonly input: TuiInputNumberDirective;
|
|
11
11
|
protected readonly step: import("@angular/core").WritableSignal<number>;
|
|
12
|
+
protected readonly value: import("@angular/core").Signal<number>;
|
|
12
13
|
set stepSetter(x: number);
|
|
13
14
|
protected onStep(step: number): void;
|
|
14
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputNumberStep, never>;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { TuiHintComponent } from '@taiga-ui/core/directives/hint';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
3
4
|
export declare class TuiLineClampBox extends TuiHintComponent {
|
|
4
5
|
protected get width(): number;
|
|
5
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiLineClampBox, never>;
|
|
6
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiLineClampBox, "tui-line-clamp-box", never, {}, {}, never, never, true,
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiLineClampBox, "tui-line-clamp-box", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
7
8
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import type { TuiPopover } from '@taiga-ui/cdk/services';
|
|
2
2
|
import type { TuiPdfViewerOptions } from './pdf-viewer.options';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
4
5
|
export declare class TuiPdfViewerComponent<I, O> {
|
|
5
|
-
protected readonly options: import("@angular/animations").AnimationOptions;
|
|
6
6
|
protected readonly closeWord$: import("rxjs").Observable<string>;
|
|
7
7
|
protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
|
|
8
8
|
protected readonly context: TuiPopover<TuiPdfViewerOptions<I>, O>;
|
|
9
9
|
protected onKeyDownEsc(): void;
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPdfViewerComponent<any, any>, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPdfViewerComponent<any, any>, "tui-pdf-viewer", never, {}, {}, never, never, true,
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPdfViewerComponent<any, any>, "tui-pdf-viewer", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
12
12
|
}
|
|
@@ -1,14 +1,8 @@
|
|
|
1
1
|
import type { TuiPopover } from '@taiga-ui/cdk/services';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
3
4
|
export declare class TuiPreviewDialog {
|
|
4
5
|
protected readonly context: TuiPopover<void, void>;
|
|
5
|
-
protected readonly animation: {
|
|
6
|
-
value: string;
|
|
7
|
-
params: {
|
|
8
|
-
start: string;
|
|
9
|
-
duration: number;
|
|
10
|
-
};
|
|
11
|
-
};
|
|
12
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPreviewDialog, never>;
|
|
13
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPreviewDialog, "tui-preview-dialog", never, {}, {}, never, never, true,
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPreviewDialog, "tui-preview-dialog", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
14
8
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { TuiRectAccessor } from '@taiga-ui/core/classes';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
3
4
|
export declare class TuiPulse extends TuiRectAccessor {
|
|
4
5
|
private readonly isBrowser;
|
|
5
6
|
private readonly el;
|
|
6
|
-
protected readonly animation: import("@angular/animations").AnimationOptions;
|
|
7
7
|
playing: boolean;
|
|
8
8
|
readonly type = "hint";
|
|
9
9
|
getClientRect(): DOMRect;
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPulse, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPulse, "tui-pulse", never, { "playing": { "alias": "playing"; "required": false; }; }, {}, never, never, true,
|
|
11
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPulse, "tui-pulse", never, { "playing": { "alias": "playing"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
12
12
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import type { TuiPopover } from '@taiga-ui/cdk/services';
|
|
2
2
|
import type { TuiPushOptions } from './push.options';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
4
5
|
export declare class TuiPushAlert {
|
|
5
|
-
protected readonly options: import("@angular/animations").AnimationOptions;
|
|
6
6
|
protected readonly context: TuiPopover<TuiPushOptions, string>;
|
|
7
7
|
protected get isDirective(): boolean;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiPushAlert, never>;
|
|
9
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPushAlert, "ng-component", never, {}, {}, never, never, true,
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiPushAlert, "ng-component", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiAnimated; inputs: {}; outputs: {}; }]>;
|
|
10
10
|
}
|
|
@@ -5,12 +5,14 @@ import { tuiIsFlat } from '@taiga-ui/kit/utils';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
7
7
|
export declare class TuiNativeSelect<T> extends TuiControl<T | null> implements TuiTextfieldAccessor<T> {
|
|
8
|
+
private readonly textfield;
|
|
8
9
|
protected readonly isFlat: typeof tuiIsFlat;
|
|
9
10
|
protected readonly placeholder: import("@angular/core").WritableSignal<string>;
|
|
10
11
|
protected readonly itemsHandlers: TuiItemsHandlers<T>;
|
|
11
12
|
protected readonly stringified: import("@angular/core").Signal<string>;
|
|
12
13
|
protected readonly showPlaceholder: import("@angular/core").Signal<boolean | "">;
|
|
13
14
|
protected readonly isSelected: import("@angular/core").Signal<(x: T) => boolean>;
|
|
15
|
+
protected readonly valueEffect: import("@angular/core").EffectRef;
|
|
14
16
|
items: ReadonlyArray<readonly T[]> | readonly T[] | null;
|
|
15
17
|
labels: readonly string[];
|
|
16
18
|
set placeholderSetter(x: string);
|
|
@@ -3,10 +3,11 @@ import type { TuiTextfieldAccessor } from '@taiga-ui/core/components/textfield';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@taiga-ui/core/components/textfield";
|
|
5
5
|
export declare class TuiSelectDirective<T> extends TuiControl<T | null> implements TuiTextfieldAccessor<T> {
|
|
6
|
+
private readonly textfield;
|
|
6
7
|
private readonly open;
|
|
7
8
|
private readonly itemsHandlers;
|
|
8
9
|
protected readonly dropdownEnabled: import("@angular/core").Signal<boolean>;
|
|
9
|
-
protected readonly
|
|
10
|
+
protected readonly valueEffect: import("@angular/core").EffectRef;
|
|
10
11
|
setValue(value: T): void;
|
|
11
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiSelectDirective<any>, never>;
|
|
12
13
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TuiSelectDirective<any>, "input[tuiSelect]", never, {}, {}, never, never, true, [{ directive: typeof i1.TuiWithTextfield; inputs: {}; outputs: {}; }, { directive: typeof i1.TuiSelectLike; inputs: {}; outputs: {}; }]>;
|
|
@@ -1,24 +1,22 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { TuiAnimated } from '@taiga-ui/cdk/directives/animated';
|
|
2
3
|
import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
3
|
-
import { tuiFadeIn, tuiSlideInTop } from '@taiga-ui/core/animations';
|
|
4
4
|
import { TUI_BUTTON_OPTIONS } from '@taiga-ui/core/components/button';
|
|
5
5
|
import { TuiExpandComponent } from '@taiga-ui/core/components/expand';
|
|
6
6
|
import { tuiLinkOptionsProvider } from '@taiga-ui/core/components/link';
|
|
7
|
-
import { TUI_ANIMATIONS_SPEED } from '@taiga-ui/core/tokens';
|
|
8
|
-
import { tuiToAnimationOptions } from '@taiga-ui/core/utils/miscellaneous';
|
|
9
7
|
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
10
9
|
class TuiActionBarComponent {
|
|
11
10
|
constructor() {
|
|
12
|
-
this.animation = tuiToAnimationOptions(inject(TUI_ANIMATIONS_SPEED));
|
|
13
11
|
this.expanded = false;
|
|
14
12
|
this.size = 'm';
|
|
15
13
|
this.appearance = 'secondary-grayscale';
|
|
16
14
|
}
|
|
17
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiActionBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
18
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiActionBarComponent, isStandalone: true, selector: "tui-action-bar", inputs: { expanded: "expanded", size: "size" }, host: { attributes: { "tuiTheme": "dark" }, properties: { "attr.data-size": "size"
|
|
16
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiActionBarComponent, isStandalone: true, selector: "tui-action-bar", inputs: { expanded: "expanded", size: "size" }, host: { attributes: { "tuiTheme": "dark" }, properties: { "attr.data-size": "size" } }, providers: [
|
|
19
17
|
tuiProvide(TUI_BUTTON_OPTIONS, TuiActionBarComponent),
|
|
20
18
|
tuiLinkOptionsProvider({ appearance: 'action-grayscale', pseudo: true }),
|
|
21
|
-
], ngImport: i0, template: "<tui-expand [expanded]=\"expanded\">\n <ng-content select=\"tui-data-list,[tuiMenu]\" />\n</tui-expand>\n\n<div class=\"t-content\">\n <ng-content />\n\n <div class=\"t-actions\">\n <ng-content select=\"a,button,[tuiAction]\" />\n </div>\n</div>\n", styles: [":host{position:fixed;left:max(calc(50% - 37rem),1.5rem);bottom:1rem;display:flex;inline-size:100%;max-inline-size:min(calc(100vw - 3rem),74rem);box-sizing:border-box;border-radius:1rem;background:var(--tui-background-elevation-3);background:color-mix(in hsl,var(--tui-background-elevation-3) 75%,transparent);color:var(--tui-text-primary);-webkit-backdrop-filter:blur(2rem);backdrop-filter:blur(2rem);flex-direction:column;justify-content:center;padding:.75rem;text-indent:.75rem;font:var(--tui-font-text-m);white-space:nowrap}:host[data-size=s]{border-radius:var(--tui-radius-l);font:var(--tui-font-text-s);padding:.5rem}:host-context(tui-root._mobile) :host{padding:1rem;border-radius:1.25rem;text-indent:0}:host ::ng-deep tui-data-list[data-size]{padding:0;margin:-.625rem -.625rem 1rem}:host ::ng-deep tui-items-with-more{text-indent:.5rem}:host-context(tui-root._mobile) :host ::ng-deep tui-items-with-more{display:none}.t-content{display:flex;align-items:center;gap:.7rem 2.5rem}:host-context(tui-root._mobile) .t-content{flex-wrap:wrap}.t-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-inline-start:auto;text-indent:0}:host-context(tui-root._mobile) .t-actions{flex:1}:host-context(tui-root._mobile) .t-actions ::ng-deep [tuiButton]{flex:1}\n"], dependencies: [{ kind: "component", type: TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }],
|
|
19
|
+
], hostDirectives: [{ directive: i1.TuiAnimated }], ngImport: i0, template: "<tui-expand [expanded]=\"expanded\">\n <ng-content select=\"tui-data-list,[tuiMenu]\" />\n</tui-expand>\n\n<div class=\"t-content\">\n <ng-content />\n\n <div class=\"t-actions\">\n <ng-content select=\"a,button,[tuiAction]\" />\n </div>\n</div>\n", styles: [":host{position:fixed;left:max(calc(50% - 37rem),1.5rem);bottom:1rem;display:flex;inline-size:100%;max-inline-size:min(calc(100vw - 3rem),74rem);box-sizing:border-box;border-radius:1rem;background:var(--tui-background-elevation-3);background:color-mix(in hsl,var(--tui-background-elevation-3) 75%,transparent);color:var(--tui-text-primary);-webkit-backdrop-filter:blur(2rem);backdrop-filter:blur(2rem);flex-direction:column;justify-content:center;padding:.75rem;text-indent:.75rem;font:var(--tui-font-text-m);white-space:nowrap}:host.tui-enter,:host.tui-leave{animation-name:tuiFade,tuiSlide}:host[data-size=s]{border-radius:var(--tui-radius-l);font:var(--tui-font-text-s);padding:.5rem}:host-context(tui-root._mobile) :host{padding:1rem;border-radius:1.25rem;text-indent:0}:host ::ng-deep tui-data-list[data-size]{padding:0;margin:-.625rem -.625rem 1rem}:host ::ng-deep tui-items-with-more{text-indent:.5rem}:host-context(tui-root._mobile) :host ::ng-deep tui-items-with-more{display:none}.t-content{display:flex;align-items:center;gap:.7rem 2.5rem}:host-context(tui-root._mobile) .t-content{flex-wrap:wrap}.t-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-inline-start:auto;text-indent:0}:host-context(tui-root._mobile) .t-actions{flex:1}:host-context(tui-root._mobile) .t-actions ::ng-deep [tuiButton]{flex:1}\n"], dependencies: [{ kind: "component", type: TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
22
20
|
}
|
|
23
21
|
export { TuiActionBarComponent };
|
|
24
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiActionBarComponent, decorators: [{
|
|
@@ -26,15 +24,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
26
24
|
args: [{ standalone: true, selector: 'tui-action-bar', imports: [TuiExpandComponent], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
27
25
|
tuiProvide(TUI_BUTTON_OPTIONS, TuiActionBarComponent),
|
|
28
26
|
tuiLinkOptionsProvider({ appearance: 'action-grayscale', pseudo: true }),
|
|
29
|
-
],
|
|
27
|
+
], hostDirectives: [TuiAnimated], host: {
|
|
30
28
|
tuiTheme: 'dark',
|
|
31
29
|
'[attr.data-size]': 'size',
|
|
32
|
-
|
|
33
|
-
'[@tuiSlideInTop]': 'animation',
|
|
34
|
-
}, template: "<tui-expand [expanded]=\"expanded\">\n <ng-content select=\"tui-data-list,[tuiMenu]\" />\n</tui-expand>\n\n<div class=\"t-content\">\n <ng-content />\n\n <div class=\"t-actions\">\n <ng-content select=\"a,button,[tuiAction]\" />\n </div>\n</div>\n", styles: [":host{position:fixed;left:max(calc(50% - 37rem),1.5rem);bottom:1rem;display:flex;inline-size:100%;max-inline-size:min(calc(100vw - 3rem),74rem);box-sizing:border-box;border-radius:1rem;background:var(--tui-background-elevation-3);background:color-mix(in hsl,var(--tui-background-elevation-3) 75%,transparent);color:var(--tui-text-primary);-webkit-backdrop-filter:blur(2rem);backdrop-filter:blur(2rem);flex-direction:column;justify-content:center;padding:.75rem;text-indent:.75rem;font:var(--tui-font-text-m);white-space:nowrap}:host[data-size=s]{border-radius:var(--tui-radius-l);font:var(--tui-font-text-s);padding:.5rem}:host-context(tui-root._mobile) :host{padding:1rem;border-radius:1.25rem;text-indent:0}:host ::ng-deep tui-data-list[data-size]{padding:0;margin:-.625rem -.625rem 1rem}:host ::ng-deep tui-items-with-more{text-indent:.5rem}:host-context(tui-root._mobile) :host ::ng-deep tui-items-with-more{display:none}.t-content{display:flex;align-items:center;gap:.7rem 2.5rem}:host-context(tui-root._mobile) .t-content{flex-wrap:wrap}.t-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-inline-start:auto;text-indent:0}:host-context(tui-root._mobile) .t-actions{flex:1}:host-context(tui-root._mobile) .t-actions ::ng-deep [tuiButton]{flex:1}\n"] }]
|
|
30
|
+
}, template: "<tui-expand [expanded]=\"expanded\">\n <ng-content select=\"tui-data-list,[tuiMenu]\" />\n</tui-expand>\n\n<div class=\"t-content\">\n <ng-content />\n\n <div class=\"t-actions\">\n <ng-content select=\"a,button,[tuiAction]\" />\n </div>\n</div>\n", styles: [":host{position:fixed;left:max(calc(50% - 37rem),1.5rem);bottom:1rem;display:flex;inline-size:100%;max-inline-size:min(calc(100vw - 3rem),74rem);box-sizing:border-box;border-radius:1rem;background:var(--tui-background-elevation-3);background:color-mix(in hsl,var(--tui-background-elevation-3) 75%,transparent);color:var(--tui-text-primary);-webkit-backdrop-filter:blur(2rem);backdrop-filter:blur(2rem);flex-direction:column;justify-content:center;padding:.75rem;text-indent:.75rem;font:var(--tui-font-text-m);white-space:nowrap}:host.tui-enter,:host.tui-leave{animation-name:tuiFade,tuiSlide}:host[data-size=s]{border-radius:var(--tui-radius-l);font:var(--tui-font-text-s);padding:.5rem}:host-context(tui-root._mobile) :host{padding:1rem;border-radius:1.25rem;text-indent:0}:host ::ng-deep tui-data-list[data-size]{padding:0;margin:-.625rem -.625rem 1rem}:host ::ng-deep tui-items-with-more{text-indent:.5rem}:host-context(tui-root._mobile) :host ::ng-deep tui-items-with-more{display:none}.t-content{display:flex;align-items:center;gap:.7rem 2.5rem}:host-context(tui-root._mobile) .t-content{flex-wrap:wrap}.t-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-inline-start:auto;text-indent:0}:host-context(tui-root._mobile) .t-actions{flex:1}:host-context(tui-root._mobile) .t-actions ::ng-deep [tuiButton]{flex:1}\n"] }]
|
|
35
31
|
}], propDecorators: { expanded: [{
|
|
36
32
|
type: Input
|
|
37
33
|
}], size: [{
|
|
38
34
|
type: Input
|
|
39
35
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWJhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9hY3Rpb24tYmFyL2FjdGlvbi1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvYWN0aW9uLWJhci9hY3Rpb24tYmFyLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBQzlELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUU3RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxrQ0FBa0MsQ0FBQztBQUNwRSxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQzs7O0FBR3RFLE1BaUJhLHFCQUFxQjtJQWpCbEM7UUFtQlcsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUdqQixTQUFJLEdBQWEsR0FBRyxDQUFDO1FBRVosZUFBVSxHQUFHLHFCQUFxQixDQUFDO0tBQ3REOytHQVJZLHFCQUFxQjttR0FBckIscUJBQXFCLHFNQVZuQjtZQUNQLFVBQVUsQ0FBQyxrQkFBa0IsRUFBRSxxQkFBcUIsQ0FBQztZQUNyRCxzQkFBc0IsQ0FBQyxFQUFDLFVBQVUsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFDLENBQUM7U0FDekUsMkVDbkJMLDRRQVdBLDIyQ0RDYyxrQkFBa0I7O1NBY25CLHFCQUFxQjs0RkFBckIscUJBQXFCO2tCQWpCakMsU0FBUztpQ0FDTSxJQUFJLFlBQ04sZ0JBQWdCLFdBQ2pCLENBQUMsa0JBQWtCLENBQUMsbUJBR1osdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDUCxVQUFVLENBQUMsa0JBQWtCLHdCQUF3Qjt3QkFDckQsc0JBQXNCLENBQUMsRUFBQyxVQUFVLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBQyxDQUFDO3FCQUN6RSxrQkFDZSxDQUFDLFdBQVcsQ0FBQyxRQUN2Qjt3QkFDRixRQUFRLEVBQUUsTUFBTTt3QkFDaEIsa0JBQWtCLEVBQUUsTUFBTTtxQkFDN0I7OEJBSU0sUUFBUTtzQkFEZCxLQUFLO2dCQUlDLElBQUk7c0JBRFYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlBbmltYXRlZH0gZnJvbSAnQHRhaWdhLXVpL2Nkay9kaXJlY3RpdmVzL2FuaW1hdGVkJztcbmltcG9ydCB7dHVpUHJvdmlkZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9taXNjZWxsYW5lb3VzJztcbmltcG9ydCB0eXBlIHtUdWlCdXR0b25PcHRpb25zfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQge1RVSV9CVVRUT05fT1BUSU9OU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHtUdWlFeHBhbmRDb21wb25lbnR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvZXhwYW5kJztcbmltcG9ydCB7dHVpTGlua09wdGlvbnNQcm92aWRlcn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9saW5rJztcbmltcG9ydCB0eXBlIHtUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAndHVpLWFjdGlvbi1iYXInLFxuICAgIGltcG9ydHM6IFtUdWlFeHBhbmRDb21wb25lbnRdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9hY3Rpb24tYmFyLnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2FjdGlvbi1iYXIuc3R5bGUubGVzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB0dWlQcm92aWRlKFRVSV9CVVRUT05fT1BUSU9OUywgVHVpQWN0aW9uQmFyQ29tcG9uZW50KSxcbiAgICAgICAgdHVpTGlua09wdGlvbnNQcm92aWRlcih7YXBwZWFyYW5jZTogJ2FjdGlvbi1ncmF5c2NhbGUnLCBwc2V1ZG86IHRydWV9KSxcbiAgICBdLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpQW5pbWF0ZWRdLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgdHVpVGhlbWU6ICdkYXJrJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc2l6ZV0nOiAnc2l6ZScsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQWN0aW9uQmFyQ29tcG9uZW50IGltcGxlbWVudHMgVHVpQnV0dG9uT3B0aW9ucyB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZXhwYW5kZWQgPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNpemU6IFR1aVNpemVTID0gJ20nO1xuXG4gICAgcHVibGljIHJlYWRvbmx5IGFwcGVhcmFuY2UgPSAnc2Vjb25kYXJ5LWdyYXlzY2FsZSc7XG59XG4iLCI8dHVpLWV4cGFuZCBbZXhwYW5kZWRdPVwiZXhwYW5kZWRcIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0dWktZGF0YS1saXN0LFt0dWlNZW51XVwiIC8+XG48L3R1aS1leHBhbmQ+XG5cbjxkaXYgY2xhc3M9XCJ0LWNvbnRlbnRcIj5cbiAgICA8bmctY29udGVudCAvPlxuXG4gICAgPGRpdiBjbGFzcz1cInQtYWN0aW9uc1wiPlxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJhLGJ1dHRvbixbdHVpQWN0aW9uXVwiIC8+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -1,25 +1,22 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, inject, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import { TUI_ANIMATIONS_SPEED } from '@taiga-ui/core/tokens';
|
|
4
|
-
import { tuiToAnimationOptions } from '@taiga-ui/core/utils/miscellaneous';
|
|
2
|
+
import { TuiAnimated } from '@taiga-ui/cdk/directives/animated';
|
|
5
3
|
import { TUI_BADGE_NOTIFICATION_OPTIONS } from './badge-notification.options';
|
|
6
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@taiga-ui/cdk/directives/animated";
|
|
7
6
|
class TuiBadgeNotification {
|
|
8
7
|
constructor() {
|
|
9
|
-
this.options = tuiToAnimationOptions(inject(TUI_ANIMATIONS_SPEED));
|
|
10
8
|
this.size = inject(TUI_BADGE_NOTIFICATION_OPTIONS).size;
|
|
11
9
|
}
|
|
12
10
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiBadgeNotification, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiBadgeNotification, isStandalone: true, selector: "tui-badge-notification", inputs: { size: "size" }, host: { properties: { "attr.data-size": "size",
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiBadgeNotification, isStandalone: true, selector: "tui-badge-notification", inputs: { size: "size" }, host: { properties: { "attr.data-size": "size" } }, hostDirectives: [{ directive: i1.TuiAnimated }], ngImport: i0, template: '<ng-content />', isInline: true, styles: [":host{--t-size: 1.5rem;position:relative;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;color:#fff;border-radius:2rem;white-space:nowrap;overflow:hidden;vertical-align:middle;font:var(--tui-font-text-s);max-inline-size:100%;padding:0 .25rem;background:#f52222;block-size:var(--t-size);min-inline-size:var(--t-size)}:host.tui-enter{animation:tuiScale var(--tui-duration) cubic-bezier(.34,1.56,.64,1)}:host.tui-leave{animation:tuiScale var(--tui-duration) ease-in-out reverse}:host[data-size=m]{--t-size: 1.25rem}:host[data-size=s]{--t-size: 1rem;padding:0 .125rem;font:var(--tui-font-text-xs)}:host[data-size=xs]{--t-size: .375rem;padding:0;font-size:0}:host :host-context([tuiIconButton]){position:absolute;right:25%;top:25%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
14
12
|
}
|
|
15
13
|
export { TuiBadgeNotification };
|
|
16
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiBadgeNotification, decorators: [{
|
|
17
15
|
type: Component,
|
|
18
|
-
args: [{ standalone: true, selector: 'tui-badge-notification', template: '<ng-content />', changeDetection: ChangeDetectionStrategy.OnPush,
|
|
16
|
+
args: [{ standalone: true, selector: 'tui-badge-notification', template: '<ng-content />', changeDetection: ChangeDetectionStrategy.OnPush, hostDirectives: [TuiAnimated], host: {
|
|
19
17
|
'[attr.data-size]': 'size',
|
|
20
|
-
|
|
21
|
-
}, styles: [":host{--t-size: 1.5rem;position:relative;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;color:#fff;border-radius:2rem;white-space:nowrap;overflow:hidden;vertical-align:middle;font:var(--tui-font-text-s);max-inline-size:100%;padding:0 .25rem;background:#f52222;block-size:var(--t-size);min-inline-size:var(--t-size)}:host[data-size=m]{--t-size: 1.25rem}:host[data-size=s]{--t-size: 1rem;padding:0 .125rem;font:var(--tui-font-text-xs)}:host[data-size=xs]{--t-size: .375rem;padding:0;font-size:0}:host :host-context([tuiIconButton]){position:absolute;right:25%;top:25%}\n"] }]
|
|
18
|
+
}, styles: [":host{--t-size: 1.5rem;position:relative;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;color:#fff;border-radius:2rem;white-space:nowrap;overflow:hidden;vertical-align:middle;font:var(--tui-font-text-s);max-inline-size:100%;padding:0 .25rem;background:#f52222;block-size:var(--t-size);min-inline-size:var(--t-size)}:host.tui-enter{animation:tuiScale var(--tui-duration) cubic-bezier(.34,1.56,.64,1)}:host.tui-leave{animation:tuiScale var(--tui-duration) ease-in-out reverse}:host[data-size=m]{--t-size: 1.25rem}:host[data-size=s]{--t-size: 1rem;padding:0 .125rem;font:var(--tui-font-text-xs)}:host[data-size=xs]{--t-size: .375rem;padding:0;font-size:0}:host :host-context([tuiIconButton]){position:absolute;right:25%;top:25%}\n"] }]
|
|
22
19
|
}], propDecorators: { size: [{
|
|
23
20
|
type: Input
|
|
24
21
|
}] } });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2Utbm90aWZpY2F0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2JhZGdlLW5vdGlmaWNhdGlvbi9iYWRnZS1ub3RpZmljYXRpb24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNoRixPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFHOUQsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sOEJBQThCLENBQUM7OztBQUU1RSxNQVdhLG9CQUFvQjtJQVhqQztRQWFXLFNBQUksR0FBeUIsTUFBTSxDQUFDLDhCQUE4QixDQUFDLENBQUMsSUFBSSxDQUFDO0tBQ25GOytHQUhZLG9CQUFvQjttR0FBcEIsb0JBQW9CLGlOQVJuQixnQkFBZ0I7O1NBUWpCLG9CQUFvQjs0RkFBcEIsb0JBQW9CO2tCQVhoQyxTQUFTO2lDQUNNLElBQUksWUFDTix3QkFBd0IsWUFDeEIsZ0JBQWdCLG1CQUVULHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CLENBQUMsV0FBVyxDQUFDLFFBQ3ZCO3dCQUNGLGtCQUFrQixFQUFFLE1BQU07cUJBQzdCOzhCQUlNLElBQUk7c0JBRFYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5qZWN0LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aUFuaW1hdGVkfSBmcm9tICdAdGFpZ2EtdWkvY2RrL2RpcmVjdGl2ZXMvYW5pbWF0ZWQnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVMLCBUdWlTaXplWFN9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3R5cGVzJztcblxuaW1wb3J0IHtUVUlfQkFER0VfTk9USUZJQ0FUSU9OX09QVElPTlN9IGZyb20gJy4vYmFkZ2Utbm90aWZpY2F0aW9uLm9wdGlvbnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAndHVpLWJhZGdlLW5vdGlmaWNhdGlvbicsXG4gICAgdGVtcGxhdGU6ICc8bmctY29udGVudCAvPicsXG4gICAgc3R5bGVVcmxzOiBbJy4vYmFkZ2Utbm90aWZpY2F0aW9uLnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0RGlyZWN0aXZlczogW1R1aUFuaW1hdGVkXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbYXR0ci5kYXRhLXNpemVdJzogJ3NpemUnLFxuICAgIH0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUJhZGdlTm90aWZpY2F0aW9uIHtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzaXplOiBUdWlTaXplTCB8IFR1aVNpemVYUyA9IGluamVjdChUVUlfQkFER0VfTk9USUZJQ0FUSU9OX09QVElPTlMpLnNpemU7XG59XG4iXX0=
|
|
@@ -107,13 +107,13 @@ class TuiCalendarRange {
|
|
|
107
107
|
onItemSelect(item) {
|
|
108
108
|
if (!tuiIsString(item)) {
|
|
109
109
|
this.selectedActivePeriod = item;
|
|
110
|
-
this.updateValue(item.range.dayLimit(this.min, this.max));
|
|
111
110
|
this.itemChange.emit(item);
|
|
111
|
+
this.updateValue(item.range.dayLimit(this.min, this.max));
|
|
112
112
|
}
|
|
113
113
|
else if (this.activePeriod !== null) {
|
|
114
114
|
this.selectedActivePeriod = null;
|
|
115
|
-
this.updateValue(null);
|
|
116
115
|
this.itemChange.emit(null);
|
|
116
|
+
this.updateValue(null);
|
|
117
117
|
}
|
|
118
118
|
this.initDefaultViewedMonth();
|
|
119
119
|
}
|
|
@@ -126,8 +126,8 @@ class TuiCalendarRange {
|
|
|
126
126
|
if (this.value instanceof TuiDay) {
|
|
127
127
|
const range = TuiDayRange.sort(this.value, day);
|
|
128
128
|
this.value = range;
|
|
129
|
-
this.updateValue(range);
|
|
130
129
|
this.itemChange.emit(this.findItemByDayRange(range));
|
|
130
|
+
this.updateValue(range);
|
|
131
131
|
}
|
|
132
132
|
else {
|
|
133
133
|
this.value = day;
|
|
@@ -204,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
204
204
|
}], defaultViewedMonth: [{
|
|
205
205
|
type: Input
|
|
206
206
|
}], 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":"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","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.updateValue(item.range.dayLimit(this.min, this.max));\n            this.itemChange.emit(item);\n        } else if (this.activePeriod !== null) {\n            this.selectedActivePeriod = null;\n            this.updateValue(null);\n            this.itemChange.emit(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.updateValue(range);\n            this.itemChange.emit(this.findItemByDayRange(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"]}
|
|
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":"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","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"]}
|
|
@@ -1,10 +1,16 @@
|
|
|
1
|
-
import { TUI_FIRST_DAY, TUI_LAST_DAY, TuiDay } from '@taiga-ui/cdk/date-time';
|
|
1
|
+
import { TUI_FIRST_DAY, TUI_LAST_DAY, TuiDay, TuiDayRange } from '@taiga-ui/cdk/date-time';
|
|
2
2
|
export const TUI_DAY_CAPS_MAPPER = (current, value, maxLength, backwards) => {
|
|
3
|
-
if (
|
|
3
|
+
if (
|
|
4
|
+
// TODO(v5): replace with `if (!(value instanceof TuiDay) || !maxLength)` (backward compatibility)
|
|
5
|
+
(value instanceof TuiDayRange && !value.isSingleDay) ||
|
|
6
|
+
!value ||
|
|
7
|
+
!maxLength) {
|
|
4
8
|
return backwards ? current || TUI_FIRST_DAY : current || TUI_LAST_DAY;
|
|
5
9
|
}
|
|
6
10
|
const negativeMaxLength = Object.fromEntries(Object.entries(maxLength).map(([key, value]) => [key, -value]));
|
|
7
|
-
|
|
11
|
+
// TODO(v5): `value instanceof TuiDay` always `true`
|
|
12
|
+
const from = value instanceof TuiDay ? value : value.from;
|
|
13
|
+
const dateShift = from
|
|
8
14
|
.append(backwards ? negativeMaxLength : maxLength)
|
|
9
15
|
.append({ day: !backwards ? -1 : 1 });
|
|
10
16
|
if (backwards) {
|
|
@@ -17,4 +23,4 @@ export const TUI_DAY_CAPS_MAPPER = (current, value, maxLength, backwards) => {
|
|
|
17
23
|
}
|
|
18
24
|
return dateShift.dayAfter(current) ? current : dateShift;
|
|
19
25
|
};
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LWNhcHMtbWFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvY2FsZW5kYXItcmFuZ2UvZGF5LWNhcHMtbWFwcGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxhQUFhLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUd6RixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FHNUIsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsRUFBRTtJQUN6QztJQUNJLGtHQUFrRztJQUNsRyxDQUFDLEtBQUssWUFBWSxXQUFXLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBQ3BELENBQUMsS0FBSztRQUNOLENBQUMsU0FBUyxFQUNaO1FBQ0UsT0FBTyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxhQUFhLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxZQUFZLENBQUM7S0FDekU7SUFFRCxNQUFNLGlCQUFpQixHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQ3hDLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FDakUsQ0FBQztJQUVGLG9EQUFvRDtJQUNwRCxNQUFNLElBQUksR0FBRyxLQUFLLFlBQVksTUFBTSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDMUQsTUFBTSxTQUFTLEdBQUcsSUFBSTtTQUNqQixNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1NBQ2pELE1BQU0sQ0FBQyxFQUFDLEdBQUcsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBQyxDQUFDLENBQUM7SUFFeEMsSUFBSSxTQUFTLEVBQUU7UUFDWCxPQUFPLFNBQVMsQ0FBQyxTQUFTLENBQUMsT0FBTyxJQUFJLGFBQWEsQ0FBQztZQUNoRCxDQUFDLENBQUMsT0FBTyxJQUFJLGFBQWE7WUFDMUIsQ0FBQyxDQUFDLFNBQVMsQ0FBQztLQUNuQjtJQUVELElBQUksQ0FBQyxPQUFPLEVBQUU7UUFDVixPQUFPLFNBQVMsQ0FBQztLQUNwQjtJQUVELE9BQU8sU0FBUyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7QUFDN0QsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1R1aURheUxpa2V9IGZyb20gJ0B0YWlnYS11aS9jZGsvZGF0ZS10aW1lJztcbmltcG9ydCB7VFVJX0ZJUlNUX0RBWSwgVFVJX0xBU1RfREFZLCBUdWlEYXksIFR1aURheVJhbmdlfSBmcm9tICdAdGFpZ2EtdWkvY2RrL2RhdGUtdGltZSc7XG5pbXBvcnQgdHlwZSB7VHVpTWFwcGVyfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IFRVSV9EQVlfQ0FQU19NQVBQRVI6IFR1aU1hcHBlcjxcbiAgICBbVHVpRGF5IHwgbnVsbCwgVHVpRGF5IHwgVHVpRGF5UmFuZ2UgfCBudWxsLCBUdWlEYXlMaWtlIHwgbnVsbCwgYm9vbGVhbl0sXG4gICAgVHVpRGF5XG4+ID0gKGN1cnJlbnQsIHZhbHVlLCBtYXhMZW5ndGgsIGJhY2t3YXJkcykgPT4ge1xuICAgIGlmIChcbiAgICAgICAgLy8gVE9ETyh2NSk6IHJlcGxhY2Ugd2l0aCBgaWYgKCEodmFsdWUgaW5zdGFuY2VvZiBUdWlEYXkpIHx8ICFtYXhMZW5ndGgpYCAoYmFja3dhcmQgY29tcGF0aWJpbGl0eSlcbiAgICAgICAgKHZhbHVlIGluc3RhbmNlb2YgVHVpRGF5UmFuZ2UgJiYgIXZhbHVlLmlzU2luZ2xlRGF5KSB8fFxuICAgICAgICAhdmFsdWUgfHxcbiAgICAgICAgIW1heExlbmd0aFxuICAgICkge1xuICAgICAgICByZXR1cm4gYmFja3dhcmRzID8gY3VycmVudCB8fCBUVUlfRklSU1RfREFZIDogY3VycmVudCB8fCBUVUlfTEFTVF9EQVk7XG4gICAgfVxuXG4gICAgY29uc3QgbmVnYXRpdmVNYXhMZW5ndGggPSBPYmplY3QuZnJvbUVudHJpZXMoXG4gICAgICAgIE9iamVjdC5lbnRyaWVzKG1heExlbmd0aCkubWFwKChba2V5LCB2YWx1ZV0pID0+IFtrZXksIC12YWx1ZV0pLFxuICAgICk7XG5cbiAgICAvLyBUT0RPKHY1KTogYHZhbHVlIGluc3RhbmNlb2YgVHVpRGF5YCBhbHdheXMgYHRydWVgXG4gICAgY29uc3QgZnJvbSA9IHZhbHVlIGluc3RhbmNlb2YgVHVpRGF5ID8gdmFsdWUgOiB2YWx1ZS5mcm9tO1xuICAgIGNvbnN0IGRhdGVTaGlmdCA9IGZyb21cbiAgICAgICAgLmFwcGVuZChiYWNrd2FyZHMgPyBuZWdhdGl2ZU1heExlbmd0aCA6IG1heExlbmd0aClcbiAgICAgICAgLmFwcGVuZCh7ZGF5OiAhYmFja3dhcmRzID8gLTEgOiAxfSk7XG5cbiAgICBpZiAoYmFja3dhcmRzKSB7XG4gICAgICAgIHJldHVybiBkYXRlU2hpZnQuZGF5QmVmb3JlKGN1cnJlbnQgfHwgVFVJX0ZJUlNUX0RBWSlcbiAgICAgICAgICAgID8gY3VycmVudCB8fCBUVUlfRklSU1RfREFZXG4gICAgICAgICAgICA6IGRhdGVTaGlmdDtcbiAgICB9XG5cbiAgICBpZiAoIWN1cnJlbnQpIHtcbiAgICAgICAgcmV0dXJuIGRhdGVTaGlmdDtcbiAgICB9XG5cbiAgICByZXR1cm4gZGF0ZVNoaWZ0LmRheUFmdGVyKGN1cnJlbnQpID8gY3VycmVudCA6IGRhdGVTaGlmdDtcbn07XG4iXX0=
|