ngx-edu-sharing-ui 10.0.20 → 10.0.22
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/material-theme.scss +3 -3
- package/assets/scss/mixins.scss +1 -1
- package/assets/scss/variables-root.scss +2 -0
- package/assets/scss/variables-scss.scss +3 -4
- package/assets/scss/variables.scss +1 -1
- package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/list-items/list-widget.d.ts +1 -1
- package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
- package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
- package/package.json +8 -9
- package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
- package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
- package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
- package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
- package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
- package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
- package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
- package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
- package/esm2022/lib/directives/icon.directive.mjs +0 -184
- package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
- package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
- package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
- package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
- package/esm2022/lib/index.mjs +0 -96
- package/esm2022/lib/list-items/available-widgets.mjs +0 -27
- package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
- package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
- package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
- package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
- package/esm2022/lib/list-items/list-items.module.mjs +0 -50
- package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
- package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
- package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
- package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
- package/esm2022/lib/list-items/list-widget.mjs +0 -49
- package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
- package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
- package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
- package/esm2022/lib/mds/mds.module.mjs +0 -16
- package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
- package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
- package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
- package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
- package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
- package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
- package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
- package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
- package/esm2022/lib/node-entries/entries-model.mjs +0 -24
- package/esm2022/lib/node-entries/items-cap.mjs +0 -47
- package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
- package/esm2022/lib/node-entries/node-cache.mjs +0 -73
- package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
- package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
- package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
- package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
- package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
- package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
- package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
- package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
- package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
- package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
- package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
- package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
- package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
- package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
- package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
- package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
- package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
- package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
- package/esm2022/lib/node-url/node-url.component.mjs +0 -132
- package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
- package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
- package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
- package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
- package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
- package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
- package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
- package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
- package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
- package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
- package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
- package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
- package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
- package/esm2022/lib/services/abstract/app.service.mjs +0 -3
- package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
- package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
- package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
- package/esm2022/lib/services/accessibility.service.mjs +0 -73
- package/esm2022/lib/services/app-container.service.mjs +0 -69
- package/esm2022/lib/services/local-events.service.mjs +0 -43
- package/esm2022/lib/services/node-entries.service.mjs +0 -201
- package/esm2022/lib/services/node-helper.service.mjs +0 -330
- package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
- package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
- package/esm2022/lib/services/render-helper.service.mjs +0 -114
- package/esm2022/lib/services/repo-url.service.mjs +0 -50
- package/esm2022/lib/services/search-helper.service.mjs +0 -52
- package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
- package/esm2022/lib/services/ui.service.mjs +0 -327
- package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
- package/esm2022/lib/spinner/spinner.component.mjs +0 -19
- package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
- package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
- package/esm2022/lib/translations/translation-loader.mjs +0 -219
- package/esm2022/lib/translations/translation-source.mjs +0 -11
- package/esm2022/lib/translations/translations.module.mjs +0 -82
- package/esm2022/lib/translations/translations.service.mjs +0 -238
- package/esm2022/lib/types/accessibillity.mjs +0 -19
- package/esm2022/lib/types/api-models.mjs +0 -2
- package/esm2022/lib/types/drag-drop.mjs +0 -2
- package/esm2022/lib/types/injection-tokens.mjs +0 -31
- package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
- package/esm2022/lib/types/list-item.mjs +0 -41
- package/esm2022/lib/types/option-item.mjs +0 -192
- package/esm2022/lib/types/workflow.mjs +0 -25
- package/esm2022/lib/util/DateHelper.mjs +0 -200
- package/esm2022/lib/util/VCard.mjs +0 -278
- package/esm2022/lib/util/color-helper.mjs +0 -124
- package/esm2022/lib/util/duration-helper.mjs +0 -102
- package/esm2022/lib/util/functions.mjs +0 -13
- package/esm2022/lib/util/helper.mjs +0 -64
- package/esm2022/lib/util/isNumeric.mjs +0 -11
- package/esm2022/lib/util/rest-helper.mjs +0 -42
- package/esm2022/lib/util/ui-animation.mjs +0 -146
- package/esm2022/lib/util/ui-constants.mjs +0 -21
- package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
- package/esm2022/public-api.mjs +0 -2
|
@@ -1,379 +0,0 @@
|
|
|
1
|
-
import { DatePipe } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, computed, Input, signal, 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 { BehaviorSubject, 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 "../mds-viewer.service";
|
|
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";
|
|
23
|
-
export var MdsType;
|
|
24
|
-
(function (MdsType) {
|
|
25
|
-
MdsType["Io"] = "io";
|
|
26
|
-
MdsType["IoBulk"] = "io_bulk";
|
|
27
|
-
MdsType["Map"] = "map";
|
|
28
|
-
MdsType["MapRef"] = "map_ref";
|
|
29
|
-
MdsType["IoChildObject"] = "io_childobject";
|
|
30
|
-
MdsType["Collection"] = "collection";
|
|
31
|
-
MdsType["ToolDefinition"] = "tool_definition";
|
|
32
|
-
MdsType["ToolInstance"] = "tool_instance";
|
|
33
|
-
MdsType["SavedSearch"] = "saved_search";
|
|
34
|
-
})(MdsType || (MdsType = {}));
|
|
35
|
-
export var MdsWidgetType;
|
|
36
|
-
(function (MdsWidgetType) {
|
|
37
|
-
MdsWidgetType["Text"] = "text";
|
|
38
|
-
MdsWidgetType["Number"] = "number";
|
|
39
|
-
MdsWidgetType["Email"] = "email";
|
|
40
|
-
MdsWidgetType["Date"] = "date";
|
|
41
|
-
MdsWidgetType["Month"] = "month";
|
|
42
|
-
MdsWidgetType["Color"] = "color";
|
|
43
|
-
MdsWidgetType["Textarea"] = "textarea";
|
|
44
|
-
MdsWidgetType["TinyMCE"] = "tinyMCE";
|
|
45
|
-
MdsWidgetType["VCard"] = "vcard";
|
|
46
|
-
MdsWidgetType["Checkbox"] = "checkbox";
|
|
47
|
-
MdsWidgetType["RadioHorizontal"] = "radioHorizontal";
|
|
48
|
-
MdsWidgetType["RadioVertical"] = "radioVertical";
|
|
49
|
-
MdsWidgetType["CheckboxHorizontal"] = "checkboxHorizontal";
|
|
50
|
-
MdsWidgetType["CheckboxVertical"] = "checkboxVertical";
|
|
51
|
-
MdsWidgetType["MultiValueBadges"] = "multivalueBadges";
|
|
52
|
-
MdsWidgetType["MultiValueFixedBadges"] = "multivalueFixedBadges";
|
|
53
|
-
MdsWidgetType["MultiValueSuggestBadges"] = "multivalueSuggestBadges";
|
|
54
|
-
MdsWidgetType["MultiValueAuthorityBadges"] = "multivalueAuthorityBadges";
|
|
55
|
-
MdsWidgetType["Singleoption"] = "singleoption";
|
|
56
|
-
MdsWidgetType["Slider"] = "slider";
|
|
57
|
-
MdsWidgetType["Range"] = "range";
|
|
58
|
-
MdsWidgetType["Duration"] = "duration";
|
|
59
|
-
MdsWidgetType["SingleValueTree"] = "singlevalueTree";
|
|
60
|
-
MdsWidgetType["SingleValueSuggestBadges"] = "singlevalueSuggestBadges";
|
|
61
|
-
MdsWidgetType["MultiValueTree"] = "multivalueTree";
|
|
62
|
-
MdsWidgetType["DefaultValue"] = "defaultvalue";
|
|
63
|
-
MdsWidgetType["FacetList"] = "facetList";
|
|
64
|
-
})(MdsWidgetType || (MdsWidgetType = {}));
|
|
65
|
-
export var ValueType;
|
|
66
|
-
(function (ValueType) {
|
|
67
|
-
ValueType[ValueType["String"] = 0] = "String";
|
|
68
|
-
ValueType[ValueType["MultiValue"] = 1] = "MultiValue";
|
|
69
|
-
ValueType[ValueType["Range"] = 2] = "Range";
|
|
70
|
-
})(ValueType || (ValueType = {}));
|
|
71
|
-
export class MdsWidgetComponent {
|
|
72
|
-
static { this.inlineEditing = [
|
|
73
|
-
MdsWidgetType.Text,
|
|
74
|
-
MdsWidgetType.Number,
|
|
75
|
-
MdsWidgetType.Date,
|
|
76
|
-
MdsWidgetType.Email,
|
|
77
|
-
MdsWidgetType.Textarea,
|
|
78
|
-
MdsWidgetType.Singleoption,
|
|
79
|
-
MdsWidgetType.SingleValueTree,
|
|
80
|
-
MdsWidgetType.SingleValueSuggestBadges,
|
|
81
|
-
MdsWidgetType.MultiValueBadges,
|
|
82
|
-
MdsWidgetType.MultiValueFixedBadges,
|
|
83
|
-
MdsWidgetType.MultiValueSuggestBadges,
|
|
84
|
-
MdsWidgetType.MultiValueTree,
|
|
85
|
-
]; }
|
|
86
|
-
get headingLevel() {
|
|
87
|
-
return this.viewInstance.headingLevel;
|
|
88
|
-
}
|
|
89
|
-
constructor(
|
|
90
|
-
// public mdsEditorInstance: MdsEditorInstanceService,
|
|
91
|
-
translate, ui, viewInstance, mdsViewerService, nodeHelper) {
|
|
92
|
-
this.translate = translate;
|
|
93
|
-
this.ui = ui;
|
|
94
|
-
this.viewInstance = viewInstance;
|
|
95
|
-
this.mdsViewerService = mdsViewerService;
|
|
96
|
-
this.nodeHelper = nodeHelper;
|
|
97
|
-
this.ROUTER_PREFIX = UIConstants.ROUTER_PREFIX;
|
|
98
|
-
this.valueType = ValueType.String;
|
|
99
|
-
this.showCaption = true;
|
|
100
|
-
/**
|
|
101
|
-
* allow inline editing
|
|
102
|
-
*/
|
|
103
|
-
this.inlineEditing = 'auto';
|
|
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);
|
|
113
|
-
this.temporaryValue = undefined;
|
|
114
|
-
// super(toast, null, translate);
|
|
115
|
-
}
|
|
116
|
-
async ngOnChanges(changes) {
|
|
117
|
-
this.value.set(await this.getNodeValue());
|
|
118
|
-
}
|
|
119
|
-
async ngOnInit() {
|
|
120
|
-
this.value.set(await this.getNodeValue());
|
|
121
|
-
this.widget
|
|
122
|
-
.getInitialDisplayValues()
|
|
123
|
-
.pipe(filter((v) => !!v))
|
|
124
|
-
.subscribe(async (value) => {
|
|
125
|
-
this.value.set(value.values.map((v) => v.displayString));
|
|
126
|
-
});
|
|
127
|
-
this.basicType.set(this.getBasicType());
|
|
128
|
-
this.rawValue = await this.getRawValue().toPromise();
|
|
129
|
-
}
|
|
130
|
-
getDefinition() {
|
|
131
|
-
return this.widget?.definition || this.definition;
|
|
132
|
-
}
|
|
133
|
-
getBasicType() {
|
|
134
|
-
switch (this.getDefinition().id) {
|
|
135
|
-
case 'license':
|
|
136
|
-
return 'license';
|
|
137
|
-
}
|
|
138
|
-
switch (this.getDefinition().type) {
|
|
139
|
-
case 'text':
|
|
140
|
-
case 'email':
|
|
141
|
-
case 'month':
|
|
142
|
-
case 'color':
|
|
143
|
-
case 'textarea':
|
|
144
|
-
case 'singleoption':
|
|
145
|
-
return 'text';
|
|
146
|
-
case 'number':
|
|
147
|
-
return 'number';
|
|
148
|
-
case 'date':
|
|
149
|
-
return 'date';
|
|
150
|
-
case 'vcard':
|
|
151
|
-
return 'vcard';
|
|
152
|
-
case 'multivalueFixedBadges':
|
|
153
|
-
case 'multivalueSuggestBadges':
|
|
154
|
-
case 'singlevalueSuggestBadges':
|
|
155
|
-
case 'multivalueBadges':
|
|
156
|
-
case 'singlevalueTree':
|
|
157
|
-
case 'multivalueTree':
|
|
158
|
-
return this.viewInstance.treeDisplay === 'flat' ? 'array' : 'tree';
|
|
159
|
-
case 'slider':
|
|
160
|
-
return 'slider';
|
|
161
|
-
case 'duration':
|
|
162
|
-
return 'duration';
|
|
163
|
-
case 'range':
|
|
164
|
-
return 'range';
|
|
165
|
-
}
|
|
166
|
-
return 'unknown';
|
|
167
|
-
}
|
|
168
|
-
supportsInlineEditing() {
|
|
169
|
-
return MdsWidgetComponent.inlineEditing.includes(this.widget?.definition.type);
|
|
170
|
-
}
|
|
171
|
-
getNodeValues() {
|
|
172
|
-
if (this.mdsEditorInstance) {
|
|
173
|
-
return (this.mdsEditorInstance.values$.value ||
|
|
174
|
-
this.mdsEditorInstance.nodes$.value.map((n) => n.properties));
|
|
175
|
-
}
|
|
176
|
-
else {
|
|
177
|
-
return this.mdsViewerService.values$.value;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
async getNodeValue() {
|
|
181
|
-
if (this.temporaryValue !== undefined) {
|
|
182
|
-
return this.getValue(this.temporaryValue);
|
|
183
|
-
}
|
|
184
|
-
const id = this.getDefinition().id;
|
|
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
|
-
}
|
|
194
|
-
if (this.getDefinition().type === 'range') {
|
|
195
|
-
if (values) {
|
|
196
|
-
return [values[id + '_from']?.[0], values[id + '_to']?.[0]];
|
|
197
|
-
}
|
|
198
|
-
return null;
|
|
199
|
-
}
|
|
200
|
-
else if (values?.[id]) {
|
|
201
|
-
// support on the fly changes+updates of the values
|
|
202
|
-
return this.getValue(values[id]);
|
|
203
|
-
}
|
|
204
|
-
else if ((await this.widget.getInitalValuesAsync())?.jointValues) {
|
|
205
|
-
return (await this.widget.getInitalValuesAsync()).jointValues;
|
|
206
|
-
}
|
|
207
|
-
else {
|
|
208
|
-
return null;
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
getValue(data) {
|
|
212
|
-
let value = data;
|
|
213
|
-
if (!value || value.every((v) => !v)) {
|
|
214
|
-
return null;
|
|
215
|
-
}
|
|
216
|
-
if (this.getDefinition().values) {
|
|
217
|
-
const mapping = this.widget.definition.values
|
|
218
|
-
.filter((v) => data.filter((d) => d === v.id).length > 0)
|
|
219
|
-
.map((v) => v.caption);
|
|
220
|
-
if (mapping) {
|
|
221
|
-
return mapping;
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
return data;
|
|
225
|
-
}
|
|
226
|
-
click() {
|
|
227
|
-
if (this.getDefinition().link === '_BLANK') {
|
|
228
|
-
window.open(this.formatText()[0]);
|
|
229
|
-
}
|
|
230
|
-
else if (this.getDefinition().link === '_SELF') {
|
|
231
|
-
window.location.href = this.formatText()[0];
|
|
232
|
-
}
|
|
233
|
-
else {
|
|
234
|
-
console.warn('Unsupported link type ' + this.getDefinition().link);
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
formatDate() {
|
|
238
|
-
return this.value().map((v) => {
|
|
239
|
-
if (this.getDefinition().format) {
|
|
240
|
-
try {
|
|
241
|
-
return new DatePipe('en').transform(v, this.getDefinition().format);
|
|
242
|
-
}
|
|
243
|
-
catch (e) {
|
|
244
|
-
console.warn('Could not format date', e, this.getDefinition());
|
|
245
|
-
return DateHelper.formatDate(this.translate, v, {
|
|
246
|
-
showAlwaysTime: true,
|
|
247
|
-
});
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
else {
|
|
251
|
-
return DateHelper.formatDate(this.translate, v, {
|
|
252
|
-
showAlwaysTime: true,
|
|
253
|
-
});
|
|
254
|
-
}
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
formatNumber() {
|
|
258
|
-
return this.value().map((v) => {
|
|
259
|
-
if (this.widget.definition.format === 'bytes') {
|
|
260
|
-
return new FormatSizePipe(this.translate).transform(v);
|
|
261
|
-
}
|
|
262
|
-
return v;
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
formatText() {
|
|
266
|
-
return this.value().map((v) => {
|
|
267
|
-
if (this.widget.definition.format) {
|
|
268
|
-
return this.widget.definition.format.replace('${value}', v);
|
|
269
|
-
}
|
|
270
|
-
return v;
|
|
271
|
-
});
|
|
272
|
-
}
|
|
273
|
-
// instance: MdsEditorWidgetBase
|
|
274
|
-
async finishEdit(instance, store = false) {
|
|
275
|
-
if (store) {
|
|
276
|
-
await this.mdsEditorInstance.saveWidgetValue(instance.widget);
|
|
277
|
-
}
|
|
278
|
-
this.temporaryValue = instance.widget.getValue();
|
|
279
|
-
this.value.set(await this.getNodeValue());
|
|
280
|
-
this.editWrapper.nativeElement.children[0].innerHTML = null;
|
|
281
|
-
await this.mdsEditorInstance.fetchDisplayValues(this.widget);
|
|
282
|
-
}
|
|
283
|
-
isEditable() {
|
|
284
|
-
if (!this.mdsEditorInstance) {
|
|
285
|
-
return false;
|
|
286
|
-
}
|
|
287
|
-
if (this.inlineEditing === 'always') {
|
|
288
|
-
return this.supportsInlineEditing();
|
|
289
|
-
}
|
|
290
|
-
const nodes = this.mdsEditorInstance.nodes$.value;
|
|
291
|
-
return (this.mdsEditorInstance.editorMode === 'inline' &&
|
|
292
|
-
this.widget.definition.interactionType === 'Input' &&
|
|
293
|
-
nodes?.length === 1 &&
|
|
294
|
-
RestHelper.hasAccessPermission(nodes[0], RestConstants.ACCESS_WRITE) &&
|
|
295
|
-
this.supportsInlineEditing());
|
|
296
|
-
}
|
|
297
|
-
async focus() {
|
|
298
|
-
// this.matRipple.launch({});
|
|
299
|
-
await this.ui.scrollSmoothElementToChild(this.editWrapper.nativeElement);
|
|
300
|
-
this.matRipple.launch({});
|
|
301
|
-
//const result = await this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);
|
|
302
|
-
//await this.ui.scrollSmoothElementToChild(result.htmlElement);
|
|
303
|
-
}
|
|
304
|
-
/**
|
|
305
|
-
* return the path for a given value in a tree
|
|
306
|
-
*/
|
|
307
|
-
getPath(v) {
|
|
308
|
-
if (!this.getDefinition().values) {
|
|
309
|
-
return [
|
|
310
|
-
{
|
|
311
|
-
id: v,
|
|
312
|
-
caption: v,
|
|
313
|
-
},
|
|
314
|
-
];
|
|
315
|
-
}
|
|
316
|
-
const path = [];
|
|
317
|
-
let pointer = v;
|
|
318
|
-
for (let i = 0; i < 100; i++) {
|
|
319
|
-
const mapped = this.getDefinition().values.find((w) => w.id === pointer);
|
|
320
|
-
if (mapped) {
|
|
321
|
-
path.push(mapped);
|
|
322
|
-
pointer = mapped.parent;
|
|
323
|
-
}
|
|
324
|
-
else {
|
|
325
|
-
break;
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
return path.reverse();
|
|
329
|
-
}
|
|
330
|
-
/**
|
|
331
|
-
* fetch the raw node value
|
|
332
|
-
* Note: Will not work in a bulk state!
|
|
333
|
-
*/
|
|
334
|
-
getRawValue() {
|
|
335
|
-
return (this.mdsEditorInstance?.nodes$.pipe(first(), map((v) => v?.[0]?.properties[this.widget.definition.id]?.map((id) => {
|
|
336
|
-
return {
|
|
337
|
-
id,
|
|
338
|
-
path: this.getPath(id),
|
|
339
|
-
};
|
|
340
|
-
}))) || of(null));
|
|
341
|
-
}
|
|
342
|
-
getSearchParams(key) {
|
|
343
|
-
const params = {};
|
|
344
|
-
const mds = {};
|
|
345
|
-
mds[this.widget.definition.id] = [key.id];
|
|
346
|
-
params.mds = this.mdsEditorInstance.mdsId;
|
|
347
|
-
params.sidenav = true;
|
|
348
|
-
params.repo = this.mdsEditorInstance.nodes$.value?.[0].ref.repo;
|
|
349
|
-
params.filters = JSON.stringify(mds);
|
|
350
|
-
return params;
|
|
351
|
-
}
|
|
352
|
-
startEdit(event) {
|
|
353
|
-
event.stopPropagation();
|
|
354
|
-
void this.view.injectEditField(this, this.editWrapper.nativeElement.children[0]);
|
|
355
|
-
}
|
|
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 }); }
|
|
358
|
-
}
|
|
359
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsWidgetComponent, decorators: [{
|
|
360
|
-
type: Component,
|
|
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: [{
|
|
363
|
-
type: Input
|
|
364
|
-
}], showCaption: [{
|
|
365
|
-
type: Input
|
|
366
|
-
}], inlineEditing: [{
|
|
367
|
-
type: Input
|
|
368
|
-
}], definition: [{
|
|
369
|
-
type: Input
|
|
370
|
-
}], view: [{
|
|
371
|
-
type: Input
|
|
372
|
-
}], editWrapper: [{
|
|
373
|
-
type: ViewChild,
|
|
374
|
-
args: ['editWrapper']
|
|
375
|
-
}], matRipple: [{
|
|
376
|
-
type: ViewChild,
|
|
377
|
-
args: [MatRipple]
|
|
378
|
-
}] } });
|
|
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,41 +0,0 @@
|
|
|
1
|
-
import { of } from 'rxjs';
|
|
2
|
-
import { NodeDataSource } from './node-data-source';
|
|
3
|
-
/**
|
|
4
|
-
* data source which joins multiple underlying data sources
|
|
5
|
-
* used for the "all" search
|
|
6
|
-
*/
|
|
7
|
-
export class CombinedDataSource extends NodeDataSource {
|
|
8
|
-
constructor(dataSources) {
|
|
9
|
-
super();
|
|
10
|
-
this.dataSources = dataSources;
|
|
11
|
-
}
|
|
12
|
-
connect() {
|
|
13
|
-
// @TODO: Using a forkJoin and real connect would be better
|
|
14
|
-
return of(this.getData());
|
|
15
|
-
/*
|
|
16
|
-
return forkJoin(this.dataSources.map(ds => ds.connect())).pipe(
|
|
17
|
-
switchMap(d => d)
|
|
18
|
-
) as Observable<T[]>;
|
|
19
|
-
*/
|
|
20
|
-
}
|
|
21
|
-
disconnect() { }
|
|
22
|
-
hasMore() {
|
|
23
|
-
return this.dataSources.filter((ds) => ds.hasMore()).length > 0;
|
|
24
|
-
}
|
|
25
|
-
getData() {
|
|
26
|
-
return [].concat.apply([], this.dataSources.map((ds) => ds.getData()));
|
|
27
|
-
}
|
|
28
|
-
isEmpty() {
|
|
29
|
-
return this.getData()?.length === 0;
|
|
30
|
-
}
|
|
31
|
-
getTotal() {
|
|
32
|
-
return this.dataSources.map((ds) => ds.getTotal()).reduce((a, b) => a + b);
|
|
33
|
-
}
|
|
34
|
-
isFullyLoaded() {
|
|
35
|
-
return this.getTotal() <= this.getData()?.length;
|
|
36
|
-
}
|
|
37
|
-
getDatasource(position) {
|
|
38
|
-
return this.dataSources[position];
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYmluZWQtZGF0YS1zb3VyY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL25vZGUtZW50cmllcy9jb21iaW5lZC1kYXRhLXNvdXJjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUdwRDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sa0JBQXNELFNBQVEsY0FBaUI7SUFDeEYsWUFBb0IsV0FBZ0M7UUFDaEQsS0FBSyxFQUFFLENBQUM7UUFEUSxnQkFBVyxHQUFYLFdBQVcsQ0FBcUI7SUFFcEQsQ0FBQztJQUVELE9BQU87UUFDSCwyREFBMkQ7UUFDM0QsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDMUI7Ozs7V0FJRztJQUNQLENBQUM7SUFFRCxVQUFVLEtBQUksQ0FBQztJQUNmLE9BQU87UUFDSCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FDbEIsRUFBRSxFQUNGLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FDN0MsQ0FBQztJQUNOLENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLEVBQUUsTUFBTSxLQUFLLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRUQsUUFBUTtRQUNKLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMvRSxDQUFDO0lBRUQsYUFBYTtRQUNULE9BQU8sSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxNQUFNLENBQUM7SUFDckQsQ0FBQztJQUVELGFBQWEsQ0FBQyxRQUFnQjtRQUMxQixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDdEMsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE5vZGVEYXRhU291cmNlIH0gZnJvbSAnLi9ub2RlLWRhdGEtc291cmNlJztcbmltcG9ydCB7IE5vZGUsIEdlbmVyaWNBdXRob3JpdHkgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcblxuLyoqXG4gKiBkYXRhIHNvdXJjZSB3aGljaCBqb2lucyBtdWx0aXBsZSB1bmRlcmx5aW5nIGRhdGEgc291cmNlc1xuICogdXNlZCBmb3IgdGhlIFwiYWxsXCIgc2VhcmNoXG4gKi9cbmV4cG9ydCBjbGFzcyBDb21iaW5lZERhdGFTb3VyY2U8VCBleHRlbmRzIE5vZGUgfCBHZW5lcmljQXV0aG9yaXR5PiBleHRlbmRzIE5vZGVEYXRhU291cmNlPFQ+IHtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRhdGFTb3VyY2VzOiBOb2RlRGF0YVNvdXJjZTxUPltdKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgY29ubmVjdCgpOiBPYnNlcnZhYmxlPFRbXT4ge1xuICAgICAgICAvLyBAVE9ETzogVXNpbmcgYSBmb3JrSm9pbiBhbmQgcmVhbCBjb25uZWN0IHdvdWxkIGJlIGJldHRlclxuICAgICAgICByZXR1cm4gb2YodGhpcy5nZXREYXRhKCkpO1xuICAgICAgICAvKlxuICAgICAgICByZXR1cm4gZm9ya0pvaW4odGhpcy5kYXRhU291cmNlcy5tYXAoZHMgPT4gZHMuY29ubmVjdCgpKSkucGlwZShcbiAgICAgICAgICAgIHN3aXRjaE1hcChkID0+IGQpXG4gICAgICAgICkgYXMgT2JzZXJ2YWJsZTxUW10+O1xuICAgICAgICAgKi9cbiAgICB9XG5cbiAgICBkaXNjb25uZWN0KCkge31cbiAgICBoYXNNb3JlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhU291cmNlcy5maWx0ZXIoKGRzKSA9PiBkcy5oYXNNb3JlKCkpLmxlbmd0aCA+IDA7XG4gICAgfVxuXG4gICAgZ2V0RGF0YSgpIHtcbiAgICAgICAgcmV0dXJuIFtdLmNvbmNhdC5hcHBseShcbiAgICAgICAgICAgIFtdLFxuICAgICAgICAgICAgdGhpcy5kYXRhU291cmNlcy5tYXAoKGRzKSA9PiBkcy5nZXREYXRhKCkpLFxuICAgICAgICApO1xuICAgIH1cblxuICAgIGlzRW1wdHkoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmdldERhdGEoKT8ubGVuZ3RoID09PSAwO1xuICAgIH1cblxuICAgIGdldFRvdGFsKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhU291cmNlcy5tYXAoKGRzKSA9PiBkcy5nZXRUb3RhbCgpKS5yZWR1Y2UoKGEsIGIpID0+IGEgKyBiKTtcbiAgICB9XG5cbiAgICBpc0Z1bGx5TG9hZGVkKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRUb3RhbCgpIDw9IHRoaXMuZ2V0RGF0YSgpPy5sZW5ndGg7XG4gICAgfVxuXG4gICAgZ2V0RGF0YXNvdXJjZShwb3NpdGlvbjogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmRhdGFTb3VyY2VzW3Bvc2l0aW9uXTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { NodeDataSource } from './node-data-source';
|
|
2
|
-
/**
|
|
3
|
-
* this is a special data source to provide custom card layouts into the node-entries components
|
|
4
|
-
*/
|
|
5
|
-
export class CustomTemplatesDataSource extends NodeDataSource {
|
|
6
|
-
}
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXRlbXBsYXRlcy1kYXRhLXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2N1c3RvbS10ZW1wbGF0ZXMtZGF0YS1zb3VyY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXBEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLHlCQUEwQixTQUFRLGNBQW1CO0NBQUciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOb2RlRGF0YVNvdXJjZSB9IGZyb20gJy4vbm9kZS1kYXRhLXNvdXJjZSc7XG5cbi8qKlxuICogdGhpcyBpcyBhIHNwZWNpYWwgZGF0YSBzb3VyY2UgdG8gcHJvdmlkZSBjdXN0b20gY2FyZCBsYXlvdXRzIGludG8gdGhlIG5vZGUtZW50cmllcyBjb21wb25lbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBDdXN0b21UZW1wbGF0ZXNEYXRhU291cmNlIGV4dGVuZHMgTm9kZURhdGFTb3VyY2U8YW55PiB7fVxuIl19
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "../../list-items/list-text/list-text.component";
|
|
5
|
-
import * as i3 from "@angular/material/badge";
|
|
6
|
-
import * as i4 from "../../pipes/node-icon.pipe";
|
|
7
|
-
export class DragPreviewComponent {
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: DragPreviewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: DragPreviewComponent, selector: "es-drag-preview", inputs: { node: "node", selected: "selected", item: "item" }, ngImport: i0, template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon | async\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ListTextComponent, selector: "es-list-text" }, { kind: "directive", type: i3.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.NodeIconPipe, name: "esNodeIcon" }] }); }
|
|
10
|
-
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: DragPreviewComponent, decorators: [{
|
|
12
|
-
type: Component,
|
|
13
|
-
args: [{ selector: 'es-drag-preview', template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon | async\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"] }]
|
|
14
|
-
}], propDecorators: { node: [{
|
|
15
|
-
type: Input
|
|
16
|
-
}], selected: [{
|
|
17
|
-
type: Input
|
|
18
|
-
}], item: [{
|
|
19
|
-
type: Input
|
|
20
|
-
}] } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2RyYWctcHJldmlldy9kcmFnLXByZXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvZHJhZy1wcmV2aWV3L2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBVWpELE1BQU0sT0FBTyxvQkFBb0I7K0dBQXBCLG9CQUFvQjttR0FBcEIsb0JBQW9CLHFIQ1ZqQyx3VEFNQTs7NEZESWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNJLGlCQUFpQjs4QkFLbEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgTm9kZUVudHJpZXNEYXRhVHlwZSB9IGZyb20gJy4uL2VudHJpZXMtbW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2VzLWRyYWctcHJldmlldycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERyYWdQcmV2aWV3Q29tcG9uZW50PFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcbiAgICBASW5wdXQoKSBzZWxlY3RlZDogVFtdO1xuICAgIEBJbnB1dCgpIGl0ZW06IExpc3RJdGVtO1xufVxuIiwiPGRpdiBjbGFzcz1cImRyYWctcHJldmlld1wiIFttYXRCYWRnZV09XCJzZWxlY3RlZC5sZW5ndGggPiAxID8gc2VsZWN0ZWQubGVuZ3RoIDogbnVsbFwiPlxuICA8ZGl2IGNsYXNzPVwiZHJhZy1wcmV2aWV3LWljb25cIj5cbiAgICA8aW1nICpuZ0lmPVwibm9kZS5pY29uVVJMXCIgW3NyY109XCJub2RlIHwgZXNOb2RlSWNvbiB8IGFzeW5jXCIgLz5cbiAgPC9kaXY+XG4gIDxlcy1saXN0LXRleHQgY2xhc3M9XCJkcmFnLXByZXZpZXctdGV4dFwiIFtub2RlXT1cIm5vZGVcIiBbaXRlbV09XCJpdGVtXCI+PC9lcy1saXN0LXRleHQ+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
export var NodeEntriesDisplayType;
|
|
2
|
-
(function (NodeEntriesDisplayType) {
|
|
3
|
-
NodeEntriesDisplayType[NodeEntriesDisplayType["Table"] = 0] = "Table";
|
|
4
|
-
NodeEntriesDisplayType[NodeEntriesDisplayType["Grid"] = 1] = "Grid";
|
|
5
|
-
NodeEntriesDisplayType[NodeEntriesDisplayType["SmallGrid"] = 2] = "SmallGrid";
|
|
6
|
-
})(NodeEntriesDisplayType || (NodeEntriesDisplayType = {}));
|
|
7
|
-
export var InteractionType;
|
|
8
|
-
(function (InteractionType) {
|
|
9
|
-
// create router link
|
|
10
|
-
InteractionType[InteractionType["DefaultActionLink"] = 0] = "DefaultActionLink";
|
|
11
|
-
// emit an event
|
|
12
|
-
InteractionType[InteractionType["Emitter"] = 1] = "Emitter";
|
|
13
|
-
InteractionType[InteractionType["None"] = 2] = "None";
|
|
14
|
-
})(InteractionType || (InteractionType = {}));
|
|
15
|
-
export var ClickSource;
|
|
16
|
-
(function (ClickSource) {
|
|
17
|
-
ClickSource[ClickSource["Preview"] = 0] = "Preview";
|
|
18
|
-
ClickSource[ClickSource["Icon"] = 1] = "Icon";
|
|
19
|
-
ClickSource[ClickSource["Metadata"] = 2] = "Metadata";
|
|
20
|
-
ClickSource[ClickSource["Comments"] = 3] = "Comments";
|
|
21
|
-
ClickSource[ClickSource["Overlay"] = 4] = "Overlay";
|
|
22
|
-
ClickSource[ClickSource["Dropdown"] = 5] = "Dropdown";
|
|
23
|
-
})(ClickSource || (ClickSource = {}));
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmllcy1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2VudHJpZXMtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0JBLE1BQU0sQ0FBTixJQUFZLHNCQUlYO0FBSkQsV0FBWSxzQkFBc0I7SUFDOUIscUVBQUssQ0FBQTtJQUNMLG1FQUFJLENBQUE7SUFDSiw2RUFBUyxDQUFBO0FBQ2IsQ0FBQyxFQUpXLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJakM7QUFFRCxNQUFNLENBQU4sSUFBWSxlQU1YO0FBTkQsV0FBWSxlQUFlO0lBQ3ZCLHFCQUFxQjtJQUNyQiwrRUFBaUIsQ0FBQTtJQUNqQixnQkFBZ0I7SUFDaEIsMkRBQU8sQ0FBQTtJQUNQLHFEQUFJLENBQUE7QUFDUixDQUFDLEVBTlcsZUFBZSxLQUFmLGVBQWUsUUFNMUI7QUE2QkQsTUFBTSxDQUFOLElBQVksV0FPWDtBQVBELFdBQVksV0FBVztJQUNuQixtREFBTyxDQUFBO0lBQ1AsNkNBQUksQ0FBQTtJQUNKLHFEQUFRLENBQUE7SUFDUixxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7QUFDWixDQUFDLEVBUFcsV0FBVyxLQUFYLFdBQVcsUUFPdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb3J0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5cbmltcG9ydCB7IFNlbGVjdGlvbk1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IEN1c3RvbU9wdGlvbnMsIE9wdGlvbkl0ZW0sIFRhcmdldCB9IGZyb20gJy4uL3R5cGVzL29wdGlvbi1pdGVtJztcbmltcG9ydCB7IExpc3RJdGVtLCBMaXN0SXRlbVNvcnQgfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgQ2FuRHJvcCwgRHJhZ0RhdGEsIERyb3BBY3Rpb24gfSBmcm9tICcuLi90eXBlcy9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgTm9kZSwgR2VuZXJpY0F1dGhvcml0eSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgQWN0aW9uYmFyQ29tcG9uZW50IH0gZnJvbSAnLi4vYWN0aW9uYmFyL2FjdGlvbmJhci5jb21wb25lbnQnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBOb2RlUm9vdCA9XG4gICAgfCAnTVlfRklMRVMnXG4gICAgfCAnQ09MTEVDVElPTl9IT01FJ1xuICAgIHwgJ1NIQVJFRF9GSUxFUydcbiAgICB8ICdNWV9TSEFSRURfRklMRVMnXG4gICAgfCAnVE9fTUVfU0hBUkVEX0ZJTEVTJ1xuICAgIHwgJ1dPUktGTE9XX1JFQ0VJVkUnXG4gICAgfCAnUkVDWUNMRSdcbiAgICB8ICdBTExfRklMRVMnO1xuXG5leHBvcnQgZW51bSBOb2RlRW50cmllc0Rpc3BsYXlUeXBlIHtcbiAgICBUYWJsZSxcbiAgICBHcmlkLFxuICAgIFNtYWxsR3JpZCxcbn1cblxuZXhwb3J0IGVudW0gSW50ZXJhY3Rpb25UeXBlIHtcbiAgICAvLyBjcmVhdGUgcm91dGVyIGxpbmtcbiAgICBEZWZhdWx0QWN0aW9uTGluayxcbiAgICAvLyBlbWl0IGFuIGV2ZW50XG4gICAgRW1pdHRlcixcbiAgICBOb25lLFxufVxuXG5leHBvcnQgdHlwZSBMaXN0T3B0aW9ucyA9IHsgW2tleSBpbiBUYXJnZXRdPzogT3B0aW9uSXRlbVtdIH07XG5leHBvcnQgdHlwZSBMaXN0T3B0aW9uc0NvbmZpZyA9IHtcbiAgICBhY3Rpb25iYXI/OiBBY3Rpb25iYXJDb21wb25lbnQ7XG4gICAgcGFyZW50PzogTm9kZTtcbiAgICBjdXN0b21PcHRpb25zPzogQ3VzdG9tT3B0aW9ucztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdFNvcnRDb25maWcgZXh0ZW5kcyBTb3J0IHtcbiAgICBjb2x1bW5zOiBMaXN0SXRlbVNvcnRbXTtcbiAgICBhbGxvd2VkPzogYm9vbGVhbjtcbiAgICBjdXN0b21Tb3J0aW5nSW5Qcm9ncmVzcz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIERyb3BUYXJnZXQgPSBOb2RlIHwgTm9kZVJvb3Q7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJvcFNvdXJjZTxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIGVsZW1lbnQ6IFRbXTtcbiAgICAvLyBzb3VyY2VMaXN0OiBMaXN0RXZlbnRJbnRlcmZhY2U8VD47XG4gICAgbW9kZTogRHJvcEFjdGlvbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMaXN0RHJhZ0dyb3BDb25maWc8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+IHtcbiAgICBkcmFnQWxsb3dlZDogYm9vbGVhbjtcbiAgICBkcm9wQWxsb3dlZD86IChkcmFnRGF0YTogRHJhZ0RhdGE8VD4pID0+IENhbkRyb3A7XG4gICAgZHJvcHBlZD86ICh0YXJnZXQ6IE5vZGUsIHNvdXJjZTogRHJvcFNvdXJjZTxOb2RlRW50cmllc0RhdGFUeXBlPikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQ2xpY2tTb3VyY2Uge1xuICAgIFByZXZpZXcsXG4gICAgSWNvbixcbiAgICBNZXRhZGF0YSxcbiAgICBDb21tZW50cyxcbiAgICBPdmVybGF5LFxuICAgIERyb3Bkb3duLCAvLyBrZWVwOiB1c2VkIGluIGV4dGVuc2lvbnNcbn1cblxuZXhwb3J0IHR5cGUgTm9kZUNsaWNrRXZlbnQ8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+ID0ge1xuICAgIGVsZW1lbnQ6IFQ7XG4gICAgc291cmNlOiBDbGlja1NvdXJjZTtcbiAgICBhdHRyaWJ1dGU/OiBMaXN0SXRlbTsgLy8gb25seSB3aGVuIHNvdXJjZSA9PT0gTWV0YWRhdGFcbn07XG5leHBvcnQgdHlwZSBGZXRjaEV2ZW50ID0ge1xuICAgIG9mZnNldDogbnVtYmVyO1xuICAgIGFtb3VudD86IG51bWJlcjtcbiAgICAvKipcbiAgICAgKiBpcyBhIHJlc2V0IG9mIHRoZSBjdXJyZW50IGRhdGEgcmVxdWlyZWQ/XG4gICAgICogdGhpcyBzaG91bGQgYmUgdHJ1ZSBpZiB0aGlzIHdhcyBhIHBhZ2luYXRpb24gcmVxdWVzdFxuICAgICAqL1xuICAgIHJlc2V0PzogYm9vbGVhbjtcbn07XG5leHBvcnQgdHlwZSBOb2RlRW50cmllc0RhdGFUeXBlID0gTm9kZSB8IEdlbmVyaWNBdXRob3JpdHk7XG5leHBvcnQgdHlwZSBHcmlkTGF5b3V0ID0gJ2dyaWQnIHwgJ3Njcm9sbCc7XG5leHBvcnQgdHlwZSBHcmlkQ29uZmlnID0ge1xuICAgIC8qKlxuICAgICAqIG1heCBhbW91bnQgb2Ygcm93cyB0aGF0IHNob3VsZCBiZSB2aXNpYmxlLCB1bnNldCBmb3Igbm8gbGltaXRcbiAgICAgKi9cbiAgICBtYXhSb3dzPzogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIGxheW91dCwgZGVmYXVsdHMgdG8gJ2dyaWQnXG4gICAgICogJ3Njcm9sbCcgbWF5IG9ubHkgYmUgdXNlZCB3aGVuIG1heFJvd3MgaXMgbm90IHNldFxuICAgICAqL1xuICAgIGxheW91dD86IEdyaWRMYXlvdXQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIExpc3RFdmVudEludGVyZmFjZTxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIHVwZGF0ZU5vZGVzKG5vZGVzOiB2b2lkIHwgVFtdKTogdm9pZDtcblxuICAgIG9uRGlzcGxheVR5cGVDaGFuZ2UoKTogT2JzZXJ2YWJsZTxOb2RlRW50cmllc0Rpc3BsYXlUeXBlPjtcblxuICAgIGdldERpc3BsYXlUeXBlKCk6IE5vZGVFbnRyaWVzRGlzcGxheVR5cGU7XG5cbiAgICBzZXREaXNwbGF5VHlwZShkaXNwbGF5VHlwZTogTm9kZUVudHJpZXNEaXNwbGF5VHlwZSk6IHZvaWQ7XG5cbiAgICBzaG93UmVvcmRlckNvbHVtbnNEaWFsb2coKTogdm9pZDtcblxuICAgIGFkZFZpcnR1YWxOb2Rlcyh2aXJ0dWFsOiBUW10pOiB2b2lkO1xuXG4gICAgc2V0T3B0aW9ucyhvcHRpb25zOiBMaXN0T3B0aW9ucyk6IHZvaWQ7XG5cbiAgICAvKipcbiAgICAgKiBhY3RpdmF0ZSBvcHRpb24gKGRyb3Bkb3duKSBnZW5lcmF0aW9uXG4gICAgICovXG4gICAgaW5pdE9wdGlvbnNHZW5lcmF0b3IoY29uZmlnOiBMaXN0T3B0aW9uc0NvbmZpZyk6IHZvaWQgfCBQcm9taXNlPHZvaWQ+O1xuXG4gICAgc2VsZWN0QWxsKCk6IHZvaWQ7XG5cbiAgICBnZXRTZWxlY3Rpb24oKTogU2VsZWN0aW9uTW9kZWw8VD47XG5cbiAgICAvKipcbiAgICAgKiB0cmlnZ2VyZWQgd2hlbiBub2Rlcy9vYmplY3RzIGFyZSBkZWxldGVkIGFuZCBzaG91bGQgbm90IGJlIHNob3duIGluIHRoZSBsaXN0IGFueW1vcmVcbiAgICAgKi9cbiAgICBkZWxldGVOb2RlcyhvYmplY3RzOiBUW10pOiB2b2lkO1xufVxuIl19
|