@quadrel-enterprise-ui/framework 18.24.1 → 18.24.2
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.
|
@@ -118,11 +118,8 @@ export class QdCalendarComponent {
|
|
|
118
118
|
this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
|
|
119
119
|
}
|
|
120
120
|
fillDates(momentObj) {
|
|
121
|
-
const firstOfMonth = moment(momentObj).startOf('month').day();
|
|
122
121
|
const lastOfMonth = moment(momentObj).endOf('month').day();
|
|
123
|
-
const firstDayOfGrid = moment(momentObj)
|
|
124
|
-
.startOf('month')
|
|
125
|
-
.subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');
|
|
122
|
+
const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');
|
|
126
123
|
const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
|
|
127
124
|
const startCalendar = firstDayOfGrid.date();
|
|
128
125
|
return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
|
|
@@ -183,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
183
180
|
}], selectedChange: [{
|
|
184
181
|
type: Output
|
|
185
182
|
}] } });
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.ts","../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { range } from 'lodash';\nimport moment, { Moment } from 'moment';\nimport { QdCalendarDay, QdCalendarMode, QdDisabledDates } from '../../model/datepicker';\nimport { QdDateAdapter } from '../adapter/date-adapter';\n\nconst YearsBefore = 9;\nconst YearsAfter = 2;\n\n@Component({\n  selector: 'qd-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdCalendarComponent implements OnInit, OnChanges {\n  /**\n   * This property is used to highlight the selected date in the calendar. It should be in the format for example 'DD.MM.YYYY' or 'MM/DD/YYYY' depending on the language used.\n   *\n   * @example '2022-12-25'\n   */\n  @Input()\n  selectedDate: QdCalendarDay['formatted'];\n\n  /**\n   * This property determines the language used for displaying the weekdays and formatting the dates in the calendar. It should be a valid language code supported by the moment.js library.\n   *\n   * @example 'de'\n   */\n  @Input()\n  language: string;\n\n  /**\n   * This property disables the given date ranges.The ranges have a \"from\" and \"to\" date.\n   * If \"from\" is empty, it will set the default value 1900\n   * If \"to\" is empty, it will be set to the default 2100\n   *\n   */\n  @Input()\n  disabledDates: QdDisabledDates[];\n\n  /**\n   * Outputs a value when the user selects a date in the calendar. The newly selected date is output as a formatted date string.\n   */\n  @Output()\n  selectedChange = new EventEmitter<QdCalendarDay['formatted']>();\n\n  currentDate: Moment;\n  todayDate: Moment;\n\n  weekdays: string[];\n  weeks: Array<QdCalendarDay[]> = [];\n  months: string[];\n  years: number[];\n\n  mode: QdCalendarMode = QdCalendarMode.Default;\n\n  protected readonly QdCalendarMode = QdCalendarMode;\n\n  ngOnInit(): void {\n    moment.locale(this.language);\n\n    this.weekdays = moment.weekdaysMin(true);\n    this.todayDate = moment();\n\n    this.months = moment.months();\n    this.years = this.getYears(\n      (QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n        ? moment(this.selectedDate, 'L', this.language)\n        : this.todayDate\n      ).year()\n    );\n\n    this.setCurrentDate();\n    this.generateCalendar(this.currentDate);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['language']) moment.locale(this.language);\n    if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange()) this.generateCalendar(this.currentDate);\n  }\n\n  isSameYearMonth(day: Moment): boolean {\n    return day.isSame(this.currentDate, 'month');\n  }\n\n  isSameMonth(month): boolean {\n    return this.currentDate.month() === month;\n  }\n\n  isSameYear(year: number): boolean {\n    return QdDateAdapter.parseToMoment(this.selectedDate).year() === year;\n  }\n\n  prev(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.subtract(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() - (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() - 1);\n    }\n  }\n\n  next(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.add(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() + (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() + 1);\n    }\n  }\n\n  isSelected(momentObj: Moment): boolean {\n    if (!this.selectedDate) return false;\n\n    return QdDateAdapter.formatToLocalizedDateString(momentObj) === this.selectedDate;\n  }\n\n  selectDate(date: QdCalendarDay | any): void {\n    this.selectedChange.emit(date.formatted);\n  }\n\n  selectYear(year: number): void {\n    this.currentDate.set('year', year);\n    this.mode = QdCalendarMode.MonthPicker;\n  }\n\n  selectMonth(month: number): void {\n    this.currentDate.set('month', month);\n    this.generateCalendar(this.currentDate);\n    this.mode = QdCalendarMode.Default;\n  }\n\n  changeMode(nr: QdCalendarMode): void {\n    this.mode = nr;\n  }\n\n  private generateCalendar(momentObj: Moment): void {\n    const dates = this.fillDates(momentObj);\n    this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));\n  }\n\n  private fillDates(momentObj: Moment): QdCalendarDay[] {\n    const firstOfMonth = moment(momentObj).startOf('month').day();\n    const lastOfMonth = moment(momentObj).endOf('month').day();\n    const firstDayOfGrid = moment(momentObj)\n      .startOf('month')\n      .subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');\n    const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');\n    const startCalendar = firstDayOfGrid.date();\n\n    return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {\n      const newDate = moment(firstDayOfGrid).date(date);\n\n      return {\n        formatted: QdDateAdapter.formatToLocalizedDateString(newDate),\n        moment: newDate,\n        selected: this.isSelected(newDate),\n        today: this.isToday(newDate),\n        disabled: this.isDisabled(newDate)\n      };\n    });\n  }\n\n  private isToday(momentObj: Moment): boolean {\n    return this.todayDate.isSame(momentObj, 'day');\n  }\n\n  private setCurrentDate(): void {\n    const currentDate: Moment = (this.currentDate = QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n      ? moment(this.selectedDate, 'L', 'de')\n      : this.todayDate);\n\n    this.currentDate = currentDate;\n    this.selectedDate = QdDateAdapter.formatToLocalizedDateString(currentDate);\n  }\n\n  private getYears(year: number): number[] {\n    const yearsBefore = YearsBefore;\n    const yearsAfter = YearsAfter;\n    const result: number[] = [];\n\n    for (let i = year - yearsBefore; i <= year + yearsAfter; i++) {\n      result.push(i);\n    }\n\n    return result;\n  }\n\n  private isDisabled(date: Moment): boolean {\n    if (!this.disabledDates) return false;\n    return this.disabledDates.some(disabledDate => {\n      let fromDate = moment(disabledDate.from);\n      let toDate = moment(disabledDate.to);\n      if (!disabledDate.from) fromDate = moment('1900-01-01T00:00:00.000Z');\n      if (!disabledDate.to) toDate = moment('2100-01-01T00:00:00.000Z');\n\n      return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');\n    });\n  }\n}\n","<div class=\"nav\">\n  <button (click)=\"prev()\">\n    <qd-icon icon=\"arrowLeft\"></qd-icon>\n  </button>\n\n  <ng-container>\n    <span\n      *ngIf=\"mode === QdCalendarMode.Default\"\n      class=\"current-month-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate.locale(language).format(\"MMMM\") }} {{ currentDate?.format(\"YYYY\") }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.YearPicker\"\n      class=\"current-years-list\"\n      (click)=\"changeMode(QdCalendarMode.MonthPicker)\"\n    >\n      {{ years[0] }} - {{ years[years.length - 1] }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.MonthPicker\"\n      class=\"current-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate?.format(\"YYYY\") }}\n    </span>\n  </ng-container>\n\n  <button (click)=\"next()\">\n    <qd-icon icon=\"arrowRight\"></qd-icon>\n  </button>\n</div>\n\n<table *ngIf=\"mode === QdCalendarMode.Default\">\n  <thead></thead>\n  <tbody>\n    <tr>\n      <td class=\"weekday\" *ngFor=\"let name of weekdays\">{{ name }}</td>\n    </tr>\n    <tr *ngFor=\"let week of weeks\">\n      <td\n        class=\"day {{ day.moment.date() }}\"\n        *ngFor=\"let day of week\"\n        (click)=\"selectDate(day)\"\n        [ngClass]=\"{\n          today: day.today,\n          selected: day.selected,\n          hidden: !isSameYearMonth(day.moment),\n          disabled: day.disabled\n        }\"\n      >\n        {{ day.moment.date() }}\n      </td>\n    </tr>\n  </tbody>\n</table>\n\n<div class=\"calendar\" *ngIf=\"mode !== QdCalendarMode.Default\">\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.YearPicker\">\n    <div class=\"col {{ year }}\" *ngFor=\"let year of years\">\n      <div class=\"entry\" (click)=\"selectYear(year)\" [ngClass]=\"{ selected: isSameYear(year) }\">\n        {{ year }}\n      </div>\n    </div>\n  </div>\n\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.MonthPicker\">\n    <div class=\"col {{ month }}\" *ngFor=\"let month of months; let i = index\">\n      <div class=\"entry\" (click)=\"selectMonth(i)\" [ngClass]=\"{ selected: isSameMonth(i), month }\">\n        {{ month }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.ts","../../../../../../../libs/qd-ui/src/lib/forms/datepicker/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { range } from 'lodash';\nimport moment, { Moment } from 'moment';\nimport { QdCalendarDay, QdCalendarMode, QdDisabledDates } from '../../model/datepicker';\nimport { QdDateAdapter } from '../adapter/date-adapter';\n\nconst YearsBefore = 9;\nconst YearsAfter = 2;\n\n@Component({\n  selector: 'qd-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class QdCalendarComponent implements OnInit, OnChanges {\n  /**\n   * This property is used to highlight the selected date in the calendar. It should be in the format for example 'DD.MM.YYYY' or 'MM/DD/YYYY' depending on the language used.\n   *\n   * @example '2022-12-25'\n   */\n  @Input()\n  selectedDate: QdCalendarDay['formatted'];\n\n  /**\n   * This property determines the language used for displaying the weekdays and formatting the dates in the calendar. It should be a valid language code supported by the moment.js library.\n   *\n   * @example 'de'\n   */\n  @Input()\n  language: string;\n\n  /**\n   * This property disables the given date ranges.The ranges have a \"from\" and \"to\" date.\n   * If \"from\" is empty, it will set the default value 1900\n   * If \"to\" is empty, it will be set to the default 2100\n   *\n   */\n  @Input()\n  disabledDates: QdDisabledDates[];\n\n  /**\n   * Outputs a value when the user selects a date in the calendar. The newly selected date is output as a formatted date string.\n   */\n  @Output()\n  selectedChange = new EventEmitter<QdCalendarDay['formatted']>();\n\n  currentDate: Moment;\n  todayDate: Moment;\n\n  weekdays: string[];\n  weeks: Array<QdCalendarDay[]> = [];\n  months: string[];\n  years: number[];\n\n  mode: QdCalendarMode = QdCalendarMode.Default;\n\n  protected readonly QdCalendarMode = QdCalendarMode;\n\n  ngOnInit(): void {\n    moment.locale(this.language);\n\n    this.weekdays = moment.weekdaysMin(true);\n    this.todayDate = moment();\n\n    this.months = moment.months();\n    this.years = this.getYears(\n      (QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n        ? moment(this.selectedDate, 'L', this.language)\n        : this.todayDate\n      ).year()\n    );\n\n    this.setCurrentDate();\n    this.generateCalendar(this.currentDate);\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['language']) moment.locale(this.language);\n    if (changes['disabledDates'] && !changes['disabledDates'].isFirstChange()) this.generateCalendar(this.currentDate);\n  }\n\n  isSameYearMonth(day: Moment): boolean {\n    return day.isSame(this.currentDate, 'month');\n  }\n\n  isSameMonth(month): boolean {\n    return this.currentDate.month() === month;\n  }\n\n  isSameYear(year: number): boolean {\n    return QdDateAdapter.parseToMoment(this.selectedDate).year() === year;\n  }\n\n  prev(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.subtract(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() - (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() - 1);\n    }\n  }\n\n  next(): void {\n    if (this.mode === QdCalendarMode.Default) {\n      this.currentDate.add(1, 'months');\n      this.generateCalendar(this.currentDate);\n    } else if (this.mode === QdCalendarMode.YearPicker) {\n      this.currentDate.set('year', this.currentDate.year() + (YearsBefore + YearsAfter + 1));\n      this.years = this.getYears(this.currentDate.year());\n    } else {\n      this.currentDate.set('year', this.currentDate.year() + 1);\n    }\n  }\n\n  isSelected(momentObj: Moment): boolean {\n    if (!this.selectedDate) return false;\n\n    return QdDateAdapter.formatToLocalizedDateString(momentObj) === this.selectedDate;\n  }\n\n  selectDate(date: QdCalendarDay | any): void {\n    this.selectedChange.emit(date.formatted);\n  }\n\n  selectYear(year: number): void {\n    this.currentDate.set('year', year);\n    this.mode = QdCalendarMode.MonthPicker;\n  }\n\n  selectMonth(month: number): void {\n    this.currentDate.set('month', month);\n    this.generateCalendar(this.currentDate);\n    this.mode = QdCalendarMode.Default;\n  }\n\n  changeMode(nr: QdCalendarMode): void {\n    this.mode = nr;\n  }\n\n  private generateCalendar(momentObj: Moment): void {\n    const dates = this.fillDates(momentObj);\n    this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));\n  }\n\n  private fillDates(momentObj: Moment): QdCalendarDay[] {\n    const lastOfMonth = moment(momentObj).endOf('month').day();\n    const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');\n    const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');\n    const startCalendar = firstDayOfGrid.date();\n\n    return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {\n      const newDate = moment(firstDayOfGrid).date(date);\n\n      return {\n        formatted: QdDateAdapter.formatToLocalizedDateString(newDate),\n        moment: newDate,\n        selected: this.isSelected(newDate),\n        today: this.isToday(newDate),\n        disabled: this.isDisabled(newDate)\n      };\n    });\n  }\n\n  private isToday(momentObj: Moment): boolean {\n    return this.todayDate.isSame(momentObj, 'day');\n  }\n\n  private setCurrentDate(): void {\n    const currentDate: Moment = (this.currentDate = QdDateAdapter.parseToMoment(this.selectedDate)?.isValid()\n      ? moment(this.selectedDate, 'L', 'de')\n      : this.todayDate);\n\n    this.currentDate = currentDate;\n    this.selectedDate = QdDateAdapter.formatToLocalizedDateString(currentDate);\n  }\n\n  private getYears(year: number): number[] {\n    const yearsBefore = YearsBefore;\n    const yearsAfter = YearsAfter;\n    const result: number[] = [];\n\n    for (let i = year - yearsBefore; i <= year + yearsAfter; i++) {\n      result.push(i);\n    }\n\n    return result;\n  }\n\n  private isDisabled(date: Moment): boolean {\n    if (!this.disabledDates) return false;\n    return this.disabledDates.some(disabledDate => {\n      let fromDate = moment(disabledDate.from);\n      let toDate = moment(disabledDate.to);\n      if (!disabledDate.from) fromDate = moment('1900-01-01T00:00:00.000Z');\n      if (!disabledDate.to) toDate = moment('2100-01-01T00:00:00.000Z');\n\n      return date.isAfter(fromDate, 'day') && date.isBefore(toDate, 'day');\n    });\n  }\n}\n","<div class=\"nav\">\n  <button (click)=\"prev()\">\n    <qd-icon icon=\"arrowLeft\"></qd-icon>\n  </button>\n\n  <ng-container>\n    <span\n      *ngIf=\"mode === QdCalendarMode.Default\"\n      class=\"current-month-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate.locale(language).format(\"MMMM\") }} {{ currentDate?.format(\"YYYY\") }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.YearPicker\"\n      class=\"current-years-list\"\n      (click)=\"changeMode(QdCalendarMode.MonthPicker)\"\n    >\n      {{ years[0] }} - {{ years[years.length - 1] }}\n    </span>\n    <span\n      *ngIf=\"mode === QdCalendarMode.MonthPicker\"\n      class=\"current-year\"\n      (click)=\"changeMode(QdCalendarMode.YearPicker)\"\n    >\n      {{ currentDate?.format(\"YYYY\") }}\n    </span>\n  </ng-container>\n\n  <button (click)=\"next()\">\n    <qd-icon icon=\"arrowRight\"></qd-icon>\n  </button>\n</div>\n\n<table *ngIf=\"mode === QdCalendarMode.Default\">\n  <thead></thead>\n  <tbody>\n    <tr>\n      <td class=\"weekday\" *ngFor=\"let name of weekdays\">{{ name }}</td>\n    </tr>\n    <tr *ngFor=\"let week of weeks\">\n      <td\n        class=\"day {{ day.moment.date() }}\"\n        *ngFor=\"let day of week\"\n        (click)=\"selectDate(day)\"\n        [ngClass]=\"{\n          today: day.today,\n          selected: day.selected,\n          hidden: !isSameYearMonth(day.moment),\n          disabled: day.disabled\n        }\"\n      >\n        {{ day.moment.date() }}\n      </td>\n    </tr>\n  </tbody>\n</table>\n\n<div class=\"calendar\" *ngIf=\"mode !== QdCalendarMode.Default\">\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.YearPicker\">\n    <div class=\"col {{ year }}\" *ngFor=\"let year of years\">\n      <div class=\"entry\" (click)=\"selectYear(year)\" [ngClass]=\"{ selected: isSameYear(year) }\">\n        {{ year }}\n      </div>\n    </div>\n  </div>\n\n  <div class=\"picker\" *ngIf=\"mode === QdCalendarMode.MonthPicker\">\n    <div class=\"col {{ month }}\" *ngFor=\"let month of months; let i = index\">\n      <div class=\"entry\" (click)=\"selectMonth(i)\" [ngClass]=\"{ selected: isSameMonth(i), month }\">\n        {{ month }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -10639,11 +10639,8 @@ class QdCalendarComponent {
|
|
|
10639
10639
|
this.weeks = Array.from({ length: Math.ceil(dates.length / 7) }, () => dates.splice(0, 7));
|
|
10640
10640
|
}
|
|
10641
10641
|
fillDates(momentObj) {
|
|
10642
|
-
const firstOfMonth = moment(momentObj).startOf('month').day();
|
|
10643
10642
|
const lastOfMonth = moment(momentObj).endOf('month').day();
|
|
10644
|
-
const firstDayOfGrid = moment(momentObj)
|
|
10645
|
-
.startOf('month')
|
|
10646
|
-
.subtract(firstOfMonth === 0 ? 6 : firstOfMonth - 1, 'days');
|
|
10643
|
+
const firstDayOfGrid = moment(momentObj).locale(this.language).startOf('month').startOf('week');
|
|
10647
10644
|
const lastDayOfGrid = moment(momentObj).endOf('month').subtract(lastOfMonth, 'days').add(7, 'days');
|
|
10648
10645
|
const startCalendar = firstDayOfGrid.date();
|
|
10649
10646
|
return range(startCalendar, startCalendar + lastDayOfGrid.diff(firstDayOfGrid, 'days')).map(date => {
|