@taiga-ui/core 4.21.0 → 4.22.0-canary.5cb8d03
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-sheet.component.d.ts +15 -2
- package/components/calendar/calendar-sheet.options.d.ts +7 -0
- package/components/calendar/index.d.ts +1 -0
- package/components/textfield/select.directive.d.ts +1 -1
- package/components/textfield/textfield.component.d.ts +3 -3
- package/components/textfield/textfield.directive.d.ts +1 -1
- package/esm2022/components/calendar/calendar-sheet.component.mjs +46 -17
- package/esm2022/components/calendar/calendar-sheet.options.mjs +9 -0
- package/esm2022/components/calendar/calendar.component.mjs +2 -2
- package/esm2022/components/calendar/index.mjs +2 -1
- package/esm2022/components/data-list/data-list.component.mjs +3 -3
- package/esm2022/components/root/root.component.mjs +2 -2
- package/esm2022/components/textfield/select.directive.mjs +6 -6
- package/esm2022/components/textfield/textfield.component.mjs +9 -9
- package/esm2022/components/textfield/textfield.directive.mjs +2 -2
- package/esm2022/directives/hint/hint.component.mjs +5 -5
- package/fesm2022/taiga-ui-core-components-calendar.mjs +55 -19
- package/fesm2022/taiga-ui-core-components-calendar.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-data-list.mjs +2 -2
- package/fesm2022/taiga-ui-core-components-data-list.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs +1 -1
- package/fesm2022/taiga-ui-core-components-root.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-components-textfield.mjs +14 -14
- package/fesm2022/taiga-ui-core-components-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-core-directives-hint.mjs +4 -4
- package/fesm2022/taiga-ui-core-directives-hint.mjs.map +1 -1
- package/package.json +3 -3
|
@@ -4,6 +4,7 @@ import type { TuiBooleanHandler, TuiHandler } from '@taiga-ui/cdk/types';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export type TuiMarkerHandler = TuiHandler<TuiDay, [] | [string, string] | [string]>;
|
|
6
6
|
export declare class TuiCalendarSheet {
|
|
7
|
+
private readonly options;
|
|
7
8
|
private readonly today;
|
|
8
9
|
protected readonly unorderedWeekDays$: import("rxjs").Observable<readonly [Monday: string, Tuesday: string, Wednesday: string, Thursday: string, Friday: string, Saturday: string, Sunday: string]>;
|
|
9
10
|
protected readonly dayTypeHandler: TuiHandler<TuiDay, string>;
|
|
@@ -13,12 +14,24 @@ export declare class TuiCalendarSheet {
|
|
|
13
14
|
value: TuiDay | TuiDayRange | readonly TuiDay[] | null;
|
|
14
15
|
hoveredItem: TuiDay | null;
|
|
15
16
|
showAdjacent: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* @deprecated use static DI options instead
|
|
19
|
+
* ```
|
|
20
|
+
* tuiCalendarSheetOptionsProvider({rangeMode: true})
|
|
21
|
+
* ```
|
|
22
|
+
* TODO(v5): delete it
|
|
23
|
+
*/
|
|
24
|
+
single: boolean;
|
|
16
25
|
readonly hoveredItemChange: EventEmitter<TuiDay | null>;
|
|
17
26
|
readonly dayClick: EventEmitter<TuiDay>;
|
|
27
|
+
/**
|
|
28
|
+
* @deprecated TODO(v5): delete it. It is used nowhere except unit tests
|
|
29
|
+
*/
|
|
18
30
|
itemIsInterval(day: TuiDay): boolean;
|
|
19
31
|
onItemHovered(item: TuiDay | false): void;
|
|
20
32
|
getItemRange(item: TuiDay): 'active' | 'end' | 'middle' | 'start' | null;
|
|
21
|
-
protected get
|
|
33
|
+
protected get computedRangeMode(): boolean;
|
|
34
|
+
protected get isRangePicking(): boolean;
|
|
22
35
|
protected readonly toMarkers: (day: TuiDay, today: boolean, range: string | null, markerHandler: TuiMarkerHandler | null) => [
|
|
23
36
|
string,
|
|
24
37
|
string
|
|
@@ -32,5 +45,5 @@ export declare class TuiCalendarSheet {
|
|
|
32
45
|
private updateHoveredItem;
|
|
33
46
|
private rangeHasDisabledDay;
|
|
34
47
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiCalendarSheet, never>;
|
|
35
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSheet, "tui-calendar-sheet", never, { "month": { "alias": "month"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "markerHandler": { "alias": "markerHandler"; "required": false; }; "value": { "alias": "value"; "required": false; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; }; }, { "hoveredItemChange": "hoveredItemChange"; "dayClick": "dayClick"; }, never, never, true, never>;
|
|
48
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiCalendarSheet, "tui-calendar-sheet", never, { "month": { "alias": "month"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "markerHandler": { "alias": "markerHandler"; "required": false; }; "value": { "alias": "value"; "required": false; }; "hoveredItem": { "alias": "hoveredItem"; "required": false; }; "showAdjacent": { "alias": "showAdjacent"; "required": false; }; "single": { "alias": "single"; "required": false; }; }, { "hoveredItemChange": "hoveredItemChange"; "dayClick": "dayClick"; }, never, never, true, never>;
|
|
36
49
|
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Provider } from '@angular/core';
|
|
2
|
+
export interface TuiCalendarSheetOptions {
|
|
3
|
+
readonly rangeMode: boolean;
|
|
4
|
+
}
|
|
5
|
+
export declare const TUI_CALENDAR_SHEET_DEFAULT_OPTIONS: TuiCalendarSheetOptions;
|
|
6
|
+
export declare const TUI_CALENDAR_SHEET_OPTIONS: import("@angular/core").InjectionToken<TuiCalendarSheetOptions>;
|
|
7
|
+
export declare function tuiCalendarSheetOptionsProvider(options: Partial<TuiCalendarSheetOptions>): Provider;
|
|
@@ -7,7 +7,7 @@ export declare class TuiSelect<T> extends TuiTextfieldBase<T> {
|
|
|
7
7
|
placeholder: string;
|
|
8
8
|
setValue(value: T): void;
|
|
9
9
|
focus(): void;
|
|
10
|
-
protected get
|
|
10
|
+
protected get stringified(): string;
|
|
11
11
|
protected onCopy(): Promise<void>;
|
|
12
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiSelect<any>, never>;
|
|
13
13
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiSelect<any>, "select[tuiTextfield]", never, { "placeholder": { "alias": "placeholder"; "required": false; }; }, {}, never, never, true, [{ directive: typeof i1.TuiNativeValidator; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiAppearance; inputs: {}; outputs: {}; }]>;
|
|
@@ -12,10 +12,8 @@ import * as i3 from "@taiga-ui/core/directives/icons";
|
|
|
12
12
|
export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
|
|
13
13
|
private readonly filler;
|
|
14
14
|
private readonly autoId;
|
|
15
|
-
private readonly el;
|
|
16
15
|
private readonly open;
|
|
17
16
|
private readonly focusedIn;
|
|
18
|
-
protected readonly directive?: TuiTextfieldDirective<T>;
|
|
19
17
|
protected readonly label?: ElementRef<HTMLElement>;
|
|
20
18
|
protected readonly control?: NgControl;
|
|
21
19
|
protected readonly icons: import("@taiga-ui/core/tokens").TuiCommonIcons;
|
|
@@ -23,11 +21,13 @@ export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
|
|
|
23
21
|
protected computedFiller: import("@angular/core").Signal<string>;
|
|
24
22
|
protected showFiller: import("@angular/core").Signal<boolean>;
|
|
25
23
|
readonly vcr?: ViewContainerRef;
|
|
24
|
+
readonly directive?: TuiTextfieldDirective<T>;
|
|
26
25
|
readonly input?: ElementRef<HTMLInputElement>;
|
|
27
26
|
stringify: TuiStringHandler<T>;
|
|
28
27
|
content: PolymorpheusContent<TuiContext<T>>;
|
|
29
28
|
readonly focused: import("@angular/core").Signal<boolean>;
|
|
30
29
|
readonly options: import("./textfield.options").TuiTextfieldOptions;
|
|
30
|
+
readonly el: HTMLElement;
|
|
31
31
|
set fillerSetter(filler: string);
|
|
32
32
|
get id(): string;
|
|
33
33
|
get size(): TuiSizeL | TuiSizeS;
|
|
@@ -35,5 +35,5 @@ export declare class TuiTextfieldComponent<T> implements TuiDataListHost<T> {
|
|
|
35
35
|
protected get hasLabel(): boolean;
|
|
36
36
|
protected onResize({ contentRect }: ResizeObserverEntry): void;
|
|
37
37
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiTextfieldComponent<any>, never>;
|
|
38
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TuiTextfieldComponent<any>, "tui-textfield", never, { "stringify": { "alias": "stringify"; "required": false; }; "content": { "alias": "content"; "required": false; }; "fillerSetter": { "alias": "filler"; "required": false; }; }, {}, ["
|
|
38
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TuiTextfieldComponent<any>, "tui-textfield", never, { "stringify": { "alias": "stringify"; "required": false; }; "content": { "alias": "content"; "required": false; }; "fillerSetter": { "alias": "filler"; "required": false; }; }, {}, ["label", "control", "directive", "input"], ["input", "select", "label", "*", "tui-icon"], true, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }, { directive: typeof i1.TuiDropdownDirective; inputs: {}; outputs: {}; }, { directive: typeof i1.TuiWithDropdownOpen; inputs: {}; outputs: {}; }, { directive: typeof i2.TuiWithTextfieldDropdown; inputs: {}; outputs: {}; }, { directive: typeof i3.TuiWithIcons; inputs: {}; outputs: {}; }]>;
|
|
39
39
|
}
|
|
@@ -16,7 +16,7 @@ export declare class TuiTextfieldBase<T> implements OnChanges {
|
|
|
16
16
|
protected readonly textfield: TuiTextfieldComponent<T>;
|
|
17
17
|
readOnly: boolean;
|
|
18
18
|
invalid: boolean | null;
|
|
19
|
-
|
|
19
|
+
readonly value: import("@angular/core").Signal<string>;
|
|
20
20
|
set focusedSetter(focused: boolean | null);
|
|
21
21
|
set stateSetter(state: TuiInteractiveState | null);
|
|
22
22
|
get mode(): string | null;
|
|
@@ -10,10 +10,12 @@ import { TuiMapperPipe } from '@taiga-ui/cdk/pipes/mapper';
|
|
|
10
10
|
import { tuiNullableSame, tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
11
11
|
import { TuiCalendarSheetPipe, TuiOrderWeekDaysPipe } from '@taiga-ui/core/pipes';
|
|
12
12
|
import { TUI_DAY_TYPE_HANDLER, TUI_SHORT_WEEK_DAYS } from '@taiga-ui/core/tokens';
|
|
13
|
+
import { TUI_CALENDAR_SHEET_OPTIONS } from './calendar-sheet.options';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
15
|
import * as i1 from "@angular/common";
|
|
15
16
|
class TuiCalendarSheet {
|
|
16
17
|
constructor() {
|
|
18
|
+
this.options = inject(TUI_CALENDAR_SHEET_OPTIONS);
|
|
17
19
|
this.today = TuiDay.currentLocal();
|
|
18
20
|
this.unorderedWeekDays$ = inject(TUI_SHORT_WEEK_DAYS);
|
|
19
21
|
this.dayTypeHandler = inject(TUI_DAY_TYPE_HANDLER);
|
|
@@ -23,6 +25,14 @@ class TuiCalendarSheet {
|
|
|
23
25
|
this.value = null;
|
|
24
26
|
this.hoveredItem = null;
|
|
25
27
|
this.showAdjacent = true;
|
|
28
|
+
/**
|
|
29
|
+
* @deprecated use static DI options instead
|
|
30
|
+
* ```
|
|
31
|
+
* tuiCalendarSheetOptionsProvider({rangeMode: true})
|
|
32
|
+
* ```
|
|
33
|
+
* TODO(v5): delete it
|
|
34
|
+
*/
|
|
35
|
+
this.single = true;
|
|
26
36
|
this.hoveredItemChange = new EventEmitter();
|
|
27
37
|
this.dayClick = new EventEmitter();
|
|
28
38
|
this.toMarkers = (day, today, range, markerHandler) => {
|
|
@@ -33,6 +43,9 @@ class TuiCalendarSheet {
|
|
|
33
43
|
return markers?.length ? markers : null;
|
|
34
44
|
};
|
|
35
45
|
}
|
|
46
|
+
/**
|
|
47
|
+
* @deprecated TODO(v5): delete it. It is used nowhere except unit tests
|
|
48
|
+
*/
|
|
36
49
|
itemIsInterval(day) {
|
|
37
50
|
const { value, hoveredItem } = this;
|
|
38
51
|
if (!(value instanceof TuiDayRange)) {
|
|
@@ -52,14 +65,20 @@ class TuiCalendarSheet {
|
|
|
52
65
|
}
|
|
53
66
|
getItemRange(item) {
|
|
54
67
|
const { value, hoveredItem } = this;
|
|
55
|
-
if (value
|
|
68
|
+
if (!value) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
if (value instanceof TuiDay && !this.computedRangeMode) {
|
|
56
72
|
return value.daySame(item) ? 'active' : null;
|
|
57
73
|
}
|
|
58
|
-
if (
|
|
59
|
-
return value
|
|
74
|
+
if (value instanceof TuiDayRange && value.isSingleDay) {
|
|
75
|
+
return value.from.daySame(item) ? 'active' : null;
|
|
76
|
+
}
|
|
77
|
+
if (!(value instanceof TuiDay) && !(value instanceof TuiDayRange)) {
|
|
78
|
+
return value.find((day) => day.daySame(item)) ? 'active' : null;
|
|
60
79
|
}
|
|
61
80
|
const range = this.getRange(value, hoveredItem);
|
|
62
|
-
if (
|
|
81
|
+
if (range.isSingleDay && range.from.daySame(item)) {
|
|
63
82
|
return 'active';
|
|
64
83
|
}
|
|
65
84
|
if (range.from.daySame(item)) {
|
|
@@ -70,8 +89,17 @@ class TuiCalendarSheet {
|
|
|
70
89
|
}
|
|
71
90
|
return range.from.dayBefore(item) && range.to.dayAfter(item) ? 'middle' : null;
|
|
72
91
|
}
|
|
73
|
-
get
|
|
74
|
-
return this.
|
|
92
|
+
get computedRangeMode() {
|
|
93
|
+
return !this.single || this.options.rangeMode;
|
|
94
|
+
}
|
|
95
|
+
get isRangePicking() {
|
|
96
|
+
return this.computedRangeMode
|
|
97
|
+
? this.value instanceof TuiDay
|
|
98
|
+
: /**
|
|
99
|
+
* Only for backward compatibility!
|
|
100
|
+
* TODO(v5): replace with `this.options.rangeMode && this.value instanceof TuiDay`
|
|
101
|
+
*/
|
|
102
|
+
this.value instanceof TuiDayRange && this.value.isSingleDay;
|
|
75
103
|
}
|
|
76
104
|
itemIsToday(item) {
|
|
77
105
|
return this.today.daySame(item);
|
|
@@ -86,6 +114,9 @@ class TuiCalendarSheet {
|
|
|
86
114
|
this.dayClick.emit(item);
|
|
87
115
|
}
|
|
88
116
|
getRange(value, hoveredItem) {
|
|
117
|
+
if (value instanceof TuiDay) {
|
|
118
|
+
return TuiDayRange.sort(value, hoveredItem ?? value);
|
|
119
|
+
}
|
|
89
120
|
return value.isSingleDay
|
|
90
121
|
? TuiDayRange.sort(value.from, hoveredItem ?? value.to)
|
|
91
122
|
: value;
|
|
@@ -98,19 +129,15 @@ class TuiCalendarSheet {
|
|
|
98
129
|
this.hoveredItemChange.emit(day);
|
|
99
130
|
}
|
|
100
131
|
rangeHasDisabledDay(item) {
|
|
101
|
-
if (this.value instanceof
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
if (this.disabledItemHandler(tuiDay)) {
|
|
106
|
-
return true;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
132
|
+
if (this.isRangePicking && this.value instanceof TuiDay) {
|
|
133
|
+
return this.getRange(this.value, item)
|
|
134
|
+
.toArray()
|
|
135
|
+
.some((x) => this.disabledItemHandler(x));
|
|
109
136
|
}
|
|
110
137
|
return false;
|
|
111
138
|
}
|
|
112
139
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendarSheet, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
113
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarSheet, isStandalone: true, selector: "tui-calendar-sheet", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._picking": "
|
|
140
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiCalendarSheet, isStandalone: true, selector: "tui-calendar-sheet", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent", single: "single" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._picking": "isRangePicking" } }, ngImport: i0, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n <div\n *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"\n item\n | tuiMapper\n : toMarkers\n : itemIsToday(item)\n : getItemRange(item)\n : markerHandler as markers\n \"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.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-start-start-radius:0;border-end-start-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-start-end-radius:0;border-end-end-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)}}.t-cell{inline-size:2.25rem}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-text-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-top:-.5rem;padding-bottom:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: TuiCalendarSheetPipe, name: "tuiCalendarSheet" }, { kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "pipe", type: TuiOrderWeekDaysPipe, name: "tuiOrderWeekDays" }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
114
141
|
}
|
|
115
142
|
__decorate([
|
|
116
143
|
tuiPure
|
|
@@ -127,7 +154,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
127
154
|
TuiOrderWeekDaysPipe,
|
|
128
155
|
TuiRepeatTimes,
|
|
129
156
|
], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
130
|
-
'[class._picking]': '
|
|
157
|
+
'[class._picking]': 'isRangePicking',
|
|
131
158
|
}, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-calendar-sheet__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n <div\n *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n automation-id=\"tui-calendar-sheet__cell\"\n class=\"t-cell\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n (click)=\"onItemClick(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"\n item\n | tuiMapper\n : toMarkers\n : itemIsToday(item)\n : getItemRange(item)\n : markerHandler as markers\n \"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.background]=\"markers?.[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.background]=\"markers?.[1] || ''\"\n ></div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [".t-row{display:flex;justify-content:flex-start;font:var(--tui-font-text-m)}.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-start-start-radius:0;border-end-start-radius:0}.t-cell[data-range=middle]:not(:last-child):before{border-start-end-radius:0;border-end-end-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)}}.t-cell{inline-size:2.25rem}[data-type=weekday]{color:var(--tui-text-primary)}[data-type=weekend]{color:var(--tui-text-negative)}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-text-s);color:var(--tui-text-secondary);pointer-events:none}.t-cell_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{position:absolute;bottom:0;display:flex;justify-content:center;margin-top:-.5rem;padding-bottom:.25rem}.t-dot{display:inline-block;inline-size:.25rem;block-size:.25rem;border-radius:100%;margin:0 .0625rem}\n"] }]
|
|
132
159
|
}], propDecorators: { month: [{
|
|
133
160
|
type: Input
|
|
@@ -141,9 +168,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
141
168
|
type: Input
|
|
142
169
|
}], showAdjacent: [{
|
|
143
170
|
type: Input
|
|
171
|
+
}], single: [{
|
|
172
|
+
type: Input
|
|
144
173
|
}], hoveredItemChange: [{
|
|
145
174
|
type: Output
|
|
146
175
|
}], dayClick: [{
|
|
147
176
|
type: Output
|
|
148
177
|
}], getRange: [] } });
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-sheet.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar-sheet.component.ts","../../../../../projects/core/components/calendar/calendar-sheet.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACtE,OAAO,EAAC,UAAU,EAAC,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAC,MAAM,EAAC,MAAM,8BAA8B,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAC,aAAa,EAAC,MAAM,4BAA4B,CAAC;AAEzD,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAC,oBAAoB,EAAE,oBAAoB,EAAC,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;;;AAIhF,MAmBa,gBAAgB;IAnB7B;QAoBqB,UAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAE5B,uBAAkB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACjD,mBAAc,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAG1D,UAAK,GAAa,QAAQ,CAAC,YAAY,EAAE,CAAC;QAG1C,wBAAmB,GAA8B,iBAAiB,CAAC;QAGnE,kBAAa,GAA4B,IAAI,CAAC;QAG9C,UAAK,GAAoD,IAAI,CAAC;QAG9D,gBAAW,GAAkB,IAAI,CAAC;QAGlC,iBAAY,GAAG,IAAI,CAAC;QAGX,sBAAiB,GAAG,IAAI,YAAY,EAAiB,CAAC;QAGtD,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QA0DnC,cAAS,GAAG,CAC3B,GAAW,EACX,KAAc,EACd,KAAoB,EACpB,aAAsC,EACJ,EAAE;YACpC,IAAI,KAAK,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE;gBAC3D,OAAO,IAAI,CAAC;aACf;YAED,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC;YAErC,OAAO,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;QAC5C,CAAC,CAAC;KAqDL;IA1HU,cAAc,CAAC,GAAW;QAC7B,MAAM,EAAC,KAAK,EAAE,WAAW,EAAC,GAAG,IAAI,CAAC;QAElC,IAAI,CAAC,CAAC,KAAK,YAAY,WAAW,CAAC,EAAE;YACjC,OAAO,KAAK,CAAC;SAChB;QAED,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACpB,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;SACpE;QAED,IAAI,WAAW,KAAK,IAAI,EAAE;YACtB,OAAO,KAAK,CAAC;SAChB;QAED,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAExD,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACrE,CAAC;IAEM,aAAa,CAAC,IAAoB;QACrC,IAAI,CAAC,iBAAiB,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;IACzC,CAAC;IAEM,YAAY,CAAC,IAAY;QAC5B,MAAM,EAAC,KAAK,EAAE,WAAW,EAAC,GAAG,IAAI,CAAC;QAElC,IAAI,KAAK,YAAY,MAAM,EAAE;YACzB,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SAChD;QAED,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,YAAY,WAAW,CAAC,EAAE;YAC3C,OAAO,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SACpE;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAEhD,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACpE,OAAO,QAAQ,CAAC;SACnB;QAED,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC1B,OAAO,OAAO,CAAC;SAClB;QAED,IAAI,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACxB,OAAO,KAAK,CAAC;SAChB;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;IACnF,CAAC;IAED,IAAc,gBAAgB;QAC1B,OAAO,IAAI,CAAC,KAAK,YAAY,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IACvE,CAAC;IAiBS,WAAW,CAAC,IAAY;QAC9B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAES,iBAAiB,CAAC,IAAY;QACpC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAES,WAAW,CAAC,IAAY;QAC9B,IAAI,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE;YAChC,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAGO,QAAQ,CAAC,KAAkB,EAAE,WAA0B;QAC3D,OAAO,KAAK,CAAC,WAAW;YACpB,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,IAAI,KAAK,CAAC,EAAE,CAAC;YACvD,CAAC,CAAC,KAAK,CAAC;IAChB,CAAC;IAEO,iBAAiB,CAAC,GAAkB;QACxC,IAAI,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;YAChE,OAAO;SACV;QAED,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAEO,mBAAmB,CAAC,IAAY;QACpC,IAAI,IAAI,CAAC,KAAK,YAAY,WAAW,EAAE;YACnC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YAE9C,KACI,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,EACxC,GAAG,IAAI,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,EACjC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,EAChC;gBACE,MAAM,MAAM,GAAG,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;gBAE/C,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAE;oBAClC,OAAO,IAAI,CAAC;iBACf;aACJ;SACJ;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;+GAvJQ,gBAAgB;mGAAhB,gBAAgB,2YCzC7B,ywEAsDA,gnID5BQ,YAAY,gTACZ,oBAAoB,yDACpB,UAAU,8FACV,MAAM,oEACN,aAAa,6CACb,oBAAoB,yDACpB,cAAc;;AA+HV;IADP,OAAO;gDAKP;SA1HQ,gBAAgB;4FAAhB,gBAAgB;kBAnB5B,SAAS;iCACM,IAAI,YACN,oBAAoB,WACrB;wBACL,YAAY;wBACZ,oBAAoB;wBACpB,UAAU;wBACV,MAAM;wBACN,aAAa;wBACb,oBAAoB;wBACpB,cAAc;qBACjB,mBAGgB,uBAAuB,CAAC,MAAM,QACzC;wBACF,kBAAkB,EAAE,kBAAkB;qBACzC;8BASM,KAAK;sBADX,KAAK;gBAIC,mBAAmB;sBADzB,KAAK;gBAIC,aAAa;sBADnB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAIU,iBAAiB;sBADhC,MAAM;gBAIS,QAAQ;sBADvB,MAAM;gBA2FC,QAAQ","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {TuiDay, TuiDayRange, TuiMonth} 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 {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport type {TuiBooleanHandler, TuiHandler} from '@taiga-ui/cdk/types';\nimport {tuiNullableSame, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiCalendarSheetPipe, TuiOrderWeekDaysPipe} from '@taiga-ui/core/pipes';\nimport {TUI_DAY_TYPE_HANDLER, TUI_SHORT_WEEK_DAYS} from '@taiga-ui/core/tokens';\n\nexport type TuiMarkerHandler = TuiHandler<TuiDay, [] | [string, string] | [string]>;\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-sheet',\n    imports: [\n        CommonModule,\n        TuiCalendarSheetPipe,\n        TuiHovered,\n        TuiLet,\n        TuiMapperPipe,\n        TuiOrderWeekDaysPipe,\n        TuiRepeatTimes,\n    ],\n    templateUrl: './calendar-sheet.template.html',\n    styleUrls: ['./calendar-sheet.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class._picking]': 'isSingleDayRange',\n    },\n})\nexport class TuiCalendarSheet {\n    private readonly today = TuiDay.currentLocal();\n\n    protected readonly unorderedWeekDays$ = inject(TUI_SHORT_WEEK_DAYS);\n    protected readonly dayTypeHandler = inject(TUI_DAY_TYPE_HANDLER);\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\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 value: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n\n    @Input()\n    public hoveredItem: TuiDay | null = null;\n\n    @Input()\n    public showAdjacent = true;\n\n    @Output()\n    public readonly hoveredItemChange = new EventEmitter<TuiDay | null>();\n\n    @Output()\n    public readonly dayClick = new EventEmitter<TuiDay>();\n\n    public itemIsInterval(day: TuiDay): boolean {\n        const {value, hoveredItem} = this;\n\n        if (!(value instanceof TuiDayRange)) {\n            return false;\n        }\n\n        if (!value.isSingleDay) {\n            return value.from.daySameOrBefore(day) && value.to.dayAfter(day);\n        }\n\n        if (hoveredItem === null) {\n            return false;\n        }\n\n        const range = TuiDayRange.sort(value.from, hoveredItem);\n\n        return range.from.daySameOrBefore(day) && range.to.dayAfter(day);\n    }\n\n    public onItemHovered(item: TuiDay | false): void {\n        this.updateHoveredItem(item || null);\n    }\n\n    public getItemRange(item: TuiDay): 'active' | 'end' | 'middle' | 'start' | null {\n        const {value, hoveredItem} = this;\n\n        if (value instanceof TuiDay) {\n            return value.daySame(item) ? 'active' : null;\n        }\n\n        if (!value || !(value instanceof TuiDayRange)) {\n            return value?.find((day) => day.daySame(item)) ? 'active' : null;\n        }\n\n        const range = this.getRange(value, hoveredItem);\n\n        if (value.isSingleDay && range.isSingleDay && value.from.daySame(item)) {\n            return 'active';\n        }\n\n        if (range.from.daySame(item)) {\n            return 'start';\n        }\n\n        if (range.to.daySame(item)) {\n            return 'end';\n        }\n\n        return range.from.dayBefore(item) && range.to.dayAfter(item) ? 'middle' : null;\n    }\n\n    protected get isSingleDayRange(): boolean {\n        return this.value instanceof TuiDayRange && this.value.isSingleDay;\n    }\n\n    protected readonly toMarkers = (\n        day: TuiDay,\n        today: boolean,\n        range: string | null,\n        markerHandler: TuiMarkerHandler | null,\n    ): [string, string] | [string] | null => {\n        if (today || ['active', 'end', 'start'].includes(range || '')) {\n            return null;\n        }\n\n        const markers = markerHandler?.(day);\n\n        return markers?.length ? markers : null;\n    };\n\n    protected itemIsToday(item: TuiDay): boolean {\n        return this.today.daySame(item);\n    }\n\n    protected itemIsUnavailable(item: TuiDay): boolean {\n        return !this.month.monthSame(item);\n    }\n\n    protected onItemClick(item: TuiDay): void {\n        if (this.rangeHasDisabledDay(item)) {\n            return;\n        }\n\n        this.dayClick.emit(item);\n    }\n\n    @tuiPure\n    private getRange(value: TuiDayRange, hoveredItem: TuiDay | null): TuiDayRange {\n        return value.isSingleDay\n            ? TuiDayRange.sort(value.from, hoveredItem ?? value.to)\n            : value;\n    }\n\n    private updateHoveredItem(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    private rangeHasDisabledDay(item: TuiDay): boolean {\n        if (this.value instanceof TuiDayRange) {\n            const range = this.getRange(this.value, item);\n\n            for (\n                const day = range.from.toUtcNativeDate();\n                day <= range.to.toUtcNativeDate();\n                day.setDate(day.getDate() + 1)\n            ) {\n                const tuiDay = TuiDay.fromLocalNativeDate(day);\n\n                if (this.disabledItemHandler(tuiDay)) {\n                    return true;\n                }\n            }\n        }\n\n        return false;\n    }\n}\n","<div class=\"t-row t-row_weekday\">\n    <div\n        *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n        class=\"t-cell\"\n        [textContent]=\"day\"\n    ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n    <div\n        *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n        automation-id=\"tui-calendar-sheet__row\"\n        class=\"t-row\"\n    >\n        <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n            <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n                <div\n                    *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n                    automation-id=\"tui-calendar-sheet__cell\"\n                    class=\"t-cell\"\n                    [attr.data-range]=\"getItemRange(item)\"\n                    [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n                    [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n                    [class.t-cell_today]=\"itemIsToday(item)\"\n                    [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n                    (click)=\"onItemClick(item)\"\n                    (tuiHoveredChange)=\"onItemHovered($event && item)\"\n                >\n                    {{ item.day }}\n                    <div\n                        *ngIf=\"\n                            item\n                                | tuiMapper\n                                    : toMarkers\n                                    : itemIsToday(item)\n                                    : getItemRange(item)\n                                    : markerHandler as markers\n                        \"\n                        class=\"t-dots\"\n                    >\n                        <div\n                            class=\"t-dot\"\n                            [style.background]=\"markers?.[0]\"\n                        ></div>\n                        <div\n                            *ngIf=\"markers.length > 1\"\n                            class=\"t-dot\"\n                            [style.background]=\"markers?.[1] || ''\"\n                        ></div>\n                    </div>\n                </div>\n            </ng-container>\n        </ng-container>\n    </div>\n</div>\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-sheet.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/calendar/calendar-sheet.component.ts","../../../../../projects/core/components/calendar/calendar-sheet.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,iBAAiB,EAAC,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACtE,OAAO,EAAC,UAAU,EAAC,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAC,MAAM,EAAC,MAAM,8BAA8B,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAC,aAAa,EAAC,MAAM,4BAA4B,CAAC;AAEzD,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAC,oBAAoB,EAAE,oBAAoB,EAAC,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;AAEhF,OAAO,EAAC,0BAA0B,EAAC,MAAM,0BAA0B,CAAC;;;AAIpE,MAmBa,gBAAgB;IAnB7B;QAoBqB,YAAO,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAC7C,UAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAE5B,uBAAkB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACjD,mBAAc,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAG1D,UAAK,GAAa,QAAQ,CAAC,YAAY,EAAE,CAAC;QAG1C,wBAAmB,GAA8B,iBAAiB,CAAC;QAGnE,kBAAa,GAA4B,IAAI,CAAC;QAG9C,UAAK,GAAoD,IAAI,CAAC;QAG9D,gBAAW,GAAkB,IAAI,CAAC;QAGlC,iBAAY,GAAG,IAAI,CAAC;QAE3B;;;;;;WAMG;QAEI,WAAM,GAAG,IAAI,CAAC;QAGL,sBAAiB,GAAG,IAAI,YAAY,EAAiB,CAAC;QAGtD,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QA+EnC,cAAS,GAAG,CAC3B,GAAW,EACX,KAAc,EACd,KAAoB,EACpB,aAAsC,EACJ,EAAE;YACpC,IAAI,KAAK,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE;gBAC3D,OAAO,IAAI,CAAC;aACf;YAED,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC;YAErC,OAAO,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;QAC5C,CAAC,CAAC;KAkDL;IA5IG;;OAEG;IACI,cAAc,CAAC,GAAW;QAC7B,MAAM,EAAC,KAAK,EAAE,WAAW,EAAC,GAAG,IAAI,CAAC;QAElC,IAAI,CAAC,CAAC,KAAK,YAAY,WAAW,CAAC,EAAE;YACjC,OAAO,KAAK,CAAC;SAChB;QAED,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACpB,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;SACpE;QAED,IAAI,WAAW,KAAK,IAAI,EAAE;YACtB,OAAO,KAAK,CAAC;SAChB;QAED,MAAM,KAAK,GAAG,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAExD,OAAO,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IACrE,CAAC;IAEM,aAAa,CAAC,IAAoB;QACrC,IAAI,CAAC,iBAAiB,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;IACzC,CAAC;IAEM,YAAY,CAAC,IAAY;QAC5B,MAAM,EAAC,KAAK,EAAE,WAAW,EAAC,GAAG,IAAI,CAAC;QAElC,IAAI,CAAC,KAAK,EAAE;YACR,OAAO,IAAI,CAAC;SACf;QAED,IAAI,KAAK,YAAY,MAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YACpD,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SAChD;QAED,IAAI,KAAK,YAAY,WAAW,IAAI,KAAK,CAAC,WAAW,EAAE;YACnD,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SACrD;QAED,IAAI,CAAC,CAAC,KAAK,YAAY,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,YAAY,WAAW,CAAC,EAAE;YAC/D,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SACnE;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAEhD,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC/C,OAAO,QAAQ,CAAC;SACnB;QAED,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC1B,OAAO,OAAO,CAAC;SAClB;QAED,IAAI,KAAK,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACxB,OAAO,KAAK,CAAC;SAChB;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;IACnF,CAAC;IAED,IAAc,iBAAiB;QAC3B,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;IAClD,CAAC;IAED,IAAc,cAAc;QACxB,OAAO,IAAI,CAAC,iBAAiB;YACzB,CAAC,CAAC,IAAI,CAAC,KAAK,YAAY,MAAM;YAC9B,CAAC,CAAC;;;iBAGG;gBACH,IAAI,CAAC,KAAK,YAAY,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IACtE,CAAC;IAiBS,WAAW,CAAC,IAAY;QAC9B,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAES,iBAAiB,CAAC,IAAY;QACpC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAES,WAAW,CAAC,IAAY;QAC9B,IAAI,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE;YAChC,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAGO,QAAQ,CACZ,KAA2B,EAC3B,WAA0B;QAE1B,IAAI,KAAK,YAAY,MAAM,EAAE;YACzB,OAAO,WAAW,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,IAAI,KAAK,CAAC,CAAC;SACxD;QAED,OAAO,KAAK,CAAC,WAAW;YACpB,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,IAAI,KAAK,CAAC,EAAE,CAAC;YACvD,CAAC,CAAC,KAAK,CAAC;IAChB,CAAC;IAEO,iBAAiB,CAAC,GAAkB;QACxC,IAAI,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;YAChE,OAAO;SACV;QAED,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAEO,mBAAmB,CAAC,IAAY;QACpC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,KAAK,YAAY,MAAM,EAAE;YACrD,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC;iBACjC,OAAO,EAAE;iBACT,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC;SACjD;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;+GApLQ,gBAAgB;mGAAhB,gBAAgB,2ZC3C7B,ywEAsDA,gnID1BQ,YAAY,gTACZ,oBAAoB,yDACpB,UAAU,8FACV,MAAM,oEACN,aAAa,6CACb,oBAAoB,yDACpB,cAAc;;AA+JV;IADP,OAAO;gDAYP;SAjKQ,gBAAgB;4FAAhB,gBAAgB;kBAnB5B,SAAS;iCACM,IAAI,YACN,oBAAoB,WACrB;wBACL,YAAY;wBACZ,oBAAoB;wBACpB,UAAU;wBACV,MAAM;wBACN,aAAa;wBACb,oBAAoB;wBACpB,cAAc;qBACjB,mBAGgB,uBAAuB,CAAC,MAAM,QACzC;wBACF,kBAAkB,EAAE,gBAAgB;qBACvC;8BAUM,KAAK;sBADX,KAAK;gBAIC,mBAAmB;sBADzB,KAAK;gBAIC,aAAa;sBADnB,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,YAAY;sBADlB,KAAK;gBAWC,MAAM;sBADZ,KAAK;gBAIU,iBAAiB;sBADhC,MAAM;gBAIS,QAAQ;sBADvB,MAAM;gBAgHC,QAAQ","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {TuiDay, TuiDayRange, TuiMonth} 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 {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport type {TuiBooleanHandler, TuiHandler} from '@taiga-ui/cdk/types';\nimport {tuiNullableSame, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiCalendarSheetPipe, TuiOrderWeekDaysPipe} from '@taiga-ui/core/pipes';\nimport {TUI_DAY_TYPE_HANDLER, TUI_SHORT_WEEK_DAYS} from '@taiga-ui/core/tokens';\n\nimport {TUI_CALENDAR_SHEET_OPTIONS} from './calendar-sheet.options';\n\nexport type TuiMarkerHandler = TuiHandler<TuiDay, [] | [string, string] | [string]>;\n\n@Component({\n    standalone: true,\n    selector: 'tui-calendar-sheet',\n    imports: [\n        CommonModule,\n        TuiCalendarSheetPipe,\n        TuiHovered,\n        TuiLet,\n        TuiMapperPipe,\n        TuiOrderWeekDaysPipe,\n        TuiRepeatTimes,\n    ],\n    templateUrl: './calendar-sheet.template.html',\n    styleUrls: ['./calendar-sheet.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class._picking]': 'isRangePicking',\n    },\n})\nexport class TuiCalendarSheet {\n    private readonly options = inject(TUI_CALENDAR_SHEET_OPTIONS);\n    private readonly today = TuiDay.currentLocal();\n\n    protected readonly unorderedWeekDays$ = inject(TUI_SHORT_WEEK_DAYS);\n    protected readonly dayTypeHandler = inject(TUI_DAY_TYPE_HANDLER);\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\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 value: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n\n    @Input()\n    public hoveredItem: TuiDay | null = null;\n\n    @Input()\n    public showAdjacent = true;\n\n    /**\n     * @deprecated use static DI options instead\n     * ```\n     * tuiCalendarSheetOptionsProvider({rangeMode: true})\n     * ```\n     * TODO(v5): delete it\n     */\n    @Input()\n    public single = true;\n\n    @Output()\n    public readonly hoveredItemChange = new EventEmitter<TuiDay | null>();\n\n    @Output()\n    public readonly dayClick = new EventEmitter<TuiDay>();\n\n    /**\n     * @deprecated TODO(v5): delete it. It is used nowhere except unit tests\n     */\n    public itemIsInterval(day: TuiDay): boolean {\n        const {value, hoveredItem} = this;\n\n        if (!(value instanceof TuiDayRange)) {\n            return false;\n        }\n\n        if (!value.isSingleDay) {\n            return value.from.daySameOrBefore(day) && value.to.dayAfter(day);\n        }\n\n        if (hoveredItem === null) {\n            return false;\n        }\n\n        const range = TuiDayRange.sort(value.from, hoveredItem);\n\n        return range.from.daySameOrBefore(day) && range.to.dayAfter(day);\n    }\n\n    public onItemHovered(item: TuiDay | false): void {\n        this.updateHoveredItem(item || null);\n    }\n\n    public getItemRange(item: TuiDay): 'active' | 'end' | 'middle' | 'start' | null {\n        const {value, hoveredItem} = this;\n\n        if (!value) {\n            return null;\n        }\n\n        if (value instanceof TuiDay && !this.computedRangeMode) {\n            return value.daySame(item) ? 'active' : null;\n        }\n\n        if (value instanceof TuiDayRange && value.isSingleDay) {\n            return value.from.daySame(item) ? 'active' : null;\n        }\n\n        if (!(value instanceof TuiDay) && !(value instanceof TuiDayRange)) {\n            return value.find((day) => day.daySame(item)) ? 'active' : null;\n        }\n\n        const range = this.getRange(value, hoveredItem);\n\n        if (range.isSingleDay && range.from.daySame(item)) {\n            return 'active';\n        }\n\n        if (range.from.daySame(item)) {\n            return 'start';\n        }\n\n        if (range.to.daySame(item)) {\n            return 'end';\n        }\n\n        return range.from.dayBefore(item) && range.to.dayAfter(item) ? 'middle' : null;\n    }\n\n    protected get computedRangeMode(): boolean {\n        return !this.single || this.options.rangeMode;\n    }\n\n    protected get isRangePicking(): boolean {\n        return this.computedRangeMode\n            ? this.value instanceof TuiDay\n            : /**\n               * Only for backward compatibility!\n               * TODO(v5): replace with `this.options.rangeMode && this.value instanceof TuiDay`\n               */\n              this.value instanceof TuiDayRange && this.value.isSingleDay;\n    }\n\n    protected readonly toMarkers = (\n        day: TuiDay,\n        today: boolean,\n        range: string | null,\n        markerHandler: TuiMarkerHandler | null,\n    ): [string, string] | [string] | null => {\n        if (today || ['active', 'end', 'start'].includes(range || '')) {\n            return null;\n        }\n\n        const markers = markerHandler?.(day);\n\n        return markers?.length ? markers : null;\n    };\n\n    protected itemIsToday(item: TuiDay): boolean {\n        return this.today.daySame(item);\n    }\n\n    protected itemIsUnavailable(item: TuiDay): boolean {\n        return !this.month.monthSame(item);\n    }\n\n    protected onItemClick(item: TuiDay): void {\n        if (this.rangeHasDisabledDay(item)) {\n            return;\n        }\n\n        this.dayClick.emit(item);\n    }\n\n    @tuiPure\n    private getRange(\n        value: TuiDay | TuiDayRange,\n        hoveredItem: TuiDay | null,\n    ): TuiDayRange {\n        if (value instanceof TuiDay) {\n            return TuiDayRange.sort(value, hoveredItem ?? value);\n        }\n\n        return value.isSingleDay\n            ? TuiDayRange.sort(value.from, hoveredItem ?? value.to)\n            : value;\n    }\n\n    private updateHoveredItem(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    private rangeHasDisabledDay(item: TuiDay): boolean {\n        if (this.isRangePicking && this.value instanceof TuiDay) {\n            return this.getRange(this.value, item)\n                .toArray()\n                .some((x) => this.disabledItemHandler(x));\n        }\n\n        return false;\n    }\n}\n","<div class=\"t-row t-row_weekday\">\n    <div\n        *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n        class=\"t-cell\"\n        [textContent]=\"day\"\n    ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n    <div\n        *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n        automation-id=\"tui-calendar-sheet__row\"\n        class=\"t-row\"\n    >\n        <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex]?.length || 0\">\n            <ng-container *tuiLet=\"sheet[rowIndex]?.[colIndex] as item\">\n                <div\n                    *ngIf=\"item && (!itemIsUnavailable(item) || showAdjacent)\"\n                    automation-id=\"tui-calendar-sheet__cell\"\n                    class=\"t-cell\"\n                    [attr.data-range]=\"getItemRange(item)\"\n                    [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n                    [class.t-cell_disabled]=\"disabledItemHandler(item)\"\n                    [class.t-cell_today]=\"itemIsToday(item)\"\n                    [class.t-cell_unavailable]=\"itemIsUnavailable(item)\"\n                    (click)=\"onItemClick(item)\"\n                    (tuiHoveredChange)=\"onItemHovered($event && item)\"\n                >\n                    {{ item.day }}\n                    <div\n                        *ngIf=\"\n                            item\n                                | tuiMapper\n                                    : toMarkers\n                                    : itemIsToday(item)\n                                    : getItemRange(item)\n                                    : markerHandler as markers\n                        \"\n                        class=\"t-dots\"\n                    >\n                        <div\n                            class=\"t-dot\"\n                            [style.background]=\"markers?.[0]\"\n                        ></div>\n                        <div\n                            *ngIf=\"markers.length > 1\"\n                            class=\"t-dot\"\n                            [style.background]=\"markers?.[1] || ''\"\n                        ></div>\n                    </div>\n                </div>\n            </ng-container>\n        </ng-container>\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { tuiCreateToken, tuiProvideOptions } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
2
|
+
export const TUI_CALENDAR_SHEET_DEFAULT_OPTIONS = {
|
|
3
|
+
rangeMode: false,
|
|
4
|
+
};
|
|
5
|
+
export const TUI_CALENDAR_SHEET_OPTIONS = tuiCreateToken(TUI_CALENDAR_SHEET_DEFAULT_OPTIONS);
|
|
6
|
+
export function tuiCalendarSheetOptionsProvider(options) {
|
|
7
|
+
return tuiProvideOptions(TUI_CALENDAR_SHEET_OPTIONS, options, TUI_CALENDAR_SHEET_DEFAULT_OPTIONS);
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItc2hlZXQub3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9jYWxlbmRhci9jYWxlbmRhci1zaGVldC5vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxjQUFjLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQU1wRixNQUFNLENBQUMsTUFBTSxrQ0FBa0MsR0FBNEI7SUFDdkUsU0FBUyxFQUFFLEtBQUs7Q0FDbkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLGNBQWMsQ0FDcEQsa0NBQWtDLENBQ3JDLENBQUM7QUFFRixNQUFNLFVBQVUsK0JBQStCLENBQzNDLE9BQXlDO0lBRXpDLE9BQU8saUJBQWlCLENBQ3BCLDBCQUEwQixFQUMxQixPQUFPLEVBQ1Asa0NBQWtDLENBQ3JDLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1Byb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHVpQ3JlYXRlVG9rZW4sIHR1aVByb3ZpZGVPcHRpb25zfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR1aUNhbGVuZGFyU2hlZXRPcHRpb25zIHtcbiAgICByZWFkb25seSByYW5nZU1vZGU6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfQ0FMRU5EQVJfU0hFRVRfREVGQVVMVF9PUFRJT05TOiBUdWlDYWxlbmRhclNoZWV0T3B0aW9ucyA9IHtcbiAgICByYW5nZU1vZGU6IGZhbHNlLFxufTtcblxuZXhwb3J0IGNvbnN0IFRVSV9DQUxFTkRBUl9TSEVFVF9PUFRJT05TID0gdHVpQ3JlYXRlVG9rZW4oXG4gICAgVFVJX0NBTEVOREFSX1NIRUVUX0RFRkFVTFRfT1BUSU9OUyxcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlDYWxlbmRhclNoZWV0T3B0aW9uc1Byb3ZpZGVyKFxuICAgIG9wdGlvbnM6IFBhcnRpYWw8VHVpQ2FsZW5kYXJTaGVldE9wdGlvbnM+LFxuKTogUHJvdmlkZXIge1xuICAgIHJldHVybiB0dWlQcm92aWRlT3B0aW9ucyhcbiAgICAgICAgVFVJX0NBTEVOREFSX1NIRUVUX09QVElPTlMsXG4gICAgICAgIG9wdGlvbnMsXG4gICAgICAgIFRVSV9DQUxFTkRBUl9TSEVFVF9ERUZBVUxUX09QVElPTlMsXG4gICAgKTtcbn1cbiJdfQ==
|
|
@@ -91,7 +91,7 @@ class TuiCalendar {
|
|
|
91
91
|
this.hoveredItemChange.emit(day);
|
|
92
92
|
}
|
|
93
93
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
-
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" }, 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 [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:18.25rem;inline-size:15.75rem;padding:1rem 1.125rem;box-sizing:content-box}.t-scrollbar{block-size:18.25rem;inline-size:16.875rem}.t-pagination{margin-bottom: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"], 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: ["value", "initialItem", "min", "max", "disabledItemHandler"], outputs: ["yearClick"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
94
|
+
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" }, 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 [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:18.25rem;inline-size:15.75rem;padding:1rem 1.125rem;box-sizing:content-box}.t-scrollbar{block-size:18.25rem;inline-size:16.875rem}.t-pagination{margin-bottom: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: ["value", "initialItem", "min", "max", "disabledItemHandler"], outputs: ["yearClick"] }, { kind: "pipe", type: TuiMapperPipe, name: "tuiMapper" }, { kind: "component", type: TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
95
95
|
}
|
|
96
96
|
export { TuiCalendar };
|
|
97
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, decorators: [{
|
|
@@ -133,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
133
133
|
}], initialView: [{
|
|
134
134
|
type: Input
|
|
135
135
|
}] } });
|
|
136
|
-
//# 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    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    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';\n\nimport type {TuiMarkerHandler} from './calendar-sheet.component';\nimport {TuiCalendarSheet} from './calendar-sheet.component';\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})\nexport class TuiCalendar {\n    private day: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n\n    private view: 'month' | 'year' = 'month';\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> = TUI_FALSE_HANDLER;\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    @Input()\n    public set value(value: TuiDay | TuiDayRange | readonly TuiDay[] | null) {\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    }\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        [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"]}
|
|
136
|
+
//# 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    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    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';\n\nimport type {TuiMarkerHandler} from './calendar-sheet.component';\nimport {TuiCalendarSheet} from './calendar-sheet.component';\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})\nexport class TuiCalendar {\n    private day: TuiDay | TuiDayRange | readonly TuiDay[] | null = null;\n\n    private view: 'month' | 'year' = 'month';\n\n    @Input()\n    public month: TuiMonth = TuiMonth.currentLocal();\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiDay> = TUI_FALSE_HANDLER;\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    @Input()\n    public set value(value: TuiDay | TuiDayRange | readonly TuiDay[] | null) {\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    }\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        [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"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * from './calendar.component';
|
|
2
2
|
export * from './calendar-sheet.component';
|
|
3
|
+
export * from './calendar-sheet.options';
|
|
3
4
|
export * from './calendar-spin.component';
|
|
4
5
|
export * from './calendar-year.component';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvY2FsZW5kYXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jYWxlbmRhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYWxlbmRhci1zaGVldC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYWxlbmRhci1zaGVldC5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vY2FsZW5kYXItc3Bpbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jYWxlbmRhci15ZWFyLmNvbXBvbmVudCc7XG4iXX0=
|