ngx-edu-sharing-ui 9.2.0 → 10.0.1

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/mixins.scss +4 -4
  2. package/assets/scss/variables-scss.scss +5 -1
  3. package/assets/scss/variables.scss +1 -3
  4. package/esm2022/lib/actionbar/actionbar.component.mjs +38 -20
  5. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +8 -5
  6. package/esm2022/lib/directives/border-box-observer.directive.mjs +6 -6
  7. package/esm2022/lib/directives/check-text-overflow.directive.mjs +5 -5
  8. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +4 -4
  9. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +4 -4
  10. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +4 -4
  11. package/esm2022/lib/directives/focus-state.directive.mjs +4 -4
  12. package/esm2022/lib/directives/icon.directive.mjs +26 -9
  13. package/esm2022/lib/directives/infinite-scroll.directive.mjs +4 -4
  14. package/esm2022/lib/dropdown/dropdown.component.mjs +25 -12
  15. package/esm2022/lib/edu-sharing-ui-configuration.mjs +4 -4
  16. package/esm2022/lib/edu-sharing-ui.module.mjs +5 -5
  17. package/esm2022/lib/index.mjs +88 -0
  18. package/esm2022/lib/list-items/format-duration.pipe.mjs +4 -4
  19. package/esm2022/lib/list-items/list-base/list-base.component.mjs +4 -4
  20. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +4 -4
  21. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +4 -4
  22. package/esm2022/lib/list-items/list-items.module.mjs +5 -5
  23. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +4 -4
  24. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +4 -4
  25. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +5 -5
  26. package/esm2022/lib/list-items/list-text/list-text.component.mjs +11 -11
  27. package/esm2022/lib/list-items/list-widget.mjs +4 -4
  28. package/esm2022/lib/list-items/node-row/node-row.component.mjs +4 -4
  29. package/esm2022/lib/list-items/node-source.pipe.mjs +4 -4
  30. package/esm2022/lib/mds/mds-helper.service.mjs +4 -4
  31. package/esm2022/lib/mds/mds.module.mjs +5 -5
  32. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +5 -5
  33. package/esm2022/lib/node-entries/entries-model.mjs +1 -1
  34. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +11 -8
  35. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +9 -25
  36. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +45 -38
  37. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +7 -8
  38. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +5 -5
  39. package/esm2022/lib/node-entries/node-entries-global.service.mjs +4 -4
  40. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +4 -4
  41. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +51 -56
  42. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +4 -4
  43. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +60 -22
  44. package/esm2022/lib/node-entries/node-entries.component.mjs +5 -5
  45. package/esm2022/lib/node-entries/node-entries.module.mjs +5 -5
  46. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +4 -4
  47. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +4 -4
  48. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +4 -4
  49. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +11 -9
  50. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +4 -4
  51. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +5 -5
  52. package/esm2022/lib/node-url/node-url.component.mjs +4 -4
  53. package/esm2022/lib/pipes/file-size.pipe.mjs +9 -8
  54. package/esm2022/lib/pipes/format-date.pipe.mjs +4 -4
  55. package/esm2022/lib/pipes/node-icon.pipe.mjs +4 -4
  56. package/esm2022/lib/pipes/node-image-size.pipe.mjs +4 -4
  57. package/esm2022/lib/pipes/node-image.pipe.mjs +4 -4
  58. package/esm2022/lib/pipes/node-license.pipe.mjs +24 -0
  59. package/esm2022/lib/pipes/node-person-name.pipe.mjs +4 -4
  60. package/esm2022/lib/pipes/node-title.pipe.mjs +21 -6
  61. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +6 -6
  62. package/esm2022/lib/pipes/property-slug.pipe.mjs +4 -4
  63. package/esm2022/lib/pipes/replace-chars.pipe.mjs +4 -4
  64. package/esm2022/lib/pipes/vcard-name.pipe.mjs +10 -4
  65. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +4 -4
  66. package/esm2022/lib/services/abstract/options-helper.service.mjs +1 -1
  67. package/esm2022/lib/services/accessibility.service.mjs +4 -4
  68. package/esm2022/lib/services/app-container.service.mjs +7 -4
  69. package/esm2022/lib/services/local-events.service.mjs +11 -4
  70. package/esm2022/lib/services/node-entries.service.mjs +31 -11
  71. package/esm2022/lib/services/node-helper.service.mjs +38 -6
  72. package/esm2022/lib/services/nodes-drag-drop.service.mjs +4 -4
  73. package/esm2022/lib/services/options-helper-data.service.mjs +7 -7
  74. package/esm2022/lib/services/render-helper.service.mjs +114 -0
  75. package/esm2022/lib/services/repo-url.service.mjs +4 -4
  76. package/esm2022/lib/services/search-helper.service.mjs +52 -0
  77. package/esm2022/lib/services/temporary-storage.service.mjs +4 -4
  78. package/esm2022/lib/services/ui.service.mjs +21 -6
  79. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +8 -8
  80. package/esm2022/lib/spinner/spinner.component.mjs +4 -4
  81. package/esm2022/lib/translations/translation-loader.mjs +54 -16
  82. package/esm2022/lib/translations/translations.module.mjs +8 -6
  83. package/esm2022/lib/translations/translations.service.mjs +36 -10
  84. package/esm2022/lib/types/api-models.mjs +1 -1
  85. package/esm2022/lib/types/injection-tokens.mjs +10 -1
  86. package/esm2022/lib/types/list-item.mjs +1 -1
  87. package/esm2022/lib/types/option-item.mjs +23 -7
  88. package/esm2022/lib/util/VCard.mjs +2 -2
  89. package/esm2022/ngx-edu-sharing-ui.mjs +2 -2
  90. package/esm2022/public-api.mjs +2 -0
  91. package/fesm2022/ngx-edu-sharing-ui.mjs +1004 -577
  92. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  93. package/index.d.ts +1 -1
  94. package/lib/actionbar/actionbar.component.d.ts +15 -4
  95. package/lib/common/edu-sharing-ui-common.module.d.ts +17 -16
  96. package/lib/directives/icon.directive.d.ts +5 -3
  97. package/lib/dropdown/dropdown.component.d.ts +10 -6
  98. package/lib/index.d.ts +84 -0
  99. package/lib/list-items/list-text/list-text.component.d.ts +4 -5
  100. package/lib/node-entries/entries-model.d.ts +4 -1
  101. package/lib/node-entries/list-item-label.pipe.d.ts +3 -1
  102. package/lib/node-entries/node-entries-card/node-entries-card.component.d.ts +1 -1
  103. package/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.d.ts +4 -2
  104. package/lib/node-entries/node-entries-card-small/node-entries-card-small.component.d.ts +1 -3
  105. package/lib/node-entries/node-entries-table/node-entries-table.component.d.ts +3 -1
  106. package/lib/node-entries/node-entries-wrapper.component.d.ts +9 -2
  107. package/lib/node-entries/option-button/option-button.component.d.ts +2 -1
  108. package/lib/pipes/node-license.pipe.d.ts +14 -0
  109. package/lib/pipes/node-title.pipe.d.ts +4 -1
  110. package/lib/pipes/option-tooltip.pipe.d.ts +1 -1
  111. package/lib/pipes/vcard-name.pipe.d.ts +1 -1
  112. package/lib/services/abstract/options-helper.service.d.ts +2 -2
  113. package/lib/services/app-container.service.d.ts +2 -1
  114. package/lib/services/local-events.service.d.ts +7 -0
  115. package/lib/services/node-entries.service.d.ts +10 -3
  116. package/lib/services/node-helper.service.d.ts +11 -2
  117. package/lib/services/options-helper-data.service.d.ts +7 -7
  118. package/lib/services/render-helper.service.d.ts +24 -0
  119. package/lib/services/search-helper.service.d.ts +21 -0
  120. package/lib/services/ui.service.d.ts +9 -2
  121. package/lib/sort-dropdown/sort-dropdown.component.d.ts +2 -2
  122. package/lib/translations/translation-loader.d.ts +3 -1
  123. package/lib/translations/translations.service.d.ts +6 -2
  124. package/lib/types/api-models.d.ts +9 -0
  125. package/lib/types/injection-tokens.d.ts +9 -0
  126. package/lib/types/list-item.d.ts +2 -2
  127. package/lib/types/option-item.d.ts +27 -10
  128. package/package.json +7 -7
  129. package/public-api.d.ts +1 -0
  130. package/esm2022/module.mjs +0 -84
  131. package/module.d.ts +0 -80
@@ -14,26 +14,27 @@ import * as i0 from "@angular/core";
14
14
  import * as i1 from "../../services/node-entries.service";
15
15
  import * as i2 from "../node-entries-global.service";
16
16
  import * as i3 from "../node-entries-templates.service";
17
- import * as i4 from "../../services/ui.service";
18
- import * as i5 from "@angular/common";
19
- import * as i6 from "@angular/cdk/overlay";
20
- import * as i7 from "@angular/cdk/drag-drop";
21
- import * as i8 from "../../directives/border-box-observer.directive";
22
- import * as i9 from "../../dropdown/dropdown.component";
23
- import * as i10 from "../../directives/icon.directive";
24
- import * as i11 from "../../directives/infinite-scroll.directive";
25
- import * as i12 from "../../spinner/spinner.component";
26
- import * as i13 from "@angular/material/button";
27
- import * as i14 from "@angular/material/badge";
28
- import * as i15 from "@angular/material/tooltip";
29
- import * as i16 from "../node-entries-table/column-chooser/column-chooser.component";
30
- import * as i17 from "../node-entries-card/node-entries-card.component";
31
- import * as i18 from "../node-entries-card-small/node-entries-card-small.component";
32
- import * as i19 from "../sort-select-panel/sort-select-panel.component";
33
- import * as i20 from "../../directives/drag-nodes/nodes-drag.directive";
34
- import * as i21 from "../../directives/drag-nodes/nodes-drop-target.directive";
35
- import * as i22 from "../node-entries-global-options/node-entries-global-options.component";
36
- import * as i23 from "@ngx-translate/core";
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";
37
38
  let displayedWarnings = [];
38
39
  export class NodeEntriesCardGridComponent {
39
40
  set gridTop(value) {
@@ -46,10 +47,11 @@ export class NodeEntriesCardGridComponent {
46
47
  });
47
48
  // }
48
49
  }
49
- constructor(entriesService, entriesGlobalService, templatesService, ui, ngZone) {
50
+ constructor(entriesService, entriesGlobalService, templatesService, nodeHelperService, ui, ngZone) {
50
51
  this.entriesService = entriesService;
51
52
  this.entriesGlobalService = entriesGlobalService;
52
53
  this.templatesService = templatesService;
54
+ this.nodeHelperService = nodeHelperService;
53
55
  this.ui = ui;
54
56
  this.ngZone = ngZone;
55
57
  this.NodeEntriesDisplayType = NodeEntriesDisplayType;
@@ -209,14 +211,17 @@ export class NodeEntriesCardGridComponent {
209
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))
210
212
  .some((c2) => c.type === c2.type && c2.name === c.name);
211
213
  if (!result && !this.entriesService.configureColumns) {
212
- const warning = 'Sort field ' +
213
- c.name +
214
- ' was specified but is not present as a column. ' +
215
- 'It will be ignored. Please also configure this field in the <lists> section';
216
- if (!displayedWarnings.includes(warning)) {
217
- console.warn(warning);
218
- displayedWarnings.push(warning);
219
- }
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
+ }*/
220
225
  }
221
226
  return result;
222
227
  });
@@ -283,19 +288,21 @@ export class NodeEntriesCardGridComponent {
283
288
  behavior: 'smooth',
284
289
  });
285
290
  }
286
- isCustomTemplate() {
287
- return this.entriesService.dataSource instanceof CustomTemplatesDataSource;
291
+ isCustomTemplate(node) {
292
+ return (this.entriesService.dataSource instanceof CustomTemplatesDataSource ||
293
+ node.elementRef);
288
294
  }
289
295
  isBlocked(node) {
290
- return node.properties?.[RestConstants.CCM_PROP_IMPORT_BLOCKED]?.[0] === 'true';
296
+ return (node.properties?.[RestConstants.CCM_PROP_IMPORT_BLOCKED]?.[0] === 'true' ||
297
+ this.nodeHelperService.isNodeRevoked(node));
291
298
  }
292
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesCardGridComponent, deps: [{ token: i1.NodeEntriesService }, { token: i2.NodeEntriesGlobalService }, { token: i3.NodeEntriesTemplatesService }, { token: i4.UIService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
293
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", 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()\">\n <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!isCustomTemplate()\">\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)\"\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)\"\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: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "directive", type: i7.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i7.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i7.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i7.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "directive", type: i8.BorderBoxObserverDirective, selector: "[esBorderBoxObserver]", outputs: ["esBorderBoxObserver"], exportAs: ["borderBoxObserver"] }, { kind: "component", type: i9.DropdownComponent, selector: "es-dropdown", inputs: ["position", "options", "callbackObject", "showDisabled", "menuClass"] }, { kind: "directive", type: i10.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "directive", type: i11.InfiniteScrollDirective, selector: "[esInfiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollThrottle", "scrollWindow"], outputs: ["scrolled"] }, { kind: "component", type: i12.SpinnerComponent, selector: "es-spinner" }, { kind: "component", type: i13.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i13.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i14.MatBadge, selector: "[matBadge]", inputs: ["matBadgeColor", "matBadgeOverlap", "matBadgeDisabled", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "directive", type: i15.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i16.ColumnChooserComponent, selector: "es-column-chooser", inputs: ["origin", "columnChooserVisible", "columns"], outputs: ["columnChooserVisibleChange", "columnsChange"] }, { kind: "component", type: i17.NodeEntriesCardComponent, selector: "es-node-entries-card", inputs: ["dropdown", "node"] }, { kind: "component", type: i18.NodeEntriesCardSmallComponent, selector: "es-node-entries-card-small", inputs: ["node"] }, { kind: "component", type: i19.SortSelectPanelComponent, selector: "es-sort-select-panel", inputs: ["active", "direction", "columns", "customSortingInProgress"], outputs: ["sortChange", "customSortingInProgressChange"] }, { kind: "directive", type: i20.NodesDragDirective, selector: "[esNodesDrag]" }, { kind: "directive", type: i21.NodesDropTargetDirective, selector: "[esNodesDropTarget]", inputs: ["esNodesDropTarget", "canDropNodes"], outputs: ["nodeDropped"], exportAs: ["esNodesDropTarget"] }, { kind: "component", type: i22.NodeEntriesGlobalOptionsComponent, selector: "es-node-entries-global-options", inputs: ["displayType"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i23.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
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 }); }
294
301
  }
295
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesCardGridComponent, decorators: [{
302
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardGridComponent, decorators: [{
296
303
  type: Component,
297
- 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()\">\n <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!isCustomTemplate()\">\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)\"\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)\"\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"] }]
298
- }], ctorParameters: () => [{ type: i1.NodeEntriesService }, { type: i2.NodeEntriesGlobalService }, { type: i3.NodeEntriesTemplatesService }, { type: i4.UIService }, { type: i0.NgZone }], propDecorators: { columnChooserTrigger: [{
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: [{
299
306
  type: ViewChild,
300
307
  args: ['columnChooserTrigger']
301
308
  }], gridTop: [{
@@ -319,4 +326,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
319
326
  type: HostBinding,
320
327
  args: ['style.--scroll-gradient-color']
321
328
  }] } });
322
- //# 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';\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 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                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() {\n        return this.entriesService.dataSource instanceof CustomTemplatesDataSource;\n    }\n\n    isBlocked(node: Node) {\n        return node.properties?.[RestConstants.CCM_PROP_IMPORT_BLOCKED]?.[0] === 'true';\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()\">\n            <ng-container *ngTemplateOutlet=\"$any(node)\"></ng-container>\n          </ng-container>\n          <ng-container *ngIf=\"!isCustomTemplate()\">\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)\"\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)\"\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"]}
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"]}