ngx-edu-sharing-ui 10.0.20 → 10.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/assets/scss/material-theme.scss +3 -3
  2. package/assets/scss/mixins.scss +1 -1
  3. package/assets/scss/variables-root.scss +2 -0
  4. package/assets/scss/variables-scss.scss +3 -4
  5. package/assets/scss/variables.scss +1 -1
  6. package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
  7. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  8. package/lib/index.d.ts +1 -0
  9. package/lib/list-items/list-widget.d.ts +1 -1
  10. package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
  11. package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
  12. package/package.json +8 -9
  13. package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
  14. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
  15. package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
  16. package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
  17. package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
  18. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
  19. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
  20. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
  21. package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
  22. package/esm2022/lib/directives/icon.directive.mjs +0 -184
  23. package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
  24. package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
  25. package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
  26. package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
  27. package/esm2022/lib/index.mjs +0 -96
  28. package/esm2022/lib/list-items/available-widgets.mjs +0 -27
  29. package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
  30. package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
  31. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
  32. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
  33. package/esm2022/lib/list-items/list-items.module.mjs +0 -50
  34. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
  35. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
  36. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
  37. package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
  38. package/esm2022/lib/list-items/list-widget.mjs +0 -49
  39. package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
  40. package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
  41. package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
  42. package/esm2022/lib/mds/mds.module.mjs +0 -16
  43. package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
  44. package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
  45. package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
  46. package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
  47. package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
  48. package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
  49. package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
  50. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
  51. package/esm2022/lib/node-entries/entries-model.mjs +0 -24
  52. package/esm2022/lib/node-entries/items-cap.mjs +0 -47
  53. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
  54. package/esm2022/lib/node-entries/node-cache.mjs +0 -73
  55. package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
  56. package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
  57. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
  58. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
  59. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
  60. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
  61. package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
  62. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
  63. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
  64. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
  65. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
  66. package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
  67. package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
  68. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
  69. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
  70. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
  71. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
  72. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
  73. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
  74. package/esm2022/lib/node-url/node-url.component.mjs +0 -132
  75. package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
  76. package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
  77. package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
  78. package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
  79. package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
  80. package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
  81. package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
  82. package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
  83. package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
  84. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
  85. package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
  86. package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
  87. package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
  88. package/esm2022/lib/services/abstract/app.service.mjs +0 -3
  89. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
  90. package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
  91. package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
  92. package/esm2022/lib/services/accessibility.service.mjs +0 -73
  93. package/esm2022/lib/services/app-container.service.mjs +0 -69
  94. package/esm2022/lib/services/local-events.service.mjs +0 -43
  95. package/esm2022/lib/services/node-entries.service.mjs +0 -201
  96. package/esm2022/lib/services/node-helper.service.mjs +0 -330
  97. package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
  98. package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
  99. package/esm2022/lib/services/render-helper.service.mjs +0 -114
  100. package/esm2022/lib/services/repo-url.service.mjs +0 -50
  101. package/esm2022/lib/services/search-helper.service.mjs +0 -52
  102. package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
  103. package/esm2022/lib/services/ui.service.mjs +0 -327
  104. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
  105. package/esm2022/lib/spinner/spinner.component.mjs +0 -19
  106. package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
  107. package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
  108. package/esm2022/lib/translations/translation-loader.mjs +0 -219
  109. package/esm2022/lib/translations/translation-source.mjs +0 -11
  110. package/esm2022/lib/translations/translations.module.mjs +0 -82
  111. package/esm2022/lib/translations/translations.service.mjs +0 -238
  112. package/esm2022/lib/types/accessibillity.mjs +0 -19
  113. package/esm2022/lib/types/api-models.mjs +0 -2
  114. package/esm2022/lib/types/drag-drop.mjs +0 -2
  115. package/esm2022/lib/types/injection-tokens.mjs +0 -31
  116. package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
  117. package/esm2022/lib/types/list-item.mjs +0 -41
  118. package/esm2022/lib/types/option-item.mjs +0 -192
  119. package/esm2022/lib/types/workflow.mjs +0 -25
  120. package/esm2022/lib/util/DateHelper.mjs +0 -200
  121. package/esm2022/lib/util/VCard.mjs +0 -278
  122. package/esm2022/lib/util/color-helper.mjs +0 -124
  123. package/esm2022/lib/util/duration-helper.mjs +0 -102
  124. package/esm2022/lib/util/functions.mjs +0 -13
  125. package/esm2022/lib/util/helper.mjs +0 -64
  126. package/esm2022/lib/util/isNumeric.mjs +0 -11
  127. package/esm2022/lib/util/rest-helper.mjs +0 -42
  128. package/esm2022/lib/util/ui-animation.mjs +0 -146
  129. package/esm2022/lib/util/ui-constants.mjs +0 -21
  130. package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
  131. package/esm2022/public-api.mjs +0 -2
@@ -1,47 +0,0 @@
1
- import * as rxjs from 'rxjs';
2
- import { BehaviorSubject } from 'rxjs';
3
- import { distinctUntilChanged, map } from 'rxjs/operators';
4
- export class ItemsCap {
5
- constructor() {
6
- this._cap = new BehaviorSubject(null);
7
- this._disabled = new BehaviorSubject(false);
8
- this._isActivelyCapping = false;
9
- this._effectiveCap = rxjs
10
- .combineLatest([this._cap, this._disabled])
11
- .pipe(map(([cap, disabled]) => (disabled ? null : cap)), distinctUntilChanged());
12
- }
13
- /** The number of items to which the data should be capped. */
14
- get cap() {
15
- return this._cap.value;
16
- }
17
- set cap(value) {
18
- this._cap.next(value ?? null);
19
- }
20
- /** Whether to temporarily disable capping. */
21
- get disabled() {
22
- return this._disabled.value;
23
- }
24
- set disabled(value) {
25
- this._disabled.next(value);
26
- }
27
- /** Whether there is more data available that is currently being capped. */
28
- get isActivelyCapping() {
29
- return this._isActivelyCapping;
30
- }
31
- connect(dataStream) {
32
- return rxjs.combineLatest([this._effectiveCap, dataStream]).pipe(map(([effectiveCap, originalData]) => {
33
- const needToCap = this._needToCap(effectiveCap, originalData);
34
- this._isActivelyCapping = needToCap;
35
- if (needToCap) {
36
- return originalData.slice(0, effectiveCap);
37
- }
38
- else {
39
- return originalData;
40
- }
41
- }));
42
- }
43
- _needToCap(effectiveCap, originalData) {
44
- return effectiveCap && originalData?.length > effectiveCap;
45
- }
46
- }
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbXMtY2FwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvaXRlbXMtY2FwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBQzdCLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTNELE1BQU0sT0FBTyxRQUFRO0lBQXJCO1FBUVksU0FBSSxHQUFHLElBQUksZUFBZSxDQUFnQixJQUFJLENBQUMsQ0FBQztRQVNoRCxjQUFTLEdBQUcsSUFBSSxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7UUFNdkMsdUJBQWtCLEdBQUcsS0FBSyxDQUFDO1FBRTNCLGtCQUFhLEdBQThCLElBQUk7YUFDbEQsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDMUMsSUFBSSxDQUNELEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUNqRCxvQkFBb0IsRUFBRSxDQUN6QixDQUFDO0lBbUJWLENBQUM7SUFoREcsOERBQThEO0lBQzlELElBQUksR0FBRztRQUNILE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDM0IsQ0FBQztJQUNELElBQUksR0FBRyxDQUFDLEtBQW9CO1FBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBR0QsOENBQThDO0lBQzlDLElBQUksUUFBUTtRQUNSLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUM7SUFDaEMsQ0FBQztJQUNELElBQUksUUFBUSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUdELDJFQUEyRTtJQUMzRSxJQUFJLGlCQUFpQjtRQUNqQixPQUFPLElBQUksQ0FBQyxrQkFBa0IsQ0FBQztJQUNuQyxDQUFDO0lBVUQsT0FBTyxDQUFDLFVBQTJCO1FBQy9CLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzVELEdBQUcsQ0FBQyxDQUFDLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQyxFQUFFLEVBQUU7WUFDakMsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxDQUFDLENBQUM7WUFDOUQsSUFBSSxDQUFDLGtCQUFrQixHQUFHLFNBQVMsQ0FBQztZQUNwQyxJQUFJLFNBQVMsRUFBRSxDQUFDO2dCQUNaLE9BQU8sWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsWUFBWSxDQUFDLENBQUM7WUFDL0MsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLE9BQU8sWUFBWSxDQUFDO1lBQ3hCLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FDTCxDQUFDO0lBQ04sQ0FBQztJQUVPLFVBQVUsQ0FBQyxZQUEyQixFQUFFLFlBQWlCO1FBQzdELE9BQU8sWUFBWSxJQUFJLFlBQVksRUFBRSxNQUFNLEdBQUcsWUFBWSxDQUFDO0lBQy9ELENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHJ4anMgZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGRpc3RpbmN0VW50aWxDaGFuZ2VkLCBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmV4cG9ydCBjbGFzcyBJdGVtc0NhcDxUPiB7XG4gICAgLyoqIFRoZSBudW1iZXIgb2YgaXRlbXMgdG8gd2hpY2ggdGhlIGRhdGEgc2hvdWxkIGJlIGNhcHBlZC4gKi9cbiAgICBnZXQgY2FwKCk6IG51bWJlciB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5fY2FwLnZhbHVlO1xuICAgIH1cbiAgICBzZXQgY2FwKHZhbHVlOiBudW1iZXIgfCBudWxsKSB7XG4gICAgICAgIHRoaXMuX2NhcC5uZXh0KHZhbHVlID8/IG51bGwpO1xuICAgIH1cbiAgICBwcml2YXRlIF9jYXAgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PG51bWJlciB8IG51bGw+KG51bGwpO1xuXG4gICAgLyoqIFdoZXRoZXIgdG8gdGVtcG9yYXJpbHkgZGlzYWJsZSBjYXBwaW5nLiAqL1xuICAgIGdldCBkaXNhYmxlZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2Rpc2FibGVkLnZhbHVlO1xuICAgIH1cbiAgICBzZXQgZGlzYWJsZWQodmFsdWU6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5fZGlzYWJsZWQubmV4dCh2YWx1ZSk7XG4gICAgfVxuICAgIHByaXZhdGUgX2Rpc2FibGVkID0gbmV3IEJlaGF2aW9yU3ViamVjdChmYWxzZSk7XG5cbiAgICAvKiogV2hldGhlciB0aGVyZSBpcyBtb3JlIGRhdGEgYXZhaWxhYmxlIHRoYXQgaXMgY3VycmVudGx5IGJlaW5nIGNhcHBlZC4gKi9cbiAgICBnZXQgaXNBY3RpdmVseUNhcHBpbmcoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pc0FjdGl2ZWx5Q2FwcGluZztcbiAgICB9XG4gICAgcHJpdmF0ZSBfaXNBY3RpdmVseUNhcHBpbmcgPSBmYWxzZTtcblxuICAgIHByaXZhdGUgX2VmZmVjdGl2ZUNhcDogT2JzZXJ2YWJsZTxudW1iZXIgfCBudWxsPiA9IHJ4anNcbiAgICAgICAgLmNvbWJpbmVMYXRlc3QoW3RoaXMuX2NhcCwgdGhpcy5fZGlzYWJsZWRdKVxuICAgICAgICAucGlwZShcbiAgICAgICAgICAgIG1hcCgoW2NhcCwgZGlzYWJsZWRdKSA9PiAoZGlzYWJsZWQgPyBudWxsIDogY2FwKSksXG4gICAgICAgICAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpLFxuICAgICAgICApO1xuXG4gICAgY29ubmVjdChkYXRhU3RyZWFtOiBPYnNlcnZhYmxlPFRbXT4pOiBPYnNlcnZhYmxlPFRbXT4ge1xuICAgICAgICByZXR1cm4gcnhqcy5jb21iaW5lTGF0ZXN0KFt0aGlzLl9lZmZlY3RpdmVDYXAsIGRhdGFTdHJlYW1dKS5waXBlKFxuICAgICAgICAgICAgbWFwKChbZWZmZWN0aXZlQ2FwLCBvcmlnaW5hbERhdGFdKSA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgbmVlZFRvQ2FwID0gdGhpcy5fbmVlZFRvQ2FwKGVmZmVjdGl2ZUNhcCwgb3JpZ2luYWxEYXRhKTtcbiAgICAgICAgICAgICAgICB0aGlzLl9pc0FjdGl2ZWx5Q2FwcGluZyA9IG5lZWRUb0NhcDtcbiAgICAgICAgICAgICAgICBpZiAobmVlZFRvQ2FwKSB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBvcmlnaW5hbERhdGEuc2xpY2UoMCwgZWZmZWN0aXZlQ2FwKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gb3JpZ2luYWxEYXRhO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pLFxuICAgICAgICApO1xuICAgIH1cblxuICAgIHByaXZhdGUgX25lZWRUb0NhcChlZmZlY3RpdmVDYXA6IG51bWJlciB8IG51bGwsIG9yaWdpbmFsRGF0YTogVFtdKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBlZmZlY3RpdmVDYXAgJiYgb3JpZ2luYWxEYXRhPy5sZW5ndGggPiBlZmZlY3RpdmVDYXA7XG4gICAgfVxufVxuIl19
@@ -1,37 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import * as rxjs from 'rxjs';
3
- import { delay, startWith, switchMap } from 'rxjs/operators';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@ngx-translate/core";
6
- import * as i2 from "../translations/translations.service";
7
- export class ListItemLabelPipe {
8
- constructor(translate, translations) {
9
- this.translate = translate;
10
- this.translations = translations;
11
- }
12
- transform(item, args = { fallback: item.name }) {
13
- const mapping = {
14
- NODE: 'NODE',
15
- COLLECTION: 'NODE',
16
- NODE_PROPOSAL: 'NODE_PROPOSAL',
17
- ORG: 'ORG',
18
- GROUP: 'GROUP',
19
- USER: 'USER',
20
- };
21
- if (item.label) {
22
- return rxjs.of(item.label);
23
- }
24
- else {
25
- return this.translations.waitForInit().pipe(startWith(null), delay(1), switchMap(() => this.translate.get(mapping[item.type] + '.' + item.name, {
26
- fallback: args.fallback,
27
- })));
28
- }
29
- }
30
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ListItemLabelPipe, deps: [{ token: i1.TranslateService }, { token: i2.TranslationsService }], target: i0.ɵɵFactoryTarget.Pipe }); }
31
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: ListItemLabelPipe, name: "esListItemLabel" }); }
32
- }
33
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ListItemLabelPipe, decorators: [{
34
- type: Pipe,
35
- args: [{ name: 'esListItemLabel' }]
36
- }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.TranslationsService }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1pdGVtLWxhYmVsLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL25vZGUtZW50cmllcy9saXN0LWl0ZW0tbGFiZWwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUVwRCxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUk3QixPQUFPLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQUc3RCxNQUFNLE9BQU8saUJBQWlCO0lBQzFCLFlBQW9CLFNBQTJCLEVBQVUsWUFBaUM7UUFBdEUsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFBVSxpQkFBWSxHQUFaLFlBQVksQ0FBcUI7SUFBRyxDQUFDO0lBRTlGLFNBQVMsQ0FBQyxJQUFjLEVBQUUsSUFBSSxHQUFHLEVBQUUsUUFBUSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUU7UUFDcEQsTUFBTSxPQUFPLEdBQUc7WUFDWixJQUFJLEVBQUUsTUFBTTtZQUNaLFVBQVUsRUFBRSxNQUFNO1lBQ2xCLGFBQWEsRUFBRSxlQUFlO1lBQzlCLEdBQUcsRUFBRSxLQUFLO1lBQ1YsS0FBSyxFQUFFLE9BQU87WUFDZCxJQUFJLEVBQUUsTUFBTTtTQUNmLENBQUM7UUFDRixJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNiLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0IsQ0FBQzthQUFNLENBQUM7WUFDSixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUMsSUFBSSxDQUN2QyxTQUFTLENBQUMsSUFBWSxDQUFDLEVBQ3ZCLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFDUixTQUFTLENBQUMsR0FBRyxFQUFFLENBQ1gsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksRUFBRTtnQkFDckQsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO2FBQzFCLENBQUMsQ0FDTCxDQUNKLENBQUM7UUFDTixDQUFDO0lBQ0wsQ0FBQzsrR0F6QlEsaUJBQWlCOzZHQUFqQixpQkFBaUI7OzRGQUFqQixpQkFBaUI7a0JBRDdCLElBQUk7bUJBQUMsRUFBRSxJQUFJLEVBQUUsaUJBQWlCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgKiBhcyByeGpzIGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgVHJhbnNsYXRpb25zU2VydmljZSB9IGZyb20gJy4uL3RyYW5zbGF0aW9ucy90cmFuc2xhdGlvbnMuc2VydmljZSc7XG5pbXBvcnQgeyBkZWxheSwgc3RhcnRXaXRoLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBQaXBlKHsgbmFtZTogJ2VzTGlzdEl0ZW1MYWJlbCcgfSlcbmV4cG9ydCBjbGFzcyBMaXN0SXRlbUxhYmVsUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlLCBwcml2YXRlIHRyYW5zbGF0aW9uczogVHJhbnNsYXRpb25zU2VydmljZSkge31cblxuICAgIHRyYW5zZm9ybShpdGVtOiBMaXN0SXRlbSwgYXJncyA9IHsgZmFsbGJhY2s6IGl0ZW0ubmFtZSB9KTogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcbiAgICAgICAgY29uc3QgbWFwcGluZyA9IHtcbiAgICAgICAgICAgIE5PREU6ICdOT0RFJyxcbiAgICAgICAgICAgIENPTExFQ1RJT046ICdOT0RFJyxcbiAgICAgICAgICAgIE5PREVfUFJPUE9TQUw6ICdOT0RFX1BST1BPU0FMJyxcbiAgICAgICAgICAgIE9SRzogJ09SRycsXG4gICAgICAgICAgICBHUk9VUDogJ0dST1VQJyxcbiAgICAgICAgICAgIFVTRVI6ICdVU0VSJyxcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKGl0ZW0ubGFiZWwpIHtcbiAgICAgICAgICAgIHJldHVybiByeGpzLm9mKGl0ZW0ubGFiZWwpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25zLndhaXRGb3JJbml0KCkucGlwZShcbiAgICAgICAgICAgICAgICBzdGFydFdpdGgobnVsbCBhcyB2b2lkKSxcbiAgICAgICAgICAgICAgICBkZWxheSgxKSxcbiAgICAgICAgICAgICAgICBzd2l0Y2hNYXAoKCkgPT5cbiAgICAgICAgICAgICAgICAgICAgdGhpcy50cmFuc2xhdGUuZ2V0KG1hcHBpbmdbaXRlbS50eXBlXSArICcuJyArIGl0ZW0ubmFtZSwge1xuICAgICAgICAgICAgICAgICAgICAgICAgZmFsbGJhY2s6IGFyZ3MuZmFsbGJhY2ssXG4gICAgICAgICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -1,73 +0,0 @@
1
- import { notNull } from '../util/functions';
2
- export class NodeCache {
3
- constructor() {
4
- this._slices = [];
5
- }
6
- add(slice) {
7
- if (slice.endIndex - slice.startIndex !== slice.data.length) {
8
- throw new Error('Tried to add invalid slice to cache: ' + JSON.stringify(slice));
9
- }
10
- this._slices = this._normalizeSlices([...this._slices, slice]);
11
- }
12
- clear() {
13
- this._slices = [];
14
- }
15
- get(range) {
16
- for (const slice of this._slices) {
17
- if (slice.startIndex <= range.startIndex && slice.endIndex >= range.endIndex) {
18
- return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
19
- }
20
- }
21
- // for the first request
22
- console.warn('Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)', range, this._slices);
23
- for (const slice of this._slices) {
24
- if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {
25
- return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
26
- }
27
- }
28
- console.error('Could not find any slice for the range', range, this._slices);
29
- return null;
30
- }
31
- getMissingRange(requestedRange) {
32
- let fromIndex = requestedRange.startIndex;
33
- let toIndex = requestedRange.endIndex;
34
- for (const slice of this._slices) {
35
- if (slice.startIndex <= fromIndex && slice.endIndex > fromIndex) {
36
- fromIndex = slice.endIndex;
37
- }
38
- else if (slice.startIndex < toIndex && slice.endIndex >= toIndex) {
39
- toIndex = slice.startIndex;
40
- }
41
- if (fromIndex >= toIndex) {
42
- return null;
43
- }
44
- }
45
- return { startIndex: fromIndex, endIndex: toIndex };
46
- }
47
- _normalizeSlices(slices) {
48
- slices.sort((lhs, rhs) => lhs.startIndex - rhs.startIndex);
49
- for (let i = 0; i < slices.length - 1; i++) {
50
- for (let j = i + 1; j < slices.length; j++) {
51
- if (this._canMerge(slices[i], slices[j])) {
52
- slices[i] = this._merge(slices[i], slices[j]);
53
- slices[j] = null; // Mark for deletion
54
- }
55
- }
56
- }
57
- return slices.filter(notNull);
58
- }
59
- _canMerge(lhs, rhs) {
60
- if (!lhs || !rhs) {
61
- return false;
62
- }
63
- return lhs.endIndex >= rhs.startIndex;
64
- }
65
- _merge(lhs, rhs) {
66
- return {
67
- startIndex: lhs.startIndex,
68
- endIndex: rhs.endIndex,
69
- data: [...lhs.data, ...rhs.data.slice(lhs.endIndex - rhs.startIndex)],
70
- };
71
- }
72
- }
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-cache.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-cache.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAW5C,MAAM,OAAO,SAAS;IAAtB;QACY,YAAO,GAAiC,EAAE,CAAC;IAmFvD,CAAC;IAjFG,GAAG,CAAC,KAAwB;QACxB,IAAI,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,UAAU,KAAK,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YAC1D,MAAM,IAAI,KAAK,CAAC,uCAAuC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;QACrF,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;IACnE,CAAC;IAED,KAAK;QACD,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,GAAG,CAAC,KAAqB;QACrB,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;gBAC3E,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CACnB,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,EACnC,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,UAAU,CACpC,CAAC;YACN,CAAC;QACL,CAAC;QACD,wBAAwB;QACxB,OAAO,CAAC,IAAI,CACR,yHAAyH,EACzH,KAAK,EACL,IAAI,CAAC,OAAO,CACf,CAAC;QACF,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;gBAC7E,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CACnB,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,EACnC,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,UAAU,CACpC,CAAC;YACN,CAAC;QACL,CAAC;QACD,OAAO,CAAC,KAAK,CAAC,wCAAwC,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC7E,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,eAAe,CAAC,cAA8B;QAC1C,IAAI,SAAS,GAAG,cAAc,CAAC,UAAU,CAAC;QAC1C,IAAI,OAAO,GAAG,cAAc,CAAC,QAAQ,CAAC;QACtC,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,IAAI,KAAK,CAAC,UAAU,IAAI,SAAS,IAAI,KAAK,CAAC,QAAQ,GAAG,SAAS,EAAE,CAAC;gBAC9D,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC/B,CAAC;iBAAM,IAAI,KAAK,CAAC,UAAU,GAAG,OAAO,IAAI,KAAK,CAAC,QAAQ,IAAI,OAAO,EAAE,CAAC;gBACjE,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC;YAC/B,CAAC;YACD,IAAI,SAAS,IAAI,OAAO,EAAE,CAAC;gBACvB,OAAO,IAAI,CAAC;YAChB,CAAC;QACL,CAAC;QACD,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC;IACxD,CAAC;IAEO,gBAAgB,CAAC,MAA2B;QAChD,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC;QAC3D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YACzC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBACzC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBACvC,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC9C,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,oBAAoB;gBAC1C,CAAC;YACL,CAAC;QACL,CAAC;QACD,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAEO,SAAS,CAAC,GAAsB,EAAE,GAAsB;QAC5D,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACf,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,UAAU,CAAC;IAC1C,CAAC;IAEO,MAAM,CAAC,GAAsB,EAAE,GAAsB;QACzD,OAAO;YACH,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,IAAI,EAAE,CAAC,GAAG,GAAG,CAAC,IAAI,EAAE,GAAG,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC;SACxE,CAAC;IACN,CAAC;CACJ","sourcesContent":["import { notNull } from '../util/functions';\n\nexport interface NodeCacheRange {\n    startIndex: number;\n    endIndex: number;\n}\n\nexport interface NodeCacheSlice<T> extends NodeCacheRange {\n    data: readonly T[];\n}\n\nexport class NodeCache<T> {\n    private _slices: readonly NodeCacheSlice<T>[] = [];\n\n    add(slice: NodeCacheSlice<T>): void {\n        if (slice.endIndex - slice.startIndex !== slice.data.length) {\n            throw new Error('Tried to add invalid slice to cache: ' + JSON.stringify(slice));\n        }\n        this._slices = this._normalizeSlices([...this._slices, slice]);\n    }\n\n    clear() {\n        this._slices = [];\n    }\n\n    get(range: NodeCacheRange): T[] | null {\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.endIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        // for the first request\n        console.warn(\n            'Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)',\n            range,\n            this._slices,\n        );\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        console.error('Could not find any slice for the range', range, this._slices);\n        return null;\n    }\n\n    getMissingRange(requestedRange: NodeCacheRange): NodeCacheRange | null {\n        let fromIndex = requestedRange.startIndex;\n        let toIndex = requestedRange.endIndex;\n        for (const slice of this._slices) {\n            if (slice.startIndex <= fromIndex && slice.endIndex > fromIndex) {\n                fromIndex = slice.endIndex;\n            } else if (slice.startIndex < toIndex && slice.endIndex >= toIndex) {\n                toIndex = slice.startIndex;\n            }\n            if (fromIndex >= toIndex) {\n                return null;\n            }\n        }\n        return { startIndex: fromIndex, endIndex: toIndex };\n    }\n\n    private _normalizeSlices(slices: NodeCacheSlice<T>[]): NodeCacheSlice<T>[] {\n        slices.sort((lhs, rhs) => lhs.startIndex - rhs.startIndex);\n        for (let i = 0; i < slices.length - 1; i++) {\n            for (let j = i + 1; j < slices.length; j++) {\n                if (this._canMerge(slices[i], slices[j])) {\n                    slices[i] = this._merge(slices[i], slices[j]);\n                    slices[j] = null; // Mark for deletion\n                }\n            }\n        }\n        return slices.filter(notNull);\n    }\n\n    private _canMerge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): boolean {\n        if (!lhs || !rhs) {\n            return false;\n        }\n        return lhs.endIndex >= rhs.startIndex;\n    }\n\n    private _merge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): NodeCacheSlice<T> {\n        return {\n            startIndex: lhs.startIndex,\n            endIndex: rhs.endIndex,\n            data: [...lhs.data, ...rhs.data.slice(lhs.endIndex - rhs.startIndex)],\n        };\n    }\n}\n"]}
@@ -1,4 +0,0 @@
1
- import { NodeDataSource } from './node-data-source';
2
- export class NodeDataSourceRemote extends NodeDataSource {
3
- }
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1kYXRhLXNvdXJjZS1yZW1vdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL25vZGUtZW50cmllcy9ub2RlLWRhdGEtc291cmNlLXJlbW90ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFjcEQsTUFBTSxPQUFnQixvQkFHcEIsU0FBUSxjQUFpQjtDQWdCMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOb2RlRGF0YVNvdXJjZSB9IGZyb20gJy4vbm9kZS1kYXRhLXNvdXJjZSc7XG5pbXBvcnQgeyBHZW5lcmljQXV0aG9yaXR5LCBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBNYXRUYWJsZURhdGFTb3VyY2UgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90YWJsZSc7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBQYWdpbmF0aW9uU3RyYXRlZ3kgfSBmcm9tICcuL25vZGUtZW50cmllcy1nbG9iYWwuc2VydmljZSc7XG5pbXBvcnQgeyBTb3J0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5pbXBvcnQgeyBTb3J0UGFuZWwgfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgTWF0UGFnaW5hdG9yIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcGFnaW5hdG9yJztcblxuZXhwb3J0IGludGVyZmFjZSBQYWdpbmF0aW9uQ29uZmlnIHtcbiAgICBkZWZhdWx0UGFnZVNpemU6IG51bWJlcjtcbiAgICBzdHJhdGVneTogUGFnaW5hdGlvblN0cmF0ZWd5O1xufVxuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgTm9kZURhdGFTb3VyY2VSZW1vdGU8XG4gICAgVCBleHRlbmRzIE5vZGUgfCBHZW5lcmljQXV0aG9yaXR5ID0gTm9kZSxcbiAgICBQIGV4dGVuZHMgTWF0UGFnaW5hdG9yID0gTWF0UGFnaW5hdG9yLFxuPiBleHRlbmRzIE5vZGVEYXRhU291cmNlPFQ+IHtcbiAgICBhYnN0cmFjdCBnZXQgcGFnaW5hdG9yKCk6IFAgfCBudWxsO1xuICAgIGFic3RyYWN0IHNldCBwYWdpbmF0b3IodmFsdWU6IFAgfCBudWxsKTtcbiAgICBhYnN0cmFjdCBnZXQgc29ydFBhbmVsKCk6IFNvcnRQYW5lbDtcbiAgICBhYnN0cmFjdCBzZXQgc29ydFBhbmVsKHZhbHVlOiBTb3J0UGFuZWwpO1xuICAgIGFic3RyYWN0IGxvYWRNb3JlKCk6IGJvb2xlYW47XG5cbiAgICBhYnN0cmFjdCByZWdpc3RlclF1ZXJ5UGFyYW1ldGVycyhyb3V0ZTogQWN0aXZhdGVkUm91dGUpOiB2b2lkO1xuXG4gICAgYWJzdHJhY3QgaW5pdCh7XG4gICAgICAgIHBhZ2luYXRpb25Db25maWcsXG4gICAgICAgIGRlZmF1bHRTb3J0LFxuICAgIH06IHtcbiAgICAgICAgcGFnaW5hdGlvbkNvbmZpZzogUGFnaW5hdGlvbkNvbmZpZztcbiAgICAgICAgZGVmYXVsdFNvcnQ6IFNvcnQ7XG4gICAgfSk6IHZvaWQ7XG59XG4iXX0=
@@ -1,117 +0,0 @@
1
- import { DataSource } from '@angular/cdk/collections';
2
- import { BehaviorSubject } from 'rxjs';
3
- import { Helper } from '../util/helper';
4
- export class NodeDataSource extends DataSource {
5
- get isLoading() {
6
- return this.isLoadingSubject.value;
7
- }
8
- set isLoading(isLoading) {
9
- this.isLoadingSubject.next(isLoading);
10
- }
11
- get itemsCap() {
12
- return this._itemsCap;
13
- }
14
- set itemsCap(value) {
15
- this._itemsCap = value;
16
- this.connectRenderData();
17
- }
18
- constructor(initialData = []) {
19
- super();
20
- this.dataStream = new BehaviorSubject([]);
21
- this.pagination$ = new BehaviorSubject(null);
22
- // Include `LoadingState` to be type-compatible to `NodeDataSourceRemote` although not used
23
- // here.
24
- this.isLoadingSubject = new BehaviorSubject(false);
25
- this.initialPageLoaded = false;
26
- this.renderData = new BehaviorSubject([]);
27
- this.setData(initialData);
28
- }
29
- connect() {
30
- if (!this.renderDataSubscription) {
31
- this.connectRenderData();
32
- }
33
- return this.renderData;
34
- }
35
- connectRenderData() {
36
- this.renderDataSubscription?.unsubscribe();
37
- if (this.itemsCap) {
38
- this.renderDataSubscription = this.itemsCap
39
- .connect(this.dataStream)
40
- .subscribe((data) => this.renderData.next(data));
41
- }
42
- else {
43
- this.renderDataSubscription = this.dataStream.subscribe((data) => this.renderData.next(data));
44
- }
45
- }
46
- connectPagination() {
47
- return this.pagination$;
48
- }
49
- disconnect() { }
50
- setData(data, pagination = null) {
51
- this.dataStream.next(data);
52
- this.setPagination(pagination);
53
- }
54
- appendData(appendData, location = 'after') {
55
- let data = this.getData();
56
- if (location === 'after') {
57
- data = data.concat(appendData);
58
- }
59
- else {
60
- data = appendData.concat(data);
61
- }
62
- this.dataStream.next(data);
63
- }
64
- /**
65
- * Removes elements from the visible data.
66
- */
67
- removeData(toRemove) {
68
- const newData = this.getData().filter((value) => !toRemove.some((d) => Helper.objectEquals(d.ref, value.ref)));
69
- const removedData = this.getData().filter((value) => !newData.includes(value));
70
- this.dataStream.next(newData);
71
- if (this.pagination$.value) {
72
- const pagination = this.pagination$.value;
73
- this.setPagination({
74
- count: pagination.count - removedData.length,
75
- from: pagination.from,
76
- total: pagination.total - removedData.length,
77
- });
78
- }
79
- }
80
- setPagination(pagination) {
81
- this.pagination$.next(pagination);
82
- }
83
- reset() {
84
- this.setData([]);
85
- }
86
- hasMore() {
87
- if (!this.pagination$.value) {
88
- return undefined;
89
- }
90
- return this.pagination$.value.total > this.dataStream.value?.length;
91
- }
92
- // FIXME: This is somewhat dangerous because we rely on `connect` being called from outside, but
93
- // this method provides a way to access data without ever calling `connect`.
94
- getData() {
95
- return this.renderData.value;
96
- }
97
- isEmpty() {
98
- return this.dataStream.value?.length === 0;
99
- }
100
- getTotal() {
101
- return this.pagination$.value?.total
102
- ? Math.max(this.pagination$.value?.total, this.getData()?.length || 0)
103
- : this.dataStream.value?.length ?? 0;
104
- }
105
- isFullyLoaded() {
106
- return this.getTotal() <= this.dataStream.value?.length;
107
- }
108
- /**
109
- * force a refresh of all elements in the current data stream
110
- * trigger this to enforce a rebuild of the nodes in all sub-components
111
- * i.e. if data from some nodes has changed
112
- */
113
- refresh() {
114
- this.dataStream.next(Helper.deepCopy(this.dataStream.value));
115
- }
116
- }
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-data-source.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-data-source.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,eAAe,EAA4B,MAAM,MAAM,CAAC;AAGjE,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAYxC,MAAM,OAAO,cAAkD,SAAQ,UAAa;IAMhF,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC;IACvC,CAAC;IACD,IAAI,SAAS,CAAC,SAAiC;QAC3C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAGD,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAyB;QAClC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAID,YAAY,cAAmB,EAAE;QAC7B,KAAK,EAAE,CAAC;QAxBF,eAAU,GAAG,IAAI,eAAe,CAAM,EAAE,CAAC,CAAC;QAC5C,gBAAW,GAAG,IAAI,eAAe,CAAa,IAAI,CAAC,CAAC;QAC5D,2FAA2F;QAC3F,QAAQ;QACD,qBAAgB,GAAG,IAAI,eAAe,CAAyB,KAAK,CAAC,CAAC;QAO7E,sBAAiB,GAAG,KAAK,CAAC;QAShB,eAAU,GAAG,IAAI,eAAe,CAAM,EAAE,CAAC,CAAC;QAKhD,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAC9B,CAAC;IAED,OAAO;QACH,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7B,CAAC;QACD,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,sBAAsB,EAAE,WAAW,EAAE,CAAC;QAC3C,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,QAAQ;iBACtC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC;iBACxB,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAC7D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAC7B,CAAC;QACN,CAAC;IACL,CAAC;IAED,iBAAiB;QACb,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED,UAAU,KAAI,CAAC;IAEf,OAAO,CAAC,IAAS,EAAE,aAAyB,IAAI;QAC5C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;IACnC,CAAC;IAED,UAAU,CAAC,UAAe,EAAE,WAA+B,OAAO;QAC9D,IAAI,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC1B,IAAI,QAAQ,KAAK,OAAO,EAAE,CAAC;YACvB,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACJ,IAAI,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,UAAU,CAAC,QAAa;QACpB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CACjC,CAAC,KAAK,EAAE,EAAE,CACN,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,YAAY,CAAE,CAAU,CAAC,GAAG,EAAG,KAAc,CAAC,GAAG,CAAC,CAAC,CACvF,CAAC;QACF,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9B,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YACzB,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC;gBACf,KAAK,EAAE,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;gBAC5C,IAAI,EAAE,UAAU,CAAC,IAAI;gBACrB,KAAK,EAAE,UAAU,CAAC,KAAK,GAAG,WAAW,CAAC,MAAM;aAC/C,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAED,aAAa,CAAC,UAAsB;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACtC,CAAC;IAED,KAAK;QACD,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACrB,CAAC;IAED,OAAO;QACH,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;YAC1B,OAAO,SAAS,CAAC;QACrB,CAAC;QACD,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC;IACxE,CAAC;IAED,gGAAgG;IAChG,4EAA4E;IAC5E,OAAO;QACH,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;IACjC,CAAC;IAED,OAAO;QACH,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,KAAK,CAAC,CAAC;IAC/C,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK;YAChC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,IAAI,CAAC,CAAC;YACtE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED,aAAa;QACT,OAAO,IAAI,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACH,OAAO;QACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;IACjE,CAAC;CACJ","sourcesContent":["import { DataSource } from '@angular/cdk/collections';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\nimport { ItemsCap } from './items-cap';\nimport { GenericAuthority, Node, Pagination } from 'ngx-edu-sharing-api';\nimport { Helper } from '../util/helper';\n\nexport type LoadingState =\n    // The data source is loading data for the first time.\n    | 'initial'\n    // Loading data after change of parameters, i.e., it will replace the current data when done.\n    | 'reset'\n    // Loading another page with unchanged parameters.\n    | 'page'\n    // Loading done.\n    | false;\n\nexport class NodeDataSource<T extends Node | GenericAuthority> extends DataSource<T> {\n    protected dataStream = new BehaviorSubject<T[]>([]);\n    private pagination$ = new BehaviorSubject<Pagination>(null);\n    // Include `LoadingState` to be type-compatible to `NodeDataSourceRemote` although not used\n    // here.\n    public isLoadingSubject = new BehaviorSubject<LoadingState | boolean>(false);\n    get isLoading() {\n        return this.isLoadingSubject.value;\n    }\n    set isLoading(isLoading: LoadingState | boolean) {\n        this.isLoadingSubject.next(isLoading);\n    }\n    initialPageLoaded = false;\n    protected _itemsCap: ItemsCap<T> | null;\n    get itemsCap(): ItemsCap<T> | null {\n        return this._itemsCap;\n    }\n    set itemsCap(value: ItemsCap<T> | null) {\n        this._itemsCap = value;\n        this.connectRenderData();\n    }\n    protected renderData = new BehaviorSubject<T[]>([]);\n    protected renderDataSubscription: Subscription | null;\n\n    constructor(initialData: T[] = []) {\n        super();\n        this.setData(initialData);\n    }\n\n    connect(): Observable<T[]> {\n        if (!this.renderDataSubscription) {\n            this.connectRenderData();\n        }\n        return this.renderData;\n    }\n\n    private connectRenderData(): void {\n        this.renderDataSubscription?.unsubscribe();\n        if (this.itemsCap) {\n            this.renderDataSubscription = this.itemsCap\n                .connect(this.dataStream)\n                .subscribe((data) => this.renderData.next(data));\n        } else {\n            this.renderDataSubscription = this.dataStream.subscribe((data) =>\n                this.renderData.next(data),\n            );\n        }\n    }\n\n    connectPagination(): Observable<Pagination> {\n        return this.pagination$;\n    }\n\n    disconnect() {}\n\n    setData(data: T[], pagination: Pagination = null) {\n        this.dataStream.next(data);\n        this.setPagination(pagination);\n    }\n\n    appendData(appendData: T[], location: 'before' | 'after' = 'after') {\n        let data = this.getData();\n        if (location === 'after') {\n            data = data.concat(appendData);\n        } else {\n            data = appendData.concat(data);\n        }\n        this.dataStream.next(data);\n    }\n\n    /**\n     * Removes elements from the visible data.\n     */\n    removeData(toRemove: T[]): void {\n        const newData = this.getData().filter(\n            (value) =>\n                !toRemove.some((d) => Helper.objectEquals((d as Node).ref, (value as Node).ref)),\n        );\n        const removedData = this.getData().filter((value) => !newData.includes(value));\n        this.dataStream.next(newData);\n        if (this.pagination$.value) {\n            const pagination = this.pagination$.value;\n            this.setPagination({\n                count: pagination.count - removedData.length,\n                from: pagination.from,\n                total: pagination.total - removedData.length,\n            });\n        }\n    }\n\n    setPagination(pagination: Pagination) {\n        this.pagination$.next(pagination);\n    }\n\n    reset() {\n        this.setData([]);\n    }\n\n    hasMore() {\n        if (!this.pagination$.value) {\n            return undefined;\n        }\n        return this.pagination$.value.total > this.dataStream.value?.length;\n    }\n\n    // FIXME: This is somewhat dangerous because we rely on `connect` being called from outside, but\n    // this method provides a way to access data without ever calling `connect`.\n    getData() {\n        return this.renderData.value;\n    }\n\n    isEmpty(): boolean {\n        return this.dataStream.value?.length === 0;\n    }\n\n    getTotal() {\n        return this.pagination$.value?.total\n            ? Math.max(this.pagination$.value?.total, this.getData()?.length || 0)\n            : this.dataStream.value?.length ?? 0;\n    }\n\n    isFullyLoaded() {\n        return this.getTotal() <= this.dataStream.value?.length;\n    }\n\n    /**\n     * force a refresh of all elements in the current data stream\n     * trigger this to enforce a rebuild of the nodes in all sub-components\n     * i.e. if data from some nodes has changed\n     */\n    refresh() {\n        this.dataStream.next(Helper.deepCopy(this.dataStream.value));\n    }\n}\n"]}
@@ -1,117 +0,0 @@
1
- import { Component, Input, Optional, ViewChild, } from '@angular/core';
2
- import { ClickSource, InteractionType } from '../entries-model';
3
- import { CustomFieldSpecialType } from '../node-entries-global.service';
4
- import { Target } from '../../types/option-item';
5
- import { RestConstants } from 'ngx-edu-sharing-api';
6
- import { ColorHelper, PreferredColor } from '../../util/color-helper';
7
- import { take } from 'rxjs/operators';
8
- import { BehaviorSubject } from 'rxjs';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../../services/node-entries.service";
11
- import * as i2 from "../../services/node-helper.service";
12
- import * as i3 from "ngx-edu-sharing-api";
13
- import * as i4 from "../node-entries-templates.service";
14
- import * as i5 from "../node-entries-global.service";
15
- import * as i6 from "../../services/abstract/toast.service";
16
- import * as i7 from "@angular/common";
17
- import * as i8 from "../../directives/focus-state.directive";
18
- import * as i9 from "../../directives/icon.directive";
19
- import * as i10 from "../../node-url/node-url.component";
20
- import * as i11 from "../../list-items/list-base/list-base.component";
21
- import * as i12 from "@angular/material/checkbox";
22
- import * as i13 from "@angular/material/button";
23
- import * as i14 from "@angular/material/menu";
24
- import * as i15 from "@angular/material/core";
25
- import * as i16 from "../node-rating/node-rating.component";
26
- import * as i17 from "../preview-image/preview-image.component";
27
- import * as i18 from "../node-type-badge/node-type-badge.component";
28
- import * as i19 from "../option-button/option-button.component";
29
- import * as i20 from "../node-stats-badges/node-stats-badges.component";
30
- import * as i21 from "../../pipes/property-slug.pipe";
31
- import * as i22 from "../../pipes/node-title.pipe";
32
- import * as i23 from "@ngx-translate/core";
33
- import * as i24 from "../list-item-label.pipe";
34
- export class NodeEntriesCardComponent {
35
- constructor(entriesService, nodeHelper, applicationRef, configService, authenticationService, templatesService, nodeEntriesGlobalService, toast) {
36
- this.entriesService = entriesService;
37
- this.nodeHelper = nodeHelper;
38
- this.applicationRef = applicationRef;
39
- this.configService = configService;
40
- this.authenticationService = authenticationService;
41
- this.templatesService = templatesService;
42
- this.nodeEntriesGlobalService = nodeEntriesGlobalService;
43
- this.toast = toast;
44
- this.InteractionType = InteractionType;
45
- this.Target = Target;
46
- this.ClickSource = ClickSource;
47
- this.CustomFieldSpecialType = CustomFieldSpecialType;
48
- this.showRatings = new BehaviorSubject(false);
49
- }
50
- ngOnChanges(changes) {
51
- this.isCollection = this.nodeHelper.isNodeCollection(changes.node?.currentValue);
52
- }
53
- getTextColor() {
54
- return ColorHelper.getPreferredColor(this.node.collection.color) === PreferredColor.Black
55
- ? '#000'
56
- : '#fff';
57
- }
58
- optionsOnCard() {
59
- const options = this.entriesService.options?.[Target.List];
60
- const always = options?.filter((o) => o.showAlways);
61
- if (always?.some((o) => o.showCallback([this.node]))) {
62
- return always;
63
- }
64
- // we do NOT show any additional actions
65
- return [];
66
- // return options.filter((o) => o.showAsAction && o.showCallback(this.node)).slice(0, 3);
67
- }
68
- openContextmenu(event, node) {
69
- event.stopPropagation();
70
- event.preventDefault();
71
- if (!this.dropdown) {
72
- // Call `preventDefault()` even when there is no menu, so we can use `cdkDrag` with a
73
- // start delay without being interrupted by the standard long-tap action.
74
- return;
75
- }
76
- if (event instanceof MouseEvent) {
77
- ({ clientX: this.dropdownLeft, clientY: this.dropdownTop } = event);
78
- }
79
- else {
80
- ({ x: this.dropdownLeft, y: this.dropdownTop } = event.target.getBoundingClientRect());
81
- }
82
- this.entriesService.openDropdown(this.dropdown, node, () => this.menuTrigger.openMenu());
83
- }
84
- getVisibleColumns() {
85
- return this.entriesService.columns?.filter((c) => c.visible);
86
- }
87
- async openMenu(node) {
88
- this.entriesService.openDropdown(this.dropdown, node);
89
- }
90
- async ngOnInit() {
91
- await this.configService.observeConfig().pipe(take(1)).toPromise();
92
- this.showRatings.next(this.configService.instant('rating.mode', 'none') !== 'none' &&
93
- (await this.authenticationService.hasToolpermission(RestConstants.TOOLPERMISSION_RATE_READ)));
94
- }
95
- getTemplate(name) {
96
- return this.nodeEntriesGlobalService.getCustomFieldTemplate({
97
- type: 'NODE',
98
- name,
99
- }, this.node);
100
- }
101
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardComponent, deps: [{ token: i1.NodeEntriesService }, { token: i2.NodeHelperService }, { token: i0.ApplicationRef }, { token: i3.ConfigService }, { token: i3.AuthenticationService }, { token: i4.NodeEntriesTemplatesService }, { token: i5.NodeEntriesGlobalService }, { token: i6.Toast, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeEntriesCardComponent, selector: "es-node-entries-card", inputs: { dropdown: "dropdown", node: "node" }, viewQueries: [{ propertyName: "menuTrigger", first: true, predicate: ["menuTrigger"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n [class]=\"\n 'grid-card' +\n (isCollection\n ? ' grid-card-collection grid-card-collection-scope-' +\n node.collection.scope +\n ' grid-card-collection-type-' +\n node.collection.type\n : '') +\n ($any(node).virtual ? ' grid-card-virtual' : '') +\n ' ' +\n nodeEntriesGlobalService.getCustomCssClass(node)\n \"\n [style.background-color]=\"isCollection ? node.collection.color : null\"\n [class.dynamic-single-click]=\"entriesService.singleClickHint === 'dynamic'\"\n [class.selected]=\"entriesService.selection.isSelected(node)\"\n (contextmenu)=\"openContextmenu($event, node)\"\n (keydown.ContextMenu)=\"openContextmenu($event, node)\"\n>\n <div\n *ngIf=\"templatesService.overlay\"\n class=\"card-overlay\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Overlay,\n })\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n ></ng-container>\n </div>\n <button\n *ngIf=\"dropdown\"\n #menuTrigger=\"matMenuTrigger\"\n mat-button\n class=\"dropdown-dummy cdk-visually-hidden\"\n [style.left.px]=\"dropdownLeft\"\n [style.top.px]=\"dropdownTop\"\n [matMenuTriggerFor]=\"dropdown.menu\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n <div class=\"card-top-bar\" [style.background-color]=\"isCollection ? node.collection.color : null\">\n <div class=\"card-top-bar-collection-color\" *ngIf=\"nodeHelper.isNodeCollection(node)\"></div>\n <es-node-type-badge [node]=\"node\"></es-node-type-badge>\n <div *ngIf=\"isCollection && node.collection.pinned\" class=\"card-top-bar-flag\">\n <i esIcon=\"edu-pin\"></i>\n </div>\n <div class=\"card-top-bar-empty\"></div>\n <es-node-stats-badges [node]=\"node\"></es-node-stats-badges>\n <div class=\"card-top-bar-checkbox\" *ngIf=\"entriesService.checkbox\">\n <mat-checkbox\n [checked]=\"entriesService.selection.isSelected(node)\"\n (change)=\"entriesService.onCheckboxChanged(node, $event.checked)\"\n color=\"primary\"\n aria-label=\"{{ 'SELECT' | translate : { element: (node | nodeTitle) } }}\"\n ></mat-checkbox>\n </div>\n </div>\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n mode=\"wrapper\"\n [node]=\"node\"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </es-node-url>\n <div\n *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\"\n matRipple\n (click)=\"\n entriesService.onClicked({\n event: $event,\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n (dblclick)=\"\n entriesService.dblClickItem.emit({\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </div>\n <div class=\"card-options\" *ngIf=\"entriesService.options || showRatings\">\n <div class=\"card-rating-area\">\n <es-node-rating [node]=\"node\"></es-node-rating>\n </div>\n <div class=\"card-options-area\">\n <es-option-button\n *ngFor=\"let option of optionsOnCard()\"\n class=\"card-options-always\"\n [option]=\"option\"\n [node]=\"node\"\n ></es-option-button>\n <div class=\"card-options-spacer\"></div>\n <button\n *ngIf=\"dropdown\"\n mat-icon-button\n color=\"primary\"\n (click)=\"openMenu(node)\"\n [matMenuTriggerFor]=\"dropdown.menu\"\n [attr.aria-label]=\"'OPTIONS_FOR' | translate : { element: (node | nodeTitle) }\"\n data-test=\"card-options-button\"\n >\n <i esIcon=\"more_vert\"></i>\n </button>\n </div>\n </div>\n <ng-template #image let-playAnimation=\"playAnimation\">\n <div\n class=\"card-image-area\"\n [style.background-color]=\"isCollection ? node.collection.color : null\"\n >\n <ng-container *ngIf=\"getTemplate(CustomFieldSpecialType.preview) as ref\">\n <ng-container *ngTemplateOutlet=\"ref; context: { node: this.node }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!getTemplate(CustomFieldSpecialType.preview)\">\n <es-preview-image\n *ngIf=\"!(isCollection && node.preview.isIcon)\"\n [node]=\"node\"\n [playAnimation]=\"playAnimation\"\n ></es-preview-image>\n <div *ngIf=\"isCollection && node.preview.isIcon\" class=\"card-collection-image\">\n <i esIcon=\"layers\"></i>\n </div>\n </ng-container>\n </div>\n </ng-template>\n <ng-template #meta let-link=\"link\">\n <div class=\"card-meta\">\n <div\n *ngFor=\"let displayPart of getVisibleColumns(); let first = first\"\n class=\"card-meta-row card-meta-row-{{ displayPart.name | lowercase | propertySlug }}\"\n [class.card-meta-row-primary]=\"first\"\n >\n <ng-container *ngIf=\"first\">\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n [node]=\"node\"\n #link\n >\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </es-node-url>\n <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!first\">\n <label>\n {{ displayPart | esListItemLabel | async }}\n </label>\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </ng-container>\n </div>\n </div>\n </ng-template>\n</div>\n", styles: [".grid-card{transition:all var(--transitionNormal);overflow:hidden;background-color:#fff;box-shadow:0 3px 3px #0000001a;display:grid;height:100%;grid-template-columns:auto}:host-context(body.es-contrast-mode) .grid-card{border:1px solid rgba(0,0,0,.42)}.grid-card.selected{background-color:rgb(var(--palette-primary-50))}.grid-card .dropdown-dummy{position:fixed}.grid-card .card-options{display:grid;grid-template-columns:1fr auto;grid-column-gap:10px}.grid-card .card-options .card-rating-area{display:flex;align-items:center;height:100%;padding-left:10px}.grid-card .card-options .card-options-area{display:flex}.grid-card .card-options .card-options-area es-option-button,.grid-card .card-options .card-options-area button{transition:all var(--transitionNormal);margin:0 2px;border-radius:50%}.grid-card .card-options .card-options-area es-option-button:hover,.grid-card .card-options .card-options-area es-option-button:focus,.grid-card .card-options .card-options-area button:hover,.grid-card .card-options .card-options-area button:focus{background-color:#fff}.grid-card:not(.grid-card-collection) .card-top-bar{background-color:var(--palette-primary-200)}.grid-card.grid-card-virtual{outline:2px dashed var(--nodeVirtualColor)}.grid-card .card-top-bar{height:40px;display:flex;gap:15px;align-items:center;padding:0 20px;position:relative}.grid-card .card-top-bar .card-top-bar-collection-color{position:absolute;background-color:#ffffff80;inset:0}.grid-card .card-top-bar .card-top-bar-flag{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}.grid-card .card-top-bar .card-top-bar-flag i{font-size:18px;color:#333}.grid-card .card-top-bar .card-top-bar-flag img{width:18px;height:18px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox{margin-right:-5px;position:relative;top:-1.3px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator{outline:none}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator:after{content:\"\";position:absolute;inset:2px;outline:none;border:2px solid var(--palette-primary-300);border-color:#fff}.grid-card .card-top-bar .card-top-bar-empty{width:0;flex-grow:1}.grid-card .card-image-area{height:150px;padding:0;display:flex}.grid-card .card-image-area es-preview-image{flex-grow:1}.grid-card .card-image-area .card-collection-image{display:flex;width:100%;height:100%;align-items:center;justify-content:center}.grid-card .card-image-area .card-collection-image i{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;color:#000000bf;background-color:#ffffff80;padding:40px;font-size:40px;border-radius:50%}.grid-card .card-meta{padding:10px 20px 0;display:grid;flex-direction:row}.grid-card .card-meta .card-meta-row{display:flex;flex-direction:row;align-items:center;min-height:2.8em;gap:5px}.grid-card .card-meta .card-meta-row:not(:first-child)>label{cursor:inherit;color:var(--textLight);font-size:85%}.grid-card .card-meta .card-meta-row:not(:first-child)>es-list-base{color:#000;flex-grow:1;margin:5px 0;display:flex;justify-content:flex-end;text-align:end;word-break:break-word}.grid-card .card-meta .card-meta-row:first-child{font-size:120%}.grid-card .card-meta .card-meta-row:first-child>es-list-base,.grid-card .card-meta .card-meta-row:first-child>es-node-url{width:100%;font-size:120%;color:var(--textMain);height:2.8em;text-align:left;word-break:break-word}.grid-card.dynamic-single-click:hover{box-shadow:0 0 25px #0003;background-color:rgb(var(--palette-primary-50))}.grid-card.dynamic-single-click.grid-card-collection:hover .card-meta{background-color:#ffffffe6}.grid-card.grid-card-collection .card-meta{background-color:#fffc}.grid-card.grid-card-collection .card-options{background-color:#ffffffe6}.grid-card .card-options{border-top:1px solid #ddd}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text{word-break:break-word}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text span,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text span{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row es-node-url a{color:var(--textMain)}:host ::ng-deep .grid-card .card-meta-row es-node-url a.cdk-keyboard-focused{display:inline-flex;outline:none;outline:2px solid var(--palette-primary-300);outline-offset:2px}:host ::ng-deep .card-meta es-list-base img{max-width:100px;max-height:20px}:host ::ng-deep .card-meta es-list-base es-list-node-license img{height:20px}:host ::ng-deep .card-meta es-list-base es-list-collection-info{display:flex;align-items:center}:host ::ng-deep .card-meta es-list-base es-list-collection-info i{font-size:12pt;margin:0 6px}:host ::ng-deep .grid-card-collection es-node-url a.cdk-keyboard-focused .card-meta{background-color:#fff}.card-overlay{position:absolute;z-index:2;inset:0;pointer-events:none}.card-overlay ::ng-deep>*{pointer-events:auto}.grid-card{grid-template-rows:40px auto auto}.grid-card .card-meta .card-meta-row>es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card es-node-url .node-url-wrapper{height:100%}\n"], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i8.FocusStateDirective, selector: "[esFocusState]", exportAs: ["esFocusState"] }, { kind: "directive", type: i9.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i10.NodeUrlComponent, selector: "es-node-url", inputs: ["node", "nodes", "target", "scope", "queryParams", "mode", "disabled", "alwaysRipple", "aria-describedby", "aria-label"], outputs: ["buttonClick"] }, { kind: "component", type: i11.ListBaseComponent, selector: "es-list-base", inputs: ["forceText"] }, { kind: "component", type: i12.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { 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.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i15.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "component", type: i16.NodeRatingComponent, selector: "es-node-rating", inputs: ["node"] }, { kind: "component", type: i17.PreviewImageComponent, selector: "es-preview-image", inputs: ["node", "playAnimation"] }, { kind: "component", type: i18.NodeTypeBadgeComponent, selector: "es-node-type-badge", inputs: ["node"] }, { kind: "component", type: i19.OptionButtonComponent, selector: "es-option-button", inputs: ["option", "node"] }, { kind: "component", type: i20.NodeStatsBadgesComponent, selector: "es-node-stats-badges", inputs: ["node", "backgroundStyle"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i21.PropertySlugPipe, name: "propertySlug" }, { kind: "pipe", type: i22.NodeTitlePipe, name: "nodeTitle" }, { kind: "pipe", type: i23.TranslatePipe, name: "translate" }, { kind: "pipe", type: i24.ListItemLabelPipe, name: "esListItemLabel" }] }); }
103
- }
104
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeEntriesCardComponent, decorators: [{
105
- type: Component,
106
- args: [{ selector: 'es-node-entries-card', template: "<div\n [class]=\"\n 'grid-card' +\n (isCollection\n ? ' grid-card-collection grid-card-collection-scope-' +\n node.collection.scope +\n ' grid-card-collection-type-' +\n node.collection.type\n : '') +\n ($any(node).virtual ? ' grid-card-virtual' : '') +\n ' ' +\n nodeEntriesGlobalService.getCustomCssClass(node)\n \"\n [style.background-color]=\"isCollection ? node.collection.color : null\"\n [class.dynamic-single-click]=\"entriesService.singleClickHint === 'dynamic'\"\n [class.selected]=\"entriesService.selection.isSelected(node)\"\n (contextmenu)=\"openContextmenu($event, node)\"\n (keydown.ContextMenu)=\"openContextmenu($event, node)\"\n>\n <div\n *ngIf=\"templatesService.overlay\"\n class=\"card-overlay\"\n (click)=\"\n entriesService.clickItem.emit({\n element: node,\n source: ClickSource.Overlay,\n })\n \"\n >\n <ng-container\n *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n ></ng-container>\n </div>\n <button\n *ngIf=\"dropdown\"\n #menuTrigger=\"matMenuTrigger\"\n mat-button\n class=\"dropdown-dummy cdk-visually-hidden\"\n [style.left.px]=\"dropdownLeft\"\n [style.top.px]=\"dropdownTop\"\n [matMenuTriggerFor]=\"dropdown.menu\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n ></button>\n <div class=\"card-top-bar\" [style.background-color]=\"isCollection ? node.collection.color : null\">\n <div class=\"card-top-bar-collection-color\" *ngIf=\"nodeHelper.isNodeCollection(node)\"></div>\n <es-node-type-badge [node]=\"node\"></es-node-type-badge>\n <div *ngIf=\"isCollection && node.collection.pinned\" class=\"card-top-bar-flag\">\n <i esIcon=\"edu-pin\"></i>\n </div>\n <div class=\"card-top-bar-empty\"></div>\n <es-node-stats-badges [node]=\"node\"></es-node-stats-badges>\n <div class=\"card-top-bar-checkbox\" *ngIf=\"entriesService.checkbox\">\n <mat-checkbox\n [checked]=\"entriesService.selection.isSelected(node)\"\n (change)=\"entriesService.onCheckboxChanged(node, $event.checked)\"\n color=\"primary\"\n aria-label=\"{{ 'SELECT' | translate : { element: (node | nodeTitle) } }}\"\n ></mat-checkbox>\n </div>\n </div>\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n mode=\"wrapper\"\n [node]=\"node\"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </es-node-url>\n <div\n *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\"\n matRipple\n (click)=\"\n entriesService.onClicked({\n event: $event,\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n (dblclick)=\"\n entriesService.dblClickItem.emit({\n element: node,\n source: ClickSource.Metadata,\n })\n \"\n esFocusState\n #cardFocusState=\"esFocusState\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n image;\n context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n \"\n ></ng-container>\n <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n </div>\n <div class=\"card-options\" *ngIf=\"entriesService.options || showRatings\">\n <div class=\"card-rating-area\">\n <es-node-rating [node]=\"node\"></es-node-rating>\n </div>\n <div class=\"card-options-area\">\n <es-option-button\n *ngFor=\"let option of optionsOnCard()\"\n class=\"card-options-always\"\n [option]=\"option\"\n [node]=\"node\"\n ></es-option-button>\n <div class=\"card-options-spacer\"></div>\n <button\n *ngIf=\"dropdown\"\n mat-icon-button\n color=\"primary\"\n (click)=\"openMenu(node)\"\n [matMenuTriggerFor]=\"dropdown.menu\"\n [attr.aria-label]=\"'OPTIONS_FOR' | translate : { element: (node | nodeTitle) }\"\n data-test=\"card-options-button\"\n >\n <i esIcon=\"more_vert\"></i>\n </button>\n </div>\n </div>\n <ng-template #image let-playAnimation=\"playAnimation\">\n <div\n class=\"card-image-area\"\n [style.background-color]=\"isCollection ? node.collection.color : null\"\n >\n <ng-container *ngIf=\"getTemplate(CustomFieldSpecialType.preview) as ref\">\n <ng-container *ngTemplateOutlet=\"ref; context: { node: this.node }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!getTemplate(CustomFieldSpecialType.preview)\">\n <es-preview-image\n *ngIf=\"!(isCollection && node.preview.isIcon)\"\n [node]=\"node\"\n [playAnimation]=\"playAnimation\"\n ></es-preview-image>\n <div *ngIf=\"isCollection && node.preview.isIcon\" class=\"card-collection-image\">\n <i esIcon=\"layers\"></i>\n </div>\n </ng-container>\n </div>\n </ng-template>\n <ng-template #meta let-link=\"link\">\n <div class=\"card-meta\">\n <div\n *ngFor=\"let displayPart of getVisibleColumns(); let first = first\"\n class=\"card-meta-row card-meta-row-{{ displayPart.name | lowercase | propertySlug }}\"\n [class.card-meta-row-primary]=\"first\"\n >\n <ng-container *ngIf=\"first\">\n <es-node-url\n *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n [node]=\"node\"\n #link\n >\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </es-node-url>\n <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!first\">\n <label>\n {{ displayPart | esListItemLabel | async }}\n </label>\n <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n </ng-container>\n </div>\n </div>\n </ng-template>\n</div>\n", styles: [".grid-card{transition:all var(--transitionNormal);overflow:hidden;background-color:#fff;box-shadow:0 3px 3px #0000001a;display:grid;height:100%;grid-template-columns:auto}:host-context(body.es-contrast-mode) .grid-card{border:1px solid rgba(0,0,0,.42)}.grid-card.selected{background-color:rgb(var(--palette-primary-50))}.grid-card .dropdown-dummy{position:fixed}.grid-card .card-options{display:grid;grid-template-columns:1fr auto;grid-column-gap:10px}.grid-card .card-options .card-rating-area{display:flex;align-items:center;height:100%;padding-left:10px}.grid-card .card-options .card-options-area{display:flex}.grid-card .card-options .card-options-area es-option-button,.grid-card .card-options .card-options-area button{transition:all var(--transitionNormal);margin:0 2px;border-radius:50%}.grid-card .card-options .card-options-area es-option-button:hover,.grid-card .card-options .card-options-area es-option-button:focus,.grid-card .card-options .card-options-area button:hover,.grid-card .card-options .card-options-area button:focus{background-color:#fff}.grid-card:not(.grid-card-collection) .card-top-bar{background-color:var(--palette-primary-200)}.grid-card.grid-card-virtual{outline:2px dashed var(--nodeVirtualColor)}.grid-card .card-top-bar{height:40px;display:flex;gap:15px;align-items:center;padding:0 20px;position:relative}.grid-card .card-top-bar .card-top-bar-collection-color{position:absolute;background-color:#ffffff80;inset:0}.grid-card .card-top-bar .card-top-bar-flag{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}.grid-card .card-top-bar .card-top-bar-flag i{font-size:18px;color:#333}.grid-card .card-top-bar .card-top-bar-flag img{width:18px;height:18px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox{margin-right:-5px;position:relative;top:-1.3px}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator{outline:none}.grid-card .card-top-bar .card-top-bar-checkbox mat-checkbox.cdk-keyboard-focused ::ng-deep .mat-focus-indicator:after{content:\"\";position:absolute;inset:2px;outline:none;border:2px solid var(--palette-primary-300);border-color:#fff}.grid-card .card-top-bar .card-top-bar-empty{width:0;flex-grow:1}.grid-card .card-image-area{height:150px;padding:0;display:flex}.grid-card .card-image-area es-preview-image{flex-grow:1}.grid-card .card-image-area .card-collection-image{display:flex;width:100%;height:100%;align-items:center;justify-content:center}.grid-card .card-image-area .card-collection-image i{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;color:#000000bf;background-color:#ffffff80;padding:40px;font-size:40px;border-radius:50%}.grid-card .card-meta{padding:10px 20px 0;display:grid;flex-direction:row}.grid-card .card-meta .card-meta-row{display:flex;flex-direction:row;align-items:center;min-height:2.8em;gap:5px}.grid-card .card-meta .card-meta-row:not(:first-child)>label{cursor:inherit;color:var(--textLight);font-size:85%}.grid-card .card-meta .card-meta-row:not(:first-child)>es-list-base{color:#000;flex-grow:1;margin:5px 0;display:flex;justify-content:flex-end;text-align:end;word-break:break-word}.grid-card .card-meta .card-meta-row:first-child{font-size:120%}.grid-card .card-meta .card-meta-row:first-child>es-list-base,.grid-card .card-meta .card-meta-row:first-child>es-node-url{width:100%;font-size:120%;color:var(--textMain);height:2.8em;text-align:left;word-break:break-word}.grid-card.dynamic-single-click:hover{box-shadow:0 0 25px #0003;background-color:rgb(var(--palette-primary-50))}.grid-card.dynamic-single-click.grid-card-collection:hover .card-meta{background-color:#ffffffe6}.grid-card.grid-card-collection .card-meta{background-color:#fffc}.grid-card.grid-card-collection .card-options{background-color:#ffffffe6}.grid-card .card-options{border-top:1px solid #ddd}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text{word-break:break-word}:host ::ng-deep .grid-card .card-meta-row:first-child es-list-base>es-list-text span,:host ::ng-deep .grid-card .card-meta-row:first-child es-node-url a es-list-base>es-list-text span{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card .card-meta-row es-node-url a{color:var(--textMain)}:host ::ng-deep .grid-card .card-meta-row es-node-url a.cdk-keyboard-focused{display:inline-flex;outline:none;outline:2px solid var(--palette-primary-300);outline-offset:2px}:host ::ng-deep .card-meta es-list-base img{max-width:100px;max-height:20px}:host ::ng-deep .card-meta es-list-base es-list-node-license img{height:20px}:host ::ng-deep .card-meta es-list-base es-list-collection-info{display:flex;align-items:center}:host ::ng-deep .card-meta es-list-base es-list-collection-info i{font-size:12pt;margin:0 6px}:host ::ng-deep .grid-card-collection es-node-url a.cdk-keyboard-focused .card-meta{background-color:#fff}.card-overlay{position:absolute;z-index:2;inset:0;pointer-events:none}.card-overlay ::ng-deep>*{pointer-events:auto}.grid-card{grid-template-rows:40px auto auto}.grid-card .card-meta .card-meta-row>es-list-base{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.4em;max-height:2.8em;-webkit-line-clamp:2;-webkit-box-orient:vertical}:host ::ng-deep .grid-card es-node-url .node-url-wrapper{height:100%}\n"] }]
107
- }], ctorParameters: () => [{ type: i1.NodeEntriesService }, { type: i2.NodeHelperService }, { type: i0.ApplicationRef }, { type: i3.ConfigService }, { type: i3.AuthenticationService }, { type: i4.NodeEntriesTemplatesService }, { type: i5.NodeEntriesGlobalService }, { type: i6.Toast, decorators: [{
108
- type: Optional
109
- }] }], propDecorators: { dropdown: [{
110
- type: Input
111
- }], menuTrigger: [{
112
- type: ViewChild,
113
- args: ['menuTrigger']
114
- }], node: [{
115
- type: Input
116
- }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-card.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card/node-entries-card.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-card/node-entries-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    Component,\n    Input,\n    OnChanges,\n    OnInit,\n    Optional,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { MatMenuTrigger } from '@angular/material/menu';\nimport { ClickSource, InteractionType } from '../entries-model';\nimport { NodeEntriesTemplatesService } from '../node-entries-templates.service';\nimport { CustomFieldSpecialType, NodeEntriesGlobalService } from '../node-entries-global.service';\nimport { Target } from '../../types/option-item';\nimport { NodeEntriesService } from '../../services/node-entries.service';\nimport { NodeHelperService } from '../../services/node-helper.service';\nimport { AuthenticationService, ConfigService, Node, RestConstants } from 'ngx-edu-sharing-api';\nimport { ColorHelper, PreferredColor } from '../../util/color-helper';\nimport { take } from 'rxjs/operators';\nimport { DropdownComponent } from '../../dropdown/dropdown.component';\nimport { Toast } from '../../services/abstract/toast.service';\nimport { BehaviorSubject } from 'rxjs';\n\n@Component({\n    selector: 'es-node-entries-card',\n    templateUrl: 'node-entries-card.component.html',\n    styleUrls: ['node-entries-card.component.scss'],\n})\nexport class NodeEntriesCardComponent<T extends Node> implements OnChanges, OnInit {\n    readonly InteractionType = InteractionType;\n    readonly Target = Target;\n    readonly ClickSource = ClickSource;\n    readonly CustomFieldSpecialType = CustomFieldSpecialType;\n    @Input() dropdown: DropdownComponent;\n\n    @ViewChild('menuTrigger') menuTrigger: MatMenuTrigger;\n\n    @Input() node: T;\n    dropdownLeft: number;\n    dropdownTop: number;\n    showRatings = new BehaviorSubject(false);\n    isCollection: boolean;\n    constructor(\n        public entriesService: NodeEntriesService<T>,\n        public nodeHelper: NodeHelperService,\n        public applicationRef: ApplicationRef,\n        public configService: ConfigService,\n        public authenticationService: AuthenticationService,\n        public templatesService: NodeEntriesTemplatesService,\n        public nodeEntriesGlobalService: NodeEntriesGlobalService,\n        @Optional() private toast: Toast,\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.isCollection = this.nodeHelper.isNodeCollection(changes.node?.currentValue);\n    }\n\n    getTextColor() {\n        return ColorHelper.getPreferredColor(this.node.collection.color) === PreferredColor.Black\n            ? '#000'\n            : '#fff';\n    }\n    optionsOnCard() {\n        const options = this.entriesService.options?.[Target.List];\n        const always = options?.filter((o) => o.showAlways);\n        if (always?.some((o) => o.showCallback([this.node]))) {\n            return always;\n        }\n        // we do NOT show any additional actions\n        return [];\n        // return options.filter((o) => o.showAsAction && o.showCallback(this.node)).slice(0, 3);\n    }\n\n    openContextmenu(event: MouseEvent | Event, node: T) {\n        event.stopPropagation();\n        event.preventDefault();\n        if (!this.dropdown) {\n            // Call `preventDefault()` even when there is no menu, so we can use `cdkDrag` with a\n            // start delay without being interrupted by the standard long-tap action.\n            return;\n        }\n        if (event instanceof MouseEvent) {\n            ({ clientX: this.dropdownLeft, clientY: this.dropdownTop } = event);\n        } else {\n            ({ x: this.dropdownLeft, y: this.dropdownTop } = (\n                event.target as HTMLElement\n            ).getBoundingClientRect());\n        }\n        this.entriesService.openDropdown(this.dropdown, node, () => this.menuTrigger.openMenu());\n    }\n\n    getVisibleColumns() {\n        return this.entriesService.columns?.filter((c) => c.visible);\n    }\n\n    async openMenu(node: T) {\n        this.entriesService.openDropdown(this.dropdown, node);\n    }\n\n    async ngOnInit() {\n        await this.configService.observeConfig().pipe(take(1)).toPromise();\n        this.showRatings.next(\n            this.configService.instant('rating.mode', 'none') !== 'none' &&\n                (await this.authenticationService.hasToolpermission(\n                    RestConstants.TOOLPERMISSION_RATE_READ,\n                )),\n        );\n    }\n\n    getTemplate(name: CustomFieldSpecialType) {\n        return this.nodeEntriesGlobalService.getCustomFieldTemplate(\n            {\n                type: 'NODE',\n                name,\n            },\n            this.node as Node,\n        );\n    }\n}\n","<div\n  [class]=\"\n    'grid-card' +\n    (isCollection\n      ? ' grid-card-collection grid-card-collection-scope-' +\n        node.collection.scope +\n        ' grid-card-collection-type-' +\n        node.collection.type\n      : '') +\n    ($any(node).virtual ? ' grid-card-virtual' : '') +\n    ' ' +\n    nodeEntriesGlobalService.getCustomCssClass(node)\n  \"\n  [style.background-color]=\"isCollection ? node.collection.color : null\"\n  [class.dynamic-single-click]=\"entriesService.singleClickHint === 'dynamic'\"\n  [class.selected]=\"entriesService.selection.isSelected(node)\"\n  (contextmenu)=\"openContextmenu($event, node)\"\n  (keydown.ContextMenu)=\"openContextmenu($event, node)\"\n>\n  <div\n    *ngIf=\"templatesService.overlay\"\n    class=\"card-overlay\"\n    (click)=\"\n      entriesService.clickItem.emit({\n        element: node,\n        source: ClickSource.Overlay,\n      })\n    \"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"templatesService.overlay; context: { element: node }\"\n    ></ng-container>\n  </div>\n  <button\n    *ngIf=\"dropdown\"\n    #menuTrigger=\"matMenuTrigger\"\n    mat-button\n    class=\"dropdown-dummy cdk-visually-hidden\"\n    [style.left.px]=\"dropdownLeft\"\n    [style.top.px]=\"dropdownTop\"\n    [matMenuTriggerFor]=\"dropdown.menu\"\n    tabindex=\"-1\"\n    aria-hidden=\"true\"\n  ></button>\n  <div class=\"card-top-bar\" [style.background-color]=\"isCollection ? node.collection.color : null\">\n    <div class=\"card-top-bar-collection-color\" *ngIf=\"nodeHelper.isNodeCollection(node)\"></div>\n    <es-node-type-badge [node]=\"node\"></es-node-type-badge>\n    <div *ngIf=\"isCollection && node.collection.pinned\" class=\"card-top-bar-flag\">\n      <i esIcon=\"edu-pin\"></i>\n    </div>\n    <div class=\"card-top-bar-empty\"></div>\n    <es-node-stats-badges [node]=\"node\"></es-node-stats-badges>\n    <div class=\"card-top-bar-checkbox\" *ngIf=\"entriesService.checkbox\">\n      <mat-checkbox\n        [checked]=\"entriesService.selection.isSelected(node)\"\n        (change)=\"entriesService.onCheckboxChanged(node, $event.checked)\"\n        color=\"primary\"\n        aria-label=\"{{ 'SELECT' | translate : { element: (node | nodeTitle) } }}\"\n      ></mat-checkbox>\n    </div>\n  </div>\n  <es-node-url\n    *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n    mode=\"wrapper\"\n    [node]=\"node\"\n    esFocusState\n    #cardFocusState=\"esFocusState\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"\n        image;\n        context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n      \"\n    ></ng-container>\n    <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n  </es-node-url>\n  <div\n    *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\"\n    matRipple\n    (click)=\"\n      entriesService.onClicked({\n        event: $event,\n        element: node,\n        source: ClickSource.Metadata,\n      })\n    \"\n    (dblclick)=\"\n      entriesService.dblClickItem.emit({\n        element: node,\n        source: ClickSource.Metadata,\n      })\n    \"\n    esFocusState\n    #cardFocusState=\"esFocusState\"\n  >\n    <ng-container\n      *ngTemplateOutlet=\"\n        image;\n        context: { playAnimation: cardFocusState.hovering || cardFocusState.hasFocus }\n      \"\n    ></ng-container>\n    <ng-container *ngTemplateOutlet=\"meta\"></ng-container>\n  </div>\n  <div class=\"card-options\" *ngIf=\"entriesService.options || showRatings\">\n    <div class=\"card-rating-area\">\n      <es-node-rating [node]=\"node\"></es-node-rating>\n    </div>\n    <div class=\"card-options-area\">\n      <es-option-button\n        *ngFor=\"let option of optionsOnCard()\"\n        class=\"card-options-always\"\n        [option]=\"option\"\n        [node]=\"node\"\n      ></es-option-button>\n      <div class=\"card-options-spacer\"></div>\n      <button\n        *ngIf=\"dropdown\"\n        mat-icon-button\n        color=\"primary\"\n        (click)=\"openMenu(node)\"\n        [matMenuTriggerFor]=\"dropdown.menu\"\n        [attr.aria-label]=\"'OPTIONS_FOR' | translate : { element: (node | nodeTitle) }\"\n        data-test=\"card-options-button\"\n      >\n        <i esIcon=\"more_vert\"></i>\n      </button>\n    </div>\n  </div>\n  <ng-template #image let-playAnimation=\"playAnimation\">\n    <div\n      class=\"card-image-area\"\n      [style.background-color]=\"isCollection ? node.collection.color : null\"\n    >\n      <ng-container *ngIf=\"getTemplate(CustomFieldSpecialType.preview) as ref\">\n        <ng-container *ngTemplateOutlet=\"ref; context: { node: this.node }\"></ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"!getTemplate(CustomFieldSpecialType.preview)\">\n        <es-preview-image\n          *ngIf=\"!(isCollection && node.preview.isIcon)\"\n          [node]=\"node\"\n          [playAnimation]=\"playAnimation\"\n        ></es-preview-image>\n        <div *ngIf=\"isCollection && node.preview.isIcon\" class=\"card-collection-image\">\n          <i esIcon=\"layers\"></i>\n        </div>\n      </ng-container>\n    </div>\n  </ng-template>\n  <ng-template #meta let-link=\"link\">\n    <div class=\"card-meta\">\n      <div\n        *ngFor=\"let displayPart of getVisibleColumns(); let first = first\"\n        class=\"card-meta-row card-meta-row-{{ displayPart.name | lowercase | propertySlug }}\"\n        [class.card-meta-row-primary]=\"first\"\n      >\n        <ng-container *ngIf=\"first\">\n          <es-node-url\n            *ngIf=\"entriesService.elementInteractionType === InteractionType.DefaultActionLink\"\n            [node]=\"node\"\n            #link\n          >\n            <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n          </es-node-url>\n          <div *ngIf=\"entriesService.elementInteractionType !== InteractionType.DefaultActionLink\">\n            <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n          </div>\n        </ng-container>\n        <ng-container *ngIf=\"!first\">\n          <label>\n            {{ displayPart | esListItemLabel | async }}\n          </label>\n          <es-list-base [item]=\"displayPart\" [node]=\"node\" [provideLabel]=\"false\"> </es-list-base>\n        </ng-container>\n      </div>\n    </div>\n  </ng-template>\n</div>\n"]}