dialog-wrapper.component.js 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. "use strict";
  2. var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
  3. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  4. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  5. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  6. return c > 3 && r && Object.defineProperty(target, key, r), r;
  7. };
  8. var __metadata = (this && this.__metadata) || function (k, v) {
  9. if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
  10. };
  11. Object.defineProperty(exports, "__esModule", { value: true });
  12. var core_1 = require("@angular/core");
  13. var dialog_service_1 = require("./dialog.service");
  14. var DialogWrapperComponent = (function () {
  15. function DialogWrapperComponent(resolver, dialogService) {
  16. this.resolver = resolver;
  17. this.dialogService = dialogService;
  18. }
  19. DialogWrapperComponent.prototype.addComponent = function (component) {
  20. var factory = this.resolver.resolveComponentFactory(component);
  21. var injector = core_1.ReflectiveInjector.fromResolvedProviders([], this.element.injector);
  22. var componentRef = factory.create(injector);
  23. this.element.insert(componentRef.hostView);
  24. this.content = componentRef.instance;
  25. this.content.wrapper = this;
  26. return this.content;
  27. };
  28. DialogWrapperComponent.prototype.closeByClickOutside = function () {
  29. var _this = this;
  30. var containerEl = this.container.nativeElement;
  31. containerEl.querySelector('.modal-content').addEventListener('click', function (event) {
  32. event.stopPropagation();
  33. });
  34. containerEl.addEventListener('click', function () {
  35. _this.dialogService.removeDialog(_this.content);
  36. }, false);
  37. };
  38. return DialogWrapperComponent;
  39. }());
  40. __decorate([
  41. core_1.ViewChild('element', { read: core_1.ViewContainerRef }),
  42. __metadata("design:type", core_1.ViewContainerRef)
  43. ], DialogWrapperComponent.prototype, "element", void 0);
  44. __decorate([
  45. core_1.ViewChild('container'),
  46. __metadata("design:type", Object)
  47. ], DialogWrapperComponent.prototype, "container", void 0);
  48. DialogWrapperComponent = __decorate([
  49. core_1.Component({
  50. selector: 'dialog-wrapper',
  51. template: "\n <div #container class=\"modal fade\" style=\"display:block !important;\" role=\"dialog\">\n <template #element></template>\n </div>\n"
  52. }),
  53. __metadata("design:paramtypes", [core_1.ComponentFactoryResolver, dialog_service_1.DialogService])
  54. ], DialogWrapperComponent);
  55. exports.DialogWrapperComponent = DialogWrapperComponent;
  56. //# sourceMappingURL=dialog-wrapper.component.js.map