UNPKG

@ng-bootstrap/ng-bootstrap

Version:
558 lines (550 loc) 70.3 kB
import { fromEvent, merge, Subject } from 'rxjs'; import { filter, take, takeUntil } from 'rxjs/operators'; import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, forwardRef, inject, Inject, Injector, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { NgFor, NgIf, NgTemplateOutlet } from '@angular/common'; import { NgbDate } from './ngb-date'; import { NgbDatepickerService } from './datepicker-service'; import { NavigationEvent } from './datepicker-view-model'; import { isChangedDate, isChangedMonth } from './datepicker-tools'; import { hasClassName } from '../util/util'; import { NgbDatepickerDayView } from './datepicker-day-view'; import { NgbDatepickerNavigation } from './datepicker-navigation'; import * as i0 from "@angular/core"; import * as i1 from "./datepicker-i18n"; import * as i2 from "./datepicker-keyboard-service"; import * as i3 from "./datepicker-service"; import * as i4 from "./ngb-calendar"; import * as i5 from "./datepicker-config"; import * as i6 from "./adapters/ngb-date-adapter"; /** * A directive that marks the content template that customizes the way datepicker months are displayed * * @since 5.3.0 */ class NgbDatepickerContent { constructor(templateRef) { this.templateRef = templateRef; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepickerContent, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.6", type: NgbDatepickerContent, isStandalone: true, selector: "ng-template[ngbDatepickerContent]", ngImport: i0 }); } } export { NgbDatepickerContent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepickerContent, decorators: [{ type: Directive, args: [{ selector: 'ng-template[ngbDatepickerContent]', standalone: true }] }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } }); /** * A component that renders one month including all the days, weekdays and week numbers. Can be used inside * the `<ng-template ngbDatepickerMonths></ng-template>` when you want to customize months layout. * * For a usage example, see [custom month layout demo](#/components/datepicker/examples#custommonth) * * @since 5.3.0 */ class NgbDatepickerMonth { /** * The first date of month to be rendered. * * This month must one of the months present in the * [datepicker state](#/components/datepicker/api#NgbDatepickerState). */ set month(month) { this.viewModel = this._service.getMonth(month); } constructor(i18n, datepicker, _keyboardService, _service) { this.i18n = i18n; this.datepicker = datepicker; this._keyboardService = _keyboardService; this._service = _service; } onKeyDown(event) { this._keyboardService.processKey(event, this.datepicker); } doSelect(day) { if (!day.context.disabled && !day.hidden) { this.datepicker.onDateSelect(day.date); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepickerMonth, deps: [{ token: i1.NgbDatepickerI18n }, { token: forwardRef(() => NgbDatepicker) }, { token: i2.NgbDatepickerKeyboardService }, { token: i3.NgbDatepickerService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.6", type: NgbDatepickerMonth, isStandalone: true, selector: "ngb-datepicker-month", inputs: { month: "month" }, host: { attributes: { "role": "grid" }, listeners: { "keydown": "onKeyDown($event)" } }, ngImport: i0, template: ` <div *ngIf="viewModel.weekdays.length > 0" class="ngb-dp-week ngb-dp-weekdays" role="row"> <div *ngIf="datepicker.showWeekNumbers" class="ngb-dp-weekday ngb-dp-showweek small">{{ i18n.getWeekLabel() }}</div> <div *ngFor="let weekday of viewModel.weekdays" class="ngb-dp-weekday small" role="columnheader">{{ weekday }}</div> </div> <ng-template ngFor let-week [ngForOf]="viewModel.weeks"> <div *ngIf="!week.collapsed" class="ngb-dp-week" role="row"> <div *ngIf="datepicker.showWeekNumbers" class="ngb-dp-week-number small text-muted">{{ i18n.getWeekNumerals(week.number) }}</div> <div *ngFor="let day of week.days" (click)="doSelect(day); $event.preventDefault()" class="ngb-dp-day" role="gridcell" [class.disabled]="day.context.disabled" [tabindex]="day.tabindex" [class.hidden]="day.hidden" [class.ngb-dp-today]="day.context.today" [attr.aria-label]="day.ariaLabel" > <ng-template [ngIf]="!day.hidden"> <ng-template [ngTemplateOutlet]="datepicker.dayTemplate" [ngTemplateOutletContext]="day.context" ></ng-template> </ng-template> </div> </div> </ng-template> `, isInline: true, styles: ["ngb-datepicker-month{display:block}.ngb-dp-weekday,.ngb-dp-week-number{line-height:2rem;text-align:center;font-style:italic}.ngb-dp-weekday{color:var(--bs-info)}.ngb-dp-week{border-radius:.25rem;display:flex}.ngb-dp-weekdays{border-bottom:1px solid var(--bs-border-color);border-radius:0;background-color:var(--bs-light)}.ngb-dp-day,.ngb-dp-weekday,.ngb-dp-week-number{width:2rem;height:2rem}.ngb-dp-day{cursor:pointer}.ngb-dp-day.disabled,.ngb-dp-day.hidden{cursor:default;pointer-events:none}.ngb-dp-day[tabindex=\"0\"]{z-index:1}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], encapsulation: i0.ViewEncapsulation.None }); } } export { NgbDatepickerMonth }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepickerMonth, decorators: [{ type: Component, args: [{ selector: 'ngb-datepicker-month', standalone: true, imports: [NgIf, NgFor, NgTemplateOutlet], host: { role: 'grid', '(keydown)': 'onKeyDown($event)' }, encapsulation: ViewEncapsulation.None, template: ` <div *ngIf="viewModel.weekdays.length > 0" class="ngb-dp-week ngb-dp-weekdays" role="row"> <div *ngIf="datepicker.showWeekNumbers" class="ngb-dp-weekday ngb-dp-showweek small">{{ i18n.getWeekLabel() }}</div> <div *ngFor="let weekday of viewModel.weekdays" class="ngb-dp-weekday small" role="columnheader">{{ weekday }}</div> </div> <ng-template ngFor let-week [ngForOf]="viewModel.weeks"> <div *ngIf="!week.collapsed" class="ngb-dp-week" role="row"> <div *ngIf="datepicker.showWeekNumbers" class="ngb-dp-week-number small text-muted">{{ i18n.getWeekNumerals(week.number) }}</div> <div *ngFor="let day of week.days" (click)="doSelect(day); $event.preventDefault()" class="ngb-dp-day" role="gridcell" [class.disabled]="day.context.disabled" [tabindex]="day.tabindex" [class.hidden]="day.hidden" [class.ngb-dp-today]="day.context.today" [attr.aria-label]="day.ariaLabel" > <ng-template [ngIf]="!day.hidden"> <ng-template [ngTemplateOutlet]="datepicker.dayTemplate" [ngTemplateOutletContext]="day.context" ></ng-template> </ng-template> </div> </div> </ng-template> `, styles: ["ngb-datepicker-month{display:block}.ngb-dp-weekday,.ngb-dp-week-number{line-height:2rem;text-align:center;font-style:italic}.ngb-dp-weekday{color:var(--bs-info)}.ngb-dp-week{border-radius:.25rem;display:flex}.ngb-dp-weekdays{border-bottom:1px solid var(--bs-border-color);border-radius:0;background-color:var(--bs-light)}.ngb-dp-day,.ngb-dp-weekday,.ngb-dp-week-number{width:2rem;height:2rem}.ngb-dp-day{cursor:pointer}.ngb-dp-day.disabled,.ngb-dp-day.hidden{cursor:default;pointer-events:none}.ngb-dp-day[tabindex=\"0\"]{z-index:1}\n"] }] }], ctorParameters: function () { return [{ type: i1.NgbDatepickerI18n }, { type: NgbDatepicker, decorators: [{ type: Inject, args: [forwardRef(() => NgbDatepicker)] }] }, { type: i2.NgbDatepickerKeyboardService }, { type: i3.NgbDatepickerService }]; }, propDecorators: { month: [{ type: Input }] } }); /** * A highly configurable component that helps you with selecting calendar dates. * * `NgbDatepicker` is meant to be displayed inline on a page or put inside a popup. */ class NgbDatepicker { constructor(_service, _calendar, _i18n, config, cd, _elementRef, _ngbDateAdapter, _ngZone) { this._service = _service; this._calendar = _calendar; this._i18n = _i18n; this._elementRef = _elementRef; this._ngbDateAdapter = _ngbDateAdapter; this._ngZone = _ngZone; this.injector = inject(Injector); this._controlValue = null; this._destroyed$ = new Subject(); this._publicState = {}; /** * An event emitted right before the navigation happens and displayed month changes. * * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info. */ this.navigate = new EventEmitter(); /** * An event emitted when user selects a date using keyboard or mouse. * * The payload of the event is currently selected `NgbDate`. * * @since 5.2.0 */ this.dateSelect = new EventEmitter(); this.onChange = (_) => { }; this.onTouched = () => { }; [ 'contentTemplate', 'dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate', 'maxDate', 'navigation', 'outsideDays', 'showWeekNumbers', 'startDate', 'weekdays', ].forEach((input) => (this[input] = config[input])); _service.dateSelect$.pipe(takeUntil(this._destroyed$)).subscribe((date) => { this.dateSelect.emit(date); }); _service.model$.pipe(takeUntil(this._destroyed$)).subscribe((model) => { const newDate = model.firstDate; const oldDate = this.model ? this.model.firstDate : null; // update public state this._publicState = { maxDate: model.maxDate, minDate: model.minDate, firstDate: model.firstDate, lastDate: model.lastDate, focusedDate: model.focusDate, months: model.months.map((viewModel) => viewModel.firstDate), }; let navigationPrevented = false; // emitting navigation event if the first month changes if (!newDate.equals(oldDate)) { this.navigate.emit({ current: oldDate ? { year: oldDate.year, month: oldDate.month } : null, next: { year: newDate.year, month: newDate.month }, preventDefault: () => (navigationPrevented = true), }); // can't prevent the very first navigation if (navigationPrevented && oldDate !== null) { this._service.open(oldDate); return; } } const newSelectedDate = model.selectedDate; const newFocusedDate = model.focusDate; const oldFocusedDate = this.model ? this.model.focusDate : null; this.model = model; // handling selection change if (isChangedDate(newSelectedDate, this._controlValue)) { this._controlValue = newSelectedDate; this.onTouched(); this.onChange(this._ngbDateAdapter.toModel(newSelectedDate)); } // handling focus change if (isChangedDate(newFocusedDate, oldFocusedDate) && oldFocusedDate && model.focusVisible) { this.focus(); } cd.markForCheck(); }); } /** * Returns the readonly public state of the datepicker * * @since 5.2.0 */ get state() { return this._publicState; } /** * Returns the calendar service used in the specific datepicker instance. * * @since 5.3.0 */ get calendar() { return this._calendar; } /** * Returns the i18n service used in the specific datepicker instance. * * @since 14.2.0 */ get i18n() { return this._i18n; } /** * Focuses on given date. */ focusDate(date) { this._service.focus(NgbDate.from(date)); } /** * Selects focused date. */ focusSelect() { this._service.focusSelect(); } focus() { this._ngZone.onStable .asObservable() .pipe(take(1)) .subscribe(() => { const elementToFocus = this._elementRef.nativeElement.querySelector('div.ngb-dp-day[tabindex="0"]'); if (elementToFocus) { elementToFocus.focus(); } }); } /** * Navigates to the provided date. * * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec. * If nothing or invalid date provided calendar will open current month. * * Use the `[startDate]` input as an alternative. */ navigateTo(date) { this._service.open(NgbDate.from(date ? (date.day ? date : { ...date, day: 1 }) : null)); } ngAfterViewInit() { this._ngZone.runOutsideAngular(() => { const focusIns$ = fromEvent(this._contentEl.nativeElement, 'focusin'); const focusOuts$ = fromEvent(this._contentEl.nativeElement, 'focusout'); const { nativeElement } = this._elementRef; // we're changing 'focusVisible' only when entering or leaving months view // and ignoring all focus events where both 'target' and 'related' target are day cells merge(focusIns$, focusOuts$) .pipe(filter(({ target, relatedTarget }) => !(hasClassName(target, 'ngb-dp-day') && hasClassName(relatedTarget, 'ngb-dp-day') && nativeElement.contains(target) && nativeElement.contains(relatedTarget))), takeUntil(this._destroyed$)) .subscribe(({ type }) => this._ngZone.run(() => this._service.set({ focusVisible: type === 'focusin' }))); }); } ngOnDestroy() { this._destroyed$.next(); } ngOnInit() { if (this.model === undefined) { const inputs = {}; [ 'dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate', 'outsideDays', 'weekdays', ].forEach((name) => (inputs[name] = this[name])); this._service.set(inputs); this.navigateTo(this.startDate); } if (!this.dayTemplate) { this.dayTemplate = this._defaultDayTemplate; } } ngOnChanges(changes) { const inputs = {}; [ 'dayTemplateData', 'displayMonths', 'markDisabled', 'firstDayOfWeek', 'navigation', 'minDate', 'maxDate', 'outsideDays', 'weekdays', ] .filter((name) => name in changes) .forEach((name) => (inputs[name] = this[name])); this._service.set(inputs); if ('startDate' in changes) { const { currentValue, previousValue } = changes.startDate; if (isChangedMonth(previousValue, currentValue)) { this.navigateTo(this.startDate); } } } onDateSelect(date) { this._service.focus(date); this._service.select(date, { emitEvent: true }); } onNavigateDateSelect(date) { this._service.open(date); } onNavigateEvent(event) { switch (event) { case NavigationEvent.PREV: this._service.open(this._calendar.getPrev(this.model.firstDate, 'm', 1)); break; case NavigationEvent.NEXT: this._service.open(this._calendar.getNext(this.model.firstDate, 'm', 1)); break; } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(disabled) { this._service.set({ disabled }); } writeValue(value) { this._controlValue = NgbDate.from(this._ngbDateAdapter.fromModel(value)); this._service.select(this._controlValue); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepicker, deps: [{ token: i3.NgbDatepickerService }, { token: i4.NgbCalendar }, { token: i1.NgbDatepickerI18n }, { token: i5.NgbDatepickerConfig }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i6.NgbDateAdapter }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.6", type: NgbDatepicker, isStandalone: true, selector: "ngb-datepicker", inputs: { contentTemplate: "contentTemplate", dayTemplate: "dayTemplate", dayTemplateData: "dayTemplateData", displayMonths: "displayMonths", firstDayOfWeek: "firstDayOfWeek", footerTemplate: "footerTemplate", markDisabled: "markDisabled", maxDate: "maxDate", minDate: "minDate", navigation: "navigation", outsideDays: "outsideDays", showWeekNumbers: "showWeekNumbers", startDate: "startDate", weekdays: "weekdays" }, outputs: { navigate: "navigate", dateSelect: "dateSelect" }, host: { properties: { "class.disabled": "model.disabled" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgbDatepicker), multi: true }, NgbDatepickerService, ], queries: [{ propertyName: "contentTemplateFromContent", first: true, predicate: NgbDatepickerContent, descendants: true, static: true }], viewQueries: [{ propertyName: "_defaultDayTemplate", first: true, predicate: ["defaultDayTemplate"], descendants: true, static: true }, { propertyName: "_contentEl", first: true, predicate: ["content"], descendants: true, static: true }], exportAs: ["ngbDatepicker"], usesOnChanges: true, ngImport: i0, template: ` <ng-template #defaultDayTemplate let-date="date" let-currentMonth="currentMonth" let-selected="selected" let-disabled="disabled" let-focused="focused" > <div ngbDatepickerDayView [date]="date" [currentMonth]="currentMonth" [selected]="selected" [disabled]="disabled" [focused]="focused" > </div> </ng-template> <ng-template #defaultContentTemplate> <div *ngFor="let month of model.months; let i = index" class="ngb-dp-month"> <div *ngIf="navigation === 'none' || (displayMonths > 1 && navigation === 'select')" class="ngb-dp-month-name"> {{ i18n.getMonthLabel(month.firstDate) }} </div> <ngb-datepicker-month [month]="month.firstDate"></ngb-datepicker-month> </div> </ng-template> <div class="ngb-dp-header"> <ngb-datepicker-navigation *ngIf="navigation !== 'none'" [date]="model.firstDate!" [months]="model.months" [disabled]="model.disabled" [showSelect]="model.navigation === 'select'" [prevDisabled]="model.prevDisabled" [nextDisabled]="model.nextDisabled" [selectBoxes]="model.selectBoxes" (navigate)="onNavigateEvent($event)" (select)="onNavigateDateSelect($event)" > </ngb-datepicker-navigation> </div> <div class="ngb-dp-content" [class.ngb-dp-months]="!contentTemplate" #content> <ng-template [ngTemplateOutlet]="contentTemplate || contentTemplateFromContent?.templateRef || defaultContentTemplate" [ngTemplateOutletContext]="{ $implicit: this }" [ngTemplateOutletInjector]="injector" ></ng-template> </div> <ng-template [ngTemplateOutlet]="footerTemplate"></ng-template> `, isInline: true, styles: ["ngb-datepicker{border:1px solid var(--bs-border-color);border-radius:.25rem;display:inline-block}ngb-datepicker-month{pointer-events:auto}ngb-datepicker.dropdown-menu{padding:0}ngb-datepicker.disabled .ngb-dp-weekday,ngb-datepicker.disabled .ngb-dp-week-number,ngb-datepicker.disabled .ngb-dp-month-name{color:var(--bs-text-muted)}.ngb-dp-body{z-index:1055}.ngb-dp-header{border-bottom:0;border-radius:.25rem .25rem 0 0;padding-top:.25rem;background-color:var(--bs-light)}.ngb-dp-months{display:flex}.ngb-dp-month{pointer-events:none}.ngb-dp-month-name{font-size:larger;height:2rem;line-height:2rem;text-align:center;background-color:var(--bs-light)}.ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,.ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-left:1rem}.ngb-dp-month:last-child .ngb-dp-week{padding-right:.25rem}.ngb-dp-month:first-child .ngb-dp-week{padding-left:.25rem}.ngb-dp-month .ngb-dp-week:last-child{padding-bottom:.25rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NgbDatepickerDayView, selector: "[ngbDatepickerDayView]", inputs: ["currentMonth", "date", "disabled", "focused", "selected"] }, { kind: "component", type: NgbDatepickerMonth, selector: "ngb-datepicker-month", inputs: ["month"] }, { kind: "component", type: NgbDatepickerNavigation, selector: "ngb-datepicker-navigation", inputs: ["date", "disabled", "months", "showSelect", "prevDisabled", "nextDisabled", "selectBoxes"], outputs: ["navigate", "select"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } export { NgbDatepicker }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbDatepicker, decorators: [{ type: Component, args: [{ exportAs: 'ngbDatepicker', selector: 'ngb-datepicker', standalone: true, imports: [NgIf, NgFor, NgTemplateOutlet, NgbDatepickerDayView, NgbDatepickerMonth, NgbDatepickerNavigation], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { '[class.disabled]': 'model.disabled' }, template: ` <ng-template #defaultDayTemplate let-date="date" let-currentMonth="currentMonth" let-selected="selected" let-disabled="disabled" let-focused="focused" > <div ngbDatepickerDayView [date]="date" [currentMonth]="currentMonth" [selected]="selected" [disabled]="disabled" [focused]="focused" > </div> </ng-template> <ng-template #defaultContentTemplate> <div *ngFor="let month of model.months; let i = index" class="ngb-dp-month"> <div *ngIf="navigation === 'none' || (displayMonths > 1 && navigation === 'select')" class="ngb-dp-month-name"> {{ i18n.getMonthLabel(month.firstDate) }} </div> <ngb-datepicker-month [month]="month.firstDate"></ngb-datepicker-month> </div> </ng-template> <div class="ngb-dp-header"> <ngb-datepicker-navigation *ngIf="navigation !== 'none'" [date]="model.firstDate!" [months]="model.months" [disabled]="model.disabled" [showSelect]="model.navigation === 'select'" [prevDisabled]="model.prevDisabled" [nextDisabled]="model.nextDisabled" [selectBoxes]="model.selectBoxes" (navigate)="onNavigateEvent($event)" (select)="onNavigateDateSelect($event)" > </ngb-datepicker-navigation> </div> <div class="ngb-dp-content" [class.ngb-dp-months]="!contentTemplate" #content> <ng-template [ngTemplateOutlet]="contentTemplate || contentTemplateFromContent?.templateRef || defaultContentTemplate" [ngTemplateOutletContext]="{ $implicit: this }" [ngTemplateOutletInjector]="injector" ></ng-template> </div> <ng-template [ngTemplateOutlet]="footerTemplate"></ng-template> `, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgbDatepicker), multi: true }, NgbDatepickerService, ], styles: ["ngb-datepicker{border:1px solid var(--bs-border-color);border-radius:.25rem;display:inline-block}ngb-datepicker-month{pointer-events:auto}ngb-datepicker.dropdown-menu{padding:0}ngb-datepicker.disabled .ngb-dp-weekday,ngb-datepicker.disabled .ngb-dp-week-number,ngb-datepicker.disabled .ngb-dp-month-name{color:var(--bs-text-muted)}.ngb-dp-body{z-index:1055}.ngb-dp-header{border-bottom:0;border-radius:.25rem .25rem 0 0;padding-top:.25rem;background-color:var(--bs-light)}.ngb-dp-months{display:flex}.ngb-dp-month{pointer-events:none}.ngb-dp-month-name{font-size:larger;height:2rem;line-height:2rem;text-align:center;background-color:var(--bs-light)}.ngb-dp-month+.ngb-dp-month .ngb-dp-month-name,.ngb-dp-month+.ngb-dp-month .ngb-dp-week{padding-left:1rem}.ngb-dp-month:last-child .ngb-dp-week{padding-right:.25rem}.ngb-dp-month:first-child .ngb-dp-week{padding-left:.25rem}.ngb-dp-month .ngb-dp-week:last-child{padding-bottom:.25rem}\n"] }] }], ctorParameters: function () { return [{ type: i3.NgbDatepickerService }, { type: i4.NgbCalendar }, { type: i1.NgbDatepickerI18n }, { type: i5.NgbDatepickerConfig }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i6.NgbDateAdapter }, { type: i0.NgZone }]; }, propDecorators: { _defaultDayTemplate: [{ type: ViewChild, args: ['defaultDayTemplate', { static: true }] }], _contentEl: [{ type: ViewChild, args: ['content', { static: true }] }], contentTemplate: [{ type: Input }], contentTemplateFromContent: [{ type: ContentChild, args: [NgbDatepickerContent, { static: true }] }], dayTemplate: [{ type: Input }], dayTemplateData: [{ type: Input }], displayMonths: [{ type: Input }], firstDayOfWeek: [{ type: Input }], footerTemplate: [{ type: Input }], markDisabled: [{ type: Input }], maxDate: [{ type: Input }], minDate: [{ type: Input }], navigation: [{ type: Input }], outsideDays: [{ type: Input }], showWeekNumbers: [{ type: Input }], startDate: [{ type: Input }], weekdays: [{ type: Input }], navigate: [{ type: Output }], dateSelect: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.js","sourceRoot":"","sources":["../../../../src/datepicker/datepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, take, takeUntil } from 'rxjs/operators';\nimport {\n\tAfterViewInit,\n\tChangeDetectionStrategy,\n\tChangeDetectorRef,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tforwardRef,\n\tinject,\n\tInject,\n\tInjector,\n\tInput,\n\tNgZone,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild,\n\tViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgFor, NgIf, NgTemplateOutlet, TranslationWidth } from '@angular/common';\n\nimport { NgbCalendar } from './ngb-calendar';\nimport { NgbDate } from './ngb-date';\nimport { DatepickerServiceInputs, NgbDatepickerService } from './datepicker-service';\nimport { DatepickerViewModel, DayViewModel, MonthViewModel, NavigationEvent } from './datepicker-view-model';\nimport { DayTemplateContext } from './datepicker-day-template-context';\nimport { NgbDatepickerConfig } from './datepicker-config';\nimport { NgbDateAdapter } from './adapters/ngb-date-adapter';\nimport { NgbDateStruct } from './ngb-date-struct';\nimport { NgbDatepickerI18n } from './datepicker-i18n';\nimport { NgbDatepickerKeyboardService } from './datepicker-keyboard-service';\nimport { isChangedDate, isChangedMonth } from './datepicker-tools';\nimport { hasClassName } from '../util/util';\nimport { NgbDatepickerDayView } from './datepicker-day-view';\nimport { NgbDatepickerNavigation } from './datepicker-navigation';\nimport { ContentTemplateContext } from './datepicker-content-template-context';\n\n/**\n * An event emitted right before the navigation happens and the month displayed by the datepicker changes.\n */\nexport interface NgbDatepickerNavigateEvent {\n\t/**\n\t * The currently displayed month.\n\t */\n\tcurrent: { year: number; month: number } | null;\n\n\t/**\n\t * The month we're navigating to.\n\t */\n\tnext: { year: number; month: number };\n\n\t/**\n\t * Calling this function will prevent navigation from happening.\n\t *\n\t * @since 4.1.0\n\t */\n\tpreventDefault: () => void;\n}\n\n/**\n * An interface that represents the readonly public state of the datepicker.\n *\n * Accessible via the `datepicker.state` getter\n *\n * @since 5.2.0\n */\nexport interface NgbDatepickerState {\n\t/**\n\t * The earliest date that can be displayed or selected\n\t */\n\treadonly minDate: NgbDate | null;\n\n\t/**\n\t * The latest date that can be displayed or selected\n\t */\n\treadonly maxDate: NgbDate | null;\n\n\t/**\n\t * The first visible date of currently displayed months\n\t */\n\treadonly firstDate: NgbDate;\n\n\t/**\n\t * The last visible date of currently displayed months\n\t */\n\treadonly lastDate: NgbDate;\n\n\t/**\n\t * The date currently focused by the datepicker\n\t */\n\treadonly focusedDate: NgbDate;\n\n\t/**\n\t * First dates of months currently displayed by the datepicker\n\t *\n\t * @since 5.3.0\n\t */\n\treadonly months: NgbDate[];\n}\n\n/**\n * A directive that marks the content template that customizes the way datepicker months are displayed\n *\n * @since 5.3.0\n */\n@Directive({ selector: 'ng-template[ngbDatepickerContent]', standalone: true })\nexport class NgbDatepickerContent {\n\tconstructor(public templateRef: TemplateRef<any>) {}\n}\n\n/**\n * A component that renders one month including all the days, weekdays and week numbers. Can be used inside\n * the `<ng-template ngbDatepickerMonths></ng-template>` when you want to customize months layout.\n *\n * For a usage example, see [custom month layout demo](#/components/datepicker/examples#custommonth)\n *\n * @since 5.3.0\n */\n@Component({\n\tselector: 'ngb-datepicker-month',\n\tstandalone: true,\n\timports: [NgIf, NgFor, NgTemplateOutlet],\n\thost: { role: 'grid', '(keydown)': 'onKeyDown($event)' },\n\tencapsulation: ViewEncapsulation.None,\n\tstyleUrls: ['./datepicker-month.scss'],\n\ttemplate: `\n\t\t<div *ngIf=\"viewModel.weekdays.length > 0\" class=\"ngb-dp-week ngb-dp-weekdays\" role=\"row\">\n\t\t\t<div *ngIf=\"datepicker.showWeekNumbers\" class=\"ngb-dp-weekday ngb-dp-showweek small\">{{\n\t\t\t\ti18n.getWeekLabel()\n\t\t\t}}</div>\n\t\t\t<div *ngFor=\"let weekday of viewModel.weekdays\" class=\"ngb-dp-weekday small\" role=\"columnheader\">{{\n\t\t\t\tweekday\n\t\t\t}}</div>\n\t\t</div>\n\t\t<ng-template ngFor let-week [ngForOf]=\"viewModel.weeks\">\n\t\t\t<div *ngIf=\"!week.collapsed\" class=\"ngb-dp-week\" role=\"row\">\n\t\t\t\t<div *ngIf=\"datepicker.showWeekNumbers\" class=\"ngb-dp-week-number small text-muted\">{{\n\t\t\t\t\ti18n.getWeekNumerals(week.number)\n\t\t\t\t}}</div>\n\t\t\t\t<div\n\t\t\t\t\t*ngFor=\"let day of week.days\"\n\t\t\t\t\t(click)=\"doSelect(day); $event.preventDefault()\"\n\t\t\t\t\tclass=\"ngb-dp-day\"\n\t\t\t\t\trole=\"gridcell\"\n\t\t\t\t\t[class.disabled]=\"day.context.disabled\"\n\t\t\t\t\t[tabindex]=\"day.tabindex\"\n\t\t\t\t\t[class.hidden]=\"day.hidden\"\n\t\t\t\t\t[class.ngb-dp-today]=\"day.context.today\"\n\t\t\t\t\t[attr.aria-label]=\"day.ariaLabel\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template [ngIf]=\"!day.hidden\">\n\t\t\t\t\t\t<ng-template\n\t\t\t\t\t\t\t[ngTemplateOutlet]=\"datepicker.dayTemplate\"\n\t\t\t\t\t\t\t[ngTemplateOutletContext]=\"day.context\"\n\t\t\t\t\t\t></ng-template>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</ng-template>\n\t`,\n})\nexport class NgbDatepickerMonth {\n\t/**\n\t * The first date of month to be rendered.\n\t *\n\t * This month must one of the months present in the\n\t * [datepicker state](#/components/datepicker/api#NgbDatepickerState).\n\t */\n\t@Input()\n\tset month(month: NgbDateStruct) {\n\t\tthis.viewModel = this._service.getMonth(month);\n\t}\n\n\tviewModel: MonthViewModel;\n\n\tconstructor(\n\t\tpublic i18n: NgbDatepickerI18n,\n\t\t@Inject(forwardRef(() => NgbDatepicker)) public datepicker: NgbDatepicker,\n\t\tprivate _keyboardService: NgbDatepickerKeyboardService,\n\t\tprivate _service: NgbDatepickerService,\n\t) {}\n\n\tonKeyDown(event: KeyboardEvent) {\n\t\tthis._keyboardService.processKey(event, this.datepicker);\n\t}\n\n\tdoSelect(day: DayViewModel) {\n\t\tif (!day.context.disabled && !day.hidden) {\n\t\t\tthis.datepicker.onDateSelect(day.date);\n\t\t}\n\t}\n}\n\n/**\n * A highly configurable component that helps you with selecting calendar dates.\n *\n * `NgbDatepicker` is meant to be displayed inline on a page or put inside a popup.\n */\n@Component({\n\texportAs: 'ng