ngx-edu-sharing-ui 10.0.8 → 10.0.9
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/assets/scss/branding.scss +3 -8
- package/assets/scss/material-theme.scss +36 -36
- package/assets/scss/variables-scss.scss +2 -1
- package/assets/scss/variables.scss +5 -0
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +20 -4
- package/esm2022/lib/directives/icon.directive.mjs +37 -16
- package/esm2022/lib/index.mjs +7 -1
- package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +154 -0
- package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +18 -0
- package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +47 -0
- package/esm2022/lib/mds-viewer/view-instance.service.mjs +27 -0
- package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +349 -0
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +2 -2
- package/esm2022/lib/pipes/mds-duration.pipe.mjs +25 -0
- package/esm2022/lib/services/node-helper.service.mjs +21 -18
- package/esm2022/lib/services/options-helper-data.service.mjs +2 -2
- package/esm2022/lib/services/ui.service.mjs +147 -3
- package/esm2022/lib/util/rest-helper.mjs +11 -4
- package/fesm2022/ngx-edu-sharing-ui.mjs +2968 -2202
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/common/edu-sharing-ui-common.module.d.ts +33 -30
- package/lib/directives/icon.directive.d.ts +4 -2
- package/lib/index.d.ts +6 -0
- package/lib/mds-viewer/mds-viewer.component.d.ts +52 -0
- package/lib/mds-viewer/mds-viewer.service.d.ts +12 -0
- package/lib/mds-viewer/replace-element-with-div.d.ts +8 -0
- package/lib/mds-viewer/view-instance.service.d.ts +20 -0
- package/lib/mds-viewer/widget/mds-widget.component.d.ts +111 -0
- package/lib/pipes/mds-duration.pipe.d.ts +7 -0
- package/lib/services/node-helper.service.d.ts +3 -0
- package/lib/services/ui.service.d.ts +32 -1
- package/lib/util/rest-helper.d.ts +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import { DatePipe } from '@angular/common';
|
|
2
|
+
import { Component, Input, ViewChild, } from '@angular/core';
|
|
3
|
+
import { MatRipple } from '@angular/material/core';
|
|
4
|
+
import { filter, first, map } from 'rxjs/operators';
|
|
5
|
+
import { RestConstants } from 'ngx-edu-sharing-api';
|
|
6
|
+
import { UIConstants } from '../../util/ui-constants';
|
|
7
|
+
import { DateHelper } from '../../util/DateHelper';
|
|
8
|
+
import { RestHelper } from '../../util/rest-helper';
|
|
9
|
+
import { FormatSizePipe } from '../../pipes/file-size.pipe';
|
|
10
|
+
import { of } from 'rxjs';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@ngx-translate/core";
|
|
13
|
+
import * as i2 from "../../services/ui.service";
|
|
14
|
+
import * as i3 from "../view-instance.service";
|
|
15
|
+
import * as i4 from "@angular/common";
|
|
16
|
+
import * as i5 from "@angular/material/core";
|
|
17
|
+
import * as i6 from "@angular/router";
|
|
18
|
+
import * as i7 from "../../directives/icon.directive";
|
|
19
|
+
import * as i8 from "../../pipes/mds-duration.pipe";
|
|
20
|
+
import * as i9 from "../../pipes/vcard-name.pipe";
|
|
21
|
+
export var MdsType;
|
|
22
|
+
(function (MdsType) {
|
|
23
|
+
MdsType["Io"] = "io";
|
|
24
|
+
MdsType["IoBulk"] = "io_bulk";
|
|
25
|
+
MdsType["Map"] = "map";
|
|
26
|
+
MdsType["MapRef"] = "map_ref";
|
|
27
|
+
MdsType["IoChildObject"] = "io_childobject";
|
|
28
|
+
MdsType["Collection"] = "collection";
|
|
29
|
+
MdsType["ToolDefinition"] = "tool_definition";
|
|
30
|
+
MdsType["ToolInstance"] = "tool_instance";
|
|
31
|
+
MdsType["SavedSearch"] = "saved_search";
|
|
32
|
+
})(MdsType || (MdsType = {}));
|
|
33
|
+
export var MdsWidgetType;
|
|
34
|
+
(function (MdsWidgetType) {
|
|
35
|
+
MdsWidgetType["Text"] = "text";
|
|
36
|
+
MdsWidgetType["Number"] = "number";
|
|
37
|
+
MdsWidgetType["Email"] = "email";
|
|
38
|
+
MdsWidgetType["Date"] = "date";
|
|
39
|
+
MdsWidgetType["Month"] = "month";
|
|
40
|
+
MdsWidgetType["Color"] = "color";
|
|
41
|
+
MdsWidgetType["Textarea"] = "textarea";
|
|
42
|
+
MdsWidgetType["TinyMCE"] = "tinyMCE";
|
|
43
|
+
MdsWidgetType["VCard"] = "vcard";
|
|
44
|
+
MdsWidgetType["Checkbox"] = "checkbox";
|
|
45
|
+
MdsWidgetType["RadioHorizontal"] = "radioHorizontal";
|
|
46
|
+
MdsWidgetType["RadioVertical"] = "radioVertical";
|
|
47
|
+
MdsWidgetType["CheckboxHorizontal"] = "checkboxHorizontal";
|
|
48
|
+
MdsWidgetType["CheckboxVertical"] = "checkboxVertical";
|
|
49
|
+
MdsWidgetType["MultiValueBadges"] = "multivalueBadges";
|
|
50
|
+
MdsWidgetType["MultiValueFixedBadges"] = "multivalueFixedBadges";
|
|
51
|
+
MdsWidgetType["MultiValueSuggestBadges"] = "multivalueSuggestBadges";
|
|
52
|
+
MdsWidgetType["MultiValueAuthorityBadges"] = "multivalueAuthorityBadges";
|
|
53
|
+
MdsWidgetType["Singleoption"] = "singleoption";
|
|
54
|
+
MdsWidgetType["Slider"] = "slider";
|
|
55
|
+
MdsWidgetType["Range"] = "range";
|
|
56
|
+
MdsWidgetType["Duration"] = "duration";
|
|
57
|
+
MdsWidgetType["SingleValueTree"] = "singlevalueTree";
|
|
58
|
+
MdsWidgetType["SingleValueSuggestBadges"] = "singlevalueSuggestBadges";
|
|
59
|
+
MdsWidgetType["MultiValueTree"] = "multivalueTree";
|
|
60
|
+
MdsWidgetType["DefaultValue"] = "defaultvalue";
|
|
61
|
+
MdsWidgetType["FacetList"] = "facetList";
|
|
62
|
+
})(MdsWidgetType || (MdsWidgetType = {}));
|
|
63
|
+
export var ValueType;
|
|
64
|
+
(function (ValueType) {
|
|
65
|
+
ValueType[ValueType["String"] = 0] = "String";
|
|
66
|
+
ValueType[ValueType["MultiValue"] = 1] = "MultiValue";
|
|
67
|
+
ValueType[ValueType["Range"] = 2] = "Range";
|
|
68
|
+
})(ValueType || (ValueType = {}));
|
|
69
|
+
export class MdsWidgetComponent {
|
|
70
|
+
static { this.inlineEditing = [
|
|
71
|
+
MdsWidgetType.Text,
|
|
72
|
+
MdsWidgetType.Number,
|
|
73
|
+
MdsWidgetType.Date,
|
|
74
|
+
MdsWidgetType.Email,
|
|
75
|
+
MdsWidgetType.Textarea,
|
|
76
|
+
MdsWidgetType.Singleoption,
|
|
77
|
+
MdsWidgetType.SingleValueTree,
|
|
78
|
+
MdsWidgetType.SingleValueSuggestBadges,
|
|
79
|
+
MdsWidgetType.MultiValueBadges,
|
|
80
|
+
MdsWidgetType.MultiValueFixedBadges,
|
|
81
|
+
MdsWidgetType.MultiValueSuggestBadges,
|
|
82
|
+
MdsWidgetType.MultiValueTree,
|
|
83
|
+
]; }
|
|
84
|
+
get headingLevel() {
|
|
85
|
+
return this.viewInstance.headingLevel;
|
|
86
|
+
}
|
|
87
|
+
constructor(
|
|
88
|
+
// public mdsEditorInstance: MdsEditorInstanceService,
|
|
89
|
+
translate, ui, viewInstance) {
|
|
90
|
+
this.translate = translate;
|
|
91
|
+
this.ui = ui;
|
|
92
|
+
this.viewInstance = viewInstance;
|
|
93
|
+
this.ROUTER_PREFIX = UIConstants.ROUTER_PREFIX;
|
|
94
|
+
this.valueType = ValueType.String;
|
|
95
|
+
this.showCaption = true;
|
|
96
|
+
/**
|
|
97
|
+
* allow inline editing
|
|
98
|
+
*/
|
|
99
|
+
this.inlineEditing = 'auto';
|
|
100
|
+
this.value = undefined;
|
|
101
|
+
this.temporaryValue = undefined;
|
|
102
|
+
// super(toast, null, translate);
|
|
103
|
+
}
|
|
104
|
+
ngOnChanges(changes) {
|
|
105
|
+
this.value = this.getNodeValue();
|
|
106
|
+
}
|
|
107
|
+
async ngOnInit() {
|
|
108
|
+
this.value = this.getNodeValue();
|
|
109
|
+
this.widget
|
|
110
|
+
.getInitialDisplayValues()
|
|
111
|
+
.pipe(filter((v) => !!v))
|
|
112
|
+
.subscribe(async (value) => {
|
|
113
|
+
this.value = value.values.map((v) => v.displayString);
|
|
114
|
+
});
|
|
115
|
+
this.basicType = this.getBasicType();
|
|
116
|
+
this.rawValue = await this.getRawValue().toPromise();
|
|
117
|
+
}
|
|
118
|
+
getDefinition() {
|
|
119
|
+
return this.widget?.definition || this.definition;
|
|
120
|
+
}
|
|
121
|
+
getBasicType() {
|
|
122
|
+
switch (this.getDefinition().type) {
|
|
123
|
+
case 'text':
|
|
124
|
+
case 'email':
|
|
125
|
+
case 'month':
|
|
126
|
+
case 'color':
|
|
127
|
+
case 'textarea':
|
|
128
|
+
case 'singleoption':
|
|
129
|
+
return 'text';
|
|
130
|
+
case 'number':
|
|
131
|
+
return 'number';
|
|
132
|
+
case 'date':
|
|
133
|
+
return 'date';
|
|
134
|
+
case 'vcard':
|
|
135
|
+
return 'vcard';
|
|
136
|
+
case 'multivalueFixedBadges':
|
|
137
|
+
case 'multivalueSuggestBadges':
|
|
138
|
+
case 'singlevalueSuggestBadges':
|
|
139
|
+
case 'multivalueBadges':
|
|
140
|
+
case 'singlevalueTree':
|
|
141
|
+
case 'multivalueTree':
|
|
142
|
+
return this.viewInstance.treeDisplay === 'flat' ? 'array' : 'tree';
|
|
143
|
+
case 'slider':
|
|
144
|
+
return 'slider';
|
|
145
|
+
case 'duration':
|
|
146
|
+
return 'duration';
|
|
147
|
+
case 'range':
|
|
148
|
+
return 'range';
|
|
149
|
+
}
|
|
150
|
+
return 'unknown';
|
|
151
|
+
}
|
|
152
|
+
supportsInlineEditing() {
|
|
153
|
+
return MdsWidgetComponent.inlineEditing.includes(this.widget?.definition.type);
|
|
154
|
+
}
|
|
155
|
+
getNodeValue() {
|
|
156
|
+
if (this.temporaryValue !== undefined) {
|
|
157
|
+
return this.getValue(this.temporaryValue);
|
|
158
|
+
}
|
|
159
|
+
const id = this.getDefinition().id;
|
|
160
|
+
if (this.getDefinition().type === 'range') {
|
|
161
|
+
const values = this.mdsEditorInstance?.values$.value;
|
|
162
|
+
if (values) {
|
|
163
|
+
return [values[id + '_from']?.[0], values[id + '_to']?.[0]];
|
|
164
|
+
}
|
|
165
|
+
return null;
|
|
166
|
+
}
|
|
167
|
+
else if (this.mdsEditorInstance?.values$.value?.[id]) {
|
|
168
|
+
// support on the fly changes+updates of the values
|
|
169
|
+
return this.getValue(this.mdsEditorInstance.values$.value[id]);
|
|
170
|
+
}
|
|
171
|
+
else if (this.widget.getInitialValues()?.jointValues) {
|
|
172
|
+
return this.getValue(this.widget.getInitialValues().jointValues);
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
return null;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
getValue(data) {
|
|
179
|
+
let value = data;
|
|
180
|
+
if (!value || value.every((v) => !v)) {
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
if (this.getDefinition().values) {
|
|
184
|
+
const mapping = this.widget.definition.values
|
|
185
|
+
.filter((v) => data.filter((d) => d === v.id).length > 0)
|
|
186
|
+
.map((v) => v.caption);
|
|
187
|
+
if (mapping) {
|
|
188
|
+
return mapping;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
return data;
|
|
192
|
+
}
|
|
193
|
+
click() {
|
|
194
|
+
if (this.getDefinition().link === '_BLANK') {
|
|
195
|
+
window.open(this.formatText()[0]);
|
|
196
|
+
}
|
|
197
|
+
else if (this.getDefinition().link === '_SELF') {
|
|
198
|
+
window.location.href = this.formatText()[0];
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
console.warn('Unsupported link type ' + this.getDefinition().link);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
isEmpty() {
|
|
205
|
+
return this.value?.every((v) => !v) || this.value?.length === 0 || !this.value;
|
|
206
|
+
}
|
|
207
|
+
formatDate() {
|
|
208
|
+
return this.value.map((v) => {
|
|
209
|
+
if (this.getDefinition().format) {
|
|
210
|
+
try {
|
|
211
|
+
return new DatePipe('en').transform(v, this.getDefinition().format);
|
|
212
|
+
}
|
|
213
|
+
catch (e) {
|
|
214
|
+
console.warn('Could not format date', e, this.getDefinition());
|
|
215
|
+
return DateHelper.formatDate(this.translate, v, {
|
|
216
|
+
showAlwaysTime: true,
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
else {
|
|
221
|
+
return DateHelper.formatDate(this.translate, v, {
|
|
222
|
+
showAlwaysTime: true,
|
|
223
|
+
});
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
formatNumber() {
|
|
228
|
+
return this.value.map((v) => {
|
|
229
|
+
if (this.widget.definition.format === 'bytes') {
|
|
230
|
+
return new FormatSizePipe(this.translate).transform(v);
|
|
231
|
+
}
|
|
232
|
+
return v;
|
|
233
|
+
});
|
|
234
|
+
}
|
|
235
|
+
formatText() {
|
|
236
|
+
return this.value.map((v) => {
|
|
237
|
+
if (this.widget.definition.format) {
|
|
238
|
+
return this.widget.definition.format.replace('${value}', v);
|
|
239
|
+
}
|
|
240
|
+
return v;
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
// instance: MdsEditorWidgetBase
|
|
244
|
+
async finishEdit(instance, store = false) {
|
|
245
|
+
if (store) {
|
|
246
|
+
await this.mdsEditorInstance.saveWidgetValue(instance.widget);
|
|
247
|
+
}
|
|
248
|
+
this.temporaryValue = instance.widget.getValue();
|
|
249
|
+
this.value = this.getNodeValue();
|
|
250
|
+
this.editWrapper.nativeElement.children[0].innerHTML = null;
|
|
251
|
+
await this.mdsEditorInstance.fetchDisplayValues(this.widget);
|
|
252
|
+
}
|
|
253
|
+
isEditable() {
|
|
254
|
+
if (!this.mdsEditorInstance) {
|
|
255
|
+
return false;
|
|
256
|
+
}
|
|
257
|
+
if (this.inlineEditing === 'always') {
|
|
258
|
+
return this.supportsInlineEditing();
|
|
259
|
+
}
|
|
260
|
+
const nodes = this.mdsEditorInstance.nodes$.value;
|
|
261
|
+
return (this.mdsEditorInstance.editorMode === 'inline' &&
|
|
262
|
+
this.widget.definition.interactionType === 'Input' &&
|
|
263
|
+
nodes?.length === 1 &&
|
|
264
|
+
RestHelper.hasAccessPermission(nodes[0], RestConstants.ACCESS_WRITE) &&
|
|
265
|
+
this.supportsInlineEditing());
|
|
266
|
+
}
|
|
267
|
+
async focus() {
|
|
268
|
+
// this.matRipple.launch({});
|
|
269
|
+
await this.ui.scrollSmoothElementToChild(this.editWrapper.nativeElement);
|
|
270
|
+
this.matRipple.launch({});
|
|
271
|
+
//const result = await this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);
|
|
272
|
+
//await this.ui.scrollSmoothElementToChild(result.htmlElement);
|
|
273
|
+
}
|
|
274
|
+
/**
|
|
275
|
+
* return the path for a given value in a tree
|
|
276
|
+
*/
|
|
277
|
+
getPath(v) {
|
|
278
|
+
if (!this.getDefinition().values) {
|
|
279
|
+
return [
|
|
280
|
+
{
|
|
281
|
+
id: v,
|
|
282
|
+
caption: v,
|
|
283
|
+
},
|
|
284
|
+
];
|
|
285
|
+
}
|
|
286
|
+
const path = [];
|
|
287
|
+
let pointer = v;
|
|
288
|
+
for (let i = 0; i < 100; i++) {
|
|
289
|
+
const mapped = this.getDefinition().values.find((w) => w.id === pointer);
|
|
290
|
+
if (mapped) {
|
|
291
|
+
path.push(mapped);
|
|
292
|
+
pointer = mapped.parent;
|
|
293
|
+
}
|
|
294
|
+
else {
|
|
295
|
+
break;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
return path.reverse();
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* fetch the raw node value
|
|
302
|
+
* Note: Will not work in a bulk state!
|
|
303
|
+
*/
|
|
304
|
+
getRawValue() {
|
|
305
|
+
return (this.mdsEditorInstance?.nodes$.pipe(first(), map((v) => v?.[0]?.properties[this.widget.definition.id]?.map((id) => {
|
|
306
|
+
return {
|
|
307
|
+
id,
|
|
308
|
+
path: this.getPath(id),
|
|
309
|
+
};
|
|
310
|
+
}))) || of(null));
|
|
311
|
+
}
|
|
312
|
+
getSearchParams(key) {
|
|
313
|
+
const params = {};
|
|
314
|
+
const mds = {};
|
|
315
|
+
mds[this.widget.definition.id] = [key.id];
|
|
316
|
+
params.mds = this.mdsEditorInstance.mdsId;
|
|
317
|
+
params.sidenav = true;
|
|
318
|
+
params.repo = this.mdsEditorInstance.nodes$.value?.[0].ref.repo;
|
|
319
|
+
params.filters = JSON.stringify(mds);
|
|
320
|
+
return params;
|
|
321
|
+
}
|
|
322
|
+
startEdit(event) {
|
|
323
|
+
event.stopPropagation();
|
|
324
|
+
void this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);
|
|
325
|
+
}
|
|
326
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsWidgetComponent, deps: [{ token: i1.TranslateService }, { token: i2.UIService }, { token: i3.ViewInstanceService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
327
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: MdsWidgetComponent, selector: "es-mds-widget", inputs: { widget: "widget", showCaption: "showCaption", inlineEditing: "inlineEditing", definition: "definition", view: "view" }, viewQueries: [{ propertyName: "editWrapper", first: true, predicate: ["editWrapper"], descendants: true }, { propertyName: "matRipple", first: true, predicate: MatRipple, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<es-mds-editor-widget-container\n *ngIf=\"!editWrapper.innerText.trim()\"\n [injectedView]=\"this\"\n [widget]=\"widget\"\n [label]=\"false\"\n [wrapInFormField]=\"false\"\n [wrapInGroup]=\"false\"\n [valueType]=\"valueType\"\n matRipple\n [matRippleDisabled]=\"true\"\n>\n <div class=\"edit-wrapper\">\n <div\n *ngIf=\"!isEmpty() || !widget.definition.hideIfEmpty || isEditable()\"\n class=\"widget-wrapper\"\n >\n <div\n class=\"widget-label\"\n [attr.role]=\"headingLevel ? 'heading' : null\"\n [attr.aria-level]=\"headingLevel\"\n *ngIf=\"widget.definition.caption && showCaption\"\n >\n {{ widget.definition.caption\n }}<span *ngIf=\"!headingLevel\" class=\"cdk-visually-hidden\">: </span>\n </div>\n <div\n class=\"value-wrapper\"\n [class.value-wrapper-edit]=\"isEditable()\"\n (click)=\"isEditable() ? startEdit($event) : null\"\n >\n <div *ngIf=\"isEmpty()\" class=\"widget-data widget-no-data widget-type-{{ basicType }}\">\n -\n </div>\n <div\n *ngIf=\"!isEmpty()\"\n class=\"widget-data widget-type-{{ basicType }} {{\n widget.definition.link ? 'widget-link' : ''\n }}\"\n (click)=\"click()\"\n >\n <div *ngIf=\"basicType === 'text'\">{{ formatText() }}</div>\n <div *ngIf=\"basicType === 'number'\">{{ formatNumber() }}</div>\n <div *ngIf=\"basicType === 'date'\">{{ formatDate() }}</div>\n <div *ngIf=\"basicType === 'array'\">\n <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v }}</div>\n </div>\n <div *ngIf=\"basicType === 'tree'\">\n <div class=\"tree-entry\" *ngFor=\"let v of rawValue\">\n <ng-container *ngTemplateOutlet=\"treeEntry; context: { path: v.path }\"></ng-container>\n </div>\n </div>\n <div *ngIf=\"basicType === 'vcard'\">\n <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v | vcardName }}</div>\n </div>\n <div *ngIf=\"basicType === 'slider'\">\n <span class=\"slider-value\">{{ value }}</span\n ><span> / </span><span class=\"slider-max\">{{ widget.definition.max }}</span>\n </div>\n <div *ngIf=\"basicType === 'duration'\">\n <span class=\"duration-value\">{{ value[0] | appMdsDuration }}</span>\n </div>\n <div *ngIf=\"basicType === 'range'\">\n <span class=\"slider-value\">{{ value[0] }}</span\n >-<span class=\"slider-value\">{{ value[1] }}</span>\n </div>\n <div *ngIf=\"basicType === 'unknown'\">\n The widget type {{ widget.definition.type }} is currently not supported via angular\n rendering\n </div>\n </div>\n </div>\n </div>\n <!--<button mat-icon-button\n *ngIf=\"mdsEditorInstance.editorMode === 'inline' && widget.definition.interactionType === 'Input'\"\n (click)=\"view.injectEditField(this, edit)\"\n class=\"btn-edit\">\n <i esIcon=\"edit\"></i>\n </button>-->\n </div>\n</es-mds-editor-widget-container>\n<div class=\"edit-wrapper\">\n <div #editWrapper><div #edit></div></div>\n <!--<button *ngIf=\"!!editWrapper.innerText.trim()\" mat-icon-button><i esIcon=\"save\"></i></button>-->\n</div>\n<ng-template #treeEntry let-path=\"path\">\n <ng-container *ngFor=\"let t of path; let first = first\">\n <ng-container *ngIf=\"!first\">\n <span class=\"cdk-visually-hidden\">{{ 'SUB_CATEGORY_ARIA' | translate }}</span>\n <i esIcon=\"keyboard_arrow_right\" [aria]=\"false\"></i>\n </ng-container>\n <a\n [routerLink]=\"'/' + ROUTER_PREFIX + 'search'\"\n [queryParams]=\"getSearchParams(t)\"\n *ngIf=\"widget.definition.isSearchable\"\n >{{ t.caption }}</a\n >\n <span *ngIf=\"!widget.definition.isSearchable\">{{ t.caption }}</span>\n </ng-container>\n</ng-template>\n", styles: [".widget-label{font-size:90%;opacity:.8}.edit-wrapper{display:flex;align-items:center;transition:var(--transitionNormal) all}.edit-wrapper>div:first-child{flex-grow:1}.edit-wrapper>button{margin-left:10px}.edit-wrapper .widget-wrapper{padding:2px 5px}.edit-wrapper .value-wrapper-edit:hover{outline:1px solid #ccc;cursor:text}.widget-data{padding:4px 0 10px;word-break:break-word}.widget-data.widget-type-slider{opacity:.8}.widget-data.widget-type-slider .slider-value{opacity:.9;font-weight:700}.widget-data.widget-type-array .array-entry,.widget-data.widget-type-vcard .array-entry{display:inline}.widget-data.widget-type-array .array-entry:not(:last-child):after,.widget-data.widget-type-vcard .array-entry:not(:last-child):after{content:\", \";padding-right:.3em;display:inline;align-items:flex-end}.widget-data.widget-type-tree>div{display:flex;flex-wrap:wrap;gap:10px}.widget-data.widget-type-tree .tree-entry{display:inline-block;border-radius:5px;padding:5px 10px;background-color:#f9f9f9}.widget-data.widget-type-tree .tree-entry>a{color:var(--palette-primary-800);text-decoration:none}.widget-data.widget-type-tree .tree-entry>*{vertical-align:middle}.widget-data.widget-type-tree .tree-entry>i{font-size:18px}.widget-data.widget-link{text-decoration:underline;cursor:pointer}.widget-type-text>div{white-space:pre-line}:host ::ng-deep .edit-wrapper .widget-container mat-form-field{margin-top:.5em}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i7.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i8.MdsDurationPipe, name: "appMdsDuration" }, { kind: "pipe", type: i9.VCardNamePipe, name: "vcardName" }] }); }
|
|
328
|
+
}
|
|
329
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsWidgetComponent, decorators: [{
|
|
330
|
+
type: Component,
|
|
331
|
+
args: [{ selector: 'es-mds-widget', template: "<es-mds-editor-widget-container\n *ngIf=\"!editWrapper.innerText.trim()\"\n [injectedView]=\"this\"\n [widget]=\"widget\"\n [label]=\"false\"\n [wrapInFormField]=\"false\"\n [wrapInGroup]=\"false\"\n [valueType]=\"valueType\"\n matRipple\n [matRippleDisabled]=\"true\"\n>\n <div class=\"edit-wrapper\">\n <div\n *ngIf=\"!isEmpty() || !widget.definition.hideIfEmpty || isEditable()\"\n class=\"widget-wrapper\"\n >\n <div\n class=\"widget-label\"\n [attr.role]=\"headingLevel ? 'heading' : null\"\n [attr.aria-level]=\"headingLevel\"\n *ngIf=\"widget.definition.caption && showCaption\"\n >\n {{ widget.definition.caption\n }}<span *ngIf=\"!headingLevel\" class=\"cdk-visually-hidden\">: </span>\n </div>\n <div\n class=\"value-wrapper\"\n [class.value-wrapper-edit]=\"isEditable()\"\n (click)=\"isEditable() ? startEdit($event) : null\"\n >\n <div *ngIf=\"isEmpty()\" class=\"widget-data widget-no-data widget-type-{{ basicType }}\">\n -\n </div>\n <div\n *ngIf=\"!isEmpty()\"\n class=\"widget-data widget-type-{{ basicType }} {{\n widget.definition.link ? 'widget-link' : ''\n }}\"\n (click)=\"click()\"\n >\n <div *ngIf=\"basicType === 'text'\">{{ formatText() }}</div>\n <div *ngIf=\"basicType === 'number'\">{{ formatNumber() }}</div>\n <div *ngIf=\"basicType === 'date'\">{{ formatDate() }}</div>\n <div *ngIf=\"basicType === 'array'\">\n <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v }}</div>\n </div>\n <div *ngIf=\"basicType === 'tree'\">\n <div class=\"tree-entry\" *ngFor=\"let v of rawValue\">\n <ng-container *ngTemplateOutlet=\"treeEntry; context: { path: v.path }\"></ng-container>\n </div>\n </div>\n <div *ngIf=\"basicType === 'vcard'\">\n <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v | vcardName }}</div>\n </div>\n <div *ngIf=\"basicType === 'slider'\">\n <span class=\"slider-value\">{{ value }}</span\n ><span> / </span><span class=\"slider-max\">{{ widget.definition.max }}</span>\n </div>\n <div *ngIf=\"basicType === 'duration'\">\n <span class=\"duration-value\">{{ value[0] | appMdsDuration }}</span>\n </div>\n <div *ngIf=\"basicType === 'range'\">\n <span class=\"slider-value\">{{ value[0] }}</span\n >-<span class=\"slider-value\">{{ value[1] }}</span>\n </div>\n <div *ngIf=\"basicType === 'unknown'\">\n The widget type {{ widget.definition.type }} is currently not supported via angular\n rendering\n </div>\n </div>\n </div>\n </div>\n <!--<button mat-icon-button\n *ngIf=\"mdsEditorInstance.editorMode === 'inline' && widget.definition.interactionType === 'Input'\"\n (click)=\"view.injectEditField(this, edit)\"\n class=\"btn-edit\">\n <i esIcon=\"edit\"></i>\n </button>-->\n </div>\n</es-mds-editor-widget-container>\n<div class=\"edit-wrapper\">\n <div #editWrapper><div #edit></div></div>\n <!--<button *ngIf=\"!!editWrapper.innerText.trim()\" mat-icon-button><i esIcon=\"save\"></i></button>-->\n</div>\n<ng-template #treeEntry let-path=\"path\">\n <ng-container *ngFor=\"let t of path; let first = first\">\n <ng-container *ngIf=\"!first\">\n <span class=\"cdk-visually-hidden\">{{ 'SUB_CATEGORY_ARIA' | translate }}</span>\n <i esIcon=\"keyboard_arrow_right\" [aria]=\"false\"></i>\n </ng-container>\n <a\n [routerLink]=\"'/' + ROUTER_PREFIX + 'search'\"\n [queryParams]=\"getSearchParams(t)\"\n *ngIf=\"widget.definition.isSearchable\"\n >{{ t.caption }}</a\n >\n <span *ngIf=\"!widget.definition.isSearchable\">{{ t.caption }}</span>\n </ng-container>\n</ng-template>\n", styles: [".widget-label{font-size:90%;opacity:.8}.edit-wrapper{display:flex;align-items:center;transition:var(--transitionNormal) all}.edit-wrapper>div:first-child{flex-grow:1}.edit-wrapper>button{margin-left:10px}.edit-wrapper .widget-wrapper{padding:2px 5px}.edit-wrapper .value-wrapper-edit:hover{outline:1px solid #ccc;cursor:text}.widget-data{padding:4px 0 10px;word-break:break-word}.widget-data.widget-type-slider{opacity:.8}.widget-data.widget-type-slider .slider-value{opacity:.9;font-weight:700}.widget-data.widget-type-array .array-entry,.widget-data.widget-type-vcard .array-entry{display:inline}.widget-data.widget-type-array .array-entry:not(:last-child):after,.widget-data.widget-type-vcard .array-entry:not(:last-child):after{content:\", \";padding-right:.3em;display:inline;align-items:flex-end}.widget-data.widget-type-tree>div{display:flex;flex-wrap:wrap;gap:10px}.widget-data.widget-type-tree .tree-entry{display:inline-block;border-radius:5px;padding:5px 10px;background-color:#f9f9f9}.widget-data.widget-type-tree .tree-entry>a{color:var(--palette-primary-800);text-decoration:none}.widget-data.widget-type-tree .tree-entry>*{vertical-align:middle}.widget-data.widget-type-tree .tree-entry>i{font-size:18px}.widget-data.widget-link{text-decoration:underline;cursor:pointer}.widget-type-text>div{white-space:pre-line}:host ::ng-deep .edit-wrapper .widget-container mat-form-field{margin-top:.5em}\n"] }]
|
|
332
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.UIService }, { type: i3.ViewInstanceService }], propDecorators: { widget: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], showCaption: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}], inlineEditing: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], definition: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], view: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], editWrapper: [{
|
|
343
|
+
type: ViewChild,
|
|
344
|
+
args: ['editWrapper']
|
|
345
|
+
}], matRipple: [{
|
|
346
|
+
type: ViewChild,
|
|
347
|
+
args: [MatRipple]
|
|
348
|
+
}] } });
|
|
349
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mds-widget.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/widget/mds-widget.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/mds-viewer/widget/mds-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    Input,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { MatRipple } from '@angular/material/core';\nimport { filter, first, map } from 'rxjs/operators';\nimport { MdsValue, MdsWidget, Node, RestConstants, Suggestion } from 'ngx-edu-sharing-api';\nimport { UIConstants } from '../../util/ui-constants';\nimport { DateHelper } from '../../util/DateHelper';\nimport { UIService } from '../../services/ui.service';\nimport { ViewInstanceService } from '../view-instance.service';\nimport { RestHelper } from '../../util/rest-helper';\nimport { FormatSizePipe } from '../../pipes/file-size.pipe';\nimport { of } from 'rxjs';\n\nexport enum MdsType {\n    Io = 'io',\n    IoBulk = 'io_bulk',\n    Map = 'map',\n    MapRef = 'map_ref',\n    IoChildObject = 'io_childobject',\n    Collection = 'collection',\n    ToolDefinition = 'tool_definition',\n    ToolInstance = 'tool_instance',\n    SavedSearch = 'saved_search',\n}\n\nexport interface MdsValueList {\n    values: Suggestion[];\n}\n\nexport enum MdsWidgetType {\n    Text = 'text',\n    Number = 'number',\n    Email = 'email',\n    Date = 'date',\n    Month = 'month',\n    Color = 'color',\n    Textarea = 'textarea',\n    TinyMCE = 'tinyMCE',\n    VCard = 'vcard',\n    Checkbox = 'checkbox',\n    RadioHorizontal = 'radioHorizontal',\n    RadioVertical = 'radioVertical',\n    CheckboxHorizontal = 'checkboxHorizontal',\n    CheckboxVertical = 'checkboxVertical',\n    MultiValueBadges = 'multivalueBadges',\n    MultiValueFixedBadges = 'multivalueFixedBadges',\n    MultiValueSuggestBadges = 'multivalueSuggestBadges',\n    MultiValueAuthorityBadges = 'multivalueAuthorityBadges',\n    Singleoption = 'singleoption',\n    Slider = 'slider',\n    Range = 'range',\n    Duration = 'duration',\n    SingleValueTree = 'singlevalueTree',\n    SingleValueSuggestBadges = 'singlevalueSuggestBadges',\n    MultiValueTree = 'multivalueTree',\n    DefaultValue = 'defaultvalue',\n    FacetList = 'facetList',\n}\n\nexport enum ValueType {\n    String,\n    MultiValue,\n    Range,\n}\n\n@Component({\n    selector: 'es-mds-widget',\n    templateUrl: 'mds-widget.component.html',\n    styleUrls: ['mds-widget.component.scss'],\n    // required for external editor injection\n})\nexport class MdsWidgetComponent implements OnInit, OnChanges {\n    readonly ROUTER_PREFIX = UIConstants.ROUTER_PREFIX;\n    private static readonly inlineEditing: MdsWidgetType[] = [\n        MdsWidgetType.Text,\n        MdsWidgetType.Number,\n        MdsWidgetType.Date,\n        MdsWidgetType.Email,\n        MdsWidgetType.Textarea,\n        MdsWidgetType.Singleoption,\n        MdsWidgetType.SingleValueTree,\n        MdsWidgetType.SingleValueSuggestBadges,\n        MdsWidgetType.MultiValueBadges,\n        MdsWidgetType.MultiValueFixedBadges,\n        MdsWidgetType.MultiValueSuggestBadges,\n        MdsWidgetType.MultiValueTree,\n    ];\n\n    readonly valueType = ValueType.String;\n\n    // use any instead of `Widget` cause of external type\n    @Input() widget: any;\n    @Input() showCaption = true;\n    /**\n     * allow inline editing\n     */\n    @Input() inlineEditing: 'auto' | 'always' = 'auto';\n    @Input() definition: MdsWidget;\n    // use any instead of MdsEditorViewComponent cause of external type\n    @Input() view: any;\n\n    @ViewChild('editWrapper') editWrapper: ElementRef;\n    @ViewChild(MatRipple) matRipple: MatRipple;\n    basicType: string;\n    rawValue: { path: MdsValue[]; id: string }[];\n\n    private mdsEditorInstance: any;\n\n    get headingLevel() {\n        return this.viewInstance.headingLevel;\n    }\n\n    value: string[] = undefined;\n    private temporaryValue: string[] = undefined;\n\n    constructor(\n        // public mdsEditorInstance: MdsEditorInstanceService,\n        public translate: TranslateService,\n        private ui: UIService,\n        private viewInstance: ViewInstanceService,\n    ) {\n        // super(toast, null, translate);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.value = this.getNodeValue();\n    }\n\n    async ngOnInit() {\n        this.value = this.getNodeValue();\n        this.widget\n            .getInitialDisplayValues()\n            .pipe(filter((v: MdsValueList) => !!v))\n            .subscribe(async (value: MdsValueList) => {\n                this.value = value.values.map((v) => v.displayString);\n            });\n        this.basicType = this.getBasicType();\n        this.rawValue = await this.getRawValue().toPromise();\n    }\n\n    getDefinition(): MdsWidget {\n        return this.widget?.definition || this.definition;\n    }\n\n    getBasicType() {\n        switch (this.getDefinition().type) {\n            case 'text':\n            case 'email':\n            case 'month':\n            case 'color':\n            case 'textarea':\n            case 'singleoption':\n                return 'text';\n            case 'number':\n                return 'number';\n            case 'date':\n                return 'date';\n            case 'vcard':\n                return 'vcard';\n            case 'multivalueFixedBadges':\n            case 'multivalueSuggestBadges':\n            case 'singlevalueSuggestBadges':\n            case 'multivalueBadges':\n            case 'singlevalueTree':\n            case 'multivalueTree':\n                return this.viewInstance.treeDisplay === 'flat' ? 'array' : 'tree';\n            case 'slider':\n                return 'slider';\n            case 'duration':\n                return 'duration';\n            case 'range':\n                return 'range';\n        }\n        return 'unknown';\n    }\n\n    supportsInlineEditing() {\n        return MdsWidgetComponent.inlineEditing.includes(\n            this.widget?.definition.type as MdsWidgetType,\n        );\n    }\n\n    private getNodeValue() {\n        if (this.temporaryValue !== undefined) {\n            return this.getValue(this.temporaryValue);\n        }\n        const id = this.getDefinition().id;\n        if (this.getDefinition().type === 'range') {\n            const values = this.mdsEditorInstance?.values$.value;\n            if (values) {\n                return [values[id + '_from']?.[0], values[id + '_to']?.[0]];\n            }\n            return null;\n        } else if (this.mdsEditorInstance?.values$.value?.[id]) {\n            // support on the fly changes+updates of the values\n            return this.getValue(this.mdsEditorInstance.values$.value[id]);\n        } else if (this.widget.getInitialValues()?.jointValues) {\n            return this.getValue(this.widget.getInitialValues().jointValues);\n        } else {\n            return null;\n        }\n    }\n\n    getValue(data: string[]) {\n        let value = data;\n        if (!value || value.every((v) => !v)) {\n            return null;\n        }\n\n        if (this.getDefinition().values) {\n            const mapping = this.widget.definition.values\n                .filter((v: any) => data.filter((d) => d === v.id).length > 0)\n                .map((v: any) => v.caption);\n            if (mapping) {\n                return mapping;\n            }\n        }\n\n        return data;\n    }\n\n    click() {\n        if (this.getDefinition().link === '_BLANK') {\n            window.open(this.formatText()[0]);\n        } else if (this.getDefinition().link === '_SELF') {\n            window.location.href = this.formatText()[0];\n        } else {\n            console.warn('Unsupported link type ' + this.getDefinition().link);\n        }\n    }\n\n    isEmpty() {\n        return this.value?.every((v) => !v) || this.value?.length === 0 || !this.value;\n    }\n\n    formatDate() {\n        return this.value.map((v) => {\n            if (this.getDefinition().format) {\n                try {\n                    return new DatePipe('en').transform(v, this.getDefinition().format);\n                } catch (e) {\n                    console.warn('Could not format date', e, this.getDefinition());\n                    return DateHelper.formatDate(this.translate, v, {\n                        showAlwaysTime: true,\n                    });\n                }\n            } else {\n                return DateHelper.formatDate(this.translate, v, {\n                    showAlwaysTime: true,\n                });\n            }\n        });\n    }\n\n    formatNumber() {\n        return this.value.map((v) => {\n            if (this.widget.definition.format === 'bytes') {\n                return new FormatSizePipe(this.translate).transform(v);\n            }\n            return v;\n        });\n    }\n\n    formatText() {\n        return this.value.map((v) => {\n            if (this.widget.definition.format) {\n                return this.widget.definition.format.replace('${value}', v);\n            }\n            return v;\n        });\n    }\n    // instance: MdsEditorWidgetBase\n    async finishEdit(instance: any, store = false) {\n        if (store) {\n            await this.mdsEditorInstance.saveWidgetValue(instance.widget);\n        }\n        this.temporaryValue = instance.widget.getValue();\n        this.value = this.getNodeValue();\n        this.editWrapper.nativeElement.children[0].innerHTML = null;\n        await this.mdsEditorInstance.fetchDisplayValues(this.widget);\n    }\n\n    isEditable() {\n        if (!this.mdsEditorInstance) {\n            return false;\n        }\n        if (this.inlineEditing === 'always') {\n            return this.supportsInlineEditing();\n        }\n        const nodes = this.mdsEditorInstance.nodes$.value;\n        return (\n            this.mdsEditorInstance.editorMode === 'inline' &&\n            this.widget.definition.interactionType === 'Input' &&\n            nodes?.length === 1 &&\n            RestHelper.hasAccessPermission(nodes[0], RestConstants.ACCESS_WRITE) &&\n            this.supportsInlineEditing()\n        );\n    }\n\n    async focus() {\n        // this.matRipple.launch({});\n        await this.ui.scrollSmoothElementToChild(this.editWrapper.nativeElement);\n        this.matRipple.launch({});\n        //const result = await this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);\n        //await this.ui.scrollSmoothElementToChild(result.htmlElement);\n    }\n\n    /**\n     * return the path for a given value in a tree\n     */\n    private getPath(v: string) {\n        if (!this.getDefinition().values) {\n            return [\n                {\n                    id: v,\n                    caption: v,\n                },\n            ];\n        }\n        const path: MdsValue[] = [];\n        let pointer: string = v;\n        for (let i = 0; i < 100; i++) {\n            const mapped = this.getDefinition().values.find((w) => w.id === pointer);\n            if (mapped) {\n                path.push(mapped);\n                pointer = mapped.parent;\n            } else {\n                break;\n            }\n        }\n        return path.reverse();\n    }\n\n    /**\n     * fetch the raw node value\n     * Note: Will not work in a bulk state!\n     */\n    private getRawValue() {\n        return (\n            this.mdsEditorInstance?.nodes$.pipe(\n                first(),\n                map((v: Node[]) =>\n                    (v?.[0]?.properties[this.widget.definition.id] as string[])?.map((id) => {\n                        return {\n                            id,\n                            path: this.getPath(id),\n                        };\n                    }),\n                ),\n            ) || of(null)\n        );\n    }\n\n    getSearchParams(key: MdsValue) {\n        const params: any = {};\n        const mds: { [key: string]: string[] } = {};\n        mds[this.widget.definition.id] = [key.id];\n        params.mds = this.mdsEditorInstance.mdsId;\n        params.sidenav = true;\n        params.repo = this.mdsEditorInstance.nodes$.value?.[0].ref.repo;\n        params.filters = JSON.stringify(mds);\n        return params;\n    }\n\n    startEdit(event: MouseEvent) {\n        event.stopPropagation();\n        void this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);\n    }\n}\n","<es-mds-editor-widget-container\n  *ngIf=\"!editWrapper.innerText.trim()\"\n  [injectedView]=\"this\"\n  [widget]=\"widget\"\n  [label]=\"false\"\n  [wrapInFormField]=\"false\"\n  [wrapInGroup]=\"false\"\n  [valueType]=\"valueType\"\n  matRipple\n  [matRippleDisabled]=\"true\"\n>\n  <div class=\"edit-wrapper\">\n    <div\n      *ngIf=\"!isEmpty() || !widget.definition.hideIfEmpty || isEditable()\"\n      class=\"widget-wrapper\"\n    >\n      <div\n        class=\"widget-label\"\n        [attr.role]=\"headingLevel ? 'heading' : null\"\n        [attr.aria-level]=\"headingLevel\"\n        *ngIf=\"widget.definition.caption && showCaption\"\n      >\n        {{ widget.definition.caption\n        }}<span *ngIf=\"!headingLevel\" class=\"cdk-visually-hidden\">: </span>\n      </div>\n      <div\n        class=\"value-wrapper\"\n        [class.value-wrapper-edit]=\"isEditable()\"\n        (click)=\"isEditable() ? startEdit($event) : null\"\n      >\n        <div *ngIf=\"isEmpty()\" class=\"widget-data widget-no-data widget-type-{{ basicType }}\">\n          -\n        </div>\n        <div\n          *ngIf=\"!isEmpty()\"\n          class=\"widget-data widget-type-{{ basicType }} {{\n            widget.definition.link ? 'widget-link' : ''\n          }}\"\n          (click)=\"click()\"\n        >\n          <div *ngIf=\"basicType === 'text'\">{{ formatText() }}</div>\n          <div *ngIf=\"basicType === 'number'\">{{ formatNumber() }}</div>\n          <div *ngIf=\"basicType === 'date'\">{{ formatDate() }}</div>\n          <div *ngIf=\"basicType === 'array'\">\n            <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v }}</div>\n          </div>\n          <div *ngIf=\"basicType === 'tree'\">\n            <div class=\"tree-entry\" *ngFor=\"let v of rawValue\">\n              <ng-container *ngTemplateOutlet=\"treeEntry; context: { path: v.path }\"></ng-container>\n            </div>\n          </div>\n          <div *ngIf=\"basicType === 'vcard'\">\n            <div class=\"array-entry\" *ngFor=\"let v of value\">{{ v | vcardName }}</div>\n          </div>\n          <div *ngIf=\"basicType === 'slider'\">\n            <span class=\"slider-value\">{{ value }}</span\n            ><span> / </span><span class=\"slider-max\">{{ widget.definition.max }}</span>\n          </div>\n          <div *ngIf=\"basicType === 'duration'\">\n            <span class=\"duration-value\">{{ value[0] | appMdsDuration }}</span>\n          </div>\n          <div *ngIf=\"basicType === 'range'\">\n            <span class=\"slider-value\">{{ value[0] }}</span\n            >-<span class=\"slider-value\">{{ value[1] }}</span>\n          </div>\n          <div *ngIf=\"basicType === 'unknown'\">\n            The widget type {{ widget.definition.type }} is currently not supported via angular\n            rendering\n          </div>\n        </div>\n      </div>\n    </div>\n    <!--<button mat-icon-button\n            *ngIf=\"mdsEditorInstance.editorMode === 'inline' && widget.definition.interactionType === 'Input'\"\n            (click)=\"view.injectEditField(this, edit)\"\n            class=\"btn-edit\">\n      <i esIcon=\"edit\"></i>\n    </button>-->\n  </div>\n</es-mds-editor-widget-container>\n<div class=\"edit-wrapper\">\n  <div #editWrapper><div #edit></div></div>\n  <!--<button *ngIf=\"!!editWrapper.innerText.trim()\" mat-icon-button><i esIcon=\"save\"></i></button>-->\n</div>\n<ng-template #treeEntry let-path=\"path\">\n  <ng-container *ngFor=\"let t of path; let first = first\">\n    <ng-container *ngIf=\"!first\">\n      <span class=\"cdk-visually-hidden\">{{ 'SUB_CATEGORY_ARIA' | translate }}</span>\n      <i esIcon=\"keyboard_arrow_right\" [aria]=\"false\"></i>\n    </ng-container>\n    <a\n      [routerLink]=\"'/' + ROUTER_PREFIX + 'search'\"\n      [queryParams]=\"getSearchParams(t)\"\n      *ngIf=\"widget.definition.isSearchable\"\n      >{{ t.caption }}</a\n    >\n    <span *ngIf=\"!widget.definition.isSearchable\">{{ t.caption }}</span>\n  </ng-container>\n</ng-template>\n"]}
|
|
@@ -16,11 +16,11 @@ export class NodeEntriesGlobalOptionsComponent {
|
|
|
16
16
|
return this.entriesService.globalOptionsSubject.pipe(map((options) => options.filter((e) => e.isEnabled)));
|
|
17
17
|
}
|
|
18
18
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesGlobalOptionsComponent, deps: [{ token: i1.NodeEntriesService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesGlobalOptionsComponent, selector: "es-node-entries-global-options", inputs: { displayType: "displayType" }, ngImport: i0, template: "<div\n *ngIf=\"(getEnabledOptions() | async)?.length\"\n role=\"listitem\"\n class=\"global-options\"\n [class.global-options-small]=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n [class.global-options-table]=\"displayType === NodeEntriesDisplayType.Table\"\n>\n <button\n mat-button\n *ngFor=\"let option of getEnabledOptions() | async\"\n (click)=\"option.callback()\"\n class=\"global-option-btn\"\n attr.data-test=\"card-button-{{ option.name }}\"\n >\n <ng-container *ngTemplateOutlet=\"globalOption; context: { option: this.option }\"></ng-container>\n </button>\n</div>\n<ng-template #globalOption let-option=\"option\">\n <span class=\"global-option\">\n <i [esIcon]=\"option.icon\"></i>\n <span class=\"label\">{{ option.name | translate }}</span>\n </span>\n</ng-template>\n", styles: [":root{--primary: var(--palette-primary-500);--warning: #cd2457;--aiColor: #6d176e;--aiColorText: #fff;--tableIconSize: 38px;--textLight: #585858;--textMediumLight: #888;--textMain: #383838;--cardWidth: 240px;--colorStatusPositive: #40bf8e;--colorStatusNegative: var(--warning);--colorStarActive: #ba7c00;--nodeVirtualColor: #42ca8d;--nodeVirtualColorLight: #b8fcdd;--transitionNormal: .2s;--focusWidth: 2px;--fontSizeXSmall: 85%;--itemSelectedTextColor: var(--palette-primary-700);--listItemSelectedBackground: var(--palette-primary-50);--listItemSelectedBackgroundEffect: linear-gradient( to right, var(--primary) 0, var(--primary) 5px, var(--palette-primary-50) 5px, var(--palette-primary-50) 5px ) no-repeat}.global-options{display:grid;grid-template-columns:auto;grid-template-rows:repeat(auto-fit,minmax(70px,1fr));grid-row-gap:20px;height:100%;min-height:250px}.global-options.global-options-small{min-height:130px}.global-options.global-options-table{min-height:100px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-column-gap:20px}.global-options .global-option-btn{display:flex;height:100%;padding:0}.global-options .global-option{cursor:pointer;display:flex;box-shadow:0 0 5px #0000004d;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;border:3px dashed var(--primary);color:var(--primary)}.global-options .global-option>i{font-size:32px;margin-bottom:5px}.global-options .global-option>.label{cursor:pointer;font-weight:700}.global-options .global-option:hover,.global-options .global-option:focus{background-color:rgb(var(--palette-primary-50))}:host ::ng-deep .global-options .global-option-btn .mdc-button__label{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesGlobalOptionsComponent, selector: "es-node-entries-global-options", inputs: { displayType: "displayType" }, ngImport: i0, template: "<div\n *ngIf=\"(getEnabledOptions() | async)?.length\"\n role=\"listitem\"\n class=\"global-options\"\n [class.global-options-small]=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n [class.global-options-table]=\"displayType === NodeEntriesDisplayType.Table\"\n>\n <button\n mat-button\n *ngFor=\"let option of getEnabledOptions() | async\"\n (click)=\"option.callback()\"\n class=\"global-option-btn\"\n attr.data-test=\"card-button-{{ option.name }}\"\n >\n <ng-container *ngTemplateOutlet=\"globalOption; context: { option: this.option }\"></ng-container>\n </button>\n</div>\n<ng-template #globalOption let-option=\"option\">\n <span class=\"global-option\">\n <i [esIcon]=\"option.icon\"></i>\n <span class=\"label\">{{ option.name | translate }}</span>\n </span>\n</ng-template>\n", styles: [":root{--primary: var(--palette-primary-500);--warning: #cd2457;--aiColor: #6d176e;--aiColorText: #fff;--aiColorChip: #fff;--aiColorChipRemove: #555;--aiColorChipBorder: #ddd;--aiColorChipText: var(--aiColor);--tableIconSize: 38px;--textLight: #585858;--textMediumLight: #888;--textMain: #383838;--cardWidth: 240px;--chipsSeperatorLineColor: #e2e2e2;--colorStatusPositive: #40bf8e;--colorStatusNegative: var(--warning);--colorStarActive: #ba7c00;--nodeVirtualColor: #42ca8d;--nodeVirtualColorLight: #b8fcdd;--transitionNormal: .2s;--focusWidth: 2px;--fontSizeXSmall: 85%;--itemSelectedTextColor: var(--palette-primary-700);--listItemSelectedBackground: var(--palette-primary-50);--listItemSelectedBackgroundEffect: linear-gradient( to right, var(--primary) 0, var(--primary) 5px, var(--palette-primary-50) 5px, var(--palette-primary-50) 5px ) no-repeat}.global-options{display:grid;grid-template-columns:auto;grid-template-rows:repeat(auto-fit,minmax(70px,1fr));grid-row-gap:20px;height:100%;min-height:250px}.global-options.global-options-small{min-height:130px}.global-options.global-options-table{min-height:100px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-column-gap:20px}.global-options .global-option-btn{display:flex;height:100%;padding:0}.global-options .global-option{cursor:pointer;display:flex;box-shadow:0 0 5px #0000004d;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;border:3px dashed var(--primary);color:var(--primary)}.global-options .global-option>i{font-size:32px;margin-bottom:5px}.global-options .global-option>.label{cursor:pointer;font-weight:700}.global-options .global-option:hover,.global-options .global-option:focus{background-color:rgb(var(--palette-primary-50))}:host ::ng-deep .global-options .global-option-btn .mdc-button__label{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
20
20
|
}
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesGlobalOptionsComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
|
-
args: [{ selector: 'es-node-entries-global-options', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"(getEnabledOptions() | async)?.length\"\n role=\"listitem\"\n class=\"global-options\"\n [class.global-options-small]=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n [class.global-options-table]=\"displayType === NodeEntriesDisplayType.Table\"\n>\n <button\n mat-button\n *ngFor=\"let option of getEnabledOptions() | async\"\n (click)=\"option.callback()\"\n class=\"global-option-btn\"\n attr.data-test=\"card-button-{{ option.name }}\"\n >\n <ng-container *ngTemplateOutlet=\"globalOption; context: { option: this.option }\"></ng-container>\n </button>\n</div>\n<ng-template #globalOption let-option=\"option\">\n <span class=\"global-option\">\n <i [esIcon]=\"option.icon\"></i>\n <span class=\"label\">{{ option.name | translate }}</span>\n </span>\n</ng-template>\n", styles: [":root{--primary: var(--palette-primary-500);--warning: #cd2457;--aiColor: #6d176e;--aiColorText: #fff;--tableIconSize: 38px;--textLight: #585858;--textMediumLight: #888;--textMain: #383838;--cardWidth: 240px;--colorStatusPositive: #40bf8e;--colorStatusNegative: var(--warning);--colorStarActive: #ba7c00;--nodeVirtualColor: #42ca8d;--nodeVirtualColorLight: #b8fcdd;--transitionNormal: .2s;--focusWidth: 2px;--fontSizeXSmall: 85%;--itemSelectedTextColor: var(--palette-primary-700);--listItemSelectedBackground: var(--palette-primary-50);--listItemSelectedBackgroundEffect: linear-gradient( to right, var(--primary) 0, var(--primary) 5px, var(--palette-primary-50) 5px, var(--palette-primary-50) 5px ) no-repeat}.global-options{display:grid;grid-template-columns:auto;grid-template-rows:repeat(auto-fit,minmax(70px,1fr));grid-row-gap:20px;height:100%;min-height:250px}.global-options.global-options-small{min-height:130px}.global-options.global-options-table{min-height:100px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-column-gap:20px}.global-options .global-option-btn{display:flex;height:100%;padding:0}.global-options .global-option{cursor:pointer;display:flex;box-shadow:0 0 5px #0000004d;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;border:3px dashed var(--primary);color:var(--primary)}.global-options .global-option>i{font-size:32px;margin-bottom:5px}.global-options .global-option>.label{cursor:pointer;font-weight:700}.global-options .global-option:hover,.global-options .global-option:focus{background-color:rgb(var(--palette-primary-50))}:host ::ng-deep .global-options .global-option-btn .mdc-button__label{width:100%;height:100%}\n"] }]
|
|
23
|
+
args: [{ selector: 'es-node-entries-global-options', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"(getEnabledOptions() | async)?.length\"\n role=\"listitem\"\n class=\"global-options\"\n [class.global-options-small]=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n [class.global-options-table]=\"displayType === NodeEntriesDisplayType.Table\"\n>\n <button\n mat-button\n *ngFor=\"let option of getEnabledOptions() | async\"\n (click)=\"option.callback()\"\n class=\"global-option-btn\"\n attr.data-test=\"card-button-{{ option.name }}\"\n >\n <ng-container *ngTemplateOutlet=\"globalOption; context: { option: this.option }\"></ng-container>\n </button>\n</div>\n<ng-template #globalOption let-option=\"option\">\n <span class=\"global-option\">\n <i [esIcon]=\"option.icon\"></i>\n <span class=\"label\">{{ option.name | translate }}</span>\n </span>\n</ng-template>\n", styles: [":root{--primary: var(--palette-primary-500);--warning: #cd2457;--aiColor: #6d176e;--aiColorText: #fff;--aiColorChip: #fff;--aiColorChipRemove: #555;--aiColorChipBorder: #ddd;--aiColorChipText: var(--aiColor);--tableIconSize: 38px;--textLight: #585858;--textMediumLight: #888;--textMain: #383838;--cardWidth: 240px;--chipsSeperatorLineColor: #e2e2e2;--colorStatusPositive: #40bf8e;--colorStatusNegative: var(--warning);--colorStarActive: #ba7c00;--nodeVirtualColor: #42ca8d;--nodeVirtualColorLight: #b8fcdd;--transitionNormal: .2s;--focusWidth: 2px;--fontSizeXSmall: 85%;--itemSelectedTextColor: var(--palette-primary-700);--listItemSelectedBackground: var(--palette-primary-50);--listItemSelectedBackgroundEffect: linear-gradient( to right, var(--primary) 0, var(--primary) 5px, var(--palette-primary-50) 5px, var(--palette-primary-50) 5px ) no-repeat}.global-options{display:grid;grid-template-columns:auto;grid-template-rows:repeat(auto-fit,minmax(70px,1fr));grid-row-gap:20px;height:100%;min-height:250px}.global-options.global-options-small{min-height:130px}.global-options.global-options-table{min-height:100px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-column-gap:20px}.global-options .global-option-btn{display:flex;height:100%;padding:0}.global-options .global-option{cursor:pointer;display:flex;box-shadow:0 0 5px #0000004d;width:100%;height:100%;flex-direction:column;align-items:center;justify-content:center;border:3px dashed var(--primary);color:var(--primary)}.global-options .global-option>i{font-size:32px;margin-bottom:5px}.global-options .global-option>.label{cursor:pointer;font-weight:700}.global-options .global-option:hover,.global-options .global-option:focus{background-color:rgb(var(--palette-primary-50))}:host ::ng-deep .global-options .global-option-btn .mdc-button__label{width:100%;height:100%}\n"] }]
|
|
24
24
|
}], ctorParameters: () => [{ type: i1.NodeEntriesService }], propDecorators: { displayType: [{
|
|
25
25
|
type: Input
|
|
26
26
|
}] } });
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class MdsDurationPipe {
|
|
4
|
+
transform(value) {
|
|
5
|
+
if (isNaN(Number(value)) || !value) {
|
|
6
|
+
return '-';
|
|
7
|
+
}
|
|
8
|
+
const totalSeconds = Math.floor(parseInt(value) / 1000);
|
|
9
|
+
const hours = Math.floor(totalSeconds / 3600);
|
|
10
|
+
const minutes = Math.round((totalSeconds - hours * 3600) / 60);
|
|
11
|
+
if (hours > 0) {
|
|
12
|
+
return hours + 'h ' + minutes + 'm';
|
|
13
|
+
}
|
|
14
|
+
return minutes + 'm';
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsDurationPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
17
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: MdsDurationPipe, name: "appMdsDuration" }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsDurationPipe, decorators: [{
|
|
20
|
+
type: Pipe,
|
|
21
|
+
args: [{
|
|
22
|
+
name: 'appMdsDuration',
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWRzLWR1cmF0aW9uLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3BpcGVzL21kcy1kdXJhdGlvbi5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUtwRCxNQUFNLE9BQU8sZUFBZTtJQUN4QixTQUFTLENBQUMsS0FBYTtRQUNuQixJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2pDLE9BQU8sR0FBRyxDQUFDO1FBQ2YsQ0FBQztRQUNELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1FBQ3hELE1BQU0sS0FBSyxHQUFXLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxDQUFDO1FBQ3RELE1BQU0sT0FBTyxHQUFXLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxZQUFZLEdBQUcsS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLElBQUksS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ1osT0FBTyxLQUFLLEdBQUcsSUFBSSxHQUFHLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDeEMsQ0FBQztRQUNELE9BQU8sT0FBTyxHQUFHLEdBQUcsQ0FBQztJQUN6QixDQUFDOytHQVpRLGVBQWU7NkdBQWYsZUFBZTs7NEZBQWYsZUFBZTtrQkFIM0IsSUFBSTttQkFBQztvQkFDRixJQUFJLEVBQUUsZ0JBQWdCO2lCQUN6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICAgIG5hbWU6ICdhcHBNZHNEdXJhdGlvbicsXG59KVxuZXhwb3J0IGNsYXNzIE1kc0R1cmF0aW9uUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIHRyYW5zZm9ybSh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcbiAgICAgICAgaWYgKGlzTmFOKE51bWJlcih2YWx1ZSkpIHx8ICF2YWx1ZSkge1xuICAgICAgICAgICAgcmV0dXJuICctJztcbiAgICAgICAgfVxuICAgICAgICBjb25zdCB0b3RhbFNlY29uZHMgPSBNYXRoLmZsb29yKHBhcnNlSW50KHZhbHVlKSAvIDEwMDApO1xuICAgICAgICBjb25zdCBob3VyczogbnVtYmVyID0gTWF0aC5mbG9vcih0b3RhbFNlY29uZHMgLyAzNjAwKTtcbiAgICAgICAgY29uc3QgbWludXRlczogbnVtYmVyID0gTWF0aC5yb3VuZCgodG90YWxTZWNvbmRzIC0gaG91cnMgKiAzNjAwKSAvIDYwKTtcbiAgICAgICAgaWYgKGhvdXJzID4gMCkge1xuICAgICAgICAgICAgcmV0dXJuIGhvdXJzICsgJ2ggJyArIG1pbnV0ZXMgKyAnbSc7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG1pbnV0ZXMgKyAnbSc7XG4gICAgfVxufVxuIl19
|