ngx-rs-ant 1.6.2 → 1.6.4
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/box-container/box-container.module.d.ts +7 -6
- package/box-container/box-item/item-config/form-item-config-error/form-item-config-error.component.d.ts +5 -0
- package/camunda-bpmn-editor/camunda-bpmn-editor.component.d.ts +7 -2
- package/camunda-bpmn-editor/custom/hide-other/HideOtherContextPadProvider.d.ts +9 -5
- package/esm2020/box-container/PluginManager.mjs +11 -2
- package/esm2020/box-container/box-container.module.mjs +4 -1
- package/esm2020/box-container/box-item/item-config/form-item-config-error/form-item-config-error.component.mjs +11 -0
- package/esm2020/box-container/plugin-active/plugin-active.component.mjs +3 -3
- package/esm2020/box-container/plugin-hover/plugin-hover.component.mjs +3 -3
- package/esm2020/camunda-bpmn-editor/camunda-bpmn-editor.component.mjs +29 -7
- package/esm2020/camunda-bpmn-editor/custom/hide-other/HideOtherContextPadProvider.mjs +11 -12
- package/esm2020/camunda-bpmn-editor/custom/hide-other/HideOtherPaletteProvider.mjs +2 -3
- package/esm2020/camunda-bpmn-editor/custom/service-task/ServiceTaskContextPadProvider.mjs +2 -2
- package/esm2020/camunda-bpmn-editor/custom/service-task/ServiceTaskPaletteProvider.mjs +2 -2
- package/esm2020/camunda-bpmn-editor/custom/translate/translations.mjs +21 -293
- package/esm2020/camunda-bpmn-editor/custom/user-task/UserTaskContextPadProvider.mjs +2 -2
- package/esm2020/camunda-bpmn-editor/custom/user-task/UserTaskPaletteProvider.mjs +2 -2
- package/esm2020/code-editor/code-editor.component.mjs +3 -3
- package/esm2020/form/field-selector/field-selector.component.mjs +144 -0
- package/esm2020/form/form.module.mjs +10 -5
- package/esm2020/icon-selector/icon-selector.component.mjs +3 -3
- package/esm2020/modal/modal.component.mjs +3 -3
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/util/form-item-config-base.mjs +7 -0
- package/fesm2015/ngx-rs-ant.mjs +242 -473
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +242 -473
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/form/field-selector/field-selector.component.d.ts +25 -0
- package/form/form.module.d.ts +5 -4
- package/package.json +2 -2
- package/public-api.d.ts +2 -0
- package/util/form-item-config-base.d.ts +6 -0
- package/camunda-bpmn-editor/custom/config/CustomPropertiesProvider.d.ts +0 -5
- package/camunda-bpmn-editor/custom/config/index.d.ts +0 -6
- package/camunda-bpmn-editor/custom/config/properties/user-task/TaskDescriptionProps.d.ts +0 -6
- package/camunda-bpmn-editor/custom/config/properties/user-task/user-assignment/UserAssignmentProps.d.ts +0 -2
- package/camunda-bpmn-editor/custom/config/properties/user-task/user-assignment/UserAssignmentStaticOrDynamicProps.d.ts +0 -6
- package/camunda-bpmn-editor/custom/config/util/ElementUtils.d.ts +0 -3
- package/esm2020/camunda-bpmn-editor/custom/config/CustomPropertiesProvider.mjs +0 -33
- package/esm2020/camunda-bpmn-editor/custom/config/index.mjs +0 -6
- package/esm2020/camunda-bpmn-editor/custom/config/properties/user-task/TaskDescriptionProps.mjs +0 -26
- package/esm2020/camunda-bpmn-editor/custom/config/properties/user-task/user-assignment/UserAssignmentProps.mjs +0 -5
- package/esm2020/camunda-bpmn-editor/custom/config/properties/user-task/user-assignment/UserAssignmentStaticOrDynamicProps.mjs +0 -32
- package/esm2020/camunda-bpmn-editor/custom/config/util/ElementUtils.mjs +0 -52
|
@@ -10,13 +10,14 @@ import * as i8 from "./box-item/item-config/item-config.component";
|
|
|
10
10
|
import * as i9 from "./box-item/item-style/item-style.component";
|
|
11
11
|
import * as i10 from "./box-item/item-style/style-blank/style-blank.component";
|
|
12
12
|
import * as i11 from "./box-item/item-blank/item-blank.component";
|
|
13
|
-
import * as i12 from "./box-item/item-
|
|
14
|
-
import * as i13 from "./
|
|
15
|
-
import * as i14 from "./
|
|
16
|
-
import * as i15 from "
|
|
17
|
-
import * as i16 from "
|
|
13
|
+
import * as i12 from "./box-item/item-config/form-item-config-error/form-item-config-error.component";
|
|
14
|
+
import * as i13 from "./box-item/item-style/style/style.component";
|
|
15
|
+
import * as i14 from "./plugin-not-found/plugin-not-found.component";
|
|
16
|
+
import * as i15 from "./box-item/item-config/config-blank/config-blank.component";
|
|
17
|
+
import * as i16 from "@angular/common";
|
|
18
|
+
import * as i17 from "devextreme-angular";
|
|
18
19
|
export declare class BoxContainerModule {
|
|
19
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<BoxContainerModule, never>;
|
|
20
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<BoxContainerModule, [typeof i1.BoxContainerComponent, typeof i2.BoxItemHostDirective, typeof i3.BoxItemComponent, typeof i4.PluginActiveComponent, typeof i5.DividerComponent, typeof i6.DividerLineComponent, typeof i7.PluginHoverComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent, typeof i10.StyleBlankComponent, typeof i11.ItemBlankComponent, typeof i12.
|
|
21
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<BoxContainerModule, [typeof i1.BoxContainerComponent, typeof i2.BoxItemHostDirective, typeof i3.BoxItemComponent, typeof i4.PluginActiveComponent, typeof i5.DividerComponent, typeof i6.DividerLineComponent, typeof i7.PluginHoverComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent, typeof i10.StyleBlankComponent, typeof i11.ItemBlankComponent, typeof i12.FormItemConfigErrorComponent, typeof i13.StyleComponent, typeof i14.PluginNotFoundComponent, typeof i15.ConfigBlankComponent], [typeof i16.CommonModule, typeof i17.DevExtremeModule], [typeof i1.BoxContainerComponent, typeof i8.ItemConfigComponent, typeof i9.ItemStyleComponent]>;
|
|
21
22
|
static ɵinj: i0.ɵɵInjectorDeclaration<BoxContainerModule>;
|
|
22
23
|
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class FormItemConfigErrorComponent {
|
|
3
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FormItemConfigErrorComponent, never>;
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FormItemConfigErrorComponent, "rs-form-item-config-error", never, {}, {}, never, never, false, never>;
|
|
5
|
+
}
|
|
@@ -1,14 +1,19 @@
|
|
|
1
|
-
import { ElementRef } from '@angular/core';
|
|
1
|
+
import { ElementRef, EventEmitter } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class CamundaBpmnEditorComponent {
|
|
4
4
|
set xml(xml: any);
|
|
5
5
|
get xml(): any;
|
|
6
6
|
private _xml;
|
|
7
|
+
selectedNodeChanged: EventEmitter<{
|
|
8
|
+
element: any;
|
|
9
|
+
util?: any;
|
|
10
|
+
}>;
|
|
7
11
|
bpmnContainer?: ElementRef;
|
|
8
12
|
bpmnConfig?: ElementRef;
|
|
9
13
|
private modeler;
|
|
10
14
|
private canvas;
|
|
11
15
|
protected isShowXml: boolean;
|
|
16
|
+
protected isShowConfig: boolean;
|
|
12
17
|
private initialDiagram;
|
|
13
18
|
ngOnInit(): void;
|
|
14
19
|
ngAfterViewInit(): void;
|
|
@@ -16,5 +21,5 @@ export declare class CamundaBpmnEditorComponent {
|
|
|
16
21
|
showXml(): void;
|
|
17
22
|
saveXml(callback?: any): void;
|
|
18
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<CamundaBpmnEditorComponent, never>;
|
|
19
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CamundaBpmnEditorComponent, "rs-camunda-bpmn-editor", never, { "xml": "xml"; }, {}, never, never, false, never>;
|
|
24
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CamundaBpmnEditorComponent, "rs-camunda-bpmn-editor", never, { "xml": "xml"; }, { "selectedNodeChanged": "selectedNodeChanged"; }, never, never, false, never>;
|
|
20
25
|
}
|
|
@@ -4,8 +4,15 @@ export default class HideOtherContextPadProvider {
|
|
|
4
4
|
private readonly popupMenu;
|
|
5
5
|
constructor(contextPad: any, translate: any, popupMenu: any);
|
|
6
6
|
getContextPadEntries(element: any): (entries: any) => {
|
|
7
|
+
delete?: undefined;
|
|
8
|
+
replace?: undefined;
|
|
9
|
+
'append.user-task'?: undefined;
|
|
10
|
+
'append.service-task'?: undefined;
|
|
11
|
+
'append.gateway'?: undefined;
|
|
12
|
+
'append.end-event'?: undefined;
|
|
13
|
+
connect?: undefined;
|
|
14
|
+
} | {
|
|
7
15
|
delete: any;
|
|
8
|
-
'set-color': any;
|
|
9
16
|
replace?: undefined;
|
|
10
17
|
'append.user-task'?: undefined;
|
|
11
18
|
'append.service-task'?: undefined;
|
|
@@ -22,7 +29,6 @@ export default class HideOtherContextPadProvider {
|
|
|
22
29
|
};
|
|
23
30
|
};
|
|
24
31
|
delete: any;
|
|
25
|
-
'set-color': any;
|
|
26
32
|
'append.user-task'?: undefined;
|
|
27
33
|
'append.service-task'?: undefined;
|
|
28
34
|
'append.gateway'?: undefined;
|
|
@@ -43,16 +49,14 @@ export default class HideOtherContextPadProvider {
|
|
|
43
49
|
};
|
|
44
50
|
};
|
|
45
51
|
delete: any;
|
|
46
|
-
'set-color': any;
|
|
47
52
|
} | {
|
|
48
53
|
'append.user-task': any;
|
|
49
54
|
'append.service-task': any;
|
|
50
|
-
'append.gateway': any;
|
|
51
55
|
'append.end-event': any;
|
|
52
56
|
connect: any;
|
|
53
57
|
delete: any;
|
|
54
|
-
'set-color': any;
|
|
55
58
|
replace?: undefined;
|
|
59
|
+
'append.gateway'?: undefined;
|
|
56
60
|
};
|
|
57
61
|
private getReplaceMenuPosition;
|
|
58
62
|
private createReplaceAction;
|
|
@@ -6,6 +6,8 @@ import { PluginNotFoundComponent } from "./plugin-not-found/plugin-not-found.com
|
|
|
6
6
|
import { ConfigBlankComponent } from "./box-item/item-config/config-blank/config-blank.component";
|
|
7
7
|
import { StyleComponent } from "./box-item/item-style/style/style.component";
|
|
8
8
|
import { StyleBlankComponent } from "./box-item/item-style/style-blank/style-blank.component";
|
|
9
|
+
import { FormItemConfigBase } from "../util/form-item-config-base";
|
|
10
|
+
import { FormItemConfigErrorComponent } from "./box-item/item-config/form-item-config-error/form-item-config-error.component";
|
|
9
11
|
export class PluginManager {
|
|
10
12
|
static createComponent(boxItem, index, style, config) {
|
|
11
13
|
let plugin = PluginFactory.get(config.name);
|
|
@@ -150,6 +152,11 @@ export class PluginManager {
|
|
|
150
152
|
const instance = componentRef.instance;
|
|
151
153
|
instance.config = item.config.pluginConfig;
|
|
152
154
|
if (pluginType === 'form') {
|
|
155
|
+
if (!(instance instanceof FormItemConfigBase)) {
|
|
156
|
+
itemConfigContainerRef.clear();
|
|
157
|
+
itemConfigContainerRef.createComponent(FormItemConfigErrorComponent);
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
153
160
|
instance.fieldTree = fieldTree;
|
|
154
161
|
}
|
|
155
162
|
instance.configChange.subscribe((reload) => {
|
|
@@ -158,7 +165,9 @@ export class PluginManager {
|
|
|
158
165
|
componentRef.location.nativeElement.click();
|
|
159
166
|
}
|
|
160
167
|
else {
|
|
161
|
-
|
|
168
|
+
setTimeout(() => {
|
|
169
|
+
Object.assign(item.componentRef.instance, item.config.pluginConfig);
|
|
170
|
+
});
|
|
162
171
|
}
|
|
163
172
|
});
|
|
164
173
|
}
|
|
@@ -180,4 +189,4 @@ export class PluginManager {
|
|
|
180
189
|
PluginManager.hoverItems = [];
|
|
181
190
|
PluginManager.activeItem = new Subject();
|
|
182
191
|
PluginManager.activeItems = {};
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PluginManager.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/box-container/PluginManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef, ViewContainerRef} from '@angular/core';\r\nimport {PluginFactory} from 'coast-plugin-register';\r\nimport {PluginActiveComponent} from './plugin-active/plugin-active.component';\r\nimport {PluginHoverComponent} from './plugin-hover/plugin-hover.component';\r\nimport {Subject} from 'rxjs';\r\nimport {BoxItemComponent} from './box-item/box-item.component';\r\nimport {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\nimport {ConfigBlankComponent} from \"./box-item/item-config/config-blank/config-blank.component\";\r\nimport {StyleComponent} from \"./box-item/item-style/style/style.component\";\r\nimport {StyleBlankComponent} from \"./box-item/item-style/style-blank/style-blank.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<{ id: string, item: any }>();\r\n  static activeItems: { [id: string]: any } = {};\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\r\n    }\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    viewContainerRef.clear();\r\n    const componentRef = viewContainerRef.createComponent(plugin.component);\r\n    const instance: any = componentRef.instance;\r\n    Object.assign(instance, config.pluginConfig);\r\n    instance.editMode = boxItem.boxContainer.editMode;\r\n    if (plugin.type === 'form') {\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    if (boxItem.boxContainer.readonly) {\r\n      instance.readonly = true;\r\n    }\r\n    instance.opener = boxItem.boxContainer.opener;\r\n    instance.params = boxItem.boxContainer.params;\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.editMode) {\r\n      instance.onRemove = () => {\r\n        boxItem.config.list.splice(index, 1, {type: 'blank', style: boxItem.config.list[index].style});\r\n        boxItem.load();\r\n      };\r\n      componentRef.location.nativeElement.style.margin = '8px';\r\n      componentRef.location.nativeElement.style.pointerEvents = 'all';\r\n      for (let child of componentRef.location.nativeElement.children) {\r\n        child.style.pointerEvents = 'none';\r\n      }\r\n      this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, componentRef, style, {\r\n        caption: plugin.caption,\r\n        config\r\n      }, true);\r\n    }\r\n    return componentRef;\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(hoverElement);\r\n    this.hoverItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('mouseenter', ($event: any) => {\r\n      for (let hoverItem of this.hoverItems) {\r\n        hoverItem.classList.remove('plugin-hover');\r\n      }\r\n      $event.target.classList.add('plugin-hover');\r\n    });\r\n    componentRef.location.nativeElement.addEventListener('mouseleave', ($event: any) => {\r\n      $event.target.classList.remove('plugin-hover');\r\n      $event.target.parentElement.parentElement.classList.add('plugin-hover');\r\n    });\r\n    return hoverComponentRef;\r\n  }\r\n\r\n  static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>,\r\n                               style: any, config: any, showClose: boolean): any {\r\n    const id = boxItem.boxContainer.id;\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);\r\n    activeComponentRef.instance.name = config.caption;\r\n    activeComponentRef.instance.showClose = showClose;\r\n    activeComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(activeElement);\r\n    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(componentRef.location.nativeElement);\r\n    } else {\r\n      this.activeItems[id] = [componentRef.location.nativeElement];\r\n    }\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems[id]) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems[id].indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({\r\n        id,\r\n        item: {boxItem, index, style, config: config.config, componentRef}\r\n      });\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\r\n      if (boxItem.config.direction === direction) {\r\n        boxItem.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\r\n        boxItem.load();\r\n      } else {\r\n        if (boxItem.config.list.length === 1) {\r\n          boxItem.config.direction = direction;\r\n          boxItem.config.list.push({type: 'blank', style: {}});\r\n        } else {\r\n          if (boxItem.config.list[index].type === 'item' && boxItem.config.list[index].config.direction === direction) {\r\n            boxItem.config.list[index].config.list.push({type: 'blank', style: {}});\r\n          } else {\r\n            boxItem.config.list.splice(index, 1, {\r\n              type: 'item',\r\n              style: boxItem.config.list[index].style,\r\n              config: {\r\n                direction,\r\n                list: [boxItem.config.list[index], {type: 'blank', style: {}}]\r\n              }\r\n            });\r\n          }\r\n        }\r\n        boxItem.load();\r\n      }\r\n    };\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next({\r\n        id,\r\n        item: ''\r\n      });\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n\r\n  static resetItemConfig(itemConfigContainerRef: ViewContainerRef, item: any, fieldTree?: any) {\r\n    itemConfigContainerRef.clear();\r\n    if (!item) {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n      return;\r\n    }\r\n    const plugin = PluginFactory.get(item.config?.name);\r\n    const pluginType = plugin?.type;\r\n    const pluginConfig = PluginFactory.getConfig(item.config?.name);\r\n    if (pluginConfig) {\r\n      const componentRef = itemConfigContainerRef.createComponent(pluginConfig.component);\r\n      const instance: any = componentRef.instance;\r\n      instance.config = item.config.pluginConfig;\r\n      if (pluginType === 'form') {\r\n        instance.fieldTree = fieldTree;\r\n      }\r\n      instance.configChange.subscribe((reload?: boolean) => {\r\n        if (reload) {\r\n          const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);\r\n          componentRef.location.nativeElement.click();\r\n        } else {\r\n          Object.assign(item.componentRef.instance, item.config.pluginConfig);\r\n        }\r\n      });\r\n    } else {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n    }\r\n  }\r\n\r\n  static resetItemStyle(itemStyleContainerRef: ViewContainerRef, item: any) {\r\n    itemStyleContainerRef.clear();\r\n    if (!item) {\r\n      itemStyleContainerRef.createComponent(StyleBlankComponent);\r\n      return;\r\n    }\r\n    const componentRef = itemStyleContainerRef.createComponent(StyleComponent);\r\n    const instance: any = componentRef.instance;\r\n    instance.style = item.style;\r\n  }\r\n}\r\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PluginManager.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/box-container/PluginManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef, ViewContainerRef} from '@angular/core';\r\nimport {PluginFactory} from 'coast-plugin-register';\r\nimport {PluginActiveComponent} from './plugin-active/plugin-active.component';\r\nimport {PluginHoverComponent} from './plugin-hover/plugin-hover.component';\r\nimport {Subject} from 'rxjs';\r\nimport {BoxItemComponent} from './box-item/box-item.component';\r\nimport {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\nimport {ConfigBlankComponent} from \"./box-item/item-config/config-blank/config-blank.component\";\r\nimport {StyleComponent} from \"./box-item/item-style/style/style.component\";\r\nimport {StyleBlankComponent} from \"./box-item/item-style/style-blank/style-blank.component\";\r\nimport {FormItemConfigBase} from \"../util/form-item-config-base\";\r\nimport {\r\n  FormItemConfigErrorComponent\r\n} from \"./box-item/item-config/form-item-config-error/form-item-config-error.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<{ id: string, item: any }>();\r\n  static activeItems: { [id: string]: any } = {};\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\r\n    }\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    viewContainerRef.clear();\r\n    const componentRef = viewContainerRef.createComponent(plugin.component);\r\n    const instance: any = componentRef.instance;\r\n    Object.assign(instance, config.pluginConfig);\r\n    instance.editMode = boxItem.boxContainer.editMode;\r\n    if (plugin.type === 'form') {\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    if (boxItem.boxContainer.readonly) {\r\n      instance.readonly = true;\r\n    }\r\n    instance.opener = boxItem.boxContainer.opener;\r\n    instance.params = boxItem.boxContainer.params;\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.editMode) {\r\n      instance.onRemove = () => {\r\n        boxItem.config.list.splice(index, 1, {type: 'blank', style: boxItem.config.list[index].style});\r\n        boxItem.load();\r\n      };\r\n      componentRef.location.nativeElement.style.margin = '8px';\r\n      componentRef.location.nativeElement.style.pointerEvents = 'all';\r\n      for (let child of componentRef.location.nativeElement.children) {\r\n        child.style.pointerEvents = 'none';\r\n      }\r\n      this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, componentRef, style, {\r\n        caption: plugin.caption,\r\n        config\r\n      }, true);\r\n    }\r\n    return componentRef;\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(hoverElement);\r\n    this.hoverItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('mouseenter', ($event: any) => {\r\n      for (let hoverItem of this.hoverItems) {\r\n        hoverItem.classList.remove('plugin-hover');\r\n      }\r\n      $event.target.classList.add('plugin-hover');\r\n    });\r\n    componentRef.location.nativeElement.addEventListener('mouseleave', ($event: any) => {\r\n      $event.target.classList.remove('plugin-hover');\r\n      $event.target.parentElement.parentElement.classList.add('plugin-hover');\r\n    });\r\n    return hoverComponentRef;\r\n  }\r\n\r\n  static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>,\r\n                               style: any, config: any, showClose: boolean): any {\r\n    const id = boxItem.boxContainer.id;\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);\r\n    activeComponentRef.instance.name = config.caption;\r\n    activeComponentRef.instance.showClose = showClose;\r\n    activeComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(activeElement);\r\n    if (this.activeItems[id]) {\r\n      this.activeItems[id].push(componentRef.location.nativeElement);\r\n    } else {\r\n      this.activeItems[id] = [componentRef.location.nativeElement];\r\n    }\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems[id]) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems[id].indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({\r\n        id,\r\n        item: {boxItem, index, style, config: config.config, componentRef}\r\n      });\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.splitItem = (direction: 'row' | 'column') => {\r\n      if (boxItem.config.direction === direction) {\r\n        boxItem.config.list.splice(index + 1, 0, {type: 'blank', style: {}});\r\n        boxItem.load();\r\n      } else {\r\n        if (boxItem.config.list.length === 1) {\r\n          boxItem.config.direction = direction;\r\n          boxItem.config.list.push({type: 'blank', style: {}});\r\n        } else {\r\n          if (boxItem.config.list[index].type === 'item' && boxItem.config.list[index].config.direction === direction) {\r\n            boxItem.config.list[index].config.list.push({type: 'blank', style: {}});\r\n          } else {\r\n            boxItem.config.list.splice(index, 1, {\r\n              type: 'item',\r\n              style: boxItem.config.list[index].style,\r\n              config: {\r\n                direction,\r\n                list: [boxItem.config.list[index], {type: 'blank', style: {}}]\r\n              }\r\n            });\r\n          }\r\n        }\r\n        boxItem.load();\r\n      }\r\n    };\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next({\r\n        id,\r\n        item: ''\r\n      });\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n\r\n  static resetItemConfig(itemConfigContainerRef: ViewContainerRef, item: any, fieldTree?: any) {\r\n    itemConfigContainerRef.clear();\r\n    if (!item) {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n      return;\r\n    }\r\n    const plugin = PluginFactory.get(item.config?.name);\r\n    const pluginType = plugin?.type;\r\n    const pluginConfig = PluginFactory.getConfig(item.config?.name);\r\n    if (pluginConfig) {\r\n      const componentRef = itemConfigContainerRef.createComponent(pluginConfig.component);\r\n      const instance: any = componentRef.instance;\r\n      instance.config = item.config.pluginConfig;\r\n      if (pluginType === 'form') {\r\n        if (!(instance instanceof FormItemConfigBase)) {\r\n          itemConfigContainerRef.clear();\r\n          itemConfigContainerRef.createComponent(FormItemConfigErrorComponent);\r\n          return;\r\n        }\r\n        instance.fieldTree = fieldTree;\r\n      }\r\n      instance.configChange.subscribe((reload?: boolean) => {\r\n        if (reload) {\r\n          const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);\r\n          componentRef.location.nativeElement.click();\r\n        } else {\r\n          setTimeout(() => {\r\n            Object.assign(item.componentRef.instance, item.config.pluginConfig);\r\n          });\r\n        }\r\n      });\r\n    } else {\r\n      itemConfigContainerRef.createComponent(ConfigBlankComponent);\r\n    }\r\n  }\r\n\r\n  static resetItemStyle(itemStyleContainerRef: ViewContainerRef, item: any) {\r\n    itemStyleContainerRef.clear();\r\n    if (!item) {\r\n      itemStyleContainerRef.createComponent(StyleBlankComponent);\r\n      return;\r\n    }\r\n    const componentRef = itemStyleContainerRef.createComponent(StyleComponent);\r\n    const instance: any = componentRef.instance;\r\n    instance.style = item.style;\r\n  }\r\n}\r\n"]}
|
|
@@ -15,6 +15,7 @@ import { StyleComponent } from './box-item/item-style/style/style.component';
|
|
|
15
15
|
import { PluginNotFoundComponent } from './plugin-not-found/plugin-not-found.component';
|
|
16
16
|
import { DevExtremeModule } from "devextreme-angular";
|
|
17
17
|
import { ConfigBlankComponent } from './box-item/item-config/config-blank/config-blank.component';
|
|
18
|
+
import { FormItemConfigErrorComponent } from './box-item/item-config/form-item-config-error/form-item-config-error.component';
|
|
18
19
|
import * as i0 from "@angular/core";
|
|
19
20
|
export class BoxContainerModule {
|
|
20
21
|
}
|
|
@@ -30,6 +31,7 @@ BoxContainerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", vers
|
|
|
30
31
|
ItemStyleComponent,
|
|
31
32
|
StyleBlankComponent,
|
|
32
33
|
ItemBlankComponent,
|
|
34
|
+
FormItemConfigErrorComponent,
|
|
33
35
|
StyleComponent,
|
|
34
36
|
PluginNotFoundComponent,
|
|
35
37
|
ConfigBlankComponent], imports: [CommonModule,
|
|
@@ -53,6 +55,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
53
55
|
ItemStyleComponent,
|
|
54
56
|
StyleBlankComponent,
|
|
55
57
|
ItemBlankComponent,
|
|
58
|
+
FormItemConfigErrorComponent,
|
|
56
59
|
StyleComponent,
|
|
57
60
|
PluginNotFoundComponent,
|
|
58
61
|
ConfigBlankComponent
|
|
@@ -68,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
68
71
|
]
|
|
69
72
|
}]
|
|
70
73
|
}] });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWNvbnRhaW5lci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1jb250YWluZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ2hFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLHlDQUF5QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLDZEQUE2RCxDQUFDO0FBQ2pHLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHlEQUF5RCxDQUFDO0FBQzVGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSw2Q0FBNkMsQ0FBQztBQUMzRSxPQUFPLEVBQUMsdUJBQXVCLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUN0RixPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0REFBNEQsQ0FBQztBQUNoRyxPQUFPLEVBQ0wsNEJBQTRCLEVBQzdCLE1BQU0sZ0ZBQWdGLENBQUM7O0FBOEJ4RixNQUFNLE9BQU8sa0JBQWtCOzsrR0FBbEIsa0JBQWtCO2dIQUFsQixrQkFBa0IsaUJBMUIzQixxQkFBcUI7UUFDckIsb0JBQW9CO1FBQ3BCLGdCQUFnQjtRQUNoQixxQkFBcUI7UUFDckIsZ0JBQWdCO1FBQ2hCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsbUJBQW1CO1FBQ25CLGtCQUFrQjtRQUNsQixtQkFBbUI7UUFDbkIsa0JBQWtCO1FBQ2xCLDRCQUE0QjtRQUM1QixjQUFjO1FBQ2QsdUJBQXVCO1FBQ3ZCLG9CQUFvQixhQUdwQixZQUFZO1FBQ1osZ0JBQWdCLGFBR2hCLHFCQUFxQjtRQUNyQixtQkFBbUI7UUFDbkIsa0JBQWtCO2dIQUdULGtCQUFrQixZQVQzQixZQUFZO1FBQ1osZ0JBQWdCOzJGQVFQLGtCQUFrQjtrQkE1QjlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHFCQUFxQjt3QkFDckIsb0JBQW9CO3dCQUNwQixnQkFBZ0I7d0JBQ2hCLHFCQUFxQjt3QkFDckIsZ0JBQWdCO3dCQUNoQixvQkFBb0I7d0JBQ3BCLG9CQUFvQjt3QkFDcEIsbUJBQW1CO3dCQUNuQixrQkFBa0I7d0JBQ2xCLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3dCQUNsQiw0QkFBNEI7d0JBQzVCLGNBQWM7d0JBQ2QsdUJBQXVCO3dCQUN2QixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixrQkFBa0I7cUJBQ25CO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge0JveENvbnRhaW5lckNvbXBvbmVudH0gZnJvbSAnLi9ib3gtY29udGFpbmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7Qm94SXRlbUhvc3REaXJlY3RpdmV9IGZyb20gJy4vYm94LWl0ZW0vYm94LWl0ZW0taG9zdC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQge0JveEl0ZW1Db21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vYm94LWl0ZW0uY29tcG9uZW50JztcclxuaW1wb3J0IHtQbHVnaW5BY3RpdmVDb21wb25lbnR9IGZyb20gXCIuL3BsdWdpbi1hY3RpdmUvcGx1Z2luLWFjdGl2ZS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtQbHVnaW5Ib3ZlckNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWhvdmVyL3BsdWdpbi1ob3Zlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyQ29tcG9uZW50fSBmcm9tIFwiLi9wbHVnaW4tYWN0aXZlL2RpdmlkZXIvZGl2aWRlci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEaXZpZGVyTGluZUNvbXBvbmVudH0gZnJvbSBcIi4vcGx1Z2luLWFjdGl2ZS9kaXZpZGVyL2RpdmlkZXItbGluZS9kaXZpZGVyLWxpbmUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SXRlbUNvbmZpZ0NvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQnO1xyXG5pbXBvcnQge0l0ZW1TdHlsZUNvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLXN0eWxlL2l0ZW0tc3R5bGUuY29tcG9uZW50JztcclxuaW1wb3J0IHtTdHlsZUJsYW5rQ29tcG9uZW50fSBmcm9tICcuL2JveC1pdGVtL2l0ZW0tc3R5bGUvc3R5bGUtYmxhbmsvc3R5bGUtYmxhbmsuY29tcG9uZW50JztcclxuaW1wb3J0IHtJdGVtQmxhbmtDb21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1ibGFuay9pdGVtLWJsYW5rLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7U3R5bGVDb21wb25lbnR9IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1zdHlsZS9zdHlsZS9zdHlsZS5jb21wb25lbnQnO1xyXG5pbXBvcnQge1BsdWdpbk5vdEZvdW5kQ29tcG9uZW50fSBmcm9tICcuL3BsdWdpbi1ub3QtZm91bmQvcGx1Z2luLW5vdC1mb3VuZC5jb21wb25lbnQnO1xyXG5pbXBvcnQge0RldkV4dHJlbWVNb2R1bGV9IGZyb20gXCJkZXZleHRyZW1lLWFuZ3VsYXJcIjtcclxuaW1wb3J0IHtDb25maWdCbGFua0NvbXBvbmVudH0gZnJvbSAnLi9ib3gtaXRlbS9pdGVtLWNvbmZpZy9jb25maWctYmxhbmsvY29uZmlnLWJsYW5rLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7XHJcbiAgRm9ybUl0ZW1Db25maWdFcnJvckNvbXBvbmVudFxyXG59IGZyb20gJy4vYm94LWl0ZW0vaXRlbS1jb25maWcvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci9mb3JtLWl0ZW0tY29uZmlnLWVycm9yLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgQm94Q29udGFpbmVyQ29tcG9uZW50LFxyXG4gICAgQm94SXRlbUhvc3REaXJlY3RpdmUsXHJcbiAgICBCb3hJdGVtQ29tcG9uZW50LFxyXG4gICAgUGx1Z2luQWN0aXZlQ29tcG9uZW50LFxyXG4gICAgRGl2aWRlckNvbXBvbmVudCxcclxuICAgIERpdmlkZXJMaW5lQ29tcG9uZW50LFxyXG4gICAgUGx1Z2luSG92ZXJDb21wb25lbnQsXHJcbiAgICBJdGVtQ29uZmlnQ29tcG9uZW50LFxyXG4gICAgSXRlbVN0eWxlQ29tcG9uZW50LFxyXG4gICAgU3R5bGVCbGFua0NvbXBvbmVudCxcclxuICAgIEl0ZW1CbGFua0NvbXBvbmVudCxcclxuICAgIEZvcm1JdGVtQ29uZmlnRXJyb3JDb21wb25lbnQsXHJcbiAgICBTdHlsZUNvbXBvbmVudCxcclxuICAgIFBsdWdpbk5vdEZvdW5kQ29tcG9uZW50LFxyXG4gICAgQ29uZmlnQmxhbmtDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIERldkV4dHJlbWVNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEJveENvbnRhaW5lckNvbXBvbmVudCxcclxuICAgIEl0ZW1Db25maWdDb21wb25lbnQsXHJcbiAgICBJdGVtU3R5bGVDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCb3hDb250YWluZXJNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class FormItemConfigErrorComponent {
|
|
4
|
+
}
|
|
5
|
+
FormItemConfigErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormItemConfigErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
FormItemConfigErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: FormItemConfigErrorComponent, selector: "rs-form-item-config-error", ngImport: i0, template: "<div>\n <span>\u8868\u5355\u7EC4\u4EF6\u914D\u7F6E\u5FC5\u9700\u7EE7\u627F\u81EAFormItemConfigBase</span>\n</div>\n", styles: [":host{height:80px;margin:8px;display:flex;flex-flow:row nowrap;justify-content:center}:host div{flex:1;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}:host div span{text-align:center;-webkit-user-select:none;user-select:none}\n"] });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: FormItemConfigErrorComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'rs-form-item-config-error', template: "<div>\n <span>\u8868\u5355\u7EC4\u4EF6\u914D\u7F6E\u5FC5\u9700\u7EE7\u627F\u81EAFormItemConfigBase</span>\n</div>\n", styles: [":host{height:80px;margin:8px;display:flex;flex-flow:row nowrap;justify-content:center}:host div{flex:1;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}:host div span{text-align:center;-webkit-user-select:none;user-select:none}\n"] }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tY29uZmlnL2Zvcm0taXRlbS1jb25maWctZXJyb3IvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tY29uZmlnL2Zvcm0taXRlbS1jb25maWctZXJyb3IvZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQU94QyxNQUFNLE9BQU8sNEJBQTRCOzt5SEFBNUIsNEJBQTRCOzZHQUE1Qiw0QkFBNEIsaUVDUHpDLHNIQUdBOzJGRElhLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDRSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3JzLWZvcm0taXRlbS1jb25maWctZXJyb3InLFxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybS1pdGVtLWNvbmZpZy1lcnJvci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Zvcm0taXRlbS1jb25maWctZXJyb3IuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBGb3JtSXRlbUNvbmZpZ0Vycm9yQ29tcG9uZW50IHtcblxufVxuIiwiPGRpdj5cbiAgPHNwYW4+6KGo5Y2V57uE5Lu26YWN572u5b+F6ZyA57un5om/6IeqRm9ybUl0ZW1Db25maWdCYXNlPC9zcGFuPlxuPC9kaXY+XG4iXX0=
|
|
@@ -42,12 +42,12 @@ export class PluginActiveComponent {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
PluginActiveComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: PluginActiveComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
45
|
-
PluginActiveComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: PluginActiveComponent, selector: "rs-plugin-active", host: { properties: { "style": "this._style" } }, ngImport: i0, template: "<div class=\"active-item\">\r\n <div class=\"active-bar\">\r\n <i *ngIf=\"showClose && !showDivider\" class=\"icon-drag\"></i>\r\n <span>{{name}}</span>\r\n <i class=\"coast-icon-add-row\" title=\"\u6DFB\u52A0\u884C\" (click)=\"splitItem('column')\"></i>\r\n <i class=\"coast-icon-add-column\" title=\"\u6DFB\u52A0\u5217\" (click)=\"splitItem('row')\"></i>\r\n <i *ngIf=\"showClose\" class=\"icon-close\" (click)=\"onItemCloseIconClick($event)\"></i>\r\n </div>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"row\"\r\n (dividerClick)=\"splitItem('column')\"></rs-divider>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"column\"\r\n (dividerClick)=\"splitItem('row')\"></rs-divider>\r\n</div>\r\n", styles: [":host{display:none;position:absolute;border:1px solid var(--coast-default-color, #337ab7);pointer-events:none}:host .active-item{width:100%;height:100%}:host .active-item .active-bar{padding:2px 4px;color:#fff;background-color:var(--coast-default-color, #337ab7);position:absolute;top:-23px;right:-1px;display:flex;flex-flow:row nowrap;align-items:center;pointer-events:all;white-space:nowrap}:host .active-item .active-bar i{flex:none;cursor:pointer}:host .active-item .active-bar i:not(:last-child){margin-right:8px}:host .active-item .active-bar i.icon-drag{cursor:move}:host .active-item .active-bar i.icon-close:hover{color:var(--coast-danger-color, #d9534f)}:host .active-item .active-bar span{flex:1;margin-right:8px}.plugin-active>:host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DividerComponent, selector: "rs-divider", inputs: ["direction", "targetElement"], outputs: ["dividerClick"] }] });
|
|
45
|
+
PluginActiveComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: PluginActiveComponent, selector: "rs-plugin-active", host: { properties: { "style": "this._style" } }, ngImport: i0, template: "<div class=\"active-item\">\r\n <div class=\"active-bar\">\r\n <i *ngIf=\"showClose && !showDivider\" class=\"icon-drag\"></i>\r\n <span>{{ name }}</span>\r\n <i class=\"coast-icon-add-row\" title=\"\u6DFB\u52A0\u884C\" (click)=\"splitItem('column')\"></i>\r\n <i class=\"coast-icon-add-column\" title=\"\u6DFB\u52A0\u5217\" (click)=\"splitItem('row')\"></i>\r\n <i *ngIf=\"showClose\" class=\"icon-close\" (click)=\"onItemCloseIconClick($event)\"></i>\r\n </div>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"row\"\r\n (dividerClick)=\"splitItem('column')\"></rs-divider>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"column\"\r\n (dividerClick)=\"splitItem('row')\"></rs-divider>\r\n</div>\r\n", styles: [":host{display:none;position:absolute;border:1px solid var(--coast-default-color, #337ab7);pointer-events:none}:host .active-item{width:100%;height:100%}:host .active-item .active-bar{padding:2px 4px;color:#fff;background-color:var(--coast-default-color, #337ab7);position:absolute;top:-23px;right:-1px;display:flex;flex-flow:row nowrap;align-items:center;pointer-events:all;white-space:nowrap}:host .active-item .active-bar i{flex:none;cursor:pointer}:host .active-item .active-bar i:not(:last-child){margin-right:8px}:host .active-item .active-bar i.icon-drag{cursor:move}:host .active-item .active-bar i.icon-close:hover{color:var(--coast-danger-color, #d9534f)}:host .active-item .active-bar span{flex:1;margin-right:8px}.plugin-active>:host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DividerComponent, selector: "rs-divider", inputs: ["direction", "targetElement"], outputs: ["dividerClick"] }] });
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: PluginActiveComponent, decorators: [{
|
|
47
47
|
type: Component,
|
|
48
|
-
args: [{ selector: 'rs-plugin-active', template: "<div class=\"active-item\">\r\n <div class=\"active-bar\">\r\n <i *ngIf=\"showClose && !showDivider\" class=\"icon-drag\"></i>\r\n <span>{{name}}</span>\r\n <i class=\"coast-icon-add-row\" title=\"\u6DFB\u52A0\u884C\" (click)=\"splitItem('column')\"></i>\r\n <i class=\"coast-icon-add-column\" title=\"\u6DFB\u52A0\u5217\" (click)=\"splitItem('row')\"></i>\r\n <i *ngIf=\"showClose\" class=\"icon-close\" (click)=\"onItemCloseIconClick($event)\"></i>\r\n </div>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"row\"\r\n (dividerClick)=\"splitItem('column')\"></rs-divider>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"column\"\r\n (dividerClick)=\"splitItem('row')\"></rs-divider>\r\n</div>\r\n", styles: [":host{display:none;position:absolute;border:1px solid var(--coast-default-color, #337ab7);pointer-events:none}:host .active-item{width:100%;height:100%}:host .active-item .active-bar{padding:2px 4px;color:#fff;background-color:var(--coast-default-color, #337ab7);position:absolute;top:-23px;right:-1px;display:flex;flex-flow:row nowrap;align-items:center;pointer-events:all;white-space:nowrap}:host .active-item .active-bar i{flex:none;cursor:pointer}:host .active-item .active-bar i:not(:last-child){margin-right:8px}:host .active-item .active-bar i.icon-drag{cursor:move}:host .active-item .active-bar i.icon-close:hover{color:var(--coast-danger-color, #d9534f)}:host .active-item .active-bar span{flex:1;margin-right:8px}.plugin-active>:host{display:block}\n"] }]
|
|
48
|
+
args: [{ selector: 'rs-plugin-active', template: "<div class=\"active-item\">\r\n <div class=\"active-bar\">\r\n <i *ngIf=\"showClose && !showDivider\" class=\"icon-drag\"></i>\r\n <span>{{ name }}</span>\r\n <i class=\"coast-icon-add-row\" title=\"\u6DFB\u52A0\u884C\" (click)=\"splitItem('column')\"></i>\r\n <i class=\"coast-icon-add-column\" title=\"\u6DFB\u52A0\u5217\" (click)=\"splitItem('row')\"></i>\r\n <i *ngIf=\"showClose\" class=\"icon-close\" (click)=\"onItemCloseIconClick($event)\"></i>\r\n </div>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"row\"\r\n (dividerClick)=\"splitItem('column')\"></rs-divider>\r\n <rs-divider *ngIf=\"showDivider\" [targetElement]=\"targetElement\" direction=\"column\"\r\n (dividerClick)=\"splitItem('row')\"></rs-divider>\r\n</div>\r\n", styles: [":host{display:none;position:absolute;border:1px solid var(--coast-default-color, #337ab7);pointer-events:none}:host .active-item{width:100%;height:100%}:host .active-item .active-bar{padding:2px 4px;color:#fff;background-color:var(--coast-default-color, #337ab7);position:absolute;top:-23px;right:-1px;display:flex;flex-flow:row nowrap;align-items:center;pointer-events:all;white-space:nowrap}:host .active-item .active-bar i{flex:none;cursor:pointer}:host .active-item .active-bar i:not(:last-child){margin-right:8px}:host .active-item .active-bar i.icon-drag{cursor:move}:host .active-item .active-bar i.icon-close:hover{color:var(--coast-danger-color, #d9534f)}:host .active-item .active-bar span{flex:1;margin-right:8px}.plugin-active>:host{display:block}\n"] }]
|
|
49
49
|
}], propDecorators: { _style: [{
|
|
50
50
|
type: HostBinding,
|
|
51
51
|
args: ['style']
|
|
52
52
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLWFjdGl2ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL3BsdWdpbi1hY3RpdmUvcGx1Z2luLWFjdGl2ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL3BsdWdpbi1hY3RpdmUvcGx1Z2luLWFjdGl2ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7QUFPM0UsTUFBTSxPQUFPLHFCQUFxQjtJQUxsQztRQU9FLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFDMUIsZ0JBQVcsR0FBWSxLQUFLLENBQUM7UUFDN0IsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFaEMsZUFBVSxHQUFRO1lBQ2hCLEtBQUssRUFBRSxDQUFDO1lBQ1IsTUFBTSxFQUFFLENBQUM7U0FDVixDQUFDO1FBQ0YsZ0JBQVcsR0FBUSxFQUFFLENBQUM7UUFDdEIsVUFBSyxHQUFXLENBQUMsQ0FBQztRQUNsQixXQUFNLEdBQVcsQ0FBQyxDQUFDO0tBOEJwQjtJQTVCQyxJQUEwQixNQUFNO1FBQzlCLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3ZCLE9BQU8sRUFBRSxDQUFDO1NBQ1g7UUFDRCxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLHFCQUFxQixFQUFFLENBQUM7UUFDL0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQztRQUMzQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsTUFBTSxDQUFDO1FBQzdDLE9BQU87WUFDTCxLQUFLLEVBQUUsV0FBVyxDQUFDLEtBQUssR0FBRyxJQUFJO1lBQy9CLE1BQU0sRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLElBQUk7WUFDakMsR0FBRyxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFHLElBQUk7WUFDeEMsSUFBSSxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxHQUFHLElBQUk7U0FDM0MsQ0FBQztJQUNKLENBQUM7SUFFRCxRQUFRO1FBQ04sVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUNyQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxNQUFXO1FBQzlCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELFNBQVMsQ0FBQyxTQUEyQjtRQUNuQyxXQUFXO0lBQ2IsQ0FBQzs7a0hBekNVLHFCQUFxQjtzR0FBckIscUJBQXFCLDBHQ1BsQyxrekJBYUE7MkZETmEscUJBQXFCO2tCQUxqQyxTQUFTOytCQUNFLGtCQUFrQjs4QkFrQkYsTUFBTTtzQkFBL0IsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3JzLXBsdWdpbi1hY3RpdmUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9wbHVnaW4tYWN0aXZlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9wbHVnaW4tYWN0aXZlLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFBsdWdpbkFjdGl2ZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgbmFtZSE6IHN0cmluZztcclxuICBzaG93Q2xvc2U6IGJvb2xlYW4gPSB0cnVlO1xyXG4gIHNob3dEaXZpZGVyOiBib29sZWFuID0gZmFsc2U7XHJcbiAgaXRlbVJlbW92ZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICB0YXJnZXRFbGVtZW50OiBhbnk7XHJcbiAgdGFyZ2V0UmVjdDogYW55ID0ge1xyXG4gICAgd2lkdGg6IDAsXHJcbiAgICBoZWlnaHQ6IDBcclxuICB9O1xyXG4gIF90YXJnZXRSZWN0OiBhbnkgPSB7fTtcclxuICB3aWR0aDogbnVtYmVyID0gMDtcclxuICBoZWlnaHQ6IG51bWJlciA9IDA7XHJcblxyXG4gIEBIb3N0QmluZGluZygnc3R5bGUnKSBnZXQgX3N0eWxlKCkge1xyXG4gICAgaWYgKCF0aGlzLnRhcmdldEVsZW1lbnQpIHtcclxuICAgICAgcmV0dXJuIHt9O1xyXG4gICAgfVxyXG4gICAgY29uc3QgZWxlbWVudFJlY3QgPSB0aGlzLnRhcmdldEVsZW1lbnQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XHJcbiAgICB0aGlzLl90YXJnZXRSZWN0LndpZHRoID0gZWxlbWVudFJlY3Qud2lkdGg7XHJcbiAgICB0aGlzLl90YXJnZXRSZWN0LmhlaWdodCA9IGVsZW1lbnRSZWN0LmhlaWdodDtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHdpZHRoOiBlbGVtZW50UmVjdC53aWR0aCArICdweCcsXHJcbiAgICAgIGhlaWdodDogZWxlbWVudFJlY3QuaGVpZ2h0ICsgJ3B4JyxcclxuICAgICAgdG9wOiB0aGlzLnRhcmdldEVsZW1lbnQub2Zmc2V0VG9wICsgJ3B4JyxcclxuICAgICAgbGVmdDogdGhpcy50YXJnZXRFbGVtZW50Lm9mZnNldExlZnQgKyAncHgnXHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy50YXJnZXRSZWN0ID0gdGhpcy5fdGFyZ2V0UmVjdDtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgb25JdGVtQ2xvc2VJY29uQ2xpY2soJGV2ZW50OiBhbnkpIHtcclxuICAgIHRoaXMuaXRlbVJlbW92ZS5lbWl0KCk7XHJcbiAgfVxyXG5cclxuICBzcGxpdEl0ZW0oZGlyZWN0aW9uOiAncm93JyB8ICdjb2x1bW4nKSB7XHJcbiAgICAvLyDkuIrlsYLlrp7kvovljJbml7bph43lhplcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFjdGl2ZS1pdGVtXCI+XHJcbiAgPGRpdiBjbGFzcz1cImFjdGl2ZS1iYXJcIj5cclxuICAgIDxpICpuZ0lmPVwic2hvd0Nsb3NlICYmICFzaG93RGl2aWRlclwiIGNsYXNzPVwiaWNvbi1kcmFnXCI+PC9pPlxyXG4gICAgPHNwYW4+e3sgbmFtZSB9fTwvc3Bhbj5cclxuICAgIDxpIGNsYXNzPVwiY29hc3QtaWNvbi1hZGQtcm93XCIgdGl0bGU9XCLmt7vliqDooYxcIiAoY2xpY2spPVwic3BsaXRJdGVtKCdjb2x1bW4nKVwiPjwvaT5cclxuICAgIDxpIGNsYXNzPVwiY29hc3QtaWNvbi1hZGQtY29sdW1uXCIgdGl0bGU9XCLmt7vliqDliJdcIiAoY2xpY2spPVwic3BsaXRJdGVtKCdyb3cnKVwiPjwvaT5cclxuICAgIDxpICpuZ0lmPVwic2hvd0Nsb3NlXCIgY2xhc3M9XCJpY29uLWNsb3NlXCIgKGNsaWNrKT1cIm9uSXRlbUNsb3NlSWNvbkNsaWNrKCRldmVudClcIj48L2k+XHJcbiAgPC9kaXY+XHJcbiAgPHJzLWRpdmlkZXIgKm5nSWY9XCJzaG93RGl2aWRlclwiIFt0YXJnZXRFbGVtZW50XT1cInRhcmdldEVsZW1lbnRcIiBkaXJlY3Rpb249XCJyb3dcIlxyXG4gICAgICAgICAgICAgIChkaXZpZGVyQ2xpY2spPVwic3BsaXRJdGVtKCdjb2x1bW4nKVwiPjwvcnMtZGl2aWRlcj5cclxuICA8cnMtZGl2aWRlciAqbmdJZj1cInNob3dEaXZpZGVyXCIgW3RhcmdldEVsZW1lbnRdPVwidGFyZ2V0RWxlbWVudFwiIGRpcmVjdGlvbj1cImNvbHVtblwiXHJcbiAgICAgICAgICAgICAgKGRpdmlkZXJDbGljayk9XCJzcGxpdEl0ZW0oJ3JvdycpXCI+PC9ycy1kaXZpZGVyPlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -15,12 +15,12 @@ export class PluginHoverComponent {
|
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
17
|
PluginHoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: PluginHoverComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
-
PluginHoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: PluginHoverComponent, selector: "rs-plugin-hover", host: { properties: { "style": "this._style" } }, ngImport: i0, template: "<div class=\"hover-title\">{{name}}</div>\n", styles: [":host{display:none;position:absolute;border:1px dashed var(--coast-default-color, #337ab7);pointer-events:none}:host .hover-title{color:var(--coast-default-color, #337ab7);position:absolute;top:-18px;left:0}.plugin-active>:host{display:none!important}.plugin-hover>:host{display:block}\n"] });
|
|
18
|
+
PluginHoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: PluginHoverComponent, selector: "rs-plugin-hover", host: { properties: { "style": "this._style" } }, ngImport: i0, template: "<div class=\"hover-title\">{{ name }}</div>\n", styles: [":host{display:none;position:absolute;border:1px dashed var(--coast-default-color, #337ab7);pointer-events:none}:host .hover-title{color:var(--coast-default-color, #337ab7);position:absolute;top:-18px;left:0}.plugin-active>:host{display:none!important}.plugin-hover>:host{display:block}\n"] });
|
|
19
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: PluginHoverComponent, decorators: [{
|
|
20
20
|
type: Component,
|
|
21
|
-
args: [{ selector: 'rs-plugin-hover', template: "<div class=\"hover-title\">{{name}}</div>\n", styles: [":host{display:none;position:absolute;border:1px dashed var(--coast-default-color, #337ab7);pointer-events:none}:host .hover-title{color:var(--coast-default-color, #337ab7);position:absolute;top:-18px;left:0}.plugin-active>:host{display:none!important}.plugin-hover>:host{display:block}\n"] }]
|
|
21
|
+
args: [{ selector: 'rs-plugin-hover', template: "<div class=\"hover-title\">{{ name }}</div>\n", styles: [":host{display:none;position:absolute;border:1px dashed var(--coast-default-color, #337ab7);pointer-events:none}:host .hover-title{color:var(--coast-default-color, #337ab7);position:absolute;top:-18px;left:0}.plugin-active>:host{display:none!important}.plugin-hover>:host{display:block}\n"] }]
|
|
22
22
|
}], propDecorators: { _style: [{
|
|
23
23
|
type: HostBinding,
|
|
24
24
|
args: ['style']
|
|
25
25
|
}] } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLWhvdmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL2JveC1jb250YWluZXIvcGx1Z2luLWhvdmVyL3BsdWdpbi1ob3Zlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL3BsdWdpbi1ob3Zlci9wbHVnaW4taG92ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBT3JELE1BQU0sT0FBTyxvQkFBb0I7SUFJL0IsSUFBMEIsTUFBTTtRQUM5QixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN2QixPQUFPLEVBQUUsQ0FBQztTQUNYO1FBQ0QsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1FBQy9ELE9BQU87WUFDTCxLQUFLLEVBQUUsV0FBVyxDQUFDLEtBQUssR0FBRyxJQUFJO1lBQy9CLE1BQU0sRUFBRSxXQUFXLENBQUMsTUFBTSxHQUFHLElBQUk7WUFDakMsR0FBRyxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxHQUFHLElBQUk7WUFDeEMsSUFBSSxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxHQUFHLElBQUk7U0FDM0MsQ0FBQztJQUNKLENBQUM7O2lIQWZVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHlHQ1BqQywrQ0FDQTsyRkRNYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0UsaUJBQWlCOzhCQVFELE1BQU07c0JBQS9CLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBIb3N0QmluZGluZ30gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3JzLXBsdWdpbi1ob3ZlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3BsdWdpbi1ob3Zlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcGx1Z2luLWhvdmVyLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFBsdWdpbkhvdmVyQ29tcG9uZW50IHtcclxuICBuYW1lITogc3RyaW5nO1xyXG4gIHRhcmdldEVsZW1lbnQ6IGFueTtcclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZScpIGdldCBfc3R5bGUoKSB7XHJcbiAgICBpZiAoIXRoaXMudGFyZ2V0RWxlbWVudCkge1xyXG4gICAgICByZXR1cm4ge307XHJcbiAgICB9XHJcbiAgICBjb25zdCBlbGVtZW50UmVjdCA9IHRoaXMudGFyZ2V0RWxlbWVudC5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIHdpZHRoOiBlbGVtZW50UmVjdC53aWR0aCArICdweCcsXHJcbiAgICAgIGhlaWdodDogZWxlbWVudFJlY3QuaGVpZ2h0ICsgJ3B4JyxcclxuICAgICAgdG9wOiB0aGlzLnRhcmdldEVsZW1lbnQub2Zmc2V0VG9wICsgJ3B4JyxcclxuICAgICAgbGVmdDogdGhpcy50YXJnZXRFbGVtZW50Lm9mZnNldExlZnQgKyAncHgnXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiaG92ZXItdGl0bGVcIj57eyBuYW1lIH19PC9kaXY+XG4iXX0=
|
|
@@ -1,17 +1,18 @@
|
|
|
1
|
-
import { Component, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import BpmnModeler from 'camunda-bpmn-js/lib/camunda-platform/Modeler';
|
|
3
3
|
import customTranslateModule from './custom/translate';
|
|
4
4
|
import customUserTaskModule from './custom/user-task';
|
|
5
5
|
import customServiceTaskModule from './custom/service-task';
|
|
6
6
|
import customHideOtherModule from './custom/hide-other';
|
|
7
|
-
import customPropertiesPanelModule from './custom/config';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
9
8
|
import * as i1 from "@angular/common";
|
|
10
9
|
import * as i2 from "../code-editor/code-editor.component";
|
|
11
10
|
import * as i3 from "devextreme-angular/ui/button";
|
|
12
11
|
export class CamundaBpmnEditorComponent {
|
|
13
12
|
constructor() {
|
|
13
|
+
this.selectedNodeChanged = new EventEmitter();
|
|
14
14
|
this.isShowXml = false;
|
|
15
|
+
this.isShowConfig = false;
|
|
15
16
|
this.initialDiagram = '<?xml version="1.0" encoding="UTF-8"?>' +
|
|
16
17
|
'<bpmn:definitions xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ' +
|
|
17
18
|
'xmlns:bpmn="http://www.omg.org/spec/BPMN/20100524/MODEL" ' +
|
|
@@ -33,7 +34,9 @@ export class CamundaBpmnEditorComponent {
|
|
|
33
34
|
}
|
|
34
35
|
set xml(xml) {
|
|
35
36
|
this._xml = xml;
|
|
36
|
-
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
this.loadXml();
|
|
39
|
+
});
|
|
37
40
|
}
|
|
38
41
|
get xml() {
|
|
39
42
|
return this._xml;
|
|
@@ -57,14 +60,31 @@ export class CamundaBpmnEditorComponent {
|
|
|
57
60
|
customUserTaskModule,
|
|
58
61
|
customServiceTaskModule,
|
|
59
62
|
customHideOtherModule,
|
|
60
|
-
customPropertiesPanelModule
|
|
63
|
+
// customPropertiesPanelModule
|
|
61
64
|
]
|
|
62
65
|
});
|
|
63
66
|
const logo = this.modeler._container.querySelector('.bjs-powered-by');
|
|
64
67
|
if (logo) {
|
|
65
68
|
this.modeler._container.removeChild(logo);
|
|
66
69
|
}
|
|
70
|
+
this.modeler.get('palette')._toggleState({ twoColumn: false });
|
|
67
71
|
this.canvas = this.modeler.get('canvas');
|
|
72
|
+
const eventBus = this.modeler.get('eventBus');
|
|
73
|
+
eventBus.on(['propertiesPanel.updated'], ($event) => {
|
|
74
|
+
if (Array.isArray($event.element)) {
|
|
75
|
+
this.selectedNodeChanged.emit();
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.selectedNodeChanged.emit({
|
|
79
|
+
element: $event.element,
|
|
80
|
+
util: {
|
|
81
|
+
bpmnFactory: this.modeler.get('bpmnFactory'),
|
|
82
|
+
modeling: this.modeler.get('modeling'),
|
|
83
|
+
elementRegistry: this.modeler.get('elementRegistry')
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
});
|
|
68
88
|
this.loadXml();
|
|
69
89
|
}
|
|
70
90
|
loadXml() {
|
|
@@ -89,12 +109,14 @@ export class CamundaBpmnEditorComponent {
|
|
|
89
109
|
}
|
|
90
110
|
}
|
|
91
111
|
CamundaBpmnEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: CamundaBpmnEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
92
|
-
CamundaBpmnEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: CamundaBpmnEditorComponent, selector: "rs-camunda-bpmn-editor", inputs: { xml: "xml" }, viewQueries: [{ propertyName: "bpmnContainer", first: true, predicate: ["bpmnContainer"], descendants: true }, { propertyName: "bpmnConfig", first: true, predicate: ["bpmnConfig"], descendants: true }], ngImport: i0, template: "<div class=\"main\">\n <div class=\"container\" #bpmnContainer></div>\n <div class=\"config\" #bpmnConfig></div>\n <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n </div>\n</div>\n<div class=\"footer\">\n <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n (onClick)=\"showXml()\"></dx-button>\n</div>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .main{flex:1;display:flex;flex-flow:row nowrap;position:relative}:host .main .container{flex:1}:host .main .config{flex:0 0 360px;border:1px solid var(--coast-border-color, #dddddd)}:host .main .xml-viewer{position:absolute;width:100%;height:100%;display:flex;flex-flow:column nowrap;z-index:var(--coast-z-index-drawer, 2000)}:host .main .xml-viewer rs-code-editor{flex:1}:host .footer{flex:0 0 24px;border:1px solid var(--coast-border-color, #dddddd)}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.CodeEditorComponent, selector: "rs-code-editor", inputs: ["code", "language", "readonly", "enableMinimap", "consoleMessage"], outputs: ["codeChange", "onContentReady"] }, { kind: "component", type: i3.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }] });
|
|
112
|
+
CamundaBpmnEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: CamundaBpmnEditorComponent, selector: "rs-camunda-bpmn-editor", inputs: { xml: "xml" }, outputs: { selectedNodeChanged: "selectedNodeChanged" }, viewQueries: [{ propertyName: "bpmnContainer", first: true, predicate: ["bpmnContainer"], descendants: true }, { propertyName: "bpmnConfig", first: true, predicate: ["bpmnConfig"], descendants: true }], ngImport: i0, template: "<div class=\"main\">\n <div class=\"container\" #bpmnContainer></div>\n <div [hidden]=\"!isShowConfig\" class=\"config\" #bpmnConfig></div>\n <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n </div>\n</div>\n<div class=\"footer\">\n <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n (onClick)=\"showXml()\"></dx-button>\n <dx-button [type]=\"isShowConfig ? 'default' : 'normal'\" icon=\"coast-icon coast-icon-setting\"\n style=\"float: right;\"\n (onClick)=\"isShowConfig = !isShowConfig;\"></dx-button>\n</div>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .main{flex:1;display:flex;flex-flow:row nowrap;position:relative}:host .main .container{flex:1}:host .main .config{flex:0 0 360px;border:1px solid var(--coast-border-color, #dddddd)}:host .main .xml-viewer{position:absolute;width:100%;height:100%;display:flex;flex-flow:column nowrap;z-index:var(--coast-z-index-drawer, 2000)}:host .main .xml-viewer rs-code-editor{flex:1}:host .footer{flex:0 0 24px;border:1px solid var(--coast-border-color, #dddddd)}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.CodeEditorComponent, selector: "rs-code-editor", inputs: ["code", "language", "readonly", "enableMinimap", "consoleMessage"], outputs: ["codeChange", "onContentReady"] }, { kind: "component", type: i3.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }] });
|
|
93
113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: CamundaBpmnEditorComponent, decorators: [{
|
|
94
114
|
type: Component,
|
|
95
|
-
args: [{ selector: 'rs-camunda-bpmn-editor', template: "<div class=\"main\">\n <div class=\"container\" #bpmnContainer></div>\n <div class=\"config\" #bpmnConfig></div>\n <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n </div>\n</div>\n<div class=\"footer\">\n <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n (onClick)=\"showXml()\"></dx-button>\n</div>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .main{flex:1;display:flex;flex-flow:row nowrap;position:relative}:host .main .container{flex:1}:host .main .config{flex:0 0 360px;border:1px solid var(--coast-border-color, #dddddd)}:host .main .xml-viewer{position:absolute;width:100%;height:100%;display:flex;flex-flow:column nowrap;z-index:var(--coast-z-index-drawer, 2000)}:host .main .xml-viewer rs-code-editor{flex:1}:host .footer{flex:0 0 24px;border:1px solid var(--coast-border-color, #dddddd)}\n"] }]
|
|
115
|
+
args: [{ selector: 'rs-camunda-bpmn-editor', template: "<div class=\"main\">\n <div class=\"container\" #bpmnContainer></div>\n <div [hidden]=\"!isShowConfig\" class=\"config\" #bpmnConfig></div>\n <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n </div>\n</div>\n<div class=\"footer\">\n <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n (onClick)=\"showXml()\"></dx-button>\n <dx-button [type]=\"isShowConfig ? 'default' : 'normal'\" icon=\"coast-icon coast-icon-setting\"\n style=\"float: right;\"\n (onClick)=\"isShowConfig = !isShowConfig;\"></dx-button>\n</div>\n", styles: [":host{flex:1;display:flex;flex-flow:column nowrap}:host .main{flex:1;display:flex;flex-flow:row nowrap;position:relative}:host .main .container{flex:1}:host .main .config{flex:0 0 360px;border:1px solid var(--coast-border-color, #dddddd)}:host .main .xml-viewer{position:absolute;width:100%;height:100%;display:flex;flex-flow:column nowrap;z-index:var(--coast-z-index-drawer, 2000)}:host .main .xml-viewer rs-code-editor{flex:1}:host .footer{flex:0 0 24px;border:1px solid var(--coast-border-color, #dddddd)}\n"] }]
|
|
96
116
|
}], propDecorators: { xml: [{
|
|
97
117
|
type: Input
|
|
118
|
+
}], selectedNodeChanged: [{
|
|
119
|
+
type: Output
|
|
98
120
|
}], bpmnContainer: [{
|
|
99
121
|
type: ViewChild,
|
|
100
122
|
args: ['bpmnContainer']
|
|
@@ -102,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
102
124
|
type: ViewChild,
|
|
103
125
|
args: ['bpmnConfig']
|
|
104
126
|
}] } });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"camunda-bpmn-editor.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/camunda-bpmn-editor/camunda-bpmn-editor.component.ts","../../../../projects/ngx-rs-ant/src/camunda-bpmn-editor/camunda-bpmn-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, ViewChild} from '@angular/core';\r\nimport BpmnModeler from 'camunda-bpmn-js/lib/camunda-platform/Modeler';\r\nimport customTranslateModule from './custom/translate';\r\nimport customUserTaskModule from './custom/user-task';\r\nimport customServiceTaskModule from './custom/service-task';\r\nimport customHideOtherModule from './custom/hide-other';\r\nimport customPropertiesPanelModule from './custom/config';\r\n\r\n@Component({\r\n  selector: 'rs-camunda-bpmn-editor',\r\n  templateUrl: './camunda-bpmn-editor.component.html',\r\n  styleUrls: ['./camunda-bpmn-editor.component.scss']\r\n})\r\nexport class CamundaBpmnEditorComponent {\r\n  @Input()\r\n  set xml(xml: any) {\r\n    this._xml = xml;\r\n    this.loadXml();\r\n  }\r\n\r\n  get xml() {\r\n    return this._xml;\r\n  }\r\n\r\n  private _xml: any;\r\n  @ViewChild('bpmnContainer') bpmnContainer?: ElementRef;\r\n  @ViewChild('bpmnConfig') bpmnConfig?: ElementRef;\r\n  private modeler: any;\r\n  private canvas: any;\r\n  protected isShowXml = false;\r\n  private initialDiagram =\r\n    '<?xml version=\"1.0\" encoding=\"UTF-8\"?>' +\r\n    '<bpmn:definitions xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" ' +\r\n    'xmlns:bpmn=\"http://www.omg.org/spec/BPMN/20100524/MODEL\" ' +\r\n    'xmlns:bpmndi=\"http://www.omg.org/spec/BPMN/20100524/DI\" ' +\r\n    'xmlns:dc=\"http://www.omg.org/spec/DD/20100524/DC\" ' +\r\n    'targetNamespace=\"http://bpmn.io/schema/bpmn\" ' +\r\n    'id=\"Definitions_1\">' +\r\n    '<bpmn:process id=\"Process_1\" isExecutable=\"true\">' +\r\n    '<bpmn:startEvent id=\"StartEvent_1\"/>' +\r\n    '</bpmn:process>' +\r\n    '<bpmndi:BPMNDiagram id=\"BPMNDiagram_1\">' +\r\n    '<bpmndi:BPMNPlane id=\"BPMNPlane_1\" bpmnElement=\"Process_1\">' +\r\n    '<bpmndi:BPMNShape id=\"_BPMNShape_StartEvent_2\" bpmnElement=\"StartEvent_1\">' +\r\n    '<dc:Bounds height=\"36.0\" width=\"36.0\" x=\"173.0\" y=\"102.0\"/>' +\r\n    '</bpmndi:BPMNShape>' +\r\n    '</bpmndi:BPMNPlane>' +\r\n    '</bpmndi:BPMNDiagram>' +\r\n    '</bpmn:definitions>';\r\n\r\n  ngOnInit() {\r\n    if (!this.xml) {\r\n      this.xml = this.initialDiagram;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.modeler = new BpmnModeler({\r\n      container: this.bpmnContainer?.nativeElement,\r\n      propertiesPanel: {\r\n        parent: this.bpmnConfig?.nativeElement,\r\n      },\r\n      keyboard: {\r\n        bindTo: document,\r\n      },\r\n      additionalModules: [\r\n        customTranslateModule,\r\n        customUserTaskModule,\r\n        customServiceTaskModule,\r\n        customHideOtherModule,\r\n        customPropertiesPanelModule\r\n      ]\r\n    });\r\n    const logo = this.modeler._container.querySelector('.bjs-powered-by');\r\n    if (logo) {\r\n      this.modeler._container.removeChild(logo);\r\n    }\r\n    this.canvas = this.modeler.get('canvas');\r\n    this.loadXml();\r\n  }\r\n\r\n  loadXml() {\r\n    this.modeler.importXML(this.xml).then(() => {\r\n      this.canvas.zoom('fit-viewport');\r\n    });\r\n  }\r\n\r\n  showXml() {\r\n    if (!this.isShowXml) {\r\n      this.saveXml((xml: any) => {\r\n        this.xml = xml;\r\n      })\r\n    }\r\n    this.isShowXml = !this.isShowXml;\r\n  }\r\n\r\n  public saveXml(callback?: any) {\r\n    this.modeler.saveXML({format: true}).then((response: any) => {\r\n      if (callback) {\r\n        callback(response.xml);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"main\">\n  <div class=\"container\" #bpmnContainer></div>\n  <div class=\"config\" #bpmnConfig></div>\n  <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n    <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n  </div>\n</div>\n<div class=\"footer\">\n  <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n             (onClick)=\"showXml()\"></dx-button>\n</div>\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"camunda-bpmn-editor.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/camunda-bpmn-editor/camunda-bpmn-editor.component.ts","../../../../projects/ngx-rs-ant/src/camunda-bpmn-editor/camunda-bpmn-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, Input, Output, ViewChild} from '@angular/core';\r\nimport BpmnModeler from 'camunda-bpmn-js/lib/camunda-platform/Modeler';\r\nimport customTranslateModule from './custom/translate';\r\nimport customUserTaskModule from './custom/user-task';\r\nimport customServiceTaskModule from './custom/service-task';\r\nimport customHideOtherModule from './custom/hide-other';\r\n\r\n@Component({\r\n  selector: 'rs-camunda-bpmn-editor',\r\n  templateUrl: './camunda-bpmn-editor.component.html',\r\n  styleUrls: ['./camunda-bpmn-editor.component.scss']\r\n})\r\nexport class CamundaBpmnEditorComponent {\r\n  @Input()\r\n  set xml(xml: any) {\r\n    this._xml = xml;\r\n    setTimeout(() => {\r\n      this.loadXml();\r\n    });\r\n  }\r\n\r\n  get xml() {\r\n    return this._xml;\r\n  }\r\n\r\n  private _xml: any;\r\n  @Output()\r\n  selectedNodeChanged = new EventEmitter<{ element: any, util?: any }>();\r\n  @ViewChild('bpmnContainer') bpmnContainer?: ElementRef;\r\n  @ViewChild('bpmnConfig') bpmnConfig?: ElementRef;\r\n  private modeler: any;\r\n  private canvas: any;\r\n  protected isShowXml = false;\r\n  protected isShowConfig = false;\r\n  private initialDiagram =\r\n    '<?xml version=\"1.0\" encoding=\"UTF-8\"?>' +\r\n    '<bpmn:definitions xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" ' +\r\n    'xmlns:bpmn=\"http://www.omg.org/spec/BPMN/20100524/MODEL\" ' +\r\n    'xmlns:bpmndi=\"http://www.omg.org/spec/BPMN/20100524/DI\" ' +\r\n    'xmlns:dc=\"http://www.omg.org/spec/DD/20100524/DC\" ' +\r\n    'targetNamespace=\"http://bpmn.io/schema/bpmn\" ' +\r\n    'id=\"Definitions_1\">' +\r\n    '<bpmn:process id=\"Process_1\" isExecutable=\"true\">' +\r\n    '<bpmn:startEvent id=\"StartEvent_1\"/>' +\r\n    '</bpmn:process>' +\r\n    '<bpmndi:BPMNDiagram id=\"BPMNDiagram_1\">' +\r\n    '<bpmndi:BPMNPlane id=\"BPMNPlane_1\" bpmnElement=\"Process_1\">' +\r\n    '<bpmndi:BPMNShape id=\"_BPMNShape_StartEvent_2\" bpmnElement=\"StartEvent_1\">' +\r\n    '<dc:Bounds height=\"36.0\" width=\"36.0\" x=\"173.0\" y=\"102.0\"/>' +\r\n    '</bpmndi:BPMNShape>' +\r\n    '</bpmndi:BPMNPlane>' +\r\n    '</bpmndi:BPMNDiagram>' +\r\n    '</bpmn:definitions>';\r\n\r\n  ngOnInit() {\r\n    if (!this.xml) {\r\n      this.xml = this.initialDiagram;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.modeler = new BpmnModeler({\r\n      container: this.bpmnContainer?.nativeElement,\r\n      propertiesPanel: {\r\n        parent: this.bpmnConfig?.nativeElement,\r\n      },\r\n      keyboard: {\r\n        bindTo: document,\r\n      },\r\n      additionalModules: [\r\n        customTranslateModule,\r\n        customUserTaskModule,\r\n        customServiceTaskModule,\r\n        customHideOtherModule,\r\n        // customPropertiesPanelModule\r\n      ]\r\n    });\r\n    const logo = this.modeler._container.querySelector('.bjs-powered-by');\r\n    if (logo) {\r\n      this.modeler._container.removeChild(logo);\r\n    }\r\n    this.modeler.get('palette')._toggleState({twoColumn: false});\r\n    this.canvas = this.modeler.get('canvas');\r\n    const eventBus = this.modeler.get('eventBus');\r\n    eventBus.on(['propertiesPanel.updated'], ($event: any) => {\r\n      if (Array.isArray($event.element)) {\r\n        this.selectedNodeChanged.emit();\r\n      } else {\r\n        this.selectedNodeChanged.emit({\r\n          element: $event.element,\r\n          util: {\r\n            bpmnFactory: this.modeler.get('bpmnFactory'),\r\n            modeling: this.modeler.get('modeling'),\r\n            elementRegistry: this.modeler.get('elementRegistry')\r\n          }\r\n        });\r\n      }\r\n    });\r\n    this.loadXml();\r\n  }\r\n\r\n  loadXml() {\r\n    this.modeler.importXML(this.xml).then(() => {\r\n      this.canvas.zoom('fit-viewport');\r\n    });\r\n  }\r\n\r\n  showXml() {\r\n    if (!this.isShowXml) {\r\n      this.saveXml((xml: any) => {\r\n        this.xml = xml;\r\n      })\r\n    }\r\n    this.isShowXml = !this.isShowXml;\r\n  }\r\n\r\n  public saveXml(callback?: any) {\r\n    this.modeler.saveXML({format: true}).then((response: any) => {\r\n      if (callback) {\r\n        callback(response.xml);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div class=\"main\">\n  <div class=\"container\" #bpmnContainer></div>\n  <div [hidden]=\"!isShowConfig\" class=\"config\" #bpmnConfig></div>\n  <div class=\"xml-viewer\" [ngStyle]=\"{display: isShowXml ? 'flex' : 'none'}\">\n    <rs-code-editor language=\"xml\" [code]=\"xml\" [readonly]=\"true\" [enableMinimap]=\"true\"></rs-code-editor>\n  </div>\n</div>\n<div class=\"footer\">\n  <dx-button [type]=\"isShowXml ? 'default' : 'normal'\" text=\"XML\" [hoverStateEnabled]=\"false\"\n             (onClick)=\"showXml()\"></dx-button>\n  <dx-button [type]=\"isShowConfig ? 'default' : 'normal'\" icon=\"coast-icon coast-icon-setting\"\n             style=\"float: right;\"\n             (onClick)=\"isShowConfig = !isShowConfig;\"></dx-button>\n</div>\n"]}
|