UNPKG

@ng-bootstrap/ng-bootstrap

Version:
547 lines 47.5 kB
import { Component, forwardRef, Input, ViewEncapsulation, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { isInteger, isNumber, padNumber, toInteger } from '../util/util'; import { NgbTime } from './ngb-time'; import { NgIf } from '@angular/common'; import * as i0 from "@angular/core"; import * as i1 from "./timepicker-config"; import * as i2 from "./ngb-time-adapter"; import * as i3 from "./timepicker-i18n"; const FILTER_REGEX = /[^0-9]/g; /** * A directive that helps with wth picking hours, minutes and seconds. */ class NgbTimepicker { /** * The number of hours to add/subtract when clicking hour spinners. */ set hourStep(step) { this._hourStep = isInteger(step) ? step : this._config.hourStep; } get hourStep() { return this._hourStep; } /** * The number of minutes to add/subtract when clicking minute spinners. */ set minuteStep(step) { this._minuteStep = isInteger(step) ? step : this._config.minuteStep; } get minuteStep() { return this._minuteStep; } /** * The number of seconds to add/subtract when clicking second spinners. */ set secondStep(step) { this._secondStep = isInteger(step) ? step : this._config.secondStep; } get secondStep() { return this._secondStep; } constructor(_config, _ngbTimeAdapter, _cd, i18n) { this._config = _config; this._ngbTimeAdapter = _ngbTimeAdapter; this._cd = _cd; this.i18n = i18n; this.onChange = (_) => { }; this.onTouched = () => { }; this.meridian = _config.meridian; this.spinners = _config.spinners; this.seconds = _config.seconds; this.hourStep = _config.hourStep; this.minuteStep = _config.minuteStep; this.secondStep = _config.secondStep; this.disabled = _config.disabled; this.readonlyInputs = _config.readonlyInputs; this.size = _config.size; } writeValue(value) { const structValue = this._ngbTimeAdapter.fromModel(value); this.model = structValue ? new NgbTime(structValue.hour, structValue.minute, structValue.second) : new NgbTime(); if (!this.seconds && (!structValue || !isNumber(structValue.second))) { this.model.second = 0; } this._cd.markForCheck(); } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } /** * Increments the hours by the given step. */ changeHour(step) { this.model?.changeHour(step); this.propagateModelChange(); } /** * Increments the minutes by the given step. */ changeMinute(step) { this.model?.changeMinute(step); this.propagateModelChange(); } /** * Increments the seconds by the given step. */ changeSecond(step) { this.model?.changeSecond(step); this.propagateModelChange(); } /** * Update hours with the new value. */ updateHour(newVal) { const isPM = this.model ? this.model.hour >= 12 : false; const enteredHour = toInteger(newVal); if (this.meridian && ((isPM && enteredHour < 12) || (!isPM && enteredHour === 12))) { this.model?.updateHour(enteredHour + 12); } else { this.model?.updateHour(enteredHour); } this.propagateModelChange(); } /** * Update minutes with the new value. */ updateMinute(newVal) { this.model?.updateMinute(toInteger(newVal)); this.propagateModelChange(); } /** * Update seconds with the new value. */ updateSecond(newVal) { this.model?.updateSecond(toInteger(newVal)); this.propagateModelChange(); } toggleMeridian() { if (this.meridian) { this.changeHour(12); } } formatInput(input) { input.value = input.value.replace(FILTER_REGEX, ''); } formatHour(value) { if (isNumber(value)) { if (this.meridian) { return padNumber(value % 12 === 0 ? 12 : value % 12); } else { return padNumber(value % 24); } } else { return padNumber(NaN); } } formatMinSec(value) { return padNumber(isNumber(value) ? value : NaN); } handleBlur() { this.onTouched(); } get isSmallSize() { return this.size === 'small'; } get isLargeSize() { return this.size === 'large'; } ngOnChanges(changes) { if (changes['seconds'] && !this.seconds && this.model && !isNumber(this.model.second)) { this.model.second = 0; this.propagateModelChange(false); } } propagateModelChange(touched = true) { if (touched) { this.onTouched(); } if (this.model?.isValid(this.seconds)) { this.onChange(this._ngbTimeAdapter.toModel({ hour: this.model.hour, minute: this.model.minute, second: this.model.second })); } else { this.onChange(this._ngbTimeAdapter.toModel(null)); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbTimepicker, deps: [{ token: i1.NgbTimepickerConfig }, { token: i2.NgbTimeAdapter }, { token: i0.ChangeDetectorRef }, { token: i3.NgbTimepickerI18n }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.6", type: NgbTimepicker, isStandalone: true, selector: "ngb-timepicker", inputs: { meridian: "meridian", spinners: "spinners", seconds: "seconds", hourStep: "hourStep", minuteStep: "minuteStep", secondStep: "secondStep", readonlyInputs: "readonlyInputs", size: "size" }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgbTimepicker), multi: true }], exportAs: ["ngbTimepicker"], usesOnChanges: true, ngImport: i0, template: ` <fieldset [disabled]="disabled" [class.disabled]="disabled"> <div class="ngb-tp"> <div class="ngb-tp-input-container ngb-tp-hour"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeHour(hourStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-hours">Increment hours</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="HH" i18n-placeholder="@@ngb.timepicker.HH" [value]="formatHour(model?.hour)" (change)="updateHour($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Hours" i18n-aria-label="@@ngb.timepicker.hours" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeHour(hourStep); $event.preventDefault()" (keydown.ArrowDown)="changeHour(-hourStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeHour(-hourStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-hours">Decrement hours</span> </button> </div> <div class="ngb-tp-spacer">:</div> <div class="ngb-tp-input-container ngb-tp-minute"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeMinute(minuteStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-minutes">Increment minutes</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="MM" i18n-placeholder="@@ngb.timepicker.MM" [value]="formatMinSec(model?.minute)" (change)="updateMinute($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Minutes" i18n-aria-label="@@ngb.timepicker.minutes" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeMinute(minuteStep); $event.preventDefault()" (keydown.ArrowDown)="changeMinute(-minuteStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeMinute(-minuteStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-minutes">Decrement minutes</span> </button> </div> <div *ngIf="seconds" class="ngb-tp-spacer">:</div> <div *ngIf="seconds" class="ngb-tp-input-container ngb-tp-second"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeSecond(secondStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-seconds">Increment seconds</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="SS" i18n-placeholder="@@ngb.timepicker.SS" [value]="formatMinSec(model?.second)" (change)="updateSecond($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Seconds" i18n-aria-label="@@ngb.timepicker.seconds" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeSecond(secondStep); $event.preventDefault()" (keydown.ArrowDown)="changeSecond(-secondStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeSecond(-secondStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-seconds">Decrement seconds</span> </button> </div> <div *ngIf="meridian" class="ngb-tp-spacer"></div> <div *ngIf="meridian" class="ngb-tp-meridian"> <button type="button" class="btn btn-outline-primary" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [disabled]="disabled" [class.disabled]="disabled" (click)="toggleMeridian()" > <ng-container *ngIf="model && model.hour >= 12; else am" i18n="@@ngb.timepicker.PM">{{ i18n.getAfternoonPeriod() }}</ng-container> <ng-template #am i18n="@@ngb.timepicker.AM">{{ i18n.getMorningPeriod() }}</ng-template> </button> </div> </div> </fieldset> `, isInline: true, styles: ["ngb-timepicker{font-size:1rem}.ngb-tp{display:flex;align-items:center}.ngb-tp-input-container{width:4em}.ngb-tp-chevron:before{border-style:solid;border-width:.29em .29em 0 0;content:\"\";display:inline-block;height:.69em;left:.05em;position:relative;top:.15em;transform:rotate(-45deg);vertical-align:middle;width:.69em}.ngb-tp-chevron.bottom:before{top:-.3em;transform:rotate(135deg)}.ngb-tp-input{text-align:center}.ngb-tp-hour,.ngb-tp-minute,.ngb-tp-second,.ngb-tp-meridian{display:flex;flex-direction:column;align-items:center;justify-content:space-around}.ngb-tp-spacer{width:1em;text-align:center}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); } } export { NgbTimepicker }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.6", ngImport: i0, type: NgbTimepicker, decorators: [{ type: Component, args: [{ exportAs: 'ngbTimepicker', selector: 'ngb-timepicker', standalone: true, imports: [NgIf], encapsulation: ViewEncapsulation.None, template: ` <fieldset [disabled]="disabled" [class.disabled]="disabled"> <div class="ngb-tp"> <div class="ngb-tp-input-container ngb-tp-hour"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeHour(hourStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-hours">Increment hours</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="HH" i18n-placeholder="@@ngb.timepicker.HH" [value]="formatHour(model?.hour)" (change)="updateHour($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Hours" i18n-aria-label="@@ngb.timepicker.hours" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeHour(hourStep); $event.preventDefault()" (keydown.ArrowDown)="changeHour(-hourStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeHour(-hourStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-hours">Decrement hours</span> </button> </div> <div class="ngb-tp-spacer">:</div> <div class="ngb-tp-input-container ngb-tp-minute"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeMinute(minuteStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-minutes">Increment minutes</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="MM" i18n-placeholder="@@ngb.timepicker.MM" [value]="formatMinSec(model?.minute)" (change)="updateMinute($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Minutes" i18n-aria-label="@@ngb.timepicker.minutes" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeMinute(minuteStep); $event.preventDefault()" (keydown.ArrowDown)="changeMinute(-minuteStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeMinute(-minuteStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-minutes">Decrement minutes</span> </button> </div> <div *ngIf="seconds" class="ngb-tp-spacer">:</div> <div *ngIf="seconds" class="ngb-tp-input-container ngb-tp-second"> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeSecond(secondStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.increment-seconds">Increment seconds</span> </button> <input type="text" class="ngb-tp-input form-control" [class.form-control-sm]="isSmallSize" [class.form-control-lg]="isLargeSize" maxlength="2" inputmode="numeric" placeholder="SS" i18n-placeholder="@@ngb.timepicker.SS" [value]="formatMinSec(model?.second)" (change)="updateSecond($any($event).target.value)" [readOnly]="readonlyInputs" [disabled]="disabled" aria-label="Seconds" i18n-aria-label="@@ngb.timepicker.seconds" (blur)="handleBlur()" (input)="formatInput($any($event).target)" (keydown.ArrowUp)="changeSecond(secondStep); $event.preventDefault()" (keydown.ArrowDown)="changeSecond(-secondStep); $event.preventDefault()" /> <button *ngIf="spinners" tabindex="-1" type="button" (click)="changeSecond(-secondStep)" class="btn btn-link" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [class.disabled]="disabled" [disabled]="disabled" > <span class="chevron ngb-tp-chevron bottom"></span> <span class="visually-hidden" i18n="@@ngb.timepicker.decrement-seconds">Decrement seconds</span> </button> </div> <div *ngIf="meridian" class="ngb-tp-spacer"></div> <div *ngIf="meridian" class="ngb-tp-meridian"> <button type="button" class="btn btn-outline-primary" [class.btn-sm]="isSmallSize" [class.btn-lg]="isLargeSize" [disabled]="disabled" [class.disabled]="disabled" (click)="toggleMeridian()" > <ng-container *ngIf="model && model.hour >= 12; else am" i18n="@@ngb.timepicker.PM">{{ i18n.getAfternoonPeriod() }}</ng-container> <ng-template #am i18n="@@ngb.timepicker.AM">{{ i18n.getMorningPeriod() }}</ng-template> </button> </div> </div> </fieldset> `, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgbTimepicker), multi: true }], styles: ["ngb-timepicker{font-size:1rem}.ngb-tp{display:flex;align-items:center}.ngb-tp-input-container{width:4em}.ngb-tp-chevron:before{border-style:solid;border-width:.29em .29em 0 0;content:\"\";display:inline-block;height:.69em;left:.05em;position:relative;top:.15em;transform:rotate(-45deg);vertical-align:middle;width:.69em}.ngb-tp-chevron.bottom:before{top:-.3em;transform:rotate(135deg)}.ngb-tp-input{text-align:center}.ngb-tp-hour,.ngb-tp-minute,.ngb-tp-second,.ngb-tp-meridian{display:flex;flex-direction:column;align-items:center;justify-content:space-around}.ngb-tp-spacer{width:1em;text-align:center}\n"] }] }], ctorParameters: function () { return [{ type: i1.NgbTimepickerConfig }, { type: i2.NgbTimeAdapter }, { type: i0.ChangeDetectorRef }, { type: i3.NgbTimepickerI18n }]; }, propDecorators: { meridian: [{ type: Input }], spinners: [{ type: Input }], seconds: [{ type: Input }], hourStep: [{ type: Input }], minuteStep: [{ type: Input }], secondStep: [{ type: Input }], readonlyInputs: [{ type: Input }], size: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.js","sourceRoot":"","sources":["../../../../src/timepicker/timepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tChangeDetectorRef,\n\tComponent,\n\tforwardRef,\n\tInput,\n\tOnChanges,\n\tSimpleChanges,\n\tViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { isInteger, isNumber, padNumber, toInteger } from '../util/util';\nimport { NgbTime } from './ngb-time';\nimport { NgbTimepickerConfig } from './timepicker-config';\nimport { NgbTimeAdapter } from './ngb-time-adapter';\nimport { NgbTimepickerI18n } from './timepicker-i18n';\nimport { NgIf } from '@angular/common';\n\nconst FILTER_REGEX = /[^0-9]/g;\n\n/**\n * A directive that helps with wth picking hours, minutes and seconds.\n */\n@Component({\n\texportAs: 'ngbTimepicker',\n\tselector: 'ngb-timepicker',\n\tstandalone: true,\n\timports: [NgIf],\n\tencapsulation: ViewEncapsulation.None,\n\tstyleUrls: ['./timepicker.scss'],\n\ttemplate: `\n\t\t<fieldset [disabled]=\"disabled\" [class.disabled]=\"disabled\">\n\t\t\t<div class=\"ngb-tp\">\n\t\t\t\t<div class=\"ngb-tp-input-container ngb-tp-hour\">\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeHour(hourStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.increment-hours\">Increment hours</span>\n\t\t\t\t\t</button>\n\t\t\t\t\t<input\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\tclass=\"ngb-tp-input form-control\"\n\t\t\t\t\t\t[class.form-control-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.form-control-lg]=\"isLargeSize\"\n\t\t\t\t\t\tmaxlength=\"2\"\n\t\t\t\t\t\tinputmode=\"numeric\"\n\t\t\t\t\t\tplaceholder=\"HH\"\n\t\t\t\t\t\ti18n-placeholder=\"@@ngb.timepicker.HH\"\n\t\t\t\t\t\t[value]=\"formatHour(model?.hour)\"\n\t\t\t\t\t\t(change)=\"updateHour($any($event).target.value)\"\n\t\t\t\t\t\t[readOnly]=\"readonlyInputs\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t\taria-label=\"Hours\"\n\t\t\t\t\t\ti18n-aria-label=\"@@ngb.timepicker.hours\"\n\t\t\t\t\t\t(blur)=\"handleBlur()\"\n\t\t\t\t\t\t(input)=\"formatInput($any($event).target)\"\n\t\t\t\t\t\t(keydown.ArrowUp)=\"changeHour(hourStep); $event.preventDefault()\"\n\t\t\t\t\t\t(keydown.ArrowDown)=\"changeHour(-hourStep); $event.preventDefault()\"\n\t\t\t\t\t/>\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeHour(-hourStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron bottom\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.decrement-hours\">Decrement hours</span>\n\t\t\t\t\t</button>\n\t\t\t\t</div>\n\t\t\t\t<div class=\"ngb-tp-spacer\">:</div>\n\t\t\t\t<div class=\"ngb-tp-input-container ngb-tp-minute\">\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeMinute(minuteStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.increment-minutes\">Increment minutes</span>\n\t\t\t\t\t</button>\n\t\t\t\t\t<input\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\tclass=\"ngb-tp-input form-control\"\n\t\t\t\t\t\t[class.form-control-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.form-control-lg]=\"isLargeSize\"\n\t\t\t\t\t\tmaxlength=\"2\"\n\t\t\t\t\t\tinputmode=\"numeric\"\n\t\t\t\t\t\tplaceholder=\"MM\"\n\t\t\t\t\t\ti18n-placeholder=\"@@ngb.timepicker.MM\"\n\t\t\t\t\t\t[value]=\"formatMinSec(model?.minute)\"\n\t\t\t\t\t\t(change)=\"updateMinute($any($event).target.value)\"\n\t\t\t\t\t\t[readOnly]=\"readonlyInputs\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t\taria-label=\"Minutes\"\n\t\t\t\t\t\ti18n-aria-label=\"@@ngb.timepicker.minutes\"\n\t\t\t\t\t\t(blur)=\"handleBlur()\"\n\t\t\t\t\t\t(input)=\"formatInput($any($event).target)\"\n\t\t\t\t\t\t(keydown.ArrowUp)=\"changeMinute(minuteStep); $event.preventDefault()\"\n\t\t\t\t\t\t(keydown.ArrowDown)=\"changeMinute(-minuteStep); $event.preventDefault()\"\n\t\t\t\t\t/>\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeMinute(-minuteStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron bottom\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.decrement-minutes\">Decrement minutes</span>\n\t\t\t\t\t</button>\n\t\t\t\t</div>\n\t\t\t\t<div *ngIf=\"seconds\" class=\"ngb-tp-spacer\">:</div>\n\t\t\t\t<div *ngIf=\"seconds\" class=\"ngb-tp-input-container ngb-tp-second\">\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeSecond(secondStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.increment-seconds\">Increment seconds</span>\n\t\t\t\t\t</button>\n\t\t\t\t\t<input\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\tclass=\"ngb-tp-input form-control\"\n\t\t\t\t\t\t[class.form-control-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.form-control-lg]=\"isLargeSize\"\n\t\t\t\t\t\tmaxlength=\"2\"\n\t\t\t\t\t\tinputmode=\"numeric\"\n\t\t\t\t\t\tplaceholder=\"SS\"\n\t\t\t\t\t\ti18n-placeholder=\"@@ngb.timepicker.SS\"\n\t\t\t\t\t\t[value]=\"formatMinSec(model?.second)\"\n\t\t\t\t\t\t(change)=\"updateSecond($any($event).target.value)\"\n\t\t\t\t\t\t[readOnly]=\"readonlyInputs\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t\taria-label=\"Seconds\"\n\t\t\t\t\t\ti18n-aria-label=\"@@ngb.timepicker.seconds\"\n\t\t\t\t\t\t(blur)=\"handleBlur()\"\n\t\t\t\t\t\t(input)=\"formatInput($any($event).target)\"\n\t\t\t\t\t\t(keydown.ArrowUp)=\"changeSecond(secondStep); $event.preventDefault()\"\n\t\t\t\t\t\t(keydown.ArrowDown)=\"changeSecond(-secondStep); $event.preventDefault()\"\n\t\t\t\t\t/>\n\t\t\t\t\t<button\n\t\t\t\t\t\t*ngIf=\"spinners\"\n\t\t\t\t\t\ttabindex=\"-1\"\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t(click)=\"changeSecond(-secondStep)\"\n\t\t\t\t\t\tclass=\"btn btn-link\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<span class=\"chevron ngb-tp-chevron bottom\"></span>\n\t\t\t\t\t\t<span class=\"visually-hidden\" i18n=\"@@ngb.timepicker.decrement-seconds\">Decrement seconds</span>\n\t\t\t\t\t</button>\n\t\t\t\t</div>\n\t\t\t\t<div *ngIf=\"meridian\" class=\"ngb-tp-spacer\"></div>\n\t\t\t\t<div *ngIf=\"meridian\" class=\"ngb-tp-meridian\">\n\t\t\t\t\t<button\n\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\tclass=\"btn btn-outline-primary\"\n\t\t\t\t\t\t[class.btn-sm]=\"isSmallSize\"\n\t\t\t\t\t\t[class.btn-lg]=\"isLargeSize\"\n\t\t\t\t\t\t[disabled]=\"disabled\"\n\t\t\t\t\t\t[class.disabled]=\"disabled\"\n\t\t\t\t\t\t(click)=\"toggleMeridian()\"\n\t\t\t\t\t>\n\t\t\t\t\t\t<ng-container *ngIf=\"model && model.hour >= 12; else am\" i18n=\"@@ngb.timepicker.PM\">{{\n\t\t\t\t\t\t\ti18n.getAfternoonPeriod()\n\t\t\t\t\t\t}}</ng-container>\n\t\t\t\t\t\t<ng-template #am i18n=\"@@ngb.timepicker.AM\">{{ i18n.getMorningPeriod() }}</ng-template>\n\t\t\t\t\t</button>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</fieldset>\n\t`,\n\tproviders: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgbTimepicker), multi: true }],\n})\nexport class NgbTimepicker implements ControlValueAccessor, OnChanges {\n\tstatic ngAcceptInputType_size: string;\n\n\tdisabled: boolean;\n\tmodel?: NgbTime;\n\n\tprivate _hourStep: number;\n\tprivate _minuteStep: number;\n\tprivate _secondStep: number;\n\n\t/**\n\t * Whether to display 12H or 24H mode.\n\t */\n\t@Input() meridian: boolean;\n\n\t/**\n\t * If `true`, the spinners above and below inputs are visible.\n\t */\n\t@Input() spinners: boolean;\n\n\t/**\n\t * If `true`, it is possible to select seconds.\n\t */\n\t@Input() seconds: boolean;\n\n\t/**\n\t * The number of hours to add/subtract when clicking hour spinners.\n\t */\n\t@Input()\n\tset hourStep(step: number) {\n\t\tthis._hourStep = isInteger(step) ? step : this._config.hourStep;\n\t}\n\n\tget hourStep(): number {\n\t\treturn this._hourStep;\n\t}\n\n\t/**\n\t * The number of minutes to add/subtract when clicking minute spinners.\n\t */\n\t@Input()\n\tset minuteStep(step: number) {\n\t\tthis._minuteStep = isInteger(step) ? step : this._config.minuteStep;\n\t}\n\n\tget minuteStep(): number {\n\t\treturn this._minuteStep;\n\t}\n\n\t/**\n\t * The number of seconds to add/subtract when clicking second spinners.\n\t */\n\t@Input()\n\tset secondStep(step: number) {\n\t\tthis._secondStep = isInteger(step) ? step : this._config.secondStep;\n\t}\n\n\tget secondStep(): number {\n\t\treturn this._secondStep;\n\t}\n\n\t/**\n\t * If `true`, the timepicker is readonly and can't be changed.\n\t */\n\t@Input() readonlyInputs: boolean;\n\n\t/**\n\t * The size of inputs and buttons.\n\t */\n\t@Input() size: 'small' | 'medium' | 'large';\n\n\tconstructor(\n\t\tprivate readonly _config: NgbTimepickerConfig,\n\t\tprivate _ngbTimeAdapter: NgbTimeAdapter<any>,\n\t\tprivate _cd: ChangeDetectorRef,\n\t\tpublic i18n: NgbTimepickerI18n,\n\t) {\n\t\tthis.meridian = _config.meridian;\n\t\tthis.spinners = _config.spinners;\n\t\tthis.seconds = _config.seconds;\n\t\tthis.hourStep = _config.hourStep;\n\t\tthis.minuteStep = _config.minuteStep;\n\t\tthis.secondStep = _config.secondStep;\n\t\tthis.disabled = _config.disabled;\n\t\tthis.readonlyInputs = _config.readonlyInputs;\n\t\tthis.size = _config.size;\n\t}\n\n\tonChange = (_: any) => {};\n\tonTouched = () => {};\n\n\twriteValue(value) {\n\t\tconst structValue = this._ngbTimeAdapter.fromModel(value);\n\t\tthis.model = structValue ? new NgbTime(structValue.hour, structValue.minute, structValue.second) : new NgbTime();\n\t\tif (!this.seconds && (!structValue || !isNumber(structValue.second))) {\n\t\t\tthis.model.second = 0;\n\t\t}\n\t\tthis._cd.markForCheck();\n\t}\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean) {\n\t\tthis.disabled = isDisabled;\n\t}\n\n\t/**\n\t * Increments the hours by the given step.\n\t */\n\tchangeHour(step: number) {\n\t\tthis.model?.changeHour(step);\n\t\tthis.propagateModelChange();\n\t}\n\n\t/**\n\t * Increments the minutes by the given step.\n\t */\n\tchangeMinute(step: number) {\n\t\tthis.model?.changeMinute(step);\n\t\tthis.propagateModelChange();\n\t}\n\n\t/**\n\t * Increments the seconds by the given step.\n\t */\n\tchangeSecond(step: number) {\n\t\tthis.model?.changeSecond(step);\n\t\tthis.propagateModelChange();\n\t}\n\n\t/**\n\t * Update hours with the new value.\n\t */\n\tupdateHour(newVal: string) {\n\t\tconst isPM = this.model ? this.model.hour >= 12 : false;\n\t\tconst enteredHour = toInteger(newVal);\n\t\tif (this.meridian && ((isPM && enteredHour < 12) || (!isPM && enteredHour === 12))) {\n\t\t\tthis.model?.updateHour(enteredHour + 12);\n\t\t} else {\n\t\t\tthis.model?.updateHour(enteredHour);\n\t\t}\n\t\tthis.propagateModelChange();\n\t}\n\n\t/**\n\t * Update minutes with the new value.\n\t */\n\tupdateMinute(newVal: string) {\n\t\tthis.model?.updateMinute(toInteger(newVal));\n\t\tthis.propagateModelChange();\n\t}\n\n\t/**\n\t * Update seconds with the new value.\n\t */\n\tupdateSecond(newVal: string) {\n\t\tthis.model?.updateSecond(toInteger(newVal));\n\t\tthis.propagateModelChange();\n\t}\n\n\ttoggleMeridian() {\n\t\tif (this.meridian) {\n\t\t\tthis.changeHour(12);\n\t\t}\n\t}\n\n\tformatInput(input: HTMLInputElement) {\n\t\tinput.value = input.value.replace(FILTER_REGEX, '');\n\t}\n\n\tformatHour(value?: number) {\n\t\tif (isNumber(value)) {\n\t\t\tif (this.meridian) {\n\t\t\t\treturn padNumber(value % 12 === 0 ? 12 : value % 12);\n\t\t\t} else {\n\t\t\t\treturn padNumber(value % 24);\n\t\t\t}\n\t\t} else {\n\t\t\treturn padNumber(NaN);\n\t\t}\n\t}\n\n\tformatMinSec(value?: number) {\n\t\treturn padNumber(isNumber(value) ? value : NaN);\n\t}\n\n\thandleBlur() {\n\t\tthis.onTouched();\n\t}\n\n\tget isSmallSize(): boolean {\n\t\treturn this.size === 'small';\n\t}\n\n\tget isLargeSize(): boolean {\n\t\treturn this.size === 'large';\n\t}\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (changes['seconds'] && !this.seconds && this.model && !isNumber(this.model.second)) {\n\t\t\tthis.model.second = 0;\n\t\t\tthis.propagateModelChange(false);\n\t\t}\n\t}\n\n\tprivate propagateModelChange(touched = true) {\n\t\tif (touched) {\n\t\t\tthis.onTouched();\n\t\t}\n\t\tif (this.model?.isValid(this.seconds)) {\n\t\t\tthis.onChange(\n\t\t\t\tthis._ngbTimeAdapter.toModel({ hour: this.model.hour, minute: this.model.minute, second: this.model.second }),\n\t\t\t);\n\t\t} else {\n\t\t\tthis.onChange(this._ngbTimeAdapter.toModel(null));\n\t\t}\n\t}\n}\n"]}