dropdown.js 58 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { ChangeDetectorRef, ContentChild, ContentChildren, Directive, ElementRef, EventEmitter, forwardRef, Inject, Input, NgZone, Output, QueryList, Renderer2, Optional } from '@angular/core';
  7. import { DOCUMENT } from '@angular/common';
  8. import { fromEvent, Subject } from 'rxjs';
  9. import { take } from 'rxjs/operators';
  10. import { positionElements } from '../util/positioning';
  11. import { ngbAutoClose } from '../util/autoclose';
  12. import { Key } from '../util/key';
  13. import { NgbDropdownConfig } from './dropdown-config';
  14. var NgbNavbar = /** @class */ (function () {
  15. function NgbNavbar() {
  16. }
  17. NgbNavbar.decorators = [
  18. { type: Directive, args: [{ selector: '.navbar' },] }
  19. ];
  20. return NgbNavbar;
  21. }());
  22. export { NgbNavbar };
  23. /**
  24. * A directive you should put on a dropdown item to enable keyboard navigation.
  25. * Arrow keys will move focus between items marked with this directive.
  26. *
  27. * \@since 4.1.0
  28. */
  29. var NgbDropdownItem = /** @class */ (function () {
  30. function NgbDropdownItem(elementRef) {
  31. this.elementRef = elementRef;
  32. this._disabled = false;
  33. }
  34. Object.defineProperty(NgbDropdownItem.prototype, "disabled", {
  35. get: /**
  36. * @return {?}
  37. */
  38. function () { return this._disabled; },
  39. set: /**
  40. * @param {?} value
  41. * @return {?}
  42. */
  43. function (value) {
  44. this._disabled = (/** @type {?} */ (value)) === '' || value === true; // accept an empty attribute as true
  45. },
  46. enumerable: true,
  47. configurable: true
  48. });
  49. NgbDropdownItem.decorators = [
  50. { type: Directive, args: [{ selector: '[ngbDropdownItem]', host: { 'class': 'dropdown-item', '[class.disabled]': 'disabled' } },] }
  51. ];
  52. /** @nocollapse */
  53. NgbDropdownItem.ctorParameters = function () { return [
  54. { type: ElementRef }
  55. ]; };
  56. NgbDropdownItem.propDecorators = {
  57. disabled: [{ type: Input }]
  58. };
  59. return NgbDropdownItem;
  60. }());
  61. export { NgbDropdownItem };
  62. if (false) {
  63. /**
  64. * @type {?}
  65. * @private
  66. */
  67. NgbDropdownItem.prototype._disabled;
  68. /** @type {?} */
  69. NgbDropdownItem.prototype.elementRef;
  70. }
  71. /**
  72. * A directive that wraps dropdown menu content and dropdown items.
  73. */
  74. var NgbDropdownMenu = /** @class */ (function () {
  75. function NgbDropdownMenu(dropdown) {
  76. this.dropdown = dropdown;
  77. this.placement = 'bottom';
  78. this.isOpen = false;
  79. }
  80. NgbDropdownMenu.decorators = [
  81. { type: Directive, args: [{
  82. selector: '[ngbDropdownMenu]',
  83. host: {
  84. '[class.dropdown-menu]': 'true',
  85. '[class.show]': 'dropdown.isOpen()',
  86. '[attr.x-placement]': 'placement',
  87. '(keydown.ArrowUp)': 'dropdown.onKeyDown($event)',
  88. '(keydown.ArrowDown)': 'dropdown.onKeyDown($event)',
  89. '(keydown.Home)': 'dropdown.onKeyDown($event)',
  90. '(keydown.End)': 'dropdown.onKeyDown($event)',
  91. '(keydown.Enter)': 'dropdown.onKeyDown($event)',
  92. '(keydown.Space)': 'dropdown.onKeyDown($event)'
  93. }
  94. },] }
  95. ];
  96. /** @nocollapse */
  97. NgbDropdownMenu.ctorParameters = function () { return [
  98. { type: undefined, decorators: [{ type: Inject, args: [forwardRef((/**
  99. * @return {?}
  100. */
  101. function () { return NgbDropdown; })),] }] }
  102. ]; };
  103. NgbDropdownMenu.propDecorators = {
  104. menuItems: [{ type: ContentChildren, args: [NgbDropdownItem,] }]
  105. };
  106. return NgbDropdownMenu;
  107. }());
  108. export { NgbDropdownMenu };
  109. if (false) {
  110. /** @type {?} */
  111. NgbDropdownMenu.prototype.placement;
  112. /** @type {?} */
  113. NgbDropdownMenu.prototype.isOpen;
  114. /** @type {?} */
  115. NgbDropdownMenu.prototype.menuItems;
  116. /** @type {?} */
  117. NgbDropdownMenu.prototype.dropdown;
  118. }
  119. /**
  120. * A directive to mark an element to which dropdown menu will be anchored.
  121. *
  122. * This is a simple version of the `NgbDropdownToggle` directive.
  123. * It plays the same role, but doesn't listen to click events to toggle dropdown menu thus enabling support
  124. * for events other than click.
  125. *
  126. * \@since 1.1.0
  127. */
  128. var NgbDropdownAnchor = /** @class */ (function () {
  129. function NgbDropdownAnchor(dropdown, _elementRef) {
  130. this.dropdown = dropdown;
  131. this._elementRef = _elementRef;
  132. this.anchorEl = _elementRef.nativeElement;
  133. }
  134. /**
  135. * @return {?}
  136. */
  137. NgbDropdownAnchor.prototype.getNativeElement = /**
  138. * @return {?}
  139. */
  140. function () { return this._elementRef.nativeElement; };
  141. NgbDropdownAnchor.decorators = [
  142. { type: Directive, args: [{
  143. selector: '[ngbDropdownAnchor]',
  144. host: { 'class': 'dropdown-toggle', 'aria-haspopup': 'true', '[attr.aria-expanded]': 'dropdown.isOpen()' }
  145. },] }
  146. ];
  147. /** @nocollapse */
  148. NgbDropdownAnchor.ctorParameters = function () { return [
  149. { type: undefined, decorators: [{ type: Inject, args: [forwardRef((/**
  150. * @return {?}
  151. */
  152. function () { return NgbDropdown; })),] }] },
  153. { type: ElementRef }
  154. ]; };
  155. return NgbDropdownAnchor;
  156. }());
  157. export { NgbDropdownAnchor };
  158. if (false) {
  159. /** @type {?} */
  160. NgbDropdownAnchor.prototype.anchorEl;
  161. /** @type {?} */
  162. NgbDropdownAnchor.prototype.dropdown;
  163. /**
  164. * @type {?}
  165. * @private
  166. */
  167. NgbDropdownAnchor.prototype._elementRef;
  168. }
  169. /**
  170. * A directive to mark an element that will toggle dropdown via the `click` event.
  171. *
  172. * You can also use `NgbDropdownAnchor` as an alternative.
  173. */
  174. var NgbDropdownToggle = /** @class */ (function (_super) {
  175. tslib_1.__extends(NgbDropdownToggle, _super);
  176. function NgbDropdownToggle(dropdown, elementRef) {
  177. return _super.call(this, dropdown, elementRef) || this;
  178. }
  179. NgbDropdownToggle.decorators = [
  180. { type: Directive, args: [{
  181. selector: '[ngbDropdownToggle]',
  182. host: {
  183. 'class': 'dropdown-toggle',
  184. 'aria-haspopup': 'true',
  185. '[attr.aria-expanded]': 'dropdown.isOpen()',
  186. '(click)': 'dropdown.toggle()',
  187. '(keydown.ArrowUp)': 'dropdown.onKeyDown($event)',
  188. '(keydown.ArrowDown)': 'dropdown.onKeyDown($event)',
  189. '(keydown.Home)': 'dropdown.onKeyDown($event)',
  190. '(keydown.End)': 'dropdown.onKeyDown($event)'
  191. },
  192. providers: [{ provide: NgbDropdownAnchor, useExisting: forwardRef((/**
  193. * @return {?}
  194. */
  195. function () { return NgbDropdownToggle; })) }]
  196. },] }
  197. ];
  198. /** @nocollapse */
  199. NgbDropdownToggle.ctorParameters = function () { return [
  200. { type: undefined, decorators: [{ type: Inject, args: [forwardRef((/**
  201. * @return {?}
  202. */
  203. function () { return NgbDropdown; })),] }] },
  204. { type: ElementRef }
  205. ]; };
  206. return NgbDropdownToggle;
  207. }(NgbDropdownAnchor));
  208. export { NgbDropdownToggle };
  209. /**
  210. * A directive that provides contextual overlays for displaying lists of links and more.
  211. */
  212. var NgbDropdown = /** @class */ (function () {
  213. function NgbDropdown(_changeDetector, config, _document, _ngZone, _elementRef, _renderer, ngbNavbar) {
  214. var _this = this;
  215. this._changeDetector = _changeDetector;
  216. this._document = _document;
  217. this._ngZone = _ngZone;
  218. this._elementRef = _elementRef;
  219. this._renderer = _renderer;
  220. this._closed$ = new Subject();
  221. /**
  222. * Defines whether or not the dropdown menu is opened initially.
  223. */
  224. this._open = false;
  225. /**
  226. * An event fired when the dropdown is opened or closed.
  227. *
  228. * The event payload is a `boolean`:
  229. * * `true` - the dropdown was opened
  230. * * `false` - the dropdown was closed
  231. */
  232. this.openChange = new EventEmitter();
  233. this.placement = config.placement;
  234. this.container = config.container;
  235. this.autoClose = config.autoClose;
  236. this.display = ngbNavbar ? 'static' : 'dynamic';
  237. this._zoneSubscription = _ngZone.onStable.subscribe((/**
  238. * @return {?}
  239. */
  240. function () { _this._positionMenu(); }));
  241. }
  242. /**
  243. * @return {?}
  244. */
  245. NgbDropdown.prototype.ngAfterContentInit = /**
  246. * @return {?}
  247. */
  248. function () {
  249. var _this = this;
  250. this._ngZone.onStable.pipe(take(1)).subscribe((/**
  251. * @return {?}
  252. */
  253. function () {
  254. _this._applyPlacementClasses();
  255. if (_this._open) {
  256. _this._setCloseHandlers();
  257. }
  258. }));
  259. };
  260. /**
  261. * @param {?} changes
  262. * @return {?}
  263. */
  264. NgbDropdown.prototype.ngOnChanges = /**
  265. * @param {?} changes
  266. * @return {?}
  267. */
  268. function (changes) {
  269. if (changes.container && this._open) {
  270. this._applyContainer(this.container);
  271. }
  272. if (changes.placement && !changes.placement.isFirstChange) {
  273. this._applyPlacementClasses();
  274. }
  275. };
  276. /**
  277. * Checks if the dropdown menu is open.
  278. */
  279. /**
  280. * Checks if the dropdown menu is open.
  281. * @return {?}
  282. */
  283. NgbDropdown.prototype.isOpen = /**
  284. * Checks if the dropdown menu is open.
  285. * @return {?}
  286. */
  287. function () { return this._open; };
  288. /**
  289. * Opens the dropdown menu.
  290. */
  291. /**
  292. * Opens the dropdown menu.
  293. * @return {?}
  294. */
  295. NgbDropdown.prototype.open = /**
  296. * Opens the dropdown menu.
  297. * @return {?}
  298. */
  299. function () {
  300. if (!this._open) {
  301. this._open = true;
  302. this._applyContainer(this.container);
  303. this.openChange.emit(true);
  304. this._setCloseHandlers();
  305. }
  306. };
  307. /**
  308. * @private
  309. * @return {?}
  310. */
  311. NgbDropdown.prototype._setCloseHandlers = /**
  312. * @private
  313. * @return {?}
  314. */
  315. function () {
  316. var _this = this;
  317. /** @type {?} */
  318. var anchor = this._anchor;
  319. ngbAutoClose(this._ngZone, this._document, this.autoClose, (/**
  320. * @return {?}
  321. */
  322. function () { return _this.close(); }), this._closed$, this._menu ? [this._menuElement.nativeElement] : [], anchor ? [anchor.getNativeElement()] : [], '.dropdown-item,.dropdown-divider');
  323. };
  324. /**
  325. * Closes the dropdown menu.
  326. */
  327. /**
  328. * Closes the dropdown menu.
  329. * @return {?}
  330. */
  331. NgbDropdown.prototype.close = /**
  332. * Closes the dropdown menu.
  333. * @return {?}
  334. */
  335. function () {
  336. if (this._open) {
  337. this._open = false;
  338. this._resetContainer();
  339. this._closed$.next();
  340. this.openChange.emit(false);
  341. this._changeDetector.markForCheck();
  342. }
  343. };
  344. /**
  345. * Toggles the dropdown menu.
  346. */
  347. /**
  348. * Toggles the dropdown menu.
  349. * @return {?}
  350. */
  351. NgbDropdown.prototype.toggle = /**
  352. * Toggles the dropdown menu.
  353. * @return {?}
  354. */
  355. function () {
  356. if (this.isOpen()) {
  357. this.close();
  358. }
  359. else {
  360. this.open();
  361. }
  362. };
  363. /**
  364. * @return {?}
  365. */
  366. NgbDropdown.prototype.ngOnDestroy = /**
  367. * @return {?}
  368. */
  369. function () {
  370. this._resetContainer();
  371. this._closed$.next();
  372. this._zoneSubscription.unsubscribe();
  373. };
  374. /**
  375. * @param {?} event
  376. * @return {?}
  377. */
  378. NgbDropdown.prototype.onKeyDown = /**
  379. * @param {?} event
  380. * @return {?}
  381. */
  382. function (event) {
  383. var _this = this;
  384. // tslint:disable-next-line:deprecation
  385. /** @type {?} */
  386. var key = event.which;
  387. /** @type {?} */
  388. var itemElements = this._getMenuElements();
  389. /** @type {?} */
  390. var position = -1;
  391. /** @type {?} */
  392. var isEventFromItems = false;
  393. /** @type {?} */
  394. var itemElement = null;
  395. /** @type {?} */
  396. var isEventFromToggle = this._isEventFromToggle(event);
  397. if (!isEventFromToggle && itemElements.length) {
  398. itemElements.forEach((/**
  399. * @param {?} item
  400. * @param {?} index
  401. * @return {?}
  402. */
  403. function (item, index) {
  404. if (item.contains((/** @type {?} */ (event.target)))) {
  405. isEventFromItems = true;
  406. itemElement = item;
  407. }
  408. if (item === _this._document.activeElement) {
  409. position = index;
  410. }
  411. }));
  412. }
  413. // closing on Enter / Space
  414. if (key === Key.Space || key === Key.Enter) {
  415. if (isEventFromItems && (this.autoClose === true || this.autoClose === 'inside')) {
  416. // Item is either a button or a link, so click will be triggered by the browser on Enter or Space.
  417. // So we have to register a one-time click handler that will fire after any user defined click handlers
  418. // to close the dropdown
  419. fromEvent(itemElement, 'click').pipe(take(1)).subscribe((/**
  420. * @return {?}
  421. */
  422. function () { return _this.close(); }));
  423. }
  424. return;
  425. }
  426. // opening / navigating
  427. if (isEventFromToggle || isEventFromItems) {
  428. this.open();
  429. if (itemElements.length) {
  430. switch (key) {
  431. case Key.ArrowDown:
  432. position = Math.min(position + 1, itemElements.length - 1);
  433. break;
  434. case Key.ArrowUp:
  435. if (this._isDropup() && position === -1) {
  436. position = itemElements.length - 1;
  437. break;
  438. }
  439. position = Math.max(position - 1, 0);
  440. break;
  441. case Key.Home:
  442. position = 0;
  443. break;
  444. case Key.End:
  445. position = itemElements.length - 1;
  446. break;
  447. }
  448. itemElements[position].focus();
  449. }
  450. event.preventDefault();
  451. }
  452. };
  453. /**
  454. * @private
  455. * @return {?}
  456. */
  457. NgbDropdown.prototype._isDropup = /**
  458. * @private
  459. * @return {?}
  460. */
  461. function () { return this._elementRef.nativeElement.classList.contains('dropup'); };
  462. /**
  463. * @private
  464. * @param {?} event
  465. * @return {?}
  466. */
  467. NgbDropdown.prototype._isEventFromToggle = /**
  468. * @private
  469. * @param {?} event
  470. * @return {?}
  471. */
  472. function (event) {
  473. return this._anchor.getNativeElement().contains((/** @type {?} */ (event.target)));
  474. };
  475. /**
  476. * @private
  477. * @return {?}
  478. */
  479. NgbDropdown.prototype._getMenuElements = /**
  480. * @private
  481. * @return {?}
  482. */
  483. function () {
  484. /** @type {?} */
  485. var menu = this._menu;
  486. if (menu == null) {
  487. return [];
  488. }
  489. return menu.menuItems.filter((/**
  490. * @param {?} item
  491. * @return {?}
  492. */
  493. function (item) { return !item.disabled; })).map((/**
  494. * @param {?} item
  495. * @return {?}
  496. */
  497. function (item) { return item.elementRef.nativeElement; }));
  498. };
  499. /**
  500. * @private
  501. * @return {?}
  502. */
  503. NgbDropdown.prototype._positionMenu = /**
  504. * @private
  505. * @return {?}
  506. */
  507. function () {
  508. /** @type {?} */
  509. var menu = this._menu;
  510. if (this.isOpen() && menu) {
  511. this._applyPlacementClasses(this.display === 'dynamic' ?
  512. positionElements(this._anchor.anchorEl, this._bodyContainer || this._menuElement.nativeElement, this.placement, this.container === 'body') :
  513. this._getFirstPlacement(this.placement));
  514. }
  515. };
  516. /**
  517. * @private
  518. * @param {?} placement
  519. * @return {?}
  520. */
  521. NgbDropdown.prototype._getFirstPlacement = /**
  522. * @private
  523. * @param {?} placement
  524. * @return {?}
  525. */
  526. function (placement) {
  527. return Array.isArray(placement) ? placement[0] : (/** @type {?} */ (placement.split(' ')[0]));
  528. };
  529. /**
  530. * @private
  531. * @return {?}
  532. */
  533. NgbDropdown.prototype._resetContainer = /**
  534. * @private
  535. * @return {?}
  536. */
  537. function () {
  538. /** @type {?} */
  539. var renderer = this._renderer;
  540. /** @type {?} */
  541. var menuElement = this._menuElement;
  542. if (menuElement) {
  543. /** @type {?} */
  544. var dropdownElement = this._elementRef.nativeElement;
  545. /** @type {?} */
  546. var dropdownMenuElement = menuElement.nativeElement;
  547. renderer.appendChild(dropdownElement, dropdownMenuElement);
  548. renderer.removeStyle(dropdownMenuElement, 'position');
  549. renderer.removeStyle(dropdownMenuElement, 'transform');
  550. }
  551. if (this._bodyContainer) {
  552. renderer.removeChild(this._document.body, this._bodyContainer);
  553. this._bodyContainer = null;
  554. }
  555. };
  556. /**
  557. * @private
  558. * @param {?=} container
  559. * @return {?}
  560. */
  561. NgbDropdown.prototype._applyContainer = /**
  562. * @private
  563. * @param {?=} container
  564. * @return {?}
  565. */
  566. function (container) {
  567. if (container === void 0) { container = null; }
  568. this._resetContainer();
  569. if (container === 'body') {
  570. /** @type {?} */
  571. var renderer = this._renderer;
  572. /** @type {?} */
  573. var dropdownMenuElement = this._menuElement.nativeElement;
  574. /** @type {?} */
  575. var bodyContainer = this._bodyContainer = this._bodyContainer || renderer.createElement('div');
  576. // Override some styles to have the positionning working
  577. renderer.setStyle(bodyContainer, 'position', 'absolute');
  578. renderer.setStyle(dropdownMenuElement, 'position', 'static');
  579. renderer.setStyle(bodyContainer, 'z-index', '1050');
  580. renderer.appendChild(bodyContainer, dropdownMenuElement);
  581. renderer.appendChild(this._document.body, bodyContainer);
  582. }
  583. };
  584. /**
  585. * @private
  586. * @param {?=} placement
  587. * @return {?}
  588. */
  589. NgbDropdown.prototype._applyPlacementClasses = /**
  590. * @private
  591. * @param {?=} placement
  592. * @return {?}
  593. */
  594. function (placement) {
  595. /** @type {?} */
  596. var menu = this._menu;
  597. if (menu) {
  598. if (!placement) {
  599. placement = this._getFirstPlacement(this.placement);
  600. }
  601. /** @type {?} */
  602. var renderer = this._renderer;
  603. /** @type {?} */
  604. var dropdownElement = this._elementRef.nativeElement;
  605. // remove the current placement classes
  606. renderer.removeClass(dropdownElement, 'dropup');
  607. renderer.removeClass(dropdownElement, 'dropdown');
  608. menu.placement = this.display === 'static' ? null : placement;
  609. /*
  610. * apply the new placement
  611. * in case of top use up-arrow or down-arrow otherwise
  612. */
  613. /** @type {?} */
  614. var dropdownClass = placement.search('^top') !== -1 ? 'dropup' : 'dropdown';
  615. renderer.addClass(dropdownElement, dropdownClass);
  616. /** @type {?} */
  617. var bodyContainer = this._bodyContainer;
  618. if (bodyContainer) {
  619. renderer.removeClass(bodyContainer, 'dropup');
  620. renderer.removeClass(bodyContainer, 'dropdown');
  621. renderer.addClass(bodyContainer, dropdownClass);
  622. }
  623. }
  624. };
  625. NgbDropdown.decorators = [
  626. { type: Directive, args: [{ selector: '[ngbDropdown]', exportAs: 'ngbDropdown', host: { '[class.show]': 'isOpen()' } },] }
  627. ];
  628. /** @nocollapse */
  629. NgbDropdown.ctorParameters = function () { return [
  630. { type: ChangeDetectorRef },
  631. { type: NgbDropdownConfig },
  632. { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
  633. { type: NgZone },
  634. { type: ElementRef },
  635. { type: Renderer2 },
  636. { type: NgbNavbar, decorators: [{ type: Optional }] }
  637. ]; };
  638. NgbDropdown.propDecorators = {
  639. _menu: [{ type: ContentChild, args: [NgbDropdownMenu, { static: false },] }],
  640. _menuElement: [{ type: ContentChild, args: [NgbDropdownMenu, { read: ElementRef, static: false },] }],
  641. _anchor: [{ type: ContentChild, args: [NgbDropdownAnchor, { static: false },] }],
  642. autoClose: [{ type: Input }],
  643. _open: [{ type: Input, args: ['open',] }],
  644. placement: [{ type: Input }],
  645. container: [{ type: Input }],
  646. display: [{ type: Input }],
  647. openChange: [{ type: Output }]
  648. };
  649. return NgbDropdown;
  650. }());
  651. export { NgbDropdown };
  652. if (false) {
  653. /**
  654. * @type {?}
  655. * @private
  656. */
  657. NgbDropdown.prototype._closed$;
  658. /**
  659. * @type {?}
  660. * @private
  661. */
  662. NgbDropdown.prototype._zoneSubscription;
  663. /**
  664. * @type {?}
  665. * @private
  666. */
  667. NgbDropdown.prototype._bodyContainer;
  668. /**
  669. * @type {?}
  670. * @private
  671. */
  672. NgbDropdown.prototype._menu;
  673. /**
  674. * @type {?}
  675. * @private
  676. */
  677. NgbDropdown.prototype._menuElement;
  678. /**
  679. * @type {?}
  680. * @private
  681. */
  682. NgbDropdown.prototype._anchor;
  683. /**
  684. * Indicates whether the dropdown should be closed when clicking one of dropdown items or pressing ESC.
  685. *
  686. * * `true` - the dropdown will close on both outside and inside (menu) clicks.
  687. * * `false` - the dropdown can only be closed manually via `close()` or `toggle()` methods.
  688. * * `"inside"` - the dropdown will close on inside menu clicks, but not outside clicks.
  689. * * `"outside"` - the dropdown will close only on the outside clicks and not on menu clicks.
  690. * @type {?}
  691. */
  692. NgbDropdown.prototype.autoClose;
  693. /**
  694. * Defines whether or not the dropdown menu is opened initially.
  695. * @type {?}
  696. */
  697. NgbDropdown.prototype._open;
  698. /**
  699. * The preferred placement of the dropdown.
  700. *
  701. * Possible values are `"top"`, `"top-left"`, `"top-right"`, `"bottom"`, `"bottom-left"`,
  702. * `"bottom-right"`, `"left"`, `"left-top"`, `"left-bottom"`, `"right"`, `"right-top"`,
  703. * `"right-bottom"`
  704. *
  705. * Accepts an array of strings or a string with space separated possible values.
  706. *
  707. * The default order of preference is `"bottom-left bottom-right top-left top-right"`
  708. *
  709. * Please see the [positioning overview](#/positioning) for more details.
  710. * @type {?}
  711. */
  712. NgbDropdown.prototype.placement;
  713. /**
  714. * A selector specifying the element the dropdown should be appended to.
  715. * Currently only supports "body".
  716. *
  717. * \@since 4.1.0
  718. * @type {?}
  719. */
  720. NgbDropdown.prototype.container;
  721. /**
  722. * Enable or disable the dynamic positioning. The default value is dynamic unless the dropdown is used
  723. * inside a Bootstrap navbar. If you need custom placement for a dropdown in a navbar, set it to
  724. * dynamic explicitly. See the [positioning of dropdown](#/positioning#dropdown)
  725. * and the [navbar demo](/#/components/dropdown/examples#navbar) for more details.
  726. *
  727. * \@since 4.2.0
  728. * @type {?}
  729. */
  730. NgbDropdown.prototype.display;
  731. /**
  732. * An event fired when the dropdown is opened or closed.
  733. *
  734. * The event payload is a `boolean`:
  735. * * `true` - the dropdown was opened
  736. * * `false` - the dropdown was closed
  737. * @type {?}
  738. */
  739. NgbDropdown.prototype.openChange;
  740. /**
  741. * @type {?}
  742. * @private
  743. */
  744. NgbDropdown.prototype._changeDetector;
  745. /**
  746. * @type {?}
  747. * @private
  748. */
  749. NgbDropdown.prototype._document;
  750. /**
  751. * @type {?}
  752. * @private
  753. */
  754. NgbDropdown.prototype._ngZone;
  755. /**
  756. * @type {?}
  757. * @private
  758. */
  759. NgbDropdown.prototype._elementRef;
  760. /**
  761. * @type {?}
  762. * @private
  763. */
  764. NgbDropdown.prototype._renderer;
  765. }
  766. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["dropdown/dropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  NgZone,\n  AfterContentInit,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  SimpleChanges,\n  Optional\n} from '@angular/core';\nimport {DOCUMENT} from '@angular/common';\nimport {fromEvent, Subject, Subscription} from 'rxjs';\nimport {take} from 'rxjs/operators';\n\nimport {Placement, PlacementArray, positionElements} from '../util/positioning';\nimport {ngbAutoClose} from '../util/autoclose';\nimport {Key} from '../util/key';\n\nimport {NgbDropdownConfig} from './dropdown-config';\n\n@Directive({selector: '.navbar'})\nexport class NgbNavbar {\n}\n\n/**\n * A directive you should put on a dropdown item to enable keyboard navigation.\n * Arrow keys will move focus between items marked with this directive.\n *\n * @since 4.1.0\n */\n@Directive({selector: '[ngbDropdownItem]', host: {'class': 'dropdown-item', '[class.disabled]': 'disabled'}})\nexport class NgbDropdownItem {\n  private _disabled = false;\n\n  @Input()\n  set disabled(value: boolean) {\n    this._disabled = <any>value === '' || value === true;  // accept an empty attribute as true\n  }\n\n  get disabled(): boolean { return this._disabled; }\n\n  constructor(public elementRef: ElementRef<HTMLElement>) {}\n}\n\n/**\n * A directive that wraps dropdown menu content and dropdown items.\n */\n@Directive({\n  selector: '[ngbDropdownMenu]',\n  host: {\n    '[class.dropdown-menu]': 'true',\n    '[class.show]': 'dropdown.isOpen()',\n    '[attr.x-placement]': 'placement',\n    '(keydown.ArrowUp)': 'dropdown.onKeyDown($event)',\n    '(keydown.ArrowDown)': 'dropdown.onKeyDown($event)',\n    '(keydown.Home)': 'dropdown.onKeyDown($event)',\n    '(keydown.End)': 'dropdown.onKeyDown($event)',\n    '(keydown.Enter)': 'dropdown.onKeyDown($event)',\n    '(keydown.Space)': 'dropdown.onKeyDown($event)'\n  }\n})\nexport class NgbDropdownMenu {\n  placement: Placement = 'bottom';\n  isOpen = false;\n\n  @ContentChildren(NgbDropdownItem) menuItems: QueryList<NgbDropdownItem>;\n\n  constructor(@Inject(forwardRef(() => NgbDropdown)) public dropdown) {}\n}\n\n/**\n * A directive to mark an element to which dropdown menu will be anchored.\n *\n * This is a simple version of the `NgbDropdownToggle` directive.\n * It plays the same role, but doesn't listen to click events to toggle dropdown menu thus enabling support\n * for events other than click.\n *\n * @since 1.1.0\n */\n@Directive({\n  selector: '[ngbDropdownAnchor]',\n  host: {'class': 'dropdown-toggle', 'aria-haspopup': 'true', '[attr.aria-expanded]': 'dropdown.isOpen()'}\n})\nexport class NgbDropdownAnchor {\n  anchorEl;\n\n  constructor(@Inject(forwardRef(() => NgbDropdown)) public dropdown, private _elementRef: ElementRef<HTMLElement>) {\n    this.anchorEl = _elementRef.nativeElement;\n  }\n\n  getNativeElement() { return this._elementRef.nativeElement; }\n}\n\n/**\n * A directive to mark an element that will toggle dropdown via the `click` event.\n *\n * You can also use `NgbDropdownAnchor` as an alternative.\n */\n@Directive({\n  selector: '[ngbDropdownToggle]',\n  host: {\n    'class': 'dropdown-toggle',\n    'aria-haspopup': 'true',\n    '[attr.aria-expanded]': 'dropdown.isOpen()',\n    '(click)': 'dropdown.toggle()',\n    '(keydown.ArrowUp)': 'dropdown.onKeyDown($event)',\n    '(keydown.ArrowDown)': 'dropdown.onKeyDown($event)',\n    '(keydown.Home)': 'dropdown.onKeyDown($event)',\n    '(keydown.End)': 'dropdown.onKeyDown($event)'\n  },\n  providers: [{provide: NgbDropdownAnchor, useExisting: forwardRef(() => NgbDropdownToggle)}]\n})\nexport class NgbDropdownToggle extends NgbDropdownAnchor {\n  constructor(@Inject(forwardRef(() => NgbDropdown)) dropdown, elementRef: ElementRef<HTMLElement>) {\n    super(dropdown, elementRef);\n  }\n}\n\n/**\n * A directive that provides contextual overlays for displaying lists of links and more.\n */\n@Directive({selector: '[ngbDropdown]', exportAs: 'ngbDropdown', host: {'[class.show]': 'isOpen()'}})\nexport class NgbDropdown implements AfterContentInit, OnDestroy {\n  private _closed$ = new Subject<void>();\n  private _zoneSubscription: Subscription;\n  private _bodyContainer: HTMLElement;\n\n  @ContentChild(NgbDropdownMenu, {static: false}) private _menu: NgbDropdownMenu;\n  @ContentChild(NgbDropdownMenu, {read: ElementRef, static: false}) private _menuElement: ElementRef;\n  @ContentChild(NgbDropdownAnchor, {static: false}) private _anchor: NgbDropdownAnchor;\n\n  /**\n   * Indicates whether the dropdown should be closed when clicking one of dropdown items or pressing ESC.\n   *\n   * * `true` - the dropdown will close on both outside and inside (menu) clicks.\n   * * `false` - the dropdown can only be closed manually via `close()` or `toggle()` methods.\n   * * `\"inside\"` - the dropdown will close on inside menu clicks, but not outside clicks.\n   * * `\"outside\"` - the dropdown will close only on the outside clicks and not on menu clicks.\n   */\n  @Input() autoClose: boolean | 'outside' | 'inside';\n\n  /**\n   * Defines whether or not the dropdown menu is opened initially.\n   */\n  @Input('open') _open = false;\n\n  /**\n   * The preferred placement of the dropdown.\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  * A selector specifying the element the dropdown should be appended to.\n  * Currently only supports \"body\".\n  *\n  * @since 4.1.0\n  */\n  @Input() container: null | 'body';\n\n  /**\n   * Enable or disable the dynamic positioning. The default value is dynamic unless the dropdown is used\n   * inside a Bootstrap navbar. If you need custom placement for a dropdown in a navbar, set it to\n   * dynamic explicitly. See the [positioning of dropdown](#/positioning#dropdown)\n   * and the [navbar demo](/#/components/dropdown/examples#navbar) for more details.\n   *\n   * @since 4.2.0\n   */\n  @Input() display: 'dynamic' | 'static';\n\n  /**\n   * An event fired when the dropdown is opened or closed.\n   *\n   * The event payload is a `boolean`:\n   * * `true` - the dropdown was opened\n   * * `false` - the dropdown was closed\n   */\n  @Output() openChange = new EventEmitter<boolean>();\n\n  constructor(\n      private _changeDetector: ChangeDetectorRef, config: NgbDropdownConfig, @Inject(DOCUMENT) private _document: any,\n      private _ngZone: NgZone, private _elementRef: ElementRef<HTMLElement>, private _renderer: Renderer2,\n      @Optional() ngbNavbar: NgbNavbar) {\n    this.placement = config.placement;\n    this.container = config.container;\n    this.autoClose = config.autoClose;\n\n    this.display = ngbNavbar ? 'static' : 'dynamic';\n\n    this._zoneSubscription = _ngZone.onStable.subscribe(() => { this._positionMenu(); });\n  }\n\n  ngAfterContentInit() {\n    this._ngZone.onStable.pipe(take(1)).subscribe(() => {\n      this._applyPlacementClasses();\n      if (this._open) {\n        this._setCloseHandlers();\n      }\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.container && this._open) {\n      this._applyContainer(this.container);\n    }\n\n    if (changes.placement && !changes.placement.isFirstChange) {\n      this._applyPlacementClasses();\n    }\n  }\n\n  /**\n   * Checks if the dropdown menu is open.\n   */\n  isOpen(): boolean { return this._open; }\n\n  /**\n   * Opens the dropdown menu.\n   */\n  open(): void {\n    if (!this._open) {\n      this._open = true;\n      this._applyContainer(this.container);\n      this.openChange.emit(true);\n      this._setCloseHandlers();\n    }\n  }\n\n  private _setCloseHandlers() {\n    const anchor = this._anchor;\n    ngbAutoClose(\n        this._ngZone, this._document, this.autoClose, () => this.close(), this._closed$,\n        this._menu ? [this._menuElement.nativeElement] : [], anchor ? [anchor.getNativeElement()] : [],\n        '.dropdown-item,.dropdown-divider');\n  }\n\n  /**\n   * Closes the dropdown menu.\n   */\n  close(): void {\n    if (this._open) {\n      this._open = false;\n      this._resetContainer();\n      this._closed$.next();\n      this.openChange.emit(false);\n      this._changeDetector.markForCheck();\n    }\n  }\n\n  /**\n   * Toggles the dropdown menu.\n   */\n  toggle(): void {\n    if (this.isOpen()) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  ngOnDestroy() {\n    this._resetContainer();\n\n    this._closed$.next();\n    this._zoneSubscription.unsubscribe();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    // tslint:disable-next-line:deprecation\n    const key = event.which;\n    const itemElements = this._getMenuElements();\n\n    let position = -1;\n    let isEventFromItems = false;\n    let itemElement: HTMLElement = null;\n    const isEventFromToggle = this._isEventFromToggle(event);\n\n    if (!isEventFromToggle && itemElements.length) {\n      itemElements.forEach((item, index) => {\n        if (item.contains(event.target as HTMLElement)) {\n          isEventFromItems = true;\n          itemElement = item;\n        }\n        if (item === this._document.activeElement) {\n          position = index;\n        }\n      });\n    }\n\n    // closing on Enter / Space\n    if (key === Key.Space || key === Key.Enter) {\n      if (isEventFromItems && (this.autoClose === true || this.autoClose === 'inside')) {\n        // Item is either a button or a link, so click will be triggered by the browser on Enter or Space.\n        // So we have to register a one-time click handler that will fire after any user defined click handlers\n        // to close the dropdown\n        fromEvent(itemElement, 'click').pipe(take(1)).subscribe(() => this.close());\n      }\n      return;\n    }\n\n    // opening / navigating\n    if (isEventFromToggle || isEventFromItems) {\n      this.open();\n\n      if (itemElements.length) {\n        switch (key) {\n          case Key.ArrowDown:\n            position = Math.min(position + 1, itemElements.length - 1);\n            break;\n          case Key.ArrowUp:\n            if (this._isDropup() && position === -1) {\n              position = itemElements.length - 1;\n              break;\n            }\n            position = Math.max(position - 1, 0);\n            break;\n          case Key.Home:\n            position = 0;\n            break;\n          case Key.End:\n            position = itemElements.length - 1;\n            break;\n        }\n        itemElements[position].focus();\n      }\n      event.preventDefault();\n    }\n  }\n\n  private _isDropup(): boolean { return this._elementRef.nativeElement.classList.contains('dropup'); }\n\n  private _isEventFromToggle(event: KeyboardEvent) {\n    return this._anchor.getNativeElement().contains(event.target as HTMLElement);\n  }\n\n  private _getMenuElements(): HTMLElement[] {\n    const menu = this._menu;\n    if (menu == null) {\n      return [];\n    }\n    return menu.menuItems.filter(item => !item.disabled).map(item => item.elementRef.nativeElement);\n  }\n\n  private _positionMenu() {\n    const menu = this._menu;\n    if (this.isOpen() && menu) {\n      this._applyPlacementClasses(\n          this.display === 'dynamic' ?\n              positionElements(\n                  this._anchor.anchorEl, this._bodyContainer || this._menuElement.nativeElement, this.placement,\n                  this.container === 'body') :\n              this._getFirstPlacement(this.placement));\n    }\n  }\n\n  private _getFirstPlacement(placement: PlacementArray): Placement {\n    return Array.isArray(placement) ? placement[0] : placement.split(' ')[0] as Placement;\n  }\n\n  private _resetContainer() {\n    const renderer = this._renderer;\n    const menuElement = this._menuElement;\n    if (menuElement) {\n      const dropdownElement = this._elementRef.nativeElement;\n      const dropdownMenuElement = menuElement.nativeElement;\n\n      renderer.appendChild(dropdownElement, dropdownMenuElement);\n      renderer.removeStyle(dropdownMenuElement, 'position');\n      renderer.removeStyle(dropdownMenuElement, 'transform');\n    }\n    if (this._bodyContainer) {\n      renderer.removeChild(this._document.body, this._bodyContainer);\n      this._bodyContainer = null;\n    }\n  }\n\n  private _applyContainer(container: null | 'body' = null) {\n    this._resetContainer();\n    if (container === 'body') {\n      const renderer = this._renderer;\n      const dropdownMenuElement = this._menuElement.nativeElement;\n      const bodyContainer = this._bodyContainer = this._bodyContainer || renderer.createElement('div');\n\n      // Override some styles to have the positionning working\n      renderer.setStyle(bodyContainer, 'position', 'absolute');\n      renderer.setStyle(dropdownMenuElement, 'position', 'static');\n      renderer.setStyle(bodyContainer, 'z-index', '1050');\n\n      renderer.appendChild(bodyContainer, dropdownMenuElement);\n      renderer.appendChild(this._document.body, bodyContainer);\n    }\n  }\n\n  private _applyPlacementClasses(placement?: Placement) {\n    const menu = this._menu;\n    if (menu) {\n      if (!placement) {\n        placement = this._getFirstPlacement(this.placement);\n      }\n\n      const renderer = this._renderer;\n      const dropdownElement = this._elementRef.nativeElement;\n\n      // remove the current placement classes\n      renderer.removeClass(dropdownElement, 'dropup');\n      renderer.removeClass(dropdownElement, 'dropdown');\n      menu.placement = this.display === 'static' ? null : placement;\n\n      /*\n      * apply the new placement\n      * in case of top use up-arrow or down-arrow otherwise\n      */\n      const dropdownClass = placement.search('^top') !== -1 ? 'dropup' : 'dropdown';\n      renderer.addClass(dropdownElement, dropdownClass);\n\n      const bodyContainer = this._bodyContainer;\n      if (bodyContainer) {\n        renderer.removeClass(bodyContainer, 'dropup');\n        renderer.removeClass(bodyContainer, 'dropdown');\n        renderer.addClass(bodyContainer, dropdownClass);\n      }\n    }\n  }\n}\n"]}