ngx-edu-sharing-ui 9.0.2 → 9.1.2

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 (88) hide show
  1. package/esm2022/lib/actionbar/actionbar.component.mjs +33 -18
  2. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +73 -62
  3. package/esm2022/lib/directives/check-text-overflow.directive.mjs +8 -2
  4. package/esm2022/lib/directives/icon.directive.mjs +38 -14
  5. package/esm2022/lib/directives/infinite-scroll.directive.mjs +85 -0
  6. package/esm2022/lib/dropdown/dropdown.component.mjs +17 -10
  7. package/esm2022/lib/edu-sharing-ui-configuration.mjs +8 -1
  8. package/esm2022/lib/edu-sharing-ui.module.mjs +5 -1
  9. package/esm2022/lib/list-items/list-base/list-base.component.mjs +6 -6
  10. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +3 -1
  11. package/esm2022/lib/list-items/list-text/list-text.component.mjs +17 -17
  12. package/esm2022/lib/mds/mds-helper.service.mjs +167 -0
  13. package/esm2022/lib/mds/mds.module.mjs +16 -0
  14. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +3 -3
  15. package/esm2022/lib/node-entries/entries-model.mjs +2 -1
  16. package/esm2022/lib/node-entries/node-cache.mjs +9 -1
  17. package/esm2022/lib/node-entries/node-data-source.mjs +4 -2
  18. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +16 -12
  19. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +37 -22
  20. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +5 -5
  21. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +7 -3
  22. package/esm2022/lib/node-entries/node-entries-global.service.mjs +14 -1
  23. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +3 -3
  24. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +45 -34
  25. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +17 -5
  26. package/esm2022/lib/node-entries/node-entries.component.mjs +2 -2
  27. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +35 -12
  28. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +24 -11
  29. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +3 -3
  30. package/esm2022/lib/node-url/node-url.component.mjs +7 -3
  31. package/esm2022/lib/pipes/file-size.pipe.mjs +6 -5
  32. package/esm2022/lib/pipes/node-title.pipe.mjs +7 -1
  33. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +3 -3
  34. package/esm2022/lib/pipes/property-slug.pipe.mjs +16 -0
  35. package/esm2022/lib/services/abstract/options-helper.service.mjs +1 -1
  36. package/esm2022/lib/services/app-container.service.mjs +66 -0
  37. package/esm2022/lib/services/node-entries.service.mjs +47 -3
  38. package/esm2022/lib/services/node-helper.service.mjs +38 -12
  39. package/esm2022/lib/services/options-helper-data.service.mjs +5 -5
  40. package/esm2022/lib/services/repo-url.service.mjs +2 -1
  41. package/esm2022/lib/services/ui.service.mjs +22 -1
  42. package/esm2022/lib/spinner/spinner.component.mjs +4 -3
  43. package/esm2022/lib/translations/translation-loader.mjs +48 -14
  44. package/esm2022/lib/translations/translations.module.mjs +15 -4
  45. package/esm2022/lib/translations/translations.service.mjs +25 -7
  46. package/esm2022/lib/types/injection-tokens.mjs +9 -0
  47. package/esm2022/lib/types/option-item.mjs +9 -3
  48. package/esm2022/module.mjs +51 -43
  49. package/fesm2022/ngx-edu-sharing-ui.mjs +4595 -3931
  50. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  51. package/lib/actionbar/actionbar.component.d.ts +13 -3
  52. package/lib/common/edu-sharing-ui-common.module.d.ts +27 -25
  53. package/lib/directives/icon.directive.d.ts +6 -4
  54. package/lib/directives/infinite-scroll.directive.d.ts +22 -0
  55. package/lib/dropdown/dropdown.component.d.ts +6 -3
  56. package/lib/edu-sharing-ui-configuration.d.ts +5 -0
  57. package/lib/edu-sharing-ui.module.d.ts +7 -6
  58. package/lib/list-items/list-widget.d.ts +1 -1
  59. package/lib/mds/mds-helper.service.d.ts +37 -0
  60. package/lib/mds/mds.module.d.ts +6 -0
  61. package/lib/node-entries/entries-model.d.ts +3 -2
  62. package/lib/node-entries/node-data-source.d.ts +1 -1
  63. package/lib/node-entries/node-entries-card/node-entries-card.component.d.ts +2 -2
  64. package/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.d.ts +6 -1
  65. package/lib/node-entries/node-entries-global-options/node-entries-global-options.component.d.ts +1 -0
  66. package/lib/node-entries/node-entries-global.service.d.ts +7 -0
  67. package/lib/node-entries/node-entries-table/node-entries-table.component.d.ts +4 -1
  68. package/lib/node-entries/node-entries-wrapper.component.d.ts +8 -3
  69. package/lib/node-entries/node-rating/node-rating.component.d.ts +3 -3
  70. package/lib/node-entries/option-button/option-button.component.d.ts +8 -3
  71. package/lib/pipes/node-title.pipe.d.ts +2 -1
  72. package/lib/pipes/option-tooltip.pipe.d.ts +1 -1
  73. package/lib/pipes/property-slug.pipe.d.ts +7 -0
  74. package/lib/services/abstract/options-helper.service.d.ts +4 -4
  75. package/lib/services/app-container.service.d.ts +43 -0
  76. package/lib/services/node-entries.service.d.ts +31 -6
  77. package/lib/services/node-helper.service.d.ts +7 -5
  78. package/lib/services/options-helper-data.service.d.ts +6 -6
  79. package/lib/services/ui.service.d.ts +15 -2
  80. package/lib/spinner/spinner.component.d.ts +1 -1
  81. package/lib/translations/translation-loader.d.ts +2 -1
  82. package/lib/translations/translations.service.d.ts +5 -2
  83. package/lib/types/injection-tokens.d.ts +8 -0
  84. package/lib/types/option-item.d.ts +10 -6
  85. package/module.d.ts +50 -42
  86. package/package.json +1 -1
  87. package/esm2022/lib/translations/languages.mjs +0 -5
  88. package/lib/translations/languages.d.ts +0 -4
@@ -5,19 +5,22 @@ import { switchMap } from 'rxjs/operators';
5
5
  import { ListItem } from '../../types/list-item';
6
6
  import { ListWidget } from '../list-widget';
7
7
  import * as Constants from 'ngx-edu-sharing-api';
8
+ import { MdsHelperService } from '../../mds/mds-helper.service';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "../../services/node-helper.service";
10
11
  import * as i2 from "ngx-edu-sharing-api";
11
12
  import * as i3 from "@angular/common";
12
- import * as i4 from "@angular/material/tooltip";
13
- import * as i5 from "../../pipes/vcard-name.pipe";
14
- import * as i6 from "../../pipes/file-size.pipe";
15
- import * as i7 from "../../pipes/node-image-size.pipe";
16
- import * as i8 from "../../pipes/node-person-name.pipe";
17
- import * as i9 from "../../pipes/format-date.pipe";
18
- import * as i10 from "@ngx-translate/core";
19
- import * as i11 from "../node-source.pipe";
20
- import * as i12 from "../format-duration.pipe";
13
+ import * as i4 from "../../directives/check-text-overflow.directive";
14
+ import * as i5 from "@angular/material/tooltip";
15
+ import * as i6 from "../list-node-workflow/list-node-workflow.component";
16
+ import * as i7 from "../../pipes/format-date.pipe";
17
+ import * as i8 from "../../pipes/file-size.pipe";
18
+ import * as i9 from "../../pipes/node-image-size.pipe";
19
+ import * as i10 from "../../pipes/node-person-name.pipe";
20
+ import * as i11 from "../../pipes/vcard-name.pipe";
21
+ import * as i12 from "@ngx-translate/core";
22
+ import * as i13 from "../node-source.pipe";
23
+ import * as i14 from "../format-duration.pipe";
21
24
  export class ListTextComponent extends ListWidget {
22
25
  static { this.supportedItems = [
23
26
  new ListItem('NODE', '*'),
@@ -79,13 +82,11 @@ export class ListTextComponent extends ListWidget {
79
82
  : node.properties[this.item.name]?.join(', '));
80
83
  const mds = await this.mds
81
84
  .getMetadataSet({
82
- repository: node.ref?.repo,
85
+ repository: node.ref?.repo || Constants.HOME_REPOSITORY,
83
86
  metadataSet: node.metadataset || Constants.DEFAULT,
84
87
  })
85
88
  .toPromise();
86
- // @TODO
87
- /*
88
- const widget = MdsHelper.getWidget(this.item.name, null, mds.widgets);
89
+ const widget = MdsHelperService.getWidget(this.item.name, null, mds.widgets);
89
90
  if (widget?.values) {
90
91
  const i18n = node.properties[this.item.name]
91
92
  ?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)
@@ -94,13 +95,12 @@ export class ListTextComponent extends ListWidget {
94
95
  this.displayName$.next(i18n.join(', '));
95
96
  }
96
97
  }
97
- */
98
98
  }
99
99
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: ListTextComponent, deps: [{ token: i1.NodeHelperService }, { token: i2.MdsService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
100
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: ListTextComponent, selector: "es-list-text", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile.displayName }}\n </span>\n <span *ngSwitchCase=\"'groupType'\">\n {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile.groupType | translate }}\n </span>\n <span *ngSwitchDefault>\n {{ $any(getNode())[item.name] }}\n </span>\n </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n <span *ngIf=\"isUserProfileAttribute(item.name)\">\n {{ $any(getNode()).profile[item.name] }}\n </span>\n <span *ngIf=\"item.name === 'status'\">\n {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n </span>\n <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n {{ $any(getNode())[item.name] }}\n </span>\n</ng-container>\n<ng-container\n [ngSwitch]=\"item.name\"\n *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n <span *ngSwitchCase=\"'name'\">\n {{ $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'cm:title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'cclom:title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'mediatype'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n </span>\n <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).size | formatSize }}\n </span>\n <span\n *ngSwitchCase=\"'dimensions'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()) | NodeImageSize }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:wf_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n </span>\n <span\n *ngSwitchCase=\"'cm:creator'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).createdBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'cm:modifier'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cm:modifier' | translate }}:</span\n >\n {{ $any(getNode()).modifiedBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:replicationsource'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n >\n {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span *ngSwitchDefault [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.VCardNamePipe, name: "vcardName" }, { kind: "pipe", type: i6.FormatSizePipe, name: "formatSize" }, { kind: "pipe", type: i7.NodeImageSizePipe, name: "NodeImageSize" }, { kind: "pipe", type: i8.NodePersonNamePipe, name: "nodePersonName" }, { kind: "pipe", type: i9.FormatDatePipe, name: "formatDate" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }, { kind: "pipe", type: i11.NodeSourcePipe, name: "appNodeSource" }, { kind: "pipe", type: i12.FormatDurationPipe, name: "formatDuration" }] }); }
100
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: ListTextComponent, selector: "es-list-text", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile?.displayName || $any(getNode()).authorityName }}\n </span>\n <span *ngSwitchCase=\"'groupType'\">\n {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile?.groupType | translate }}\n </span>\n <span *ngSwitchDefault>\n {{ $any(getNode())[item.name] }}\n </span>\n </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n <span *ngIf=\"isUserProfileAttribute(item.name)\">\n {{ $any(getNode()).profile?.[item.name] }}\n </span>\n <span *ngIf=\"item.name === 'status'\">\n {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n </span>\n <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n {{ $any(getNode())[item.name] }}\n </span>\n</ng-container>\n<ng-container\n [ngSwitch]=\"item.name\"\n *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n <span *ngSwitchCase=\"'name'\">\n {{ $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'mediatype'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n </span>\n <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).size | formatSize }}\n </span>\n <span\n *ngSwitchCase=\"'dimensions'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()) | NodeImageSize }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:wf_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <es-list-node-workflow\n [item]=\"item\"\n [node]=\"node\"\n [provideLabel]=\"false\"\n ></es-list-node-workflow>\n <!--<span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}-->\n </span>\n <span\n *ngSwitchCase=\"'cm:creator'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).createdBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'cm:modifier'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cm:modifier' | translate }}:</span\n >\n {{ $any(getNode()).modifiedBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:replicationsource'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n >\n {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span\n *ngSwitchDefault\n esCheckTextOverflow\n #text=\"esCheckTextOverflow\"\n [matTooltip]=\"\n provideLabel ? (getI18n(item) | translate) : text.hasTextOverflow() ? content.innerText : null\n \"\n #content\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container *ngIf=\"['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n {{ $any(getNode()).title || $any(getNode()).name }}\n </ng-container>\n <ng-container *ngIf=\"!['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true, time: true, relative: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}span{display:block}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.CheckTextOverflowDirective, selector: "[esCheckTextOverflow]", inputs: ["esCheckTextOverflow"], exportAs: ["esCheckTextOverflow"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i6.ListNodeWorkflowComponent, selector: "es-list-node-workflow" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.FormatDatePipe, name: "formatDate" }, { kind: "pipe", type: i8.FormatSizePipe, name: "formatSize" }, { kind: "pipe", type: i9.NodeImageSizePipe, name: "NodeImageSize" }, { kind: "pipe", type: i10.NodePersonNamePipe, name: "nodePersonName" }, { kind: "pipe", type: i11.VCardNamePipe, name: "vcardName" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.NodeSourcePipe, name: "appNodeSource" }, { kind: "pipe", type: i14.FormatDurationPipe, name: "formatDuration" }] }); }
101
101
  }
102
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: ListTextComponent, decorators: [{
103
103
  type: Component,
104
- args: [{ selector: 'es-list-text', template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile.displayName }}\n </span>\n <span *ngSwitchCase=\"'groupType'\">\n {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile.groupType | translate }}\n </span>\n <span *ngSwitchDefault>\n {{ $any(getNode())[item.name] }}\n </span>\n </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n <span *ngIf=\"isUserProfileAttribute(item.name)\">\n {{ $any(getNode()).profile[item.name] }}\n </span>\n <span *ngIf=\"item.name === 'status'\">\n {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n </span>\n <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n {{ $any(getNode())[item.name] }}\n </span>\n</ng-container>\n<ng-container\n [ngSwitch]=\"item.name\"\n *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n <span *ngSwitchCase=\"'name'\">\n {{ $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'cm:title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'cclom:title'\"\n [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n >\n {{ $any(getNode()).title || $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'mediatype'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n </span>\n <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).size | formatSize }}\n </span>\n <span\n *ngSwitchCase=\"'dimensions'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()) | NodeImageSize }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:wf_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n </span>\n <span\n *ngSwitchCase=\"'cm:creator'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).createdBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'cm:modifier'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cm:modifier' | translate }}:</span\n >\n {{ $any(getNode()).modifiedBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:replicationsource'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n >\n {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span *ngSwitchDefault [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}\n"] }]
104
+ args: [{ selector: 'es-list-text', template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile?.displayName || $any(getNode()).authorityName }}\n </span>\n <span *ngSwitchCase=\"'groupType'\">\n {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile?.groupType | translate }}\n </span>\n <span *ngSwitchDefault>\n {{ $any(getNode())[item.name] }}\n </span>\n </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n <span *ngIf=\"isUserProfileAttribute(item.name)\">\n {{ $any(getNode()).profile?.[item.name] }}\n </span>\n <span *ngIf=\"item.name === 'status'\">\n {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n </span>\n <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n {{ $any(getNode())[item.name] }}\n </span>\n</ng-container>\n<ng-container\n [ngSwitch]=\"item.name\"\n *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n <span *ngSwitchCase=\"'name'\">\n {{ $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'mediatype'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n </span>\n <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).size | formatSize }}\n </span>\n <span\n *ngSwitchCase=\"'dimensions'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()) | NodeImageSize }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:wf_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <es-list-node-workflow\n [item]=\"item\"\n [node]=\"node\"\n [provideLabel]=\"false\"\n ></es-list-node-workflow>\n <!--<span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}-->\n </span>\n <span\n *ngSwitchCase=\"'cm:creator'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).createdBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'cm:modifier'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cm:modifier' | translate }}:</span\n >\n {{ $any(getNode()).modifiedBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:replicationsource'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n >\n {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span\n *ngSwitchDefault\n esCheckTextOverflow\n #text=\"esCheckTextOverflow\"\n [matTooltip]=\"\n provideLabel ? (getI18n(item) | translate) : text.hasTextOverflow() ? content.innerText : null\n \"\n #content\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container *ngIf=\"['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n {{ $any(getNode()).title || $any(getNode()).name }}\n </ng-container>\n <ng-container *ngIf=\"!['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true, time: true, relative: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}span{display:block}\n"] }]
105
105
  }], ctorParameters: function () { return [{ type: i1.NodeHelperService }, { type: i2.MdsService }, { type: i0.ChangeDetectorRef }]; } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-text.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit, SimpleChanges } from '@angular/core';\nimport { MdsService, Node, Organization, RestConstants, ProposalNode } from 'ngx-edu-sharing-api';\nimport { BehaviorSubject, merge } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { ListItem } from '../../types/list-item';\nimport { ListWidget } from '../list-widget';\nimport { NodeHelperService } from '../../services/node-helper.service';\nimport * as Constants from 'ngx-edu-sharing-api';\n\n@Component({\n    selector: 'es-list-text',\n    templateUrl: './list-text.component.html',\n    styleUrls: ['./list-text.component.scss'],\n})\nexport class ListTextComponent extends ListWidget implements OnInit {\n    static supportedItems = [\n        new ListItem('NODE', '*'),\n        new ListItem('NODE_PROPOSAL', '*'),\n        new ListItem('COLLECTION', '*'),\n        new ListItem('ORG', '*'),\n        new ListItem('GROUP', '*'),\n        new ListItem('USER', '*'),\n    ];\n    readonly DATE_FIELDS = RestConstants.DATE_FIELDS;\n    readonly VCARD_FIELDS = RestConstants.getAllVCardFields();\n    displayName$ = new BehaviorSubject<string>(null);\n\n    constructor(\n        private nodeHelper: NodeHelperService,\n        private mds: MdsService,\n        private changeDetectorRef: ChangeDetectorRef,\n    ) {\n        super();\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {}\n\n    async ngOnInit() {\n        merge([this.nodeSubject, this.itemSubject])\n            .pipe(switchMap(() => this.updateDisplayname()))\n            .subscribe((displayName) => {});\n    }\n    getNode() {\n        if (this.item.type === 'NODE_PROPOSAL') {\n            return (this.node as ProposalNode).proposal || this.node;\n        } else if ((this.node as Node).type === RestConstants.CCM_TYPE_COLLECTION_PROPOSAL) {\n            return (this.node as Node).relations?.Original ?? this.node;\n        }\n        return this.node;\n    }\n\n    isUserProfileAttribute(attribute: string) {\n        return (\n            [\n                RestConstants.AUTHORITY_FIRSTNAME,\n                RestConstants.AUTHORITY_LASTNAME,\n                RestConstants.AUTHORITY_EMAIL,\n            ].indexOf(attribute) !== -1\n        );\n    }\n    getWorkflowStatus() {\n        return this.nodeHelper.getWorkflowStatus(this.node as Node).current;\n    }\n\n    getI18n(item: ListItem) {\n        return (item.type === 'NODE_PROPOSAL' ? 'NODE_PROPOSAL' : 'NODE') + '.' + item.name;\n    }\n\n    isDangerousGroup() {\n        return (\n            (this.node as Organization).authorityName ===\n            RestConstants.GROUP_ALFRESCO_ADMINISTRATORS\n        );\n    }\n\n    private async updateDisplayname() {\n        const node = this.getNode() as Node;\n        if (!node.properties) {\n            this.displayName$.next('');\n            return;\n        }\n        this.displayName$.next(\n            node.properties[this.item.name + '_DISPLAYNAME']?.length > 0\n                ? node.properties[this.item.name + '_DISPLAYNAME'].join(', ')\n                : node.properties[this.item.name]?.join(', '),\n        );\n\n        const mds = await this.mds\n            .getMetadataSet({\n                repository: node.ref?.repo,\n                metadataSet: node.metadataset || Constants.DEFAULT,\n            })\n            .toPromise();\n        // @TODO\n        /*\n        const widget = MdsHelper.getWidget(this.item.name, null, mds.widgets);\n        if (widget?.values) {\n            const i18n = node.properties[this.item.name]\n                ?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)\n                .filter((cap) => !!cap);\n            if (i18n) {\n                this.displayName$.next(i18n.join(', '));\n            }\n        }\n         */\n    }\n}\n","<label *ngIf=\"item.config?.showLabel\">\n  {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n  <ng-container [ngSwitch]=\"item.name\">\n    <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n      {{ $any(getNode()).profile.displayName }}\n    </span>\n    <span *ngSwitchCase=\"'groupType'\">\n      {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile.groupType | translate }}\n    </span>\n    <span *ngSwitchDefault>\n      {{ $any(getNode())[item.name] }}\n    </span>\n  </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n  <span *ngIf=\"isUserProfileAttribute(item.name)\">\n    {{ $any(getNode()).profile[item.name] }}\n  </span>\n  <span *ngIf=\"item.name === 'status'\">\n    {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n  </span>\n  <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n    {{ $any(getNode())[item.name] }}\n  </span>\n</ng-container>\n<ng-container\n  [ngSwitch]=\"item.name\"\n  *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n  <span *ngSwitchCase=\"'name'\">\n    {{ $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cclom:title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'mediatype'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n  </span>\n  <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).size | formatSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'dimensions'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()) | NodeImageSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:wf_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:creator'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).createdBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:modifier'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cm:modifier' | translate }}:</span\n    >\n    {{ $any(getNode()).modifiedBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:replicationsource'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:commonlicense_key'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n    >\n    <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n      {{\n        license[0] === 'CUSTOM'\n          ? $any(getNode()).properties['cclom:rights_description']\n          : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n            | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n      }}\n    </ng-container>\n    <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n      {{ 'LICENSE.NAMES.NONE' | translate }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n    >\n    <ng-container\n      *ngIf=\"\n        $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n        $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n      \"\n    >\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'cclom:duration'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cclom:duration' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n    >\n    <!-- use node instead of getNode() to access the raw proposal data! -->\n    {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n  </span>\n  <span *ngSwitchDefault [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    <ng-container\n      *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n    >\n      {{ displayName$ | async }}\n    </ng-container>\n    <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n      {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true } | async }}\n    </ng-container>\n    <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n      {{\n        $any(getNode()).properties[item.name]\n          ? ($any(getNode()).properties[item.name][0] | vcardName)\n          : ''\n      }}\n    </ng-container>\n  </span>\n</ng-container>\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-text.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit, SimpleChanges } from '@angular/core';\nimport { MdsService, Node, Organization, RestConstants, ProposalNode } from 'ngx-edu-sharing-api';\nimport { BehaviorSubject, merge } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { ListItem } from '../../types/list-item';\nimport { ListWidget } from '../list-widget';\nimport { NodeHelperService } from '../../services/node-helper.service';\nimport * as Constants from 'ngx-edu-sharing-api';\nimport { MdsHelperService } from '../../mds/mds-helper.service';\n\n@Component({\n    selector: 'es-list-text',\n    templateUrl: './list-text.component.html',\n    styleUrls: ['./list-text.component.scss'],\n})\nexport class ListTextComponent extends ListWidget implements OnInit {\n    static supportedItems = [\n        new ListItem('NODE', '*'),\n        new ListItem('NODE_PROPOSAL', '*'),\n        new ListItem('COLLECTION', '*'),\n        new ListItem('ORG', '*'),\n        new ListItem('GROUP', '*'),\n        new ListItem('USER', '*'),\n    ];\n    readonly DATE_FIELDS = RestConstants.DATE_FIELDS;\n    readonly VCARD_FIELDS = RestConstants.getAllVCardFields();\n    displayName$ = new BehaviorSubject<string>(null);\n\n    constructor(\n        private nodeHelper: NodeHelperService,\n        private mds: MdsService,\n        private changeDetectorRef: ChangeDetectorRef,\n    ) {\n        super();\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {}\n\n    async ngOnInit() {\n        merge([this.nodeSubject, this.itemSubject])\n            .pipe(switchMap(() => this.updateDisplayname()))\n            .subscribe((displayName) => {});\n    }\n    getNode() {\n        if (this.item.type === 'NODE_PROPOSAL') {\n            return (this.node as ProposalNode).proposal || this.node;\n        } else if ((this.node as Node).type === RestConstants.CCM_TYPE_COLLECTION_PROPOSAL) {\n            return (this.node as Node).relations?.Original ?? this.node;\n        }\n        return this.node;\n    }\n\n    isUserProfileAttribute(attribute: string) {\n        return (\n            [\n                RestConstants.AUTHORITY_FIRSTNAME,\n                RestConstants.AUTHORITY_LASTNAME,\n                RestConstants.AUTHORITY_EMAIL,\n            ].indexOf(attribute) !== -1\n        );\n    }\n    getWorkflowStatus() {\n        return this.nodeHelper.getWorkflowStatus(this.node as Node).current;\n    }\n\n    getI18n(item: ListItem) {\n        return (item.type === 'NODE_PROPOSAL' ? 'NODE_PROPOSAL' : 'NODE') + '.' + item.name;\n    }\n\n    isDangerousGroup() {\n        return (\n            (this.node as Organization).authorityName ===\n            RestConstants.GROUP_ALFRESCO_ADMINISTRATORS\n        );\n    }\n\n    private async updateDisplayname() {\n        const node = this.getNode() as Node;\n        if (!node.properties) {\n            this.displayName$.next('');\n            return;\n        }\n        this.displayName$.next(\n            node.properties[this.item.name + '_DISPLAYNAME']?.length > 0\n                ? node.properties[this.item.name + '_DISPLAYNAME'].join(', ')\n                : node.properties[this.item.name]?.join(', '),\n        );\n\n        const mds = await this.mds\n            .getMetadataSet({\n                repository: node.ref?.repo || Constants.HOME_REPOSITORY,\n                metadataSet: node.metadataset || Constants.DEFAULT,\n            })\n            .toPromise();\n        const widget = MdsHelperService.getWidget(this.item.name, null, mds.widgets);\n        if (widget?.values) {\n            const i18n = node.properties[this.item.name]\n                ?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)\n                .filter((cap) => !!cap);\n            if (i18n) {\n                this.displayName$.next(i18n.join(', '));\n            }\n        }\n    }\n}\n","<label *ngIf=\"item.config?.showLabel\">\n  {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n  <ng-container [ngSwitch]=\"item.name\">\n    <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n      {{ $any(getNode()).profile?.displayName || $any(getNode()).authorityName }}\n    </span>\n    <span *ngSwitchCase=\"'groupType'\">\n      {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile?.groupType | translate }}\n    </span>\n    <span *ngSwitchDefault>\n      {{ $any(getNode())[item.name] }}\n    </span>\n  </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n  <span *ngIf=\"isUserProfileAttribute(item.name)\">\n    {{ $any(getNode()).profile?.[item.name] }}\n  </span>\n  <span *ngIf=\"item.name === 'status'\">\n    {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n  </span>\n  <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n    {{ $any(getNode())[item.name] }}\n  </span>\n</ng-container>\n<ng-container\n  [ngSwitch]=\"item.name\"\n  *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n  <span *ngSwitchCase=\"'name'\">\n    {{ $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'mediatype'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n  </span>\n  <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).size | formatSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'dimensions'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()) | NodeImageSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:wf_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <es-list-node-workflow\n      [item]=\"item\"\n      [node]=\"node\"\n      [provideLabel]=\"false\"\n    ></es-list-node-workflow>\n    <!--<span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}-->\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:creator'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).createdBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:modifier'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cm:modifier' | translate }}:</span\n    >\n    {{ $any(getNode()).modifiedBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:replicationsource'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:commonlicense_key'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n    >\n    <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n      {{\n        license[0] === 'CUSTOM'\n          ? $any(getNode()).properties['cclom:rights_description']\n          : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n            | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n      }}\n    </ng-container>\n    <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n      {{ 'LICENSE.NAMES.NONE' | translate }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n    >\n    <ng-container\n      *ngIf=\"\n        $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n        $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n      \"\n    >\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'cclom:duration'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cclom:duration' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n    >\n    <!-- use node instead of getNode() to access the raw proposal data! -->\n    {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n  </span>\n  <span\n    *ngSwitchDefault\n    esCheckTextOverflow\n    #text=\"esCheckTextOverflow\"\n    [matTooltip]=\"\n      provideLabel ? (getI18n(item) | translate) : text.hasTextOverflow() ? content.innerText : null\n    \"\n    #content\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    <ng-container *ngIf=\"['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n      {{ $any(getNode()).title || $any(getNode()).name }}\n    </ng-container>\n    <ng-container *ngIf=\"!['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n      <ng-container\n        *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n      >\n        {{ displayName$ | async }}\n      </ng-container>\n      <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n        {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true, time: true, relative: true } | async }}\n      </ng-container>\n      <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n        {{\n          $any(getNode()).properties[item.name]\n            ? ($any(getNode()).properties[item.name][0] | vcardName)\n            : ''\n        }}\n      </ng-container>\n    </ng-container>\n  </span>\n</ng-container>\n"]}
@@ -0,0 +1,167 @@
1
+ import { RestConstants, } from 'ngx-edu-sharing-api';
2
+ import { Injectable } from '@angular/core';
3
+ import { ListItem } from '../types/list-item';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "ngx-edu-sharing-api";
6
+ export class MdsHelperService {
7
+ static getSortInfo(mdsSet, name) {
8
+ if (mdsSet) {
9
+ if (mdsSet.sorts) {
10
+ for (const list of mdsSet.sorts) {
11
+ if (list.id == name) {
12
+ return list;
13
+ }
14
+ }
15
+ }
16
+ console.error('mds does not define sort info for ' + name + ', invalid configuration!');
17
+ }
18
+ return null;
19
+ }
20
+ static getColumns(translate, mdsSet, name) {
21
+ let columns = [];
22
+ if (mdsSet) {
23
+ for (const list of mdsSet.lists) {
24
+ if (list.id === name) {
25
+ for (const column of list.columns) {
26
+ let type = 'NODE';
27
+ if (name === 'mediacenterGroups') {
28
+ type = 'GROUP';
29
+ }
30
+ else if (name === 'searchCollections') {
31
+ type = 'COLLECTION';
32
+ }
33
+ // in this case, the type is included
34
+ if (column.id.includes('.')) {
35
+ const split = column.id.split('.');
36
+ type = split[0];
37
+ column.id = split[1];
38
+ }
39
+ const item = new ListItem(type, column.id);
40
+ item.format = column.format;
41
+ columns.push(item);
42
+ }
43
+ break;
44
+ }
45
+ }
46
+ }
47
+ if (!columns.length) {
48
+ if (mdsSet !== null) {
49
+ console.warn('mds does not define columns for ' + name + ', invalid configuration!');
50
+ }
51
+ if (name === 'search' || name === 'collectionReferences') {
52
+ columns.push(new ListItem('NODE', RestConstants.LOM_PROP_TITLE));
53
+ columns.push(new ListItem('NODE', RestConstants.CM_MODIFIED_DATE));
54
+ columns.push(new ListItem('NODE', RestConstants.CCM_PROP_LICENSE));
55
+ columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCE));
56
+ }
57
+ else if (name === 'mediacenterManaged') {
58
+ columns.push(new ListItem('NODE', RestConstants.LOM_PROP_TITLE));
59
+ columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCEID));
60
+ columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCE));
61
+ }
62
+ else if (name === 'mediacenterGroups') {
63
+ columns.push(new ListItem('GROUP', RestConstants.AUTHORITY_DISPLAYNAME));
64
+ columns.push(new ListItem('GROUP', RestConstants.AUTHORITY_GROUPTYPE));
65
+ }
66
+ else if (name === 'searchCollections') {
67
+ columns.push(new ListItem('COLLECTION', 'title'));
68
+ columns.push(new ListItem('COLLECTION', 'info'));
69
+ columns.push(new ListItem('COLLECTION', 'scope'));
70
+ }
71
+ }
72
+ columns.map((c) => {
73
+ const key = c.type + '.' + c.name;
74
+ if (c.type === 'NODE' && translate.instant(key) === key) {
75
+ c.label = mdsSet.widgets.filter((w) => w.id === c.name)?.[0]?.caption;
76
+ }
77
+ return c;
78
+ });
79
+ return columns;
80
+ }
81
+ /**
82
+ * Finds the appropriate widget with the id, but will not check any widget conditions
83
+ * @param cid
84
+ * @param template
85
+ * @param widgets
86
+ */
87
+ static getWidget(cid, template, widgets) {
88
+ if (widgets == null) {
89
+ console.warn('Could not iterate widget ' + cid + ': no widgets data provided');
90
+ return null;
91
+ }
92
+ for (let w of widgets) {
93
+ if (w.id == cid) {
94
+ if (template === undefined || w.template === template) {
95
+ return w;
96
+ }
97
+ }
98
+ }
99
+ return null;
100
+ }
101
+ constructor(authentication) {
102
+ this.authentication = authentication;
103
+ }
104
+ /**
105
+ * Same as getWidget, but will also check the widget conditions
106
+ * @param connector
107
+ * @param properties
108
+ * @param id
109
+ * @param template
110
+ * @param widgets
111
+ */
112
+ async getWidgetWithCondition(properties, id, template = null, widgets) {
113
+ for (let w of widgets) {
114
+ if (w.id == id) {
115
+ if ((template == null || w.template == template) &&
116
+ (await this.isWidgetConditionTrue(w, properties))) {
117
+ return w;
118
+ }
119
+ }
120
+ }
121
+ return null;
122
+ }
123
+ async isWidgetConditionTrue(widget, properties) {
124
+ if (!widget.condition)
125
+ return true;
126
+ let condition = widget.condition;
127
+ if (condition.type == 'PROPERTY' && properties) {
128
+ if ((!properties[condition.value] && !condition.negate) ||
129
+ (properties[condition.value] && condition.negate)) {
130
+ return false;
131
+ }
132
+ }
133
+ if (condition.type == 'TOOLPERMISSION') {
134
+ let tp = await this.authentication.hasToolpermission(condition.value);
135
+ if (tp == condition.negate) {
136
+ return false;
137
+ }
138
+ }
139
+ return true;
140
+ }
141
+ /**
142
+ * Find a template by id in the given mds
143
+ */
144
+ static findTemplate(mds, id) {
145
+ return mds.views.find((v) => v.id === id);
146
+ }
147
+ /**
148
+ * Returns all widgets used by the given template
149
+ */
150
+ static getUsedWidgets(mds, template = null) {
151
+ const used = [];
152
+ const templateData = MdsHelperService.findTemplate(mds, template);
153
+ for (const w of mds.widgets) {
154
+ if (templateData.html.indexOf('<' + w.id) !== -1 &&
155
+ !used.find((w2) => w2.id === w.id)) {
156
+ used.push(w);
157
+ }
158
+ }
159
+ return used;
160
+ }
161
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsHelperService, deps: [{ token: i1.AuthenticationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
162
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsHelperService }); }
163
+ }
164
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsHelperService, decorators: [{
165
+ type: Injectable
166
+ }], ctorParameters: function () { return [{ type: i1.AuthenticationService }]; } });
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mds-helper.service.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/mds/mds-helper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { TranslateService } from '@ngx-translate/core';\nimport {\n    AuthenticationService,\n    MdsDefinition,\n    MdsSort,\n    MdsWidget,\n    RestConstants,\n    Sort,\n} from 'ngx-edu-sharing-api';\nimport { Injectable } from '@angular/core';\nimport { ListItem, ListItemType } from '../types/list-item';\n\n@Injectable()\nexport class MdsHelperService {\n    static getSortInfo(mdsSet: MdsDefinition, name: string): MdsSort {\n        if (mdsSet) {\n            if (mdsSet.sorts) {\n                for (const list of mdsSet.sorts) {\n                    if (list.id == name) {\n                        return list;\n                    }\n                }\n            }\n            console.error('mds does not define sort info for ' + name + ', invalid configuration!');\n        }\n        return null;\n    }\n    static getColumns(translate: TranslateService, mdsSet: any, name: string) {\n        let columns: ListItem[] = [];\n        if (mdsSet) {\n            for (const list of mdsSet.lists) {\n                if (list.id === name) {\n                    for (const column of list.columns) {\n                        let type: ListItemType = 'NODE';\n                        if (name === 'mediacenterGroups') {\n                            type = 'GROUP';\n                        } else if (name === 'searchCollections') {\n                            type = 'COLLECTION';\n                        }\n                        // in this case, the type is included\n                        if (column.id.includes('.')) {\n                            const split = column.id.split('.');\n                            type = split[0];\n                            column.id = split[1];\n                        }\n                        const item = new ListItem(type, column.id);\n                        item.format = column.format;\n                        columns.push(item);\n                    }\n                    break;\n                }\n            }\n        }\n        if (!columns.length) {\n            if (mdsSet !== null) {\n                console.warn(\n                    'mds does not define columns for ' + name + ', invalid configuration!',\n                );\n            }\n            if (name === 'search' || name === 'collectionReferences') {\n                columns.push(new ListItem('NODE', RestConstants.LOM_PROP_TITLE));\n                columns.push(new ListItem('NODE', RestConstants.CM_MODIFIED_DATE));\n                columns.push(new ListItem('NODE', RestConstants.CCM_PROP_LICENSE));\n                columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCE));\n            } else if (name === 'mediacenterManaged') {\n                columns.push(new ListItem('NODE', RestConstants.LOM_PROP_TITLE));\n                columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCEID));\n                columns.push(new ListItem('NODE', RestConstants.CCM_PROP_REPLICATIONSOURCE));\n            } else if (name === 'mediacenterGroups') {\n                columns.push(new ListItem('GROUP', RestConstants.AUTHORITY_DISPLAYNAME));\n                columns.push(new ListItem('GROUP', RestConstants.AUTHORITY_GROUPTYPE));\n            } else if (name === 'searchCollections') {\n                columns.push(new ListItem('COLLECTION', 'title'));\n                columns.push(new ListItem('COLLECTION', 'info'));\n                columns.push(new ListItem('COLLECTION', 'scope'));\n            }\n        }\n        columns.map((c) => {\n            const key = c.type + '.' + c.name;\n            if (c.type === 'NODE' && translate.instant(key) === key) {\n                c.label = mdsSet.widgets.filter((w: any) => w.id === c.name)?.[0]?.caption;\n            }\n            return c;\n        });\n        return columns;\n    }\n\n    /**\n     * Finds the appropriate widget with the id, but will not check any widget conditions\n     * @param cid\n     * @param template\n     * @param widgets\n     */\n    static getWidget(cid: string, template: string | undefined | null, widgets: MdsWidget[]) {\n        if (widgets == null) {\n            console.warn('Could not iterate widget ' + cid + ': no widgets data provided');\n            return null;\n        }\n        for (let w of widgets) {\n            if (w.id == cid) {\n                if (template === undefined || w.template === template) {\n                    return w;\n                }\n            }\n        }\n        return null;\n    }\n\n    constructor(private authentication: AuthenticationService) {}\n\n    /**\n     * Same as getWidget, but will also check the widget conditions\n     * @param connector\n     * @param properties\n     * @param id\n     * @param template\n     * @param widgets\n     */\n    async getWidgetWithCondition(\n        properties: any,\n        id: string,\n        template: string = null,\n        widgets: any,\n    ) {\n        for (let w of widgets) {\n            if (w.id == id) {\n                if (\n                    (template == null || w.template == template) &&\n                    (await this.isWidgetConditionTrue(w, properties))\n                ) {\n                    return w;\n                }\n            }\n        }\n        return null;\n    }\n\n    async isWidgetConditionTrue(widget: any, properties: any) {\n        if (!widget.condition) return true;\n        let condition = widget.condition;\n        if (condition.type == 'PROPERTY' && properties) {\n            if (\n                (!properties[condition.value] && !condition.negate) ||\n                (properties[condition.value] && condition.negate)\n            ) {\n                return false;\n            }\n        }\n        if (condition.type == 'TOOLPERMISSION') {\n            let tp = await this.authentication.hasToolpermission(condition.value);\n            if (tp == condition.negate) {\n                return false;\n            }\n        }\n        return true;\n    }\n    /**\n     * Find a template by id in the given mds\n     */\n    static findTemplate(mds: MdsDefinition, id: string) {\n        return (\n            mds.views as Array<\n                ArrayElement<MdsDefinition['views']> | ArrayElement<MdsDefinition['views']>\n            >\n        ).find((v) => v.id === id);\n    }\n    /**\n     * Returns all widgets used by the given template\n     */\n    static getUsedWidgets(mds: MdsDefinition, template: string = null): any[] {\n        const used: any = [];\n        const templateData = MdsHelperService.findTemplate(mds, template);\n        for (const w of mds.widgets) {\n            if (\n                templateData.html.indexOf('<' + w.id) !== -1 &&\n                !used.find((w2: any) => w2.id === w.id)\n            ) {\n                used.push(w);\n            }\n        }\n        return used;\n    }\n}\n\ntype ArrayElement<ArrayType extends readonly unknown[]> =\n    ArrayType extends readonly (infer ElementType)[] ? ElementType : never;\n"]}
@@ -0,0 +1,16 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { MdsHelperService } from './mds-helper.service';
3
+ import * as i0 from "@angular/core";
4
+ export class MdsModule {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.6", ngImport: i0, type: MdsModule }); }
7
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsModule, providers: [MdsHelperService] }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: MdsModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ declarations: [],
13
+ providers: [MdsHelperService],
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbWRzL21kcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFNeEQsTUFBTSxPQUFPLFNBQVM7OEdBQVQsU0FBUzsrR0FBVCxTQUFTOytHQUFULFNBQVMsYUFGUCxDQUFDLGdCQUFnQixDQUFDOzsyRkFFcEIsU0FBUztrQkFKckIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsU0FBUyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQ2hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1kc0hlbHBlclNlcnZpY2UgfSBmcm9tICcuL21kcy1oZWxwZXIuc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXSxcbiAgICBwcm92aWRlcnM6IFtNZHNIZWxwZXJTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWRzTW9kdWxlIHt9XG4iXX0=
@@ -6,11 +6,11 @@ import * as i3 from "@angular/material/badge";
6
6
  import * as i4 from "../../pipes/node-icon.pipe";
7
7
  export class DragPreviewComponent {
8
8
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: DragPreviewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: DragPreviewComponent, selector: "es-drag-preview", inputs: { node: "node", selected: "selected", item: "item" }, ngImport: i0, template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ListTextComponent, selector: "es-list-text" }, { kind: "directive", type: i3.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "pipe", type: i4.NodeIconPipe, name: "esNodeIcon" }] }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: DragPreviewComponent, selector: "es-drag-preview", inputs: { node: "node", selected: "selected", item: "item" }, ngImport: i0, template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon | async\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ListTextComponent, selector: "es-list-text" }, { kind: "directive", type: i3.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.NodeIconPipe, name: "esNodeIcon" }] }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: DragPreviewComponent, decorators: [{
12
12
  type: Component,
13
- args: [{ selector: 'es-drag-preview', template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"] }]
13
+ args: [{ selector: 'es-drag-preview', template: "<div class=\"drag-preview\" [matBadge]=\"selected.length > 1 ? selected.length : null\">\n <div class=\"drag-preview-icon\">\n <img *ngIf=\"node.iconURL\" [src]=\"node | esNodeIcon | async\" />\n </div>\n <es-list-text class=\"drag-preview-text\" [node]=\"node\" [item]=\"item\"></es-list-text>\n</div>\n", styles: [".drag-preview{display:flex;align-items:center;gap:16px;height:48px;padding:0 12px;background-color:var(--palette-primary-50)}.drag-preview-icon{width:30px;height:30px;padding:3px;margin:1px 0;background-color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 0 3px #0000004d}.drag-preview-icon>img{width:18px;height:auto}.drag-preview-text{max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"] }]
14
14
  }], propDecorators: { node: [{
15
15
  type: Input
16
16
  }], selected: [{
@@ -18,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
18
18
  }], item: [{
19
19
  type: Input
20
20
  }] } });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2RyYWctcHJldmlldy9kcmFnLXByZXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvZHJhZy1wcmV2aWV3L2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBVWpELE1BQU0sT0FBTyxvQkFBb0I7OEdBQXBCLG9CQUFvQjtrR0FBcEIsb0JBQW9CLHFIQ1ZqQyxnVEFNQTs7MkZESWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNJLGlCQUFpQjs4QkFLbEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgTm9kZUVudHJpZXNEYXRhVHlwZSB9IGZyb20gJy4uL2VudHJpZXMtbW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2VzLWRyYWctcHJldmlldycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERyYWdQcmV2aWV3Q29tcG9uZW50PFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcbiAgICBASW5wdXQoKSBzZWxlY3RlZDogVFtdO1xuICAgIEBJbnB1dCgpIGl0ZW06IExpc3RJdGVtO1xufVxuIiwiPGRpdiBjbGFzcz1cImRyYWctcHJldmlld1wiIFttYXRCYWRnZV09XCJzZWxlY3RlZC5sZW5ndGggPiAxID8gc2VsZWN0ZWQubGVuZ3RoIDogbnVsbFwiPlxuICA8ZGl2IGNsYXNzPVwiZHJhZy1wcmV2aWV3LWljb25cIj5cbiAgICA8aW1nICpuZ0lmPVwibm9kZS5pY29uVVJMXCIgW3NyY109XCJub2RlIHwgZXNOb2RlSWNvblwiIC8+XG4gIDwvZGl2PlxuICA8ZXMtbGlzdC10ZXh0IGNsYXNzPVwiZHJhZy1wcmV2aWV3LXRleHRcIiBbbm9kZV09XCJub2RlXCIgW2l0ZW1dPVwiaXRlbVwiPjwvZXMtbGlzdC10ZXh0PlxuPC9kaXY+XG4iXX0=
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2RyYWctcHJldmlldy9kcmFnLXByZXZpZXcuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvZHJhZy1wcmV2aWV3L2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBVWpELE1BQU0sT0FBTyxvQkFBb0I7OEdBQXBCLG9CQUFvQjtrR0FBcEIsb0JBQW9CLHFIQ1ZqQyx3VEFNQTs7MkZESWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNJLGlCQUFpQjs4QkFLbEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgTm9kZUVudHJpZXNEYXRhVHlwZSB9IGZyb20gJy4uL2VudHJpZXMtbW9kZWwnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2VzLWRyYWctcHJldmlldycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RyYWctcHJldmlldy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZHJhZy1wcmV2aWV3LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERyYWdQcmV2aWV3Q29tcG9uZW50PFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcbiAgICBASW5wdXQoKSBzZWxlY3RlZDogVFtdO1xuICAgIEBJbnB1dCgpIGl0ZW06IExpc3RJdGVtO1xufVxuIiwiPGRpdiBjbGFzcz1cImRyYWctcHJldmlld1wiIFttYXRCYWRnZV09XCJzZWxlY3RlZC5sZW5ndGggPiAxID8gc2VsZWN0ZWQubGVuZ3RoIDogbnVsbFwiPlxuICA8ZGl2IGNsYXNzPVwiZHJhZy1wcmV2aWV3LWljb25cIj5cbiAgICA8aW1nICpuZ0lmPVwibm9kZS5pY29uVVJMXCIgW3NyY109XCJub2RlIHwgZXNOb2RlSWNvbiB8IGFzeW5jXCIgLz5cbiAgPC9kaXY+XG4gIDxlcy1saXN0LXRleHQgY2xhc3M9XCJkcmFnLXByZXZpZXctdGV4dFwiIFtub2RlXT1cIm5vZGVcIiBbaXRlbV09XCJpdGVtXCI+PC9lcy1saXN0LXRleHQ+XG48L2Rpdj5cbiJdfQ==
@@ -19,5 +19,6 @@ export var ClickSource;
19
19
  ClickSource[ClickSource["Metadata"] = 2] = "Metadata";
20
20
  ClickSource[ClickSource["Comments"] = 3] = "Comments";
21
21
  ClickSource[ClickSource["Overlay"] = 4] = "Overlay";
22
+ ClickSource[ClickSource["Dropdown"] = 5] = "Dropdown";
22
23
  })(ClickSource || (ClickSource = {}));
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmllcy1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2VudHJpZXMtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JBLE1BQU0sQ0FBTixJQUFZLHNCQUlYO0FBSkQsV0FBWSxzQkFBc0I7SUFDOUIscUVBQUssQ0FBQTtJQUNMLG1FQUFJLENBQUE7SUFDSiw2RUFBUyxDQUFBO0FBQ2IsQ0FBQyxFQUpXLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJakM7QUFFRCxNQUFNLENBQU4sSUFBWSxlQU1YO0FBTkQsV0FBWSxlQUFlO0lBQ3ZCLHFCQUFxQjtJQUNyQiwrRUFBaUIsQ0FBQTtJQUNqQixnQkFBZ0I7SUFDaEIsMkRBQU8sQ0FBQTtJQUNQLHFEQUFJLENBQUE7QUFDUixDQUFDLEVBTlcsZUFBZSxLQUFmLGVBQWUsUUFNMUI7QUE2QkQsTUFBTSxDQUFOLElBQVksV0FNWDtBQU5ELFdBQVksV0FBVztJQUNuQixtREFBTyxDQUFBO0lBQ1AsNkNBQUksQ0FBQTtJQUNKLHFEQUFRLENBQUE7SUFDUixxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtBQUNYLENBQUMsRUFOVyxXQUFXLEtBQVgsV0FBVyxRQU10QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNvcnQgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zb3J0JztcblxuaW1wb3J0IHsgU2VsZWN0aW9uTW9kZWwgfSBmcm9tICdAYW5ndWxhci9jZGsvY29sbGVjdGlvbnMnO1xuaW1wb3J0IHsgQ3VzdG9tT3B0aW9ucywgT3B0aW9uSXRlbSwgVGFyZ2V0IH0gZnJvbSAnLi4vdHlwZXMvb3B0aW9uLWl0ZW0nO1xuaW1wb3J0IHsgTGlzdEl0ZW0sIExpc3RJdGVtU29ydCB9IGZyb20gJy4uL3R5cGVzL2xpc3QtaXRlbSc7XG5pbXBvcnQgeyBDYW5Ecm9wLCBEcmFnRGF0YSwgRHJvcEFjdGlvbiB9IGZyb20gJy4uL3R5cGVzL2RyYWctZHJvcCc7XG5pbXBvcnQgeyBOb2RlLCBHZW5lcmljQXV0aG9yaXR5IH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBBY3Rpb25iYXJDb21wb25lbnQgfSBmcm9tICcuLi9hY3Rpb25iYXIvYWN0aW9uYmFyLmNvbXBvbmVudCc7XG5cbmV4cG9ydCB0eXBlIE5vZGVSb290ID1cbiAgICB8ICdNWV9GSUxFUydcbiAgICB8ICdTSEFSRURfRklMRVMnXG4gICAgfCAnTVlfU0hBUkVEX0ZJTEVTJ1xuICAgIHwgJ1RPX01FX1NIQVJFRF9GSUxFUydcbiAgICB8ICdXT1JLRkxPV19SRUNFSVZFJ1xuICAgIHwgJ1JFQ1lDTEUnXG4gICAgfCAnQUxMX0ZJTEVTJztcblxuZXhwb3J0IGVudW0gTm9kZUVudHJpZXNEaXNwbGF5VHlwZSB7XG4gICAgVGFibGUsXG4gICAgR3JpZCxcbiAgICBTbWFsbEdyaWQsXG59XG5cbmV4cG9ydCBlbnVtIEludGVyYWN0aW9uVHlwZSB7XG4gICAgLy8gY3JlYXRlIHJvdXRlciBsaW5rXG4gICAgRGVmYXVsdEFjdGlvbkxpbmssXG4gICAgLy8gZW1pdCBhbiBldmVudFxuICAgIEVtaXR0ZXIsXG4gICAgTm9uZSxcbn1cblxuZXhwb3J0IHR5cGUgTGlzdE9wdGlvbnMgPSB7IFtrZXkgaW4gVGFyZ2V0XT86IE9wdGlvbkl0ZW1bXSB9O1xuZXhwb3J0IHR5cGUgTGlzdE9wdGlvbnNDb25maWcgPSB7XG4gICAgYWN0aW9uYmFyPzogQWN0aW9uYmFyQ29tcG9uZW50O1xuICAgIHBhcmVudD86IE5vZGU7XG4gICAgY3VzdG9tT3B0aW9ucz86IEN1c3RvbU9wdGlvbnM7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIExpc3RTb3J0Q29uZmlnIGV4dGVuZHMgU29ydCB7XG4gICAgY29sdW1uczogTGlzdEl0ZW1Tb3J0W107XG4gICAgYWxsb3dlZD86IGJvb2xlYW47XG4gICAgY3VzdG9tU29ydGluZ0luUHJvZ3Jlc3M/OiBib29sZWFuO1xufVxuXG5leHBvcnQgdHlwZSBEcm9wVGFyZ2V0ID0gTm9kZSB8IE5vZGVSb290O1xuXG5leHBvcnQgaW50ZXJmYWNlIERyb3BTb3VyY2U8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+IHtcbiAgICBlbGVtZW50OiBUW107XG4gICAgLy8gc291cmNlTGlzdDogTGlzdEV2ZW50SW50ZXJmYWNlPFQ+O1xuICAgIG1vZGU6IERyb3BBY3Rpb247XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdERyYWdHcm9wQ29uZmlnPFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgZHJhZ0FsbG93ZWQ6IGJvb2xlYW47XG4gICAgZHJvcEFsbG93ZWQ/OiAoZHJhZ0RhdGE6IERyYWdEYXRhPFQ+KSA9PiBDYW5Ecm9wO1xuICAgIGRyb3BwZWQ/OiAodGFyZ2V0OiBOb2RlLCBzb3VyY2U6IERyb3BTb3VyY2U8Tm9kZUVudHJpZXNEYXRhVHlwZT4pID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBlbnVtIENsaWNrU291cmNlIHtcbiAgICBQcmV2aWV3LFxuICAgIEljb24sXG4gICAgTWV0YWRhdGEsXG4gICAgQ29tbWVudHMsXG4gICAgT3ZlcmxheSxcbn1cblxuZXhwb3J0IHR5cGUgTm9kZUNsaWNrRXZlbnQ8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+ID0ge1xuICAgIGVsZW1lbnQ6IFQ7XG4gICAgc291cmNlOiBDbGlja1NvdXJjZTtcbiAgICBhdHRyaWJ1dGU/OiBMaXN0SXRlbTsgLy8gb25seSB3aGVuIHNvdXJjZSA9PT0gTWV0YWRhdGFcbn07XG5leHBvcnQgdHlwZSBGZXRjaEV2ZW50ID0ge1xuICAgIG9mZnNldDogbnVtYmVyO1xuICAgIGFtb3VudD86IG51bWJlcjtcbiAgICAvKipcbiAgICAgKiBpcyBhIHJlc2V0IG9mIHRoZSBjdXJyZW50IGRhdGEgcmVxdWlyZWQ/XG4gICAgICogdGhpcyBzaG91bGQgYmUgdHJ1ZSBpZiB0aGlzIHdhcyBhIHBhZ2luYXRpb24gcmVxdWVzdFxuICAgICAqL1xuICAgIHJlc2V0PzogYm9vbGVhbjtcbn07XG5leHBvcnQgdHlwZSBOb2RlRW50cmllc0RhdGFUeXBlID0gTm9kZSB8IEdlbmVyaWNBdXRob3JpdHk7XG5leHBvcnQgdHlwZSBHcmlkTGF5b3V0ID0gJ2dyaWQnIHwgJ3Njcm9sbCc7XG5leHBvcnQgdHlwZSBHcmlkQ29uZmlnID0ge1xuICAgIC8qKlxuICAgICAqIG1heCBhbW91bnQgb2Ygcm93cyB0aGF0IHNob3VsZCBiZSB2aXNpYmxlLCB1bnNldCBmb3Igbm8gbGltaXRcbiAgICAgKi9cbiAgICBtYXhSb3dzPzogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIGxheW91dCwgZGVmYXVsdHMgdG8gJ2dyaWQnXG4gICAgICogJ3Njcm9sbCcgbWF5IG9ubHkgYmUgdXNlZCB3aGVuIG1heFJvd3MgaXMgbm90IHNldFxuICAgICAqL1xuICAgIGxheW91dD86IEdyaWRMYXlvdXQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIExpc3RFdmVudEludGVyZmFjZTxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIHVwZGF0ZU5vZGVzKG5vZGVzOiB2b2lkIHwgVFtdKTogdm9pZDtcblxuICAgIGdldERpc3BsYXlUeXBlKCk6IE5vZGVFbnRyaWVzRGlzcGxheVR5cGU7XG5cbiAgICBzZXREaXNwbGF5VHlwZShkaXNwbGF5VHlwZTogTm9kZUVudHJpZXNEaXNwbGF5VHlwZSk6IHZvaWQ7XG5cbiAgICBzaG93UmVvcmRlckNvbHVtbnNEaWFsb2coKTogdm9pZDtcblxuICAgIGFkZFZpcnR1YWxOb2Rlcyh2aXJ0dWFsOiBUW10pOiB2b2lkO1xuXG4gICAgc2V0T3B0aW9ucyhvcHRpb25zOiBMaXN0T3B0aW9ucyk6IHZvaWQ7XG5cbiAgICAvKipcbiAgICAgKiBhY3RpdmF0ZSBvcHRpb24gKGRyb3Bkb3duKSBnZW5lcmF0aW9uXG4gICAgICovXG4gICAgaW5pdE9wdGlvbnNHZW5lcmF0b3IoY29uZmlnOiBMaXN0T3B0aW9uc0NvbmZpZyk6IHZvaWQgfCBQcm9taXNlPHZvaWQ+O1xuXG4gICAgZ2V0U2VsZWN0aW9uKCk6IFNlbGVjdGlvbk1vZGVsPFQ+O1xuXG4gICAgLyoqXG4gICAgICogdHJpZ2dlcmVkIHdoZW4gbm9kZXMvb2JqZWN0cyBhcmUgZGVsZXRlZCBhbmQgc2hvdWxkIG5vdCBiZSBzaG93biBpbiB0aGUgbGlzdCBhbnltb3JlXG4gICAgICovXG4gICAgZGVsZXRlTm9kZXMob2JqZWN0czogVFtdKTogdm9pZDtcbn1cbiJdfQ==
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmllcy1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2VudHJpZXMtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBLE1BQU0sQ0FBTixJQUFZLHNCQUlYO0FBSkQsV0FBWSxzQkFBc0I7SUFDOUIscUVBQUssQ0FBQTtJQUNMLG1FQUFJLENBQUE7SUFDSiw2RUFBUyxDQUFBO0FBQ2IsQ0FBQyxFQUpXLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJakM7QUFFRCxNQUFNLENBQU4sSUFBWSxlQU1YO0FBTkQsV0FBWSxlQUFlO0lBQ3ZCLHFCQUFxQjtJQUNyQiwrRUFBaUIsQ0FBQTtJQUNqQixnQkFBZ0I7SUFDaEIsMkRBQU8sQ0FBQTtJQUNQLHFEQUFJLENBQUE7QUFDUixDQUFDLEVBTlcsZUFBZSxLQUFmLGVBQWUsUUFNMUI7QUE2QkQsTUFBTSxDQUFOLElBQVksV0FPWDtBQVBELFdBQVksV0FBVztJQUNuQixtREFBTyxDQUFBO0lBQ1AsNkNBQUksQ0FBQTtJQUNKLHFEQUFRLENBQUE7SUFDUixxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7QUFDWixDQUFDLEVBUFcsV0FBVyxLQUFYLFdBQVcsUUFPdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb3J0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5cbmltcG9ydCB7IFNlbGVjdGlvbk1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IEN1c3RvbU9wdGlvbnMsIE9wdGlvbkl0ZW0sIFRhcmdldCB9IGZyb20gJy4uL3R5cGVzL29wdGlvbi1pdGVtJztcbmltcG9ydCB7IExpc3RJdGVtLCBMaXN0SXRlbVNvcnQgfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgQ2FuRHJvcCwgRHJhZ0RhdGEsIERyb3BBY3Rpb24gfSBmcm9tICcuLi90eXBlcy9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgTm9kZSwgR2VuZXJpY0F1dGhvcml0eSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgQWN0aW9uYmFyQ29tcG9uZW50IH0gZnJvbSAnLi4vYWN0aW9uYmFyL2FjdGlvbmJhci5jb21wb25lbnQnO1xuXG5leHBvcnQgdHlwZSBOb2RlUm9vdCA9XG4gICAgfCAnTVlfRklMRVMnXG4gICAgfCAnQ09MTEVDVElPTl9IT01FJ1xuICAgIHwgJ1NIQVJFRF9GSUxFUydcbiAgICB8ICdNWV9TSEFSRURfRklMRVMnXG4gICAgfCAnVE9fTUVfU0hBUkVEX0ZJTEVTJ1xuICAgIHwgJ1dPUktGTE9XX1JFQ0VJVkUnXG4gICAgfCAnUkVDWUNMRSdcbiAgICB8ICdBTExfRklMRVMnO1xuXG5leHBvcnQgZW51bSBOb2RlRW50cmllc0Rpc3BsYXlUeXBlIHtcbiAgICBUYWJsZSxcbiAgICBHcmlkLFxuICAgIFNtYWxsR3JpZCxcbn1cblxuZXhwb3J0IGVudW0gSW50ZXJhY3Rpb25UeXBlIHtcbiAgICAvLyBjcmVhdGUgcm91dGVyIGxpbmtcbiAgICBEZWZhdWx0QWN0aW9uTGluayxcbiAgICAvLyBlbWl0IGFuIGV2ZW50XG4gICAgRW1pdHRlcixcbiAgICBOb25lLFxufVxuXG5leHBvcnQgdHlwZSBMaXN0T3B0aW9ucyA9IHsgW2tleSBpbiBUYXJnZXRdPzogT3B0aW9uSXRlbVtdIH07XG5leHBvcnQgdHlwZSBMaXN0T3B0aW9uc0NvbmZpZyA9IHtcbiAgICBhY3Rpb25iYXI/OiBBY3Rpb25iYXJDb21wb25lbnQ7XG4gICAgcGFyZW50PzogTm9kZTtcbiAgICBjdXN0b21PcHRpb25zPzogQ3VzdG9tT3B0aW9ucztcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdFNvcnRDb25maWcgZXh0ZW5kcyBTb3J0IHtcbiAgICBjb2x1bW5zOiBMaXN0SXRlbVNvcnRbXTtcbiAgICBhbGxvd2VkPzogYm9vbGVhbjtcbiAgICBjdXN0b21Tb3J0aW5nSW5Qcm9ncmVzcz86IGJvb2xlYW47XG59XG5cbmV4cG9ydCB0eXBlIERyb3BUYXJnZXQgPSBOb2RlIHwgTm9kZVJvb3Q7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJvcFNvdXJjZTxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIGVsZW1lbnQ6IFRbXTtcbiAgICAvLyBzb3VyY2VMaXN0OiBMaXN0RXZlbnRJbnRlcmZhY2U8VD47XG4gICAgbW9kZTogRHJvcEFjdGlvbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMaXN0RHJhZ0dyb3BDb25maWc8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+IHtcbiAgICBkcmFnQWxsb3dlZDogYm9vbGVhbjtcbiAgICBkcm9wQWxsb3dlZD86IChkcmFnRGF0YTogRHJhZ0RhdGE8VD4pID0+IENhbkRyb3A7XG4gICAgZHJvcHBlZD86ICh0YXJnZXQ6IE5vZGUsIHNvdXJjZTogRHJvcFNvdXJjZTxOb2RlRW50cmllc0RhdGFUeXBlPikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQ2xpY2tTb3VyY2Uge1xuICAgIFByZXZpZXcsXG4gICAgSWNvbixcbiAgICBNZXRhZGF0YSxcbiAgICBDb21tZW50cyxcbiAgICBPdmVybGF5LFxuICAgIERyb3Bkb3duLCAvLyBrZWVwOiB1c2VkIGluIGV4dGVuc2lvbnNcbn1cblxuZXhwb3J0IHR5cGUgTm9kZUNsaWNrRXZlbnQ8VCBleHRlbmRzIE5vZGVFbnRyaWVzRGF0YVR5cGU+ID0ge1xuICAgIGVsZW1lbnQ6IFQ7XG4gICAgc291cmNlOiBDbGlja1NvdXJjZTtcbiAgICBhdHRyaWJ1dGU/OiBMaXN0SXRlbTsgLy8gb25seSB3aGVuIHNvdXJjZSA9PT0gTWV0YWRhdGFcbn07XG5leHBvcnQgdHlwZSBGZXRjaEV2ZW50ID0ge1xuICAgIG9mZnNldDogbnVtYmVyO1xuICAgIGFtb3VudD86IG51bWJlcjtcbiAgICAvKipcbiAgICAgKiBpcyBhIHJlc2V0IG9mIHRoZSBjdXJyZW50IGRhdGEgcmVxdWlyZWQ/XG4gICAgICogdGhpcyBzaG91bGQgYmUgdHJ1ZSBpZiB0aGlzIHdhcyBhIHBhZ2luYXRpb24gcmVxdWVzdFxuICAgICAqL1xuICAgIHJlc2V0PzogYm9vbGVhbjtcbn07XG5leHBvcnQgdHlwZSBOb2RlRW50cmllc0RhdGFUeXBlID0gTm9kZSB8IEdlbmVyaWNBdXRob3JpdHk7XG5leHBvcnQgdHlwZSBHcmlkTGF5b3V0ID0gJ2dyaWQnIHwgJ3Njcm9sbCc7XG5leHBvcnQgdHlwZSBHcmlkQ29uZmlnID0ge1xuICAgIC8qKlxuICAgICAqIG1heCBhbW91bnQgb2Ygcm93cyB0aGF0IHNob3VsZCBiZSB2aXNpYmxlLCB1bnNldCBmb3Igbm8gbGltaXRcbiAgICAgKi9cbiAgICBtYXhSb3dzPzogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIGxheW91dCwgZGVmYXVsdHMgdG8gJ2dyaWQnXG4gICAgICogJ3Njcm9sbCcgbWF5IG9ubHkgYmUgdXNlZCB3aGVuIG1heFJvd3MgaXMgbm90IHNldFxuICAgICAqL1xuICAgIGxheW91dD86IEdyaWRMYXlvdXQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIExpc3RFdmVudEludGVyZmFjZTxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIHVwZGF0ZU5vZGVzKG5vZGVzOiB2b2lkIHwgVFtdKTogdm9pZDtcblxuICAgIGdldERpc3BsYXlUeXBlKCk6IE5vZGVFbnRyaWVzRGlzcGxheVR5cGU7XG5cbiAgICBzZXREaXNwbGF5VHlwZShkaXNwbGF5VHlwZTogTm9kZUVudHJpZXNEaXNwbGF5VHlwZSk6IHZvaWQ7XG5cbiAgICBzaG93UmVvcmRlckNvbHVtbnNEaWFsb2coKTogdm9pZDtcblxuICAgIGFkZFZpcnR1YWxOb2Rlcyh2aXJ0dWFsOiBUW10pOiB2b2lkO1xuXG4gICAgc2V0T3B0aW9ucyhvcHRpb25zOiBMaXN0T3B0aW9ucyk6IHZvaWQ7XG5cbiAgICAvKipcbiAgICAgKiBhY3RpdmF0ZSBvcHRpb24gKGRyb3Bkb3duKSBnZW5lcmF0aW9uXG4gICAgICovXG4gICAgaW5pdE9wdGlvbnNHZW5lcmF0b3IoY29uZmlnOiBMaXN0T3B0aW9uc0NvbmZpZyk6IHZvaWQgfCBQcm9taXNlPHZvaWQ+O1xuXG4gICAgZ2V0U2VsZWN0aW9uKCk6IFNlbGVjdGlvbk1vZGVsPFQ+O1xuXG4gICAgLyoqXG4gICAgICogdHJpZ2dlcmVkIHdoZW4gbm9kZXMvb2JqZWN0cyBhcmUgZGVsZXRlZCBhbmQgc2hvdWxkIG5vdCBiZSBzaG93biBpbiB0aGUgbGlzdCBhbnltb3JlXG4gICAgICovXG4gICAgZGVsZXRlTm9kZXMob2JqZWN0czogVFtdKTogdm9pZDtcbn1cbiJdfQ==
@@ -18,6 +18,14 @@ export class NodeCache {
18
18
  return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
19
19
  }
20
20
  }
21
+ // for the first request
22
+ console.warn('Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)', range, this._slices);
23
+ for (const slice of this._slices) {
24
+ if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {
25
+ return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
26
+ }
27
+ }
28
+ console.error('Could not find any slice for the range', range, this._slices);
21
29
  return null;
22
30
  }
23
31
  getMissingRange(requestedRange) {
@@ -62,4 +70,4 @@ export class NodeCache {
62
70
  };
63
71
  }
64
72
  }
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1jYWNoZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL25vZGUtY2FjaGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBVzVDLE1BQU0sT0FBTyxTQUFTO0lBQXRCO1FBQ1ksWUFBTyxHQUFpQyxFQUFFLENBQUM7SUFvRXZELENBQUM7SUFsRUcsR0FBRyxDQUFDLEtBQXdCO1FBQ3hCLElBQUksS0FBSyxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsVUFBVSxLQUFLLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ3pELE1BQU0sSUFBSSxLQUFLLENBQUMsdUNBQXVDLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ3BGO1FBQ0QsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsS0FBSztRQUNELElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxHQUFHLENBQUMsS0FBcUI7UUFDckIsS0FBSyxNQUFNLEtBQUssSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQzlCLElBQUksS0FBSyxDQUFDLFVBQVUsSUFBSSxLQUFLLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQyxRQUFRLElBQUksS0FBSyxDQUFDLFFBQVEsRUFBRTtnQkFDMUUsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FDbkIsS0FBSyxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUMsVUFBVSxFQUNuQyxLQUFLLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQ3BDLENBQUM7YUFDTDtTQUNKO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUVELGVBQWUsQ0FBQyxjQUE4QjtRQUMxQyxJQUFJLFNBQVMsR0FBRyxjQUFjLENBQUMsVUFBVSxDQUFDO1FBQzFDLElBQUksT0FBTyxHQUFHLGNBQWMsQ0FBQyxRQUFRLENBQUM7UUFDdEMsS0FBSyxNQUFNLEtBQUssSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQzlCLElBQUksS0FBSyxDQUFDLFVBQVUsSUFBSSxTQUFTLElBQUksS0FBSyxDQUFDLFFBQVEsR0FBRyxTQUFTLEVBQUU7Z0JBQzdELFNBQVMsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO2FBQzlCO2lCQUFNLElBQUksS0FBSyxDQUFDLFVBQVUsR0FBRyxPQUFPLElBQUksS0FBSyxDQUFDLFFBQVEsSUFBSSxPQUFPLEVBQUU7Z0JBQ2hFLE9BQU8sR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO2FBQzlCO1lBQ0QsSUFBSSxTQUFTLElBQUksT0FBTyxFQUFFO2dCQUN0QixPQUFPLElBQUksQ0FBQzthQUNmO1NBQ0o7UUFDRCxPQUFPLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUM7SUFDeEQsQ0FBQztJQUVPLGdCQUFnQixDQUFDLE1BQTJCO1FBQ2hELE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsVUFBVSxHQUFHLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMzRCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDeEMsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFO2dCQUN4QyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFO29CQUN0QyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQzlDLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxvQkFBb0I7aUJBQ3pDO2FBQ0o7U0FDSjtRQUNELE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRU8sU0FBUyxDQUFDLEdBQXNCLEVBQUUsR0FBc0I7UUFDNUQsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNkLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO1FBQ0QsT0FBTyxHQUFHLENBQUMsUUFBUSxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUM7SUFDMUMsQ0FBQztJQUVPLE1BQU0sQ0FBQyxHQUFzQixFQUFFLEdBQXNCO1FBQ3pELE9BQU87WUFDSCxVQUFVLEVBQUUsR0FBRyxDQUFDLFVBQVU7WUFDMUIsUUFBUSxFQUFFLEdBQUcsQ0FBQyxRQUFRO1lBQ3RCLElBQUksRUFBRSxDQUFDLEdBQUcsR0FBRyxDQUFDLElBQUksRUFBRSxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQ3hFLENBQUM7SUFDTixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBub3ROdWxsIH0gZnJvbSAnLi4vdXRpbC9mdW5jdGlvbnMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5vZGVDYWNoZVJhbmdlIHtcbiAgICBzdGFydEluZGV4OiBudW1iZXI7XG4gICAgZW5kSW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb2RlQ2FjaGVTbGljZTxUPiBleHRlbmRzIE5vZGVDYWNoZVJhbmdlIHtcbiAgICBkYXRhOiByZWFkb25seSBUW107XG59XG5cbmV4cG9ydCBjbGFzcyBOb2RlQ2FjaGU8VD4ge1xuICAgIHByaXZhdGUgX3NsaWNlczogcmVhZG9ubHkgTm9kZUNhY2hlU2xpY2U8VD5bXSA9IFtdO1xuXG4gICAgYWRkKHNsaWNlOiBOb2RlQ2FjaGVTbGljZTxUPik6IHZvaWQge1xuICAgICAgICBpZiAoc2xpY2UuZW5kSW5kZXggLSBzbGljZS5zdGFydEluZGV4ICE9PSBzbGljZS5kYXRhLmxlbmd0aCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdUcmllZCB0byBhZGQgaW52YWxpZCBzbGljZSB0byBjYWNoZTogJyArIEpTT04uc3RyaW5naWZ5KHNsaWNlKSk7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5fc2xpY2VzID0gdGhpcy5fbm9ybWFsaXplU2xpY2VzKFsuLi50aGlzLl9zbGljZXMsIHNsaWNlXSk7XG4gICAgfVxuXG4gICAgY2xlYXIoKSB7XG4gICAgICAgIHRoaXMuX3NsaWNlcyA9IFtdO1xuICAgIH1cblxuICAgIGdldChyYW5nZTogTm9kZUNhY2hlUmFuZ2UpOiBUW10gfCBudWxsIHtcbiAgICAgICAgZm9yIChjb25zdCBzbGljZSBvZiB0aGlzLl9zbGljZXMpIHtcbiAgICAgICAgICAgIGlmIChzbGljZS5zdGFydEluZGV4IDw9IHJhbmdlLnN0YXJ0SW5kZXggJiYgc2xpY2UuZW5kSW5kZXggPj0gcmFuZ2UuZW5kSW5kZXgpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gc2xpY2UuZGF0YS5zbGljZShcbiAgICAgICAgICAgICAgICAgICAgcmFuZ2Uuc3RhcnRJbmRleCAtIHNsaWNlLnN0YXJ0SW5kZXgsXG4gICAgICAgICAgICAgICAgICAgIHJhbmdlLmVuZEluZGV4IC0gc2xpY2Uuc3RhcnRJbmRleCxcbiAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGdldE1pc3NpbmdSYW5nZShyZXF1ZXN0ZWRSYW5nZTogTm9kZUNhY2hlUmFuZ2UpOiBOb2RlQ2FjaGVSYW5nZSB8IG51bGwge1xuICAgICAgICBsZXQgZnJvbUluZGV4ID0gcmVxdWVzdGVkUmFuZ2Uuc3RhcnRJbmRleDtcbiAgICAgICAgbGV0IHRvSW5kZXggPSByZXF1ZXN0ZWRSYW5nZS5lbmRJbmRleDtcbiAgICAgICAgZm9yIChjb25zdCBzbGljZSBvZiB0aGlzLl9zbGljZXMpIHtcbiAgICAgICAgICAgIGlmIChzbGljZS5zdGFydEluZGV4IDw9IGZyb21JbmRleCAmJiBzbGljZS5lbmRJbmRleCA+IGZyb21JbmRleCkge1xuICAgICAgICAgICAgICAgIGZyb21JbmRleCA9IHNsaWNlLmVuZEluZGV4O1xuICAgICAgICAgICAgfSBlbHNlIGlmIChzbGljZS5zdGFydEluZGV4IDwgdG9JbmRleCAmJiBzbGljZS5lbmRJbmRleCA+PSB0b0luZGV4KSB7XG4gICAgICAgICAgICAgICAgdG9JbmRleCA9IHNsaWNlLnN0YXJ0SW5kZXg7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoZnJvbUluZGV4ID49IHRvSW5kZXgpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4geyBzdGFydEluZGV4OiBmcm9tSW5kZXgsIGVuZEluZGV4OiB0b0luZGV4IH07XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfbm9ybWFsaXplU2xpY2VzKHNsaWNlczogTm9kZUNhY2hlU2xpY2U8VD5bXSk6IE5vZGVDYWNoZVNsaWNlPFQ+W10ge1xuICAgICAgICBzbGljZXMuc29ydCgobGhzLCByaHMpID0+IGxocy5zdGFydEluZGV4IC0gcmhzLnN0YXJ0SW5kZXgpO1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHNsaWNlcy5sZW5ndGggLSAxOyBpKyspIHtcbiAgICAgICAgICAgIGZvciAobGV0IGogPSBpICsgMTsgaiA8IHNsaWNlcy5sZW5ndGg7IGorKykge1xuICAgICAgICAgICAgICAgIGlmICh0aGlzLl9jYW5NZXJnZShzbGljZXNbaV0sIHNsaWNlc1tqXSkpIHtcbiAgICAgICAgICAgICAgICAgICAgc2xpY2VzW2ldID0gdGhpcy5fbWVyZ2Uoc2xpY2VzW2ldLCBzbGljZXNbal0pO1xuICAgICAgICAgICAgICAgICAgICBzbGljZXNbal0gPSBudWxsOyAvLyBNYXJrIGZvciBkZWxldGlvblxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gc2xpY2VzLmZpbHRlcihub3ROdWxsKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIF9jYW5NZXJnZShsaHM6IE5vZGVDYWNoZVNsaWNlPFQ+LCByaHM6IE5vZGVDYWNoZVNsaWNlPFQ+KTogYm9vbGVhbiB7XG4gICAgICAgIGlmICghbGhzIHx8ICFyaHMpIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbGhzLmVuZEluZGV4ID49IHJocy5zdGFydEluZGV4O1xuICAgIH1cblxuICAgIHByaXZhdGUgX21lcmdlKGxoczogTm9kZUNhY2hlU2xpY2U8VD4sIHJoczogTm9kZUNhY2hlU2xpY2U8VD4pOiBOb2RlQ2FjaGVTbGljZTxUPiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBzdGFydEluZGV4OiBsaHMuc3RhcnRJbmRleCxcbiAgICAgICAgICAgIGVuZEluZGV4OiByaHMuZW5kSW5kZXgsXG4gICAgICAgICAgICBkYXRhOiBbLi4ubGhzLmRhdGEsIC4uLnJocy5kYXRhLnNsaWNlKGxocy5lbmRJbmRleCAtIHJocy5zdGFydEluZGV4KV0sXG4gICAgICAgIH07XG4gICAgfVxufVxuIl19
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-cache.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-cache.ts"],"names":[],"mappings":"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","sourcesContent":["import { notNull } from '../util/functions';\n\nexport interface NodeCacheRange {\n    startIndex: number;\n    endIndex: number;\n}\n\nexport interface NodeCacheSlice<T> extends NodeCacheRange {\n    data: readonly T[];\n}\n\nexport class NodeCache<T> {\n    private _slices: readonly NodeCacheSlice<T>[] = [];\n\n    add(slice: NodeCacheSlice<T>): void {\n        if (slice.endIndex - slice.startIndex !== slice.data.length) {\n            throw new Error('Tried to add invalid slice to cache: ' + JSON.stringify(slice));\n        }\n        this._slices = this._normalizeSlices([...this._slices, slice]);\n    }\n\n    clear() {\n        this._slices = [];\n    }\n\n    get(range: NodeCacheRange): T[] | null {\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.endIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        // for the first request\n        console.warn(\n            'Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)',\n            range,\n            this._slices,\n        );\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        console.error('Could not find any slice for the range', range, this._slices);\n        return null;\n    }\n\n    getMissingRange(requestedRange: NodeCacheRange): NodeCacheRange | null {\n        let fromIndex = requestedRange.startIndex;\n        let toIndex = requestedRange.endIndex;\n        for (const slice of this._slices) {\n            if (slice.startIndex <= fromIndex && slice.endIndex > fromIndex) {\n                fromIndex = slice.endIndex;\n            } else if (slice.startIndex < toIndex && slice.endIndex >= toIndex) {\n                toIndex = slice.startIndex;\n            }\n            if (fromIndex >= toIndex) {\n                return null;\n            }\n        }\n        return { startIndex: fromIndex, endIndex: toIndex };\n    }\n\n    private _normalizeSlices(slices: NodeCacheSlice<T>[]): NodeCacheSlice<T>[] {\n        slices.sort((lhs, rhs) => lhs.startIndex - rhs.startIndex);\n        for (let i = 0; i < slices.length - 1; i++) {\n            for (let j = i + 1; j < slices.length; j++) {\n                if (this._canMerge(slices[i], slices[j])) {\n                    slices[i] = this._merge(slices[i], slices[j]);\n                    slices[j] = null; // Mark for deletion\n                }\n            }\n        }\n        return slices.filter(notNull);\n    }\n\n    private _canMerge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): boolean {\n        if (!lhs || !rhs) {\n            return false;\n        }\n        return lhs.endIndex >= rhs.startIndex;\n    }\n\n    private _merge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): NodeCacheSlice<T> {\n        return {\n            startIndex: lhs.startIndex,\n            endIndex: rhs.endIndex,\n            data: [...lhs.data, ...rhs.data.slice(lhs.endIndex - rhs.startIndex)],\n        };\n    }\n}\n"]}