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.
- package/bundles/qms-angular.umd.js +6802 -207
- package/bundles/qms-angular.umd.js.map +1 -1
- package/esm2015/lib/components/comment/comment.js +6 -3
- package/esm2015/lib/components/qms-navigation-drawer/qms-navigation-drawer.component.js +3 -3
- package/esm2015/lib/components/related/content/related-content.component.js +2 -2
- package/esm2015/lib/components/table/table.module.js +4 -4
- package/esm2015/lib/directives/file-upload/file-upload-multiple-selector.directive.js +3 -1
- package/esm2015/lib/directives/file-upload/file-upload-selector.directive.js +3 -1
- package/esm2015/lib/directives/file-upload/file-upload.directive.js +1 -1
- package/esm2015/lib/model/en.js +63 -2
- package/esm2015/lib/model/no.js +63 -2
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/halo.function.js +87 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/inspector.function.js +3767 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/selection.function.js +56 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/stencil.function.js +1003 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/config/toolbar.function.js +302 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/models/app-shapes.js +320 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/service/keyboard-service.js +69 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/service/kitchensink-service.js +412 -0
- package/esm2015/lib/qms-ckeditor-components/common/flowchart/themes/theme-picker.js +80 -0
- package/esm2015/lib/qms-ckeditor-components/common/models/qms-ckeditor-save-as-template.model.js +1 -1
- package/esm2015/lib/qms-ckeditor-components/common/module/confirm/qms-ckeditor-confirm.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-bpmn/qms-ckeditor-bpmn.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-bpmn/save-template/save-template.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.js +317 -0
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-imagemap/qms-ckeditor-imagemap.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-link/attachments/link-attachment.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-link/qms-ckeditor-link.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-load-template/qms-ckeditor-load-template.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-relation/qmsckeditor-related.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-template/qms-ckeditor-template.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/components/qms-ckeditor-tooltip/qms-ckeditor-tooltip.component.js +2 -2
- package/esm2015/lib/qms-ckeditor-components/qms-ckeditor.component.js +31 -1
- package/esm2015/lib/qms-ckeditor-components/qms-ckeditor.module.js +4 -2
- package/esm2015/public-api.js +7 -1
- package/esm2015/qms-angular.js +2 -1
- package/fesm2015/qms-angular.js +6744 -194
- package/fesm2015/qms-angular.js.map +1 -1
- package/lib/components/comment/comment.d.ts +1 -0
- package/lib/model/en.d.ts +61 -0
- package/lib/model/no.d.ts +61 -0
- package/lib/qms-ckeditor-components/common/flowchart/config/halo.function.d.ts +37 -0
- package/lib/qms-ckeditor-components/common/flowchart/config/inspector.function.d.ts +7 -0
- package/lib/qms-ckeditor-components/common/flowchart/config/selection.function.d.ts +39 -0
- package/lib/qms-ckeditor-components/common/flowchart/config/stencil.function.d.ts +11 -0
- package/lib/qms-ckeditor-components/common/flowchart/config/toolbar.function.d.ts +224 -0
- package/lib/qms-ckeditor-components/common/flowchart/models/app-shapes.d.ts +58 -0
- package/lib/qms-ckeditor-components/common/flowchart/service/keyboard-service.d.ts +16 -0
- package/lib/qms-ckeditor-components/common/flowchart/service/kitchensink-service.d.ts +56 -0
- package/lib/qms-ckeditor-components/common/flowchart/themes/theme-picker.d.ts +35 -0
- package/lib/qms-ckeditor-components/common/models/qms-ckeditor-save-as-template.model.d.ts +2 -0
- package/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.d.ts +41 -0
- package/lib/qms-ckeditor-components/qms-ckeditor.component.d.ts +4 -0
- package/lib.theme.scss +4 -0
- package/package.json +1 -1
- package/public-api.d.ts +6 -0
- package/qms-angular.d.ts +1 -0
- package/qms-angular.metadata.json +1 -1
- package/src/assets/fonts/OpenSans/OpenSans.woff2 +0 -0
- package/src/assets/jointjs/images/delete-icon-modern.png +0 -0
- package/src/assets/jointjs/images/reset-icon-modern.png +0 -0
- package/src/assets/jointjs/images/save-icon-modern.png +0 -0
- package/src/assets/jointjs/images/to-front-icon-modern.png +0 -0
- package/src/assets/jointjs/images/toback-icon-modern.png +0 -0
- package/src/assets/jointjs/images/toolbar-icons-material.png +0 -0
- package/src/assets/jointjs/images/toolbar-icons-modern.png +0 -0
- package/src/assets/jointjs/scss/rappid.scss +326 -0
- package/src/assets/jointjs/scss/theme-picker.scss +22 -0
- package/src/assets/qms-ckeditor-plugin/build/ckeditor.js +1 -1
- package/src/assets/qms-ckeditor-plugin/build/ckeditor.js.map +1 -1
- package/src/assets/qms-ckeditor-plugin/package-lock.json +12634 -345
- package/src/assets/qms-ckeditor-plugin/src/ckeditor.js +2 -2
- package/src/assets/qms-ckeditor-plugin/src/plugins/common/qmsCKEditorService.js +9 -0
- package/src/assets/qms-ckeditor-plugin/src/plugins/flowchart/flowchartdialogcommand.js +47 -0
- package/src/assets/qms-ckeditor-plugin/src/plugins/flowchart/qmsCKEditorFlowchartPlugin.js +30 -0
- package/src/assets/qms-ckeditor-plugin/src/themes/icons/flowchart.svg +507 -0
- package/src/lib/components/comment/comment.scss +1 -0
- package/src/lib/components/qms-navigation-drawer/qms-navigation-drawer.component.scss +1 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon1.svg +1 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon2.svg +6 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon3.svg +11 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/image-icon4.svg +8 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/member-female.png +0 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/member-male.png +0 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/no-color-icon.svg +72 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/toolbar-icons-material.png +0 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/toolbar-icons-modern.png +0 -0
- package/src/lib/qms-ckeditor-components/common/flowchart/assets/transparent-icon.svg +50 -0
- package/src/lib/qms-ckeditor-components/components/qms-ckeditor-flowchart/qms-ckeditor-flowchart.component.scss +68 -0
@@ -0,0 +1,320 @@
|
|
1
|
+
/*! Rappid v3.3.0 - HTML5 Diagramming Framework
|
2
|
+
|
3
|
+
Copyright (c) 2021 client IO
|
4
|
+
|
5
|
+
2021-02-12
|
6
|
+
|
7
|
+
|
8
|
+
This Source Code Form is subject to the terms of the Rappid License
|
9
|
+
, v. 2.0. If a copy of the Rappid License was not distributed with this
|
10
|
+
file, You can obtain one at http://jointjs.com/license/rappid_v2.txt
|
11
|
+
or from the Rappid archive as was distributed by client IO. See the LICENSE file.*/
|
12
|
+
import { memoize } from 'lodash';
|
13
|
+
export var app;
|
14
|
+
(function (app) {
|
15
|
+
class CircularModel extends joint.shapes.standard.Ellipse {
|
16
|
+
constructor() {
|
17
|
+
super(...arguments);
|
18
|
+
this.portLabelMarkup = [{
|
19
|
+
tagName: 'text',
|
20
|
+
selector: 'portLabel'
|
21
|
+
}];
|
22
|
+
}
|
23
|
+
defaults() {
|
24
|
+
return joint.util.defaultsDeep({
|
25
|
+
type: 'app.CircularModel',
|
26
|
+
attrs: {
|
27
|
+
root: {
|
28
|
+
magnet: false
|
29
|
+
}
|
30
|
+
},
|
31
|
+
ports: {
|
32
|
+
groups: {
|
33
|
+
'in': {
|
34
|
+
markup: [{
|
35
|
+
tagName: 'circle',
|
36
|
+
selector: 'portBody',
|
37
|
+
attributes: {
|
38
|
+
'r': 10
|
39
|
+
}
|
40
|
+
}],
|
41
|
+
attrs: {
|
42
|
+
portBody: {
|
43
|
+
magnet: true,
|
44
|
+
fill: '#61549c',
|
45
|
+
strokeWidth: 0
|
46
|
+
},
|
47
|
+
portLabel: {
|
48
|
+
fontSize: 11,
|
49
|
+
fill: '#61549c',
|
50
|
+
fontWeight: 800
|
51
|
+
}
|
52
|
+
},
|
53
|
+
position: {
|
54
|
+
name: 'ellipse',
|
55
|
+
args: {
|
56
|
+
startAngle: 0,
|
57
|
+
step: 30
|
58
|
+
}
|
59
|
+
},
|
60
|
+
label: {
|
61
|
+
position: {
|
62
|
+
name: 'radial',
|
63
|
+
args: null
|
64
|
+
}
|
65
|
+
}
|
66
|
+
},
|
67
|
+
'out': {
|
68
|
+
markup: [{
|
69
|
+
tagName: 'circle',
|
70
|
+
selector: 'portBody',
|
71
|
+
attributes: {
|
72
|
+
'r': 10
|
73
|
+
}
|
74
|
+
}],
|
75
|
+
attrs: {
|
76
|
+
portBody: {
|
77
|
+
magnet: true,
|
78
|
+
fill: '#61549c',
|
79
|
+
strokeWidth: 0
|
80
|
+
},
|
81
|
+
portLabel: {
|
82
|
+
fontSize: 11,
|
83
|
+
fill: '#61549c',
|
84
|
+
fontWeight: 800
|
85
|
+
}
|
86
|
+
},
|
87
|
+
position: {
|
88
|
+
name: 'ellipse',
|
89
|
+
args: {
|
90
|
+
startAngle: 180,
|
91
|
+
step: 30
|
92
|
+
}
|
93
|
+
},
|
94
|
+
label: {
|
95
|
+
position: {
|
96
|
+
name: 'radial',
|
97
|
+
args: null
|
98
|
+
}
|
99
|
+
}
|
100
|
+
}
|
101
|
+
}
|
102
|
+
}
|
103
|
+
}, joint.shapes.standard.Ellipse.prototype.defaults);
|
104
|
+
}
|
105
|
+
}
|
106
|
+
app.CircularModel = CircularModel;
|
107
|
+
class RectangularModel extends joint.shapes.standard.Rectangle {
|
108
|
+
constructor() {
|
109
|
+
super(...arguments);
|
110
|
+
this.portLabelMarkup = [{
|
111
|
+
tagName: 'text',
|
112
|
+
selector: 'portLabel'
|
113
|
+
}];
|
114
|
+
}
|
115
|
+
defaults() {
|
116
|
+
return joint.util.defaultsDeep({
|
117
|
+
type: 'app.RectangularModel',
|
118
|
+
attrs: {
|
119
|
+
root: {
|
120
|
+
magnet: false
|
121
|
+
}
|
122
|
+
},
|
123
|
+
ports: {
|
124
|
+
groups: {
|
125
|
+
'in': {
|
126
|
+
markup: [{
|
127
|
+
tagName: 'circle',
|
128
|
+
selector: 'portBody',
|
129
|
+
attributes: {
|
130
|
+
'r': 10
|
131
|
+
}
|
132
|
+
}],
|
133
|
+
attrs: {
|
134
|
+
portBody: {
|
135
|
+
magnet: true,
|
136
|
+
fill: '#61549c',
|
137
|
+
strokeWidth: 0
|
138
|
+
},
|
139
|
+
portLabel: {
|
140
|
+
fontSize: 11,
|
141
|
+
fill: '#61549c',
|
142
|
+
fontWeight: 800
|
143
|
+
}
|
144
|
+
},
|
145
|
+
position: {
|
146
|
+
name: 'left'
|
147
|
+
},
|
148
|
+
label: {
|
149
|
+
position: {
|
150
|
+
name: 'left',
|
151
|
+
args: {
|
152
|
+
y: 0
|
153
|
+
}
|
154
|
+
}
|
155
|
+
}
|
156
|
+
},
|
157
|
+
'out': {
|
158
|
+
markup: [{
|
159
|
+
tagName: 'circle',
|
160
|
+
selector: 'portBody',
|
161
|
+
attributes: {
|
162
|
+
'r': 10
|
163
|
+
}
|
164
|
+
}],
|
165
|
+
position: {
|
166
|
+
name: 'right'
|
167
|
+
},
|
168
|
+
attrs: {
|
169
|
+
portBody: {
|
170
|
+
magnet: true,
|
171
|
+
fill: '#61549c',
|
172
|
+
strokeWidth: 0
|
173
|
+
},
|
174
|
+
portLabel: {
|
175
|
+
fontSize: 11,
|
176
|
+
fill: '#61549c',
|
177
|
+
fontWeight: 800
|
178
|
+
}
|
179
|
+
},
|
180
|
+
label: {
|
181
|
+
position: {
|
182
|
+
name: 'right',
|
183
|
+
args: {
|
184
|
+
y: 0
|
185
|
+
}
|
186
|
+
}
|
187
|
+
}
|
188
|
+
}
|
189
|
+
}
|
190
|
+
}
|
191
|
+
}, joint.shapes.standard.Rectangle.prototype.defaults);
|
192
|
+
}
|
193
|
+
}
|
194
|
+
app.RectangularModel = RectangularModel;
|
195
|
+
class Link extends joint.shapes.standard.Link {
|
196
|
+
constructor() {
|
197
|
+
super(...arguments);
|
198
|
+
this.defaultLabel = {
|
199
|
+
attrs: {
|
200
|
+
rect: {
|
201
|
+
fill: '#ffffff',
|
202
|
+
stroke: '#8f8f8f',
|
203
|
+
strokeWidth: 1,
|
204
|
+
refWidth: 10,
|
205
|
+
refHeight: 10,
|
206
|
+
refX: -5,
|
207
|
+
refY: -5
|
208
|
+
}
|
209
|
+
}
|
210
|
+
};
|
211
|
+
this.getDataWidthCached = memoize((d) => (new joint.g.Path(d)).bbox().width);
|
212
|
+
}
|
213
|
+
static connectionPoint(line, view, magnet, opt, type, linkView) {
|
214
|
+
const markerWidth = linkView.model.getMarkerWidth(type);
|
215
|
+
opt = { offset: markerWidth, stroke: true };
|
216
|
+
// connection point for UML shapes lies on the root group containg all the shapes components
|
217
|
+
const modelType = view.model.get('type');
|
218
|
+
if (modelType.indexOf('uml') === 0) {
|
219
|
+
opt.selector = 'root';
|
220
|
+
}
|
221
|
+
// taking the border stroke-width into account
|
222
|
+
if (modelType === 'standard.InscribedImage') {
|
223
|
+
opt.selector = 'border';
|
224
|
+
}
|
225
|
+
return joint.connectionPoints.boundary.call(this, line, view, magnet, opt, type, linkView);
|
226
|
+
}
|
227
|
+
defaults() {
|
228
|
+
return joint.util.defaultsDeep({
|
229
|
+
type: 'app.Link',
|
230
|
+
router: {
|
231
|
+
name: 'normal'
|
232
|
+
},
|
233
|
+
connector: {
|
234
|
+
name: 'rounded'
|
235
|
+
},
|
236
|
+
labels: [],
|
237
|
+
attrs: {
|
238
|
+
line: {
|
239
|
+
stroke: '#8f8f8f',
|
240
|
+
strokeDasharray: '0',
|
241
|
+
strokeWidth: 2,
|
242
|
+
fill: 'none',
|
243
|
+
sourceMarker: {
|
244
|
+
type: 'path',
|
245
|
+
d: 'M 0 0 0 0',
|
246
|
+
stroke: 'none'
|
247
|
+
},
|
248
|
+
targetMarker: {
|
249
|
+
type: 'path',
|
250
|
+
d: 'M 0 -5 -10 0 0 5 z',
|
251
|
+
stroke: 'none'
|
252
|
+
}
|
253
|
+
}
|
254
|
+
}
|
255
|
+
}, joint.shapes.standard.Link.prototype.defaults);
|
256
|
+
}
|
257
|
+
getMarkerWidth(type) {
|
258
|
+
const d = (type === 'source') ? this.attr('line/sourceMarker/d') : this.attr('line/targetMarker/d');
|
259
|
+
return this.getDataWidth(d);
|
260
|
+
}
|
261
|
+
getDataWidth(d) {
|
262
|
+
return this.getDataWidthCached(d);
|
263
|
+
}
|
264
|
+
}
|
265
|
+
app.Link = Link;
|
266
|
+
})(app || (app = {}));
|
267
|
+
const ɵ0 = function (flags) {
|
268
|
+
if (this.hasFlag(flags, 'RENDER')) {
|
269
|
+
this.render();
|
270
|
+
}
|
271
|
+
if (this.hasFlag(flags, 'UPDATE')) {
|
272
|
+
this.update();
|
273
|
+
}
|
274
|
+
if (this.hasFlag(flags, 'TRANSFORM')) {
|
275
|
+
this.updateTransformation();
|
276
|
+
}
|
277
|
+
}, ɵ1 = function () {
|
278
|
+
const { fragment, selectors: { body } } = joint.util.parseDOMJSON(this.markup);
|
279
|
+
this.body = body;
|
280
|
+
this.el.appendChild(fragment);
|
281
|
+
}, ɵ2 = function () {
|
282
|
+
const { model, body } = this;
|
283
|
+
const { width, height } = model.size();
|
284
|
+
body.setAttribute('width', width);
|
285
|
+
body.setAttribute('height', height);
|
286
|
+
};
|
287
|
+
export const NavigatorElementView = joint.dia.ElementView.extend({
|
288
|
+
body: null,
|
289
|
+
markup: [{
|
290
|
+
tagName: 'rect',
|
291
|
+
selector: 'body',
|
292
|
+
attributes: {
|
293
|
+
'fill': '#31d0c6'
|
294
|
+
}
|
295
|
+
}],
|
296
|
+
initFlag: ['RENDER', 'UPDATE', 'TRANSFORM'],
|
297
|
+
presentationAttributes: {
|
298
|
+
size: ['UPDATE'],
|
299
|
+
position: ['TRANSFORM'],
|
300
|
+
angle: ['TRANSFORM']
|
301
|
+
},
|
302
|
+
confirmUpdate: ɵ0,
|
303
|
+
render: ɵ1,
|
304
|
+
update: ɵ2
|
305
|
+
});
|
306
|
+
export const NavigatorLinkView = joint.dia.LinkView.extend({
|
307
|
+
initialize: joint.util.noop,
|
308
|
+
render: joint.util.noop,
|
309
|
+
update: joint.util.noop
|
310
|
+
});
|
311
|
+
// re-export build-in shapes from rappid
|
312
|
+
export const basic = joint.shapes.basic;
|
313
|
+
export const standard = joint.shapes.standard;
|
314
|
+
export const fsa = joint.shapes.fsa;
|
315
|
+
export const pn = joint.shapes.pn;
|
316
|
+
export const erd = joint.shapes.erd;
|
317
|
+
export const uml = joint.shapes.uml;
|
318
|
+
export const org = joint.shapes.org;
|
319
|
+
export { ɵ0, ɵ1, ɵ2 };
|
320
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-shapes.js","sourceRoot":"","sources":["../../../../../../../../projects/qms-angular/src/lib/qms-ckeditor-components/common/flowchart/models/app-shapes.ts"],"names":[],"mappings":"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","sourcesContent":["/*! Rappid v3.3.0 - HTML5 Diagramming Framework\r\n\r\nCopyright (c) 2021 client IO\r\n\r\n 2021-02-12 \r\n\r\n\r\nThis Source Code Form is subject to the terms of the Rappid License\r\n, v. 2.0. If a copy of the Rappid License was not distributed with this\r\nfile, You can obtain one at http://jointjs.com/license/rappid_v2.txt\r\n or from the Rappid archive as was distributed by client IO. See the LICENSE file.*/\r\n\r\n\r\nimport { memoize } from 'lodash';\r\ndeclare var joint: any\r\nexport namespace app {\r\n\r\n    export class CircularModel extends joint.shapes.standard.Ellipse {\r\n\r\n        portLabelMarkup = [{\r\n            tagName: 'text',\r\n            selector: 'portLabel'\r\n        }];\r\n\r\n        defaults() {\r\n\r\n            return joint.util.defaultsDeep({\r\n                type: 'app.CircularModel',\r\n                attrs: {\r\n                    root: {\r\n                        magnet: false\r\n                    }\r\n                },\r\n                ports: {\r\n                    groups: {\r\n                        'in': {\r\n                            markup: [{\r\n                                tagName: 'circle',\r\n                                selector: 'portBody',\r\n                                attributes: {\r\n                                    'r': 10\r\n                                }\r\n                            }],\r\n                            attrs: {\r\n                                portBody: {\r\n                                    magnet: true,\r\n                                    fill: '#61549c',\r\n                                    strokeWidth: 0\r\n                                },\r\n                                portLabel: {\r\n                                    fontSize: 11,\r\n                                    fill: '#61549c',\r\n                                    fontWeight: 800\r\n                                }\r\n                            },\r\n                            position: {\r\n                                name: 'ellipse',\r\n                                args: {\r\n                                    startAngle: 0,\r\n                                    step: 30\r\n                                }\r\n                            },\r\n                            label: {\r\n                                position: {\r\n                                    name: 'radial',\r\n                                    args: null\r\n                                }\r\n                            }\r\n                        },\r\n                        'out': {\r\n                            markup: [{\r\n                                tagName: 'circle',\r\n                                selector: 'portBody',\r\n                                attributes: {\r\n                                    'r': 10\r\n                                }\r\n                            }],\r\n                            attrs: {\r\n                                portBody: {\r\n                                    magnet: true,\r\n                                    fill: '#61549c',\r\n                                    strokeWidth: 0\r\n                                },\r\n                                portLabel: {\r\n                                    fontSize: 11,\r\n                                    fill: '#61549c',\r\n                                    fontWeight: 800\r\n                                }\r\n                            },\r\n                            position: {\r\n                                name: 'ellipse',\r\n                                args: {\r\n                                    startAngle: 180,\r\n                                    step: 30\r\n                                }\r\n                            },\r\n                            label: {\r\n                                position: {\r\n                                    name: 'radial',\r\n                                    args: null\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }, joint.shapes.standard.Ellipse.prototype.defaults);\r\n        }\r\n    }\r\n\r\n    export class RectangularModel extends joint.shapes.standard.Rectangle {\r\n\r\n        portLabelMarkup = [{\r\n            tagName: 'text',\r\n            selector: 'portLabel'\r\n        }];\r\n\r\n        defaults() {\r\n\r\n            return joint.util.defaultsDeep({\r\n                type: 'app.RectangularModel',\r\n                attrs: {\r\n                    root: {\r\n                        magnet: false\r\n                    }\r\n                },\r\n                ports: {\r\n                    groups: {\r\n                        'in': {\r\n                            markup: [{\r\n                                tagName: 'circle',\r\n                                selector: 'portBody',\r\n                                attributes: {\r\n                                    'r': 10\r\n                                }\r\n                            }],\r\n                            attrs: {\r\n                                portBody: {\r\n                                    magnet: true,\r\n                                    fill: '#61549c',\r\n                                    strokeWidth: 0\r\n                                },\r\n                                portLabel: {\r\n                                    fontSize: 11,\r\n                                    fill: '#61549c',\r\n                                    fontWeight: 800\r\n                                }\r\n                            },\r\n                            position: {\r\n                                name: 'left'\r\n                            },\r\n                            label: {\r\n                                position: {\r\n                                    name: 'left',\r\n                                    args: {\r\n                                        y: 0\r\n                                    }\r\n                                }\r\n                            }\r\n                        },\r\n                        'out': {\r\n                            markup: [{\r\n                                tagName: 'circle',\r\n                                selector: 'portBody',\r\n                                attributes: {\r\n                                    'r': 10\r\n                                }\r\n                            }],\r\n                            position: {\r\n                                name: 'right'\r\n                            },\r\n                            attrs: {\r\n                                portBody: {\r\n                                    magnet: true,\r\n                                    fill: '#61549c',\r\n                                    strokeWidth: 0\r\n                                },\r\n                                portLabel: {\r\n                                    fontSize: 11,\r\n                                    fill: '#61549c',\r\n                                    fontWeight: 800\r\n                                }\r\n                            },\r\n                            label: {\r\n                                position: {\r\n                                    name: 'right',\r\n                                    args: {\r\n                                        y: 0\r\n                                    }\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }, joint.shapes.standard.Rectangle.prototype.defaults);\r\n        }\r\n    }\r\n\r\n    export class Link extends joint.shapes.standard.Link {\r\n\r\n        defaultLabel = {\r\n            attrs: {\r\n                rect: {\r\n                    fill: '#ffffff',\r\n                    stroke: '#8f8f8f',\r\n                    strokeWidth: 1,\r\n                    refWidth: 10,\r\n                    refHeight: 10,\r\n                    refX: -5,\r\n                    refY: -5\r\n                }\r\n            }\r\n        };\r\n\r\n        private getDataWidthCached = memoize((d: string) => (new joint.g.Path(d)).bbox().width);\r\n\r\n        static connectionPoint(line: any, view: any, magnet: any, opt: any, type: any, linkView: any): any {\r\n            const markerWidth = linkView.model.getMarkerWidth(type);\r\n            opt = { offset: markerWidth, stroke: true };\r\n            // connection point for UML shapes lies on the root group containg all the shapes components\r\n            const modelType = view.model.get('type');\r\n            if (modelType.indexOf('uml') === 0) { opt.selector = 'root'; }\r\n            // taking the border stroke-width into account\r\n            if (modelType === 'standard.InscribedImage') { opt.selector = 'border'; }\r\n            return joint.connectionPoints.boundary.call(this, line, view, magnet, opt, type, linkView);\r\n        }\r\n\r\n        defaults() {\r\n            return joint.util.defaultsDeep({\r\n                type: 'app.Link',\r\n                router: {\r\n                    name: 'normal'\r\n                },\r\n                connector: {\r\n                    name: 'rounded'\r\n                },\r\n                labels: [],\r\n                attrs: {\r\n                    line: {\r\n                        stroke: '#8f8f8f',\r\n                        strokeDasharray: '0',\r\n                        strokeWidth: 2,\r\n                        fill: 'none',\r\n                        sourceMarker: {\r\n                            type: 'path',\r\n                            d: 'M 0 0 0 0',\r\n                            stroke: 'none'\r\n                        },\r\n                        targetMarker: {\r\n                            type: 'path',\r\n                            d: 'M 0 -5 -10 0 0 5 z',\r\n                            stroke: 'none'\r\n                        }\r\n                    }\r\n                }\r\n            }, joint.shapes.standard.Link.prototype.defaults);\r\n        }\r\n\r\n        getMarkerWidth(type: any) {\r\n            const d = (type === 'source') ? this.attr('line/sourceMarker/d') : this.attr('line/targetMarker/d');\r\n            return this.getDataWidth(d);\r\n        }\r\n\r\n        getDataWidth(d: any) {\r\n            return this.getDataWidthCached(d);\r\n        }\r\n    }\r\n}\r\n\r\nexport const NavigatorElementView = joint.dia.ElementView.extend({\r\n\r\n    body: null,\r\n\r\n    markup: [{\r\n        tagName: 'rect',\r\n        selector: 'body',\r\n        attributes: {\r\n            'fill': '#31d0c6'\r\n        }\r\n    }],\r\n\r\n    initFlag: ['RENDER', 'UPDATE', 'TRANSFORM'],\r\n\r\n    presentationAttributes: {\r\n        size: ['UPDATE'],\r\n        position: ['TRANSFORM'],\r\n        angle: ['TRANSFORM']\r\n    },\r\n\r\n    confirmUpdate: function (flags: number) {\r\n\r\n        if (this.hasFlag(flags, 'RENDER')) { this.render(); }\r\n        if (this.hasFlag(flags, 'UPDATE')) { this.update(); }\r\n        if (this.hasFlag(flags, 'TRANSFORM')) { this.updateTransformation(); }\r\n    },\r\n\r\n    render: function () {\r\n        const { fragment, selectors: { body } } = joint.util.parseDOMJSON(this.markup);\r\n        this.body = body;\r\n        this.el.appendChild(fragment);\r\n    },\r\n\r\n    update: function () {\r\n        const { model, body } = this;\r\n        const { width, height } = model.size();\r\n        body.setAttribute('width', width);\r\n        body.setAttribute('height', height);\r\n    }\r\n});\r\n\r\n\r\nexport const NavigatorLinkView = joint.dia.LinkView.extend({\r\n\r\n    initialize: joint.util.noop,\r\n\r\n    render: joint.util.noop,\r\n\r\n    update: joint.util.noop\r\n});\r\n\r\n// re-export build-in shapes from rappid\r\nexport const basic = joint.shapes.basic;\r\nexport const standard = joint.shapes.standard;\r\nexport const fsa = joint.shapes.fsa;\r\nexport const pn = joint.shapes.pn;\r\nexport const erd = joint.shapes.erd;\r\nexport const uml = joint.shapes.uml;\r\nexport const org = joint.shapes.org;\r\n\r\n"]}
|
@@ -0,0 +1,69 @@
|
|
1
|
+
/*! Rappid v3.3.0 - HTML5 Diagramming Framework
|
2
|
+
|
3
|
+
Copyright (c) 2021 client IO
|
4
|
+
|
5
|
+
2021-02-12
|
6
|
+
|
7
|
+
|
8
|
+
This Source Code Form is subject to the terms of the Rappid License
|
9
|
+
, v. 2.0. If a copy of the Rappid License was not distributed with this
|
10
|
+
file, You can obtain one at http://jointjs.com/license/rappid_v2.txt
|
11
|
+
or from the Rappid archive as was distributed by client IO. See the LICENSE file.*/
|
12
|
+
// import * as joint from '@clientio/rappid';
|
13
|
+
import * as _ from 'lodash';
|
14
|
+
export class KeyboardService {
|
15
|
+
constructor() {
|
16
|
+
this.keyboard = new joint.ui.Keyboard();
|
17
|
+
}
|
18
|
+
create(graph, clipboard, selection, paperScroller, commandManager) {
|
19
|
+
this.keyboard.on({
|
20
|
+
'ctrl+c': () => {
|
21
|
+
// Copy all selected elements and their associated links.
|
22
|
+
clipboard.copyElements(selection.collection, graph);
|
23
|
+
},
|
24
|
+
'ctrl+v': () => {
|
25
|
+
const pastedCells = clipboard.pasteCells(graph, {
|
26
|
+
translate: { dx: 20, dy: 20 },
|
27
|
+
useLocalStorage: true
|
28
|
+
});
|
29
|
+
const elements = _.filter(pastedCells, cell => cell.isElement());
|
30
|
+
// Make sure pasted elements get selected immediately. This makes the UX better as
|
31
|
+
// the user can immediately manipulate the pasted elements.
|
32
|
+
selection.collection.reset(elements);
|
33
|
+
},
|
34
|
+
'ctrl+x shift+delete': () => {
|
35
|
+
clipboard.cutElements(selection.collection, graph);
|
36
|
+
},
|
37
|
+
'delete backspace': (evt) => {
|
38
|
+
evt.preventDefault();
|
39
|
+
graph.removeCells(selection.collection.toArray());
|
40
|
+
},
|
41
|
+
'ctrl+z': () => {
|
42
|
+
commandManager.undo();
|
43
|
+
selection.cancelSelection();
|
44
|
+
},
|
45
|
+
'ctrl+y': () => {
|
46
|
+
commandManager.redo();
|
47
|
+
selection.cancelSelection();
|
48
|
+
},
|
49
|
+
'ctrl+a': () => {
|
50
|
+
selection.collection.reset(graph.getElements());
|
51
|
+
},
|
52
|
+
'ctrl+plus': (evt) => {
|
53
|
+
evt.preventDefault();
|
54
|
+
paperScroller.zoom(0.2, { max: 5, grid: 0.2 });
|
55
|
+
},
|
56
|
+
'ctrl+minus': (evt) => {
|
57
|
+
evt.preventDefault();
|
58
|
+
paperScroller.zoom(-0.2, { min: 0.2, grid: 0.2 });
|
59
|
+
},
|
60
|
+
'keydown:shift': (evt) => {
|
61
|
+
paperScroller.setCursor('crosshair');
|
62
|
+
},
|
63
|
+
'keyup:shift': () => {
|
64
|
+
paperScroller.setCursor('grab');
|
65
|
+
}
|
66
|
+
});
|
67
|
+
}
|
68
|
+
}
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Ym9hcmQtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Ftcy1hbmd1bGFyL3NyYy9saWIvcW1zLWNrZWRpdG9yLWNvbXBvbmVudHMvY29tbW9uL2Zsb3djaGFydC9zZXJ2aWNlL2tleWJvYXJkLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7b0ZBVW9GO0FBR3BGLDZDQUE2QztBQUM3QyxPQUFPLEtBQUssQ0FBQyxNQUFNLFFBQVEsQ0FBQztBQUU1QixNQUFNLE9BQU8sZUFBZTtJQUl4QjtRQUNJLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzVDLENBQUM7SUFFRCxNQUFNLENBQ0YsS0FBVSxFQUNWLFNBQWMsRUFDZCxTQUFjLEVBQ2QsYUFBa0IsRUFDbEIsY0FBbUI7UUFHbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFFYixRQUFRLEVBQUUsR0FBRyxFQUFFO2dCQUVYLHlEQUF5RDtnQkFDekQsU0FBUyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3hELENBQUM7WUFFRCxRQUFRLEVBQUUsR0FBRyxFQUFFO2dCQUVYLE1BQU0sV0FBVyxHQUFHLFNBQVMsQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFO29CQUM1QyxTQUFTLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUU7b0JBQzdCLGVBQWUsRUFBRSxJQUFJO2lCQUN4QixDQUFDLENBQUM7Z0JBRUgsTUFBTSxRQUFRLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztnQkFFakUsa0ZBQWtGO2dCQUNsRiwyREFBMkQ7Z0JBQzNELFNBQVMsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3pDLENBQUM7WUFFRCxxQkFBcUIsRUFBRSxHQUFHLEVBQUU7Z0JBQ3hCLFNBQVMsQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUN2RCxDQUFDO1lBRUQsa0JBQWtCLEVBQUUsQ0FBQyxHQUFpQixFQUFFLEVBQUU7Z0JBQ3RDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDckIsS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7WUFDdEQsQ0FBQztZQUVELFFBQVEsRUFBRSxHQUFHLEVBQUU7Z0JBQ1gsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUN0QixTQUFTLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDaEMsQ0FBQztZQUVELFFBQVEsRUFBRSxHQUFHLEVBQUU7Z0JBQ1gsY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO2dCQUN0QixTQUFTLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDaEMsQ0FBQztZQUVELFFBQVEsRUFBRSxHQUFHLEVBQUU7Z0JBQ1gsU0FBUyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7WUFDcEQsQ0FBQztZQUVELFdBQVcsRUFBRSxDQUFDLEdBQWlCLEVBQUUsRUFBRTtnQkFDL0IsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO2dCQUNyQixhQUFhLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFDbkQsQ0FBQztZQUVELFlBQVksRUFBRSxDQUFDLEdBQWlCLEVBQUUsRUFBRTtnQkFDaEMsR0FBRyxDQUFDLGNBQWMsRUFBRSxDQUFDO2dCQUNyQixhQUFhLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztZQUN0RCxDQUFDO1lBRUQsZUFBZSxFQUFFLENBQUMsR0FBaUIsRUFBRSxFQUFFO2dCQUNuQyxhQUFhLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQ3pDLENBQUM7WUFFRCxhQUFhLEVBQUUsR0FBRyxFQUFFO2dCQUNoQixhQUFhLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3BDLENBQUM7U0FDSixDQUFDLENBQUM7SUFDUCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyIvKiEgUmFwcGlkIHYzLjMuMCAtIEhUTUw1IERpYWdyYW1taW5nIEZyYW1ld29ya1xyXG5cclxuQ29weXJpZ2h0IChjKSAyMDIxIGNsaWVudCBJT1xyXG5cclxuIDIwMjEtMDItMTIgXHJcblxyXG5cclxuVGhpcyBTb3VyY2UgQ29kZSBGb3JtIGlzIHN1YmplY3QgdG8gdGhlIHRlcm1zIG9mIHRoZSBSYXBwaWQgTGljZW5zZVxyXG4sIHYuIDIuMC4gSWYgYSBjb3B5IG9mIHRoZSBSYXBwaWQgTGljZW5zZSB3YXMgbm90IGRpc3RyaWJ1dGVkIHdpdGggdGhpc1xyXG5maWxlLCBZb3UgY2FuIG9idGFpbiBvbmUgYXQgaHR0cDovL2pvaW50anMuY29tL2xpY2Vuc2UvcmFwcGlkX3YyLnR4dFxyXG4gb3IgZnJvbSB0aGUgUmFwcGlkIGFyY2hpdmUgYXMgd2FzIGRpc3RyaWJ1dGVkIGJ5IGNsaWVudCBJTy4gU2VlIHRoZSBMSUNFTlNFIGZpbGUuKi9cclxuXHJcblxyXG4vLyBpbXBvcnQgKiBhcyBqb2ludCBmcm9tICdAY2xpZW50aW8vcmFwcGlkJztcclxuaW1wb3J0ICogYXMgXyBmcm9tICdsb2Rhc2gnO1xyXG5kZWNsYXJlIHZhciBqb2ludDogYW55O1xyXG5leHBvcnQgY2xhc3MgS2V5Ym9hcmRTZXJ2aWNlIHtcclxuXHJcbiAgICBrZXlib2FyZDogYW55O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKCkge1xyXG4gICAgICAgIHRoaXMua2V5Ym9hcmQgPSBuZXcgam9pbnQudWkuS2V5Ym9hcmQoKTtcclxuICAgIH1cclxuXHJcbiAgICBjcmVhdGUoXHJcbiAgICAgICAgZ3JhcGg6IGFueSxcclxuICAgICAgICBjbGlwYm9hcmQ6IGFueSxcclxuICAgICAgICBzZWxlY3Rpb246IGFueSxcclxuICAgICAgICBwYXBlclNjcm9sbGVyOiBhbnksXHJcbiAgICAgICAgY29tbWFuZE1hbmFnZXI6IGFueVxyXG4gICAgKSB7XHJcblxyXG4gICAgICAgIHRoaXMua2V5Ym9hcmQub24oe1xyXG5cclxuICAgICAgICAgICAgJ2N0cmwrYyc6ICgpID0+IHtcclxuXHJcbiAgICAgICAgICAgICAgICAvLyBDb3B5IGFsbCBzZWxlY3RlZCBlbGVtZW50cyBhbmQgdGhlaXIgYXNzb2NpYXRlZCBsaW5rcy5cclxuICAgICAgICAgICAgICAgIGNsaXBib2FyZC5jb3B5RWxlbWVudHMoc2VsZWN0aW9uLmNvbGxlY3Rpb24sIGdyYXBoKTtcclxuICAgICAgICAgICAgfSxcclxuXHJcbiAgICAgICAgICAgICdjdHJsK3YnOiAoKSA9PiB7XHJcblxyXG4gICAgICAgICAgICAgICAgY29uc3QgcGFzdGVkQ2VsbHMgPSBjbGlwYm9hcmQucGFzdGVDZWxscyhncmFwaCwge1xyXG4gICAgICAgICAgICAgICAgICAgIHRyYW5zbGF0ZTogeyBkeDogMjAsIGR5OiAyMCB9LFxyXG4gICAgICAgICAgICAgICAgICAgIHVzZUxvY2FsU3RvcmFnZTogdHJ1ZVxyXG4gICAgICAgICAgICAgICAgfSk7XHJcblxyXG4gICAgICAgICAgICAgICAgY29uc3QgZWxlbWVudHMgPSBfLmZpbHRlcihwYXN0ZWRDZWxscywgY2VsbCA9PiBjZWxsLmlzRWxlbWVudCgpKTtcclxuXHJcbiAgICAgICAgICAgICAgICAvLyBNYWtlIHN1cmUgcGFzdGVkIGVsZW1lbnRzIGdldCBzZWxlY3RlZCBpbW1lZGlhdGVseS4gVGhpcyBtYWtlcyB0aGUgVVggYmV0dGVyIGFzXHJcbiAgICAgICAgICAgICAgICAvLyB0aGUgdXNlciBjYW4gaW1tZWRpYXRlbHkgbWFuaXB1bGF0ZSB0aGUgcGFzdGVkIGVsZW1lbnRzLlxyXG4gICAgICAgICAgICAgICAgc2VsZWN0aW9uLmNvbGxlY3Rpb24ucmVzZXQoZWxlbWVudHMpO1xyXG4gICAgICAgICAgICB9LFxyXG5cclxuICAgICAgICAgICAgJ2N0cmwreCBzaGlmdCtkZWxldGUnOiAoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBjbGlwYm9hcmQuY3V0RWxlbWVudHMoc2VsZWN0aW9uLmNvbGxlY3Rpb24sIGdyYXBoKTtcclxuICAgICAgICAgICAgfSxcclxuXHJcbiAgICAgICAgICAgICdkZWxldGUgYmFja3NwYWNlJzogKGV2dDogSlF1ZXJ5LkV2ZW50KSA9PiB7XHJcbiAgICAgICAgICAgICAgICBldnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgICAgIGdyYXBoLnJlbW92ZUNlbGxzKHNlbGVjdGlvbi5jb2xsZWN0aW9uLnRvQXJyYXkoKSk7XHJcbiAgICAgICAgICAgIH0sXHJcblxyXG4gICAgICAgICAgICAnY3RybCt6JzogKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29tbWFuZE1hbmFnZXIudW5kbygpO1xyXG4gICAgICAgICAgICAgICAgc2VsZWN0aW9uLmNhbmNlbFNlbGVjdGlvbigpO1xyXG4gICAgICAgICAgICB9LFxyXG5cclxuICAgICAgICAgICAgJ2N0cmwreSc6ICgpID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbW1hbmRNYW5hZ2VyLnJlZG8oKTtcclxuICAgICAgICAgICAgICAgIHNlbGVjdGlvbi5jYW5jZWxTZWxlY3Rpb24oKTtcclxuICAgICAgICAgICAgfSxcclxuXHJcbiAgICAgICAgICAgICdjdHJsK2EnOiAoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZWxlY3Rpb24uY29sbGVjdGlvbi5yZXNldChncmFwaC5nZXRFbGVtZW50cygpKTtcclxuICAgICAgICAgICAgfSxcclxuXHJcbiAgICAgICAgICAgICdjdHJsK3BsdXMnOiAoZXZ0OiBKUXVlcnkuRXZlbnQpID0+IHtcclxuICAgICAgICAgICAgICAgIGV2dC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICAgICAgICAgICAgcGFwZXJTY3JvbGxlci56b29tKDAuMiwgeyBtYXg6IDUsIGdyaWQ6IDAuMiB9KTtcclxuICAgICAgICAgICAgfSxcclxuXHJcbiAgICAgICAgICAgICdjdHJsK21pbnVzJzogKGV2dDogSlF1ZXJ5LkV2ZW50KSA9PiB7XHJcbiAgICAgICAgICAgICAgICBldnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgICAgIHBhcGVyU2Nyb2xsZXIuem9vbSgtMC4yLCB7IG1pbjogMC4yLCBncmlkOiAwLjIgfSk7XHJcbiAgICAgICAgICAgIH0sXHJcblxyXG4gICAgICAgICAgICAna2V5ZG93bjpzaGlmdCc6IChldnQ6IEpRdWVyeS5FdmVudCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgcGFwZXJTY3JvbGxlci5zZXRDdXJzb3IoJ2Nyb3NzaGFpcicpO1xyXG4gICAgICAgICAgICB9LFxyXG5cclxuICAgICAgICAgICAgJ2tleXVwOnNoaWZ0JzogKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgcGFwZXJTY3JvbGxlci5zZXRDdXJzb3IoJ2dyYWInKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|