ngx-edu-sharing-ui 9.0.2 → 9.2.0

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 (129) hide show
  1. package/assets/scss/variables-scss.scss +2 -0
  2. package/assets/scss/variables.scss +2 -1
  3. package/esm2022/lib/actionbar/actionbar.component.mjs +8 -8
  4. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +76 -65
  5. package/esm2022/lib/directives/border-box-observer.directive.mjs +5 -5
  6. package/esm2022/lib/directives/check-text-overflow.directive.mjs +12 -6
  7. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +5 -5
  8. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +5 -5
  9. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +5 -5
  10. package/esm2022/lib/directives/focus-state.directive.mjs +5 -5
  11. package/esm2022/lib/directives/icon.directive.mjs +20 -13
  12. package/esm2022/lib/directives/infinite-scroll.directive.mjs +85 -0
  13. package/esm2022/lib/dropdown/dropdown.component.mjs +8 -8
  14. package/esm2022/lib/edu-sharing-ui-configuration.mjs +11 -4
  15. package/esm2022/lib/edu-sharing-ui.module.mjs +9 -5
  16. package/esm2022/lib/list-items/format-duration.pipe.mjs +3 -3
  17. package/esm2022/lib/list-items/list-base/list-base.component.mjs +10 -10
  18. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +5 -5
  19. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +6 -4
  20. package/esm2022/lib/list-items/list-items.module.mjs +4 -4
  21. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +5 -5
  22. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +5 -5
  23. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +5 -5
  24. package/esm2022/lib/list-items/list-text/list-text.component.mjs +20 -20
  25. package/esm2022/lib/list-items/list-widget.mjs +5 -5
  26. package/esm2022/lib/list-items/node-row/node-row.component.mjs +5 -5
  27. package/esm2022/lib/list-items/node-source.pipe.mjs +5 -5
  28. package/esm2022/lib/mds/mds-helper.service.mjs +167 -0
  29. package/esm2022/lib/mds/mds.module.mjs +16 -0
  30. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +3 -3
  31. package/esm2022/lib/node-entries/entries-model.mjs +2 -1
  32. package/esm2022/lib/node-entries/items-cap.mjs +1 -1
  33. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +5 -5
  34. package/esm2022/lib/node-entries/node-cache.mjs +9 -1
  35. package/esm2022/lib/node-entries/node-data-source-remote.mjs +1 -1
  36. package/esm2022/lib/node-entries/node-data-source.mjs +4 -2
  37. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +17 -15
  38. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +39 -24
  39. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +8 -8
  40. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +10 -6
  41. package/esm2022/lib/node-entries/node-entries-global.service.mjs +18 -5
  42. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +6 -6
  43. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +44 -35
  44. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +4 -4
  45. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +13 -6
  46. package/esm2022/lib/node-entries/node-entries.component.mjs +7 -7
  47. package/esm2022/lib/node-entries/node-entries.module.mjs +4 -4
  48. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +36 -13
  49. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +6 -6
  50. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +5 -5
  51. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +21 -10
  52. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +5 -5
  53. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +6 -6
  54. package/esm2022/lib/node-url/node-url.component.mjs +11 -7
  55. package/esm2022/lib/pipes/file-size.pipe.mjs +6 -6
  56. package/esm2022/lib/pipes/format-date.pipe.mjs +5 -5
  57. package/esm2022/lib/pipes/node-icon.pipe.mjs +4 -4
  58. package/esm2022/lib/pipes/node-image-size.pipe.mjs +4 -4
  59. package/esm2022/lib/pipes/node-image.pipe.mjs +5 -5
  60. package/esm2022/lib/pipes/node-person-name.pipe.mjs +5 -5
  61. package/esm2022/lib/pipes/node-title.pipe.mjs +4 -4
  62. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +5 -5
  63. package/esm2022/lib/pipes/property-slug.pipe.mjs +16 -0
  64. package/esm2022/lib/pipes/replace-chars.pipe.mjs +5 -5
  65. package/esm2022/lib/pipes/vcard-name.pipe.mjs +4 -4
  66. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +3 -3
  67. package/esm2022/lib/services/abstract/options-helper.service.mjs +1 -1
  68. package/esm2022/lib/services/accessibility.service.mjs +5 -5
  69. package/esm2022/lib/services/app-container.service.mjs +66 -0
  70. package/esm2022/lib/services/local-events.service.mjs +3 -3
  71. package/esm2022/lib/services/node-entries.service.mjs +51 -7
  72. package/esm2022/lib/services/node-helper.service.mjs +36 -13
  73. package/esm2022/lib/services/nodes-drag-drop.service.mjs +5 -5
  74. package/esm2022/lib/services/options-helper-data.service.mjs +9 -9
  75. package/esm2022/lib/services/repo-url.service.mjs +6 -5
  76. package/esm2022/lib/services/temporary-storage.service.mjs +5 -5
  77. package/esm2022/lib/services/ui.service.mjs +11 -5
  78. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +5 -5
  79. package/esm2022/lib/spinner/spinner.component.mjs +7 -6
  80. package/esm2022/lib/translations/translation-loader.mjs +40 -8
  81. package/esm2022/lib/translations/translations.module.mjs +21 -10
  82. package/esm2022/lib/translations/translations.service.mjs +17 -9
  83. package/esm2022/lib/types/injection-tokens.mjs +9 -0
  84. package/esm2022/lib/types/option-item.mjs +4 -3
  85. package/esm2022/lib/util/DateHelper.mjs +1 -1
  86. package/esm2022/lib/util/VCard.mjs +1 -1
  87. package/esm2022/lib/util/color-helper.mjs +1 -1
  88. package/esm2022/lib/util/duration-helper.mjs +1 -1
  89. package/esm2022/lib/util/helper.mjs +1 -1
  90. package/esm2022/lib/util/rest-helper.mjs +1 -1
  91. package/esm2022/module.mjs +51 -43
  92. package/fesm2022/ngx-edu-sharing-ui.mjs +5771 -5197
  93. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  94. package/lib/common/edu-sharing-ui-common.module.d.ts +27 -25
  95. package/lib/directives/icon.directive.d.ts +2 -2
  96. package/lib/directives/infinite-scroll.directive.d.ts +22 -0
  97. package/lib/edu-sharing-ui-configuration.d.ts +5 -0
  98. package/lib/edu-sharing-ui.module.d.ts +7 -6
  99. package/lib/list-items/list-text/list-text.component.d.ts +1 -1
  100. package/lib/list-items/list-widget.d.ts +1 -1
  101. package/lib/mds/mds-helper.service.d.ts +37 -0
  102. package/lib/mds/mds.module.d.ts +6 -0
  103. package/lib/node-entries/entries-model.d.ts +2 -1
  104. package/lib/node-entries/node-data-source-remote.d.ts +2 -2
  105. package/lib/node-entries/node-data-source.d.ts +1 -1
  106. package/lib/node-entries/node-entries-card/node-entries-card.component.d.ts +1 -1
  107. package/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.d.ts +6 -1
  108. package/lib/node-entries/node-entries-global-options/node-entries-global-options.component.d.ts +1 -0
  109. package/lib/node-entries/node-entries-global.service.d.ts +7 -0
  110. package/lib/node-entries/node-entries-table/node-entries-table.component.d.ts +4 -1
  111. package/lib/node-entries/node-entries-wrapper.component.d.ts +8 -3
  112. package/lib/node-entries/node-rating/node-rating.component.d.ts +3 -3
  113. package/lib/node-entries/option-button/option-button.component.d.ts +6 -2
  114. package/lib/pipes/property-slug.pipe.d.ts +7 -0
  115. package/lib/services/abstract/options-helper.service.d.ts +3 -3
  116. package/lib/services/app-container.service.d.ts +43 -0
  117. package/lib/services/node-entries.service.d.ts +31 -6
  118. package/lib/services/node-helper.service.d.ts +5 -3
  119. package/lib/services/options-helper-data.service.d.ts +3 -3
  120. package/lib/services/ui.service.d.ts +8 -1
  121. package/lib/spinner/spinner.component.d.ts +1 -1
  122. package/lib/translations/translation-loader.d.ts +2 -1
  123. package/lib/types/injection-tokens.d.ts +8 -0
  124. package/lib/types/option-item.d.ts +24 -25
  125. package/lib/util/ui-constants.d.ts +2 -2
  126. package/module.d.ts +50 -42
  127. package/package.json +5 -5
  128. package/esm2022/lib/translations/languages.mjs +0 -5
  129. package/lib/translations/languages.d.ts +0 -4
@@ -36,6 +36,11 @@ export class NodeEntriesWrapperComponent {
36
36
  this.displayType = NodeEntriesDisplayType.Grid;
37
37
  this.displayTypeChange = new EventEmitter();
38
38
  this.elementInteractionType = InteractionType.DefaultActionLink;
39
+ /**
40
+ * This color defines the base color of gradients visually limiting a grid in scroll direction.
41
+ * Defaults to white.
42
+ */
43
+ this.scrollGradientColor = '#fff';
39
44
  /**
40
45
  * UI hints for whether a single click will cause a dynamic action.
41
46
  *
@@ -94,7 +99,6 @@ export class NodeEntriesWrapperComponent {
94
99
  this.entriesService.columns = this.columns;
95
100
  this.entriesService.configureColumns = this.configureColumns;
96
101
  this.entriesService.checkbox = this.checkbox;
97
- this.entriesService.columnsChange = this.columnsChange;
98
102
  this.entriesService.displayType = this.displayType;
99
103
  this.entriesService.elementInteractionType = this.elementInteractionType;
100
104
  this.entriesService.gridConfig = this.gridConfig;
@@ -109,6 +113,7 @@ export class NodeEntriesWrapperComponent {
109
113
  this.entriesService.primaryInstance = this.primaryInstance;
110
114
  this.entriesService.singleClickHint = this.singleClickHint;
111
115
  this.entriesService.disableInfiniteScroll = this.disableInfiniteScroll;
116
+ this.entriesService.scrollGradientColor.set(this.scrollGradientColor);
112
117
  if (changes['initConfig']) {
113
118
  this.initOptionsGenerator(this.initConfig);
114
119
  }
@@ -243,13 +248,13 @@ export class NodeEntriesWrapperComponent {
243
248
  this.dataSource.removeData(objects);
244
249
  this.getSelection().clear();
245
250
  }
246
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesWrapperComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TemporaryStorageService }, { token: i0.NgZone }, { token: i2.NodeEntriesService }, { token: i3.OptionsHelperDataService }, { token: i4.NodeHelperService }, { token: i5.UIService }, { token: i6.NodeEntriesTemplatesService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
247
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: NodeEntriesWrapperComponent, selector: "es-node-entries-wrapper", inputs: { dataSource: "dataSource", scope: "scope", columns: "columns", configureColumns: "configureColumns", checkbox: "checkbox", globalOptions: "globalOptions", displayType: "displayType", elementInteractionType: "elementInteractionType", sort: "sort", dragDrop: "dragDrop", gridConfig: "gridConfig", initConfig: "initConfig", primaryInstance: "primaryInstance", singleClickHint: "singleClickHint", disableInfiniteScroll: "disableInfiniteScroll" }, outputs: { columnsChange: "columnsChange", displayTypeChange: "displayTypeChange", fetchData: "fetchData", clickItem: "clickItem", dblClickItem: "dblClickItem", sortChange: "sortChange", virtualNodesAdded: "virtualNodesAdded", displayTypeChanged: "displayTypeChanged" }, providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService], queries: [{ propertyName: "titleRef", first: true, predicate: ["title"], descendants: true }, { propertyName: "emptyRef", first: true, predicate: ["empty"], descendants: true }, { propertyName: "actionAreaRef", first: true, predicate: ["actionArea"], descendants: true }, { propertyName: "overlayRef", first: true, predicate: ["overlay"], descendants: true }], viewQueries: [{ propertyName: "nodeEntriesComponentRef", first: true, predicate: ["nodeEntriesComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<es-node-entries
251
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesWrapperComponent, deps: [{ token: i0.ViewContainerRef }, { token: i1.TemporaryStorageService }, { token: i0.NgZone }, { token: i2.NodeEntriesService }, { token: i3.OptionsHelperDataService }, { token: i4.NodeHelperService }, { token: i5.UIService }, { token: i6.NodeEntriesTemplatesService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
252
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: NodeEntriesWrapperComponent, selector: "es-node-entries-wrapper", inputs: { dataSource: "dataSource", scope: "scope", columns: "columns", configureColumns: "configureColumns", checkbox: "checkbox", globalOptions: "globalOptions", displayType: "displayType", elementInteractionType: "elementInteractionType", sort: "sort", dragDrop: "dragDrop", gridConfig: "gridConfig", scrollGradientColor: "scrollGradientColor", initConfig: "initConfig", primaryInstance: "primaryInstance", singleClickHint: "singleClickHint", disableInfiniteScroll: "disableInfiniteScroll" }, outputs: { columnsChange: "columnsChange", displayTypeChange: "displayTypeChange", fetchData: "fetchData", clickItem: "clickItem", dblClickItem: "dblClickItem", sortChange: "sortChange", virtualNodesAdded: "virtualNodesAdded", displayTypeChanged: "displayTypeChanged" }, providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService], queries: [{ propertyName: "titleRef", first: true, predicate: ["title"], descendants: true }, { propertyName: "emptyRef", first: true, predicate: ["empty"], descendants: true }, { propertyName: "actionAreaRef", first: true, predicate: ["actionArea"], descendants: true }, { propertyName: "overlayRef", first: true, predicate: ["overlay"], descendants: true }], viewQueries: [{ propertyName: "nodeEntriesComponentRef", first: true, predicate: ["nodeEntriesComponent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `<es-node-entries
248
253
  #nodeEntriesComponent
249
254
  *ngIf="!customNodeListComponent"
250
255
  ></es-node-entries>`, isInline: true, dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.NodeEntriesComponent, selector: "es-node-entries" }] }); }
251
256
  }
252
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesWrapperComponent, decorators: [{
257
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesWrapperComponent, decorators: [{
253
258
  type: Component,
254
259
  args: [{
255
260
  selector: 'es-node-entries-wrapper',
@@ -259,7 +264,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
259
264
  ></es-node-entries>`,
260
265
  providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService],
261
266
  }]
262
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i1.TemporaryStorageService }, { type: i0.NgZone }, { type: i2.NodeEntriesService }, { type: i3.OptionsHelperDataService }, { type: i4.NodeHelperService }, { type: i5.UIService }, { type: i6.NodeEntriesTemplatesService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { titleRef: [{
267
+ }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i1.TemporaryStorageService }, { type: i0.NgZone }, { type: i2.NodeEntriesService }, { type: i3.OptionsHelperDataService }, { type: i4.NodeHelperService }, { type: i5.UIService }, { type: i6.NodeEntriesTemplatesService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { titleRef: [{
263
268
  type: ContentChild,
264
269
  args: ['title']
265
270
  }], emptyRef: [{
@@ -300,6 +305,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
300
305
  type: Input
301
306
  }], gridConfig: [{
302
307
  type: Input
308
+ }], scrollGradientColor: [{
309
+ type: Input
303
310
  }], initConfig: [{
304
311
  type: Input
305
312
  }], primaryInstance: [{
@@ -321,4 +328,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
321
328
  }], displayTypeChanged: [{
322
329
  type: Output
323
330
  }] } });
324
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChange,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesComponent } from './node-entries.component';\nimport {\n    FetchEvent,\n    GridConfig,\n    InteractionType,\n    ListDragGropConfig,\n    ListEventInterface,\n    ListOptions,\n    ListOptionsConfig,\n    ListSortConfig,\n    NodeClickEvent,\n    NodeEntriesDataType,\n    NodeEntriesDisplayType,\n} from './entries-model';\nimport { NodeDataSource } from './node-data-source';\nimport { Helper } from '../util/helper';\nimport { NodeEntriesService } from '../services/node-entries.service';\nimport { OptionItem, Scope } from '../types/option-item';\nimport { NodeHelperService } from '../services/node-helper.service';\nimport { ListItem } from '../types/list-item';\nimport { TemporaryStorageService } from '../services/temporary-storage.service';\nimport { CollectionReference, Node, User } from 'ngx-edu-sharing-api';\nimport { VirtualNode } from '../types/api-models';\nimport { OptionsHelperDataService } from '../services/options-helper-data.service';\nimport { UIService } from '../services/ui.service';\n\n@Component({\n    selector: 'es-node-entries-wrapper',\n    template: `<es-node-entries\n        #nodeEntriesComponent\n        *ngIf=\"!customNodeListComponent\"\n    ></es-node-entries>`,\n    providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService],\n})\nexport class NodeEntriesWrapperComponent<T extends NodeEntriesDataType>\n    implements AfterViewInit, OnInit, OnChanges, OnDestroy, ListEventInterface<T>\n{\n    /**\n     * title (above) the table/grid\n     */\n    @ContentChild('title') titleRef: TemplateRef<any>;\n    /**\n     * data shown when data source is empty\n     */\n    @ContentChild('empty') emptyRef: TemplateRef<any>;\n    /**\n     * custom area for actions only for NodeEntriesDisplayType.SmallGrid (per card at the bottom)\n     */\n    @ContentChild('actionArea') actionAreaRef: TemplateRef<any>;\n    /**\n     * custom area for an overlay \"above\" each card (i.e. to show disabled infos), only for NodeEntriesDisplayType.SmallGrid & odeEntriesDisplayType.Grid\n     */\n    @ContentChild('overlay') overlayRef: TemplateRef<any>;\n    @ViewChild('nodeEntriesComponent') nodeEntriesComponentRef: NodeEntriesComponent<T>;\n    @Input() dataSource: NodeDataSource<T>;\n    @Input() scope: Scope;\n    @Input() columns: ListItem[];\n    @Input() configureColumns: boolean;\n    @Input() checkbox = true;\n    @Output() columnsChange = new EventEmitter<ListItem[]>();\n    @Input() globalOptions: OptionItem[];\n    @Input() displayType = NodeEntriesDisplayType.Grid;\n    @Output() displayTypeChange = new EventEmitter<NodeEntriesDisplayType>();\n    @Input() elementInteractionType = InteractionType.DefaultActionLink;\n    @Input() sort: ListSortConfig;\n    @Input() dragDrop: ListDragGropConfig<T>;\n    @Input() gridConfig: GridConfig;\n    /**\n     * this can be set instead of calling initOptionsGenerator()\n     */\n    @Input() initConfig: ListOptionsConfig;\n    /**\n     * Whether this node-entries instance represents the page's main content.\n     *\n     * Only set to true for one instance per page.\n     *\n     * If true, this instance will\n     * - handle page-wide keyboard shortcuts\n     * - take control of the `page` and `pageSize` query parameters for pagination\n     */\n    @Input() primaryInstance: boolean;\n    /**\n     * UI hints for whether a single click will cause a dynamic action.\n     *\n     * This does not configure the actual behavior but only UI hints to the user. Hints include\n     * hover effects and a changed cursor.\n     *\n     * - When choosing 'static', the `clickItem` event should trigger some stationary action like\n     *   selecting the element or displaying information in a complementary page area. The\n     *   `dblClickItem` event can be used for a more disruptive action.\n     * - When choosing 'dynamic', the `clickItem` event should trigger a major action like\n     *   navigating to a new page or closing a dialog.\n     */\n    // TODO: Consider controlling the ui hints and the actual behavior with a single option.\n    @Input() singleClickHint: 'dynamic' | 'static' = 'dynamic';\n    /**\n     * Do not load more data on scroll.\n     */\n    @Input() disableInfiniteScroll = false;\n\n    @Output() fetchData = new EventEmitter<FetchEvent>();\n    @Output() clickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() dblClickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() sortChange = new EventEmitter<ListSortConfig>();\n    @Output() virtualNodesAdded;\n    @Output() displayTypeChanged;\n\n    customNodeListComponent: Type<NodeEntriesComponent<T>>;\n    private componentRef: ComponentRef<NodeEntriesComponent<T>>;\n    private options: ListOptions;\n    private destroyed = new Subject<void>();\n\n    constructor(\n        private viewContainerRef: ViewContainerRef,\n        private temporaryStorageService: TemporaryStorageService,\n        private ngZone: NgZone,\n        private entriesService: NodeEntriesService<T>,\n        public optionsHelper: OptionsHelperDataService,\n        private nodeHelperService: NodeHelperService,\n        private uiService: UIService,\n        // @TODO\n        // private mainNav: MainNavService,\n        private templatesService: NodeEntriesTemplatesService,\n        private changeDetectorRef: ChangeDetectorRef,\n        private elementRef: ElementRef,\n    ) {\n        // regulary re-bind template since it might have updated without ngChanges trigger\n        /*\n        ngZone.runOutsideAngular(() =>\n            setInterval(() => this.componentRef.instance.emptyRef = this.emptyRef)\n        );\n        */\n        this.virtualNodesAdded = this.optionsHelper.virtualNodesAdded;\n        this.displayTypeChanged = this.optionsHelper.displayTypeChanged;\n        this.entriesService.selection.changed.subscribe(() => {\n            if (this.optionsHelper.getData()) {\n                this.optionsHelper.getData().selectedObjects =\n                    this.entriesService.selection.selected;\n                this.optionsHelper.getData().activeObjects = this.entriesService.selection.selected;\n            } else {\n                console.warn('optionsHelper is not initalized correctly; data is empty');\n            }\n            this.optionsHelper.refreshComponents();\n        });\n    }\n\n    ngOnInit(): void {\n        if (this.primaryInstance) {\n            this.optionsHelper.registerGlobalKeyboardShortcuts();\n        }\n    }\n\n    ngOnChanges(changes: { [key: string]: SimpleChange } = {}) {\n        if (!this.componentRef) {\n            this.init();\n        }\n        this.entriesService.list = this;\n        this.entriesService.dataSource = this.dataSource;\n        this.entriesService.scope = this.scope;\n        this.entriesService.columns = this.columns;\n        this.entriesService.configureColumns = this.configureColumns;\n        this.entriesService.checkbox = this.checkbox;\n        this.entriesService.columnsChange = this.columnsChange;\n        this.entriesService.displayType = this.displayType;\n        this.entriesService.elementInteractionType = this.elementInteractionType;\n        this.entriesService.gridConfig = this.gridConfig;\n        this.entriesService.options = this.options;\n        this.entriesService.globalOptions = this.globalOptions;\n        this.entriesService.sort = this.sort;\n        this.entriesService.sortChange = this.sortChange;\n        this.entriesService.dragDrop = this.dragDrop;\n        this.entriesService.clickItem = this.clickItem;\n        this.entriesService.dblClickItem = this.dblClickItem;\n        this.entriesService.fetchData = this.fetchData;\n        this.entriesService.primaryInstance = this.primaryInstance;\n        this.entriesService.singleClickHint = this.singleClickHint;\n        this.entriesService.disableInfiniteScroll = this.disableInfiniteScroll;\n\n        if (changes['initConfig']) {\n            this.initOptionsGenerator(this.initConfig);\n        }\n        if (this.componentRef) {\n            this.componentRef.instance.changeDetectorRef?.detectChanges();\n        }\n        // This might need wrapping with `setTimeout`.\n        this.updateTemplates();\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    /**\n     * Replaces this wrapper with the configured custom-node-list component.\n     */\n    private init(): void {\n        this.customNodeListComponent = this.temporaryStorageService.get(\n            TemporaryStorageService.CUSTOM_NODE_ENTRIES_COMPONENT,\n            null,\n        );\n        if (this.customNodeListComponent == null) {\n            return;\n        }\n        this.componentRef = this.uiService.injectAngularComponent(\n            this.viewContainerRef,\n            this.customNodeListComponent,\n            this.elementRef.nativeElement,\n            // Input bindings are initialized in `ngOnChanges`.\n            this.getOutputBindings(),\n        );\n    }\n    /**\n     * Creates a simple map of the output bindings defined in this component.\n     */\n    private getOutputBindings(): { [key: string]: EventEmitter<any> } {\n        const outputBindings: { [key: string]: any } = {};\n        for (const key of Object.keys(this)) {\n            const value = (this as any)[key];\n            if (value instanceof EventEmitter) {\n                outputBindings[key] = value;\n            }\n        }\n        return outputBindings;\n    }\n\n    getDisplayType(): NodeEntriesDisplayType {\n        return this.displayType;\n    }\n\n    setDisplayType(displayType: NodeEntriesDisplayType): void {\n        this.displayType = displayType;\n        this.entriesService.displayType = displayType;\n        this.ngOnChanges();\n        this.displayTypeChange.emit(displayType);\n    }\n\n    updateNodes(nodes: void | T[]) {\n        if (!nodes) {\n            return;\n        }\n        this.dataSource.getData().forEach((d) => {\n            let hits = (nodes as T[]).filter((n) => (n as Node).ref.id === (d as Node).ref.id);\n            if (hits.length === 0) {\n                // handle if the original has changed (for collection refs)\n                hits = (nodes as T[]).filter(\n                    (n) => (n as Node).ref.id === (d as unknown as CollectionReference).originalId,\n                );\n            }\n            if (hits.length === 1) {\n                this.nodeHelperService.copyDataToNode(d as Node, hits[0] as Node);\n            }\n        });\n        // trigger rebuild\n        if (this.dataSource instanceof NodeDataSource) {\n            (this.dataSource as NodeDataSource<T>).refresh();\n        }\n        const oldSelection = this.entriesService.selection.selected;\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(\n            ...oldSelection.map(\n                (o) => this.dataSource.getData().filter((d) => Helper.objectEquals(o, d))?.[0],\n            ),\n        );\n        this.changeDetectorRef.detectChanges();\n    }\n\n    showReorderColumnsDialog(): void {}\n\n    addVirtualNodes(virtual: T[]): void {\n        virtual = virtual.map((o) => {\n            (o as VirtualNode).virtual = true;\n            return o;\n        });\n        virtual.forEach((v) => {\n            const contains = this.dataSource\n                .getData()\n                .some((d) =>\n                    (d as Node).ref\n                        ? (d as Node).ref?.id === (v as Node).ref?.id\n                        : (d as User).authorityName === (v as User).authorityName,\n                );\n            if (contains) {\n                this.updateNodes([v]);\n            } else {\n                this.dataSource.appendData([v], 'before');\n            }\n        });\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(...virtual);\n        this.virtualNodesAdded.emit(virtual as Node[]);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    setOptions(options: ListOptions): void {\n        this.options = options;\n        this.ngOnChanges();\n    }\n\n    getSelection() {\n        return this.entriesService.selection;\n    }\n\n    async initOptionsGenerator(config: ListOptionsConfig) {\n        await this.optionsHelper.initComponents(config.actionbar, this);\n        this.optionsHelper.setData({\n            scope: this.entriesService.scope,\n            activeObjects: this.entriesService.selection.selected,\n            selectedObjects: this.entriesService.selection.selected,\n            allObjects: this.dataSource.getData(),\n            parent: config.parent,\n            customOptions: config.customOptions,\n        });\n        this.optionsHelper.refreshComponents();\n    }\n\n    ngAfterViewInit(): void {\n        // Prevent changed-after-checked error\n        Promise.resolve().then(() => this.updateTemplates());\n    }\n\n    private updateTemplates(): void {\n        this.templatesService.title = this.titleRef;\n        this.templatesService.empty = this.emptyRef;\n        this.templatesService.actionArea = this.actionAreaRef;\n        this.templatesService.overlay = this.overlayRef;\n    }\n\n    /**\n     * reset the pagination to the first page\n     * hint: this will do nothing in case the paginationStrategy !== Pagination\n     */\n    resetPagination() {\n        this.nodeEntriesComponentRef?.paginator?.firstPage();\n    }\n\n    deleteNodes(objects: T[]): void {\n        this.dataSource.removeData(objects);\n        this.getSelection().clear();\n    }\n}\n"]}
331
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    signal,\n    SimpleChange,\n    TemplateRef,\n    Type,\n    ViewChild,\n    ViewContainerRef,\n    WritableSignal,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesComponent } from './node-entries.component';\nimport {\n    FetchEvent,\n    GridConfig,\n    InteractionType,\n    ListDragGropConfig,\n    ListEventInterface,\n    ListOptions,\n    ListOptionsConfig,\n    ListSortConfig,\n    NodeClickEvent,\n    NodeEntriesDataType,\n    NodeEntriesDisplayType,\n} from './entries-model';\nimport { NodeDataSource } from './node-data-source';\nimport { Helper } from '../util/helper';\nimport { CustomSelectionModel, NodeEntriesService } from '../services/node-entries.service';\nimport { OptionItem, Scope } from '../types/option-item';\nimport { NodeHelperService } from '../services/node-helper.service';\nimport { ListItem } from '../types/list-item';\nimport { TemporaryStorageService } from '../services/temporary-storage.service';\nimport { CollectionReference, Node, User } from 'ngx-edu-sharing-api';\nimport { VirtualNode } from '../types/api-models';\nimport { OptionsHelperDataService } from '../services/options-helper-data.service';\nimport { UIService } from '../services/ui.service';\n\n@Component({\n    selector: 'es-node-entries-wrapper',\n    template: `<es-node-entries\n        #nodeEntriesComponent\n        *ngIf=\"!customNodeListComponent\"\n    ></es-node-entries>`,\n    providers: [NodeEntriesService, OptionsHelperDataService, NodeEntriesTemplatesService],\n})\nexport class NodeEntriesWrapperComponent<T extends NodeEntriesDataType>\n    implements AfterViewInit, OnInit, OnChanges, OnDestroy, ListEventInterface<T>\n{\n    /**\n     * title (above) the table/grid\n     */\n    @ContentChild('title') titleRef: TemplateRef<any>;\n    /**\n     * data shown when data source is empty\n     */\n    @ContentChild('empty') emptyRef: TemplateRef<any>;\n    /**\n     * custom area for actions only for NodeEntriesDisplayType.SmallGrid (per card at the bottom)\n     */\n    @ContentChild('actionArea') actionAreaRef: TemplateRef<any>;\n    /**\n     * custom area for an overlay \"above\" each card (i.e. to show disabled infos), only for NodeEntriesDisplayType.SmallGrid & odeEntriesDisplayType.Grid\n     */\n    @ContentChild('overlay') overlayRef: TemplateRef<any>;\n    @ViewChild('nodeEntriesComponent') nodeEntriesComponentRef: NodeEntriesComponent<T>;\n    @Input() dataSource: NodeDataSource<T>;\n    @Input() scope: Scope;\n    @Input() columns: ListItem[];\n    @Input() configureColumns: boolean;\n    @Input() checkbox = true;\n    @Output() columnsChange = new EventEmitter<ListItem[]>();\n    @Input() globalOptions: OptionItem[];\n    @Input() displayType = NodeEntriesDisplayType.Grid;\n    @Output() displayTypeChange = new EventEmitter<NodeEntriesDisplayType>();\n    @Input() elementInteractionType = InteractionType.DefaultActionLink;\n    @Input() sort: ListSortConfig;\n    @Input() dragDrop: ListDragGropConfig<T>;\n    @Input() gridConfig: GridConfig;\n\n    /**\n     * This color defines the base color of gradients visually limiting a grid in scroll direction.\n     * Defaults to white.\n     */\n    @Input() scrollGradientColor: string = '#fff';\n\n    /**\n     * this can be set instead of calling initOptionsGenerator()\n     */\n    @Input() initConfig: ListOptionsConfig;\n    /**\n     * Whether this node-entries instance represents the page's main content.\n     *\n     * Only set to true for one instance per page.\n     *\n     * If true, this instance will\n     * - handle page-wide keyboard shortcuts\n     * - take control of the `page` and `pageSize` query parameters for pagination\n     */\n    @Input() primaryInstance: boolean;\n    /**\n     * UI hints for whether a single click will cause a dynamic action.\n     *\n     * This does not configure the actual behavior but only UI hints to the user. Hints include\n     * hover effects and a changed cursor.\n     *\n     * - When choosing 'static', the `clickItem` event should trigger some stationary action like\n     *   selecting the element or displaying information in a complementary page area. The\n     *   `dblClickItem` event can be used for a more disruptive action.\n     * - When choosing 'dynamic', the `clickItem` event should trigger a major action like\n     *   navigating to a new page or closing a dialog.\n     */\n    // TODO: Consider controlling the ui hints and the actual behavior with a single option.\n    @Input() singleClickHint: 'dynamic' | 'static' = 'dynamic';\n    /**\n     * Do not load more data on scroll.\n     */\n    @Input() disableInfiniteScroll = false;\n\n    @Output() fetchData = new EventEmitter<FetchEvent>();\n    @Output() clickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() dblClickItem = new EventEmitter<NodeClickEvent<T>>();\n    @Output() sortChange = new EventEmitter<ListSortConfig>();\n    @Output() virtualNodesAdded;\n    @Output() displayTypeChanged;\n\n    customNodeListComponent: Type<NodeEntriesComponent<T>>;\n    private componentRef: ComponentRef<NodeEntriesComponent<T>>;\n    private options: ListOptions;\n    private destroyed = new Subject<void>();\n\n    constructor(\n        private viewContainerRef: ViewContainerRef,\n        private temporaryStorageService: TemporaryStorageService,\n        private ngZone: NgZone,\n        private entriesService: NodeEntriesService<T>,\n        public optionsHelper: OptionsHelperDataService,\n        private nodeHelperService: NodeHelperService,\n        private uiService: UIService,\n        // @TODO\n        // private mainNav: MainNavService,\n        private templatesService: NodeEntriesTemplatesService,\n        private changeDetectorRef: ChangeDetectorRef,\n        private elementRef: ElementRef,\n    ) {\n        // regulary re-bind template since it might have updated without ngChanges trigger\n        /*\n        ngZone.runOutsideAngular(() =>\n            setInterval(() => this.componentRef.instance.emptyRef = this.emptyRef)\n        );\n        */\n        this.virtualNodesAdded = this.optionsHelper.virtualNodesAdded;\n        this.displayTypeChanged = this.optionsHelper.displayTypeChanged;\n        this.entriesService.selection.changed.subscribe(() => {\n            if (this.optionsHelper.getData()) {\n                this.optionsHelper.getData().selectedObjects =\n                    this.entriesService.selection.selected;\n                this.optionsHelper.getData().activeObjects = this.entriesService.selection.selected;\n            } else {\n                console.warn('optionsHelper is not initalized correctly; data is empty');\n            }\n            this.optionsHelper.refreshComponents();\n        });\n    }\n\n    ngOnInit(): void {\n        if (this.primaryInstance) {\n            this.optionsHelper.registerGlobalKeyboardShortcuts();\n        }\n    }\n\n    ngOnChanges(changes: { [key: string]: SimpleChange } = {}) {\n        if (!this.componentRef) {\n            this.init();\n        }\n        this.entriesService.list = this;\n        this.entriesService.dataSource = this.dataSource;\n        this.entriesService.scope = this.scope;\n        this.entriesService.columns = this.columns;\n        this.entriesService.configureColumns = this.configureColumns;\n        this.entriesService.checkbox = this.checkbox;\n        this.entriesService.displayType = this.displayType;\n        this.entriesService.elementInteractionType = this.elementInteractionType;\n        this.entriesService.gridConfig = this.gridConfig;\n        this.entriesService.options = this.options;\n        this.entriesService.globalOptions = this.globalOptions;\n        this.entriesService.sort = this.sort;\n        this.entriesService.sortChange = this.sortChange;\n        this.entriesService.dragDrop = this.dragDrop;\n        this.entriesService.clickItem = this.clickItem;\n        this.entriesService.dblClickItem = this.dblClickItem;\n        this.entriesService.fetchData = this.fetchData;\n        this.entriesService.primaryInstance = this.primaryInstance;\n        this.entriesService.singleClickHint = this.singleClickHint;\n        this.entriesService.disableInfiniteScroll = this.disableInfiniteScroll;\n        this.entriesService.scrollGradientColor.set(this.scrollGradientColor);\n\n        if (changes['initConfig']) {\n            this.initOptionsGenerator(this.initConfig);\n        }\n        if (this.componentRef) {\n            this.componentRef.instance.changeDetectorRef?.detectChanges();\n        }\n        // This might need wrapping with `setTimeout`.\n        this.updateTemplates();\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    /**\n     * Replaces this wrapper with the configured custom-node-list component.\n     */\n    private init(): void {\n        this.customNodeListComponent = this.temporaryStorageService.get(\n            TemporaryStorageService.CUSTOM_NODE_ENTRIES_COMPONENT,\n            null,\n        );\n        if (this.customNodeListComponent == null) {\n            return;\n        }\n        this.componentRef = this.uiService.injectAngularComponent(\n            this.viewContainerRef,\n            this.customNodeListComponent,\n            this.elementRef.nativeElement,\n            // Input bindings are initialized in `ngOnChanges`.\n            this.getOutputBindings(),\n        );\n    }\n    /**\n     * Creates a simple map of the output bindings defined in this component.\n     */\n    private getOutputBindings(): { [key: string]: EventEmitter<any> } {\n        const outputBindings: { [key: string]: any } = {};\n        for (const key of Object.keys(this)) {\n            const value = (this as any)[key];\n            if (value instanceof EventEmitter) {\n                outputBindings[key] = value;\n            }\n        }\n        return outputBindings;\n    }\n\n    getDisplayType(): NodeEntriesDisplayType {\n        return this.displayType;\n    }\n\n    setDisplayType(displayType: NodeEntriesDisplayType): void {\n        this.displayType = displayType;\n        this.entriesService.displayType = displayType;\n        this.ngOnChanges();\n        this.displayTypeChange.emit(displayType);\n    }\n\n    updateNodes(nodes: void | T[]) {\n        if (!nodes) {\n            return;\n        }\n        this.dataSource.getData().forEach((d) => {\n            let hits = (nodes as T[]).filter((n) => (n as Node).ref.id === (d as Node).ref.id);\n            if (hits.length === 0) {\n                // handle if the original has changed (for collection refs)\n                hits = (nodes as T[]).filter(\n                    (n) => (n as Node).ref.id === (d as unknown as CollectionReference).originalId,\n                );\n            }\n            if (hits.length === 1) {\n                this.nodeHelperService.copyDataToNode(d as Node, hits[0] as Node);\n            }\n        });\n        // trigger rebuild\n        if (this.dataSource instanceof NodeDataSource) {\n            (this.dataSource as NodeDataSource<T>).refresh();\n        }\n        const oldSelection = this.entriesService.selection.selected;\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(\n            ...oldSelection.map(\n                (o) => this.dataSource.getData().filter((d) => Helper.objectEquals(o, d))?.[0],\n            ),\n        );\n        this.changeDetectorRef.detectChanges();\n    }\n\n    showReorderColumnsDialog(): void {}\n\n    addVirtualNodes(virtual: T[]): void {\n        virtual = virtual.map((o) => {\n            (o as VirtualNode).virtual = true;\n            return o;\n        });\n        virtual.forEach((v) => {\n            const contains = this.dataSource\n                .getData()\n                .some((d) =>\n                    (d as Node).ref\n                        ? (d as Node).ref?.id === (v as Node).ref?.id\n                        : (d as User).authorityName === (v as User).authorityName,\n                );\n            if (contains) {\n                this.updateNodes([v]);\n            } else {\n                this.dataSource.appendData([v], 'before');\n            }\n        });\n        this.entriesService.selection.clear();\n        this.entriesService.selection.select(...virtual);\n        this.virtualNodesAdded.emit(virtual as Node[]);\n        this.changeDetectorRef.detectChanges();\n    }\n\n    setOptions(options: ListOptions): void {\n        this.options = options;\n        this.ngOnChanges();\n    }\n\n    getSelection(): CustomSelectionModel<T> {\n        return this.entriesService.selection;\n    }\n\n    async initOptionsGenerator(config: ListOptionsConfig) {\n        await this.optionsHelper.initComponents(config.actionbar, this);\n        this.optionsHelper.setData({\n            scope: this.entriesService.scope,\n            activeObjects: this.entriesService.selection.selected,\n            selectedObjects: this.entriesService.selection.selected,\n            allObjects: this.dataSource.getData(),\n            parent: config.parent,\n            customOptions: config.customOptions,\n        });\n        this.optionsHelper.refreshComponents();\n    }\n\n    ngAfterViewInit(): void {\n        // Prevent changed-after-checked error\n        Promise.resolve().then(() => this.updateTemplates());\n    }\n\n    private updateTemplates(): void {\n        this.templatesService.title = this.titleRef;\n        this.templatesService.empty = this.emptyRef;\n        this.templatesService.actionArea = this.actionAreaRef;\n        this.templatesService.overlay = this.overlayRef;\n    }\n\n    /**\n     * reset the pagination to the first page\n     * hint: this will do nothing in case the paginationStrategy !== Pagination\n     */\n    resetPagination() {\n        this.nodeEntriesComponentRef?.paginator?.firstPage();\n    }\n\n    deleteNodes(objects: T[]): void {\n        this.dataSource.removeData(objects);\n        this.getSelection().clear();\n    }\n}\n"]}
@@ -116,16 +116,16 @@ export class NodeEntriesComponent {
116
116
  reset: true,
117
117
  });
118
118
  }
119
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NodeEntriesGlobalService }, { token: i2.NodeEntriesService }, { token: i3.NodeEntriesTemplatesService }, { token: i4.KeyboardShortcutsService, optional: true }, { token: i5.ActivatedRoute }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
120
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: NodeEntriesComponent, selector: "es-node-entries", viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], ngImport: i0, template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 0;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i8.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: i9.NodeEntriesCardGridComponent, selector: "es-node-entries-card-grid", inputs: ["displayType"] }, { kind: "component", type: i10.NodeEntriesTableComponent, selector: "es-node-entries-table" }] }); }
119
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NodeEntriesGlobalService }, { token: i2.NodeEntriesService }, { token: i3.NodeEntriesTemplatesService }, { token: i4.KeyboardShortcutsService, optional: true }, { token: i5.ActivatedRoute }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
120
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: NodeEntriesComponent, selector: "es-node-entries", viewQueries: [{ propertyName: "paginator", first: true, predicate: MatPaginator, descendants: true }], ngImport: i0, template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 10px;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i8.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }, { kind: "component", type: i9.NodeEntriesCardGridComponent, selector: "es-node-entries-card-grid", inputs: ["displayType"] }, { kind: "component", type: i10.NodeEntriesTableComponent, selector: "es-node-entries-table" }] }); }
121
121
  }
122
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesComponent, decorators: [{
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesComponent, decorators: [{
123
123
  type: Component,
124
- args: [{ selector: 'es-node-entries', template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 0;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"] }]
125
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NodeEntriesGlobalService }, { type: i2.NodeEntriesService }, { type: i3.NodeEntriesTemplatesService }, { type: i4.KeyboardShortcutsService, decorators: [{
124
+ args: [{ selector: 'es-node-entries', template: "<div class=\"top-matter\">\n <div class=\"title\">\n <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n <es-node-entries-table></es-node-entries-table>\n </ng-container>\n <ng-container\n *ngIf=\"\n entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n entriesService.displayType === NodeEntriesDisplayType.Grid\n \"\n >\n <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n </es-node-entries-card-grid>\n </ng-container>\n <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n </ng-container>\n</ng-container>\n<mat-paginator\n #paginator\n [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n [class.display-none]=\"\n (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n entriesService.dataSource.isEmpty()\n \"\n (page)=\"openPage($event)\"\n></mat-paginator>\n", styles: [".top-matter{display:flex;align-items:center;flex-wrap:wrap;gap:12px 10px;position:relative;z-index:1}.top-matter .title{display:flex;flex-grow:1}\n"] }]
125
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.NodeEntriesGlobalService }, { type: i2.NodeEntriesService }, { type: i3.NodeEntriesTemplatesService }, { type: i4.KeyboardShortcutsService, decorators: [{
126
126
  type: Optional
127
- }] }, { type: i5.ActivatedRoute }, { type: i6.TranslateService }]; }, propDecorators: { paginator: [{
127
+ }] }, { type: i5.ActivatedRoute }, { type: i6.TranslateService }], propDecorators: { paginator: [{
128
128
  type: ViewChild,
129
129
  args: [MatPaginator]
130
130
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.ts","../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewChild,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { ActivatedRoute } from '@angular/router';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject } from 'rxjs';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { NodeEntriesDataType, NodeEntriesDisplayType } from './entries-model';\nimport { NodeEntriesGlobalService } from './node-entries-global.service';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesService } from '../services/node-entries.service';\nimport { Node, GenericAuthority } from 'ngx-edu-sharing-api';\nimport { KeyboardShortcutsService } from '../services/abstract/keyboard-shortcuts.service';\nimport { NodeDataSourceRemote } from './node-data-source-remote';\n\n@Component({\n    selector: 'es-node-entries',\n    templateUrl: 'node-entries.component.html',\n    styleUrls: ['node-entries.component.scss'],\n})\nexport class NodeEntriesComponent<T extends NodeEntriesDataType>\n    implements OnInit, AfterViewInit, OnDestroy\n{\n    readonly NodeEntriesDisplayType = NodeEntriesDisplayType;\n\n    @ViewChild(MatPaginator) paginator: MatPaginator;\n\n    private readonly destroyed = new Subject<void>();\n\n    constructor(\n        public changeDetectorRef: ChangeDetectorRef,\n        public entriesGlobalService: NodeEntriesGlobalService,\n        public entriesService: NodeEntriesService<T>,\n        public templatesService: NodeEntriesTemplatesService,\n        @Optional() private globalKeyboardShortcuts: KeyboardShortcutsService,\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n    ) {}\n\n    ngOnInit(): void {\n        if (this.entriesService.primaryInstance) {\n            this.registerGlobalKeyboardShortcuts();\n        }\n        if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {\n            // We don't require `sort` to be defined, but if it is set but not yet ready (`null`),\n            // we wait for its value before initializing the data source, so the first request is\n            // sent with the correct sort configuration. That is why we explicitly do not drop\n            // `undefined` with the `first` operator below.\n            this.entriesService.sortSubject\n                .pipe(first((sort) => sort !== null))\n                .subscribe(() =>\n                    this.initRemoteDataSource(\n                        this.entriesService.dataSource as NodeDataSourceRemote<T>,\n                    ),\n                );\n        }\n    }\n\n    ngAfterViewInit() {\n        if (this.paginator) {\n            this.initPaginator(this.paginator);\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    private registerGlobalKeyboardShortcuts() {\n        this.globalKeyboardShortcuts.register(\n            [\n                {\n                    modifiers: ['Ctrl/Cmd'],\n                    keyCode: 'KeyA',\n                    ignoreWhen: (event) =>\n                        // SmallGrid doesn't support selection\n                        this.entriesService.displayType === NodeEntriesDisplayType.SmallGrid,\n                    callback: () => this.entriesService.toggleSelectAll(),\n                },\n            ],\n            { until: this.destroyed },\n        );\n    }\n\n    private initRemoteDataSource(dataSource: NodeDataSourceRemote<T>): void {\n        const pageSize = this.entriesGlobalService.getPaginatorSizeOptions(\n            this.entriesService.scope,\n        )[0];\n        dataSource.init({\n            paginationConfig: {\n                defaultPageSize: pageSize,\n                strategy: this.entriesService.paginationStrategy,\n            },\n            defaultSort: this.entriesService.sort,\n        });\n        if (this.entriesService.primaryInstance) {\n            // Automatic query-params handling is only supported by node-data-source-remote.\n            dataSource.registerQueryParameters(this.route);\n        }\n    }\n\n    private async initPaginator(paginator: MatPaginator) {\n        paginator._intl.itemsPerPageLabel = await this.translate\n            .get('PAGINATOR.itemsPerPageLabel')\n            .toPromise();\n        paginator._intl.nextPageLabel = await this.translate\n            .get('PAGINATOR.nextPageLabel')\n            .toPromise();\n        paginator._intl.previousPageLabel = await this.translate\n            .get('PAGINATOR.previousPageLabel')\n            .toPromise();\n        paginator._intl.getRangeLabel = (page, pageSize, length) =>\n            this.translate.instant('PAGINATOR.getRangeLabel', {\n                page: page + 1,\n                pageSize,\n                length,\n                pageCount: Math.ceil(length / pageSize),\n            });\n        // Connect data source.\n        this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe((dataSource) => {\n            if (dataSource instanceof NodeDataSourceRemote) {\n                (dataSource as NodeDataSourceRemote).paginator = paginator;\n            } else {\n                paginator.length = dataSource?.getTotal();\n                dataSource\n                    ?.connectPagination()\n                    .pipe(takeUntil(this.destroyed))\n                    .subscribe(() => {\n                        paginator.length = dataSource.getTotal();\n                    });\n            }\n        });\n    }\n\n    openPage(page: PageEvent) {\n        this.entriesService.fetchData.emit({\n            offset: page.pageIndex * page.pageSize,\n            amount: page.pageSize,\n            reset: true,\n        });\n    }\n}\n","<div class=\"top-matter\">\n  <div class=\"title\">\n    <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n  </div>\n  <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n  <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n    <es-node-entries-table></es-node-entries-table>\n  </ng-container>\n  <ng-container\n    *ngIf=\"\n      entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n      entriesService.displayType === NodeEntriesDisplayType.Grid\n    \"\n  >\n    <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n    </es-node-entries-card-grid>\n  </ng-container>\n  <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n    <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n  </ng-container>\n</ng-container>\n<mat-paginator\n  #paginator\n  [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n  *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n  [class.display-none]=\"\n    (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n    entriesService.dataSource.isEmpty()\n  \"\n  (page)=\"openPage($event)\"\n></mat-paginator>\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-entries.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.ts","../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-entries.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewChild,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { ActivatedRoute } from '@angular/router';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject } from 'rxjs';\nimport { first, takeUntil } from 'rxjs/operators';\nimport { NodeEntriesDataType, NodeEntriesDisplayType } from './entries-model';\nimport { NodeEntriesGlobalService } from './node-entries-global.service';\nimport { NodeEntriesTemplatesService } from './node-entries-templates.service';\nimport { NodeEntriesService } from '../services/node-entries.service';\nimport { Node, GenericAuthority } from 'ngx-edu-sharing-api';\nimport { KeyboardShortcutsService } from '../services/abstract/keyboard-shortcuts.service';\nimport { NodeDataSourceRemote } from './node-data-source-remote';\n\n@Component({\n    selector: 'es-node-entries',\n    templateUrl: 'node-entries.component.html',\n    styleUrls: ['node-entries.component.scss'],\n})\nexport class NodeEntriesComponent<T extends NodeEntriesDataType>\n    implements OnInit, AfterViewInit, OnDestroy\n{\n    readonly NodeEntriesDisplayType = NodeEntriesDisplayType;\n\n    @ViewChild(MatPaginator) paginator: MatPaginator;\n\n    private readonly destroyed = new Subject<void>();\n\n    constructor(\n        public changeDetectorRef: ChangeDetectorRef,\n        public entriesGlobalService: NodeEntriesGlobalService,\n        public entriesService: NodeEntriesService<T>,\n        public templatesService: NodeEntriesTemplatesService,\n        @Optional() private globalKeyboardShortcuts: KeyboardShortcutsService,\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n    ) {}\n\n    ngOnInit(): void {\n        if (this.entriesService.primaryInstance) {\n            this.registerGlobalKeyboardShortcuts();\n        }\n        if (this.entriesService.dataSource instanceof NodeDataSourceRemote) {\n            // We don't require `sort` to be defined, but if it is set but not yet ready (`null`),\n            // we wait for its value before initializing the data source, so the first request is\n            // sent with the correct sort configuration. That is why we explicitly do not drop\n            // `undefined` with the `first` operator below.\n            this.entriesService.sortSubject\n                .pipe(first((sort) => sort !== null))\n                .subscribe(() =>\n                    this.initRemoteDataSource(\n                        this.entriesService.dataSource as NodeDataSourceRemote<T>,\n                    ),\n                );\n        }\n    }\n\n    ngAfterViewInit() {\n        if (this.paginator) {\n            this.initPaginator(this.paginator);\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroyed.next();\n        this.destroyed.complete();\n    }\n\n    private registerGlobalKeyboardShortcuts() {\n        this.globalKeyboardShortcuts.register(\n            [\n                {\n                    modifiers: ['Ctrl/Cmd'],\n                    keyCode: 'KeyA',\n                    ignoreWhen: (event) =>\n                        // SmallGrid doesn't support selection\n                        this.entriesService.displayType === NodeEntriesDisplayType.SmallGrid,\n                    callback: () => this.entriesService.toggleSelectAll(),\n                },\n            ],\n            { until: this.destroyed },\n        );\n    }\n\n    private initRemoteDataSource(dataSource: NodeDataSourceRemote<T>): void {\n        const pageSize = this.entriesGlobalService.getPaginatorSizeOptions(\n            this.entriesService.scope,\n        )[0];\n        dataSource.init({\n            paginationConfig: {\n                defaultPageSize: pageSize,\n                strategy: this.entriesService.paginationStrategy,\n            },\n            defaultSort: this.entriesService.sort,\n        });\n        if (this.entriesService.primaryInstance) {\n            // Automatic query-params handling is only supported by node-data-source-remote.\n            dataSource.registerQueryParameters(this.route);\n        }\n    }\n\n    private async initPaginator(paginator: MatPaginator) {\n        paginator._intl.itemsPerPageLabel = await this.translate\n            .get('PAGINATOR.itemsPerPageLabel')\n            .toPromise();\n        paginator._intl.nextPageLabel = await this.translate\n            .get('PAGINATOR.nextPageLabel')\n            .toPromise();\n        paginator._intl.previousPageLabel = await this.translate\n            .get('PAGINATOR.previousPageLabel')\n            .toPromise();\n        paginator._intl.getRangeLabel = (page, pageSize, length) =>\n            this.translate.instant('PAGINATOR.getRangeLabel', {\n                page: page + 1,\n                pageSize,\n                length,\n                pageCount: Math.ceil(length / pageSize),\n            });\n        // Connect data source.\n        this.entriesService.dataSource$.pipe(takeUntil(this.destroyed)).subscribe((dataSource) => {\n            if (dataSource instanceof NodeDataSourceRemote) {\n                (dataSource as NodeDataSourceRemote).paginator = paginator;\n            } else {\n                paginator.length = dataSource?.getTotal();\n                dataSource\n                    ?.connectPagination()\n                    .pipe(takeUntil(this.destroyed))\n                    .subscribe(() => {\n                        paginator.length = dataSource.getTotal();\n                    });\n            }\n        });\n    }\n\n    openPage(page: PageEvent) {\n        this.entriesService.fetchData.emit({\n            offset: page.pageIndex * page.pageSize,\n            amount: page.pageSize,\n            reset: true,\n        });\n    }\n}\n","<div class=\"top-matter\">\n  <div class=\"title\">\n    <ng-container *ngTemplateOutlet=\"templatesService.title\"></ng-container>\n  </div>\n  <ng-container *ngTemplateOutlet=\"templatesService.entriesTopMatter\"></ng-container>\n</div>\n<ng-container *ngIf=\"entriesService.dataSource\">\n  <ng-container *ngIf=\"entriesService.displayType === NodeEntriesDisplayType.Table\">\n    <es-node-entries-table></es-node-entries-table>\n  </ng-container>\n  <ng-container\n    *ngIf=\"\n      entriesService.displayType === NodeEntriesDisplayType.SmallGrid ||\n      entriesService.displayType === NodeEntriesDisplayType.Grid\n    \"\n  >\n    <es-node-entries-card-grid [displayType]=\"entriesService.displayType\">\n    </es-node-entries-card-grid>\n  </ng-container>\n  <ng-container *ngIf=\"entriesService.dataSource.isEmpty() && !entriesService.dataSource.isLoading\">\n    <ng-container *ngTemplateOutlet=\"templatesService.empty\"></ng-container>\n  </ng-container>\n</ng-container>\n<mat-paginator\n  #paginator\n  [pageSizeOptions]=\"entriesGlobalService.getPaginatorSizeOptions(entriesService.scope)\"\n  *ngIf=\"entriesService.paginationStrategy === 'paginator'\"\n  [class.display-none]=\"\n    (entriesService.dataSource.isLoading && entriesService.dataSource.isLoading !== 'page') ||\n    entriesService.dataSource.isEmpty()\n  \"\n  (page)=\"openPage($event)\"\n></mat-paginator>\n"]}
@@ -38,8 +38,8 @@ import { PreviewImageComponent } from './preview-image/preview-image.component';
38
38
  import { SortSelectPanelComponent } from './sort-select-panel/sort-select-panel.component';
39
39
  import * as i0 from "@angular/core";
40
40
  export class NodeEntriesModule {
41
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
42
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesModule, declarations: [ColumnChooserComponent,
41
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
42
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesModule, declarations: [ColumnChooserComponent,
43
43
  DragPreviewComponent,
44
44
  ListItemLabelPipe,
45
45
  NodeEntriesCardComponent,
@@ -82,7 +82,7 @@ export class NodeEntriesModule {
82
82
  NodesDragSourceDirective,
83
83
  NodesDropTargetDirective,
84
84
  ListItemLabelPipe] }); }
85
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesModule, imports: [CommonModule,
85
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesModule, imports: [CommonModule,
86
86
  FormsModule,
87
87
  A11yModule,
88
88
  OverlayModule,
@@ -102,7 +102,7 @@ export class NodeEntriesModule {
102
102
  MatTooltipModule,
103
103
  TranslateModule] }); }
104
104
  }
105
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeEntriesModule, decorators: [{
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeEntriesModule, decorators: [{
106
106
  type: NgModule,
107
107
  args: [{
108
108
  declarations: [
@@ -11,14 +11,13 @@ import * as i5 from "@angular/material/button";
11
11
  import * as i6 from "@angular/material/tooltip";
12
12
  import * as i7 from "@ngx-translate/core";
13
13
  export class NodeRatingComponent {
14
- constructor(toast, configService, networkApi, authenticationService, changeDetectorRef) {
14
+ constructor(toast, configService, networkApi, authenticationService, changeDetectorRef, ratingService) {
15
15
  this.toast = toast;
16
16
  this.configService = configService;
17
17
  this.networkApi = networkApi;
18
18
  this.authenticationService = authenticationService;
19
19
  this.changeDetectorRef = changeDetectorRef;
20
- // @TODO
21
- this.ratingService = {};
20
+ this.ratingService = ratingService;
22
21
  }
23
22
  async ngOnInit() {
24
23
  await this.configService.observeConfig().pipe(take(1)).toPromise();
@@ -29,7 +28,12 @@ export class NodeRatingComponent {
29
28
  const name = RestHelper.getTitle(this.node);
30
29
  if (this.node.rating?.user) {
31
30
  try {
32
- await this.ratingService.deleteNodeRating(this.node.ref.id).toPromise();
31
+ await this.ratingService
32
+ .deleteRating({
33
+ repository: this.node.ref.repo,
34
+ node: this.node.ref.id,
35
+ })
36
+ .toPromise();
33
37
  this.toast.toast('RATING.TOAST.LIKE_REMOVED', { name });
34
38
  this.node.rating.user = 0;
35
39
  this.node.rating.overall.count--;
@@ -40,7 +44,14 @@ export class NodeRatingComponent {
40
44
  }
41
45
  else {
42
46
  try {
43
- await this.ratingService.updateNodeRating(this.node.ref.id, 5).toPromise();
47
+ await this.ratingService
48
+ .addOrUpdateRating({
49
+ repository: this.node.ref.repo,
50
+ node: this.node.ref.id,
51
+ rating: 5,
52
+ body: null,
53
+ })
54
+ .toPromise();
44
55
  this.toast.toast('RATING.TOAST.LIKED', { name });
45
56
  this.node.rating.user = 5;
46
57
  this.node.rating.overall.count++;
@@ -63,7 +74,14 @@ export class NodeRatingComponent {
63
74
  async setRating(rating) {
64
75
  const name = RestHelper.getTitle(this.node);
65
76
  try {
66
- await this.ratingService.updateNodeRating(this.node.ref.id, rating).toPromise();
77
+ await this.ratingService
78
+ .addOrUpdateRating({
79
+ repository: this.node.ref.repo,
80
+ node: this.node.ref.id,
81
+ rating,
82
+ body: null,
83
+ })
84
+ .toPromise();
67
85
  this.toast.toast('RATING.TOAST.RATED', { name, rating });
68
86
  this.node.rating.overall.count += this.node.rating.user ? 0 : 1;
69
87
  this.node.rating.user = rating;
@@ -76,7 +94,12 @@ export class NodeRatingComponent {
76
94
  async deleteRating() {
77
95
  const name = RestHelper.getTitle(this.node);
78
96
  try {
79
- await this.ratingService.deleteNodeRating(this.node.ref.id).toPromise();
97
+ await this.ratingService
98
+ .deleteRating({
99
+ repository: this.node.ref.repo,
100
+ node: this.node.ref.id,
101
+ })
102
+ .toPromise();
80
103
  this.toast.toast('RATING.TOAST.RATING_REMOVED', { name });
81
104
  this.node.rating.overall.count--;
82
105
  this.node.rating.overall.sum -= this.node.rating.user;
@@ -90,13 +113,13 @@ export class NodeRatingComponent {
90
113
  isFromHomeRepo(node) {
91
114
  return this.networkApi.isFromHomeRepository(node);
92
115
  }
93
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeRatingComponent, deps: [{ token: i1.Toast }, { token: i2.ConfigService }, { token: i2.NetworkService }, { token: i2.AuthenticationService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
94
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: NodeRatingComponent, selector: "es-node-rating", inputs: { node: "node" }, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mat-icon-button.mat-primary{color:var(--textLight)}.mat-icon-button.mat-primary.star,.mat-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mat-icon-button.mat-primary.star ::ng-deep i,.mat-icon-button.mat-primary.delete ::ng-deep i{font-size:17px;line-height:1}.mat-icon-button.mat-primary.star.star-hover,.mat-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
116
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeRatingComponent, deps: [{ token: i1.Toast }, { token: i2.ConfigService }, { token: i2.NetworkService }, { token: i2.AuthenticationService }, { token: i0.ChangeDetectorRef }, { token: i2.RatingV1Service }], target: i0.ɵɵFactoryTarget.Component }); }
117
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: NodeRatingComponent, selector: "es-node-rating", inputs: { node: "node" }, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mdc-icon-button.mat-primary{color:var(--textLight);display:flex;align-items:center;padding:0}.mdc-icon-button.mat-primary.star,.mdc-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mdc-icon-button.mat-primary.star i,.mdc-icon-button.mat-primary.delete i{font-size:17px;line-height:1}.mdc-icon-button.mat-primary.star ::ng-deep .mat-mdc-button-touch-target,.mdc-icon-button.mat-primary.delete ::ng-deep .mat-mdc-button-touch-target{display:none}.mdc-icon-button.mat-primary.star.star-hover,.mdc-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
95
118
  }
96
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: NodeRatingComponent, decorators: [{
119
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeRatingComponent, decorators: [{
97
120
  type: Component,
98
- args: [{ selector: 'es-node-rating', template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mat-icon-button.mat-primary{color:var(--textLight)}.mat-icon-button.mat-primary.star,.mat-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mat-icon-button.mat-primary.star ::ng-deep i,.mat-icon-button.mat-primary.delete ::ng-deep i{font-size:17px;line-height:1}.mat-icon-button.mat-primary.star.star-hover,.mat-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"] }]
99
- }], ctorParameters: function () { return [{ type: i1.Toast }, { type: i2.ConfigService }, { type: i2.NetworkService }, { type: i2.AuthenticationService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { node: [{
121
+ args: [{ selector: 'es-node-rating', template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mdc-icon-button.mat-primary{color:var(--textLight);display:flex;align-items:center;padding:0}.mdc-icon-button.mat-primary.star,.mdc-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mdc-icon-button.mat-primary.star i,.mdc-icon-button.mat-primary.delete i{font-size:17px;line-height:1}.mdc-icon-button.mat-primary.star ::ng-deep .mat-mdc-button-touch-target,.mdc-icon-button.mat-primary.delete ::ng-deep .mat-mdc-button-touch-target{display:none}.mdc-icon-button.mat-primary.star.star-hover,.mdc-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"] }]
122
+ }], ctorParameters: () => [{ type: i1.Toast }, { type: i2.ConfigService }, { type: i2.NetworkService }, { type: i2.AuthenticationService }, { type: i0.ChangeDetectorRef }, { type: i2.RatingV1Service }], propDecorators: { node: [{
100
123
  type: Input
101
124
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-rating.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';\nimport {\n    Node,\n    ConfigService,\n    AuthenticationService,\n    RestConstants,\n    NetworkService,\n} from 'ngx-edu-sharing-api';\nimport { Toast } from '../../services/abstract/toast.service';\nimport { take, takeUntil } from 'rxjs/operators';\nimport { RestHelper } from '../../util/rest-helper';\n@Component({\n    selector: 'es-node-rating',\n    templateUrl: 'node-rating.component.html',\n    styleUrls: ['node-rating.component.scss'],\n})\nexport class NodeRatingComponent<T extends Node> implements OnInit {\n    // @TODO\n    ratingService: any = {};\n    @Input() node: T;\n    mode: RatingMode;\n    hasPermission: boolean;\n    hoverStar: number;\n    constructor(\n        public toast: Toast,\n        public configService: ConfigService,\n        private networkApi: NetworkService,\n        public authenticationService: AuthenticationService,\n        public changeDetectorRef: ChangeDetectorRef, // @TODO // public ratingService: RestRatingService,\n    ) {}\n\n    async ngOnInit() {\n        await this.configService.observeConfig().pipe(take(1)).toPromise();\n        this.mode = this.configService.instant('rating.mode', 'none');\n        this.hasPermission = await this.authenticationService.hasToolpermission(\n            RestConstants.TOOLPERMISSION_RATE_READ,\n        );\n    }\n\n    async toogleLike() {\n        const name = RestHelper.getTitle(this.node);\n        if (this.node.rating?.user) {\n            try {\n                await this.ratingService.deleteNodeRating(this.node.ref.id).toPromise();\n                this.toast.toast('RATING.TOAST.LIKE_REMOVED', { name });\n                this.node.rating.user = 0;\n                this.node.rating.overall.count--;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        } else {\n            try {\n                await this.ratingService.updateNodeRating(this.node.ref.id, 5).toPromise();\n                this.toast.toast('RATING.TOAST.LIKED', { name });\n                this.node.rating.user = 5;\n                this.node.rating.overall.count++;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    getPrimaryRating() {\n        if (!this.node.rating) {\n            return 0;\n        }\n        if (this.node.rating.user) {\n            return this.node.rating.user;\n        }\n        return this.node.rating.overall.sum / this.node.rating.overall.count;\n    }\n\n    async setRating(rating: number) {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService.updateNodeRating(this.node.ref.id, rating).toPromise();\n            this.toast.toast('RATING.TOAST.RATED', { name, rating });\n            this.node.rating.overall.count += this.node.rating.user ? 0 : 1;\n            this.node.rating.user = rating;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    async deleteRating() {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService.deleteNodeRating(this.node.ref.id).toPromise();\n            this.toast.toast('RATING.TOAST.RATING_REMOVED', { name });\n            this.node.rating.overall.count--;\n            this.node.rating.overall.sum -= this.node.rating.user;\n            this.node.rating.user = 0;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    isFromHomeRepo(node: Node) {\n        return this.networkApi.isFromHomeRepository(node);\n    }\n}\nexport type RatingMode = 'none' | 'likes' | 'stars';\n","<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n  <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n    <button\n      (click)=\"toogleLike()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      mat-icon-button\n      color=\"primary\"\n      matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n    >\n      <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n      node.rating?.overall.count\n    }}</span>\n  </div>\n  <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n    <button\n      *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"star\"\n      (click)=\"setRating(rating)\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      (focus)=\"hoverStar = rating\"\n      (mouseenter)=\"hoverStar = rating\"\n      (mouseleave)=\"hoverStar = 0\"\n      (blur)=\"hoverStar = 0\"\n      [class.star-hover]=\"hoverStar >= rating\"\n    >\n      <i\n        [esIcon]=\"\n          'star' +\n          ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n        \"\n        matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n      ></i>\n    </button>\n    <button\n      *ngIf=\"!!node.rating?.user\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"delete\"\n      matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n      (click)=\"deleteRating()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n    >\n      <i esIcon=\"clear\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n      >({{ node.rating?.overall.count }})</span\n    >\n  </div>\n</ng-container>\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-rating.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';\nimport {\n    Node,\n    ConfigService,\n    AuthenticationService,\n    RestConstants,\n    NetworkService,\n    RatingV1Service,\n} from 'ngx-edu-sharing-api';\nimport { Toast } from '../../services/abstract/toast.service';\nimport { take, takeUntil } from 'rxjs/operators';\nimport { RestHelper } from '../../util/rest-helper';\n\n@Component({\n    selector: 'es-node-rating',\n    templateUrl: 'node-rating.component.html',\n    styleUrls: ['node-rating.component.scss'],\n})\nexport class NodeRatingComponent<T extends Node> implements OnInit {\n    @Input() node: T;\n    mode: RatingMode;\n    hasPermission: boolean;\n    hoverStar: number;\n    constructor(\n        public toast: Toast,\n        public configService: ConfigService,\n        private networkApi: NetworkService,\n        public authenticationService: AuthenticationService,\n        public changeDetectorRef: ChangeDetectorRef,\n        public ratingService: RatingV1Service,\n    ) {}\n\n    async ngOnInit() {\n        await this.configService.observeConfig().pipe(take(1)).toPromise();\n        this.mode = this.configService.instant('rating.mode', 'none');\n        this.hasPermission = await this.authenticationService.hasToolpermission(\n            RestConstants.TOOLPERMISSION_RATE_READ,\n        );\n    }\n\n    async toogleLike() {\n        const name = RestHelper.getTitle(this.node);\n        if (this.node.rating?.user) {\n            try {\n                await this.ratingService\n                    .deleteRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKE_REMOVED', { name });\n                this.node.rating.user = 0;\n                this.node.rating.overall.count--;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        } else {\n            try {\n                await this.ratingService\n                    .addOrUpdateRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                        rating: 5,\n                        body: null,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKED', { name });\n                this.node.rating.user = 5;\n                this.node.rating.overall.count++;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    getPrimaryRating() {\n        if (!this.node.rating) {\n            return 0;\n        }\n        if (this.node.rating.user) {\n            return this.node.rating.user;\n        }\n        return this.node.rating.overall.sum / this.node.rating.overall.count;\n    }\n\n    async setRating(rating: number) {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .addOrUpdateRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                    rating,\n                    body: null,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATED', { name, rating });\n            this.node.rating.overall.count += this.node.rating.user ? 0 : 1;\n            this.node.rating.user = rating;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    async deleteRating() {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .deleteRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATING_REMOVED', { name });\n            this.node.rating.overall.count--;\n            this.node.rating.overall.sum -= this.node.rating.user;\n            this.node.rating.user = 0;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    isFromHomeRepo(node: Node) {\n        return this.networkApi.isFromHomeRepository(node);\n    }\n}\nexport type RatingMode = 'none' | 'likes' | 'stars';\n","<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n  <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n    <button\n      (click)=\"toogleLike()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      mat-icon-button\n      color=\"primary\"\n      matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n    >\n      <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n      node.rating?.overall.count\n    }}</span>\n  </div>\n  <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n    <button\n      *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"star\"\n      (click)=\"setRating(rating)\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      (focus)=\"hoverStar = rating\"\n      (mouseenter)=\"hoverStar = rating\"\n      (mouseleave)=\"hoverStar = 0\"\n      (blur)=\"hoverStar = 0\"\n      [class.star-hover]=\"hoverStar >= rating\"\n    >\n      <i\n        [esIcon]=\"\n          'star' +\n          ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n        \"\n        matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n      ></i>\n    </button>\n    <button\n      *ngIf=\"!!node.rating?.user\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"delete\"\n      matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n      (click)=\"deleteRating()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n    >\n      <i esIcon=\"clear\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n      >({{ node.rating?.overall.count }})</span\n    >\n  </div>\n</ng-container>\n"]}