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.
Files changed (131) hide show
  1. package/assets/scss/material-theme.scss +3 -3
  2. package/assets/scss/mixins.scss +1 -1
  3. package/assets/scss/variables-root.scss +2 -0
  4. package/assets/scss/variables-scss.scss +3 -4
  5. package/assets/scss/variables.scss +1 -1
  6. package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
  7. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  8. package/lib/index.d.ts +1 -0
  9. package/lib/list-items/list-widget.d.ts +1 -1
  10. package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
  11. package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
  12. package/package.json +8 -9
  13. package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
  14. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
  15. package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
  16. package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
  17. package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
  18. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
  19. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
  20. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
  21. package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
  22. package/esm2022/lib/directives/icon.directive.mjs +0 -184
  23. package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
  24. package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
  25. package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
  26. package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
  27. package/esm2022/lib/index.mjs +0 -96
  28. package/esm2022/lib/list-items/available-widgets.mjs +0 -27
  29. package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
  30. package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
  31. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
  32. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
  33. package/esm2022/lib/list-items/list-items.module.mjs +0 -50
  34. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
  35. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
  36. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
  37. package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
  38. package/esm2022/lib/list-items/list-widget.mjs +0 -49
  39. package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
  40. package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
  41. package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
  42. package/esm2022/lib/mds/mds.module.mjs +0 -16
  43. package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
  44. package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
  45. package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
  46. package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
  47. package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
  48. package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
  49. package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
  50. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
  51. package/esm2022/lib/node-entries/entries-model.mjs +0 -24
  52. package/esm2022/lib/node-entries/items-cap.mjs +0 -47
  53. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
  54. package/esm2022/lib/node-entries/node-cache.mjs +0 -73
  55. package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
  56. package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
  57. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
  58. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
  59. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
  60. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
  61. package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
  62. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
  63. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
  64. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
  65. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
  66. package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
  67. package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
  68. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
  69. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
  70. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
  71. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
  72. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
  73. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
  74. package/esm2022/lib/node-url/node-url.component.mjs +0 -132
  75. package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
  76. package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
  77. package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
  78. package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
  79. package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
  80. package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
  81. package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
  82. package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
  83. package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
  84. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
  85. package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
  86. package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
  87. package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
  88. package/esm2022/lib/services/abstract/app.service.mjs +0 -3
  89. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
  90. package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
  91. package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
  92. package/esm2022/lib/services/accessibility.service.mjs +0 -73
  93. package/esm2022/lib/services/app-container.service.mjs +0 -69
  94. package/esm2022/lib/services/local-events.service.mjs +0 -43
  95. package/esm2022/lib/services/node-entries.service.mjs +0 -201
  96. package/esm2022/lib/services/node-helper.service.mjs +0 -330
  97. package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
  98. package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
  99. package/esm2022/lib/services/render-helper.service.mjs +0 -114
  100. package/esm2022/lib/services/repo-url.service.mjs +0 -50
  101. package/esm2022/lib/services/search-helper.service.mjs +0 -52
  102. package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
  103. package/esm2022/lib/services/ui.service.mjs +0 -327
  104. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
  105. package/esm2022/lib/spinner/spinner.component.mjs +0 -19
  106. package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
  107. package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
  108. package/esm2022/lib/translations/translation-loader.mjs +0 -219
  109. package/esm2022/lib/translations/translation-source.mjs +0 -11
  110. package/esm2022/lib/translations/translations.module.mjs +0 -82
  111. package/esm2022/lib/translations/translations.service.mjs +0 -238
  112. package/esm2022/lib/types/accessibillity.mjs +0 -19
  113. package/esm2022/lib/types/api-models.mjs +0 -2
  114. package/esm2022/lib/types/drag-drop.mjs +0 -2
  115. package/esm2022/lib/types/injection-tokens.mjs +0 -31
  116. package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
  117. package/esm2022/lib/types/list-item.mjs +0 -41
  118. package/esm2022/lib/types/option-item.mjs +0 -192
  119. package/esm2022/lib/types/workflow.mjs +0 -25
  120. package/esm2022/lib/util/DateHelper.mjs +0 -200
  121. package/esm2022/lib/util/VCard.mjs +0 -278
  122. package/esm2022/lib/util/color-helper.mjs +0 -124
  123. package/esm2022/lib/util/duration-helper.mjs +0 -102
  124. package/esm2022/lib/util/functions.mjs +0 -13
  125. package/esm2022/lib/util/helper.mjs +0 -64
  126. package/esm2022/lib/util/isNumeric.mjs +0 -11
  127. package/esm2022/lib/util/rest-helper.mjs +0 -42
  128. package/esm2022/lib/util/ui-animation.mjs +0 -146
  129. package/esm2022/lib/util/ui-constants.mjs +0 -21
  130. package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
  131. 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