ngx-tethys 18.2.10 → 18.2.11

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 (50) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/date-picker/abstract-picker.component.d.ts +6 -1
  3. package/date-picker/base-picker.component.d.ts +1 -1
  4. package/date-picker/lib/calendar/calendar-footer.component.d.ts +2 -1
  5. package/date-picker/lib/calendar/calendar-table.component.d.ts +4 -3
  6. package/date-picker/lib/popups/date-popup.component.d.ts +2 -1
  7. package/date-picker/lib/popups/inner-popup.component.d.ts +2 -1
  8. package/date-picker/picker.component.d.ts +2 -1
  9. package/date-picker/picker.util.d.ts +5 -5
  10. package/esm2022/date-picker/abstract-picker.component.mjs +16 -28
  11. package/esm2022/date-picker/base-picker.component.mjs +17 -13
  12. package/esm2022/date-picker/date-picker.component.mjs +3 -3
  13. package/esm2022/date-picker/lib/calendar/calendar-footer.component.mjs +7 -5
  14. package/esm2022/date-picker/lib/calendar/calendar-table.component.mjs +5 -3
  15. package/esm2022/date-picker/lib/date/date-table.component.mjs +2 -2
  16. package/esm2022/date-picker/lib/popups/date-popup.component.mjs +29 -45
  17. package/esm2022/date-picker/lib/popups/inner-popup.component.mjs +7 -5
  18. package/esm2022/date-picker/month-picker.component.mjs +3 -3
  19. package/esm2022/date-picker/picker.component.mjs +9 -4
  20. package/esm2022/date-picker/picker.util.mjs +21 -15
  21. package/esm2022/date-picker/quarter-picker.component.mjs +3 -3
  22. package/esm2022/date-picker/range-picker.component.mjs +3 -3
  23. package/esm2022/date-picker/week-picker.component.mjs +3 -3
  24. package/esm2022/date-picker/year-picker.component.mjs +3 -3
  25. package/esm2022/i18n/i18n.service.mjs +3 -6
  26. package/esm2022/i18n/locale.mjs +17 -2
  27. package/esm2022/time-picker/inner/inner-time-picker.component.mjs +13 -11
  28. package/esm2022/time-picker/inner/inner-time-picker.store.mjs +16 -16
  29. package/esm2022/time-picker/time-picker.utils.mjs +14 -14
  30. package/esm2022/util/date/tiny-date.mjs +20 -4
  31. package/esm2022/util/helpers/helpers.mjs +13 -1
  32. package/esm2022/version.mjs +2 -2
  33. package/fesm2022/ngx-tethys-date-picker.mjs +113 -120
  34. package/fesm2022/ngx-tethys-date-picker.mjs.map +1 -1
  35. package/fesm2022/ngx-tethys-i18n.mjs +17 -5
  36. package/fesm2022/ngx-tethys-i18n.mjs.map +1 -1
  37. package/fesm2022/ngx-tethys-time-picker.mjs +40 -38
  38. package/fesm2022/ngx-tethys-time-picker.mjs.map +1 -1
  39. package/fesm2022/ngx-tethys-util.mjs +419 -391
  40. package/fesm2022/ngx-tethys-util.mjs.map +1 -1
  41. package/fesm2022/ngx-tethys.mjs +1 -1
  42. package/fesm2022/ngx-tethys.mjs.map +1 -1
  43. package/i18n/locale.d.ts +7 -1
  44. package/package.json +2 -1
  45. package/schematics/version.d.ts +1 -1
  46. package/schematics/version.js +1 -1
  47. package/time-picker/inner/inner-time-picker.component.d.ts +3 -1
  48. package/time-picker/inner/inner-time-picker.store.d.ts +5 -5
  49. package/time-picker/time-picker.utils.d.ts +5 -5
  50. package/util/helpers/helpers.d.ts +1 -0
@@ -1,12 +1,12 @@
1
1
  import { ThyClickDispatcher } from 'ngx-tethys/core';
2
2
  import { elementMatchClosest, TinyDate } from 'ngx-tethys/util';
3
- import { Component, ElementRef, EventEmitter, Input, NgZone, Output, PLATFORM_ID, ViewChild, inject } from '@angular/core';
3
+ import { Component, ElementRef, EventEmitter, inject, Input, NgZone, Output, PLATFORM_ID, ViewChild } from '@angular/core';
4
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
5
+ import { isPlatformBrowser } from '@angular/common';
6
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
7
  import { AbstractPickerComponent } from './abstract-picker.component';
5
8
  import { ThyPicker } from './picker.component';
6
9
  import { hasTimeInStringDate, isValidStringDate, parseStringDate, transformDateValue } from './picker.util';
7
- import { isPlatformBrowser } from '@angular/common';
8
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
9
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
10
10
  import * as i0 from "@angular/core";
11
11
  /**
12
12
  * @private
@@ -104,15 +104,19 @@ export class BasePicker extends AbstractPickerComponent {
104
104
  return;
105
105
  }
106
106
  let value = formatDate;
107
- const valueValid = isValidStringDate(value);
108
- const valueLimitValid = valueValid ? this.isValidDateLimit(parseStringDate(value)) : false;
107
+ const valueValid = isValidStringDate(value, this.thyTimeZone);
108
+ const valueLimitValid = valueValid ? this.isValidDateLimit(parseStringDate(value, this.thyTimeZone)) : false;
109
109
  if (valueValid && valueLimitValid) {
110
110
  this.innerPreviousDate = value;
111
111
  }
112
112
  else {
113
113
  value = this.innerPreviousDate;
114
114
  }
115
- const tinyDate = value ? (this.thyShowTime ? parseStringDate(value) : parseStringDate(value).startOfDay()) : null;
115
+ const tinyDate = value
116
+ ? this.thyShowTime
117
+ ? parseStringDate(value, this.thyTimeZone)
118
+ : parseStringDate(value, this.thyTimeZone).startOfDay()
119
+ : null;
116
120
  this.restoreTimePickerState(tinyDate);
117
121
  super.onValueChange(tinyDate);
118
122
  }
@@ -190,11 +194,11 @@ export class BasePicker extends AbstractPickerComponent {
190
194
  this.onTouchedFn();
191
195
  }
192
196
  onInputDate(value) {
193
- if (value && isValidStringDate(value)) {
197
+ if (value && isValidStringDate(value, this.thyTimeZone)) {
194
198
  if (this.thyShowTime) {
195
- this.withTime = hasTimeInStringDate(value);
199
+ this.withTime = hasTimeInStringDate(value, this.thyTimeZone);
196
200
  }
197
- this.thyValue = parseStringDate(value);
201
+ this.thyValue = parseStringDate(value, this.thyTimeZone);
198
202
  }
199
203
  }
200
204
  isValidDateLimit(date) {
@@ -202,8 +206,8 @@ export class BasePicker extends AbstractPickerComponent {
202
206
  if (this.thyDisabledDate !== undefined) {
203
207
  disable = this.thyDisabledDate(date.nativeDate);
204
208
  }
205
- const minDate = this.thyMinDate ? new TinyDate(transformDateValue(this.thyMinDate).value) : null;
206
- const maxDate = this.thyMaxDate ? new TinyDate(transformDateValue(this.thyMaxDate).value) : null;
209
+ const minDate = this.thyMinDate ? new TinyDate(transformDateValue(this.thyMinDate).value, this.thyTimeZone) : null;
210
+ const maxDate = this.thyMaxDate ? new TinyDate(transformDateValue(this.thyMaxDate).value, this.thyTimeZone) : null;
207
211
  return ((!minDate || date.startOfDay().nativeDate >= minDate.startOfDay().nativeDate) &&
208
212
  (!maxDate || date.startOfDay().nativeDate <= maxDate.startOfDay().nativeDate) &&
209
213
  !disable);
@@ -246,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
246
250
  }], thyOnOk: [{
247
251
  type: Output
248
252
  }] } });
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-picker.component.js","sourceRoot":"","sources":["../../../../src/date-picker/base-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThyClickDispatcher, ThyPlacement } from 'ngx-tethys/core';\nimport { elementMatchClosest, FunctionProp, TinyDate } from 'ngx-tethys/util';\n\nimport {\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    TemplateRef,\n    ViewChild,\n    inject\n} from '@angular/core';\n\nimport { AbstractPickerComponent } from './abstract-picker.component';\nimport { CompatibleValue, RangeAdvancedValue } from './inner-types';\nimport { CompatibleDate, ThyPanelMode } from './standard-types';\nimport { ThyPicker } from './picker.component';\nimport { hasTimeInStringDate, isValidStringDate, parseStringDate, transformDateValue } from './picker.util';\nimport { isPlatformBrowser } from '@angular/common';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\n/**\n * @private\n */\n@Component({\n    template: ``,\n    standalone: true,\n    host: {\n        '[attr.tabindex]': `tabIndex`,\n        '(focus)': 'onFocus($event)',\n        '(blur)': 'onBlur($event)'\n    }\n})\nexport class BasePicker extends AbstractPickerComponent implements OnInit, OnChanges {\n    protected element = inject(ElementRef);\n\n    showWeek = false;\n\n    panelMode: ThyPanelMode | ThyPanelMode[];\n\n    initialized: boolean;\n\n    private innerPreviousDate: string;\n\n    @ViewChild('thyPicker', { static: true }) thyPicker: ThyPicker;\n\n    @Input() thyDateRender: FunctionProp<TemplateRef<Date> | string>;\n\n    @Input() set thyMode(value: ThyPanelMode) {\n        this._panelMode = value ?? 'date';\n        if (this.initialized) {\n            this.setDefaultTimePickerState(this._panelMode);\n        }\n    }\n\n    get thyMode() {\n        return this._panelMode;\n    }\n\n    /**\n     * 是否有幕布\n     * @default true\n     */\n    @Input({ transform: coerceBooleanProperty }) thyHasBackdrop = true;\n\n    /**\n     * @type EventEmitter<ThyPanelMode | ThyPanelMode[]>\n     */\n    @Output() readonly thyOnPanelChange = new EventEmitter<ThyPanelMode | ThyPanelMode[]>();\n\n    /**\n     * @type EventEmitter<Date[]>\n     */\n    @Output() readonly thyOnCalendarChange = new EventEmitter<Date[]>();\n\n    private _showTime: object | boolean;\n\n    /**\n     * 增加时间选择功能\n     * @default false\n     */\n    @Input() get thyShowTime(): object | boolean {\n        return this._showTime;\n    }\n    set thyShowTime(value: object | boolean) {\n        this._showTime = typeof value === 'object' ? value : coerceBooleanProperty(value);\n    }\n\n    /**\n     * 是否展示时间(时、分)\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty }) thyMustShowTime = false;\n\n    /**\n     * 弹出位置\n     * @type top | topLeft | topRight | bottom | bottomLeft | bottomRight | left | leftTop | leftBottom | right | rightTop | rightBottom\n     */\n    @Input() thyPlacement: ThyPlacement = 'bottomLeft';\n\n    /**\n     * @type EventEmitter<CompatibleDate | null>\n     */\n    @Output() readonly thyOnOk = new EventEmitter<CompatibleDate | null>();\n\n    takeUntilDestroyed = takeUntilDestroyed();\n\n    thyClickDispatcher = inject(ThyClickDispatcher);\n\n    platformId = inject(PLATFORM_ID);\n\n    ngZone = inject(NgZone);\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.setDefaultTimePickerState(this._panelMode);\n        this.initialized = true;\n\n        if (isPlatformBrowser(this.platformId)) {\n            this.thyClickDispatcher\n                .clicked(0)\n                .pipe(this.takeUntilDestroyed)\n                .subscribe((event: Event) => {\n                    if (\n                        !this.element.nativeElement.contains(event.target) &&\n                        !this.thyPicker?.overlayContainer?.nativeElement.contains(event.target as Node) &&\n                        this.realOpenState\n                    ) {\n                        this.ngZone.run(() => {\n                            this.closeOverlay();\n                            this.cdr.markForCheck();\n                        });\n                    }\n                });\n        }\n    }\n\n    onValueChange(value: CompatibleValue | RangeAdvancedValue): void {\n        this.thyPicker.entering = false;\n        this.restoreTimePickerState(value as CompatibleValue);\n        super.onValueChange(value);\n        if (!this.flexible) {\n            this.closeOverlay();\n        }\n        this.innerPreviousDate = this.thyPicker.getReadableValue(this.thyValue);\n    }\n\n    onInputValueChange(formatDate: string | null | Array<null>) {\n        if (!formatDate || !formatDate.length) {\n            const compatibleValue = formatDate ? (formatDate as CompatibleValue) : null;\n            this.restoreTimePickerState(compatibleValue);\n            super.onValueChange(compatibleValue);\n            return;\n        }\n        let value = formatDate as string;\n        const valueValid = isValidStringDate(value);\n        const valueLimitValid = valueValid ? this.isValidDateLimit(parseStringDate(value)) : false;\n        if (valueValid && valueLimitValid) {\n            this.innerPreviousDate = value;\n        } else {\n            value = this.innerPreviousDate;\n        }\n        const tinyDate = value ? (this.thyShowTime ? parseStringDate(value) : parseStringDate(value).startOfDay()) : null;\n        this.restoreTimePickerState(tinyDate);\n        super.onValueChange(tinyDate);\n    }\n\n    // Displays the time directly when the time must be displayed by default\n    setDefaultTimePickerState(value: ThyPanelMode) {\n        this.withTime = this.thyMustShowTime;\n        if (this.isRange) {\n            this.panelMode = this.flexible ? ['date', 'date'] : [value, value];\n        } else {\n            this.panelMode = value;\n        }\n        this.showWeek = value === 'week';\n        if (!this.thyFormat) {\n            const inputFormats: { [key in ThyPanelMode]?: string } = {\n                year: 'yyyy',\n                quarter: 'yyyy-qqq',\n                month: 'yyyy-MM',\n                week: this.locale().weekThFormat,\n                date: this.thyShowTime ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd'\n            };\n            this.thyFormat = this.flexible ? inputFormats['date'] : inputFormats[value];\n        }\n    }\n\n    // Restore after clearing time to select whether the original picker time is displayed or not\n    restoreTimePickerState(value: CompatibleValue | null) {\n        if (!value) {\n            this.withTime = this.thyMustShowTime || this.originWithTime;\n        }\n    }\n\n    // Emit thyOnCalendarChange when select date by thy-range-picker\n    onCalendarChange(value: TinyDate[]): void {\n        if (this.isRange) {\n            const rangeValue = value.map(x => x.nativeDate);\n            this.thyOnCalendarChange.emit(rangeValue);\n        }\n    }\n\n    onShowTimePickerChange(show: boolean): void {\n        this.withTime = show;\n    }\n\n    onResultOk(): void {\n        if (this.isRange) {\n            const value = this.thyValue as TinyDate[];\n            if (value.length) {\n                this.thyOnOk.emit([value[0].nativeDate, value[1].nativeDate]);\n            } else {\n                this.thyOnOk.emit([]);\n            }\n        } else {\n            if (this.thyValue) {\n                this.thyOnOk.emit((this.thyValue as TinyDate).nativeDate);\n            } else {\n                this.thyOnOk.emit(null);\n            }\n        }\n        this.closeOverlay();\n    }\n\n    onOpenChange(open: boolean): void {\n        this.thyOpenChange.emit(open);\n        if (!open) {\n            this.onTouchedFn();\n        }\n    }\n\n    onFocus(event: Event) {\n        this.picker.focus();\n    }\n\n    onBlur(event?: FocusEvent) {\n        // Tab 聚焦后自动聚焦到 input 输入框，此分支下直接返回，无需触发 onTouchedFn\n        if (elementMatchClosest(event?.relatedTarget as HTMLElement, ['date-popup', 'thy-picker'])) {\n            return;\n        }\n        this.onTouchedFn();\n    }\n\n    onInputDate(value: string) {\n        if (value && isValidStringDate(value)) {\n            if (this.thyShowTime) {\n                this.withTime = hasTimeInStringDate(value);\n            }\n            this.thyValue = parseStringDate(value);\n        }\n    }\n\n    private isValidDateLimit(date: TinyDate): boolean {\n        let disable = false;\n        if (this.thyDisabledDate !== undefined) {\n            disable = this.thyDisabledDate(date.nativeDate);\n        }\n        const minDate = this.thyMinDate ? new TinyDate(transformDateValue(this.thyMinDate).value as Date) : null;\n        const maxDate = this.thyMaxDate ? new TinyDate(transformDateValue(this.thyMaxDate).value as Date) : null;\n        return (\n            (!minDate || date.startOfDay().nativeDate >= minDate.startOfDay().nativeDate) &&\n            (!maxDate || date.startOfDay().nativeDate <= maxDate.startOfDay().nativeDate) &&\n            !disable\n        );\n    }\n}\n"]}
253
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-picker.component.js","sourceRoot":"","sources":["../../../../src/date-picker/base-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ThyClickDispatcher, ThyPlacement } from 'ngx-tethys/core';\nimport { elementMatchClosest, FunctionProp, TinyDate } from 'ngx-tethys/util';\n\nimport {\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { isPlatformBrowser } from '@angular/common';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AbstractPickerComponent } from './abstract-picker.component';\nimport { CompatibleValue, RangeAdvancedValue } from './inner-types';\nimport { ThyPicker } from './picker.component';\nimport { hasTimeInStringDate, isValidStringDate, parseStringDate, transformDateValue } from './picker.util';\nimport { CompatibleDate, ThyPanelMode } from './standard-types';\n\n/**\n * @private\n */\n@Component({\n    template: ``,\n    standalone: true,\n    host: {\n        '[attr.tabindex]': `tabIndex`,\n        '(focus)': 'onFocus($event)',\n        '(blur)': 'onBlur($event)'\n    }\n})\nexport class BasePicker extends AbstractPickerComponent implements OnInit, OnChanges {\n    protected element = inject(ElementRef);\n\n    showWeek = false;\n\n    panelMode: ThyPanelMode | ThyPanelMode[];\n\n    initialized: boolean;\n\n    private innerPreviousDate: string;\n\n    @ViewChild('thyPicker', { static: true }) thyPicker: ThyPicker;\n\n    @Input() thyDateRender: FunctionProp<TemplateRef<Date> | string>;\n\n    @Input() set thyMode(value: ThyPanelMode) {\n        this._panelMode = value ?? 'date';\n        if (this.initialized) {\n            this.setDefaultTimePickerState(this._panelMode);\n        }\n    }\n\n    get thyMode() {\n        return this._panelMode;\n    }\n\n    /**\n     * 是否有幕布\n     * @default true\n     */\n    @Input({ transform: coerceBooleanProperty }) thyHasBackdrop = true;\n\n    /**\n     * @type EventEmitter<ThyPanelMode | ThyPanelMode[]>\n     */\n    @Output() readonly thyOnPanelChange = new EventEmitter<ThyPanelMode | ThyPanelMode[]>();\n\n    /**\n     * @type EventEmitter<Date[]>\n     */\n    @Output() readonly thyOnCalendarChange = new EventEmitter<Date[]>();\n\n    private _showTime: object | boolean;\n\n    /**\n     * 增加时间选择功能\n     * @default false\n     */\n    @Input() get thyShowTime(): object | boolean {\n        return this._showTime;\n    }\n    set thyShowTime(value: object | boolean) {\n        this._showTime = typeof value === 'object' ? value : coerceBooleanProperty(value);\n    }\n\n    /**\n     * 是否展示时间(时、分)\n     * @default false\n     */\n    @Input({ transform: coerceBooleanProperty }) thyMustShowTime = false;\n\n    /**\n     * 弹出位置\n     * @type top | topLeft | topRight | bottom | bottomLeft | bottomRight | left | leftTop | leftBottom | right | rightTop | rightBottom\n     */\n    @Input() thyPlacement: ThyPlacement = 'bottomLeft';\n\n    /**\n     * @type EventEmitter<CompatibleDate | null>\n     */\n    @Output() readonly thyOnOk = new EventEmitter<CompatibleDate | null>();\n\n    takeUntilDestroyed = takeUntilDestroyed();\n\n    thyClickDispatcher = inject(ThyClickDispatcher);\n\n    platformId = inject(PLATFORM_ID);\n\n    ngZone = inject(NgZone);\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.setDefaultTimePickerState(this._panelMode);\n        this.initialized = true;\n\n        if (isPlatformBrowser(this.platformId)) {\n            this.thyClickDispatcher\n                .clicked(0)\n                .pipe(this.takeUntilDestroyed)\n                .subscribe((event: Event) => {\n                    if (\n                        !this.element.nativeElement.contains(event.target) &&\n                        !this.thyPicker?.overlayContainer?.nativeElement.contains(event.target as Node) &&\n                        this.realOpenState\n                    ) {\n                        this.ngZone.run(() => {\n                            this.closeOverlay();\n                            this.cdr.markForCheck();\n                        });\n                    }\n                });\n        }\n    }\n\n    onValueChange(value: CompatibleValue | RangeAdvancedValue): void {\n        this.thyPicker.entering = false;\n        this.restoreTimePickerState(value as CompatibleValue);\n        super.onValueChange(value);\n        if (!this.flexible) {\n            this.closeOverlay();\n        }\n        this.innerPreviousDate = this.thyPicker.getReadableValue(this.thyValue);\n    }\n\n    onInputValueChange(formatDate: string | null | Array<null>) {\n        if (!formatDate || !formatDate.length) {\n            const compatibleValue = formatDate ? (formatDate as CompatibleValue) : null;\n            this.restoreTimePickerState(compatibleValue);\n            super.onValueChange(compatibleValue);\n            return;\n        }\n        let value = formatDate as string;\n        const valueValid = isValidStringDate(value, this.thyTimeZone);\n        const valueLimitValid = valueValid ? this.isValidDateLimit(parseStringDate(value, this.thyTimeZone)) : false;\n        if (valueValid && valueLimitValid) {\n            this.innerPreviousDate = value;\n        } else {\n            value = this.innerPreviousDate;\n        }\n        const tinyDate = value\n            ? this.thyShowTime\n                ? parseStringDate(value, this.thyTimeZone)\n                : parseStringDate(value, this.thyTimeZone).startOfDay()\n            : null;\n        this.restoreTimePickerState(tinyDate);\n        super.onValueChange(tinyDate);\n    }\n\n    // Displays the time directly when the time must be displayed by default\n    setDefaultTimePickerState(value: ThyPanelMode) {\n        this.withTime = this.thyMustShowTime;\n        if (this.isRange) {\n            this.panelMode = this.flexible ? ['date', 'date'] : [value, value];\n        } else {\n            this.panelMode = value;\n        }\n        this.showWeek = value === 'week';\n        if (!this.thyFormat) {\n            const inputFormats: { [key in ThyPanelMode]?: string } = {\n                year: 'yyyy',\n                quarter: 'yyyy-qqq',\n                month: 'yyyy-MM',\n                week: this.locale().weekThFormat,\n                date: this.thyShowTime ? 'yyyy-MM-dd HH:mm' : 'yyyy-MM-dd'\n            };\n            this.thyFormat = this.flexible ? inputFormats['date'] : inputFormats[value];\n        }\n    }\n\n    // Restore after clearing time to select whether the original picker time is displayed or not\n    restoreTimePickerState(value: CompatibleValue | null) {\n        if (!value) {\n            this.withTime = this.thyMustShowTime || this.originWithTime;\n        }\n    }\n\n    // Emit thyOnCalendarChange when select date by thy-range-picker\n    onCalendarChange(value: TinyDate[]): void {\n        if (this.isRange) {\n            const rangeValue = value.map(x => x.nativeDate);\n            this.thyOnCalendarChange.emit(rangeValue);\n        }\n    }\n\n    onShowTimePickerChange(show: boolean): void {\n        this.withTime = show;\n    }\n\n    onResultOk(): void {\n        if (this.isRange) {\n            const value = this.thyValue as TinyDate[];\n            if (value.length) {\n                this.thyOnOk.emit([value[0].nativeDate, value[1].nativeDate]);\n            } else {\n                this.thyOnOk.emit([]);\n            }\n        } else {\n            if (this.thyValue) {\n                this.thyOnOk.emit((this.thyValue as TinyDate).nativeDate);\n            } else {\n                this.thyOnOk.emit(null);\n            }\n        }\n        this.closeOverlay();\n    }\n\n    onOpenChange(open: boolean): void {\n        this.thyOpenChange.emit(open);\n        if (!open) {\n            this.onTouchedFn();\n        }\n    }\n\n    onFocus(event: Event) {\n        this.picker.focus();\n    }\n\n    onBlur(event?: FocusEvent) {\n        // Tab 聚焦后自动聚焦到 input 输入框，此分支下直接返回，无需触发 onTouchedFn\n        if (elementMatchClosest(event?.relatedTarget as HTMLElement, ['date-popup', 'thy-picker'])) {\n            return;\n        }\n        this.onTouchedFn();\n    }\n\n    onInputDate(value: string) {\n        if (value && isValidStringDate(value, this.thyTimeZone)) {\n            if (this.thyShowTime) {\n                this.withTime = hasTimeInStringDate(value, this.thyTimeZone);\n            }\n            this.thyValue = parseStringDate(value, this.thyTimeZone);\n        }\n    }\n\n    private isValidDateLimit(date: TinyDate): boolean {\n        let disable = false;\n        if (this.thyDisabledDate !== undefined) {\n            disable = this.thyDisabledDate(date.nativeDate);\n        }\n        const minDate = this.thyMinDate ? new TinyDate(transformDateValue(this.thyMinDate).value as Date, this.thyTimeZone) : null;\n        const maxDate = this.thyMaxDate ? new TinyDate(transformDateValue(this.thyMaxDate).value as Date, this.thyTimeZone) : null;\n        return (\n            (!minDate || date.startOfDay().nativeDate >= minDate.startOfDay().nativeDate) &&\n            (!maxDate || date.startOfDay().nativeDate <= maxDate.startOfDay().nativeDate) &&\n            !disable\n        );\n    }\n}\n"]}
@@ -24,7 +24,7 @@ export class ThyDatePicker extends BasePicker {
24
24
  multi: true,
25
25
  useExisting: forwardRef(() => ThyDatePicker)
26
26
  }
27
- ], exportAs: ["thyDatePicker"], usesInheritance: true, ngImport: i0, template: "<thy-picker\n #thyPicker\n [isRange]=\"isRange\"\n [value]=\"thyValue\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n (valueChange)=\"onInputValueChange($event)\"\n [open]=\"thyOpen\"\n [disabled]=\"thyDisabled\"\n [format]=\"thyFormat\"\n [separator]=\"separator()\"\n [mode]=\"thyMode\"\n [allowClear]=\"thyAllowClear\"\n [className]=\"thyOriginClassName\"\n [autoFocus]=\"thyAutoFocus\"\n [placeholder]=\"thyPlaceHolder\"\n [readonly]=\"thyReadonly\"\n [size]=\"thySize\"\n [suffixIcon]=\"thySuffixIcon\"\n [placement]=\"thyPlacement\"\n [hasBackdrop]=\"thyHasBackdrop\"\n (openChange)=\"onOpenChange($event)\"\n (blur)=\"onBlur($event)\"\n (inputChange)=\"onInputDate($event)\">\n @if (isShowDatePopup) {\n <date-popup\n [attr.tabindex]=\"-1\"\n [isRange]=\"isRange\"\n [showWeek]=\"showWeek\"\n [panelMode]=\"panelMode\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n [defaultPickerValue]=\"thyDefaultPickerValue\"\n (panelModeChange)=\"thyOnPanelChange.emit($event)\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n [value]=\"thyValue\"\n (valueChange)=\"onValueChange($event)\"\n (calendarChange)=\"onCalendarChange($event)\"\n [showTime]=\"thyShowTime\"\n [mustShowTime]=\"withTime\"\n [format]=\"thyFormat\"\n [dateRender]=\"thyDateRender\"\n [disabledDate]=\"thyDisabledDate\"\n [minDate]=\"thyMinDate\"\n [maxDate]=\"thyMaxDate\"\n [showShortcut]=\"thyShowShortcut\"\n [shortcutPresets]=\"shortcutPresets\"\n [shortcutPosition]=\"shortcutPosition\"\n [timestampPrecision]=\"thyTimestampPrecision\"\n (dateValueChange)=\"onDateValueChange($event)\"\n [className]=\"thyPanelClassName\"\n (resultOk)=\"onResultOk()\"></date-popup>\n }\n</thy-picker>\n", dependencies: [{ kind: "component", type: ThyPicker, selector: "thy-picker", inputs: ["isRange", "open", "disabled", "placeholder", "readonly", "allowClear", "autoFocus", "className", "size", "suffixIcon", "placement", "flexible", "mode", "hasBackdrop", "separator", "format", "flexibleDateGranularity", "value"], outputs: ["blur", "valueChange", "openChange", "inputChange"], exportAs: ["thyPicker"] }, { kind: "component", type: DatePopup, selector: "date-popup", inputs: ["isRange", "showWeek", "format", "disabledDate", "minDate", "maxDate", "showToday", "showTime", "mustShowTime", "dateRender", "className", "panelMode", "value", "defaultPickerValue", "showShortcut", "shortcutPresets", "shortcutPosition", "flexible", "flexibleDateGranularity", "timestampPrecision"], outputs: ["panelModeChange", "calendarChange", "valueChange", "resultOk", "showTimePickerChange", "dateValueChange"], exportAs: ["datePopup"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
27
+ ], exportAs: ["thyDatePicker"], usesInheritance: true, ngImport: i0, template: "<thy-picker\n #thyPicker\n [isRange]=\"isRange\"\n [value]=\"thyValue\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n (valueChange)=\"onInputValueChange($event)\"\n [open]=\"thyOpen\"\n [disabled]=\"thyDisabled\"\n [format]=\"thyFormat\"\n [separator]=\"separator()\"\n [mode]=\"thyMode\"\n [allowClear]=\"thyAllowClear\"\n [className]=\"thyOriginClassName\"\n [autoFocus]=\"thyAutoFocus\"\n [placeholder]=\"thyPlaceHolder\"\n [readonly]=\"thyReadonly\"\n [size]=\"thySize\"\n [timeZone]=\"thyTimeZone\"\n [suffixIcon]=\"thySuffixIcon\"\n [placement]=\"thyPlacement\"\n [hasBackdrop]=\"thyHasBackdrop\"\n (openChange)=\"onOpenChange($event)\"\n (blur)=\"onBlur($event)\"\n (inputChange)=\"onInputDate($event)\">\n @if (isShowDatePopup) {\n <date-popup\n [attr.tabindex]=\"-1\"\n [isRange]=\"isRange\"\n [showWeek]=\"showWeek\"\n [panelMode]=\"panelMode\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n [defaultPickerValue]=\"thyDefaultPickerValue\"\n (panelModeChange)=\"thyOnPanelChange.emit($event)\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n [value]=\"thyValue\"\n (valueChange)=\"onValueChange($event)\"\n (calendarChange)=\"onCalendarChange($event)\"\n [showTime]=\"thyShowTime\"\n [mustShowTime]=\"withTime\"\n [format]=\"thyFormat\"\n [dateRender]=\"thyDateRender\"\n [disabledDate]=\"thyDisabledDate\"\n [minDate]=\"thyMinDate\"\n [maxDate]=\"thyMaxDate\"\n [showShortcut]=\"thyShowShortcut\"\n [shortcutPresets]=\"shortcutPresets\"\n [shortcutPosition]=\"shortcutPosition\"\n [timestampPrecision]=\"thyTimestampPrecision\"\n (dateValueChange)=\"onDateValueChange($event)\"\n [className]=\"thyPanelClassName\"\n (resultOk)=\"onResultOk()\"\n [timeZone]=\"thyTimeZone\"\n ></date-popup>\n }\n</thy-picker>\n", dependencies: [{ kind: "component", type: ThyPicker, selector: "thy-picker", inputs: ["isRange", "open", "disabled", "placeholder", "readonly", "allowClear", "autoFocus", "className", "size", "suffixIcon", "placement", "flexible", "mode", "hasBackdrop", "separator", "timeZone", "format", "flexibleDateGranularity", "value"], outputs: ["blur", "valueChange", "openChange", "inputChange"], exportAs: ["thyPicker"] }, { kind: "component", type: DatePopup, selector: "date-popup", inputs: ["isRange", "showWeek", "format", "disabledDate", "minDate", "maxDate", "showToday", "showTime", "mustShowTime", "dateRender", "className", "panelMode", "value", "defaultPickerValue", "showShortcut", "shortcutPresets", "shortcutPosition", "flexible", "flexibleDateGranularity", "timestampPrecision", "timeZone"], outputs: ["panelModeChange", "calendarChange", "valueChange", "resultOk", "showTimePickerChange", "dateValueChange"], exportAs: ["datePopup"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
28
28
  }
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ThyDatePicker, decorators: [{
30
30
  type: Component,
@@ -36,6 +36,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
36
36
  }
37
37
  ], standalone: true, imports: [ThyPicker, DatePopup], host: {
38
38
  '[attr.tabindex]': 'tabIndex'
39
- }, template: "<thy-picker\n #thyPicker\n [isRange]=\"isRange\"\n [value]=\"thyValue\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n (valueChange)=\"onInputValueChange($event)\"\n [open]=\"thyOpen\"\n [disabled]=\"thyDisabled\"\n [format]=\"thyFormat\"\n [separator]=\"separator()\"\n [mode]=\"thyMode\"\n [allowClear]=\"thyAllowClear\"\n [className]=\"thyOriginClassName\"\n [autoFocus]=\"thyAutoFocus\"\n [placeholder]=\"thyPlaceHolder\"\n [readonly]=\"thyReadonly\"\n [size]=\"thySize\"\n [suffixIcon]=\"thySuffixIcon\"\n [placement]=\"thyPlacement\"\n [hasBackdrop]=\"thyHasBackdrop\"\n (openChange)=\"onOpenChange($event)\"\n (blur)=\"onBlur($event)\"\n (inputChange)=\"onInputDate($event)\">\n @if (isShowDatePopup) {\n <date-popup\n [attr.tabindex]=\"-1\"\n [isRange]=\"isRange\"\n [showWeek]=\"showWeek\"\n [panelMode]=\"panelMode\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n [defaultPickerValue]=\"thyDefaultPickerValue\"\n (panelModeChange)=\"thyOnPanelChange.emit($event)\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n [value]=\"thyValue\"\n (valueChange)=\"onValueChange($event)\"\n (calendarChange)=\"onCalendarChange($event)\"\n [showTime]=\"thyShowTime\"\n [mustShowTime]=\"withTime\"\n [format]=\"thyFormat\"\n [dateRender]=\"thyDateRender\"\n [disabledDate]=\"thyDisabledDate\"\n [minDate]=\"thyMinDate\"\n [maxDate]=\"thyMaxDate\"\n [showShortcut]=\"thyShowShortcut\"\n [shortcutPresets]=\"shortcutPresets\"\n [shortcutPosition]=\"shortcutPosition\"\n [timestampPrecision]=\"thyTimestampPrecision\"\n (dateValueChange)=\"onDateValueChange($event)\"\n [className]=\"thyPanelClassName\"\n (resultOk)=\"onResultOk()\"></date-popup>\n }\n</thy-picker>\n" }]
39
+ }, template: "<thy-picker\n #thyPicker\n [isRange]=\"isRange\"\n [value]=\"thyValue\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n (valueChange)=\"onInputValueChange($event)\"\n [open]=\"thyOpen\"\n [disabled]=\"thyDisabled\"\n [format]=\"thyFormat\"\n [separator]=\"separator()\"\n [mode]=\"thyMode\"\n [allowClear]=\"thyAllowClear\"\n [className]=\"thyOriginClassName\"\n [autoFocus]=\"thyAutoFocus\"\n [placeholder]=\"thyPlaceHolder\"\n [readonly]=\"thyReadonly\"\n [size]=\"thySize\"\n [timeZone]=\"thyTimeZone\"\n [suffixIcon]=\"thySuffixIcon\"\n [placement]=\"thyPlacement\"\n [hasBackdrop]=\"thyHasBackdrop\"\n (openChange)=\"onOpenChange($event)\"\n (blur)=\"onBlur($event)\"\n (inputChange)=\"onInputDate($event)\">\n @if (isShowDatePopup) {\n <date-popup\n [attr.tabindex]=\"-1\"\n [isRange]=\"isRange\"\n [showWeek]=\"showWeek\"\n [panelMode]=\"panelMode\"\n [flexible]=\"flexible\"\n [flexibleDateGranularity]=\"flexibleDateGranularity\"\n [defaultPickerValue]=\"thyDefaultPickerValue\"\n (panelModeChange)=\"thyOnPanelChange.emit($event)\"\n (showTimePickerChange)=\"onShowTimePickerChange($event)\"\n [value]=\"thyValue\"\n (valueChange)=\"onValueChange($event)\"\n (calendarChange)=\"onCalendarChange($event)\"\n [showTime]=\"thyShowTime\"\n [mustShowTime]=\"withTime\"\n [format]=\"thyFormat\"\n [dateRender]=\"thyDateRender\"\n [disabledDate]=\"thyDisabledDate\"\n [minDate]=\"thyMinDate\"\n [maxDate]=\"thyMaxDate\"\n [showShortcut]=\"thyShowShortcut\"\n [shortcutPresets]=\"shortcutPresets\"\n [shortcutPosition]=\"shortcutPosition\"\n [timestampPrecision]=\"thyTimestampPrecision\"\n (dateValueChange)=\"onDateValueChange($event)\"\n [className]=\"thyPanelClassName\"\n (resultOk)=\"onResultOk()\"\n [timeZone]=\"thyTimeZone\"\n ></date-popup>\n }\n</thy-picker>\n" }]
40
40
  }], ctorParameters: () => [] });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9kYXRlLXBpY2tlci9iYXNlLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBRS9DOzs7O0dBSUc7QUFtQkgsTUFBTSxPQUFPLGFBQWMsU0FBUSxVQUFVO0lBS3pDO1FBQ0ksS0FBSyxFQUFFLENBQUM7UUFMWixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRVIsaUJBQVksR0FBRyxlQUFlLEVBQUUsQ0FBQztRQUlyQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQ3RELENBQUM7K0dBUlEsYUFBYTttR0FBYixhQUFhLHFIQWJYO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUM7YUFDL0M7U0FDSiw4RUN4QkwsbzNEQXNEQSw0Q0Q1QmMsU0FBUyw0WEFBRSxTQUFTOzs0RkFLckIsYUFBYTtrQkFsQnpCLFNBQVM7c0NBQ1csdUJBQXVCLENBQUMsTUFBTSxZQUNyQyxpQkFBaUIsWUFDakIsZUFBZSxhQUVkO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLEtBQUssRUFBRSxJQUFJOzRCQUNYLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGNBQWMsQ0FBQzt5QkFDL0M7cUJBQ0osY0FDVyxJQUFJLFdBQ1AsQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLFFBQ3pCO3dCQUNGLGlCQUFpQixFQUFFLFVBQVU7cUJBQ2hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IHVzZUhvc3RSZW5kZXJlciB9IGZyb20gJ0B0ZXRoeXMvY2RrL2RvbSc7XG5cbmltcG9ydCB7IEJhc2VQaWNrZXIgfSBmcm9tICcuL2Jhc2UtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRlUG9wdXAgfSBmcm9tICcuL2xpYi9wb3B1cHMvZGF0ZS1wb3B1cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGh5UGlja2VyIH0gZnJvbSAnLi9waWNrZXIuY29tcG9uZW50JztcblxuLyoqXG4gKiDml6XmnJ/pgInmi6nnu4Tku7ZcbiAqIEBuYW1lIHRoeS1kYXRlLXBpY2tlclxuICogQG9yZGVyIDEwXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHNlbGVjdG9yOiAndGh5LWRhdGUtcGlja2VyJyxcbiAgICBleHBvcnRBczogJ3RoeURhdGVQaWNrZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXNlLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUaHlEYXRlUGlja2VyKVxuICAgICAgICB9XG4gICAgXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtUaHlQaWNrZXIsIERhdGVQb3B1cF0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIudGFiaW5kZXhdJzogJ3RhYkluZGV4J1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgVGh5RGF0ZVBpY2tlciBleHRlbmRzIEJhc2VQaWNrZXIgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGlzUmFuZ2UgPSBmYWxzZTtcblxuICAgIHByaXZhdGUgaG9zdFJlbmRlcmVyID0gdXNlSG9zdFJlbmRlcmVyKCk7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIuYWRkQ2xhc3MoJ3RoeS1jYWxlbmRhci1waWNrZXInKTtcbiAgICB9XG59XG4iLCI8dGh5LXBpY2tlclxuICAjdGh5UGlja2VyXG4gIFtpc1JhbmdlXT1cImlzUmFuZ2VcIlxuICBbdmFsdWVdPVwidGh5VmFsdWVcIlxuICBbZmxleGlibGVdPVwiZmxleGlibGVcIlxuICBbZmxleGlibGVEYXRlR3JhbnVsYXJpdHldPVwiZmxleGlibGVEYXRlR3JhbnVsYXJpdHlcIlxuICAodmFsdWVDaGFuZ2UpPVwib25JbnB1dFZhbHVlQ2hhbmdlKCRldmVudClcIlxuICBbb3Blbl09XCJ0aHlPcGVuXCJcbiAgW2Rpc2FibGVkXT1cInRoeURpc2FibGVkXCJcbiAgW2Zvcm1hdF09XCJ0aHlGb3JtYXRcIlxuICBbc2VwYXJhdG9yXT1cInNlcGFyYXRvcigpXCJcbiAgW21vZGVdPVwidGh5TW9kZVwiXG4gIFthbGxvd0NsZWFyXT1cInRoeUFsbG93Q2xlYXJcIlxuICBbY2xhc3NOYW1lXT1cInRoeU9yaWdpbkNsYXNzTmFtZVwiXG4gIFthdXRvRm9jdXNdPVwidGh5QXV0b0ZvY3VzXCJcbiAgW3BsYWNlaG9sZGVyXT1cInRoeVBsYWNlSG9sZGVyXCJcbiAgW3JlYWRvbmx5XT1cInRoeVJlYWRvbmx5XCJcbiAgW3NpemVdPVwidGh5U2l6ZVwiXG4gIFtzdWZmaXhJY29uXT1cInRoeVN1ZmZpeEljb25cIlxuICBbcGxhY2VtZW50XT1cInRoeVBsYWNlbWVudFwiXG4gIFtoYXNCYWNrZHJvcF09XCJ0aHlIYXNCYWNrZHJvcFwiXG4gIChvcGVuQ2hhbmdlKT1cIm9uT3BlbkNoYW5nZSgkZXZlbnQpXCJcbiAgKGJsdXIpPVwib25CbHVyKCRldmVudClcIlxuICAoaW5wdXRDaGFuZ2UpPVwib25JbnB1dERhdGUoJGV2ZW50KVwiPlxuICBAaWYgKGlzU2hvd0RhdGVQb3B1cCkge1xuICAgIDxkYXRlLXBvcHVwXG4gICAgICBbYXR0ci50YWJpbmRleF09XCItMVwiXG4gICAgICBbaXNSYW5nZV09XCJpc1JhbmdlXCJcbiAgICAgIFtzaG93V2Vla109XCJzaG93V2Vla1wiXG4gICAgICBbcGFuZWxNb2RlXT1cInBhbmVsTW9kZVwiXG4gICAgICBbZmxleGlibGVdPVwiZmxleGlibGVcIlxuICAgICAgW2ZsZXhpYmxlRGF0ZUdyYW51bGFyaXR5XT1cImZsZXhpYmxlRGF0ZUdyYW51bGFyaXR5XCJcbiAgICAgIFtkZWZhdWx0UGlja2VyVmFsdWVdPVwidGh5RGVmYXVsdFBpY2tlclZhbHVlXCJcbiAgICAgIChwYW5lbE1vZGVDaGFuZ2UpPVwidGh5T25QYW5lbENoYW5nZS5lbWl0KCRldmVudClcIlxuICAgICAgKHNob3dUaW1lUGlja2VyQ2hhbmdlKT1cIm9uU2hvd1RpbWVQaWNrZXJDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICBbdmFsdWVdPVwidGh5VmFsdWVcIlxuICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uVmFsdWVDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAoY2FsZW5kYXJDaGFuZ2UpPVwib25DYWxlbmRhckNoYW5nZSgkZXZlbnQpXCJcbiAgICAgIFtzaG93VGltZV09XCJ0aHlTaG93VGltZVwiXG4gICAgICBbbXVzdFNob3dUaW1lXT1cIndpdGhUaW1lXCJcbiAgICAgIFtmb3JtYXRdPVwidGh5Rm9ybWF0XCJcbiAgICAgIFtkYXRlUmVuZGVyXT1cInRoeURhdGVSZW5kZXJcIlxuICAgICAgW2Rpc2FibGVkRGF0ZV09XCJ0aHlEaXNhYmxlZERhdGVcIlxuICAgICAgW21pbkRhdGVdPVwidGh5TWluRGF0ZVwiXG4gICAgICBbbWF4RGF0ZV09XCJ0aHlNYXhEYXRlXCJcbiAgICAgIFtzaG93U2hvcnRjdXRdPVwidGh5U2hvd1Nob3J0Y3V0XCJcbiAgICAgIFtzaG9ydGN1dFByZXNldHNdPVwic2hvcnRjdXRQcmVzZXRzXCJcbiAgICAgIFtzaG9ydGN1dFBvc2l0aW9uXT1cInNob3J0Y3V0UG9zaXRpb25cIlxuICAgICAgW3RpbWVzdGFtcFByZWNpc2lvbl09XCJ0aHlUaW1lc3RhbXBQcmVjaXNpb25cIlxuICAgICAgKGRhdGVWYWx1ZUNoYW5nZSk9XCJvbkRhdGVWYWx1ZUNoYW5nZSgkZXZlbnQpXCJcbiAgICAgIFtjbGFzc05hbWVdPVwidGh5UGFuZWxDbGFzc05hbWVcIlxuICAgICAgKHJlc3VsdE9rKT1cIm9uUmVzdWx0T2soKVwiPjwvZGF0ZS1wb3B1cD5cbiAgfVxuPC90aHktcGlja2VyPlxuIl19
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9kYXRlLXBpY2tlci9iYXNlLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN2RixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUM5RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBRS9DOzs7O0dBSUc7QUFtQkgsTUFBTSxPQUFPLGFBQWMsU0FBUSxVQUFVO0lBS3pDO1FBQ0ksS0FBSyxFQUFFLENBQUM7UUFMWixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRVIsaUJBQVksR0FBRyxlQUFlLEVBQUUsQ0FBQztRQUlyQyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBQ3RELENBQUM7K0dBUlEsYUFBYTttR0FBYixhQUFhLHFIQWJYO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsS0FBSyxFQUFFLElBQUk7Z0JBQ1gsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUM7YUFDL0M7U0FDSiw4RUN4QkwsNDdEQXlEQSw0Q0QvQmMsU0FBUyx3WUFBRSxTQUFTOzs0RkFLckIsYUFBYTtrQkFsQnpCLFNBQVM7c0NBQ1csdUJBQXVCLENBQUMsTUFBTSxZQUNyQyxpQkFBaUIsWUFDakIsZUFBZSxhQUVkO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLEtBQUssRUFBRSxJQUFJOzRCQUNYLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGNBQWMsQ0FBQzt5QkFDL0M7cUJBQ0osY0FDVyxJQUFJLFdBQ1AsQ0FBQyxTQUFTLEVBQUUsU0FBUyxDQUFDLFFBQ3pCO3dCQUNGLGlCQUFpQixFQUFFLFVBQVU7cUJBQ2hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IHVzZUhvc3RSZW5kZXJlciB9IGZyb20gJ0B0ZXRoeXMvY2RrL2RvbSc7XG5cbmltcG9ydCB7IEJhc2VQaWNrZXIgfSBmcm9tICcuL2Jhc2UtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRlUG9wdXAgfSBmcm9tICcuL2xpYi9wb3B1cHMvZGF0ZS1wb3B1cC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGh5UGlja2VyIH0gZnJvbSAnLi9waWNrZXIuY29tcG9uZW50JztcblxuLyoqXG4gKiDml6XmnJ/pgInmi6nnu4Tku7ZcbiAqIEBuYW1lIHRoeS1kYXRlLXBpY2tlclxuICogQG9yZGVyIDEwXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHNlbGVjdG9yOiAndGh5LWRhdGUtcGlja2VyJyxcbiAgICBleHBvcnRBczogJ3RoeURhdGVQaWNrZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXNlLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgICAgICAgbXVsdGk6IHRydWUsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUaHlEYXRlUGlja2VyKVxuICAgICAgICB9XG4gICAgXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtUaHlQaWNrZXIsIERhdGVQb3B1cF0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIudGFiaW5kZXhdJzogJ3RhYkluZGV4J1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgVGh5RGF0ZVBpY2tlciBleHRlbmRzIEJhc2VQaWNrZXIgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGlzUmFuZ2UgPSBmYWxzZTtcblxuICAgIHByaXZhdGUgaG9zdFJlbmRlcmVyID0gdXNlSG9zdFJlbmRlcmVyKCk7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgdGhpcy5ob3N0UmVuZGVyZXIuYWRkQ2xhc3MoJ3RoeS1jYWxlbmRhci1waWNrZXInKTtcbiAgICB9XG59XG4iLCI8dGh5LXBpY2tlclxuICAjdGh5UGlja2VyXG4gIFtpc1JhbmdlXT1cImlzUmFuZ2VcIlxuICBbdmFsdWVdPVwidGh5VmFsdWVcIlxuICBbZmxleGlibGVdPVwiZmxleGlibGVcIlxuICBbZmxleGlibGVEYXRlR3JhbnVsYXJpdHldPVwiZmxleGlibGVEYXRlR3JhbnVsYXJpdHlcIlxuICAodmFsdWVDaGFuZ2UpPVwib25JbnB1dFZhbHVlQ2hhbmdlKCRldmVudClcIlxuICBbb3Blbl09XCJ0aHlPcGVuXCJcbiAgW2Rpc2FibGVkXT1cInRoeURpc2FibGVkXCJcbiAgW2Zvcm1hdF09XCJ0aHlGb3JtYXRcIlxuICBbc2VwYXJhdG9yXT1cInNlcGFyYXRvcigpXCJcbiAgW21vZGVdPVwidGh5TW9kZVwiXG4gIFthbGxvd0NsZWFyXT1cInRoeUFsbG93Q2xlYXJcIlxuICBbY2xhc3NOYW1lXT1cInRoeU9yaWdpbkNsYXNzTmFtZVwiXG4gIFthdXRvRm9jdXNdPVwidGh5QXV0b0ZvY3VzXCJcbiAgW3BsYWNlaG9sZGVyXT1cInRoeVBsYWNlSG9sZGVyXCJcbiAgW3JlYWRvbmx5XT1cInRoeVJlYWRvbmx5XCJcbiAgW3NpemVdPVwidGh5U2l6ZVwiXG4gIFt0aW1lWm9uZV09XCJ0aHlUaW1lWm9uZVwiXG4gIFtzdWZmaXhJY29uXT1cInRoeVN1ZmZpeEljb25cIlxuICBbcGxhY2VtZW50XT1cInRoeVBsYWNlbWVudFwiXG4gIFtoYXNCYWNrZHJvcF09XCJ0aHlIYXNCYWNrZHJvcFwiXG4gIChvcGVuQ2hhbmdlKT1cIm9uT3BlbkNoYW5nZSgkZXZlbnQpXCJcbiAgKGJsdXIpPVwib25CbHVyKCRldmVudClcIlxuICAoaW5wdXRDaGFuZ2UpPVwib25JbnB1dERhdGUoJGV2ZW50KVwiPlxuICBAaWYgKGlzU2hvd0RhdGVQb3B1cCkge1xuICAgIDxkYXRlLXBvcHVwXG4gICAgICBbYXR0ci50YWJpbmRleF09XCItMVwiXG4gICAgICBbaXNSYW5nZV09XCJpc1JhbmdlXCJcbiAgICAgIFtzaG93V2Vla109XCJzaG93V2Vla1wiXG4gICAgICBbcGFuZWxNb2RlXT1cInBhbmVsTW9kZVwiXG4gICAgICBbZmxleGlibGVdPVwiZmxleGlibGVcIlxuICAgICAgW2ZsZXhpYmxlRGF0ZUdyYW51bGFyaXR5XT1cImZsZXhpYmxlRGF0ZUdyYW51bGFyaXR5XCJcbiAgICAgIFtkZWZhdWx0UGlja2VyVmFsdWVdPVwidGh5RGVmYXVsdFBpY2tlclZhbHVlXCJcbiAgICAgIChwYW5lbE1vZGVDaGFuZ2UpPVwidGh5T25QYW5lbENoYW5nZS5lbWl0KCRldmVudClcIlxuICAgICAgKHNob3dUaW1lUGlja2VyQ2hhbmdlKT1cIm9uU2hvd1RpbWVQaWNrZXJDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICBbdmFsdWVdPVwidGh5VmFsdWVcIlxuICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uVmFsdWVDaGFuZ2UoJGV2ZW50KVwiXG4gICAgICAoY2FsZW5kYXJDaGFuZ2UpPVwib25DYWxlbmRhckNoYW5nZSgkZXZlbnQpXCJcbiAgICAgIFtzaG93VGltZV09XCJ0aHlTaG93VGltZVwiXG4gICAgICBbbXVzdFNob3dUaW1lXT1cIndpdGhUaW1lXCJcbiAgICAgIFtmb3JtYXRdPVwidGh5Rm9ybWF0XCJcbiAgICAgIFtkYXRlUmVuZGVyXT1cInRoeURhdGVSZW5kZXJcIlxuICAgICAgW2Rpc2FibGVkRGF0ZV09XCJ0aHlEaXNhYmxlZERhdGVcIlxuICAgICAgW21pbkRhdGVdPVwidGh5TWluRGF0ZVwiXG4gICAgICBbbWF4RGF0ZV09XCJ0aHlNYXhEYXRlXCJcbiAgICAgIFtzaG93U2hvcnRjdXRdPVwidGh5U2hvd1Nob3J0Y3V0XCJcbiAgICAgIFtzaG9ydGN1dFByZXNldHNdPVwic2hvcnRjdXRQcmVzZXRzXCJcbiAgICAgIFtzaG9ydGN1dFBvc2l0aW9uXT1cInNob3J0Y3V0UG9zaXRpb25cIlxuICAgICAgW3RpbWVzdGFtcFByZWNpc2lvbl09XCJ0aHlUaW1lc3RhbXBQcmVjaXNpb25cIlxuICAgICAgKGRhdGVWYWx1ZUNoYW5nZSk9XCJvbkRhdGVWYWx1ZUNoYW5nZSgkZXZlbnQpXCJcbiAgICAgIFtjbGFzc05hbWVdPVwidGh5UGFuZWxDbGFzc05hbWVcIlxuICAgICAgKHJlc3VsdE9rKT1cIm9uUmVzdWx0T2soKVwiXG4gICAgICBbdGltZVpvbmVdPVwidGh5VGltZVpvbmVcIlxuICAgICAgPjwvZGF0ZS1wb3B1cD5cbiAgfVxuPC90aHktcGlja2VyPlxuIl19
@@ -26,7 +26,7 @@ export class CalendarFooter {
26
26
  ngOnInit() {
27
27
  this._initTimeShowMode();
28
28
  if (!this.value) {
29
- this.value = new TinyDate();
29
+ this.value = new TinyDate(undefined, this.timeZone);
30
30
  }
31
31
  }
32
32
  ngOnChanges(changes) {
@@ -35,7 +35,7 @@ export class CalendarFooter {
35
35
  }
36
36
  }
37
37
  onSelectTime(date) {
38
- this.selectTime.emit(new TinyDate(date));
38
+ this.selectTime.emit(new TinyDate(date, this.timeZone));
39
39
  }
40
40
  onTimeOk() {
41
41
  if (this.disableTimeConfirm) {
@@ -72,17 +72,19 @@ export class CalendarFooter {
72
72
  }
73
73
  }
74
74
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarFooter, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
75
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CalendarFooter, isStandalone: true, selector: "calendar-footer", inputs: { showTime: "showTime", mustShowTime: "mustShowTime", value: "value", disableTimeConfirm: ["disableTimeConfirm", "disableTimeConfirm", coerceBooleanProperty] }, outputs: { selectTime: "selectTime", clickOk: "clickOk", clickRemove: "clickRemove", showTimePickerChange: "showTimePickerChange" }, exportAs: ["calendarFooter"], usesOnChanges: true, ngImport: i0, template: "@if (isShowTime || isCanTime) {\n <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n @if (isCanTime) {\n <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n </a>\n }\n @if (isShowTime) {\n <thy-inner-time-picker\n class=\"time-picker-wrap\"\n [showMeridian]=\"false\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n }\n <div class=\"time-picker-btn-wrap\">\n @if (!isCanTime) {\n <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n {{ locale().ok }}\n </button>\n }\n <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n </div>\n </div>\n}\n", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyInnerTimePicker, selector: "thy-inner-time-picker", inputs: ["hourStep", "minuteStep", "secondsStep", "readonlyInput", "disabled", "mousewheel", "arrowKeys", "showSpinners", "showMeridian", "showMinutes", "showSeconds", "meridians", "min", "max", "hoursPlaceholder", "minutesPlaceholder", "secondsPlaceholder"], outputs: ["isValid"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ThyButton, selector: "thy-button,[thy-button],[thyButton]", inputs: ["thyButton", "thyType", "thyLoading", "thyLoadingText", "thySize", "thyIcon", "thyBlock"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CalendarFooter, isStandalone: true, selector: "calendar-footer", inputs: { showTime: "showTime", mustShowTime: "mustShowTime", value: "value", timeZone: "timeZone", disableTimeConfirm: ["disableTimeConfirm", "disableTimeConfirm", coerceBooleanProperty] }, outputs: { selectTime: "selectTime", clickOk: "clickOk", clickRemove: "clickRemove", showTimePickerChange: "showTimePickerChange" }, exportAs: ["calendarFooter"], usesOnChanges: true, ngImport: i0, template: "@if (isShowTime || isCanTime) {\n <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n @if (isCanTime) {\n <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n </a>\n }\n @if (isShowTime) {\n <thy-inner-time-picker\n class=\"time-picker-wrap\"\n [showMeridian]=\"false\"\n [timeZone]=\"timeZone\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n }\n <div class=\"time-picker-btn-wrap\">\n @if (!isCanTime) {\n <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n {{ locale().ok }}\n </button>\n }\n <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n </div>\n </div>\n}\n", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyInnerTimePicker, selector: "thy-inner-time-picker", inputs: ["hourStep", "minuteStep", "secondsStep", "readonlyInput", "disabled", "mousewheel", "arrowKeys", "showSpinners", "showMeridian", "showMinutes", "showSeconds", "meridians", "min", "max", "hoursPlaceholder", "minutesPlaceholder", "secondsPlaceholder", "timeZone"], outputs: ["isValid"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ThyButton, selector: "thy-button,[thy-button],[thyButton]", inputs: ["thyButton", "thyType", "thyLoading", "thyLoadingText", "thySize", "thyIcon", "thyBlock"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
76
76
  }
77
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarFooter, decorators: [{
78
78
  type: Component,
79
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'calendar-footer', exportAs: 'calendarFooter', standalone: true, imports: [ThyIcon, ThyInnerTimePicker, FormsModule, ThyButton], template: "@if (isShowTime || isCanTime) {\n <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n @if (isCanTime) {\n <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n </a>\n }\n @if (isShowTime) {\n <thy-inner-time-picker\n class=\"time-picker-wrap\"\n [showMeridian]=\"false\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n }\n <div class=\"time-picker-btn-wrap\">\n @if (!isCanTime) {\n <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n {{ locale().ok }}\n </button>\n }\n <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n </div>\n </div>\n}\n" }]
79
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'calendar-footer', exportAs: 'calendarFooter', standalone: true, imports: [ThyIcon, ThyInnerTimePicker, FormsModule, ThyButton], template: "@if (isShowTime || isCanTime) {\n <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n @if (isCanTime) {\n <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n </a>\n }\n @if (isShowTime) {\n <thy-inner-time-picker\n class=\"time-picker-wrap\"\n [showMeridian]=\"false\"\n [timeZone]=\"timeZone\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n }\n <div class=\"time-picker-btn-wrap\">\n @if (!isCanTime) {\n <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n {{ locale().ok }}\n </button>\n }\n <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n </div>\n </div>\n}\n" }]
80
80
  }], propDecorators: { showTime: [{
81
81
  type: Input
82
82
  }], mustShowTime: [{
83
83
  type: Input
84
84
  }], value: [{
85
85
  type: Input
86
+ }], timeZone: [{
87
+ type: Input
86
88
  }], disableTimeConfirm: [{
87
89
  type: Input,
88
90
  args: [{ transform: coerceBooleanProperty }]
@@ -95,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
95
97
  }], showTimePickerChange: [{
96
98
  type: Output
97
99
  }] } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-footer.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/calendar/calendar-footer.component.ts","../../../../../../src/date-picker/lib/calendar/calendar-footer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output, Signal, SimpleChanges } from '@angular/core';\n\nimport { FormsModule } from '@angular/forms';\nimport { ThyButton } from 'ngx-tethys/button';\nimport { injectLocale, ThyDatePickerLocale } from 'ngx-tethys/i18n';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInnerTimePicker } from 'ngx-tethys/time-picker';\nimport { coerceBooleanProperty, TinyDate } from 'ngx-tethys/util';\n\n/**\n * @private\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'calendar-footer',\n    exportAs: 'calendarFooter',\n    templateUrl: 'calendar-footer.component.html',\n    standalone: true,\n    imports: [ThyIcon, ThyInnerTimePicker, FormsModule, ThyButton]\n})\nexport class CalendarFooter implements OnInit, OnChanges {\n    @Input() showTime = false;\n    @Input() mustShowTime = false;\n    @Input() value: TinyDate;\n    @Input({ transform: coerceBooleanProperty }) disableTimeConfirm = false;\n    @Output() readonly selectTime = new EventEmitter<TinyDate>();\n    @Output() readonly clickOk = new EventEmitter<void>();\n    @Output() readonly clickRemove = new EventEmitter<void>();\n    @Output() readonly showTimePickerChange = new EventEmitter<boolean>();\n    isShowTime = false;\n    isCanTime = false;\n    locale: Signal<ThyDatePickerLocale> = injectLocale('datePicker');\n\n    ngOnInit() {\n        this._initTimeShowMode();\n        if (!this.value) {\n            this.value = new TinyDate();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.mustShowTime) {\n            this._initTimeShowMode();\n        }\n    }\n\n    onSelectTime(date: Date): void {\n        this.selectTime.emit(new TinyDate(date));\n    }\n\n    onTimeOk() {\n        if (this.disableTimeConfirm) {\n            return;\n        }\n        this.selectTime.emit(this.value);\n        this.clickOk.emit();\n    }\n\n    onClear() {\n        this.value = null;\n        this.clickRemove.emit();\n    }\n\n    changeTimeShowMode(type: string) {\n        switch (type) {\n            case 'can':\n                this.isCanTime = true;\n                this.isShowTime = false;\n                break;\n            case 'show':\n                this.isCanTime = false;\n                this.isShowTime = true;\n                break;\n        }\n        this.showTimePickerChange.emit(this.isShowTime);\n    }\n\n    private _initTimeShowMode() {\n        if (this.mustShowTime) {\n            this.changeTimeShowMode('show');\n        } else {\n            if (this.showTime) {\n                this.changeTimeShowMode('can');\n            }\n        }\n    }\n}\n","@if (isShowTime || isCanTime) {\n  <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n    @if (isCanTime) {\n      <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n        <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n      </a>\n    }\n    @if (isShowTime) {\n      <thy-inner-time-picker\n        class=\"time-picker-wrap\"\n        [showMeridian]=\"false\"\n        [ngModel]=\"value\"\n        (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n    }\n    <div class=\"time-picker-btn-wrap\">\n      @if (!isCanTime) {\n        <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n          {{ locale().ok }}\n        </button>\n      }\n      <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n    </div>\n  </div>\n}\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-footer.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/calendar/calendar-footer.component.ts","../../../../../../src/date-picker/lib/calendar/calendar-footer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output, Signal, SimpleChanges } from '@angular/core';\n\nimport { FormsModule } from '@angular/forms';\nimport { ThyButton } from 'ngx-tethys/button';\nimport { injectLocale, ThyDatePickerLocale } from 'ngx-tethys/i18n';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInnerTimePicker } from 'ngx-tethys/time-picker';\nimport { coerceBooleanProperty, TinyDate } from 'ngx-tethys/util';\n\n/**\n * @private\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'calendar-footer',\n    exportAs: 'calendarFooter',\n    templateUrl: 'calendar-footer.component.html',\n    standalone: true,\n    imports: [ThyIcon, ThyInnerTimePicker, FormsModule, ThyButton]\n})\nexport class CalendarFooter implements OnInit, OnChanges {\n    @Input() showTime = false;\n    @Input() mustShowTime = false;\n    @Input() value: TinyDate;\n    @Input() timeZone: string;\n    @Input({ transform: coerceBooleanProperty }) disableTimeConfirm = false;\n    @Output() readonly selectTime = new EventEmitter<TinyDate>();\n    @Output() readonly clickOk = new EventEmitter<void>();\n    @Output() readonly clickRemove = new EventEmitter<void>();\n    @Output() readonly showTimePickerChange = new EventEmitter<boolean>();\n    isShowTime = false;\n    isCanTime = false;\n    locale: Signal<ThyDatePickerLocale> = injectLocale('datePicker');\n\n    ngOnInit() {\n        this._initTimeShowMode();\n        if (!this.value) {\n            this.value = new TinyDate(undefined, this.timeZone);\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.mustShowTime) {\n            this._initTimeShowMode();\n        }\n    }\n\n    onSelectTime(date: Date): void {\n        this.selectTime.emit(new TinyDate(date, this.timeZone));\n    }\n\n    onTimeOk() {\n        if (this.disableTimeConfirm) {\n            return;\n        }\n        this.selectTime.emit(this.value);\n        this.clickOk.emit();\n    }\n\n    onClear() {\n        this.value = null;\n        this.clickRemove.emit();\n    }\n\n    changeTimeShowMode(type: string) {\n        switch (type) {\n            case 'can':\n                this.isCanTime = true;\n                this.isShowTime = false;\n                break;\n            case 'show':\n                this.isCanTime = false;\n                this.isShowTime = true;\n                break;\n        }\n        this.showTimePickerChange.emit(this.isShowTime);\n    }\n\n    private _initTimeShowMode() {\n        if (this.mustShowTime) {\n            this.changeTimeShowMode('show');\n        } else {\n            if (this.showTime) {\n                this.changeTimeShowMode('can');\n            }\n        }\n    }\n}\n","@if (isShowTime || isCanTime) {\n  <div class=\"time-picker-section\" (click)=\"$event.stopPropagation()\">\n    @if (isCanTime) {\n      <a href=\"javascript:;\" class=\"link-has-icon time-picker-set-btn\" (click)=\"changeTimeShowMode('show')\">\n        <thy-icon thyIconName=\"clock-circle\"></thy-icon>{{ locale().setTime }}\n      </a>\n    }\n    @if (isShowTime) {\n      <thy-inner-time-picker\n        class=\"time-picker-wrap\"\n        [showMeridian]=\"false\"\n        [timeZone]=\"timeZone\"\n        [ngModel]=\"value\"\n        (ngModelChange)=\"onSelectTime($event)\"></thy-inner-time-picker>\n    }\n    <div class=\"time-picker-btn-wrap\">\n      @if (!isCanTime) {\n        <button [disabled]=\"disableTimeConfirm\" class=\"time-picker-ok-btn\" thyButton=\"primary\" thySize=\"sm\" (click)=\"onTimeOk()\">\n          {{ locale().ok }}\n        </button>\n      }\n      <button class=\"time-picker-clear-btn\" thyButton=\"link-secondary\" thySize=\"sm\" (click)=\"onClear()\">{{ locale().clear }}</button>\n    </div>\n  </div>\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { Directive, EventEmitter, Input, Output } from '@angular/core';
2
- import { isTemplateRef, TinyDate } from 'ngx-tethys/util';
3
2
  import { injectLocale } from 'ngx-tethys/i18n';
3
+ import { isTemplateRef, TinyDate } from 'ngx-tethys/util';
4
4
  import * as i0 from "@angular/core";
5
5
  /**
6
6
  * @private
@@ -75,7 +75,7 @@ export class CalendarTable {
75
75
  return (!left && !right) || (left && right && right.isSameDay(left));
76
76
  }
77
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarTable, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
78
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CalendarTable, inputs: { prefixCls: "prefixCls", value: "value", activeDate: "activeDate", showWeek: "showWeek", selectedValue: "selectedValue", hoverValue: "hoverValue", disabledDate: "disabledDate", cellRender: "cellRender", fullCellRender: "fullCellRender" }, outputs: { valueChange: "valueChange", cellHover: "cellHover" }, usesOnChanges: true, ngImport: i0 }); }
78
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CalendarTable, inputs: { prefixCls: "prefixCls", value: "value", activeDate: "activeDate", showWeek: "showWeek", selectedValue: "selectedValue", hoverValue: "hoverValue", timeZone: "timeZone", disabledDate: "disabledDate", cellRender: "cellRender", fullCellRender: "fullCellRender" }, outputs: { valueChange: "valueChange", cellHover: "cellHover" }, usesOnChanges: true, ngImport: i0 }); }
79
79
  }
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CalendarTable, decorators: [{
81
81
  type: Directive
@@ -91,6 +91,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
91
91
  type: Input
92
92
  }], hoverValue: [{
93
93
  type: Input
94
+ }], timeZone: [{
95
+ type: Input
94
96
  }], disabledDate: [{
95
97
  type: Input
96
98
  }], cellRender: [{
@@ -102,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
102
104
  }], cellHover: [{
103
105
  type: Output
104
106
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/calendar/calendar-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, EventEmitter, Input, OnChanges, OnInit, Output, Signal, SimpleChange, SimpleChanges, TemplateRef } from '@angular/core';\nimport { SafeAny } from 'ngx-tethys/types';\nimport { FunctionProp, isTemplateRef, TinyDate } from 'ngx-tethys/util';\nimport { DateCell, DateBodyRow } from '../date/types';\nimport { injectLocale, ThyDatePickerLocale } from 'ngx-tethys/i18n';\n\n/**\n * @private\n */\n@Directive()\nexport abstract class CalendarTable implements OnInit, OnChanges {\n    locale: Signal<ThyDatePickerLocale> = injectLocale('datePicker');\n    isTemplateRef = isTemplateRef;\n    headRow: DateCell[] = [];\n    bodyRows: DateBodyRow[] = [];\n    MAX_ROW = 6;\n    MAX_COL = 7;\n\n    @Input() prefixCls: string = 'thy-calendar';\n    @Input() value: TinyDate;\n    @Input() activeDate: TinyDate = new TinyDate();\n    @Input() showWeek: boolean = false;\n    @Input() selectedValue: TinyDate[] = []; // Range ONLY\n    @Input() hoverValue: TinyDate[] = []; // Range ONLY\n    @Input() disabledDate?: (d: Date) => boolean;\n    @Input() cellRender?: FunctionProp<TemplateRef<Date> | string>;\n    @Input() fullCellRender?: FunctionProp<TemplateRef<Date> | string>;\n    @Output() readonly valueChange = new EventEmitter<TinyDate>();\n\n    @Output() readonly cellHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor() {}\n\n    protected render(): void {\n        if (this.activeDate) {\n            this.headRow = this.makeHeadRow();\n            this.bodyRows = this.makeBodyRows();\n        }\n    }\n\n    trackByBodyRow(_index: number, item: DateBodyRow): SafeAny {\n        return item.trackByIndex;\n    }\n\n    trackByBodyColumn(_index: number, item: DateCell): SafeAny {\n        return item.trackByIndex;\n    }\n\n    hasRangeValue(): boolean {\n        return this.selectedValue?.length > 0 || this.hoverValue?.length > 0;\n    }\n\n    abstract makeHeadRow(): DateCell[];\n    abstract makeBodyRows(): DateBodyRow[];\n\n    ngOnInit(): void {\n        this.render();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.activeDate && !changes.activeDate.currentValue) {\n            this.activeDate = new TinyDate();\n        }\n\n        if (\n            changes.disabledDate ||\n            changes.locale ||\n            changes.showWeek ||\n            this.isDateRealChange(changes.activeDate) ||\n            this.isDateRealChange(changes.value) ||\n            this.isDateRealChange(changes.selectedValue) ||\n            this.isDateRealChange(changes.hoverValue)\n        ) {\n            this.render();\n        }\n    }\n\n    private isDateRealChange(change: SimpleChange): boolean {\n        if (change) {\n            const previousValue: TinyDate | TinyDate[] = change.previousValue;\n            const currentValue: TinyDate | TinyDate[] = change.currentValue;\n            if (Array.isArray(currentValue)) {\n                return (\n                    !Array.isArray(previousValue) ||\n                    currentValue.length !== previousValue.length ||\n                    currentValue.some((value, index) => {\n                        const previousCandyDate = previousValue[index];\n                        return previousCandyDate instanceof TinyDate ? previousCandyDate.isSameDay(value) : previousCandyDate !== value;\n                    })\n                );\n            } else {\n                return !this.isSameDate(previousValue as TinyDate, currentValue);\n            }\n        }\n        return false;\n    }\n\n    private isSameDate(left: TinyDate, right: TinyDate): boolean {\n        return (!left && !right) || (left && right && right.isSameDay(left));\n    }\n}\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/calendar/calendar-table.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAoD,MAAM,eAAe,CAAC;AAC5I,OAAO,EAAE,YAAY,EAAuB,MAAM,iBAAiB,CAAC;AAEpE,OAAO,EAAgB,aAAa,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;AAGxE;;GAEG;AAEH,MAAM,OAAgB,aAAa;IAsB/B;QArBA,WAAM,GAAgC,YAAY,CAAC,YAAY,CAAC,CAAC;QACjE,kBAAa,GAAG,aAAa,CAAC;QAC9B,YAAO,GAAe,EAAE,CAAC;QACzB,aAAQ,GAAkB,EAAE,CAAC;QAC7B,YAAO,GAAG,CAAC,CAAC;QACZ,YAAO,GAAG,CAAC,CAAC;QAEH,cAAS,GAAW,cAAc,CAAC;QAEnC,eAAU,GAAa,IAAI,QAAQ,EAAE,CAAC;QACtC,aAAQ,GAAY,KAAK,CAAC;QAC1B,kBAAa,GAAe,EAAE,CAAC,CAAC,aAAa;QAC7C,eAAU,GAAe,EAAE,CAAC,CAAC,aAAa;QAKhC,gBAAW,GAAG,IAAI,YAAY,EAAY,CAAC;QAE3C,cAAS,GAAG,IAAI,YAAY,EAAY,CAAC,CAAC,6CAA6C;IAE3F,CAAC;IAEN,MAAM;QACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,IAAiB;QAC5C,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,iBAAiB,CAAC,MAAc,EAAE,IAAc;QAC5C,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,aAAa;QACT,OAAO,IAAI,CAAC,aAAa,EAAE,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,CAAC,CAAC;IACzE,CAAC;IAKD,QAAQ;QACJ,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,UAAU,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;YACzD,IAAI,CAAC,UAAU,GAAG,IAAI,QAAQ,EAAE,CAAC;QACrC,CAAC;QAED,IACI,OAAO,CAAC,YAAY;YACpB,OAAO,CAAC,MAAM;YACd,OAAO,CAAC,QAAQ;YAChB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,UAAU,CAAC;YACzC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC;YACpC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,aAAa,CAAC;YAC5C,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,UAAU,CAAC,EAC3C,CAAC;YACC,IAAI,CAAC,MAAM,EAAE,CAAC;QAClB,CAAC;IACL,CAAC;IAEO,gBAAgB,CAAC,MAAoB;QACzC,IAAI,MAAM,EAAE,CAAC;YACT,MAAM,aAAa,GAA0B,MAAM,CAAC,aAAa,CAAC;YAClE,MAAM,YAAY,GAA0B,MAAM,CAAC,YAAY,CAAC;YAChE,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC;gBAC9B,OAAO,CACH,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC;oBAC7B,YAAY,CAAC,MAAM,KAAK,aAAa,CAAC,MAAM;oBAC5C,YAAY,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;wBAC/B,MAAM,iBAAiB,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;wBAC/C,OAAO,iBAAiB,YAAY,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,iBAAiB,KAAK,KAAK,CAAC;oBACpH,CAAC,CAAC,CACL,CAAC;YACN,CAAC;iBAAM,CAAC;gBACJ,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,aAAyB,EAAE,YAAY,CAAC,CAAC;YACrE,CAAC;QACL,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,UAAU,CAAC,IAAc,EAAE,KAAe;QAC9C,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,KAAK,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IACzE,CAAC;+GA1FiB,aAAa;mGAAb,aAAa;;4FAAb,aAAa;kBADlC,SAAS;wDASG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACa,WAAW;sBAA7B,MAAM;gBAEY,SAAS;sBAA3B,MAAM","sourcesContent":["import { Directive, EventEmitter, Input, OnChanges, OnInit, Output, Signal, SimpleChange, SimpleChanges, TemplateRef } from '@angular/core';\nimport { injectLocale, ThyDatePickerLocale } from 'ngx-tethys/i18n';\nimport { SafeAny } from 'ngx-tethys/types';\nimport { FunctionProp, isTemplateRef, TinyDate } from 'ngx-tethys/util';\nimport { DateBodyRow, DateCell } from '../date/types';\n\n/**\n * @private\n */\n@Directive()\nexport abstract class CalendarTable implements OnInit, OnChanges {\n    locale: Signal<ThyDatePickerLocale> = injectLocale('datePicker');\n    isTemplateRef = isTemplateRef;\n    headRow: DateCell[] = [];\n    bodyRows: DateBodyRow[] = [];\n    MAX_ROW = 6;\n    MAX_COL = 7;\n\n    @Input() prefixCls: string = 'thy-calendar';\n    @Input() value: TinyDate;\n    @Input() activeDate: TinyDate = new TinyDate();\n    @Input() showWeek: boolean = false;\n    @Input() selectedValue: TinyDate[] = []; // Range ONLY\n    @Input() hoverValue: TinyDate[] = []; // Range ONLY\n    @Input() timeZone: string;\n    @Input() disabledDate?: (d: Date) => boolean;\n    @Input() cellRender?: FunctionProp<TemplateRef<Date> | string>;\n    @Input() fullCellRender?: FunctionProp<TemplateRef<Date> | string>;\n    @Output() readonly valueChange = new EventEmitter<TinyDate>();\n\n    @Output() readonly cellHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor() {}\n\n    protected render(): void {\n        if (this.activeDate) {\n            this.headRow = this.makeHeadRow();\n            this.bodyRows = this.makeBodyRows();\n        }\n    }\n\n    trackByBodyRow(_index: number, item: DateBodyRow): SafeAny {\n        return item.trackByIndex;\n    }\n\n    trackByBodyColumn(_index: number, item: DateCell): SafeAny {\n        return item.trackByIndex;\n    }\n\n    hasRangeValue(): boolean {\n        return this.selectedValue?.length > 0 || this.hoverValue?.length > 0;\n    }\n\n    abstract makeHeadRow(): DateCell[];\n    abstract makeBodyRows(): DateBodyRow[];\n\n    ngOnInit(): void {\n        this.render();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.activeDate && !changes.activeDate.currentValue) {\n            this.activeDate = new TinyDate();\n        }\n\n        if (\n            changes.disabledDate ||\n            changes.locale ||\n            changes.showWeek ||\n            this.isDateRealChange(changes.activeDate) ||\n            this.isDateRealChange(changes.value) ||\n            this.isDateRealChange(changes.selectedValue) ||\n            this.isDateRealChange(changes.hoverValue)\n        ) {\n            this.render();\n        }\n    }\n\n    private isDateRealChange(change: SimpleChange): boolean {\n        if (change) {\n            const previousValue: TinyDate | TinyDate[] = change.previousValue;\n            const currentValue: TinyDate | TinyDate[] = change.currentValue;\n            if (Array.isArray(currentValue)) {\n                return (\n                    !Array.isArray(previousValue) ||\n                    currentValue.length !== previousValue.length ||\n                    currentValue.some((value, index) => {\n                        const previousCandyDate = previousValue[index];\n                        return previousCandyDate instanceof TinyDate ? previousCandyDate.isSameDay(value) : previousCandyDate !== value;\n                    })\n                );\n            } else {\n                return !this.isSameDate(previousValue as TinyDate, currentValue);\n            }\n        }\n        return false;\n    }\n\n    private isSameDate(left: TinyDate, right: TinyDate): boolean {\n        return (!left && !right) || (left && right && right.isSameDay(left));\n    }\n}\n"]}
@@ -18,7 +18,7 @@ export class DateTable extends CalendarTable {
18
18
  }
19
19
  chooseDate(value) {
20
20
  // Only change date not change time
21
- const date = new TinyDate(TinyDate.createDateInTimeZone(value.getFullYear(), value.getMonth(), value.getDate(), this.activeDate?.getHours(), this.activeDate?.getMinutes(), this.activeDate?.getSeconds()));
21
+ const date = new TinyDate(TinyDate.createDateInTimeZone(value.getFullYear(), value.getMonth(), value.getDate(), this.activeDate?.getHours(), this.activeDate?.getMinutes(), this.activeDate?.getSeconds(), this.timeZone), this.timeZone);
22
22
  this.activeDate = date.clone();
23
23
  this.valueChange.emit(date);
24
24
  }
@@ -146,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
146
146
  }], ctorParameters: () => [], propDecorators: { dayHover: [{
147
147
  type: Output
148
148
  }] } });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/date/date-table.component.ts","../../../../../../src/date-picker/lib/date/date-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, EventEmitter, OnChanges, Output, inject } from '@angular/core';\nimport { TinyDate, valueFunctionProp } from 'ngx-tethys/util';\nimport { DateHelperService } from '../../date-helper.service';\nimport { ThyDatePickerConfigService } from '../../date-picker.service';\nimport { CalendarTable } from '../calendar/calendar-table.component';\nimport { DateTableCell } from './date-table-cell.component';\nimport { DateBodyRow, DateCell } from './types';\n\n/**\n * @private\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'date-table',\n    exportAs: 'dateTable',\n    templateUrl: 'date-table.component.html',\n    standalone: true,\n    imports: [NgClass, DateTableCell]\n})\nexport class DateTable extends CalendarTable implements OnChanges {\n    private dateHelper = inject(DateHelperService);\n    private datePickerConfigService = inject(ThyDatePickerConfigService);\n\n    @Output() readonly dayHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor() {\n        super();\n    }\n\n    private chooseDate(value: TinyDate): void {\n        // Only change date not change time\n        const date = new TinyDate(\n            TinyDate.createDateInTimeZone(\n                value.getFullYear(),\n                value.getMonth(),\n                value.getDate(),\n                this.activeDate?.getHours(),\n                this.activeDate?.getMinutes(),\n                this.activeDate?.getSeconds()\n            )\n        );\n        this.activeDate = date.clone();\n        this.valueChange.emit(date);\n    }\n\n    makeHeadRow(): DateCell[] {\n        const weekDays: DateCell[] = [];\n        const start = this.activeDate.calendarStart({ weekStartsOn: this.datePickerConfigService.config.weekStartsOn });\n        for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n            const day = start.addDays(colIndex);\n            weekDays[colIndex] = {\n                title: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'),\n                content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()),\n                isSelected: false,\n                isDisabled: false,\n                onClick(): void {},\n                onMouseEnter(): void {}\n            };\n        }\n        return weekDays;\n    }\n\n    private getVeryShortWeekFormat(): string {\n        if (this.dateHelper.relyOnDatePipe) {\n            return this.prefixCls === 'thy-calendar-full' ? this.locale().fullWeekFormat : this.locale().weekFormat;\n        }\n        return 'dd';\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const dateRows: DateBodyRow[] = [];\n        const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.datePickerConfigService.config.weekStartsOn });\n        for (let week = 0; week < this.MAX_ROW; week++) {\n            const weekStart = firstDayOfMonth.addDays(week * 7);\n            const row: DateBodyRow = {\n                isActive: false,\n                isCurrent: false,\n                dateCells: [],\n                year: weekStart.getYear()\n            };\n\n            for (let day = 0; day < 7; day++) {\n                const date = weekStart.addDays(day);\n                const dateFormat = this.dateHelper.relyOnDatePipe ? 'longDate' : 'YYYY-MM-DD';\n                const title = this.dateHelper.format(date.nativeDate, dateFormat);\n                const label = this.dateHelper.format(date.nativeDate, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n\n                const cell: DateCell = {\n                    value: date.nativeDate,\n                    label: label,\n                    isSelected: false,\n                    isDisabled: false,\n                    isToday: false,\n                    title: title,\n                    dateCellRender: valueFunctionProp(this.cellRender, date),\n                    content: `${date.getDate()}`,\n                    onClick: () => this.chooseDate(date),\n                    onMouseEnter: () => this.dayHover.emit(date)\n                };\n                this.addCellProperty(cell, date);\n\n                if (this.showWeek && !row.weekNum) {\n                    row.weekNum = this.dateHelper.getISOWeek(date.nativeDate);\n                }\n\n                if (date.isToday()) {\n                    cell.isToday = true;\n                    row.isCurrent = true;\n                }\n\n                if (this.selectedValue?.length > 0) {\n                    const [startSelected, endSelected] = this.selectedValue;\n                    if (date.isSameDay(startSelected)) {\n                        row.isActive = true;\n                    }\n                    if (date.isSameDay(endSelected)) {\n                        row.isActive = true;\n                    }\n                } else if (date.isSameDay(this.value)) {\n                    row.isActive = true;\n                }\n\n                row.dateCells.push(cell);\n            }\n\n            row.classMap = {\n                [`${this.prefixCls}-current-week`]: row.isCurrent,\n                [`${this.prefixCls}-active-week`]: row.isActive\n            };\n\n            dateRows.push(row);\n        }\n\n        return dateRows;\n    }\n\n    addCellProperty(cell: DateCell, date: TinyDate): void {\n        if (this.selectedValue?.length > 0) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            if (endSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeDay(date) && date.isBeforeDay(endSelected);\n        } else {\n            cell.isSelected = date.isSameDay(this.value);\n        }\n        cell.isLastMonthCell = date.isBeforeMonth(this.activeDate);\n        cell.isNextMonthCell = date.isAfterMonth(this.activeDate);\n        cell.isToday = date.isToday();\n        cell.isDisabled = !!this.disabledDate?.(date.nativeDate);\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    getClassMap(cell: DateCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-cell`]: true,\n            [`${this.prefixCls}-today`]: cell.isToday,\n            [`${this.prefixCls}-last-month-cell`]: cell.isLastMonthCell,\n            [`${this.prefixCls}-next-month-btn-day`]: cell.isNextMonthCell,\n            [`${this.prefixCls}-selected-day`]: cell.isSelected,\n            [`${this.prefixCls}-disabled-cell`]: cell.isDisabled,\n            [`${this.prefixCls}-selected-start-date`]: !!cell.isSelectedStartDate,\n            [`${this.prefixCls}-selected-end-date`]: !!cell.isSelectedEndDate,\n            [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n  <thead>\n    <tr role=\"row\">\n      @if (showWeek) {\n        <th role=\"columnheader\" [title]=\"locale().week\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n          <span class=\"{{ prefixCls }}-column-header-inner\">{{ locale().prefixWeek }}</span>\n        </th>\n      }\n      @for (cell of headRow; track $index) {\n        <th role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n          @if (prefixCls === 'thy-calendar') {\n            <span class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n          }\n          @if (prefixCls === 'thy-calendar-full') {\n            <span class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n          }\n        </th>\n      }\n    </tr>\n  </thead>\n  <tbody class=\"{{ prefixCls }}-tbody\">\n    @for (row of bodyRows; track $index) {\n      <tr [ngClass]=\"row.classMap\" role=\"row\">\n        @if (row.weekNum) {\n          <td role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n            {{ row.weekNum }}\n          </td>\n        }\n        @for (cell of row.dateCells; track $index) {\n          <td\n            role=\"gridcell\"\n            [ngClass]=\"cell.classMap\"\n            (click)=\"cell.isDisabled ? null : cell.onClick()\"\n            date-table-cell\n            [prefixCls]=\"prefixCls\"\n            [cell]=\"cell\"></td>\n        }\n      </tr>\n    }\n  </tbody>\n</table>\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-table.component.js","sourceRoot":"","sources":["../../../../../../src/date-picker/lib/date/date-table.component.ts","../../../../../../src/date-picker/lib/date/date-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, EventEmitter, OnChanges, Output, inject } from '@angular/core';\nimport { TinyDate, valueFunctionProp } from 'ngx-tethys/util';\nimport { DateHelperService } from '../../date-helper.service';\nimport { ThyDatePickerConfigService } from '../../date-picker.service';\nimport { CalendarTable } from '../calendar/calendar-table.component';\nimport { DateTableCell } from './date-table-cell.component';\nimport { DateBodyRow, DateCell } from './types';\n\n/**\n * @private\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'date-table',\n    exportAs: 'dateTable',\n    templateUrl: 'date-table.component.html',\n    standalone: true,\n    imports: [NgClass, DateTableCell]\n})\nexport class DateTable extends CalendarTable implements OnChanges {\n    private dateHelper = inject(DateHelperService);\n    private datePickerConfigService = inject(ThyDatePickerConfigService);\n\n    @Output() readonly dayHover = new EventEmitter<TinyDate>(); // Emitted when hover on a day by mouse enter\n\n    constructor() {\n        super();\n    }\n\n    private chooseDate(value: TinyDate): void {\n        // Only change date not change time\n        const date = new TinyDate(\n            TinyDate.createDateInTimeZone(\n                value.getFullYear(),\n                value.getMonth(),\n                value.getDate(),\n                this.activeDate?.getHours(),\n                this.activeDate?.getMinutes(),\n                this.activeDate?.getSeconds(),\n                this.timeZone\n            ),\n            this.timeZone\n        );\n        this.activeDate = date.clone();\n        this.valueChange.emit(date);\n    }\n\n    makeHeadRow(): DateCell[] {\n        const weekDays: DateCell[] = [];\n        const start = this.activeDate.calendarStart({ weekStartsOn: this.datePickerConfigService.config.weekStartsOn });\n        for (let colIndex = 0; colIndex < this.MAX_COL; colIndex++) {\n            const day = start.addDays(colIndex);\n            weekDays[colIndex] = {\n                title: this.dateHelper.format(day.nativeDate, this.dateHelper.relyOnDatePipe ? 'E' : 'ddd'),\n                content: this.dateHelper.format(day.nativeDate, this.getVeryShortWeekFormat()),\n                isSelected: false,\n                isDisabled: false,\n                onClick(): void {},\n                onMouseEnter(): void {}\n            };\n        }\n        return weekDays;\n    }\n\n    private getVeryShortWeekFormat(): string {\n        if (this.dateHelper.relyOnDatePipe) {\n            return this.prefixCls === 'thy-calendar-full' ? this.locale().fullWeekFormat : this.locale().weekFormat;\n        }\n        return 'dd';\n    }\n\n    makeBodyRows(): DateBodyRow[] {\n        const dateRows: DateBodyRow[] = [];\n        const firstDayOfMonth = this.activeDate.calendarStart({ weekStartsOn: this.datePickerConfigService.config.weekStartsOn });\n        for (let week = 0; week < this.MAX_ROW; week++) {\n            const weekStart = firstDayOfMonth.addDays(week * 7);\n            const row: DateBodyRow = {\n                isActive: false,\n                isCurrent: false,\n                dateCells: [],\n                year: weekStart.getYear()\n            };\n\n            for (let day = 0; day < 7; day++) {\n                const date = weekStart.addDays(day);\n                const dateFormat = this.dateHelper.relyOnDatePipe ? 'longDate' : 'YYYY-MM-DD';\n                const title = this.dateHelper.format(date.nativeDate, dateFormat);\n                const label = this.dateHelper.format(date.nativeDate, this.dateHelper.relyOnDatePipe ? 'dd' : 'DD');\n\n                const cell: DateCell = {\n                    value: date.nativeDate,\n                    label: label,\n                    isSelected: false,\n                    isDisabled: false,\n                    isToday: false,\n                    title: title,\n                    dateCellRender: valueFunctionProp(this.cellRender, date),\n                    content: `${date.getDate()}`,\n                    onClick: () => this.chooseDate(date),\n                    onMouseEnter: () => this.dayHover.emit(date)\n                };\n                this.addCellProperty(cell, date);\n\n                if (this.showWeek && !row.weekNum) {\n                    row.weekNum = this.dateHelper.getISOWeek(date.nativeDate);\n                }\n\n                if (date.isToday()) {\n                    cell.isToday = true;\n                    row.isCurrent = true;\n                }\n\n                if (this.selectedValue?.length > 0) {\n                    const [startSelected, endSelected] = this.selectedValue;\n                    if (date.isSameDay(startSelected)) {\n                        row.isActive = true;\n                    }\n                    if (date.isSameDay(endSelected)) {\n                        row.isActive = true;\n                    }\n                } else if (date.isSameDay(this.value)) {\n                    row.isActive = true;\n                }\n\n                row.dateCells.push(cell);\n            }\n\n            row.classMap = {\n                [`${this.prefixCls}-current-week`]: row.isCurrent,\n                [`${this.prefixCls}-active-week`]: row.isActive\n            };\n\n            dateRows.push(row);\n        }\n\n        return dateRows;\n    }\n\n    addCellProperty(cell: DateCell, date: TinyDate): void {\n        if (this.selectedValue?.length > 0) {\n            const [startSelected, endSelected] = this.selectedValue;\n            if (startSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            if (endSelected?.isSameDay(date)) {\n                cell.isSelected = true;\n            }\n            cell.isStartSingle = startSelected && !endSelected;\n            cell.isEndSingle = !startSelected && !!endSelected;\n            cell.isInRange = startSelected?.isBeforeDay(date) && date.isBeforeDay(endSelected);\n        } else {\n            cell.isSelected = date.isSameDay(this.value);\n        }\n        cell.isLastMonthCell = date.isBeforeMonth(this.activeDate);\n        cell.isNextMonthCell = date.isAfterMonth(this.activeDate);\n        cell.isToday = date.isToday();\n        cell.isDisabled = !!this.disabledDate?.(date.nativeDate);\n        cell.classMap = this.getClassMap(cell);\n    }\n\n    getClassMap(cell: DateCell): { [key: string]: boolean } {\n        return {\n            [`${this.prefixCls}-cell`]: true,\n            [`${this.prefixCls}-today`]: cell.isToday,\n            [`${this.prefixCls}-last-month-cell`]: cell.isLastMonthCell,\n            [`${this.prefixCls}-next-month-btn-day`]: cell.isNextMonthCell,\n            [`${this.prefixCls}-selected-day`]: cell.isSelected,\n            [`${this.prefixCls}-disabled-cell`]: cell.isDisabled,\n            [`${this.prefixCls}-selected-start-date`]: !!cell.isSelectedStartDate,\n            [`${this.prefixCls}-selected-end-date`]: !!cell.isSelectedEndDate,\n            [`${this.prefixCls}-in-range-cell`]: !!cell.isInRange\n        };\n    }\n}\n","<table class=\"{{ prefixCls }}-table\" cellSpacing=\"0\" role=\"grid\">\n  <thead>\n    <tr role=\"row\">\n      @if (showWeek) {\n        <th role=\"columnheader\" [title]=\"locale().week\" class=\"{{ prefixCls }}-column-header {{ prefixCls }}-week-number-header\">\n          <span class=\"{{ prefixCls }}-column-header-inner\">{{ locale().prefixWeek }}</span>\n        </th>\n      }\n      @for (cell of headRow; track $index) {\n        <th role=\"columnheader\" title=\"{{ cell.title }}\" class=\"{{ prefixCls }}-column-header\">\n          @if (prefixCls === 'thy-calendar') {\n            <span class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n          }\n          @if (prefixCls === 'thy-calendar-full') {\n            <span class=\"{{ prefixCls }}-column-header-inner\">{{ cell.content }}</span>\n          }\n        </th>\n      }\n    </tr>\n  </thead>\n  <tbody class=\"{{ prefixCls }}-tbody\">\n    @for (row of bodyRows; track $index) {\n      <tr [ngClass]=\"row.classMap\" role=\"row\">\n        @if (row.weekNum) {\n          <td role=\"gridcell\" class=\"{{ prefixCls }}-week-number-cell\">\n            {{ row.weekNum }}\n          </td>\n        }\n        @for (cell of row.dateCells; track $index) {\n          <td\n            role=\"gridcell\"\n            [ngClass]=\"cell.classMap\"\n            (click)=\"cell.isDisabled ? null : cell.onClick()\"\n            date-table-cell\n            [prefixCls]=\"prefixCls\"\n            [cell]=\"cell\"></td>\n        }\n      </tr>\n    }\n  </tbody>\n</table>\n"]}