datepicker-input.js 65 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { ChangeDetectorRef, ComponentFactoryResolver, Directive, ElementRef, EventEmitter, forwardRef, Inject, Input, NgZone, Output, Renderer2, TemplateRef, ViewContainerRef } from '@angular/core';
  6. import { DOCUMENT } from '@angular/common';
  7. import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
  8. import { ngbAutoClose } from '../util/autoclose';
  9. import { ngbFocusTrap } from '../util/focus-trap';
  10. import { positionElements } from '../util/positioning';
  11. import { NgbDateAdapter } from './adapters/ngb-date-adapter';
  12. import { NgbDatepicker } from './datepicker';
  13. import { NgbCalendar } from './ngb-calendar';
  14. import { NgbDate } from './ngb-date';
  15. import { NgbDateParserFormatter } from './ngb-date-parser-formatter';
  16. import { NgbInputDatepickerConfig } from './datepicker-input-config';
  17. import { NgbDatepickerConfig } from './datepicker-config';
  18. import { isString } from '../util/util';
  19. /** @type {?} */
  20. var NGB_DATEPICKER_VALUE_ACCESSOR = {
  21. provide: NG_VALUE_ACCESSOR,
  22. useExisting: forwardRef((/**
  23. * @return {?}
  24. */
  25. function () { return NgbInputDatepicker; })),
  26. multi: true
  27. };
  28. /** @type {?} */
  29. var NGB_DATEPICKER_VALIDATOR = {
  30. provide: NG_VALIDATORS,
  31. useExisting: forwardRef((/**
  32. * @return {?}
  33. */
  34. function () { return NgbInputDatepicker; })),
  35. multi: true
  36. };
  37. /**
  38. * A directive that allows to stick a datepicker popup to an input field.
  39. *
  40. * Manages interaction with the input field itself, does value formatting and provides forms integration.
  41. */
  42. var NgbInputDatepicker = /** @class */ (function () {
  43. function NgbInputDatepicker(_parserFormatter, _elRef, _vcRef, _renderer, _cfr, _ngZone, _calendar, _dateAdapter, _document, _changeDetector, config) {
  44. var _this = this;
  45. this._parserFormatter = _parserFormatter;
  46. this._elRef = _elRef;
  47. this._vcRef = _vcRef;
  48. this._renderer = _renderer;
  49. this._cfr = _cfr;
  50. this._ngZone = _ngZone;
  51. this._calendar = _calendar;
  52. this._dateAdapter = _dateAdapter;
  53. this._document = _document;
  54. this._changeDetector = _changeDetector;
  55. this._cRef = null;
  56. this._disabled = false;
  57. this._elWithFocus = null;
  58. /**
  59. * An event emitted when user selects a date using keyboard or mouse.
  60. *
  61. * The payload of the event is currently selected `NgbDate`.
  62. *
  63. * \@since 1.1.1
  64. */
  65. this.dateSelect = new EventEmitter();
  66. /**
  67. * Event emitted right after the navigation happens and displayed month changes.
  68. *
  69. * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.
  70. */
  71. this.navigate = new EventEmitter();
  72. /**
  73. * An event fired after closing datepicker window.
  74. *
  75. * \@since 4.2.0
  76. */
  77. this.closed = new EventEmitter();
  78. this._onChange = (/**
  79. * @param {?} _
  80. * @return {?}
  81. */
  82. function (_) { });
  83. this._onTouched = (/**
  84. * @return {?}
  85. */
  86. function () { });
  87. this._validatorChange = (/**
  88. * @return {?}
  89. */
  90. function () { });
  91. ['autoClose', 'container', 'positionTarget', 'placement'].forEach((/**
  92. * @param {?} input
  93. * @return {?}
  94. */
  95. function (input) { return _this[input] = config[input]; }));
  96. this._zoneSubscription = _ngZone.onStable.subscribe((/**
  97. * @return {?}
  98. */
  99. function () { return _this._updatePopupPosition(); }));
  100. }
  101. Object.defineProperty(NgbInputDatepicker.prototype, "disabled", {
  102. get: /**
  103. * @return {?}
  104. */
  105. function () {
  106. return this._disabled;
  107. },
  108. set: /**
  109. * @param {?} value
  110. * @return {?}
  111. */
  112. function (value) {
  113. this._disabled = value === '' || (value && value !== 'false');
  114. if (this.isOpen()) {
  115. this._cRef.instance.setDisabledState(this._disabled);
  116. }
  117. },
  118. enumerable: true,
  119. configurable: true
  120. });
  121. /**
  122. * @param {?} fn
  123. * @return {?}
  124. */
  125. NgbInputDatepicker.prototype.registerOnChange = /**
  126. * @param {?} fn
  127. * @return {?}
  128. */
  129. function (fn) { this._onChange = fn; };
  130. /**
  131. * @param {?} fn
  132. * @return {?}
  133. */
  134. NgbInputDatepicker.prototype.registerOnTouched = /**
  135. * @param {?} fn
  136. * @return {?}
  137. */
  138. function (fn) { this._onTouched = fn; };
  139. /**
  140. * @param {?} fn
  141. * @return {?}
  142. */
  143. NgbInputDatepicker.prototype.registerOnValidatorChange = /**
  144. * @param {?} fn
  145. * @return {?}
  146. */
  147. function (fn) { this._validatorChange = fn; };
  148. /**
  149. * @param {?} isDisabled
  150. * @return {?}
  151. */
  152. NgbInputDatepicker.prototype.setDisabledState = /**
  153. * @param {?} isDisabled
  154. * @return {?}
  155. */
  156. function (isDisabled) { this.disabled = isDisabled; };
  157. /**
  158. * @param {?} c
  159. * @return {?}
  160. */
  161. NgbInputDatepicker.prototype.validate = /**
  162. * @param {?} c
  163. * @return {?}
  164. */
  165. function (c) {
  166. /** @type {?} */
  167. var value = c.value;
  168. if (value === null || value === undefined) {
  169. return null;
  170. }
  171. /** @type {?} */
  172. var ngbDate = this._fromDateStruct(this._dateAdapter.fromModel(value));
  173. if (!this._calendar.isValid(ngbDate)) {
  174. return { 'ngbDate': { invalid: c.value } };
  175. }
  176. if (this.minDate && ngbDate.before(NgbDate.from(this.minDate))) {
  177. return { 'ngbDate': { requiredBefore: this.minDate } };
  178. }
  179. if (this.maxDate && ngbDate.after(NgbDate.from(this.maxDate))) {
  180. return { 'ngbDate': { requiredAfter: this.maxDate } };
  181. }
  182. };
  183. /**
  184. * @param {?} value
  185. * @return {?}
  186. */
  187. NgbInputDatepicker.prototype.writeValue = /**
  188. * @param {?} value
  189. * @return {?}
  190. */
  191. function (value) {
  192. this._model = this._fromDateStruct(this._dateAdapter.fromModel(value));
  193. this._writeModelValue(this._model);
  194. };
  195. /**
  196. * @param {?} value
  197. * @param {?=} updateView
  198. * @return {?}
  199. */
  200. NgbInputDatepicker.prototype.manualDateChange = /**
  201. * @param {?} value
  202. * @param {?=} updateView
  203. * @return {?}
  204. */
  205. function (value, updateView) {
  206. if (updateView === void 0) { updateView = false; }
  207. /** @type {?} */
  208. var inputValueChanged = value !== this._inputValue;
  209. if (inputValueChanged) {
  210. this._inputValue = value;
  211. this._model = this._fromDateStruct(this._parserFormatter.parse(value));
  212. }
  213. if (inputValueChanged || !updateView) {
  214. this._onChange(this._model ? this._dateAdapter.toModel(this._model) : (value === '' ? null : value));
  215. }
  216. if (updateView && this._model) {
  217. this._writeModelValue(this._model);
  218. }
  219. };
  220. /**
  221. * @return {?}
  222. */
  223. NgbInputDatepicker.prototype.isOpen = /**
  224. * @return {?}
  225. */
  226. function () { return !!this._cRef; };
  227. /**
  228. * Opens the datepicker popup.
  229. *
  230. * If the related form control contains a valid date, the corresponding month will be opened.
  231. */
  232. /**
  233. * Opens the datepicker popup.
  234. *
  235. * If the related form control contains a valid date, the corresponding month will be opened.
  236. * @return {?}
  237. */
  238. NgbInputDatepicker.prototype.open = /**
  239. * Opens the datepicker popup.
  240. *
  241. * If the related form control contains a valid date, the corresponding month will be opened.
  242. * @return {?}
  243. */
  244. function () {
  245. var _this = this;
  246. if (!this.isOpen()) {
  247. /** @type {?} */
  248. var cf = this._cfr.resolveComponentFactory(NgbDatepicker);
  249. this._cRef = this._vcRef.createComponent(cf);
  250. this._applyPopupStyling(this._cRef.location.nativeElement);
  251. this._applyDatepickerInputs(this._cRef.instance);
  252. this._subscribeForDatepickerOutputs(this._cRef.instance);
  253. this._cRef.instance.ngOnInit();
  254. this._cRef.instance.writeValue(this._dateAdapter.toModel(this._model));
  255. // date selection event handling
  256. this._cRef.instance.registerOnChange((/**
  257. * @param {?} selectedDate
  258. * @return {?}
  259. */
  260. function (selectedDate) {
  261. _this.writeValue(selectedDate);
  262. _this._onChange(selectedDate);
  263. _this._onTouched();
  264. }));
  265. this._cRef.changeDetectorRef.detectChanges();
  266. this._cRef.instance.setDisabledState(this.disabled);
  267. if (this.container === 'body') {
  268. window.document.querySelector(this.container).appendChild(this._cRef.location.nativeElement);
  269. }
  270. // focus handling
  271. this._elWithFocus = this._document.activeElement;
  272. ngbFocusTrap(this._ngZone, this._cRef.location.nativeElement, this.closed, true);
  273. this._cRef.instance.focus();
  274. ngbAutoClose(this._ngZone, this._document, this.autoClose, (/**
  275. * @return {?}
  276. */
  277. function () { return _this.close(); }), this.closed, [], [this._elRef.nativeElement, this._cRef.location.nativeElement]);
  278. }
  279. };
  280. /**
  281. * Closes the datepicker popup.
  282. */
  283. /**
  284. * Closes the datepicker popup.
  285. * @return {?}
  286. */
  287. NgbInputDatepicker.prototype.close = /**
  288. * Closes the datepicker popup.
  289. * @return {?}
  290. */
  291. function () {
  292. if (this.isOpen()) {
  293. this._vcRef.remove(this._vcRef.indexOf(this._cRef.hostView));
  294. this._cRef = null;
  295. this.closed.emit();
  296. this._changeDetector.markForCheck();
  297. // restore focus
  298. /** @type {?} */
  299. var elementToFocus = this._elWithFocus;
  300. if (isString(this.restoreFocus)) {
  301. elementToFocus = this._document.querySelector(this.restoreFocus);
  302. }
  303. else if (this.restoreFocus !== undefined) {
  304. elementToFocus = this.restoreFocus;
  305. }
  306. // in IE document.activeElement can contain an object without 'focus()' sometimes
  307. if (elementToFocus && elementToFocus['focus']) {
  308. elementToFocus.focus();
  309. }
  310. else {
  311. this._document.body.focus();
  312. }
  313. }
  314. };
  315. /**
  316. * Toggles the datepicker popup.
  317. */
  318. /**
  319. * Toggles the datepicker popup.
  320. * @return {?}
  321. */
  322. NgbInputDatepicker.prototype.toggle = /**
  323. * Toggles the datepicker popup.
  324. * @return {?}
  325. */
  326. function () {
  327. if (this.isOpen()) {
  328. this.close();
  329. }
  330. else {
  331. this.open();
  332. }
  333. };
  334. /**
  335. * Navigates to the provided date.
  336. *
  337. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  338. * If nothing or invalid date provided calendar will open current month.
  339. *
  340. * Use the `[startDate]` input as an alternative.
  341. */
  342. /**
  343. * Navigates to the provided date.
  344. *
  345. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  346. * If nothing or invalid date provided calendar will open current month.
  347. *
  348. * Use the `[startDate]` input as an alternative.
  349. * @param {?=} date
  350. * @return {?}
  351. */
  352. NgbInputDatepicker.prototype.navigateTo = /**
  353. * Navigates to the provided date.
  354. *
  355. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  356. * If nothing or invalid date provided calendar will open current month.
  357. *
  358. * Use the `[startDate]` input as an alternative.
  359. * @param {?=} date
  360. * @return {?}
  361. */
  362. function (date) {
  363. if (this.isOpen()) {
  364. this._cRef.instance.navigateTo(date);
  365. }
  366. };
  367. /**
  368. * @return {?}
  369. */
  370. NgbInputDatepicker.prototype.onBlur = /**
  371. * @return {?}
  372. */
  373. function () { this._onTouched(); };
  374. /**
  375. * @return {?}
  376. */
  377. NgbInputDatepicker.prototype.onFocus = /**
  378. * @return {?}
  379. */
  380. function () { this._elWithFocus = this._elRef.nativeElement; };
  381. /**
  382. * @param {?} changes
  383. * @return {?}
  384. */
  385. NgbInputDatepicker.prototype.ngOnChanges = /**
  386. * @param {?} changes
  387. * @return {?}
  388. */
  389. function (changes) {
  390. if (changes['minDate'] || changes['maxDate']) {
  391. this._validatorChange();
  392. if (this.isOpen()) {
  393. if (changes['minDate']) {
  394. this._cRef.instance.minDate = this._dateAdapter.toModel(changes.minDate.currentValue);
  395. }
  396. if (changes['maxDate']) {
  397. this._cRef.instance.maxDate = this._dateAdapter.toModel(changes.maxDate.currentValue);
  398. }
  399. this._cRef.instance.ngOnChanges(changes);
  400. }
  401. }
  402. };
  403. /**
  404. * @return {?}
  405. */
  406. NgbInputDatepicker.prototype.ngOnDestroy = /**
  407. * @return {?}
  408. */
  409. function () {
  410. this.close();
  411. this._zoneSubscription.unsubscribe();
  412. };
  413. /**
  414. * @private
  415. * @param {?} datepickerInstance
  416. * @return {?}
  417. */
  418. NgbInputDatepicker.prototype._applyDatepickerInputs = /**
  419. * @private
  420. * @param {?} datepickerInstance
  421. * @return {?}
  422. */
  423. function (datepickerInstance) {
  424. var _this = this;
  425. ['dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate',
  426. 'maxDate', 'navigation', 'outsideDays', 'showNavigation', 'showWeekdays', 'showWeekNumbers']
  427. .forEach((/**
  428. * @param {?} optionName
  429. * @return {?}
  430. */
  431. function (optionName) {
  432. if (_this[optionName] !== undefined) {
  433. datepickerInstance[optionName] = _this[optionName];
  434. }
  435. }));
  436. datepickerInstance.startDate = this.startDate || this._model;
  437. };
  438. /**
  439. * @private
  440. * @param {?} nativeElement
  441. * @return {?}
  442. */
  443. NgbInputDatepicker.prototype._applyPopupStyling = /**
  444. * @private
  445. * @param {?} nativeElement
  446. * @return {?}
  447. */
  448. function (nativeElement) {
  449. this._renderer.addClass(nativeElement, 'dropdown-menu');
  450. this._renderer.addClass(nativeElement, 'show');
  451. if (this.container === 'body') {
  452. this._renderer.addClass(nativeElement, 'ngb-dp-body');
  453. }
  454. };
  455. /**
  456. * @private
  457. * @param {?} datepickerInstance
  458. * @return {?}
  459. */
  460. NgbInputDatepicker.prototype._subscribeForDatepickerOutputs = /**
  461. * @private
  462. * @param {?} datepickerInstance
  463. * @return {?}
  464. */
  465. function (datepickerInstance) {
  466. var _this = this;
  467. datepickerInstance.navigate.subscribe((/**
  468. * @param {?} navigateEvent
  469. * @return {?}
  470. */
  471. function (navigateEvent) { return _this.navigate.emit(navigateEvent); }));
  472. datepickerInstance.dateSelect.subscribe((/**
  473. * @param {?} date
  474. * @return {?}
  475. */
  476. function (date) {
  477. _this.dateSelect.emit(date);
  478. if (_this.autoClose === true || _this.autoClose === 'inside') {
  479. _this.close();
  480. }
  481. }));
  482. };
  483. /**
  484. * @private
  485. * @param {?} model
  486. * @return {?}
  487. */
  488. NgbInputDatepicker.prototype._writeModelValue = /**
  489. * @private
  490. * @param {?} model
  491. * @return {?}
  492. */
  493. function (model) {
  494. /** @type {?} */
  495. var value = this._parserFormatter.format(model);
  496. this._inputValue = value;
  497. this._renderer.setProperty(this._elRef.nativeElement, 'value', value);
  498. if (this.isOpen()) {
  499. this._cRef.instance.writeValue(this._dateAdapter.toModel(model));
  500. this._onTouched();
  501. }
  502. };
  503. /**
  504. * @private
  505. * @param {?} date
  506. * @return {?}
  507. */
  508. NgbInputDatepicker.prototype._fromDateStruct = /**
  509. * @private
  510. * @param {?} date
  511. * @return {?}
  512. */
  513. function (date) {
  514. /** @type {?} */
  515. var ngbDate = date ? new NgbDate(date.year, date.month, date.day) : null;
  516. return this._calendar.isValid(ngbDate) ? ngbDate : null;
  517. };
  518. /**
  519. * @private
  520. * @return {?}
  521. */
  522. NgbInputDatepicker.prototype._updatePopupPosition = /**
  523. * @private
  524. * @return {?}
  525. */
  526. function () {
  527. if (!this._cRef) {
  528. return;
  529. }
  530. /** @type {?} */
  531. var hostElement;
  532. if (isString(this.positionTarget)) {
  533. hostElement = this._document.querySelector(this.positionTarget);
  534. }
  535. else if (this.positionTarget instanceof HTMLElement) {
  536. hostElement = this.positionTarget;
  537. }
  538. else {
  539. hostElement = this._elRef.nativeElement;
  540. }
  541. if (this.positionTarget && !hostElement) {
  542. throw new Error('ngbDatepicker could not find element declared in [positionTarget] to position against.');
  543. }
  544. positionElements(hostElement, this._cRef.location.nativeElement, this.placement, this.container === 'body');
  545. };
  546. NgbInputDatepicker.decorators = [
  547. { type: Directive, args: [{
  548. selector: 'input[ngbDatepicker]',
  549. exportAs: 'ngbDatepicker',
  550. host: {
  551. '(input)': 'manualDateChange($event.target.value)',
  552. '(change)': 'manualDateChange($event.target.value, true)',
  553. '(focus)': 'onFocus()',
  554. '(blur)': 'onBlur()',
  555. '[disabled]': 'disabled'
  556. },
  557. providers: [
  558. NGB_DATEPICKER_VALUE_ACCESSOR, NGB_DATEPICKER_VALIDATOR,
  559. { provide: NgbDatepickerConfig, useExisting: NgbInputDatepickerConfig }
  560. ],
  561. },] }
  562. ];
  563. /** @nocollapse */
  564. NgbInputDatepicker.ctorParameters = function () { return [
  565. { type: NgbDateParserFormatter },
  566. { type: ElementRef },
  567. { type: ViewContainerRef },
  568. { type: Renderer2 },
  569. { type: ComponentFactoryResolver },
  570. { type: NgZone },
  571. { type: NgbCalendar },
  572. { type: NgbDateAdapter },
  573. { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
  574. { type: ChangeDetectorRef },
  575. { type: NgbInputDatepickerConfig }
  576. ]; };
  577. NgbInputDatepicker.propDecorators = {
  578. autoClose: [{ type: Input }],
  579. dayTemplate: [{ type: Input }],
  580. dayTemplateData: [{ type: Input }],
  581. displayMonths: [{ type: Input }],
  582. firstDayOfWeek: [{ type: Input }],
  583. footerTemplate: [{ type: Input }],
  584. markDisabled: [{ type: Input }],
  585. minDate: [{ type: Input }],
  586. maxDate: [{ type: Input }],
  587. navigation: [{ type: Input }],
  588. outsideDays: [{ type: Input }],
  589. placement: [{ type: Input }],
  590. restoreFocus: [{ type: Input }],
  591. showWeekdays: [{ type: Input }],
  592. showWeekNumbers: [{ type: Input }],
  593. startDate: [{ type: Input }],
  594. container: [{ type: Input }],
  595. positionTarget: [{ type: Input }],
  596. dateSelect: [{ type: Output }],
  597. navigate: [{ type: Output }],
  598. closed: [{ type: Output }],
  599. disabled: [{ type: Input }]
  600. };
  601. return NgbInputDatepicker;
  602. }());
  603. export { NgbInputDatepicker };
  604. if (false) {
  605. /**
  606. * @type {?}
  607. * @private
  608. */
  609. NgbInputDatepicker.prototype._cRef;
  610. /**
  611. * @type {?}
  612. * @private
  613. */
  614. NgbInputDatepicker.prototype._disabled;
  615. /**
  616. * @type {?}
  617. * @private
  618. */
  619. NgbInputDatepicker.prototype._elWithFocus;
  620. /**
  621. * @type {?}
  622. * @private
  623. */
  624. NgbInputDatepicker.prototype._model;
  625. /**
  626. * @type {?}
  627. * @private
  628. */
  629. NgbInputDatepicker.prototype._inputValue;
  630. /**
  631. * @type {?}
  632. * @private
  633. */
  634. NgbInputDatepicker.prototype._zoneSubscription;
  635. /**
  636. * Indicates whether the datepicker popup should be closed automatically after date selection / outside click or not.
  637. *
  638. * * `true` - the popup will close on both date selection and outside click.
  639. * * `false` - the popup can only be closed manually via `close()` or `toggle()` methods.
  640. * * `"inside"` - the popup will close on date selection, but not outside clicks.
  641. * * `"outside"` - the popup will close only on the outside click and not on date selection/inside clicks.
  642. *
  643. * \@since 3.0.0
  644. * @type {?}
  645. */
  646. NgbInputDatepicker.prototype.autoClose;
  647. /**
  648. * The reference to a custom template for the day.
  649. *
  650. * Allows to completely override the way a day 'cell' in the calendar is displayed.
  651. *
  652. * See [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext) for the data you get inside.
  653. * @type {?}
  654. */
  655. NgbInputDatepicker.prototype.dayTemplate;
  656. /**
  657. * The callback to pass any arbitrary data to the template cell via the
  658. * [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext)'s `data` parameter.
  659. *
  660. * `current` is the month that is currently displayed by the datepicker.
  661. *
  662. * \@since 3.3.0
  663. * @type {?}
  664. */
  665. NgbInputDatepicker.prototype.dayTemplateData;
  666. /**
  667. * The number of months to display.
  668. * @type {?}
  669. */
  670. NgbInputDatepicker.prototype.displayMonths;
  671. /**
  672. * The first day of the week.
  673. *
  674. * With default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun.
  675. * @type {?}
  676. */
  677. NgbInputDatepicker.prototype.firstDayOfWeek;
  678. /**
  679. * The reference to the custom template for the datepicker footer.
  680. *
  681. * \@since 3.3.0
  682. * @type {?}
  683. */
  684. NgbInputDatepicker.prototype.footerTemplate;
  685. /**
  686. * The callback to mark some dates as disabled.
  687. *
  688. * It is called for each new date when navigating to a different month.
  689. *
  690. * `current` is the month that is currently displayed by the datepicker.
  691. * @type {?}
  692. */
  693. NgbInputDatepicker.prototype.markDisabled;
  694. /**
  695. * The earliest date that can be displayed or selected. Also used for form validation.
  696. *
  697. * If not provided, 'year' select box will display 10 years before the current month.
  698. * @type {?}
  699. */
  700. NgbInputDatepicker.prototype.minDate;
  701. /**
  702. * The latest date that can be displayed or selected. Also used for form validation.
  703. *
  704. * If not provided, 'year' select box will display 10 years after the current month.
  705. * @type {?}
  706. */
  707. NgbInputDatepicker.prototype.maxDate;
  708. /**
  709. * Navigation type.
  710. *
  711. * * `"select"` - select boxes for month and navigation arrows
  712. * * `"arrows"` - only navigation arrows
  713. * * `"none"` - no navigation visible at all
  714. * @type {?}
  715. */
  716. NgbInputDatepicker.prototype.navigation;
  717. /**
  718. * The way of displaying days that don't belong to the current month.
  719. *
  720. * * `"visible"` - days are visible
  721. * * `"hidden"` - days are hidden, white space preserved
  722. * * `"collapsed"` - days are collapsed, so the datepicker height might change between months
  723. *
  724. * For the 2+ months view, days in between months are never shown.
  725. * @type {?}
  726. */
  727. NgbInputDatepicker.prototype.outsideDays;
  728. /**
  729. * The preferred placement of the datepicker popup.
  730. *
  731. * Possible values are `"top"`, `"top-left"`, `"top-right"`, `"bottom"`, `"bottom-left"`,
  732. * `"bottom-right"`, `"left"`, `"left-top"`, `"left-bottom"`, `"right"`, `"right-top"`,
  733. * `"right-bottom"`
  734. *
  735. * Accepts an array of strings or a string with space separated possible values.
  736. *
  737. * The default order of preference is `"bottom-left bottom-right top-left top-right"`
  738. *
  739. * Please see the [positioning overview](#/positioning) for more details.
  740. * @type {?}
  741. */
  742. NgbInputDatepicker.prototype.placement;
  743. /**
  744. * If `true`, when closing datepicker will focus element that was focused before datepicker was opened.
  745. *
  746. * Alternatively you could provide a selector or an `HTMLElement` to focus. If the element doesn't exist or invalid,
  747. * we'll fallback to focus document body.
  748. *
  749. * \@since 5.2.0
  750. * @type {?}
  751. */
  752. NgbInputDatepicker.prototype.restoreFocus;
  753. /**
  754. * If `true`, weekdays will be displayed.
  755. * @type {?}
  756. */
  757. NgbInputDatepicker.prototype.showWeekdays;
  758. /**
  759. * If `true`, week numbers will be displayed.
  760. * @type {?}
  761. */
  762. NgbInputDatepicker.prototype.showWeekNumbers;
  763. /**
  764. * The date to open calendar with.
  765. *
  766. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  767. * If nothing or invalid date is provided, calendar will open with current month.
  768. *
  769. * You could use `navigateTo(date)` method as an alternative.
  770. * @type {?}
  771. */
  772. NgbInputDatepicker.prototype.startDate;
  773. /**
  774. * A selector specifying the element the datepicker popup should be appended to.
  775. *
  776. * Currently only supports `"body"`.
  777. * @type {?}
  778. */
  779. NgbInputDatepicker.prototype.container;
  780. /**
  781. * A css selector or html element specifying the element the datepicker popup should be positioned against.
  782. *
  783. * By default the input is used as a target.
  784. *
  785. * \@since 4.2.0
  786. * @type {?}
  787. */
  788. NgbInputDatepicker.prototype.positionTarget;
  789. /**
  790. * An event emitted when user selects a date using keyboard or mouse.
  791. *
  792. * The payload of the event is currently selected `NgbDate`.
  793. *
  794. * \@since 1.1.1
  795. * @type {?}
  796. */
  797. NgbInputDatepicker.prototype.dateSelect;
  798. /**
  799. * Event emitted right after the navigation happens and displayed month changes.
  800. *
  801. * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.
  802. * @type {?}
  803. */
  804. NgbInputDatepicker.prototype.navigate;
  805. /**
  806. * An event fired after closing datepicker window.
  807. *
  808. * \@since 4.2.0
  809. * @type {?}
  810. */
  811. NgbInputDatepicker.prototype.closed;
  812. /**
  813. * @type {?}
  814. * @private
  815. */
  816. NgbInputDatepicker.prototype._onChange;
  817. /**
  818. * @type {?}
  819. * @private
  820. */
  821. NgbInputDatepicker.prototype._onTouched;
  822. /**
  823. * @type {?}
  824. * @private
  825. */
  826. NgbInputDatepicker.prototype._validatorChange;
  827. /**
  828. * @type {?}
  829. * @private
  830. */
  831. NgbInputDatepicker.prototype._parserFormatter;
  832. /**
  833. * @type {?}
  834. * @private
  835. */
  836. NgbInputDatepicker.prototype._elRef;
  837. /**
  838. * @type {?}
  839. * @private
  840. */
  841. NgbInputDatepicker.prototype._vcRef;
  842. /**
  843. * @type {?}
  844. * @private
  845. */
  846. NgbInputDatepicker.prototype._renderer;
  847. /**
  848. * @type {?}
  849. * @private
  850. */
  851. NgbInputDatepicker.prototype._cfr;
  852. /**
  853. * @type {?}
  854. * @private
  855. */
  856. NgbInputDatepicker.prototype._ngZone;
  857. /**
  858. * @type {?}
  859. * @private
  860. */
  861. NgbInputDatepicker.prototype._calendar;
  862. /**
  863. * @type {?}
  864. * @private
  865. */
  866. NgbInputDatepicker.prototype._dateAdapter;
  867. /**
  868. * @type {?}
  869. * @private
  870. */
  871. NgbInputDatepicker.prototype._document;
  872. /**
  873. * @type {?}
  874. * @private
  875. */
  876. NgbInputDatepicker.prototype._changeDetector;
  877. }
  878. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["datepicker/datepicker-input.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,iBAAiB,EACjB,wBAAwB,EAExB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EAGN,MAAM,EACN,SAAS,EAET,WAAW,EACX,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAwC,aAAa,EAAE,iBAAiB,EAAY,MAAM,gBAAgB,CAAC;AAElH,OAAO,EAAC,YAAY,EAAC,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAC,YAAY,EAAC,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAiB,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AAErE,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAC,aAAa,EAA6B,MAAM,cAAc,CAAC;AAEvE,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,OAAO,EAAC,MAAM,YAAY,CAAC;AACnC,OAAO,EAAC,sBAAsB,EAAC,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EAAC,wBAAwB,EAAC,MAAM,2BAA2B,CAAC;AACnE,OAAO,EAAC,mBAAmB,EAAC,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAC,QAAQ,EAAC,MAAM,cAAc,CAAC;;IAEhC,6BAA6B,GAAG;IACpC,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU;;;IAAC,cAAM,OAAA,kBAAkB,EAAlB,CAAkB,EAAC;IACjD,KAAK,EAAE,IAAI;CACZ;;IAEK,wBAAwB,GAAG;IAC/B,OAAO,EAAE,aAAa;IACtB,WAAW,EAAE,UAAU;;;IAAC,cAAM,OAAA,kBAAkB,EAAlB,CAAkB,EAAC;IACjD,KAAK,EAAE,IAAI;CACZ;;;;;;AAOD;IA0NE,4BACY,gBAAwC,EAAU,MAAoC,EACtF,MAAwB,EAAU,SAAoB,EAAU,IAA8B,EAC9F,OAAe,EAAU,SAAsB,EAAU,YAAiC,EACxE,SAAc,EAAU,eAAkC,EACpF,MAAgC;QALpC,iBAQC;QAPW,qBAAgB,GAAhB,gBAAgB,CAAwB;QAAU,WAAM,GAAN,MAAM,CAA8B;QACtF,WAAM,GAAN,MAAM,CAAkB;QAAU,cAAS,GAAT,SAAS,CAAW;QAAU,SAAI,GAAJ,IAAI,CAA0B;QAC9F,YAAO,GAAP,OAAO,CAAQ;QAAU,cAAS,GAAT,SAAS,CAAa;QAAU,iBAAY,GAAZ,YAAY,CAAqB;QACxE,cAAS,GAAT,SAAS,CAAK;QAAU,oBAAe,GAAf,eAAe,CAAmB;QA7MhF,UAAK,GAAgC,IAAI,CAAC;QAC1C,cAAS,GAAG,KAAK,CAAC;QAClB,iBAAY,GAAG,IAAI,CAAC;;;;;;;;QAsKlB,eAAU,GAAG,IAAI,YAAY,EAAW,CAAC;;;;;;QAOzC,aAAQ,GAAG,IAAI,YAAY,EAA8B,CAAC;;;;;;QAO1D,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAcpC,cAAS;;;;QAAG,UAAC,CAAM,IAAM,CAAC,EAAC;QAC3B,eAAU;;;QAAG,cAAO,CAAC,EAAC;QACtB,qBAAgB;;;QAAG,cAAO,CAAC,EAAC;QASlC,CAAC,WAAW,EAAE,WAAW,EAAE,gBAAgB,EAAE,WAAW,CAAC,CAAC,OAAO;;;;QAAC,UAAA,KAAK,IAAI,OAAA,KAAI,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,EAA3B,CAA2B,EAAC,CAAC;QACxG,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS;;;QAAC,cAAM,OAAA,KAAI,CAAC,oBAAoB,EAAE,EAA3B,CAA2B,EAAC,CAAC;IACzF,CAAC;IAzBD,sBACI,wCAAQ;;;;QADZ;YAEE,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;;;;;QACD,UAAa,KAAU;YACrB,IAAI,CAAC,SAAS,GAAG,KAAK,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,KAAK,KAAK,OAAO,CAAC,CAAC;YAE9D,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;gBACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACtD;QACH,CAAC;;;OAPA;;;;;IAwBD,6CAAgB;;;;IAAhB,UAAiB,EAAuB,IAAU,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC;;;;;IAExE,8CAAiB;;;;IAAjB,UAAkB,EAAa,IAAU,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC,CAAC,CAAC;;;;;IAEhE,sDAAyB;;;;IAAzB,UAA0B,EAAc,IAAU,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC,CAAC,CAAC;;;;;IAE/E,6CAAgB;;;;IAAhB,UAAiB,UAAmB,IAAU,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,CAAC,CAAC;;;;;IAE3E,qCAAQ;;;;IAAR,UAAS,CAAkB;;YACnB,KAAK,GAAG,CAAC,CAAC,KAAK;QAErB,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;YACzC,OAAO,IAAI,CAAC;SACb;;YAEK,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAExE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACpC,OAAO,EAAC,SAAS,EAAE,EAAC,OAAO,EAAE,CAAC,CAAC,KAAK,EAAC,EAAC,CAAC;SACxC;QAED,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE;YAC9D,OAAO,EAAC,SAAS,EAAE,EAAC,cAAc,EAAE,IAAI,CAAC,OAAO,EAAC,EAAC,CAAC;SACpD;QAED,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE;YAC7D,OAAO,EAAC,SAAS,EAAE,EAAC,aAAa,EAAE,IAAI,CAAC,OAAO,EAAC,EAAC,CAAC;SACnD;IACH,CAAC;;;;;IAED,uCAAU;;;;IAAV,UAAW,KAAK;QACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;;;;;;IAED,6CAAgB;;;;;IAAhB,UAAiB,KAAa,EAAE,UAAkB;QAAlB,2BAAA,EAAA,kBAAkB;;YAC1C,iBAAiB,GAAG,KAAK,KAAK,IAAI,CAAC,WAAW;QACpD,IAAI,iBAAiB,EAAE;YACrB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;SACxE;QACD,IAAI,iBAAiB,IAAI,CAAC,UAAU,EAAE;YACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SACtG;QACD,IAAI,UAAU,IAAI,IAAI,CAAC,MAAM,EAAE;YAC7B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACpC;IACH,CAAC;;;;IAED,mCAAM;;;IAAN,cAAW,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAEjC;;;;OAIG;;;;;;;IACH,iCAAI;;;;;;IAAJ;QAAA,iBAmCC;QAlCC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE;;gBACZ,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC;YAC3D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;YAE7C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;YAC3D,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACjD,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACzD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAEvE,gCAAgC;YAChC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB;;;;YAAC,UAAC,YAAY;gBAChD,KAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;gBAC9B,KAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;gBAC7B,KAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC,EAAC,CAAC;YAEH,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;YAE7C,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEpD,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;gBAC7B,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aAC9F;YAED,iBAAiB;YACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;YACjD,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACjF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YAE5B,YAAY,CACR,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS;;;YAAE,cAAM,OAAA,KAAI,CAAC,KAAK,EAAE,EAAZ,CAAY,GAAE,IAAI,CAAC,MAAM,EAAE,EAAE,EACjF,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC;SACrE;IACH,CAAC;IAED;;OAEG;;;;;IACH,kCAAK;;;;IAAL;QACE,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YACjB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC7D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACnB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;;;gBAGhC,cAAc,GAAG,IAAI,CAAC,YAAY;YACtC,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;gBAC/B,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aAClE;iBAAM,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS,EAAE;gBAC1C,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC;aACpC;YAED,iFAAiF;YACjF,IAAI,cAAc,IAAI,cAAc,CAAC,OAAO,CAAC,EAAE;gBAC7C,cAAc,CAAC,KAAK,EAAE,CAAC;aACxB;iBAAM;gBACL,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;aAC7B;SACF;IACH,CAAC;IAED;;OAEG;;;;;IACH,mCAAM;;;;IAAN;QACE,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YACjB,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;aAAM;YACL,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;IAED;;;;;;;OAOG;;;;;;;;;;;IACH,uCAAU;;;;;;;;;;IAAV,UAAW,IAAkD;QAC3D,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;SACtC;IACH,CAAC;;;;IAED,mCAAM;;;IAAN,cAAW,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;;;;IAE/B,oCAAO;;;IAAP,cAAY,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC;;;;;IAE5D,wCAAW;;;;IAAX,UAAY,OAAsB;QAChC,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;YAC5C,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAExB,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;gBACjB,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;oBACtB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;iBACvF;gBACD,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;oBACtB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;iBACvF;gBACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;aAC1C;SACF;IACH,CAAC;;;;IAED,wCAAW;;;IAAX;QACE,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE,CAAC;IACvC,CAAC;;;;;;IAEO,mDAAsB;;;;;IAA9B,UAA+B,kBAAiC;QAAhE,iBASC;QARC,CAAC,aAAa,EAAE,iBAAiB,EAAE,eAAe,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,cAAc,EAAE,SAAS;YAChH,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,cAAc,EAAE,iBAAiB,CAAC;aACxF,OAAO;;;;QAAC,UAAC,UAAkB;YAC1B,IAAI,KAAI,CAAC,UAAU,CAAC,KAAK,SAAS,EAAE;gBAClC,kBAAkB,CAAC,UAAU,CAAC,GAAG,KAAI,CAAC,UAAU,CAAC,CAAC;aACnD;QACH,CAAC,EAAC,CAAC;QACP,kBAAkB,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC;IAC/D,CAAC;;;;;;IAEO,+CAAkB;;;;;IAA1B,UAA2B,aAAkB;QAC3C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,eAAe,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QAE/C,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE;YAC7B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;SACvD;IACH,CAAC;;;;;;IAEO,2DAA8B;;;;;IAAtC,UAAuC,kBAAiC;QAAxE,iBAQC;QAPC,kBAAkB,CAAC,QAAQ,CAAC,SAAS;;;;QAAC,UAAA,aAAa,IAAI,OAAA,KAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,EAAjC,CAAiC,EAAC,CAAC;QAC1F,kBAAkB,CAAC,UAAU,CAAC,SAAS;;;;QAAC,UAAA,IAAI;YAC1C,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,KAAI,CAAC,SAAS,KAAK,IAAI,IAAI,KAAI,CAAC,SAAS,KAAK,QAAQ,EAAE;gBAC1D,KAAI,CAAC,KAAK,EAAE,CAAC;aACd;QACH,CAAC,EAAC,CAAC;IACL,CAAC;;;;;;IAEO,6CAAgB;;;;;IAAxB,UAAyB,KAAc;;YAC/B,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QACtE,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE;YACjB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;YACjE,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;;;;;;IAEO,4CAAe;;;;;IAAvB,UAAwB,IAAmB;;YACnC,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI;QAC1E,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1D,CAAC;;;;;IAEO,iDAAoB;;;;IAA5B;QACE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,OAAO;SACR;;YAEG,WAAwB;QAC5B,IAAI,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YACjC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACjE;aAAM,IAAI,IAAI,CAAC,cAAc,YAAY,WAAW,EAAE;YACrD,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC;SACnC;aAAM;YACL,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;SACzC;QAED,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,WAAW,EAAE;YACvC,MAAM,IAAI,KAAK,CAAC,wFAAwF,CAAC,CAAC;SAC3G;QAED,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,CAAC;IAC9G,CAAC;;gBA9cF,SAAS,SAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,QAAQ,EAAE,eAAe;oBACzB,IAAI,EAAE;wBACJ,SAAS,EAAE,uCAAuC;wBAClD,UAAU,EAAE,6CAA6C;wBACzD,SAAS,EAAE,WAAW;wBACtB,QAAQ,EAAE,UAAU;wBACpB,YAAY,EAAE,UAAU;qBACzB;oBACD,SAAS,EAAE;wBACT,6BAA6B,EAAE,wBAAwB;wBACvD,EAAC,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,wBAAwB,EAAC;qBACtE;iBACF;;;;gBArCO,sBAAsB;gBA1B5B,UAAU;gBAYV,gBAAgB;gBAHhB,SAAS;gBAZT,wBAAwB;gBAQxB,MAAM;gBAmBA,WAAW;gBAHX,cAAc;gDA0Pf,MAAM,SAAC,QAAQ;gBAnRpB,iBAAiB;gBAgCX,wBAAwB;;;4BAuD7B,KAAK;8BASL,KAAK;kCAUL,KAAK;gCAKL,KAAK;iCAOL,KAAK;iCAOL,KAAK;+BASL,KAAK;0BAOL,KAAK;0BAOL,KAAK;6BASL,KAAK;8BAWL,KAAK;4BAeL,KAAK;+BAUL,KAAK;+BAKL,KAAK;kCAKL,KAAK;4BAUL,KAAK;4BAOL,KAAK;iCASL,KAAK;6BASL,MAAM;2BAON,MAAM;yBAON,MAAM;2BAEN,KAAK;;IAsQR,yBAAC;CAAA,AA/cD,IA+cC;SAhcY,kBAAkB;;;;;;IAE7B,mCAAkD;;;;;IAClD,uCAA0B;;;;;IAC1B,0CAA4B;;;;;IAC5B,oCAAwB;;;;;IACxB,yCAA4B;;;;;IAC5B,+CAA+B;;;;;;;;;;;;IAY/B,uCAAmD;;;;;;;;;IASnD,yCAAsD;;;;;;;;;;IAUtD,6CAAyF;;;;;IAKzF,2CAA+B;;;;;;;IAO/B,4CAAgC;;;;;;;IAOhC,4CAA0C;;;;;;;;;IAS1C,0CAA0F;;;;;;;IAO1F,qCAAgC;;;;;;;IAOhC,qCAAgC;;;;;;;;;IAShC,wCAAkD;;;;;;;;;;;IAWlD,yCAAyD;;;;;;;;;;;;;;;IAezD,uCAAmC;;;;;;;;;;IAUnC,0CAAmD;;;;;IAKnD,0CAA+B;;;;;IAK/B,6CAAkC;;;;;;;;;;IAUlC,uCAAgE;;;;;;;IAOhE,uCAA2B;;;;;;;;;IAS3B,4CAA8C;;;;;;;;;IAS9C,wCAAmD;;;;;;;IAOnD,sCAAoE;;;;;;;IAOpE,oCAA4C;;;;;IAc5C,uCAAmC;;;;;IACnC,wCAA8B;;;;;IAC9B,8CAAoC;;;;;IAIhC,8CAAgD;;;;;IAAE,oCAA4C;;;;;IAC9F,oCAAgC;;;;;IAAE,uCAA4B;;;;;IAAE,kCAAsC;;;;;IACtG,qCAAuB;;;;;IAAE,uCAA8B;;;;;IAAE,0CAAyC;;;;;IAClG,uCAAwC;;;;;IAAE,6CAA0C","sourcesContent":["import {\n  ChangeDetectorRef,\n  ComponentFactoryResolver,\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport {DOCUMENT} from '@angular/common';\nimport {AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, Validator} from '@angular/forms';\n\nimport {ngbAutoClose} from '../util/autoclose';\nimport {ngbFocusTrap} from '../util/focus-trap';\nimport {PlacementArray, positionElements} from '../util/positioning';\n\nimport {NgbDateAdapter} from './adapters/ngb-date-adapter';\nimport {NgbDatepicker, NgbDatepickerNavigateEvent} from './datepicker';\nimport {DayTemplateContext} from './datepicker-day-template-context';\nimport {NgbCalendar} from './ngb-calendar';\nimport {NgbDate} from './ngb-date';\nimport {NgbDateParserFormatter} from './ngb-date-parser-formatter';\nimport {NgbDateStruct} from './ngb-date-struct';\nimport {NgbInputDatepickerConfig} from './datepicker-input-config';\nimport {NgbDatepickerConfig} from './datepicker-config';\nimport {isString} from '../util/util';\n\nconst NGB_DATEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => NgbInputDatepicker),\n  multi: true\n};\n\nconst NGB_DATEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => NgbInputDatepicker),\n  multi: true\n};\n\n/**\n * A directive that allows to stick a datepicker popup to an input field.\n *\n * Manages interaction with the input field itself, does value formatting and provides forms integration.\n */\n@Directive({\n  selector: 'input[ngbDatepicker]',\n  exportAs: 'ngbDatepicker',\n  host: {\n    '(input)': 'manualDateChange($event.target.value)',\n    '(change)': 'manualDateChange($event.target.value, true)',\n    '(focus)': 'onFocus()',\n    '(blur)': 'onBlur()',\n    '[disabled]': 'disabled'\n  },\n  providers: [\n    NGB_DATEPICKER_VALUE_ACCESSOR, NGB_DATEPICKER_VALIDATOR,\n    {provide: NgbDatepickerConfig, useExisting: NgbInputDatepickerConfig}\n  ],\n})\nexport class NgbInputDatepicker implements OnChanges,\n    OnDestroy, ControlValueAccessor, Validator {\n  private _cRef: ComponentRef<NgbDatepicker> = null;\n  private _disabled = false;\n  private _elWithFocus = null;\n  private _model: NgbDate;\n  private _inputValue: string;\n  private _zoneSubscription: any;\n\n  /**\n   * Indicates whether the datepicker popup should be closed automatically after date selection / outside click or not.\n   *\n   * * `true` - the popup will close on both date selection and outside click.\n   * * `false` - the popup can only be closed manually via `close()` or `toggle()` methods.\n   * * `\"inside\"` - the popup will close on date selection, but not outside clicks.\n   * * `\"outside\"` - the popup will close only on the outside click and not on date selection/inside clicks.\n   *\n   * @since 3.0.0\n   */\n  @Input() autoClose: boolean | 'inside' | 'outside';\n\n  /**\n   * The reference to a custom template for the day.\n   *\n   * Allows to completely override the way a day 'cell' in the calendar is displayed.\n   *\n   * See [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext) for the data you get inside.\n   */\n  @Input() dayTemplate: TemplateRef<DayTemplateContext>;\n\n  /**\n   * The callback to pass any arbitrary data to the template cell via the\n   * [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext)'s `data` parameter.\n   *\n   * `current` is the month that is currently displayed by the datepicker.\n   *\n   * @since 3.3.0\n   */\n  @Input() dayTemplateData: (date: NgbDate, current: {year: number, month: number}) => any;\n\n  /**\n   * The number of months to display.\n   */\n  @Input() displayMonths: number;\n\n  /**\n   * The first day of the week.\n   *\n   * With default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun.\n   */\n  @Input() firstDayOfWeek: number;\n\n  /**\n   * The reference to the custom template for the datepicker footer.\n   *\n   * @since 3.3.0\n   */\n  @Input() footerTemplate: TemplateRef<any>;\n\n  /**\n   * The callback to mark some dates as disabled.\n   *\n   * It is called for each new date when navigating to a different month.\n   *\n   * `current` is the month that is currently displayed by the datepicker.\n   */\n  @Input() markDisabled: (date: NgbDate, current: {year: number, month: number}) => boolean;\n\n  /**\n   * The earliest date that can be displayed or selected. Also used for form validation.\n   *\n   * If not provided, 'year' select box will display 10 years before the current month.\n   */\n  @Input() minDate: NgbDateStruct;\n\n  /**\n   * The latest date that can be displayed or selected. Also used for form validation.\n   *\n   * If not provided, 'year' select box will display 10 years after the current month.\n   */\n  @Input() maxDate: NgbDateStruct;\n\n  /**\n   * Navigation type.\n   *\n   * * `\"select\"` - select boxes for month and navigation arrows\n   * * `\"arrows\"` - only navigation arrows\n   * * `\"none\"` - no navigation visible at all\n   */\n  @Input() navigation: 'select' | 'arrows' | 'none';\n\n  /**\n   * The way of displaying days that don't belong to the current month.\n   *\n   * * `\"visible\"` - days are visible\n   * * `\"hidden\"` - days are hidden, white space preserved\n   * * `\"collapsed\"` - days are collapsed, so the datepicker height might change between months\n   *\n   * For the 2+ months view, days in between months are never shown.\n   */\n  @Input() outsideDays: 'visible' | 'collapsed' | 'hidden';\n\n  /**\n   * The preferred placement of the datepicker popup.\n   *\n   * Possible values are `\"top\"`, `\"top-left\"`, `\"top-right\"`, `\"bottom\"`, `\"bottom-left\"`,\n   * `\"bottom-right\"`, `\"left\"`, `\"left-top\"`, `\"left-bottom\"`, `\"right\"`, `\"right-top\"`,\n   * `\"right-bottom\"`\n   *\n   * Accepts an array of strings or a string with space separated possible values.\n   *\n   * The default order of preference is `\"bottom-left bottom-right top-left top-right\"`\n   *\n   * Please see the [positioning overview](#/positioning) for more details.\n   */\n  @Input() placement: PlacementArray;\n\n  /**\n   * If `true`, when closing datepicker will focus element that was focused before datepicker was opened.\n   *\n   * Alternatively you could provide a selector or an `HTMLElement` to focus. If the element doesn't exist or invalid,\n   * we'll fallback to focus document body.\n   *\n   * @since 5.2.0\n   */\n  @Input() restoreFocus: true | string | HTMLElement;\n\n  /**\n   * If `true`, weekdays will be displayed.\n   */\n  @Input() showWeekdays: boolean;\n\n  /**\n   * If `true`, week numbers will be displayed.\n   */\n  @Input() showWeekNumbers: boolean;\n\n  /**\n   * The date to open calendar with.\n   *\n   * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.\n   * If nothing or invalid date is provided, calendar will open with current month.\n   *\n   * You could use `navigateTo(date)` method as an alternative.\n   */\n  @Input() startDate: {year: number, month: number, day?: number};\n\n  /**\n   * A selector specifying the element the datepicker popup should be appended to.\n   *\n   * Currently only supports `\"body\"`.\n   */\n  @Input() container: string;\n\n  /**\n   * A css selector or html element specifying the element the datepicker popup should be positioned against.\n   *\n   * By default the input is used as a target.\n   *\n   * @since 4.2.0\n   */\n  @Input() positionTarget: string | HTMLElement;\n\n  /**\n   * An event emitted when user selects a date using keyboard or mouse.\n   *\n   * The payload of the event is currently selected `NgbDate`.\n   *\n   * @since 1.1.1\n   */\n  @Output() dateSelect = new EventEmitter<NgbDate>();\n\n  /**\n   * Event emitted right after the navigation happens and displayed month changes.\n   *\n   * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.\n   */\n  @Output() navigate = new EventEmitter<NgbDatepickerNavigateEvent>();\n\n  /**\n   * An event fired after closing datepicker window.\n   *\n   * @since 4.2.0\n   */\n  @Output() closed = new EventEmitter<void>();\n\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n  set disabled(value: any) {\n    this._disabled = value === '' || (value && value !== 'false');\n\n    if (this.isOpen()) {\n      this._cRef.instance.setDisabledState(this._disabled);\n    }\n  }\n\n  private _onChange = (_: any) => {};\n  private _onTouched = () => {};\n  private _validatorChange = () => {};\n\n\n  constructor(\n      private _parserFormatter: NgbDateParserFormatter, private _elRef: ElementRef<HTMLInputElement>,\n      private _vcRef: ViewContainerRef, private _renderer: Renderer2, private _cfr: ComponentFactoryResolver,\n      private _ngZone: NgZone, private _calendar: NgbCalendar, private _dateAdapter: NgbDateAdapter<any>,\n      @Inject(DOCUMENT) private _document: any, private _changeDetector: ChangeDetectorRef,\n      config: NgbInputDatepickerConfig) {\n    ['autoClose', 'container', 'positionTarget', 'placement'].forEach(input => this[input] = config[input]);\n    this._zoneSubscription = _ngZone.onStable.subscribe(() => this._updatePopupPosition());\n  }\n\n  registerOnChange(fn: (value: any) => any): void { this._onChange = fn; }\n\n  registerOnTouched(fn: () => any): void { this._onTouched = fn; }\n\n  registerOnValidatorChange(fn: () => void): void { this._validatorChange = fn; }\n\n  setDisabledState(isDisabled: boolean): void { this.disabled = isDisabled; }\n\n  validate(c: AbstractControl): {[key: string]: any} {\n    const value = c.value;\n\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    const ngbDate = this._fromDateStruct(this._dateAdapter.fromModel(value));\n\n    if (!this._calendar.isValid(ngbDate)) {\n      return {'ngbDate': {invalid: c.value}};\n    }\n\n    if (this.minDate && ngbDate.before(NgbDate.from(this.minDate))) {\n      return {'ngbDate': {requiredBefore: this.minDate}};\n    }\n\n    if (this.maxDate && ngbDate.after(NgbDate.from(this.maxDate))) {\n      return {'ngbDate': {requiredAfter: this.maxDate}};\n    }\n  }\n\n  writeValue(value) {\n    this._model = this._fromDateStruct(this._dateAdapter.fromModel(value));\n    this._writeModelValue(this._model);\n  }\n\n  manualDateChange(value: string, updateView = false) {\n    const inputValueChanged = value !== this._inputValue;\n    if (inputValueChanged) {\n      this._inputValue = value;\n      this._model = this._fromDateStruct(this._parserFormatter.parse(value));\n    }\n    if (inputValueChanged || !updateView) {\n      this._onChange(this._model ? this._dateAdapter.toModel(this._model) : (value === '' ? null : value));\n    }\n    if (updateView && this._model) {\n      this._writeModelValue(this._model);\n    }\n  }\n\n  isOpen() { return !!this._cRef; }\n\n  /**\n   * Opens the datepicker popup.\n   *\n   * If the related form control contains a valid date, the corresponding month will be opened.\n   */\n  open() {\n    if (!this.isOpen()) {\n      const cf = this._cfr.resolveComponentFactory(NgbDatepicker);\n      this._cRef = this._vcRef.createComponent(cf);\n\n      this._applyPopupStyling(this._cRef.location.nativeElement);\n      this._applyDatepickerInputs(this._cRef.instance);\n      this._subscribeForDatepickerOutputs(this._cRef.instance);\n      this._cRef.instance.ngOnInit();\n      this._cRef.instance.writeValue(this._dateAdapter.toModel(this._model));\n\n      // date selection event handling\n      this._cRef.instance.registerOnChange((selectedDate) => {\n        this.writeValue(selectedDate);\n        this._onChange(selectedDate);\n        this._onTouched();\n      });\n\n      this._cRef.changeDetectorRef.detectChanges();\n\n      this._cRef.instance.setDisabledState(this.disabled);\n\n      if (this.container === 'body') {\n        window.document.querySelector(this.container).appendChild(this._cRef.location.nativeElement);\n      }\n\n      // focus handling\n      this._elWithFocus = this._document.activeElement;\n      ngbFocusTrap(this._ngZone, this._cRef.location.nativeElement, this.closed, true);\n      this._cRef.instance.focus();\n\n      ngbAutoClose(\n          this._ngZone, this._document, this.autoClose, () => this.close(), this.closed, [],\n          [this._elRef.nativeElement, this._cRef.location.nativeElement]);\n    }\n  }\n\n  /**\n   * Closes the datepicker popup.\n   */\n  close() {\n    if (this.isOpen()) {\n      this._vcRef.remove(this._vcRef.indexOf(this._cRef.hostView));\n      this._cRef = null;\n      this.closed.emit();\n      this._changeDetector.markForCheck();\n\n      // restore focus\n      let elementToFocus = this._elWithFocus;\n      if (isString(this.restoreFocus)) {\n        elementToFocus = this._document.querySelector(this.restoreFocus);\n      } else if (this.restoreFocus !== undefined) {\n        elementToFocus = this.restoreFocus;\n      }\n\n      // in IE document.activeElement can contain an object without 'focus()' sometimes\n      if (elementToFocus && elementToFocus['focus']) {\n        elementToFocus.focus();\n      } else {\n        this._document.body.focus();\n      }\n    }\n  }\n\n  /**\n   * Toggles the datepicker popup.\n   */\n  toggle() {\n    if (this.isOpen()) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  /**\n   * Navigates to the provided date.\n   *\n   * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.\n   * If nothing or invalid date provided calendar will open current month.\n   *\n   * Use the `[startDate]` input as an alternative.\n   */\n  navigateTo(date?: {year: number, month: number, day?: number}) {\n    if (this.isOpen()) {\n      this._cRef.instance.navigateTo(date);\n    }\n  }\n\n  onBlur() { this._onTouched(); }\n\n  onFocus() { this._elWithFocus = this._elRef.nativeElement; }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['minDate'] || changes['maxDate']) {\n      this._validatorChange();\n\n      if (this.isOpen()) {\n        if (changes['minDate']) {\n          this._cRef.instance.minDate = this._dateAdapter.toModel(changes.minDate.currentValue);\n        }\n        if (changes['maxDate']) {\n          this._cRef.instance.maxDate = this._dateAdapter.toModel(changes.maxDate.currentValue);\n        }\n        this._cRef.instance.ngOnChanges(changes);\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.close();\n    this._zoneSubscription.unsubscribe();\n  }\n\n  private _applyDatepickerInputs(datepickerInstance: NgbDatepicker): void {\n    ['dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate',\n     'maxDate', 'navigation', 'outsideDays', 'showNavigation', 'showWeekdays', 'showWeekNumbers']\n        .forEach((optionName: string) => {\n          if (this[optionName] !== undefined) {\n            datepickerInstance[optionName] = this[optionName];\n          }\n        });\n    datepickerInstance.startDate = this.startDate || this._model;\n  }\n\n  private _applyPopupStyling(nativeElement: any) {\n    this._renderer.addClass(nativeElement, 'dropdown-menu');\n    this._renderer.addClass(nativeElement, 'show');\n\n    if (this.container === 'body') {\n      this._renderer.addClass(nativeElement, 'ngb-dp-body');\n    }\n  }\n\n  private _subscribeForDatepickerOutputs(datepickerInstance: NgbDatepicker) {\n    datepickerInstance.navigate.subscribe(navigateEvent => this.navigate.emit(navigateEvent));\n    datepickerInstance.dateSelect.subscribe(date => {\n      this.dateSelect.emit(date);\n      if (this.autoClose === true || this.autoClose === 'inside') {\n        this.close();\n      }\n    });\n  }\n\n  private _writeModelValue(model: NgbDate) {\n    const value = this._parserFormatter.format(model);\n    this._inputValue = value;\n    this._renderer.setProperty(this._elRef.nativeElement, 'value', value);\n    if (this.isOpen()) {\n      this._cRef.instance.writeValue(this._dateAdapter.toModel(model));\n      this._onTouched();\n    }\n  }\n\n  private _fromDateStruct(date: NgbDateStruct): NgbDate {\n    const ngbDate = date ? new NgbDate(date.year, date.month, date.day) : null;\n    return this._calendar.isValid(ngbDate) ? ngbDate : null;\n  }\n\n  private _updatePopupPosition() {\n    if (!this._cRef) {\n      return;\n    }\n\n    let hostElement: HTMLElement;\n    if (isString(this.positionTarget)) {\n      hostElement = this._document.querySelector(this.positionTarget);\n    } else if (this.positionTarget instanceof HTMLElement) {\n      hostElement = this.positionTarget;\n    } else {\n      hostElement = this._elRef.nativeElement;\n    }\n\n    if (this.positionTarget && !hostElement) {\n      throw new Error('ngbDatepicker could not find element declared in [positionTarget] to position against.');\n    }\n\n    positionElements(hostElement, this._cRef.location.nativeElement, this.placement, this.container === 'body');\n  }\n}\n"]}