datepicker.component.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
  6. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  7. import { DatePickerInnerComponent } from './datepicker-inner.component';
  8. import { DatepickerConfig } from './datepicker.config';
  9. /** @type {?} */
  10. export const DATEPICKER_CONTROL_VALUE_ACCESSOR = {
  11. provide: NG_VALUE_ACCESSOR,
  12. /* tslint:disable-next-line: no-use-before-declare */
  13. useExisting: forwardRef((/**
  14. * @return {?}
  15. */
  16. () => DatePickerComponent)),
  17. multi: true
  18. };
  19. /* tslint:disable:component-selector-name component-selector-type */
  20. /* tslint:enable:component-selector-name component-selector-type */
  21. export class DatePickerComponent {
  22. /**
  23. * @param {?} config
  24. */
  25. constructor(config) {
  26. /**
  27. * sets datepicker mode, supports: `day`, `month`, `year`
  28. */
  29. this.datepickerMode = 'day';
  30. /**
  31. * if false week numbers will be hidden
  32. */
  33. this.showWeeks = true;
  34. this.selectionDone = new EventEmitter(undefined);
  35. /**
  36. * callback to invoke when the activeDate is changed.
  37. */
  38. this.activeDateChange = new EventEmitter(undefined);
  39. /* tslint:disable-next-line: no-any*/
  40. this.onChange = Function.prototype;
  41. /* tslint:disable-next-line: no-any*/
  42. this.onTouched = Function.prototype;
  43. this._now = new Date();
  44. this.config = config;
  45. this.configureOptions();
  46. }
  47. /**
  48. * currently active date
  49. * @return {?}
  50. */
  51. get activeDate() {
  52. return this._activeDate || this._now;
  53. }
  54. /**
  55. * @param {?} value
  56. * @return {?}
  57. */
  58. set activeDate(value) {
  59. this._activeDate = value;
  60. }
  61. /**
  62. * @return {?}
  63. */
  64. configureOptions() {
  65. Object.assign(this, this.config);
  66. }
  67. /**
  68. * @param {?} event
  69. * @return {?}
  70. */
  71. onUpdate(event) {
  72. this.activeDate = event;
  73. this.onChange(event);
  74. }
  75. /**
  76. * @param {?} event
  77. * @return {?}
  78. */
  79. onSelectionDone(event) {
  80. this.selectionDone.emit(event);
  81. }
  82. /**
  83. * @param {?} event
  84. * @return {?}
  85. */
  86. onActiveDateChange(event) {
  87. this.activeDateChange.emit(event);
  88. }
  89. // todo: support null value
  90. /* tslint:disable-next-line: no-any*/
  91. /**
  92. * @param {?} value
  93. * @return {?}
  94. */
  95. writeValue(value) {
  96. if (this._datePicker.compare(value, this._activeDate) === 0) {
  97. return;
  98. }
  99. if (value && value instanceof Date) {
  100. this.activeDate = value;
  101. this._datePicker.select(value, false);
  102. return;
  103. }
  104. this.activeDate = value ? new Date(value) : void 0;
  105. }
  106. /**
  107. * @param {?} fn
  108. * @return {?}
  109. */
  110. registerOnChange(fn) {
  111. this.onChange = fn;
  112. }
  113. /**
  114. * @param {?} fn
  115. * @return {?}
  116. */
  117. registerOnTouched(fn) {
  118. this.onTouched = fn;
  119. }
  120. }
  121. DatePickerComponent.decorators = [
  122. { type: Component, args: [{
  123. selector: 'datepicker',
  124. template: `
  125. <datepicker-inner [activeDate]="activeDate"
  126. (update)="onUpdate($event)"
  127. [locale]="config.locale"
  128. [datepickerMode]="datepickerMode"
  129. [initDate]="initDate"
  130. [minDate]="minDate"
  131. [maxDate]="maxDate"
  132. [minMode]="minMode"
  133. [maxMode]="maxMode"
  134. [showWeeks]="showWeeks"
  135. [formatDay]="formatDay"
  136. [formatMonth]="formatMonth"
  137. [formatYear]="formatYear"
  138. [formatDayHeader]="formatDayHeader"
  139. [formatDayTitle]="formatDayTitle"
  140. [formatMonthTitle]="formatMonthTitle"
  141. [startingDay]="startingDay"
  142. [yearRange]="yearRange"
  143. [customClass]="customClass"
  144. [dateDisabled]="dateDisabled"
  145. [dayDisabled]="dayDisabled"
  146. [onlyCurrentMonth]="onlyCurrentMonth"
  147. [shortcutPropagation]="shortcutPropagation"
  148. [monthColLimit]="monthColLimit"
  149. [yearColLimit]="yearColLimit"
  150. (selectionDone)="onSelectionDone($event)"
  151. (activeDateChange)="onActiveDateChange($event)">
  152. <daypicker tabindex="0"></daypicker>
  153. <monthpicker tabindex="0"></monthpicker>
  154. <yearpicker tabindex="0"></yearpicker>
  155. </datepicker-inner>
  156. `,
  157. providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]
  158. }] }
  159. ];
  160. /** @nocollapse */
  161. DatePickerComponent.ctorParameters = () => [
  162. { type: DatepickerConfig }
  163. ];
  164. DatePickerComponent.propDecorators = {
  165. datepickerMode: [{ type: Input }],
  166. initDate: [{ type: Input }],
  167. minDate: [{ type: Input }],
  168. maxDate: [{ type: Input }],
  169. minMode: [{ type: Input }],
  170. maxMode: [{ type: Input }],
  171. showWeeks: [{ type: Input }],
  172. formatDay: [{ type: Input }],
  173. formatMonth: [{ type: Input }],
  174. formatYear: [{ type: Input }],
  175. formatDayHeader: [{ type: Input }],
  176. formatDayTitle: [{ type: Input }],
  177. formatMonthTitle: [{ type: Input }],
  178. startingDay: [{ type: Input }],
  179. yearRange: [{ type: Input }],
  180. onlyCurrentMonth: [{ type: Input }],
  181. shortcutPropagation: [{ type: Input }],
  182. monthColLimit: [{ type: Input }],
  183. yearColLimit: [{ type: Input }],
  184. customClass: [{ type: Input }],
  185. dateDisabled: [{ type: Input }],
  186. dayDisabled: [{ type: Input }],
  187. activeDate: [{ type: Input }],
  188. selectionDone: [{ type: Output }],
  189. activeDateChange: [{ type: Output }],
  190. _datePicker: [{ type: ViewChild, args: [DatePickerInnerComponent, { static: true },] }]
  191. };
  192. if (false) {
  193. /**
  194. * sets datepicker mode, supports: `day`, `month`, `year`
  195. * @type {?}
  196. */
  197. DatePickerComponent.prototype.datepickerMode;
  198. /**
  199. * default date to show if `ng-model` value is not specified
  200. * @type {?}
  201. */
  202. DatePickerComponent.prototype.initDate;
  203. /**
  204. * oldest selectable date
  205. * @type {?}
  206. */
  207. DatePickerComponent.prototype.minDate;
  208. /**
  209. * latest selectable date
  210. * @type {?}
  211. */
  212. DatePickerComponent.prototype.maxDate;
  213. /**
  214. * set lower datepicker mode, supports: `day`, `month`, `year`
  215. * @type {?}
  216. */
  217. DatePickerComponent.prototype.minMode;
  218. /**
  219. * sets upper datepicker mode, supports: `day`, `month`, `year`
  220. * @type {?}
  221. */
  222. DatePickerComponent.prototype.maxMode;
  223. /**
  224. * if false week numbers will be hidden
  225. * @type {?}
  226. */
  227. DatePickerComponent.prototype.showWeeks;
  228. /**
  229. * format of day in month
  230. * @type {?}
  231. */
  232. DatePickerComponent.prototype.formatDay;
  233. /**
  234. * format of month in year
  235. * @type {?}
  236. */
  237. DatePickerComponent.prototype.formatMonth;
  238. /**
  239. * format of year in year range
  240. * @type {?}
  241. */
  242. DatePickerComponent.prototype.formatYear;
  243. /**
  244. * format of day in week header
  245. * @type {?}
  246. */
  247. DatePickerComponent.prototype.formatDayHeader;
  248. /**
  249. * format of title when selecting day
  250. * @type {?}
  251. */
  252. DatePickerComponent.prototype.formatDayTitle;
  253. /**
  254. * format of title when selecting month
  255. * @type {?}
  256. */
  257. DatePickerComponent.prototype.formatMonthTitle;
  258. /**
  259. * starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday)
  260. * @type {?}
  261. */
  262. DatePickerComponent.prototype.startingDay;
  263. /**
  264. * number of years displayed in year selection
  265. * @type {?}
  266. */
  267. DatePickerComponent.prototype.yearRange;
  268. /**
  269. * if true only dates from the currently displayed month will be shown
  270. * @type {?}
  271. */
  272. DatePickerComponent.prototype.onlyCurrentMonth;
  273. /**
  274. * if true shortcut`s event propagation will be disabled
  275. * @type {?}
  276. */
  277. DatePickerComponent.prototype.shortcutPropagation;
  278. /**
  279. * number of months displayed in a single row of month picker
  280. * @type {?}
  281. */
  282. DatePickerComponent.prototype.monthColLimit;
  283. /**
  284. * number of years displayed in a single row of year picker
  285. * @type {?}
  286. */
  287. DatePickerComponent.prototype.yearColLimit;
  288. /**
  289. * array of custom css classes to be applied to targeted dates
  290. * @type {?}
  291. */
  292. DatePickerComponent.prototype.customClass;
  293. /**
  294. * array of disabled dates
  295. * @type {?}
  296. */
  297. DatePickerComponent.prototype.dateDisabled;
  298. /**
  299. * disabled days of the week from 0-6 (0=Sunday, ..., 6=Saturday)
  300. * @type {?}
  301. */
  302. DatePickerComponent.prototype.dayDisabled;
  303. /** @type {?} */
  304. DatePickerComponent.prototype.selectionDone;
  305. /**
  306. * callback to invoke when the activeDate is changed.
  307. * @type {?}
  308. */
  309. DatePickerComponent.prototype.activeDateChange;
  310. /** @type {?} */
  311. DatePickerComponent.prototype._datePicker;
  312. /** @type {?} */
  313. DatePickerComponent.prototype.onChange;
  314. /** @type {?} */
  315. DatePickerComponent.prototype.onTouched;
  316. /** @type {?} */
  317. DatePickerComponent.prototype.config;
  318. /**
  319. * @type {?}
  320. * @protected
  321. */
  322. DatePickerComponent.prototype._now;
  323. /**
  324. * @type {?}
  325. * @protected
  326. */
  327. DatePickerComponent.prototype._activeDate;
  328. }
  329. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["datepicker.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EAEN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;;AAEvD,MAAM,OAAO,iCAAiC,GAAa;IACzD,OAAO,EAAE,iBAAiB;;IAE1B,WAAW,EAAE,UAAU;;;IAAC,GAAG,EAAE,CAAC,mBAAmB,EAAC;IAClD,KAAK,EAAE,IAAI;CACZ;;AAwCD,mEAAmE;AACnE,MAAM,OAAO,mBAAmB;;;;IA8E9B,YAAY,MAAwB;;;;QA5E3B,mBAAc,GAAG,KAAK,CAAC;;;;QAYvB,cAAS,GAAG,IAAI,CAAC;QA2C1B,kBAAa,GAAuB,IAAI,YAAY,CAAO,SAAS,CAAC,CAAC;;;;QAItE,qBAAgB,GAAuB,IAAI,YAAY,CACrD,SAAS,CACV,CAAC;;QAMF,aAAQ,GAAQ,QAAQ,CAAC,SAAS,CAAC;;QAEnC,cAAS,GAAQ,QAAQ,CAAC,SAAS,CAAC;QAI1B,SAAI,GAAS,IAAI,IAAI,EAAE,CAAC;QAIhC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;;IAlCD,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,CAAC;IACvC,CAAC;;;;;IAED,IAAI,UAAU,CAAC,KAAW;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;;;;IA6BD,gBAAgB;QACd,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;;;;;IAED,QAAQ,CAAC,KAAW;QAClB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;;;;;IAED,eAAe,CAAC,KAAW;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;;;;;IAED,kBAAkB,CAAC,KAAW;QAC5B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;;;;;;;IAGD,UAAU,CAAC,KAAU;QACnB,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE;YAC3D,OAAO;SACR;QACD,IAAI,KAAK,IAAI,KAAK,YAAY,IAAI,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YAEtC,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;;;;;IAED,gBAAgB,CAAC,EAAc;QAC7B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;;;;;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;YA/JF,SAAS,SAAC;gBACT,QAAQ,EAAE,YAAY;gBACtB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgCP;gBACH,SAAS,EAAE,CAAC,iCAAiC,CAAC;aAC/C;;;;YA9CQ,gBAAgB;;;6BAkDtB,KAAK;uBAEL,KAAK;sBAEL,KAAK;sBAEL,KAAK;sBAEL,KAAK;sBAEL,KAAK;wBAEL,KAAK;wBAEL,KAAK;0BAEL,KAAK;yBAEL,KAAK;8BAEL,KAAK;6BAEL,KAAK;+BAEL,KAAK;0BAEL,KAAK;wBAEL,KAAK;+BAEL,KAAK;kCAEL,KAAK;4BAEL,KAAK;2BAEL,KAAK;0BAEL,KAAK;2BAEL,KAAK;0BAEL,KAAK;yBAGL,KAAK;4BASL,MAAM;+BAIN,MAAM;0BAKN,SAAS,SAAC,wBAAwB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;;;;;;;IA/DrD,6CAAgC;;;;;IAEhC,uCAAwB;;;;;IAExB,sCAAuB;;;;;IAEvB,sCAAuB;;;;;IAEvB,sCAAyB;;;;;IAEzB,sCAAyB;;;;;IAEzB,wCAA0B;;;;;IAE1B,wCAA2B;;;;;IAE3B,0CAA6B;;;;;IAE7B,yCAA4B;;;;;IAE5B,8CAAiC;;;;;IAEjC,6CAAgC;;;;;IAEhC,+CAAkC;;;;;IAElC,0CAA6B;;;;;IAE7B,wCAA2B;;;;;IAE3B,+CAAmC;;;;;IAEnC,kDAAsC;;;;;IAEtC,4CAA+B;;;;;IAE/B,2CAA8B;;;;;IAE9B,0CAAoE;;;;;IAEpE,2CAAsD;;;;;IAEtD,0CAA+B;;IAY/B,4CACsE;;;;;IAGtE,+CAGE;;IAEF,0CACsC;;IAGtC,uCAAmC;;IAEnC,wCAAoC;;IAEpC,qCAAyB;;;;;IAEzB,mCAAkC;;;;;IAClC,0CAA4B","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  Provider,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DatePickerInnerComponent } from './datepicker-inner.component';\nimport { DatepickerConfig } from './datepicker.config';\n\nexport const DATEPICKER_CONTROL_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  /* tslint:disable-next-line: no-use-before-declare */\n  useExisting: forwardRef(() => DatePickerComponent),\n  multi: true\n};\n\n/* tslint:disable:component-selector-name component-selector-type */\n@Component({\n  selector: 'datepicker',\n  template: `\n    <datepicker-inner [activeDate]=\"activeDate\"\n                      (update)=\"onUpdate($event)\"\n                      [locale]=\"config.locale\"\n                      [datepickerMode]=\"datepickerMode\"\n                      [initDate]=\"initDate\"\n                      [minDate]=\"minDate\"\n                      [maxDate]=\"maxDate\"\n                      [minMode]=\"minMode\"\n                      [maxMode]=\"maxMode\"\n                      [showWeeks]=\"showWeeks\"\n                      [formatDay]=\"formatDay\"\n                      [formatMonth]=\"formatMonth\"\n                      [formatYear]=\"formatYear\"\n                      [formatDayHeader]=\"formatDayHeader\"\n                      [formatDayTitle]=\"formatDayTitle\"\n                      [formatMonthTitle]=\"formatMonthTitle\"\n                      [startingDay]=\"startingDay\"\n                      [yearRange]=\"yearRange\"\n                      [customClass]=\"customClass\"\n                      [dateDisabled]=\"dateDisabled\"\n                      [dayDisabled]=\"dayDisabled\"\n                      [onlyCurrentMonth]=\"onlyCurrentMonth\"\n                      [shortcutPropagation]=\"shortcutPropagation\"\n                      [monthColLimit]=\"monthColLimit\"\n                      [yearColLimit]=\"yearColLimit\"\n                      (selectionDone)=\"onSelectionDone($event)\"\n                      (activeDateChange)=\"onActiveDateChange($event)\">\n      <daypicker tabindex=\"0\"></daypicker>\n      <monthpicker tabindex=\"0\"></monthpicker>\n      <yearpicker tabindex=\"0\"></yearpicker>\n    </datepicker-inner>\n    `,\n  providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]\n})\n/* tslint:enable:component-selector-name component-selector-type */\nexport class DatePickerComponent implements ControlValueAccessor {\n  /** sets datepicker mode, supports: `day`, `month`, `year` */\n  @Input() datepickerMode = 'day';\n  /** default date to show if `ng-model` value is not specified */\n  @Input() initDate: Date;\n  /**  oldest selectable date */\n  @Input() minDate: Date;\n  /** latest selectable date */\n  @Input() maxDate: Date;\n  /** set lower datepicker mode, supports: `day`, `month`, `year` */\n  @Input() minMode: string;\n  /** sets upper datepicker mode, supports: `day`, `month`, `year` */\n  @Input() maxMode: string;\n  /** if false week numbers will be hidden */\n  @Input() showWeeks = true;\n  /** format of day in month */\n  @Input() formatDay: string;\n  /** format of month in year */\n  @Input() formatMonth: string;\n  /** format of year in year range */\n  @Input() formatYear: string;\n  /** format of day in week header */\n  @Input() formatDayHeader: string;\n  /** format of title when selecting day */\n  @Input() formatDayTitle: string;\n  /** format of title when selecting month */\n  @Input() formatMonthTitle: string;\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input() startingDay: number;\n  /** number of years displayed in year selection */\n  @Input() yearRange: number;\n  /** if true only dates from the currently displayed month will be shown */\n  @Input() onlyCurrentMonth: boolean;\n  /** if true shortcut`s event propagation will be disabled */\n  @Input() shortcutPropagation: boolean;\n  /** number of months displayed in a single row of month picker */\n  @Input() monthColLimit: number;\n  /** number of years displayed in a single row of year picker */\n  @Input() yearColLimit: number;\n  /** array of custom css classes to be applied to targeted dates */\n  @Input() customClass: { date: Date; mode: string; clazz: string }[];\n  /** array of disabled dates */\n  @Input() dateDisabled: { date: Date; mode: string }[];\n  /** disabled days of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input() dayDisabled: number[];\n\n  /** currently active date */\n  @Input()\n  get activeDate(): Date {\n    return this._activeDate || this._now;\n  }\n\n  set activeDate(value: Date) {\n    this._activeDate = value;\n  }\n\n  @Output()\n  selectionDone: EventEmitter<Date> = new EventEmitter<Date>(undefined);\n\n  /** callback to invoke when the activeDate is changed. */\n  @Output()\n  activeDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined\n  );\n\n  @ViewChild(DatePickerInnerComponent, { static: true })\n  _datePicker: DatePickerInnerComponent;\n\n  /* tslint:disable-next-line: no-any*/\n  onChange: any = Function.prototype;\n  /* tslint:disable-next-line: no-any*/\n  onTouched: any = Function.prototype;\n\n  config: DatepickerConfig;\n\n  protected _now: Date = new Date();\n  protected _activeDate: Date;\n\n  constructor(config: DatepickerConfig) {\n    this.config = config;\n    this.configureOptions();\n  }\n\n  configureOptions(): void {\n    Object.assign(this, this.config);\n  }\n\n  onUpdate(event: Date): void {\n    this.activeDate = event;\n    this.onChange(event);\n  }\n\n  onSelectionDone(event: Date): void {\n    this.selectionDone.emit(event);\n  }\n\n  onActiveDateChange(event: Date): void {\n    this.activeDateChange.emit(event);\n  }\n  // todo: support null value\n  /* tslint:disable-next-line: no-any*/\n  writeValue(value: any): void {\n    if (this._datePicker.compare(value, this._activeDate) === 0) {\n      return;\n    }\n    if (value && value instanceof Date) {\n      this.activeDate = value;\n      this._datePicker.select(value, false);\n\n      return;\n    }\n\n    this.activeDate = value ? new Date(value) : void 0;\n  }\n\n  registerOnChange(fn: () => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n}\n"]}