@alauda/ui 6.5.10-beta.55 → 6.5.10-beta.56
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.
|
@@ -2,10 +2,10 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEn
|
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import dayjs from 'dayjs';
|
|
4
4
|
import { CommonFormControl } from '../../../form/common-form';
|
|
5
|
+
import { HOUR_ITEMS, MINUTE_ITEMS, SECOND_ITEMS } from '../../../time-picker';
|
|
5
6
|
import { DateNavRange } from '../../date-picker.type';
|
|
6
7
|
import { DatePickerType } from '../constant';
|
|
7
8
|
import { getNavRangeByType, getTimePickerModel, getTypeByNavRange, nextNavRangeType, updateDate, updateDateByTimeModel, } from '../util';
|
|
8
|
-
import { HOUR_ITEMS, MINUTE_ITEMS, SECOND_ITEMS } from 'src/time-picker';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "@angular/common";
|
|
11
11
|
import * as i2 from "../../../button/button.component";
|
|
@@ -172,4 +172,4 @@ function combineDisabledTimeFn(...disabledFnList) {
|
|
|
172
172
|
seconds: (hour, minute) => Array.from(new Set(disabledFnList.flatMap(fn => fn(date)?.seconds?.(hour, minute) || []))),
|
|
173
173
|
});
|
|
174
174
|
}
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/date-picker-panel/component.ts","../../../../../src/date-picker/calendar/date-picker-panel/template.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,iBAAiB,EACjB,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,KAA4B,MAAM,OAAO,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,EAAE,YAAY,EAAkB,MAAM,wBAAwB,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,UAAU,EACV,qBAAqB,GACtB,MAAM,SAAS,CAAC;AAEjB,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;;AAgBzE,MAAM,OAAO,wBAAyB,SAAQ,iBAAwB;IAEpE,SAAS,GAAG,IAAI,CAAC;IAGjB,SAAS,CAAS;IAElB,IACI,IAAI,CAAC,IAAoB;QAC3B,IAAI,CAAC,QAAQ,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAEO,KAAK,CAAiB;IAG9B,QAAQ,GAAG,KAAK,CAAC;IAGjB,YAAY,GAAiD,GAAG,EAAE,CAAC,KAAK,CAAC;IAGzE,YAAY,GAAmB,GAAG,EAAE,CAAC,IAAI,CAAC;IAG1C,YAAY,GAAG,CAAC,CAAC;IAGjB,UAAU,GAAG,IAAI,CAAC;IAGlB,cAAc,CAAuB;IAGrC,WAAW,CAAuB;IAGlC,OAAO,CAAQ;IAGf,OAAO,CAAQ;IAGf,OAAO,GAAG,IAAI,YAAY,EAAS,CAAC;IAGpC,KAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;IAEzB,kBAAkB,CAAQ;IAC1B,oBAAoB,CAA6B;IAEzD,iBAAiB,CACf,YAAmB,EACnB,IAAsC;QAEtC,IAAI,YAAY,KAAK,IAAI,CAAC,kBAAkB,EAAE;YAC5C,IAAI,CAAC,oBAAoB,GAAG,qBAAqB,CAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,EAC/B,IAAI,CAAC,YAAY,CAClB,CAAC,YAAY,CAAC,CAAC;YAChB,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC;SACxC;QACD,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;IAED,QAAQ,CAAe;IAEvB,IAAI,cAAc;QAChB,OAAO,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,MAAM,CAAQ;IAEd,YAAY,CAAQ;IAEpB,YAAY,CAAkB;IAE9B,YAAY,GAAG,YAAY,CAAC;IAC5B,cAAc,GAAG,cAAc,CAAC;IAEvB,UAAU,CAAC,GAAU;QAC5B,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;QACtB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;QAC7B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,KAAY;QAC3B,IAAI,CAAC,YAAY,GAAG,UAAU,CAC5B,IAAI,CAAC,YAAY,IAAI,KAAK,EAAE,EAC5B,KAAK,EACL,IAAI,CAAC,cAAc,CACpB,CAAC;QACF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,qBAAqB,CACvC,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,cAAc,EAAE;YACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtD;QACD,MAAM,YAAY,GAAG,gBAAgB,CACnC,IAAI,CAAC,QAAQ,EACb,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAC7B,CAAC;QACF,IAAI,IAAI,CAAC,QAAQ,KAAK,YAAY,EAAE;YAClC,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC;SAC9B;IACH,CAAC;IAED,YAAY,CAAC,KAAkB,EAAE,iBAAiB,GAAG,IAAI;QACvD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzD,iBAAiB,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,cAAc,CAAC,IAAqB;QAClC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,OAAO;SACR;QACD,IAAI,CAAC,YAAY,GAAG,qBAAqB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACnE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,UAAU;QACR,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAEO,eAAe,CAAC,YAAwB;QAC9C,MAAM,aAAa,GAAG,CACpB,IAAW,EACX,UAA6C,EAC7C,EAAE,CAAC,CAAC;YACJ,KAAK,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YACrE,OAAO,EAAE,CAAC,IAAa,EAAE,EAAE,CACzB,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE;gBAClB,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC9D,CAAC,CAAC,EAAE;YACR,OAAO,EAAE,CAAC,IAAa,EAAE,MAAe,EAAE,EAAE,CAC1C,IAAI,KAAK,IAAI,CAAC,IAAI,EAAE,IAAI,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE;gBAC9C,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;gBAC9D,CAAC,CAAC,EAAE;SACT,CAAC,CAAC;QAEH,IAAI,YAAY,EAAE;YAChB,IACE,IAAI,CAAC,OAAO;gBACX,YAAsB,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EACrD;gBACA,OAAO,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACrD;YACD,IACE,IAAI,CAAC,OAAO;gBACX,YAAsB,EAAE,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EACrD;gBACA,OAAO,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACrD;SACF;QAED,OAAO;YACL,KAAK,EAAE,GAAG,EAAE,CAAC,EAAE;YACf,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;YACjB,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;SAC0C,CAAC;IAChE,CAAC;uGA7KU,wBAAwB;2FAAxB,wBAAwB,2ZARxB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC;gBACvD,KAAK,EAAE,IAAI;aACZ;SACF,iDCxCH,o6EA+EA;;2FDrCa,wBAAwB;kBAdpC,SAAS;+BACE,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yBAAyB,CAAC;4BACvD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAID,SAAS;sBADR,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIF,IAAI;sBADP,KAAK;gBAaN,QAAQ;sBADP,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,MAAM;gBAIP,KAAK;sBADJ,MAAM;;AA+HT,SAAS,qBAAqB,CAC5B,GAAG,cAAgC;IAEnC,OAAO,CAAC,IAAiB,EAAE,EAAE,CAAC,CAAC;QAC7B,KAAK,EAAE,GAAG,EAAE,CACV,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CACjE;QACH,OAAO,EAAE,CAAC,IAAa,EAAE,EAAE,CACzB,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CACvE;QACH,OAAO,EAAE,CAAC,IAAa,EAAE,MAAe,EAAE,EAAE,CAC1C,KAAK,CAAC,IAAI,CACR,IAAI,GAAG,CACL,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CACtE,CACF;KACJ,CAAC,CAAC;AACL,CAAC","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { CommonFormControl } from '../../../form/common-form';\nimport { TimePickerModel } from '../../../time-picker/time-picker.type';\nimport { DateNavRange, DisabledTimeFn } from '../../date-picker.type';\nimport { DatePickerType } from '../constant';\nimport {\n  getNavRangeByType,\n  getTimePickerModel,\n  getTypeByNavRange,\n  nextNavRangeType,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\nimport { HOUR_ITEMS, MINUTE_ITEMS, SECOND_ITEMS } from 'src/time-picker';\n\n@Component({\n  selector: 'aui-date-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerPanelComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DatePickerPanelComponent extends CommonFormControl<Dayjs> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  set type(type: DatePickerType) {\n    this.navRange = getNavRangeByType(type);\n    this._type = type;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  private _type: DatePickerType;\n\n  @Input()\n  showTime = false;\n\n  @Input()\n  disabledDate: (date: Dayjs, type: DateNavRange) => boolean = () => false;\n\n  @Input()\n  disabledTime: DisabledTimeFn = () => null;\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  footerTemplate: TemplateRef<unknown>;\n\n  @Input()\n  extraFooter: TemplateRef<unknown>;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  confirm = new EventEmitter<Dayjs>();\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  private _cacheSelectedDate: Dayjs;\n  private _cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n\n  getDisabledTimeFn(\n    selectedDate: Dayjs,\n    type: keyof ReturnType<DisabledTimeFn>,\n  ) {\n    if (selectedDate !== this._cacheSelectedDate) {\n      this._cacheDisabledTimeFn = combineDisabledTimeFn(\n        this._disabledTimeFn.bind(this),\n        this.disabledTime,\n      )(selectedDate);\n      this._cacheSelectedDate = selectedDate;\n    }\n    return this._cacheDisabledTimeFn?.[type];\n  }\n\n  navRange: DateNavRange;\n\n  get currentNavType() {\n    return getTypeByNavRange(this.navRange);\n  }\n\n  anchor: Dayjs;\n\n  selectedDate: Dayjs;\n\n  selectedTime: TimePickerModel;\n\n  DateNavRange = DateNavRange;\n  DatePickerType = DatePickerType;\n\n  override writeValue(obj: Dayjs) {\n    super.writeValue(obj);\n    this.selectedDate = obj;\n    this.selectedTime = getTimePickerModel(obj);\n    this.anchor = obj || dayjs();\n    this.cdr.markForCheck();\n  }\n\n  panelValueChange(value: Dayjs) {\n    this.selectedDate = updateDate(\n      this.selectedDate || dayjs(),\n      value,\n      this.currentNavType,\n    );\n    this.anchor = this.selectedDate;\n    this.selectedDate = updateDateByTimeModel(\n      this.selectedDate,\n      this.selectedTime,\n    );\n    if (this.type === this.currentNavType) {\n      this.confirmValue(this.selectedDate, !this.showTime);\n    }\n    const nextNavRange = nextNavRangeType(\n      this.navRange,\n      getNavRangeByType(this.type),\n    );\n    if (this.navRange !== nextNavRange) {\n      this.navRange = nextNavRange;\n    }\n  }\n\n  confirmValue(value?: ConfigType, closeAfterConfirm = true) {\n    this.emitValue(value ? dayjs(value) : this.selectedDate);\n    closeAfterConfirm && this.confirm.next(null);\n  }\n\n  timeDateChange(time: TimePickerModel) {\n    if (!this.selectedDate) {\n      return;\n    }\n    this.selectedDate = updateDateByTimeModel(this.selectedDate, time);\n    this.emitValue(this.selectedDate);\n  }\n\n  setToday() {\n    this.confirmValue(dayjs(), true);\n  }\n\n  clearValue() {\n    this.selectedTime = null;\n    this.clear.next();\n  }\n\n  private _disabledTimeFn(selectedDate: ConfigType) {\n    const getTimeFilter = (\n      date: Dayjs,\n      comparator: (a: number, b: number) => boolean,\n    ) => ({\n      hours: () => HOUR_ITEMS.filter(item => comparator(item, date.hour())),\n      minutes: (hour?: number) =>\n        hour === date.hour()\n          ? MINUTE_ITEMS.filter(item => comparator(item, date.minute()))\n          : [],\n      seconds: (hour?: number, minute?: number) =>\n        hour === date.hour() && minute === date.minute()\n          ? SECOND_ITEMS.filter(item => comparator(item, date.second()))\n          : [],\n    });\n\n    if (selectedDate) {\n      if (\n        this.minDate &&\n        (selectedDate as Dayjs)?.isSame(this.minDate, 'date')\n      ) {\n        return getTimeFilter(this.minDate, (a, b) => a < b);\n      }\n      if (\n        this.maxDate &&\n        (selectedDate as Dayjs)?.isSame(this.maxDate, 'date')\n      ) {\n        return getTimeFilter(this.maxDate, (a, b) => a > b);\n      }\n    }\n\n    return {\n      hours: () => [],\n      minutes: () => [],\n      seconds: () => [],\n    } as Record<keyof ReturnType<DisabledTimeFn>, () => number[]>;\n  }\n}\n\nfunction combineDisabledTimeFn(\n  ...disabledFnList: DisabledTimeFn[]\n): DisabledTimeFn {\n  return (date?: ConfigType) => ({\n    hours: () =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.hours?.() || [])),\n      ),\n    minutes: (hour?: number) =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.minutes?.(hour) || [])),\n      ),\n    seconds: (hour?: number, minute?: number) =>\n      Array.from(\n        new Set(\n          disabledFnList.flatMap(fn => fn(date)?.seconds?.(hour, minute) || []),\n        ),\n      ),\n  });\n}\n","<div class=\"aui-date-picker-panel__wrapper\">\n  <aui-calendar-header\n    [dateNavRange]=\"navRange\"\n    [anchor]=\"anchor\"\n    [minAvail]=\"minDate\"\n    [maxAvail]=\"maxDate\"\n    [style.margin-inline.px]=\"4\"\n    (navRangeChange)=\"navRange = $event\"\n    (anchorChange)=\"anchor = $event\"\n  ></aui-calendar-header>\n\n  <aui-picker-panel\n    [style.margin]=\"'16px 0'\"\n    [anchor]=\"anchor\"\n    [navRange]=\"navRange\"\n    [disabledDate]=\"disabledDate\"\n    [weekStartDay]=\"weekStartDay\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [type]=\"type\"\n    [matchDates]=\"[selectedDate]\"\n    (select)=\"panelValueChange($event)\"\n  ></aui-picker-panel>\n\n  <ng-container\n    *ngIf=\"extraFooter\"\n    [ngTemplateOutlet]=\"extraFooter\"\n    [ngTemplateOutletContext]=\"{ context: this }\"\n  ></ng-container>\n\n  <ng-container *ngIf=\"showFooter\">\n    <aui-calendar-footer\n      (clear)=\"clear.next()\"\n      (confirm)=\"confirmValue()\"\n      [clearable]=\"clearable\"\n      [clearText]=\"clearText\"\n      *ngIf=\"showTime; else today\"\n    >\n      <ng-container\n        *ngIf=\"footerTemplate; else default\"\n        [ngTemplateOutlet]=\"footerTemplate\"\n        [ngTemplateOutletContext]=\"{ context: this }\"\n      ></ng-container>\n\n      <ng-template #default>\n        <aui-time-picker\n          *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n          [showIcon]=\"false\"\n          size=\"small\"\n          [(ngModel)]=\"selectedTime\"\n          [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n          [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n          [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n          tooltipPosition=\"top start\"\n          (ngModelChange)=\"timeDateChange($event)\"\n          [placeholder]=\"'select_time' | auiI18n\"\n        ></aui-time-picker>\n      </ng-template>\n    </aui-calendar-footer>\n\n    <ng-template #today>\n      <aui-calendar-footer\n        *ngIf=\"type === DatePickerType.Day\"\n        (clear)=\"clearValue()\"\n        [clearable]=\"false\"\n        [customAction]=\"todayBtn\"\n      >\n      </aui-calendar-footer>\n      <ng-template #todayBtn>\n        <button\n          aui-button=\"inline\"\n          (click)=\"setToday()\"\n        >\n          {{ 'today' | auiI18n }}\n        </button>\n      </ng-template>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/date-picker-panel/component.ts","../../../../../src/date-picker/calendar/date-picker-panel/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport dayjs, { ConfigType, Dayjs } from 'dayjs';\n\nimport { CommonFormControl } from '../../../form/common-form';\nimport { HOUR_ITEMS, MINUTE_ITEMS, SECOND_ITEMS } from '../../../time-picker';\nimport { TimePickerModel } from '../../../time-picker/time-picker.type';\nimport { DateNavRange, DisabledTimeFn } from '../../date-picker.type';\nimport { DatePickerType } from '../constant';\nimport {\n  getNavRangeByType,\n  getTimePickerModel,\n  getTypeByNavRange,\n  nextNavRangeType,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\n@Component({\n  selector: 'aui-date-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerPanelComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DatePickerPanelComponent extends CommonFormControl<Dayjs> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  set type(type: DatePickerType) {\n    this.navRange = getNavRangeByType(type);\n    this._type = type;\n  }\n\n  get type() {\n    return this._type;\n  }\n\n  private _type: DatePickerType;\n\n  @Input()\n  showTime = false;\n\n  @Input()\n  disabledDate: (date: Dayjs, type: DateNavRange) => boolean = () => false;\n\n  @Input()\n  disabledTime: DisabledTimeFn = () => null;\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  footerTemplate: TemplateRef<unknown>;\n\n  @Input()\n  extraFooter: TemplateRef<unknown>;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  confirm = new EventEmitter<Dayjs>();\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  private _cacheSelectedDate: Dayjs;\n  private _cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n\n  getDisabledTimeFn(\n    selectedDate: Dayjs,\n    type: keyof ReturnType<DisabledTimeFn>,\n  ) {\n    if (selectedDate !== this._cacheSelectedDate) {\n      this._cacheDisabledTimeFn = combineDisabledTimeFn(\n        this._disabledTimeFn.bind(this),\n        this.disabledTime,\n      )(selectedDate);\n      this._cacheSelectedDate = selectedDate;\n    }\n    return this._cacheDisabledTimeFn?.[type];\n  }\n\n  navRange: DateNavRange;\n\n  get currentNavType() {\n    return getTypeByNavRange(this.navRange);\n  }\n\n  anchor: Dayjs;\n\n  selectedDate: Dayjs;\n\n  selectedTime: TimePickerModel;\n\n  DateNavRange = DateNavRange;\n  DatePickerType = DatePickerType;\n\n  override writeValue(obj: Dayjs) {\n    super.writeValue(obj);\n    this.selectedDate = obj;\n    this.selectedTime = getTimePickerModel(obj);\n    this.anchor = obj || dayjs();\n    this.cdr.markForCheck();\n  }\n\n  panelValueChange(value: Dayjs) {\n    this.selectedDate = updateDate(\n      this.selectedDate || dayjs(),\n      value,\n      this.currentNavType,\n    );\n    this.anchor = this.selectedDate;\n    this.selectedDate = updateDateByTimeModel(\n      this.selectedDate,\n      this.selectedTime,\n    );\n    if (this.type === this.currentNavType) {\n      this.confirmValue(this.selectedDate, !this.showTime);\n    }\n    const nextNavRange = nextNavRangeType(\n      this.navRange,\n      getNavRangeByType(this.type),\n    );\n    if (this.navRange !== nextNavRange) {\n      this.navRange = nextNavRange;\n    }\n  }\n\n  confirmValue(value?: ConfigType, closeAfterConfirm = true) {\n    this.emitValue(value ? dayjs(value) : this.selectedDate);\n    closeAfterConfirm && this.confirm.next(null);\n  }\n\n  timeDateChange(time: TimePickerModel) {\n    if (!this.selectedDate) {\n      return;\n    }\n    this.selectedDate = updateDateByTimeModel(this.selectedDate, time);\n    this.emitValue(this.selectedDate);\n  }\n\n  setToday() {\n    this.confirmValue(dayjs(), true);\n  }\n\n  clearValue() {\n    this.selectedTime = null;\n    this.clear.next();\n  }\n\n  private _disabledTimeFn(selectedDate: ConfigType) {\n    const getTimeFilter = (\n      date: Dayjs,\n      comparator: (a: number, b: number) => boolean,\n    ) => ({\n      hours: () => HOUR_ITEMS.filter(item => comparator(item, date.hour())),\n      minutes: (hour?: number) =>\n        hour === date.hour()\n          ? MINUTE_ITEMS.filter(item => comparator(item, date.minute()))\n          : [],\n      seconds: (hour?: number, minute?: number) =>\n        hour === date.hour() && minute === date.minute()\n          ? SECOND_ITEMS.filter(item => comparator(item, date.second()))\n          : [],\n    });\n\n    if (selectedDate) {\n      if (\n        this.minDate &&\n        (selectedDate as Dayjs)?.isSame(this.minDate, 'date')\n      ) {\n        return getTimeFilter(this.minDate, (a, b) => a < b);\n      }\n      if (\n        this.maxDate &&\n        (selectedDate as Dayjs)?.isSame(this.maxDate, 'date')\n      ) {\n        return getTimeFilter(this.maxDate, (a, b) => a > b);\n      }\n    }\n\n    return {\n      hours: () => [],\n      minutes: () => [],\n      seconds: () => [],\n    } as Record<keyof ReturnType<DisabledTimeFn>, () => number[]>;\n  }\n}\n\nfunction combineDisabledTimeFn(\n  ...disabledFnList: DisabledTimeFn[]\n): DisabledTimeFn {\n  return (date?: ConfigType) => ({\n    hours: () =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.hours?.() || [])),\n      ),\n    minutes: (hour?: number) =>\n      Array.from(\n        new Set(disabledFnList.flatMap(fn => fn(date)?.minutes?.(hour) || [])),\n      ),\n    seconds: (hour?: number, minute?: number) =>\n      Array.from(\n        new Set(\n          disabledFnList.flatMap(fn => fn(date)?.seconds?.(hour, minute) || []),\n        ),\n      ),\n  });\n}\n","<div class=\"aui-date-picker-panel__wrapper\">\n  <aui-calendar-header\n    [dateNavRange]=\"navRange\"\n    [anchor]=\"anchor\"\n    [minAvail]=\"minDate\"\n    [maxAvail]=\"maxDate\"\n    [style.margin-inline.px]=\"4\"\n    (navRangeChange)=\"navRange = $event\"\n    (anchorChange)=\"anchor = $event\"\n  ></aui-calendar-header>\n\n  <aui-picker-panel\n    [style.margin]=\"'16px 0'\"\n    [anchor]=\"anchor\"\n    [navRange]=\"navRange\"\n    [disabledDate]=\"disabledDate\"\n    [weekStartDay]=\"weekStartDay\"\n    [minDate]=\"minDate\"\n    [maxDate]=\"maxDate\"\n    [type]=\"type\"\n    [matchDates]=\"[selectedDate]\"\n    (select)=\"panelValueChange($event)\"\n  ></aui-picker-panel>\n\n  <ng-container\n    *ngIf=\"extraFooter\"\n    [ngTemplateOutlet]=\"extraFooter\"\n    [ngTemplateOutletContext]=\"{ context: this }\"\n  ></ng-container>\n\n  <ng-container *ngIf=\"showFooter\">\n    <aui-calendar-footer\n      (clear)=\"clear.next()\"\n      (confirm)=\"confirmValue()\"\n      [clearable]=\"clearable\"\n      [clearText]=\"clearText\"\n      *ngIf=\"showTime; else today\"\n    >\n      <ng-container\n        *ngIf=\"footerTemplate; else default\"\n        [ngTemplateOutlet]=\"footerTemplate\"\n        [ngTemplateOutletContext]=\"{ context: this }\"\n      ></ng-container>\n\n      <ng-template #default>\n        <aui-time-picker\n          *ngIf=\"currentNavType === DatePickerType.Day && showTime\"\n          [showIcon]=\"false\"\n          size=\"small\"\n          [(ngModel)]=\"selectedTime\"\n          [disableHours]=\"getDisabledTimeFn(selectedDate, 'hours')\"\n          [disableMinutes]=\"getDisabledTimeFn(selectedDate, 'minutes')\"\n          [disableSeconds]=\"getDisabledTimeFn(selectedDate, 'seconds')\"\n          tooltipPosition=\"top start\"\n          (ngModelChange)=\"timeDateChange($event)\"\n          [placeholder]=\"'select_time' | auiI18n\"\n        ></aui-time-picker>\n      </ng-template>\n    </aui-calendar-footer>\n\n    <ng-template #today>\n      <aui-calendar-footer\n        *ngIf=\"type === DatePickerType.Day\"\n        (clear)=\"clearValue()\"\n        [clearable]=\"false\"\n        [customAction]=\"todayBtn\"\n      >\n      </aui-calendar-footer>\n      <ng-template #todayBtn>\n        <button\n          aui-button=\"inline\"\n          (click)=\"setToday()\"\n        >\n          {{ 'today' | auiI18n }}\n        </button>\n      </ng-template>\n    </ng-template>\n  </ng-container>\n</div>\n"]}
|