@ng-nest/ui 15.0.6 → 15.0.7

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.
Files changed (166) hide show
  1. package/core/functions/date.d.ts +1 -0
  2. package/date-picker/date-picker.property.d.ts +129 -3
  3. package/date-picker/date-range-portal.component.d.ts +9 -8
  4. package/date-picker/date-range.component.d.ts +12 -10
  5. package/date-picker/picker-date.component.d.ts +15 -6
  6. package/esm2020/core/functions/date.mjs +20 -29
  7. package/esm2020/date-picker/date-picker.property.mjs +23 -2
  8. package/esm2020/date-picker/date-range-portal.component.mjs +36 -33
  9. package/esm2020/date-picker/date-range.component.mjs +75 -53
  10. package/esm2020/date-picker/picker-date.component.mjs +133 -17
  11. package/esm2020/input/input.component.mjs +2 -2
  12. package/esm2020/loading/loading.component.mjs +13 -6
  13. package/esm2020/loading/loading.property.mjs +1 -1
  14. package/esm2020/switch/switch.component.mjs +13 -6
  15. package/esm2020/switch/switch.module.mjs +6 -4
  16. package/esm2020/switch/switch.property.mjs +33 -4
  17. package/esm2020/table/drag.directive.mjs +13 -5
  18. package/esm2020/table/table-head.component.mjs +20 -6
  19. package/esm2020/table/table.property.mjs +23 -2
  20. package/fesm2015/ng-nest-ui-anchor.mjs +1 -0
  21. package/fesm2015/ng-nest-ui-api.mjs +1 -0
  22. package/fesm2015/ng-nest-ui-auto-complete.mjs +1 -0
  23. package/fesm2015/ng-nest-ui-avatar.mjs +1 -0
  24. package/fesm2015/ng-nest-ui-back-top.mjs +1 -0
  25. package/fesm2015/ng-nest-ui-badge.mjs +1 -0
  26. package/fesm2015/ng-nest-ui-base-form.mjs +1 -0
  27. package/fesm2015/ng-nest-ui-border.mjs +1 -0
  28. package/fesm2015/ng-nest-ui-button.mjs +1 -0
  29. package/fesm2015/ng-nest-ui-calendar.mjs +1 -0
  30. package/fesm2015/ng-nest-ui-card.mjs +1 -0
  31. package/fesm2015/ng-nest-ui-carousel.mjs +1 -0
  32. package/fesm2015/ng-nest-ui-cascade.mjs +1 -0
  33. package/fesm2015/ng-nest-ui-checkbox.mjs +1 -0
  34. package/fesm2015/ng-nest-ui-collapse.mjs +1 -0
  35. package/fesm2015/ng-nest-ui-color-picker.mjs +1 -0
  36. package/fesm2015/ng-nest-ui-color.mjs +1 -0
  37. package/fesm2015/ng-nest-ui-comment.mjs +1 -0
  38. package/fesm2015/ng-nest-ui-container.mjs +1 -0
  39. package/fesm2015/ng-nest-ui-core.mjs +20 -29
  40. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  41. package/fesm2015/ng-nest-ui-date-picker.mjs +262 -99
  42. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  43. package/fesm2015/ng-nest-ui-dialog.mjs +1 -0
  44. package/fesm2015/ng-nest-ui-drawer.mjs +1 -0
  45. package/fesm2015/ng-nest-ui-dropdown.mjs +1 -0
  46. package/fesm2015/ng-nest-ui-find.mjs +1 -0
  47. package/fesm2015/ng-nest-ui-highlight.mjs +1 -0
  48. package/fesm2015/ng-nest-ui-icon.mjs +1 -0
  49. package/fesm2015/ng-nest-ui-image.mjs +1 -0
  50. package/fesm2015/ng-nest-ui-inner.mjs +1 -0
  51. package/fesm2015/ng-nest-ui-input-number.mjs +1 -0
  52. package/fesm2015/ng-nest-ui-input.mjs +1 -1
  53. package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
  54. package/fesm2015/ng-nest-ui-link.mjs +1 -0
  55. package/fesm2015/ng-nest-ui-list.mjs +1 -0
  56. package/fesm2015/ng-nest-ui-loading.mjs +12 -5
  57. package/fesm2015/ng-nest-ui-loading.mjs.map +1 -1
  58. package/fesm2015/ng-nest-ui-menu.mjs +1 -0
  59. package/fesm2015/ng-nest-ui-message-box.mjs +1 -0
  60. package/fesm2015/ng-nest-ui-message.mjs +1 -0
  61. package/fesm2015/ng-nest-ui-notification.mjs +1 -0
  62. package/fesm2015/ng-nest-ui-pagination.mjs +1 -0
  63. package/fesm2015/ng-nest-ui-popconfirm.mjs +1 -0
  64. package/fesm2015/ng-nest-ui-popover.mjs +1 -0
  65. package/fesm2015/ng-nest-ui-progress.mjs +1 -0
  66. package/fesm2015/ng-nest-ui-radio.mjs +1 -0
  67. package/fesm2015/ng-nest-ui-rate.mjs +1 -0
  68. package/fesm2015/ng-nest-ui-result.mjs +1 -0
  69. package/fesm2015/ng-nest-ui-select.mjs +1 -0
  70. package/fesm2015/ng-nest-ui-skeleton.mjs +1 -0
  71. package/fesm2015/ng-nest-ui-slider-select.mjs +1 -0
  72. package/fesm2015/ng-nest-ui-slider.mjs +1 -0
  73. package/fesm2015/ng-nest-ui-steps.mjs +1 -0
  74. package/fesm2015/ng-nest-ui-switch.mjs +48 -11
  75. package/fesm2015/ng-nest-ui-switch.mjs.map +1 -1
  76. package/fesm2015/ng-nest-ui-table.mjs +53 -10
  77. package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
  78. package/fesm2015/ng-nest-ui-tabs.mjs +1 -0
  79. package/fesm2015/ng-nest-ui-tag.mjs +1 -0
  80. package/fesm2015/ng-nest-ui-text-retract.mjs +1 -0
  81. package/fesm2015/ng-nest-ui-textarea.mjs +1 -0
  82. package/fesm2015/ng-nest-ui-timeline.mjs +1 -0
  83. package/fesm2015/ng-nest-ui-tooltip.mjs +1 -0
  84. package/fesm2015/ng-nest-ui-transfer.mjs +1 -0
  85. package/fesm2015/ng-nest-ui-tree-file.mjs +1 -0
  86. package/fesm2015/ng-nest-ui-tree-select.mjs +1 -0
  87. package/fesm2015/ng-nest-ui-tree.mjs +1 -0
  88. package/fesm2015/ng-nest-ui-upload.mjs +1 -0
  89. package/fesm2020/ng-nest-ui-anchor.mjs +1 -0
  90. package/fesm2020/ng-nest-ui-api.mjs +1 -0
  91. package/fesm2020/ng-nest-ui-auto-complete.mjs +1 -0
  92. package/fesm2020/ng-nest-ui-avatar.mjs +1 -0
  93. package/fesm2020/ng-nest-ui-back-top.mjs +1 -0
  94. package/fesm2020/ng-nest-ui-badge.mjs +1 -0
  95. package/fesm2020/ng-nest-ui-base-form.mjs +1 -0
  96. package/fesm2020/ng-nest-ui-border.mjs +1 -0
  97. package/fesm2020/ng-nest-ui-button.mjs +1 -0
  98. package/fesm2020/ng-nest-ui-calendar.mjs +1 -0
  99. package/fesm2020/ng-nest-ui-card.mjs +1 -0
  100. package/fesm2020/ng-nest-ui-carousel.mjs +1 -0
  101. package/fesm2020/ng-nest-ui-cascade.mjs +1 -0
  102. package/fesm2020/ng-nest-ui-checkbox.mjs +1 -0
  103. package/fesm2020/ng-nest-ui-collapse.mjs +1 -0
  104. package/fesm2020/ng-nest-ui-color-picker.mjs +1 -0
  105. package/fesm2020/ng-nest-ui-color.mjs +1 -0
  106. package/fesm2020/ng-nest-ui-comment.mjs +1 -0
  107. package/fesm2020/ng-nest-ui-container.mjs +1 -0
  108. package/fesm2020/ng-nest-ui-core.mjs +20 -29
  109. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  110. package/fesm2020/ng-nest-ui-date-picker.mjs +261 -99
  111. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  112. package/fesm2020/ng-nest-ui-dialog.mjs +1 -0
  113. package/fesm2020/ng-nest-ui-drawer.mjs +1 -0
  114. package/fesm2020/ng-nest-ui-dropdown.mjs +1 -0
  115. package/fesm2020/ng-nest-ui-find.mjs +1 -0
  116. package/fesm2020/ng-nest-ui-highlight.mjs +1 -0
  117. package/fesm2020/ng-nest-ui-icon.mjs +1 -0
  118. package/fesm2020/ng-nest-ui-image.mjs +1 -0
  119. package/fesm2020/ng-nest-ui-inner.mjs +1 -0
  120. package/fesm2020/ng-nest-ui-input-number.mjs +1 -0
  121. package/fesm2020/ng-nest-ui-input.mjs +1 -1
  122. package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
  123. package/fesm2020/ng-nest-ui-link.mjs +1 -0
  124. package/fesm2020/ng-nest-ui-list.mjs +1 -0
  125. package/fesm2020/ng-nest-ui-loading.mjs +12 -5
  126. package/fesm2020/ng-nest-ui-loading.mjs.map +1 -1
  127. package/fesm2020/ng-nest-ui-menu.mjs +1 -0
  128. package/fesm2020/ng-nest-ui-message-box.mjs +1 -0
  129. package/fesm2020/ng-nest-ui-message.mjs +1 -0
  130. package/fesm2020/ng-nest-ui-notification.mjs +1 -0
  131. package/fesm2020/ng-nest-ui-pagination.mjs +1 -0
  132. package/fesm2020/ng-nest-ui-popconfirm.mjs +1 -0
  133. package/fesm2020/ng-nest-ui-popover.mjs +1 -0
  134. package/fesm2020/ng-nest-ui-progress.mjs +1 -0
  135. package/fesm2020/ng-nest-ui-radio.mjs +1 -0
  136. package/fesm2020/ng-nest-ui-rate.mjs +1 -0
  137. package/fesm2020/ng-nest-ui-result.mjs +1 -0
  138. package/fesm2020/ng-nest-ui-select.mjs +1 -0
  139. package/fesm2020/ng-nest-ui-skeleton.mjs +1 -0
  140. package/fesm2020/ng-nest-ui-slider-select.mjs +1 -0
  141. package/fesm2020/ng-nest-ui-slider.mjs +1 -0
  142. package/fesm2020/ng-nest-ui-steps.mjs +1 -0
  143. package/fesm2020/ng-nest-ui-switch.mjs +48 -11
  144. package/fesm2020/ng-nest-ui-switch.mjs.map +1 -1
  145. package/fesm2020/ng-nest-ui-table.mjs +53 -10
  146. package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
  147. package/fesm2020/ng-nest-ui-tabs.mjs +1 -0
  148. package/fesm2020/ng-nest-ui-tag.mjs +1 -0
  149. package/fesm2020/ng-nest-ui-text-retract.mjs +1 -0
  150. package/fesm2020/ng-nest-ui-textarea.mjs +1 -0
  151. package/fesm2020/ng-nest-ui-timeline.mjs +1 -0
  152. package/fesm2020/ng-nest-ui-tooltip.mjs +1 -0
  153. package/fesm2020/ng-nest-ui-transfer.mjs +1 -0
  154. package/fesm2020/ng-nest-ui-tree-file.mjs +1 -0
  155. package/fesm2020/ng-nest-ui-tree-select.mjs +1 -0
  156. package/fesm2020/ng-nest-ui-tree.mjs +1 -0
  157. package/fesm2020/ng-nest-ui-upload.mjs +1 -0
  158. package/loading/loading.component.d.ts +1 -0
  159. package/loading/loading.property.d.ts +1 -1
  160. package/package.json +1 -1
  161. package/switch/switch.component.d.ts +2 -1
  162. package/switch/switch.module.d.ts +3 -1
  163. package/switch/switch.property.d.ts +42 -1
  164. package/table/drag.directive.d.ts +12 -2
  165. package/table/table-head.component.d.ts +11 -1
  166. package/table/table.property.d.ts +50 -1
@@ -1,5 +1,6 @@
1
1
  export declare type XDate = string | Date | number;
2
2
  export declare function XToDate(date: XDate): Date;
3
+ export declare function XAddMilliseconds(date: XDate, amount: number): Date;
3
4
  export declare function XAddSeconds(date: XDate, amount: number): Date;
4
5
  export declare function XAddMinutes(date: XDate, amount: number): Date;
5
6
  export declare function XAddHours(date: XDate, amount: number): Date;
@@ -227,7 +227,7 @@ export declare class XPickerDateProperty extends XProperty {
227
227
  * @zh_CN 选中的日期
228
228
  * @en_US Selected date
229
229
  */
230
- model?: Date;
230
+ model?: Date | null;
231
231
  /**
232
232
  * @zh_CN 日期显示模板
233
233
  * @en_US Date display template
@@ -267,7 +267,7 @@ export declare class XPickerDateProperty extends XProperty {
267
267
  * @zh_CN 范围日期
268
268
  * @en_US Range date
269
269
  */
270
- rangeValue: number[];
270
+ rangeValue: (number | null)[];
271
271
  /**
272
272
  * @zh_CN 当前选择的是开始/结束日期
273
273
  * @en_US The current choice is the start / end date
@@ -303,8 +303,134 @@ export declare class XPickerDateProperty extends XProperty {
303
303
  * @en_US display date event
304
304
  */
305
305
  displayChange: EventEmitter<Date>;
306
+ /**
307
+ * @zh_CN 范围日期 mouseenter 事件
308
+ * @en_US Date mouseenter event
309
+ */
310
+ rangeTdMouseenter: EventEmitter<XDateCell>;
311
+ /**
312
+ * @zh_CN 范围日期 mouseleave 事件
313
+ * @en_US Date mouseleave event
314
+ */
315
+ rangeTdMouseleave: EventEmitter<XDateCell>;
316
+ /**
317
+ * @zh_CN 范围中的日期点击事件
318
+ * @en_US Range date click event
319
+ */
320
+ rangeDateClick: EventEmitter<XDateCell>;
306
321
  static ɵfac: i0.ɵɵFactoryDeclaration<XPickerDateProperty, never>;
307
- static ɵcmp: i0.ɵɵComponentDeclaration<XPickerDateProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "dateTemp": "dateTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "lastMonthBtn": "lastMonthBtn"; "nextYearBtn": "nextYearBtn"; "nextMonthBtn": "nextMonthBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; }, { "typeChange": "typeChange"; "modelChange": "modelChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; }, never, never, false, never>;
322
+ static ɵcmp: i0.ɵɵComponentDeclaration<XPickerDateProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "dateTemp": "dateTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "lastMonthBtn": "lastMonthBtn"; "nextYearBtn": "nextYearBtn"; "nextMonthBtn": "nextMonthBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; }, { "typeChange": "typeChange"; "modelChange": "modelChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
323
+ }
324
+ /**
325
+ * @zh_CN 单个日期数据对象
326
+ * @en_US 单个日期数据对象
327
+ */
328
+ export interface XDateCell {
329
+ /**
330
+ * @zh_CN 日期
331
+ * @en_US Date
332
+ */
333
+ date?: Date;
334
+ /**
335
+ * @zh_CN 上个月或下个月的日期
336
+ * @en_US Date of the previous or next month
337
+ */
338
+ isLastOrNext?: boolean;
339
+ /**
340
+ * @zh_CN 当天
341
+ * @en_US Same day
342
+ */
343
+ isNow?: boolean;
344
+ /**
345
+ * @zh_CN 当月第一天
346
+ * @en_US The first day of the month
347
+ */
348
+ isFirstDay?: boolean;
349
+ /**
350
+ * @zh_CN 当月最后一天
351
+ * @en_US The last day of the month
352
+ */
353
+ isLastDay?: boolean;
354
+ /**
355
+ * @zh_CN 范围内日期
356
+ * @en_US 范围内日期
357
+ */
358
+ isInRange?: boolean;
359
+ /**
360
+ * @zh_CN 范围内 hover 选中
361
+ * @en_US 范围内 hover 选中
362
+ */
363
+ isInRangeHover?: boolean;
364
+ /**
365
+ * @zh_CN 范围内 hover 当前日期左边
366
+ * @en_US 范围内 hover 当前日期左边
367
+ */
368
+ isInRangeHoverLeft?: boolean;
369
+ /**
370
+ * @zh_CN 范围内 hover 当前日期右边
371
+ * @en_US 范围内 hover 当前日期右边
372
+ */
373
+ isInRangeHoverRight?: boolean;
374
+ /**
375
+ * @zh_CN 选中开始左边
376
+ * @en_US Range start left
377
+ */
378
+ isRangeStartLeft?: boolean;
379
+ /**
380
+ * @zh_CN 选中开始右边
381
+ * @en_US Range start right
382
+ */
383
+ isRangeStartRight?: boolean;
384
+ /**
385
+ * @zh_CN 选中结束左边
386
+ * @en_US Range start left
387
+ */
388
+ isRangeEndLeft?: boolean;
389
+ /**
390
+ * @zh_CN 选中结束右边
391
+ * @en_US Range start right
392
+ */
393
+ isRangeEndRight?: boolean;
394
+ /**
395
+ * @zh_CN 范围 hover
396
+ * @en_US Range hover
397
+ */
398
+ isRangeHover?: boolean;
399
+ /**
400
+ * @zh_CN hover 当前开始
401
+ * @en_US Range hover start
402
+ */
403
+ isRangeHoverStart?: boolean;
404
+ /**
405
+ * @zh_CN hover 当前结束
406
+ * @en_US End date
407
+ */
408
+ isRangeHoverEnd?: boolean;
409
+ /**
410
+ * @zh_CN hover 开始左边
411
+ * @en_US Range hover start left
412
+ */
413
+ isRangeHoverStartLeft?: boolean;
414
+ /**
415
+ * @zh_CN hover 开始右边
416
+ * @en_US Range hover start right
417
+ */
418
+ isRangeHoverStartRight?: boolean;
419
+ /**
420
+ * @zh_CN hover 结束左边
421
+ * @en_US Range hover end left
422
+ */
423
+ isRangeHoverEndLeft?: boolean;
424
+ /**
425
+ * @zh_CN hover 结束右边
426
+ * @en_US Range hover end right
427
+ */
428
+ isRangeHoverEndRight?: boolean;
429
+ /**
430
+ * @zh_CN 当前选中日期
431
+ * @en_US Current selected date
432
+ */
433
+ isActive?: boolean;
308
434
  }
309
435
  /**
310
436
  * @zh_CN 当前选择的是开始/结束日期
@@ -18,25 +18,26 @@ export declare class XDateRangePortalComponent implements OnInit, OnDestroy, Aft
18
18
  type: XDatePickerType;
19
19
  display: Date;
20
20
  model: Date;
21
- startModel: Date;
22
- endModel: Date;
21
+ startModel: Date | null;
22
+ endModel: Date | null;
23
23
  startYear: number;
24
24
  startDisplay: Date;
25
25
  endDisplay: Date;
26
- value: number[];
26
+ value: (number | null)[];
27
27
  valueChange: Subject<number[]>;
28
28
  positionChange: Subject<any>;
29
- inputActiveChange: Subject<'start' | 'end'>;
29
+ activeTypeChange: Subject<'start' | 'end'>;
30
30
  activeType: 'start' | 'end';
31
31
  animating: Function;
32
32
  closePortal: Function;
33
33
  destroyPortal: Function;
34
- nodeEmit: (date: Date[], sure?: boolean) => void;
35
- startNodeEmit: (date: Date) => void;
36
- endNodeEmit: (date: Date) => void;
34
+ nodeEmit: (date: Date[], close?: boolean) => void;
35
+ startNodeEmit: (date: Date | null, close?: boolean) => void;
36
+ endNodeEmit: (date: Date | null, close?: boolean) => void;
37
37
  locale: XI18nDatePicker;
38
38
  time: number;
39
39
  preset: XDatePickerPreset[];
40
+ nodeClickCount: number;
40
41
  private _type;
41
42
  private _unSubject;
42
43
  constructor(datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, i18n: XI18nService);
@@ -47,7 +48,7 @@ export declare class XDateRangePortalComponent implements OnInit, OnDestroy, Aft
47
48
  stopPropagation(event: Event): void;
48
49
  setDefault(): void;
49
50
  setDisplay(date: Date): void;
50
- dateChange(date: Date, type: 'start' | 'end'): void;
51
+ dateChange(date: Date): void;
51
52
  typeChange(type: XDatePickerType): void;
52
53
  monthChange(date: Date): void;
53
54
  yearChange(date: Date): void;
@@ -2,7 +2,7 @@ import { XPortalService, XPortalOverlayRef } from '@ng-nest/ui/portal';
2
2
  import { Subject } from 'rxjs';
3
3
  import { OnInit, ChangeDetectorRef, Renderer2, ElementRef, OnChanges, ViewContainerRef, SimpleChanges } from '@angular/core';
4
4
  import { XDatePickerModelType, XDateRangeProperty } from './date-picker.property';
5
- import { XConfigService, XBoolean } from '@ng-nest/ui/core';
5
+ import { XConfigService } from '@ng-nest/ui/core';
6
6
  import { XInputComponent, XInputGroupComponent } from '@ng-nest/ui/input';
7
7
  import { DatePipe } from '@angular/common';
8
8
  import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
@@ -21,8 +21,9 @@ export declare class XDateRangeComponent extends XDateRangeProperty implements O
21
21
  inputStartCom: XInputComponent;
22
22
  inputEndCom: XInputComponent;
23
23
  modelType: XDatePickerModelType;
24
- numberValue: number[];
24
+ numberValue: (number | null)[];
25
25
  isInput: boolean;
26
+ showClearable: boolean;
26
27
  get getRequired(): boolean | "";
27
28
  writeValue(value: any): void;
28
29
  enter: boolean;
@@ -38,12 +39,10 @@ export declare class XDateRangeComponent extends XDateRangeProperty implements O
38
39
  valueChange: Subject<any>;
39
40
  dataChange: Subject<any>;
40
41
  positionChange: Subject<any>;
41
- inputActiveChange: Subject<string>;
42
42
  closeSubject: Subject<void>;
43
+ activeTypeChange: Subject<"end" | "start">;
43
44
  startDisplay: string | number;
44
45
  endDisplay: string | number;
45
- startActive: XBoolean;
46
- endActive: XBoolean;
47
46
  activeType?: 'start' | 'end';
48
47
  private _unSubject;
49
48
  constructor(renderer: Renderer2, configService: XConfigService, cdr: ChangeDetectorRef, portalService: XPortalService, viewContainerRef: ViewContainerRef, datePipe: DatePipe, overlay: Overlay);
@@ -56,19 +55,22 @@ export declare class XDateRangeComponent extends XDateRangeProperty implements O
56
55
  menter(): void;
57
56
  mleave(): void;
58
57
  clearEmit(): void;
58
+ onIconClick(event: Event): void;
59
59
  modelChange(): void;
60
- getValue(): number[] | Date[] | (string | null)[];
60
+ getValue(): (number | null)[] | Date[] | (string | null)[];
61
+ getNumberValue(): any;
61
62
  portalAttached(): boolean | undefined;
62
63
  closePortal(): boolean;
63
64
  destroyPortal(): void;
64
65
  showPortal($event: Event, type?: 'start' | 'end'): void;
65
66
  setPosition(config: OverlayConfig): void;
66
67
  setInstance(): void;
67
- startNodeClick(node: Date): void;
68
- endNodeClick(node: Date): void;
69
- onNodeClick(dates: Date[], sure?: boolean): void;
68
+ startNodeClick(node?: Date, close?: boolean): void;
69
+ endNodeClick(node?: Date, close?: boolean): void;
70
+ onNodeClick(dates: Date[], close?: boolean): void;
70
71
  onInput(): void;
71
- setDisplayValue(dateNumber: number[]): void;
72
+ onFocus(type: 'start' | 'end'): void;
73
+ setDisplayValue(dateNumber: (number | null)[]): void;
72
74
  setPlacement(): import("@angular/cdk/overlay").PositionStrategy;
73
75
  setPortal(): void;
74
76
  setClassMap(): void;
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectorRef, Renderer2, OnChanges, SimpleChanges } from '@angular/core';
2
2
  import { XConfigService } from '@ng-nest/ui/core';
3
- import { XDatePickerType, XPickerDateProperty } from './date-picker.property';
3
+ import { XDateCell, XDatePickerType, XPickerDateProperty } from './date-picker.property';
4
4
  import { XI18nDatePicker, XI18nService } from '@ng-nest/ui/i18n';
5
5
  import { DatePipe, LowerCasePipe } from '@angular/common';
6
6
  import * as i0 from "@angular/core";
@@ -13,25 +13,34 @@ export declare class XPickerDateComponent extends XPickerDateProperty implements
13
13
  i18n: XI18nService;
14
14
  titles: string[];
15
15
  now: Date;
16
- dates: Date[][];
16
+ dates: XDateCell[];
17
+ weekDates: XDateCell[][];
18
+ clickCell?: XDateCell;
17
19
  locale: XI18nDatePicker;
18
20
  private _unSubject;
19
- get rangeStart(): number | "";
20
- get rangeEnd(): number | "";
21
+ get rangeStart(): number | "" | null;
22
+ get rangeEnd(): number | "" | null;
21
23
  constructor(renderer: Renderer2, datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, configService: XConfigService, i18n: XI18nService);
22
24
  ngOnInit(): void;
23
25
  ngOnChanges(simples: SimpleChanges): void;
24
26
  ngOnDestroy(): void;
25
27
  init(): void;
28
+ isStartDate(date: Date): boolean | undefined;
29
+ isEndDate(date: Date): boolean | undefined;
30
+ setDatesState(cell: XDateCell): void;
31
+ onTdMouseenter(cell: XDateCell, isEmit?: boolean): void;
32
+ onTdMouseleave(cell: XDateCell, isEmit?: boolean): void;
33
+ clearState(...cells: XDateCell[]): void;
26
34
  setDays(date: Date): void;
27
- dateClick(date: Date): void;
35
+ setDayState(cell: XDateCell): XDateCell;
36
+ dateClick(cell: XDateCell): void;
28
37
  getLocaleMonth(date: Date): any;
29
38
  rangeDisabled(date: Date): boolean;
30
39
  setDisplay(date: Date): void;
31
40
  nextMonth(num: number): void;
32
41
  nextYear(num: number): void;
33
42
  typeOnChange(type: XDatePickerType): void;
34
- trackByNode(_index: number, item: string | Date): string | Date;
43
+ trackByNode(_index: number, item: string | Date | XDateCell): string | Date | XDateCell;
35
44
  static ɵfac: i0.ɵɵFactoryDeclaration<XPickerDateComponent, never>;
36
45
  static ɵcmp: i0.ɵɵComponentDeclaration<XPickerDateComponent, "x-picker-date", never, {}, {}, never, never, false, never>;
37
46
  }
@@ -7,35 +7,23 @@ export function XToDate(date) {
7
7
  return new Date(Date.parse(date));
8
8
  }
9
9
  }
10
- export function XAddSeconds(date, amount) {
10
+ export function XAddMilliseconds(date, amount) {
11
11
  let dt = XToDate(date);
12
12
  if (!isNaN(dt.valueOf()) && amount) {
13
- dt.setSeconds(dt.getSeconds() + amount);
14
- return dt;
13
+ return new Date(dt.getTime() + amount);
15
14
  }
16
15
  else {
17
16
  return date;
18
17
  }
19
18
  }
19
+ export function XAddSeconds(date, amount) {
20
+ return XAddMilliseconds(date, amount * 1000);
21
+ }
20
22
  export function XAddMinutes(date, amount) {
21
- let dt = XToDate(date);
22
- if (!isNaN(dt.valueOf()) && amount) {
23
- dt.setMinutes(dt.getMinutes() + amount);
24
- return dt;
25
- }
26
- else {
27
- return date;
28
- }
23
+ return XAddMilliseconds(date, amount * 60000);
29
24
  }
30
25
  export function XAddHours(date, amount) {
31
- let dt = XToDate(date);
32
- if (!isNaN(dt.valueOf()) && amount) {
33
- dt.setHours(dt.getHours() + amount);
34
- return dt;
35
- }
36
- else {
37
- return date;
38
- }
26
+ return XAddMilliseconds(date, amount * 3600000);
39
27
  }
40
28
  export function XAddDays(date, amount) {
41
29
  let dt = XToDate(date);
@@ -50,7 +38,17 @@ export function XAddDays(date, amount) {
50
38
  export function XAddMonths(date, amount) {
51
39
  let dt = XToDate(date);
52
40
  if (!isNaN(dt.valueOf()) && amount) {
53
- dt.setMonth(dt.getMonth() + amount);
41
+ const day = dt.getDate();
42
+ const month = dt.getMonth();
43
+ const endMonth = new Date(dt);
44
+ endMonth.setMonth(month + amount + 1, 0);
45
+ const endDay = endMonth.getDate();
46
+ if (day >= endDay) {
47
+ return endMonth;
48
+ }
49
+ else {
50
+ dt.setFullYear(endMonth.getFullYear(), endMonth.getMonth(), day);
51
+ }
54
52
  return dt;
55
53
  }
56
54
  else {
@@ -58,13 +56,6 @@ export function XAddMonths(date, amount) {
58
56
  }
59
57
  }
60
58
  export function XAddYears(date, amount) {
61
- let dt = XToDate(date);
62
- if (!isNaN(dt.valueOf()) && amount) {
63
- dt.setFullYear(dt.getFullYear() + amount);
64
- return dt;
65
- }
66
- else {
67
- return date;
68
- }
59
+ return XAddMonths(date, amount * 12);
69
60
  }
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2NvcmUvZnVuY3Rpb25zL2RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJbkQsTUFBTSxVQUFVLE9BQU8sQ0FBQyxJQUFXO0lBQ2pDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNwQyxPQUFPLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0tBQ3ZCO1NBQU07UUFDTCxPQUFPLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBYyxDQUFDLENBQUMsQ0FBQztLQUM3QztBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsV0FBVyxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ3JELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUN4QyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsV0FBVyxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ3JELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUN4QyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ25ELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUNwQyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ2xELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUNsQyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ3BELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUNwQyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ25ELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUMxQyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBYSXNEYXRlLCBYSXNOdW1iZXIgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcclxuXHJcbmV4cG9ydCB0eXBlIFhEYXRlID0gc3RyaW5nIHwgRGF0ZSB8IG51bWJlcjtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBYVG9EYXRlKGRhdGU6IFhEYXRlKTogRGF0ZSB7XHJcbiAgaWYgKFhJc0RhdGUoZGF0ZSkgfHwgWElzTnVtYmVyKGRhdGUpKSB7XHJcbiAgICByZXR1cm4gbmV3IERhdGUoZGF0ZSk7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBuZXcgRGF0ZShEYXRlLnBhcnNlKGRhdGUgYXMgc3RyaW5nKSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZFNlY29uZHMoZGF0ZTogWERhdGUsIGFtb3VudDogbnVtYmVyKTogRGF0ZSB7XHJcbiAgbGV0IGR0ID0gWFRvRGF0ZShkYXRlKTtcclxuICBpZiAoIWlzTmFOKGR0LnZhbHVlT2YoKSkgJiYgYW1vdW50KSB7XHJcbiAgICBkdC5zZXRTZWNvbmRzKGR0LmdldFNlY29uZHMoKSArIGFtb3VudCk7XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZE1pbnV0ZXMoZGF0ZTogWERhdGUsIGFtb3VudDogbnVtYmVyKTogRGF0ZSB7XHJcbiAgbGV0IGR0ID0gWFRvRGF0ZShkYXRlKTtcclxuICBpZiAoIWlzTmFOKGR0LnZhbHVlT2YoKSkgJiYgYW1vdW50KSB7XHJcbiAgICBkdC5zZXRNaW51dGVzKGR0LmdldE1pbnV0ZXMoKSArIGFtb3VudCk7XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZEhvdXJzKGRhdGU6IFhEYXRlLCBhbW91bnQ6IG51bWJlcik6IERhdGUge1xyXG4gIGxldCBkdCA9IFhUb0RhdGUoZGF0ZSk7XHJcbiAgaWYgKCFpc05hTihkdC52YWx1ZU9mKCkpICYmIGFtb3VudCkge1xyXG4gICAgZHQuc2V0SG91cnMoZHQuZ2V0SG91cnMoKSArIGFtb3VudCk7XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZERheXMoZGF0ZTogWERhdGUsIGFtb3VudDogbnVtYmVyKTogRGF0ZSB7XHJcbiAgbGV0IGR0ID0gWFRvRGF0ZShkYXRlKTtcclxuICBpZiAoIWlzTmFOKGR0LnZhbHVlT2YoKSkgJiYgYW1vdW50KSB7XHJcbiAgICBkdC5zZXREYXRlKGR0LmdldERhdGUoKSArIGFtb3VudCk7XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZE1vbnRocyhkYXRlOiBYRGF0ZSwgYW1vdW50OiBudW1iZXIpOiBEYXRlIHtcclxuICBsZXQgZHQgPSBYVG9EYXRlKGRhdGUpO1xyXG4gIGlmICghaXNOYU4oZHQudmFsdWVPZigpKSAmJiBhbW91bnQpIHtcclxuICAgIGR0LnNldE1vbnRoKGR0LmdldE1vbnRoKCkgKyBhbW91bnQpO1xyXG4gICAgcmV0dXJuIGR0O1xyXG4gIH0gZWxzZSB7XHJcbiAgICByZXR1cm4gZGF0ZSBhcyBEYXRlO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIFhBZGRZZWFycyhkYXRlOiBYRGF0ZSwgYW1vdW50OiBudW1iZXIpOiBEYXRlIHtcclxuICBsZXQgZHQgPSBYVG9EYXRlKGRhdGUpO1xyXG4gIGlmICghaXNOYU4oZHQudmFsdWVPZigpKSAmJiBhbW91bnQpIHtcclxuICAgIGR0LnNldEZ1bGxZZWFyKGR0LmdldEZ1bGxZZWFyKCkgKyBhbW91bnQpO1xyXG4gICAgcmV0dXJuIGR0O1xyXG4gIH0gZWxzZSB7XHJcbiAgICByZXR1cm4gZGF0ZSBhcyBEYXRlO1xyXG4gIH1cclxufVxyXG4iXX0=
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2NvcmUvZnVuY3Rpb25zL2RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJbkQsTUFBTSxVQUFVLE9BQU8sQ0FBQyxJQUFXO0lBQ2pDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUNwQyxPQUFPLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0tBQ3ZCO1NBQU07UUFDTCxPQUFPLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBYyxDQUFDLENBQUMsQ0FBQztLQUM3QztBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsSUFBVyxFQUFFLE1BQWM7SUFDMUQsSUFBSSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZCLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLElBQUksTUFBTSxFQUFFO1FBQ2xDLE9BQU8sSUFBSSxJQUFJLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxHQUFHLE1BQU0sQ0FBQyxDQUFDO0tBQ3hDO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsV0FBVyxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ3JELE9BQU8sZ0JBQWdCLENBQUMsSUFBSSxFQUFFLE1BQU0sR0FBRyxJQUFJLENBQUMsQ0FBQztBQUMvQyxDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxJQUFXLEVBQUUsTUFBYztJQUNyRCxPQUFPLGdCQUFnQixDQUFDLElBQUksRUFBRSxNQUFNLEdBQUcsS0FBSyxDQUFDLENBQUM7QUFDaEQsQ0FBQztBQUVELE1BQU0sVUFBVSxTQUFTLENBQUMsSUFBVyxFQUFFLE1BQWM7SUFDbkQsT0FBTyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxDQUFDO0FBQ2xELENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ2xELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxNQUFNLENBQUMsQ0FBQztRQUNsQyxPQUFPLEVBQUUsQ0FBQztLQUNYO1NBQU07UUFDTCxPQUFPLElBQVksQ0FBQztLQUNyQjtBQUNILENBQUM7QUFFRCxNQUFNLFVBQVUsVUFBVSxDQUFDLElBQVcsRUFBRSxNQUFjO0lBQ3BELElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxJQUFJLE1BQU0sRUFBRTtRQUNsQyxNQUFNLEdBQUcsR0FBRyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDekIsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQzVCLE1BQU0sUUFBUSxHQUFHLElBQUksSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzlCLFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDekMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2xDLElBQUksR0FBRyxJQUFJLE1BQU0sRUFBRTtZQUNqQixPQUFPLFFBQVEsQ0FBQztTQUNqQjthQUFNO1lBQ0wsRUFBRSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLEVBQUUsUUFBUSxDQUFDLFFBQVEsRUFBRSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1NBQ2xFO1FBQ0QsT0FBTyxFQUFFLENBQUM7S0FDWDtTQUFNO1FBQ0wsT0FBTyxJQUFZLENBQUM7S0FDckI7QUFDSCxDQUFDO0FBRUQsTUFBTSxVQUFVLFNBQVMsQ0FBQyxJQUFXLEVBQUUsTUFBYztJQUNuRCxPQUFPLFVBQVUsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLEVBQUUsQ0FBQyxDQUFDO0FBQ3ZDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBYSXNEYXRlLCBYSXNOdW1iZXIgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcclxuXHJcbmV4cG9ydCB0eXBlIFhEYXRlID0gc3RyaW5nIHwgRGF0ZSB8IG51bWJlcjtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBYVG9EYXRlKGRhdGU6IFhEYXRlKTogRGF0ZSB7XHJcbiAgaWYgKFhJc0RhdGUoZGF0ZSkgfHwgWElzTnVtYmVyKGRhdGUpKSB7XHJcbiAgICByZXR1cm4gbmV3IERhdGUoZGF0ZSk7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBuZXcgRGF0ZShEYXRlLnBhcnNlKGRhdGUgYXMgc3RyaW5nKSk7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZE1pbGxpc2Vjb25kcyhkYXRlOiBYRGF0ZSwgYW1vdW50OiBudW1iZXIpOiBEYXRlIHtcclxuICBsZXQgZHQgPSBYVG9EYXRlKGRhdGUpO1xyXG4gIGlmICghaXNOYU4oZHQudmFsdWVPZigpKSAmJiBhbW91bnQpIHtcclxuICAgIHJldHVybiBuZXcgRGF0ZShkdC5nZXRUaW1lKCkgKyBhbW91bnQpO1xyXG4gIH0gZWxzZSB7XHJcbiAgICByZXR1cm4gZGF0ZSBhcyBEYXRlO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIFhBZGRTZWNvbmRzKGRhdGU6IFhEYXRlLCBhbW91bnQ6IG51bWJlcik6IERhdGUge1xyXG4gIHJldHVybiBYQWRkTWlsbGlzZWNvbmRzKGRhdGUsIGFtb3VudCAqIDEwMDApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZE1pbnV0ZXMoZGF0ZTogWERhdGUsIGFtb3VudDogbnVtYmVyKTogRGF0ZSB7XHJcbiAgcmV0dXJuIFhBZGRNaWxsaXNlY29uZHMoZGF0ZSwgYW1vdW50ICogNjAwMDApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZEhvdXJzKGRhdGU6IFhEYXRlLCBhbW91bnQ6IG51bWJlcik6IERhdGUge1xyXG4gIHJldHVybiBYQWRkTWlsbGlzZWNvbmRzKGRhdGUsIGFtb3VudCAqIDM2MDAwMDApO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZERheXMoZGF0ZTogWERhdGUsIGFtb3VudDogbnVtYmVyKTogRGF0ZSB7XHJcbiAgbGV0IGR0ID0gWFRvRGF0ZShkYXRlKTtcclxuICBpZiAoIWlzTmFOKGR0LnZhbHVlT2YoKSkgJiYgYW1vdW50KSB7XHJcbiAgICBkdC5zZXREYXRlKGR0LmdldERhdGUoKSArIGFtb3VudCk7XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZE1vbnRocyhkYXRlOiBYRGF0ZSwgYW1vdW50OiBudW1iZXIpOiBEYXRlIHtcclxuICBsZXQgZHQgPSBYVG9EYXRlKGRhdGUpO1xyXG4gIGlmICghaXNOYU4oZHQudmFsdWVPZigpKSAmJiBhbW91bnQpIHtcclxuICAgIGNvbnN0IGRheSA9IGR0LmdldERhdGUoKTtcclxuICAgIGNvbnN0IG1vbnRoID0gZHQuZ2V0TW9udGgoKTtcclxuICAgIGNvbnN0IGVuZE1vbnRoID0gbmV3IERhdGUoZHQpO1xyXG4gICAgZW5kTW9udGguc2V0TW9udGgobW9udGggKyBhbW91bnQgKyAxLCAwKTtcclxuICAgIGNvbnN0IGVuZERheSA9IGVuZE1vbnRoLmdldERhdGUoKTtcclxuICAgIGlmIChkYXkgPj0gZW5kRGF5KSB7XHJcbiAgICAgIHJldHVybiBlbmRNb250aDtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIGR0LnNldEZ1bGxZZWFyKGVuZE1vbnRoLmdldEZ1bGxZZWFyKCksIGVuZE1vbnRoLmdldE1vbnRoKCksIGRheSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gZHQ7XHJcbiAgfSBlbHNlIHtcclxuICAgIHJldHVybiBkYXRlIGFzIERhdGU7XHJcbiAgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gWEFkZFllYXJzKGRhdGU6IFhEYXRlLCBhbW91bnQ6IG51bWJlcik6IERhdGUge1xyXG4gIHJldHVybiBYQWRkTW9udGhzKGRhdGUsIGFtb3VudCAqIDEyKTtcclxufVxyXG4iXX0=
@@ -241,10 +241,25 @@ export class XPickerDateProperty extends XProperty {
241
241
  * @en_US display date event
242
242
  */
243
243
  this.displayChange = new EventEmitter();
244
+ /**
245
+ * @zh_CN 范围日期 mouseenter 事件
246
+ * @en_US Date mouseenter event
247
+ */
248
+ this.rangeTdMouseenter = new EventEmitter();
249
+ /**
250
+ * @zh_CN 范围日期 mouseleave 事件
251
+ * @en_US Date mouseleave event
252
+ */
253
+ this.rangeTdMouseleave = new EventEmitter();
254
+ /**
255
+ * @zh_CN 范围中的日期点击事件
256
+ * @en_US Range date click event
257
+ */
258
+ this.rangeDateClick = new EventEmitter();
244
259
  }
245
260
  }
246
261
  /** @nocollapse */ XPickerDateProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XPickerDateProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
247
- /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker", lastYearBtn: "lastYearBtn", lastMonthBtn: "lastMonthBtn", nextYearBtn: "nextYearBtn", nextMonthBtn: "nextMonthBtn", rangeValue: "rangeValue", rangeType: "rangeType" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange", yearChange: "yearChange", monthChange: "monthChange", displayChange: "displayChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
262
+ /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker", lastYearBtn: "lastYearBtn", lastMonthBtn: "lastMonthBtn", nextYearBtn: "nextYearBtn", nextMonthBtn: "nextMonthBtn", rangeValue: "rangeValue", rangeType: "rangeType" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange", yearChange: "yearChange", monthChange: "monthChange", displayChange: "displayChange", rangeTdMouseenter: "rangeTdMouseenter", rangeTdMouseleave: "rangeTdMouseleave", rangeDateClick: "rangeDateClick" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
248
263
  __decorate([
249
264
  XInputBoolean()
250
265
  ], XPickerDateProperty.prototype, "showHeader", void 0);
@@ -302,6 +317,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
302
317
  type: Output
303
318
  }], displayChange: [{
304
319
  type: Output
320
+ }], rangeTdMouseenter: [{
321
+ type: Output
322
+ }], rangeTdMouseleave: [{
323
+ type: Output
324
+ }], rangeDateClick: [{
325
+ type: Output
305
326
  }] } });
306
327
  /**
307
328
  * PickerMonth
@@ -439,4 +460,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
439
460
  }], startChange: [{
440
461
  type: Output
441
462
  }] } });
442
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker.property.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,aAAa,EACb,SAAS,EAGT,WAAW,EAGX,YAAY,EAGb,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAe,SAAS,EAAE,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,qBAAqB,EAAe,MAAM,uBAAuB,CAAC;;AAE3E;;;;GAIG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,eAAe,CAAC;AACjD,MAAM,aAAa,GAAG,YAAY,CAAC;AAEnC;;GAEG;AAEH,MAAM,OAAO,mBAAoB,SAAQ,qBAA0B;IADnE;;QAEE;;;WAGG;QACM,SAAI,GAAoB,MAAM,CAAC;QA0BxC;;;WAGG;QACsB,WAAM,GAA6B,EAAE,CAAC;QAC/D;;;WAGG;QACO,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;KACjD;;mIAzCY,mBAAmB;uHAAnB,mBAAmB,gQADT,EAAE;AAWoC;IAAjD,WAAW,CAAS,aAAa,EAAE,YAAY,CAAC;mDAAiB;AAKL;IAA5D,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;IAAE,aAAa,EAAE;sDAAsB;AAK7B;IAApD,WAAW,CAAU,aAAa,EAAE,cAAc,CAAC;sDAAqB;AAK5B;IAA5C,WAAW,CAAQ,aAAa,EAAE,QAAQ,CAAC;iDAAuB;AAKN;IAA5D,aAAa,EAAE;IAAE,WAAW,CAAW,aAAa,EAAE,IAAI,CAAC;qDAAqB;AAKjE;IAAf,YAAY,EAAE;mDAAuC;2FAnCpD,mBAAmB;kBAD/B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMhB,IAAI;sBAAZ,KAAK;gBAKqD,MAAM;sBAAhE,KAAK;gBAKgE,SAAS;sBAA9E,KAAK;gBAKwD,SAAS;sBAAtE,KAAK;gBAKyD,IAAI;sBAAlE,KAAK;gBAKgE,QAAQ;sBAA7E,KAAK;gBAKmB,MAAM;sBAA9B,KAAK;gBAKI,QAAQ;sBAAjB,MAAM;;AAuDT;;;;GAIG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG,cAAc,CAAC;AAC/C,MAAM,mBAAmB,GAAG,WAAW,CAAC;AAExC;;GAEG;AAEH,MAAM,OAAO,kBAAmB,SAAQ,qBAA0B;IADlE;;QAEE;;;WAGG;QACM,SAAI,GAAoB,MAAM,CAAC;QA0BxC;;;WAGG;QACsB,WAAM,GAA6B,EAAE,CAAC;QAC/D;;;WAGG;QACO,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;KACnD;;kIAzCY,kBAAkB;sHAAlB,kBAAkB,gQADR,EAAE;AAW0C;IAAvD,WAAW,CAAS,mBAAmB,EAAE,YAAY,CAAC;kDAAiB;AAKL;IAAlE,WAAW,CAAW,mBAAmB,EAAE,IAAI,CAAC;IAAE,aAAa,EAAE;qDAAsB;AAK7B;IAA1D,WAAW,CAAU,mBAAmB,EAAE,cAAc,CAAC;qDAAqB;AAK5B;IAAlD,WAAW,CAAQ,mBAAmB,EAAE,QAAQ,CAAC;gDAAuB;AAKN;IAAlE,aAAa,EAAE;IAAE,WAAW,CAAW,mBAAmB,EAAE,IAAI,CAAC;oDAAqB;AAKvE;IAAf,YAAY,EAAE;kDAAuC;2FAnCpD,kBAAkB;kBAD9B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMhB,IAAI;sBAAZ,KAAK;gBAK2D,MAAM;sBAAtE,KAAK;gBAKsE,SAAS;sBAApF,KAAK;gBAK8D,SAAS;sBAA5E,KAAK;gBAK+D,IAAI;sBAAxE,KAAK;gBAKsE,QAAQ;sBAAnF,KAAK;gBAKmB,MAAM;sBAA9B,KAAK;gBAKI,QAAQ;sBAAjB,MAAM;;AAuCT;;;;GAIG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAAG,sBAAsB,CAAC;AAE9D;;;;GAIG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,qBAAqB,CAAC;AAE5D;;;;GAIG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,eAAe,CAAC;AAEjD;;GAEG;AAEH,MAAM,OAAO,mBAAoB,SAAQ,SAAS;IADlD;;QAEE;;;WAGG;QACM,SAAI,GAAoB,MAAM,CAAC;QACxC;;;WAGG;QACM,YAAO,GAAG,IAAI,IAAI,EAAE,CAAC;QAW9B;;;WAGG;QACuB,eAAU,GAAa,IAAI,CAAC;QAMtD;;;WAGG;QACuB,gBAAW,GAAa,IAAI,CAAC;QACvD;;;WAGG;QACuB,iBAAY,GAAa,IAAI,CAAC;QACxD;;;WAGG;QACuB,gBAAW,GAAa,IAAI,CAAC;QACvD;;;WAGG;QACuB,iBAAY,GAAa,IAAI,CAAC;QACxD;;;WAGG;QACM,eAAU,GAAa,EAAE,CAAC;QAMnC;;;WAGG;QACO,eAAU,GAAG,IAAI,YAAY,EAAmB,CAAC;QAC3D;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QACjD;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACnD;;;WAGG;QACO,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAClD;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACnD;;;WAGG;QACO,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;KACpD;;mIA3FY,mBAAmB;uHAAnB,mBAAmB,gjBADT,EAAE;AA0BG;IAAhB,aAAa,EAAE;uDAA6B;AAK5B;IAAhB,aAAa,EAAE;wDAAwB;AAKvB;IAAhB,aAAa,EAAE;wDAA8B;AAK7B;IAAhB,aAAa,EAAE;yDAA+B;AAK9B;IAAhB,aAAa,EAAE;wDAA8B;AAK7B;IAAhB,aAAa,EAAE;yDAA+B;2FAlD7C,mBAAmB;kBAD/B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMhB,IAAI;sBAAZ,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBAKoB,UAAU;sBAAnC,KAAK;gBAKoB,WAAW;sBAApC,KAAK;gBAKoB,WAAW;sBAApC,KAAK;gBAKoB,YAAY;sBAArC,KAAK;gBAKoB,WAAW;sBAApC,KAAK;gBAKoB,YAAY;sBAArC,KAAK;gBAKG,UAAU;sBAAlB,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAKI,UAAU;sBAAnB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAKG,UAAU;sBAAnB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAKG,aAAa;sBAAtB,MAAM;;AAST;;;;GAIG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,gBAAgB,CAAC;AAEnD;;GAEG;AAEH,MAAM,OAAO,oBAAqB,SAAQ,SAAS;IADnD;;QAEE;;;WAGG;QACM,SAAI,GAAoB,MAAM,CAAC;QACxC;;;WAGG;QACM,YAAO,GAAS,IAAI,IAAI,EAAE,CAAC;QAWpC;;;WAGG;QACuB,eAAU,GAAa,IAAI,CAAC;QACtD;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QACjD;;;WAGG;QACO,eAAU,GAAG,IAAI,YAAY,EAAmB,CAAC;QAC3D;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;KACpD;;oIAzCY,oBAAoB;wHAApB,oBAAoB,0RADV,EAAE;AA0BG;IAAhB,aAAa,EAAE;wDAA6B;2FAzB3C,oBAAoB;kBADhC,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMhB,IAAI;sBAAZ,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAKoB,UAAU;sBAAnC,KAAK;gBAKI,WAAW;sBAApB,MAAM;gBAKG,UAAU;sBAAnB,MAAM;gBAKG,WAAW;sBAApB,MAAM;;AAGT;;;;GAIG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,eAAe,CAAC;AAEjD;;GAEG;AAEH,MAAM,OAAO,mBAAoB,SAAQ,SAAS;IADlD;;QAEE;;;WAGG;QACM,SAAI,GAAoB,MAAM,CAAC;QACxC;;;WAGG;QACM,YAAO,GAAS,IAAI,IAAI,EAAE,CAAC;QAMpC;;;WAGG;QACuB,eAAU,GAAa,IAAI,CAAC;QACtD;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QACjD;;;WAGG;QACO,eAAU,GAAG,IAAI,YAAY,EAAmB,CAAC;QAC3D;;;WAGG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;KACpD;;mIApCY,mBAAmB;uHAAnB,mBAAmB,kQADT,EAAE;AAqBG;IAAhB,aAAa,EAAE;uDAA6B;2FApB3C,mBAAmB;kBAD/B,SAAS;mBAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;8BAMhB,IAAI;sBAAZ,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAKG,KAAK;sBAAb,KAAK;gBAKoB,UAAU;sBAAnC,KAAK;gBAKI,WAAW;sBAApB,MAAM;gBAKG,UAAU;sBAAnB,MAAM;gBAKG,WAAW;sBAApB,MAAM","sourcesContent":["import {\r\n  XInputBoolean,\r\n  XProperty,\r\n  XBoolean,\r\n  XCorner,\r\n  XWithConfig,\r\n  XSize,\r\n  XTemplate,\r\n  XDataConvert,\r\n  XData,\r\n  XIdentityProperty\r\n} from '@ng-nest/ui/core';\r\nimport { Input, EventEmitter, Output, TemplateRef, Component } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * DatePicker\r\n * @selector x-date-picker\r\n * @decorator component\r\n */\r\nexport const XDatePickerPrefix = 'x-date-picker';\r\nconst X_CONFIG_NAME = 'datePicker';\r\n\r\n/**\r\n * DatePicker Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDatePickerProperty extends XControlValueAccessor<any> implements XDatePickerOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number>();\r\n}\r\n\r\n/**\r\n * DatePicker Option\r\n * @undocument true\r\n */\r\nexport interface XDatePickerOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Choose a type\r\n   */\r\n  type?: XDatePickerType;\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 前置标签\r\n   * @en_US Before label\r\n   */\r\n  before?: XTemplate;\r\n  /**\r\n   * @zh_CN 后置标签\r\n   * @en_US After label\r\n   */\r\n  after?: XTemplate;\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  nodeClick?: (value: number) => void;\r\n}\r\n\r\n/**\r\n * DateRange\r\n * @selector x-date-range\r\n * @decorator component\r\n */\r\nexport const XDateRangePrefix = 'x-date-range';\r\nconst X_CONFIG_RANGE_NAME = 'dateRange';\r\n\r\n/**\r\n * DateRange Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDateRangeProperty extends XControlValueAccessor<any> implements XDateRangeOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_RANGE_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_RANGE_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_RANGE_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number[]>();\r\n}\r\n\r\n/**\r\n * DateRange Option\r\n * @undocument true\r\n */\r\nexport interface XDateRangeOption extends XFormOption {\r\n  /**\r\n   * @zh_CN tab 键控制次序\r\n   * @en_US Tab key control order\r\n   */\r\n  tabindex?: number;\r\n}\r\n\r\n/**\r\n * @zh_CN 快捷选择按钮\r\n * @en_US Quick selection button\r\n */\r\nexport interface XDatePickerPreset extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 自定义函数\r\n   * @en_US Custom function\r\n   */\r\n  func: () => Date;\r\n}\r\n\r\n/**\r\n * @zh_CN 日期选择类型\r\n * @en_US Date selection type\r\n */\r\nexport type XDatePickerType = 'date' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';\r\n\r\n/**\r\n * @zh_CN 日期数据类型\r\n * @en_US Date data type\r\n */\r\nexport type XDatePickerModelType = 'date' | 'number' | 'string';\r\n\r\n/**\r\n * DatePicker Portal\r\n * @selector x-date-picker-portal\r\n * @decorator component\r\n */\r\nexport const XDatePickerPortalPrefix = 'x-date-picker-portal';\r\n\r\n/**\r\n * DateRange Portal\r\n * @selector x-date-range-portal\r\n * @decorator component\r\n */\r\nexport const XDateRangePortalPrefix = 'x-date-range-portal';\r\n\r\n/**\r\n * PickerDate\r\n * @selector x-picker-date\r\n * @decorator component\r\n */\r\nexport const XPickerDatePrefix = 'x-picker-date';\r\n\r\n/**\r\n * PickerDate Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerDateProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 日期显示模板\r\n   * @en_US Date display template\r\n   */\r\n  @Input() dateTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围选择\r\n   * @en_US Range picker\r\n   */\r\n  @Input() @XInputBoolean() rangePicker?: XBoolean;\r\n  /**\r\n   * @zh_CN 上一年\r\n   * @en_US Last year\r\n   */\r\n  @Input() @XInputBoolean() lastYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Last month\r\n   */\r\n  @Input() @XInputBoolean() lastMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 下一年\r\n   * @en_US Next year\r\n   */\r\n  @Input() @XInputBoolean() nextYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Next month\r\n   */\r\n  @Input() @XInputBoolean() nextMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围日期\r\n   * @en_US Range date\r\n   */\r\n  @Input() rangeValue: number[] = [];\r\n  /**\r\n   * @zh_CN 当前选择的是开始/结束日期\r\n   * @en_US The current choice is the start / end date\r\n   */\r\n  @Input() rangeType!: XDatePickerRangType;\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n  /**\r\n   * @zh_CN 选年的事件\r\n   * @en_US Year change event\r\n   */\r\n  @Output() yearChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 选月的事件\r\n   * @en_US Month change event\r\n   */\r\n  @Output() monthChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 显示日期事件\r\n   * @en_US display date event\r\n   */\r\n  @Output() displayChange = new EventEmitter<Date>();\r\n}\r\n\r\n/**\r\n * @zh_CN 当前选择的是开始/结束日期\r\n * @en_US The current choice is the start / end date\r\n */\r\nexport type XDatePickerRangType = 'start' | 'end';\r\n\r\n/**\r\n * PickerMonth\r\n * @selector x-picker-month\r\n * @decorator component\r\n */\r\nexport const XPickerMonthPrefix = 'x-picker-month';\r\n\r\n/**\r\n * PickerMonth Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerMonthProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 月份显示模板\r\n   * @en_US Month display template\r\n   */\r\n  @Input() monthTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n}\r\n\r\n/**\r\n * PickerYear\r\n * @selector x-picker-year\r\n * @decorator component\r\n */\r\nexport const XPickerYearPrefix = 'x-picker-year';\r\n\r\n/**\r\n * PickerYear Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerYearProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 开始年份变化的事件\r\n   * @en_US Start year change event\r\n   */\r\n  @Output() startChange = new EventEmitter<number>();\r\n}\r\n"]}
463
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker.property.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  XInputBoolean,\r\n  XProperty,\r\n  XBoolean,\r\n  XCorner,\r\n  XWithConfig,\r\n  XSize,\r\n  XTemplate,\r\n  XDataConvert,\r\n  XData,\r\n  XIdentityProperty\r\n} from '@ng-nest/ui/core';\r\nimport { Input, EventEmitter, Output, TemplateRef, Component } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * DatePicker\r\n * @selector x-date-picker\r\n * @decorator component\r\n */\r\nexport const XDatePickerPrefix = 'x-date-picker';\r\nconst X_CONFIG_NAME = 'datePicker';\r\n\r\n/**\r\n * DatePicker Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDatePickerProperty extends XControlValueAccessor<any> implements XDatePickerOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number>();\r\n}\r\n\r\n/**\r\n * DatePicker Option\r\n * @undocument true\r\n */\r\nexport interface XDatePickerOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Choose a type\r\n   */\r\n  type?: XDatePickerType;\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 前置标签\r\n   * @en_US Before label\r\n   */\r\n  before?: XTemplate;\r\n  /**\r\n   * @zh_CN 后置标签\r\n   * @en_US After label\r\n   */\r\n  after?: XTemplate;\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  nodeClick?: (value: number) => void;\r\n}\r\n\r\n/**\r\n * DateRange\r\n * @selector x-date-range\r\n * @decorator component\r\n */\r\nexport const XDateRangePrefix = 'x-date-range';\r\nconst X_CONFIG_RANGE_NAME = 'dateRange';\r\n\r\n/**\r\n * DateRange Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDateRangeProperty extends XControlValueAccessor<any> implements XDateRangeOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_RANGE_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_RANGE_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_RANGE_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number[]>();\r\n}\r\n\r\n/**\r\n * DateRange Option\r\n * @undocument true\r\n */\r\nexport interface XDateRangeOption extends XFormOption {\r\n  /**\r\n   * @zh_CN tab 键控制次序\r\n   * @en_US Tab key control order\r\n   */\r\n  tabindex?: number;\r\n}\r\n\r\n/**\r\n * @zh_CN 快捷选择按钮\r\n * @en_US Quick selection button\r\n */\r\nexport interface XDatePickerPreset extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 自定义函数\r\n   * @en_US Custom function\r\n   */\r\n  func: () => Date;\r\n}\r\n\r\n/**\r\n * @zh_CN 日期选择类型\r\n * @en_US Date selection type\r\n */\r\nexport type XDatePickerType = 'date' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';\r\n\r\n/**\r\n * @zh_CN 日期数据类型\r\n * @en_US Date data type\r\n */\r\nexport type XDatePickerModelType = 'date' | 'number' | 'string';\r\n\r\n/**\r\n * DatePicker Portal\r\n * @selector x-date-picker-portal\r\n * @decorator component\r\n */\r\nexport const XDatePickerPortalPrefix = 'x-date-picker-portal';\r\n\r\n/**\r\n * DateRange Portal\r\n * @selector x-date-range-portal\r\n * @decorator component\r\n */\r\nexport const XDateRangePortalPrefix = 'x-date-range-portal';\r\n\r\n/**\r\n * PickerDate\r\n * @selector x-picker-date\r\n * @decorator component\r\n */\r\nexport const XPickerDatePrefix = 'x-picker-date';\r\n\r\n/**\r\n * PickerDate Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerDateProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date | null;\r\n  /**\r\n   * @zh_CN 日期显示模板\r\n   * @en_US Date display template\r\n   */\r\n  @Input() dateTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围选择\r\n   * @en_US Range picker\r\n   */\r\n  @Input() @XInputBoolean() rangePicker?: XBoolean;\r\n  /**\r\n   * @zh_CN 上一年\r\n   * @en_US Last year\r\n   */\r\n  @Input() @XInputBoolean() lastYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Last month\r\n   */\r\n  @Input() @XInputBoolean() lastMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 下一年\r\n   * @en_US Next year\r\n   */\r\n  @Input() @XInputBoolean() nextYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Next month\r\n   */\r\n  @Input() @XInputBoolean() nextMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围日期\r\n   * @en_US Range date\r\n   */\r\n  @Input() rangeValue: (number | null)[] = [];\r\n  /**\r\n   * @zh_CN 当前选择的是开始/结束日期\r\n   * @en_US The current choice is the start / end date\r\n   */\r\n  @Input() rangeType!: XDatePickerRangType;\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n  /**\r\n   * @zh_CN 选年的事件\r\n   * @en_US Year change event\r\n   */\r\n  @Output() yearChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 选月的事件\r\n   * @en_US Month change event\r\n   */\r\n  @Output() monthChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 显示日期事件\r\n   * @en_US display date event\r\n   */\r\n  @Output() displayChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 范围日期 mouseenter 事件\r\n   * @en_US Date mouseenter event\r\n   */\r\n  @Output() rangeTdMouseenter = new EventEmitter<XDateCell>();\r\n  /**\r\n   * @zh_CN 范围日期 mouseleave 事件\r\n   * @en_US Date mouseleave event\r\n   */\r\n  @Output() rangeTdMouseleave = new EventEmitter<XDateCell>();\r\n  /**\r\n   * @zh_CN 范围中的日期点击事件\r\n   * @en_US Range date click event\r\n   */\r\n  @Output() rangeDateClick = new EventEmitter<XDateCell>();\r\n}\r\n\r\n/**\r\n * @zh_CN 单个日期数据对象\r\n * @en_US 单个日期数据对象\r\n */\r\nexport interface XDateCell {\r\n  /**\r\n   * @zh_CN 日期\r\n   * @en_US Date\r\n   */\r\n  date?: Date;\r\n  /**\r\n   * @zh_CN 上个月或下个月的日期\r\n   * @en_US Date of the previous or next month\r\n   */\r\n  isLastOrNext?: boolean;\r\n  /**\r\n   * @zh_CN 当天\r\n   * @en_US Same day\r\n   */\r\n  isNow?: boolean;\r\n  /**\r\n   * @zh_CN 当月第一天\r\n   * @en_US The first day of the month\r\n   */\r\n  isFirstDay?: boolean;\r\n  /**\r\n   * @zh_CN 当月最后一天\r\n   * @en_US The last day of the month\r\n   */\r\n  isLastDay?: boolean;\r\n  /**\r\n   * @zh_CN 范围内日期\r\n   * @en_US 范围内日期\r\n   */\r\n  isInRange?: boolean;\r\n  /**\r\n   * @zh_CN 范围内 hover 选中\r\n   * @en_US 范围内 hover 选中\r\n   */\r\n  isInRangeHover?: boolean;\r\n  /**\r\n   * @zh_CN 范围内 hover 当前日期左边\r\n   * @en_US 范围内 hover 当前日期左边\r\n   */\r\n  isInRangeHoverLeft?: boolean;\r\n  /**\r\n   * @zh_CN 范围内 hover 当前日期右边\r\n   * @en_US 范围内 hover 当前日期右边\r\n   */\r\n  isInRangeHoverRight?: boolean;\r\n  /**\r\n   * @zh_CN 选中开始左边\r\n   * @en_US Range start left\r\n   */\r\n  isRangeStartLeft?: boolean;\r\n  /**\r\n   * @zh_CN 选中开始右边\r\n   * @en_US Range start right\r\n   */\r\n  isRangeStartRight?: boolean;\r\n  /**\r\n   * @zh_CN 选中结束左边\r\n   * @en_US Range start left\r\n   */\r\n  isRangeEndLeft?: boolean;\r\n  /**\r\n   * @zh_CN 选中结束右边\r\n   * @en_US Range start right\r\n   */\r\n  isRangeEndRight?: boolean;\r\n  /**\r\n   * @zh_CN 范围 hover\r\n   * @en_US Range hover\r\n   */\r\n  isRangeHover?: boolean;\r\n  /**\r\n   * @zh_CN hover 当前开始\r\n   * @en_US Range hover start\r\n   */\r\n  isRangeHoverStart?: boolean;\r\n  /**\r\n   * @zh_CN hover 当前结束\r\n   * @en_US End date\r\n   */\r\n  isRangeHoverEnd?: boolean;\r\n  /**\r\n   * @zh_CN hover 开始左边\r\n   * @en_US Range hover start left\r\n   */\r\n  isRangeHoverStartLeft?: boolean;\r\n  /**\r\n   * @zh_CN hover 开始右边\r\n   * @en_US Range hover start right\r\n   */\r\n  isRangeHoverStartRight?: boolean;\r\n  /**\r\n   * @zh_CN hover 结束左边\r\n   * @en_US Range hover end left\r\n   */\r\n  isRangeHoverEndLeft?: boolean;\r\n  /**\r\n   * @zh_CN hover 结束右边\r\n   * @en_US Range hover end right\r\n   */\r\n  isRangeHoverEndRight?: boolean;\r\n  /**\r\n   * @zh_CN 当前选中日期\r\n   * @en_US Current selected date\r\n   */\r\n  isActive?: boolean;\r\n}\r\n\r\n/**\r\n * @zh_CN 当前选择的是开始/结束日期\r\n * @en_US The current choice is the start / end date\r\n */\r\nexport type XDatePickerRangType = 'start' | 'end';\r\n\r\n/**\r\n * PickerMonth\r\n * @selector x-picker-month\r\n * @decorator component\r\n */\r\nexport const XPickerMonthPrefix = 'x-picker-month';\r\n\r\n/**\r\n * PickerMonth Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerMonthProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 月份显示模板\r\n   * @en_US Month display template\r\n   */\r\n  @Input() monthTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n}\r\n\r\n/**\r\n * PickerYear\r\n * @selector x-picker-year\r\n * @decorator component\r\n */\r\nexport const XPickerYearPrefix = 'x-picker-year';\r\n\r\n/**\r\n * PickerYear Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerYearProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 开始年份变化的事件\r\n   * @en_US Start year change event\r\n   */\r\n  @Output() startChange = new EventEmitter<number>();\r\n}\r\n"]}