ngx-edu-sharing-ui 10.0.21 → 10.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/assets/scss/material-theme.scss +3 -3
  2. package/assets/scss/mixins.scss +1 -1
  3. package/assets/scss/variables-root.scss +2 -0
  4. package/assets/scss/variables-scss.scss +3 -4
  5. package/assets/scss/variables.scss +1 -1
  6. package/fesm2022/ngx-edu-sharing-ui.mjs +376 -319
  7. package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
  8. package/lib/index.d.ts +1 -0
  9. package/lib/list-items/list-widget.d.ts +1 -1
  10. package/lib/mds-viewer/mds-editor-instance-service.abstract.d.ts +14 -0
  11. package/lib/mds-viewer/widget/mds-widget.component.d.ts +6 -4
  12. package/package.json +6 -8
  13. package/esm2022/lib/actionbar/actionbar.component.mjs +0 -206
  14. package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +0 -170
  15. package/esm2022/lib/directives/border-box-observer.directive.mjs +0 -71
  16. package/esm2022/lib/directives/check-text-overflow.directive.mjs +0 -71
  17. package/esm2022/lib/directives/drag-nodes/drag-nodes.mjs +0 -14
  18. package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +0 -79
  19. package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +0 -49
  20. package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +0 -105
  21. package/esm2022/lib/directives/focus-state.directive.mjs +0 -44
  22. package/esm2022/lib/directives/icon.directive.mjs +0 -184
  23. package/esm2022/lib/directives/infinite-scroll.directive.mjs +0 -85
  24. package/esm2022/lib/dropdown/dropdown.component.mjs +0 -83
  25. package/esm2022/lib/edu-sharing-ui-configuration.mjs +0 -48
  26. package/esm2022/lib/edu-sharing-ui.module.mjs +0 -82
  27. package/esm2022/lib/index.mjs +0 -96
  28. package/esm2022/lib/list-items/available-widgets.mjs +0 -27
  29. package/esm2022/lib/list-items/format-duration.pipe.mjs +0 -20
  30. package/esm2022/lib/list-items/list-base/list-base.component.mjs +0 -46
  31. package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +0 -29
  32. package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +0 -56
  33. package/esm2022/lib/list-items/list-items.module.mjs +0 -50
  34. package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +0 -41
  35. package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +0 -47
  36. package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +0 -24
  37. package/esm2022/lib/list-items/list-text/list-text.component.mjs +0 -106
  38. package/esm2022/lib/list-items/list-widget.mjs +0 -49
  39. package/esm2022/lib/list-items/node-row/node-row.component.mjs +0 -24
  40. package/esm2022/lib/list-items/node-source.pipe.mjs +0 -49
  41. package/esm2022/lib/mds/mds-helper.service.mjs +0 -167
  42. package/esm2022/lib/mds/mds.module.mjs +0 -16
  43. package/esm2022/lib/mds-viewer/mds-viewer.component.mjs +0 -170
  44. package/esm2022/lib/mds-viewer/mds-viewer.service.mjs +0 -18
  45. package/esm2022/lib/mds-viewer/replace-element-with-div.mjs +0 -47
  46. package/esm2022/lib/mds-viewer/view-instance.service.mjs +0 -27
  47. package/esm2022/lib/mds-viewer/widget/mds-widget.component.mjs +0 -379
  48. package/esm2022/lib/node-entries/combined-data-source.mjs +0 -41
  49. package/esm2022/lib/node-entries/custom-templates-data-source.mjs +0 -7
  50. package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +0 -21
  51. package/esm2022/lib/node-entries/entries-model.mjs +0 -24
  52. package/esm2022/lib/node-entries/items-cap.mjs +0 -47
  53. package/esm2022/lib/node-entries/list-item-label.pipe.mjs +0 -37
  54. package/esm2022/lib/node-entries/node-cache.mjs +0 -73
  55. package/esm2022/lib/node-entries/node-data-source-remote.mjs +0 -4
  56. package/esm2022/lib/node-entries/node-data-source.mjs +0 -117
  57. package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +0 -117
  58. package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +0 -329
  59. package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +0 -44
  60. package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +0 -27
  61. package/esm2022/lib/node-entries/node-entries-global.service.mjs +0 -71
  62. package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +0 -42
  63. package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +0 -294
  64. package/esm2022/lib/node-entries/node-entries-templates.service.mjs +0 -11
  65. package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +0 -369
  66. package/esm2022/lib/node-entries/node-entries.component.mjs +0 -132
  67. package/esm2022/lib/node-entries/node-entries.module.mjs +0 -161
  68. package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +0 -125
  69. package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +0 -48
  70. package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +0 -36
  71. package/esm2022/lib/node-entries/option-button/option-button.component.mjs +0 -75
  72. package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +0 -53
  73. package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +0 -41
  74. package/esm2022/lib/node-url/node-url.component.mjs +0 -132
  75. package/esm2022/lib/pipes/file-size.pipe.mjs +0 -32
  76. package/esm2022/lib/pipes/format-date.pipe.mjs +0 -38
  77. package/esm2022/lib/pipes/mds-duration.pipe.mjs +0 -25
  78. package/esm2022/lib/pipes/node-icon.pipe.mjs +0 -18
  79. package/esm2022/lib/pipes/node-image-size.pipe.mjs +0 -24
  80. package/esm2022/lib/pipes/node-image.pipe.mjs +0 -55
  81. package/esm2022/lib/pipes/node-license.pipe.mjs +0 -24
  82. package/esm2022/lib/pipes/node-person-name.pipe.mjs +0 -50
  83. package/esm2022/lib/pipes/node-title.pipe.mjs +0 -35
  84. package/esm2022/lib/pipes/option-tooltip.pipe.mjs +0 -33
  85. package/esm2022/lib/pipes/property-slug.pipe.mjs +0 -16
  86. package/esm2022/lib/pipes/replace-chars.pipe.mjs +0 -29
  87. package/esm2022/lib/pipes/vcard-name.pipe.mjs +0 -25
  88. package/esm2022/lib/services/abstract/app.service.mjs +0 -3
  89. package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +0 -10
  90. package/esm2022/lib/services/abstract/options-helper.service.mjs +0 -3
  91. package/esm2022/lib/services/abstract/toast.service.mjs +0 -3
  92. package/esm2022/lib/services/accessibility.service.mjs +0 -73
  93. package/esm2022/lib/services/app-container.service.mjs +0 -69
  94. package/esm2022/lib/services/local-events.service.mjs +0 -43
  95. package/esm2022/lib/services/node-entries.service.mjs +0 -201
  96. package/esm2022/lib/services/node-helper.service.mjs +0 -330
  97. package/esm2022/lib/services/nodes-drag-drop.service.mjs +0 -155
  98. package/esm2022/lib/services/options-helper-data.service.mjs +0 -142
  99. package/esm2022/lib/services/render-helper.service.mjs +0 -114
  100. package/esm2022/lib/services/repo-url.service.mjs +0 -50
  101. package/esm2022/lib/services/search-helper.service.mjs +0 -52
  102. package/esm2022/lib/services/temporary-storage.service.mjs +0 -48
  103. package/esm2022/lib/services/ui.service.mjs +0 -327
  104. package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +0 -50
  105. package/esm2022/lib/spinner/spinner.component.mjs +0 -19
  106. package/esm2022/lib/spinner-small/spinner-small.component.mjs +0 -18
  107. package/esm2022/lib/translations/fallback-translation-handler.mjs +0 -6
  108. package/esm2022/lib/translations/translation-loader.mjs +0 -219
  109. package/esm2022/lib/translations/translation-source.mjs +0 -11
  110. package/esm2022/lib/translations/translations.module.mjs +0 -82
  111. package/esm2022/lib/translations/translations.service.mjs +0 -238
  112. package/esm2022/lib/types/accessibillity.mjs +0 -19
  113. package/esm2022/lib/types/api-models.mjs +0 -2
  114. package/esm2022/lib/types/drag-drop.mjs +0 -2
  115. package/esm2022/lib/types/injection-tokens.mjs +0 -31
  116. package/esm2022/lib/types/keyboard-shortcuts.mjs +0 -11
  117. package/esm2022/lib/types/list-item.mjs +0 -41
  118. package/esm2022/lib/types/option-item.mjs +0 -192
  119. package/esm2022/lib/types/workflow.mjs +0 -25
  120. package/esm2022/lib/util/DateHelper.mjs +0 -200
  121. package/esm2022/lib/util/VCard.mjs +0 -278
  122. package/esm2022/lib/util/color-helper.mjs +0 -124
  123. package/esm2022/lib/util/duration-helper.mjs +0 -102
  124. package/esm2022/lib/util/functions.mjs +0 -13
  125. package/esm2022/lib/util/helper.mjs +0 -64
  126. package/esm2022/lib/util/isNumeric.mjs +0 -11
  127. package/esm2022/lib/util/rest-helper.mjs +0 -42
  128. package/esm2022/lib/util/ui-animation.mjs +0 -146
  129. package/esm2022/lib/util/ui-constants.mjs +0 -21
  130. package/esm2022/ngx-edu-sharing-ui.mjs +0 -5
  131. package/esm2022/public-api.mjs +0 -2
@@ -1,106 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as Constants from 'ngx-edu-sharing-api';
3
- import { RestConstants } from 'ngx-edu-sharing-api';
4
- import { BehaviorSubject, merge } from 'rxjs';
5
- import { switchMap } from 'rxjs/operators';
6
- import { ListItem } from '../../types/list-item';
7
- import { ListWidget } from '../list-widget';
8
- import { MdsHelperService } from '../../mds/mds-helper.service';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../../services/node-helper.service";
11
- import * as i2 from "ngx-edu-sharing-api";
12
- import * as i3 from "@angular/common";
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/node-title.pipe";
21
- import * as i12 from "../../pipes/vcard-name.pipe";
22
- import * as i13 from "@ngx-translate/core";
23
- import * as i14 from "../node-source.pipe";
24
- import * as i15 from "../format-duration.pipe";
25
- export class ListTextComponent extends ListWidget {
26
- static { this.supportedItems = [
27
- new ListItem('NODE', '*'),
28
- new ListItem('NODE_PROPOSAL', '*'),
29
- new ListItem('COLLECTION', '*'),
30
- new ListItem('ORG', '*'),
31
- new ListItem('GROUP', '*'),
32
- new ListItem('USER', '*'),
33
- ]; }
34
- constructor(nodeHelper, mds, changeDetectorRef) {
35
- super();
36
- this.nodeHelper = nodeHelper;
37
- this.mds = mds;
38
- this.changeDetectorRef = changeDetectorRef;
39
- this.DATE_FIELDS = RestConstants.DATE_FIELDS;
40
- this.VCARD_FIELDS = RestConstants.getAllVCardFields();
41
- this.displayName$ = new BehaviorSubject(null);
42
- }
43
- async ngOnInit() {
44
- merge([this.nodeSubject, this.itemSubject])
45
- .pipe(switchMap(() => this.updateDisplayname()))
46
- .subscribe((displayName) => { });
47
- }
48
- getNode() {
49
- if (this.item.type === 'NODE_PROPOSAL') {
50
- return this.node.proposal || this.node;
51
- }
52
- else if (this.node.type === RestConstants.CCM_TYPE_COLLECTION_PROPOSAL) {
53
- return this.node.relations?.Original ?? this.node;
54
- }
55
- return this.node;
56
- }
57
- isUserProfileAttribute(attribute) {
58
- return ([
59
- RestConstants.AUTHORITY_FIRSTNAME,
60
- RestConstants.AUTHORITY_LASTNAME,
61
- RestConstants.AUTHORITY_EMAIL,
62
- ].indexOf(attribute) !== -1);
63
- }
64
- getWorkflowStatus() {
65
- return this.nodeHelper.getWorkflowStatus(this.node).current;
66
- }
67
- getI18n(item) {
68
- return (item.type === 'NODE_PROPOSAL' ? 'NODE_PROPOSAL' : 'NODE') + '.' + item.name;
69
- }
70
- isDangerousGroup() {
71
- return (this.node.authorityName ===
72
- RestConstants.GROUP_ALFRESCO_ADMINISTRATORS);
73
- }
74
- async updateDisplayname() {
75
- const node = this.getNode();
76
- if (!node.properties) {
77
- this.displayName$.next('');
78
- return;
79
- }
80
- this.displayName$.next(node.properties[this.item.name + '_DISPLAYNAME']?.length > 0
81
- ? node.properties[this.item.name + '_DISPLAYNAME'].join(', ')
82
- : node.properties[this.item.name]?.join(', '));
83
- const mds = await this.mds
84
- .getMetadataSet({
85
- repository: node.ref?.repo || Constants.HOME_REPOSITORY,
86
- metadataSet: node.metadataset || Constants.DEFAULT,
87
- })
88
- .toPromise();
89
- const widget = MdsHelperService.getWidget(this.item.name, null, mds.widgets);
90
- if (widget?.values) {
91
- const i18n = node.properties[this.item.name]
92
- ?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)
93
- .filter((cap) => !!cap);
94
- if (i18n) {
95
- this.displayName$.next(i18n.join(', '));
96
- }
97
- }
98
- }
99
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", 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: "18.2.12", type: ListTextComponent, selector: "es-list-text", usesInheritance: 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 {{\n 'PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]\n | translate: { fallback: '' }\n }}\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()) | nodeTitle }}\n </ng-container>\n <ng-container *ngIf=\"['name', 'cm:name'].includes(item.name)\">\n {{ $any(getNode()) | nodeTitle : { type: 'name' } }}\n </ng-container>\n <ng-container\n *ngIf=\"!['name', 'cm:name', 'title', 'cm:title', 'cclom:title'].includes(item.name)\"\n >\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 {{\n ($any(getNode()).properties[item.name + '_LONG']?.[0] || $any(getNode()).properties[item.name]?.[0])\n | formatDate: { async: true, time: true, relative: true }\n | async\n }}\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] | 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]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], 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.NodeTitlePipe, name: "nodeTitle" }, { kind: "pipe", type: i12.VCardNamePipe, name: "vcardName" }, { kind: "pipe", type: i13.TranslatePipe, name: "translate" }, { kind: "pipe", type: i14.NodeSourcePipe, name: "appNodeSource" }, { kind: "pipe", type: i15.FormatDurationPipe, name: "formatDuration" }] }); }
101
- }
102
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ListTextComponent, decorators: [{
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 || $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 {{\n 'PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]\n | translate: { fallback: '' }\n }}\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()) | nodeTitle }}\n </ng-container>\n <ng-container *ngIf=\"['name', 'cm:name'].includes(item.name)\">\n {{ $any(getNode()) | nodeTitle : { type: 'name' } }}\n </ng-container>\n <ng-container\n *ngIf=\"!['name', 'cm:name', 'title', 'cm:title', 'cclom:title'].includes(item.name)\"\n >\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 {{\n ($any(getNode()).properties[item.name + '_LONG']?.[0] || $any(getNode()).properties[item.name]?.[0])\n | formatDate: { async: true, time: true, relative: true }\n | async\n }}\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] | 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
- }], ctorParameters: () => [{ 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 } from '@angular/core';\nimport * as Constants from 'ngx-edu-sharing-api';\nimport { MdsService, Node, Organization, ProposalNode, RestConstants } 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 { 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 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    {{\n      'PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]\n        | translate: { fallback: '' }\n    }}\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()) | nodeTitle }}\n    </ng-container>\n    <ng-container *ngIf=\"['name', 'cm:name'].includes(item.name)\">\n      {{ $any(getNode()) | nodeTitle : { type: 'name' } }}\n    </ng-container>\n    <ng-container\n      *ngIf=\"!['name', 'cm:name', 'title', 'cm:title', 'cclom:title'].includes(item.name)\"\n    >\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        {{\n          ($any(getNode()).properties[item.name + '_LONG']?.[0] || $any(getNode()).properties[item.name]?.[0])\n            | formatDate: { async: true, time: true, relative: true }\n            | async\n        }}\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] | vcardName)\n            : ''\n        }}\n      </ng-container>\n    </ng-container>\n  </span>\n</ng-container>\n"]}
@@ -1,49 +0,0 @@
1
- import { Input, Directive } from '@angular/core';
2
- import { BehaviorSubject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- export class ListWidget {
5
- get node() {
6
- return this.nodeSubject.value;
7
- }
8
- set node(value) {
9
- this.nodeSubject.next(value);
10
- }
11
- get item() {
12
- return this.itemSubject.value;
13
- }
14
- set item(value) {
15
- this.itemSubject.next(value);
16
- }
17
- /**
18
- * Provide a label for non-obvious fields that describes the field the given value belongs to.
19
- *
20
- * The label is included in a tooltip and made available for a11y technologies.
21
- *
22
- * Useful when the value is displayed without context.
23
- *
24
- * Other tooltips might be added even with this input set to `false`.
25
- */
26
- get provideLabel() {
27
- return this.provideLabelSubject.value;
28
- }
29
- set provideLabel(value) {
30
- this.provideLabelSubject.next(value);
31
- }
32
- constructor() {
33
- this.nodeSubject = new BehaviorSubject(null); // node (or group/user)
34
- this.itemSubject = new BehaviorSubject(null);
35
- this.provideLabelSubject = new BehaviorSubject(false);
36
- }
37
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ListWidget, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
38
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.12", type: ListWidget, inputs: { node: "node", item: "item", provideLabel: "provideLabel" }, ngImport: i0 }); }
39
- }
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ListWidget, decorators: [{
41
- type: Directive
42
- }], ctorParameters: () => [], propDecorators: { node: [{
43
- type: Input
44
- }], item: [{
45
- type: Input
46
- }], provideLabel: [{
47
- type: Input
48
- }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC13aWRnZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL2xpc3QtaXRlbXMvbGlzdC13aWRnZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBUSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFLdkMsTUFBTSxPQUFPLFVBQVU7SUFDbkIsSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBQ0QsSUFBSSxJQUFJLENBQUMsS0FBd0Q7UUFDN0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUtELElBQ0ksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUM7SUFDbEMsQ0FBQztJQUNELElBQUksSUFBSSxDQUFDLEtBQWU7UUFDcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUdEOzs7Ozs7OztPQVFHO0lBQ0gsSUFDSSxZQUFZO1FBQ1osT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDO0lBQzFDLENBQUM7SUFDRCxJQUFJLFlBQVksQ0FBQyxLQUFLO1FBQ2xCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUdEO1FBL0JtQixnQkFBVyxHQUFHLElBQUksZUFBZSxDQUVsRCxJQUFJLENBQUMsQ0FBQyxDQUFDLHVCQUF1QjtRQVNiLGdCQUFXLEdBQUcsSUFBSSxlQUFlLENBQVcsSUFBSSxDQUFDLENBQUM7UUFrQmxELHdCQUFtQixHQUFHLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXJELENBQUM7K0dBdkNQLFVBQVU7bUdBQVYsVUFBVTs7NEZBQVYsVUFBVTtrQkFEdEIsU0FBUzt3REFHRixJQUFJO3NCQURQLEtBQUs7Z0JBWUYsSUFBSTtzQkFEUCxLQUFLO2dCQW1CRixZQUFZO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnB1dCwgVHlwZSwgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQZXJzb24gfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTm9kZSwgUHJvcG9zYWxOb2RlLCBHcm91cCwgU3RhdGlzdGljcyB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBjbGFzcyBMaXN0V2lkZ2V0IHtcbiAgICBASW5wdXQoKVxuICAgIGdldCBub2RlKCk6IE5vZGUgfCBQcm9wb3NhbE5vZGUgfCBHcm91cCB8IFBlcnNvbiB8IFN0YXRpc3RpY3Mge1xuICAgICAgICByZXR1cm4gdGhpcy5ub2RlU3ViamVjdC52YWx1ZTtcbiAgICB9XG4gICAgc2V0IG5vZGUodmFsdWU6IE5vZGUgfCBQcm9wb3NhbE5vZGUgfCBHcm91cCB8IFBlcnNvbiB8IFN0YXRpc3RpY3MpIHtcbiAgICAgICAgdGhpcy5ub2RlU3ViamVjdC5uZXh0KHZhbHVlKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IG5vZGVTdWJqZWN0ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxcbiAgICAgICAgTm9kZSB8IFByb3Bvc2FsTm9kZSB8IEdyb3VwIHwgUGVyc29uIHwgU3RhdGlzdGljc1xuICAgID4obnVsbCk7IC8vIG5vZGUgKG9yIGdyb3VwL3VzZXIpXG5cbiAgICBASW5wdXQoKVxuICAgIGdldCBpdGVtKCk6IExpc3RJdGVtIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaXRlbVN1YmplY3QudmFsdWU7XG4gICAgfVxuICAgIHNldCBpdGVtKHZhbHVlOiBMaXN0SXRlbSkge1xuICAgICAgICB0aGlzLml0ZW1TdWJqZWN0Lm5leHQodmFsdWUpO1xuICAgIH1cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXRlbVN1YmplY3QgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PExpc3RJdGVtPihudWxsKTtcblxuICAgIC8qKlxuICAgICAqIFByb3ZpZGUgYSBsYWJlbCBmb3Igbm9uLW9idmlvdXMgZmllbGRzIHRoYXQgZGVzY3JpYmVzIHRoZSBmaWVsZCB0aGUgZ2l2ZW4gdmFsdWUgYmVsb25ncyB0by5cbiAgICAgKlxuICAgICAqIFRoZSBsYWJlbCBpcyBpbmNsdWRlZCBpbiBhIHRvb2x0aXAgYW5kIG1hZGUgYXZhaWxhYmxlIGZvciBhMTF5IHRlY2hub2xvZ2llcy5cbiAgICAgKlxuICAgICAqIFVzZWZ1bCB3aGVuIHRoZSB2YWx1ZSBpcyBkaXNwbGF5ZWQgd2l0aG91dCBjb250ZXh0LlxuICAgICAqXG4gICAgICogT3RoZXIgdG9vbHRpcHMgbWlnaHQgYmUgYWRkZWQgZXZlbiB3aXRoIHRoaXMgaW5wdXQgc2V0IHRvIGBmYWxzZWAuXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBnZXQgcHJvdmlkZUxhYmVsKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5wcm92aWRlTGFiZWxTdWJqZWN0LnZhbHVlO1xuICAgIH1cbiAgICBzZXQgcHJvdmlkZUxhYmVsKHZhbHVlKSB7XG4gICAgICAgIHRoaXMucHJvdmlkZUxhYmVsU3ViamVjdC5uZXh0KHZhbHVlKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHByb3ZpZGVMYWJlbFN1YmplY3QgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcblxuICAgIGNvbnN0cnVjdG9yKCkge31cbn1cblxuZXhwb3J0IHR5cGUgTGlzdFdpZGdldENsYXNzID0ge1xuICAgIHN1cHBvcnRlZEl0ZW1zOiBMaXN0SXRlbVtdO1xufSAmIFR5cGU8TGlzdFdpZGdldD47XG4iXX0=
@@ -1,24 +0,0 @@
1
- import { Component, ContentChild, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- import * as i2 from "@angular/material/tooltip";
5
- import * as i3 from "../list-text/list-text.component";
6
- import * as i4 from "../../pipes/node-icon.pipe";
7
- import * as i5 from "@ngx-translate/core";
8
- export class NodeRowComponent {
9
- constructor() { }
10
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeRowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
11
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeRowComponent, selector: "es-node-row", inputs: { node: "node", columns: "columns" }, queries: [{ propertyName: "customMetadataRef", first: true, predicate: ["customMetadata"], descendants: true }], ngImport: i0, template: "<div class=\"node-row\" *ngIf=\"node\">\n <div class=\"icon-bg\">\n <img\n [src]=\"node | esNodeIcon | async\"\n [alt]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n [matTooltip]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n />\n </div>\n <div class=\"node-data\">\n <div class=\"node-data-primary\">\n <es-list-text [node]=\"node\" [item]=\"columns[0]\"> </es-list-text>\n </div>\n <div class=\"node-data-secondary\">\n <es-list-text\n *ngFor=\"let column of columns.slice(1)\"\n [node]=\"node\"\n [item]=\"column\"\n [provideLabel]=\"true\"\n ></es-list-text>\n <ng-container *ngTemplateOutlet=\"customMetadataRef; context: { node: node }\"></ng-container>\n </div>\n </div>\n</div>\n", styles: [".node-row{width:100%;display:grid;grid-template-columns:var(--tableIconSize) auto;grid-gap:10px;align-items:center;padding:10px;white-space:normal}.node-row .node-data{flex-grow:1;display:flex;flex-direction:column}.node-row .node-data .node-data-primary{font-weight:700;padding-bottom:5px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.25em;max-height:1.25em;-webkit-line-clamp:1;-webkit-box-orient:vertical}.node-row .node-data .node-data-secondary{color:var(--textLight);display:flex;justify-content:space-between}.node-row .icon-bg{background-color:rgb(var(--palette-foreground-text-dark));border-radius:50%;width:var(--tableIconSize);height:var(--tableIconSize)!important;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 3px #0000001a}.node-row .icon-bg img,.node-row .icon-bg i{width:50%;z-index:0}.node-row .icon-bg i{color:rgb(var(--palette-foreground-text));font-size:20px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i3.ListTextComponent, selector: "es-list-text" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.NodeIconPipe, name: "esNodeIcon" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
12
- }
13
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeRowComponent, decorators: [{
14
- type: Component,
15
- args: [{ selector: 'es-node-row', template: "<div class=\"node-row\" *ngIf=\"node\">\n <div class=\"icon-bg\">\n <img\n [src]=\"node | esNodeIcon | async\"\n [alt]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n [matTooltip]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n />\n </div>\n <div class=\"node-data\">\n <div class=\"node-data-primary\">\n <es-list-text [node]=\"node\" [item]=\"columns[0]\"> </es-list-text>\n </div>\n <div class=\"node-data-secondary\">\n <es-list-text\n *ngFor=\"let column of columns.slice(1)\"\n [node]=\"node\"\n [item]=\"column\"\n [provideLabel]=\"true\"\n ></es-list-text>\n <ng-container *ngTemplateOutlet=\"customMetadataRef; context: { node: node }\"></ng-container>\n </div>\n </div>\n</div>\n", styles: [".node-row{width:100%;display:grid;grid-template-columns:var(--tableIconSize) auto;grid-gap:10px;align-items:center;padding:10px;white-space:normal}.node-row .node-data{flex-grow:1;display:flex;flex-direction:column}.node-row .node-data .node-data-primary{font-weight:700;padding-bottom:5px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-height:1.25em;max-height:1.25em;-webkit-line-clamp:1;-webkit-box-orient:vertical}.node-row .node-data .node-data-secondary{color:var(--textLight);display:flex;justify-content:space-between}.node-row .icon-bg{background-color:rgb(var(--palette-foreground-text-dark));border-radius:50%;width:var(--tableIconSize);height:var(--tableIconSize)!important;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 3px #0000001a}.node-row .icon-bg img,.node-row .icon-bg i{width:50%;z-index:0}.node-row .icon-bg i{color:rgb(var(--palette-foreground-text));font-size:20px}\n"] }]
16
- }], ctorParameters: () => [], propDecorators: { customMetadataRef: [{
17
- type: ContentChild,
18
- args: ['customMetadata']
19
- }], node: [{
20
- type: Input
21
- }], columns: [{
22
- type: Input
23
- }] } });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1yb3cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9saXN0LWl0ZW1zL25vZGUtcm93L25vZGUtcm93LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9ub2RlLXJvdy9ub2RlLXJvdy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFTNUUsTUFBTSxPQUFPLGdCQUFnQjtJQUt6QixnQkFBZSxDQUFDOytHQUxQLGdCQUFnQjttR0FBaEIsZ0JBQWdCLGtOQ1Q3Qix3OUJBK0JBOzs0RkR0QmEsZ0JBQWdCO2tCQUw1QixTQUFTOytCQUNJLGFBQWE7d0RBS1MsaUJBQWlCO3NCQUFoRCxZQUFZO3VCQUFDLGdCQUFnQjtnQkFDckIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vZGUgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IExpc3RJdGVtIH0gZnJvbSAnLi4vLi4vdHlwZXMvbGlzdC1pdGVtJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1ub2RlLXJvdycsXG4gICAgdGVtcGxhdGVVcmw6ICdub2RlLXJvdy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ25vZGUtcm93LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVSb3dDb21wb25lbnQge1xuICAgIEBDb250ZW50Q2hpbGQoJ2N1c3RvbU1ldGFkYXRhJykgY3VzdG9tTWV0YWRhdGFSZWY6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcbiAgICBASW5wdXQoKSBjb2x1bW5zOiBMaXN0SXRlbVtdO1xuXG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIiwiPGRpdiBjbGFzcz1cIm5vZGUtcm93XCIgKm5nSWY9XCJub2RlXCI+XG4gIDxkaXYgY2xhc3M9XCJpY29uLWJnXCI+XG4gICAgPGltZ1xuICAgICAgW3NyY109XCJub2RlIHwgZXNOb2RlSWNvbiB8IGFzeW5jXCJcbiAgICAgIFthbHRdPVwiXG4gICAgICAgIG5vZGUubWVkaWF0eXBlXG4gICAgICAgICAgPyAoJ05PREUubWVkaWF0eXBlJyB8IHRyYW5zbGF0ZSkgKyAnOiAnICsgKCdNRURJQVRZUEUuJyArIG5vZGUubWVkaWF0eXBlIHwgdHJhbnNsYXRlKVxuICAgICAgICAgIDogJydcbiAgICAgIFwiXG4gICAgICBbbWF0VG9vbHRpcF09XCJcbiAgICAgICAgbm9kZS5tZWRpYXR5cGVcbiAgICAgICAgICA/ICgnTk9ERS5tZWRpYXR5cGUnIHwgdHJhbnNsYXRlKSArICc6ICcgKyAoJ01FRElBVFlQRS4nICsgbm9kZS5tZWRpYXR5cGUgfCB0cmFuc2xhdGUpXG4gICAgICAgICAgOiAnJ1xuICAgICAgXCJcbiAgICAvPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm5vZGUtZGF0YVwiPlxuICAgIDxkaXYgY2xhc3M9XCJub2RlLWRhdGEtcHJpbWFyeVwiPlxuICAgICAgPGVzLWxpc3QtdGV4dCBbbm9kZV09XCJub2RlXCIgW2l0ZW1dPVwiY29sdW1uc1swXVwiPiA8L2VzLWxpc3QtdGV4dD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwibm9kZS1kYXRhLXNlY29uZGFyeVwiPlxuICAgICAgPGVzLWxpc3QtdGV4dFxuICAgICAgICAqbmdGb3I9XCJsZXQgY29sdW1uIG9mIGNvbHVtbnMuc2xpY2UoMSlcIlxuICAgICAgICBbbm9kZV09XCJub2RlXCJcbiAgICAgICAgW2l0ZW1dPVwiY29sdW1uXCJcbiAgICAgICAgW3Byb3ZpZGVMYWJlbF09XCJ0cnVlXCJcbiAgICAgID48L2VzLWxpc3QtdGV4dD5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjdXN0b21NZXRhZGF0YVJlZjsgY29udGV4dDogeyBub2RlOiBub2RlIH1cIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -1,49 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../services/node-helper.service";
4
- import * as i2 from "ngx-edu-sharing-api";
5
- export class NodeSourcePipe {
6
- constructor(nodeHelper, networkApi) {
7
- this.nodeHelper = nodeHelper;
8
- this.networkApi = networkApi;
9
- this.networkApi.getHomeRepository().subscribe((homeRepository) => {
10
- this.homeRepository = homeRepository;
11
- });
12
- }
13
- transform(replicationSource, args) {
14
- const rawSrc = replicationSource ? replicationSource.toString().trim() : 'home';
15
- if (args.mode === 'text') {
16
- if (rawSrc === 'home') {
17
- // FIXME: This will fix the pipe's return value to 'home' for calls before
18
- // `this.homeRepository` was populated (although that doesn't seem to happen).
19
- return this.homeRepository?.title || 'home';
20
- }
21
- return rawSrc;
22
- }
23
- else if (args.mode === 'url') {
24
- const src = this.escape(rawSrc);
25
- return this.nodeHelper.getSourceIconPath(src);
26
- }
27
- else if (args.mode === 'escaped') {
28
- return this.escape(rawSrc);
29
- }
30
- return null;
31
- }
32
- escape(src) {
33
- if (!src) {
34
- return src;
35
- }
36
- src = src.substring(src.lastIndexOf(':') + 1).toLowerCase();
37
- src = src.replace(/\s/g, '_');
38
- src = src.replace(/\./g, '_');
39
- src = src.replace(/\//g, '_');
40
- return src;
41
- }
42
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeSourcePipe, deps: [{ token: i1.NodeHelperService }, { token: i2.NetworkService }], target: i0.ɵɵFactoryTarget.Pipe }); }
43
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: NodeSourcePipe, name: "appNodeSource" }); }
44
- }
45
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeSourcePipe, decorators: [{
46
- type: Pipe,
47
- args: [{ name: 'appNodeSource' }]
48
- }], ctorParameters: () => [{ type: i1.NodeHelperService }, { type: i2.NetworkService }] });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1zb3VyY2UucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9ub2RlLXNvdXJjZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7O0FBS3BELE1BQU0sT0FBTyxjQUFjO0lBR3ZCLFlBQW9CLFVBQTZCLEVBQVUsVUFBMEI7UUFBakUsZUFBVSxHQUFWLFVBQVUsQ0FBbUI7UUFBVSxlQUFVLEdBQVYsVUFBVSxDQUFnQjtRQUNqRixJQUFJLENBQUMsVUFBVSxDQUFDLGlCQUFpQixFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMsY0FBYyxFQUFFLEVBQUU7WUFDN0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsU0FBUyxDQUNMLGlCQUF5QixFQUN6QixJQUVDO1FBRUQsTUFBTSxNQUFNLEdBQUcsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDaEYsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLE1BQU0sRUFBRSxDQUFDO1lBQ3ZCLElBQUksTUFBTSxLQUFLLE1BQU0sRUFBRSxDQUFDO2dCQUNwQiwwRUFBMEU7Z0JBQzFFLDhFQUE4RTtnQkFDOUUsT0FBTyxJQUFJLENBQUMsY0FBYyxFQUFFLEtBQUssSUFBSSxNQUFNLENBQUM7WUFDaEQsQ0FBQztZQUNELE9BQU8sTUFBTSxDQUFDO1FBQ2xCLENBQUM7YUFBTSxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDN0IsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNoQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbEQsQ0FBQzthQUFNLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxNQUFNLENBQUMsR0FBVztRQUN0QixJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDUCxPQUFPLEdBQUcsQ0FBQztRQUNmLENBQUM7UUFDRCxHQUFHLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVELEdBQUcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM5QixHQUFHLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDOUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQzlCLE9BQU8sR0FBRyxDQUFDO0lBQ2YsQ0FBQzsrR0F6Q1EsY0FBYzs2R0FBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUQxQixJQUFJO21CQUFDLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ldHdvcmtTZXJ2aWNlLCBSZXBvc2l0b3J5IH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBOb2RlSGVscGVyU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL25vZGUtaGVscGVyLnNlcnZpY2UnO1xuXG5AUGlwZSh7IG5hbWU6ICdhcHBOb2RlU291cmNlJyB9KVxuZXhwb3J0IGNsYXNzIE5vZGVTb3VyY2VQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgcHJpdmF0ZSBob21lUmVwb3NpdG9yeTogUmVwb3NpdG9yeTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbm9kZUhlbHBlcjogTm9kZUhlbHBlclNlcnZpY2UsIHByaXZhdGUgbmV0d29ya0FwaTogTmV0d29ya1NlcnZpY2UpIHtcbiAgICAgICAgdGhpcy5uZXR3b3JrQXBpLmdldEhvbWVSZXBvc2l0b3J5KCkuc3Vic2NyaWJlKChob21lUmVwb3NpdG9yeSkgPT4ge1xuICAgICAgICAgICAgdGhpcy5ob21lUmVwb3NpdG9yeSA9IGhvbWVSZXBvc2l0b3J5O1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICB0cmFuc2Zvcm0oXG4gICAgICAgIHJlcGxpY2F0aW9uU291cmNlOiBzdHJpbmcsXG4gICAgICAgIGFyZ3M6IHtcbiAgICAgICAgICAgIG1vZGU6ICd0ZXh0JyB8ICd1cmwnIHwgJ2VzY2FwZWQnO1xuICAgICAgICB9LFxuICAgICk6IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHJhd1NyYyA9IHJlcGxpY2F0aW9uU291cmNlID8gcmVwbGljYXRpb25Tb3VyY2UudG9TdHJpbmcoKS50cmltKCkgOiAnaG9tZSc7XG4gICAgICAgIGlmIChhcmdzLm1vZGUgPT09ICd0ZXh0Jykge1xuICAgICAgICAgICAgaWYgKHJhd1NyYyA9PT0gJ2hvbWUnKSB7XG4gICAgICAgICAgICAgICAgLy8gRklYTUU6IFRoaXMgd2lsbCBmaXggdGhlIHBpcGUncyByZXR1cm4gdmFsdWUgdG8gJ2hvbWUnIGZvciBjYWxscyBiZWZvcmVcbiAgICAgICAgICAgICAgICAvLyBgdGhpcy5ob21lUmVwb3NpdG9yeWAgd2FzIHBvcHVsYXRlZCAoYWx0aG91Z2ggdGhhdCBkb2Vzbid0IHNlZW0gdG8gaGFwcGVuKS5cbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5ob21lUmVwb3NpdG9yeT8udGl0bGUgfHwgJ2hvbWUnO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHJhd1NyYztcbiAgICAgICAgfSBlbHNlIGlmIChhcmdzLm1vZGUgPT09ICd1cmwnKSB7XG4gICAgICAgICAgICBjb25zdCBzcmMgPSB0aGlzLmVzY2FwZShyYXdTcmMpO1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMubm9kZUhlbHBlci5nZXRTb3VyY2VJY29uUGF0aChzcmMpO1xuICAgICAgICB9IGVsc2UgaWYgKGFyZ3MubW9kZSA9PT0gJ2VzY2FwZWQnKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5lc2NhcGUocmF3U3JjKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBwcml2YXRlIGVzY2FwZShzcmM6IHN0cmluZykge1xuICAgICAgICBpZiAoIXNyYykge1xuICAgICAgICAgICAgcmV0dXJuIHNyYztcbiAgICAgICAgfVxuICAgICAgICBzcmMgPSBzcmMuc3Vic3RyaW5nKHNyYy5sYXN0SW5kZXhPZignOicpICsgMSkudG9Mb3dlckNhc2UoKTtcbiAgICAgICAgc3JjID0gc3JjLnJlcGxhY2UoL1xccy9nLCAnXycpO1xuICAgICAgICBzcmMgPSBzcmMucmVwbGFjZSgvXFwuL2csICdfJyk7XG4gICAgICAgIHNyYyA9IHNyYy5yZXBsYWNlKC9cXC8vZywgJ18nKTtcbiAgICAgICAgcmV0dXJuIHNyYztcbiAgICB9XG59XG4iXX0=
@@ -1,167 +0,0 @@
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: "18.2.12", ngImport: i0, type: MdsHelperService, deps: [{ token: i1.AuthenticationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
162
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsHelperService }); }
163
- }
164
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsHelperService, decorators: [{
165
- type: Injectable
166
- }], ctorParameters: () => [{ 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"]}
@@ -1,16 +0,0 @@
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: "18.2.12", ngImport: i0, type: MdsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: MdsModule }); }
7
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsModule, providers: [MdsHelperService] }); }
8
- }
9
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MdsModule, decorators: [{
10
- type: NgModule,
11
- args: [{
12
- declarations: [],
13
- providers: [MdsHelperService],
14
- }]
15
- }] });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbWRzL21kcy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFNeEQsTUFBTSxPQUFPLFNBQVM7K0dBQVQsU0FBUztnSEFBVCxTQUFTO2dIQUFULFNBQVMsYUFGUCxDQUFDLGdCQUFnQixDQUFDOzs0RkFFcEIsU0FBUztrQkFKckIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsU0FBUyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQ2hDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1kc0hlbHBlclNlcnZpY2UgfSBmcm9tICcuL21kcy1oZWxwZXIuc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXSxcbiAgICBwcm92aWRlcnM6IFtNZHNIZWxwZXJTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWRzTW9kdWxlIHt9XG4iXX0=