component-loader.class.js 46 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. // tslint:disable:max-file-line-count
  6. // todo: add delay support
  7. // todo: merge events onShow, onShown, etc...
  8. // todo: add global positioning configuration?
  9. import { ElementRef, EventEmitter, Injector, TemplateRef } from '@angular/core';
  10. import { listenToTriggersV2, registerEscClick, registerOutsideClick } from 'ngx-bootstrap/utils';
  11. import { ContentRef } from './content-ref.class';
  12. /**
  13. * @template T
  14. */
  15. var /**
  16. * @template T
  17. */
  18. ComponentLoader = /** @class */ (function () {
  19. /**
  20. * Do not use this directly, it should be instanced via
  21. * `ComponentLoadFactory.attach`
  22. * @internal
  23. */
  24. // tslint:disable-next-line
  25. function ComponentLoader(_viewContainerRef, _renderer, _elementRef, _injector, _componentFactoryResolver, _ngZone, _applicationRef, _posService) {
  26. this._viewContainerRef = _viewContainerRef;
  27. this._renderer = _renderer;
  28. this._elementRef = _elementRef;
  29. this._injector = _injector;
  30. this._componentFactoryResolver = _componentFactoryResolver;
  31. this._ngZone = _ngZone;
  32. this._applicationRef = _applicationRef;
  33. this._posService = _posService;
  34. this.onBeforeShow = new EventEmitter();
  35. /* tslint:disable-next-line: no-any*/
  36. this.onShown = new EventEmitter();
  37. /* tslint:disable-next-line: no-any*/
  38. this.onBeforeHide = new EventEmitter();
  39. this.onHidden = new EventEmitter();
  40. this._providers = [];
  41. this._isHiding = false;
  42. /**
  43. * A selector used if container element was not found
  44. */
  45. this.containerDefaultSelector = 'body';
  46. this._listenOpts = {};
  47. this._globalListener = Function.prototype;
  48. }
  49. Object.defineProperty(ComponentLoader.prototype, "isShown", {
  50. get: /**
  51. * @return {?}
  52. */
  53. function () {
  54. if (this._isHiding) {
  55. return false;
  56. }
  57. return !!this._componentRef;
  58. },
  59. enumerable: true,
  60. configurable: true
  61. });
  62. /**
  63. * @param {?} compType
  64. * @return {?}
  65. */
  66. ComponentLoader.prototype.attach = /**
  67. * @param {?} compType
  68. * @return {?}
  69. */
  70. function (compType) {
  71. this._componentFactory = this._componentFactoryResolver
  72. .resolveComponentFactory(compType);
  73. return this;
  74. };
  75. // todo: add behaviour: to target element, `body`, custom element
  76. // todo: add behaviour: to target element, `body`, custom element
  77. /**
  78. * @param {?=} container
  79. * @return {?}
  80. */
  81. ComponentLoader.prototype.to =
  82. // todo: add behaviour: to target element, `body`, custom element
  83. /**
  84. * @param {?=} container
  85. * @return {?}
  86. */
  87. function (container) {
  88. this.container = container || this.container;
  89. return this;
  90. };
  91. /**
  92. * @param {?=} opts
  93. * @return {?}
  94. */
  95. ComponentLoader.prototype.position = /**
  96. * @param {?=} opts
  97. * @return {?}
  98. */
  99. function (opts) {
  100. this.attachment = opts.attachment || this.attachment;
  101. /* tslint:disable-next-line: no-unnecessary-type-assertion */
  102. this._elementRef = ((/** @type {?} */ (opts.target))) || this._elementRef;
  103. return this;
  104. };
  105. /**
  106. * @param {?} provider
  107. * @return {?}
  108. */
  109. ComponentLoader.prototype.provide = /**
  110. * @param {?} provider
  111. * @return {?}
  112. */
  113. function (provider) {
  114. this._providers.push(provider);
  115. return this;
  116. };
  117. // todo: appendChild to element or document.querySelector(this.container)
  118. // todo: appendChild to element or document.querySelector(this.container)
  119. /**
  120. * @param {?=} opts
  121. * @return {?}
  122. */
  123. ComponentLoader.prototype.show =
  124. // todo: appendChild to element or document.querySelector(this.container)
  125. /**
  126. * @param {?=} opts
  127. * @return {?}
  128. */
  129. function (opts) {
  130. if (opts === void 0) { opts = {}; }
  131. this._subscribePositioning();
  132. this._innerComponent = null;
  133. if (!this._componentRef) {
  134. this.onBeforeShow.emit();
  135. this._contentRef = this._getContentRef(opts.content, opts.context, opts.initialState);
  136. /** @type {?} */
  137. var injector = Injector.create({
  138. providers: this._providers,
  139. parent: this._injector
  140. });
  141. this._componentRef = this._componentFactory.create(injector, this._contentRef.nodes);
  142. this._applicationRef.attachView(this._componentRef.hostView);
  143. // this._componentRef = this._viewContainerRef
  144. // .createComponent(this._componentFactory, 0, injector, this._contentRef.nodes);
  145. this.instance = this._componentRef.instance;
  146. Object.assign(this._componentRef.instance, opts);
  147. if (this.container instanceof ElementRef) {
  148. this.container.nativeElement.appendChild(this._componentRef.location.nativeElement);
  149. }
  150. if (typeof this.container === 'string' && typeof document !== 'undefined') {
  151. /** @type {?} */
  152. var selectedElement = document.querySelector(this.container) ||
  153. document.querySelector(this.containerDefaultSelector);
  154. selectedElement.appendChild(this._componentRef.location.nativeElement);
  155. }
  156. if (!this.container &&
  157. this._elementRef &&
  158. this._elementRef.nativeElement.parentElement) {
  159. this._elementRef.nativeElement.parentElement.appendChild(this._componentRef.location.nativeElement);
  160. }
  161. // we need to manually invoke change detection since events registered
  162. // via
  163. // Renderer::listen() are not picked up by change detection with the
  164. // OnPush strategy
  165. if (this._contentRef.componentRef) {
  166. this._innerComponent = this._contentRef.componentRef.instance;
  167. this._contentRef.componentRef.changeDetectorRef.markForCheck();
  168. this._contentRef.componentRef.changeDetectorRef.detectChanges();
  169. }
  170. this._componentRef.changeDetectorRef.markForCheck();
  171. this._componentRef.changeDetectorRef.detectChanges();
  172. this.onShown.emit(this._componentRef.instance);
  173. }
  174. this._registerOutsideClick();
  175. return this._componentRef;
  176. };
  177. /**
  178. * @return {?}
  179. */
  180. ComponentLoader.prototype.hide = /**
  181. * @return {?}
  182. */
  183. function () {
  184. if (!this._componentRef) {
  185. return this;
  186. }
  187. this._posService.deletePositionElement(this._componentRef.location);
  188. this.onBeforeHide.emit(this._componentRef.instance);
  189. /** @type {?} */
  190. var componentEl = this._componentRef.location.nativeElement;
  191. componentEl.parentNode.removeChild(componentEl);
  192. if (this._contentRef.componentRef) {
  193. this._contentRef.componentRef.destroy();
  194. }
  195. this._componentRef.destroy();
  196. if (this._viewContainerRef && this._contentRef.viewRef) {
  197. this._viewContainerRef.remove(this._viewContainerRef.indexOf(this._contentRef.viewRef));
  198. }
  199. if (this._contentRef.viewRef) {
  200. this._contentRef.viewRef.destroy();
  201. }
  202. this._contentRef = null;
  203. this._componentRef = null;
  204. this._removeGlobalListener();
  205. this.onHidden.emit();
  206. return this;
  207. };
  208. /**
  209. * @return {?}
  210. */
  211. ComponentLoader.prototype.toggle = /**
  212. * @return {?}
  213. */
  214. function () {
  215. if (this.isShown) {
  216. this.hide();
  217. return;
  218. }
  219. this.show();
  220. };
  221. /**
  222. * @return {?}
  223. */
  224. ComponentLoader.prototype.dispose = /**
  225. * @return {?}
  226. */
  227. function () {
  228. if (this.isShown) {
  229. this.hide();
  230. }
  231. this._unsubscribePositioning();
  232. if (this._unregisterListenersFn) {
  233. this._unregisterListenersFn();
  234. }
  235. };
  236. /**
  237. * @param {?} listenOpts
  238. * @return {?}
  239. */
  240. ComponentLoader.prototype.listen = /**
  241. * @param {?} listenOpts
  242. * @return {?}
  243. */
  244. function (listenOpts) {
  245. var _this = this;
  246. this.triggers = listenOpts.triggers || this.triggers;
  247. this._listenOpts.outsideClick = listenOpts.outsideClick;
  248. this._listenOpts.outsideEsc = listenOpts.outsideEsc;
  249. listenOpts.target = listenOpts.target || this._elementRef.nativeElement;
  250. /** @type {?} */
  251. var hide = (this._listenOpts.hide = (/**
  252. * @return {?}
  253. */
  254. function () {
  255. return listenOpts.hide ? listenOpts.hide() : void _this.hide();
  256. }));
  257. /** @type {?} */
  258. var show = (this._listenOpts.show = (/**
  259. * @param {?} registerHide
  260. * @return {?}
  261. */
  262. function (registerHide) {
  263. listenOpts.show ? listenOpts.show(registerHide) : _this.show(registerHide);
  264. registerHide();
  265. }));
  266. /** @type {?} */
  267. var toggle = (/**
  268. * @param {?} registerHide
  269. * @return {?}
  270. */
  271. function (registerHide) {
  272. _this.isShown ? hide() : show(registerHide);
  273. });
  274. this._unregisterListenersFn = listenToTriggersV2(this._renderer, {
  275. target: listenOpts.target,
  276. triggers: listenOpts.triggers,
  277. show: show,
  278. hide: hide,
  279. toggle: toggle
  280. });
  281. return this;
  282. };
  283. /**
  284. * @return {?}
  285. */
  286. ComponentLoader.prototype._removeGlobalListener = /**
  287. * @return {?}
  288. */
  289. function () {
  290. if (this._globalListener) {
  291. this._globalListener();
  292. this._globalListener = null;
  293. }
  294. };
  295. /**
  296. * @param {?} vRef
  297. * @param {?} template
  298. * @return {?}
  299. */
  300. ComponentLoader.prototype.attachInline = /**
  301. * @param {?} vRef
  302. * @param {?} template
  303. * @return {?}
  304. */
  305. function (vRef,
  306. /* tslint:disable-next-line: no-any*/
  307. template) {
  308. this._inlineViewRef = vRef.createEmbeddedView(template);
  309. return this;
  310. };
  311. /**
  312. * @return {?}
  313. */
  314. ComponentLoader.prototype._registerOutsideClick = /**
  315. * @return {?}
  316. */
  317. function () {
  318. var _this = this;
  319. if (!this._componentRef || !this._componentRef.location) {
  320. return;
  321. }
  322. // why: should run after first event bubble
  323. if (this._listenOpts.outsideClick) {
  324. /** @type {?} */
  325. var target_1 = this._componentRef.location.nativeElement;
  326. setTimeout((/**
  327. * @return {?}
  328. */
  329. function () {
  330. _this._globalListener = registerOutsideClick(_this._renderer, {
  331. targets: [target_1, _this._elementRef.nativeElement],
  332. outsideClick: _this._listenOpts.outsideClick,
  333. hide: (/**
  334. * @return {?}
  335. */
  336. function () { return _this._listenOpts.hide(); })
  337. });
  338. }));
  339. }
  340. if (this._listenOpts.outsideEsc) {
  341. /** @type {?} */
  342. var target = this._componentRef.location.nativeElement;
  343. this._globalListener = registerEscClick(this._renderer, {
  344. targets: [target, this._elementRef.nativeElement],
  345. outsideEsc: this._listenOpts.outsideEsc,
  346. hide: (/**
  347. * @return {?}
  348. */
  349. function () { return _this._listenOpts.hide(); })
  350. });
  351. }
  352. };
  353. /**
  354. * @return {?}
  355. */
  356. ComponentLoader.prototype.getInnerComponent = /**
  357. * @return {?}
  358. */
  359. function () {
  360. return this._innerComponent;
  361. };
  362. /**
  363. * @private
  364. * @return {?}
  365. */
  366. ComponentLoader.prototype._subscribePositioning = /**
  367. * @private
  368. * @return {?}
  369. */
  370. function () {
  371. var _this = this;
  372. if (this._zoneSubscription || !this.attachment) {
  373. return;
  374. }
  375. this.onShown.subscribe((/**
  376. * @return {?}
  377. */
  378. function () {
  379. _this._posService.position({
  380. element: _this._componentRef.location,
  381. target: _this._elementRef,
  382. attachment: _this.attachment,
  383. appendToBody: _this.container === 'body'
  384. });
  385. }));
  386. this._zoneSubscription = this._ngZone.onStable.subscribe((/**
  387. * @return {?}
  388. */
  389. function () {
  390. if (!_this._componentRef) {
  391. return;
  392. }
  393. _this._posService.calcPosition();
  394. }));
  395. };
  396. /**
  397. * @private
  398. * @return {?}
  399. */
  400. ComponentLoader.prototype._unsubscribePositioning = /**
  401. * @private
  402. * @return {?}
  403. */
  404. function () {
  405. if (!this._zoneSubscription) {
  406. return;
  407. }
  408. this._zoneSubscription.unsubscribe();
  409. this._zoneSubscription = null;
  410. };
  411. /**
  412. * @private
  413. * @param {?} content
  414. * @param {?=} context
  415. * @param {?=} initialState
  416. * @return {?}
  417. */
  418. ComponentLoader.prototype._getContentRef = /**
  419. * @private
  420. * @param {?} content
  421. * @param {?=} context
  422. * @param {?=} initialState
  423. * @return {?}
  424. */
  425. function (
  426. /* tslint:disable-next-line: no-any*/
  427. content,
  428. /* tslint:disable-next-line: no-any*/
  429. context,
  430. /* tslint:disable-next-line: no-any*/
  431. initialState) {
  432. if (!content) {
  433. return new ContentRef([]);
  434. }
  435. if (content instanceof TemplateRef) {
  436. if (this._viewContainerRef) {
  437. /** @type {?} */
  438. var _viewRef = this._viewContainerRef
  439. .createEmbeddedView(content, context);
  440. _viewRef.markForCheck();
  441. return new ContentRef([_viewRef.rootNodes], _viewRef);
  442. }
  443. /** @type {?} */
  444. var viewRef = content.createEmbeddedView({});
  445. this._applicationRef.attachView(viewRef);
  446. return new ContentRef([viewRef.rootNodes], viewRef);
  447. }
  448. if (typeof content === 'function') {
  449. /** @type {?} */
  450. var contentCmptFactory = this._componentFactoryResolver.resolveComponentFactory(content);
  451. /** @type {?} */
  452. var modalContentInjector = Injector.create({
  453. providers: this._providers,
  454. parent: this._injector
  455. });
  456. /** @type {?} */
  457. var componentRef = contentCmptFactory.create(modalContentInjector);
  458. Object.assign(componentRef.instance, initialState);
  459. this._applicationRef.attachView(componentRef.hostView);
  460. return new ContentRef([[componentRef.location.nativeElement]], componentRef.hostView, componentRef);
  461. }
  462. return new ContentRef([[this._renderer.createText("" + content)]]);
  463. };
  464. return ComponentLoader;
  465. }());
  466. /**
  467. * @template T
  468. */
  469. export { ComponentLoader };
  470. if (false) {
  471. /** @type {?} */
  472. ComponentLoader.prototype.onBeforeShow;
  473. /** @type {?} */
  474. ComponentLoader.prototype.onShown;
  475. /** @type {?} */
  476. ComponentLoader.prototype.onBeforeHide;
  477. /** @type {?} */
  478. ComponentLoader.prototype.onHidden;
  479. /** @type {?} */
  480. ComponentLoader.prototype.instance;
  481. /** @type {?} */
  482. ComponentLoader.prototype._componentRef;
  483. /** @type {?} */
  484. ComponentLoader.prototype._inlineViewRef;
  485. /**
  486. * @type {?}
  487. * @private
  488. */
  489. ComponentLoader.prototype._providers;
  490. /**
  491. * @type {?}
  492. * @private
  493. */
  494. ComponentLoader.prototype._componentFactory;
  495. /**
  496. * @type {?}
  497. * @private
  498. */
  499. ComponentLoader.prototype._zoneSubscription;
  500. /**
  501. * @type {?}
  502. * @private
  503. */
  504. ComponentLoader.prototype._contentRef;
  505. /**
  506. * @type {?}
  507. * @private
  508. */
  509. ComponentLoader.prototype._innerComponent;
  510. /**
  511. * @type {?}
  512. * @private
  513. */
  514. ComponentLoader.prototype._unregisterListenersFn;
  515. /**
  516. * @type {?}
  517. * @private
  518. */
  519. ComponentLoader.prototype._isHiding;
  520. /**
  521. * Placement of a component. Accepts: "top", "bottom", "left", "right"
  522. * @type {?}
  523. * @private
  524. */
  525. ComponentLoader.prototype.attachment;
  526. /**
  527. * A selector specifying the element the popover should be appended to.
  528. * @type {?}
  529. * @private
  530. */
  531. ComponentLoader.prototype.container;
  532. /**
  533. * A selector used if container element was not found
  534. * @type {?}
  535. * @private
  536. */
  537. ComponentLoader.prototype.containerDefaultSelector;
  538. /**
  539. * Specifies events that should trigger. Supports a space separated list of
  540. * event names.
  541. * @type {?}
  542. * @private
  543. */
  544. ComponentLoader.prototype.triggers;
  545. /**
  546. * @type {?}
  547. * @private
  548. */
  549. ComponentLoader.prototype._listenOpts;
  550. /**
  551. * @type {?}
  552. * @private
  553. */
  554. ComponentLoader.prototype._globalListener;
  555. /**
  556. * @type {?}
  557. * @private
  558. */
  559. ComponentLoader.prototype._viewContainerRef;
  560. /**
  561. * @type {?}
  562. * @private
  563. */
  564. ComponentLoader.prototype._renderer;
  565. /**
  566. * @type {?}
  567. * @private
  568. */
  569. ComponentLoader.prototype._elementRef;
  570. /**
  571. * @type {?}
  572. * @private
  573. */
  574. ComponentLoader.prototype._injector;
  575. /**
  576. * @type {?}
  577. * @private
  578. */
  579. ComponentLoader.prototype._componentFactoryResolver;
  580. /**
  581. * @type {?}
  582. * @private
  583. */
  584. ComponentLoader.prototype._ngZone;
  585. /**
  586. * @type {?}
  587. * @private
  588. */
  589. ComponentLoader.prototype._applicationRef;
  590. /**
  591. * @type {?}
  592. * @private
  593. */
  594. ComponentLoader.prototype._posService;
  595. }
  596. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component-loader.class.js","sourceRoot":"ng://ngx-bootstrap/component-loader/","sources":["component-loader.class.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:max-file-line-count\n// todo: add delay support\n// todo: merge events onShow, onShown, etc...\n// todo: add global positioning configuration?\nimport {\n  ApplicationRef,\n  ComponentFactory,\n  ComponentFactoryResolver,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  EventEmitter,\n  Injector,\n  NgZone,\n  Renderer2,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewContainerRef\n} from '@angular/core';\n\nimport { PositioningOptions, PositioningService } from 'ngx-bootstrap/positioning';\n\nimport {\n  listenToTriggersV2,\n  registerEscClick,\n  registerOutsideClick\n} from 'ngx-bootstrap/utils';\n\nimport { ContentRef } from './content-ref.class';\nimport { ListenOptions } from './listen-options.model';\nimport { Subscription } from 'rxjs';\n\nexport class ComponentLoader<T> {\n  onBeforeShow: EventEmitter<void> = new EventEmitter();\n  /* tslint:disable-next-line: no-any*/\n  onShown: EventEmitter<any> = new EventEmitter();\n  /* tslint:disable-next-line: no-any*/\n  onBeforeHide: EventEmitter<any> = new EventEmitter();\n  onHidden: EventEmitter<boolean> = new EventEmitter();\n\n  instance: T;\n  _componentRef: ComponentRef<T>;\n  _inlineViewRef: EmbeddedViewRef<T>;\n\n  private _providers: StaticProvider[] = [];\n  private _componentFactory: ComponentFactory<T>;\n  private _zoneSubscription: Subscription;\n  private _contentRef: ContentRef;\n  private _innerComponent: ComponentRef<T>;\n\n  private _unregisterListenersFn: Function;\n\n  get isShown(): boolean {\n    if (this._isHiding) {\n      return false;\n    }\n\n    return !!this._componentRef;\n  }\n\n  private _isHiding = false;\n\n  /**\n   * Placement of a component. Accepts: \"top\", \"bottom\", \"left\", \"right\"\n   */\n  private attachment: string;\n\n  /**\n   * A selector specifying the element the popover should be appended to.\n   */\n  /* tslint:disable-next-line: no-any*/\n  private container: string | ElementRef | any;\n\n  /**\n   * A selector used if container element was not found\n   */\n  private containerDefaultSelector = 'body';\n\n  /**\n   * Specifies events that should trigger. Supports a space separated list of\n   * event names.\n   */\n  private triggers: string;\n\n  private _listenOpts: ListenOptions = {};\n  private _globalListener = Function.prototype;\n\n  /**\n   * Do not use this directly, it should be instanced via\n   * `ComponentLoadFactory.attach`\n   * @internal\n   */\n  // tslint:disable-next-line\n  public constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _renderer: Renderer2,\n    private _elementRef: ElementRef,\n    private _injector: Injector,\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _ngZone: NgZone,\n    private _applicationRef: ApplicationRef,\n    private _posService: PositioningService\n  ) {}\n\n  attach(compType: Type<T>): ComponentLoader<T> {\n    this._componentFactory = this._componentFactoryResolver\n      .resolveComponentFactory<T>(compType);\n\n    return this;\n  }\n\n  // todo: add behaviour: to target element, `body`, custom element\n  to(container?: string | ElementRef): ComponentLoader<T> {\n    this.container = container || this.container;\n\n    return this;\n  }\n\n  position(opts?: PositioningOptions): ComponentLoader<T> {\n    this.attachment = opts.attachment || this.attachment;\n    /* tslint:disable-next-line: no-unnecessary-type-assertion */\n    this._elementRef = (opts.target as ElementRef) || this._elementRef;\n\n    return this;\n  }\n\n  provide(provider: StaticProvider): ComponentLoader<T> {\n    this._providers.push(provider);\n\n    return this;\n  }\n\n  // todo: appendChild to element or document.querySelector(this.container)\n\n  show(opts: {\n    /* tslint:disable-next-line: no-any*/\n    content?: string | TemplateRef<any>;\n    /* tslint:disable-next-line: no-any*/\n    context?: any;\n    /* tslint:disable-next-line: no-any*/\n    initialState?: any;\n    /* tslint:disable-next-line: no-any*/\n    [key: string]: any;\n  } = {}\n  ): ComponentRef<T> {\n\n    this._subscribePositioning();\n    this._innerComponent = null;\n\n    if (!this._componentRef) {\n      this.onBeforeShow.emit();\n      this._contentRef = this._getContentRef(opts.content, opts.context, opts.initialState);\n\n      const injector = Injector.create({\n        providers: this._providers,\n        parent: this._injector\n      });\n\n      this._componentRef = this._componentFactory.create(injector, this._contentRef.nodes);\n\n      this._applicationRef.attachView(this._componentRef.hostView);\n      // this._componentRef = this._viewContainerRef\n      //   .createComponent(this._componentFactory, 0, injector, this._contentRef.nodes);\n      this.instance = this._componentRef.instance;\n\n      Object.assign(this._componentRef.instance, opts);\n\n      if (this.container instanceof ElementRef) {\n        this.container.nativeElement.appendChild(\n          this._componentRef.location.nativeElement\n        );\n      }\n\n      if (typeof this.container === 'string' && typeof document !== 'undefined') {\n        const selectedElement = document.querySelector(this.container) ||\n                                document.querySelector(this.containerDefaultSelector);\n\n        selectedElement.appendChild(this._componentRef.location.nativeElement);\n      }\n\n      if (\n        !this.container &&\n        this._elementRef &&\n        this._elementRef.nativeElement.parentElement\n      ) {\n        this._elementRef.nativeElement.parentElement.appendChild(\n          this._componentRef.location.nativeElement\n        );\n      }\n\n      // we need to manually invoke change detection since events registered\n      // via\n      // Renderer::listen() are not picked up by change detection with the\n      // OnPush strategy\n      if (this._contentRef.componentRef) {\n        this._innerComponent = this._contentRef.componentRef.instance;\n        this._contentRef.componentRef.changeDetectorRef.markForCheck();\n        this._contentRef.componentRef.changeDetectorRef.detectChanges();\n      }\n      this._componentRef.changeDetectorRef.markForCheck();\n      this._componentRef.changeDetectorRef.detectChanges();\n      this.onShown.emit(this._componentRef.instance);\n    }\n\n    this._registerOutsideClick();\n\n    return this._componentRef;\n  }\n\n  hide(): ComponentLoader<T> {\n    if (!this._componentRef) {\n      return this;\n    }\n\n    this._posService.deletePositionElement(this._componentRef.location);\n\n    this.onBeforeHide.emit(this._componentRef.instance);\n\n    const componentEl = this._componentRef.location.nativeElement;\n    componentEl.parentNode.removeChild(componentEl);\n    if (this._contentRef.componentRef) {\n      this._contentRef.componentRef.destroy();\n    }\n    this._componentRef.destroy();\n    if (this._viewContainerRef && this._contentRef.viewRef) {\n      this._viewContainerRef.remove(\n        this._viewContainerRef.indexOf(this._contentRef.viewRef)\n      );\n    }\n    if (this._contentRef.viewRef) {\n      this._contentRef.viewRef.destroy();\n    }\n\n    this._contentRef = null;\n    this._componentRef = null;\n    this._removeGlobalListener();\n\n    this.onHidden.emit();\n\n    return this;\n  }\n\n  toggle(): void {\n    if (this.isShown) {\n      this.hide();\n\n      return;\n    }\n\n    this.show();\n  }\n\n  dispose(): void {\n    if (this.isShown) {\n      this.hide();\n    }\n\n    this._unsubscribePositioning();\n\n    if (this._unregisterListenersFn) {\n      this._unregisterListenersFn();\n    }\n  }\n\n  listen(listenOpts: ListenOptions): ComponentLoader<T> {\n    this.triggers = listenOpts.triggers || this.triggers;\n    this._listenOpts.outsideClick = listenOpts.outsideClick;\n    this._listenOpts.outsideEsc = listenOpts.outsideEsc;\n    listenOpts.target = listenOpts.target || this._elementRef.nativeElement;\n\n    const hide = (this._listenOpts.hide = () =>\n      listenOpts.hide ? listenOpts.hide() : void this.hide());\n    const show = (this._listenOpts.show = (registerHide: Function) => {\n      listenOpts.show ? listenOpts.show(registerHide) : this.show(registerHide);\n      registerHide();\n    });\n\n    const toggle = (registerHide: Function) => {\n      this.isShown ? hide() : show(registerHide);\n    };\n\n    this._unregisterListenersFn = listenToTriggersV2(this._renderer, {\n      target: listenOpts.target,\n      triggers: listenOpts.triggers,\n      show,\n      hide,\n      toggle\n    });\n\n    return this;\n  }\n\n  _removeGlobalListener() {\n    if (this._globalListener) {\n      this._globalListener();\n      this._globalListener = null;\n    }\n  }\n\n  attachInline(\n    vRef: ViewContainerRef,\n    /* tslint:disable-next-line: no-any*/\n    template: TemplateRef<any>\n  ): ComponentLoader<T> {\n    this._inlineViewRef = vRef.createEmbeddedView(template);\n\n    return this;\n  }\n\n  _registerOutsideClick(): void {\n    if (!this._componentRef || !this._componentRef.location) {\n      return;\n    }\n    // why: should run after first event bubble\n    if (this._listenOpts.outsideClick) {\n      const target = this._componentRef.location.nativeElement;\n      setTimeout(() => {\n        this._globalListener = registerOutsideClick(this._renderer, {\n          targets: [target, this._elementRef.nativeElement],\n          outsideClick: this._listenOpts.outsideClick,\n          hide: () => this._listenOpts.hide()\n        });\n      });\n    }\n    if (this._listenOpts.outsideEsc) {\n      const target = this._componentRef.location.nativeElement;\n      this._globalListener = registerEscClick(this._renderer, {\n        targets: [target, this._elementRef.nativeElement],\n        outsideEsc: this._listenOpts.outsideEsc,\n        hide: () => this._listenOpts.hide()\n      });\n    }\n  }\n\n  getInnerComponent(): ComponentRef<T> {\n    return this._innerComponent;\n  }\n\n  private _subscribePositioning(): void {\n    if (this._zoneSubscription || !this.attachment) {\n      return;\n    }\n\n    this.onShown.subscribe(() => {\n      this._posService.position({\n        element: this._componentRef.location,\n        target: this._elementRef,\n        attachment: this.attachment,\n        appendToBody: this.container === 'body'\n      });\n    });\n\n    this._zoneSubscription = this._ngZone.onStable.subscribe(() => {\n      if (!this._componentRef) {\n        return;\n      }\n\n      this._posService.calcPosition();\n    });\n  }\n\n  private _unsubscribePositioning(): void {\n    if (!this._zoneSubscription) {\n      return;\n    }\n\n    this._zoneSubscription.unsubscribe();\n    this._zoneSubscription = null;\n  }\n\n  private _getContentRef(\n    /* tslint:disable-next-line: no-any*/\n    content: string | TemplateRef<any> | any,\n    /* tslint:disable-next-line: no-any*/\n    context?: any,\n    /* tslint:disable-next-line: no-any*/\n    initialState?: any\n  ): ContentRef {\n    if (!content) {\n      return new ContentRef([]);\n    }\n\n    if (content instanceof TemplateRef) {\n      if (this._viewContainerRef) {\n        const _viewRef = this._viewContainerRef\n          .createEmbeddedView<TemplateRef<T>>(content, context);\n        _viewRef.markForCheck();\n\n        return new ContentRef([_viewRef.rootNodes], _viewRef);\n      }\n      const viewRef = content.createEmbeddedView({});\n      this._applicationRef.attachView(viewRef);\n\n      return new ContentRef([viewRef.rootNodes], viewRef);\n    }\n\n    if (typeof content === 'function') {\n      const contentCmptFactory = this._componentFactoryResolver.resolveComponentFactory(\n        content\n      );\n\n      const modalContentInjector = Injector.create({\n        providers: this._providers,\n        parent: this._injector\n      });\n\n      const componentRef = contentCmptFactory.create(modalContentInjector);\n      Object.assign(componentRef.instance, initialState);\n      this._applicationRef.attachView(componentRef.hostView);\n\n      return new ContentRef(\n        [[componentRef.location.nativeElement]],\n        componentRef.hostView,\n        componentRef\n      );\n    }\n\n    return new ContentRef([[this._renderer.createText(`${content}`)]]);\n  }\n}\n"]}