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,329 +0,0 @@
1
- import { CdkDropList, moveItemInArray } from '@angular/cdk/drag-drop';
2
- import { ChangeDetectionStrategy, Component, effect, ElementRef, HostBinding, Input, ViewChild, ViewChildren, } from '@angular/core';
3
- import { RestConstants } from 'ngx-edu-sharing-api';
4
- import * as rxjs from 'rxjs';
5
- import { BehaviorSubject, Subject } from 'rxjs';
6
- import { distinctUntilChanged, map, switchMap, take, takeUntil } from 'rxjs/operators';
7
- import { NodeEntriesDisplayType } from '../entries-model';
8
- import { ItemsCap } from '../items-cap';
9
- import { SortSelectPanelComponent } from '../sort-select-panel/sort-select-panel.component';
10
- import { CustomTemplatesDataSource } from '../custom-templates-data-source';
11
- import { Target } from '../../types/option-item';
12
- import { ListItemSort } from '../../types/list-item';
13
- import * as i0 from "@angular/core";
14
- import * as i1 from "../../services/node-entries.service";
15
- import * as i2 from "../node-entries-global.service";
16
- import * as i3 from "../node-entries-templates.service";
17
- import * as i4 from "../../services/node-helper.service";
18
- import * as i5 from "../../services/ui.service";
19
- import * as i6 from "@angular/common";
20
- import * as i7 from "@angular/cdk/overlay";
21
- import * as i8 from "@angular/cdk/drag-drop";
22
- import * as i9 from "../../directives/border-box-observer.directive";
23
- import * as i10 from "../../dropdown/dropdown.component";
24
- import * as i11 from "../../directives/icon.directive";
25
- import * as i12 from "../../directives/infinite-scroll.directive";
26
- import * as i13 from "../../spinner/spinner.component";
27
- import * as i14 from "@angular/material/button";
28
- import * as i15 from "@angular/material/badge";
29
- import * as i16 from "@angular/material/tooltip";
30
- import * as i17 from "../node-entries-table/column-chooser/column-chooser.component";
31
- import * as i18 from "../node-entries-card/node-entries-card.component";
32
- import * as i19 from "../node-entries-card-small/node-entries-card-small.component";
33
- import * as i20 from "../sort-select-panel/sort-select-panel.component";
34
- import * as i21 from "../../directives/drag-nodes/nodes-drag.directive";
35
- import * as i22 from "../../directives/drag-nodes/nodes-drop-target.directive";
36
- import * as i23 from "../node-entries-global-options/node-entries-global-options.component";
37
- import * as i24 from "@ngx-translate/core";
38
- let displayedWarnings = [];
39
- export class NodeEntriesCardGridComponent {
40
- set gridTop(value) {
41
- this.registerGridTop(value);
42
- }
43
- set sortPanel(value) {
44
- // if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {
45
- setTimeout(() => {
46
- this.entriesService.dataSource.sortPanel = value;
47
- });
48
- // }
49
- }
50
- constructor(entriesService, entriesGlobalService, templatesService, nodeHelperService, ui, ngZone) {
51
- this.entriesService = entriesService;
52
- this.entriesGlobalService = entriesGlobalService;
53
- this.templatesService = templatesService;
54
- this.nodeHelperService = nodeHelperService;
55
- this.ui = ui;
56
- this.ngZone = ngZone;
57
- this.NodeEntriesDisplayType = NodeEntriesDisplayType;
58
- this.Target = Target;
59
- /**
60
- * relative scrolling when a scrolling arrow (left or right) is used
61
- * a value of 1 would mean to scroll the full width of the entire content
62
- */
63
- this.ScrollingOffsetPercentage = 0.4;
64
- this.columnChooserVisible$ = new BehaviorSubject(false);
65
- this.isDragging = false; // Drag-and-drop, not rearrange
66
- /**
67
- * Whether the number of shown items is limited by `gridConfig.maxRows`.
68
- *
69
- * A value of `true` does not mean, that there would be more items available.
70
- */
71
- this.visibleItemsLimited = false;
72
- /**
73
- * updates via boxObserver
74
- * and holds the information if scrolling in the direction is currently feasible
75
- */
76
- this.scroll = {
77
- left: false,
78
- right: false,
79
- };
80
- this.itemsPerRowSubject = new BehaviorSubject(null);
81
- this.itemsCap = new ItemsCap();
82
- this.destroyed = new Subject();
83
- this.canDropNodes = (dragData) => this.entriesService.dragDrop.dropAllowed?.(dragData);
84
- this.nodes$ = this.entriesService.dataSource$.pipe(switchMap((dataSource) => dataSource?.connect()));
85
- this.maxRows$ = this.entriesService.gridConfig$.pipe(map((gridConfig) => gridConfig?.maxRows || null), distinctUntilChanged());
86
- this.layout$ = this.entriesService.gridConfig$.pipe(map((gridConfig) => gridConfig?.layout || 'grid'), distinctUntilChanged());
87
- this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe(() => {
88
- this.updateScrollState();
89
- });
90
- effect(() => (this.scrollGradientColor = this.entriesService.scrollGradientColor()));
91
- }
92
- ngOnInit() {
93
- this.registerItemsCap();
94
- this.registerLayout();
95
- this.registerVisibleItemsLimited();
96
- }
97
- ngOnDestroy() {
98
- this.destroyed.next();
99
- this.destroyed.complete();
100
- }
101
- registerGridTop(gridTop) {
102
- setTimeout(() => {
103
- this.templatesService.entriesTopMatter = gridTop;
104
- });
105
- this.destroyed.subscribe(() => {
106
- if (this.templatesService.entriesTopMatter === gridTop) {
107
- setTimeout(() => {
108
- this.templatesService.entriesTopMatter = null;
109
- });
110
- }
111
- });
112
- }
113
- registerItemsCap() {
114
- this.entriesService.dataSource$
115
- .pipe(takeUntil(this.destroyed))
116
- .subscribe((dataSource) => (dataSource.itemsCap = this.itemsCap));
117
- rxjs.combineLatest([this.itemsPerRowSubject.pipe(distinctUntilChanged()), this.maxRows$])
118
- .pipe(map(([itemsPerRow, maxRows]) => maxRows > 0 && itemsPerRow !== null ? itemsPerRow * maxRows : null))
119
- .subscribe((cap) => (this.itemsCap.cap = cap));
120
- }
121
- registerLayout() {
122
- this.layout$.subscribe((layout) => (this.layout = layout));
123
- }
124
- onSortChange(sort) {
125
- this.entriesService.sort.active = sort.active;
126
- this.entriesService.sort.direction = sort.direction;
127
- this.entriesService.sortChange.emit(this.entriesService.sort);
128
- }
129
- loadData(source) {
130
- // @TODO: Maybe this is better handled in a more centraled service
131
- if (source === 'scroll') {
132
- // check if there is a footer
133
- const elements = document.getElementsByTagName('footer');
134
- if (elements.length && elements.item(0).innerHTML.trim()) {
135
- return;
136
- }
137
- }
138
- const couldLoadMore = this.entriesService.loadMore(source);
139
- if (couldLoadMore && source === 'button') {
140
- this.focusFirstNewItemWhenLoaded();
141
- }
142
- }
143
- onCustomSortingInProgressChange() {
144
- this.entriesService.sortChange.emit(this.entriesService.sort);
145
- setTimeout(() => {
146
- this.refreshDropLists();
147
- });
148
- }
149
- onRearrangeDragEntered($event) {
150
- moveItemInArray(this.entriesService.dataSource.getData(), $event.item.data, $event.container.data);
151
- // `CdkDrag` doesn't really want us to rearrange the items while dragging. Its cached
152
- // element positions get out of sync unless we update them manually.
153
- this.ngZone.runOutsideAngular(() => setTimeout(() => this.dropLists?.forEach((list) => list._dropListRef['_cacheItems']())));
154
- }
155
- onRearrangeDragStarted() {
156
- this.globalCursorStyle = document.createElement('style');
157
- document.body.appendChild(this.globalCursorStyle);
158
- this.globalCursorStyle.innerHTML = `* {cursor: grabbing !important; }`;
159
- }
160
- onRearrangeDragEnded() {
161
- document.body.removeChild(this.globalCursorStyle);
162
- this.globalCursorStyle = null;
163
- }
164
- getDragStartDelay() {
165
- if (this.ui.isMobile()) {
166
- return 500;
167
- }
168
- else {
169
- return null;
170
- }
171
- }
172
- registerVisibleItemsLimited() {
173
- this.maxRows$.subscribe((maxRows) => {
174
- this.visibleItemsLimited = maxRows > 0;
175
- });
176
- }
177
- refreshDropLists() {
178
- this.dropLists = this.dropListsQuery.toArray();
179
- }
180
- focusFirstNewItemWhenLoaded() {
181
- const oldLength = this.itemRefs.length;
182
- this.itemRefs.changes
183
- .pipe(take(1))
184
- .subscribe((items) => {
185
- if (items.length > oldLength) {
186
- this.focusOnce(items.get(oldLength).nativeElement);
187
- }
188
- });
189
- }
190
- focusOnce(element) {
191
- element.setAttribute('tabindex', '-1');
192
- element.focus();
193
- element.addEventListener('blur', () => element.removeAttribute('tabindex'), { once: true });
194
- }
195
- onGridSizeChanges() {
196
- const itemsPerRow = this.getItemsPerRow();
197
- this.itemsPerRowSubject.next(itemsPerRow);
198
- this.updateScrollState();
199
- }
200
- getItemsPerRow() {
201
- if (!this.gridRef?.nativeElement) {
202
- return null;
203
- }
204
- return getComputedStyle(this.gridRef.nativeElement)
205
- .getPropertyValue('grid-template-columns')
206
- .split(' ').length;
207
- }
208
- getSortColumns() {
209
- return this.entriesService.sort?.columns?.filter((c) => {
210
- const result = this.entriesService.columns
211
- .concat(new ListItemSort('NODE', 'score'), new ListItemSort('NODE', RestConstants.CCM_PROP_COLLECTION_ORDERED_POSITION), new ListItemSort('NODE', RestConstants.CM_PROP_TITLE), new ListItemSort('NODE', RestConstants.CM_NAME), new ListItemSort('NODE', RestConstants.CM_PROP_C_CREATED), new ListItemSort('NODE', RestConstants.CM_MODIFIED_DATE), new ListItemSort('NODE', RestConstants.CCM_PROP_REPLICATIONMODIFIED), new ListItemSort('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCETIMESTAMP))
212
- .some((c2) => c.type === c2.type && c2.name === c.name);
213
- if (!result && !this.entriesService.configureColumns) {
214
- return this.entriesService.sort?.columns;
215
- /*
216
- const warning =
217
- 'Sort field ' +
218
- c.name +
219
- ' was specified but is not present as a column. ' +
220
- 'It will be ignored. Please also configure this field in the <lists> section';
221
- if (!displayedWarnings.includes(warning)) {
222
- console.warn(warning);
223
- displayedWarnings.push(warning);
224
- }*/
225
- }
226
- return result;
227
- });
228
- }
229
- onNodesDropped(dragData) {
230
- this.entriesService.dragDrop.dropped(dragData.target, {
231
- element: dragData.draggedNodes,
232
- mode: dragData.action,
233
- });
234
- }
235
- getDragEnabled() {
236
- return this.ui.isTouchSubject.pipe(map((touch) => !touch && this.entriesService.dragDrop?.dragAllowed));
237
- }
238
- getDragData(node) {
239
- const selection = this.entriesService.selection;
240
- if (selection.isSelected(node)) {
241
- return selection.selected;
242
- }
243
- else {
244
- return [node];
245
- }
246
- }
247
- onDragStarted(node) {
248
- if (!this.entriesService.selection.isSelected(node)) {
249
- this.entriesService.selection.clear();
250
- this.entriesService.selection.select(node);
251
- }
252
- this.isDragging = true;
253
- }
254
- onDragEnded() {
255
- this.isDragging = false;
256
- }
257
- canScroll(direction) {
258
- const element = this.gridRef?.nativeElement;
259
- if (element) {
260
- if (direction === 'left') {
261
- return element.scrollLeft > 0;
262
- }
263
- else if (direction === 'right') {
264
- /*
265
- use a small pixel buffer (10px) because scrolling aligns with the start of each card and
266
- it can cause slight alignment issues on the end of the container
267
- */
268
- return element.scrollLeft < element.scrollWidth - element.clientWidth - 10;
269
- }
270
- }
271
- return false;
272
- }
273
- updateScrollState() {
274
- if (this.layout === 'scroll') {
275
- this.scroll.left = this.canScroll('left');
276
- this.scroll.right = this.canScroll('right');
277
- }
278
- }
279
- doScroll(direction) {
280
- // 1 is enough because the browser will handle it via css snapping
281
- const leftScroll = this.gridRef?.nativeElement.scrollLeft;
282
- const rect = this.gridRef?.nativeElement.getBoundingClientRect();
283
- // using scroll because it works more reliable than scrollBy
284
- this.gridRef?.nativeElement.scroll({
285
- left: leftScroll +
286
- Math.max(250, rect.width * this.ScrollingOffsetPercentage) *
287
- (direction === 'right' ? 1 : -1),
288
- behavior: 'smooth',
289
- });
290
- }
291
- isCustomTemplate(node) {
292
- return (this.entriesService.dataSource instanceof CustomTemplatesDataSource ||
293
- node.elementRef);
294
- }
295
- isBlocked(node) {
296
- return (node.properties?.[RestConstants.CCM_PROP_IMPORT_BLOCKED]?.[0] === 'true' ||
297
- this.nodeHelperService.isNodeRevoked(node));
298
- }
299
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardGridComponent, deps: [{ token: i1.NodeEntriesService }, { token: i2.NodeEntriesGlobalService }, { token: i3.NodeEntriesTemplatesService }, { token: i4.NodeHelperService }, { token: i5.UIService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
300
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesCardGridComponent, selector: "es-node-entries-card-grid", inputs: { displayType: "displayType" }, host: { properties: { "style.--scroll-gradient-color": "this.scrollGradientColor" } }, viewQueries: [{ propertyName: "columnChooserTrigger", first: true, predicate: ["columnChooserTrigger"], descendants: true }, { propertyName: "gridTop", first: true, predicate: ["gridTop"], descendants: true, static: true }, { propertyName: "sortPanel", first: true, predicate: SortSelectPanelComponent, descendants: true }, { propertyName: "gridRef", first: true, predicate: ["grid"], descendants: true }, { propertyName: "dropListsQuery", predicate: CdkDropList, descendants: true }, { propertyName: "itemRefs", predicate: ["item"], descendants: true, read: ElementRef }], ngImport: i0, template: "<ng-template #gridTop>\n <button\n *ngIf=\"entriesService.configureColumns\"\n mat-icon-button\n (click)=\"columnChooserVisible$.next(!columnChooserVisible$.value)\"\n cdkOverlayOrigin\n #columnChooserTrigger=\"cdkOverlayOrigin\"\n [matTooltip]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n [attr.aria-label]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n >\n <i esIcon=\"settings\"></i>\n </button>\n <es-sort-select-panel\n *ngIf=\"entriesService.sort?.allowed\"\n class=\"order-panel\"\n [active]=\"entriesService.sort.active\"\n [direction]=\"entriesService.sort.direction\"\n [columns]=\"getSortColumns()\"\n (sortChange)=\"onSortChange($event)\"\n [(customSortingInProgress)]=\"entriesService.sort.customSortingInProgress\"\n (customSortingInProgressChange)=\"onCustomSortingInProgressChange()\"\n ></es-sort-select-panel>\n</ng-template>\n<es-column-chooser\n *ngIf=\"entriesService.configureColumns\"\n [(columns)]=\"entriesService.columns\"\n [columnChooserVisible]=\"columnChooserVisible$ | async\"\n [origin]=\"columnChooserTrigger\"\n (columnChooserVisibleChange)=\"columnChooserVisible$.next($event)\"\n></es-column-chooser>\n<es-dropdown #dropdown [options]=\"entriesService.options?.[Target.ListDropdown]\"></es-dropdown>\n\n<!-- Do not render the list element (`role=\"list\"` or `li`) when there are no list items. -->\n<ng-container\n *ngIf=\"(nodes$ | async)?.length > 0 || (entriesService.globalOptionsSubject | async)?.length > 0\"\n>\n <!-- FIXME: Ideally, we would use native `ul` and `li` elements, but these have a strict model,\n that only allows `li` elements as direct children of `ul` elements. So we would need to use the\n native elements at all places without any elements between `ul` and `li`. -->\n <div\n *ngIf=\"entriesService.sort?.customSortingInProgress\"\n role=\"list\"\n class=\"card-grid card-grid-reorder\"\n cdkDropListGroup\n >\n <ng-container *ngIf=\"nodes$ | async as nodes\">\n <div\n class=\"card-grid-order-wrapper\"\n *ngFor=\"let node of nodes; let i = index\"\n role=\"none\"\n cdkDropList\n [cdkDropListConnectedTo]=\"dropLists\"\n [cdkDropListData]=\"i\"\n >\n <es-node-entries-card\n *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragData]=\"i\"\n [cdkDragStartDelay]=\"getDragStartDelay()\"\n cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n (cdkDragStarted)=\"onRearrangeDragStarted()\"\n (cdkDragEnded)=\"onRearrangeDragEnded()\"\n ></es-node-entries-card>\n <es-node-entries-card-small\n *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragData]=\"i\"\n [cdkDragStartDelay]=\"getDragStartDelay()\"\n cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n (cdkDragStarted)=\"onRearrangeDragStarted()\"\n (cdkDragEnded)=\"onRearrangeDragEnded()\"\n ></es-node-entries-card-small>\n </div>\n </ng-container>\n </div>\n <div class=\"card-grid-wrapper\" *ngIf=\"!entriesService.sort?.customSortingInProgress\">\n <ng-container *ngTemplateOutlet=\"scrollHelper\"></ng-container>\n <div\n role=\"list\"\n class=\"card-grid card-grid-layout-{{ layout }}\"\n #grid\n (esBorderBoxObserver)=\"onGridSizeChanges()\"\n esInfiniteScroll\n (scroll)=\"updateScrollState()\"\n (scrolled)=\"!visibleItemsLimited && loadData('scroll')\"\n >\n <es-node-entries-global-options\n *ngIf=\"(entriesService.globalOptionsSubject | async)?.length\"\n [displayType]=\"displayType\"\n >\n </es-node-entries-global-options>\n <ng-container *ngIf=\"nodes$ | async as nodes\">\n <div\n class=\"card-grid-drag-wrapper\"\n *ngFor=\"let node of nodes; let i = index\"\n role=\"none\"\n [esNodesDropTarget]=\"node\"\n [canDropNodes]=\"canDropNodes\"\n (nodeDropped)=\"onNodesDropped($event)\"\n #dropTarget=\"esNodesDropTarget\"\n >\n <ng-container *ngIf=\"isCustomTemplate(node)\">\n <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!isCustomTemplate(node)\">\n <es-node-entries-card\n *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n #item\n [node]=\"node\"\n [dropdown]=\"dropdown\"\n role=\"listitem\"\n cdkDrag\n [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n [cdkDragData]=\"getDragData(node)\"\n esNodesDrag\n (cdkDragStarted)=\"onDragStarted(node)\"\n (cdkDragEnded)=\"onDragEnded()\"\n [class.card-import-blocked]=\"isBlocked(node)\"\n [class.selected-when-dragging]=\"\n isDragging && entriesService.selection.isSelected(node)\n \"\n >\n <ng-container *ngIf=\"entriesService.selection.selected.length > 1\">\n <es-node-entries-card\n *cdkDragPreview\n [node]=\"node\"\n [matBadge]=\"\n entriesService.selection.selected.length > 1\n ? entriesService.selection.selected.length\n : null\n \"\n class=\"card-drag-preview\"\n ></es-node-entries-card>\n </ng-container>\n </es-node-entries-card>\n <es-node-entries-card-small\n *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n [cdkDragData]=\"[node]\"\n esNodesDrag\n >\n </es-node-entries-card-small>\n </ng-container>\n <div\n *ngIf=\"dropTarget.active?.canDrop?.denyExplicit\"\n class=\"card-grid-drop-blocked-container\"\n >\n <i esIcon=\"cancel\"></i>\n </div>\n <div *ngIf=\"dropTarget.active?.canDrop?.accept\" class=\"card-grid-drop-allowed-container\">\n <i\n [esIcon]=\"dropTarget.active.action === 'copy' ? 'add_circle_outline' : 'archive'\"\n ></i>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-container>\n<ng-container\n *ngIf=\"\n !entriesService.dataSource.isLoading &&\n entriesService.dataSource.hasMore() &&\n !visibleItemsLimited &&\n entriesService.paginationStrategy === 'infinite-scroll' &&\n layout !== 'scroll'\n \"\n>\n <div class=\"load-more\">\n <button mat-button color=\"primary\" (click)=\"loadData('button')\">\n <i esIcon=\"refresh\"></i>\n <span>{{ 'LOAD_MORE' | translate }}</span>\n </button>\n </div>\n</ng-container>\n<ng-container\n *ngIf=\"\n entriesService.dataSource.isLoading === true ||\n entriesService.dataSource.isLoading === 'initial' ||\n (entriesService.dataSource.isLoading === 'page' &&\n entriesService.paginationStrategy === 'infinite-scroll')\n \"\n>\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n</ng-container>\n\n<ng-template #loading>\n <es-spinner></es-spinner>\n</ng-template>\n<ng-template #scrollHelper>\n <ng-container *ngIf=\"layout === 'scroll'\">\n <div\n class=\"scroll-helper-left\"\n role=\"presentation\"\n (click)=\"doScroll('left')\"\n *ngIf=\"scroll.left\"\n >\n <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('left')\">\n <i esIcon=\"keyboard_arrow_left\" [aria]=\"true\"></i>\n </button>\n </div>\n <div\n class=\"scroll-helper-right\"\n role=\"presentation\"\n (click)=\"doScroll('right')\"\n *ngIf=\"scroll.right\"\n >\n <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('right')\">\n <i esIcon=\"keyboard_arrow_right\" [aria]=\"true\"></i>\n </button>\n </div>\n </ng-container>\n</ng-template>\n", styles: ["@keyframes OrderAnimationCards{0%{transform:rotate(-.25deg)}50%{transform:rotate(.25deg)}to{transform:rotate(-.25deg)}}:host{--scroll-gradient-color: white}.order-panel{margin-left:auto}.load-more{display:flex;justify-content:center}.card-grid-wrapper{position:relative;z-index:0}.card-grid-wrapper .scroll-helper-left,.card-grid-wrapper .scroll-helper-right{position:absolute;width:15%;min-width:60px;max-width:calc(var(--cardWidth) * .4);display:flex;align-items:center;height:calc(100% - 10px);z-index:5;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.card-grid-wrapper .scroll-helper-left>button,.card-grid-wrapper .scroll-helper-right>button{background-color:#fff;color:var(--primary);box-shadow:0 0 25px #00000040}.card-grid-wrapper .scroll-helper-left{left:-1.5em;justify-content:flex-start;background:linear-gradient(to left,transparent 0,var(--scroll-gradient-color) calc(100% - 1.5em))}.card-grid-wrapper .scroll-helper-left>button{margin-left:calc(1.5em - 8px)}.card-grid-wrapper .scroll-helper-right{right:-1.5em;justify-content:flex-end;background:linear-gradient(to right,transparent 0,var(--scroll-gradient-color) calc(100% - 1.5em))}.card-grid-wrapper .scroll-helper-right>button{margin-right:calc(1.5em - 8px)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--cardWidth),1fr));grid-column-gap:20px;grid-row-gap:20px;grid-template-rows:auto;padding-block-start:1em;padding-block-end:1em}.card-grid.card-grid-layout-scroll{position:relative;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;grid-auto-flow:column;grid-template-columns:repeat(auto-fit,var(--cardWidth));grid-auto-columns:minmax(var(--cardWidth),1fr);padding:1.5em;margin:-.5em -1.5em 0}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-track{margin:0 1.5em}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-track{-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.1);border-radius:10px;background-color:transparent}.card-grid.card-grid-layout-scroll::-webkit-scrollbar{height:10px;background-color:transparent}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-thumb{max-width:20px;border-radius:10px;background-color:var(--primary)}.card-grid.card-grid-layout-scroll>.card-grid-drag-wrapper{scroll-snap-align:center;scroll-snap-stop:always}.card-grid .card-import-blocked ::ng-deep .card-meta{opacity:.75;text-decoration:line-through}.card-grid>.card-grid-drag-wrapper{position:relative}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container,.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container{position:absolute;z-index:1;inset:0;display:flex;justify-content:center;align-items:center}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container>i,.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container>i{background:radial-gradient(circle,#fff 30%,#fff0 70%);width:200px;height:200px;font-size:80px;display:flex;align-items:center;justify-content:center}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container>i{color:var(--colorStatusPositive)}.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container>i{color:var(--colorStatusNegative)}.card-grid>.card-grid-drag-wrapper .selected-when-dragging{opacity:.5}.card-grid>.card-grid-drag-wrapper.cdk-drop-list-dragging>*:first-child{display:none}.card-grid.card-grid-reorder>.card-grid-order-wrapper{animation-iteration-count:infinite;animation-duration:.5s;animation-name:OrderAnimationCards}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(2n){animation-delay:0s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(odd){animation-delay:-.25s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(3n){animation-delay:-.125s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(5n){animation-delay:-.0625s}.card-grid.card-grid-reorder>.card-grid-order-wrapper .cdk-drag-placeholder{display:none}.card-drag-preview{width:250px}::ng-deep .es-card-grid-rearrange-drag-preview.cdk-drag-animating{transition:none}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i7.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: i8.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i8.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i8.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i8.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "directive", type: i9.BorderBoxObserverDirective, selector: "[esBorderBoxObserver]", outputs: ["esBorderBoxObserver"], exportAs: ["borderBoxObserver"] }, { kind: "component", type: i10.DropdownComponent, selector: "es-dropdown", inputs: ["position", "options", "callbackObjects", "showDisabled", "menuClass"] }, { kind: "directive", type: i11.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "directive", type: i12.InfiniteScrollDirective, selector: "[esInfiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollThrottle", "scrollWindow"], outputs: ["scrolled"] }, { kind: "component", type: i13.SpinnerComponent, selector: "es-spinner" }, { kind: "component", type: i14.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i14.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i15.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "directive", type: i16.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i17.ColumnChooserComponent, selector: "es-column-chooser", inputs: ["origin", "columnChooserVisible", "columns"], outputs: ["columnChooserVisibleChange", "columnsChange"] }, { kind: "component", type: i18.NodeEntriesCardComponent, selector: "es-node-entries-card", inputs: ["dropdown", "node"] }, { kind: "component", type: i19.NodeEntriesCardSmallComponent, selector: "es-node-entries-card-small", inputs: ["node"] }, { kind: "component", type: i20.SortSelectPanelComponent, selector: "es-sort-select-panel", inputs: ["active", "direction", "columns", "customSortingInProgress"], outputs: ["sortChange", "customSortingInProgressChange"] }, { kind: "directive", type: i21.NodesDragDirective, selector: "[esNodesDrag]" }, { kind: "directive", type: i22.NodesDropTargetDirective, selector: "[esNodesDropTarget]", inputs: ["esNodesDropTarget", "canDropNodes"], outputs: ["nodeDropped"], exportAs: ["esNodesDropTarget"] }, { kind: "component", type: i23.NodeEntriesGlobalOptionsComponent, selector: "es-node-entries-global-options", inputs: ["displayType"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i24.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
301
- }
302
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardGridComponent, decorators: [{
303
- type: Component,
304
- args: [{ selector: 'es-node-entries-card-grid', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #gridTop>\n <button\n *ngIf=\"entriesService.configureColumns\"\n mat-icon-button\n (click)=\"columnChooserVisible$.next(!columnChooserVisible$.value)\"\n cdkOverlayOrigin\n #columnChooserTrigger=\"cdkOverlayOrigin\"\n [matTooltip]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n [attr.aria-label]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n >\n <i esIcon=\"settings\"></i>\n </button>\n <es-sort-select-panel\n *ngIf=\"entriesService.sort?.allowed\"\n class=\"order-panel\"\n [active]=\"entriesService.sort.active\"\n [direction]=\"entriesService.sort.direction\"\n [columns]=\"getSortColumns()\"\n (sortChange)=\"onSortChange($event)\"\n [(customSortingInProgress)]=\"entriesService.sort.customSortingInProgress\"\n (customSortingInProgressChange)=\"onCustomSortingInProgressChange()\"\n ></es-sort-select-panel>\n</ng-template>\n<es-column-chooser\n *ngIf=\"entriesService.configureColumns\"\n [(columns)]=\"entriesService.columns\"\n [columnChooserVisible]=\"columnChooserVisible$ | async\"\n [origin]=\"columnChooserTrigger\"\n (columnChooserVisibleChange)=\"columnChooserVisible$.next($event)\"\n></es-column-chooser>\n<es-dropdown #dropdown [options]=\"entriesService.options?.[Target.ListDropdown]\"></es-dropdown>\n\n<!-- Do not render the list element (`role=\"list\"` or `li`) when there are no list items. -->\n<ng-container\n *ngIf=\"(nodes$ | async)?.length > 0 || (entriesService.globalOptionsSubject | async)?.length > 0\"\n>\n <!-- FIXME: Ideally, we would use native `ul` and `li` elements, but these have a strict model,\n that only allows `li` elements as direct children of `ul` elements. So we would need to use the\n native elements at all places without any elements between `ul` and `li`. -->\n <div\n *ngIf=\"entriesService.sort?.customSortingInProgress\"\n role=\"list\"\n class=\"card-grid card-grid-reorder\"\n cdkDropListGroup\n >\n <ng-container *ngIf=\"nodes$ | async as nodes\">\n <div\n class=\"card-grid-order-wrapper\"\n *ngFor=\"let node of nodes; let i = index\"\n role=\"none\"\n cdkDropList\n [cdkDropListConnectedTo]=\"dropLists\"\n [cdkDropListData]=\"i\"\n >\n <es-node-entries-card\n *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragData]=\"i\"\n [cdkDragStartDelay]=\"getDragStartDelay()\"\n cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n (cdkDragStarted)=\"onRearrangeDragStarted()\"\n (cdkDragEnded)=\"onRearrangeDragEnded()\"\n ></es-node-entries-card>\n <es-node-entries-card-small\n *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragData]=\"i\"\n [cdkDragStartDelay]=\"getDragStartDelay()\"\n cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n (cdkDragStarted)=\"onRearrangeDragStarted()\"\n (cdkDragEnded)=\"onRearrangeDragEnded()\"\n ></es-node-entries-card-small>\n </div>\n </ng-container>\n </div>\n <div class=\"card-grid-wrapper\" *ngIf=\"!entriesService.sort?.customSortingInProgress\">\n <ng-container *ngTemplateOutlet=\"scrollHelper\"></ng-container>\n <div\n role=\"list\"\n class=\"card-grid card-grid-layout-{{ layout }}\"\n #grid\n (esBorderBoxObserver)=\"onGridSizeChanges()\"\n esInfiniteScroll\n (scroll)=\"updateScrollState()\"\n (scrolled)=\"!visibleItemsLimited && loadData('scroll')\"\n >\n <es-node-entries-global-options\n *ngIf=\"(entriesService.globalOptionsSubject | async)?.length\"\n [displayType]=\"displayType\"\n >\n </es-node-entries-global-options>\n <ng-container *ngIf=\"nodes$ | async as nodes\">\n <div\n class=\"card-grid-drag-wrapper\"\n *ngFor=\"let node of nodes; let i = index\"\n role=\"none\"\n [esNodesDropTarget]=\"node\"\n [canDropNodes]=\"canDropNodes\"\n (nodeDropped)=\"onNodesDropped($event)\"\n #dropTarget=\"esNodesDropTarget\"\n >\n <ng-container *ngIf=\"isCustomTemplate(node)\">\n <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!isCustomTemplate(node)\">\n <es-node-entries-card\n *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n #item\n [node]=\"node\"\n [dropdown]=\"dropdown\"\n role=\"listitem\"\n cdkDrag\n [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n [cdkDragData]=\"getDragData(node)\"\n esNodesDrag\n (cdkDragStarted)=\"onDragStarted(node)\"\n (cdkDragEnded)=\"onDragEnded()\"\n [class.card-import-blocked]=\"isBlocked(node)\"\n [class.selected-when-dragging]=\"\n isDragging && entriesService.selection.isSelected(node)\n \"\n >\n <ng-container *ngIf=\"entriesService.selection.selected.length > 1\">\n <es-node-entries-card\n *cdkDragPreview\n [node]=\"node\"\n [matBadge]=\"\n entriesService.selection.selected.length > 1\n ? entriesService.selection.selected.length\n : null\n \"\n class=\"card-drag-preview\"\n ></es-node-entries-card>\n </ng-container>\n </es-node-entries-card>\n <es-node-entries-card-small\n *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n #item\n [node]=\"node\"\n role=\"listitem\"\n cdkDrag\n [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n [cdkDragData]=\"[node]\"\n esNodesDrag\n >\n </es-node-entries-card-small>\n </ng-container>\n <div\n *ngIf=\"dropTarget.active?.canDrop?.denyExplicit\"\n class=\"card-grid-drop-blocked-container\"\n >\n <i esIcon=\"cancel\"></i>\n </div>\n <div *ngIf=\"dropTarget.active?.canDrop?.accept\" class=\"card-grid-drop-allowed-container\">\n <i\n [esIcon]=\"dropTarget.active.action === 'copy' ? 'add_circle_outline' : 'archive'\"\n ></i>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-container>\n<ng-container\n *ngIf=\"\n !entriesService.dataSource.isLoading &&\n entriesService.dataSource.hasMore() &&\n !visibleItemsLimited &&\n entriesService.paginationStrategy === 'infinite-scroll' &&\n layout !== 'scroll'\n \"\n>\n <div class=\"load-more\">\n <button mat-button color=\"primary\" (click)=\"loadData('button')\">\n <i esIcon=\"refresh\"></i>\n <span>{{ 'LOAD_MORE' | translate }}</span>\n </button>\n </div>\n</ng-container>\n<ng-container\n *ngIf=\"\n entriesService.dataSource.isLoading === true ||\n entriesService.dataSource.isLoading === 'initial' ||\n (entriesService.dataSource.isLoading === 'page' &&\n entriesService.paginationStrategy === 'infinite-scroll')\n \"\n>\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n</ng-container>\n\n<ng-template #loading>\n <es-spinner></es-spinner>\n</ng-template>\n<ng-template #scrollHelper>\n <ng-container *ngIf=\"layout === 'scroll'\">\n <div\n class=\"scroll-helper-left\"\n role=\"presentation\"\n (click)=\"doScroll('left')\"\n *ngIf=\"scroll.left\"\n >\n <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('left')\">\n <i esIcon=\"keyboard_arrow_left\" [aria]=\"true\"></i>\n </button>\n </div>\n <div\n class=\"scroll-helper-right\"\n role=\"presentation\"\n (click)=\"doScroll('right')\"\n *ngIf=\"scroll.right\"\n >\n <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('right')\">\n <i esIcon=\"keyboard_arrow_right\" [aria]=\"true\"></i>\n </button>\n </div>\n </ng-container>\n</ng-template>\n", styles: ["@keyframes OrderAnimationCards{0%{transform:rotate(-.25deg)}50%{transform:rotate(.25deg)}to{transform:rotate(-.25deg)}}:host{--scroll-gradient-color: white}.order-panel{margin-left:auto}.load-more{display:flex;justify-content:center}.card-grid-wrapper{position:relative;z-index:0}.card-grid-wrapper .scroll-helper-left,.card-grid-wrapper .scroll-helper-right{position:absolute;width:15%;min-width:60px;max-width:calc(var(--cardWidth) * .4);display:flex;align-items:center;height:calc(100% - 10px);z-index:5;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.card-grid-wrapper .scroll-helper-left>button,.card-grid-wrapper .scroll-helper-right>button{background-color:#fff;color:var(--primary);box-shadow:0 0 25px #00000040}.card-grid-wrapper .scroll-helper-left{left:-1.5em;justify-content:flex-start;background:linear-gradient(to left,transparent 0,var(--scroll-gradient-color) calc(100% - 1.5em))}.card-grid-wrapper .scroll-helper-left>button{margin-left:calc(1.5em - 8px)}.card-grid-wrapper .scroll-helper-right{right:-1.5em;justify-content:flex-end;background:linear-gradient(to right,transparent 0,var(--scroll-gradient-color) calc(100% - 1.5em))}.card-grid-wrapper .scroll-helper-right>button{margin-right:calc(1.5em - 8px)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--cardWidth),1fr));grid-column-gap:20px;grid-row-gap:20px;grid-template-rows:auto;padding-block-start:1em;padding-block-end:1em}.card-grid.card-grid-layout-scroll{position:relative;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;grid-auto-flow:column;grid-template-columns:repeat(auto-fit,var(--cardWidth));grid-auto-columns:minmax(var(--cardWidth),1fr);padding:1.5em;margin:-.5em -1.5em 0}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-track{margin:0 1.5em}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-track{-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,.1);border-radius:10px;background-color:transparent}.card-grid.card-grid-layout-scroll::-webkit-scrollbar{height:10px;background-color:transparent}.card-grid.card-grid-layout-scroll::-webkit-scrollbar-thumb{max-width:20px;border-radius:10px;background-color:var(--primary)}.card-grid.card-grid-layout-scroll>.card-grid-drag-wrapper{scroll-snap-align:center;scroll-snap-stop:always}.card-grid .card-import-blocked ::ng-deep .card-meta{opacity:.75;text-decoration:line-through}.card-grid>.card-grid-drag-wrapper{position:relative}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container,.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container{position:absolute;z-index:1;inset:0;display:flex;justify-content:center;align-items:center}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container>i,.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container>i{background:radial-gradient(circle,#fff 30%,#fff0 70%);width:200px;height:200px;font-size:80px;display:flex;align-items:center;justify-content:center}.card-grid>.card-grid-drag-wrapper .card-grid-drop-allowed-container>i{color:var(--colorStatusPositive)}.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.card-grid>.card-grid-drag-wrapper .card-grid-drop-blocked-container>i{color:var(--colorStatusNegative)}.card-grid>.card-grid-drag-wrapper .selected-when-dragging{opacity:.5}.card-grid>.card-grid-drag-wrapper.cdk-drop-list-dragging>*:first-child{display:none}.card-grid.card-grid-reorder>.card-grid-order-wrapper{animation-iteration-count:infinite;animation-duration:.5s;animation-name:OrderAnimationCards}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(2n){animation-delay:0s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(odd){animation-delay:-.25s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(3n){animation-delay:-.125s}.card-grid.card-grid-reorder>.card-grid-order-wrapper:nth-of-type(5n){animation-delay:-.0625s}.card-grid.card-grid-reorder>.card-grid-order-wrapper .cdk-drag-placeholder{display:none}.card-drag-preview{width:250px}::ng-deep .es-card-grid-rearrange-drag-preview.cdk-drag-animating{transition:none}\n"] }]
305
- }], ctorParameters: () => [{ type: i1.NodeEntriesService }, { type: i2.NodeEntriesGlobalService }, { type: i3.NodeEntriesTemplatesService }, { type: i4.NodeHelperService }, { type: i5.UIService }, { type: i0.NgZone }], propDecorators: { columnChooserTrigger: [{
306
- type: ViewChild,
307
- args: ['columnChooserTrigger']
308
- }], gridTop: [{
309
- type: ViewChild,
310
- args: ['gridTop', { static: true }]
311
- }], sortPanel: [{
312
- type: ViewChild,
313
- args: [SortSelectPanelComponent]
314
- }], dropListsQuery: [{
315
- type: ViewChildren,
316
- args: [CdkDropList]
317
- }], gridRef: [{
318
- type: ViewChild,
319
- args: ['grid']
320
- }], itemRefs: [{
321
- type: ViewChildren,
322
- args: ['item', { read: ElementRef }]
323
- }], displayType: [{
324
- type: Input
325
- }], scrollGradientColor: [{
326
- type: HostBinding,
327
- args: ['style.--scroll-gradient-color']
328
- }] } });
329
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-card-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragEnter, CdkDropList, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    ElementRef,\n    HostBinding,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    TemplateRef,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport { Sort } from '@angular/material/sort';\nimport { Node, RestConstants } from 'ngx-edu-sharing-api';\nimport * as rxjs from 'rxjs';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { distinctUntilChanged, map, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { GridLayout, NodeEntriesDisplayType } from '../entries-model';\nimport { ItemsCap } from '../items-cap';\nimport { NodeEntriesGlobalService } from '../node-entries-global.service';\nimport { NodeEntriesTemplatesService } from '../node-entries-templates.service';\nimport { SortSelectPanelComponent } from '../sort-select-panel/sort-select-panel.component';\nimport { CustomTemplatesDataSource } from '../custom-templates-data-source';\nimport { Target } from '../../types/option-item';\nimport { NodeEntriesService } from '../../services/node-entries.service';\nimport { UIService } from '../../services/ui.service';\nimport { ListItemSort } from '../../types/list-item';\nimport { DragData } from '../../types/drag-drop';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { NodeHelperService } from '../../services/node-helper.service';\n\nlet displayedWarnings: string[] = [];\n\n@Component({\n    selector: 'es-node-entries-card-grid',\n    templateUrl: 'node-entries-card-grid.component.html',\n    styleUrls: ['node-entries-card-grid.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NodeEntriesCardGridComponent<T extends Node> implements OnInit, OnDestroy {\n    readonly NodeEntriesDisplayType = NodeEntriesDisplayType;\n    readonly Target = Target;\n    /**\n     * relative scrolling when a scrolling arrow (left or right) is used\n     * a value of 1 would mean to scroll the full width of the entire content\n     */\n    readonly ScrollingOffsetPercentage = 0.4;\n\n    columnChooserVisible$ = new BehaviorSubject(false);\n    @ViewChild('columnChooserTrigger') columnChooserTrigger: CdkOverlayOrigin;\n    @ViewChild('gridTop', { static: true }) set gridTop(value: TemplateRef<unknown>) {\n        this.registerGridTop(value);\n    }\n    @ViewChild(SortSelectPanelComponent)\n    set sortPanel(value: SortSelectPanelComponent) {\n        // if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {\n        setTimeout(() => {\n            (this.entriesService.dataSource as any).sortPanel = value;\n        });\n        // }\n    }\n    @ViewChildren(CdkDropList) dropListsQuery: QueryList<CdkDropList>;\n    @ViewChild('grid') gridRef: ElementRef;\n    @ViewChildren('item', { read: ElementRef }) itemRefs: QueryList<ElementRef<HTMLElement>>;\n    @Input() displayType: NodeEntriesDisplayType;\n\n    isDragging = false; // Drag-and-drop, not rearrange\n    dropLists: CdkDropList[];\n    /**\n     * Whether the number of shown items is limited by `gridConfig.maxRows`.\n     *\n     * A value of `true` does not mean, that there would be more items available.\n     */\n    visibleItemsLimited = false;\n    layout: GridLayout;\n    /**\n     * updates via boxObserver\n     * and holds the information if scrolling in the direction is currently feasible\n     */\n    scroll = {\n        left: false,\n        right: false,\n    };\n\n    readonly nodes$;\n    private readonly maxRows$;\n    private readonly layout$;\n    private readonly itemsPerRowSubject = new BehaviorSubject<number | null>(null);\n    readonly itemsCap = new ItemsCap<T>();\n    private globalCursorStyle: HTMLStyleElement;\n    private destroyed = new Subject<void>();\n    @HostBinding('style.--scroll-gradient-color') scrollGradientColor: string;\n\n    constructor(\n        public entriesService: NodeEntriesService<T>,\n        public entriesGlobalService: NodeEntriesGlobalService,\n        public templatesService: NodeEntriesTemplatesService,\n        public nodeHelperService: NodeHelperService,\n        public ui: UIService,\n        private ngZone: NgZone,\n    ) {\n        this.nodes$ = this.entriesService.dataSource$.pipe(\n            switchMap((dataSource) => dataSource?.connect()),\n        );\n        this.maxRows$ = this.entriesService.gridConfig$.pipe(\n            map((gridConfig) => gridConfig?.maxRows || null),\n            distinctUntilChanged(),\n        );\n        this.layout$ = this.entriesService.gridConfig$.pipe(\n            map((gridConfig) => gridConfig?.layout || 'grid'),\n            distinctUntilChanged(),\n        );\n        this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe(() => {\n            this.updateScrollState();\n        });\n        effect(() => (this.scrollGradientColor = this.entriesService.scrollGradientColor()));\n    }\n\n    ngOnInit(): void {\n        this.registerItemsCap();\n        this.registerLayout();\n        this.registerVisibleItemsLimited();\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    private registerGridTop(gridTop: TemplateRef<unknown>): void {\n        setTimeout(() => {\n            this.templatesService.entriesTopMatter = gridTop;\n        });\n        this.destroyed.subscribe(() => {\n            if (this.templatesService.entriesTopMatter === gridTop) {\n                setTimeout(() => {\n                    this.templatesService.entriesTopMatter = null;\n                });\n            }\n        });\n    }\n\n    private registerItemsCap() {\n        this.entriesService.dataSource$\n            .pipe(takeUntil(this.destroyed))\n            .subscribe((dataSource) => (dataSource.itemsCap = this.itemsCap));\n        rxjs.combineLatest([this.itemsPerRowSubject.pipe(distinctUntilChanged()), this.maxRows$])\n            .pipe(\n                map(([itemsPerRow, maxRows]) =>\n                    maxRows > 0 && itemsPerRow !== null ? itemsPerRow * maxRows : null,\n                ),\n            )\n            .subscribe((cap) => (this.itemsCap.cap = cap));\n    }\n\n    private registerLayout() {\n        this.layout$.subscribe((layout) => (this.layout = layout));\n    }\n\n    onSortChange(sort: Sort) {\n        this.entriesService.sort.active = sort.active;\n        this.entriesService.sort.direction = sort.direction;\n        this.entriesService.sortChange.emit(this.entriesService.sort);\n    }\n\n    loadData(source: 'scroll' | 'button') {\n        // @TODO: Maybe this is better handled in a more centraled service\n        if (source === 'scroll') {\n            // check if there is a footer\n            const elements = document.getElementsByTagName('footer');\n            if (elements.length && elements.item(0).innerHTML.trim()) {\n                return;\n            }\n        }\n        const couldLoadMore = this.entriesService.loadMore(source);\n        if (couldLoadMore && source === 'button') {\n            this.focusFirstNewItemWhenLoaded();\n        }\n    }\n\n    onCustomSortingInProgressChange() {\n        this.entriesService.sortChange.emit(this.entriesService.sort);\n        setTimeout(() => {\n            this.refreshDropLists();\n        });\n    }\n\n    onRearrangeDragEntered($event: CdkDragEnter) {\n        moveItemInArray(\n            this.entriesService.dataSource.getData(),\n            $event.item.data,\n            $event.container.data,\n        );\n        // `CdkDrag` doesn't really want us to rearrange the items while dragging. Its cached\n        // element positions get out of sync unless we update them manually.\n        this.ngZone.runOutsideAngular(() =>\n            setTimeout(() =>\n                this.dropLists?.forEach((list) => (list._dropListRef as any)['_cacheItems']()),\n            ),\n        );\n    }\n\n    onRearrangeDragStarted() {\n        this.globalCursorStyle = document.createElement('style');\n        document.body.appendChild(this.globalCursorStyle);\n        this.globalCursorStyle.innerHTML = `* {cursor: grabbing !important; }`;\n    }\n\n    onRearrangeDragEnded() {\n        document.body.removeChild(this.globalCursorStyle);\n        this.globalCursorStyle = null;\n    }\n\n    getDragStartDelay(): number {\n        if (this.ui.isMobile()) {\n            return 500;\n        } else {\n            return null;\n        }\n    }\n\n    private registerVisibleItemsLimited() {\n        this.maxRows$.subscribe((maxRows) => {\n            this.visibleItemsLimited = maxRows > 0;\n        });\n    }\n\n    private refreshDropLists() {\n        this.dropLists = this.dropListsQuery.toArray();\n    }\n\n    private focusFirstNewItemWhenLoaded() {\n        const oldLength = this.itemRefs.length;\n        this.itemRefs.changes\n            .pipe(take(1))\n            .subscribe((items: NodeEntriesCardGridComponent<T>['itemRefs']) => {\n                if (items.length > oldLength) {\n                    this.focusOnce(items.get(oldLength).nativeElement);\n                }\n            });\n    }\n\n    private focusOnce(element: HTMLElement): void {\n        element.setAttribute('tabindex', '-1');\n        element.focus();\n        element.addEventListener('blur', () => element.removeAttribute('tabindex'), { once: true });\n    }\n\n    onGridSizeChanges(): void {\n        const itemsPerRow = this.getItemsPerRow();\n        this.itemsPerRowSubject.next(itemsPerRow);\n        this.updateScrollState();\n    }\n\n    private getItemsPerRow(): number | null {\n        if (!this.gridRef?.nativeElement) {\n            return null;\n        }\n        return getComputedStyle(this.gridRef.nativeElement)\n            .getPropertyValue('grid-template-columns')\n            .split(' ').length;\n    }\n\n    getSortColumns() {\n        return this.entriesService.sort?.columns?.filter((c) => {\n            const result = this.entriesService.columns\n                .concat(\n                    new ListItemSort('NODE', 'score'),\n                    new ListItemSort('NODE', RestConstants.CCM_PROP_COLLECTION_ORDERED_POSITION),\n                    new ListItemSort('NODE', RestConstants.CM_PROP_TITLE),\n                    new ListItemSort('NODE', RestConstants.CM_NAME),\n                    new ListItemSort('NODE', RestConstants.CM_PROP_C_CREATED),\n                    new ListItemSort('NODE', RestConstants.CM_MODIFIED_DATE),\n                    new ListItemSort('NODE', RestConstants.CCM_PROP_REPLICATIONMODIFIED),\n                    new ListItemSort('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCETIMESTAMP),\n                )\n                .some((c2) => c.type === c2.type && c2.name === c.name);\n            if (!result && !this.entriesService.configureColumns) {\n                return this.entriesService.sort?.columns;\n                /*\n                    const warning =\n                        'Sort field ' +\n                        c.name +\n                        ' was specified but is not present as a column. ' +\n                        'It will be ignored. Please also configure this field in the <lists> section';\n                    if (!displayedWarnings.includes(warning)) {\n                        console.warn(warning);\n                        displayedWarnings.push(warning);\n                    }*/\n            }\n            return result;\n        });\n    }\n\n    canDropNodes = (dragData: DragData<T>) => this.entriesService.dragDrop.dropAllowed?.(dragData);\n\n    onNodesDropped(dragData: DragData<Node>) {\n        this.entriesService.dragDrop.dropped(dragData.target, {\n            element: dragData.draggedNodes,\n            mode: dragData.action,\n        });\n    }\n\n    getDragEnabled() {\n        return this.ui.isTouchSubject.pipe(\n            map((touch) => !touch && this.entriesService.dragDrop?.dragAllowed),\n        );\n    }\n\n    getDragData(node: T): T[] {\n        const selection = this.entriesService.selection;\n        if (selection.isSelected(node)) {\n            return selection.selected;\n        } else {\n            return [node];\n        }\n    }\n\n    onDragStarted(node: T) {\n        if (!this.entriesService.selection.isSelected(node)) {\n            this.entriesService.selection.clear();\n            this.entriesService.selection.select(node);\n        }\n        this.isDragging = true;\n    }\n\n    onDragEnded() {\n        this.isDragging = false;\n    }\n\n    private canScroll(direction: 'left' | 'right') {\n        const element = this.gridRef?.nativeElement;\n        if (element) {\n            if (direction === 'left') {\n                return element.scrollLeft > 0;\n            } else if (direction === 'right') {\n                /*\n                 use a small pixel buffer (10px) because scrolling aligns with the start of each card and\n                 it can cause slight alignment issues on the end of the container\n                 */\n                return element.scrollLeft < element.scrollWidth - element.clientWidth - 10;\n            }\n        }\n        return false;\n    }\n\n    updateScrollState() {\n        if (this.layout === 'scroll') {\n            this.scroll.left = this.canScroll('left');\n            this.scroll.right = this.canScroll('right');\n        }\n    }\n\n    doScroll(direction: 'left' | 'right') {\n        // 1 is enough because the browser will handle it via css snapping\n        const leftScroll = this.gridRef?.nativeElement.scrollLeft;\n        const rect = this.gridRef?.nativeElement.getBoundingClientRect();\n        // using scroll because it works more reliable than scrollBy\n        this.gridRef?.nativeElement.scroll({\n            left:\n                leftScroll +\n                Math.max(250, rect.width * this.ScrollingOffsetPercentage) *\n                    (direction === 'right' ? 1 : -1),\n            behavior: 'smooth',\n        });\n    }\n\n    isCustomTemplate(node: T) {\n        return (\n            this.entriesService.dataSource instanceof CustomTemplatesDataSource ||\n            (node as any).elementRef\n        );\n    }\n\n    isBlocked(node: Node) {\n        return (\n            node.properties?.[RestConstants.CCM_PROP_IMPORT_BLOCKED]?.[0] === 'true' ||\n            this.nodeHelperService.isNodeRevoked(node)\n        );\n    }\n}\n","<ng-template #gridTop>\n  <button\n    *ngIf=\"entriesService.configureColumns\"\n    mat-icon-button\n    (click)=\"columnChooserVisible$.next(!columnChooserVisible$.value)\"\n    cdkOverlayOrigin\n    #columnChooserTrigger=\"cdkOverlayOrigin\"\n    [matTooltip]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n    [attr.aria-label]=\"'LIST_TABLE.CONFIGURE_COLUMNS' | translate\"\n  >\n    <i esIcon=\"settings\"></i>\n  </button>\n  <es-sort-select-panel\n    *ngIf=\"entriesService.sort?.allowed\"\n    class=\"order-panel\"\n    [active]=\"entriesService.sort.active\"\n    [direction]=\"entriesService.sort.direction\"\n    [columns]=\"getSortColumns()\"\n    (sortChange)=\"onSortChange($event)\"\n    [(customSortingInProgress)]=\"entriesService.sort.customSortingInProgress\"\n    (customSortingInProgressChange)=\"onCustomSortingInProgressChange()\"\n  ></es-sort-select-panel>\n</ng-template>\n<es-column-chooser\n  *ngIf=\"entriesService.configureColumns\"\n  [(columns)]=\"entriesService.columns\"\n  [columnChooserVisible]=\"columnChooserVisible$ | async\"\n  [origin]=\"columnChooserTrigger\"\n  (columnChooserVisibleChange)=\"columnChooserVisible$.next($event)\"\n></es-column-chooser>\n<es-dropdown #dropdown [options]=\"entriesService.options?.[Target.ListDropdown]\"></es-dropdown>\n\n<!-- Do not render the list element (`role=\"list\"` or `li`) when there are no list items. -->\n<ng-container\n  *ngIf=\"(nodes$ | async)?.length > 0 || (entriesService.globalOptionsSubject | async)?.length > 0\"\n>\n  <!-- FIXME: Ideally, we would use native `ul` and `li` elements, but these have a strict model,\n  that only allows `li` elements as direct children of `ul` elements. So we would need to use the\n  native elements at all places without any elements between `ul` and `li`. -->\n  <div\n    *ngIf=\"entriesService.sort?.customSortingInProgress\"\n    role=\"list\"\n    class=\"card-grid card-grid-reorder\"\n    cdkDropListGroup\n  >\n    <ng-container *ngIf=\"nodes$ | async as nodes\">\n      <div\n        class=\"card-grid-order-wrapper\"\n        *ngFor=\"let node of nodes; let i = index\"\n        role=\"none\"\n        cdkDropList\n        [cdkDropListConnectedTo]=\"dropLists\"\n        [cdkDropListData]=\"i\"\n      >\n        <es-node-entries-card\n          *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n          #item\n          [node]=\"node\"\n          role=\"listitem\"\n          cdkDrag\n          [cdkDragData]=\"i\"\n          [cdkDragStartDelay]=\"getDragStartDelay()\"\n          cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n          (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n          (cdkDragStarted)=\"onRearrangeDragStarted()\"\n          (cdkDragEnded)=\"onRearrangeDragEnded()\"\n        ></es-node-entries-card>\n        <es-node-entries-card-small\n          *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n          #item\n          [node]=\"node\"\n          role=\"listitem\"\n          cdkDrag\n          [cdkDragData]=\"i\"\n          [cdkDragStartDelay]=\"getDragStartDelay()\"\n          cdkDragPreviewClass=\"es-card-grid-rearrange-drag-preview\"\n          (cdkDragEntered)=\"onRearrangeDragEntered($event)\"\n          (cdkDragStarted)=\"onRearrangeDragStarted()\"\n          (cdkDragEnded)=\"onRearrangeDragEnded()\"\n        ></es-node-entries-card-small>\n      </div>\n    </ng-container>\n  </div>\n  <div class=\"card-grid-wrapper\" *ngIf=\"!entriesService.sort?.customSortingInProgress\">\n    <ng-container *ngTemplateOutlet=\"scrollHelper\"></ng-container>\n    <div\n      role=\"list\"\n      class=\"card-grid card-grid-layout-{{ layout }}\"\n      #grid\n      (esBorderBoxObserver)=\"onGridSizeChanges()\"\n      esInfiniteScroll\n      (scroll)=\"updateScrollState()\"\n      (scrolled)=\"!visibleItemsLimited && loadData('scroll')\"\n    >\n      <es-node-entries-global-options\n        *ngIf=\"(entriesService.globalOptionsSubject | async)?.length\"\n        [displayType]=\"displayType\"\n      >\n      </es-node-entries-global-options>\n      <ng-container *ngIf=\"nodes$ | async as nodes\">\n        <div\n          class=\"card-grid-drag-wrapper\"\n          *ngFor=\"let node of nodes; let i = index\"\n          role=\"none\"\n          [esNodesDropTarget]=\"node\"\n          [canDropNodes]=\"canDropNodes\"\n          (nodeDropped)=\"onNodesDropped($event)\"\n          #dropTarget=\"esNodesDropTarget\"\n        >\n          <ng-container *ngIf=\"isCustomTemplate(node)\">\n            <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n          </ng-container>\n          <ng-container *ngIf=\"!isCustomTemplate(node)\">\n            <es-node-entries-card\n              *ngIf=\"displayType === NodeEntriesDisplayType.Grid\"\n              #item\n              [node]=\"node\"\n              [dropdown]=\"dropdown\"\n              role=\"listitem\"\n              cdkDrag\n              [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n              [cdkDragData]=\"getDragData(node)\"\n              esNodesDrag\n              (cdkDragStarted)=\"onDragStarted(node)\"\n              (cdkDragEnded)=\"onDragEnded()\"\n              [class.card-import-blocked]=\"isBlocked(node)\"\n              [class.selected-when-dragging]=\"\n                isDragging && entriesService.selection.isSelected(node)\n              \"\n            >\n              <ng-container *ngIf=\"entriesService.selection.selected.length > 1\">\n                <es-node-entries-card\n                  *cdkDragPreview\n                  [node]=\"node\"\n                  [matBadge]=\"\n                    entriesService.selection.selected.length > 1\n                      ? entriesService.selection.selected.length\n                      : null\n                  \"\n                  class=\"card-drag-preview\"\n                ></es-node-entries-card>\n              </ng-container>\n            </es-node-entries-card>\n            <es-node-entries-card-small\n              *ngIf=\"displayType === NodeEntriesDisplayType.SmallGrid\"\n              #item\n              [node]=\"node\"\n              role=\"listitem\"\n              cdkDrag\n              [cdkDragDisabled]=\"(getDragEnabled() | async) === false\"\n              [cdkDragData]=\"[node]\"\n              esNodesDrag\n            >\n            </es-node-entries-card-small>\n          </ng-container>\n          <div\n            *ngIf=\"dropTarget.active?.canDrop?.denyExplicit\"\n            class=\"card-grid-drop-blocked-container\"\n          >\n            <i esIcon=\"cancel\"></i>\n          </div>\n          <div *ngIf=\"dropTarget.active?.canDrop?.accept\" class=\"card-grid-drop-allowed-container\">\n            <i\n              [esIcon]=\"dropTarget.active.action === 'copy' ? 'add_circle_outline' : 'archive'\"\n            ></i>\n          </div>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</ng-container>\n<ng-container\n  *ngIf=\"\n    !entriesService.dataSource.isLoading &&\n    entriesService.dataSource.hasMore() &&\n    !visibleItemsLimited &&\n    entriesService.paginationStrategy === 'infinite-scroll' &&\n    layout !== 'scroll'\n  \"\n>\n  <div class=\"load-more\">\n    <button mat-button color=\"primary\" (click)=\"loadData('button')\">\n      <i esIcon=\"refresh\"></i>\n      <span>{{ 'LOAD_MORE' | translate }}</span>\n    </button>\n  </div>\n</ng-container>\n<ng-container\n  *ngIf=\"\n    entriesService.dataSource.isLoading === true ||\n    entriesService.dataSource.isLoading === 'initial' ||\n    (entriesService.dataSource.isLoading === 'page' &&\n      entriesService.paginationStrategy === 'infinite-scroll')\n  \"\n>\n  <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n</ng-container>\n\n<ng-template #loading>\n  <es-spinner></es-spinner>\n</ng-template>\n<ng-template #scrollHelper>\n  <ng-container *ngIf=\"layout === 'scroll'\">\n    <div\n      class=\"scroll-helper-left\"\n      role=\"presentation\"\n      (click)=\"doScroll('left')\"\n      *ngIf=\"scroll.left\"\n    >\n      <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('left')\">\n        <i esIcon=\"keyboard_arrow_left\" [aria]=\"true\"></i>\n      </button>\n    </div>\n    <div\n      class=\"scroll-helper-right\"\n      role=\"presentation\"\n      (click)=\"doScroll('right')\"\n      *ngIf=\"scroll.right\"\n    >\n      <button mat-icon-button color=\"primary\" (click)=\"$event.stopPropagation(); doScroll('right')\">\n        <i esIcon=\"keyboard_arrow_right\" [aria]=\"true\"></i>\n      </button>\n    </div>\n  </ng-container>\n</ng-template>\n"]}
@@ -1,44 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import { Target } from '../../types/option-item';
3
- import { ClickSource, InteractionType } from '../entries-model';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "../../services/node-entries.service";
6
- import * as i2 from "../../services/node-helper.service";
7
- import * as i3 from "../node-entries-templates.service";
8
- import * as i4 from "@angular/common";
9
- import * as i5 from "../../directives/focus-state.directive";
10
- import * as i6 from "../../directives/icon.directive";
11
- import * as i7 from "../../node-url/node-url.component";
12
- import * as i8 from "../../list-items/list-base/list-base.component";
13
- import * as i9 from "../preview-image/preview-image.component";
14
- export class NodeEntriesCardSmallComponent {
15
- constructor(entriesService, nodeHelper, templatesService) {
16
- this.entriesService = entriesService;
17
- this.nodeHelper = nodeHelper;
18
- this.templatesService = templatesService;
19
- this.ClickSource = ClickSource;
20
- this.InteractionType = InteractionType;
21
- this.Target = Target;
22
- }
23
- optionsOnCard() {
24
- const options = this.entriesService.options[Target.List];
25
- const always = options.filter((o) => o.showAlways);
26
- if (always.some((o) => o.showCallback([this.node]))) {
27
- return always;
28
- }
29
- return options.filter((o) => o.showAsAction && o.showCallback([this.node])).slice(0, 3);
30
- }
31
- openContextmenu(event) {
32
- event.preventDefault();
33
- event.stopPropagation();
34
- }
35
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardSmallComponent, deps: [{ token: i1.NodeEntriesService }, { token: i2.NodeHelperService }, { token: i3.NodeEntriesTemplatesService }], target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesCardSmallComponent, selector: "es-node-entries-card-small", inputs: { node: "node" }, ngImport: i0, template: "<div\n [class]=\"\n 'grid-card' +\n (nodeHelper.isNodeCollection(node)\n ? ' grid-card-collection grid-card-collection-scope-' +\n node.collection.scope +\n ' grid-card-collection-type-' +\n node.collection.type\n : '') +\n ($any(node).virtual ? ' grid-card-virtual' : '') +\n ' ' +\n (entriesService.singleClickHint === 'dynamic' ? ' dynamic-single-click' : '')\n \"\n [style.background-color]=\"nodeHelper.isNodeCollection(node) ? node.collection.color : null\"\n (contextmenu)=\"openContextmenu($event)\"\n (keydown.ContextMenu)=\"openContextmenu($event)\"\n>\n <div\n *ngIf=\"templatesService.overlay\"\n class=\"card-overlay\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Overlay,\n })\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n ></ng-container>\n </div>\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n mode=\"wrapper\"\n [node]=\"node\"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </es-node-url>\n <ng-container *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <ng-container *ngTemplateOutlet=\"image\"></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </ng-container>\n</div>\n<ng-template #image let-playAnimation=\"playAnimation\">\n <div\n class=\"card-image-area\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Preview,\n })\n \"\n >\n <div *ngIf=\"nodeHelper.isNodeCollection(node) && node.collection.pinned\" class=\"collection-pin\">\n <i esIcon=\"edu-pin\"></i>\n </div>\n <es-preview-image\n *ngIf=\"!(nodeHelper.isNodeCollection(node) && node.preview.isIcon)\"\n [node]=\"node\"\n [playAnimation]=\"playAnimation\"\n ></es-preview-image>\n <div\n *ngIf=\"nodeHelper.isNodeCollection(node) && node.preview.isIcon\"\n class=\"card-collection-image\"\n >\n <i esIcon=\"layers\"></i>\n </div>\n </div>\n</ng-template>\n<ng-template #meta>\n <div\n class=\"card-meta\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n >\n <div\n *ngFor=\"let displayPart of entriesService.columns; let first = first\"\n class=\"card-meta-row\"\n >\n <ng-container *ngIf=\"first\">\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n [node]=\"node\"\n #link\n >\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </es-node-url>\n <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!first\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </ng-container>\n </div>\n </div>\n <ng-container\n *ngTemplateOutlet=\"templatesService.actionArea; context: { element: node }\"\n ></ng-container>\n</ng-template>\n", styles: [".grid-card{transition:all var(--transitionNormal);overflow:hidden;background-color:#fff;box-shadow:0 3px 3px #0000001a;display:grid;height:100%;grid-template-columns:auto}:host-context(body.es-contrast-mode) .grid-card{border:1px solid rgba(0,0,0,.42)}.grid-card.selected{background-color:rgb(var(--palette-primary-50))}.grid-card .dropdown-dummy{position:fixed}.grid-card .card-options{display:grid;grid-template-columns:1fr auto;grid-column-gap:10px}.grid-card .card-options .card-rating-area{display:flex;align-items:center;height:100%;padding-left:10px}.grid-card .card-options .card-options-area{display:flex}.grid-card .card-options .card-options-area es-option-button,.grid-card .card-options .card-options-area button{transition:all var(--transitionNormal);margin:0 2px;border-radius:50%}.grid-card .card-options .card-options-area es-option-button:hover,.grid-card .card-options .card-options-area es-option-button:focus,.grid-card .card-options .card-options-area button:hover,.grid-card .card-options .card-options-area button:focus{background-color:#fff}.grid-card:not(.grid-card-collection) .card-top-bar{background-color:var(--palette-primary-200)}.grid-card.grid-card-virtual{outline:2px dashed var(--nodeVirtualColor)}.grid-card .card-top-bar{height:40px;display:flex;gap:15px;align-items:center;padding:0 15px;position:relative}.grid-card .card-top-bar .card-top-bar-collection-color{position:absolute;background-color:#ffffff80;inset:0}.grid-card .card-top-bar .card-top-bar-flag{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}.grid-card .card-top-bar .card-top-bar-flag i{font-size:18px;color:#333}.grid-card .card-top-bar .card-top-bar-flag img{width:18px;height:18px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox{margin-right:-5px;position:relative;top:-1.3px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator{outline:none}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator:after{content:\"\";position:absolute;inset:2px;outline:none;border:2px solid var(--palette-primary-300);border-color:#fff}.grid-card .card-top-bar .card-top-bar-empty{width:0;flex-grow:1}.grid-card .card-image-area{height:100px;padding:0;display:flex}.grid-card .card-image-area es-preview-image{flex-grow:1}.grid-card .card-image-area .card-collection-image{display:flex;width:100%;height:100%;align-items:center;justify-content:center}.grid-card .card-image-area .card-collection-image i{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;color:#000000bf;background-color:#ffffff80;padding:25px;font-size:25px;border-radius:50%}.grid-card .card-meta{padding:8px 15px 0;display:grid;flex-direction:row}.grid-card .card-meta .card-meta-row{display:flex;flex-direction:row;align-items:center;min-height:2.8em;gap:5px}.grid-card .card-meta .card-meta-row:not(:first-child)>label{cursor:inherit;color:var(--textLight);font-size:85%}.grid-card .card-meta .card-meta-row:not(:first-child)>es-list-base{color:#000;flex-grow:1;margin:5px 0;display:flex;justify-content:flex-end;text-align:end;word-break:break-word}.grid-card .card-meta .card-meta-row:first-child{font-size:120%}.grid-card .card-meta .card-meta-row:first-child>es-list-base,.grid-card .card-meta .card-meta-row:first-child>es-node-url{width:100%;font-size:120%;color:var(--textMain);height:2.8em;text-align:left;word-break:break-word}.grid-card.dynamic-single-click:hover{box-shadow:0 0 25px #0003;background-color:rgb(var(--palette-primary-50))}.grid-card.dynamic-single-click.grid-card-collection:hover .card-meta{background-color:#ffffffe6}.grid-card.grid-card-collection .card-meta{background-color:#fffc}.grid-card.grid-card-collection .card-options{background-color:#ffffffe6}.grid-card .card-options{border-top:1px solid #ddd}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text{word-break:break-word}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text span,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text span{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row es-node-url a{color:var(--textMain)}:host ::ng-deep .grid-card .card-meta-row es-node-url a.cdk-keyboard-focused{display:inline-flex;outline:none;outline:2px solid var(--palette-primary-300);outline-offset:2px}:host ::ng-deep .card-meta es-list-base img{max-width:100px;max-height:20px}:host ::ng-deep .card-meta es-list-base es-list-node-license img{height:20px}:host ::ng-deep .card-meta es-list-base es-list-collection-info{display:flex;align-items:center}:host ::ng-deep .card-meta es-list-base es-list-collection-info i{font-size:12pt;margin:0 6px}:host ::ng-deep .grid-card-collection es-node-url a.cdk-keyboard-focused .card-meta{background-color:#fff}.card-overlay{position:absolute;z-index:2;inset:0;pointer-events:none}.card-overlay ::ng-deep>*{pointer-events:auto}.collection-pin{background:#ffffff80;border-radius:50px;position:absolute;z-index:1;right:10px;top:10px;width:25px;height:25px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 3px #0000001a}.collection-pin>i{font-size:12px}.grid-card .card-meta-row ::ng-deep es-node-url a.cdk-keyboard-focused{outline-color:var(--palette-primary-400)}.grid-card{cursor:pointer}.grid-card.grid-card-collection{background-color:rgb(var(--palette-primary-200))}.grid-card .card-meta{background-color:#fffc;padding-bottom:8px}.grid-card .card-meta .card-meta-row:nth-child(1){grid-column:1/3}.grid-card .card-meta .card-meta-row:nth-child(2){justify-self:flex-start}.grid-card .card-meta .card-meta-row:nth-child(2),.grid-card .card-meta .card-meta-row:nth-child(3){grid-row:2;font-size:var(--fontSizeXSmall)}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.FocusStateDirective, selector: "[esFocusState]", exportAs: ["esFocusState"] }, { kind: "directive", type: i6.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i7.NodeUrlComponent, selector: "es-node-url", inputs: ["node", "nodes", "target", "scope", "queryParams", "mode", "disabled", "alwaysRipple", "aria-describedby", "aria-label"], outputs: ["buttonClick"] }, { kind: "component", type: i8.ListBaseComponent, selector: "es-list-base", inputs: ["forceText"] }, { kind: "component", type: i9.PreviewImageComponent, selector: "es-preview-image", inputs: ["node", "playAnimation"] }] }); }
37
- }
38
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardSmallComponent, decorators: [{
39
- type: Component,
40
- args: [{ selector: 'es-node-entries-card-small', template: "<div\n [class]=\"\n 'grid-card' +\n (nodeHelper.isNodeCollection(node)\n ? ' grid-card-collection grid-card-collection-scope-' +\n node.collection.scope +\n ' grid-card-collection-type-' +\n node.collection.type\n : '') +\n ($any(node).virtual ? ' grid-card-virtual' : '') +\n ' ' +\n (entriesService.singleClickHint === 'dynamic' ? ' dynamic-single-click' : '')\n \"\n [style.background-color]=\"nodeHelper.isNodeCollection(node) ? node.collection.color : null\"\n (contextmenu)=\"openContextmenu($event)\"\n (keydown.ContextMenu)=\"openContextmenu($event)\"\n>\n <div\n *ngIf=\"templatesService.overlay\"\n class=\"card-overlay\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Overlay,\n })\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n ></ng-container>\n </div>\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n mode=\"wrapper\"\n [node]=\"node\"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </es-node-url>\n <ng-container *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <ng-container *ngTemplateOutlet=\"image\"></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </ng-container>\n</div>\n<ng-template #image let-playAnimation=\"playAnimation\">\n <div\n class=\"card-image-area\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Preview,\n })\n \"\n >\n <div *ngIf=\"nodeHelper.isNodeCollection(node) && node.collection.pinned\" class=\"collection-pin\">\n <i esIcon=\"edu-pin\"></i>\n </div>\n <es-preview-image\n *ngIf=\"!(nodeHelper.isNodeCollection(node) && node.preview.isIcon)\"\n [node]=\"node\"\n [playAnimation]=\"playAnimation\"\n ></es-preview-image>\n <div\n *ngIf=\"nodeHelper.isNodeCollection(node) && node.preview.isIcon\"\n class=\"card-collection-image\"\n >\n <i esIcon=\"layers\"></i>\n </div>\n </div>\n</ng-template>\n<ng-template #meta>\n <div\n class=\"card-meta\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n >\n <div\n *ngFor=\"let displayPart of entriesService.columns; let first = first\"\n class=\"card-meta-row\"\n >\n <ng-container *ngIf=\"first\">\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n [node]=\"node\"\n #link\n >\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </es-node-url>\n <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!first\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </ng-container>\n </div>\n </div>\n <ng-container\n *ngTemplateOutlet=\"templatesService.actionArea; context: { element: node }\"\n ></ng-container>\n</ng-template>\n", styles: [".grid-card{transition:all var(--transitionNormal);overflow:hidden;background-color:#fff;box-shadow:0 3px 3px #0000001a;display:grid;height:100%;grid-template-columns:auto}:host-context(body.es-contrast-mode) .grid-card{border:1px solid rgba(0,0,0,.42)}.grid-card.selected{background-color:rgb(var(--palette-primary-50))}.grid-card .dropdown-dummy{position:fixed}.grid-card .card-options{display:grid;grid-template-columns:1fr auto;grid-column-gap:10px}.grid-card .card-options .card-rating-area{display:flex;align-items:center;height:100%;padding-left:10px}.grid-card .card-options .card-options-area{display:flex}.grid-card .card-options .card-options-area es-option-button,.grid-card .card-options .card-options-area button{transition:all var(--transitionNormal);margin:0 2px;border-radius:50%}.grid-card .card-options .card-options-area es-option-button:hover,.grid-card .card-options .card-options-area es-option-button:focus,.grid-card .card-options .card-options-area button:hover,.grid-card .card-options .card-options-area button:focus{background-color:#fff}.grid-card:not(.grid-card-collection) .card-top-bar{background-color:var(--palette-primary-200)}.grid-card.grid-card-virtual{outline:2px dashed var(--nodeVirtualColor)}.grid-card .card-top-bar{height:40px;display:flex;gap:15px;align-items:center;padding:0 15px;position:relative}.grid-card .card-top-bar .card-top-bar-collection-color{position:absolute;background-color:#ffffff80;inset:0}.grid-card .card-top-bar .card-top-bar-flag{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}.grid-card .card-top-bar .card-top-bar-flag i{font-size:18px;color:#333}.grid-card .card-top-bar .card-top-bar-flag img{width:18px;height:18px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox{margin-right:-5px;position:relative;top:-1.3px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator{outline:none}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator:after{content:\"\";position:absolute;inset:2px;outline:none;border:2px solid var(--palette-primary-300);border-color:#fff}.grid-card .card-top-bar .card-top-bar-empty{width:0;flex-grow:1}.grid-card .card-image-area{height:100px;padding:0;display:flex}.grid-card .card-image-area es-preview-image{flex-grow:1}.grid-card .card-image-area .card-collection-image{display:flex;width:100%;height:100%;align-items:center;justify-content:center}.grid-card .card-image-area .card-collection-image i{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;color:#000000bf;background-color:#ffffff80;padding:25px;font-size:25px;border-radius:50%}.grid-card .card-meta{padding:8px 15px 0;display:grid;flex-direction:row}.grid-card .card-meta .card-meta-row{display:flex;flex-direction:row;align-items:center;min-height:2.8em;gap:5px}.grid-card .card-meta .card-meta-row:not(:first-child)>label{cursor:inherit;color:var(--textLight);font-size:85%}.grid-card .card-meta .card-meta-row:not(:first-child)>es-list-base{color:#000;flex-grow:1;margin:5px 0;display:flex;justify-content:flex-end;text-align:end;word-break:break-word}.grid-card .card-meta .card-meta-row:first-child{font-size:120%}.grid-card .card-meta .card-meta-row:first-child>es-list-base,.grid-card .card-meta .card-meta-row:first-child>es-node-url{width:100%;font-size:120%;color:var(--textMain);height:2.8em;text-align:left;word-break:break-word}.grid-card.dynamic-single-click:hover{box-shadow:0 0 25px #0003;background-color:rgb(var(--palette-primary-50))}.grid-card.dynamic-single-click.grid-card-collection:hover .card-meta{background-color:#ffffffe6}.grid-card.grid-card-collection .card-meta{background-color:#fffc}.grid-card.grid-card-collection .card-options{background-color:#ffffffe6}.grid-card .card-options{border-top:1px solid #ddd}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text{word-break:break-word}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text span,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text span{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row es-node-url a{color:var(--textMain)}:host ::ng-deep .grid-card .card-meta-row es-node-url a.cdk-keyboard-focused{display:inline-flex;outline:none;outline:2px solid var(--palette-primary-300);outline-offset:2px}:host ::ng-deep .card-meta es-list-base img{max-width:100px;max-height:20px}:host ::ng-deep .card-meta es-list-base es-list-node-license img{height:20px}:host ::ng-deep .card-meta es-list-base es-list-collection-info{display:flex;align-items:center}:host ::ng-deep .card-meta es-list-base es-list-collection-info i{font-size:12pt;margin:0 6px}:host ::ng-deep .grid-card-collection es-node-url a.cdk-keyboard-focused .card-meta{background-color:#fff}.card-overlay{position:absolute;z-index:2;inset:0;pointer-events:none}.card-overlay ::ng-deep>*{pointer-events:auto}.collection-pin{background:#ffffff80;border-radius:50px;position:absolute;z-index:1;right:10px;top:10px;width:25px;height:25px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 3px #0000001a}.collection-pin>i{font-size:12px}.grid-card .card-meta-row ::ng-deep es-node-url a.cdk-keyboard-focused{outline-color:var(--palette-primary-400)}.grid-card{cursor:pointer}.grid-card.grid-card-collection{background-color:rgb(var(--palette-primary-200))}.grid-card .card-meta{background-color:#fffc;padding-bottom:8px}.grid-card .card-meta .card-meta-row:nth-child(1){grid-column:1/3}.grid-card .card-meta .card-meta-row:nth-child(2){justify-self:flex-start}.grid-card .card-meta .card-meta-row:nth-child(2),.grid-card .card-meta .card-meta-row:nth-child(3){grid-row:2;font-size:var(--fontSizeXSmall)}\n"] }]
41
- }], ctorParameters: () => [{ type: i1.NodeEntriesService }, { type: i2.NodeHelperService }, { type: i3.NodeEntriesTemplatesService }], propDecorators: { node: [{
42
- type: Input
43
- }] } });
44
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-card-small.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card-small/node-entries-card-small.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card-small/node-entries-card-small.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;;;;AAYhE,MAAM,OAAO,6BAA6B;IAKtC,YACW,cAAqC,EACrC,UAA6B,EAC7B,gBAA6C;QAF7C,mBAAc,GAAd,cAAc,CAAuB;QACrC,eAAU,GAAV,UAAU,CAAmB;QAC7B,qBAAgB,GAAhB,gBAAgB,CAA6B;QAP/C,gBAAW,GAAG,WAAW,CAAC;QAC1B,oBAAe,GAAG,eAAe,CAAC;QAClC,WAAM,GAAG,MAAM,CAAC;IAMtB,CAAC;IAEJ,aAAa;QACT,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;QACnD,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YAClD,OAAO,MAAM,CAAC;QAClB,CAAC;QACD,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5F,CAAC;IAED,eAAe,CAAC,KAAyB;QACrC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;+GAvBQ,6BAA6B;mGAA7B,6BAA6B,4FCd1C,8nHAgHA;;4FDlGa,6BAA6B;kBALzC,SAAS;+BACI,4BAA4B;iKAQ7B,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { Target } from '../../types/option-item';\nimport { ClickSource, InteractionType } from '../entries-model';\n\nimport { NodeEntriesTemplatesService } from '../node-entries-templates.service';\nimport { NodeEntriesService } from '../../services/node-entries.service';\nimport { NodeHelperService } from '../../services/node-helper.service';\nimport { Node } from 'ngx-edu-sharing-api';\n\n@Component({\n    selector: 'es-node-entries-card-small',\n    templateUrl: 'node-entries-card-small.component.html',\n    styleUrls: ['node-entries-card-small.component.scss'],\n})\nexport class NodeEntriesCardSmallComponent<T extends Node> {\n    readonly ClickSource = ClickSource;\n    readonly InteractionType = InteractionType;\n    readonly Target = Target;\n    @Input() node: T;\n    constructor(\n        public entriesService: NodeEntriesService<T>,\n        public nodeHelper: NodeHelperService,\n        public templatesService: NodeEntriesTemplatesService,\n    ) {}\n\n    optionsOnCard() {\n        const options = this.entriesService.options[Target.List];\n        const always = options.filter((o) => o.showAlways);\n        if (always.some((o) => o.showCallback([this.node]))) {\n            return always;\n        }\n        return options.filter((o) => o.showAsAction && o.showCallback([this.node])).slice(0, 3);\n    }\n\n    openContextmenu(event: MouseEvent | Event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n}\n","<div\n  [class]=\"\n    'grid-card' +\n    (nodeHelper.isNodeCollection(node)\n      ? ' grid-card-collection grid-card-collection-scope-' +\n        node.collection.scope +\n        ' grid-card-collection-type-' +\n        node.collection.type\n      : '') +\n    ($any(node).virtual ? ' grid-card-virtual' : '') +\n    ' ' +\n    (entriesService.singleClickHint === 'dynamic' ? ' dynamic-single-click' : '')\n  \"\n  [style.background-color]=\"nodeHelper.isNodeCollection(node) ? node.collection.color : null\"\n  (contextmenu)=\"openContextmenu($event)\"\n  (keydown.ContextMenu)=\"openContextmenu($event)\"\n>\n  <div\n    *ngIf=\"templatesService.overlay\"\n    class=\"card-overlay\"\n    (click)=\"\n      entriesService.clickItem.emit({\n        element: node,\n        source: ClickSource.Overlay,\n      })\n    \"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n    ></ng-container>\n  </div>\n  <es-node-url\n    *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n    mode=\"wrapper\"\n    [node]=\"node\"\n    esFocusState\n    #cardFocusState=\"esFocusState\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"\n        image;\n        context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n      \"\n    ></ng-container>\n    <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n  </es-node-url>\n  <ng-container *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n    <ng-container *ngTemplateOutlet=\"image\"></ng-container>\n    <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n  </ng-container>\n</div>\n<ng-template #image let-playAnimation=\"playAnimation\">\n  <div\n    class=\"card-image-area\"\n    (click)=\"\n      entriesService.clickItem.emit({\n        element: node,\n        source: ClickSource.Preview,\n      })\n    \"\n  >\n    <div *ngIf=\"nodeHelper.isNodeCollection(node) && node.collection.pinned\" class=\"collection-pin\">\n      <i esIcon=\"edu-pin\"></i>\n    </div>\n    <es-preview-image\n      *ngIf=\"!(nodeHelper.isNodeCollection(node) && node.preview.isIcon)\"\n      [node]=\"node\"\n      [playAnimation]=\"playAnimation\"\n    ></es-preview-image>\n    <div\n      *ngIf=\"nodeHelper.isNodeCollection(node) && node.preview.isIcon\"\n      class=\"card-collection-image\"\n    >\n      <i esIcon=\"layers\"></i>\n    </div>\n  </div>\n</ng-template>\n<ng-template #meta>\n  <div\n    class=\"card-meta\"\n    (click)=\"\n      entriesService.clickItem.emit({\n        element: node,\n        source: ClickSource.Metadata,\n      })\n    \"\n  >\n    <div\n      *ngFor=\"let displayPart of entriesService.columns; let first = first\"\n      class=\"card-meta-row\"\n    >\n      <ng-container *ngIf=\"first\">\n        <es-node-url\n          *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n          [node]=\"node\"\n          #link\n        >\n          <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n        </es-node-url>\n        <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n          <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"!first\">\n        <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n      </ng-container>\n    </div>\n  </div>\n  <ng-container\n    *ngTemplateOutlet=\"templatesService.actionArea; context: { element: node }\"\n  ></ng-container>\n</ng-template>\n"]}