timepicker.js 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { ChangeDetectorRef, Component, forwardRef, Input, ViewEncapsulation } from '@angular/core';
  6. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  7. import { isInteger, isNumber, padNumber, toInteger } from '../util/util';
  8. import { NgbTime } from './ngb-time';
  9. import { NgbTimepickerConfig } from './timepicker-config';
  10. import { NgbTimeAdapter } from './ngb-time-adapter';
  11. import { NgbTimepickerI18n } from './timepicker-i18n';
  12. /** @type {?} */
  13. var FILTER_REGEX = /[^0-9]/g;
  14. /** @type {?} */
  15. var NGB_TIMEPICKER_VALUE_ACCESSOR = {
  16. provide: NG_VALUE_ACCESSOR,
  17. useExisting: forwardRef((/**
  18. * @return {?}
  19. */
  20. function () { return NgbTimepicker; })),
  21. multi: true
  22. };
  23. /**
  24. * A directive that helps with wth picking hours, minutes and seconds.
  25. */
  26. var NgbTimepicker = /** @class */ (function () {
  27. function NgbTimepicker(_config, _ngbTimeAdapter, _cd, i18n) {
  28. this._config = _config;
  29. this._ngbTimeAdapter = _ngbTimeAdapter;
  30. this._cd = _cd;
  31. this.i18n = i18n;
  32. this.onChange = (/**
  33. * @param {?} _
  34. * @return {?}
  35. */
  36. function (_) { });
  37. this.onTouched = (/**
  38. * @return {?}
  39. */
  40. function () { });
  41. this.meridian = _config.meridian;
  42. this.spinners = _config.spinners;
  43. this.seconds = _config.seconds;
  44. this.hourStep = _config.hourStep;
  45. this.minuteStep = _config.minuteStep;
  46. this.secondStep = _config.secondStep;
  47. this.disabled = _config.disabled;
  48. this.readonlyInputs = _config.readonlyInputs;
  49. this.size = _config.size;
  50. }
  51. Object.defineProperty(NgbTimepicker.prototype, "hourStep", {
  52. get: /**
  53. * @return {?}
  54. */
  55. function () { return this._hourStep; },
  56. /**
  57. * The number of hours to add/subtract when clicking hour spinners.
  58. */
  59. set: /**
  60. * The number of hours to add/subtract when clicking hour spinners.
  61. * @param {?} step
  62. * @return {?}
  63. */
  64. function (step) {
  65. this._hourStep = isInteger(step) ? step : this._config.hourStep;
  66. },
  67. enumerable: true,
  68. configurable: true
  69. });
  70. Object.defineProperty(NgbTimepicker.prototype, "minuteStep", {
  71. get: /**
  72. * @return {?}
  73. */
  74. function () { return this._minuteStep; },
  75. /**
  76. * The number of minutes to add/subtract when clicking minute spinners.
  77. */
  78. set: /**
  79. * The number of minutes to add/subtract when clicking minute spinners.
  80. * @param {?} step
  81. * @return {?}
  82. */
  83. function (step) {
  84. this._minuteStep = isInteger(step) ? step : this._config.minuteStep;
  85. },
  86. enumerable: true,
  87. configurable: true
  88. });
  89. Object.defineProperty(NgbTimepicker.prototype, "secondStep", {
  90. get: /**
  91. * @return {?}
  92. */
  93. function () { return this._secondStep; },
  94. /**
  95. * The number of seconds to add/subtract when clicking second spinners.
  96. */
  97. set: /**
  98. * The number of seconds to add/subtract when clicking second spinners.
  99. * @param {?} step
  100. * @return {?}
  101. */
  102. function (step) {
  103. this._secondStep = isInteger(step) ? step : this._config.secondStep;
  104. },
  105. enumerable: true,
  106. configurable: true
  107. });
  108. /**
  109. * @param {?} value
  110. * @return {?}
  111. */
  112. NgbTimepicker.prototype.writeValue = /**
  113. * @param {?} value
  114. * @return {?}
  115. */
  116. function (value) {
  117. /** @type {?} */
  118. var structValue = this._ngbTimeAdapter.fromModel(value);
  119. this.model = structValue ? new NgbTime(structValue.hour, structValue.minute, structValue.second) : new NgbTime();
  120. if (!this.seconds && (!structValue || !isNumber(structValue.second))) {
  121. this.model.second = 0;
  122. }
  123. this._cd.markForCheck();
  124. };
  125. /**
  126. * @param {?} fn
  127. * @return {?}
  128. */
  129. NgbTimepicker.prototype.registerOnChange = /**
  130. * @param {?} fn
  131. * @return {?}
  132. */
  133. function (fn) { this.onChange = fn; };
  134. /**
  135. * @param {?} fn
  136. * @return {?}
  137. */
  138. NgbTimepicker.prototype.registerOnTouched = /**
  139. * @param {?} fn
  140. * @return {?}
  141. */
  142. function (fn) { this.onTouched = fn; };
  143. /**
  144. * @param {?} isDisabled
  145. * @return {?}
  146. */
  147. NgbTimepicker.prototype.setDisabledState = /**
  148. * @param {?} isDisabled
  149. * @return {?}
  150. */
  151. function (isDisabled) { this.disabled = isDisabled; };
  152. /**
  153. * @param {?} step
  154. * @return {?}
  155. */
  156. NgbTimepicker.prototype.changeHour = /**
  157. * @param {?} step
  158. * @return {?}
  159. */
  160. function (step) {
  161. this.model.changeHour(step);
  162. this.propagateModelChange();
  163. };
  164. /**
  165. * @param {?} step
  166. * @return {?}
  167. */
  168. NgbTimepicker.prototype.changeMinute = /**
  169. * @param {?} step
  170. * @return {?}
  171. */
  172. function (step) {
  173. this.model.changeMinute(step);
  174. this.propagateModelChange();
  175. };
  176. /**
  177. * @param {?} step
  178. * @return {?}
  179. */
  180. NgbTimepicker.prototype.changeSecond = /**
  181. * @param {?} step
  182. * @return {?}
  183. */
  184. function (step) {
  185. this.model.changeSecond(step);
  186. this.propagateModelChange();
  187. };
  188. /**
  189. * @param {?} newVal
  190. * @return {?}
  191. */
  192. NgbTimepicker.prototype.updateHour = /**
  193. * @param {?} newVal
  194. * @return {?}
  195. */
  196. function (newVal) {
  197. /** @type {?} */
  198. var isPM = this.model.hour >= 12;
  199. /** @type {?} */
  200. var enteredHour = toInteger(newVal);
  201. if (this.meridian && (isPM && enteredHour < 12 || !isPM && enteredHour === 12)) {
  202. this.model.updateHour(enteredHour + 12);
  203. }
  204. else {
  205. this.model.updateHour(enteredHour);
  206. }
  207. this.propagateModelChange();
  208. };
  209. /**
  210. * @param {?} newVal
  211. * @return {?}
  212. */
  213. NgbTimepicker.prototype.updateMinute = /**
  214. * @param {?} newVal
  215. * @return {?}
  216. */
  217. function (newVal) {
  218. this.model.updateMinute(toInteger(newVal));
  219. this.propagateModelChange();
  220. };
  221. /**
  222. * @param {?} newVal
  223. * @return {?}
  224. */
  225. NgbTimepicker.prototype.updateSecond = /**
  226. * @param {?} newVal
  227. * @return {?}
  228. */
  229. function (newVal) {
  230. this.model.updateSecond(toInteger(newVal));
  231. this.propagateModelChange();
  232. };
  233. /**
  234. * @return {?}
  235. */
  236. NgbTimepicker.prototype.toggleMeridian = /**
  237. * @return {?}
  238. */
  239. function () {
  240. if (this.meridian) {
  241. this.changeHour(12);
  242. }
  243. };
  244. /**
  245. * @param {?} input
  246. * @return {?}
  247. */
  248. NgbTimepicker.prototype.formatInput = /**
  249. * @param {?} input
  250. * @return {?}
  251. */
  252. function (input) { input.value = input.value.replace(FILTER_REGEX, ''); };
  253. /**
  254. * @param {?} value
  255. * @return {?}
  256. */
  257. NgbTimepicker.prototype.formatHour = /**
  258. * @param {?} value
  259. * @return {?}
  260. */
  261. function (value) {
  262. if (isNumber(value)) {
  263. if (this.meridian) {
  264. return padNumber(value % 12 === 0 ? 12 : value % 12);
  265. }
  266. else {
  267. return padNumber(value % 24);
  268. }
  269. }
  270. else {
  271. return padNumber(NaN);
  272. }
  273. };
  274. /**
  275. * @param {?} value
  276. * @return {?}
  277. */
  278. NgbTimepicker.prototype.formatMinSec = /**
  279. * @param {?} value
  280. * @return {?}
  281. */
  282. function (value) { return padNumber(value); };
  283. Object.defineProperty(NgbTimepicker.prototype, "isSmallSize", {
  284. get: /**
  285. * @return {?}
  286. */
  287. function () { return this.size === 'small'; },
  288. enumerable: true,
  289. configurable: true
  290. });
  291. Object.defineProperty(NgbTimepicker.prototype, "isLargeSize", {
  292. get: /**
  293. * @return {?}
  294. */
  295. function () { return this.size === 'large'; },
  296. enumerable: true,
  297. configurable: true
  298. });
  299. /**
  300. * @param {?} changes
  301. * @return {?}
  302. */
  303. NgbTimepicker.prototype.ngOnChanges = /**
  304. * @param {?} changes
  305. * @return {?}
  306. */
  307. function (changes) {
  308. if (changes['seconds'] && !this.seconds && this.model && !isNumber(this.model.second)) {
  309. this.model.second = 0;
  310. this.propagateModelChange(false);
  311. }
  312. };
  313. /**
  314. * @private
  315. * @param {?=} touched
  316. * @return {?}
  317. */
  318. NgbTimepicker.prototype.propagateModelChange = /**
  319. * @private
  320. * @param {?=} touched
  321. * @return {?}
  322. */
  323. function (touched) {
  324. if (touched === void 0) { touched = true; }
  325. if (touched) {
  326. this.onTouched();
  327. }
  328. if (this.model.isValid(this.seconds)) {
  329. this.onChange(this._ngbTimeAdapter.toModel({ hour: this.model.hour, minute: this.model.minute, second: this.model.second }));
  330. }
  331. else {
  332. this.onChange(this._ngbTimeAdapter.toModel(null));
  333. }
  334. };
  335. NgbTimepicker.decorators = [
  336. { type: Component, args: [{
  337. selector: 'ngb-timepicker',
  338. encapsulation: ViewEncapsulation.None,
  339. template: "\n <fieldset [disabled]=\"disabled\" [class.disabled]=\"disabled\">\n <div class=\"ngb-tp\">\n <div class=\"ngb-tp-input-container ngb-tp-hour\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeHour(hourStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-hours\">Increment hours</span>\n </button>\n <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\"\n [class.form-control-lg]=\"isLargeSize\"\n maxlength=\"2\" inputmode=\"numeric\" placeholder=\"HH\" i18n-placeholder=\"@@ngb.timepicker.HH\"\n [value]=\"formatHour(model?.hour)\" (change)=\"updateHour($event.target.value)\"\n [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Hours\" i18n-aria-label=\"@@ngb.timepicker.hours\"\n (input)=\"formatInput($event.target)\"\n (keydown.ArrowUp)=\"changeHour(hourStep); $event.preventDefault()\"\n (keydown.ArrowDown)=\"changeHour(-hourStep); $event.preventDefault()\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeHour(-hourStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron bottom\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.decrement-hours\">Decrement hours</span>\n </button>\n </div>\n <div class=\"ngb-tp-spacer\">:</div>\n <div class=\"ngb-tp-input-container ngb-tp-minute\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeMinute(minuteStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-minutes\">Increment minutes</span>\n </button>\n <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\" [class.form-control-lg]=\"isLargeSize\"\n maxlength=\"2\" inputmode=\"numeric\" placeholder=\"MM\" i18n-placeholder=\"@@ngb.timepicker.MM\"\n [value]=\"formatMinSec(model?.minute)\" (change)=\"updateMinute($event.target.value)\"\n [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Minutes\" i18n-aria-label=\"@@ngb.timepicker.minutes\"\n (input)=\"formatInput($event.target)\"\n (keydown.ArrowUp)=\"changeMinute(minuteStep); $event.preventDefault()\"\n (keydown.ArrowDown)=\"changeMinute(-minuteStep); $event.preventDefault()\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeMinute(-minuteStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron bottom\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.decrement-minutes\">Decrement minutes</span>\n </button>\n </div>\n <div *ngIf=\"seconds\" class=\"ngb-tp-spacer\">:</div>\n <div *ngIf=\"seconds\" class=\"ngb-tp-input-container ngb-tp-second\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeSecond(secondStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-seconds\">Increment seconds</span>\n </button>\n <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\" [class.form-control-lg]=\"isLargeSize\"\n maxlength=\"2\" inputmode=\"numeric\" placeholder=\"SS\" i18n-placeholder=\"@@ngb.timepicker.SS\"\n [value]=\"formatMinSec(model?.second)\" (change)=\"updateSecond($event.target.value)\"\n [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Seconds\" i18n-aria-label=\"@@ngb.timepicker.seconds\"\n (input)=\"formatInput($event.target)\"\n (keydown.ArrowUp)=\"changeSecond(secondStep); $event.preventDefault()\"\n (keydown.ArrowDown)=\"changeSecond(-secondStep); $event.preventDefault()\">\n <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeSecond(-secondStep)\"\n class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n [disabled]=\"disabled\">\n <span class=\"chevron ngb-tp-chevron bottom\"></span>\n <span class=\"sr-only\" i18n=\"@@ngb.timepicker.decrement-seconds\">Decrement seconds</span>\n </button>\n </div>\n <div *ngIf=\"meridian\" class=\"ngb-tp-spacer\"></div>\n <div *ngIf=\"meridian\" class=\"ngb-tp-meridian\">\n <button type=\"button\" class=\"btn btn-outline-primary\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\"\n [disabled]=\"disabled\" [class.disabled]=\"disabled\"\n (click)=\"toggleMeridian()\">\n <ng-container *ngIf=\"model?.hour >= 12; else am\" i18n=\"@@ngb.timepicker.PM\">{{ i18n.getAfternoonPeriod() }}</ng-container>\n <ng-template #am i18n=\"@@ngb.timepicker.AM\">{{ i18n.getMorningPeriod() }}</ng-template>\n </button>\n </div>\n </div>\n </fieldset>\n ",
  340. providers: [NGB_TIMEPICKER_VALUE_ACCESSOR],
  341. styles: ["ngb-timepicker{font-size:1rem}.ngb-tp{display:-ms-flexbox;display:flex;-ms-flex-align:center;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;-webkit-transform:rotate(-45deg);transform:rotate(-45deg);vertical-align:middle;width:.69em}.ngb-tp-chevron.bottom:before{top:-.3em;-webkit-transform:rotate(135deg);transform:rotate(135deg)}.ngb-tp-input{text-align:center}.ngb-tp-hour,.ngb-tp-meridian,.ngb-tp-minute,.ngb-tp-second{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-align:center;align-items:center;-ms-flex-pack:distribute;justify-content:space-around}.ngb-tp-spacer{width:1em;text-align:center}"]
  342. }] }
  343. ];
  344. /** @nocollapse */
  345. NgbTimepicker.ctorParameters = function () { return [
  346. { type: NgbTimepickerConfig },
  347. { type: NgbTimeAdapter },
  348. { type: ChangeDetectorRef },
  349. { type: NgbTimepickerI18n }
  350. ]; };
  351. NgbTimepicker.propDecorators = {
  352. meridian: [{ type: Input }],
  353. spinners: [{ type: Input }],
  354. seconds: [{ type: Input }],
  355. hourStep: [{ type: Input }],
  356. minuteStep: [{ type: Input }],
  357. secondStep: [{ type: Input }],
  358. readonlyInputs: [{ type: Input }],
  359. size: [{ type: Input }]
  360. };
  361. return NgbTimepicker;
  362. }());
  363. export { NgbTimepicker };
  364. if (false) {
  365. /** @type {?} */
  366. NgbTimepicker.prototype.disabled;
  367. /** @type {?} */
  368. NgbTimepicker.prototype.model;
  369. /**
  370. * @type {?}
  371. * @private
  372. */
  373. NgbTimepicker.prototype._hourStep;
  374. /**
  375. * @type {?}
  376. * @private
  377. */
  378. NgbTimepicker.prototype._minuteStep;
  379. /**
  380. * @type {?}
  381. * @private
  382. */
  383. NgbTimepicker.prototype._secondStep;
  384. /**
  385. * Whether to display 12H or 24H mode.
  386. * @type {?}
  387. */
  388. NgbTimepicker.prototype.meridian;
  389. /**
  390. * If `true`, the spinners above and below inputs are visible.
  391. * @type {?}
  392. */
  393. NgbTimepicker.prototype.spinners;
  394. /**
  395. * If `true`, it is possible to select seconds.
  396. * @type {?}
  397. */
  398. NgbTimepicker.prototype.seconds;
  399. /**
  400. * If `true`, the timepicker is readonly and can't be changed.
  401. * @type {?}
  402. */
  403. NgbTimepicker.prototype.readonlyInputs;
  404. /**
  405. * The size of inputs and buttons.
  406. * @type {?}
  407. */
  408. NgbTimepicker.prototype.size;
  409. /** @type {?} */
  410. NgbTimepicker.prototype.onChange;
  411. /** @type {?} */
  412. NgbTimepicker.prototype.onTouched;
  413. /**
  414. * @type {?}
  415. * @private
  416. */
  417. NgbTimepicker.prototype._config;
  418. /**
  419. * @type {?}
  420. * @private
  421. */
  422. NgbTimepicker.prototype._ngbTimeAdapter;
  423. /**
  424. * @type {?}
  425. * @private
  426. */
  427. NgbTimepicker.prototype._cd;
  428. /** @type {?} */
  429. NgbTimepicker.prototype.i18n;
  430. }
  431. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["timepicker/timepicker.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  forwardRef,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewEncapsulation\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';\n\nconst FILTER_REGEX = /[^0-9]/g;\n\nconst NGB_TIMEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgbTimepicker),\n  multi: true\n};\n\n/**\n * A directive that helps with wth picking hours, minutes and seconds.\n */\n@Component({\n  selector: 'ngb-timepicker',\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: ['./timepicker.scss'],\n  template: `\n    <fieldset [disabled]=\"disabled\" [class.disabled]=\"disabled\">\n      <div class=\"ngb-tp\">\n        <div class=\"ngb-tp-input-container ngb-tp-hour\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeHour(hourStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron\"></span>\n            <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-hours\">Increment hours</span>\n          </button>\n          <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\"\n            [class.form-control-lg]=\"isLargeSize\"\n            maxlength=\"2\" inputmode=\"numeric\" placeholder=\"HH\" i18n-placeholder=\"@@ngb.timepicker.HH\"\n            [value]=\"formatHour(model?.hour)\" (change)=\"updateHour($event.target.value)\"\n            [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Hours\" i18n-aria-label=\"@@ngb.timepicker.hours\"\n            (input)=\"formatInput($event.target)\"\n            (keydown.ArrowUp)=\"changeHour(hourStep); $event.preventDefault()\"\n            (keydown.ArrowDown)=\"changeHour(-hourStep); $event.preventDefault()\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeHour(-hourStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron bottom\"></span>\n            <span class=\"sr-only\" i18n=\"@@ngb.timepicker.decrement-hours\">Decrement hours</span>\n          </button>\n        </div>\n        <div class=\"ngb-tp-spacer\">:</div>\n        <div class=\"ngb-tp-input-container ngb-tp-minute\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeMinute(minuteStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron\"></span>\n            <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-minutes\">Increment minutes</span>\n          </button>\n          <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\" [class.form-control-lg]=\"isLargeSize\"\n            maxlength=\"2\" inputmode=\"numeric\" placeholder=\"MM\" i18n-placeholder=\"@@ngb.timepicker.MM\"\n            [value]=\"formatMinSec(model?.minute)\" (change)=\"updateMinute($event.target.value)\"\n            [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Minutes\" i18n-aria-label=\"@@ngb.timepicker.minutes\"\n            (input)=\"formatInput($event.target)\"\n            (keydown.ArrowUp)=\"changeMinute(minuteStep); $event.preventDefault()\"\n            (keydown.ArrowDown)=\"changeMinute(-minuteStep); $event.preventDefault()\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeMinute(-minuteStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\"  [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron bottom\"></span>\n            <span class=\"sr-only\"  i18n=\"@@ngb.timepicker.decrement-minutes\">Decrement minutes</span>\n          </button>\n        </div>\n        <div *ngIf=\"seconds\" class=\"ngb-tp-spacer\">:</div>\n        <div *ngIf=\"seconds\" class=\"ngb-tp-input-container ngb-tp-second\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeSecond(secondStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\" [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron\"></span>\n            <span class=\"sr-only\" i18n=\"@@ngb.timepicker.increment-seconds\">Increment seconds</span>\n          </button>\n          <input type=\"text\" class=\"ngb-tp-input form-control\" [class.form-control-sm]=\"isSmallSize\" [class.form-control-lg]=\"isLargeSize\"\n            maxlength=\"2\" inputmode=\"numeric\" placeholder=\"SS\" i18n-placeholder=\"@@ngb.timepicker.SS\"\n            [value]=\"formatMinSec(model?.second)\" (change)=\"updateSecond($event.target.value)\"\n            [readOnly]=\"readonlyInputs\" [disabled]=\"disabled\" aria-label=\"Seconds\" i18n-aria-label=\"@@ngb.timepicker.seconds\"\n            (input)=\"formatInput($event.target)\"\n            (keydown.ArrowUp)=\"changeSecond(secondStep); $event.preventDefault()\"\n            (keydown.ArrowDown)=\"changeSecond(-secondStep); $event.preventDefault()\">\n          <button *ngIf=\"spinners\" tabindex=\"-1\" type=\"button\" (click)=\"changeSecond(-secondStep)\"\n            class=\"btn btn-link\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\"  [class.disabled]=\"disabled\"\n            [disabled]=\"disabled\">\n            <span class=\"chevron ngb-tp-chevron bottom\"></span>\n            <span class=\"sr-only\" i18n=\"@@ngb.timepicker.decrement-seconds\">Decrement seconds</span>\n          </button>\n        </div>\n        <div *ngIf=\"meridian\" class=\"ngb-tp-spacer\"></div>\n        <div *ngIf=\"meridian\" class=\"ngb-tp-meridian\">\n          <button type=\"button\" class=\"btn btn-outline-primary\" [class.btn-sm]=\"isSmallSize\" [class.btn-lg]=\"isLargeSize\"\n            [disabled]=\"disabled\" [class.disabled]=\"disabled\"\n                  (click)=\"toggleMeridian()\">\n            <ng-container *ngIf=\"model?.hour >= 12; else am\" i18n=\"@@ngb.timepicker.PM\">{{ i18n.getAfternoonPeriod() }}</ng-container>\n            <ng-template #am i18n=\"@@ngb.timepicker.AM\">{{ i18n.getMorningPeriod() }}</ng-template>\n          </button>\n        </div>\n      </div>\n    </fieldset>\n  `,\n  providers: [NGB_TIMEPICKER_VALUE_ACCESSOR]\n})\nexport class NgbTimepicker implements ControlValueAccessor,\n    OnChanges {\n  disabled: boolean;\n  model: NgbTime;\n\n  private _hourStep: number;\n  private _minuteStep: number;\n  private _secondStep: number;\n\n  /**\n   * Whether to display 12H or 24H mode.\n   */\n  @Input() meridian: boolean;\n\n  /**\n   * If `true`, the spinners above and below inputs are visible.\n   */\n  @Input() spinners: boolean;\n\n  /**\n   * If `true`, it is possible to select seconds.\n   */\n  @Input() seconds: boolean;\n\n  /**\n   * The number of hours to add/subtract when clicking hour spinners.\n   */\n  @Input()\n  set hourStep(step: number) {\n    this._hourStep = isInteger(step) ? step : this._config.hourStep;\n  }\n\n  get hourStep(): number { return this._hourStep; }\n\n  /**\n   * The number of minutes to add/subtract when clicking minute spinners.\n   */\n  @Input()\n  set minuteStep(step: number) {\n    this._minuteStep = isInteger(step) ? step : this._config.minuteStep;\n  }\n\n  get minuteStep(): number { return this._minuteStep; }\n\n  /**\n   * The number of seconds to add/subtract when clicking second spinners.\n   */\n  @Input()\n  set secondStep(step: number) {\n    this._secondStep = isInteger(step) ? step : this._config.secondStep;\n  }\n\n  get secondStep(): number { return this._secondStep; }\n\n  /**\n   * If `true`, the timepicker is readonly and can't be changed.\n   */\n  @Input() readonlyInputs: boolean;\n\n  /**\n   * The size of inputs and buttons.\n   */\n  @Input() size: 'small' | 'medium' | 'large';\n\n  constructor(\n      private readonly _config: NgbTimepickerConfig, private _ngbTimeAdapter: NgbTimeAdapter<any>,\n      private _cd: ChangeDetectorRef, public i18n: NgbTimepickerI18n) {\n    this.meridian = _config.meridian;\n    this.spinners = _config.spinners;\n    this.seconds = _config.seconds;\n    this.hourStep = _config.hourStep;\n    this.minuteStep = _config.minuteStep;\n    this.secondStep = _config.secondStep;\n    this.disabled = _config.disabled;\n    this.readonlyInputs = _config.readonlyInputs;\n    this.size = _config.size;\n  }\n\n  onChange = (_: any) => {};\n  onTouched = () => {};\n\n  writeValue(value) {\n    const structValue = this._ngbTimeAdapter.fromModel(value);\n    this.model = structValue ? new NgbTime(structValue.hour, structValue.minute, structValue.second) : new NgbTime();\n    if (!this.seconds && (!structValue || !isNumber(structValue.second))) {\n      this.model.second = 0;\n    }\n    this._cd.markForCheck();\n  }\n\n  registerOnChange(fn: (value: any) => any): void { this.onChange = fn; }\n\n  registerOnTouched(fn: () => any): void { this.onTouched = fn; }\n\n  setDisabledState(isDisabled: boolean) { this.disabled = isDisabled; }\n\n  changeHour(step: number) {\n    this.model.changeHour(step);\n    this.propagateModelChange();\n  }\n\n  changeMinute(step: number) {\n    this.model.changeMinute(step);\n    this.propagateModelChange();\n  }\n\n  changeSecond(step: number) {\n    this.model.changeSecond(step);\n    this.propagateModelChange();\n  }\n\n  updateHour(newVal: string) {\n    const isPM = this.model.hour >= 12;\n    const enteredHour = toInteger(newVal);\n    if (this.meridian && (isPM && enteredHour < 12 || !isPM && enteredHour === 12)) {\n      this.model.updateHour(enteredHour + 12);\n    } else {\n      this.model.updateHour(enteredHour);\n    }\n    this.propagateModelChange();\n  }\n\n  updateMinute(newVal: string) {\n    this.model.updateMinute(toInteger(newVal));\n    this.propagateModelChange();\n  }\n\n  updateSecond(newVal: string) {\n    this.model.updateSecond(toInteger(newVal));\n    this.propagateModelChange();\n  }\n\n  toggleMeridian() {\n    if (this.meridian) {\n      this.changeHour(12);\n    }\n  }\n\n  formatInput(input: HTMLInputElement) { input.value = input.value.replace(FILTER_REGEX, ''); }\n\n  formatHour(value: number) {\n    if (isNumber(value)) {\n      if (this.meridian) {\n        return padNumber(value % 12 === 0 ? 12 : value % 12);\n      } else {\n        return padNumber(value % 24);\n      }\n    } else {\n      return padNumber(NaN);\n    }\n  }\n\n  formatMinSec(value: number) { return padNumber(value); }\n\n  get isSmallSize(): boolean { return this.size === 'small'; }\n\n  get isLargeSize(): boolean { return this.size === 'large'; }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['seconds'] && !this.seconds && this.model && !isNumber(this.model.second)) {\n      this.model.second = 0;\n      this.propagateModelChange(false);\n    }\n  }\n\n  private propagateModelChange(touched = true) {\n    if (touched) {\n      this.onTouched();\n    }\n    if (this.model.isValid(this.seconds)) {\n      this.onChange(\n          this._ngbTimeAdapter.toModel({hour: this.model.hour, minute: this.model.minute, second: this.model.second}));\n    } else {\n      this.onChange(this._ngbTimeAdapter.toModel(null));\n    }\n  }\n}\n"]}