@taiga-ui/core
Version:
Core library for creating Angular components and applications using Taiga UI
147 lines • 25.5 kB
JavaScript
import { NgIf } from '@angular/common';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
import { TUI_FIRST_DAY, TUI_LAST_DAY, TUI_LAST_DISPLAYED_DAY, TuiDay, TuiMonth, } from '@taiga-ui/cdk/date-time';
import { TuiMapperPipe } from '@taiga-ui/cdk/pipes/mapper';
import { tuiNullableSame } from '@taiga-ui/cdk/utils/miscellaneous';
import { TuiScrollbar } from '@taiga-ui/core/components/scrollbar';
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives';
import { tuiAsAuxiliary } from '@taiga-ui/core/tokens';
import { Subject } from 'rxjs';
import { TuiCalendarSheet } from './calendar-sheet.component';
import { TUI_CALENDAR_SHEET_OPTIONS } from './calendar-sheet.options';
import { TuiCalendarSpin } from './calendar-spin.component';
import { TuiCalendarYear } from './calendar-year.component';
import * as i0 from "@angular/core";
class TuiCalendar {
constructor() {
this.cdr = inject(ChangeDetectorRef);
this.day = null;
this.view = 'month';
this.options = inject(TUI_CALENDAR_SHEET_OPTIONS);
this.month = TuiMonth.currentLocal();
this.disabledItemHandler = inject(TUI_ITEMS_HANDLERS).disabledItemHandler();
this.min = TUI_FIRST_DAY;
this.max = TUI_LAST_DAY;
this.minViewedMonth = TUI_FIRST_DAY;
this.maxViewedMonth = TUI_LAST_DAY;
this.hoveredItem = null;
this.showAdjacent = true;
this.markerHandler = null;
this.dayClick = new EventEmitter();
this.monthChange = new EventEmitter();
this.hoveredItemChange = new EventEmitter();
/** @deprecated for private use only until Calendars are refactored */
this.valueChange = new Subject();
this.disabledItemHandlerMapper = (disabledItemHandler, min, max) => (item) => item.dayBefore(min) || item.dayAfter(max) || disabledItemHandler(item);
}
set value(value) {
this.cdr.markForCheck();
this.day = value;
if (this.showAdjacent &&
value instanceof TuiDay &&
value.daySameOrBefore(TUI_LAST_DISPLAYED_DAY)) {
this.month = value;
}
}
set initialView(view) {
this.view = view;
}
get value() {
return this.day;
}
onPaginationValueChange(month) {
this.updateViewedMonth(month);
}
onDayClick(day) {
this.dayClick.emit(day);
this.valueChange.next(day);
}
onHoveredItemChange(day) {
this.updateHoveredDay(day);
}
get computedMin() {
return this.min ?? TUI_FIRST_DAY;
}
get computedMax() {
return this.max ?? TUI_LAST_DAY;
}
get computedMinViewedMonth() {
const min = this.computedMin;
const minViewed = this.minViewedMonth ?? TUI_FIRST_DAY;
return minViewed.monthSameOrAfter(min) ? minViewed : min;
}
get computedMaxViewedMonth() {
const max = this.computedMax;
const maxViewed = this.maxViewedMonth ?? TUI_LAST_DAY;
return maxViewed.monthSameOrBefore(max) ? maxViewed : max;
}
get isInYearView() {
return this.view === 'year';
}
onPaginationYearClick() {
this.view = 'year';
}
onPickerYearClick(year) {
this.view = 'month';
this.updateViewedMonth(new TuiMonth(year, this.month.month));
}
updateViewedMonth(month) {
if (this.month.monthSame(month)) {
return;
}
this.month = month;
this.monthChange.emit(month);
}
updateHoveredDay(day) {
if (tuiNullableSame(this.hoveredItem, day, (a, b) => a.daySame(b))) {
return;
}
this.hoveredItem = day;
this.hoveredItemChange.emit(day);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
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 }); }
}
export { TuiCalendar };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiCalendar, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'tui-calendar', imports: [
NgIf,
TuiCalendarSheet,
TuiCalendarSpin,
TuiCalendarYear,
TuiMapperPipe,
TuiScrollbar,
], changeDetection: ChangeDetectionStrategy.OnPush, providers: [tuiAsAuxiliary(TuiCalendar)], host: {
'(pointerdown.prevent.zoneless)': '0',
}, 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"] }]
}], propDecorators: { month: [{
type: Input
}], disabledItemHandler: [{
type: Input
}], min: [{
type: Input
}], max: [{
type: Input
}], minViewedMonth: [{
type: Input
}], maxViewedMonth: [{
type: Input
}], hoveredItem: [{
type: Input
}], showAdjacent: [{
type: Input
}], markerHandler: [{
type: Input
}], dayClick: [{
type: Output
}], monthChange: [{
type: Output
}], hoveredItemChange: [{
type: Output
}], value: [{
type: Input
}], initialView: [{
type: Input
}] } });
//# 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 {\n    TUI_FIRST_DAY,\n    TUI_LAST_DAY,\n    TUI_LAST_DISPLAYED_DAY,\n    TuiDay,\n    type TuiDayRange,\n    TuiMonth,\n} from '@taiga-ui/cdk/date-time';\nimport {TuiMapperPipe} from '@taiga-ui/cdk/pipes/mapper';\nimport {type TuiBooleanHandler, type 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 {TuiCalendarSheet, type TuiMarkerHandler} 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"]}