@taiga-ui/core 4.46.0 → 4.47.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/calendar/calendar-year.component.d.ts +14 -9
- package/directives/icons/icons.directive.d.ts +2 -0
- package/esm2022/components/calendar/calendar-year.component.mjs +57 -41
- package/esm2022/components/calendar/calendar.component.mjs +3 -3
- package/esm2022/components/root/root.component.mjs +3 -3
- package/esm2022/components/textfield/textfield.directive.mjs +3 -2
- package/esm2022/directives/icons/icons.directive.mjs +7 -5
- package/fesm2022/taiga-ui-core-components-calendar.mjs +56 -41
- package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs +2 -2
- package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs +2 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-icons.mjs +6 -4
- package/fesm2022/taiga-ui-core-directives-icons.mjs.map +1 -1
- package/package.json +15 -15
|
@@ -4,26 +4,31 @@ import { TuiDay, TuiMonthRange, TuiYear } from '@taiga-ui/cdk/date-time';
|
|
|
4
4
|
import type { TuiBooleanHandler } from '@taiga-ui/cdk/types';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class TuiCalendarYear {
|
|
7
|
-
private hoveredItem;
|
|
8
|
-
|
|
9
|
-
value: TuiDayRange | TuiMonthRange | TuiYear | number | readonly TuiDay[] | null;
|
|
10
|
-
initialItem: number;
|
|
11
|
-
min: number | null;
|
|
12
|
-
max: number | null;
|
|
7
|
+
private readonly hoveredItem;
|
|
8
|
+
protected readonly isRangePicking: import("@angular/core").Signal<boolean>;
|
|
13
9
|
rangeMode: boolean;
|
|
14
10
|
disabledItemHandler: TuiBooleanHandler<number>;
|
|
15
11
|
readonly yearClick: EventEmitter<number>;
|
|
12
|
+
readonly initialItem: import("@angular/core").WritableSignal<number>;
|
|
13
|
+
readonly min: import("@angular/core").WritableSignal<number>;
|
|
14
|
+
readonly max: import("@angular/core").WritableSignal<number>;
|
|
15
|
+
readonly value: import("@angular/core").WritableSignal<number | TuiYear | TuiDayRange | readonly TuiDay[] | TuiMonthRange | null>;
|
|
16
|
+
set initialItemSetter(x: number | null);
|
|
17
|
+
set minSetter(x: number);
|
|
18
|
+
set maxSetter(x: number);
|
|
19
|
+
set valueSetter(x: TuiDayRange | TuiMonthRange | TuiYear | number | readonly TuiDay[] | null);
|
|
16
20
|
isDisabled(item: number): boolean;
|
|
17
21
|
getItemRange(item: number): 'active' | 'end' | 'middle' | 'start' | null;
|
|
18
22
|
onItemHovered(hovered: boolean, item: number): void;
|
|
19
|
-
protected get isRangePicking(): boolean;
|
|
20
23
|
protected get rows(): number;
|
|
21
24
|
protected scrollItemIntoView(item: number): boolean;
|
|
22
25
|
protected getItem(rowIndex: number, colIndex: number): number;
|
|
23
26
|
protected itemIsToday(item: number): boolean;
|
|
24
27
|
private get calculatedMin();
|
|
25
28
|
private get calculatedMax();
|
|
26
|
-
private updateHoveredItem;
|
|
27
29
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendarYear, never>;
|
|
28
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarYear, "tui-calendar-year", never, { "
|
|
30
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarYear, "tui-calendar-year", never, { "rangeMode": { "alias": "rangeMode"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "initialItemSetter": { "alias": "initialItem"; "required": false; }; "minSetter": { "alias": "min"; "required": false; }; "maxSetter": { "alias": "max"; "required": false; }; "valueSetter": { "alias": "value"; "required": false; }; }, { "yearClick": "yearClick"; }, never, never, true, never>;
|
|
31
|
+
static ngAcceptInputType_initialItemSetter: number | null;
|
|
32
|
+
static ngAcceptInputType_minSetter: number | null;
|
|
33
|
+
static ngAcceptInputType_maxSetter: number | null;
|
|
29
34
|
}
|
|
@@ -7,6 +7,8 @@ type Icon = SafeResourceUrl | string | null | undefined;
|
|
|
7
7
|
export declare class TuiIcons {
|
|
8
8
|
private readonly resolver;
|
|
9
9
|
protected readonly nothing: undefined;
|
|
10
|
+
protected readonly iconStartUrl: import("@angular/core").Signal<string | null>;
|
|
11
|
+
protected readonly iconEndUrl: import("@angular/core").Signal<string | null>;
|
|
10
12
|
readonly iconStart: import("@angular/core").WritableSignal<Icon>;
|
|
11
13
|
readonly iconEnd: import("@angular/core").WritableSignal<string>;
|
|
12
14
|
set iconStartSetter(x: Icon);
|
|
@@ -1,33 +1,52 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
-
import { TUI_FALSE_HANDLER } from '@taiga-ui/cdk/constants';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, EventEmitter, inject, Input, Output, signal, } from '@angular/core';
|
|
3
2
|
import { MAX_YEAR, MIN_YEAR, TuiDay, TuiMonth, TuiMonthRange, TuiYear, } from '@taiga-ui/cdk/date-time';
|
|
4
3
|
import { TuiHovered } from '@taiga-ui/cdk/directives/hovered';
|
|
5
4
|
import { TuiLet } from '@taiga-ui/cdk/directives/let';
|
|
6
5
|
import { TuiRepeatTimes } from '@taiga-ui/cdk/directives/repeat-times';
|
|
7
6
|
import { tuiIsNumber } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
8
7
|
import { TuiScrollIntoView } from '@taiga-ui/core/components/scrollbar';
|
|
8
|
+
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives';
|
|
9
|
+
import { tuiAsAuxiliary } from '@taiga-ui/core/tokens';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
const LIMIT = 100;
|
|
11
12
|
const ITEMS_IN_ROW = 4;
|
|
13
|
+
const CURRENT_YEAR = TuiMonth.currentLocal().year;
|
|
12
14
|
class TuiCalendarYear {
|
|
13
15
|
constructor() {
|
|
14
|
-
this.hoveredItem = null;
|
|
15
|
-
this.
|
|
16
|
-
this.value = null;
|
|
17
|
-
this.initialItem = this.currentYear;
|
|
18
|
-
this.min = MIN_YEAR;
|
|
19
|
-
this.max = MAX_YEAR;
|
|
16
|
+
this.hoveredItem = signal(null);
|
|
17
|
+
this.isRangePicking = computed((x = this.value()) => this.rangeMode && (x instanceof TuiDay || x instanceof TuiMonth));
|
|
20
18
|
this.rangeMode = false;
|
|
21
|
-
this.disabledItemHandler =
|
|
19
|
+
this.disabledItemHandler = inject(TUI_ITEMS_HANDLERS).disabledItemHandler();
|
|
22
20
|
this.yearClick = new EventEmitter();
|
|
21
|
+
this.initialItem = signal(CURRENT_YEAR);
|
|
22
|
+
this.min = signal(MIN_YEAR);
|
|
23
|
+
this.max = signal(MAX_YEAR);
|
|
24
|
+
this.value = signal(null);
|
|
25
|
+
}
|
|
26
|
+
// TODO(v5): use signal inputs
|
|
27
|
+
set initialItemSetter(x) {
|
|
28
|
+
this.initialItem.set(x ?? CURRENT_YEAR);
|
|
29
|
+
}
|
|
30
|
+
// TODO(v5): use signal inputs
|
|
31
|
+
set minSetter(x) {
|
|
32
|
+
this.min.set(x);
|
|
33
|
+
}
|
|
34
|
+
// TODO(v5): use signal inputs
|
|
35
|
+
set maxSetter(x) {
|
|
36
|
+
this.max.set(x);
|
|
37
|
+
}
|
|
38
|
+
// TODO(v5): use signal inputs
|
|
39
|
+
set valueSetter(x) {
|
|
40
|
+
this.value.set(x);
|
|
23
41
|
}
|
|
24
42
|
isDisabled(item) {
|
|
25
|
-
return ((this.max && this.max < item) ||
|
|
26
|
-
(this.min && this.min > item) ||
|
|
43
|
+
return ((this.max() && this.max() < item) ||
|
|
44
|
+
(this.min() && this.min() > item) ||
|
|
27
45
|
this.disabledItemHandler(item));
|
|
28
46
|
}
|
|
29
47
|
getItemRange(item) {
|
|
30
|
-
const
|
|
48
|
+
const value = this.value();
|
|
49
|
+
const hoveredItem = this.hoveredItem();
|
|
31
50
|
if (value instanceof TuiYear && value.year === item) {
|
|
32
51
|
return 'active';
|
|
33
52
|
}
|
|
@@ -37,7 +56,7 @@ class TuiCalendarYear {
|
|
|
37
56
|
if (!(value instanceof TuiMonthRange) && !(value instanceof TuiYear)) {
|
|
38
57
|
return value?.find((day) => day.year === item) ? 'active' : null;
|
|
39
58
|
}
|
|
40
|
-
const hovered = this.isRangePicking ? hoveredItem : null;
|
|
59
|
+
const hovered = this.isRangePicking() ? hoveredItem : null;
|
|
41
60
|
const from = 'from' in value ? value.from?.year : value.year;
|
|
42
61
|
const to = 'from' in value ? value.to.year : value.year;
|
|
43
62
|
const min = Math.min(from, hovered ?? to);
|
|
@@ -54,59 +73,56 @@ class TuiCalendarYear {
|
|
|
54
73
|
return min < item && item < max ? 'middle' : null;
|
|
55
74
|
}
|
|
56
75
|
onItemHovered(hovered, item) {
|
|
57
|
-
this.
|
|
58
|
-
}
|
|
59
|
-
get isRangePicking() {
|
|
60
|
-
return (this.rangeMode &&
|
|
61
|
-
(this.value instanceof TuiDay || this.value instanceof TuiMonth));
|
|
76
|
+
this.hoveredItem.set(hovered ? item : null);
|
|
62
77
|
}
|
|
63
78
|
get rows() {
|
|
64
79
|
return Math.ceil((this.calculatedMax - this.calculatedMin) / ITEMS_IN_ROW);
|
|
65
80
|
}
|
|
66
81
|
scrollItemIntoView(item) {
|
|
67
|
-
return this.initialItem === item;
|
|
82
|
+
return this.initialItem() === item;
|
|
68
83
|
}
|
|
69
84
|
getItem(rowIndex, colIndex) {
|
|
70
85
|
return rowIndex * ITEMS_IN_ROW + colIndex + this.calculatedMin;
|
|
71
86
|
}
|
|
72
87
|
itemIsToday(item) {
|
|
73
|
-
return
|
|
88
|
+
return CURRENT_YEAR === item;
|
|
74
89
|
}
|
|
75
90
|
get calculatedMin() {
|
|
76
|
-
const initial = this.initialItem - LIMIT;
|
|
77
|
-
const min = this.min ?? MIN_YEAR;
|
|
91
|
+
const initial = this.initialItem() - LIMIT;
|
|
92
|
+
const min = this.min() ?? MIN_YEAR;
|
|
78
93
|
return min > initial ? min : initial;
|
|
79
94
|
}
|
|
80
95
|
get calculatedMax() {
|
|
81
|
-
const initial = this.initialItem + LIMIT;
|
|
82
|
-
const max = this.max ?? MAX_YEAR;
|
|
96
|
+
const initial = this.initialItem() + LIMIT;
|
|
97
|
+
const max = this.max() ?? MAX_YEAR;
|
|
83
98
|
return max < initial ? max + 1 : initial;
|
|
84
99
|
}
|
|
85
|
-
updateHoveredItem(hovered, item) {
|
|
86
|
-
this.hoveredItem = hovered ? item : null;
|
|
87
|
-
}
|
|
88
100
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarYear, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
89
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "16.2.12", type: TuiCalendarYear, isStandalone: true, selector: "tui-calendar-year", inputs: { rangeMode: "rangeMode", disabledItemHandler: "disabledItemHandler", initialItemSetter: ["initialItem", "initialItemSetter", (x) => x ?? CURRENT_YEAR], minSetter: ["min", "minSetter", (x) => x ?? MIN_YEAR], maxSetter: ["max", "maxSetter", (x) => x ?? MAX_YEAR], valueSetter: ["value", "valueSetter"] }, outputs: { yearClick: "yearClick" }, host: { properties: { "class._picking": "isRangePicking()" } }, providers: [tuiAsAuxiliary(TuiCalendarYear)], ngImport: i0, template: "<div\n *tuiRepeatTimes=\"let rowIndex of rows\"\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n>\n <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n <div\n *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n </ng-container>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"], dependencies: [{ kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }, { kind: "directive", type: TuiScrollIntoView, selector: "[tuiScrollIntoView]", inputs: ["tuiScrollIntoView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
90
102
|
}
|
|
91
103
|
export { TuiCalendarYear };
|
|
92
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarYear, decorators: [{
|
|
93
105
|
type: Component,
|
|
94
|
-
args: [{ standalone: true, selector: 'tui-calendar-year', imports: [TuiHovered, TuiLet, TuiRepeatTimes, TuiScrollIntoView], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
95
|
-
'[class._picking]': 'isRangePicking',
|
|
96
|
-
}, template: "<div\n *tuiRepeatTimes=\"let rowIndex of rows\"\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n>\n <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n <div\n *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n </ng-container>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"] }]
|
|
97
|
-
}], propDecorators: {
|
|
98
|
-
type: Input
|
|
99
|
-
}], initialItem: [{
|
|
100
|
-
type: Input
|
|
101
|
-
}], min: [{
|
|
102
|
-
type: Input
|
|
103
|
-
}], max: [{
|
|
104
|
-
type: Input
|
|
105
|
-
}], rangeMode: [{
|
|
106
|
+
args: [{ standalone: true, selector: 'tui-calendar-year', imports: [TuiHovered, TuiLet, TuiRepeatTimes, TuiScrollIntoView], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendarYear)], host: {
|
|
107
|
+
'[class._picking]': 'isRangePicking()',
|
|
108
|
+
}, template: "<div\n *tuiRepeatTimes=\"let rowIndex of rows\"\n automation-id=\"tui-calendar-year__row\"\n class=\"t-row\"\n>\n <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n <div\n *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n automation-id=\"tui-calendar-year__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [class.t-cell_disabled]=\"isDisabled(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n (click)=\"yearClick.emit(item)\"\n (tuiHoveredChange)=\"onItemHovered($event, item)\"\n >\n {{ item }}\n </div>\n </ng-container>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.t-row:first-child{justify-content:flex-end}.t-row:last-child{justify-content:flex-start}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;line-height:2rem;isolation:isolate;cursor:pointer;overflow:hidden;border:.125rem solid transparent;box-sizing:border-box;-webkit-mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem));mask:linear-gradient(transparent calc(50% - 1rem),#000 calc(50% - 1rem),#000 calc(50% + 1rem),transparent calc(50% + 1rem))}.t-cell:first-child{border-inline-start-color:transparent!important}.t-cell:last-child{border-inline-end-color:transparent!important}.t-cell:before,.t-cell:after{position:absolute;top:0;left:0;bottom:0;right:0;content:\"\";z-index:-1;border-radius:var(--tui-radius-m)}.t-cell:after{-webkit-mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat;mask:url('data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 32\"><path d=\"M0.2856 0L0.6763 0C2.9265 0 4.9876 1.259 6.0147 3.2611L10.2442 11.5048C11.5301 14.0113 11.5683 16.9754 10.3472 19.5141L5.9766 28.6007C4.9772 30.6786 2.8754 32 0.5696 32H0.285645V0Z\"></path></svg>') right / .75rem 100% no-repeat,linear-gradient(#000,#000) left / calc(100% - .7rem) 100% no-repeat}.t-cell[data-range]:before{background:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range]:before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1)}:host._picking .t-cell[data-range=middle]{border-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=middle]:not(:first-child):before{border-top-left-radius:0;border-bottom-left-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-top-right-radius:0;border-bottom-right-radius:0}.t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=start]{border-inline-end-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:not(:last-child):before{right:-1rem}.t-cell[data-range=start]:after{background:var(--tui-background-accent-1)}.t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1);color:var(--tui-text-primary-on-accent-1)}:host._picking .t-cell[data-range=end]{border-inline-start-color:var(--tui-background-neutral-1-hover)}.t-cell[data-range=end]:not(:first-child):before{left:-1rem}.t-cell[data-range=end]:after{background:var(--tui-background-accent-1);transform:scaleX(-1)}.t-cell[data-range=active]{color:var(--tui-text-primary-on-accent-1)}.t-cell[data-range=active]:after{background:var(--tui-background-accent-1);-webkit-mask:none;mask:none}.t-cell_disabled{opacity:var(--tui-disabled-opacity);pointer-events:none}.t-cell_today{text-decoration:underline;text-underline-offset:.25rem}@media (hover: hover) and (pointer: fine){.t-cell:hover:not([data-range=start]):not([data-range=end]):before{background:var(--tui-background-neutral-1-hover)}.t-cell[data-range=start]:hover:after,.t-cell[data-range=end]:hover:after,.t-cell[data-range=active]:hover:after{background:var(--tui-background-accent-1-hover)}}:host{display:block;padding-inline-end:1rem;inline-size:15.75rem;padding:0 1.125rem}.t-cell{flex:1;border-block-start-width:.5rem;border-block-end-width:.5rem}\n"] }]
|
|
109
|
+
}], propDecorators: { rangeMode: [{
|
|
106
110
|
type: Input
|
|
107
111
|
}], disabledItemHandler: [{
|
|
108
112
|
type: Input
|
|
109
113
|
}], yearClick: [{
|
|
110
114
|
type: Output
|
|
115
|
+
}], initialItemSetter: [{
|
|
116
|
+
type: Input,
|
|
117
|
+
args: [{ alias: 'initialItem', transform: (x) => x ?? CURRENT_YEAR }]
|
|
118
|
+
}], minSetter: [{
|
|
119
|
+
type: Input,
|
|
120
|
+
args: [{ alias: 'min', transform: (x) => x ?? MIN_YEAR }]
|
|
121
|
+
}], maxSetter: [{
|
|
122
|
+
type: Input,
|
|
123
|
+
args: [{ alias: 'max', transform: (x) => x ?? MAX_YEAR }]
|
|
124
|
+
}], valueSetter: [{
|
|
125
|
+
type: Input,
|
|
126
|
+
args: ['value']
|
|
111
127
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-year.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar-year.component.ts","../../../../../projects/core/components/calendar/calendar-year.template.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EACH,QAAQ,EACR,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,aAAa,EACb,OAAO,GACV,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAC,UAAU,EAAC,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAC,MAAM,EAAC,MAAM,8BAA8B,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,uCAAuC,CAAC;AAErE,OAAO,EAAC,WAAW,EAAC,MAAM,mCAAmC,CAAC;AAC9D,OAAO,EAAC,iBAAiB,EAAC,MAAM,qCAAqC,CAAC;;AAEtE,MAAM,KAAK,GAAG,GAAG,CAAC;AAClB,MAAM,YAAY,GAAG,CAAC,CAAC;AAEvB,MAWa,eAAe;IAX5B;QAYY,gBAAW,GAAkB,IAAI,CAAC;QACzB,gBAAW,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC;QAGrD,UAAK,GAMC,IAAI,CAAC;QAGX,gBAAW,GAAW,IAAI,CAAC,WAAW,CAAC;QAGvC,QAAG,GAAkB,QAAQ,CAAC;QAG9B,QAAG,GAAkB,QAAQ,CAAC;QAG9B,cAAS,GAAG,KAAK,CAAC;QAGlB,wBAAmB,GAA8B,iBAAiB,CAAC;QAG1D,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;KA2F1D;IAzFU,UAAU,CAAC,IAAY;QAC1B,OAAO,CACH,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;YAC7B,CAAC,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CACjC,CAAC;IACN,CAAC;IAEM,YAAY,CAAC,IAAY;QAC5B,MAAM,EAAC,KAAK,EAAE,WAAW,EAAC,GAAG,IAAI,CAAC;QAElC,IAAI,KAAK,YAAY,OAAO,IAAI,KAAK,CAAC,IAAI,KAAK,IAAI,EAAE;YACjD,OAAO,QAAQ,CAAC;SACnB;QAED,IAAI,WAAW,CAAC,KAAK,CAAC,EAAE;YACpB,OAAO,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SAC3C;QAED,IAAI,CAAC,CAAC,KAAK,YAAY,aAAa,CAAC,IAAI,CAAC,CAAC,KAAK,YAAY,OAAO,CAAC,EAAE;YAClE,OAAO,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SACpE;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC;QACzD,MAAM,IAAI,GAAG,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QAC7D,MAAM,EAAE,GAAG,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QAExD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC;QAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,IAAI,EAAE,CAAC,CAAC;QAE1C,IAAI,GAAG,KAAK,GAAG,IAAI,IAAI,KAAK,EAAE,IAAI,IAAI,KAAK,IAAI,EAAE;YAC7C,OAAO,QAAQ,CAAC;SACnB;QAED,IAAI,GAAG,KAAK,IAAI,EAAE;YACd,OAAO,OAAO,CAAC;SAClB;QAED,IAAI,GAAG,KAAK,IAAI,EAAE;YACd,OAAO,KAAK,CAAC;SAChB;QAED,OAAO,GAAG,GAAG,IAAI,IAAI,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;IACtD,CAAC;IAEM,aAAa,CAAC,OAAgB,EAAE,IAAY;QAC/C,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,IAAc,cAAc;QACxB,OAAO,CACH,IAAI,CAAC,SAAS;YACd,CAAC,IAAI,CAAC,KAAK,YAAY,MAAM,IAAI,IAAI,CAAC,KAAK,YAAY,QAAQ,CAAC,CACnE,CAAC;IACN,CAAC;IAED,IAAc,IAAI;QACd,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,YAAY,CAAC,CAAC;IAC/E,CAAC;IAES,kBAAkB,CAAC,IAAY;QACrC,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC;IACrC,CAAC;IAES,OAAO,CAAC,QAAgB,EAAE,QAAgB;QAChD,OAAO,QAAQ,GAAG,YAAY,GAAG,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC;IACnE,CAAC;IAES,WAAW,CAAC,IAAY;QAC9B,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC;IACrC,CAAC;IAED,IAAY,aAAa;QACrB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,QAAQ,CAAC;QAEjC,OAAO,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC;IACzC,CAAC;IAED,IAAY,aAAa;QACrB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,QAAQ,CAAC;QAEjC,OAAO,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAC7C,CAAC;IAEO,iBAAiB,CAAC,OAAgB,EAAE,IAAY;QACpD,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAC7C,CAAC;+GAvHQ,eAAe;mGAAf,eAAe,oUCtC5B,0vBAqBA,6tHDSc,UAAU,8FAAE,MAAM,yEAAE,cAAc,6GAAE,iBAAiB;;SAQtD,eAAe;4FAAf,eAAe;kBAX3B,SAAS;iCACM,IAAI,YACN,mBAAmB,WACpB,CAAC,UAAU,EAAE,MAAM,EAAE,cAAc,EAAE,iBAAiB,CAAC,mBAG/C,uBAAuB,CAAC,MAAM,QACzC;wBACF,kBAAkB,EAAE,gBAAgB;qBACvC;8BAOM,KAAK;sBADX,KAAK;gBAUC,WAAW;sBADjB,KAAK;gBAIC,GAAG;sBADT,KAAK;gBAIC,GAAG;sBADT,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,mBAAmB;sBADzB,KAAK;gBAIU,SAAS;sBADxB,MAAM","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n} from '@angular/core';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport type {TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {\n    MAX_YEAR,\n    MIN_YEAR,\n    TuiDay,\n    TuiMonth,\n    TuiMonthRange,\n    TuiYear,\n} from '@taiga-ui/cdk/date-time';\nimport {TuiHovered} from '@taiga-ui/cdk/directives/hovered';\nimport {TuiLet} from '@taiga-ui/cdk/directives/let';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsNumber} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiScrollIntoView} from '@taiga-ui/core/components/scrollbar';\n\nconst LIMIT = 100;\nconst ITEMS_IN_ROW = 4;\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-year',\n    imports: [TuiHovered, TuiLet, TuiRepeatTimes, TuiScrollIntoView],\n    templateUrl: './calendar-year.template.html',\n    styleUrls: ['./calendar-year.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class._picking]': 'isRangePicking',\n    },\n})\nexport class TuiCalendarYear {\n    private hoveredItem: number | null = null;\n    private readonly currentYear = TuiMonth.currentLocal().year;\n\n    @Input()\n    public value:\n        | TuiDayRange\n        | TuiMonthRange\n        | TuiYear\n        | number\n        | readonly TuiDay[]\n        | null = null;\n\n    @Input()\n    public initialItem: number = this.currentYear;\n\n    @Input()\n    public min: number | null = MIN_YEAR;\n\n    @Input()\n    public max: number | null = MAX_YEAR;\n\n    @Input()\n    public rangeMode = false;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<number> = TUI_FALSE_HANDLER;\n\n    @Output()\n    public readonly yearClick = new EventEmitter<number>();\n\n    public isDisabled(item: number): boolean {\n        return (\n            (this.max && this.max < item) ||\n            (this.min && this.min > item) ||\n            this.disabledItemHandler(item)\n        );\n    }\n\n    public getItemRange(item: number): 'active' | 'end' | 'middle' | 'start' | null {\n        const {value, hoveredItem} = this;\n\n        if (value instanceof TuiYear && value.year === item) {\n            return 'active';\n        }\n\n        if (tuiIsNumber(value)) {\n            return value === item ? 'active' : null;\n        }\n\n        if (!(value instanceof TuiMonthRange) && !(value instanceof TuiYear)) {\n            return value?.find((day) => day.year === item) ? 'active' : null;\n        }\n\n        const hovered = this.isRangePicking ? hoveredItem : null;\n        const from = 'from' in value ? value.from?.year : value.year;\n        const to = 'from' in value ? value.to.year : value.year;\n\n        const min = Math.min(from, hovered ?? to);\n        const max = Math.max(from, hovered ?? to);\n\n        if (min === max && from === to && from === item) {\n            return 'active';\n        }\n\n        if (min === item) {\n            return 'start';\n        }\n\n        if (max === item) {\n            return 'end';\n        }\n\n        return min < item && item < max ? 'middle' : null;\n    }\n\n    public onItemHovered(hovered: boolean, item: number): void {\n        this.updateHoveredItem(hovered, item);\n    }\n\n    protected get isRangePicking(): boolean {\n        return (\n            this.rangeMode &&\n            (this.value instanceof TuiDay || this.value instanceof TuiMonth)\n        );\n    }\n\n    protected get rows(): number {\n        return Math.ceil((this.calculatedMax - this.calculatedMin) / ITEMS_IN_ROW);\n    }\n\n    protected scrollItemIntoView(item: number): boolean {\n        return this.initialItem === item;\n    }\n\n    protected getItem(rowIndex: number, colIndex: number): number {\n        return rowIndex * ITEMS_IN_ROW + colIndex + this.calculatedMin;\n    }\n\n    protected itemIsToday(item: number): boolean {\n        return this.currentYear === item;\n    }\n\n    private get calculatedMin(): number {\n        const initial = this.initialItem - LIMIT;\n        const min = this.min ?? MIN_YEAR;\n\n        return min > initial ? min : initial;\n    }\n\n    private get calculatedMax(): number {\n        const initial = this.initialItem + LIMIT;\n        const max = this.max ?? MAX_YEAR;\n\n        return max < initial ? max + 1 : initial;\n    }\n\n    private updateHoveredItem(hovered: boolean, item: number): void {\n        this.hoveredItem = hovered ? item : null;\n    }\n}\n","<div\n    *tuiRepeatTimes=\"let rowIndex of rows\"\n    automation-id=\"tui-calendar-year__row\"\n    class=\"t-row\"\n>\n    <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n        <div\n            *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n            automation-id=\"tui-calendar-year__cell\"\n            class=\"t-cell\"\n            [attr.data-range]=\"getItemRange(item)\"\n            [class.t-cell_disabled]=\"isDisabled(item)\"\n            [class.t-cell_today]=\"itemIsToday(item)\"\n            [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n            (click)=\"yearClick.emit(item)\"\n            (tuiHoveredChange)=\"onItemHovered($event, item)\"\n        >\n            {{ item }}\n        </div>\n    </ng-container>\n</div>\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-year.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar-year.component.ts","../../../../../projects/core/components/calendar/calendar-year.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    signal,\n} from '@angular/core';\nimport type {TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {\n    MAX_YEAR,\n    MIN_YEAR,\n    TuiDay,\n    TuiMonth,\n    TuiMonthRange,\n    TuiYear,\n} from '@taiga-ui/cdk/date-time';\nimport {TuiHovered} from '@taiga-ui/cdk/directives/hovered';\nimport {TuiLet} from '@taiga-ui/cdk/directives/let';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsNumber} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiScrollIntoView} from '@taiga-ui/core/components/scrollbar';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives';\nimport {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\n\nconst LIMIT = 100;\nconst ITEMS_IN_ROW = 4;\nconst CURRENT_YEAR = TuiMonth.currentLocal().year;\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-year',\n    imports: [TuiHovered, TuiLet, TuiRepeatTimes, TuiScrollIntoView],\n    templateUrl: './calendar-year.template.html',\n    styleUrls: ['./calendar-year.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsAuxiliary(TuiCalendarYear)],\n    host: {\n        '[class._picking]': 'isRangePicking()',\n    },\n})\nexport class TuiCalendarYear {\n    private readonly hoveredItem = signal<number | null>(null);\n\n    protected readonly isRangePicking = computed(\n        (x = this.value()) =>\n            this.rangeMode && (x instanceof TuiDay || x instanceof TuiMonth),\n    );\n\n    @Input()\n    public rangeMode = false;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<number> =\n        inject(TUI_ITEMS_HANDLERS).disabledItemHandler();\n\n    @Output()\n    public readonly yearClick = new EventEmitter<number>();\n\n    public readonly initialItem = signal<number>(CURRENT_YEAR);\n    public readonly min = signal(MIN_YEAR);\n    public readonly max = signal(MAX_YEAR);\n    public readonly value = signal<\n        TuiDayRange | TuiMonthRange | TuiYear | number | readonly TuiDay[] | null\n    >(null);\n\n    // TODO(v5): use signal inputs\n    @Input({alias: 'initialItem', transform: (x: number | null) => x ?? CURRENT_YEAR})\n    public set initialItemSetter(x: number | null) {\n        this.initialItem.set(x ?? CURRENT_YEAR);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input({alias: 'min', transform: (x: number | null) => x ?? MIN_YEAR})\n    public set minSetter(x: number) {\n        this.min.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input({alias: 'max', transform: (x: number | null) => x ?? MAX_YEAR})\n    public set maxSetter(x: number) {\n        this.max.set(x);\n    }\n\n    // TODO(v5): use signal inputs\n    @Input('value')\n    public set valueSetter(\n        x: TuiDayRange | TuiMonthRange | TuiYear | number | readonly TuiDay[] | null,\n    ) {\n        this.value.set(x);\n    }\n\n    public isDisabled(item: number): boolean {\n        return (\n            (this.max() && this.max() < item) ||\n            (this.min() && this.min() > item) ||\n            this.disabledItemHandler(item)\n        );\n    }\n\n    public getItemRange(item: number): 'active' | 'end' | 'middle' | 'start' | null {\n        const value = this.value();\n        const hoveredItem = this.hoveredItem();\n\n        if (value instanceof TuiYear && value.year === item) {\n            return 'active';\n        }\n\n        if (tuiIsNumber(value)) {\n            return value === item ? 'active' : null;\n        }\n\n        if (!(value instanceof TuiMonthRange) && !(value instanceof TuiYear)) {\n            return value?.find((day) => day.year === item) ? 'active' : null;\n        }\n\n        const hovered = this.isRangePicking() ? hoveredItem : null;\n        const from = 'from' in value ? value.from?.year : value.year;\n        const to = 'from' in value ? value.to.year : value.year;\n\n        const min = Math.min(from, hovered ?? to);\n        const max = Math.max(from, hovered ?? to);\n\n        if (min === max && from === to && from === item) {\n            return 'active';\n        }\n\n        if (min === item) {\n            return 'start';\n        }\n\n        if (max === item) {\n            return 'end';\n        }\n\n        return min < item && item < max ? 'middle' : null;\n    }\n\n    public onItemHovered(hovered: boolean, item: number): void {\n        this.hoveredItem.set(hovered ? item : null);\n    }\n\n    protected get rows(): number {\n        return Math.ceil((this.calculatedMax - this.calculatedMin) / ITEMS_IN_ROW);\n    }\n\n    protected scrollItemIntoView(item: number): boolean {\n        return this.initialItem() === item;\n    }\n\n    protected getItem(rowIndex: number, colIndex: number): number {\n        return rowIndex * ITEMS_IN_ROW + colIndex + this.calculatedMin;\n    }\n\n    protected itemIsToday(item: number): boolean {\n        return CURRENT_YEAR === item;\n    }\n\n    private get calculatedMin(): number {\n        const initial = this.initialItem() - LIMIT;\n        const min = this.min() ?? MIN_YEAR;\n\n        return min > initial ? min : initial;\n    }\n\n    private get calculatedMax(): number {\n        const initial = this.initialItem() + LIMIT;\n        const max = this.max() ?? MAX_YEAR;\n\n        return max < initial ? max + 1 : initial;\n    }\n}\n","<div\n    *tuiRepeatTimes=\"let rowIndex of rows\"\n    automation-id=\"tui-calendar-year__row\"\n    class=\"t-row\"\n>\n    <ng-container *tuiRepeatTimes=\"let colIndex of 4\">\n        <div\n            *tuiLet=\"getItem(rowIndex, colIndex) as item\"\n            automation-id=\"tui-calendar-year__cell\"\n            class=\"t-cell\"\n            [attr.data-range]=\"getItemRange(item)\"\n            [class.t-cell_disabled]=\"isDisabled(item)\"\n            [class.t-cell_today]=\"itemIsToday(item)\"\n            [tuiScrollIntoView]=\"scrollItemIntoView(item)\"\n            (click)=\"yearClick.emit(item)\"\n            (tuiHoveredChange)=\"onItemHovered($event, item)\"\n        >\n            {{ item }}\n        </div>\n    </ng-container>\n</div>\n"]}
|
|
@@ -100,7 +100,7 @@ class TuiCalendar {
|
|
|
100
100
|
this.hoveredItemChange.emit(day);
|
|
101
101
|
}
|
|
102
102
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
103
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendar, isStandalone: true, selector: "tui-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", min: "min", max: "max", minViewedMonth: "minViewedMonth", maxViewedMonth: "maxViewedMonth", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", markerHandler: "markerHandler", value: "value", initialView: "initialView" }, outputs: { dayClick: "dayClick", monthChange: "monthChange", hoveredItemChange: "hoveredItemChange" }, host: { listeners: { "pointerdown.prevent.zoneless": "0" } }, providers: [tuiAsAuxiliary(TuiCalendar)], ngImport: i0, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCalendarSheet, selector: "tui-calendar-sheet", inputs: ["month", "disabledItemHandler", "markerHandler", "value", "hoveredItem", "showAdjacent", "single"], outputs: ["hoveredItemChange", "dayClick"] }, { kind: "component", type: TuiCalendarSpin, selector: "tui-calendar-spin", inputs: ["value", "min", "max"], outputs: ["valueChange", "yearClick"] }, { kind: "component", type: TuiCalendarYear, selector: "tui-calendar-year", inputs: ["
|
|
103
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendar, isStandalone: true, selector: "tui-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", min: "min", max: "max", minViewedMonth: "minViewedMonth", maxViewedMonth: "maxViewedMonth", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", markerHandler: "markerHandler", value: "value", initialView: "initialView" }, outputs: { dayClick: "dayClick", monthChange: "monthChange", hoveredItemChange: "hoveredItemChange" }, host: { listeners: { "pointerdown.prevent.zoneless": "0" } }, providers: [tuiAsAuxiliary(TuiCalendar)], ngImport: i0, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiCalendarSheet, selector: "tui-calendar-sheet", inputs: ["month", "disabledItemHandler", "markerHandler", "value", "hoveredItem", "showAdjacent", "single"], outputs: ["hoveredItemChange", "dayClick"] }, { kind: "component", type: TuiCalendarSpin, selector: "tui-calendar-spin", inputs: ["value", "min", "max"], outputs: ["valueChange", "yearClick"] }, { kind: "component", type: TuiCalendarYear, selector: "tui-calendar-year", inputs: ["rangeMode", "disabledItemHandler", "initialItem", "min", "max", "value"], outputs: ["yearClick"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
104
104
|
}
|
|
105
105
|
export { TuiCalendar };
|
|
106
106
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, decorators: [{
|
|
@@ -114,7 +114,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
114
114
|
TuiScrollbar,
|
|
115
115
|
], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendar)], host: {
|
|
116
116
|
'(pointerdown.prevent.zoneless)': '0',
|
|
117
|
-
}, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"] }]
|
|
117
|
+
}, template: "<tui-scrollbar\n *ngIf=\"isInYearView; else calendar\"\n automation-id=\"tui-calendar__scrollbar\"\n class=\"t-scrollbar\"\n>\n <tui-calendar-year\n automation-id=\"tui-calendar__year\"\n [initialItem]=\"month.year\"\n [max]=\"computedMax.year\"\n [min]=\"computedMin.year\"\n [rangeMode]=\"options.rangeMode\"\n [value]=\"value\"\n (yearClick)=\"onPickerYearClick($event)\"\n />\n</tui-scrollbar>\n<ng-template #calendar>\n <tui-calendar-spin\n automation-id=\"tui-calendar__pagination\"\n class=\"t-pagination\"\n [max]=\"computedMaxViewedMonth\"\n [min]=\"computedMinViewedMonth\"\n [value]=\"month\"\n (valueChange)=\"onPaginationValueChange($event)\"\n (yearClick)=\"onPaginationYearClick()\"\n />\n <tui-calendar-sheet\n automation-id=\"tui-calendar__calendar\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n [hoveredItem]=\"hoveredItem\"\n [markerHandler]=\"markerHandler\"\n [month]=\"month\"\n [showAdjacent]=\"showAdjacent\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (hoveredItemChange)=\"onHoveredItemChange($event)\"\n />\n</ng-template>\n", styles: [":host{display:block;min-block-size:20.25rem;inline-size:18rem;padding:1rem 1.125rem;box-sizing:border-box;flex-shrink:0}:host-context(tui-dropdown-mobile){inline-size:100%}tui-calendar-year{padding:0}.t-scrollbar{block-size:18.25rem;inline-size:calc(100% + 1rem)}.t-pagination{margin-block-end:1rem}\n"] }]
|
|
118
118
|
}], propDecorators: { month: [{
|
|
119
119
|
type: Input
|
|
120
120
|
}], disabledItemHandler: [{
|
|
@@ -144,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
144
144
|
}], initialView: [{
|
|
145
145
|
type: Input
|
|
146
146
|
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar.component.ts","../../../../../projects/core/components/calendar/calendar.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport type {TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {\n    TUI_FIRST_DAY,\n    TUI_LAST_DAY,\n    TUI_LAST_DISPLAYED_DAY,\n    TuiDay,\n    TuiMonth,\n} from '@taiga-ui/cdk/date-time';\nimport {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport type {TuiBooleanHandler, TuiMapper} from '@taiga-ui/cdk/types';\nimport {tuiNullableSame} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiScrollbar} from '@taiga-ui/core/components/scrollbar';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives';\nimport {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {Subject} from 'rxjs';\n\nimport type {TuiMarkerHandler} from './calendar-sheet.component';\nimport {TuiCalendarSheet} from './calendar-sheet.component';\nimport {TUI_CALENDAR_SHEET_OPTIONS} from './calendar-sheet.options';\nimport {TuiCalendarSpin} from './calendar-spin.component';\nimport {TuiCalendarYear} from './calendar-year.component';\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar',\n    imports: [\n        NgIf,\n        TuiCalendarSheet,\n        TuiCalendarSpin,\n        TuiCalendarYear,\n        TuiMapperPipe,\n        TuiScrollbar,\n    ],\n    templateUrl: './calendar.template.html',\n    styleUrls: ['./calendar.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsAuxiliary(TuiCalendar)],\n    host: {\n        '(pointerdown.prevent.zoneless)': '0',\n    },\n})\nexport class TuiCalendar {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private day: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n    private view: 'month' | 'year' = 'month';\n    protected readonly options = inject(TUI_CALENDAR_SHEET_OPTIONS);\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> =\n        inject(TUI_ITEMS_HANDLERS).disabledItemHandler();\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 minViewedMonth: TuiMonth | null = TUI_FIRST_DAY;\n\n    @Input()\n    public maxViewedMonth: TuiMonth | null = TUI_LAST_DAY;\n\n    @Input()\n    public hoveredItem: TuiDay | null = null;\n\n    @Input()\n    public showAdjacent = true;\n\n    @Input()\n    public markerHandler: TuiMarkerHandler | null = null;\n\n    @Output()\n    public readonly dayClick = new EventEmitter<TuiDay>();\n\n    @Output()\n    public readonly monthChange = new EventEmitter<TuiMonth>();\n\n    @Output()\n    public readonly hoveredItemChange = new EventEmitter<TuiDay | null>();\n\n    /** @deprecated for private use only until Calendars are refactored */\n    public readonly valueChange = new Subject<TuiDay>();\n\n    @Input()\n    public set value(value: TuiDay | TuiDayRange | readonly TuiDay[] | null) {\n        this.cdr.markForCheck();\n        this.day = value;\n\n        if (\n            this.showAdjacent &&\n            value instanceof TuiDay &&\n            value.daySameOrBefore(TUI_LAST_DISPLAYED_DAY)\n        ) {\n            this.month = value;\n        }\n    }\n\n    @Input()\n    public set initialView(view: 'month' | 'year') {\n        this.view = view;\n    }\n\n    public get value(): TuiDay | TuiDayRange | readonly TuiDay[] | null {\n        return this.day;\n    }\n\n    public onPaginationValueChange(month: TuiMonth): void {\n        this.updateViewedMonth(month);\n    }\n\n    public onDayClick(day: TuiDay): void {\n        this.dayClick.emit(day);\n        this.valueChange.next(day);\n    }\n\n    public onHoveredItemChange(day: TuiDay | null): void {\n        this.updateHoveredDay(day);\n    }\n\n    protected get computedMin(): TuiDay {\n        return this.min ?? TUI_FIRST_DAY;\n    }\n\n    protected get computedMax(): TuiDay {\n        return this.max ?? TUI_LAST_DAY;\n    }\n\n    protected get computedMinViewedMonth(): TuiMonth {\n        const min = this.computedMin;\n        const minViewed = this.minViewedMonth ?? TUI_FIRST_DAY;\n\n        return minViewed.monthSameOrAfter(min) ? minViewed : min;\n    }\n\n    protected get computedMaxViewedMonth(): TuiMonth {\n        const max = this.computedMax;\n        const maxViewed = this.maxViewedMonth ?? TUI_LAST_DAY;\n\n        return maxViewed.monthSameOrBefore(max) ? maxViewed : max;\n    }\n\n    protected get isInYearView(): boolean {\n        return this.view === 'year';\n    }\n\n    protected readonly disabledItemHandlerMapper: TuiMapper<\n        [TuiBooleanHandler<TuiDay>, TuiDay, TuiDay],\n        TuiBooleanHandler<TuiDay>\n    > = (disabledItemHandler, min, max) => (item) =>\n        item.dayBefore(min) || item.dayAfter(max) || disabledItemHandler(item);\n\n    protected onPaginationYearClick(): void {\n        this.view = 'year';\n    }\n\n    protected onPickerYearClick(year: number): void {\n        this.view = 'month';\n        this.updateViewedMonth(new TuiMonth(year, this.month.month));\n    }\n\n    private updateViewedMonth(month: TuiMonth): void {\n        if (this.month.monthSame(month)) {\n            return;\n        }\n\n        this.month = month;\n        this.monthChange.emit(month);\n    }\n\n    private updateHoveredDay(day: TuiDay | null): void {\n        if (tuiNullableSame(this.hoveredItem, day, (a, b) => a.daySame(b))) {\n            return;\n        }\n\n        this.hoveredItem = day;\n        this.hoveredItemChange.emit(day);\n    }\n}\n","<tui-scrollbar\n    *ngIf=\"isInYearView; else calendar\"\n    automation-id=\"tui-calendar__scrollbar\"\n    class=\"t-scrollbar\"\n>\n    <tui-calendar-year\n        automation-id=\"tui-calendar__year\"\n        [initialItem]=\"month.year\"\n        [max]=\"computedMax.year\"\n        [min]=\"computedMin.year\"\n        [rangeMode]=\"options.rangeMode\"\n        [value]=\"value\"\n        (yearClick)=\"onPickerYearClick($event)\"\n    />\n</tui-scrollbar>\n<ng-template #calendar>\n    <tui-calendar-spin\n        automation-id=\"tui-calendar__pagination\"\n        class=\"t-pagination\"\n        [max]=\"computedMaxViewedMonth\"\n        [min]=\"computedMinViewedMonth\"\n        [value]=\"month\"\n        (valueChange)=\"onPaginationValueChange($event)\"\n        (yearClick)=\"onPaginationYearClick()\"\n    />\n    <tui-calendar-sheet\n        automation-id=\"tui-calendar__calendar\"\n        [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n        [hoveredItem]=\"hoveredItem\"\n        [markerHandler]=\"markerHandler\"\n        [month]=\"month\"\n        [showAdjacent]=\"showAdjacent\"\n        [value]=\"value\"\n        (dayClick)=\"onDayClick($event)\"\n        (hoveredItemChange)=\"onHoveredItemChange($event)\"\n    />\n</ng-template>\n"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar.component.ts","../../../../../projects/core/components/calendar/calendar.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport type {TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {\n    TUI_FIRST_DAY,\n    TUI_LAST_DAY,\n    TUI_LAST_DISPLAYED_DAY,\n    TuiDay,\n    TuiMonth,\n} from '@taiga-ui/cdk/date-time';\nimport {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport type {TuiBooleanHandler, TuiMapper} from '@taiga-ui/cdk/types';\nimport {tuiNullableSame} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiScrollbar} from '@taiga-ui/core/components/scrollbar';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives';\nimport {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {Subject} from 'rxjs';\n\nimport type {TuiMarkerHandler} from './calendar-sheet.component';\nimport {TuiCalendarSheet} from './calendar-sheet.component';\nimport {TUI_CALENDAR_SHEET_OPTIONS} from './calendar-sheet.options';\nimport {TuiCalendarSpin} from './calendar-spin.component';\nimport {TuiCalendarYear} from './calendar-year.component';\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar',\n    imports: [\n        NgIf,\n        TuiCalendarSheet,\n        TuiCalendarSpin,\n        TuiCalendarYear,\n        TuiMapperPipe,\n        TuiScrollbar,\n    ],\n    templateUrl: './calendar.template.html',\n    styleUrls: ['./calendar.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsAuxiliary(TuiCalendar)],\n    host: {\n        '(pointerdown.prevent.zoneless)': '0',\n    },\n})\nexport class TuiCalendar {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private day: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n    private view: 'month' | 'year' = 'month';\n    protected readonly options = inject(TUI_CALENDAR_SHEET_OPTIONS);\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> =\n        inject(TUI_ITEMS_HANDLERS).disabledItemHandler();\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 minViewedMonth: TuiMonth | null = TUI_FIRST_DAY;\n\n    @Input()\n    public maxViewedMonth: TuiMonth | null = TUI_LAST_DAY;\n\n    @Input()\n    public hoveredItem: TuiDay | null = null;\n\n    @Input()\n    public showAdjacent = true;\n\n    @Input()\n    public markerHandler: TuiMarkerHandler | null = null;\n\n    @Output()\n    public readonly dayClick = new EventEmitter<TuiDay>();\n\n    @Output()\n    public readonly monthChange = new EventEmitter<TuiMonth>();\n\n    @Output()\n    public readonly hoveredItemChange = new EventEmitter<TuiDay | null>();\n\n    /** @deprecated for private use only until Calendars are refactored */\n    public readonly valueChange = new Subject<TuiDay>();\n\n    @Input()\n    public set value(value: TuiDay | TuiDayRange | readonly TuiDay[] | null) {\n        this.cdr.markForCheck();\n        this.day = value;\n\n        if (\n            this.showAdjacent &&\n            value instanceof TuiDay &&\n            value.daySameOrBefore(TUI_LAST_DISPLAYED_DAY)\n        ) {\n            this.month = value;\n        }\n    }\n\n    @Input()\n    public set initialView(view: 'month' | 'year') {\n        this.view = view;\n    }\n\n    public get value(): TuiDay | TuiDayRange | readonly TuiDay[] | null {\n        return this.day;\n    }\n\n    public onPaginationValueChange(month: TuiMonth): void {\n        this.updateViewedMonth(month);\n    }\n\n    public onDayClick(day: TuiDay): void {\n        this.dayClick.emit(day);\n        this.valueChange.next(day);\n    }\n\n    public onHoveredItemChange(day: TuiDay | null): void {\n        this.updateHoveredDay(day);\n    }\n\n    protected get computedMin(): TuiDay {\n        return this.min ?? TUI_FIRST_DAY;\n    }\n\n    protected get computedMax(): TuiDay {\n        return this.max ?? TUI_LAST_DAY;\n    }\n\n    protected get computedMinViewedMonth(): TuiMonth {\n        const min = this.computedMin;\n        const minViewed = this.minViewedMonth ?? TUI_FIRST_DAY;\n\n        return minViewed.monthSameOrAfter(min) ? minViewed : min;\n    }\n\n    protected get computedMaxViewedMonth(): TuiMonth {\n        const max = this.computedMax;\n        const maxViewed = this.maxViewedMonth ?? TUI_LAST_DAY;\n\n        return maxViewed.monthSameOrBefore(max) ? maxViewed : max;\n    }\n\n    protected get isInYearView(): boolean {\n        return this.view === 'year';\n    }\n\n    protected readonly disabledItemHandlerMapper: TuiMapper<\n        [TuiBooleanHandler<TuiDay>, TuiDay, TuiDay],\n        TuiBooleanHandler<TuiDay>\n    > = (disabledItemHandler, min, max) => (item) =>\n        item.dayBefore(min) || item.dayAfter(max) || disabledItemHandler(item);\n\n    protected onPaginationYearClick(): void {\n        this.view = 'year';\n    }\n\n    protected onPickerYearClick(year: number): void {\n        this.view = 'month';\n        this.updateViewedMonth(new TuiMonth(year, this.month.month));\n    }\n\n    private updateViewedMonth(month: TuiMonth): void {\n        if (this.month.monthSame(month)) {\n            return;\n        }\n\n        this.month = month;\n        this.monthChange.emit(month);\n    }\n\n    private updateHoveredDay(day: TuiDay | null): void {\n        if (tuiNullableSame(this.hoveredItem, day, (a, b) => a.daySame(b))) {\n            return;\n        }\n\n        this.hoveredItem = day;\n        this.hoveredItemChange.emit(day);\n    }\n}\n","<tui-scrollbar\n    *ngIf=\"isInYearView; else calendar\"\n    automation-id=\"tui-calendar__scrollbar\"\n    class=\"t-scrollbar\"\n>\n    <tui-calendar-year\n        automation-id=\"tui-calendar__year\"\n        [initialItem]=\"month.year\"\n        [max]=\"computedMax.year\"\n        [min]=\"computedMin.year\"\n        [rangeMode]=\"options.rangeMode\"\n        [value]=\"value\"\n        (yearClick)=\"onPickerYearClick($event)\"\n    />\n</tui-scrollbar>\n<ng-template #calendar>\n    <tui-calendar-spin\n        automation-id=\"tui-calendar__pagination\"\n        class=\"t-pagination\"\n        [max]=\"computedMaxViewedMonth\"\n        [min]=\"computedMinViewedMonth\"\n        [value]=\"month\"\n        (valueChange)=\"onPaginationValueChange($event)\"\n        (yearClick)=\"onPaginationYearClick()\"\n    />\n    <tui-calendar-sheet\n        automation-id=\"tui-calendar__calendar\"\n        [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerMapper : computedMin : computedMax\"\n        [hoveredItem]=\"hoveredItem\"\n        [markerHandler]=\"markerHandler\"\n        [month]=\"month\"\n        [showAdjacent]=\"showAdjacent\"\n        [value]=\"value\"\n        (dayClick)=\"onDayClick($event)\"\n        (hoveredItemChange)=\"onHoveredItemChange($event)\"\n    />\n</ng-template>\n"]}
|
|
@@ -59,7 +59,7 @@ class TuiRoot {
|
|
|
59
59
|
: !this.isChildRoot;
|
|
60
60
|
}
|
|
61
61
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.
|
|
62
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRoot, isStandalone: true, selector: "tui-root", host: { attributes: { "data-tui-version": "4.47.0" }, listeners: { "touchstart.passive.zoneless": "0", "document:fullscreenchange": "top.set(isTopLayer)" }, properties: { "style.--tui-duration.ms": "duration", "style.--tui-scroll-behavior": "reducedMotion ? \"auto\" : \"smooth\"", "class._mobile": "isMobileRes()" } }, hostDirectives: [{ directive: i1.TuiPlatform }, { directive: i2.TuiVisualViewport }, { directive: i3.TuiFontSize }], ngImport: i0, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{content:\"\"}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(0)}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TuiAlerts, selector: "tui-alerts" }, { kind: "component", type: TuiDialogs, selector: "tui-dialogs" }, { kind: "component", type: TuiDropdowns, selector: "tui-dropdowns" }, { kind: "component", type: TuiHints, selector: "tui-hints" }, { kind: "component", type: TuiPopups, selector: "tui-popups" }, { kind: "component", type: TuiScrollControls, selector: "tui-scroll-controls" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
|
|
63
63
|
}
|
|
64
64
|
export { TuiRoot };
|
|
65
65
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRoot, decorators: [{
|
|
@@ -80,6 +80,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
80
80
|
// Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490
|
|
81
81
|
'(touchstart.passive.zoneless)': '0',
|
|
82
82
|
'(document:fullscreenchange)': 'top.set(isTopLayer)',
|
|
83
|
-
}, template: "<div class=\"t-root-content\"
|
|
83
|
+
}, template: "<div class=\"t-root-content\">\n <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n <tui-scroll-controls\n *ngIf=\"scrollbars\"\n class=\"t-root-scrollbar\"\n />\n <tui-popups />\n <ng-content select=\"tuiOverContent\" />\n <tui-dialogs />\n <ng-content select=\"tuiOverDialogs\" />\n <tui-alerts />\n <ng-content select=\"tuiOverAlerts\" />\n <tui-dropdowns />\n <ng-content select=\"tuiOverDropdowns\" />\n <tui-hints />\n <ng-content select=\"tuiOverHints\" />\n</ng-container>\n", styles: ["@keyframes tuiSkeletonVibe{to{opacity:.5}}@keyframes tuiPresent{to{content:\"\"}}@keyframes tuiFade{0%{opacity:0}}@keyframes tuiSlide{0%{transform:var(--tui-from, translateY(100%))}}@keyframes tuiScale{0%{transform:scale(0)}}@keyframes tuiCollapse{0%{grid-template-rows:0fr}to{grid-template-rows:1fr}}.tui-enter,.tui-leave{animation-duration:var(--tui-duration);animation-timing-function:ease-in-out;pointer-events:none}.tui-leave{animation-direction:reverse}\n", ".tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.tui-zero-scrollbar::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar-thumb{display:none}body,input{margin:0}tui-root{position:relative;display:block;font:var(--tui-font-text-s);color:var(--tui-text-primary);flex:1;border-image:conic-gradient(var(--tui-background-base) 0 0) fill 0/0/0 0 100vh 0;-webkit-tap-highlight-color:transparent}:root{--tui-inline-start: left;--tui-inline-end: right;--tui-inline: 1}[dir=rtl]{--tui-inline-start: right;--tui-inline-end: left;--tui-inline: -1}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;z-index:0;display:none;margin:0}[data-tui-theme] tui-root>.t-root-scrollbar{display:block}.t-root-content{position:relative;top:var(--t-root-top);block-size:100%;isolation:isolate}.t-root-content>*{--t-root-top: 0}[tuiDropdownButton][tuiDropdownButton]{display:none}\n"] }]
|
|
84
84
|
}], ctorParameters: function () { return []; } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/root/root.component.ts","../../../../../projects/core/components/root/root.template.html"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport {DOCUMENT, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    RendererFactory2,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EVENT_MANAGER_PLUGINS} from '@angular/platform-browser';\nimport {TUI_VERSION} from '@taiga-ui/cdk/constants';\nimport {TuiFontSize} from '@taiga-ui/cdk/directives/font-size';\nimport {TuiPlatform} from '@taiga-ui/cdk/directives/platform';\nimport {TuiVisualViewport} from '@taiga-ui/cdk/directives/visual-viewport';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {TuiAlerts} from '@taiga-ui/core/components/alert';\nimport {TuiDialogs} from '@taiga-ui/core/components/dialog';\nimport {\n    TUI_SCROLLBAR_OPTIONS,\n    TuiScrollControls,\n} from '@taiga-ui/core/components/scrollbar';\nimport {TuiDropdowns} from '@taiga-ui/core/directives/dropdown';\nimport {TuiHints} from '@taiga-ui/core/directives/hint';\nimport {TuiPopups} from '@taiga-ui/core/directives/popup';\nimport {TuiBreakpointService} from '@taiga-ui/core/services';\nimport {TUI_ANIMATIONS_SPEED, TUI_REDUCED_MOTION, TUI_THEME} from '@taiga-ui/core/tokens';\nimport {tuiGetDuration} from '@taiga-ui/core/utils';\nimport {PreventEventPlugin} from '@taiga-ui/event-plugins';\nimport {map} from 'rxjs';\n\n@Component({\n    standalone: true,\n    selector: 'tui-root',\n    imports: [\n        NgIf,\n        TuiAlerts,\n        TuiDialogs,\n        TuiDropdowns,\n        TuiHints,\n        TuiPopups,\n        TuiScrollControls,\n    ],\n    templateUrl: './root.template.html',\n    styleUrls: ['./animations.less', './root.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n    changeDetection: ChangeDetectionStrategy.Default,\n    hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize],\n    host: {\n        'data-tui-version': TUI_VERSION,\n        '[style.--tui-duration.ms]': 'duration',\n        '[style.--tui-scroll-behavior]': 'reducedMotion ? \"auto\" : \"smooth\"',\n        '[class._mobile]': 'isMobileRes()',\n        // Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490\n        '(touchstart.passive.zoneless)': '0',\n        '(document:fullscreenchange)': 'top.set(isTopLayer)',\n    },\n})\nexport class TuiRoot {\n    private readonly doc = inject(DOCUMENT);\n    private readonly el = tuiInjectElement();\n    protected readonly reducedMotion = inject(TUI_REDUCED_MOTION);\n    protected readonly duration = tuiGetDuration(inject(TUI_ANIMATIONS_SPEED));\n    protected readonly isChildRoot = !!inject(TuiRoot, {optional: true, skipSelf: true});\n    protected readonly top = signal(!this.isChildRoot);\n    protected readonly isMobileRes = toSignal(\n        inject(TuiBreakpointService).pipe(\n            map((breakpoint) => breakpoint === 'mobile'),\n            tuiWatch(),\n        ),\n        {initialValue: false},\n    );\n\n    protected readonly nativeScrollbar = inject(TUI_SCROLLBAR_OPTIONS).mode === 'native';\n\n    protected readonly scrollbars =\n        !this.nativeScrollbar && !inject(TUI_IS_MOBILE) && !this.isChildRoot;\n\n    constructor() {\n        // TODO move to provideTaiga in v5\n        const factory = inject<any>(RendererFactory2);\n\n        factory.removeStylesOnCompDestroy = false;\n\n        if (factory.delegate) {\n            factory.delegate.removeStylesOnCompDestroy = false;\n        }\n\n        if (!this.top()) {\n            return;\n        }\n\n        this.doc.documentElement.setAttribute(\n            'data-tui-theme',\n            inject(TUI_THEME).toLowerCase(),\n        );\n\n        if (!this.nativeScrollbar) {\n            this.doc.defaultView?.document.documentElement.classList.add(\n                'tui-zero-scrollbar',\n            );\n        }\n\n        ngDevMode &&\n            console.assert(\n                !!inject<unknown[]>(EVENT_MANAGER_PLUGINS).find(\n                    (plugin) => plugin instanceof PreventEventPlugin,\n                ),\n                'NG_EVENT_PLUGINS is missing from global providers',\n            );\n    }\n\n    protected get isTopLayer(): boolean {\n        return this.doc.fullscreenElement?.matches('tui-root')\n            ? this.doc.fullscreenElement === this.el\n            : !this.isChildRoot;\n    }\n}\n","<div class=\"t-root-content\"><ng-content /></div>\n<ng-container *ngIf=\"top()\">\n    <tui-scroll-controls\n        *ngIf=\"scrollbars\"\n        class=\"t-root-scrollbar\"\n    />\n    <tui-popups />\n    <ng-content select=\"tuiOverContent\" />\n    <tui-dialogs />\n    <ng-content select=\"tuiOverDialogs\" />\n    <tui-alerts />\n    <ng-content select=\"tuiOverAlerts\" />\n    <tui-dropdowns />\n    <ng-content select=\"tuiOverDropdowns\" />\n    <tui-hints />\n    <ng-content select=\"tuiOverHints\" />\n</ng-container>\n"]}
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"root.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/root/root.component.ts","../../../../../projects/core/components/root/root.template.html"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport {DOCUMENT, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    RendererFactory2,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {EVENT_MANAGER_PLUGINS} from '@angular/platform-browser';\nimport {TUI_VERSION} from '@taiga-ui/cdk/constants';\nimport {TuiFontSize} from '@taiga-ui/cdk/directives/font-size';\nimport {TuiPlatform} from '@taiga-ui/cdk/directives/platform';\nimport {TuiVisualViewport} from '@taiga-ui/cdk/directives/visual-viewport';\nimport {tuiWatch} from '@taiga-ui/cdk/observables';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {TuiAlerts} from '@taiga-ui/core/components/alert';\nimport {TuiDialogs} from '@taiga-ui/core/components/dialog';\nimport {\n    TUI_SCROLLBAR_OPTIONS,\n    TuiScrollControls,\n} from '@taiga-ui/core/components/scrollbar';\nimport {TuiDropdowns} from '@taiga-ui/core/directives/dropdown';\nimport {TuiHints} from '@taiga-ui/core/directives/hint';\nimport {TuiPopups} from '@taiga-ui/core/directives/popup';\nimport {TuiBreakpointService} from '@taiga-ui/core/services';\nimport {TUI_ANIMATIONS_SPEED, TUI_REDUCED_MOTION, TUI_THEME} from '@taiga-ui/core/tokens';\nimport {tuiGetDuration} from '@taiga-ui/core/utils';\nimport {PreventEventPlugin} from '@taiga-ui/event-plugins';\nimport {map} from 'rxjs';\n\n@Component({\n    standalone: true,\n    selector: 'tui-root',\n    imports: [\n        NgIf,\n        TuiAlerts,\n        TuiDialogs,\n        TuiDropdowns,\n        TuiHints,\n        TuiPopups,\n        TuiScrollControls,\n    ],\n    templateUrl: './root.template.html',\n    styleUrls: ['./animations.less', './root.style.less'],\n    encapsulation: ViewEncapsulation.None,\n    // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n    changeDetection: ChangeDetectionStrategy.Default,\n    hostDirectives: [TuiPlatform, TuiVisualViewport, TuiFontSize],\n    host: {\n        'data-tui-version': TUI_VERSION,\n        '[style.--tui-duration.ms]': 'duration',\n        '[style.--tui-scroll-behavior]': 'reducedMotion ? \"auto\" : \"smooth\"',\n        '[class._mobile]': 'isMobileRes()',\n        // Required for the :active state to work in Safari. https://stackoverflow.com/a/33681490\n        '(touchstart.passive.zoneless)': '0',\n        '(document:fullscreenchange)': 'top.set(isTopLayer)',\n    },\n})\nexport class TuiRoot {\n    private readonly doc = inject(DOCUMENT);\n    private readonly el = tuiInjectElement();\n    protected readonly reducedMotion = inject(TUI_REDUCED_MOTION);\n    protected readonly duration = tuiGetDuration(inject(TUI_ANIMATIONS_SPEED));\n    protected readonly isChildRoot = !!inject(TuiRoot, {optional: true, skipSelf: true});\n    protected readonly top = signal(!this.isChildRoot);\n    protected readonly isMobileRes = toSignal(\n        inject(TuiBreakpointService).pipe(\n            map((breakpoint) => breakpoint === 'mobile'),\n            tuiWatch(),\n        ),\n        {initialValue: false},\n    );\n\n    protected readonly nativeScrollbar = inject(TUI_SCROLLBAR_OPTIONS).mode === 'native';\n\n    protected readonly scrollbars =\n        !this.nativeScrollbar && !inject(TUI_IS_MOBILE) && !this.isChildRoot;\n\n    constructor() {\n        // TODO move to provideTaiga in v5\n        const factory = inject<any>(RendererFactory2);\n\n        factory.removeStylesOnCompDestroy = false;\n\n        if (factory.delegate) {\n            factory.delegate.removeStylesOnCompDestroy = false;\n        }\n\n        if (!this.top()) {\n            return;\n        }\n\n        this.doc.documentElement.setAttribute(\n            'data-tui-theme',\n            inject(TUI_THEME).toLowerCase(),\n        );\n\n        if (!this.nativeScrollbar) {\n            this.doc.defaultView?.document.documentElement.classList.add(\n                'tui-zero-scrollbar',\n            );\n        }\n\n        ngDevMode &&\n            console.assert(\n                !!inject<unknown[]>(EVENT_MANAGER_PLUGINS).find(\n                    (plugin) => plugin instanceof PreventEventPlugin,\n                ),\n                'NG_EVENT_PLUGINS is missing from global providers',\n            );\n    }\n\n    protected get isTopLayer(): boolean {\n        return this.doc.fullscreenElement?.matches('tui-root')\n            ? this.doc.fullscreenElement === this.el\n            : !this.isChildRoot;\n    }\n}\n","<div class=\"t-root-content\">\n    <ng-content />\n</div>\n<ng-container *ngIf=\"top()\">\n    <tui-scroll-controls\n        *ngIf=\"scrollbars\"\n        class=\"t-root-scrollbar\"\n    />\n    <tui-popups />\n    <ng-content select=\"tuiOverContent\" />\n    <tui-dialogs />\n    <ng-content select=\"tuiOverDialogs\" />\n    <tui-alerts />\n    <ng-content select=\"tuiOverAlerts\" />\n    <tui-dropdowns />\n    <ng-content select=\"tuiOverDropdowns\" />\n    <tui-hints />\n    <ng-content select=\"tuiOverHints\" />\n</ng-container>\n"]}
|