@magic-xpa/angular 4.800.0 → 4.801.0-dev000.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/esm2020/index.mjs +57 -0
  2. package/{esm2015/magic-xpa-angular.js → esm2020/magic-xpa-angular.mjs} +0 -0
  3. package/esm2020/src/controls.metadata.model.mjs +180 -0
  4. package/{esm2015/src/interfaces/sub-form-definition.iterface.js → esm2020/src/interfaces/sub-form-definition.iterface.mjs} +1 -0
  5. package/esm2020/src/magic.core.module.mjs +157 -0
  6. package/{esm2015/src/services/ISubformMagicService.js → esm2020/src/services/ISubformMagicService.mjs} +1 -0
  7. package/esm2020/src/services/OverlayWindowService.mjs +208 -0
  8. package/esm2020/src/services/StylesMapManager.mjs +28 -0
  9. package/esm2020/src/services/accessor.magic.service.mjs +302 -0
  10. package/{esm2015/src/services/commands-collector.magic.service.js → esm2020/src/services/commands-collector.magic.service.mjs} +7 -4
  11. package/esm2020/src/services/component-list.magic.service.mjs +46 -0
  12. package/{esm2015/src/services/confirmation.components.magic.provider.js → esm2020/src/services/confirmation.components.magic.provider.mjs} +2 -2
  13. package/esm2020/src/services/engine.magic.service.mjs +82 -0
  14. package/{esm2015/src/services/exit.magic.service.js → esm2020/src/services/exit.magic.service.mjs} +2 -2
  15. package/esm2020/src/services/magic.lazy.loader.service.mjs +16 -0
  16. package/{esm2015/src/services/magic.providers.js → esm2020/src/services/magic.providers.mjs} +0 -0
  17. package/{esm2015/src/services/magic.services.js → esm2020/src/services/magic.services.mjs} +2 -2
  18. package/{esm2015/src/services/mg-date-adapter.js → esm2020/src/services/mg-date-adapter.mjs} +2 -2
  19. package/{esm2015/src/services/overlay.conainer.magic.provider.js → esm2020/src/services/overlay.conainer.magic.provider.mjs} +2 -2
  20. package/esm2020/src/services/router-commands.magic.service.mjs +28 -0
  21. package/esm2020/src/services/subform.magic.service.mjs +185 -0
  22. package/{esm2015/src/services/table.magic.service.js → esm2020/src/services/table.magic.service.mjs} +2 -2
  23. package/esm2020/src/services/task.magics.service.mjs +611 -0
  24. package/{esm2015/src/services/title.magic.service.js → esm2020/src/services/title.magic.service.mjs} +2 -2
  25. package/esm2020/src/ui/GuiInteractiveExecutor.mjs +98 -0
  26. package/{esm2015/src/ui/components/base-magic-alert.component.js → esm2020/src/ui/components/base-magic-alert.component.mjs} +2 -2
  27. package/{esm2015/src/ui/components/base-magic-confirm.component.js → esm2020/src/ui/components/base-magic-confirm.component.mjs} +2 -2
  28. package/esm2020/src/ui/components/magic-alert.component.mjs +71 -0
  29. package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +82 -0
  30. package/{esm2015/src/ui/directives/NonMagicControlDirective.js → esm2020/src/ui/directives/NonMagicControlDirective.mjs} +2 -2
  31. package/{esm2015/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs} +2 -2
  32. package/{esm2015/src/ui/directives/magic/checkbox.magic.directive.js → esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs} +2 -2
  33. package/{esm2015/src/ui/directives/magic/combobox.magic.directive.js → esm2020/src/ui/directives/magic/combobox.magic.directive.mjs} +2 -2
  34. package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.mjs} +3 -4
  35. package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.mjs} +2 -2
  36. package/{esm2015/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.js → esm2020/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.mjs} +3 -4
  37. package/{esm2015/src/ui/directives/magic/input.noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs} +2 -2
  38. package/{esm2015/src/ui/directives/magic/nocontrol.magic.directive.js → esm2020/src/ui/directives/magic/nocontrol.magic.directive.mjs} +2 -2
  39. package/{esm2015/src/ui/directives/magic/row.magic.directive.js → esm2020/src/ui/directives/magic/row.magic.directive.mjs} +2 -2
  40. package/{esm2015/src/ui/directives/magic-focus.directive.js → esm2020/src/ui/directives/magic-focus.directive.mjs} +2 -2
  41. package/esm2020/src/ui/directives/magic.directive.mjs +207 -0
  42. package/esm2020/src/ui/directives/magicViewContainerRef.directive.mjs +20 -0
  43. package/{esm2015/src/ui/directives/mgformat.magic.directive.js → esm2020/src/ui/directives/mgformat.magic.directive.mjs} +2 -2
  44. package/{esm2015/src/ui/directives/range-validator.magic.directive.js → esm2020/src/ui/directives/range-validator.magic.directive.mjs} +2 -2
  45. package/{esm2015/src/ui/magic-confirmationBox.js → esm2020/src/ui/magic-confirmationBox.mjs} +0 -0
  46. package/{esm2015/src/ui/magic-modal/base-magic-overlay-container.js → esm2020/src/ui/magic-modal/base-magic-overlay-container.mjs} +0 -0
  47. package/{esm2015/src/ui/magic-modal/magic-modal-form.js → esm2020/src/ui/magic-modal/magic-modal-form.mjs} +0 -0
  48. package/{esm2015/src/ui/magic-modal/magic-modal-interface.js → esm2020/src/ui/magic-modal/magic-modal-interface.mjs} +1 -0
  49. package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +135 -0
  50. package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +165 -0
  51. package/esm2020/src/ui/magic-root.component.mjs +237 -0
  52. package/esm2020/src/ui/mgerror.magic.component.mjs +120 -0
  53. package/esm2020/src/ui/pipes/date.magic.pipe.mjs +105 -0
  54. package/{esm2015/src/ui/pipes/time.magic.pipe.js → esm2020/src/ui/pipes/time.magic.pipe.mjs} +3 -3
  55. package/esm2020/src/ui/router-container.magic.component.mjs +109 -0
  56. package/esm2020/src/ui/subform.magic.component.mjs +52 -0
  57. package/{esm2015/src/ui/task-base.magic.component.js → esm2020/src/ui/task-base.magic.component.mjs} +2 -2
  58. package/{esm2015/src/ui/utils.js → esm2020/src/ui/utils.mjs} +0 -0
  59. package/fesm2015/magic-xpa-angular.mjs +4578 -0
  60. package/fesm2015/magic-xpa-angular.mjs.map +1 -0
  61. package/{fesm2015/magic-xpa-angular.js → fesm2020/magic-xpa-angular.mjs} +435 -415
  62. package/fesm2020/magic-xpa-angular.mjs.map +1 -0
  63. package/index.d.ts +1 -0
  64. package/package.json +28 -15
  65. package/src/magic.core.module.d.ts +3 -8
  66. package/src/services/OverlayWindowService.d.ts +2 -2
  67. package/src/services/accessor.magic.service.d.ts +2 -2
  68. package/src/services/commands-collector.magic.service.d.ts +2 -2
  69. package/src/services/component-list.magic.service.d.ts +3 -0
  70. package/src/services/confirmation.components.magic.provider.d.ts +2 -2
  71. package/src/services/engine.magic.service.d.ts +2 -2
  72. package/src/services/exit.magic.service.d.ts +2 -2
  73. package/src/services/magic.lazy.loader.service.d.ts +6 -0
  74. package/src/services/magic.services.d.ts +2 -2
  75. package/src/services/mg-date-adapter.d.ts +2 -2
  76. package/src/services/overlay.conainer.magic.provider.d.ts +2 -2
  77. package/src/services/router-commands.magic.service.d.ts +2 -2
  78. package/src/services/subform.magic.service.d.ts +6 -4
  79. package/src/services/table.magic.service.d.ts +2 -2
  80. package/src/services/task.magics.service.d.ts +2 -2
  81. package/src/services/title.magic.service.d.ts +2 -2
  82. package/src/ui/components/base-magic-alert.component.d.ts +2 -2
  83. package/src/ui/components/base-magic-confirm.component.d.ts +2 -2
  84. package/src/ui/components/magic-alert.component.d.ts +2 -2
  85. package/src/ui/components/magic-confirmation-box.component.d.ts +2 -2
  86. package/src/ui/directives/NonMagicControlDirective.d.ts +2 -2
  87. package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +2 -2
  88. package/src/ui/directives/magic/checkbox.magic.directive.d.ts +2 -2
  89. package/src/ui/directives/magic/combobox.magic.directive.d.ts +2 -2
  90. package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +2 -2
  91. package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +2 -2
  92. package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +2 -2
  93. package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +2 -2
  94. package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +2 -2
  95. package/src/ui/directives/magic/row.magic.directive.d.ts +2 -2
  96. package/src/ui/directives/magic-focus.directive.d.ts +2 -2
  97. package/src/ui/directives/magic.directive.d.ts +2 -2
  98. package/src/ui/directives/magicViewContainerRef.directive.d.ts +2 -2
  99. package/src/ui/directives/mgformat.magic.directive.d.ts +2 -2
  100. package/src/ui/directives/range-validator.magic.directive.d.ts +2 -2
  101. package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +7 -5
  102. package/src/ui/magic-modal/magic-overlay-container.d.ts +2 -2
  103. package/src/ui/magic-root.component.d.ts +2 -2
  104. package/src/ui/mgerror.magic.component.d.ts +2 -2
  105. package/src/ui/pipes/date.magic.pipe.d.ts +2 -2
  106. package/src/ui/pipes/time.magic.pipe.d.ts +2 -2
  107. package/src/ui/router-container.magic.component.d.ts +2 -2
  108. package/src/ui/subform.magic.component.d.ts +2 -2
  109. package/src/ui/task-base.magic.component.d.ts +2 -2
  110. package/bundles/magic-xpa-angular.umd.js +0 -5028
  111. package/bundles/magic-xpa-angular.umd.js.map +0 -1
  112. package/bundles/magic-xpa-angular.umd.min.js +0 -16
  113. package/bundles/magic-xpa-angular.umd.min.js.map +0 -1
  114. package/esm2015/index.js +0 -56
  115. package/esm2015/src/controls.metadata.model.js +0 -180
  116. package/esm2015/src/magic.core.module.js +0 -173
  117. package/esm2015/src/services/OverlayWindowService.js +0 -205
  118. package/esm2015/src/services/StylesMapManager.js +0 -29
  119. package/esm2015/src/services/accessor.magic.service.js +0 -302
  120. package/esm2015/src/services/component-list.magic.service.js +0 -36
  121. package/esm2015/src/services/engine.magic.service.js +0 -82
  122. package/esm2015/src/services/router-commands.magic.service.js +0 -25
  123. package/esm2015/src/services/subform.magic.service.js +0 -182
  124. package/esm2015/src/services/task.magics.service.js +0 -611
  125. package/esm2015/src/ui/GuiInteractiveExecutor.js +0 -98
  126. package/esm2015/src/ui/components/magic-alert.component.js +0 -72
  127. package/esm2015/src/ui/components/magic-confirmation-box.component.js +0 -83
  128. package/esm2015/src/ui/directives/magic.directive.js +0 -207
  129. package/esm2015/src/ui/directives/magicViewContainerRef.directive.js +0 -20
  130. package/esm2015/src/ui/magic-modal/magic-overlay-container-wrapper.js +0 -131
  131. package/esm2015/src/ui/magic-modal/magic-overlay-container.js +0 -169
  132. package/esm2015/src/ui/magic-root.component.js +0 -237
  133. package/esm2015/src/ui/mgerror.magic.component.js +0 -120
  134. package/esm2015/src/ui/pipes/date.magic.pipe.js +0 -106
  135. package/esm2015/src/ui/router-container.magic.component.js +0 -109
  136. package/esm2015/src/ui/subform.magic.component.js +0 -52
  137. package/fesm2015/magic-xpa-angular.js.map +0 -1
@@ -42,7 +42,7 @@ RangeValidatorMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: RangeValidat
42
42
  multi: true,
43
43
  }
44
44
  ])] });
45
- (function () { i0.ɵsetClassMetadata(RangeValidatorMagicDirective, [{
45
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeValidatorMagicDirective, [{
46
46
  type: Directive,
47
47
  args: [{
48
48
  selector: '[rangevalidator] ',
@@ -55,4 +55,4 @@ RangeValidatorMagicDirective.ɵdir = i0.ɵɵdefineDirective({ type: RangeValidat
55
55
  ]
56
56
  }]
57
57
  }], function () { return [{ type: i1.TaskMagicService }, { type: i0.ViewContainerRef }]; }, null); })();
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvcmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBZSxhQUFhLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7O0FBbUJ0RSxNQUFNLE9BQU8sNEJBQTRCO0lBT3ZDLFlBQXNCLEtBQXVCLEVBQWEsS0FBdUI7UUFBM0QsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFBYSxVQUFLLEdBQUwsS0FBSyxDQUFrQjtJQUNqRixDQUFDO0lBT0EsUUFBUSxDQUFDLENBQWM7UUFDbkIsSUFBSSxXQUFtQixDQUFDO1FBQ3hCLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksVUFBMkIsQ0FBQztRQUNoQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzFFLFVBQVUsQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQ2pDLElBQUksTUFBTSxHQUFXLElBQUksQ0FBQztRQUMxQixJQUFJLENBQUMsQ0FBQyxLQUFLO1lBQ1YsTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUUsV0FBVyxFQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUNsSCxJQUFJLE9BQU8sR0FBWSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDdkQsSUFBSSxPQUFPLEVBQUU7WUFDWCxPQUFPLElBQUksQ0FBQztTQUNiO2FBQ0k7WUFDSCxPQUFPO2dCQUNMLGNBQWMsRUFBRTtvQkFDZCxRQUFRLEVBQUcsTUFBTTtpQkFDbEI7YUFDRixDQUFDO1NBQ0g7SUFDTCxDQUFDO0lBS0YsY0FBYyxDQUFDLENBQWM7UUFDM0IsTUFBTSxTQUFTLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDcEMsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7SUFDNUUsQ0FBQzs7d0dBM0NVLDRCQUE0QjtpRUFBNUIsNEJBQTRCLDRFQVg1QjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxhQUFhO2dCQUN0QixXQUFXLEVBQUUsNEJBQTRCO2dCQUV6QyxLQUFLLEVBQUUsSUFBSTthQUVaO1NBQ0Y7b0NBR1UsNEJBQTRCO2NBYnhDLFNBQVM7ZUFBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixTQUFTLEVBQUU7b0JBQ1Q7d0JBQ0UsT0FBTyxFQUFFLGFBQWE7d0JBQ3RCLFdBQVcsRUFBRSw0QkFBNEI7d0JBRXpDLEtBQUssRUFBRSxJQUFJO3FCQUVaO2lCQUNGO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRm9ybUNvbnRyb2wsIE5HX1ZBTElEQVRPUlMsIFZhbGlkYXRvciB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgVGFza01hZ2ljU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3Rhc2subWFnaWNzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBDb250cm9sTWV0YWRhdGEgfSBmcm9tICcuLi8uLi9jb250cm9scy5tZXRhZGF0YS5tb2RlbCc7XHJcblxyXG4vKipcclxuICogVmFsaWRhdGVzIHRoZSBmaWVsZCByYW5nZS5cclxuICovXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3JhbmdldmFsaWRhdG9yXSAnLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxJREFUT1JTLFxyXG4gICAgICB1c2VFeGlzdGluZzogUmFuZ2VWYWxpZGF0b3JNYWdpY0RpcmVjdGl2ZSxcclxuXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG5cclxuICAgIH1cclxuICBdXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgUmFuZ2VWYWxpZGF0b3JNYWdpY0RpcmVjdGl2ZSBpbXBsZW1lbnRzIFZhbGlkYXRvciB7XHJcblxyXG4gIC8qKlxyXG4gICAqXHJcbiAgICogQHBhcmFtIF90YXNrIFRoZSB0YXNrIHNlcnZpY2VcclxuICAgKiBAcGFyYW0gdmNSZWZcclxuICAgKi9cclxuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgX3Rhc2s6IFRhc2tNYWdpY1NlcnZpY2UsICBwcm90ZWN0ZWQgdmNSZWY6IFZpZXdDb250YWluZXJSZWYpIHtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFZhbGlkYXRpb24gbWV0aG9kXHJcbiAgICogQHBhcmFtIGMgRm9ybUNvbnRyb2wgdG8gdmFsaWRhdGVcclxuICAgKiBAcmV0dXJucyBJZiB2YWxpZGF0aW9uIGZhaWxzLCByZXR1cm4gZXJyb3IgbWVzc2FnZSwgZWxzZSByZXR1cm5zIG51bGxcclxuICAgKi9cclxuICAgdmFsaWRhdGUoYzogRm9ybUNvbnRyb2wpIHtcclxuICAgICAgIGxldCBjb250cm9sTmFtZTogc3RyaW5nO1xyXG4gICAgICAgY29udHJvbE5hbWUgPSB0aGlzLmdldENvbnRyb2xOYW1lIChjKTtcclxuICAgICAgIGxldCBwcm9wZXJ0aWVzOiBDb250cm9sTWV0YWRhdGE7XHJcbiAgICAgICBwcm9wZXJ0aWVzID0gdGhpcy5fdGFzay5SZWNvcmRzLmxpc3RbXCIwXCJdLmdldENvbnRyb2xNZXRhZGF0YShjb250cm9sTmFtZSk7XHJcbiAgICAgICBwcm9wZXJ0aWVzLnJhbmdlVmFsaWRhdG9yID0gdHJ1ZTtcclxuICAgICAgIGxldCBlcnJNc2c6IHN0cmluZyA9IG51bGw7XHJcbiAgICAgICBpZiAoYy5kaXJ0eSlcclxuICAgICAgICBlcnJNc2cgPSB0aGlzLl90YXNrLlZhbGlkYXRlQ29udHJvbFZhbHVlIChjb250cm9sTmFtZSwgIHRoaXMuX3Rhc2suQ29udmVydFZhbFRvTmF0aXZlKGNvbnRyb2xOYW1lLCAgMCwgYy52YWx1ZSkpO1xyXG4gICAgICAgbGV0IGlzVmFsaWQ6IGJvb2xlYW4gPSAoZXJyTXNnID09IG51bGwpID8gdHJ1ZSA6IGZhbHNlO1xyXG4gICAgICAgaWYgKGlzVmFsaWQpIHtcclxuICAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICAgICB9XHJcbiAgICAgICBlbHNlIHtcclxuICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICByYW5nZXZhbGlkYXRvcjoge1xyXG4gICAgICAgICAgICAgZXJyb3JNc2cgOiBlcnJNc2dcclxuICAgICAgICAgICB9XHJcbiAgICAgICAgIH07XHJcbiAgICAgICB9XHJcbiAgIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQGlnbm9yZVxyXG4gICAqL1xyXG4gIGdldENvbnRyb2xOYW1lKGM6IEZvcm1Db250cm9sKTogc3RyaW5nIHwgbnVsbCB7XHJcbiAgICBjb25zdCBmb3JtR3JvdXAgPSBjLnBhcmVudC5jb250cm9scztcclxuICAgIHJldHVybiBPYmplY3Qua2V5cyhmb3JtR3JvdXApLmZpbmQobmFtZSA9PiBjID09PSBmb3JtR3JvdXBbbmFtZV0pIHx8IG51bGw7XHJcbiAgfVxyXG59XHJcbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXIvc3JjL3VpL2RpcmVjdGl2ZXMvcmFuZ2UtdmFsaWRhdG9yLm1hZ2ljLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBZSxhQUFhLEVBQWEsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7O0FBbUJ0RSxNQUFNLE9BQU8sNEJBQTRCO0lBT3ZDLFlBQXNCLEtBQXVCLEVBQWEsS0FBdUI7UUFBM0QsVUFBSyxHQUFMLEtBQUssQ0FBa0I7UUFBYSxVQUFLLEdBQUwsS0FBSyxDQUFrQjtJQUNqRixDQUFDO0lBT0EsUUFBUSxDQUFDLENBQWM7UUFDbkIsSUFBSSxXQUFtQixDQUFDO1FBQ3hCLFdBQVcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3RDLElBQUksVUFBMkIsQ0FBQztRQUNoQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzFFLFVBQVUsQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQ2pDLElBQUksTUFBTSxHQUFXLElBQUksQ0FBQztRQUMxQixJQUFJLENBQUMsQ0FBQyxLQUFLO1lBQ1YsTUFBTSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUUsV0FBVyxFQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsV0FBVyxFQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUNsSCxJQUFJLE9BQU8sR0FBWSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDdkQsSUFBSSxPQUFPLEVBQUU7WUFDWCxPQUFPLElBQUksQ0FBQztTQUNiO2FBQ0k7WUFDSCxPQUFPO2dCQUNMLGNBQWMsRUFBRTtvQkFDZCxRQUFRLEVBQUcsTUFBTTtpQkFDbEI7YUFDRixDQUFDO1NBQ0g7SUFDTCxDQUFDO0lBS0YsY0FBYyxDQUFDLENBQWM7UUFDM0IsTUFBTSxTQUFTLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDcEMsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7SUFDNUUsQ0FBQzs7d0dBM0NVLDRCQUE0QjtpRUFBNUIsNEJBQTRCLDRFQVg1QjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxhQUFhO2dCQUN0QixXQUFXLEVBQUUsNEJBQTRCO2dCQUV6QyxLQUFLLEVBQUUsSUFBSTthQUVaO1NBQ0Y7dUZBR1UsNEJBQTRCO2NBYnhDLFNBQVM7ZUFBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixTQUFTLEVBQUU7b0JBQ1Q7d0JBQ0UsT0FBTyxFQUFFLGFBQWE7d0JBQ3RCLFdBQVcsOEJBQThCO3dCQUV6QyxLQUFLLEVBQUUsSUFBSTtxQkFFWjtpQkFDRjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1Db250cm9sLCBOR19WQUxJREFUT1JTLCBWYWxpZGF0b3IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFRhc2tNYWdpY1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy90YXNrLm1hZ2ljcy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ29udHJvbE1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vY29udHJvbHMubWV0YWRhdGEubW9kZWwnO1xyXG5cclxuLyoqXHJcbiAqIFZhbGlkYXRlcyB0aGUgZmllbGQgcmFuZ2UuXHJcbiAqL1xyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1tyYW5nZXZhbGlkYXRvcl0gJyxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMSURBVE9SUyxcclxuICAgICAgdXNlRXhpc3Rpbmc6IFJhbmdlVmFsaWRhdG9yTWFnaWNEaXJlY3RpdmUsXHJcblxyXG4gICAgICBtdWx0aTogdHJ1ZSxcclxuXHJcbiAgICB9XHJcbiAgXVxyXG59KVxyXG5cclxuZXhwb3J0IGNsYXNzIFJhbmdlVmFsaWRhdG9yTWFnaWNEaXJlY3RpdmUgaW1wbGVtZW50cyBWYWxpZGF0b3Ige1xyXG5cclxuICAvKipcclxuICAgKlxyXG4gICAqIEBwYXJhbSBfdGFzayBUaGUgdGFzayBzZXJ2aWNlXHJcbiAgICogQHBhcmFtIHZjUmVmXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIF90YXNrOiBUYXNrTWFnaWNTZXJ2aWNlLCAgcHJvdGVjdGVkIHZjUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBWYWxpZGF0aW9uIG1ldGhvZFxyXG4gICAqIEBwYXJhbSBjIEZvcm1Db250cm9sIHRvIHZhbGlkYXRlXHJcbiAgICogQHJldHVybnMgSWYgdmFsaWRhdGlvbiBmYWlscywgcmV0dXJuIGVycm9yIG1lc3NhZ2UsIGVsc2UgcmV0dXJucyBudWxsXHJcbiAgICovXHJcbiAgIHZhbGlkYXRlKGM6IEZvcm1Db250cm9sKSB7XHJcbiAgICAgICBsZXQgY29udHJvbE5hbWU6IHN0cmluZztcclxuICAgICAgIGNvbnRyb2xOYW1lID0gdGhpcy5nZXRDb250cm9sTmFtZSAoYyk7XHJcbiAgICAgICBsZXQgcHJvcGVydGllczogQ29udHJvbE1ldGFkYXRhO1xyXG4gICAgICAgcHJvcGVydGllcyA9IHRoaXMuX3Rhc2suUmVjb3Jkcy5saXN0W1wiMFwiXS5nZXRDb250cm9sTWV0YWRhdGEoY29udHJvbE5hbWUpO1xyXG4gICAgICAgcHJvcGVydGllcy5yYW5nZVZhbGlkYXRvciA9IHRydWU7XHJcbiAgICAgICBsZXQgZXJyTXNnOiBzdHJpbmcgPSBudWxsO1xyXG4gICAgICAgaWYgKGMuZGlydHkpXHJcbiAgICAgICAgZXJyTXNnID0gdGhpcy5fdGFzay5WYWxpZGF0ZUNvbnRyb2xWYWx1ZSAoY29udHJvbE5hbWUsICB0aGlzLl90YXNrLkNvbnZlcnRWYWxUb05hdGl2ZShjb250cm9sTmFtZSwgIDAsIGMudmFsdWUpKTtcclxuICAgICAgIGxldCBpc1ZhbGlkOiBib29sZWFuID0gKGVyck1zZyA9PSBudWxsKSA/IHRydWUgOiBmYWxzZTtcclxuICAgICAgIGlmIChpc1ZhbGlkKSB7XHJcbiAgICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgICAgfVxyXG4gICAgICAgZWxzZSB7XHJcbiAgICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgcmFuZ2V2YWxpZGF0b3I6IHtcclxuICAgICAgICAgICAgIGVycm9yTXNnIDogZXJyTXNnXHJcbiAgICAgICAgICAgfVxyXG4gICAgICAgICB9O1xyXG4gICAgICAgfVxyXG4gICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEBpZ25vcmVcclxuICAgKi9cclxuICBnZXRDb250cm9sTmFtZShjOiBGb3JtQ29udHJvbCk6IHN0cmluZyB8IG51bGwge1xyXG4gICAgY29uc3QgZm9ybUdyb3VwID0gYy5wYXJlbnQuY29udHJvbHM7XHJcbiAgICByZXR1cm4gT2JqZWN0LmtleXMoZm9ybUdyb3VwKS5maW5kKG5hbWUgPT4gYyA9PT0gZm9ybUdyb3VwW25hbWVdKSB8fCBudWxsO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1 +1,2 @@
1
+ export {};
1
2
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFnaWMtbW9kYWwtaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci9zcmMvdWkvbWFnaWMtbW9kYWwvbWFnaWMtbW9kYWwtaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogRGVzY3JpYmVzIHRoZSBiZWhhdmlvciBvZiBhIG1vZGFsIHdpbmRvd1xyXG4gKi9cclxuZXhwb3J0IGludGVyZmFjZSBNYWdpY01vZGFsSW50ZXJmYWNlIHtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSBYIGNvb3JkaW5hdGUgb2YgdGhlIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIFgoKTtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSBZIGNvb3JkaW5hdGUgb2YgdGhlIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIFkoKTtcclxuICAvKipcclxuICAgKiBSZXR1cm5zIHRoZSB3aWR0aCBvZiBtb2RhbCB3aW5kb3dcclxuICAgKi9cclxuICBXaWR0aCgpOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogUmV0dXJucyB0aGUgaGVpZ2h0IG9mIG1vZGFsIHdpbmRvd1xyXG4gICAqL1xyXG4gIEhlaWdodCgpOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogSXMgdGhlIG1vZGFsIHdpbmRvdyBjZW50ZXJlZCByZWxhdGl2ZWx5IHRvIHRoZSBtYWluIHdpbmRvd1xyXG4gICAqL1xyXG4gIElzQ2VudGVyZWRUb1dpbmRvdygpO1xyXG4gIC8qKlxyXG4gICAqIFJldHVybnMgdGhlIG5hbWUgb2YgdGhlIGZvcm0gLSB0aXRsZSBvZiB0aGUgbW9kYWwgd2luZG93XHJcbiAgICovXHJcbiAgRm9ybU5hbWUoKTtcclxuICAvKipcclxuICAgKiBTaG91bGQgdGhlIHRpdGxlIGJhciBiZSBkaXNwbGF5ZWRcclxuICAgKi9cclxuICBTaG93VGl0bGVCYXIoKTtcclxuICAvKipcclxuICAgKiBTaG91bGQgdGhlIG1vZGFsIHdpbmRvdyBjbG9zZSB3aGVuIHRoZSB1c2VyIGNsaWNrcyBvbiB0aGUgYmFja2dyb3VuZFxyXG4gICAqL1xyXG4gIFNob3VsZENsb3NlT25CYWNrZ3JvdW5kQ2xpY2soKTtcclxufVxyXG4iXX0=
@@ -0,0 +1,135 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild, ComponentFactoryResolver, ElementRef, Injector, ChangeDetectorRef, Compiler } from '@angular/core';
2
+ import { BaseMagicOverlayContainer } from "./base-magic-overlay-container";
3
+ import { BaseMagicConfirmComponent } from "../components/base-magic-confirm.component";
4
+ import { BaseMagicAlertComponent } from "../components/base-magic-alert.component";
5
+ import { OverlayType } from "@magic-xpa/gui";
6
+ import { ComponentListMagicService } from "../../services/component-list.magic.service";
7
+ import { isNullOrUndefined } from '@magic-xpa/mscorelib';
8
+ import { MagicLazyLoaderService } from '../../services/magic.lazy.loader.service';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "../../services/component-list.magic.service";
11
+ import * as i2 from "../../services/magic.lazy.loader.service";
12
+ import * as i3 from "../directives/magic-focus.directive";
13
+ import * as i4 from "../directives/magicViewContainerRef.directive";
14
+ const _c0 = ["overlayContainerWrapper"];
15
+ export class MagicOverlayContainerWrapper {
16
+ constructor(componentListMagicService, magicLazyModuleLoader, injector, componentFactoryResolver, changeDetectorRef, compiler) {
17
+ this.componentListMagicService = componentListMagicService;
18
+ this.magicLazyModuleLoader = magicLazyModuleLoader;
19
+ this.injector = injector;
20
+ this.componentFactoryResolver = componentFactoryResolver;
21
+ this.changeDetectorRef = changeDetectorRef;
22
+ this.compiler = compiler;
23
+ this.Component = null;
24
+ this.Parameters = {};
25
+ this.onClose = new EventEmitter();
26
+ }
27
+ ngOnInit() {
28
+ let moduleRef = this.componentListMagicService.getModuleRef(this.Parameters.MagicFormName);
29
+ if (moduleRef == null) {
30
+ let lazyLoadModule = this.componentListMagicService.getLazyLoadModuleData(this.Parameters.MagicFormName);
31
+ if (lazyLoadModule != null) {
32
+ let moduleName = lazyLoadModule.moduleName.replace("Magic", "");
33
+ moduleName = moduleName.replace("Module", "");
34
+ this.magicLazyModuleLoader.Load(moduleName).then(m => {
35
+ const compiled = this.compiler.compileModuleAndAllComponentsSync(m[lazyLoadModule.moduleName]);
36
+ moduleRef = compiled.ngModuleFactory.create(this.injector);
37
+ this.loadComponent(moduleRef);
38
+ });
39
+ }
40
+ else {
41
+ this.loadComponent(null);
42
+ }
43
+ }
44
+ else
45
+ this.loadComponent(moduleRef);
46
+ }
47
+ loadComponent(moduleRef) {
48
+ this.Parameters.ModalComp = this.componentListMagicService.getComponent(this.Parameters.MagicFormName, !isNullOrUndefined(this.Parameters.MagicFormName));
49
+ let factory;
50
+ if (moduleRef != null)
51
+ factory = moduleRef.componentFactoryResolver.resolveComponentFactory(this.Component);
52
+ else
53
+ factory = this.componentFactoryResolver.resolveComponentFactory(this.Component);
54
+ let componentRef = this.overlayContentViewContainerRef.createComponent(factory);
55
+ let allowedBaseComp = MagicOverlayContainerWrapper.allowedBaseComps.get(this.OverlayTypeParam);
56
+ if (componentRef.instance instanceof allowedBaseComp.comp) {
57
+ Object.assign(componentRef.instance, this.Parameters);
58
+ componentRef.instance.onClose.subscribe((res) => {
59
+ this.onClose.emit(res);
60
+ });
61
+ }
62
+ else {
63
+ let msg = "Provided window container should subclass of : " + allowedBaseComp.error + "window will not work properly.";
64
+ alert(msg);
65
+ }
66
+ }
67
+ setViewContainerRef(vcRef) {
68
+ this.overlayContentViewContainerRef = vcRef;
69
+ }
70
+ GetRootElement() {
71
+ return this.overlayContainerWrapperElementRef.nativeElement;
72
+ }
73
+ DetectChanges() {
74
+ this.changeDetectorRef.detectChanges();
75
+ }
76
+ }
77
+ MagicOverlayContainerWrapper.allowedBaseComps = new Map([
78
+ [OverlayType.Overlay, { comp: BaseMagicOverlayContainer, error: 'BaseMagicOverlayContainer . Overlay ' }],
79
+ [OverlayType.Alert, { comp: BaseMagicAlertComponent, error: 'BaseMagicAlertComponent. Alert ' }],
80
+ [OverlayType.ConfirmationBox, { comp: BaseMagicConfirmComponent, error: 'BaseMagicConfirmComponent. Confirmation ' }]
81
+ ]);
82
+ MagicOverlayContainerWrapper.ɵfac = function MagicOverlayContainerWrapper_Factory(t) { return new (t || MagicOverlayContainerWrapper)(i0.ɵɵdirectiveInject(i1.ComponentListMagicService), i0.ɵɵdirectiveInject(i2.MagicLazyLoaderService), i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i0.Compiler)); };
83
+ MagicOverlayContainerWrapper.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContainerWrapper, selectors: [["app-magic-overlay-container-wrapper"]], viewQuery: function MagicOverlayContainerWrapper_Query(rf, ctx) { if (rf & 1) {
84
+ i0.ɵɵviewQuery(_c0, 7);
85
+ } if (rf & 2) {
86
+ let _t;
87
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.overlayContainerWrapperElementRef = _t.first);
88
+ } }, inputs: { Component: "Component", Parameters: "Parameters", OverlayTypeParam: "OverlayTypeParam" }, outputs: { onClose: "onClose" }, decls: 7, vars: 0, consts: [["tabIndex", "0", "magicFocus", "", 1, "overlay-container-wrapper-background", 2, "width", "0px", "height", "0px"], [1, "overlay-container-wrapper-background"], ["overlayContainerWrapper", ""], ["magicViewContainerRef", ""], ["overlayContent", ""], ["tabIndex", "0", 1, "overlay-container-wrapper-background", 2, "width", "0px", "height", "0px"]], template: function MagicOverlayContainerWrapper_Template(rf, ctx) { if (rf & 1) {
89
+ i0.ɵɵelementStart(0, "div");
90
+ i0.ɵɵelement(1, "div", 0);
91
+ i0.ɵɵelementStart(2, "div", 1, 2);
92
+ i0.ɵɵelement(4, "div", 3, 4);
93
+ i0.ɵɵelementEnd();
94
+ i0.ɵɵelement(6, "div", 5);
95
+ i0.ɵɵelementEnd();
96
+ } }, directives: [i3.MagicFocusDirective, i4.MagicViewContainerRef], styles: [".overlay-container-wrapper-background[_ngcontent-%COMP%]{position:fixed;top:0;z-index:999;right:0;bottom:0;left:0}"] });
97
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainerWrapper, [{
98
+ type: Component,
99
+ args: [{
100
+ selector: 'app-magic-overlay-container-wrapper',
101
+ template: `
102
+ <div>
103
+ <div class="overlay-container-wrapper-background" tabIndex="0" style="width: 0px; height: 0px;" magicFocus></div>
104
+ <div class="overlay-container-wrapper-background" #overlayContainerWrapper>
105
+ <div #overlayContent magicViewContainerRef>
106
+ </div>
107
+ </div>
108
+ <div class="overlay-container-wrapper-background" tabIndex="0" style="width: 0px; height: 0px;" ></div>
109
+ </div>
110
+ `,
111
+ styles: [`
112
+ .overlay-container-wrapper-background {
113
+ /* modal background fixed across whole screen */
114
+ position: fixed;
115
+ top: 0;
116
+ z-index: 999;
117
+ right: 0;
118
+ bottom: 0;
119
+ left: 0;
120
+ }
121
+ `]
122
+ }]
123
+ }], function () { return [{ type: i1.ComponentListMagicService }, { type: i2.MagicLazyLoaderService }, { type: i0.Injector }, { type: i0.ComponentFactoryResolver }, { type: i0.ChangeDetectorRef }, { type: i0.Compiler }]; }, { Component: [{
124
+ type: Input
125
+ }], Parameters: [{
126
+ type: Input
127
+ }], OverlayTypeParam: [{
128
+ type: Input
129
+ }], onClose: [{
130
+ type: Output
131
+ }], overlayContainerWrapperElementRef: [{
132
+ type: ViewChild,
133
+ args: ['overlayContainerWrapper', { static: true }]
134
+ }] }); })();
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic-overlay-container-wrapper.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/magic-modal/magic-overlay-container-wrapper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n  ComponentFactoryResolver,\r\n  ElementRef, NgModuleRef,\r\n  Injector, ChangeDetectorRef, Compiler\r\n} from '@angular/core';\r\nimport { BaseMagicOverlayContainer } from \"./base-magic-overlay-container\";\r\nimport { BaseMagicConfirmComponent } from \"../components/base-magic-confirm.component\";\r\nimport { BaseMagicAlertComponent } from \"../components/base-magic-alert.component\";\r\nimport { OverlayType } from \"@magic-xpa/gui\";\r\nimport { ComponentListMagicService, ModuleData } from \"../../services/component-list.magic.service\";\r\nimport { IMagicViewContainerRef } from \"../../..\";\r\nimport {isNullOrUndefined} from '@magic-xpa/mscorelib';\r\nimport { MagicLazyLoaderService } from '../../services/magic.lazy.loader.service';\r\n\r\n\r\n@Component({\r\n  selector: 'app-magic-overlay-container-wrapper',\r\n  template: `\r\n    <div>\r\n      <div class=\"overlay-container-wrapper-background\" tabIndex=\"0\" style=\"width: 0px; height: 0px;\" magicFocus></div>\r\n      <div class=\"overlay-container-wrapper-background\" #overlayContainerWrapper>\r\n        <div #overlayContent magicViewContainerRef>\r\n        </div>\r\n      </div>\r\n      <div class=\"overlay-container-wrapper-background\" tabIndex=\"0\" style=\"width: 0px; height: 0px;\" ></div>\r\n    </div>\r\n  `,\r\n  styles: [`\r\n    .overlay-container-wrapper-background {\r\n      /* modal background fixed across whole screen */\r\n      position: fixed;\r\n      top: 0;\r\n      z-index: 999;\r\n      right: 0;\r\n      bottom: 0;\r\n      left: 0;\r\n    }\r\n  `]\r\n})\r\nexport class MagicOverlayContainerWrapper  implements IMagicViewContainerRef {\r\n  /**\r\n   *\r\n   */\r\n  @Input() public Component = null;\r\n  /**\r\n   *\r\n   */\r\n  @Input() public Parameters: any = {};\r\n\r\n  @Input() private OverlayTypeParam: OverlayType;\r\n\r\n  @Output() private onClose = new EventEmitter<void>();\r\n\r\n  /**\r\n   * HTML to be displayed in the modal window\r\n   */\r\n  overlayContentViewContainerRef: ViewContainerRef;\r\n\r\n  @ViewChild('overlayContainerWrapper', { static: true }) overlayContainerWrapperElementRef: ElementRef;\r\n\r\n  /**\r\n   * @ignore\r\n   * contais data of allowed base components to use\r\n   */\r\n  static allowedBaseComps = new Map<number, {comp: any, error: string}>([\r\n    [OverlayType.Overlay, {comp: BaseMagicOverlayContainer, error:'BaseMagicOverlayContainer . Overlay '}],\r\n    [OverlayType.Alert, {comp: BaseMagicAlertComponent, error:'BaseMagicAlertComponent. Alert '}],\r\n    [OverlayType.ConfirmationBox,  {comp: BaseMagicConfirmComponent, error :'BaseMagicConfirmComponent. Confirmation '}]\r\n  ]);\r\n  /**\r\n   *\r\n   * @param componentFactoryResolver\r\n   */\r\n  constructor(private componentListMagicService: ComponentListMagicService,\r\n              private magicLazyModuleLoader: MagicLazyLoaderService,\r\n              private injector: Injector,\r\n    private componentFactoryResolver: ComponentFactoryResolver,\r\n              private changeDetectorRef:ChangeDetectorRef,\r\n              private compiler: Compiler) {\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    let moduleRef: NgModuleRef<any> = this.componentListMagicService.getModuleRef(this.Parameters.MagicFormName);\r\n\r\n    if (moduleRef == null) {\r\n      let lazyLoadModule: ModuleData = this.componentListMagicService.getLazyLoadModuleData(this.Parameters.MagicFormName);\r\n\r\n      if (lazyLoadModule != null) {\r\n        let moduleName = lazyLoadModule.moduleName.replace(\"Magic\", \"\");\r\n        moduleName = moduleName.replace(\"Module\", \"\");\r\n        this.magicLazyModuleLoader.Load(moduleName).then(m => {\r\n          const compiled = this.compiler.compileModuleAndAllComponentsSync(<any>m[lazyLoadModule.moduleName]);\r\n          moduleRef = compiled.ngModuleFactory.create(this.injector);\r\n          this.loadComponent(moduleRef);\r\n        });\r\n      }\r\n      else {\r\n        this.loadComponent(null);\r\n      }\r\n    } else\r\n      this.loadComponent(moduleRef);\r\n  }\r\n\r\n  private loadComponent(moduleRef: NgModuleRef<any>) {\r\n    this.Parameters.ModalComp = this.componentListMagicService.getComponent(this.Parameters.MagicFormName, !isNullOrUndefined(this.Parameters.MagicFormName));\r\n\r\n    let factory;\r\n    if (moduleRef != null)\r\n      factory = moduleRef.componentFactoryResolver.resolveComponentFactory(this.Component);\r\n    else\r\n      factory = this.componentFactoryResolver.resolveComponentFactory(this.Component);\r\n\r\n    let componentRef = this.overlayContentViewContainerRef.createComponent(factory);\r\n    let allowedBaseComp = MagicOverlayContainerWrapper.allowedBaseComps.get(this.OverlayTypeParam);\r\n\r\n\r\n    if (componentRef.instance instanceof allowedBaseComp.comp) {\r\n      Object.assign(componentRef.instance, this.Parameters);\r\n      (<any>componentRef.instance).onClose.subscribe((res) => {\r\n        this.onClose.emit(res);\r\n      });\r\n    } else {\r\n      let msg = \"Provided  window container should subclass of : \" + allowedBaseComp.error + \"window will not work properly.\";\r\n      alert(msg);\r\n    }\r\n  }\r\n\r\n  setViewContainerRef(vcRef: ViewContainerRef){\r\n    this.overlayContentViewContainerRef = vcRef;\r\n  }\r\n\r\n  GetRootElement(): HTMLElement {\r\n    return this.overlayContainerWrapperElementRef.nativeElement;\r\n  }\r\n\r\n  DetectChanges()\r\n  {\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,165 @@
1
+ import { Component, ComponentFactoryResolver, ElementRef, EventEmitter, Injector, Input, Output, ViewChild } from '@angular/core';
2
+ import { isNullOrUndefined } from '@magic-xpa/mscorelib';
3
+ import { BaseMagicOverlayContainer } from './base-magic-overlay-container';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "../directives/magicViewContainerRef.directive";
7
+ const _c0 = ["modalheader"];
8
+ const _c1 = ["modalForeground"];
9
+ function MagicOverlayContainer_button_2_Template(rf, ctx) { if (rf & 1) {
10
+ const _r5 = i0.ɵɵgetCurrentView();
11
+ i0.ɵɵelementStart(0, "button", 8);
12
+ i0.ɵɵlistener("click", function MagicOverlayContainer_button_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r5); const ctx_r4 = i0.ɵɵnextContext(); return ctx_r4.OnClose(); });
13
+ i0.ɵɵtext(1, "X");
14
+ i0.ɵɵelementEnd();
15
+ } }
16
+ function MagicOverlayContainer_div_5_Template(rf, ctx) { if (rf & 1) {
17
+ const _r8 = i0.ɵɵgetCurrentView();
18
+ i0.ɵɵelementStart(0, "div", 9, 10);
19
+ i0.ɵɵtext(2);
20
+ i0.ɵɵelementStart(3, "button", 11);
21
+ i0.ɵɵlistener("click", function MagicOverlayContainer_div_5_Template_button_click_3_listener() { i0.ɵɵrestoreView(_r8); const ctx_r7 = i0.ɵɵnextContext(); return ctx_r7.OnClose(); });
22
+ i0.ɵɵtext(4, "X");
23
+ i0.ɵɵelementEnd();
24
+ i0.ɵɵelementEnd();
25
+ } if (rf & 2) {
26
+ const ctx_r2 = i0.ɵɵnextContext();
27
+ i0.ɵɵadvance(2);
28
+ i0.ɵɵtextInterpolate1(" ", ctx_r2.getText(), " ");
29
+ } }
30
+ export class MagicOverlayContainer extends BaseMagicOverlayContainer {
31
+ constructor(injector, componentFactoryResolver) {
32
+ super();
33
+ this.injector = injector;
34
+ this.componentFactoryResolver = componentFactoryResolver;
35
+ this.ModalComp = null;
36
+ this.ModalCompParameters = {};
37
+ this.onClose = new EventEmitter();
38
+ this.componentRef = null;
39
+ }
40
+ ngOnInit() {
41
+ const factory = this.componentFactoryResolver.resolveComponentFactory(this.ModalComp);
42
+ this.componentRef = this.modalbodyViewContainerRef.createComponent(factory);
43
+ Object.assign(this.componentRef.instance, this.ModalCompParameters);
44
+ }
45
+ setViewContainerRef(vcRef) {
46
+ this.modalbodyViewContainerRef = vcRef;
47
+ }
48
+ getText() {
49
+ if (this.componentRef !== null) {
50
+ let comp = this.componentRef.instance;
51
+ return comp.FormName();
52
+ }
53
+ else
54
+ return "";
55
+ }
56
+ getStyle() {
57
+ let styles = {};
58
+ if (this.componentRef != undefined) {
59
+ let comp = this.componentRef.instance;
60
+ styles['width'] = comp.Width();
61
+ styles['height'] = comp.Height();
62
+ if (comp.IsCenteredToWindow()) {
63
+ styles['margin'] = "auto";
64
+ }
65
+ else {
66
+ styles['margin-left'] = comp.X() + "px";
67
+ styles['margin-top'] = comp.Y() + "px";
68
+ }
69
+ }
70
+ return styles;
71
+ }
72
+ getClientAreaStyles() {
73
+ let styles = {};
74
+ if (this.componentRef != undefined) {
75
+ let comp = this.componentRef.instance;
76
+ const headerHeight = this.getShowTitleBar() && !isNullOrUndefined(this.headerElementRef) ? (this.headerElementRef.nativeElement.offsetHeight + 1) : 0;
77
+ if (!isNullOrUndefined(this.foregroundElementRef)) {
78
+ const foregroundHeight = this.foregroundElementRef.nativeElement.offsetHeight;
79
+ styles['height'] = (foregroundHeight - headerHeight) + "px";
80
+ const foregroundWidth = this.foregroundElementRef.nativeElement.offsetWidth;
81
+ styles['width'] = (foregroundWidth) + "px";
82
+ }
83
+ styles['overflow'] = "auto";
84
+ }
85
+ return styles;
86
+ }
87
+ getShowTitleBar() {
88
+ if (this.componentRef != undefined) {
89
+ let comp = this.componentRef.instance;
90
+ return comp.ShowTitleBar();
91
+ }
92
+ }
93
+ OnClose() {
94
+ this.onClose.emit();
95
+ }
96
+ OnBackgroundClick() {
97
+ let comp = this.componentRef.instance;
98
+ if (comp.ShouldCloseOnBackgroundClick())
99
+ this.OnClose();
100
+ }
101
+ }
102
+ MagicOverlayContainer.ɵfac = function MagicOverlayContainer_Factory(t) { return new (t || MagicOverlayContainer)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver)); };
103
+ MagicOverlayContainer.ɵcmp = i0.ɵɵdefineComponent({ type: MagicOverlayContainer, selectors: [["app-magic-overlay-container"]], viewQuery: function MagicOverlayContainer_Query(rf, ctx) { if (rf & 1) {
104
+ i0.ɵɵviewQuery(_c0, 5);
105
+ i0.ɵɵviewQuery(_c1, 5);
106
+ } if (rf & 2) {
107
+ let _t;
108
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.headerElementRef = _t.first);
109
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.foregroundElementRef = _t.first);
110
+ } }, inputs: { ModalComp: "ModalComp", ModalCompParameters: "ModalCompParameters" }, outputs: { onClose: "onClose" }, features: [i0.ɵɵInheritDefinitionFeature], decls: 9, vars: 4, consts: [[1, "modal-background", 3, "click"], ["tabindex", "-1", "style", "float:right; border: none; background-color: transparent; outline: none; color: white", 3, "click", 4, "ngIf"], [1, "modal-foreground", 3, "ngStyle"], ["modalForeground", ""], ["class", "modal-header", 4, "ngIf"], [3, "ngStyle"], ["magicViewContainerRef", ""], ["modalbody", ""], ["tabindex", "-1", 2, "float", "right", "border", "none", "background-color", "transparent", "outline", "none", "color", "white", 3, "click"], [1, "modal-header"], ["modalheader", ""], ["tabindex", "-1", 2, "float", "right", 3, "click"]], template: function MagicOverlayContainer_Template(rf, ctx) { if (rf & 1) {
111
+ i0.ɵɵelementStart(0, "div");
112
+ i0.ɵɵelementStart(1, "div", 0);
113
+ i0.ɵɵlistener("click", function MagicOverlayContainer_Template_div_click_1_listener() { return ctx.OnBackgroundClick(); });
114
+ i0.ɵɵtemplate(2, MagicOverlayContainer_button_2_Template, 2, 0, "button", 1);
115
+ i0.ɵɵelementEnd();
116
+ i0.ɵɵelementStart(3, "div", 2, 3);
117
+ i0.ɵɵtemplate(5, MagicOverlayContainer_div_5_Template, 5, 1, "div", 4);
118
+ i0.ɵɵelementStart(6, "div", 5);
119
+ i0.ɵɵelement(7, "div", 6, 7);
120
+ i0.ɵɵelementEnd();
121
+ i0.ɵɵelementEnd();
122
+ i0.ɵɵelementEnd();
123
+ } if (rf & 2) {
124
+ i0.ɵɵadvance(2);
125
+ i0.ɵɵproperty("ngIf", !ctx.getShowTitleBar());
126
+ i0.ɵɵadvance(1);
127
+ i0.ɵɵproperty("ngStyle", ctx.getStyle());
128
+ i0.ɵɵadvance(2);
129
+ i0.ɵɵproperty("ngIf", ctx.getShowTitleBar());
130
+ i0.ɵɵadvance(1);
131
+ i0.ɵɵproperty("ngStyle", ctx.getClientAreaStyles());
132
+ } }, directives: [i1.NgIf, i1.NgStyle, i2.MagicViewContainerRef], styles: [".modal-foreground[_ngcontent-%COMP%]{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#fff}.modal-background[_ngcontent-%COMP%]{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000;opacity:.75}.modal-header[_ngcontent-%COMP%]{background-color:beige;border-bottom:2px solid red}"] });
133
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicOverlayContainer, [{
134
+ type: Component,
135
+ args: [{ selector: 'app-magic-overlay-container', template: `
136
+ <div>
137
+ <div class="modal-background" (click)="OnBackgroundClick()">
138
+ <button (click)="OnClose()" tabindex="-1" style="float:right; border: none; background-color: transparent; outline: none; color: white" *ngIf="!getShowTitleBar()">X</button>
139
+ </div>
140
+ <div #modalForeground class="modal-foreground" [ngStyle]="getStyle()">
141
+ <div #modalheader class="modal-header" *ngIf="getShowTitleBar()">
142
+ {{getText()}}
143
+ <button (click)="OnClose()" style="float:right" tabindex="-1">X</button>
144
+ </div>
145
+ <div [ngStyle]="getClientAreaStyles()">
146
+ <div #modalbody magicViewContainerRef>
147
+ </div>
148
+ </div>
149
+ </div>
150
+ </div>
151
+ `, styles: [".modal-foreground{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#fff}.modal-background{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000;opacity:.75}.modal-header{background-color:beige;border-bottom:2px solid red}\n"] }]
152
+ }], function () { return [{ type: i0.Injector }, { type: i0.ComponentFactoryResolver }]; }, { headerElementRef: [{
153
+ type: ViewChild,
154
+ args: ['modalheader', { static: false }]
155
+ }], foregroundElementRef: [{
156
+ type: ViewChild,
157
+ args: ['modalForeground', { static: false }]
158
+ }], ModalComp: [{
159
+ type: Input
160
+ }], ModalCompParameters: [{
161
+ type: Input
162
+ }], onClose: [{
163
+ type: Output
164
+ }] }); })();
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic-overlay-container.js","sourceRoot":"","sources":["../../../../../../../projects/angular/src/ui/magic-modal/magic-overlay-container.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { MagicModalInterface } from './magic-modal-interface';\r\nimport { isNullOrUndefined } from '@magic-xpa/mscorelib';\r\nimport { BaseMagicOverlayContainer } from './base-magic-overlay-container';\r\nimport { IMagicViewContainerRef } from '../../..';\r\n\r\n/**\r\n * Creates a modal window for Magic modal window components\r\n */\r\n@Component({\r\n  selector: 'app-magic-overlay-container',\r\n  template: `\r\n    <div>\r\n      <div class=\"modal-background\" (click)=\"OnBackgroundClick()\">\r\n        <button (click)=\"OnClose()\" tabindex=\"-1\" style=\"float:right; border: none; background-color: transparent; outline: none; color: white\" *ngIf=\"!getShowTitleBar()\">X</button>\r\n      </div>\r\n      <div #modalForeground class=\"modal-foreground\" [ngStyle]=\"getStyle()\">\r\n        <div #modalheader class=\"modal-header\" *ngIf=\"getShowTitleBar()\">\r\n          {{getText()}}\r\n          <button (click)=\"OnClose()\" style=\"float:right\" tabindex=\"-1\">X</button>\r\n        </div>\r\n        <div [ngStyle]=\"getClientAreaStyles()\">\r\n          <div #modalbody magicViewContainerRef>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  styleUrls: ['./magic-overlay-container.css']\r\n})\r\nexport class MagicOverlayContainer extends BaseMagicOverlayContainer implements OnInit , IMagicViewContainerRef{\r\n  /**\r\n   * HTML to be displayed in the modal window\r\n   */\r\n  modalbodyViewContainerRef : ViewContainerRef;\r\n\r\n  /**\r\n   * Header of the modal window\r\n   */\r\n  @ViewChild('modalheader', { static: false }) headerElementRef: ElementRef;\r\n  /**\r\n   * Foreground of the modal window\r\n   */\r\n  @ViewChild('modalForeground', { static: false }) foregroundElementRef: ElementRef;\r\n\r\n  /**\r\n   *\r\n   */\r\n  @Input() ModalComp = null;\r\n  /**\r\n   *\r\n   */\r\n  @Input() ModalCompParameters: any = {};\r\n\r\n  @Output() onClose = new EventEmitter<void>();\r\n\r\n  /**\r\n   *\r\n   */\r\n  private componentRef = null;\r\n\r\n  /**\r\n   *\r\n   * @param injector\r\n   * @param componentFactoryResolver\r\n   */\r\n  constructor(\r\n    private injector: Injector,\r\n    private componentFactoryResolver: ComponentFactoryResolver) {\r\n    super();\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  ngOnInit() {\r\n    const factory = this.componentFactoryResolver.resolveComponentFactory(this.ModalComp);\r\n    this.componentRef = this.modalbodyViewContainerRef.createComponent(factory);\r\n    Object.assign(this.componentRef.instance, this.ModalCompParameters);\r\n  }\r\n\r\n\r\n  setViewContainerRef(vcRef: ViewContainerRef){\r\n    this.modalbodyViewContainerRef = vcRef;\r\n  }\r\n\r\n\r\n  /**\r\n   * Returns the form name\r\n   * @returns\r\n   */\r\n  getText() {\r\n    if (this.componentRef !== null) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n      return comp.FormName();\r\n    }\r\n    else\r\n      return \"\";\r\n  }\r\n\r\n  /**\r\n   * Returns CSS styles for the window\r\n   * @returns\r\n   */\r\n  getStyle() {\r\n    let styles = {};\r\n    if (this.componentRef != undefined) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n\r\n      styles['width'] = comp.Width();\r\n      styles['height'] = comp.Height();\r\n\r\n      if (comp.IsCenteredToWindow()) {\r\n        styles['margin'] = \"auto\";\r\n      }\r\n      else {\r\n        styles['margin-left'] = comp.X() + \"px\";\r\n        styles['margin-top'] = comp.Y() + \"px\";\r\n      }\r\n    }\r\n    return styles;\r\n  }\r\n\r\n  /**\r\n   * Returns the CSS styles for the client area\r\n   * @returns\r\n   */\r\n  getClientAreaStyles() {\r\n    let styles = {};\r\n    if (this.componentRef != undefined) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n\r\n      const headerHeight = this.getShowTitleBar() && !isNullOrUndefined(this.headerElementRef) ? (this.headerElementRef.nativeElement.offsetHeight + 1) : 0;\r\n      if (!isNullOrUndefined(this.foregroundElementRef)) {\r\n        const foregroundHeight = this.foregroundElementRef.nativeElement.offsetHeight;\r\n        styles['height'] = (foregroundHeight - headerHeight) + \"px\";\r\n\r\n        const foregroundWidth = this.foregroundElementRef.nativeElement.offsetWidth;\r\n        styles['width'] = (foregroundWidth) + \"px\";\r\n      }\r\n      styles['overflow'] = \"auto\";\r\n    }\r\n    return styles;\r\n  }\r\n\r\n  /**\r\n   * Should the title bar be displayed\r\n   * @returns\r\n   */\r\n  getShowTitleBar() {\r\n    if (this.componentRef != undefined) {\r\n      let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n      return comp.ShowTitleBar();\r\n    }\r\n  }\r\n\r\n  /**\r\n   *\r\n   */\r\n  OnClose() {\r\n    this.onClose.emit();\r\n  }\r\n\r\n  /**\r\n   * Handles click in the background window\r\n   */\r\n  OnBackgroundClick() {\r\n    let comp: MagicModalInterface = this.componentRef.instance as MagicModalInterface;\r\n\r\n    if (comp.ShouldCloseOnBackgroundClick())\r\n      this.OnClose();\r\n  }\r\n}\r\n"]}