UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

1 lines 84.1 kB
{"version":3,"file":"ng-zorro-antd-time-picker.mjs","sources":["../../components/time-picker/time-holder.ts","../../components/time-picker/time-picker-panel.component.ts","../../components/time-picker/time-picker.component.ts","../../components/time-picker/time-picker.module.ts","../../components/time-picker/public-api.ts","../../components/time-picker/ng-zorro-antd-time-picker.ts"],"sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Observable, Subject } from 'rxjs';\n\nimport { isNil, isNotNil } from 'ng-zorro-antd/core/util';\n\nexport class TimeHolder {\n selected12Hours: string | undefined = undefined;\n private _value: Date | undefined;\n private _use12Hours: boolean = false;\n private _defaultOpenValue!: Date;\n private _changes = new Subject<Date>();\n\n setMinutes(value: number, disabled: boolean): this {\n if (!disabled) {\n this.initValue();\n this.value.setMinutes(value);\n this.update();\n }\n return this;\n }\n\n setHours(value: number, disabled: boolean): this {\n if (!disabled) {\n this.initValue();\n if (this._use12Hours) {\n if (this.selected12Hours === 'PM' && value !== 12) {\n this.value.setHours((value as number) + 12);\n } else if (this.selected12Hours === 'AM' && value === 12) {\n this.value.setHours(0);\n } else {\n this.value.setHours(value);\n }\n } else {\n this.value.setHours(value);\n }\n this.update();\n }\n return this;\n }\n\n setSeconds(value: number, disabled: boolean): this {\n if (!disabled) {\n this.initValue();\n this.value.setSeconds(value);\n this.update();\n }\n return this;\n }\n\n setUse12Hours(value: boolean): this {\n this._use12Hours = value;\n return this;\n }\n\n get changes(): Observable<Date> {\n return this._changes.asObservable();\n }\n\n setValue(value: Date | undefined, use12Hours?: boolean): this {\n if (isNotNil(use12Hours)) {\n this._use12Hours = use12Hours as boolean;\n }\n if (value !== this.value) {\n this._value = value;\n if (isNotNil(this.value)) {\n if (this._use12Hours && isNotNil(this.hours)) {\n this.selected12Hours = this.hours >= 12 ? 'PM' : 'AM';\n }\n } else {\n this._clear();\n }\n }\n\n return this;\n }\n\n initValue(): void {\n if (isNil(this.value)) {\n this.setValue(new Date(), this._use12Hours);\n }\n }\n\n clear(): void {\n this._clear();\n this.update();\n }\n\n get isEmpty(): boolean {\n return !(isNotNil(this.hours) || isNotNil(this.minutes) || isNotNil(this.seconds));\n }\n\n private _clear(): void {\n this._value = undefined;\n this.selected12Hours = undefined;\n }\n\n private update(): void {\n if (this.isEmpty) {\n this._value = undefined;\n } else {\n if (isNotNil(this.hours)) {\n this.value!.setHours(this.hours!);\n }\n\n if (isNotNil(this.minutes)) {\n this.value!.setMinutes(this.minutes!);\n }\n\n if (isNotNil(this.seconds)) {\n this.value!.setSeconds(this.seconds!);\n }\n\n if (this._use12Hours) {\n if (this.selected12Hours === 'PM' && this.hours! < 12) {\n this.value!.setHours(this.hours! + 12);\n }\n if (this.selected12Hours === 'AM' && this.hours! >= 12) {\n this.value!.setHours(this.hours! - 12);\n }\n }\n }\n this.changed();\n }\n\n changed(): void {\n this._changes.next(this.value);\n }\n\n /**\n * @description\n * UI view hours\n * Get viewHours which is selected in `time-picker-panel` and its range is [12, 1, 2, ..., 11]\n */\n get viewHours(): number | undefined {\n return this._use12Hours && isNotNil(this.hours) ? this.calculateViewHour(this.hours!) : this.hours;\n }\n\n setSelected12Hours(value: string | undefined): void {\n if (value!.toUpperCase() !== this.selected12Hours) {\n this.selected12Hours = value!.toUpperCase();\n this.update();\n }\n }\n\n get value(): Date {\n return this._value || this._defaultOpenValue;\n }\n\n get hours(): number | undefined {\n return this.value?.getHours();\n }\n\n get minutes(): number | undefined {\n return this.value?.getMinutes();\n }\n\n get seconds(): number | undefined {\n return this.value?.getSeconds();\n }\n\n setDefaultOpenValue(value: Date): this {\n this._defaultOpenValue = value;\n return this;\n }\n\n private calculateViewHour(value: number): number {\n const selected12Hours = this.selected12Hours;\n if (selected12Hours === 'PM' && value > 12) {\n return value - 12;\n }\n if (selected12Hours === 'AM' && value === 0) {\n return 12;\n }\n return value;\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { DecimalPipe, NgTemplateOutlet } from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n DebugElement,\n ElementRef,\n EventEmitter,\n Input,\n NgZone,\n OnChanges,\n OnDestroy,\n OnInit,\n Output,\n SimpleChanges,\n TemplateRef,\n ViewChild,\n ViewEncapsulation,\n booleanAttribute,\n forwardRef,\n numberAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzButtonModule } from 'ng-zorro-antd/button';\nimport { reqAnimFrame } from 'ng-zorro-antd/core/polyfill';\nimport { fromEventOutsideAngular, isNotNil } from 'ng-zorro-antd/core/util';\nimport { DateHelperService, NzI18nModule } from 'ng-zorro-antd/i18n';\n\nimport { TimeHolder } from './time-holder';\n\nfunction makeRange(length: number, step: number = 1, start: number = 0): number[] {\n return new Array(Math.ceil(length / step)).fill(0).map((_, i) => (i + start) * step);\n}\n\nexport type NzTimePickerUnit = 'hour' | 'minute' | 'second' | '12-hour';\n\n@Component({\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n selector: 'nz-time-picker-panel',\n exportAs: 'nzTimePickerPanel',\n template: `\n @if (nzInDatePicker) {\n <div class=\"ant-picker-header\">\n <div class=\"ant-picker-header-view\">{{ dateHelper.format($any(time?.value), format) || '&nbsp;' }}</div>\n </div>\n }\n <div class=\"ant-picker-content\">\n @if (hourEnabled) {\n <ul #hourListElement class=\"ant-picker-time-panel-column\" style=\"position: relative;\">\n @for (hour of hourRange; track $index) {\n @if (!(nzHideDisabledOptions && hour.disabled)) {\n <li\n class=\"ant-picker-time-panel-cell\"\n (click)=\"selectHour(hour)\"\n [class.ant-picker-time-panel-cell-selected]=\"isSelectedHour(hour)\"\n [class.ant-picker-time-panel-cell-disabled]=\"hour.disabled\"\n >\n <div class=\"ant-picker-time-panel-cell-inner\">{{ hour.index | number: '2.0-0' }}</div>\n </li>\n }\n }\n </ul>\n }\n @if (minuteEnabled) {\n <ul #minuteListElement class=\"ant-picker-time-panel-column\" style=\"position: relative;\">\n @for (minute of minuteRange; track $index) {\n @if (!(nzHideDisabledOptions && minute.disabled)) {\n <li\n class=\"ant-picker-time-panel-cell\"\n (click)=\"selectMinute(minute)\"\n [class.ant-picker-time-panel-cell-selected]=\"isSelectedMinute(minute)\"\n [class.ant-picker-time-panel-cell-disabled]=\"minute.disabled\"\n >\n <div class=\"ant-picker-time-panel-cell-inner\">{{ minute.index | number: '2.0-0' }}</div>\n </li>\n }\n }\n </ul>\n }\n @if (secondEnabled) {\n <ul #secondListElement class=\"ant-picker-time-panel-column\" style=\"position: relative;\">\n @for (second of secondRange; track $index) {\n @if (!(nzHideDisabledOptions && second.disabled)) {\n <li\n class=\"ant-picker-time-panel-cell\"\n (click)=\"selectSecond(second)\"\n [class.ant-picker-time-panel-cell-selected]=\"isSelectedSecond(second)\"\n [class.ant-picker-time-panel-cell-disabled]=\"second.disabled\"\n >\n <div class=\"ant-picker-time-panel-cell-inner\">{{ second.index | number: '2.0-0' }}</div>\n </li>\n }\n }\n </ul>\n }\n @if (nzUse12Hours) {\n <ul #use12HoursListElement class=\"ant-picker-time-panel-column\" style=\"position: relative;\">\n @for (range of use12HoursRange; track range) {\n <li\n (click)=\"select12Hours(range)\"\n class=\"ant-picker-time-panel-cell\"\n [class.ant-picker-time-panel-cell-selected]=\"isSelected12Hours(range)\"\n >\n <div class=\"ant-picker-time-panel-cell-inner\">{{ range.value }}</div>\n </li>\n }\n </ul>\n }\n </div>\n @if (!nzInDatePicker) {\n <div class=\"ant-picker-footer\">\n @if (nzAddOn) {\n <div class=\"ant-picker-footer-extra\">\n <ng-template [ngTemplateOutlet]=\"nzAddOn\"></ng-template>\n </div>\n }\n <ul class=\"ant-picker-ranges\">\n <li class=\"ant-picker-now\">\n <a (click)=\"onClickNow()\">\n {{ nzNowText || ('Calendar.lang.now' | nzI18n) }}\n </a>\n </li>\n <li class=\"ant-picker-ok\">\n <button nz-button type=\"button\" nzSize=\"small\" nzType=\"primary\" (click)=\"onClickOk()\">\n {{ nzOkText || ('Calendar.lang.ok' | nzI18n) }}\n </button>\n </li>\n </ul>\n </div>\n }\n `,\n host: {\n class: 'ant-picker-time-panel',\n '[class.ant-picker-time-panel-column-0]': `enabledColumns === 0 && !nzInDatePicker`,\n '[class.ant-picker-time-panel-column-1]': `enabledColumns === 1 && !nzInDatePicker`,\n '[class.ant-picker-time-panel-column-2]': `enabledColumns === 2 && !nzInDatePicker`,\n '[class.ant-picker-time-panel-column-3]': `enabledColumns === 3 && !nzInDatePicker`,\n '[class.ant-picker-time-panel-narrow]': `enabledColumns < 3`,\n '[class.ant-picker-time-panel-placement-bottomLeft]': `!nzInDatePicker`\n },\n providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzTimePickerPanelComponent), multi: true }],\n imports: [DecimalPipe, NgTemplateOutlet, NzI18nModule, NzButtonModule]\n})\nexport class NzTimePickerPanelComponent implements ControlValueAccessor, OnInit, OnDestroy, OnChanges {\n private _nzHourStep = 1;\n private _nzMinuteStep = 1;\n private _nzSecondStep = 1;\n private unsubscribe$ = new Subject<void>();\n private onChange?: (value: Date) => void;\n private onTouch?: () => void;\n private _format = 'HH:mm:ss';\n private _disabledHours?: () => number[] = () => [];\n private _disabledMinutes?: (hour: number) => number[] = () => [];\n private _disabledSeconds?: (hour: number, minute: number) => number[] = () => [];\n private _allowEmpty = true;\n time = new TimeHolder();\n hourEnabled = true;\n minuteEnabled = true;\n secondEnabled = true;\n firstScrolled = false;\n enabledColumns = 3;\n hourRange!: ReadonlyArray<{ index: number; disabled: boolean }>;\n minuteRange!: ReadonlyArray<{ index: number; disabled: boolean }>;\n secondRange!: ReadonlyArray<{ index: number; disabled: boolean }>;\n use12HoursRange!: ReadonlyArray<{ index: number; value: string }>;\n\n @ViewChild('hourListElement', { static: false })\n hourListElement?: DebugElement;\n @ViewChild('minuteListElement', { static: false }) minuteListElement?: DebugElement;\n @ViewChild('secondListElement', { static: false }) secondListElement?: DebugElement;\n @ViewChild('use12HoursListElement', { static: false }) use12HoursListElement?: DebugElement;\n\n @Input({ transform: booleanAttribute }) nzInDatePicker: boolean = false; // If inside a date-picker, more diff works need to be done\n @Input() nzAddOn?: TemplateRef<void>;\n @Input() nzHideDisabledOptions = false;\n @Input() nzClearText?: string;\n @Input() nzNowText?: string;\n @Input() nzOkText?: string;\n @Input() nzPlaceHolder?: string | null;\n @Input({ transform: booleanAttribute }) nzUse12Hours = false;\n @Input() nzDefaultOpenValue?: Date;\n\n @Output() readonly closePanel = new EventEmitter<void>();\n\n @Input({ transform: booleanAttribute })\n set nzAllowEmpty(value: boolean) {\n this._allowEmpty = value;\n }\n\n get nzAllowEmpty(): boolean {\n return this._allowEmpty;\n }\n\n @Input()\n set nzDisabledHours(value: undefined | (() => number[])) {\n this._disabledHours = value;\n if (this._disabledHours) {\n this.buildHours();\n }\n }\n\n get nzDisabledHours(): undefined | (() => number[]) {\n return this._disabledHours;\n }\n\n @Input()\n set nzDisabledMinutes(value: undefined | ((hour: number) => number[])) {\n if (isNotNil(value)) {\n this._disabledMinutes = value;\n this.buildMinutes();\n }\n }\n\n get nzDisabledMinutes(): undefined | ((hour: number) => number[]) {\n return this._disabledMinutes;\n }\n\n @Input()\n set nzDisabledSeconds(value: undefined | ((hour: number, minute: number) => number[])) {\n if (isNotNil(value)) {\n this._disabledSeconds = value;\n this.buildSeconds();\n }\n }\n\n get nzDisabledSeconds(): undefined | ((hour: number, minute: number) => number[]) {\n return this._disabledSeconds;\n }\n\n @Input()\n set format(value: string) {\n if (isNotNil(value)) {\n this._format = value;\n this.enabledColumns = 0;\n const charSet = new Set(value);\n this.hourEnabled = charSet.has('H') || charSet.has('h');\n this.minuteEnabled = charSet.has('m');\n this.secondEnabled = charSet.has('s');\n if (this.hourEnabled) {\n this.enabledColumns++;\n }\n if (this.minuteEnabled) {\n this.enabledColumns++;\n }\n if (this.secondEnabled) {\n this.enabledColumns++;\n }\n if (this.nzUse12Hours) {\n this.build12Hours();\n }\n }\n }\n\n get format(): string {\n return this._format;\n }\n\n @Input({ transform: numberAttribute })\n set nzHourStep(value: number) {\n this._nzHourStep = value || 1;\n this.buildHours();\n }\n\n get nzHourStep(): number {\n return this._nzHourStep;\n }\n\n @Input({ transform: numberAttribute })\n set nzMinuteStep(value: number) {\n this._nzMinuteStep = value || 1;\n this.buildMinutes();\n }\n\n get nzMinuteStep(): number {\n return this._nzMinuteStep;\n }\n\n @Input({ transform: numberAttribute })\n set nzSecondStep(value: number) {\n this._nzSecondStep = value || 1;\n this.buildSeconds();\n }\n\n get nzSecondStep(): number {\n return this._nzSecondStep;\n }\n\n buildHours(): void {\n let hourRanges = 24;\n let disabledHours = this.nzDisabledHours?.();\n let startIndex = 0;\n if (this.nzUse12Hours) {\n hourRanges = 12;\n if (disabledHours) {\n if (this.time.selected12Hours === 'PM') {\n /**\n * Filter and transform hours which greater or equal to 12\n * [0, 1, 2, ..., 12, 13, 14, 15, ..., 23] => [12, 1, 2, 3, ..., 11]\n */\n disabledHours = disabledHours.filter(i => i >= 12).map(i => (i > 12 ? i - 12 : i));\n } else {\n /**\n * Filter and transform hours which less than 12\n * [0, 1, 2,..., 12, 13, 14, 15, ...23] => [12, 1, 2, 3, ..., 11]\n */\n disabledHours = disabledHours.filter(i => i < 12 || i === 24).map(i => (i === 24 || i === 0 ? 12 : i));\n }\n }\n startIndex = 1;\n }\n this.hourRange = makeRange(hourRanges, this.nzHourStep, startIndex).map(r => ({\n index: r,\n disabled: !!disabledHours && disabledHours.indexOf(r) !== -1\n }));\n if (this.nzUse12Hours && this.hourRange[this.hourRange.length - 1].index === 12) {\n const temp = [...this.hourRange];\n temp.unshift(temp[temp.length - 1]);\n temp.splice(temp.length - 1, 1);\n this.hourRange = temp;\n }\n }\n\n buildMinutes(): void {\n this.minuteRange = makeRange(60, this.nzMinuteStep).map(r => ({\n index: r,\n disabled: !!this.nzDisabledMinutes && this.nzDisabledMinutes(this.time.hours!).indexOf(r) !== -1\n }));\n }\n\n buildSeconds(): void {\n this.secondRange = makeRange(60, this.nzSecondStep).map(r => ({\n index: r,\n disabled:\n !!this.nzDisabledSeconds && this.nzDisabledSeconds(this.time.hours!, this.time.minutes!).indexOf(r) !== -1\n }));\n }\n\n build12Hours(): void {\n const isUpperFormat = this._format.includes('A');\n this.use12HoursRange = [\n {\n index: 0,\n value: isUpperFormat ? 'AM' : 'am'\n },\n {\n index: 1,\n value: isUpperFormat ? 'PM' : 'pm'\n }\n ];\n }\n\n buildTimes(): void {\n this.buildHours();\n this.buildMinutes();\n this.buildSeconds();\n this.build12Hours();\n }\n\n scrollToTime(delay: number = 0): void {\n if (this.hourEnabled && this.hourListElement) {\n this.scrollToSelected(this.hourListElement.nativeElement, this.time.viewHours!, delay, 'hour');\n }\n if (this.minuteEnabled && this.minuteListElement) {\n this.scrollToSelected(this.minuteListElement.nativeElement, this.time.minutes!, delay, 'minute');\n }\n if (this.secondEnabled && this.secondListElement) {\n this.scrollToSelected(this.secondListElement.nativeElement, this.time.seconds!, delay, 'second');\n }\n if (this.nzUse12Hours && this.use12HoursListElement) {\n const selectedHours = this.time.selected12Hours;\n const index = selectedHours === 'AM' ? 0 : 1;\n this.scrollToSelected(this.use12HoursListElement.nativeElement, index, delay, '12-hour');\n }\n }\n\n selectHour(hour: { index: number; disabled: boolean }): void {\n this.time.setHours(hour.index, hour.disabled);\n if (this._disabledMinutes) {\n this.buildMinutes();\n }\n if (this._disabledSeconds || this._disabledMinutes) {\n this.buildSeconds();\n }\n }\n\n selectMinute(minute: { index: number; disabled: boolean }): void {\n this.time.setMinutes(minute.index, minute.disabled);\n if (this._disabledSeconds) {\n this.buildSeconds();\n }\n }\n\n selectSecond(second: { index: number; disabled: boolean }): void {\n this.time.setSeconds(second.index, second.disabled);\n }\n\n select12Hours(value: { index: number; value: string }): void {\n this.time.setSelected12Hours(value.value);\n if (this._disabledHours) {\n this.buildHours();\n }\n if (this._disabledMinutes) {\n this.buildMinutes();\n }\n if (this._disabledSeconds) {\n this.buildSeconds();\n }\n }\n\n scrollToSelected(instance: HTMLElement, index: number, duration: number = 0, unit: NzTimePickerUnit): void {\n if (!instance) {\n return;\n }\n const transIndex = this.translateIndex(index, unit);\n const currentOption = (instance.children[transIndex] || instance.children[0]) as HTMLElement;\n this.scrollTo(instance, currentOption.offsetTop, duration);\n }\n\n translateIndex(index: number, unit: NzTimePickerUnit): number {\n if (unit === 'hour') {\n return this.calcIndex(this.nzDisabledHours?.(), this.hourRange.map(item => item.index).indexOf(index));\n } else if (unit === 'minute') {\n return this.calcIndex(\n this.nzDisabledMinutes?.(this.time.hours!),\n this.minuteRange.map(item => item.index).indexOf(index)\n );\n } else if (unit === 'second') {\n // second\n return this.calcIndex(\n this.nzDisabledSeconds?.(this.time.hours!, this.time.minutes!),\n this.secondRange.map(item => item.index).indexOf(index)\n );\n } else {\n // 12-hour\n return this.calcIndex([], this.use12HoursRange.map(item => item.index).indexOf(index));\n }\n }\n\n scrollTo(element: HTMLElement, to: number, duration: number): void {\n if (duration <= 0) {\n element.scrollTop = to;\n return;\n }\n const difference = to - element.scrollTop;\n const perTick = (difference / duration) * 10;\n\n this.ngZone.runOutsideAngular(() => {\n reqAnimFrame(() => {\n element.scrollTop = element.scrollTop + perTick;\n if (element.scrollTop === to) {\n return;\n }\n this.scrollTo(element, to, duration - 10);\n });\n });\n }\n\n calcIndex(array: number[] | undefined, index: number): number {\n if (array?.length && this.nzHideDisabledOptions) {\n return index - array.reduce((pre, value) => pre + (value < index ? 1 : 0), 0);\n } else {\n return index;\n }\n }\n\n protected changed(): void {\n if (this.onChange) {\n this.onChange(this.time.value!);\n }\n }\n\n protected touched(): void {\n if (this.onTouch) {\n this.onTouch();\n }\n }\n\n timeDisabled(value: Date): boolean {\n const hour = value.getHours();\n const minute = value.getMinutes();\n const second = value.getSeconds();\n return (\n (this.nzDisabledHours?.().indexOf(hour) ?? -1) > -1 ||\n (this.nzDisabledMinutes?.(hour).indexOf(minute) ?? -1) > -1 ||\n (this.nzDisabledSeconds?.(hour, minute).indexOf(second) ?? -1) > -1\n );\n }\n\n onClickNow(): void {\n const now = new Date();\n if (this.timeDisabled(now)) {\n return;\n }\n this.time.setValue(now);\n this.changed();\n this.closePanel.emit();\n }\n\n onClickOk(): void {\n this.time.setValue(this.time.value, this.nzUse12Hours);\n this.changed();\n this.closePanel.emit();\n }\n\n isSelectedHour(hour: { index: number; disabled: boolean }): boolean {\n return hour.index === this.time.viewHours;\n }\n\n isSelectedMinute(minute: { index: number; disabled: boolean }): boolean {\n return minute.index === this.time.minutes;\n }\n\n isSelectedSecond(second: { index: number; disabled: boolean }): boolean {\n return second.index === this.time.seconds;\n }\n\n isSelected12Hours(value: { index: number; value: string }): boolean {\n return value.value.toUpperCase() === this.time.selected12Hours;\n }\n\n constructor(\n private ngZone: NgZone,\n private cdr: ChangeDetectorRef,\n public dateHelper: DateHelperService,\n private elementRef: ElementRef<HTMLElement>\n ) {}\n\n ngOnInit(): void {\n this.time.changes.pipe(takeUntil(this.unsubscribe$)).subscribe(() => {\n this.changed();\n this.touched();\n this.scrollToTime(120);\n });\n this.buildTimes();\n\n this.ngZone.runOutsideAngular(() => {\n setTimeout(() => {\n this.scrollToTime();\n this.firstScrolled = true;\n });\n });\n\n fromEventOutsideAngular(this.elementRef.nativeElement, 'mousedown')\n .pipe(takeUntil(this.unsubscribe$))\n .subscribe(event => {\n event.preventDefault();\n });\n }\n\n ngOnDestroy(): void {\n this.unsubscribe$.next();\n this.unsubscribe$.complete();\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n const { nzUse12Hours, nzDefaultOpenValue } = changes;\n if (!nzUse12Hours?.previousValue && nzUse12Hours?.currentValue) {\n this.build12Hours();\n this.enabledColumns++;\n }\n if (nzDefaultOpenValue?.currentValue) {\n this.time.setDefaultOpenValue(this.nzDefaultOpenValue || new Date());\n }\n }\n\n writeValue(value: Date): void {\n this.time.setValue(value, this.nzUse12Hours);\n this.buildTimes();\n\n if (value && this.firstScrolled) {\n this.scrollToTime(120);\n }\n // Mark this component to be checked manually with internal properties changing (see: https://github.com/angular/angular/issues/10816)\n this.cdr.markForCheck();\n }\n\n registerOnChange(fn: (value: Date) => void): void {\n this.onChange = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this.onTouch = fn;\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport { ConnectionPositionPair, OverlayModule } from '@angular/cdk/overlay';\nimport { Platform, _getEventTarget } from '@angular/cdk/platform';\nimport { AsyncPipe } from '@angular/common';\nimport {\n AfterViewInit,\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n ElementRef,\n EventEmitter,\n Input,\n OnChanges,\n OnInit,\n Output,\n Renderer2,\n SimpleChanges,\n TemplateRef,\n ViewChild,\n ViewEncapsulation,\n booleanAttribute,\n computed,\n forwardRef,\n inject,\n signal\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable, of } from 'rxjs';\nimport { distinctUntilChanged, map, takeUntil, withLatestFrom } from 'rxjs/operators';\n\nimport { isValid } from 'date-fns';\n\nimport { slideMotion } from 'ng-zorro-antd/core/animation';\nimport { NzConfigKey, NzConfigService, WithConfig } from 'ng-zorro-antd/core/config';\nimport { NzFormItemFeedbackIconComponent, NzFormNoStatusService, NzFormStatusService } from 'ng-zorro-antd/core/form';\nimport { warn } from 'ng-zorro-antd/core/logger';\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzOverlayModule } from 'ng-zorro-antd/core/overlay';\nimport { NzDestroyService } from 'ng-zorro-antd/core/services';\nimport { NgClassInterface, NzSafeAny, NzSizeLDSType, NzStatus, NzValidateStatus } from 'ng-zorro-antd/core/types';\nimport { getStatusClassNames, isNil } from 'ng-zorro-antd/core/util';\nimport { DateHelperService, NzI18nInterface, NzI18nService } from 'ng-zorro-antd/i18n';\nimport { NzIconModule } from 'ng-zorro-antd/icon';\nimport { NZ_SPACE_COMPACT_ITEM_TYPE, NZ_SPACE_COMPACT_SIZE, NzSpaceCompactItemDirective } from 'ng-zorro-antd/space';\n\nimport { NzTimePickerPanelComponent } from './time-picker-panel.component';\n\nconst NZ_CONFIG_MODULE_NAME: NzConfigKey = 'timePicker';\n\n@Component({\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n selector: 'nz-time-picker',\n exportAs: 'nzTimePicker',\n template: `\n <div class=\"ant-picker-input\">\n <input\n #inputElement\n [attr.id]=\"nzId\"\n type=\"text\"\n [size]=\"inputSize\"\n autocomplete=\"off\"\n [placeholder]=\"nzPlaceHolder || (i18nPlaceHolder$ | async)\"\n [(ngModel)]=\"inputValue\"\n [disabled]=\"nzDisabled\"\n [readOnly]=\"nzInputReadOnly\"\n (focus)=\"onFocus(true)\"\n (blur)=\"onFocus(false)\"\n (keyup.enter)=\"onKeyupEnter()\"\n (keyup.escape)=\"onKeyupEsc()\"\n (ngModelChange)=\"onInputChange($event)\"\n />\n <span class=\"ant-picker-suffix\">\n <ng-container *nzStringTemplateOutlet=\"nzSuffixIcon; let suffixIcon\">\n <nz-icon [nzType]=\"suffixIcon\" />\n </ng-container>\n @if (hasFeedback && !!status) {\n <nz-form-item-feedback-icon [status]=\"status\"></nz-form-item-feedback-icon>\n }\n </span>\n @if (nzAllowEmpty && !nzDisabled && value) {\n <span class=\"ant-picker-clear\" (click)=\"onClickClearBtn($event)\">\n <nz-icon nzType=\"close-circle\" nzTheme=\"fill\" [attr.aria-label]=\"nzClearText\" [attr.title]=\"nzClearText\" />\n </span>\n }\n </div>\n\n <ng-template\n cdkConnectedOverlay\n nzConnectedOverlay\n [cdkConnectedOverlayHasBackdrop]=\"nzBackdrop\"\n [cdkConnectedOverlayPositions]=\"overlayPositions\"\n [cdkConnectedOverlayOrigin]=\"origin\"\n [cdkConnectedOverlayOpen]=\"nzOpen\"\n [cdkConnectedOverlayTransformOriginOn]=\"'.ant-picker-dropdown'\"\n (detach)=\"close()\"\n (overlayOutsideClick)=\"onClickOutside($event)\"\n >\n <div [@slideMotion]=\"'enter'\" class=\"ant-picker-dropdown\" style=\"position: relative\">\n <div class=\"ant-picker-panel-container\">\n <div tabindex=\"-1\" class=\"ant-picker-panel\">\n <nz-time-picker-panel\n [class]=\"nzPopupClassName\"\n [format]=\"nzFormat\"\n [nzHourStep]=\"nzHourStep\"\n [nzMinuteStep]=\"nzMinuteStep\"\n [nzSecondStep]=\"nzSecondStep\"\n [nzDisabledHours]=\"nzDisabledHours\"\n [nzDisabledMinutes]=\"nzDisabledMinutes\"\n [nzDisabledSeconds]=\"nzDisabledSeconds\"\n [nzPlaceHolder]=\"nzPlaceHolder || (i18nPlaceHolder$ | async)\"\n [nzHideDisabledOptions]=\"nzHideDisabledOptions\"\n [nzUse12Hours]=\"nzUse12Hours\"\n [nzDefaultOpenValue]=\"nzDefaultOpenValue\"\n [nzAddOn]=\"nzAddOn\"\n [nzClearText]=\"nzClearText\"\n [nzNowText]=\"nzNowText\"\n [nzOkText]=\"nzOkText\"\n [nzAllowEmpty]=\"nzAllowEmpty\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onPanelValueChange($event)\"\n (closePanel)=\"closePanel()\"\n ></nz-time-picker-panel>\n </div>\n </div>\n </div>\n </ng-template>\n `,\n host: {\n class: 'ant-picker',\n '[class.ant-picker-large]': `finalSize() === 'large'`,\n '[class.ant-picker-small]': `finalSize() === 'small'`,\n '[class.ant-picker-disabled]': `nzDisabled`,\n '[class.ant-picker-focused]': `focused`,\n '[class.ant-picker-rtl]': `dir === 'rtl'`,\n '[class.ant-picker-borderless]': `nzBorderless`,\n '(click)': 'open()'\n },\n hostDirectives: [NzSpaceCompactItemDirective],\n animations: [slideMotion],\n providers: [\n NzDestroyService,\n { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzTimePickerComponent), multi: true },\n { provide: NZ_SPACE_COMPACT_ITEM_TYPE, useValue: 'picker' }\n ],\n imports: [\n AsyncPipe,\n FormsModule,\n NzOutletModule,\n NzIconModule,\n NzFormItemFeedbackIconComponent,\n NzTimePickerPanelComponent,\n NzOverlayModule,\n OverlayModule\n ]\n})\nexport class NzTimePickerComponent implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges {\n readonly _nzModuleName: NzConfigKey = NZ_CONFIG_MODULE_NAME;\n\n private _onChange?: (value: Date | null) => void;\n private _onTouched?: () => void;\n private destroy$ = inject(NzDestroyService);\n private isNzDisableFirstChange: boolean = true;\n isInit = false;\n focused = false;\n inputValue: string = '';\n value: Date | null = null;\n preValue: Date | null = null;\n inputSize?: number;\n i18nPlaceHolder$: Observable<string | undefined> = of(undefined);\n overlayPositions: ConnectionPositionPair[] = [\n {\n offsetY: 3,\n originX: 'start',\n originY: 'bottom',\n overlayX: 'start',\n overlayY: 'top'\n },\n {\n offsetY: -3,\n originX: 'start',\n originY: 'top',\n overlayX: 'start',\n overlayY: 'bottom'\n },\n {\n offsetY: 3,\n originX: 'end',\n originY: 'bottom',\n overlayX: 'end',\n overlayY: 'top'\n },\n {\n offsetY: -3,\n originX: 'end',\n originY: 'top',\n overlayX: 'end',\n overlayY: 'bottom'\n }\n ] as ConnectionPositionPair[];\n dir: Direction = 'ltr';\n // status\n prefixCls: string = 'ant-picker';\n statusCls: NgClassInterface = {};\n status: NzValidateStatus = '';\n hasFeedback: boolean = false;\n\n get origin(): ElementRef {\n return this.element;\n }\n\n @ViewChild('inputElement', { static: true }) inputRef!: ElementRef<HTMLInputElement>;\n @Input() nzId: string | null = null;\n @Input() nzSize: NzSizeLDSType = 'default';\n @Input() nzStatus: NzStatus = '';\n @Input() @WithConfig() nzHourStep: number = 1;\n @Input() @WithConfig() nzMinuteStep: number = 1;\n @Input() @WithConfig() nzSecondStep: number = 1;\n @Input() @WithConfig() nzClearText: string = 'clear';\n @Input() @WithConfig() nzNowText: string = '';\n @Input() @WithConfig() nzOkText: string = '';\n @Input() @WithConfig() nzPopupClassName: string = '';\n @Input() nzPlaceHolder = '';\n @Input() nzAddOn?: TemplateRef<void>;\n @Input() nzDefaultOpenValue?: Date;\n @Input() nzDisabledHours?: () => number[];\n @Input() nzDisabledMinutes?: (hour: number) => number[];\n @Input() nzDisabledSeconds?: (hour: number, minute: number) => number[];\n @Input() @WithConfig() nzFormat: string = 'HH:mm:ss';\n @Input() nzOpen = false;\n @Input({ transform: booleanAttribute }) @WithConfig() nzUse12Hours: boolean = false;\n @Input() @WithConfig() nzSuffixIcon: string | TemplateRef<NzSafeAny> = 'clock-circle';\n\n @Output() readonly nzOpenChange = new EventEmitter<boolean>();\n\n @Input({ transform: booleanAttribute }) nzHideDisabledOptions = false;\n @Input({ transform: booleanAttribute }) @WithConfig() nzAllowEmpty: boolean = true;\n @Input({ transform: booleanAttribute }) nzDisabled = false;\n @Input({ transform: booleanAttribute }) nzAutoFocus = false;\n @Input() @WithConfig() nzBackdrop = false;\n @Input({ transform: booleanAttribute }) nzBorderless: boolean = false;\n @Input({ transform: booleanAttribute }) nzInputReadOnly: boolean = false;\n\n emitValue(value: Date | null): void {\n this.setValue(value, true);\n\n if (this._onChange) {\n this._onChange(this.value);\n }\n\n if (this._onTouched) {\n this._onTouched();\n }\n }\n\n setValue(value: Date | null, syncPreValue: boolean = false): void {\n if (syncPreValue) {\n this.preValue = isValid(value) ? new Date(value!) : null;\n }\n this.value = isValid(value) ? new Date(value!) : null;\n this.inputValue = this.dateHelper.format(value, this.nzFormat);\n this.cdr.markForCheck();\n }\n\n open(): void {\n if (this.nzDisabled || this.nzOpen) {\n return;\n }\n this.focus();\n this.nzOpen = true;\n this.nzOpenChange.emit(this.nzOpen);\n }\n\n close(): void {\n this.nzOpen = false;\n this.cdr.markForCheck();\n this.nzOpenChange.emit(this.nzOpen);\n }\n\n updateAutoFocus(): void {\n if (this.isInit && !this.nzDisabled) {\n if (this.nzAutoFocus) {\n this.renderer.setAttribute(this.inputRef.nativeElement, 'autofocus', 'autofocus');\n } else {\n this.renderer.removeAttribute(this.inputRef.nativeElement, 'autofocus');\n }\n }\n }\n\n onClickClearBtn(event: MouseEvent): void {\n event.stopPropagation();\n this.emitValue(null);\n }\n\n onClickOutside(event: MouseEvent): void {\n const target = _getEventTarget(event);\n if (!this.element.nativeElement.contains(target)) {\n this.setCurrentValueAndClose();\n }\n }\n\n onFocus(value: boolean): void {\n this.focused = value;\n if (!value) {\n if (this.checkTimeValid(this.value)) {\n this.setCurrentValueAndClose();\n } else {\n this.setValue(this.preValue);\n this.close();\n }\n }\n }\n\n focus(): void {\n if (this.inputRef.nativeElement) {\n this.inputRef.nativeElement.focus();\n }\n }\n\n blur(): void {\n if (this.inputRef.nativeElement) {\n this.inputRef.nativeElement.blur();\n }\n }\n\n onKeyupEsc(): void {\n this.setValue(this.preValue);\n }\n\n onKeyupEnter(): void {\n if (this.nzOpen && isValid(this.value)) {\n this.setCurrentValueAndClose();\n } else if (!this.nzOpen) {\n this.open();\n }\n }\n\n onInputChange(str: string): void {\n if (!this.platform.TRIDENT && document.activeElement === this.inputRef.nativeElement) {\n this.open();\n this.parseTimeString(str);\n }\n }\n\n onPanelValueChange(value: Date): void {\n this.setValue(value);\n this.focus();\n }\n\n closePanel(): void {\n this.inputRef.nativeElement.blur();\n }\n\n setCurrentValueAndClose(): void {\n this.emitValue(this.value);\n this.close();\n }\n\n protected finalSize = computed(() => {\n if (this.compactSize) {\n return this.compactSize();\n }\n return this.size();\n });\n\n private size = signal<NzSizeLDSType>(this.nzSize);\n private compactSize = inject(NZ_SPACE_COMPACT_SIZE, { optional: true });\n private nzFormStatusService = inject(NzFormStatusService, { optional: true });\n private nzFormNoStatusService = inject(NzFormNoStatusService, { optional: true });\n\n constructor(\n public nzConfigService: NzConfigService,\n protected i18n: NzI18nService,\n private element: ElementRef,\n private renderer: Renderer2,\n private cdr: ChangeDetectorRef,\n private dateHelper: DateHelperService,\n private platform: Platform,\n private directionality: Directionality\n ) {}\n\n ngOnInit(): void {\n this.nzFormStatusService?.formStatusChanges\n .pipe(\n distinctUntilChanged((pre, cur) => {\n return pre.status === cur.status && pre.hasFeedback === cur.hasFeedback;\n }),\n withLatestFrom(this.nzFormNoStatusService ? this.nzFormNoStatusService.noFormStatus : of(false)),\n map(([{ status, hasFeedback }, noStatus]) => ({ status: noStatus ? '' : status, hasFeedback })),\n takeUntil(this.destroy$)\n )\n .subscribe(({ status, hasFeedback }) => {\n this.setStatusStyles(status, hasFeedback);\n });\n\n this.inputSize = Math.max(8, this.nzFormat.length) + 2;\n this.i18nPlaceHolder$ = this.i18n.localeChange.pipe(\n map((nzLocale: NzI18nInterface) => nzLocale.TimePicker.placeholder)\n );\n\n this.dir = this.directionality.value;\n this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction: Direction) => {\n this.dir = direction;\n });\n }\n\n ngOnChanges({ nzUse12Hours, nzFormat, nzDisabled, nzAutoFocus, nzStatus, nzSize }: SimpleChanges): void {\n if (nzUse12Hours && !nzUse12Hours.previousValue && nzUse12Hours.currentValue && !nzFormat) {\n this.nzFormat = 'h:mm:ss a';\n }\n if (nzDisabled) {\n const value = nzDisabled.currentValue;\n const input = this.inputRef.nativeElement as HTMLInputElement;\n if (value) {\n this.renderer.setAttribute(input, 'disabled', '');\n } else {\n this.renderer.removeAttribute(input, 'disabled');\n }\n }\n if (nzAutoFocus) {\n this.updateAutoFocus();\n }\n if (nzStatus) {\n this.setStatusStyles(this.nzStatus, this.hasFeedback);\n }\n if (nzSize) {\n this.size.set(nzSize.currentValue);\n }\n }\n\n parseTimeString(str: string): void {\n const value = this.dateHelper.parseTime(str, this.nzFormat) || null;\n if (isValid(value)) {\n this.value = value;\n this.cdr.markForCheck();\n }\n }\n\n ngAfterViewInit(): void {\n this.isInit = true;\n this.updateAutoFocus();\n }\n\n writeValue(time: Date | null | undefined): void {\n let result: Date | null;\n\n if (time instanceof Date) {\n result = time;\n } else if (isNil(time)) {\n result = null;\n } else {\n warn('Non-Date type is not recommended for time-picker, use \"Date\" type.');\n result = new Date(time);\n }\n\n this.setValue(result, true);\n }\n\n registerOnChange(fn: (time: Date | null) => void): void {\n this._onChange = fn;\n }\n\n registerOnTouched(fn: () => void): void {\n this._onTouched = fn;\n }\n\n setDisabledState(isDisabled: boolean): void {\n this.nzDisabled = (this.isNzDisableFirstChange && this.nzDisabled) || isDisabled;\n this.isNzDisableFirstChange = false;\n this.cdr.markForCheck();\n }\n\n private checkTimeValid(value: Date | null): boolean {\n if (!value) {\n return true;\n }\n\n const disabledHours = this.nzDisabledHours?.();\n const disabledMinutes = this.nzDisabledMinutes?.(value.getHours());\n const disabledSeconds = this.nzDisabledSeconds?.(value.getHours(), value.getMinutes());\n\n return !(\n disabledHours?.includes(value.getHours()) ||\n disabledMinutes?.includes(value.getMinutes()) ||\n disabledSeconds?.includes(value.getSeconds())\n );\n }\n\n private setStatusStyles(status: NzValidateStatus, hasFeedback: boolean): void {\n // set inner status\n this.status = status;\n this.hasFeedback = hasFeedback;\n this.cdr.markForCheck();\n // render status if nzStatus is set\n this.statusCls = getStatusClassNames(this.prefixCls, status, hasFeedback);\n Object.keys(this.statusCls).forEach(status => {\n if (this.statusCls[status]) {\n this.renderer.addClass(this.element.nativeElement, status);\n } else {\n this.renderer.removeClass(this.element.nativeElement, status);\n }\n });\n }\n}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgModule } from '@angular/core';\n\nimport { NzTimePickerPanelComponent } from './time-picker-panel.component';\nimport { NzTimePickerComponent } from './time-picker.component';\n\n@NgModule({\n imports: [NzTimePickerComponent, NzTimePickerPanelComponent],\n exports: [NzTimePickerPanelComponent, NzTimePickerComponent]\n})\nexport class NzTimePickerModule {}\n","/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nexport * from './time-picker.component';\nexport * from './time-picker.module';\nexport * from './time-picker-panel.component';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1","i2","i3","i4"],"mappings":"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