timepicker.component.js 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. /* tslint:disable:no-forward-ref max-file-line-count */
  6. import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, Input, Output, ViewEncapsulation } from '@angular/core';
  7. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  8. import { TimepickerActions } from './reducer/timepicker.actions';
  9. import { TimepickerStore } from './reducer/timepicker.store';
  10. import { getControlsValue } from './timepicker-controls.util';
  11. import { TimepickerConfig } from './timepicker.config';
  12. import { isValidDate, padNumber, parseTime, isInputValid, isHourInputValid, isMinuteInputValid, isSecondInputValid, isInputLimitValid } from './timepicker.utils';
  13. /** @type {?} */
  14. export const TIMEPICKER_CONTROL_VALUE_ACCESSOR = {
  15. provide: NG_VALUE_ACCESSOR,
  16. /* tslint:disable-next-line: no-use-before-declare */
  17. useExisting: forwardRef((/**
  18. * @return {?}
  19. */
  20. () => TimepickerComponent)),
  21. multi: true
  22. };
  23. export class TimepickerComponent {
  24. /**
  25. * @param {?} _config
  26. * @param {?} _cd
  27. * @param {?} _store
  28. * @param {?} _timepickerActions
  29. */
  30. constructor(_config, _cd, _store, _timepickerActions) {
  31. this._cd = _cd;
  32. this._store = _store;
  33. this._timepickerActions = _timepickerActions;
  34. /**
  35. * emits true if value is a valid date
  36. */
  37. this.isValid = new EventEmitter();
  38. // min\max validation for input fields
  39. this.invalidHours = false;
  40. this.invalidMinutes = false;
  41. this.invalidSeconds = false;
  42. // control value accessor methods
  43. // tslint:disable-next-line:no-any
  44. this.onChange = Function.prototype;
  45. // tslint:disable-next-line:no-any
  46. this.onTouched = Function.prototype;
  47. Object.assign(this, _config);
  48. this.timepickerSub = _store
  49. .select((/**
  50. * @param {?} state
  51. * @return {?}
  52. */
  53. state => state.value))
  54. .subscribe((/**
  55. * @param {?} value
  56. * @return {?}
  57. */
  58. (value) => {
  59. // update UI values if date changed
  60. this._renderTime(value);
  61. this.onChange(value);
  62. this._store.dispatch(this._timepickerActions.updateControls(getControlsValue(this)));
  63. }));
  64. _store
  65. .select((/**
  66. * @param {?} state
  67. * @return {?}
  68. */
  69. state => state.controls))
  70. .subscribe((/**
  71. * @param {?} controlsState
  72. * @return {?}
  73. */
  74. (controlsState) => {
  75. this.isValid.emit(isInputValid(this.hours, this.minutes, this.seconds, this.isPM()));
  76. Object.assign(this, controlsState);
  77. _cd.markForCheck();
  78. }));
  79. }
  80. /**
  81. * @deprecated - please use `isEditable` instead
  82. * @return {?}
  83. */
  84. get isSpinnersVisible() {
  85. return this.showSpinners && !this.readonlyInput;
  86. }
  87. /**
  88. * @return {?}
  89. */
  90. get isEditable() {
  91. return !(this.readonlyInput || this.disabled);
  92. }
  93. /**
  94. * @return {?}
  95. */
  96. resetValidation() {
  97. this.invalidHours = false;
  98. this.invalidMinutes = false;
  99. this.invalidSeconds = false;
  100. }
  101. /**
  102. * @return {?}
  103. */
  104. isPM() {
  105. return this.showMeridian && this.meridian === this.meridians[1];
  106. }
  107. /**
  108. * @param {?} $event
  109. * @return {?}
  110. */
  111. prevDef($event) {
  112. $event.preventDefault();
  113. }
  114. /**
  115. * @param {?} $event
  116. * @return {?}
  117. */
  118. wheelSign($event) {
  119. return Math.sign($event.deltaY) * -1;
  120. }
  121. /**
  122. * @param {?} changes
  123. * @return {?}
  124. */
  125. ngOnChanges(changes) {
  126. this._store.dispatch(this._timepickerActions.updateControls(getControlsValue(this)));
  127. }
  128. /**
  129. * @param {?} step
  130. * @param {?=} source
  131. * @return {?}
  132. */
  133. changeHours(step, source = '') {
  134. this.resetValidation();
  135. this._store.dispatch(this._timepickerActions.changeHours({ step, source }));
  136. }
  137. /**
  138. * @param {?} step
  139. * @param {?=} source
  140. * @return {?}
  141. */
  142. changeMinutes(step, source = '') {
  143. this.resetValidation();
  144. this._store.dispatch(this._timepickerActions.changeMinutes({ step, source }));
  145. }
  146. /**
  147. * @param {?} step
  148. * @param {?=} source
  149. * @return {?}
  150. */
  151. changeSeconds(step, source = '') {
  152. this.resetValidation();
  153. this._store.dispatch(this._timepickerActions.changeSeconds({ step, source }));
  154. }
  155. /**
  156. * @param {?} hours
  157. * @return {?}
  158. */
  159. updateHours(hours) {
  160. this.resetValidation();
  161. this.hours = hours;
  162. /** @type {?} */
  163. const isValid = isHourInputValid(this.hours, this.isPM()) && this.isValidLimit();
  164. if (!isValid) {
  165. this.invalidHours = true;
  166. this.isValid.emit(false);
  167. this.onChange(null);
  168. return;
  169. }
  170. this._updateTime();
  171. }
  172. /**
  173. * @param {?} minutes
  174. * @return {?}
  175. */
  176. updateMinutes(minutes) {
  177. this.resetValidation();
  178. this.minutes = minutes;
  179. /** @type {?} */
  180. const isValid = isMinuteInputValid(this.minutes) && this.isValidLimit();
  181. if (!isValid) {
  182. this.invalidMinutes = true;
  183. this.isValid.emit(false);
  184. this.onChange(null);
  185. return;
  186. }
  187. this._updateTime();
  188. }
  189. /**
  190. * @param {?} seconds
  191. * @return {?}
  192. */
  193. updateSeconds(seconds) {
  194. this.resetValidation();
  195. this.seconds = seconds;
  196. /** @type {?} */
  197. const isValid = isSecondInputValid(this.seconds) && this.isValidLimit();
  198. if (!isValid) {
  199. this.invalidSeconds = true;
  200. this.isValid.emit(false);
  201. this.onChange(null);
  202. return;
  203. }
  204. this._updateTime();
  205. }
  206. /**
  207. * @return {?}
  208. */
  209. isValidLimit() {
  210. return isInputLimitValid({
  211. hour: this.hours,
  212. minute: this.minutes,
  213. seconds: this.seconds,
  214. isPM: this.isPM()
  215. }, this.max, this.min);
  216. }
  217. /**
  218. * @return {?}
  219. */
  220. _updateTime() {
  221. /** @type {?} */
  222. const _seconds = this.showSeconds ? this.seconds : void 0;
  223. /** @type {?} */
  224. const _minutes = this.showMinutes ? this.minutes : void 0;
  225. if (!isInputValid(this.hours, _minutes, _seconds, this.isPM())) {
  226. this.isValid.emit(false);
  227. this.onChange(null);
  228. return;
  229. }
  230. this._store.dispatch(this._timepickerActions.setTime({
  231. hour: this.hours,
  232. minute: this.minutes,
  233. seconds: this.seconds,
  234. isPM: this.isPM()
  235. }));
  236. }
  237. /**
  238. * @return {?}
  239. */
  240. toggleMeridian() {
  241. if (!this.showMeridian || !this.isEditable) {
  242. return;
  243. }
  244. /** @type {?} */
  245. const _hoursPerDayHalf = 12;
  246. this._store.dispatch(this._timepickerActions.changeHours({
  247. step: _hoursPerDayHalf,
  248. source: ''
  249. }));
  250. }
  251. /**
  252. * Write a new value to the element.
  253. * @param {?} obj
  254. * @return {?}
  255. */
  256. writeValue(obj) {
  257. if (isValidDate(obj)) {
  258. this._store.dispatch(this._timepickerActions.writeValue(parseTime(obj)));
  259. }
  260. else if (obj == null) {
  261. this._store.dispatch(this._timepickerActions.writeValue(null));
  262. }
  263. }
  264. /**
  265. * Set the function to be called when the control receives a change event.
  266. * @param {?} fn
  267. * @return {?}
  268. */
  269. // tslint:disable-next-line:no-any
  270. registerOnChange(fn) {
  271. this.onChange = fn;
  272. }
  273. /**
  274. * Set the function to be called when the control receives a touch event.
  275. * @param {?} fn
  276. * @return {?}
  277. */
  278. registerOnTouched(fn) {
  279. this.onTouched = fn;
  280. }
  281. /**
  282. * This function is called when the control status changes to or from "disabled".
  283. * Depending on the value, it will enable or disable the appropriate DOM element.
  284. *
  285. * @param {?} isDisabled
  286. * @return {?}
  287. */
  288. setDisabledState(isDisabled) {
  289. this.disabled = isDisabled;
  290. this._cd.markForCheck();
  291. }
  292. /**
  293. * @return {?}
  294. */
  295. ngOnDestroy() {
  296. this.timepickerSub.unsubscribe();
  297. }
  298. /**
  299. * @private
  300. * @param {?} value
  301. * @return {?}
  302. */
  303. _renderTime(value) {
  304. if (!isValidDate(value)) {
  305. this.hours = '';
  306. this.minutes = '';
  307. this.seconds = '';
  308. this.meridian = this.meridians[0];
  309. return;
  310. }
  311. /** @type {?} */
  312. const _value = parseTime(value);
  313. /** @type {?} */
  314. const _hoursPerDayHalf = 12;
  315. /** @type {?} */
  316. let _hours = _value.getHours();
  317. if (this.showMeridian) {
  318. this.meridian = this.meridians[_hours >= _hoursPerDayHalf ? 1 : 0];
  319. _hours = _hours % _hoursPerDayHalf;
  320. // should be 12 PM, not 00 PM
  321. if (_hours === 0) {
  322. _hours = _hoursPerDayHalf;
  323. }
  324. }
  325. this.hours = padNumber(_hours);
  326. this.minutes = padNumber(_value.getMinutes());
  327. this.seconds = padNumber(_value.getUTCSeconds());
  328. }
  329. }
  330. TimepickerComponent.decorators = [
  331. { type: Component, args: [{
  332. selector: 'timepicker',
  333. changeDetection: ChangeDetectionStrategy.OnPush,
  334. providers: [TIMEPICKER_CONTROL_VALUE_ACCESSOR, TimepickerStore],
  335. template: "<table>\n <tbody>\n <tr class=\"text-center\" [hidden]=\"!showSpinners\">\n <!-- increment hours button-->\n <td>\n <a class=\"btn btn-link\" [class.disabled]=\"!canIncrementHours || !isEditable\"\n (click)=\"changeHours(hourStep)\"\n ><span class=\"bs-chevron bs-chevron-up\"></span></a>\n </td>\n <!-- divider -->\n <td *ngIf=\"showMinutes\">&nbsp;&nbsp;&nbsp;</td>\n <!-- increment minutes button -->\n <td *ngIf=\"showMinutes\">\n <a class=\"btn btn-link\" [class.disabled]=\"!canIncrementMinutes || !isEditable\"\n (click)=\"changeMinutes(minuteStep)\"\n ><span class=\"bs-chevron bs-chevron-up\"></span></a>\n </td>\n <!-- divider -->\n <td *ngIf=\"showSeconds\">&nbsp;</td>\n <!-- increment seconds button -->\n <td *ngIf=\"showSeconds\">\n <a class=\"btn btn-link\" [class.disabled]=\"!canIncrementSeconds || !isEditable\"\n (click)=\"changeSeconds(secondsStep)\">\n <span class=\"bs-chevron bs-chevron-up\"></span>\n </a>\n </td>\n <!-- space between -->\n <td *ngIf=\"showMeridian\">&nbsp;&nbsp;&nbsp;</td>\n <!-- meridian placeholder-->\n <td *ngIf=\"showMeridian\"></td>\n </tr>\n <tr>\n <!-- hours -->\n <td class=\"form-group\" [class.has-error]=\"invalidHours\">\n <input type=\"text\" [class.is-invalid]=\"invalidHours\"\n class=\"form-control text-center bs-timepicker-field\"\n [placeholder]=\"hoursPlaceholder\"\n maxlength=\"2\"\n [readonly]=\"readonlyInput\"\n [disabled]=\"disabled\"\n [value]=\"hours\"\n (wheel)=\"prevDef($event);changeHours(hourStep * wheelSign($event), 'wheel')\"\n (keydown.ArrowUp)=\"changeHours(hourStep, 'key')\"\n (keydown.ArrowDown)=\"changeHours(-hourStep, 'key')\"\n (change)=\"updateHours($event.target.value)\"></td>\n <!-- divider -->\n <td *ngIf=\"showMinutes\">&nbsp;:&nbsp;</td>\n <!-- minutes -->\n <td class=\"form-group\" *ngIf=\"showMinutes\" [class.has-error]=\"invalidMinutes\">\n <input type=\"text\" [class.is-invalid]=\"invalidMinutes\"\n class=\"form-control text-center bs-timepicker-field\"\n [placeholder]=\"minutesPlaceholder\"\n maxlength=\"2\"\n [readonly]=\"readonlyInput\"\n [disabled]=\"disabled\"\n [value]=\"minutes\"\n (wheel)=\"prevDef($event);changeMinutes(minuteStep * wheelSign($event), 'wheel')\"\n (keydown.ArrowUp)=\"changeMinutes(minuteStep, 'key')\"\n (keydown.ArrowDown)=\"changeMinutes(-minuteStep, 'key')\"\n (change)=\"updateMinutes($event.target.value)\">\n </td>\n <!-- divider -->\n <td *ngIf=\"showSeconds\">&nbsp;:&nbsp;</td>\n <!-- seconds -->\n <td class=\"form-group\" *ngIf=\"showSeconds\" [class.has-error]=\"invalidSeconds\">\n <input type=\"text\" [class.is-invalid]=\"invalidSeconds\"\n class=\"form-control text-center bs-timepicker-field\"\n [placeholder]=\"secondsPlaceholder\"\n maxlength=\"2\"\n [readonly]=\"readonlyInput\"\n [disabled]=\"disabled\"\n [value]=\"seconds\"\n (wheel)=\"prevDef($event);changeSeconds(secondsStep * wheelSign($event), 'wheel')\"\n (keydown.ArrowUp)=\"changeSeconds(secondsStep, 'key')\"\n (keydown.ArrowDown)=\"changeSeconds(-secondsStep, 'key')\"\n (change)=\"updateSeconds($event.target.value)\">\n </td>\n <!-- space between -->\n <td *ngIf=\"showMeridian\">&nbsp;&nbsp;&nbsp;</td>\n <!-- meridian -->\n <td *ngIf=\"showMeridian\">\n <button type=\"button\" class=\"btn btn-default text-center\"\n [disabled]=\"!isEditable || !canToggleMeridian\"\n [class.disabled]=\"!isEditable || !canToggleMeridian\"\n (click)=\"toggleMeridian()\"\n >{{ meridian }}\n </button>\n </td>\n </tr>\n <tr class=\"text-center\" [hidden]=\"!showSpinners\">\n <!-- decrement hours button-->\n <td>\n <a class=\"btn btn-link\" [class.disabled]=\"!canDecrementHours || !isEditable\"\n (click)=\"changeHours(-hourStep)\">\n <span class=\"bs-chevron bs-chevron-down\"></span>\n </a>\n </td>\n <!-- divider -->\n <td *ngIf=\"showMinutes\">&nbsp;&nbsp;&nbsp;</td>\n <!-- decrement minutes button-->\n <td *ngIf=\"showMinutes\">\n <a class=\"btn btn-link\" [class.disabled]=\"!canDecrementMinutes || !isEditable\"\n (click)=\"changeMinutes(-minuteStep)\">\n <span class=\"bs-chevron bs-chevron-down\"></span>\n </a>\n </td>\n <!-- divider -->\n <td *ngIf=\"showSeconds\">&nbsp;</td>\n <!-- decrement seconds button-->\n <td *ngIf=\"showSeconds\">\n <a class=\"btn btn-link\" [class.disabled]=\"!canDecrementSeconds || !isEditable\"\n (click)=\"changeSeconds(-secondsStep)\">\n <span class=\"bs-chevron bs-chevron-down\"></span>\n </a>\n </td>\n <!-- space between -->\n <td *ngIf=\"showMeridian\">&nbsp;&nbsp;&nbsp;</td>\n <!-- meridian placeholder-->\n <td *ngIf=\"showMeridian\"></td>\n </tr>\n </tbody>\n</table>\n",
  336. encapsulation: ViewEncapsulation.None,
  337. styles: [`
  338. .bs-chevron {
  339. border-style: solid;
  340. display: block;
  341. width: 9px;
  342. height: 9px;
  343. position: relative;
  344. border-width: 3px 0px 0 3px;
  345. }
  346. .bs-chevron-up {
  347. -webkit-transform: rotate(45deg);
  348. transform: rotate(45deg);
  349. top: 2px;
  350. }
  351. .bs-chevron-down {
  352. -webkit-transform: rotate(-135deg);
  353. transform: rotate(-135deg);
  354. top: -2px;
  355. }
  356. .bs-timepicker-field {
  357. width: 50px;
  358. padding: .375rem .55rem;
  359. }
  360. `]
  361. }] }
  362. ];
  363. /** @nocollapse */
  364. TimepickerComponent.ctorParameters = () => [
  365. { type: TimepickerConfig },
  366. { type: ChangeDetectorRef },
  367. { type: TimepickerStore },
  368. { type: TimepickerActions }
  369. ];
  370. TimepickerComponent.propDecorators = {
  371. hourStep: [{ type: Input }],
  372. minuteStep: [{ type: Input }],
  373. secondsStep: [{ type: Input }],
  374. readonlyInput: [{ type: Input }],
  375. disabled: [{ type: Input }],
  376. mousewheel: [{ type: Input }],
  377. arrowkeys: [{ type: Input }],
  378. showSpinners: [{ type: Input }],
  379. showMeridian: [{ type: Input }],
  380. showMinutes: [{ type: Input }],
  381. showSeconds: [{ type: Input }],
  382. meridians: [{ type: Input }],
  383. min: [{ type: Input }],
  384. max: [{ type: Input }],
  385. hoursPlaceholder: [{ type: Input }],
  386. minutesPlaceholder: [{ type: Input }],
  387. secondsPlaceholder: [{ type: Input }],
  388. isValid: [{ type: Output }]
  389. };
  390. if (false) {
  391. /**
  392. * hours change step
  393. * @type {?}
  394. */
  395. TimepickerComponent.prototype.hourStep;
  396. /**
  397. * hours change step
  398. * @type {?}
  399. */
  400. TimepickerComponent.prototype.minuteStep;
  401. /**
  402. * seconds change step
  403. * @type {?}
  404. */
  405. TimepickerComponent.prototype.secondsStep;
  406. /**
  407. * if true hours and minutes fields will be readonly
  408. * @type {?}
  409. */
  410. TimepickerComponent.prototype.readonlyInput;
  411. /**
  412. * if true hours and minutes fields will be disabled
  413. * @type {?}
  414. */
  415. TimepickerComponent.prototype.disabled;
  416. /**
  417. * if true scroll inside hours and minutes inputs will change time
  418. * @type {?}
  419. */
  420. TimepickerComponent.prototype.mousewheel;
  421. /**
  422. * if true the values of hours and minutes can be changed using the up/down arrow keys on the keyboard
  423. * @type {?}
  424. */
  425. TimepickerComponent.prototype.arrowkeys;
  426. /**
  427. * if true spinner arrows above and below the inputs will be shown
  428. * @type {?}
  429. */
  430. TimepickerComponent.prototype.showSpinners;
  431. /**
  432. * if true meridian button will be shown
  433. * @type {?}
  434. */
  435. TimepickerComponent.prototype.showMeridian;
  436. /**
  437. * show minutes in timepicker
  438. * @type {?}
  439. */
  440. TimepickerComponent.prototype.showMinutes;
  441. /**
  442. * show seconds in timepicker
  443. * @type {?}
  444. */
  445. TimepickerComponent.prototype.showSeconds;
  446. /**
  447. * meridian labels based on locale
  448. * @type {?}
  449. */
  450. TimepickerComponent.prototype.meridians;
  451. /**
  452. * minimum time user can select
  453. * @type {?}
  454. */
  455. TimepickerComponent.prototype.min;
  456. /**
  457. * maximum time user can select
  458. * @type {?}
  459. */
  460. TimepickerComponent.prototype.max;
  461. /**
  462. * placeholder for hours field in timepicker
  463. * @type {?}
  464. */
  465. TimepickerComponent.prototype.hoursPlaceholder;
  466. /**
  467. * placeholder for minutes field in timepicker
  468. * @type {?}
  469. */
  470. TimepickerComponent.prototype.minutesPlaceholder;
  471. /**
  472. * placeholder for seconds field in timepicker
  473. * @type {?}
  474. */
  475. TimepickerComponent.prototype.secondsPlaceholder;
  476. /**
  477. * emits true if value is a valid date
  478. * @type {?}
  479. */
  480. TimepickerComponent.prototype.isValid;
  481. /** @type {?} */
  482. TimepickerComponent.prototype.hours;
  483. /** @type {?} */
  484. TimepickerComponent.prototype.minutes;
  485. /** @type {?} */
  486. TimepickerComponent.prototype.seconds;
  487. /** @type {?} */
  488. TimepickerComponent.prototype.meridian;
  489. /** @type {?} */
  490. TimepickerComponent.prototype.invalidHours;
  491. /** @type {?} */
  492. TimepickerComponent.prototype.invalidMinutes;
  493. /** @type {?} */
  494. TimepickerComponent.prototype.invalidSeconds;
  495. /** @type {?} */
  496. TimepickerComponent.prototype.canIncrementHours;
  497. /** @type {?} */
  498. TimepickerComponent.prototype.canIncrementMinutes;
  499. /** @type {?} */
  500. TimepickerComponent.prototype.canIncrementSeconds;
  501. /** @type {?} */
  502. TimepickerComponent.prototype.canDecrementHours;
  503. /** @type {?} */
  504. TimepickerComponent.prototype.canDecrementMinutes;
  505. /** @type {?} */
  506. TimepickerComponent.prototype.canDecrementSeconds;
  507. /** @type {?} */
  508. TimepickerComponent.prototype.canToggleMeridian;
  509. /** @type {?} */
  510. TimepickerComponent.prototype.onChange;
  511. /** @type {?} */
  512. TimepickerComponent.prototype.onTouched;
  513. /** @type {?} */
  514. TimepickerComponent.prototype.timepickerSub;
  515. /**
  516. * @type {?}
  517. * @private
  518. */
  519. TimepickerComponent.prototype._cd;
  520. /**
  521. * @type {?}
  522. * @private
  523. */
  524. TimepickerComponent.prototype._store;
  525. /**
  526. * @type {?}
  527. * @private
  528. */
  529. TimepickerComponent.prototype._timepickerActions;
  530. }
  531. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"ng://ngx-bootstrap/timepicker/","sources":["timepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:no-forward-ref max-file-line-count */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges, ViewEncapsulation\n} from '@angular/core';\n\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { TimepickerActions } from './reducer/timepicker.actions';\nimport { TimepickerStore } from './reducer/timepicker.store';\nimport { getControlsValue } from './timepicker-controls.util';\nimport { TimepickerConfig } from './timepicker.config';\n\nimport {\n  TimeChangeSource,\n  TimepickerComponentState,\n  TimepickerControls\n} from './timepicker.models';\n\nimport {\n  isValidDate,\n  padNumber,\n  parseTime,\n  isInputValid,\n  isHourInputValid,\n  isMinuteInputValid,\n  isSecondInputValid,\n  isInputLimitValid\n} from './timepicker.utils';\n\nimport { Subscription } from 'rxjs';\n\nimport { ControlValueAccessorModel } from './models';\n\nexport const TIMEPICKER_CONTROL_VALUE_ACCESSOR: ControlValueAccessorModel = {\n  provide: NG_VALUE_ACCESSOR,\n  /* tslint:disable-next-line: no-use-before-declare */\n  useExisting: forwardRef(() => TimepickerComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'timepicker',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [TIMEPICKER_CONTROL_VALUE_ACCESSOR, TimepickerStore],\n  templateUrl: './timepicker.component.html',\n  styles: [`\n    .bs-chevron {\n      border-style: solid;\n      display: block;\n      width: 9px;\n      height: 9px;\n      position: relative;\n      border-width: 3px 0px 0 3px;\n    }\n\n    .bs-chevron-up {\n      -webkit-transform: rotate(45deg);\n      transform: rotate(45deg);\n      top: 2px;\n    }\n\n    .bs-chevron-down {\n      -webkit-transform: rotate(-135deg);\n      transform: rotate(-135deg);\n      top: -2px;\n    }\n\n    .bs-timepicker-field {\n      width: 50px;\n      padding: .375rem .55rem;\n    }\n  `],\n  encapsulation: ViewEncapsulation.None\n})\nexport class TimepickerComponent\n  implements ControlValueAccessor,\n    TimepickerComponentState,\n    TimepickerControls,\n    OnChanges,\n    OnDestroy {\n  /** hours change step */\n  @Input() hourStep: number;\n  /** hours change step */\n  @Input() minuteStep: number;\n  /** seconds change step */\n  @Input() secondsStep: number;\n  /** if true hours and minutes fields will be readonly */\n  @Input() readonlyInput: boolean;\n  /** if true hours and minutes fields will be disabled */\n  @Input() disabled: boolean;\n  /** if true scroll inside hours and minutes inputs will change time */\n  @Input() mousewheel: boolean;\n  /** if true the values of hours and minutes can be changed using the up/down arrow keys on the keyboard */\n  @Input() arrowkeys: boolean;\n  /** if true spinner arrows above and below the inputs will be shown */\n  @Input() showSpinners: boolean;\n  /** if true meridian button will be shown */\n  @Input() showMeridian: boolean;\n  /** show minutes in timepicker */\n  @Input() showMinutes: boolean;\n  /** show seconds in timepicker */\n  @Input() showSeconds: boolean;\n  /** meridian labels based on locale */\n  @Input() meridians: string[];\n  /** minimum time user can select */\n  @Input() min: Date;\n  /** maximum time user can select */\n  @Input() max: Date;\n  /** placeholder for hours field in timepicker */\n  @Input() hoursPlaceholder: string;\n  /** placeholder for minutes field in timepicker */\n  @Input() minutesPlaceholder: string;\n  /** placeholder for seconds field in timepicker */\n  @Input() secondsPlaceholder: string;\n\n  /** emits true if value is a valid date */\n  @Output() isValid = new EventEmitter<boolean>();\n\n  // ui variables\n  hours: string;\n  minutes: string;\n  seconds: string;\n  meridian: string;\n\n  /** @deprecated - please use `isEditable` instead */\n  get isSpinnersVisible(): boolean {\n    return this.showSpinners && !this.readonlyInput;\n  }\n\n  get isEditable(): boolean {\n    return !(this.readonlyInput || this.disabled);\n  }\n\n  // min\\max validation for input fields\n  invalidHours = false;\n  invalidMinutes = false;\n  invalidSeconds = false;\n\n  // time picker controls state\n  canIncrementHours: boolean;\n  canIncrementMinutes: boolean;\n  canIncrementSeconds: boolean;\n\n  canDecrementHours: boolean;\n  canDecrementMinutes: boolean;\n  canDecrementSeconds: boolean;\n\n  canToggleMeridian: boolean;\n\n  // control value accessor methods\n  // tslint:disable-next-line:no-any\n  onChange = Function.prototype;\n  // tslint:disable-next-line:no-any\n  onTouched = Function.prototype;\n\n  timepickerSub: Subscription;\n\n  constructor(\n    _config: TimepickerConfig,\n    private _cd: ChangeDetectorRef,\n    private _store: TimepickerStore,\n    private _timepickerActions: TimepickerActions\n  ) {\n    Object.assign(this, _config);\n\n    this.timepickerSub = _store\n      .select(state => state.value)\n      .subscribe((value: Date) => {\n        // update UI values if date changed\n        this._renderTime(value);\n        this.onChange(value);\n\n        this._store.dispatch(\n          this._timepickerActions.updateControls(getControlsValue(this))\n        );\n      });\n\n    _store\n      .select(state => state.controls)\n      .subscribe((controlsState: TimepickerControls) => {\n        this.isValid.emit(isInputValid(this.hours, this.minutes, this.seconds, this.isPM()));\n        Object.assign(this, controlsState);\n        _cd.markForCheck();\n      });\n  }\n\n  resetValidation(): void {\n    this.invalidHours = false;\n    this.invalidMinutes = false;\n    this.invalidSeconds = false;\n  }\n\n  isPM(): boolean {\n    return this.showMeridian && this.meridian === this.meridians[1];\n  }\n\n  prevDef($event: Event) {\n    $event.preventDefault();\n  }\n\n  wheelSign($event: WheelEventInit): number {\n    return Math.sign($event.deltaY) * -1;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this._store.dispatch(\n      this._timepickerActions.updateControls(getControlsValue(this))\n    );\n  }\n\n  changeHours(step: number, source: TimeChangeSource = ''): void {\n    this.resetValidation();\n    this._store.dispatch(this._timepickerActions.changeHours({ step, source }));\n  }\n\n  changeMinutes(step: number, source: TimeChangeSource = ''): void {\n    this.resetValidation();\n    this._store.dispatch(\n      this._timepickerActions.changeMinutes({ step, source })\n    );\n  }\n\n  changeSeconds(step: number, source: TimeChangeSource = ''): void {\n    this.resetValidation();\n    this._store.dispatch(\n      this._timepickerActions.changeSeconds({ step, source })\n    );\n  }\n\n  updateHours(hours: string): void {\n    this.resetValidation();\n    this.hours = hours;\n\n    const isValid = isHourInputValid(this.hours, this.isPM()) && this.isValidLimit();\n\n    if (!isValid) {\n      this.invalidHours = true;\n      this.isValid.emit(false);\n      this.onChange(null);\n\n      return;\n    }\n\n    this._updateTime();\n  }\n\n  updateMinutes(minutes: string) {\n    this.resetValidation();\n    this.minutes = minutes;\n\n    const isValid = isMinuteInputValid(this.minutes) && this.isValidLimit();\n\n    if (!isValid) {\n      this.invalidMinutes = true;\n      this.isValid.emit(false);\n      this.onChange(null);\n\n      return;\n    }\n\n    this._updateTime();\n  }\n\n  updateSeconds(seconds: string) {\n    this.resetValidation();\n    this.seconds = seconds;\n\n    const isValid = isSecondInputValid(this.seconds) && this.isValidLimit();\n\n    if (!isValid) {\n      this.invalidSeconds = true;\n      this.isValid.emit(false);\n      this.onChange(null);\n\n      return;\n    }\n\n    this._updateTime();\n  }\n\n  isValidLimit(): boolean {\n    return isInputLimitValid({\n      hour: this.hours,\n      minute: this.minutes,\n      seconds: this.seconds,\n      isPM: this.isPM()\n    }, this.max, this.min);\n  }\n\n  _updateTime() {\n    const _seconds = this.showSeconds ? this.seconds : void 0;\n    const _minutes = this.showMinutes ? this.minutes : void 0;\n    if (!isInputValid(this.hours, _minutes, _seconds, this.isPM())) {\n      this.isValid.emit(false);\n      this.onChange(null);\n\n      return;\n    }\n\n    this._store.dispatch(\n      this._timepickerActions.setTime({\n        hour: this.hours,\n        minute: this.minutes,\n        seconds: this.seconds,\n        isPM: this.isPM()\n      })\n    );\n  }\n\n  toggleMeridian(): void {\n    if (!this.showMeridian || !this.isEditable) {\n      return;\n    }\n\n    const _hoursPerDayHalf = 12;\n    this._store.dispatch(\n      this._timepickerActions.changeHours({\n        step: _hoursPerDayHalf,\n        source: ''\n      })\n    );\n  }\n\n  /**\n   * Write a new value to the element.\n   */\n  writeValue(obj: string | null | undefined | Date): void {\n    if (isValidDate(obj)) {\n      this._store.dispatch(this._timepickerActions.writeValue(parseTime(obj)));\n    } else if (obj == null) {\n      this._store.dispatch(this._timepickerActions.writeValue(null));\n    }\n  }\n\n  /**\n   * Set the function to be called when the control receives a change event.\n   */\n  // tslint:disable-next-line:no-any\n  registerOnChange(fn: (_: any) => {}): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * Set the function to be called when the control receives a touch event.\n   */\n  registerOnTouched(fn: () => {}): void {\n    this.onTouched = fn;\n  }\n\n  /**\n   * This function is called when the control status changes to or from \"disabled\".\n   * Depending on the value, it will enable or disable the appropriate DOM element.\n   *\n   * @param isDisabled\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._cd.markForCheck();\n  }\n\n  ngOnDestroy(): void {\n    this.timepickerSub.unsubscribe();\n  }\n\n  private _renderTime(value: string | Date): void {\n    if (!isValidDate(value)) {\n      this.hours = '';\n      this.minutes = '';\n      this.seconds = '';\n      this.meridian = this.meridians[0];\n\n      return;\n    }\n\n    const _value = parseTime(value);\n    const _hoursPerDayHalf = 12;\n    let _hours = _value.getHours();\n\n    if (this.showMeridian) {\n      this.meridian = this.meridians[_hours >= _hoursPerDayHalf ? 1 : 0];\n      _hours = _hours % _hoursPerDayHalf;\n      // should be 12 PM, not 00 PM\n      if (_hours === 0) {\n        _hours = _hoursPerDayHalf;\n      }\n    }\n\n    this.hours = padNumber(_hours);\n    this.minutes = padNumber(_value.getMinutes());\n    this.seconds = padNumber(_value.getUTCSeconds());\n  }\n}\n"]}