qms-angular 1.0.86 → 1.0.87

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/bundles/qms-angular.umd.js +6802 -207
  2. package/bundles/qms-angular.umd.js.map +1 -1
  3. package/esm2015/lib/components/comment/comment.js +6 -3
  4. package/esm2015/lib/components/qms-navigation-drawer/qms-navigation-drawer.component.js +3 -3
  5. package/esm2015/lib/components/related/content/related-content.component.js +2 -2
  6. package/esm2015/lib/components/table/table.module.js +4 -4
  7. package/esm2015/lib/directives/file-upload/file-upload-multiple-selector.directive.js +3 -1
  8. package/esm2015/lib/directives/file-upload/file-upload-selector.directive.js +3 -1
  9. package/esm2015/lib/directives/file-upload/file-upload.directive.js +1 -1
  10. package/esm2015/lib/model/en.js +63 -2
  11. package/esm2015/lib/model/no.js +63 -2
  12. package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/halo.function.js +87 -0
  13. package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/inspector.function.js +3767 -0
  14. package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/selection.function.js +56 -0
  15. package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/stencil.function.js +1003 -0
  16. package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/toolbar.function.js +302 -0
  17. package/esm2015/lib/qms-ckeditor-components/common/flowchart/models/app-shapes.js +320 -0
  18. package/esm2015/lib/qms-ckeditor-components/common/flowchart/service/keyboard-service.js +69 -0
  19. package/esm2015/lib/qms-ckeditor-components/common/flowchart/service/kitchensink-service.js +412 -0
  20. package/esm2015/lib/qms-ckeditor-components/common/flowchart/themes/theme-picker.js +80 -0
  21. package/esm2015/lib/qms-ckeditor-components/common/models/qms-ckeditor-save-as-template.model.js +1 -1
  22. package/esm2015/lib/qms-ckeditor-components/common/module/confirm/qms-ckeditor-confirm.component.js +2 -2
  23. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-bpmn/qms-ckeditor-bpmn.component.js +2 -2
  24. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-bpmn/save-template/save-template.component.js +2 -2
  25. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.js +317 -0
  26. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-imagemap/qms-ckeditor-imagemap.component.js +2 -2
  27. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-link/attachments/link-attachment.component.js +2 -2
  28. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-link/qms-ckeditor-link.component.js +2 -2
  29. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-load-template/qms-ckeditor-load-template.component.js +2 -2
  30. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-relation/qmsckeditor-related.component.js +2 -2
  31. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-template/qms-ckeditor-template.component.js +2 -2
  32. package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-tooltip/qms-ckeditor-tooltip.component.js +2 -2
  33. package/esm2015/lib/qms-ckeditor-components/qms-ckeditor.component.js +31 -1
  34. package/esm2015/lib/qms-ckeditor-components/qms-ckeditor.module.js +4 -2
  35. package/esm2015/public-api.js +7 -1
  36. package/esm2015/qms-angular.js +2 -1
  37. package/fesm2015/qms-angular.js +6744 -194
  38. package/fesm2015/qms-angular.js.map +1 -1
  39. package/lib/components/comment/comment.d.ts +1 -0
  40. package/lib/model/en.d.ts +61 -0
  41. package/lib/model/no.d.ts +61 -0
  42. package/lib/qms-ckeditor-components/common/flowchart/config/halo.function.d.ts +37 -0
  43. package/lib/qms-ckeditor-components/common/flowchart/config/inspector.function.d.ts +7 -0
  44. package/lib/qms-ckeditor-components/common/flowchart/config/selection.function.d.ts +39 -0
  45. package/lib/qms-ckeditor-components/common/flowchart/config/stencil.function.d.ts +11 -0
  46. package/lib/qms-ckeditor-components/common/flowchart/config/toolbar.function.d.ts +224 -0
  47. package/lib/qms-ckeditor-components/common/flowchart/models/app-shapes.d.ts +58 -0
  48. package/lib/qms-ckeditor-components/common/flowchart/service/keyboard-service.d.ts +16 -0
  49. package/lib/qms-ckeditor-components/common/flowchart/service/kitchensink-service.d.ts +56 -0
  50. package/lib/qms-ckeditor-components/common/flowchart/themes/theme-picker.d.ts +35 -0
  51. package/lib/qms-ckeditor-components/common/models/qms-ckeditor-save-as-template.model.d.ts +2 -0
  52. package/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.d.ts +41 -0
  53. package/lib/qms-ckeditor-components/qms-ckeditor.component.d.ts +4 -0
  54. package/lib.theme.scss +4 -0
  55. package/package.json +1 -1
  56. package/public-api.d.ts +6 -0
  57. package/qms-angular.d.ts +1 -0
  58. package/qms-angular.metadata.json +1 -1
  59. package/src/assets/fonts/OpenSans/OpenSans.woff2 +0 -0
  60. package/src/assets/jointjs/images/delete-icon-modern.png +0 -0
  61. package/src/assets/jointjs/images/reset-icon-modern.png +0 -0
  62. package/src/assets/jointjs/images/save-icon-modern.png +0 -0
  63. package/src/assets/jointjs/images/to-front-icon-modern.png +0 -0
  64. package/src/assets/jointjs/images/toback-icon-modern.png +0 -0
  65. package/src/assets/jointjs/images/toolbar-icons-material.png +0 -0
  66. package/src/assets/jointjs/images/toolbar-icons-modern.png +0 -0
  67. package/src/assets/jointjs/scss/rappid.scss +326 -0
  68. package/src/assets/jointjs/scss/theme-picker.scss +22 -0
  69. package/src/assets/qms-ckeditor-plugin/build/ckeditor.js +1 -1
  70. package/src/assets/qms-ckeditor-plugin/build/ckeditor.js.map +1 -1
  71. package/src/assets/qms-ckeditor-plugin/package-lock.json +12634 -345
  72. package/src/assets/qms-ckeditor-plugin/src/ckeditor.js +2 -2
  73. package/src/assets/qms-ckeditor-plugin/src/plugins/common/qmsCKEditorService.js +9 -0
  74. package/src/assets/qms-ckeditor-plugin/src/plugins/flowchart/flowchartdialogcommand.js +47 -0
  75. package/src/assets/qms-ckeditor-plugin/src/plugins/flowchart/qmsCKEditorFlowchartPlugin.js +30 -0
  76. package/src/assets/qms-ckeditor-plugin/src/themes/icons/flowchart.svg +507 -0
  77. package/src/lib/components/comment/comment.scss +1 -0
  78. package/src/lib/components/qms-navigation-drawer/qms-navigation-drawer.component.scss +1 -0
  79. package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon1.svg +1 -0
  80. package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon2.svg +6 -0
  81. package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon3.svg +11 -0
  82. package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon4.svg +8 -0
  83. package/src/lib/qms-ckeditor-components/common/flowchart/assets/member-female.png +0 -0
  84. package/src/lib/qms-ckeditor-components/common/flowchart/assets/member-male.png +0 -0
  85. package/src/lib/qms-ckeditor-components/common/flowchart/assets/no-color-icon.svg +72 -0
  86. package/src/lib/qms-ckeditor-components/common/flowchart/assets/toolbar-icons-material.png +0 -0
  87. package/src/lib/qms-ckeditor-components/common/flowchart/assets/toolbar-icons-modern.png +0 -0
  88. package/src/lib/qms-ckeditor-components/common/flowchart/assets/transparent-icon.svg +50 -0
  89. package/src/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.scss +68 -0
@@ -0,0 +1,317 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, ElementRef, HostListener, Inject } from "@angular/core";
3
+ import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from "@angular/material/dialog";
4
+ import { takeUntil } from "rxjs/operators";
5
+ import { TranslateLibraryService } from "../../../services/translation-registry.service";
6
+ import { CKEditorEventConst } from "../../common/constants/ckeditorEvent.constant";
7
+ import { FlowChartConst } from "../../common/constants/ckeditorFlowchart.const";
8
+ import { KeyboardService } from "../../common/flowchart/service/keyboard-service";
9
+ import RappidService from '../../common/flowchart/service/kitchensink-service';
10
+ import { ThemePicker } from "../../common/flowchart/themes/theme-picker";
11
+ import guidHelper from "../../common/helper/guidHelper";
12
+ import { QMSCKEditorDialogData } from "../../common/models/qms-ckeditor-dialog.model";
13
+ import { QMSCKEditorFlowchart } from "../../common/models/qms-ckeditor-flowchart.model";
14
+ import { QMSCKEditorSaveAsTemplate } from "../../common/models/qms-ckeditor-save-as-template.model";
15
+ import { QMSCKEditorConfirmComponent } from "../../common/module/confirm/qms-ckeditor-confirm.component";
16
+ import { QMSCKEditorToastService } from "../../common/toast/qms-ckeditor-toast.service";
17
+ import { QMSCKEditorBaseComponent } from "../../qms-ckeditor-base.component";
18
+ import { QMSCKEditorFlowchartService } from "../../services/qms-ckeditor-flowchart.service";
19
+ import { SaveTemplateComponent } from "../qms-ckeditor-bpmn/save-template/save-template.component";
20
+ export class QMSCKEditorFlowchartComponent extends QMSCKEditorBaseComponent {
21
+ constructor(dialog, element, translate, flowchartService, dialogRef, data) {
22
+ super();
23
+ this.dialog = dialog;
24
+ this.element = element;
25
+ this.translate = translate;
26
+ this.flowchartService = flowchartService;
27
+ this.dialogRef = dialogRef;
28
+ this.data = data;
29
+ this.jsonContent = '';
30
+ this.id = '';
31
+ this.flowchart = new QMSCKEditorFlowchart();
32
+ this.flowchartTemplates = [];
33
+ this.id = data;
34
+ }
35
+ onMessage(event) {
36
+ if (event.data === FlowChartConst.KS_CHANGE_TEMPLATE) {
37
+ this.onChangeTemplate();
38
+ }
39
+ else if (event.data === FlowChartConst.KS_DELETE_TEMPLATE) {
40
+ this.onDeleteTemplate(this.LANG.BPMN.DELETE_TEMPLATE, this.LANG.QMSCKEDITOR_MESSAGE.CONFIRM_DELETE_TEMPLATE);
41
+ }
42
+ else if (event.data === FlowChartConst.MUST_SELECT_TEMPLATE) {
43
+ this.showInfoMessage(this.LANG.BPMN.SELECT_TEMPLATE, this.LANG.BPMN.SELECT_TEMPLATE_INFORMATION);
44
+ }
45
+ else if (event.data === FlowChartConst.KS_SAVE_AS_TEMPLATE) {
46
+ this.onSaveAsTemplate();
47
+ }
48
+ else if (event.data === FlowChartConst.KS_RESET_TEMPLATE) {
49
+ this.onResetTemplate();
50
+ }
51
+ }
52
+ ngOnInit() {
53
+ return __awaiter(this, void 0, void 0, function* () {
54
+ this.translate.getLanguageSubject$.pipe(takeUntil(this.ngUnsubcribe)).subscribe((res) => {
55
+ if (res) {
56
+ this.LANG = this.translate.getObjectLang(res);
57
+ }
58
+ });
59
+ if (this.id) {
60
+ this.jsonContent = yield this.getJsonContent(this.id);
61
+ }
62
+ this.rappid = new RappidService(this.element.nativeElement, new KeyboardService(), this.LANG);
63
+ this.rappid.startRappid();
64
+ const themePicker = new ThemePicker({ mainView: this.rappid });
65
+ themePicker.render().$el.appendTo(document.getElementById('themepicker'));
66
+ if (this.jsonContent) {
67
+ this.rappid.graph.fromJSON(JSON.parse(this.jsonContent));
68
+ }
69
+ });
70
+ }
71
+ ngAfterViewInit() {
72
+ return __awaiter(this, void 0, void 0, function* () {
73
+ this.flowchartTemplates = yield this.getTemplates();
74
+ this.initializeTemplates(this.flowchartTemplates);
75
+ });
76
+ }
77
+ getJsonContent(id) {
78
+ return __awaiter(this, void 0, void 0, function* () {
79
+ return new Promise((resolve) => {
80
+ this.flowchartService
81
+ .getFlowchartById(id)
82
+ .pipe(takeUntil(this.ngUnsubcribe))
83
+ .subscribe((result) => {
84
+ if (result) {
85
+ resolve(result.jsonContent);
86
+ }
87
+ });
88
+ });
89
+ });
90
+ }
91
+ getTemplates() {
92
+ return __awaiter(this, void 0, void 0, function* () {
93
+ return new Promise((resolve) => {
94
+ this.flowchartService
95
+ .flowchartGetTemplates()
96
+ .pipe(takeUntil(this.ngUnsubcribe))
97
+ .subscribe((result) => {
98
+ resolve(result);
99
+ });
100
+ });
101
+ });
102
+ }
103
+ initializeTemplates(templates) {
104
+ if (templates) {
105
+ this.toolbarConfig = this.rappid.toolbar;
106
+ const arrSelect = this.toolbarConfig.tools.filter((item) => {
107
+ return item.type === 'select-box';
108
+ });
109
+ if (arrSelect && arrSelect[0]) {
110
+ templates.forEach((item) => {
111
+ const option = {
112
+ index: item.index,
113
+ content: item.templateName,
114
+ flowChartId: item.id,
115
+ name: item.templateName,
116
+ jsonContent: item.jsonContent,
117
+ selected: false
118
+ };
119
+ const index = arrSelect[0].options.findIndex((x) => {
120
+ return x.index === option.index;
121
+ });
122
+ if (index < 0) {
123
+ arrSelect[0].options.push(option);
124
+ }
125
+ });
126
+ }
127
+ }
128
+ }
129
+ addItem2Template(template) {
130
+ this.toolbarConfig = this.rappid.toolbar;
131
+ const arrSelect = this.toolbarConfig.tools.filter((item) => {
132
+ return item.type === 'select-box';
133
+ });
134
+ if (arrSelect) {
135
+ const option = {
136
+ index: 1,
137
+ content: template.templateName,
138
+ flowChartId: template.id,
139
+ name: template.templateName,
140
+ jsonContent: template.jsonContent,
141
+ selected: false
142
+ };
143
+ arrSelect[0].options.push(option);
144
+ }
145
+ }
146
+ removeSelectedValue(flowChartId) {
147
+ this.toolbarConfig = this.rappid.toolbar;
148
+ const arrSelect = this.toolbarConfig.tools.filter((item) => {
149
+ return item.type === 'select-box';
150
+ });
151
+ if (arrSelect) {
152
+ arrSelect[0].options.splice(arrSelect[0].options.findIndex((i) => {
153
+ return i.flowChartId === flowChartId;
154
+ }), 1);
155
+ }
156
+ }
157
+ setDefaultSelectedValue() {
158
+ this.toolbarConfig = this.rappid.toolbar;
159
+ const arrSelect = this.toolbarConfig.tools.filter((item) => {
160
+ return item.type === 'select-box';
161
+ });
162
+ if (arrSelect) {
163
+ arrSelect[0].options[0].selected = true;
164
+ const list = document.getElementsByClassName(`select-box-selection`)[0];
165
+ list.getElementsByClassName(`select-box-option-content`)[0].innerHTML = FlowChartConst.SELECT_TEMPLATE;
166
+ }
167
+ }
168
+ saveImageContent() {
169
+ return __awaiter(this, void 0, void 0, function* () {
170
+ return new Promise((resolve) => {
171
+ const jsonContent = this.rappid.getJsonContent();
172
+ this.flowchart = {
173
+ id: this.id ? this.id : guidHelper.empty,
174
+ jsonContent: jsonContent,
175
+ isTemplate: false,
176
+ templateName: ''
177
+ };
178
+ this.flowchartService
179
+ .flowchartModifying(this.flowchart)
180
+ .pipe(takeUntil(this.ngUnsubcribe))
181
+ .subscribe((result) => {
182
+ if (result) {
183
+ resolve(result);
184
+ }
185
+ });
186
+ });
187
+ });
188
+ }
189
+ onInsertImage() {
190
+ return __awaiter(this, void 0, void 0, function* () {
191
+ const id = yield this.saveImageContent();
192
+ const imageContent = yield this.rappid.getImageContent();
193
+ const result = { key: `${CKEditorEventConst.QMSCK_FLOWCHART}#${id}`, values: imageContent };
194
+ this.dialogRef.close(result);
195
+ });
196
+ }
197
+ onChangeTemplate() {
198
+ const jsonTemplate = window[FlowChartConst.KS_SELECTED_JSONCONTENT] ? window[FlowChartConst.KS_SELECTED_JSONCONTENT] : '';
199
+ if (!window[FlowChartConst.KS_IS_SELECTED_TEMPLATE]) {
200
+ window[FlowChartConst.KS_ORG_JSONCONTENT] = JSON.stringify(this.rappid.graph.toJSON());
201
+ window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = true;
202
+ }
203
+ if (jsonTemplate) {
204
+ this.rappid.graph.fromJSON(JSON.parse(jsonTemplate));
205
+ }
206
+ }
207
+ onDeleteTemplate(title, content) {
208
+ const data = new QMSCKEditorDialogData();
209
+ data.title = title;
210
+ data.content = content;
211
+ const dialogRef = this.dialog.open(QMSCKEditorConfirmComponent, {
212
+ width: '500px',
213
+ minHeight: '175px',
214
+ data
215
+ });
216
+ dialogRef
217
+ .afterClosed()
218
+ .pipe(takeUntil(this.ngUnsubcribe))
219
+ .subscribe((result) => {
220
+ if (result) {
221
+ const id = window[FlowChartConst.KS_SELECTED_FLOWCHART_ID];
222
+ this.flowchartService
223
+ .flowchartDeleteTemplate(id)
224
+ .pipe(takeUntil(this.ngUnsubcribe))
225
+ .subscribe((result) => {
226
+ if (result) {
227
+ this.removeSelectedValue(id);
228
+ this.setDefaultSelectedValue();
229
+ window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = false;
230
+ QMSCKEditorToastService.success(this.LANG.QMSCKEDITOR.DELETED);
231
+ }
232
+ else {
233
+ QMSCKEditorToastService.error(this.LANG.QMSCKEDITOR.DELETE_FAILED);
234
+ }
235
+ });
236
+ }
237
+ });
238
+ }
239
+ onSaveAsTemplate() {
240
+ const jsonContent = JSON.stringify(this.rappid.graph.toJSON());
241
+ let template = new QMSCKEditorFlowchart();
242
+ template = {
243
+ id: guidHelper.empty,
244
+ jsonContent: jsonContent,
245
+ isTemplate: true,
246
+ templateName: ''
247
+ };
248
+ let data = new QMSCKEditorSaveAsTemplate();
249
+ data.templateType = CKEditorEventConst.QMSCK_FLOWCHART;
250
+ data.flowchart = template;
251
+ const dialogTemplate = this.dialog.open(SaveTemplateComponent, {
252
+ width: '450px',
253
+ height: '220px',
254
+ data,
255
+ disableClose: true
256
+ });
257
+ dialogTemplate
258
+ .afterClosed()
259
+ .pipe(takeUntil(this.ngUnsubcribe))
260
+ .subscribe((result) => {
261
+ if (result) {
262
+ this.addItem2Template(result);
263
+ }
264
+ });
265
+ }
266
+ onResetTemplate() {
267
+ if (window[FlowChartConst.KS_IS_SELECTED_TEMPLATE]) {
268
+ const orgTemplate = window[FlowChartConst.KS_ORG_JSONCONTENT] ? window[FlowChartConst.KS_ORG_JSONCONTENT] : '';
269
+ if (orgTemplate) {
270
+ this.rappid.graph.fromJSON(JSON.parse(orgTemplate));
271
+ this.setDefaultSelectedValue();
272
+ window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = false;
273
+ }
274
+ }
275
+ }
276
+ showInfoMessage(title, content) {
277
+ const data = new QMSCKEditorDialogData();
278
+ data.title = title;
279
+ data.content = content;
280
+ data.isMessage = true;
281
+ const dialogRef = this.dialog.open(QMSCKEditorConfirmComponent, {
282
+ width: '500px',
283
+ minHeight: '175px',
284
+ data
285
+ });
286
+ dialogRef
287
+ .afterClosed()
288
+ .pipe(takeUntil(this.ngUnsubcribe))
289
+ .subscribe((result) => {
290
+ if (result) {
291
+ //TODO
292
+ }
293
+ });
294
+ }
295
+ onCloseDialog() {
296
+ this.dialogRef.close();
297
+ }
298
+ }
299
+ QMSCKEditorFlowchartComponent.decorators = [
300
+ { type: Component, args: [{
301
+ selector: 'qms-flowchart',
302
+ template: "<div id=\"qmsckeditor-flowchart\" class=\"qmsckeditor qmsckeditor__flowchart__container\">\r\n <div id=\"qmsckeditor-flowchart-header\">\r\n <span id=\"qmsckeditor-flowchart-header_001\" mat-icon-button class=\"qmsckeditor button__close\"\r\n (click)=\"onCloseDialog()\">\r\n <mat-icon>close</mat-icon>\r\n </span>\r\n <span id=\"qmsckeditor-flowchart-header_002\" mat-icon-button class=\"qmsckeditor button__done\"\r\n (click)=\"onInsertImage()\">\r\n <mat-icon>done</mat-icon>\r\n </span>\r\n <div id=\"qmsckeditor-flowchart-header_002\" mat-dialog-content>\r\n <h2 id=\"qmsckeditor-flowchart_002_001\">{{ LANG.BPMN.FLOWCHART }}</h2>\r\n </div>\r\n </div>\r\n <div id=\"flowchart\" class=\"flowchart__editor\">\r\n <div class=\"joint-app joint-theme-modern\">\r\n <div class=\"app-header\">\r\n <div class=\"app-title\">\r\n <h1>{{ LANG.BPMN.HANDBOOK }}</h1>\r\n </div>\r\n <div id=\"flowcharttoolbar\" class=\"toolbar-container\"></div>\r\n </div>\r\n <div class=\"app-body\">\r\n <div id=\"contentpanel\">\r\n <div id=\"stencilpanel\">\r\n <div id=\"flowchartstencil\" class=\"stencil-container\"></div>\r\n </div>\r\n <div id=\"paperpanel\">\r\n <div class=\"paper-container\"></div>\r\n <div id=\"themepicker\"></div>\r\n </div>\r\n <div id=\"rightpanel\">\r\n <div id=\"inspectorpanel\">\r\n <div class=\"inspector-container\"></div>\r\n </div>\r\n <div id=\"navigatorpanel\">\r\n <div class=\"navigator-container\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>",
303
+ styles: [".qmsckeditor__flowchart__container ::ng-deep .mat-dialog-content{padding:0}.qmsckeditor__flowchart__container .flowchart__editor{width:100%;height:600px}.qmsckeditor__flowchart__container #contentpanel{display:flex;flex-direction:row;justify-content:center;align-items:center}.qmsckeditor__flowchart__container #paperpanel{position:relative;top:0;bottom:0;left:0;right:0;height:540px;width:60%;overflow-y:auto}.qmsckeditor__flowchart__container #paperpanel .paper-container{overflow-y:auto;width:100%;height:100%}.qmsckeditor__flowchart__container #stencilpanel{position:relative;top:0;bottom:0;left:0;right:0;height:540px;width:20%}.qmsckeditor__flowchart__container #rightpanel{display:flex;flex-direction:column;align-items:center;width:20%;height:540px}.qmsckeditor__flowchart__container #rightpanel #inspectorpanel{overflow-y:auto;width:100%;height:80%}.qmsckeditor__flowchart__container #rightpanel #navigatorpanel{width:100%;height:20%}.qmsckeditor__flowchart__container #themepicker{position:absolute;right:0;bottom:0}"]
304
+ },] }
305
+ ];
306
+ QMSCKEditorFlowchartComponent.ctorParameters = () => [
307
+ { type: MatDialog },
308
+ { type: ElementRef },
309
+ { type: TranslateLibraryService },
310
+ { type: QMSCKEditorFlowchartService },
311
+ { type: MatDialogRef },
312
+ { type: String, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] }
313
+ ];
314
+ QMSCKEditorFlowchartComponent.propDecorators = {
315
+ onMessage: [{ type: HostListener, args: ['window:message', ['$event'],] }]
316
+ };
317
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qms-ckeditor-flowchart.component.js","sourceRoot":"","sources":["../../../../../../../projects/qms-angular/src/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, HostListener, Inject, OnInit } from \"@angular/core\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport { TranslateLibraryService } from \"../../../services/translation-registry.service\";\r\nimport { CKEditorEventConst } from \"../../common/constants/ckeditorEvent.constant\";\r\nimport { FlowChartConst } from \"../../common/constants/ckeditorFlowchart.const\";\r\nimport { KeyboardService } from \"../../common/flowchart/service/keyboard-service\";\r\nimport RappidService from '../../common/flowchart/service/kitchensink-service';\r\nimport { ThemePicker } from \"../../common/flowchart/themes/theme-picker\";\r\nimport guidHelper from \"../../common/helper/guidHelper\";\r\nimport { QMSCKEditorDialogData } from \"../../common/models/qms-ckeditor-dialog.model\";\r\nimport { QMSCKEditorFlowchartTemplate } from \"../../common/models/qms-ckeditor-flowchart-template.model\";\r\nimport { QMSCKEditorFlowchart } from \"../../common/models/qms-ckeditor-flowchart.model\";\r\nimport { QMSCKEditorSaveAsTemplate } from \"../../common/models/qms-ckeditor-save-as-template.model\";\r\nimport { QMSCKEditorConfirmComponent } from \"../../common/module/confirm/qms-ckeditor-confirm.component\";\r\nimport { QMSCKEditorToastService } from \"../../common/toast/qms-ckeditor-toast.service\";\r\nimport { QMSCKEditorBaseComponent } from \"../../qms-ckeditor-base.component\";\r\nimport { QMSCKEditorFlowchartService } from \"../../services/qms-ckeditor-flowchart.service\";\r\nimport { SaveTemplateComponent } from \"../qms-ckeditor-bpmn/save-template/save-template.component\";\r\n\r\n@Component({\r\n  selector: 'qms-flowchart',\r\n  templateUrl: './qms-ckeditor-flowchart.component.html',\r\n  styleUrls: ['./qms-ckeditor-flowchart.component.scss']\r\n})\r\n\r\nexport class QMSCKEditorFlowchartComponent extends QMSCKEditorBaseComponent implements OnInit, AfterViewInit {\r\n  LANG: any;\r\n  jsonContent: string = '';\r\n  rappid: RappidService;\r\n  id = '';\r\n  flowchart: QMSCKEditorFlowchart = new QMSCKEditorFlowchart();\r\n  flowchartTemplates: QMSCKEditorFlowchartTemplate[] = [];\r\n  toolbarConfig: any;\r\n\r\n  constructor(\r\n    private dialog: MatDialog,\r\n    private element: ElementRef,\r\n    private translate: TranslateLibraryService,\r\n    private flowchartService: QMSCKEditorFlowchartService,\r\n    public dialogRef: MatDialogRef<QMSCKEditorFlowchartComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data: string) {\r\n    super();\r\n    this.id = data;\r\n  }\r\n\r\n  @HostListener('window:message', ['$event'])\r\n  onMessage(event) {\r\n    if (event.data === FlowChartConst.KS_CHANGE_TEMPLATE) {\r\n      this.onChangeTemplate();\r\n    }\r\n    else if (event.data === FlowChartConst.KS_DELETE_TEMPLATE) {\r\n      this.onDeleteTemplate(this.LANG.BPMN.DELETE_TEMPLATE, this.LANG.QMSCKEDITOR_MESSAGE.CONFIRM_DELETE_TEMPLATE)\r\n    }\r\n    else if (event.data === FlowChartConst.MUST_SELECT_TEMPLATE) {\r\n      this.showInfoMessage(this.LANG.BPMN.SELECT_TEMPLATE, this.LANG.BPMN.SELECT_TEMPLATE_INFORMATION);\r\n    }\r\n    else if (event.data === FlowChartConst.KS_SAVE_AS_TEMPLATE) {\r\n      this.onSaveAsTemplate();\r\n    }\r\n    else if (event.data === FlowChartConst.KS_RESET_TEMPLATE) {\r\n      this.onResetTemplate();\r\n    }\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.translate.getLanguageSubject$.pipe(takeUntil(this.ngUnsubcribe)).subscribe((res) => {\r\n      if (res) {\r\n        this.LANG = this.translate.getObjectLang(res);\r\n      }\r\n    });\r\n\r\n    if (this.id) {\r\n      this.jsonContent = await this.getJsonContent(this.id);\r\n    }\r\n    this.rappid = new RappidService(\r\n      this.element.nativeElement,\r\n      new KeyboardService(),\r\n      this.LANG\r\n    );\r\n\r\n    this.rappid.startRappid();\r\n\r\n    const themePicker = new ThemePicker({ mainView: this.rappid });\r\n    themePicker.render().$el.appendTo(document.getElementById('themepicker'));\r\n\r\n    if (this.jsonContent) {\r\n      this.rappid.graph.fromJSON(JSON.parse(this.jsonContent));\r\n    }\r\n  }\r\n\r\n  async ngAfterViewInit(): Promise<void> {\r\n    this.flowchartTemplates = await this.getTemplates();\r\n    this.initializeTemplates(this.flowchartTemplates);\r\n  }\r\n\r\n\r\n  async getJsonContent(id: string): Promise<string> {\r\n    return new Promise((resolve) => {\r\n      this.flowchartService\r\n        .getFlowchartById(id)\r\n        .pipe(takeUntil(this.ngUnsubcribe))\r\n        .subscribe((result) => {\r\n          if (result) {\r\n            resolve(result.jsonContent);\r\n          }\r\n        });\r\n    })\r\n  }\r\n\r\n  async getTemplates(): Promise<QMSCKEditorFlowchartTemplate[]> {\r\n    return new Promise((resolve) => {\r\n      this.flowchartService\r\n        .flowchartGetTemplates()\r\n        .pipe(takeUntil(this.ngUnsubcribe))\r\n        .subscribe((result) => {\r\n          resolve(result);\r\n        })\r\n    })\r\n  }\r\n\r\n  initializeTemplates(templates: QMSCKEditorFlowchartTemplate[]) {\r\n    if (templates) {\r\n      this.toolbarConfig = this.rappid.toolbar;\r\n      const arrSelect = this.toolbarConfig.tools.filter((item) => {\r\n        return item.type === 'select-box';\r\n      });\r\n      if (arrSelect && arrSelect[0]) {\r\n        templates.forEach((item) => {\r\n          const option = {\r\n            index: item.index,\r\n            content: item.templateName,\r\n            flowChartId: item.id,\r\n            name: item.templateName,\r\n            jsonContent: item.jsonContent,\r\n            selected: false\r\n          };\r\n          const index = arrSelect[0].options.findIndex((x) => {\r\n            return x.index === option.index;\r\n          });\r\n          if (index < 0) {\r\n            arrSelect[0].options.push(option);\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  addItem2Template(template?: QMSCKEditorFlowchartTemplate) {\r\n    this.toolbarConfig = this.rappid.toolbar;\r\n    const arrSelect = this.toolbarConfig.tools.filter((item) => {\r\n      return item.type === 'select-box';\r\n    });\r\n    if (arrSelect) {\r\n      const option = {\r\n        index: 1,\r\n        content: template.templateName,\r\n        flowChartId: template.id,\r\n        name: template.templateName,\r\n        jsonContent: template.jsonContent,\r\n        selected: false\r\n      };\r\n      arrSelect[0].options.push(option);\r\n    }\r\n  }\r\n\r\n  removeSelectedValue(flowChartId?: string) {\r\n    this.toolbarConfig = this.rappid.toolbar;\r\n    const arrSelect = this.toolbarConfig.tools.filter((item) => {\r\n      return item.type === 'select-box';\r\n    });\r\n    if (arrSelect) {\r\n      arrSelect[0].options.splice(\r\n        arrSelect[0].options.findIndex((i) => {\r\n          return i.flowChartId === flowChartId;\r\n        }),\r\n        1\r\n      );\r\n    }\r\n  }\r\n\r\n  setDefaultSelectedValue() {\r\n    this.toolbarConfig = this.rappid.toolbar;\r\n    const arrSelect = this.toolbarConfig.tools.filter((item) => {\r\n      return item.type === 'select-box';\r\n    });\r\n    if (arrSelect) {\r\n      arrSelect[0].options[0].selected = true;\r\n      const list = document.getElementsByClassName(`select-box-selection`)[0];\r\n      list.getElementsByClassName(`select-box-option-content`)[0].innerHTML = FlowChartConst.SELECT_TEMPLATE;\r\n    }\r\n  }\r\n\r\n  async saveImageContent() {\r\n    return new Promise((resolve) => {\r\n      const jsonContent = this.rappid.getJsonContent();\r\n      this.flowchart = {\r\n        id: this.id ? this.id : guidHelper.empty,\r\n        jsonContent: jsonContent,\r\n        isTemplate: false,\r\n        templateName: ''\r\n      }\r\n\r\n      this.flowchartService\r\n        .flowchartModifying(this.flowchart)\r\n        .pipe(takeUntil(this.ngUnsubcribe))\r\n        .subscribe((result) => {\r\n          if (result) {\r\n            resolve(result);\r\n          }\r\n        });\r\n    })\r\n  }\r\n\r\n  async onInsertImage() {\r\n    const id = await this.saveImageContent();\r\n    const imageContent = await this.rappid.getImageContent();\r\n    const result = { key: `${CKEditorEventConst.QMSCK_FLOWCHART}#${id}`, values: imageContent }\r\n    this.dialogRef.close(result);\r\n  }\r\n\r\n  onChangeTemplate() {\r\n    const jsonTemplate = window[FlowChartConst.KS_SELECTED_JSONCONTENT] ? window[FlowChartConst.KS_SELECTED_JSONCONTENT] : '';\r\n    if (!window[FlowChartConst.KS_IS_SELECTED_TEMPLATE]) {\r\n      window[FlowChartConst.KS_ORG_JSONCONTENT] = JSON.stringify(this.rappid.graph.toJSON());\r\n      window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = true;\r\n    }\r\n    if (jsonTemplate) {\r\n      this.rappid.graph.fromJSON(JSON.parse(jsonTemplate));\r\n    }\r\n  }\r\n\r\n  onDeleteTemplate(title: string, content: string) {\r\n    const data: QMSCKEditorDialogData = new QMSCKEditorDialogData();\r\n    data.title = title;\r\n    data.content = content;\r\n    const dialogRef = this.dialog.open(QMSCKEditorConfirmComponent, {\r\n      width: '500px',\r\n      minHeight: '175px',\r\n      data\r\n    });\r\n    dialogRef\r\n      .afterClosed()\r\n      .pipe(takeUntil(this.ngUnsubcribe))\r\n      .subscribe((result) => {\r\n        if (result) {\r\n          const id = window[FlowChartConst.KS_SELECTED_FLOWCHART_ID];\r\n          this.flowchartService\r\n            .flowchartDeleteTemplate(id)\r\n            .pipe(takeUntil(this.ngUnsubcribe))\r\n            .subscribe((result) => {\r\n              if (result) {\r\n                this.removeSelectedValue(id);\r\n                this.setDefaultSelectedValue();\r\n                window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = false;\r\n                QMSCKEditorToastService.success(this.LANG.QMSCKEDITOR.DELETED);\r\n              }\r\n              else {\r\n                QMSCKEditorToastService.error(this.LANG.QMSCKEDITOR.DELETE_FAILED);\r\n              }\r\n            })\r\n        }\r\n      });\r\n  }\r\n\r\n  onSaveAsTemplate() {\r\n    const jsonContent = JSON.stringify(this.rappid.graph.toJSON());\r\n    let template = new QMSCKEditorFlowchart();\r\n    template = {\r\n      id: guidHelper.empty,\r\n      jsonContent: jsonContent,\r\n      isTemplate: true,\r\n      templateName: ''\r\n    }\r\n    let data = new QMSCKEditorSaveAsTemplate();\r\n    data.templateType = CKEditorEventConst.QMSCK_FLOWCHART;\r\n    data.flowchart = template;\r\n    const dialogTemplate = this.dialog.open(SaveTemplateComponent, {\r\n      width: '450px',\r\n      height: '220px',\r\n      data,\r\n      disableClose: true\r\n    });\r\n    dialogTemplate\r\n      .afterClosed()\r\n      .pipe(takeUntil(this.ngUnsubcribe))\r\n      .subscribe((result) => {\r\n        if (result) {\r\n          this.addItem2Template(result);\r\n        }\r\n      });\r\n  }\r\n\r\n  onResetTemplate() {\r\n    if (window[FlowChartConst.KS_IS_SELECTED_TEMPLATE]) {\r\n      const orgTemplate = window[FlowChartConst.KS_ORG_JSONCONTENT] ? window[FlowChartConst.KS_ORG_JSONCONTENT] : '';\r\n      if (orgTemplate) {\r\n        this.rappid.graph.fromJSON(JSON.parse(orgTemplate));\r\n        this.setDefaultSelectedValue();\r\n        window[FlowChartConst.KS_IS_SELECTED_TEMPLATE] = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  showInfoMessage(title: string, content: string) {\r\n    const data: QMSCKEditorDialogData = new QMSCKEditorDialogData();\r\n    data.title = title;\r\n    data.content = content;\r\n    data.isMessage = true;\r\n    const dialogRef = this.dialog.open(QMSCKEditorConfirmComponent, {\r\n      width: '500px',\r\n      minHeight: '175px',\r\n      data\r\n    });\r\n    dialogRef\r\n      .afterClosed()\r\n      .pipe(takeUntil(this.ngUnsubcribe))\r\n      .subscribe((result) => {\r\n        if (result) {\r\n          //TODO\r\n        }\r\n      });\r\n  }\r\n\r\n  onCloseDialog() {\r\n    this.dialogRef.close();\r\n  }\r\n}\r\n"]}