ngx-edu-sharing-ui 9.1.1 → 9.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/scss/variables-scss.scss +2 -0
- package/assets/scss/variables.scss +2 -1
- package/esm2022/lib/actionbar/actionbar.component.mjs +6 -6
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +4 -4
- package/esm2022/lib/directives/border-box-observer.directive.mjs +5 -5
- package/esm2022/lib/directives/check-text-overflow.directive.mjs +5 -5
- package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +5 -5
- package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +5 -5
- package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +5 -5
- package/esm2022/lib/directives/focus-state.directive.mjs +5 -5
- package/esm2022/lib/directives/icon.directive.mjs +6 -6
- package/esm2022/lib/directives/infinite-scroll.directive.mjs +5 -5
- package/esm2022/lib/dropdown/dropdown.component.mjs +6 -6
- package/esm2022/lib/edu-sharing-ui-configuration.mjs +3 -3
- package/esm2022/lib/edu-sharing-ui.module.mjs +9 -5
- package/esm2022/lib/list-items/format-duration.pipe.mjs +3 -3
- package/esm2022/lib/list-items/list-base/list-base.component.mjs +5 -5
- package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +5 -5
- package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +4 -4
- package/esm2022/lib/list-items/list-items.module.mjs +4 -4
- package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +5 -5
- package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +5 -5
- package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +5 -5
- package/esm2022/lib/list-items/list-text/list-text.component.mjs +8 -10
- package/esm2022/lib/list-items/list-widget.mjs +5 -5
- package/esm2022/lib/list-items/node-row/node-row.component.mjs +5 -5
- package/esm2022/lib/list-items/node-source.pipe.mjs +5 -5
- package/esm2022/lib/mds/mds-helper.service.mjs +167 -0
- package/esm2022/lib/mds/mds.module.mjs +16 -0
- package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +3 -3
- package/esm2022/lib/node-entries/items-cap.mjs +1 -1
- package/esm2022/lib/node-entries/list-item-label.pipe.mjs +5 -5
- package/esm2022/lib/node-entries/node-cache.mjs +1 -1
- package/esm2022/lib/node-entries/node-data-source-remote.mjs +1 -1
- package/esm2022/lib/node-entries/node-data-source.mjs +1 -1
- package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +7 -7
- package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +10 -6
- package/esm2022/lib/node-entries/node-entries-global.service.mjs +5 -5
- package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-templates.service.mjs +4 -4
- package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +5 -5
- package/esm2022/lib/node-entries/node-entries.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries.module.mjs +4 -4
- package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +5 -5
- package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +5 -5
- package/esm2022/lib/node-entries/option-button/option-button.component.mjs +5 -5
- package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +5 -5
- package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +5 -5
- package/esm2022/lib/node-url/node-url.component.mjs +5 -5
- package/esm2022/lib/pipes/file-size.pipe.mjs +5 -5
- package/esm2022/lib/pipes/format-date.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-icon.pipe.mjs +4 -4
- package/esm2022/lib/pipes/node-image-size.pipe.mjs +4 -4
- package/esm2022/lib/pipes/node-image.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-person-name.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-title.pipe.mjs +4 -4
- package/esm2022/lib/pipes/option-tooltip.pipe.mjs +5 -5
- package/esm2022/lib/pipes/property-slug.pipe.mjs +3 -3
- package/esm2022/lib/pipes/replace-chars.pipe.mjs +5 -5
- package/esm2022/lib/pipes/vcard-name.pipe.mjs +4 -4
- package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +3 -3
- package/esm2022/lib/services/accessibility.service.mjs +5 -5
- package/esm2022/lib/services/app-container.service.mjs +5 -5
- package/esm2022/lib/services/local-events.service.mjs +3 -3
- package/esm2022/lib/services/node-entries.service.mjs +5 -5
- package/esm2022/lib/services/node-helper.service.mjs +6 -6
- package/esm2022/lib/services/nodes-drag-drop.service.mjs +5 -5
- package/esm2022/lib/services/options-helper-data.service.mjs +6 -6
- package/esm2022/lib/services/repo-url.service.mjs +5 -5
- package/esm2022/lib/services/temporary-storage.service.mjs +5 -5
- package/esm2022/lib/services/ui.service.mjs +5 -5
- package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +5 -5
- package/esm2022/lib/spinner/spinner.component.mjs +6 -6
- package/esm2022/lib/translations/translation-loader.mjs +5 -4
- package/esm2022/lib/translations/translations.module.mjs +7 -7
- package/esm2022/lib/translations/translations.service.mjs +16 -8
- package/esm2022/lib/util/DateHelper.mjs +1 -1
- package/esm2022/lib/util/VCard.mjs +1 -1
- package/esm2022/lib/util/color-helper.mjs +1 -1
- package/esm2022/lib/util/duration-helper.mjs +1 -1
- package/esm2022/lib/util/helper.mjs +1 -1
- package/esm2022/lib/util/rest-helper.mjs +1 -1
- package/esm2022/module.mjs +3 -1
- package/fesm2022/ngx-edu-sharing-ui.mjs +533 -346
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/edu-sharing-ui.module.d.ts +7 -6
- package/lib/mds/mds-helper.service.d.ts +37 -0
- package/lib/mds/mds.module.d.ts +6 -0
- package/lib/node-entries/node-data-source-remote.d.ts +2 -2
- package/lib/node-entries/node-entries-global-options/node-entries-global-options.component.d.ts +1 -0
- package/lib/types/option-item.d.ts +21 -21
- package/lib/util/ui-constants.d.ts +2 -2
- package/module.d.ts +2 -0
- package/package.json +5 -5
|
@@ -31,11 +31,11 @@ export class ListNodeLicenseComponent extends ListWidget {
|
|
|
31
31
|
}));
|
|
32
32
|
this.indicatorIcons$ = this.accessibility.observe('indicatorIcons');
|
|
33
33
|
}
|
|
34
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeLicenseComponent, deps: [{ token: i1.AccessibilityService }, { token: i2.NodeHelperService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: ListNodeLicenseComponent, selector: "es-list-node-license", usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"licenseIcon$ | async as licenseIcon\">\n <span *ngIf=\"indicatorIcons$ | async; else textRepresentation\" [matTooltip]=\"tooltip$ | async\"\n ><img [alt]=\"tooltip$ | async\" [src]=\"licenseIcon\"\n /></span>\n <ng-template #textRepresentation>\n <span>{{ tooltip$ | async }}</span>\n </ng-template>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }] }); }
|
|
36
36
|
}
|
|
37
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeLicenseComponent, decorators: [{
|
|
38
38
|
type: Component,
|
|
39
39
|
args: [{ selector: 'es-list-node-license', template: "<ng-container *ngIf=\"licenseIcon$ | async as licenseIcon\">\n <span *ngIf=\"indicatorIcons$ | async; else textRepresentation\" [matTooltip]=\"tooltip$ | async\"\n ><img [alt]=\"tooltip$ | async\" [src]=\"licenseIcon\"\n /></span>\n <ng-template #textRepresentation>\n <span>{{ tooltip$ | async }}</span>\n </ng-template>\n</ng-container>\n" }]
|
|
40
|
-
}], ctorParameters:
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
}], ctorParameters: () => [{ type: i1.AccessibilityService }, { type: i2.NodeHelperService }, { type: i3.TranslateService }] });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1ub2RlLWxpY2Vuc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9saXN0LWl0ZW1zL2xpc3Qtbm9kZS1saWNlbnNlL2xpc3Qtbm9kZS1saWNlbnNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LW5vZGUtbGljZW5zZS9saXN0LW5vZGUtbGljZW5zZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU1QyxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVqRCxPQUFPLEVBQVEsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7Ozs7QUFPMUQsTUFBTSxPQUFPLHdCQUF5QixTQUFRLFVBQVU7YUFDN0MsbUJBQWMsR0FBRyxDQUFDLElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRSxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxBQUF6RCxDQUEwRDtJQXdCL0UsWUFDWSxhQUFtQyxFQUNuQyxVQUE2QixFQUM3QixTQUEyQjtRQUVuQyxLQUFLLEVBQUUsQ0FBQztRQUpBLGtCQUFhLEdBQWIsYUFBYSxDQUFzQjtRQUNuQyxlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUM3QixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQXpCOUIsaUJBQVksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FDekMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFZLENBQUMsQ0FBQyxDQUM5RCxDQUFDO1FBRU8saUJBQVksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FDekMsU0FBUyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFZLENBQUMsQ0FBQyxDQUNwRSxDQUFDO1FBRU8sYUFBUSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUN0RixTQUFTLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxZQUFZLENBQUMsRUFBRSxFQUFFO1lBQ3RDLElBQUksWUFBWSxFQUFFLENBQUM7Z0JBQ2YsT0FBTyxJQUFJLENBQUMsU0FBUztxQkFDaEIsR0FBRyxDQUFDLDRCQUE0QixDQUFDO3FCQUNqQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLEdBQUcsZ0JBQWdCLEtBQUssV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ2hGLENBQUM7aUJBQU0sQ0FBQztnQkFDSixPQUFPLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDaEMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUNMLENBQUM7UUFFTyxvQkFBZSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFReEUsQ0FBQzs4R0EvQlEsd0JBQXdCO2tHQUF4Qix3QkFBd0IsbUZDZHJDLGdXQVFBOzsyRkRNYSx3QkFBd0I7a0JBSnBDLFNBQVM7K0JBQ0ksc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBMaXN0V2lkZ2V0IH0gZnJvbSAnLi4vbGlzdC13aWRnZXQnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0ICogYXMgcnhqcyBmcm9tICdyeGpzJztcbmltcG9ydCB7IG1hcCwgc3dpdGNoTWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi8uLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgTm9kZUhlbHBlclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9ub2RlLWhlbHBlci5zZXJ2aWNlJztcbmltcG9ydCB7IE5vZGUsIFJlc3RDb25zdGFudHMgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IEFjY2Vzc2liaWxpdHlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvYWNjZXNzaWJpbGl0eS5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1saXN0LW5vZGUtbGljZW5zZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xpc3Qtbm9kZS1saWNlbnNlLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgTGlzdE5vZGVMaWNlbnNlQ29tcG9uZW50IGV4dGVuZHMgTGlzdFdpZGdldCB7XG4gICAgc3RhdGljIHN1cHBvcnRlZEl0ZW1zID0gW25ldyBMaXN0SXRlbSgnTk9ERScsIFJlc3RDb25zdGFudHMuQ0NNX1BST1BfTElDRU5TRSldO1xuXG4gICAgcmVhZG9ubHkgbGljZW5zZU5hbWUkID0gdGhpcy5ub2RlU3ViamVjdC5waXBlKFxuICAgICAgICBtYXAoKG5vZGUpID0+IHRoaXMubm9kZUhlbHBlci5nZXRMaWNlbnNlTmFtZShub2RlIGFzIE5vZGUpKSxcbiAgICApO1xuXG4gICAgcmVhZG9ubHkgbGljZW5zZUljb24kID0gdGhpcy5ub2RlU3ViamVjdC5waXBlKFxuICAgICAgICBzd2l0Y2hNYXAoKG5vZGUpID0+IHRoaXMubm9kZUhlbHBlci5nZXRMaWNlbnNlSWNvbihub2RlIGFzIE5vZGUpKSxcbiAgICApO1xuXG4gICAgcmVhZG9ubHkgdG9vbHRpcCQgPSByeGpzLmNvbWJpbmVMYXRlc3QoW3RoaXMubGljZW5zZU5hbWUkLCB0aGlzLnByb3ZpZGVMYWJlbFN1YmplY3RdKS5waXBlKFxuICAgICAgICBzd2l0Y2hNYXAoKFtsaWNlbnNlTmFtZSwgcHJvdmlkZUxhYmVsXSkgPT4ge1xuICAgICAgICAgICAgaWYgKHByb3ZpZGVMYWJlbCkge1xuICAgICAgICAgICAgICAgIHJldHVybiB0aGlzLnRyYW5zbGF0ZVxuICAgICAgICAgICAgICAgICAgICAuZ2V0KCdOT0RFLmNjbTpjb21tb25saWNlbnNlX2tleScpXG4gICAgICAgICAgICAgICAgICAgIC5waXBlKG1hcCgoY29tbW9uTGljZW5zZUtleSkgPT4gYCR7Y29tbW9uTGljZW5zZUtleX06ICR7bGljZW5zZU5hbWV9YCkpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gcnhqcy5vZihsaWNlbnNlTmFtZSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pLFxuICAgICk7XG5cbiAgICByZWFkb25seSBpbmRpY2F0b3JJY29ucyQgPSB0aGlzLmFjY2Vzc2liaWxpdHkub2JzZXJ2ZSgnaW5kaWNhdG9ySWNvbnMnKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGFjY2Vzc2liaWxpdHk6IEFjY2Vzc2liaWxpdHlTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIG5vZGVIZWxwZXI6IE5vZGVIZWxwZXJTZXJ2aWNlLFxuICAgICAgICBwcml2YXRlIHRyYW5zbGF0ZTogVHJhbnNsYXRlU2VydmljZSxcbiAgICApIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwibGljZW5zZUljb24kIHwgYXN5bmMgYXMgbGljZW5zZUljb25cIj5cbiAgPHNwYW4gKm5nSWY9XCJpbmRpY2F0b3JJY29ucyQgfCBhc3luYzsgZWxzZSB0ZXh0UmVwcmVzZW50YXRpb25cIiBbbWF0VG9vbHRpcF09XCJ0b29sdGlwJCB8IGFzeW5jXCJcbiAgICA+PGltZyBbYWx0XT1cInRvb2x0aXAkIHwgYXN5bmNcIiBbc3JjXT1cImxpY2Vuc2VJY29uXCJcbiAgLz48L3NwYW4+XG4gIDxuZy10ZW1wbGF0ZSAjdGV4dFJlcHJlc2VudGF0aW9uPlxuICAgIDxzcGFuPnt7IHRvb2x0aXAkIHwgYXN5bmMgfX08L3NwYW4+XG4gIDwvbmctdGVtcGxhdGU+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -37,11 +37,11 @@ export class ListNodeReplicationSourceComponent extends ListWidget {
|
|
|
37
37
|
}));
|
|
38
38
|
this.indicatorIcons$ = this.accessibility.observe('indicatorIcons');
|
|
39
39
|
}
|
|
40
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
41
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
40
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeReplicationSourceComponent, deps: [{ token: i1.AccessibilityService }, { token: i2.NodeSourcePipe }, { token: i3.TranslateService }, { token: i4.NetworkService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: ListNodeReplicationSourceComponent, selector: "es-list-node-replication-source", providers: [NodeSourcePipe], usesInheritance: true, ngImport: i0, template: "<span *ngIf=\"indicatorIcons$ | async; else textRepresentation\" [matTooltip]=\"tooltip$ | async\">\n <img\n [src]=\"replicationSource$ | async | appNodeSource : { mode: 'url' }\"\n (error)=\"$any($event.target).style.display = 'none'\"\n [alt]=\"tooltip$ | async\"\n />\n</span>\n\n<ng-template #textRepresentation>\n <span>{{ tooltip$ | async }}</span>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.NodeSourcePipe, name: "appNodeSource" }] }); }
|
|
42
42
|
}
|
|
43
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeReplicationSourceComponent, decorators: [{
|
|
44
44
|
type: Component,
|
|
45
45
|
args: [{ selector: 'es-list-node-replication-source', providers: [NodeSourcePipe], template: "<span *ngIf=\"indicatorIcons$ | async; else textRepresentation\" [matTooltip]=\"tooltip$ | async\">\n <img\n [src]=\"replicationSource$ | async | appNodeSource : { mode: 'url' }\"\n (error)=\"$any($event.target).style.display = 'none'\"\n [alt]=\"tooltip$ | async\"\n />\n</span>\n\n<ng-template #textRepresentation>\n <span>{{ tooltip$ | async }}</span>\n</ng-template>\n" }]
|
|
46
|
-
}], ctorParameters:
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
}], ctorParameters: () => [{ type: i1.AccessibilityService }, { type: i2.NodeSourcePipe }, { type: i3.TranslateService }, { type: i4.NetworkService }] });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1ub2RlLXJlcGxpY2F0aW9uLXNvdXJjZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL2xpc3QtaXRlbXMvbGlzdC1ub2RlLXJlcGxpY2F0aW9uLXNvdXJjZS9saXN0LW5vZGUtcmVwbGljYXRpb24tc291cmNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LW5vZGUtcmVwbGljYXRpb24tc291cmNlL2xpc3Qtbm9kZS1yZXBsaWNhdGlvbi1zb3VyY2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFckQsT0FBTyxFQUF3QixhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7Ozs7O0FBT2pELE1BQU0sT0FBTyxrQ0FBbUMsU0FBUSxVQUFVO2FBQ3ZELG1CQUFjLEdBQUcsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxNQUFNLEVBQUUsYUFBYSxDQUFDLDBCQUEwQixDQUFDLENBQUMsQUFBbkUsQ0FBb0U7SUFrQ3pGLFlBQ1ksYUFBbUMsRUFFbkMsVUFBMEIsRUFDMUIsU0FBMkIsRUFDM0IsY0FBOEI7UUFFdEMsS0FBSyxFQUFFLENBQUM7UUFOQSxrQkFBYSxHQUFiLGFBQWEsQ0FBc0I7UUFFbkMsZUFBVSxHQUFWLFVBQVUsQ0FBZ0I7UUFDMUIsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFDM0IsbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBckNqQyx1QkFBa0IsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FDL0MsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBRSxJQUFhLENBQUMsVUFBVSxDQUFDLHVCQUF1QixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUN6RSxDQUFDO1FBRU8sVUFBSyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJO1FBQ3pDLDRGQUE0RjtRQUM1RixlQUFlO1FBQ2YsU0FBUyxDQUFDLENBQUMsaUJBQWlCLEVBQUUsRUFBRSxDQUM1QixJQUFJLENBQUMsY0FBYyxDQUFDLGVBQWUsRUFBRSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUMzRSxFQUNELFNBQVMsQ0FBQyxDQUFDLGlCQUFpQixFQUFFLEVBQUUsQ0FDNUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQ2QsZUFBZSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxDQUFDLEVBQ25GLEVBQUUsUUFBUSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLGlCQUFpQixFQUFFLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FDL0UsQ0FDSixDQUNKLENBQUM7UUFFTyxhQUFRLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQy9FLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLFlBQVksQ0FBQyxFQUFFLEVBQUU7WUFDL0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztnQkFDZixPQUFPLElBQUksQ0FBQyxTQUFTO3FCQUNoQixHQUFHLENBQUMsNEJBQTRCLENBQUM7cUJBQ2pDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLENBQUMsR0FBRyxpQkFBaUIsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDM0UsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLE9BQU8sSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN6QixDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQ0wsQ0FBQztRQUVPLG9CQUFlLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQVV4RSxDQUFDOzhHQTNDUSxrQ0FBa0M7a0dBQWxDLGtDQUFrQywwREFGaEMsQ0FBQyxjQUFjLENBQUMsaURDYi9CLGtZQVdBOzsyRkRJYSxrQ0FBa0M7a0JBTDlDLFNBQVM7K0JBQ0ksaUNBQWlDLGFBRWhDLENBQUMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgKiBhcyByeGpzIGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBMaXN0V2lkZ2V0IH0gZnJvbSAnLi4vbGlzdC13aWRnZXQnO1xuaW1wb3J0IHsgTm9kZVNvdXJjZVBpcGUgfSBmcm9tICcuLi9ub2RlLXNvdXJjZS5waXBlJztcbmltcG9ydCB7IEFjY2Vzc2liaWxpdHlTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvYWNjZXNzaWJpbGl0eS5zZXJ2aWNlJztcbmltcG9ydCB7IE5ldHdvcmtTZXJ2aWNlLCBOb2RlLCBSZXN0Q29uc3RhbnRzIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBMaXN0SXRlbSB9IGZyb20gJy4uLy4uL3R5cGVzL2xpc3QtaXRlbSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtbGlzdC1ub2RlLXJlcGxpY2F0aW9uLXNvdXJjZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xpc3Qtbm9kZS1yZXBsaWNhdGlvbi1zb3VyY2UuY29tcG9uZW50Lmh0bWwnLFxuICAgIHByb3ZpZGVyczogW05vZGVTb3VyY2VQaXBlXSxcbn0pXG5leHBvcnQgY2xhc3MgTGlzdE5vZGVSZXBsaWNhdGlvblNvdXJjZUNvbXBvbmVudCBleHRlbmRzIExpc3RXaWRnZXQge1xuICAgIHN0YXRpYyBzdXBwb3J0ZWRJdGVtcyA9IFtuZXcgTGlzdEl0ZW0oJ05PREUnLCBSZXN0Q29uc3RhbnRzLkNDTV9QUk9QX1JFUExJQ0FUSU9OU09VUkNFKV07XG5cbiAgICByZWFkb25seSByZXBsaWNhdGlvblNvdXJjZSQgPSB0aGlzLm5vZGVTdWJqZWN0LnBpcGUoXG4gICAgICAgIG1hcCgobm9kZSkgPT4gKG5vZGUgYXMgTm9kZSkucHJvcGVydGllc1snY2NtOnJlcGxpY2F0aW9uc291cmNlJ10/LlswXSksXG4gICAgKTtcblxuICAgIHJlYWRvbmx5IHRleHQkID0gdGhpcy5yZXBsaWNhdGlvblNvdXJjZSQucGlwZShcbiAgICAgICAgLy8gV2FpdCBmb3IgcmVwb3NpdG9yaWVzIHRvIGJlIGF2YWlsYWJsZSB0byBgcmVzdE5ldHdvcmtgIHNpbmNlIGBub2RlU291cmNlLnRyYW5zZm9ybWAgZmFpbHNcbiAgICAgICAgLy8gaWYgaXQgaXNuJ3QuXG4gICAgICAgIHN3aXRjaE1hcCgocmVwbGljYXRpb25Tb3VyY2UpID0+XG4gICAgICAgICAgICB0aGlzLm5ldHdvcmtTZXJ2aWNlLmdldFJlcG9zaXRvcmllcygpLnBpcGUobWFwKCgpID0+IHJlcGxpY2F0aW9uU291cmNlKSksXG4gICAgICAgICksXG4gICAgICAgIHN3aXRjaE1hcCgocmVwbGljYXRpb25Tb3VyY2UpID0+XG4gICAgICAgICAgICB0aGlzLnRyYW5zbGF0ZS5nZXQoXG4gICAgICAgICAgICAgICAgJ1JFUE9TSVRPUklFUy4nICsgdGhpcy5ub2RlU291cmNlLnRyYW5zZm9ybShyZXBsaWNhdGlvblNvdXJjZSwgeyBtb2RlOiAnZXNjYXBlZCcgfSksXG4gICAgICAgICAgICAgICAgeyBmYWxsYmFjazogdGhpcy5ub2RlU291cmNlLnRyYW5zZm9ybShyZXBsaWNhdGlvblNvdXJjZSwgeyBtb2RlOiAndGV4dCcgfSkgfSxcbiAgICAgICAgICAgICksXG4gICAgICAgICksXG4gICAgKTtcblxuICAgIHJlYWRvbmx5IHRvb2x0aXAkID0gcnhqcy5jb21iaW5lTGF0ZXN0KFt0aGlzLnRleHQkLCB0aGlzLnByb3ZpZGVMYWJlbFN1YmplY3RdKS5waXBlKFxuICAgICAgICBzd2l0Y2hNYXAoKFt0ZXh0LCBwcm92aWRlTGFiZWxdKSA9PiB7XG4gICAgICAgICAgICBpZiAocHJvdmlkZUxhYmVsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRlXG4gICAgICAgICAgICAgICAgICAgIC5nZXQoJ05PREUuY2NtOnJlcGxpY2F0aW9uc291cmNlJylcbiAgICAgICAgICAgICAgICAgICAgLnBpcGUobWFwKChyZXBsaWNhdGlvblNvdXJjZSkgPT4gYCR7cmVwbGljYXRpb25Tb3VyY2V9OiAke3RleHR9YCkpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gcnhqcy5vZih0ZXh0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSksXG4gICAgKTtcblxuICAgIHJlYWRvbmx5IGluZGljYXRvckljb25zJCA9IHRoaXMuYWNjZXNzaWJpbGl0eS5vYnNlcnZlKCdpbmRpY2F0b3JJY29ucycpO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgYWNjZXNzaWJpbGl0eTogQWNjZXNzaWJpbGl0eVNlcnZpY2UsXG5cbiAgICAgICAgcHJpdmF0ZSBub2RlU291cmNlOiBOb2RlU291cmNlUGlwZSxcbiAgICAgICAgcHJpdmF0ZSB0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbmV0d29ya1NlcnZpY2U6IE5ldHdvcmtTZXJ2aWNlLFxuICAgICkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cbn1cbiIsIjxzcGFuICpuZ0lmPVwiaW5kaWNhdG9ySWNvbnMkIHwgYXN5bmM7IGVsc2UgdGV4dFJlcHJlc2VudGF0aW9uXCIgW21hdFRvb2x0aXBdPVwidG9vbHRpcCQgfCBhc3luY1wiPlxuICA8aW1nXG4gICAgW3NyY109XCJyZXBsaWNhdGlvblNvdXJjZSQgfCBhc3luYyB8IGFwcE5vZGVTb3VyY2UgOiB7IG1vZGU6ICd1cmwnIH1cIlxuICAgIChlcnJvcik9XCIkYW55KCRldmVudC50YXJnZXQpLnN0eWxlLmRpc3BsYXkgPSAnbm9uZSdcIlxuICAgIFthbHRdPVwidG9vbHRpcCQgfCBhc3luY1wiXG4gIC8+XG48L3NwYW4+XG5cbjxuZy10ZW1wbGF0ZSAjdGV4dFJlcHJlc2VudGF0aW9uPlxuICA8c3Bhbj57eyB0b29sdGlwJCB8IGFzeW5jIH19PC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -14,11 +14,11 @@ export class ListNodeWorkflowComponent extends ListWidget {
|
|
|
14
14
|
getWorkflowStatus() {
|
|
15
15
|
return this.nodeHelper.getWorkflowStatus(this.node).current;
|
|
16
16
|
}
|
|
17
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
18
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeWorkflowComponent, deps: [{ token: i1.NodeHelperService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
18
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: ListNodeWorkflowComponent, selector: "es-list-node-workflow", usesInheritance: true, ngImport: i0, template: "<div class=\"workflowStatus\" [style.background-color]=\"getWorkflowStatus().color\">\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n</div>\n", dependencies: [{ kind: "pipe", type: i2.TranslatePipe, name: "translate" }] }); }
|
|
19
19
|
}
|
|
20
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListNodeWorkflowComponent, decorators: [{
|
|
21
21
|
type: Component,
|
|
22
22
|
args: [{ selector: 'es-list-node-workflow', template: "<div class=\"workflowStatus\" [style.background-color]=\"getWorkflowStatus().color\">\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n</div>\n" }]
|
|
23
|
-
}], ctorParameters:
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
}], ctorParameters: () => [{ type: i1.NodeHelperService }] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1ub2RlLXdvcmtmbG93LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LW5vZGUtd29ya2Zsb3cvbGlzdC1ub2RlLXdvcmtmbG93LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LW5vZGUtd29ya2Zsb3cvbGlzdC1ub2RlLXdvcmtmbG93LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVqRCxPQUFPLEVBQVEsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7Ozs7QUFNMUQsTUFBTSxPQUFPLHlCQUEwQixTQUFRLFVBQVU7YUFDOUMsbUJBQWMsR0FBRyxDQUFDLElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRSxhQUFhLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxBQUEzRCxDQUE0RDtJQUVqRixZQUFvQixVQUE2QjtRQUM3QyxLQUFLLEVBQUUsQ0FBQztRQURRLGVBQVUsR0FBVixVQUFVLENBQW1CO0lBRWpELENBQUM7SUFFRCxpQkFBaUI7UUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQVksQ0FBQyxDQUFDLE9BQU8sQ0FBQztJQUN4RSxDQUFDOzhHQVRRLHlCQUF5QjtrR0FBekIseUJBQXlCLG9GQ1Z0QywySkFHQTs7MkZET2EseUJBQXlCO2tCQUpyQyxTQUFTOytCQUNJLHVCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGlzdFdpZGdldCB9IGZyb20gJy4uL2xpc3Qtd2lkZ2V0JztcbmltcG9ydCB7IExpc3RJdGVtIH0gZnJvbSAnLi4vLi4vdHlwZXMvbGlzdC1pdGVtJztcbmltcG9ydCB7IE5vZGVIZWxwZXJTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbm9kZS1oZWxwZXIuc2VydmljZSc7XG5pbXBvcnQgeyBOb2RlLCBSZXN0Q29uc3RhbnRzIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtbGlzdC1ub2RlLXdvcmtmbG93JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbGlzdC1ub2RlLXdvcmtmbG93LmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgTGlzdE5vZGVXb3JrZmxvd0NvbXBvbmVudCBleHRlbmRzIExpc3RXaWRnZXQge1xuICAgIHN0YXRpYyBzdXBwb3J0ZWRJdGVtcyA9IFtuZXcgTGlzdEl0ZW0oJ05PREUnLCBSZXN0Q29uc3RhbnRzLkNDTV9QUk9QX1dGX1NUQVRVUyldO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBub2RlSGVscGVyOiBOb2RlSGVscGVyU2VydmljZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIGdldFdvcmtmbG93U3RhdHVzKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5ub2RlSGVscGVyLmdldFdvcmtmbG93U3RhdHVzKHRoaXMubm9kZSBhcyBOb2RlKS5jdXJyZW50O1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJ3b3JrZmxvd1N0YXR1c1wiIFtzdHlsZS5iYWNrZ3JvdW5kLWNvbG9yXT1cImdldFdvcmtmbG93U3RhdHVzKCkuY29sb3JcIj5cbiAge3sgJ1dPUktGTE9XLicgKyBnZXRXb3JrZmxvd1N0YXR1cygpLmlkIHwgdHJhbnNsYXRlIH19XG48L2Rpdj5cbiJdfQ==
|
|
@@ -5,6 +5,7 @@ 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";
|
|
@@ -85,9 +86,7 @@ export class ListTextComponent extends ListWidget {
|
|
|
85
86
|
metadataSet: node.metadataset || Constants.DEFAULT,
|
|
86
87
|
})
|
|
87
88
|
.toPromise();
|
|
88
|
-
|
|
89
|
-
/*
|
|
90
|
-
const widget = MdsHelper.getWidget(this.item.name, null, mds.widgets);
|
|
89
|
+
const widget = MdsHelperService.getWidget(this.item.name, null, mds.widgets);
|
|
91
90
|
if (widget?.values) {
|
|
92
91
|
const i18n = node.properties[this.item.name]
|
|
93
92
|
?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)
|
|
@@ -96,13 +95,12 @@ export class ListTextComponent extends ListWidget {
|
|
|
96
95
|
this.displayName$.next(i18n.join(', '));
|
|
97
96
|
}
|
|
98
97
|
}
|
|
99
|
-
*/
|
|
100
98
|
}
|
|
101
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
102
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
99
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", 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.0.2", 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 {{\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()).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 {{\n $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][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]", 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.VCardNamePipe, name: "vcardName" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.NodeSourcePipe, name: "appNodeSource" }, { kind: "pipe", type: i14.FormatDurationPipe, name: "formatDuration" }] }); }
|
|
103
101
|
}
|
|
104
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListTextComponent, decorators: [{
|
|
105
103
|
type: Component,
|
|
106
|
-
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
|
|
107
|
-
}], ctorParameters:
|
|
108
|
-
//# 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 || Constants.HOME_REPOSITORY,\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 || $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"]}
|
|
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()).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 {{\n $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][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
|
+
}], 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, 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    {{\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()).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        {{\n          $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][0] | vcardName)\n            : ''\n        }}\n      </ng-container>\n    </ng-container>\n  </span>\n</ng-container>\n"]}
|
|
@@ -34,16 +34,16 @@ export class ListWidget {
|
|
|
34
34
|
this.itemSubject = new BehaviorSubject(null);
|
|
35
35
|
this.provideLabelSubject = new BehaviorSubject(false);
|
|
36
36
|
}
|
|
37
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
38
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
37
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListWidget, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
38
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.2", type: ListWidget, inputs: { node: "node", item: "item", provideLabel: "provideLabel" }, ngImport: i0 }); }
|
|
39
39
|
}
|
|
40
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: ListWidget, decorators: [{
|
|
41
41
|
type: Directive
|
|
42
|
-
}], ctorParameters:
|
|
42
|
+
}], ctorParameters: () => [], propDecorators: { node: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}], item: [{
|
|
45
45
|
type: Input
|
|
46
46
|
}], provideLabel: [{
|
|
47
47
|
type: Input
|
|
48
48
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC13aWRnZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL2xpc3QtaXRlbXMvbGlzdC13aWRnZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBUSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFLdkMsTUFBTSxPQUFPLFVBQVU7SUFDbkIsSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBQ0QsSUFBSSxJQUFJLENBQUMsS0FBd0Q7UUFDN0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUtELElBQ0ksSUFBSTtRQUNKLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUM7SUFDbEMsQ0FBQztJQUNELElBQUksSUFBSSxDQUFDLEtBQWU7UUFDcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUdEOzs7Ozs7OztPQVFHO0lBQ0gsSUFDSSxZQUFZO1FBQ1osT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsS0FBSyxDQUFDO0lBQzFDLENBQUM7SUFDRCxJQUFJLFlBQVksQ0FBQyxLQUFLO1FBQ2xCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUdEO1FBL0JtQixnQkFBVyxHQUFHLElBQUksZUFBZSxDQUVsRCxJQUFJLENBQUMsQ0FBQyxDQUFDLHVCQUF1QjtRQVNiLGdCQUFXLEdBQUcsSUFBSSxlQUFlLENBQVcsSUFBSSxDQUFDLENBQUM7UUFrQmxELHdCQUFtQixHQUFHLElBQUksZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXJELENBQUM7OEdBdkNQLFVBQVU7a0dBQVYsVUFBVTs7MkZBQVYsVUFBVTtrQkFEdEIsU0FBUzt3REFHRixJQUFJO3NCQURQLEtBQUs7Z0JBWUYsSUFBSTtzQkFEUCxLQUFLO2dCQW1CRixZQUFZO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbnB1dCwgVHlwZSwgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQZXJzb24gfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTm9kZSwgUHJvcG9zYWxOb2RlLCBHcm91cCwgU3RhdGlzdGljcyB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgTGlzdEl0ZW0gfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBjbGFzcyBMaXN0V2lkZ2V0IHtcbiAgICBASW5wdXQoKVxuICAgIGdldCBub2RlKCk6IE5vZGUgfCBQcm9wb3NhbE5vZGUgfCBHcm91cCB8IFBlcnNvbiB8IFN0YXRpc3RpY3Mge1xuICAgICAgICByZXR1cm4gdGhpcy5ub2RlU3ViamVjdC52YWx1ZTtcbiAgICB9XG4gICAgc2V0IG5vZGUodmFsdWU6IE5vZGUgfCBQcm9wb3NhbE5vZGUgfCBHcm91cCB8IFBlcnNvbiB8IFN0YXRpc3RpY3MpIHtcbiAgICAgICAgdGhpcy5ub2RlU3ViamVjdC5uZXh0KHZhbHVlKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IG5vZGVTdWJqZWN0ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxcbiAgICAgICAgTm9kZSB8IFByb3Bvc2FsTm9kZSB8IEdyb3VwIHwgUGVyc29uIHwgU3RhdGlzdGljc1xuICAgID4obnVsbCk7IC8vIG5vZGUgKG9yIGdyb3VwL3VzZXIpXG5cbiAgICBASW5wdXQoKVxuICAgIGdldCBpdGVtKCk6IExpc3RJdGVtIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaXRlbVN1YmplY3QudmFsdWU7XG4gICAgfVxuICAgIHNldCBpdGVtKHZhbHVlOiBMaXN0SXRlbSkge1xuICAgICAgICB0aGlzLml0ZW1TdWJqZWN0Lm5leHQodmFsdWUpO1xuICAgIH1cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaXRlbVN1YmplY3QgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PExpc3RJdGVtPihudWxsKTtcblxuICAgIC8qKlxuICAgICAqIFByb3ZpZGUgYSBsYWJlbCBmb3Igbm9uLW9idmlvdXMgZmllbGRzIHRoYXQgZGVzY3JpYmVzIHRoZSBmaWVsZCB0aGUgZ2l2ZW4gdmFsdWUgYmVsb25ncyB0by5cbiAgICAgKlxuICAgICAqIFRoZSBsYWJlbCBpcyBpbmNsdWRlZCBpbiBhIHRvb2x0aXAgYW5kIG1hZGUgYXZhaWxhYmxlIGZvciBhMTF5IHRlY2hub2xvZ2llcy5cbiAgICAgKlxuICAgICAqIFVzZWZ1bCB3aGVuIHRoZSB2YWx1ZSBpcyBkaXNwbGF5ZWQgd2l0aG91dCBjb250ZXh0LlxuICAgICAqXG4gICAgICogT3RoZXIgdG9vbHRpcHMgbWlnaHQgYmUgYWRkZWQgZXZlbiB3aXRoIHRoaXMgaW5wdXQgc2V0IHRvIGBmYWxzZWAuXG4gICAgICovXG4gICAgQElucHV0KClcbiAgICBnZXQgcHJvdmlkZUxhYmVsKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5wcm92aWRlTGFiZWxTdWJqZWN0LnZhbHVlO1xuICAgIH1cbiAgICBzZXQgcHJvdmlkZUxhYmVsKHZhbHVlKSB7XG4gICAgICAgIHRoaXMucHJvdmlkZUxhYmVsU3ViamVjdC5uZXh0KHZhbHVlKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHByb3ZpZGVMYWJlbFN1YmplY3QgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcblxuICAgIGNvbnN0cnVjdG9yKCkge31cbn1cblxuZXhwb3J0IHR5cGUgTGlzdFdpZGdldENsYXNzID0ge1xuICAgIHN1cHBvcnRlZEl0ZW1zOiBMaXN0SXRlbVtdO1xufSAmIFR5cGU8TGlzdFdpZGdldD47XG4iXX0=
|
|
@@ -7,13 +7,13 @@ import * as i4 from "../../pipes/node-icon.pipe";
|
|
|
7
7
|
import * as i5 from "@ngx-translate/core";
|
|
8
8
|
export class NodeRowComponent {
|
|
9
9
|
constructor() { }
|
|
10
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeRowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", 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
12
|
}
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeRowComponent, decorators: [{
|
|
14
14
|
type: Component,
|
|
15
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:
|
|
16
|
+
}], ctorParameters: () => [], propDecorators: { customMetadataRef: [{
|
|
17
17
|
type: ContentChild,
|
|
18
18
|
args: ['customMetadata']
|
|
19
19
|
}], node: [{
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
21
21
|
}], columns: [{
|
|
22
22
|
type: Input
|
|
23
23
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1yb3cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9saXN0LWl0ZW1zL25vZGUtcm93L25vZGUtcm93LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9ub2RlLXJvdy9ub2RlLXJvdy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFTNUUsTUFBTSxPQUFPLGdCQUFnQjtJQUt6QixnQkFBZSxDQUFDOzhHQUxQLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLGtOQ1Q3Qix3OUJBK0JBOzsyRkR0QmEsZ0JBQWdCO2tCQUw1QixTQUFTOytCQUNJLGFBQWE7d0RBS1MsaUJBQWlCO3NCQUFoRCxZQUFZO3VCQUFDLGdCQUFnQjtnQkFDckIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vZGUgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcbmltcG9ydCB7IExpc3RJdGVtIH0gZnJvbSAnLi4vLi4vdHlwZXMvbGlzdC1pdGVtJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1ub2RlLXJvdycsXG4gICAgdGVtcGxhdGVVcmw6ICdub2RlLXJvdy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJ25vZGUtcm93LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIE5vZGVSb3dDb21wb25lbnQge1xuICAgIEBDb250ZW50Q2hpbGQoJ2N1c3RvbU1ldGFkYXRhJykgY3VzdG9tTWV0YWRhdGFSZWY6IFRlbXBsYXRlUmVmPGFueT47XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcbiAgICBASW5wdXQoKSBjb2x1bW5zOiBMaXN0SXRlbVtdO1xuXG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIiwiPGRpdiBjbGFzcz1cIm5vZGUtcm93XCIgKm5nSWY9XCJub2RlXCI+XG4gIDxkaXYgY2xhc3M9XCJpY29uLWJnXCI+XG4gICAgPGltZ1xuICAgICAgW3NyY109XCJub2RlIHwgZXNOb2RlSWNvbiB8IGFzeW5jXCJcbiAgICAgIFthbHRdPVwiXG4gICAgICAgIG5vZGUubWVkaWF0eXBlXG4gICAgICAgICAgPyAoJ05PREUubWVkaWF0eXBlJyB8IHRyYW5zbGF0ZSkgKyAnOiAnICsgKCdNRURJQVRZUEUuJyArIG5vZGUubWVkaWF0eXBlIHwgdHJhbnNsYXRlKVxuICAgICAgICAgIDogJydcbiAgICAgIFwiXG4gICAgICBbbWF0VG9vbHRpcF09XCJcbiAgICAgICAgbm9kZS5tZWRpYXR5cGVcbiAgICAgICAgICA/ICgnTk9ERS5tZWRpYXR5cGUnIHwgdHJhbnNsYXRlKSArICc6ICcgKyAoJ01FRElBVFlQRS4nICsgbm9kZS5tZWRpYXR5cGUgfCB0cmFuc2xhdGUpXG4gICAgICAgICAgOiAnJ1xuICAgICAgXCJcbiAgICAvPlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cIm5vZGUtZGF0YVwiPlxuICAgIDxkaXYgY2xhc3M9XCJub2RlLWRhdGEtcHJpbWFyeVwiPlxuICAgICAgPGVzLWxpc3QtdGV4dCBbbm9kZV09XCJub2RlXCIgW2l0ZW1dPVwiY29sdW1uc1swXVwiPiA8L2VzLWxpc3QtdGV4dD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwibm9kZS1kYXRhLXNlY29uZGFyeVwiPlxuICAgICAgPGVzLWxpc3QtdGV4dFxuICAgICAgICAqbmdGb3I9XCJsZXQgY29sdW1uIG9mIGNvbHVtbnMuc2xpY2UoMSlcIlxuICAgICAgICBbbm9kZV09XCJub2RlXCJcbiAgICAgICAgW2l0ZW1dPVwiY29sdW1uXCJcbiAgICAgICAgW3Byb3ZpZGVMYWJlbF09XCJ0cnVlXCJcbiAgICAgID48L2VzLWxpc3QtdGV4dD5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjdXN0b21NZXRhZGF0YVJlZjsgY29udGV4dDogeyBub2RlOiBub2RlIH1cIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -39,11 +39,11 @@ export class NodeSourcePipe {
|
|
|
39
39
|
src = src.replace(/\//g, '_');
|
|
40
40
|
return src;
|
|
41
41
|
}
|
|
42
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
43
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", 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.0.2", ngImport: i0, type: NodeSourcePipe, name: "appNodeSource" }); }
|
|
44
44
|
}
|
|
45
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: NodeSourcePipe, decorators: [{
|
|
46
46
|
type: Pipe,
|
|
47
47
|
args: [{ name: 'appNodeSource' }]
|
|
48
|
-
}], ctorParameters:
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
}], ctorParameters: () => [{ type: i1.NodeHelperService }, { type: i2.NetworkService }] });
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1zb3VyY2UucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9ub2RlLXNvdXJjZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7O0FBS3BELE1BQU0sT0FBTyxjQUFjO0lBR3ZCLFlBQW9CLFVBQTZCLEVBQVUsVUFBMEI7UUFBakUsZUFBVSxHQUFWLFVBQVUsQ0FBbUI7UUFBVSxlQUFVLEdBQVYsVUFBVSxDQUFnQjtRQUNqRixJQUFJLENBQUMsVUFBVSxDQUFDLGlCQUFpQixFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMsY0FBYyxFQUFFLEVBQUU7WUFDN0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsU0FBUyxDQUNMLGlCQUF5QixFQUN6QixJQUVDO1FBRUQsTUFBTSxNQUFNLEdBQUcsaUJBQWlCLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFDaEYsSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLE1BQU0sRUFBRSxDQUFDO1lBQ3ZCLElBQUksTUFBTSxLQUFLLE1BQU0sRUFBRSxDQUFDO2dCQUNwQiwwRUFBMEU7Z0JBQzFFLDhFQUE4RTtnQkFDOUUsT0FBTyxJQUFJLENBQUMsY0FBYyxFQUFFLEtBQUssSUFBSSxNQUFNLENBQUM7WUFDaEQsQ0FBQztZQUNELE9BQU8sTUFBTSxDQUFDO1FBQ2xCLENBQUM7YUFBTSxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDN0IsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNoQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbEQsQ0FBQzthQUFNLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNqQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDL0IsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxNQUFNLENBQUMsR0FBVztRQUN0QixJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDUCxPQUFPLEdBQUcsQ0FBQztRQUNmLENBQUM7UUFDRCxHQUFHLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQzVELEdBQUcsR0FBRyxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM5QixHQUFHLEdBQUcsR0FBRyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDOUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQzlCLE9BQU8sR0FBRyxDQUFDO0lBQ2YsQ0FBQzs4R0F6Q1EsY0FBYzs0R0FBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUQxQixJQUFJO21CQUFDLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5ldHdvcmtTZXJ2aWNlLCBSZXBvc2l0b3J5IH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBOb2RlSGVscGVyU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL25vZGUtaGVscGVyLnNlcnZpY2UnO1xuXG5AUGlwZSh7IG5hbWU6ICdhcHBOb2RlU291cmNlJyB9KVxuZXhwb3J0IGNsYXNzIE5vZGVTb3VyY2VQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgcHJpdmF0ZSBob21lUmVwb3NpdG9yeTogUmVwb3NpdG9yeTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbm9kZUhlbHBlcjogTm9kZUhlbHBlclNlcnZpY2UsIHByaXZhdGUgbmV0d29ya0FwaTogTmV0d29ya1NlcnZpY2UpIHtcbiAgICAgICAgdGhpcy5uZXR3b3JrQXBpLmdldEhvbWVSZXBvc2l0b3J5KCkuc3Vic2NyaWJlKChob21lUmVwb3NpdG9yeSkgPT4ge1xuICAgICAgICAgICAgdGhpcy5ob21lUmVwb3NpdG9yeSA9IGhvbWVSZXBvc2l0b3J5O1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICB0cmFuc2Zvcm0oXG4gICAgICAgIHJlcGxpY2F0aW9uU291cmNlOiBzdHJpbmcsXG4gICAgICAgIGFyZ3M6IHtcbiAgICAgICAgICAgIG1vZGU6ICd0ZXh0JyB8ICd1cmwnIHwgJ2VzY2FwZWQnO1xuICAgICAgICB9LFxuICAgICk6IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHJhd1NyYyA9IHJlcGxpY2F0aW9uU291cmNlID8gcmVwbGljYXRpb25Tb3VyY2UudG9TdHJpbmcoKS50cmltKCkgOiAnaG9tZSc7XG4gICAgICAgIGlmIChhcmdzLm1vZGUgPT09ICd0ZXh0Jykge1xuICAgICAgICAgICAgaWYgKHJhd1NyYyA9PT0gJ2hvbWUnKSB7XG4gICAgICAgICAgICAgICAgLy8gRklYTUU6IFRoaXMgd2lsbCBmaXggdGhlIHBpcGUncyByZXR1cm4gdmFsdWUgdG8gJ2hvbWUnIGZvciBjYWxscyBiZWZvcmVcbiAgICAgICAgICAgICAgICAvLyBgdGhpcy5ob21lUmVwb3NpdG9yeWAgd2FzIHBvcHVsYXRlZCAoYWx0aG91Z2ggdGhhdCBkb2Vzbid0IHNlZW0gdG8gaGFwcGVuKS5cbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5ob21lUmVwb3NpdG9yeT8udGl0bGUgfHwgJ2hvbWUnO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHJhd1NyYztcbiAgICAgICAgfSBlbHNlIGlmIChhcmdzLm1vZGUgPT09ICd1cmwnKSB7XG4gICAgICAgICAgICBjb25zdCBzcmMgPSB0aGlzLmVzY2FwZShyYXdTcmMpO1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMubm9kZUhlbHBlci5nZXRTb3VyY2VJY29uUGF0aChzcmMpO1xuICAgICAgICB9IGVsc2UgaWYgKGFyZ3MubW9kZSA9PT0gJ2VzY2FwZWQnKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5lc2NhcGUocmF3U3JjKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBwcml2YXRlIGVzY2FwZShzcmM6IHN0cmluZykge1xuICAgICAgICBpZiAoIXNyYykge1xuICAgICAgICAgICAgcmV0dXJuIHNyYztcbiAgICAgICAgfVxuICAgICAgICBzcmMgPSBzcmMuc3Vic3RyaW5nKHNyYy5sYXN0SW5kZXhPZignOicpICsgMSkudG9Mb3dlckNhc2UoKTtcbiAgICAgICAgc3JjID0gc3JjLnJlcGxhY2UoL1xccy9nLCAnXycpO1xuICAgICAgICBzcmMgPSBzcmMucmVwbGFjZSgvXFwuL2csICdfJyk7XG4gICAgICAgIHNyYyA9IHNyYy5yZXBsYWNlKC9cXC8vZywgJ18nKTtcbiAgICAgICAgcmV0dXJuIHNyYztcbiAgICB9XG59XG4iXX0=
|