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,369 +0,0 @@
1
- import { Component, ContentChild, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
- import { interval, Subject } from 'rxjs';
3
- import { NodeEntriesTemplatesService } from './node-entries-templates.service';
4
- import { InteractionType, NodeEntriesDisplayType, } from './entries-model';
5
- import { NodeDataSource } from './node-data-source';
6
- import { Helper } from '../util/helper';
7
- import { NodeEntriesService } from '../services/node-entries.service';
8
- import { TemporaryStorageService } from '../services/temporary-storage.service';
9
- import { OptionsHelperDataService } from '../services/options-helper-data.service';
10
- import { switchMap, take, takeUntil } from 'rxjs/operators';
11
- import { filter } from 'rxjs/operators';
12
- import * as i0 from "@angular/core";
13
- import * as i1 from "../services/temporary-storage.service";
14
- import * as i2 from "../services/node-entries.service";
15
- import * as i3 from "ngx-edu-sharing-api";
16
- import * as i4 from "../services/options-helper-data.service";
17
- import * as i5 from "../services/node-helper.service";
18
- import * as i6 from "../services/ui.service";
19
- import * as i7 from "./node-entries-templates.service";
20
- import * as i8 from "@angular/common";
21
- import * as i9 from "./node-entries.component";
22
- export class NodeEntriesWrapperComponent {
23
- constructor(viewContainerRef, temporaryStorageService, ngZone, entriesService, nodeService, optionsHelper, nodeHelperService, uiService,
24
- // @TODO
25
- // private mainNav: MainNavService,
26
- templatesService, changeDetectorRef, elementRef) {
27
- this.viewContainerRef = viewContainerRef;
28
- this.temporaryStorageService = temporaryStorageService;
29
- this.ngZone = ngZone;
30
- this.entriesService = entriesService;
31
- this.nodeService = nodeService;
32
- this.optionsHelper = optionsHelper;
33
- this.nodeHelperService = nodeHelperService;
34
- this.uiService = uiService;
35
- this.templatesService = templatesService;
36
- this.changeDetectorRef = changeDetectorRef;
37
- this.elementRef = elementRef;
38
- this.checkbox = true;
39
- /**
40
- * emits when the user re-configures the columns
41
- * should be used in order to save the new configuration
42
- */
43
- this.columnsChange = new EventEmitter();
44
- this.displayType = NodeEntriesDisplayType.Grid;
45
- this.displayTypeChange = new EventEmitter();
46
- this.elementInteractionType = InteractionType.DefaultActionLink;
47
- /**
48
- * This color defines the base color of gradients visually limiting a grid in scroll direction.
49
- * Defaults to white.
50
- */
51
- this.scrollGradientColor = '#fff';
52
- /**
53
- * UI hints for whether a single click will cause a dynamic action.
54
- *
55
- * This does not configure the actual behavior but only UI hints to the user. Hints include
56
- * hover effects and a changed cursor.
57
- *
58
- * - When choosing 'static', the `clickItem` event should trigger some stationary action like
59
- * selecting the element or displaying information in a complementary page area. The
60
- * `dblClickItem` event can be used for a more disruptive action.
61
- * - When choosing 'dynamic', the `clickItem` event should trigger a major action like
62
- * navigating to a new page or closing a dialog.
63
- */
64
- // TODO: Consider controlling the ui hints and the actual behavior with a single option.
65
- this.singleClickHint = 'dynamic';
66
- /**
67
- * Do not load more data on scroll.
68
- */
69
- this.disableInfiniteScroll = false;
70
- this.fetchData = new EventEmitter();
71
- this.clickItem = new EventEmitter();
72
- this.dblClickItem = new EventEmitter();
73
- this.sortChange = new EventEmitter();
74
- this.destroyed = new Subject();
75
- // regulary re-bind template since it might have updated without ngChanges trigger
76
- /*
77
- ngZone.runOutsideAngular(() =>
78
- setInterval(() => this.componentRef.instance.emptyRef = this.emptyRef)
79
- );
80
- */
81
- this.virtualNodesAdded = this.optionsHelper.virtualNodesAdded;
82
- this.displayTypeChanged = this.optionsHelper.displayTypeChanged;
83
- this.entriesService.selection.changed.subscribe(() => {
84
- if (this.optionsHelper.getData()) {
85
- this.optionsHelper.getData().selectedObjects =
86
- this.entriesService.selection.selected;
87
- this.optionsHelper.getData().activeObjects = this.entriesService.selection.selected;
88
- }
89
- else {
90
- console.warn('optionsHelper is not initalized correctly; data is empty');
91
- }
92
- void this.optionsHelper.refreshComponents();
93
- });
94
- }
95
- ngOnInit() {
96
- if (this.primaryInstance) {
97
- this.optionsHelper.registerGlobalKeyboardShortcuts();
98
- }
99
- this.entriesService.columnsSubject
100
- .pipe(takeUntil(this.destroyed), filter((c) => c?.fromUser))
101
- .subscribe((c) => this.columnsChange.emit(c.columns));
102
- }
103
- ngOnChanges(changes = {}) {
104
- if (!this.componentRef) {
105
- this.init();
106
- }
107
- this.entriesService.list = this;
108
- this.entriesService.dataSource = this.dataSource;
109
- this.entriesService.scope = this.scope;
110
- if (changes.columns) {
111
- this.entriesService.columnsSubject.next({
112
- columns: this.columns,
113
- fromUser: false,
114
- });
115
- }
116
- this.entriesService.configureColumns = this.configureColumns;
117
- this.entriesService.checkbox = this.checkbox;
118
- this.entriesService.displayType = this.displayType;
119
- this.entriesService.elementInteractionType = this.elementInteractionType;
120
- this.entriesService.gridConfig = this.gridConfig;
121
- this.entriesService.options = this.options;
122
- this.entriesService.globalOptions = this.globalOptions;
123
- this.entriesService.sort = this.sort;
124
- this.entriesService.sortChange = this.sortChange;
125
- this.entriesService.dragDrop = this.dragDrop;
126
- this.entriesService.clickItem = this.clickItem;
127
- this.entriesService.dblClickItem = this.dblClickItem;
128
- this.entriesService.fetchData = this.fetchData;
129
- this.entriesService.primaryInstance = this.primaryInstance;
130
- this.entriesService.singleClickHint = this.singleClickHint;
131
- this.entriesService.disableInfiniteScroll = this.disableInfiniteScroll;
132
- this.entriesService.scrollGradientColor.set(this.scrollGradientColor);
133
- if (changes['initConfig']) {
134
- void this.initOptionsGenerator(this.initConfig);
135
- }
136
- if (this.componentRef) {
137
- this.componentRef.instance.changeDetectorRef?.detectChanges();
138
- }
139
- // This might need wrapping with `setTimeout`.
140
- this.updateTemplates();
141
- }
142
- ngOnDestroy() {
143
- this.destroyed.next();
144
- this.destroyed.complete();
145
- }
146
- /**
147
- * Replaces this wrapper with the configured custom-node-list component.
148
- */
149
- init() {
150
- this.customNodeListComponent = this.temporaryStorageService.get(TemporaryStorageService.CUSTOM_NODE_ENTRIES_COMPONENT, null);
151
- if (this.customNodeListComponent == null) {
152
- return;
153
- }
154
- this.componentRef = this.uiService.injectAngularComponent(this.viewContainerRef, this.customNodeListComponent, this.elementRef.nativeElement,
155
- // Input bindings are initialized in `ngOnChanges`.
156
- this.getOutputBindings());
157
- }
158
- /**
159
- * Creates a simple map of the output bindings defined in this component.
160
- */
161
- getOutputBindings() {
162
- const outputBindings = {};
163
- for (const key of Object.keys(this)) {
164
- const value = this[key];
165
- if (value instanceof EventEmitter) {
166
- outputBindings[key] = value;
167
- }
168
- }
169
- return outputBindings;
170
- }
171
- getDisplayType() {
172
- return this.displayType;
173
- }
174
- onDisplayTypeChange() {
175
- return this.displayTypeChange.asObservable();
176
- }
177
- setDisplayType(displayType) {
178
- this.displayType = displayType;
179
- this.entriesService.displayType = displayType;
180
- this.ngOnChanges();
181
- this.displayTypeChange.emit(displayType);
182
- }
183
- updateNodes(nodes) {
184
- if (!nodes) {
185
- return;
186
- }
187
- this.dataSource.getData().forEach((d) => {
188
- let hits = nodes.filter((n) => n?.ref
189
- ? n?.ref.id === d?.ref.id
190
- : n?.authorityName ===
191
- d?.authorityName);
192
- if (hits.length === 0) {
193
- // handle if the original has changed (for collection refs)
194
- hits = nodes.filter((n) => n?.ref &&
195
- n?.ref?.id === d?.originalId);
196
- }
197
- if (hits.length === 1) {
198
- this.nodeHelperService.copyDataToNode(d, hits[0]);
199
- }
200
- });
201
- // trigger rebuild
202
- if (this.dataSource instanceof NodeDataSource) {
203
- this.dataSource.refresh();
204
- }
205
- const oldSelection = this.entriesService.selection.selected;
206
- this.entriesService.selection.clear();
207
- this.entriesService.selection.select(...oldSelection.map((o) => this.dataSource.getData().filter((d) => Helper.objectEquals(o, d))?.[0]));
208
- this.changeDetectorRef.detectChanges();
209
- }
210
- showReorderColumnsDialog() { }
211
- addVirtualNodes(virtual) {
212
- virtual = virtual.map((o) => {
213
- o.virtual = true;
214
- return o;
215
- });
216
- virtual.forEach((v) => {
217
- const contains = this.dataSource
218
- .getData()
219
- .some((d) => d.ref
220
- ? d.ref?.id === v.ref?.id
221
- : d.authorityName === v.authorityName);
222
- if (contains) {
223
- if (v.override !== false) {
224
- this.updateNodes([v]);
225
- }
226
- }
227
- else {
228
- this.dataSource.appendData([v], 'before');
229
- }
230
- if (v.observe) {
231
- interval(2000)
232
- .pipe(take(10), takeUntil(this.destroyed), switchMap(() => this.nodeService.getNode(v.ref.id, {
233
- repository: v.ref.repo,
234
- })))
235
- .subscribe((node) => {
236
- node.virtual = true;
237
- this.updateNodes([node]);
238
- });
239
- }
240
- });
241
- this.entriesService.selection.clear();
242
- this.entriesService.selection.select(...virtual);
243
- this.virtualNodesAdded.emit(virtual);
244
- this.changeDetectorRef.detectChanges();
245
- }
246
- setOptions(options) {
247
- this.options = options;
248
- this.ngOnChanges();
249
- }
250
- selectAll() {
251
- this.entriesService.selection.select(...this.entriesService.dataSource.getData());
252
- }
253
- getSelection() {
254
- return this.entriesService.selection;
255
- }
256
- async initOptionsGenerator(config) {
257
- await this.optionsHelper.initComponents(config.actionbar, this);
258
- this.optionsHelper.setData({
259
- scope: this.entriesService.scope,
260
- activeObjects: this.entriesService.selection.selected,
261
- selectedObjects: this.entriesService.selection.selected,
262
- allObjects: this.dataSource.getData(),
263
- parent: config.parent,
264
- customOptions: config.customOptions,
265
- });
266
- void this.optionsHelper.refreshComponents();
267
- }
268
- ngAfterViewInit() {
269
- // Prevent changed-after-checked error
270
- void Promise.resolve().then(() => this.updateTemplates());
271
- }
272
- updateTemplates() {
273
- this.templatesService.title = this.titleRef;
274
- this.templatesService.empty = this.emptyRef;
275
- this.templatesService.actionArea = this.actionAreaRef;
276
- this.templatesService.overlay = this.overlayRef;
277
- }
278
- /**
279
- * reset the pagination to the first page
280
- * hint: this will do nothing in case the paginationStrategy !== Pagination
281
- */
282
- resetPagination() {
283
- this.nodeEntriesComponentRef?.paginator?.firstPage();
284
- }
285
- deleteNodes(objects) {
286
- this.dataSource.removeData(objects);
287
- this.getSelection().clear();
288
- }
289
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesWrapperComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TemporaryStorageService }, { token: i0.NgZone }, { token: i2.NodeEntriesService }, { token: i3.NodeService }, { token: i4.OptionsHelperDataService }, { token: i5.NodeHelperService }, { token: i6.UIService }, { token: i7.NodeEntriesTemplatesService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
290
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesWrapperComponent, selector: "es-node-entries-wrapper", inputs: { dataSource: "dataSource", scope: "scope", columns: "columns", configureColumns: "configureColumns", checkbox: "checkbox", globalOptions: "globalOptions", displayType: "displayType", elementInteractionType: "elementInteractionType", sort: "sort", dragDrop: "dragDrop", gridConfig: "gridConfig", scrollGradientColor: "scrollGradientColor", initConfig: "initConfig", primaryInstance: "primaryInstance", singleClickHint: "singleClickHint", disableInfiniteScroll: "disableInfiniteScroll" }, outputs: { columnsChange: "columnsChange", displayTypeChange: "displayTypeChange", fetchData: "fetchData", clickItem: "clickItem", dblClickItem: "dblClickItem", sortChange: "sortChange", virtualNodesAdded: "virtualNodesAdded", displayTypeChanged: "displayTypeChanged" }, providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService], queries: [{ propertyName: "titleRef", first: true, predicate: ["title"], descendants: true }, { propertyName: "emptyRef", first: true, predicate: ["empty"], descendants: true }, { propertyName: "actionAreaRef", first: true, predicate: ["actionArea"], descendants: true }, { propertyName: "overlayRef", first: true, predicate: ["overlay"], descendants: true }], viewQueries: [{ propertyName: "nodeEntriesComponentRef", first: true, predicate: ["nodeEntriesComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<es-node-entries
291
- #nodeEntriesComponent
292
- *ngIf="!customNodeListComponent"
293
- ></es-node-entries>`, isInline: true, dependencies: [{ kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i9.NodeEntriesComponent, selector: "es-node-entries" }] }); }
294
- }
295
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesWrapperComponent, decorators: [{
296
- type: Component,
297
- args: [{
298
- selector: 'es-node-entries-wrapper',
299
- template: `<es-node-entries
300
- #nodeEntriesComponent
301
- *ngIf="!customNodeListComponent"
302
- ></es-node-entries>`,
303
- providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService],
304
- }]
305
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i1.TemporaryStorageService }, { type: i0.NgZone }, { type: i2.NodeEntriesService }, { type: i3.NodeService }, { type: i4.OptionsHelperDataService }, { type: i5.NodeHelperService }, { type: i6.UIService }, { type: i7.NodeEntriesTemplatesService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { titleRef: [{
306
- type: ContentChild,
307
- args: ['title']
308
- }], emptyRef: [{
309
- type: ContentChild,
310
- args: ['empty']
311
- }], actionAreaRef: [{
312
- type: ContentChild,
313
- args: ['actionArea']
314
- }], overlayRef: [{
315
- type: ContentChild,
316
- args: ['overlay']
317
- }], nodeEntriesComponentRef: [{
318
- type: ViewChild,
319
- args: ['nodeEntriesComponent']
320
- }], dataSource: [{
321
- type: Input
322
- }], scope: [{
323
- type: Input
324
- }], columns: [{
325
- type: Input
326
- }], configureColumns: [{
327
- type: Input
328
- }], checkbox: [{
329
- type: Input
330
- }], columnsChange: [{
331
- type: Output
332
- }], globalOptions: [{
333
- type: Input
334
- }], displayType: [{
335
- type: Input
336
- }], displayTypeChange: [{
337
- type: Output
338
- }], elementInteractionType: [{
339
- type: Input
340
- }], sort: [{
341
- type: Input
342
- }], dragDrop: [{
343
- type: Input
344
- }], gridConfig: [{
345
- type: Input
346
- }], scrollGradientColor: [{
347
- type: Input
348
- }], initConfig: [{
349
- type: Input
350
- }], primaryInstance: [{
351
- type: Input
352
- }], singleClickHint: [{
353
- type: Input
354
- }], disableInfiniteScroll: [{
355
- type: Input
356
- }], fetchData: [{
357
- type: Output
358
- }], clickItem: [{
359
- type: Output
360
- }], dblClickItem: [{
361
- type: Output
362
- }], sortChange: [{
363
- type: Output
364
- }], virtualNodesAdded: [{
365
- type: Output
366
- }], displayTypeChanged: [{
367
- type: Output
368
- }] } });
369
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChange,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { interval, Subject } from 'rxjs';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesComponent } from './node-entries.component';\nimport {\n    FetchEvent,\n    GridConfig,\n    InteractionType,\n    ListDragGropConfig,\n    ListEventInterface,\n    ListOptions,\n    ListOptionsConfig,\n    ListSortConfig,\n    NodeClickEvent,\n    NodeEntriesDataType,\n    NodeEntriesDisplayType,\n} from './entries-model';\nimport { NodeDataSource } from './node-data-source';\nimport { Helper } from '../util/helper';\nimport { CustomSelectionModel, NodeEntriesService } from '../services/node-entries.service';\nimport { OptionItem, Scope } from '../types/option-item';\nimport { NodeHelperService } from '../services/node-helper.service';\nimport { ListItem } from '../types/list-item';\nimport { TemporaryStorageService } from '../services/temporary-storage.service';\nimport {\n    CollectionReference,\n    GenericAuthority,\n    Node,\n    NodeService,\n    User,\n} from 'ngx-edu-sharing-api';\nimport { VirtualNode } from '../types/api-models';\nimport { OptionsHelperDataService } from '../services/options-helper-data.service';\nimport { UIService } from '../services/ui.service';\nimport { switchMap, take, takeUntil } from 'rxjs/operators';\nimport { debounceTime, distinctUntilChanged, filter } from 'rxjs/operators';\n\n@Component({\n    selector: 'es-node-entries-wrapper',\n    template: `<es-node-entries\n        #nodeEntriesComponent\n        *ngIf=\"!customNodeListComponent\"\n    ></es-node-entries>`,\n    providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService],\n})\nexport class NodeEntriesWrapperComponent<T extends NodeEntriesDataType>\n    implements AfterViewInit, OnInit, OnChanges, OnDestroy, ListEventInterface<T>\n{\n    /**\n     * title (above) the table/grid\n     */\n    @ContentChild('title') titleRef: TemplateRef<any>;\n    /**\n     * data shown when data source is empty\n     */\n    @ContentChild('empty') emptyRef: TemplateRef<any>;\n    /**\n     * custom area for actions only for NodeEntriesDisplayType.SmallGrid (per card at the bottom)\n     */\n    @ContentChild('actionArea') actionAreaRef: TemplateRef<any>;\n    /**\n     * custom area for an overlay \"above\" each card (i.e. to show disabled infos), only for NodeEntriesDisplayType.SmallGrid & odeEntriesDisplayType.Grid\n     */\n    @ContentChild('overlay') overlayRef: TemplateRef<any>;\n    @ViewChild('nodeEntriesComponent') nodeEntriesComponentRef: NodeEntriesComponent<T>;\n    @Input() dataSource: NodeDataSource<T>;\n    @Input() scope: Scope;\n    @Input() columns: ListItem[];\n    @Input() configureColumns: boolean;\n    @Input() checkbox = true;\n    /**\n     * emits when the user re-configures the columns\n     * should be used in order to save the new configuration\n     */\n    @Output() columnsChange = new EventEmitter<ListItem[]>();\n    @Input() globalOptions: OptionItem[];\n    @Input() displayType = NodeEntriesDisplayType.Grid;\n    @Output() displayTypeChange = new EventEmitter<NodeEntriesDisplayType>();\n    @Input() elementInteractionType = InteractionType.DefaultActionLink;\n    @Input() sort: ListSortConfig;\n    @Input() dragDrop: ListDragGropConfig<T>;\n    @Input() gridConfig: GridConfig;\n\n    /**\n     * This color defines the base color of gradients visually limiting a grid in scroll direction.\n     * Defaults to white.\n     */\n    @Input() scrollGradientColor: string = '#fff';\n\n    /**\n     * this can be set instead of calling initOptionsGenerator()\n     */\n    @Input() initConfig: ListOptionsConfig;\n    /**\n     * Whether this node-entries instance represents the page's main content.\n     *\n     * Only set to true for one instance per page.\n     *\n     * If true, this instance will\n     * - handle page-wide keyboard shortcuts\n     * - take control of the `page` and `pageSize` query parameters for pagination\n     */\n    @Input() primaryInstance: boolean;\n    /**\n     * UI hints for whether a single click will cause a dynamic action.\n     *\n     * This does not configure the actual behavior but only UI hints to the user. Hints include\n     * hover effects and a changed cursor.\n     *\n     * - When choosing 'static', the `clickItem` event should trigger some stationary action like\n     *   selecting the element or displaying information in a complementary page area. The\n     *   `dblClickItem` event can be used for a more disruptive action.\n     * - When choosing 'dynamic', the `clickItem` event should trigger a major action like\n     *   navigating to a new page or closing a dialog.\n     */\n    // TODO: Consider controlling the ui hints and the actual behavior with a single option.\n    @Input() singleClickHint: 'dynamic' | 'static' = 'dynamic';\n    /**\n     * Do not load more data on scroll.\n     */\n    @Input() disableInfiniteScroll = false;\n\n    @Output() fetchData = new EventEmitter<FetchEvent>();\n    @Output() clickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() dblClickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() sortChange = new EventEmitter<ListSortConfig>();\n    @Output() virtualNodesAdded;\n    @Output() displayTypeChanged;\n\n    customNodeListComponent: Type<NodeEntriesComponent<T>>;\n    private componentRef: ComponentRef<NodeEntriesComponent<T>>;\n    private options: ListOptions;\n    private destroyed = new Subject<void>();\n\n    constructor(\n        private viewContainerRef: ViewContainerRef,\n        private temporaryStorageService: TemporaryStorageService,\n        private ngZone: NgZone,\n        private entriesService: NodeEntriesService<T>,\n        private nodeService: NodeService,\n        public optionsHelper: OptionsHelperDataService,\n        private nodeHelperService: NodeHelperService,\n        private uiService: UIService,\n        // @TODO\n        // private mainNav: MainNavService,\n        private templatesService: NodeEntriesTemplatesService,\n        private changeDetectorRef: ChangeDetectorRef,\n        private elementRef: ElementRef,\n    ) {\n        // regulary re-bind template since it might have updated without ngChanges trigger\n        /*\n        ngZone.runOutsideAngular(() =>\n            setInterval(() => this.componentRef.instance.emptyRef = this.emptyRef)\n        );\n        */\n        this.virtualNodesAdded = this.optionsHelper.virtualNodesAdded;\n        this.displayTypeChanged = this.optionsHelper.displayTypeChanged;\n        this.entriesService.selection.changed.subscribe(() => {\n            if (this.optionsHelper.getData()) {\n                this.optionsHelper.getData().selectedObjects =\n                    this.entriesService.selection.selected;\n                this.optionsHelper.getData().activeObjects = this.entriesService.selection.selected;\n            } else {\n                console.warn('optionsHelper is not initalized correctly; data is empty');\n            }\n            void this.optionsHelper.refreshComponents();\n        });\n    }\n\n    ngOnInit(): void {\n        if (this.primaryInstance) {\n            this.optionsHelper.registerGlobalKeyboardShortcuts();\n        }\n        this.entriesService.columnsSubject\n            .pipe(\n                takeUntil(this.destroyed),\n                filter((c) => c?.fromUser),\n            )\n            .subscribe((c) => this.columnsChange.emit(c.columns));\n    }\n\n    ngOnChanges(changes: { [key: string]: SimpleChange } = {}) {\n        if (!this.componentRef) {\n            this.init();\n        }\n        this.entriesService.list = this;\n        this.entriesService.dataSource = this.dataSource;\n        this.entriesService.scope = this.scope;\n        if (changes.columns) {\n            this.entriesService.columnsSubject.next({\n                columns: this.columns,\n                fromUser: false,\n            });\n        }\n        this.entriesService.configureColumns = this.configureColumns;\n        this.entriesService.checkbox = this.checkbox;\n        this.entriesService.displayType = this.displayType;\n        this.entriesService.elementInteractionType = this.elementInteractionType;\n        this.entriesService.gridConfig = this.gridConfig;\n        this.entriesService.options = this.options;\n        this.entriesService.globalOptions = this.globalOptions;\n        this.entriesService.sort = this.sort;\n        this.entriesService.sortChange = this.sortChange;\n        this.entriesService.dragDrop = this.dragDrop;\n        this.entriesService.clickItem = this.clickItem;\n        this.entriesService.dblClickItem = this.dblClickItem;\n        this.entriesService.fetchData = this.fetchData;\n        this.entriesService.primaryInstance = this.primaryInstance;\n        this.entriesService.singleClickHint = this.singleClickHint;\n        this.entriesService.disableInfiniteScroll = this.disableInfiniteScroll;\n        this.entriesService.scrollGradientColor.set(this.scrollGradientColor);\n\n        if (changes['initConfig']) {\n            void this.initOptionsGenerator(this.initConfig);\n        }\n        if (this.componentRef) {\n            this.componentRef.instance.changeDetectorRef?.detectChanges();\n        }\n        // This might need wrapping with `setTimeout`.\n        this.updateTemplates();\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    /**\n     * Replaces this wrapper with the configured custom-node-list component.\n     */\n    private init(): void {\n        this.customNodeListComponent = this.temporaryStorageService.get(\n            TemporaryStorageService.CUSTOM_NODE_ENTRIES_COMPONENT,\n            null,\n        );\n        if (this.customNodeListComponent == null) {\n            return;\n        }\n        this.componentRef = this.uiService.injectAngularComponent(\n            this.viewContainerRef,\n            this.customNodeListComponent,\n            this.elementRef.nativeElement,\n            // Input bindings are initialized in `ngOnChanges`.\n            this.getOutputBindings(),\n        );\n    }\n    /**\n     * Creates a simple map of the output bindings defined in this component.\n     */\n    private getOutputBindings(): { [key: string]: EventEmitter<any> } {\n        const outputBindings: { [key: string]: any } = {};\n        for (const key of Object.keys(this)) {\n            const value = (this as any)[key];\n            if (value instanceof EventEmitter) {\n                outputBindings[key] = value;\n            }\n        }\n        return outputBindings;\n    }\n\n    getDisplayType(): NodeEntriesDisplayType {\n        return this.displayType;\n    }\n\n    onDisplayTypeChange() {\n        return this.displayTypeChange.asObservable();\n    }\n\n    setDisplayType(displayType: NodeEntriesDisplayType): void {\n        this.displayType = displayType;\n        this.entriesService.displayType = displayType;\n        this.ngOnChanges();\n        this.displayTypeChange.emit(displayType);\n    }\n\n    updateNodes(nodes: void | T[]) {\n        if (!nodes) {\n            return;\n        }\n        this.dataSource.getData().forEach((d) => {\n            let hits = (nodes as T[]).filter((n) =>\n                (n as Node)?.ref\n                    ? (n as Node)?.ref.id === (d as Node)?.ref.id\n                    : (n as GenericAuthority)?.authorityName ===\n                      (d as GenericAuthority)?.authorityName,\n            );\n            if (hits.length === 0) {\n                // handle if the original has changed (for collection refs)\n                hits = (nodes as T[]).filter(\n                    (n) =>\n                        (n as Node)?.ref &&\n                        (n as Node)?.ref?.id === (d as unknown as CollectionReference)?.originalId,\n                );\n            }\n            if (hits.length === 1) {\n                this.nodeHelperService.copyDataToNode(d as Node, hits[0] as Node);\n            }\n        });\n        // trigger rebuild\n        if (this.dataSource instanceof NodeDataSource) {\n            (this.dataSource as NodeDataSource<T>).refresh();\n        }\n        const oldSelection = this.entriesService.selection.selected;\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(\n            ...oldSelection.map(\n                (o) => this.dataSource.getData().filter((d) => Helper.objectEquals(o, d))?.[0],\n            ),\n        );\n        this.changeDetectorRef.detectChanges();\n    }\n\n    showReorderColumnsDialog(): void {}\n\n    addVirtualNodes(virtual: T[]): void {\n        virtual = virtual.map((o) => {\n            (o as VirtualNode).virtual = true;\n            return o;\n        });\n        virtual.forEach((v: T) => {\n            const contains = this.dataSource\n                .getData()\n                .some((d) =>\n                    (d as Node).ref\n                        ? (d as Node).ref?.id === (v as Node).ref?.id\n                        : (d as User).authorityName === (v as User).authorityName,\n                );\n            if (contains) {\n                if ((v as VirtualNode).override !== false) {\n                    this.updateNodes([v]);\n                }\n            } else {\n                this.dataSource.appendData([v], 'before');\n            }\n            if ((v as VirtualNode).observe) {\n                interval(2000)\n                    .pipe(\n                        take(10),\n                        takeUntil(this.destroyed),\n                        switchMap(() =>\n                            this.nodeService.getNode((v as VirtualNode).ref.id, {\n                                repository: (v as VirtualNode).ref.repo,\n                            }),\n                        ),\n                    )\n                    .subscribe((node) => {\n                        (node as VirtualNode).virtual = true;\n                        this.updateNodes([node as T]);\n                    });\n            }\n        });\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(...virtual);\n        this.virtualNodesAdded.emit(virtual as Node[]);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    setOptions(options: ListOptions): void {\n        this.options = options;\n        this.ngOnChanges();\n    }\n\n    selectAll() {\n        this.entriesService.selection.select(...this.entriesService.dataSource.getData());\n    }\n    getSelection(): CustomSelectionModel<T> {\n        return this.entriesService.selection;\n    }\n\n    async initOptionsGenerator(config: ListOptionsConfig) {\n        await this.optionsHelper.initComponents(config.actionbar, this);\n        this.optionsHelper.setData({\n            scope: this.entriesService.scope,\n            activeObjects: this.entriesService.selection.selected,\n            selectedObjects: this.entriesService.selection.selected,\n            allObjects: this.dataSource.getData(),\n            parent: config.parent,\n            customOptions: config.customOptions,\n        });\n        void this.optionsHelper.refreshComponents();\n    }\n\n    ngAfterViewInit(): void {\n        // Prevent changed-after-checked error\n        void Promise.resolve().then(() => this.updateTemplates());\n    }\n\n    private updateTemplates(): void {\n        this.templatesService.title = this.titleRef;\n        this.templatesService.empty = this.emptyRef;\n        this.templatesService.actionArea = this.actionAreaRef;\n        this.templatesService.overlay = this.overlayRef;\n    }\n\n    /**\n     * reset the pagination to the first page\n     * hint: this will do nothing in case the paginationStrategy !== Pagination\n     */\n    resetPagination() {\n        this.nodeEntriesComponentRef?.paginator?.firstPage();\n    }\n\n    deleteNodes(objects: T[]): void {\n        this.dataSource.removeData(objects);\n        this.getSelection().clear();\n    }\n}\n"]}
@@ -1,132 +0,0 @@
1
- import { Component, Optional, ViewChild, } from '@angular/core';
2
- import { MatPaginator } from '@angular/material/paginator';
3
- import { Subject } from 'rxjs';
4
- import { first, takeUntil } from 'rxjs/operators';
5
- import { NodeEntriesDisplayType } from './entries-model';
6
- import { NodeDataSourceRemote } from './node-data-source-remote';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "./node-entries-global.service";
9
- import * as i2 from "../services/node-entries.service";
10
- import * as i3 from "./node-entries-templates.service";
11
- import * as i4 from "../services/abstract/keyboard-shortcuts.service";
12
- import * as i5 from "@angular/router";
13
- import * as i6 from "@ngx-translate/core";
14
- import * as i7 from "@angular/common";
15
- import * as i8 from "@angular/material/paginator";
16
- import * as i9 from "./node-entries-card-grid/node-entries-card-grid.component";
17
- import * as i10 from "./node-entries-table/node-entries-table.component";
18
- export class NodeEntriesComponent {
19
- constructor(changeDetectorRef, entriesGlobalService, entriesService, templatesService, globalKeyboardShortcuts, route, translate) {
20
- this.changeDetectorRef = changeDetectorRef;
21
- this.entriesGlobalService = entriesGlobalService;
22
- this.entriesService = entriesService;
23
- this.templatesService = templatesService;
24
- this.globalKeyboardShortcuts = globalKeyboardShortcuts;
25
- this.route = route;
26
- this.translate = translate;
27
- this.NodeEntriesDisplayType = NodeEntriesDisplayType;
28
- this.destroyed = new Subject();
29
- this.updateKeyboardShortcuts = new Subject();
30
- }
31
- ngOnInit() {
32
- if (this.entriesService.primaryInstance) {
33
- this.registerGlobalKeyboardShortcuts();
34
- }
35
- if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {
36
- // We don't require `sort` to be defined, but if it is set but not yet ready (`null`),
37
- // we wait for its value before initializing the data source, so the first request is
38
- // sent with the correct sort configuration. That is why we explicitly do not drop
39
- // `undefined` with the `first` operator below.
40
- this.entriesService.sortSubject
41
- .pipe(first((sort) => sort !== null))
42
- .subscribe(() => this.initRemoteDataSource(this.entriesService.dataSource));
43
- }
44
- }
45
- ngAfterViewInit() {
46
- if (this.paginator) {
47
- void this.initPaginator(this.paginator);
48
- this.changeDetectorRef.detectChanges();
49
- }
50
- }
51
- ngOnDestroy() {
52
- this.destroyed.next();
53
- this.destroyed.complete();
54
- }
55
- registerGlobalKeyboardShortcuts() {
56
- this.globalKeyboardShortcuts.register([
57
- {
58
- modifiers: ['Ctrl/Cmd'],
59
- keyCode: 'KeyA',
60
- ignoreWhen: (event) =>
61
- // SmallGrid doesn't support selection
62
- this.entriesService.displayType === NodeEntriesDisplayType.SmallGrid,
63
- callback: () => this.entriesService.toggleSelectAll(),
64
- },
65
- ], { until: this.destroyed });
66
- }
67
- initRemoteDataSource(dataSource) {
68
- const pageSize = this.entriesGlobalService.getPaginatorSizeOptions(this.entriesService.scope)[0];
69
- dataSource.init({
70
- paginationConfig: {
71
- defaultPageSize: pageSize,
72
- strategy: this.entriesService.paginationStrategy,
73
- },
74
- defaultSort: this.entriesService.sort,
75
- });
76
- if (this.entriesService.primaryInstance) {
77
- // Automatic query-params handling is only supported by node-data-source-remote.
78
- dataSource.registerQueryParameters(this.route);
79
- }
80
- }
81
- async initPaginator(paginator) {
82
- paginator._intl.itemsPerPageLabel = await this.translate
83
- .get('PAGINATOR.itemsPerPageLabel')
84
- .toPromise();
85
- paginator._intl.nextPageLabel = await this.translate
86
- .get('PAGINATOR.nextPageLabel')
87
- .toPromise();
88
- paginator._intl.previousPageLabel = await this.translate
89
- .get('PAGINATOR.previousPageLabel')
90
- .toPromise();
91
- paginator._intl.getRangeLabel = (page, pageSize, length) => this.translate.instant('PAGINATOR.getRangeLabel', {
92
- page: page + 1,
93
- pageSize,
94
- length,
95
- pageCount: Math.ceil(length / pageSize),
96
- });
97
- // Connect data source.
98
- this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe((dataSource) => {
99
- if (dataSource instanceof NodeDataSourceRemote) {
100
- dataSource.paginator = paginator;
101
- }
102
- else {
103
- paginator.length = dataSource?.getTotal();
104
- dataSource
105
- ?.connectPagination()
106
- .pipe(takeUntil(this.destroyed))
107
- .subscribe(() => {
108
- paginator.length = dataSource.getTotal();
109
- });
110
- }
111
- });
112
- }
113
- openPage(page) {
114
- this.entriesService.fetchData.emit({
115
- offset: page.pageIndex * page.pageSize,
116
- amount: page.pageSize,
117
- reset: true,
118
- });
119
- }
120
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NodeEntriesGlobalService }, { token: i2.NodeEntriesService }, { token: i3.NodeEntriesTemplatesService }, { token: i4.KeyboardShortcutsService, optional: true }, { token: i5.ActivatedRoute }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
121
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesComponent, selector: "es-node-entries", viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], ngImport: i0, template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 10px;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i8.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "component", type: i9.NodeEntriesCardGridComponent, selector: "es-node-entries-card-grid", inputs: ["displayType"] }, { kind: "component", type: i10.NodeEntriesTableComponent, selector: "es-node-entries-table" }] }); }
122
- }
123
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesComponent, decorators: [{
124
- type: Component,
125
- args: [{ selector: 'es-node-entries', template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 10px;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"] }]
126
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.NodeEntriesGlobalService }, { type: i2.NodeEntriesService }, { type: i3.NodeEntriesTemplatesService }, { type: i4.KeyboardShortcutsService, decorators: [{
127
- type: Optional
128
- }] }, { type: i5.ActivatedRoute }, { type: i6.TranslateService }], propDecorators: { paginator: [{
129
- type: ViewChild,
130
- args: [MatPaginator]
131
- }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.ts","../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewChild,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { ActivatedRoute } from '@angular/router';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject } from 'rxjs';\nimport { filter, first, takeUntil } from 'rxjs/operators';\nimport { NodeEntriesDataType, NodeEntriesDisplayType } from './entries-model';\nimport { NodeEntriesGlobalService } from './node-entries-global.service';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesService } from '../services/node-entries.service';\nimport { KeyboardShortcutsService } from '../services/abstract/keyboard-shortcuts.service';\nimport { NodeDataSourceRemote } from './node-data-source-remote';\n\n@Component({\n    selector: 'es-node-entries',\n    templateUrl: 'node-entries.component.html',\n    styleUrls: ['node-entries.component.scss'],\n})\nexport class NodeEntriesComponent<T extends NodeEntriesDataType>\n    implements OnInit, AfterViewInit, OnDestroy\n{\n    readonly NodeEntriesDisplayType = NodeEntriesDisplayType;\n\n    @ViewChild(MatPaginator) paginator: MatPaginator;\n\n    private readonly destroyed = new Subject<void>();\n    private readonly updateKeyboardShortcuts = new Subject<void>();\n\n    constructor(\n        public changeDetectorRef: ChangeDetectorRef,\n        public entriesGlobalService: NodeEntriesGlobalService,\n        public entriesService: NodeEntriesService<T>,\n        public templatesService: NodeEntriesTemplatesService,\n        @Optional() private globalKeyboardShortcuts: KeyboardShortcutsService,\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n    ) {}\n\n    ngOnInit(): void {\n        if (this.entriesService.primaryInstance) {\n            this.registerGlobalKeyboardShortcuts();\n        }\n        if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {\n            // We don't require `sort` to be defined, but if it is set but not yet ready (`null`),\n            // we wait for its value before initializing the data source, so the first request is\n            // sent with the correct sort configuration. That is why we explicitly do not drop\n            // `undefined` with the `first` operator below.\n            this.entriesService.sortSubject\n                .pipe(first((sort) => sort !== null))\n                .subscribe(() =>\n                    this.initRemoteDataSource(\n                        this.entriesService.dataSource as NodeDataSourceRemote<T>,\n                    ),\n                );\n        }\n    }\n\n    ngAfterViewInit() {\n        if (this.paginator) {\n            void this.initPaginator(this.paginator);\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    private registerGlobalKeyboardShortcuts() {\n        this.globalKeyboardShortcuts.register(\n            [\n                {\n                    modifiers: ['Ctrl/Cmd'],\n                    keyCode: 'KeyA',\n                    ignoreWhen: (event) =>\n                        // SmallGrid doesn't support selection\n                        this.entriesService.displayType === NodeEntriesDisplayType.SmallGrid,\n                    callback: () => this.entriesService.toggleSelectAll(),\n                },\n            ],\n            { until: this.destroyed },\n        );\n    }\n\n    private initRemoteDataSource(dataSource: NodeDataSourceRemote<T>): void {\n        const pageSize = this.entriesGlobalService.getPaginatorSizeOptions(\n            this.entriesService.scope,\n        )[0];\n        dataSource.init({\n            paginationConfig: {\n                defaultPageSize: pageSize,\n                strategy: this.entriesService.paginationStrategy,\n            },\n            defaultSort: this.entriesService.sort,\n        });\n        if (this.entriesService.primaryInstance) {\n            // Automatic query-params handling is only supported by node-data-source-remote.\n            dataSource.registerQueryParameters(this.route);\n        }\n    }\n\n    private async initPaginator(paginator: MatPaginator) {\n        paginator._intl.itemsPerPageLabel = await this.translate\n            .get('PAGINATOR.itemsPerPageLabel')\n            .toPromise();\n        paginator._intl.nextPageLabel = await this.translate\n            .get('PAGINATOR.nextPageLabel')\n            .toPromise();\n        paginator._intl.previousPageLabel = await this.translate\n            .get('PAGINATOR.previousPageLabel')\n            .toPromise();\n        paginator._intl.getRangeLabel = (page, pageSize, length) =>\n            this.translate.instant('PAGINATOR.getRangeLabel', {\n                page: page + 1,\n                pageSize,\n                length,\n                pageCount: Math.ceil(length / pageSize),\n            });\n        // Connect data source.\n        this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe((dataSource) => {\n            if (dataSource instanceof NodeDataSourceRemote) {\n                (dataSource as NodeDataSourceRemote).paginator = paginator;\n            } else {\n                paginator.length = dataSource?.getTotal();\n                dataSource\n                    ?.connectPagination()\n                    .pipe(takeUntil(this.destroyed))\n                    .subscribe(() => {\n                        paginator.length = dataSource.getTotal();\n                    });\n            }\n        });\n    }\n\n    openPage(page: PageEvent) {\n        this.entriesService.fetchData.emit({\n            offset: page.pageIndex * page.pageSize,\n            amount: page.pageSize,\n            reset: true,\n        });\n    }\n}\n","<div class=\"top-matter\">\n  <div class=\"title\">\n    <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n  </div>\n  <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n  <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n    <es-node-entries-table></es-node-entries-table>\n  </ng-container>\n  <ng-container\n    *ngIf=\"\n      entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n      entriesService.displayType === NodeEntriesDisplayType.Grid\n    \"\n  >\n    <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n    </es-node-entries-card-grid>\n  </ng-container>\n  <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n    <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n  </ng-container>\n</ng-container>\n<mat-paginator\n  #paginator\n  [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n  *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n  [class.display-none]=\"\n    (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n    entriesService.dataSource.isEmpty()\n  \"\n  (page)=\"openPage($event)\"\n></mat-paginator>\n"]}