datepicker-input.js 61 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763
  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. const NGB_DATEPICKER_VALUE_ACCESSOR = {
  21. provide: NG_VALUE_ACCESSOR,
  22. useExisting: forwardRef((/**
  23. * @return {?}
  24. */
  25. () => NgbInputDatepicker)),
  26. multi: true
  27. };
  28. /** @type {?} */
  29. const NGB_DATEPICKER_VALIDATOR = {
  30. provide: NG_VALIDATORS,
  31. useExisting: forwardRef((/**
  32. * @return {?}
  33. */
  34. () => 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. export class NgbInputDatepicker {
  43. /**
  44. * @param {?} _parserFormatter
  45. * @param {?} _elRef
  46. * @param {?} _vcRef
  47. * @param {?} _renderer
  48. * @param {?} _cfr
  49. * @param {?} _ngZone
  50. * @param {?} _calendar
  51. * @param {?} _dateAdapter
  52. * @param {?} _document
  53. * @param {?} _changeDetector
  54. * @param {?} config
  55. */
  56. constructor(_parserFormatter, _elRef, _vcRef, _renderer, _cfr, _ngZone, _calendar, _dateAdapter, _document, _changeDetector, config) {
  57. this._parserFormatter = _parserFormatter;
  58. this._elRef = _elRef;
  59. this._vcRef = _vcRef;
  60. this._renderer = _renderer;
  61. this._cfr = _cfr;
  62. this._ngZone = _ngZone;
  63. this._calendar = _calendar;
  64. this._dateAdapter = _dateAdapter;
  65. this._document = _document;
  66. this._changeDetector = _changeDetector;
  67. this._cRef = null;
  68. this._disabled = false;
  69. this._elWithFocus = null;
  70. /**
  71. * An event emitted when user selects a date using keyboard or mouse.
  72. *
  73. * The payload of the event is currently selected `NgbDate`.
  74. *
  75. * \@since 1.1.1
  76. */
  77. this.dateSelect = new EventEmitter();
  78. /**
  79. * Event emitted right after the navigation happens and displayed month changes.
  80. *
  81. * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.
  82. */
  83. this.navigate = new EventEmitter();
  84. /**
  85. * An event fired after closing datepicker window.
  86. *
  87. * \@since 4.2.0
  88. */
  89. this.closed = new EventEmitter();
  90. this._onChange = (/**
  91. * @param {?} _
  92. * @return {?}
  93. */
  94. (_) => { });
  95. this._onTouched = (/**
  96. * @return {?}
  97. */
  98. () => { });
  99. this._validatorChange = (/**
  100. * @return {?}
  101. */
  102. () => { });
  103. ['autoClose', 'container', 'positionTarget', 'placement'].forEach((/**
  104. * @param {?} input
  105. * @return {?}
  106. */
  107. input => this[input] = config[input]));
  108. this._zoneSubscription = _ngZone.onStable.subscribe((/**
  109. * @return {?}
  110. */
  111. () => this._updatePopupPosition()));
  112. }
  113. /**
  114. * @return {?}
  115. */
  116. get disabled() {
  117. return this._disabled;
  118. }
  119. /**
  120. * @param {?} value
  121. * @return {?}
  122. */
  123. set disabled(value) {
  124. this._disabled = value === '' || (value && value !== 'false');
  125. if (this.isOpen()) {
  126. this._cRef.instance.setDisabledState(this._disabled);
  127. }
  128. }
  129. /**
  130. * @param {?} fn
  131. * @return {?}
  132. */
  133. registerOnChange(fn) { this._onChange = fn; }
  134. /**
  135. * @param {?} fn
  136. * @return {?}
  137. */
  138. registerOnTouched(fn) { this._onTouched = fn; }
  139. /**
  140. * @param {?} fn
  141. * @return {?}
  142. */
  143. registerOnValidatorChange(fn) { this._validatorChange = fn; }
  144. /**
  145. * @param {?} isDisabled
  146. * @return {?}
  147. */
  148. setDisabledState(isDisabled) { this.disabled = isDisabled; }
  149. /**
  150. * @param {?} c
  151. * @return {?}
  152. */
  153. validate(c) {
  154. /** @type {?} */
  155. const value = c.value;
  156. if (value === null || value === undefined) {
  157. return null;
  158. }
  159. /** @type {?} */
  160. const ngbDate = this._fromDateStruct(this._dateAdapter.fromModel(value));
  161. if (!this._calendar.isValid(ngbDate)) {
  162. return { 'ngbDate': { invalid: c.value } };
  163. }
  164. if (this.minDate && ngbDate.before(NgbDate.from(this.minDate))) {
  165. return { 'ngbDate': { requiredBefore: this.minDate } };
  166. }
  167. if (this.maxDate && ngbDate.after(NgbDate.from(this.maxDate))) {
  168. return { 'ngbDate': { requiredAfter: this.maxDate } };
  169. }
  170. }
  171. /**
  172. * @param {?} value
  173. * @return {?}
  174. */
  175. writeValue(value) {
  176. this._model = this._fromDateStruct(this._dateAdapter.fromModel(value));
  177. this._writeModelValue(this._model);
  178. }
  179. /**
  180. * @param {?} value
  181. * @param {?=} updateView
  182. * @return {?}
  183. */
  184. manualDateChange(value, updateView = false) {
  185. /** @type {?} */
  186. const inputValueChanged = value !== this._inputValue;
  187. if (inputValueChanged) {
  188. this._inputValue = value;
  189. this._model = this._fromDateStruct(this._parserFormatter.parse(value));
  190. }
  191. if (inputValueChanged || !updateView) {
  192. this._onChange(this._model ? this._dateAdapter.toModel(this._model) : (value === '' ? null : value));
  193. }
  194. if (updateView && this._model) {
  195. this._writeModelValue(this._model);
  196. }
  197. }
  198. /**
  199. * @return {?}
  200. */
  201. isOpen() { return !!this._cRef; }
  202. /**
  203. * Opens the datepicker popup.
  204. *
  205. * If the related form control contains a valid date, the corresponding month will be opened.
  206. * @return {?}
  207. */
  208. open() {
  209. if (!this.isOpen()) {
  210. /** @type {?} */
  211. const cf = this._cfr.resolveComponentFactory(NgbDatepicker);
  212. this._cRef = this._vcRef.createComponent(cf);
  213. this._applyPopupStyling(this._cRef.location.nativeElement);
  214. this._applyDatepickerInputs(this._cRef.instance);
  215. this._subscribeForDatepickerOutputs(this._cRef.instance);
  216. this._cRef.instance.ngOnInit();
  217. this._cRef.instance.writeValue(this._dateAdapter.toModel(this._model));
  218. // date selection event handling
  219. this._cRef.instance.registerOnChange((/**
  220. * @param {?} selectedDate
  221. * @return {?}
  222. */
  223. (selectedDate) => {
  224. this.writeValue(selectedDate);
  225. this._onChange(selectedDate);
  226. this._onTouched();
  227. }));
  228. this._cRef.changeDetectorRef.detectChanges();
  229. this._cRef.instance.setDisabledState(this.disabled);
  230. if (this.container === 'body') {
  231. window.document.querySelector(this.container).appendChild(this._cRef.location.nativeElement);
  232. }
  233. // focus handling
  234. this._elWithFocus = this._document.activeElement;
  235. ngbFocusTrap(this._ngZone, this._cRef.location.nativeElement, this.closed, true);
  236. this._cRef.instance.focus();
  237. ngbAutoClose(this._ngZone, this._document, this.autoClose, (/**
  238. * @return {?}
  239. */
  240. () => this.close()), this.closed, [], [this._elRef.nativeElement, this._cRef.location.nativeElement]);
  241. }
  242. }
  243. /**
  244. * Closes the datepicker popup.
  245. * @return {?}
  246. */
  247. close() {
  248. if (this.isOpen()) {
  249. this._vcRef.remove(this._vcRef.indexOf(this._cRef.hostView));
  250. this._cRef = null;
  251. this.closed.emit();
  252. this._changeDetector.markForCheck();
  253. // restore focus
  254. /** @type {?} */
  255. let elementToFocus = this._elWithFocus;
  256. if (isString(this.restoreFocus)) {
  257. elementToFocus = this._document.querySelector(this.restoreFocus);
  258. }
  259. else if (this.restoreFocus !== undefined) {
  260. elementToFocus = this.restoreFocus;
  261. }
  262. // in IE document.activeElement can contain an object without 'focus()' sometimes
  263. if (elementToFocus && elementToFocus['focus']) {
  264. elementToFocus.focus();
  265. }
  266. else {
  267. this._document.body.focus();
  268. }
  269. }
  270. }
  271. /**
  272. * Toggles the datepicker popup.
  273. * @return {?}
  274. */
  275. toggle() {
  276. if (this.isOpen()) {
  277. this.close();
  278. }
  279. else {
  280. this.open();
  281. }
  282. }
  283. /**
  284. * Navigates to the provided date.
  285. *
  286. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  287. * If nothing or invalid date provided calendar will open current month.
  288. *
  289. * Use the `[startDate]` input as an alternative.
  290. * @param {?=} date
  291. * @return {?}
  292. */
  293. navigateTo(date) {
  294. if (this.isOpen()) {
  295. this._cRef.instance.navigateTo(date);
  296. }
  297. }
  298. /**
  299. * @return {?}
  300. */
  301. onBlur() { this._onTouched(); }
  302. /**
  303. * @return {?}
  304. */
  305. onFocus() { this._elWithFocus = this._elRef.nativeElement; }
  306. /**
  307. * @param {?} changes
  308. * @return {?}
  309. */
  310. ngOnChanges(changes) {
  311. if (changes['minDate'] || changes['maxDate']) {
  312. this._validatorChange();
  313. if (this.isOpen()) {
  314. if (changes['minDate']) {
  315. this._cRef.instance.minDate = this._dateAdapter.toModel(changes.minDate.currentValue);
  316. }
  317. if (changes['maxDate']) {
  318. this._cRef.instance.maxDate = this._dateAdapter.toModel(changes.maxDate.currentValue);
  319. }
  320. this._cRef.instance.ngOnChanges(changes);
  321. }
  322. }
  323. }
  324. /**
  325. * @return {?}
  326. */
  327. ngOnDestroy() {
  328. this.close();
  329. this._zoneSubscription.unsubscribe();
  330. }
  331. /**
  332. * @private
  333. * @param {?} datepickerInstance
  334. * @return {?}
  335. */
  336. _applyDatepickerInputs(datepickerInstance) {
  337. ['dayTemplate', 'dayTemplateData', 'displayMonths', 'firstDayOfWeek', 'footerTemplate', 'markDisabled', 'minDate',
  338. 'maxDate', 'navigation', 'outsideDays', 'showNavigation', 'showWeekdays', 'showWeekNumbers']
  339. .forEach((/**
  340. * @param {?} optionName
  341. * @return {?}
  342. */
  343. (optionName) => {
  344. if (this[optionName] !== undefined) {
  345. datepickerInstance[optionName] = this[optionName];
  346. }
  347. }));
  348. datepickerInstance.startDate = this.startDate || this._model;
  349. }
  350. /**
  351. * @private
  352. * @param {?} nativeElement
  353. * @return {?}
  354. */
  355. _applyPopupStyling(nativeElement) {
  356. this._renderer.addClass(nativeElement, 'dropdown-menu');
  357. this._renderer.addClass(nativeElement, 'show');
  358. if (this.container === 'body') {
  359. this._renderer.addClass(nativeElement, 'ngb-dp-body');
  360. }
  361. }
  362. /**
  363. * @private
  364. * @param {?} datepickerInstance
  365. * @return {?}
  366. */
  367. _subscribeForDatepickerOutputs(datepickerInstance) {
  368. datepickerInstance.navigate.subscribe((/**
  369. * @param {?} navigateEvent
  370. * @return {?}
  371. */
  372. navigateEvent => this.navigate.emit(navigateEvent)));
  373. datepickerInstance.dateSelect.subscribe((/**
  374. * @param {?} date
  375. * @return {?}
  376. */
  377. date => {
  378. this.dateSelect.emit(date);
  379. if (this.autoClose === true || this.autoClose === 'inside') {
  380. this.close();
  381. }
  382. }));
  383. }
  384. /**
  385. * @private
  386. * @param {?} model
  387. * @return {?}
  388. */
  389. _writeModelValue(model) {
  390. /** @type {?} */
  391. const value = this._parserFormatter.format(model);
  392. this._inputValue = value;
  393. this._renderer.setProperty(this._elRef.nativeElement, 'value', value);
  394. if (this.isOpen()) {
  395. this._cRef.instance.writeValue(this._dateAdapter.toModel(model));
  396. this._onTouched();
  397. }
  398. }
  399. /**
  400. * @private
  401. * @param {?} date
  402. * @return {?}
  403. */
  404. _fromDateStruct(date) {
  405. /** @type {?} */
  406. const ngbDate = date ? new NgbDate(date.year, date.month, date.day) : null;
  407. return this._calendar.isValid(ngbDate) ? ngbDate : null;
  408. }
  409. /**
  410. * @private
  411. * @return {?}
  412. */
  413. _updatePopupPosition() {
  414. if (!this._cRef) {
  415. return;
  416. }
  417. /** @type {?} */
  418. let hostElement;
  419. if (isString(this.positionTarget)) {
  420. hostElement = this._document.querySelector(this.positionTarget);
  421. }
  422. else if (this.positionTarget instanceof HTMLElement) {
  423. hostElement = this.positionTarget;
  424. }
  425. else {
  426. hostElement = this._elRef.nativeElement;
  427. }
  428. if (this.positionTarget && !hostElement) {
  429. throw new Error('ngbDatepicker could not find element declared in [positionTarget] to position against.');
  430. }
  431. positionElements(hostElement, this._cRef.location.nativeElement, this.placement, this.container === 'body');
  432. }
  433. }
  434. NgbInputDatepicker.decorators = [
  435. { type: Directive, args: [{
  436. selector: 'input[ngbDatepicker]',
  437. exportAs: 'ngbDatepicker',
  438. host: {
  439. '(input)': 'manualDateChange($event.target.value)',
  440. '(change)': 'manualDateChange($event.target.value, true)',
  441. '(focus)': 'onFocus()',
  442. '(blur)': 'onBlur()',
  443. '[disabled]': 'disabled'
  444. },
  445. providers: [
  446. NGB_DATEPICKER_VALUE_ACCESSOR, NGB_DATEPICKER_VALIDATOR,
  447. { provide: NgbDatepickerConfig, useExisting: NgbInputDatepickerConfig }
  448. ],
  449. },] }
  450. ];
  451. /** @nocollapse */
  452. NgbInputDatepicker.ctorParameters = () => [
  453. { type: NgbDateParserFormatter },
  454. { type: ElementRef },
  455. { type: ViewContainerRef },
  456. { type: Renderer2 },
  457. { type: ComponentFactoryResolver },
  458. { type: NgZone },
  459. { type: NgbCalendar },
  460. { type: NgbDateAdapter },
  461. { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
  462. { type: ChangeDetectorRef },
  463. { type: NgbInputDatepickerConfig }
  464. ];
  465. NgbInputDatepicker.propDecorators = {
  466. autoClose: [{ type: Input }],
  467. dayTemplate: [{ type: Input }],
  468. dayTemplateData: [{ type: Input }],
  469. displayMonths: [{ type: Input }],
  470. firstDayOfWeek: [{ type: Input }],
  471. footerTemplate: [{ type: Input }],
  472. markDisabled: [{ type: Input }],
  473. minDate: [{ type: Input }],
  474. maxDate: [{ type: Input }],
  475. navigation: [{ type: Input }],
  476. outsideDays: [{ type: Input }],
  477. placement: [{ type: Input }],
  478. restoreFocus: [{ type: Input }],
  479. showWeekdays: [{ type: Input }],
  480. showWeekNumbers: [{ type: Input }],
  481. startDate: [{ type: Input }],
  482. container: [{ type: Input }],
  483. positionTarget: [{ type: Input }],
  484. dateSelect: [{ type: Output }],
  485. navigate: [{ type: Output }],
  486. closed: [{ type: Output }],
  487. disabled: [{ type: Input }]
  488. };
  489. if (false) {
  490. /**
  491. * @type {?}
  492. * @private
  493. */
  494. NgbInputDatepicker.prototype._cRef;
  495. /**
  496. * @type {?}
  497. * @private
  498. */
  499. NgbInputDatepicker.prototype._disabled;
  500. /**
  501. * @type {?}
  502. * @private
  503. */
  504. NgbInputDatepicker.prototype._elWithFocus;
  505. /**
  506. * @type {?}
  507. * @private
  508. */
  509. NgbInputDatepicker.prototype._model;
  510. /**
  511. * @type {?}
  512. * @private
  513. */
  514. NgbInputDatepicker.prototype._inputValue;
  515. /**
  516. * @type {?}
  517. * @private
  518. */
  519. NgbInputDatepicker.prototype._zoneSubscription;
  520. /**
  521. * Indicates whether the datepicker popup should be closed automatically after date selection / outside click or not.
  522. *
  523. * * `true` - the popup will close on both date selection and outside click.
  524. * * `false` - the popup can only be closed manually via `close()` or `toggle()` methods.
  525. * * `"inside"` - the popup will close on date selection, but not outside clicks.
  526. * * `"outside"` - the popup will close only on the outside click and not on date selection/inside clicks.
  527. *
  528. * \@since 3.0.0
  529. * @type {?}
  530. */
  531. NgbInputDatepicker.prototype.autoClose;
  532. /**
  533. * The reference to a custom template for the day.
  534. *
  535. * Allows to completely override the way a day 'cell' in the calendar is displayed.
  536. *
  537. * See [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext) for the data you get inside.
  538. * @type {?}
  539. */
  540. NgbInputDatepicker.prototype.dayTemplate;
  541. /**
  542. * The callback to pass any arbitrary data to the template cell via the
  543. * [`DayTemplateContext`](#/components/datepicker/api#DayTemplateContext)'s `data` parameter.
  544. *
  545. * `current` is the month that is currently displayed by the datepicker.
  546. *
  547. * \@since 3.3.0
  548. * @type {?}
  549. */
  550. NgbInputDatepicker.prototype.dayTemplateData;
  551. /**
  552. * The number of months to display.
  553. * @type {?}
  554. */
  555. NgbInputDatepicker.prototype.displayMonths;
  556. /**
  557. * The first day of the week.
  558. *
  559. * With default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun.
  560. * @type {?}
  561. */
  562. NgbInputDatepicker.prototype.firstDayOfWeek;
  563. /**
  564. * The reference to the custom template for the datepicker footer.
  565. *
  566. * \@since 3.3.0
  567. * @type {?}
  568. */
  569. NgbInputDatepicker.prototype.footerTemplate;
  570. /**
  571. * The callback to mark some dates as disabled.
  572. *
  573. * It is called for each new date when navigating to a different month.
  574. *
  575. * `current` is the month that is currently displayed by the datepicker.
  576. * @type {?}
  577. */
  578. NgbInputDatepicker.prototype.markDisabled;
  579. /**
  580. * The earliest date that can be displayed or selected. Also used for form validation.
  581. *
  582. * If not provided, 'year' select box will display 10 years before the current month.
  583. * @type {?}
  584. */
  585. NgbInputDatepicker.prototype.minDate;
  586. /**
  587. * The latest date that can be displayed or selected. Also used for form validation.
  588. *
  589. * If not provided, 'year' select box will display 10 years after the current month.
  590. * @type {?}
  591. */
  592. NgbInputDatepicker.prototype.maxDate;
  593. /**
  594. * Navigation type.
  595. *
  596. * * `"select"` - select boxes for month and navigation arrows
  597. * * `"arrows"` - only navigation arrows
  598. * * `"none"` - no navigation visible at all
  599. * @type {?}
  600. */
  601. NgbInputDatepicker.prototype.navigation;
  602. /**
  603. * The way of displaying days that don't belong to the current month.
  604. *
  605. * * `"visible"` - days are visible
  606. * * `"hidden"` - days are hidden, white space preserved
  607. * * `"collapsed"` - days are collapsed, so the datepicker height might change between months
  608. *
  609. * For the 2+ months view, days in between months are never shown.
  610. * @type {?}
  611. */
  612. NgbInputDatepicker.prototype.outsideDays;
  613. /**
  614. * The preferred placement of the datepicker popup.
  615. *
  616. * Possible values are `"top"`, `"top-left"`, `"top-right"`, `"bottom"`, `"bottom-left"`,
  617. * `"bottom-right"`, `"left"`, `"left-top"`, `"left-bottom"`, `"right"`, `"right-top"`,
  618. * `"right-bottom"`
  619. *
  620. * Accepts an array of strings or a string with space separated possible values.
  621. *
  622. * The default order of preference is `"bottom-left bottom-right top-left top-right"`
  623. *
  624. * Please see the [positioning overview](#/positioning) for more details.
  625. * @type {?}
  626. */
  627. NgbInputDatepicker.prototype.placement;
  628. /**
  629. * If `true`, when closing datepicker will focus element that was focused before datepicker was opened.
  630. *
  631. * Alternatively you could provide a selector or an `HTMLElement` to focus. If the element doesn't exist or invalid,
  632. * we'll fallback to focus document body.
  633. *
  634. * \@since 5.2.0
  635. * @type {?}
  636. */
  637. NgbInputDatepicker.prototype.restoreFocus;
  638. /**
  639. * If `true`, weekdays will be displayed.
  640. * @type {?}
  641. */
  642. NgbInputDatepicker.prototype.showWeekdays;
  643. /**
  644. * If `true`, week numbers will be displayed.
  645. * @type {?}
  646. */
  647. NgbInputDatepicker.prototype.showWeekNumbers;
  648. /**
  649. * The date to open calendar with.
  650. *
  651. * With the default calendar we use ISO 8601: 'month' is 1=Jan ... 12=Dec.
  652. * If nothing or invalid date is provided, calendar will open with current month.
  653. *
  654. * You could use `navigateTo(date)` method as an alternative.
  655. * @type {?}
  656. */
  657. NgbInputDatepicker.prototype.startDate;
  658. /**
  659. * A selector specifying the element the datepicker popup should be appended to.
  660. *
  661. * Currently only supports `"body"`.
  662. * @type {?}
  663. */
  664. NgbInputDatepicker.prototype.container;
  665. /**
  666. * A css selector or html element specifying the element the datepicker popup should be positioned against.
  667. *
  668. * By default the input is used as a target.
  669. *
  670. * \@since 4.2.0
  671. * @type {?}
  672. */
  673. NgbInputDatepicker.prototype.positionTarget;
  674. /**
  675. * An event emitted when user selects a date using keyboard or mouse.
  676. *
  677. * The payload of the event is currently selected `NgbDate`.
  678. *
  679. * \@since 1.1.1
  680. * @type {?}
  681. */
  682. NgbInputDatepicker.prototype.dateSelect;
  683. /**
  684. * Event emitted right after the navigation happens and displayed month changes.
  685. *
  686. * See [`NgbDatepickerNavigateEvent`](#/components/datepicker/api#NgbDatepickerNavigateEvent) for the payload info.
  687. * @type {?}
  688. */
  689. NgbInputDatepicker.prototype.navigate;
  690. /**
  691. * An event fired after closing datepicker window.
  692. *
  693. * \@since 4.2.0
  694. * @type {?}
  695. */
  696. NgbInputDatepicker.prototype.closed;
  697. /**
  698. * @type {?}
  699. * @private
  700. */
  701. NgbInputDatepicker.prototype._onChange;
  702. /**
  703. * @type {?}
  704. * @private
  705. */
  706. NgbInputDatepicker.prototype._onTouched;
  707. /**
  708. * @type {?}
  709. * @private
  710. */
  711. NgbInputDatepicker.prototype._validatorChange;
  712. /**
  713. * @type {?}
  714. * @private
  715. */
  716. NgbInputDatepicker.prototype._parserFormatter;
  717. /**
  718. * @type {?}
  719. * @private
  720. */
  721. NgbInputDatepicker.prototype._elRef;
  722. /**
  723. * @type {?}
  724. * @private
  725. */
  726. NgbInputDatepicker.prototype._vcRef;
  727. /**
  728. * @type {?}
  729. * @private
  730. */
  731. NgbInputDatepicker.prototype._renderer;
  732. /**
  733. * @type {?}
  734. * @private
  735. */
  736. NgbInputDatepicker.prototype._cfr;
  737. /**
  738. * @type {?}
  739. * @private
  740. */
  741. NgbInputDatepicker.prototype._ngZone;
  742. /**
  743. * @type {?}
  744. * @private
  745. */
  746. NgbInputDatepicker.prototype._calendar;
  747. /**
  748. * @type {?}
  749. * @private
  750. */
  751. NgbInputDatepicker.prototype._dateAdapter;
  752. /**
  753. * @type {?}
  754. * @private
  755. */
  756. NgbInputDatepicker.prototype._document;
  757. /**
  758. * @type {?}
  759. * @private
  760. */
  761. NgbInputDatepicker.prototype._changeDetector;
  762. }
  763. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["datepicker/datepicker-input.ts"],"names":[],"mappings":"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","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"]}