ngx-edu-sharing-ui 10.0.20 → 10.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/scss/material-theme.scss +3 -3
- package/assets/scss/mixins.scss +1 -1
- package/assets/scss/variables-root.scss +2 -0
- package/assets/scss/variables-scss.scss +3 -4
- package/assets/scss/variables.scss +1 -1
- package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/index.d.ts +1 -0
- package/lib/list-items/list-widget.d.ts +1 -1
- package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
- package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
- package/package.json +8 -9
- package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
- package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
- package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
- package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
- package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
- package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
- package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
- package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
- package/esm2022/lib/directives/icon.directive.mjs +0 -184
- package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
- package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
- package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
- package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
- package/esm2022/lib/index.mjs +0 -96
- package/esm2022/lib/list-items/available-widgets.mjs +0 -27
- package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
- package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
- package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
- package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
- package/esm2022/lib/list-items/list-items.module.mjs +0 -50
- package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
- package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
- package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
- package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
- package/esm2022/lib/list-items/list-widget.mjs +0 -49
- package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
- package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
- package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
- package/esm2022/lib/mds/mds.module.mjs +0 -16
- package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
- package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
- package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
- package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
- package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
- package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
- package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
- package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
- package/esm2022/lib/node-entries/entries-model.mjs +0 -24
- package/esm2022/lib/node-entries/items-cap.mjs +0 -47
- package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
- package/esm2022/lib/node-entries/node-cache.mjs +0 -73
- package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
- package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
- package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
- package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
- package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
- package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
- package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
- package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
- package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
- package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
- package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
- package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
- package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
- package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
- package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
- package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
- package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
- package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
- package/esm2022/lib/node-url/node-url.component.mjs +0 -132
- package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
- package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
- package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
- package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
- package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
- package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
- package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
- package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
- package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
- package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
- package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
- package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
- package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
- package/esm2022/lib/services/abstract/app.service.mjs +0 -3
- package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
- package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
- package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
- package/esm2022/lib/services/accessibility.service.mjs +0 -73
- package/esm2022/lib/services/app-container.service.mjs +0 -69
- package/esm2022/lib/services/local-events.service.mjs +0 -43
- package/esm2022/lib/services/node-entries.service.mjs +0 -201
- package/esm2022/lib/services/node-helper.service.mjs +0 -330
- package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
- package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
- package/esm2022/lib/services/render-helper.service.mjs +0 -114
- package/esm2022/lib/services/repo-url.service.mjs +0 -50
- package/esm2022/lib/services/search-helper.service.mjs +0 -52
- package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
- package/esm2022/lib/services/ui.service.mjs +0 -327
- package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
- package/esm2022/lib/spinner/spinner.component.mjs +0 -19
- package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
- package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
- package/esm2022/lib/translations/translation-loader.mjs +0 -219
- package/esm2022/lib/translations/translation-source.mjs +0 -11
- package/esm2022/lib/translations/translations.module.mjs +0 -82
- package/esm2022/lib/translations/translations.service.mjs +0 -238
- package/esm2022/lib/types/accessibillity.mjs +0 -19
- package/esm2022/lib/types/api-models.mjs +0 -2
- package/esm2022/lib/types/drag-drop.mjs +0 -2
- package/esm2022/lib/types/injection-tokens.mjs +0 -31
- package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
- package/esm2022/lib/types/list-item.mjs +0 -41
- package/esm2022/lib/types/option-item.mjs +0 -192
- package/esm2022/lib/types/workflow.mjs +0 -25
- package/esm2022/lib/util/DateHelper.mjs +0 -200
- package/esm2022/lib/util/VCard.mjs +0 -278
- package/esm2022/lib/util/color-helper.mjs +0 -124
- package/esm2022/lib/util/duration-helper.mjs +0 -102
- package/esm2022/lib/util/functions.mjs +0 -13
- package/esm2022/lib/util/helper.mjs +0 -64
- package/esm2022/lib/util/isNumeric.mjs +0 -11
- package/esm2022/lib/util/rest-helper.mjs +0 -42
- package/esm2022/lib/util/ui-animation.mjs +0 -146
- package/esm2022/lib/util/ui-constants.mjs +0 -21
- package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
- package/esm2022/public-api.mjs +0 -2
|
@@ -1,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"]}
|