@alauda/ui 7.4.0 → 7.4.1-beta.0
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.
|
@@ -133,7 +133,8 @@ export class DateRangePickerPanelComponent extends CommonFormControl {
|
|
|
133
133
|
}
|
|
134
134
|
}
|
|
135
135
|
confirmValue(value, closeThen = true) {
|
|
136
|
-
|
|
136
|
+
const sortValue = value.sort((startDate, endDate) => startDate.isAfter(endDate) ? 1 : -1);
|
|
137
|
+
this.emitValue(sortValue);
|
|
137
138
|
closeThen && this.confirm.next();
|
|
138
139
|
}
|
|
139
140
|
timeChange(time) {
|
|
@@ -217,4 +218,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
217
218
|
}], confirm: [{
|
|
218
219
|
type: Output
|
|
219
220
|
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/range-picker-panel/component.ts","../../../../../src/date-picker/calendar/range-picker-panel/template.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf, NgTemplateOutlet, DatePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport dayjs, { Dayjs } from 'dayjs';\n\nimport { CommonFormControl } from '../../../form/common-form';\nimport { I18nPipe } from '../../../i18n/i18n.pipe';\nimport { buildBem } from '../../../internal/utils';\nimport { TimePickerComponent } from '../../../time-picker/component';\nimport { TimePickerModel } from '../../../time-picker/time-picker.type';\nimport { DateNavRange, DisabledTimeFn, Side } from '../../date-picker.type';\nimport { DatePickerType, MONTH, YEAR } from '../constant';\nimport { CalendarFooterComponent } from '../footer/component';\nimport { CalendarHeaderComponent } from '../header/component';\nimport { PickerPanelComponent } from '../panel/picker-panel';\nimport {\n  composeDisabledDateFn,\n  getTimePickerModel,\n  getTypeByNavRange,\n  maxDate,\n  minDate,\n  nextNavRangeType,\n  sortDates,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\nconst bem = buildBem('aui-date-range-picker-panel');\n\n@Component({\n  selector: 'aui-date-range-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateRangePickerPanelComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    CalendarHeaderComponent,\n    PickerPanelComponent,\n    NgIf,\n    CalendarFooterComponent,\n    NgTemplateOutlet,\n    TimePickerComponent,\n    FormsModule,\n    DatePipe,\n    I18nPipe,\n  ],\n})\nexport class DateRangePickerPanelComponent extends CommonFormControl<Dayjs[]> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  showTime = true;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  disabledDate: (\n    date: Dayjs,\n    navRange: DateNavRange,\n    startDate: Dayjs,\n  ) => boolean = () => false;\n\n  @Input()\n  disabledTime: { left: DisabledTimeFn; right: DisabledTimeFn } = {\n    left: () => null,\n    right: () => null,\n  };\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  @Output()\n  confirm = new EventEmitter<void>();\n\n  bem = bem;\n  Side = Side;\n  DatePickerType = DatePickerType;\n  leftDateRange = DateNavRange.Month;\n  rightDateRange = DateNavRange.Month;\n\n  FOOTER_DATE_FORMAT = 'YYYY-MM-dd';\n\n  leftAnchor = dayjs();\n  rightAnchor = dayjs().add(1, MONTH);\n\n  get maxHeaderAvail() {\n    return minDate(this.rightAnchor, this.maxDate);\n  }\n\n  get minHeaderAvail() {\n    return maxDate(this.minDate, this.leftAnchor);\n  }\n\n  // 用于存放 range data 序列，数量为 2 时清除\n  rangeValue: Dayjs[] = [];\n\n  // 用于组装匹配日期序列\n  matchValues: Dayjs[];\n\n  startTime: TimePickerModel;\n  endTime: TimePickerModel;\n\n  override writeValue(obj: Dayjs[]) {\n    super.writeValue(obj);\n    this.rangeValue = obj || [];\n    this.matchValues = [...this.rangeValue];\n    this.startTime = getTimePickerModel(obj?.[0]);\n    this.endTime = getTimePickerModel(obj?.[1]);\n    if (obj?.length === 2) {\n      this.reorder(sortDates(obj));\n    }\n    this.cdr.markForCheck();\n  }\n\n  calendarRangeChange(type: DateNavRange, side: Side) {\n    if (side === Side.Left) {\n      this.leftDateRange = type;\n    } else {\n      this.rightDateRange = type;\n    }\n  }\n\n  // range 组件范围受控\n  getDateDisabledFn(side: Side, constrainValue: Dayjs) {\n    return composeDisabledDateFn(\n      (date: Dayjs, navRange: DateNavRange) => {\n        if (navRange === DateNavRange.Month) {\n          return false;\n        }\n        if (navRange === DateNavRange.Decade) {\n          return date[side === Side.Left ? 'isAfter' : 'isBefore'](\n            constrainValue,\n            YEAR,\n          );\n        }\n        return !date[side === Side.Left ? 'isBefore' : 'isAfter'](\n          constrainValue,\n          MONTH,\n        );\n      },\n      (...arg) => this.disabledDate(...arg, this.rangeValue[0]),\n    );\n  }\n\n  private getDisabledTimeCachedFn(side: Side) {\n    let cacheSelectedDate: Dayjs;\n    let cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n    return (value: Dayjs, key: keyof ReturnType<DisabledTimeFn>) => {\n      if (value !== cacheSelectedDate) {\n        cacheDisabledTimeFn = (this.disabledTime?.[side] || (() => null))(\n          value,\n        );\n        cacheSelectedDate = value;\n      }\n      return cacheDisabledTimeFn?.[key];\n    };\n  }\n\n  leftDisabledTimeFn = this.getDisabledTimeCachedFn(Side.Left);\n  rightDisabledTimeFn = this.getDisabledTimeCachedFn(Side.Right);\n\n  selectPickerPanel(value: Dayjs, side: Side) {\n    const navRange =\n      side === Side.Left ? this.leftDateRange : this.rightDateRange;\n    const type = getTypeByNavRange(navRange);\n    const dateValue = updateDate(\n      side === Side.Left ? this.leftAnchor : this.rightAnchor,\n      value,\n      type,\n    );\n    const nextRange = nextNavRangeType(navRange, DateNavRange.Month);\n\n    if (side === Side.Left) {\n      this.leftAnchor = dateValue;\n      this.leftDateRange = nextRange;\n    } else {\n      this.rightAnchor = dateValue;\n      this.rightDateRange = nextRange;\n    }\n\n    if (navRange !== DateNavRange.Month) {\n      return;\n    }\n\n    if (this.leftAnchor.isSame(this.rightAnchor, MONTH)) {\n      this.rightAnchor = this.rightAnchor.add(1, MONTH);\n    }\n\n    this.rangeValue =\n      this.rangeValue.length === 2\n        ? [dateValue]\n        : sortDates([...this.rangeValue, dateValue]);\n    this.matchValues = [...this.rangeValue];\n    this.syncTime();\n    if (this.rangeValue.length === 2) {\n      this.reorder(this.rangeValue);\n      this.confirmValue(this.rangeValue, !this.showTime);\n    }\n  }\n\n  reorder(sortedDate: Dayjs[]) {\n    if (!sortedDate[0].isSame(sortedDate[1], MONTH)) {\n      this.leftAnchor = updateDate(\n        this.leftAnchor,\n        sortedDate[0],\n        DatePickerType.Day,\n      );\n      this.rightAnchor = updateDate(\n        this.leftAnchor,\n        sortedDate[1],\n        DatePickerType.Day,\n      );\n    }\n  }\n\n  hoverItem(date: Dayjs) {\n    if (this.rangeValue.length === 1) {\n      this.matchValues[1] = date;\n    }\n  }\n\n  confirmValue(value: Dayjs[], closeThen = true) {\n    this.emitValue(value);\n    closeThen && this.confirm.next();\n  }\n\n  timeChange(time: TimePickerModel) {\n    if (!time) {\n      return;\n    }\n    this.syncTime();\n    if (!this.rangeValue?.length) {\n      const date = updateDateByTimeModel(dayjs(), time);\n      this.rangeValue = [date, date];\n      this.matchValues = [...this.rangeValue];\n      this.startTime = this.endTime = time;\n    }\n    this.emitValue(this.rangeValue);\n  }\n\n  syncTime() {\n    if (this.showTime && !!this.rangeValue?.length) {\n      const startDate = this.rangeValue[0]\n        ? updateDateByTimeModel(this.rangeValue[0], this.startTime)\n        : null;\n      const endDate = this.rangeValue[1]\n        ? updateDateByTimeModel(this.rangeValue[1], this.endTime)\n        : null;\n      if (!this.startTime && startDate) {\n        this.startTime = getTimePickerModel(this.rangeValue[0]);\n      }\n      if (!this.endTime && endDate) {\n        this.endTime = getTimePickerModel(this.rangeValue[1]);\n      }\n      this.rangeValue = [startDate, endDate].filter(i => !!i);\n    }\n  }\n}\n","<div [class]=\"bem.element('container')\">\n  <div [class]=\"bem.element('header')\">\n    <aui-calendar-header\n      [dateNavRange]=\"leftDateRange\"\n      [anchor]=\"leftAnchor\"\n      (navRangeChange)=\"calendarRangeChange($event, Side.Left)\"\n      (anchorChange)=\"leftAnchor = $event\"\n      [maxAvail]=\"maxHeaderAvail\"\n      [minAvail]=\"minDate\"\n    ></aui-calendar-header>\n    <aui-calendar-header\n      [dateNavRange]=\"rightDateRange\"\n      [anchor]=\"rightAnchor\"\n      (navRangeChange)=\"calendarRangeChange($event, Side.Right)\"\n      (anchorChange)=\"rightAnchor = $event\"\n      [minAvail]=\"minHeaderAvail\"\n      [maxAvail]=\"maxDate\"\n    ></aui-calendar-header>\n  </div>\n  <div [class]=\"bem.element('body')\">\n    <aui-picker-panel\n      class=\"panel__wrapper\"\n      [navRange]=\"leftDateRange\"\n      [type]=\"DatePickerType.Day\"\n      [anchor]=\"leftAnchor\"\n      [matchDates]=\"matchValues\"\n      [minDate]=\"minDate\"\n      [maxDate]=\"maxDate\"\n      [disabledDate]=\"getDateDisabledFn(Side.Left, rightAnchor)\"\n      [weekStartDay]=\"weekStartDay\"\n      (hovered)=\"hoverItem($event)\"\n      (select)=\"selectPickerPanel($event, Side.Left)\"\n    ></aui-picker-panel>\n    <aui-picker-panel\n      class=\"panel__wrapper\"\n      [navRange]=\"rightDateRange\"\n      [type]=\"DatePickerType.Day\"\n      [anchor]=\"rightAnchor\"\n      [weekStartDay]=\"weekStartDay\"\n      [matchDates]=\"matchValues\"\n      [minDate]=\"minDate\"\n      [maxDate]=\"maxDate\"\n      [disabledDate]=\"getDateDisabledFn(Side.Right, leftAnchor)\"\n      (hovered)=\"hoverItem($event)\"\n      (select)=\"selectPickerPanel($event, Side.Right)\"\n    ></aui-picker-panel>\n  </div>\n\n  <aui-calendar-footer\n    [class]=\"bem.element('footer')\"\n    [clearable]=\"clearable\"\n    [clearText]=\"clearText\"\n    (clear)=\"clear.next()\"\n    (confirm)=\"confirmValue(rangeValue)\"\n    *ngIf=\"showFooter && showTime\"\n  >\n    <div\n      [class]=\"bem.element('footer-content')\"\n      *ngIf=\"showTime\"\n    >\n      <ng-container\n        [ngTemplateOutlet]=\"datePlaceholder\"\n        [ngTemplateOutletContext]=\"{\n          placeholder: 'start_date' | auiI18n,\n          value: rangeValue[0]\n        }\"\n      ></ng-container>\n      <aui-time-picker\n        [showIcon]=\"false\"\n        [(ngModel)]=\"startTime\"\n        size=\"small\"\n        (ngModelChange)=\"timeChange($event)\"\n        [disableHours]=\"leftDisabledTimeFn(rangeValue[0], 'hours')\"\n        [disableMinutes]=\"leftDisabledTimeFn(rangeValue[0], 'minutes')\"\n        [disableSeconds]=\"leftDisabledTimeFn(rangeValue[0], 'seconds')\"\n        [placeholder]=\"'select_time' | auiI18n\"\n        tooltipPosition=\"top start\"\n      ></aui-time-picker>\n\n      <span class=\"placeholder separator\">{{ 'to' | auiI18n }}</span>\n      <ng-container\n        [ngTemplateOutlet]=\"datePlaceholder\"\n        [ngTemplateOutletContext]=\"{\n          placeholder: 'end_date' | auiI18n,\n          value: rangeValue[1]\n        }\"\n      ></ng-container>\n      <aui-time-picker\n        [showIcon]=\"false\"\n        size=\"small\"\n        [(ngModel)]=\"endTime\"\n        [disableHours]=\"rightDisabledTimeFn(rangeValue[1], 'hours')\"\n        [disableMinutes]=\"rightDisabledTimeFn(rangeValue[1], 'minutes')\"\n        [disableSeconds]=\"rightDisabledTimeFn(rangeValue[1], 'seconds')\"\n        (ngModelChange)=\"timeChange($event)\"\n        [placeholder]=\"'select_time' | auiI18n\"\n        tooltipPosition=\"top start\"\n      ></aui-time-picker>\n    </div>\n  </aui-calendar-footer>\n</div>\n\n<ng-template\n  #datePlaceholder\n  let-placeholder=\"placeholder\"\n  let-value=\"value\"\n>\n  <span\n    *ngIf=\"!value\"\n    class=\"placeholder date-holder\"\n    >{{ placeholder }}</span\n  >\n  <span\n    *ngIf=\"value\"\n    class=\"date-value date-holder\"\n    >{{ value | date : FOOTER_DATE_FORMAT }}</span\n  >\n</ng-template>\n"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../src/date-picker/calendar/range-picker-panel/component.ts","../../../../../src/date-picker/calendar/range-picker-panel/template.html"],"names":[],"mappings":"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","sourcesContent":["import { NgIf, NgTemplateOutlet, DatePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';\nimport dayjs, { Dayjs } from 'dayjs';\n\nimport { CommonFormControl } from '../../../form/common-form';\nimport { I18nPipe } from '../../../i18n/i18n.pipe';\nimport { buildBem } from '../../../internal/utils';\nimport { TimePickerComponent } from '../../../time-picker/component';\nimport { TimePickerModel } from '../../../time-picker/time-picker.type';\nimport { DateNavRange, DisabledTimeFn, Side } from '../../date-picker.type';\nimport { DatePickerType, MONTH, YEAR } from '../constant';\nimport { CalendarFooterComponent } from '../footer/component';\nimport { CalendarHeaderComponent } from '../header/component';\nimport { PickerPanelComponent } from '../panel/picker-panel';\nimport {\n  composeDisabledDateFn,\n  getTimePickerModel,\n  getTypeByNavRange,\n  maxDate,\n  minDate,\n  nextNavRangeType,\n  sortDates,\n  updateDate,\n  updateDateByTimeModel,\n} from '../util';\n\nconst bem = buildBem('aui-date-range-picker-panel');\n\n@Component({\n  selector: 'aui-date-range-picker-panel',\n  templateUrl: './template.html',\n  styleUrls: ['./style.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateRangePickerPanelComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    CalendarHeaderComponent,\n    PickerPanelComponent,\n    NgIf,\n    CalendarFooterComponent,\n    NgTemplateOutlet,\n    TimePickerComponent,\n    FormsModule,\n    DatePipe,\n    I18nPipe,\n  ],\n})\nexport class DateRangePickerPanelComponent extends CommonFormControl<Dayjs[]> {\n  @Input()\n  clearable = true;\n\n  @Input()\n  clearText: string;\n\n  @Input()\n  showTime = true;\n\n  @Input()\n  showFooter = true;\n\n  @Input()\n  disabledDate: (\n    date: Dayjs,\n    navRange: DateNavRange,\n    startDate: Dayjs,\n  ) => boolean = () => false;\n\n  @Input()\n  disabledTime: { left: DisabledTimeFn; right: DisabledTimeFn } = {\n    left: () => null,\n    right: () => null,\n  };\n\n  @Input()\n  weekStartDay = 0;\n\n  @Input()\n  minDate: Dayjs;\n\n  @Input()\n  maxDate: Dayjs;\n\n  @Output()\n  clear = new EventEmitter<void>();\n\n  @Output()\n  confirm = new EventEmitter<void>();\n\n  bem = bem;\n  Side = Side;\n  DatePickerType = DatePickerType;\n  leftDateRange = DateNavRange.Month;\n  rightDateRange = DateNavRange.Month;\n\n  FOOTER_DATE_FORMAT = 'YYYY-MM-dd';\n\n  leftAnchor = dayjs();\n  rightAnchor = dayjs().add(1, MONTH);\n\n  get maxHeaderAvail() {\n    return minDate(this.rightAnchor, this.maxDate);\n  }\n\n  get minHeaderAvail() {\n    return maxDate(this.minDate, this.leftAnchor);\n  }\n\n  // 用于存放 range data 序列，数量为 2 时清除\n  rangeValue: Dayjs[] = [];\n\n  // 用于组装匹配日期序列\n  matchValues: Dayjs[];\n\n  startTime: TimePickerModel;\n  endTime: TimePickerModel;\n\n  override writeValue(obj: Dayjs[]) {\n    super.writeValue(obj);\n    this.rangeValue = obj || [];\n    this.matchValues = [...this.rangeValue];\n    this.startTime = getTimePickerModel(obj?.[0]);\n    this.endTime = getTimePickerModel(obj?.[1]);\n    if (obj?.length === 2) {\n      this.reorder(sortDates(obj));\n    }\n    this.cdr.markForCheck();\n  }\n\n  calendarRangeChange(type: DateNavRange, side: Side) {\n    if (side === Side.Left) {\n      this.leftDateRange = type;\n    } else {\n      this.rightDateRange = type;\n    }\n  }\n\n  // range 组件范围受控\n  getDateDisabledFn(side: Side, constrainValue: Dayjs) {\n    return composeDisabledDateFn(\n      (date: Dayjs, navRange: DateNavRange) => {\n        if (navRange === DateNavRange.Month) {\n          return false;\n        }\n        if (navRange === DateNavRange.Decade) {\n          return date[side === Side.Left ? 'isAfter' : 'isBefore'](\n            constrainValue,\n            YEAR,\n          );\n        }\n        return !date[side === Side.Left ? 'isBefore' : 'isAfter'](\n          constrainValue,\n          MONTH,\n        );\n      },\n      (...arg) => this.disabledDate(...arg, this.rangeValue[0]),\n    );\n  }\n\n  private getDisabledTimeCachedFn(side: Side) {\n    let cacheSelectedDate: Dayjs;\n    let cacheDisabledTimeFn: ReturnType<DisabledTimeFn>;\n    return (value: Dayjs, key: keyof ReturnType<DisabledTimeFn>) => {\n      if (value !== cacheSelectedDate) {\n        cacheDisabledTimeFn = (this.disabledTime?.[side] || (() => null))(\n          value,\n        );\n        cacheSelectedDate = value;\n      }\n      return cacheDisabledTimeFn?.[key];\n    };\n  }\n\n  leftDisabledTimeFn = this.getDisabledTimeCachedFn(Side.Left);\n  rightDisabledTimeFn = this.getDisabledTimeCachedFn(Side.Right);\n\n  selectPickerPanel(value: Dayjs, side: Side) {\n    const navRange =\n      side === Side.Left ? this.leftDateRange : this.rightDateRange;\n    const type = getTypeByNavRange(navRange);\n    const dateValue = updateDate(\n      side === Side.Left ? this.leftAnchor : this.rightAnchor,\n      value,\n      type,\n    );\n    const nextRange = nextNavRangeType(navRange, DateNavRange.Month);\n\n    if (side === Side.Left) {\n      this.leftAnchor = dateValue;\n      this.leftDateRange = nextRange;\n    } else {\n      this.rightAnchor = dateValue;\n      this.rightDateRange = nextRange;\n    }\n\n    if (navRange !== DateNavRange.Month) {\n      return;\n    }\n\n    if (this.leftAnchor.isSame(this.rightAnchor, MONTH)) {\n      this.rightAnchor = this.rightAnchor.add(1, MONTH);\n    }\n\n    this.rangeValue =\n      this.rangeValue.length === 2\n        ? [dateValue]\n        : sortDates([...this.rangeValue, dateValue]);\n    this.matchValues = [...this.rangeValue];\n    this.syncTime();\n    if (this.rangeValue.length === 2) {\n      this.reorder(this.rangeValue);\n      this.confirmValue(this.rangeValue, !this.showTime);\n    }\n  }\n\n  reorder(sortedDate: Dayjs[]) {\n    if (!sortedDate[0].isSame(sortedDate[1], MONTH)) {\n      this.leftAnchor = updateDate(\n        this.leftAnchor,\n        sortedDate[0],\n        DatePickerType.Day,\n      );\n      this.rightAnchor = updateDate(\n        this.leftAnchor,\n        sortedDate[1],\n        DatePickerType.Day,\n      );\n    }\n  }\n\n  hoverItem(date: Dayjs) {\n    if (this.rangeValue.length === 1) {\n      this.matchValues[1] = date;\n    }\n  }\n\n  confirmValue(value: Dayjs[], closeThen = true) {\n    const sortValue = value.sort((startDate, endDate) =>\n      startDate.isAfter(endDate) ? 1 : -1,\n    );\n    this.emitValue(sortValue);\n    closeThen && this.confirm.next();\n  }\n\n  timeChange(time: TimePickerModel) {\n    if (!time) {\n      return;\n    }\n    this.syncTime();\n    if (!this.rangeValue?.length) {\n      const date = updateDateByTimeModel(dayjs(), time);\n      this.rangeValue = [date, date];\n      this.matchValues = [...this.rangeValue];\n      this.startTime = this.endTime = time;\n    }\n    this.emitValue(this.rangeValue);\n  }\n\n  syncTime() {\n    if (this.showTime && !!this.rangeValue?.length) {\n      const startDate = this.rangeValue[0]\n        ? updateDateByTimeModel(this.rangeValue[0], this.startTime)\n        : null;\n      const endDate = this.rangeValue[1]\n        ? updateDateByTimeModel(this.rangeValue[1], this.endTime)\n        : null;\n      if (!this.startTime && startDate) {\n        this.startTime = getTimePickerModel(this.rangeValue[0]);\n      }\n      if (!this.endTime && endDate) {\n        this.endTime = getTimePickerModel(this.rangeValue[1]);\n      }\n      this.rangeValue = [startDate, endDate].filter(i => !!i);\n    }\n  }\n}\n","<div [class]=\"bem.element('container')\">\n  <div [class]=\"bem.element('header')\">\n    <aui-calendar-header\n      [dateNavRange]=\"leftDateRange\"\n      [anchor]=\"leftAnchor\"\n      (navRangeChange)=\"calendarRangeChange($event, Side.Left)\"\n      (anchorChange)=\"leftAnchor = $event\"\n      [maxAvail]=\"maxHeaderAvail\"\n      [minAvail]=\"minDate\"\n    ></aui-calendar-header>\n    <aui-calendar-header\n      [dateNavRange]=\"rightDateRange\"\n      [anchor]=\"rightAnchor\"\n      (navRangeChange)=\"calendarRangeChange($event, Side.Right)\"\n      (anchorChange)=\"rightAnchor = $event\"\n      [minAvail]=\"minHeaderAvail\"\n      [maxAvail]=\"maxDate\"\n    ></aui-calendar-header>\n  </div>\n  <div [class]=\"bem.element('body')\">\n    <aui-picker-panel\n      class=\"panel__wrapper\"\n      [navRange]=\"leftDateRange\"\n      [type]=\"DatePickerType.Day\"\n      [anchor]=\"leftAnchor\"\n      [matchDates]=\"matchValues\"\n      [minDate]=\"minDate\"\n      [maxDate]=\"maxDate\"\n      [disabledDate]=\"getDateDisabledFn(Side.Left, rightAnchor)\"\n      [weekStartDay]=\"weekStartDay\"\n      (hovered)=\"hoverItem($event)\"\n      (select)=\"selectPickerPanel($event, Side.Left)\"\n    ></aui-picker-panel>\n    <aui-picker-panel\n      class=\"panel__wrapper\"\n      [navRange]=\"rightDateRange\"\n      [type]=\"DatePickerType.Day\"\n      [anchor]=\"rightAnchor\"\n      [weekStartDay]=\"weekStartDay\"\n      [matchDates]=\"matchValues\"\n      [minDate]=\"minDate\"\n      [maxDate]=\"maxDate\"\n      [disabledDate]=\"getDateDisabledFn(Side.Right, leftAnchor)\"\n      (hovered)=\"hoverItem($event)\"\n      (select)=\"selectPickerPanel($event, Side.Right)\"\n    ></aui-picker-panel>\n  </div>\n\n  <aui-calendar-footer\n    [class]=\"bem.element('footer')\"\n    [clearable]=\"clearable\"\n    [clearText]=\"clearText\"\n    (clear)=\"clear.next()\"\n    (confirm)=\"confirmValue(rangeValue)\"\n    *ngIf=\"showFooter && showTime\"\n  >\n    <div\n      [class]=\"bem.element('footer-content')\"\n      *ngIf=\"showTime\"\n    >\n      <ng-container\n        [ngTemplateOutlet]=\"datePlaceholder\"\n        [ngTemplateOutletContext]=\"{\n          placeholder: 'start_date' | auiI18n,\n          value: rangeValue[0]\n        }\"\n      ></ng-container>\n      <aui-time-picker\n        [showIcon]=\"false\"\n        [(ngModel)]=\"startTime\"\n        size=\"small\"\n        (ngModelChange)=\"timeChange($event)\"\n        [disableHours]=\"leftDisabledTimeFn(rangeValue[0], 'hours')\"\n        [disableMinutes]=\"leftDisabledTimeFn(rangeValue[0], 'minutes')\"\n        [disableSeconds]=\"leftDisabledTimeFn(rangeValue[0], 'seconds')\"\n        [placeholder]=\"'select_time' | auiI18n\"\n        tooltipPosition=\"top start\"\n      ></aui-time-picker>\n\n      <span class=\"placeholder separator\">{{ 'to' | auiI18n }}</span>\n      <ng-container\n        [ngTemplateOutlet]=\"datePlaceholder\"\n        [ngTemplateOutletContext]=\"{\n          placeholder: 'end_date' | auiI18n,\n          value: rangeValue[1]\n        }\"\n      ></ng-container>\n      <aui-time-picker\n        [showIcon]=\"false\"\n        size=\"small\"\n        [(ngModel)]=\"endTime\"\n        [disableHours]=\"rightDisabledTimeFn(rangeValue[1], 'hours')\"\n        [disableMinutes]=\"rightDisabledTimeFn(rangeValue[1], 'minutes')\"\n        [disableSeconds]=\"rightDisabledTimeFn(rangeValue[1], 'seconds')\"\n        (ngModelChange)=\"timeChange($event)\"\n        [placeholder]=\"'select_time' | auiI18n\"\n        tooltipPosition=\"top start\"\n      ></aui-time-picker>\n    </div>\n  </aui-calendar-footer>\n</div>\n\n<ng-template\n  #datePlaceholder\n  let-placeholder=\"placeholder\"\n  let-value=\"value\"\n>\n  <span\n    *ngIf=\"!value\"\n    class=\"placeholder date-holder\"\n    >{{ placeholder }}</span\n  >\n  <span\n    *ngIf=\"value\"\n    class=\"date-value date-holder\"\n    >{{ value | date : FOOTER_DATE_FORMAT }}</span\n  >\n</ng-template>\n"]}
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -5736,7 +5736,8 @@ class DateRangePickerPanelComponent extends CommonFormControl {
|
|
|
5736
5736
|
}
|
|
5737
5737
|
}
|
|
5738
5738
|
confirmValue(value, closeThen = true) {
|
|
5739
|
-
|
|
5739
|
+
const sortValue = value.sort((startDate, endDate) => startDate.isAfter(endDate) ? 1 : -1);
|
|
5740
|
+
this.emitValue(sortValue);
|
|
5740
5741
|
closeThen && this.confirm.next();
|
|
5741
5742
|
}
|
|
5742
5743
|
timeChange(time) {
|