UNPKG

@clr/angular

Version:

Angular components for Clarity

145 lines 15.4 kB
/* * Copyright (c) 2016-2025 Broadcom. All Rights Reserved. * The term "Broadcom" refers to Broadcom Inc. and/or its subsidiaries. * This software is released under MIT license. * The full license information can be found in LICENSE in the root directory of this project. */ import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "./providers/date-navigation.service"; import * as i2 from "../../utils/i18n/common-strings.service"; export class ClrDay { constructor(_dateNavigationService, commonStrings) { this._dateNavigationService = _dateNavigationService; this.commonStrings = commonStrings; this.onSelectDay = new EventEmitter(); } /** * DayViewModel input which is used to build the Day View. */ get dayView() { return this._dayView; } set dayView(day) { this._dayView = day; } get dayString() { return this.dayView.isSelected ? this.commonStrings.parse(this.commonStrings.keys.datepickerSelectedLabel, { FULL_DATE: this._dayView.dayModel.toDateString(), }) : this._dayView.dayModel.toDateString(); } get isRangeStartDay() { return (this._dateNavigationService.isRangePicker && this.dayView?.dayModel?.toComparisonString() === this._dateNavigationService.selectedDay?.toComparisonString()); } get isRangeEndDay() { return (this._dateNavigationService.isRangePicker && this.dayView?.dayModel?.toComparisonString() === this._dateNavigationService.selectedEndDay?.toComparisonString()); } /** * Calls the DateNavigationService to update the hovered day value of the calendar */ hoverListener() { if (!this.dayView.isDisabled) { this._dateNavigationService.hoveredDay = this.dayView.dayModel; } } /** * Updates the focusedDay in the DateNavigationService when the ClrDay is focused. */ onDayViewFocus() { this._dateNavigationService.focusedDay = this.dayView.dayModel; } /** * Updates the selectedDay when the ClrDay is selected and closes the datepicker popover. */ selectDay() { if (this.dayView.isDisabled) { return; } const day = this.dayView.dayModel; this.onSelectDay.emit(day); } /** * Applicable only to date range picker * Compares whether the day is in between the start and end date range */ isInRange() { if (!this._dateNavigationService.isRangePicker) { return false; } if (this._dateNavigationService.selectedDay && this._dateNavigationService.selectedEndDay) { return (this._dayView.dayModel?.isAfter(this._dateNavigationService.selectedDay) && this._dayView.dayModel?.isBefore(this._dateNavigationService.selectedEndDay)); } else if (this._dateNavigationService.selectedDay && !this._dateNavigationService.selectedEndDay) { return (this._dayView.dayModel?.isAfter(this._dateNavigationService.selectedDay) && this._dayView.dayModel?.isBefore(this._dateNavigationService.hoveredDay, true)); } else { return false; } } } ClrDay.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrDay, deps: [{ token: i1.DateNavigationService }, { token: i2.ClrCommonStringsService }], target: i0.ɵɵFactoryTarget.Component }); ClrDay.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.2", type: ClrDay, selector: "clr-day", inputs: { dayView: ["clrDayView", "dayView"] }, outputs: { onSelectDay: "selectDay" }, host: { listeners: { "mouseenter": "hoverListener()" }, properties: { "class.day": "true" } }, ngImport: i0, template: ` <button class="day-btn" type="button" [class.is-today]="dayView.isTodaysDate" [class.is-excluded]="dayView.isExcluded" [class.is-disabled]="dayView.isDisabled" [class.is-selected]="dayView.isSelected" [class.in-range]="isInRange()" [class.is-start-range]="isRangeStartDay" [class.is-end-range]="isRangeEndDay" [attr.tabindex]="dayView.tabIndex" (click)="selectDay()" (focus)="onDayViewFocus()" [attr.aria-current]="dayView.isTodaysDate ? 'date' : 'false'" [attr.aria-label]="dayString" [attr.aria-selected]="dayView.isSelected" > {{ dayView.dayModel.date }} </button> `, isInline: true }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: ClrDay, decorators: [{ type: Component, args: [{ selector: 'clr-day', template: ` <button class="day-btn" type="button" [class.is-today]="dayView.isTodaysDate" [class.is-excluded]="dayView.isExcluded" [class.is-disabled]="dayView.isDisabled" [class.is-selected]="dayView.isSelected" [class.in-range]="isInRange()" [class.is-start-range]="isRangeStartDay" [class.is-end-range]="isRangeEndDay" [attr.tabindex]="dayView.tabIndex" (click)="selectDay()" (focus)="onDayViewFocus()" [attr.aria-current]="dayView.isTodaysDate ? 'date' : 'false'" [attr.aria-label]="dayString" [attr.aria-selected]="dayView.isSelected" > {{ dayView.dayModel.date }} </button> `, host: { '[class.day]': 'true' }, }] }], ctorParameters: function () { return [{ type: i1.DateNavigationService }, { type: i2.ClrCommonStringsService }]; }, propDecorators: { onSelectDay: [{ type: Output, args: ['selectDay'] }], dayView: [{ type: Input, args: ['clrDayView'] }], hoverListener: [{ type: HostListener, args: ['mouseenter'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"day.js","sourceRoot":"","sources":["../../../../../projects/angular/src/forms/datepicker/day.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2016-2025 Broadcom. All Rights Reserved.\n * The term \"Broadcom\" refers to Broadcom Inc. and/or its subsidiaries.\n * This software is released under MIT license.\n * The full license information can be found in LICENSE in the root directory of this project.\n */\n\nimport { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\n\nimport { ClrCommonStringsService } from '../../utils/i18n/common-strings.service';\nimport { DayViewModel } from './model/day-view.model';\nimport { DayModel } from './model/day.model';\nimport { DateNavigationService } from './providers/date-navigation.service';\n\n@Component({\n  selector: 'clr-day',\n  template: `\n    <button\n      class=\"day-btn\"\n      type=\"button\"\n      [class.is-today]=\"dayView.isTodaysDate\"\n      [class.is-excluded]=\"dayView.isExcluded\"\n      [class.is-disabled]=\"dayView.isDisabled\"\n      [class.is-selected]=\"dayView.isSelected\"\n      [class.in-range]=\"isInRange()\"\n      [class.is-start-range]=\"isRangeStartDay\"\n      [class.is-end-range]=\"isRangeEndDay\"\n      [attr.tabindex]=\"dayView.tabIndex\"\n      (click)=\"selectDay()\"\n      (focus)=\"onDayViewFocus()\"\n      [attr.aria-current]=\"dayView.isTodaysDate ? 'date' : 'false'\"\n      [attr.aria-label]=\"dayString\"\n      [attr.aria-selected]=\"dayView.isSelected\"\n    >\n      {{ dayView.dayModel.date }}\n    </button>\n  `,\n  host: { '[class.day]': 'true' },\n})\nexport class ClrDay {\n  @Output('selectDay') onSelectDay = new EventEmitter<DayModel>();\n\n  private _dayView: DayViewModel;\n\n  constructor(private _dateNavigationService: DateNavigationService, private commonStrings: ClrCommonStringsService) {}\n\n  /**\n   * DayViewModel input which is used to build the Day View.\n   */\n\n  @Input('clrDayView')\n  get dayView(): DayViewModel {\n    return this._dayView;\n  }\n  set dayView(day: DayViewModel) {\n    this._dayView = day;\n  }\n\n  get dayString(): string {\n    return this.dayView.isSelected\n      ? this.commonStrings.parse(this.commonStrings.keys.datepickerSelectedLabel, {\n          FULL_DATE: this._dayView.dayModel.toDateString(),\n        })\n      : this._dayView.dayModel.toDateString();\n  }\n\n  get isRangeStartDay(): boolean {\n    return (\n      this._dateNavigationService.isRangePicker &&\n      this.dayView?.dayModel?.toComparisonString() === this._dateNavigationService.selectedDay?.toComparisonString()\n    );\n  }\n\n  get isRangeEndDay(): boolean {\n    return (\n      this._dateNavigationService.isRangePicker &&\n      this.dayView?.dayModel?.toComparisonString() === this._dateNavigationService.selectedEndDay?.toComparisonString()\n    );\n  }\n\n  /**\n   * Calls the DateNavigationService to update the hovered day value of the calendar\n   */\n  @HostListener('mouseenter')\n  hoverListener(): void {\n    if (!this.dayView.isDisabled) {\n      this._dateNavigationService.hoveredDay = this.dayView.dayModel;\n    }\n  }\n\n  /**\n   * Updates the focusedDay in the DateNavigationService when the ClrDay is focused.\n   */\n  onDayViewFocus() {\n    this._dateNavigationService.focusedDay = this.dayView.dayModel;\n  }\n\n  /**\n   * Updates the selectedDay when the ClrDay is selected and closes the datepicker popover.\n   */\n  selectDay(): void {\n    if (this.dayView.isDisabled) {\n      return;\n    }\n    const day: DayModel = this.dayView.dayModel;\n    this.onSelectDay.emit(day);\n  }\n\n  /**\n   * Applicable only to date range picker\n   * Compares whether the day is in between the start and end date range\n   */\n  isInRange(): boolean {\n    if (!this._dateNavigationService.isRangePicker) {\n      return false;\n    }\n    if (this._dateNavigationService.selectedDay && this._dateNavigationService.selectedEndDay) {\n      return (\n        this._dayView.dayModel?.isAfter(this._dateNavigationService.selectedDay) &&\n        this._dayView.dayModel?.isBefore(this._dateNavigationService.selectedEndDay)\n      );\n    } else if (this._dateNavigationService.selectedDay && !this._dateNavigationService.selectedEndDay) {\n      return (\n        this._dayView.dayModel?.isAfter(this._dateNavigationService.selectedDay) &&\n        this._dayView.dayModel?.isBefore(this._dateNavigationService.hoveredDay, true)\n      );\n    } else {\n      return false;\n    }\n  }\n}\n"]}