ngx-edu-sharing-ui 10.0.15 → 10.0.17
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/esm2022/lib/index.mjs +2 -1
- package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +10 -9
- package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +48 -28
- package/esm2022/lib/pipes/node-title.pipe.mjs +2 -2
- package/esm2022/lib/spinner-small/spinner-small.component.mjs +2 -4
- package/esm2022/lib/util/helper.mjs +2 -2
- package/fesm2022/ngx-edu-sharing-ui.mjs +2285 -2267
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/mds-viewer/mds-viewer.component.d.ts +2 -2
- package/lib/mds-viewer/widget/mds-widget.component.d.ts +11 -5
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { DatePipe } from '@angular/common';
|
|
2
|
-
import { Component, Input, ViewChild, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, Input, signal, ViewChild, } from '@angular/core';
|
|
3
3
|
import { MatRipple } from '@angular/material/core';
|
|
4
4
|
import { filter, first, map } from 'rxjs/operators';
|
|
5
5
|
import { RestConstants } from 'ngx-edu-sharing-api';
|
|
@@ -7,18 +7,19 @@ import { UIConstants } from '../../util/ui-constants';
|
|
|
7
7
|
import { DateHelper } from '../../util/DateHelper';
|
|
8
8
|
import { RestHelper } from '../../util/rest-helper';
|
|
9
9
|
import { FormatSizePipe } from '../../pipes/file-size.pipe';
|
|
10
|
-
import { of } from 'rxjs';
|
|
10
|
+
import { BehaviorSubject, of } from 'rxjs';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
import * as i1 from "@ngx-translate/core";
|
|
13
13
|
import * as i2 from "../../services/ui.service";
|
|
14
14
|
import * as i3 from "../view-instance.service";
|
|
15
15
|
import * as i4 from "../mds-viewer.service";
|
|
16
|
-
import * as i5 from "
|
|
17
|
-
import * as i6 from "@angular/
|
|
18
|
-
import * as i7 from "@angular/
|
|
19
|
-
import * as i8 from "
|
|
20
|
-
import * as i9 from "../../
|
|
21
|
-
import * as i10 from "../../pipes/
|
|
16
|
+
import * as i5 from "../../services/node-helper.service";
|
|
17
|
+
import * as i6 from "@angular/common";
|
|
18
|
+
import * as i7 from "@angular/material/core";
|
|
19
|
+
import * as i8 from "@angular/router";
|
|
20
|
+
import * as i9 from "../../directives/icon.directive";
|
|
21
|
+
import * as i10 from "../../pipes/mds-duration.pipe";
|
|
22
|
+
import * as i11 from "../../pipes/vcard-name.pipe";
|
|
22
23
|
export var MdsType;
|
|
23
24
|
(function (MdsType) {
|
|
24
25
|
MdsType["Io"] = "io";
|
|
@@ -87,11 +88,12 @@ export class MdsWidgetComponent {
|
|
|
87
88
|
}
|
|
88
89
|
constructor(
|
|
89
90
|
// public mdsEditorInstance: MdsEditorInstanceService,
|
|
90
|
-
translate, ui, viewInstance, mdsViewerService) {
|
|
91
|
+
translate, ui, viewInstance, mdsViewerService, nodeHelper) {
|
|
91
92
|
this.translate = translate;
|
|
92
93
|
this.ui = ui;
|
|
93
94
|
this.viewInstance = viewInstance;
|
|
94
95
|
this.mdsViewerService = mdsViewerService;
|
|
96
|
+
this.nodeHelper = nodeHelper;
|
|
95
97
|
this.ROUTER_PREFIX = UIConstants.ROUTER_PREFIX;
|
|
96
98
|
this.valueType = ValueType.String;
|
|
97
99
|
this.showCaption = true;
|
|
@@ -99,28 +101,40 @@ export class MdsWidgetComponent {
|
|
|
99
101
|
* allow inline editing
|
|
100
102
|
*/
|
|
101
103
|
this.inlineEditing = 'auto';
|
|
102
|
-
this.
|
|
104
|
+
this.basicType = signal(null);
|
|
105
|
+
this.isEmpty = computed(() => {
|
|
106
|
+
if (this.basicType() === 'license') {
|
|
107
|
+
return false;
|
|
108
|
+
}
|
|
109
|
+
return this.value()?.every((v) => !v) || this.value()?.length === 0 || !this.value();
|
|
110
|
+
});
|
|
111
|
+
this.license$ = new BehaviorSubject(null);
|
|
112
|
+
this.value = signal(undefined);
|
|
103
113
|
this.temporaryValue = undefined;
|
|
104
114
|
// super(toast, null, translate);
|
|
105
115
|
}
|
|
106
116
|
async ngOnChanges(changes) {
|
|
107
|
-
this.value
|
|
117
|
+
this.value.set(await this.getNodeValue());
|
|
108
118
|
}
|
|
109
119
|
async ngOnInit() {
|
|
110
|
-
this.value
|
|
120
|
+
this.value.set(await this.getNodeValue());
|
|
111
121
|
this.widget
|
|
112
122
|
.getInitialDisplayValues()
|
|
113
123
|
.pipe(filter((v) => !!v))
|
|
114
124
|
.subscribe(async (value) => {
|
|
115
|
-
this.value
|
|
125
|
+
this.value.set(value.values.map((v) => v.displayString));
|
|
116
126
|
});
|
|
117
|
-
this.basicType
|
|
127
|
+
this.basicType.set(this.getBasicType());
|
|
118
128
|
this.rawValue = await this.getRawValue().toPromise();
|
|
119
129
|
}
|
|
120
130
|
getDefinition() {
|
|
121
131
|
return this.widget?.definition || this.definition;
|
|
122
132
|
}
|
|
123
133
|
getBasicType() {
|
|
134
|
+
switch (this.getDefinition().id) {
|
|
135
|
+
case 'license':
|
|
136
|
+
return 'license';
|
|
137
|
+
}
|
|
124
138
|
switch (this.getDefinition().type) {
|
|
125
139
|
case 'text':
|
|
126
140
|
case 'email':
|
|
@@ -156,7 +170,8 @@ export class MdsWidgetComponent {
|
|
|
156
170
|
}
|
|
157
171
|
getNodeValues() {
|
|
158
172
|
if (this.mdsEditorInstance) {
|
|
159
|
-
return this.mdsEditorInstance
|
|
173
|
+
return (this.mdsEditorInstance.values$.value ||
|
|
174
|
+
this.mdsEditorInstance.nodes$.value.map((n) => n.properties));
|
|
160
175
|
}
|
|
161
176
|
else {
|
|
162
177
|
return this.mdsViewerService.values$.value;
|
|
@@ -168,6 +183,14 @@ export class MdsWidgetComponent {
|
|
|
168
183
|
}
|
|
169
184
|
const id = this.getDefinition().id;
|
|
170
185
|
const values = this.getNodeValues();
|
|
186
|
+
if (this.getBasicType() === 'license') {
|
|
187
|
+
this.license$.next({
|
|
188
|
+
icon: await this.nodeHelper.getLicenseIcon({
|
|
189
|
+
properties: this.getNodeValues(),
|
|
190
|
+
}),
|
|
191
|
+
name: this.nodeHelper.getLicenseName({ properties: this.getNodeValues() }),
|
|
192
|
+
});
|
|
193
|
+
}
|
|
171
194
|
if (this.getDefinition().type === 'range') {
|
|
172
195
|
if (values) {
|
|
173
196
|
return [values[id + '_from']?.[0], values[id + '_to']?.[0]];
|
|
@@ -179,7 +202,7 @@ export class MdsWidgetComponent {
|
|
|
179
202
|
return this.getValue(values[id]);
|
|
180
203
|
}
|
|
181
204
|
else if ((await this.widget.getInitalValuesAsync())?.jointValues) {
|
|
182
|
-
return (
|
|
205
|
+
return (await this.widget.getInitalValuesAsync()).jointValues;
|
|
183
206
|
}
|
|
184
207
|
else {
|
|
185
208
|
return null;
|
|
@@ -211,11 +234,8 @@ export class MdsWidgetComponent {
|
|
|
211
234
|
console.warn('Unsupported link type ' + this.getDefinition().link);
|
|
212
235
|
}
|
|
213
236
|
}
|
|
214
|
-
isEmpty() {
|
|
215
|
-
return this.value?.every((v) => !v) || this.value?.length === 0 || !this.value;
|
|
216
|
-
}
|
|
217
237
|
formatDate() {
|
|
218
|
-
return this.value.map((v) => {
|
|
238
|
+
return this.value().map((v) => {
|
|
219
239
|
if (this.getDefinition().format) {
|
|
220
240
|
try {
|
|
221
241
|
return new DatePipe('en').transform(v, this.getDefinition().format);
|
|
@@ -235,7 +255,7 @@ export class MdsWidgetComponent {
|
|
|
235
255
|
});
|
|
236
256
|
}
|
|
237
257
|
formatNumber() {
|
|
238
|
-
return this.value.map((v) => {
|
|
258
|
+
return this.value().map((v) => {
|
|
239
259
|
if (this.widget.definition.format === 'bytes') {
|
|
240
260
|
return new FormatSizePipe(this.translate).transform(v);
|
|
241
261
|
}
|
|
@@ -243,7 +263,7 @@ export class MdsWidgetComponent {
|
|
|
243
263
|
});
|
|
244
264
|
}
|
|
245
265
|
formatText() {
|
|
246
|
-
return this.value.map((v) => {
|
|
266
|
+
return this.value().map((v) => {
|
|
247
267
|
if (this.widget.definition.format) {
|
|
248
268
|
return this.widget.definition.format.replace('${value}', v);
|
|
249
269
|
}
|
|
@@ -256,7 +276,7 @@ export class MdsWidgetComponent {
|
|
|
256
276
|
await this.mdsEditorInstance.saveWidgetValue(instance.widget);
|
|
257
277
|
}
|
|
258
278
|
this.temporaryValue = instance.widget.getValue();
|
|
259
|
-
this.value
|
|
279
|
+
this.value.set(await this.getNodeValue());
|
|
260
280
|
this.editWrapper.nativeElement.children[0].innerHTML = null;
|
|
261
281
|
await this.mdsEditorInstance.fetchDisplayValues(this.widget);
|
|
262
282
|
}
|
|
@@ -333,13 +353,13 @@ export class MdsWidgetComponent {
|
|
|
333
353
|
event.stopPropagation();
|
|
334
354
|
void this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);
|
|
335
355
|
}
|
|
336
|
-
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 }, { token: i4.MdsViewerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
337
|
-
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:
|
|
356
|
+
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 }, { token: i4.MdsViewerService }, { token: i5.NodeHelperService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
357
|
+
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() === 'license' && (license$ | async) as license\">\n <img alt=\"\" [src]=\"license.icon\" /> {{ license.name }}\n </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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i7.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i8.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i9.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: i10.MdsDurationPipe, name: "appMdsDuration" }, { kind: "pipe", type: i11.VCardNamePipe, name: "vcardName" }], changeDetection: i0.ChangeDetectionStrategy.Default }); }
|
|
338
358
|
}
|
|
339
359
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsWidgetComponent, decorators: [{
|
|
340
360
|
type: Component,
|
|
341
|
-
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"] }]
|
|
342
|
-
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.UIService }, { type: i3.ViewInstanceService }, { type: i4.MdsViewerService }], propDecorators: { widget: [{
|
|
361
|
+
args: [{ selector: 'es-mds-widget', changeDetection: ChangeDetectionStrategy.Default, 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() === 'license' && (license$ | async) as license\">\n <img alt=\"\" [src]=\"license.icon\" /> {{ license.name }}\n </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"] }]
|
|
362
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.UIService }, { type: i3.ViewInstanceService }, { type: i4.MdsViewerService }, { type: i5.NodeHelperService }], propDecorators: { widget: [{
|
|
343
363
|
type: Input
|
|
344
364
|
}], showCaption: [{
|
|
345
365
|
type: Input
|
|
@@ -356,4 +376,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
356
376
|
type: ViewChild,
|
|
357
377
|
args: [MatRipple]
|
|
358
378
|
}] } });
|
|
359
|
-
//# 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 { BehaviorSubject, Observable, of } from 'rxjs';\nimport { MdsViewerService } from '../mds-viewer.service';\nimport { Values } from '../../services/search-helper.service';\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}\nexport interface MdsViewerWidget {\n    definition: MdsWidget;\n    getInitalValuesAsync(): Promise<InitialValues>;\n    getInitialDisplayValues(): BehaviorSubject<MdsValueList>;\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 interface InitialValues {\n    /** Values that are initially present in all nodes. */\n    readonly jointValues: string[];\n    /**\n     * Values that are initially present in some but not all nodes.\n     *\n     * Can be null but will never be set to an empty array.\n     */\n    readonly individualValues?: string[];\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: MdsViewerWidget;\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        private mdsViewerService: MdsViewerService,\n    ) {\n        // super(toast, null, translate);\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        this.value = await this.getNodeValue();\n    }\n\n    async ngOnInit() {\n        this.value = await 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    private getNodeValues() {\n        if(this.mdsEditorInstance) {\n            return this.mdsEditorInstance?.values$.value as Values;\n        } else {\n            return this.mdsViewerService.values$.value;\n        }\n    }\n    private async getNodeValue() {\n        if (this.temporaryValue !== undefined) {\n            return this.getValue(this.temporaryValue);\n        }\n        const id = this.getDefinition().id;\n        const values = this.getNodeValues();\n        if (this.getDefinition().type === 'range') {\n            if (values) {\n                return [values[id + '_from']?.[0], values[id + '_to']?.[0]];\n            }\n            return null;\n        } else if (values?.[id]) {\n            // support on the fly changes+updates of the values\n            return this.getValue(values[id]);\n        } else if ((await this.widget.getInitalValuesAsync())?.jointValues) {\n            return ((await this.widget.getInitalValuesAsync()).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 = await 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"]}
|
|
379
|
+
//# 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    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    Input,\n    OnChanges,\n    OnInit,\n    signal,\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 { BehaviorSubject, of } from 'rxjs';\nimport { MdsViewerService } from '../mds-viewer.service';\nimport { Values } from '../../services/search-helper.service';\nimport { NodeHelperService } from '../../services/node-helper.service';\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}\nexport interface MdsViewerWidget {\n    definition: MdsWidget;\n    getInitalValuesAsync(): Promise<InitialValues>;\n    getInitialDisplayValues(): BehaviorSubject<MdsValueList>;\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 interface InitialValues {\n    /** Values that are initially present in all nodes. */\n    readonly jointValues: string[];\n    /**\n     * Values that are initially present in some but not all nodes.\n     *\n     * Can be null but will never be set to an empty array.\n     */\n    readonly individualValues?: string[];\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    changeDetection: ChangeDetectionStrategy.Default,\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: MdsViewerWidget;\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 = signal<string>(null);\n    rawValue: { path: MdsValue[]; id: string }[];\n\n    isEmpty = computed(() => {\n        if (this.basicType() === 'license') {\n            return false;\n        }\n        return this.value()?.every((v) => !v) || this.value()?.length === 0 || !this.value();\n    });\n    private mdsEditorInstance: any;\n    license$ = new BehaviorSubject<{ name: string; icon: string }>(null);\n\n    get headingLevel() {\n        return this.viewInstance.headingLevel;\n    }\n\n    value = signal<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        private mdsViewerService: MdsViewerService,\n        private nodeHelper: NodeHelperService,\n    ) {\n        // super(toast, null, translate);\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {\n        this.value.set(await this.getNodeValue());\n    }\n\n    async ngOnInit() {\n        this.value.set(await this.getNodeValue());\n        this.widget\n            .getInitialDisplayValues()\n            .pipe(filter((v: MdsValueList) => !!v))\n            .subscribe(async (value: MdsValueList) => {\n                this.value.set(value.values.map((v) => v.displayString));\n            });\n        this.basicType.set(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().id) {\n            case 'license':\n                return 'license';\n        }\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    private getNodeValues() {\n        if (this.mdsEditorInstance) {\n            return (\n                (this.mdsEditorInstance.values$.value as Values) ||\n                this.mdsEditorInstance.nodes$.value.map((n: Node) => n.properties)\n            );\n        } else {\n            return this.mdsViewerService.values$.value;\n        }\n    }\n    private async getNodeValue() {\n        if (this.temporaryValue !== undefined) {\n            return this.getValue(this.temporaryValue);\n        }\n        const id = this.getDefinition().id;\n        const values = this.getNodeValues();\n        if (this.getBasicType() === 'license') {\n            this.license$.next({\n                icon: await this.nodeHelper.getLicenseIcon({\n                    properties: this.getNodeValues(),\n                } as Node),\n                name: this.nodeHelper.getLicenseName({ properties: this.getNodeValues() } as Node),\n            });\n        }\n        if (this.getDefinition().type === 'range') {\n            if (values) {\n                return [values[id + '_from']?.[0], values[id + '_to']?.[0]];\n            }\n            return null;\n        } else if (values?.[id]) {\n            // support on the fly changes+updates of the values\n            return this.getValue(values[id]);\n        } else if ((await this.widget.getInitalValuesAsync())?.jointValues) {\n            return (await this.widget.getInitalValuesAsync()).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    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.set(await 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() === 'license' && (license$ | async) as license\">\n            <img alt=\"\" [src]=\"license.icon\" /> {{ license.name }}\n          </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"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Pipe } from '@angular/core';
|
|
2
2
|
import { RestConstants } from 'ngx-edu-sharing-api';
|
|
3
3
|
import { RestHelper } from '../util/rest-helper';
|
|
4
|
-
import { isString } from 'lodash';
|
|
4
|
+
import { isString } from 'lodash-es';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@ngx-translate/core";
|
|
7
7
|
export class NodeTitlePipe {
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
32
32
|
type: Pipe,
|
|
33
33
|
args: [{ name: 'nodeTitle' }]
|
|
34
34
|
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10aXRsZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9waXBlcy9ub2RlLXRpdGxlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixJQUFJLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFcEQsT0FBTyxFQUFRLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUVqRCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDOzs7QUFHckMsTUFBTSxPQUFPLGFBQWE7SUFDdEIsU0FBUyxDQUFDLElBQThCLEVBQUUsSUFBaUM7UUFDdkUsSUFBSSxDQUFFLElBQWEsRUFBRSxJQUFJLElBQUksUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDMUMsSUFBSSxJQUFJLEtBQUssTUFBTSxFQUFFLENBQUM7Z0JBQ2xCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxDQUFDO1lBQ3ZELENBQUM7WUFDRCxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsQ0FBQztRQUN2RCxDQUFDO1FBQ0QsTUFBTSxLQUFLLEdBQ1AsSUFBSSxFQUFFLElBQUksS0FBSyxNQUFNO1lBQ2pCLENBQUMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLElBQVksQ0FBQztZQUNsQyxDQUFDLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFZLENBQUMsQ0FBQztRQUM1QyxJQUFLLElBQWEsRUFBRSxVQUFVLEVBQUUsQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxDQUFDO1lBQy9ELE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQ3pCLFVBQVUsR0FBSSxJQUFhLEVBQUUsVUFBVSxFQUFFLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQzVFO2dCQUNJLFFBQVEsRUFBRSxLQUFLO2FBQ2xCLENBQ0osQ0FBQztRQUNOLENBQUM7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNqQixDQUFDO0lBQ0QsWUFBb0IsU0FBMkI7UUFBM0IsY0FBUyxHQUFULFNBQVMsQ0FBa0I7SUFBRyxDQUFDOytHQXRCMUMsYUFBYTs2R0FBYixhQUFhOzs0RkFBYixhQUFhO2tCQUR6QixJQUFJO21CQUFDLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGVUcmFuc2Zvcm0sIFBpcGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IE5vZGUsIFJlc3RDb25zdGFudHMgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IFJlc3RIZWxwZXIgfSBmcm9tICcuLi91dGlsL3Jlc3QtaGVscGVyJztcbmltcG9ydCB7IE5vZGVSb290IH0gZnJvbSAnLi4vbm9kZS1lbnRyaWVzL2VudHJpZXMtbW9kZWwnO1xuaW1wb3J0IHsgaXNTdHJpbmcgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5AUGlwZSh7IG5hbWU6ICdub2RlVGl0bGUnIH0pXG5leHBvcnQgY2xhc3MgTm9kZVRpdGxlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIHRyYW5zZm9ybShub2RlOiBOb2RlIHwgTm9kZVJvb3QgfCAnSE9NRScsIGFyZ3M/OiB7IHR5cGU6ICduYW1lJyB8ICd0aXRsZScgfSk6IHN0cmluZyB7XG4gICAgICAgIGlmICghKG5vZGUgYXMgTm9kZSk/Lm5hbWUgJiYgaXNTdHJpbmcobm9kZSkpIHtcbiAgICAgICAgICAgIGlmIChub2RlID09PSAnSE9NRScpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy50cmFuc2xhdGUuaW5zdGFudCgnV09SS1NQQUNFLicgKyBub2RlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KCdXT1JLU1BBQ0UuJyArIG5vZGUpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHZhbHVlID1cbiAgICAgICAgICAgIGFyZ3M/LnR5cGUgPT09ICduYW1lJ1xuICAgICAgICAgICAgICAgID8gUmVzdEhlbHBlci5nZXROYW1lKG5vZGUgYXMgTm9kZSlcbiAgICAgICAgICAgICAgICA6IFJlc3RIZWxwZXIuZ2V0VGl0bGUobm9kZSBhcyBOb2RlKTtcbiAgICAgICAgaWYgKChub2RlIGFzIE5vZGUpPy5wcm9wZXJ0aWVzPy5bUmVzdENvbnN0YW50cy5DQ01fUFJPUF9NQVBUWVBFXSkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRlLmluc3RhbnQoXG4gICAgICAgICAgICAgICAgJ01BUFRZUEUuJyArIChub2RlIGFzIE5vZGUpPy5wcm9wZXJ0aWVzPy5bUmVzdENvbnN0YW50cy5DQ01fUFJPUF9NQVBUWVBFXVswXSxcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGZhbGxiYWNrOiB2YWx1ZSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfVxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlKSB7fVxufVxuIl19
|
|
@@ -11,10 +11,8 @@ export class SpinnerSmallComponent {
|
|
|
11
11
|
}
|
|
12
12
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SpinnerSmallComponent, decorators: [{
|
|
13
13
|
type: Component,
|
|
14
|
-
args: [{ selector: 'es-spinner-small', standalone: true, imports: [
|
|
15
|
-
MatProgressSpinnerModule,
|
|
16
|
-
], template: "<mat-progress-spinner\n color=\"primary\"\n mode=\"indeterminate\"\n [diameter]=\"diameter\"\n></mat-progress-spinner>\n" }]
|
|
14
|
+
args: [{ selector: 'es-spinner-small', standalone: true, imports: [MatProgressSpinnerModule], template: "<mat-progress-spinner\n color=\"primary\"\n mode=\"indeterminate\"\n [diameter]=\"diameter\"\n></mat-progress-spinner>\n" }]
|
|
17
15
|
}], ctorParameters: () => [], propDecorators: { diameter: [{
|
|
18
16
|
type: Input
|
|
19
17
|
}] } });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci1zbWFsbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXItc21hbGwvc3Bpbm5lci1zbWFsbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3NwaW5uZXItc21hbGwvc3Bpbm5lci1zbWFsbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQzs7O0FBUzlFLE1BQU0sT0FBTyxxQkFBcUI7SUFFOUI7UUFEUyxhQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ1IsQ0FBQzsrR0FGUCxxQkFBcUI7bUdBQXJCLHFCQUFxQiw4R0NWbEMsNkhBS0EseURER2Msd0JBQXdCOzs0RkFFekIscUJBQXFCO2tCQVBqQyxTQUFTOytCQUNJLGtCQUFrQixjQUdoQixJQUFJLFdBQ1AsQ0FBQyx3QkFBd0IsQ0FBQzt3REFHMUIsUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2VzLXNwaW5uZXItc21hbGwnLFxuICAgIHRlbXBsYXRlVXJsOiAnc3Bpbm5lci1zbWFsbC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ3NwaW5uZXItc21hbGwuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBTcGlubmVyU21hbGxDb21wb25lbnQge1xuICAgIEBJbnB1dCgpIGRpYW1ldGVyID0gMjA7XG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIiwiPG1hdC1wcm9ncmVzcy1zcGlubmVyXG4gIGNvbG9yPVwicHJpbWFyeVwiXG4gIG1vZGU9XCJpbmRldGVybWluYXRlXCJcbiAgW2RpYW1ldGVyXT1cImRpYW1ldGVyXCJcbj48L21hdC1wcm9ncmVzcy1zcGlubmVyPlxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { isNumeric } from './isNumeric';
|
|
2
|
-
import { isArray } from 'lodash';
|
|
2
|
+
import { isArray } from 'lodash-es';
|
|
3
3
|
export class Helper {
|
|
4
4
|
static deepCopy(data) {
|
|
5
5
|
if (data == null)
|
|
@@ -61,4 +61,4 @@ export class Helper {
|
|
|
61
61
|
return obj;
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi91dGlsL2hlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFcEMsTUFBTSxPQUFPLE1BQU07SUFDUixNQUFNLENBQUMsUUFBUSxDQUFDLElBQVM7UUFDNUIsSUFBSSxJQUFJLElBQUksSUFBSTtZQUFFLE9BQU8sSUFBSSxDQUFDO1FBQzlCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVNLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBVztRQUNuQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7WUFBRSxPQUFPLElBQUksQ0FBQztRQUN0QyxPQUFPLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0ksTUFBTSxDQUFDLFlBQVksQ0FBQyxPQUFZLEVBQUUsT0FBWTtRQUNqRCxJQUFJLE9BQU8sSUFBSSxJQUFJO1lBQUUsT0FBTyxPQUFPLElBQUksSUFBSSxDQUFDO1FBQzVDLElBQUksT0FBTyxJQUFJLElBQUk7WUFBRSxPQUFPLE9BQU8sSUFBSSxJQUFJLENBQUM7UUFDNUMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ksTUFBTSxDQUFDLDBCQUEwQixDQUFDLE1BQVcsRUFBRSxJQUFZO1FBQzlELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDOUIsSUFBSSxHQUFHLEdBQUcsTUFBTSxDQUFDO1FBQ2pCLEtBQUssSUFBSSxHQUFHLElBQUksS0FBSyxFQUFFLENBQUM7WUFDcEIsSUFBSSxTQUFTLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDakIsR0FBRyxHQUFHLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1lBQy9CLENBQUM7aUJBQU0sQ0FBQztnQkFDSixJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO29CQUNmLE9BQU8sR0FBRyxDQUFDO2dCQUNmLENBQUM7Z0JBQ0QsR0FBRyxHQUFHLEdBQUcsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3JCLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxHQUFHLENBQUM7SUFDZixDQUFDO0lBQ00sTUFBTSxDQUFDLDBCQUEwQixDQUFDLEdBQVEsRUFBRSxRQUFrQjtRQUNqRSxLQUFLLElBQUksQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBQ2hCLElBQUksQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQztnQkFBRSxTQUFTO1lBQ3JDLElBQUksUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUN2QixPQUFPLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQixDQUFDO2lCQUFNLElBQUksT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssUUFBUSxFQUFFLENBQUM7Z0JBQ3BDLE1BQU0sQ0FBQywwQkFBMEIsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQUM7WUFDeEQsQ0FBQztRQUNMLENBQUM7UUFDRCxPQUFPLEdBQUcsQ0FBQztJQUNmLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzTnVtZXJpYyB9IGZyb20gJy4vaXNOdW1lcmljJztcbmltcG9ydCB7IGlzQXJyYXkgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5leHBvcnQgY2xhc3MgSGVscGVyIHtcbiAgICBwdWJsaWMgc3RhdGljIGRlZXBDb3B5KGRhdGE6IGFueSkge1xuICAgICAgICBpZiAoZGF0YSA9PSBudWxsKSByZXR1cm4gbnVsbDtcbiAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkoZGF0YSkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgZGVlcENvcHlBcnJheShkYXRhOiBhbnlbXSkge1xuICAgICAgICBpZiAoIUFycmF5LmlzQXJyYXkoZGF0YSkpIHJldHVybiBkYXRhO1xuICAgICAgICByZXR1cm4gZGF0YS5zbGljZSgpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFJldHVybnMgdHJ1ZSBpZiBib3RoIG9iamVjdHMgaGF2ZSB0aGUgc2FtZSB2YWx1ZXMgc3RvcmVkXG4gICAgICogd2lsbCBub3Qgd29yayBmb3IgY2xhc3NlcyBpbmNsdWRpbmcgbWV0aG9kcyBvciBzaW1pbGFyIGR5bmFtaWMgZGF0YVxuICAgICAqIEBwYXJhbSBvYmplY3QxXG4gICAgICogQHBhcmFtIG9iamVjdDJcbiAgICAgKiBAcmV0dXJucyB7Ym9vbGVhbn1cbiAgICAgKi9cbiAgICBwdWJsaWMgc3RhdGljIG9iamVjdEVxdWFscyhvYmplY3QxOiBhbnksIG9iamVjdDI6IGFueSkge1xuICAgICAgICBpZiAob2JqZWN0MSA9PSBudWxsKSByZXR1cm4gb2JqZWN0MiA9PSBudWxsO1xuICAgICAgICBpZiAob2JqZWN0MiA9PSBudWxsKSByZXR1cm4gb2JqZWN0MSA9PSBudWxsO1xuICAgICAgICByZXR1cm4gSlNPTi5zdHJpbmdpZnkob2JqZWN0MSkgPT0gSlNPTi5zdHJpbmdpZnkob2JqZWN0Mik7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogZ2V0IGRhdGEgZnJvbSBhbiBvYmplY3QgYmFzZWQgb24gYSBkb3R0ZWQgcGF0aFxuICAgICAqIGFsc28gc3VwcG9ydHMgYXJyYXlzIGxpa2UgXCJhcnJheS4wLmtleVwiXG4gICAgICogQHBhcmFtIG5lc3RlZCB0aGUgb2JqZWN0IHRvIHJldHVybiB0aGUgZGF0YSBmcm9tXG4gICAgICogQHBhcmFtIHBhdGggdGhlIHBhdGggb2YgdGhlIGZpZWxkIGxvY2F0aW9uIGluIGRvdHRlZCBub3RhdGlvblxuICAgICAqL1xuICAgIHB1YmxpYyBzdGF0aWMgZ2V0RG90UGF0aEZyb21OZXN0ZWRPYmplY3QobmVzdGVkOiBhbnksIHBhdGg6IHN0cmluZykge1xuICAgICAgICBjb25zdCBzcGxpdCA9IHBhdGguc3BsaXQoJy4nKTtcbiAgICAgICAgbGV0IG9iaiA9IG5lc3RlZDtcbiAgICAgICAgZm9yIChsZXQga2V5IG9mIHNwbGl0KSB7XG4gICAgICAgICAgICBpZiAoaXNOdW1lcmljKGtleSkpIHtcbiAgICAgICAgICAgICAgICBvYmogPSBvYmo/LltwYXJzZUludChrZXkpXTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgaWYgKGlzQXJyYXkob2JqKSkge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gb2JqO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBvYmogPSBvYmo/LltrZXldO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBvYmo7XG4gICAgfVxuICAgIHB1YmxpYyBzdGF0aWMgZmlsdGVyT2JqZWN0UHJvcGVydHlOZXN0ZWQob2JqOiBhbnksIHByb3BlcnR5OiBzdHJpbmdbXSkge1xuICAgICAgICBmb3IgKGxldCBpIGluIG9iaikge1xuICAgICAgICAgICAgaWYgKCFvYmouaGFzT3duUHJvcGVydHkoaSkpIGNvbnRpbnVlO1xuICAgICAgICAgICAgaWYgKHByb3BlcnR5LmluY2x1ZGVzKGkpKSB7XG4gICAgICAgICAgICAgICAgZGVsZXRlIG9ialtpXTtcbiAgICAgICAgICAgIH0gZWxzZSBpZiAodHlwZW9mIG9ialtpXSA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgICAgICBIZWxwZXIuZmlsdGVyT2JqZWN0UHJvcGVydHlOZXN0ZWQob2JqW2ldLCBwcm9wZXJ0eSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG9iajtcbiAgICB9XG59XG4iXX0=
|