@magic-xpa/angular 4.801.0-dev481.243 → 4.801.0-dev481.249
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.
- package/esm2020/index.mjs +57 -0
- package/{esm2015/magic-xpa-angular.js → esm2020/magic-xpa-angular.mjs} +0 -0
- package/{esm2015/src/controls.metadata.model.js → esm2020/src/controls.metadata.model.mjs} +0 -0
- package/{esm2015/src/interfaces/sub-form-definition.iterface.js → esm2020/src/interfaces/sub-form-definition.iterface.mjs} +1 -0
- package/esm2020/src/magic.core.module.mjs +157 -0
- package/{esm2015/src/services/ISubformMagicService.js → esm2020/src/services/ISubformMagicService.mjs} +1 -0
- package/esm2020/src/services/OverlayWindowService.mjs +208 -0
- package/{esm2015/src/services/StylesMapManager.js → esm2020/src/services/StylesMapManager.mjs} +0 -0
- package/{esm2015/src/services/accessor.magic.service.js → esm2020/src/services/accessor.magic.service.mjs} +2 -2
- package/{esm2015/src/services/commands-collector.magic.service.js → esm2020/src/services/commands-collector.magic.service.mjs} +7 -4
- package/esm2020/src/services/component-list.magic.service.mjs +46 -0
- package/{esm2015/src/services/confirmation.components.magic.provider.js → esm2020/src/services/confirmation.components.magic.provider.mjs} +2 -2
- package/esm2020/src/services/engine.magic.service.mjs +82 -0
- package/{esm2015/src/services/exit.magic.service.js → esm2020/src/services/exit.magic.service.mjs} +2 -2
- package/esm2020/src/services/magic.lazy.loader.service.mjs +16 -0
- package/{esm2015/src/services/magic.providers.js → esm2020/src/services/magic.providers.mjs} +0 -0
- package/{esm2015/src/services/magic.services.js → esm2020/src/services/magic.services.mjs} +2 -2
- package/{esm2015/src/services/mg-date-adapter.js → esm2020/src/services/mg-date-adapter.mjs} +2 -2
- package/{esm2015/src/services/overlay.conainer.magic.provider.js → esm2020/src/services/overlay.conainer.magic.provider.mjs} +2 -2
- package/esm2020/src/services/router-commands.magic.service.mjs +28 -0
- package/{esm2015/src/services/subform.magic.service.js → esm2020/src/services/subform.magic.service.mjs} +14 -10
- package/{esm2015/src/services/table.magic.service.js → esm2020/src/services/table.magic.service.mjs} +2 -2
- package/{esm2015/src/services/task.magics.service.js → esm2020/src/services/task.magics.service.mjs} +2 -2
- package/{esm2015/src/services/title.magic.service.js → esm2020/src/services/title.magic.service.mjs} +2 -2
- package/{esm2015/src/ui/GuiInteractiveExecutor.js → esm2020/src/ui/GuiInteractiveExecutor.mjs} +0 -0
- package/{esm2015/src/ui/components/base-magic-alert.component.js → esm2020/src/ui/components/base-magic-alert.component.mjs} +2 -2
- package/{esm2015/src/ui/components/base-magic-confirm.component.js → esm2020/src/ui/components/base-magic-confirm.component.mjs} +2 -2
- package/esm2020/src/ui/components/magic-alert.component.mjs +71 -0
- package/esm2020/src/ui/components/magic-confirmation-box.component.mjs +82 -0
- package/{esm2015/src/ui/directives/NonMagicControlDirective.js → esm2020/src/ui/directives/NonMagicControlDirective.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/checkbox.magic.directive.js → esm2020/src/ui/directives/magic/checkbox.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/combobox.magic.directive.js → esm2020/src/ui/directives/magic/combobox.magic.directive.mjs} +2 -2
- 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
- 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
- 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
- package/{esm2015/src/ui/directives/magic/input.noformcontrol.magic.directive.js → esm2020/src/ui/directives/magic/input.noformcontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/nocontrol.magic.directive.js → esm2020/src/ui/directives/magic/nocontrol.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic/row.magic.directive.js → esm2020/src/ui/directives/magic/row.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/magic-focus.directive.js → esm2020/src/ui/directives/magic-focus.directive.mjs} +2 -2
- package/esm2020/src/ui/directives/magic.directive.mjs +207 -0
- package/{esm2015/src/ui/directives/magicViewContainerRef.directive.js → esm2020/src/ui/directives/magicViewContainerRef.directive.mjs} +3 -3
- package/{esm2015/src/ui/directives/mgformat.magic.directive.js → esm2020/src/ui/directives/mgformat.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/directives/range-validator.magic.directive.js → esm2020/src/ui/directives/range-validator.magic.directive.mjs} +2 -2
- package/{esm2015/src/ui/magic-confirmationBox.js → esm2020/src/ui/magic-confirmationBox.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/base-magic-overlay-container.js → esm2020/src/ui/magic-modal/base-magic-overlay-container.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/magic-modal-form.js → esm2020/src/ui/magic-modal/magic-modal-form.mjs} +0 -0
- package/{esm2015/src/ui/magic-modal/magic-modal-interface.js → esm2020/src/ui/magic-modal/magic-modal-interface.mjs} +1 -0
- package/esm2020/src/ui/magic-modal/magic-overlay-container-wrapper.mjs +135 -0
- package/esm2020/src/ui/magic-modal/magic-overlay-container.mjs +165 -0
- package/esm2020/src/ui/magic-root.component.mjs +237 -0
- package/esm2020/src/ui/mgerror.magic.component.mjs +120 -0
- package/{esm2015/src/ui/pipes/date.magic.pipe.js → esm2020/src/ui/pipes/date.magic.pipe.mjs} +3 -3
- package/{esm2015/src/ui/pipes/time.magic.pipe.js → esm2020/src/ui/pipes/time.magic.pipe.mjs} +3 -3
- package/{esm2015/src/ui/router-container.magic.component.js → esm2020/src/ui/router-container.magic.component.mjs} +2 -2
- package/{esm2015/src/ui/subform.magic.component.js → esm2020/src/ui/subform.magic.component.mjs} +3 -3
- package/{esm2015/src/ui/task-base.magic.component.js → esm2020/src/ui/task-base.magic.component.mjs} +2 -2
- package/{esm2015/src/ui/utils.js → esm2020/src/ui/utils.mjs} +0 -0
- package/fesm2015/magic-xpa-angular.mjs +4578 -0
- package/fesm2015/magic-xpa-angular.mjs.map +1 -0
- package/{fesm2015/magic-xpa-angular.js → fesm2020/magic-xpa-angular.mjs} +433 -412
- package/fesm2020/magic-xpa-angular.mjs.map +1 -0
- package/index.d.ts +1 -0
- package/package.json +28 -15
- package/src/magic.core.module.d.ts +3 -8
- package/src/services/OverlayWindowService.d.ts +2 -2
- package/src/services/accessor.magic.service.d.ts +2 -2
- package/src/services/commands-collector.magic.service.d.ts +2 -2
- package/src/services/component-list.magic.service.d.ts +3 -0
- package/src/services/confirmation.components.magic.provider.d.ts +2 -2
- package/src/services/engine.magic.service.d.ts +2 -2
- package/src/services/exit.magic.service.d.ts +2 -2
- package/src/services/magic.lazy.loader.service.d.ts +6 -0
- package/src/services/magic.services.d.ts +2 -2
- package/src/services/mg-date-adapter.d.ts +2 -2
- package/src/services/overlay.conainer.magic.provider.d.ts +2 -2
- package/src/services/router-commands.magic.service.d.ts +2 -2
- package/src/services/subform.magic.service.d.ts +6 -4
- package/src/services/table.magic.service.d.ts +2 -2
- package/src/services/task.magics.service.d.ts +2 -2
- package/src/services/title.magic.service.d.ts +2 -2
- package/src/ui/components/base-magic-alert.component.d.ts +2 -2
- package/src/ui/components/base-magic-confirm.component.d.ts +2 -2
- package/src/ui/components/magic-alert.component.d.ts +2 -2
- package/src/ui/components/magic-confirmation-box.component.d.ts +2 -2
- package/src/ui/directives/NonMagicControlDirective.d.ts +2 -2
- package/src/ui/directives/magic/checkbox-noformcontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/checkbox.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/combobox.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/checkbox.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/date.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/form-controls/control-value-accessors/default.cva.directive.d.ts +2 -2
- package/src/ui/directives/magic/input.noformcontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/nocontrol.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic/row.magic.directive.d.ts +2 -2
- package/src/ui/directives/magic-focus.directive.d.ts +2 -2
- package/src/ui/directives/magic.directive.d.ts +2 -2
- package/src/ui/directives/magicViewContainerRef.directive.d.ts +2 -2
- package/src/ui/directives/mgformat.magic.directive.d.ts +2 -2
- package/src/ui/directives/range-validator.magic.directive.d.ts +2 -2
- package/src/ui/magic-modal/magic-overlay-container-wrapper.d.ts +7 -5
- package/src/ui/magic-modal/magic-overlay-container.d.ts +2 -2
- package/src/ui/magic-root.component.d.ts +2 -2
- package/src/ui/mgerror.magic.component.d.ts +2 -2
- package/src/ui/pipes/date.magic.pipe.d.ts +2 -2
- package/src/ui/pipes/time.magic.pipe.d.ts +2 -2
- package/src/ui/router-container.magic.component.d.ts +2 -2
- package/src/ui/subform.magic.component.d.ts +2 -2
- package/src/ui/task-base.magic.component.d.ts +2 -2
- package/bundles/magic-xpa-angular.umd.js +0 -5028
- package/bundles/magic-xpa-angular.umd.js.map +0 -1
- package/bundles/magic-xpa-angular.umd.min.js +0 -16
- package/bundles/magic-xpa-angular.umd.min.js.map +0 -1
- package/esm2015/index.js +0 -56
- package/esm2015/src/magic.core.module.js +0 -173
- package/esm2015/src/services/OverlayWindowService.js +0 -205
- package/esm2015/src/services/component-list.magic.service.js +0 -36
- package/esm2015/src/services/engine.magic.service.js +0 -82
- package/esm2015/src/services/router-commands.magic.service.js +0 -25
- package/esm2015/src/ui/components/magic-alert.component.js +0 -72
- package/esm2015/src/ui/components/magic-confirmation-box.component.js +0 -83
- package/esm2015/src/ui/directives/magic.directive.js +0 -207
- package/esm2015/src/ui/magic-modal/magic-overlay-container-wrapper.js +0 -131
- package/esm2015/src/ui/magic-modal/magic-overlay-container.js +0 -169
- package/esm2015/src/ui/magic-root.component.js +0 -237
- package/esm2015/src/ui/mgerror.magic.component.js +0 -120
- package/fesm2015/magic-xpa-angular.js.map +0 -1
|
@@ -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":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EAET,wBAAwB,EACxB,UAAU,EACV,QAAQ,EAAE,iBAAiB,EAAE,QAAQ,EACtC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,EAAE,uBAAuB,EAAE,MAAM,0CAA0C,CAAC;AACnF,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,yBAAyB,EAAc,MAAM,6CAA6C,CAAC;AAEpG,OAAO,EAAC,iBAAiB,EAAC,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;AA2BlF,MAAM,OAAO,4BAA4B;IAkCvC,YAAoB,yBAAoD,EACpD,qBAA6C,EAC7C,QAAkB,EAC5B,wBAAkD,EACxC,iBAAmC,EACnC,QAAkB;QALlB,8BAAyB,GAAzB,yBAAyB,CAA2B;QACpD,0BAAqB,GAArB,qBAAqB,CAAwB;QAC7C,aAAQ,GAAR,QAAQ,CAAU;QAC5B,6BAAwB,GAAxB,wBAAwB,CAA0B;QACxC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,aAAQ,GAAR,QAAQ,CAAU;QAnCtB,cAAS,GAAG,IAAI,CAAC;QAIjB,eAAU,GAAQ,EAAE,CAAC;QAInB,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;IA4BrD,CAAC;IAKD,QAAQ;QACN,IAAI,SAAS,GAAqB,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QAE7G,IAAI,SAAS,IAAI,IAAI,EAAE;YACrB,IAAI,cAAc,GAAe,IAAI,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YAErH,IAAI,cAAc,IAAI,IAAI,EAAE;gBAC1B,IAAI,UAAU,GAAG,cAAc,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;gBAChE,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;gBAC9C,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;oBACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,iCAAiC,CAAM,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;oBACpG,SAAS,GAAG,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBAC3D,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;gBAChC,CAAC,CAAC,CAAC;aACJ;iBACI;gBACH,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;aAC1B;SACF;;YACC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;IAEO,aAAa,CAAC,SAA2B;QAC/C,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC;QAE1J,IAAI,OAAO,CAAC;QACZ,IAAI,SAAS,IAAI,IAAI;YACnB,OAAO,GAAG,SAAS,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;;YAErF,OAAO,GAAG,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAElF,IAAI,YAAY,GAAG,IAAI,CAAC,8BAA8B,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAChF,IAAI,eAAe,GAAG,4BAA4B,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAG/F,IAAI,YAAY,CAAC,QAAQ,YAAY,eAAe,CAAC,IAAI,EAAE;YACzD,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAChD,YAAY,CAAC,QAAS,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBACrD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACzB,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,GAAG,GAAG,kDAAkD,GAAG,eAAe,CAAC,KAAK,GAAG,gCAAgC,CAAC;YACxH,KAAK,CAAC,GAAG,CAAC,CAAC;SACZ;IACH,CAAC;IAED,mBAAmB,CAAC,KAAuB;QACzC,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC;IAC9C,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,iCAAiC,CAAC,aAAa,CAAC;IAC9D,CAAC;IAED,aAAa;QAEX,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;;AA7EM,6CAAgB,GAAG,IAAI,GAAG,CAAqC;IACpE,CAAC,WAAW,CAAC,OAAO,EAAE,EAAC,IAAI,EAAE,yBAAyB,EAAE,KAAK,EAAC,sCAAsC,EAAC,CAAC;IACtG,CAAC,WAAW,CAAC,KAAK,EAAE,EAAC,IAAI,EAAE,uBAAuB,EAAE,KAAK,EAAC,iCAAiC,EAAC,CAAC;IAC7F,CAAC,WAAW,CAAC,eAAe,EAAG,EAAC,IAAI,EAAE,yBAAyB,EAAE,KAAK,EAAE,0CAA0C,EAAC,CAAC;CACrH,CAAE,CAAA;wGA7BQ,4BAA4B;iEAA5B,4BAA4B;;;;;;QArBrC,2BAAK;QACH,yBAAiH;QACjH,iCAA2E;QACzE,4BACM;QACR,iBAAM;QACN,yBAAuG;QACzG,iBAAM;;uFAcG,4BAA4B;cAxBxC,SAAS;eAAC;gBACT,QAAQ,EAAE,qCAAqC;gBAC/C,QAAQ,EAAE;;;;;;;;;GAST;gBACD,MAAM,EAAE,CAAC;;;;;;;;;;GAUR,CAAC;aACH;sOAKiB,SAAS;kBAAxB,KAAK;YAIU,UAAU;kBAAzB,KAAK;YAEW,gBAAgB;kBAAhC,KAAK;YAEY,OAAO;kBAAxB,MAAM;YAOiD,iCAAiC;kBAAxF,SAAS;mBAAC,yBAAyB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","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"]}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import { ChangeDetectorRef, Component, ElementRef, HostListener, Input, Optional, TemplateRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { CommandType } from '@magic-xpa/gui';
|
|
3
|
+
import { Title } from '@angular/platform-browser';
|
|
4
|
+
import { EngineMagicService } from '../services/engine.magic.service';
|
|
5
|
+
import { ComponentListMagicService } from '../services/component-list.magic.service';
|
|
6
|
+
import { GuiInteractiveExecutor } from './GuiInteractiveExecutor';
|
|
7
|
+
import { filter } from 'rxjs/operators';
|
|
8
|
+
import { ExitMagicService } from '../services/exit.magic.service';
|
|
9
|
+
import { OverlayWindowService } from '../services/OverlayWindowService';
|
|
10
|
+
import { CommandsCollectorMagicService } from '../services/commands-collector.magic.service';
|
|
11
|
+
import { HttpClient } from '@angular/common/http';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "../services/engine.magic.service";
|
|
14
|
+
import * as i2 from "../services/component-list.magic.service";
|
|
15
|
+
import * as i3 from "@angular/platform-browser";
|
|
16
|
+
import * as i4 from "../services/OverlayWindowService";
|
|
17
|
+
import * as i5 from "@angular/common/http";
|
|
18
|
+
import * as i6 from "../services/commands-collector.magic.service";
|
|
19
|
+
import * as i7 from "../services/exit.magic.service";
|
|
20
|
+
import * as i8 from "@angular/common";
|
|
21
|
+
import * as i9 from "ng-dynamic-component";
|
|
22
|
+
import * as i10 from "./directives/magicViewContainerRef.directive";
|
|
23
|
+
const _c0 = ["magicRoot"];
|
|
24
|
+
function MagicShellComponent_ndc_dynamic_2_Template(rf, ctx) { if (rf & 1) {
|
|
25
|
+
i0.ɵɵelement(0, "ndc-dynamic", 6);
|
|
26
|
+
} if (rf & 2) {
|
|
27
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
28
|
+
i0.ɵɵproperty("ndcDynamicComponent", ctx_r1.RootComponent)("ndcDynamicInputs", ctx_r1.RootComponentParameters);
|
|
29
|
+
} }
|
|
30
|
+
function MagicShellComponent_div_5_Template(rf, ctx) { if (rf & 1) {
|
|
31
|
+
i0.ɵɵelementStart(0, "div", 7);
|
|
32
|
+
i0.ɵɵelementContainer(1, 8);
|
|
33
|
+
i0.ɵɵelementEnd();
|
|
34
|
+
} if (rf & 2) {
|
|
35
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
36
|
+
const _r4 = i0.ɵɵreference(7);
|
|
37
|
+
i0.ɵɵadvance(1);
|
|
38
|
+
i0.ɵɵproperty("ngTemplateOutlet", ctx_r3.SpinnerTemplate ? ctx_r3.SpinnerTemplate : _r4);
|
|
39
|
+
} }
|
|
40
|
+
function MagicShellComponent_ng_template_6_Template(rf, ctx) { if (rf & 1) {
|
|
41
|
+
i0.ɵɵelement(0, "div", 9);
|
|
42
|
+
} }
|
|
43
|
+
export class MagicShellComponent {
|
|
44
|
+
constructor(engineMagicService, componentList, changeDetectorRef, titleService, overlayWindowService, httpClient, pendingCommandsCollector, exitMagicService) {
|
|
45
|
+
this.engineMagicService = engineMagicService;
|
|
46
|
+
this.componentList = componentList;
|
|
47
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
48
|
+
this.titleService = titleService;
|
|
49
|
+
this.overlayWindowService = overlayWindowService;
|
|
50
|
+
this.httpClient = httpClient;
|
|
51
|
+
this.pendingCommandsCollector = pendingCommandsCollector;
|
|
52
|
+
this.exitMagicService = exitMagicService;
|
|
53
|
+
this.RootComponent = null;
|
|
54
|
+
this.magicEngineTerminated = false;
|
|
55
|
+
this.initialize();
|
|
56
|
+
this.setTitle();
|
|
57
|
+
}
|
|
58
|
+
onBeforeUnload(event) {
|
|
59
|
+
if (this.engineMagicService.TransCacheExists()) {
|
|
60
|
+
event.returnValue = 'Are you sure?';
|
|
61
|
+
return 'Are you sure?';
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this.engineMagicService.TerminateContextUsingFetchAPI();
|
|
65
|
+
this.magicEngineTerminated = true;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
onUnload(event) {
|
|
69
|
+
if (!this.magicEngineTerminated)
|
|
70
|
+
this.engineMagicService.TerminateContextUsingFetchAPI();
|
|
71
|
+
}
|
|
72
|
+
ngAfterViewInit() {
|
|
73
|
+
this.overlayWindowService.init(this.overlayWindowsContainerViewRef, this.rootMagicElementRef.nativeElement);
|
|
74
|
+
this.engineMagicService.startMagicEngine(this.httpClient);
|
|
75
|
+
}
|
|
76
|
+
setViewContainerRef(vcRef) {
|
|
77
|
+
this.overlayWindowsContainerViewRef = vcRef;
|
|
78
|
+
}
|
|
79
|
+
initialize() {
|
|
80
|
+
this.registerUICommands();
|
|
81
|
+
}
|
|
82
|
+
setTitle() {
|
|
83
|
+
const newTitle = this.componentList.title;
|
|
84
|
+
this.titleService.setTitle(newTitle);
|
|
85
|
+
}
|
|
86
|
+
setComponent(formName, taskId, taskDescription, isModal) {
|
|
87
|
+
this.pendingCommandsCollector.startCollecting();
|
|
88
|
+
if (isModal) {
|
|
89
|
+
this.overlayWindowService.open(formName, taskId, taskDescription);
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
this.RootComponent = this.componentList.getComponent(formName);
|
|
93
|
+
this.RootComponentParameters = { taskIdParam: taskId, taskDescription: taskDescription };
|
|
94
|
+
}
|
|
95
|
+
this.changeDetectorRef.detectChanges();
|
|
96
|
+
}
|
|
97
|
+
registerUICommands() {
|
|
98
|
+
this.engineMagicService.refreshDom.pipe(filter(command => command.TaskTag === '0'))
|
|
99
|
+
.subscribe(command => {
|
|
100
|
+
this.executeCommand(command);
|
|
101
|
+
});
|
|
102
|
+
this.engineMagicService
|
|
103
|
+
.interactiveCommands.pipe(filter(command => command.TaskTag === '0'))
|
|
104
|
+
.subscribe(command => {
|
|
105
|
+
GuiInteractiveExecutor.executeInteractiveCommand(null, command, this.overlayWindowService);
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
executeCommand(command) {
|
|
109
|
+
switch (command.CommandType) {
|
|
110
|
+
case CommandType.OPEN_FORM:
|
|
111
|
+
this.setComponent(command.str, command.stringList[0], command.stringList[1], command.Bool1);
|
|
112
|
+
break;
|
|
113
|
+
case CommandType.SET_IS_LOGGED_IN:
|
|
114
|
+
this.engineMagicService.setIsLoggedIn(command.Bool1);
|
|
115
|
+
break;
|
|
116
|
+
case CommandType.CLOSE_FORM:
|
|
117
|
+
if (this.RootComponent != null && command.str === this.RootComponentParameters.taskIdParam) {
|
|
118
|
+
this.RootComponent = null;
|
|
119
|
+
this.RootComponentParameters = {};
|
|
120
|
+
this.changeDetectorRef.detectChanges();
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
this.overlayWindowService.close(command.str);
|
|
124
|
+
this.changeDetectorRef.detectChanges();
|
|
125
|
+
}
|
|
126
|
+
break;
|
|
127
|
+
case CommandType.RELOAD_PAGE:
|
|
128
|
+
window.location.reload();
|
|
129
|
+
break;
|
|
130
|
+
case CommandType.SHOW_SPINNER:
|
|
131
|
+
if (this.showSpinner != command.Bool1) {
|
|
132
|
+
this.showSpinner = command.Bool1;
|
|
133
|
+
this.changeDetectorRef.detectChanges();
|
|
134
|
+
}
|
|
135
|
+
break;
|
|
136
|
+
case CommandType.EXIT_MAGIC:
|
|
137
|
+
if (this.exitMagicService)
|
|
138
|
+
this.exitMagicService.exitMagic();
|
|
139
|
+
break;
|
|
140
|
+
case CommandType.SHOW_HTML_ERROR:
|
|
141
|
+
window.document.write(command.str);
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
MagicShellComponent.ɵfac = function MagicShellComponent_Factory(t) { return new (t || MagicShellComponent)(i0.ɵɵdirectiveInject(i1.EngineMagicService), i0.ɵɵdirectiveInject(i2.ComponentListMagicService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i3.Title), i0.ɵɵdirectiveInject(i4.OverlayWindowService), i0.ɵɵdirectiveInject(i5.HttpClient), i0.ɵɵdirectiveInject(i6.CommandsCollectorMagicService), i0.ɵɵdirectiveInject(i7.ExitMagicService, 8)); };
|
|
147
|
+
MagicShellComponent.ɵcmp = i0.ɵɵdefineComponent({ type: MagicShellComponent, selectors: [["magic-root"]], viewQuery: function MagicShellComponent_Query(rf, ctx) { if (rf & 1) {
|
|
148
|
+
i0.ɵɵviewQuery(_c0, 7);
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
let _t;
|
|
151
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.rootMagicElementRef = _t.first);
|
|
152
|
+
} }, hostBindings: function MagicShellComponent_HostBindings(rf, ctx) { if (rf & 1) {
|
|
153
|
+
i0.ɵɵlistener("beforeunload", function MagicShellComponent_beforeunload_HostBindingHandler($event) { return ctx.onBeforeUnload($event); }, false, i0.ɵɵresolveWindow)("unload", function MagicShellComponent_unload_HostBindingHandler($event) { return ctx.onUnload($event); }, false, i0.ɵɵresolveWindow);
|
|
154
|
+
} }, inputs: { SpinnerTemplate: "SpinnerTemplate" }, features: [i0.ɵɵProvidersFeature([])], decls: 8, vars: 2, consts: [["magicRoot", ""], [3, "ndcDynamicComponent", "ndcDynamicInputs", 4, "ngIf"], ["magicViewContainerRef", ""], ["overlayWindowsContainer", ""], ["class", "spinner-background", 4, "ngIf"], ["defaultSpinner", ""], [3, "ndcDynamicComponent", "ndcDynamicInputs"], [1, "spinner-background"], [3, "ngTemplateOutlet"], [1, "mgSpinnerClass"]], template: function MagicShellComponent_Template(rf, ctx) { if (rf & 1) {
|
|
155
|
+
i0.ɵɵelementStart(0, "div", null, 0);
|
|
156
|
+
i0.ɵɵtemplate(2, MagicShellComponent_ndc_dynamic_2_Template, 1, 2, "ndc-dynamic", 1);
|
|
157
|
+
i0.ɵɵelement(3, "div", 2, 3);
|
|
158
|
+
i0.ɵɵelementEnd();
|
|
159
|
+
i0.ɵɵtemplate(5, MagicShellComponent_div_5_Template, 2, 1, "div", 4);
|
|
160
|
+
i0.ɵɵtemplate(6, MagicShellComponent_ng_template_6_Template, 1, 0, "ng-template", null, 5, i0.ɵɵtemplateRefExtractor);
|
|
161
|
+
} if (rf & 2) {
|
|
162
|
+
i0.ɵɵadvance(2);
|
|
163
|
+
i0.ɵɵproperty("ngIf", ctx.RootComponent !== null);
|
|
164
|
+
i0.ɵɵadvance(3);
|
|
165
|
+
i0.ɵɵproperty("ngIf", ctx.showSpinner);
|
|
166
|
+
} }, directives: [i8.NgIf, i9.DynamicComponent, i9.DynamicIoDirective, i10.MagicViewContainerRef, i8.NgTemplateOutlet], styles: [".mgSpinnerClass[_ngcontent-%COMP%]{border:10px solid #cccccc;border-top:10px solid black;border-radius:50%;position:fixed;margin:auto;top:0;right:0;bottom:0;left:0;width:100px;height:100px;animation:spin 2s linear infinite}.spinner-background[_ngcontent-%COMP%]{position:fixed;top:0;right:0;bottom:0;z-index:1000;left:0;opacity:.5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}"] });
|
|
167
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MagicShellComponent, [{
|
|
168
|
+
type: Component,
|
|
169
|
+
args: [{
|
|
170
|
+
selector: 'magic-root',
|
|
171
|
+
providers: [],
|
|
172
|
+
template: `
|
|
173
|
+
<div #magicRoot>
|
|
174
|
+
<ndc-dynamic
|
|
175
|
+
*ngIf = "RootComponent !== null"
|
|
176
|
+
[ndcDynamicComponent]="RootComponent"
|
|
177
|
+
[ndcDynamicInputs] ="RootComponentParameters">
|
|
178
|
+
</ndc-dynamic>
|
|
179
|
+
|
|
180
|
+
<div #overlayWindowsContainer magicViewContainerRef>
|
|
181
|
+
</div>
|
|
182
|
+
</div>
|
|
183
|
+
|
|
184
|
+
<div class="spinner-background" *ngIf="showSpinner">
|
|
185
|
+
<ng-container [ngTemplateOutlet]="SpinnerTemplate ? SpinnerTemplate:defaultSpinner"></ng-container>
|
|
186
|
+
</div>
|
|
187
|
+
|
|
188
|
+
<ng-template #defaultSpinner>
|
|
189
|
+
<div class="mgSpinnerClass"></div>
|
|
190
|
+
</ng-template>
|
|
191
|
+
`,
|
|
192
|
+
styles: [`
|
|
193
|
+
.mgSpinnerClass {
|
|
194
|
+
border: 10px solid #cccccc; /* Light grey */
|
|
195
|
+
border-top: 10px solid black; /* Blue */
|
|
196
|
+
border-radius: 50%;
|
|
197
|
+
position: fixed;
|
|
198
|
+
margin: auto;
|
|
199
|
+
top: 0;
|
|
200
|
+
right: 0;
|
|
201
|
+
bottom: 0;
|
|
202
|
+
left: 0;
|
|
203
|
+
width: 100px;
|
|
204
|
+
height: 100px;
|
|
205
|
+
animation: spin 2s linear infinite;
|
|
206
|
+
}
|
|
207
|
+
.spinner-background {
|
|
208
|
+
/* background fixed across whole screen */
|
|
209
|
+
position: fixed;
|
|
210
|
+
top: 0;
|
|
211
|
+
right: 0;
|
|
212
|
+
bottom: 0;
|
|
213
|
+
z-index: 1000;
|
|
214
|
+
left: 0;
|
|
215
|
+
opacity: 0.5;
|
|
216
|
+
}
|
|
217
|
+
@keyframes spin {
|
|
218
|
+
0% { transform: rotate(0deg); }
|
|
219
|
+
100% { transform: rotate(360deg); }
|
|
220
|
+
}
|
|
221
|
+
`]
|
|
222
|
+
}]
|
|
223
|
+
}], function () { return [{ type: i1.EngineMagicService }, { type: i2.ComponentListMagicService }, { type: i0.ChangeDetectorRef }, { type: i3.Title }, { type: i4.OverlayWindowService }, { type: i5.HttpClient }, { type: i6.CommandsCollectorMagicService }, { type: i7.ExitMagicService, decorators: [{
|
|
224
|
+
type: Optional
|
|
225
|
+
}] }]; }, { rootMagicElementRef: [{
|
|
226
|
+
type: ViewChild,
|
|
227
|
+
args: ['magicRoot', { static: true }]
|
|
228
|
+
}], SpinnerTemplate: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], onBeforeUnload: [{
|
|
231
|
+
type: HostListener,
|
|
232
|
+
args: ['window:beforeunload', ['$event']]
|
|
233
|
+
}], onUnload: [{
|
|
234
|
+
type: HostListener,
|
|
235
|
+
args: ['window:unload', ['$event']]
|
|
236
|
+
}] }); })();
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magic-root.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/ui/magic-root.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  Optional,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { CommandType, GuiCommand } from '@magic-xpa/gui';\r\nimport { Title } from '@angular/platform-browser';\r\nimport { EngineMagicService } from '../services/engine.magic.service';\r\nimport { ComponentListMagicService } from '../services/component-list.magic.service';\r\nimport { GuiInteractiveExecutor } from './GuiInteractiveExecutor';\r\nimport { filter } from 'rxjs/operators';\r\nimport { ExitMagicService } from '../services/exit.magic.service';\r\nimport { OverlayWindowService } from '../services/OverlayWindowService';\r\nimport { IMagicViewContainerRef } from '../..';\r\nimport { CommandsCollectorMagicService } from '../services/commands-collector.magic.service';\r\nimport { HttpClient } from '@angular/common/http';\r\n\r\n/**\r\n * Root Magic component\r\n */\r\n@Component({\r\n  selector: 'magic-root',\r\n  providers: [\r\n   // ExitMagicService\r\n  ],\r\n  template: `\r\n    <div #magicRoot>\r\n      <ndc-dynamic\r\n        *ngIf = \"RootComponent !== null\"\r\n        [ndcDynamicComponent]=\"RootComponent\"\r\n        [ndcDynamicInputs]   =\"RootComponentParameters\">\r\n      </ndc-dynamic>\r\n\r\n      <div #overlayWindowsContainer magicViewContainerRef>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"spinner-background\" *ngIf=\"showSpinner\">\r\n      <ng-container [ngTemplateOutlet]=\"SpinnerTemplate ? SpinnerTemplate:defaultSpinner\"></ng-container>\r\n    </div>\r\n\r\n    <ng-template #defaultSpinner>\r\n      <div class=\"mgSpinnerClass\"></div>\r\n    </ng-template>\r\n  `,\r\n  styles: [`\r\n    .mgSpinnerClass {\r\n      border: 10px solid #cccccc; /* Light grey */\r\n      border-top: 10px solid black; /* Blue */\r\n      border-radius: 50%;\r\n      position: fixed;\r\n      margin: auto;\r\n      top: 0;\r\n      right: 0;\r\n      bottom: 0;\r\n      left: 0;\r\n      width: 100px;\r\n      height: 100px;\r\n      animation: spin 2s linear infinite;\r\n    }\r\n    .spinner-background {\r\n      /* background fixed across whole screen */\r\n      position: fixed;\r\n      top: 0;\r\n      right: 0;\r\n      bottom: 0;\r\n      z-index: 1000;\r\n      left: 0;\r\n      opacity: 0.5;\r\n    }\r\n    @keyframes spin {\r\n      0% { transform: rotate(0deg); }\r\n      100% { transform: rotate(360deg); }\r\n    }\r\n  `]\r\n})\r\nexport class MagicShellComponent implements AfterViewInit, IMagicViewContainerRef {\r\n  /**\r\n   * Root component to be displayed in the window\r\n   */\r\n  RootComponent : Component = null;\r\n  /**\r\n   * parameters for the Root Component\r\n   */\r\n  RootComponentParameters : any;\r\n\r\n  overlayWindowsContainerViewRef: ViewContainerRef;\r\n\r\n  @ViewChild('magicRoot', { static: true }) rootMagicElementRef: ElementRef;\r\n\r\n  @Input() SpinnerTemplate: TemplateRef<any>;\r\n\r\n  showSpinner: boolean;\r\n  magicEngineTerminated: boolean = false;\r\n\r\n  /**\r\n   *\r\n   * @param magic Magic's service\r\n   * @param componentList Magic component list\r\n   * @param changeDetectorRef Changes detector\r\n   * @param titleService Title setting service\r\n   * @param httpClient The native httpClient instance\r\n   * @param exitMagicService Magic exit service\r\n   */\r\n  constructor(protected engineMagicService: EngineMagicService,\r\n              protected componentList:ComponentListMagicService,\r\n              protected changeDetectorRef: ChangeDetectorRef,\r\n              private titleService: Title,\r\n              private overlayWindowService: OverlayWindowService,\r\n              private httpClient: HttpClient,\r\n              private pendingCommandsCollector: CommandsCollectorMagicService,\r\n              @Optional()  public exitMagicService: ExitMagicService) {\r\n\r\n    this.initialize();\r\n    this.setTitle();\r\n  }\r\n\r\n  /**\r\n   * Before-unload event listener\r\n   * @param event\r\n   */\r\n  @HostListener('window:beforeunload', ['$event'])\r\n  onBeforeUnload(event) {\r\n    if(this.engineMagicService.TransCacheExists())\r\n    {\r\n      // Show the confirmation box before unloading the browser\r\n      event.returnValue = 'Are you sure?';\r\n      return 'Are you sure?';\r\n    }\r\n    else\r\n    {\r\n      // terminate the magic server context using fetch API with keep-alive\r\n      this.engineMagicService.TerminateContextUsingFetchAPI();\r\n      this.magicEngineTerminated = true;\r\n    }\r\n  }\r\n\r\n  @HostListener('window:unload', ['$event'])\r\n  onUnload(event) {\r\n    // Chrome provides an opportunity to terminate the context after user approves the browser unload alert\r\n    if(!this.magicEngineTerminated)\r\n      this.engineMagicService.TerminateContextUsingFetchAPI();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.overlayWindowService.init(this.overlayWindowsContainerViewRef, this.rootMagicElementRef.nativeElement);\r\n    this.engineMagicService.startMagicEngine(this.httpClient);\r\n  }\r\n\r\n  setViewContainerRef(vcRef: ViewContainerRef){\r\n    this.overlayWindowsContainerViewRef = vcRef;\r\n  }\r\n\r\n  /**\r\n   * Initialization of Magic mechanisms\r\n   */\r\n  initialize() {\r\n    this.registerUICommands();\r\n  }\r\n\r\n  /**\r\n   * Set the title\r\n   */\r\n  public setTitle( ) {\r\n    const newTitle: string = this.componentList.title;\r\n    this.titleService.setTitle( newTitle );\r\n  }\r\n\r\n  /**\r\n   * Set the component according to requested form\r\n   * @param formName Name of the form to open\r\n   * @param taskId Id of opening task\r\n   * @param taskDescription TODO\r\n   * @param isModal whether modal window is being opened\r\n   */\r\n  private setComponent(formName: string, taskId: string, taskDescription: string, isModal: boolean) {\r\n    this.pendingCommandsCollector.startCollecting();\r\n\r\n    if(isModal) {\r\n      this.overlayWindowService.open(formName, taskId, taskDescription);\r\n    }\r\n    else {\r\n      this.RootComponent = this.componentList.getComponent(formName);\r\n      this.RootComponentParameters = { taskIdParam: taskId, taskDescription: taskDescription };\r\n    }\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  registerUICommands() {\r\n    this.engineMagicService.refreshDom.pipe(\r\n      filter(command => command.TaskTag === '0'))\r\n      .subscribe(command => {\r\n        this.executeCommand(command);\r\n      });\r\n    this.engineMagicService\r\n      .interactiveCommands.pipe(\r\n      filter(command => command.TaskTag === '0'))\r\n      .subscribe(command => {\r\n        GuiInteractiveExecutor.executeInteractiveCommand(null, command, this.overlayWindowService);\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Execute commands received from the Magic WebClient engine\r\n   * @param command\r\n   */\r\n  executeCommand(command: GuiCommand): void {\r\n    switch (command.CommandType) {\r\n      case CommandType.OPEN_FORM:\r\n          this.setComponent(command.str, command.stringList[0], command.stringList[1], command.Bool1);\r\n          break;\r\n\r\n      case CommandType.SET_IS_LOGGED_IN:\r\n        this.engineMagicService.setIsLoggedIn(command.Bool1);\r\n        break;\r\n\r\n      case CommandType.CLOSE_FORM:\r\n        if (this.RootComponent != null && command.str === this.RootComponentParameters.taskIdParam) {\r\n          this.RootComponent = null;\r\n          this.RootComponentParameters = {};\r\n\r\n          this.changeDetectorRef.detectChanges();\r\n        }\r\n        else { // Close modal window\r\n          this.overlayWindowService.close(command.str);\r\n          this.changeDetectorRef.detectChanges();\r\n        }\r\n        break;\r\n\r\n      case CommandType.RELOAD_PAGE:\r\n        window.location.reload();\r\n        break;\r\n\r\n      case CommandType.SHOW_SPINNER:\r\n        if (this.showSpinner != command.Bool1) {\r\n          this.showSpinner = command.Bool1;\r\n          this.changeDetectorRef.detectChanges();\r\n        }\r\n        break;\r\n\r\n      case CommandType.EXIT_MAGIC:\r\n        if (this.exitMagicService)\r\n          this.exitMagicService.exitMagic();\r\n        break;\r\n\r\n      case CommandType.SHOW_HTML_ERROR:\r\n        window.document.write(command.str);\r\n        break;\r\n    }\r\n  }\r\n}\r\n"]}
|