ngx-edu-sharing-ui 9.0.2 → 9.1.1
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/esm2022/lib/actionbar/actionbar.component.mjs +5 -5
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +73 -62
- package/esm2022/lib/directives/check-text-overflow.directive.mjs +8 -2
- package/esm2022/lib/directives/icon.directive.mjs +15 -8
- package/esm2022/lib/directives/infinite-scroll.directive.mjs +85 -0
- package/esm2022/lib/dropdown/dropdown.component.mjs +3 -3
- package/esm2022/lib/edu-sharing-ui-configuration.mjs +8 -1
- package/esm2022/lib/list-items/list-base/list-base.component.mjs +6 -6
- package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +3 -1
- package/esm2022/lib/list-items/list-text/list-text.component.mjs +15 -13
- package/esm2022/lib/node-entries/entries-model.mjs +2 -1
- package/esm2022/lib/node-entries/node-cache.mjs +9 -1
- package/esm2022/lib/node-entries/node-data-source.mjs +4 -2
- package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +13 -11
- package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +37 -22
- package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +5 -5
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +3 -3
- package/esm2022/lib/node-entries/node-entries-global.service.mjs +14 -1
- package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +3 -3
- package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +43 -34
- package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +10 -3
- package/esm2022/lib/node-entries/node-entries.component.mjs +2 -2
- package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +35 -12
- package/esm2022/lib/node-entries/option-button/option-button.component.mjs +18 -7
- package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +3 -3
- package/esm2022/lib/node-url/node-url.component.mjs +7 -3
- package/esm2022/lib/pipes/file-size.pipe.mjs +2 -2
- package/esm2022/lib/pipes/property-slug.pipe.mjs +16 -0
- package/esm2022/lib/services/abstract/options-helper.service.mjs +1 -1
- package/esm2022/lib/services/app-container.service.mjs +66 -0
- package/esm2022/lib/services/node-entries.service.mjs +47 -3
- package/esm2022/lib/services/node-helper.service.mjs +34 -11
- package/esm2022/lib/services/options-helper-data.service.mjs +4 -4
- package/esm2022/lib/services/repo-url.service.mjs +2 -1
- package/esm2022/lib/services/ui.service.mjs +7 -1
- package/esm2022/lib/spinner/spinner.component.mjs +4 -3
- package/esm2022/lib/translations/translation-loader.mjs +39 -8
- package/esm2022/lib/translations/translations.module.mjs +15 -4
- package/esm2022/lib/translations/translations.service.mjs +3 -3
- package/esm2022/lib/types/injection-tokens.mjs +9 -0
- package/esm2022/lib/types/option-item.mjs +4 -3
- package/esm2022/module.mjs +49 -43
- package/fesm2022/ngx-edu-sharing-ui.mjs +3955 -3568
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/common/edu-sharing-ui-common.module.d.ts +27 -25
- package/lib/directives/icon.directive.d.ts +2 -2
- package/lib/directives/infinite-scroll.directive.d.ts +22 -0
- package/lib/edu-sharing-ui-configuration.d.ts +5 -0
- package/lib/list-items/list-text/list-text.component.d.ts +1 -1
- package/lib/list-items/list-widget.d.ts +1 -1
- package/lib/node-entries/entries-model.d.ts +2 -1
- package/lib/node-entries/node-data-source.d.ts +1 -1
- package/lib/node-entries/node-entries-card/node-entries-card.component.d.ts +1 -1
- package/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.d.ts +6 -1
- package/lib/node-entries/node-entries-global.service.d.ts +7 -0
- package/lib/node-entries/node-entries-table/node-entries-table.component.d.ts +4 -1
- package/lib/node-entries/node-entries-wrapper.component.d.ts +8 -3
- package/lib/node-entries/node-rating/node-rating.component.d.ts +3 -3
- package/lib/node-entries/option-button/option-button.component.d.ts +6 -2
- package/lib/pipes/property-slug.pipe.d.ts +7 -0
- package/lib/services/abstract/options-helper.service.d.ts +3 -3
- package/lib/services/app-container.service.d.ts +43 -0
- package/lib/services/node-entries.service.d.ts +31 -6
- package/lib/services/node-helper.service.d.ts +5 -3
- package/lib/services/options-helper-data.service.d.ts +3 -3
- package/lib/services/ui.service.d.ts +8 -1
- package/lib/spinner/spinner.component.d.ts +1 -1
- package/lib/translations/translation-loader.d.ts +2 -1
- package/lib/types/injection-tokens.d.ts +8 -0
- package/lib/types/option-item.d.ts +3 -4
- package/module.d.ts +48 -42
- package/package.json +1 -1
- package/esm2022/lib/translations/languages.mjs +0 -5
- package/lib/translations/languages.d.ts +0 -4
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../services/app-container.service";
|
|
5
|
+
export class InfiniteScrollDirective {
|
|
6
|
+
constructor(appContainer, element, zone) {
|
|
7
|
+
this.appContainer = appContainer;
|
|
8
|
+
this.element = element;
|
|
9
|
+
this.zone = zone;
|
|
10
|
+
this.scrolled = new EventEmitter();
|
|
11
|
+
this.infiniteScrollDistance = 1.5;
|
|
12
|
+
this.infiniteScrollThrottle = 1000;
|
|
13
|
+
this.scrollWindow = true;
|
|
14
|
+
this.lastEvent = 0;
|
|
15
|
+
this.lastScroll = 0;
|
|
16
|
+
this.destroyed$ = new Subject();
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this.zone.runOutsideAngular(() => {
|
|
20
|
+
const handleScroll = () => this.handleOnScroll();
|
|
21
|
+
const eventTarget = this.scrollWindow
|
|
22
|
+
? this.appContainer.getScrollContainer({ fallback: window })
|
|
23
|
+
: this.element.nativeElement;
|
|
24
|
+
eventTarget.addEventListener('scroll', handleScroll);
|
|
25
|
+
this.destroyed$.subscribe(() => eventTarget.removeEventListener('scroll', handleScroll));
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
ngOnDestroy() {
|
|
29
|
+
this.destroyed$.next();
|
|
30
|
+
this.destroyed$.complete();
|
|
31
|
+
}
|
|
32
|
+
handleOnScroll() {
|
|
33
|
+
if (!this.element.nativeElement)
|
|
34
|
+
return;
|
|
35
|
+
if (this.scrollWindow) {
|
|
36
|
+
const scrollContainer = this.appContainer.getScrollContainer();
|
|
37
|
+
const height = scrollContainer.scrollHeight;
|
|
38
|
+
const scroll = scrollContainer.scrollTop;
|
|
39
|
+
if (scroll > this.lastScroll &&
|
|
40
|
+
height - scroll < scrollContainer.clientHeight * this.infiniteScrollDistance) {
|
|
41
|
+
const time = new Date().getTime();
|
|
42
|
+
if (time - this.lastEvent < this.infiniteScrollThrottle)
|
|
43
|
+
return;
|
|
44
|
+
this.lastEvent = time;
|
|
45
|
+
this.emitScrolled();
|
|
46
|
+
}
|
|
47
|
+
this.lastScroll = scroll;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
const element = this.element.nativeElement;
|
|
51
|
+
const height = element.scrollHeight;
|
|
52
|
+
const scroll = element.scrollTop;
|
|
53
|
+
if (scroll > this.lastScroll &&
|
|
54
|
+
height - scroll <
|
|
55
|
+
element.getBoundingClientRect().height * this.infiniteScrollDistance) {
|
|
56
|
+
const time = new Date().getTime();
|
|
57
|
+
if (time - this.lastEvent < this.infiniteScrollThrottle)
|
|
58
|
+
return;
|
|
59
|
+
this.lastEvent = time;
|
|
60
|
+
this.emitScrolled();
|
|
61
|
+
}
|
|
62
|
+
this.lastScroll = scroll;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
emitScrolled() {
|
|
66
|
+
this.zone.run(() => this.scrolled.emit());
|
|
67
|
+
}
|
|
68
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: InfiniteScrollDirective, deps: [{ token: i1.AppContainerService }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
69
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.6", type: InfiniteScrollDirective, selector: "[esInfiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: { infiniteScrollDistance: "infiniteScrollDistance", infiniteScrollThrottle: "infiniteScrollThrottle", scrollWindow: "scrollWindow" }, outputs: { scrolled: "scrolled" }, ngImport: i0 }); }
|
|
70
|
+
}
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: InfiniteScrollDirective, decorators: [{
|
|
72
|
+
type: Directive,
|
|
73
|
+
args: [{
|
|
74
|
+
selector: '[esInfiniteScroll], [infinite-scroll], [data-infinite-scroll]',
|
|
75
|
+
}]
|
|
76
|
+
}], ctorParameters: function () { return [{ type: i1.AppContainerService }, { type: i0.ElementRef }, { type: i0.NgZone }]; }, propDecorators: { scrolled: [{
|
|
77
|
+
type: Output
|
|
78
|
+
}], infiniteScrollDistance: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], infiniteScrollThrottle: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], scrollWindow: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}] } });
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5maW5pdGUtc2Nyb2xsLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvZGlyZWN0aXZlcy9pbmZpbml0ZS1zY3JvbGwuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBRVQsWUFBWSxFQUNaLEtBQUssRUFJTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBTS9CLE1BQU0sT0FBTyx1QkFBdUI7SUFVaEMsWUFDWSxZQUFpQyxFQUNqQyxPQUFtQixFQUNuQixJQUFZO1FBRlosaUJBQVksR0FBWixZQUFZLENBQXFCO1FBQ2pDLFlBQU8sR0FBUCxPQUFPLENBQVk7UUFDbkIsU0FBSSxHQUFKLElBQUksQ0FBUTtRQVpkLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO1FBRXJDLDJCQUFzQixHQUFXLEdBQUcsQ0FBQztRQUNyQywyQkFBc0IsR0FBVyxJQUFJLENBQUM7UUFDdEMsaUJBQVksR0FBWSxJQUFJLENBQUM7UUFDOUIsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUNkLGVBQVUsR0FBRyxDQUFDLENBQUM7UUFDZixlQUFVLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQU10QyxDQUFDO0lBRUosUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFO1lBQzdCLE1BQU0sWUFBWSxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUNqRCxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsWUFBWTtnQkFDakMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsa0JBQWtCLENBQUMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLENBQUM7Z0JBQzVELENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQztZQUNqQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ3JELElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUMzQixXQUFXLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLFlBQVksQ0FBQyxDQUMxRCxDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdkIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBRUQsY0FBYztRQUNWLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWE7WUFBRSxPQUFPO1FBQ3hDLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNuQixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDL0QsTUFBTSxNQUFNLEdBQUcsZUFBZSxDQUFDLFlBQVksQ0FBQztZQUM1QyxNQUFNLE1BQU0sR0FBRyxlQUFlLENBQUMsU0FBUyxDQUFDO1lBQ3pDLElBQ0ksTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVO2dCQUN4QixNQUFNLEdBQUcsTUFBTSxHQUFHLGVBQWUsQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixFQUM5RTtnQkFDRSxNQUFNLElBQUksR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNsQyxJQUFJLElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxzQkFBc0I7b0JBQUUsT0FBTztnQkFDaEUsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7Z0JBQ3RCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQzthQUN2QjtZQUNELElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFDO1NBQzVCO2FBQU07WUFDSCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQztZQUMzQyxNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDO1lBQ3BDLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUM7WUFDakMsSUFDSSxNQUFNLEdBQUcsSUFBSSxDQUFDLFVBQVU7Z0JBQ3hCLE1BQU0sR0FBRyxNQUFNO29CQUNYLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsc0JBQXNCLEVBQzFFO2dCQUNFLE1BQU0sSUFBSSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2xDLElBQUksSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLHNCQUFzQjtvQkFBRSxPQUFPO2dCQUNoRSxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztnQkFDdEIsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQ3ZCO1lBQ0QsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLENBQUM7U0FDNUI7SUFDTCxDQUFDO0lBRU8sWUFBWTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7SUFDOUMsQ0FBQzs4R0F0RVEsdUJBQXVCO2tHQUF2Qix1QkFBdUI7OzJGQUF2Qix1QkFBdUI7a0JBSG5DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLCtEQUErRDtpQkFDNUU7d0pBRWEsUUFBUTtzQkFBakIsTUFBTTtnQkFFRSxzQkFBc0I7c0JBQTlCLEtBQUs7Z0JBQ0csc0JBQXNCO3NCQUE5QixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIERpcmVjdGl2ZSxcbiAgICBFbGVtZW50UmVmLFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbnB1dCxcbiAgICBOZ1pvbmUsXG4gICAgT25EZXN0cm95LFxuICAgIE9uSW5pdCxcbiAgICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQXBwQ29udGFpbmVyU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2FwcC1jb250YWluZXIuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2VzSW5maW5pdGVTY3JvbGxdLCBbaW5maW5pdGUtc2Nyb2xsXSwgW2RhdGEtaW5maW5pdGUtc2Nyb2xsXScsXG59KVxuZXhwb3J0IGNsYXNzIEluZmluaXRlU2Nyb2xsRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIEBPdXRwdXQoKSBzY3JvbGxlZCA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICAgIEBJbnB1dCgpIGluZmluaXRlU2Nyb2xsRGlzdGFuY2U6IG51bWJlciA9IDEuNTtcbiAgICBASW5wdXQoKSBpbmZpbml0ZVNjcm9sbFRocm90dGxlOiBudW1iZXIgPSAxMDAwO1xuICAgIEBJbnB1dCgpIHNjcm9sbFdpbmRvdzogYm9vbGVhbiA9IHRydWU7XG4gICAgcHJpdmF0ZSBsYXN0RXZlbnQgPSAwO1xuICAgIHByaXZhdGUgbGFzdFNjcm9sbCA9IDA7XG4gICAgcHJpdmF0ZSBkZXN0cm95ZWQkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGFwcENvbnRhaW5lcjogQXBwQ29udGFpbmVyU2VydmljZSxcbiAgICAgICAgcHJpdmF0ZSBlbGVtZW50OiBFbGVtZW50UmVmLFxuICAgICAgICBwcml2YXRlIHpvbmU6IE5nWm9uZSxcbiAgICApIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy56b25lLnJ1bk91dHNpZGVBbmd1bGFyKCgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGhhbmRsZVNjcm9sbCA9ICgpID0+IHRoaXMuaGFuZGxlT25TY3JvbGwoKTtcbiAgICAgICAgICAgIGNvbnN0IGV2ZW50VGFyZ2V0ID0gdGhpcy5zY3JvbGxXaW5kb3dcbiAgICAgICAgICAgICAgICA/IHRoaXMuYXBwQ29udGFpbmVyLmdldFNjcm9sbENvbnRhaW5lcih7IGZhbGxiYWNrOiB3aW5kb3cgfSlcbiAgICAgICAgICAgICAgICA6IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50O1xuICAgICAgICAgICAgZXZlbnRUYXJnZXQuYWRkRXZlbnRMaXN0ZW5lcignc2Nyb2xsJywgaGFuZGxlU2Nyb2xsKTtcbiAgICAgICAgICAgIHRoaXMuZGVzdHJveWVkJC5zdWJzY3JpYmUoKCkgPT5cbiAgICAgICAgICAgICAgICBldmVudFRhcmdldC5yZW1vdmVFdmVudExpc3RlbmVyKCdzY3JvbGwnLCBoYW5kbGVTY3JvbGwpLFxuICAgICAgICAgICAgKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGVzdHJveWVkJC5uZXh0KCk7XG4gICAgICAgIHRoaXMuZGVzdHJveWVkJC5jb21wbGV0ZSgpO1xuICAgIH1cblxuICAgIGhhbmRsZU9uU2Nyb2xsKCkge1xuICAgICAgICBpZiAoIXRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50KSByZXR1cm47XG4gICAgICAgIGlmICh0aGlzLnNjcm9sbFdpbmRvdykge1xuICAgICAgICAgICAgY29uc3Qgc2Nyb2xsQ29udGFpbmVyID0gdGhpcy5hcHBDb250YWluZXIuZ2V0U2Nyb2xsQ29udGFpbmVyKCk7XG4gICAgICAgICAgICBjb25zdCBoZWlnaHQgPSBzY3JvbGxDb250YWluZXIuc2Nyb2xsSGVpZ2h0O1xuICAgICAgICAgICAgY29uc3Qgc2Nyb2xsID0gc2Nyb2xsQ29udGFpbmVyLnNjcm9sbFRvcDtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgICBzY3JvbGwgPiB0aGlzLmxhc3RTY3JvbGwgJiZcbiAgICAgICAgICAgICAgICBoZWlnaHQgLSBzY3JvbGwgPCBzY3JvbGxDb250YWluZXIuY2xpZW50SGVpZ2h0ICogdGhpcy5pbmZpbml0ZVNjcm9sbERpc3RhbmNlXG4gICAgICAgICAgICApIHtcbiAgICAgICAgICAgICAgICBjb25zdCB0aW1lID0gbmV3IERhdGUoKS5nZXRUaW1lKCk7XG4gICAgICAgICAgICAgICAgaWYgKHRpbWUgLSB0aGlzLmxhc3RFdmVudCA8IHRoaXMuaW5maW5pdGVTY3JvbGxUaHJvdHRsZSkgcmV0dXJuO1xuICAgICAgICAgICAgICAgIHRoaXMubGFzdEV2ZW50ID0gdGltZTtcbiAgICAgICAgICAgICAgICB0aGlzLmVtaXRTY3JvbGxlZCgpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5sYXN0U2Nyb2xsID0gc2Nyb2xsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgY29uc3QgZWxlbWVudCA9IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50O1xuICAgICAgICAgICAgY29uc3QgaGVpZ2h0ID0gZWxlbWVudC5zY3JvbGxIZWlnaHQ7XG4gICAgICAgICAgICBjb25zdCBzY3JvbGwgPSBlbGVtZW50LnNjcm9sbFRvcDtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgICBzY3JvbGwgPiB0aGlzLmxhc3RTY3JvbGwgJiZcbiAgICAgICAgICAgICAgICBoZWlnaHQgLSBzY3JvbGwgPFxuICAgICAgICAgICAgICAgICAgICBlbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLmhlaWdodCAqIHRoaXMuaW5maW5pdGVTY3JvbGxEaXN0YW5jZVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgdGltZSA9IG5ldyBEYXRlKCkuZ2V0VGltZSgpO1xuICAgICAgICAgICAgICAgIGlmICh0aW1lIC0gdGhpcy5sYXN0RXZlbnQgPCB0aGlzLmluZmluaXRlU2Nyb2xsVGhyb3R0bGUpIHJldHVybjtcbiAgICAgICAgICAgICAgICB0aGlzLmxhc3RFdmVudCA9IHRpbWU7XG4gICAgICAgICAgICAgICAgdGhpcy5lbWl0U2Nyb2xsZWQoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMubGFzdFNjcm9sbCA9IHNjcm9sbDtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgZW1pdFNjcm9sbGVkKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnpvbmUucnVuKCgpID0+IHRoaXMuc2Nyb2xsZWQuZW1pdCgpKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -7,8 +7,8 @@ import * as i3 from "@angular/material/menu";
|
|
|
7
7
|
import * as i4 from "@angular/material/tooltip";
|
|
8
8
|
import * as i5 from "../directives/icon.directive";
|
|
9
9
|
import * as i6 from "@ngx-translate/core";
|
|
10
|
-
import * as i7 from "../pipes/
|
|
11
|
-
import * as i8 from "../pipes/
|
|
10
|
+
import * as i7 from "../pipes/option-tooltip.pipe";
|
|
11
|
+
import * as i8 from "../pipes/replace-chars.pipe";
|
|
12
12
|
/**
|
|
13
13
|
* The dropdown is one base component of the action bar (showing more actions),
|
|
14
14
|
* but can also be used standalone.
|
|
@@ -45,7 +45,7 @@ export class DropdownComponent {
|
|
|
45
45
|
return this._options?.some((o) => o.isEnabled);
|
|
46
46
|
}
|
|
47
47
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: DropdownComponent, deps: [{ token: i1.UIService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: DropdownComponent, selector: "es-dropdown", inputs: { position: "position", options: "options", callbackObject: "callbackObject", showDisabled: "showDisabled", menuClass: "menuClass" }, viewQueries: [{ propertyName: "menu", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "menuTrigger", first: true, predicate: ["menuTrigger"], descendants: true }], ngImport: i0, template: "<mat-menu\n #dropdown=\"matMenu\"\n class=\"mat-dropdown-menu\"\n [class]=\"menuClass\"\n backdropClass=\"mat-dropdown-menu\"\n [xPosition]=\"position === 'right' ? 'after' : 'before'\"\n>\n <!-- MatMenu has role=\"menu\", so the only meaningful role of descendants is \"menuitem\" -->\n <ul role=\"none\">\n <ng-container *ngFor=\"let option of _options; let i = index\">\n <li *ngIf=\"option.isEnabled || showDisabled\" role=\"none\">\n <button\n mat-menu-item\n class=\"mat-menu-item collection-item-{{\n option.name | replaceChars : { search: '.', replace: '-' }\n }}\"\n matTooltip=\"{{ option | optionTooltip }}\"\n matTooltipPosition=\"right\"\n matTooltipTouchGestures=\"off\"\n [class.mat-menu-item-separate]=\"option.isSeparate || isNewGroup(i)\"\n [class.mat-menu-item-selected]=\"option.isSelected\"\n [disabled]=\"!option.isEnabled\"\n (click)=\"click(option)\"\n attr.data-test=\"menu-item-{{ option.name }}\"\n >\n <i [esIcon]=\"option.icon\"></i> {{ option.name | translate }}\n </button>\n </li>\n </ng-container>\n </ul>\n</mat-menu>\n<div #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"display-none\"></div>\n", styles: ["::ng-deep .mat-dropdown-menu .mat-mdc-menu-content{min-width:200px}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button{display:flex;align-items:center}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button:not(:disabled)>span{color:var(--primary)}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button>i{width:35px}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content:not(:empty){padding:0!important}::ng-deep .mat-dropdown-menu ul{margin:0;list-style:none;padding-left:0}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item .mat-mdc-menu-item-text{display:flex;align-items:center}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item .mat-mdc-menu-item-text i{margin-right:10px}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item:hover:not([disabled]),::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item.cdk-focused{color:var(--itemSelectedTextColor);background-color:var(--listItemSelectedBackground)}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item.cdk-keyboard-focused{outline:none;border:var(--focusWidth) solid var(--palette-primary-300)}::ng-deep .mat-dropdown-menu ul li .mat-menu-item-separate{border-top:1px solid #ccc}@media screen and (max-width: calc(var(--mobileWidth) - var(--mobileStage) * 1)){::ng-deep .mat-dropdown-menu ul li.cdk-overlay-backdrop{background:rgba(0,0,0,.8)}::ng-deep .mat-dropdown-menu ul li.mat-menu-panel{position:fixed;bottom:0;left:0;max-width:100%;width:100%;border-radius:0}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i5.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.
|
|
48
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: DropdownComponent, selector: "es-dropdown", inputs: { position: "position", options: "options", callbackObject: "callbackObject", showDisabled: "showDisabled", menuClass: "menuClass" }, viewQueries: [{ propertyName: "menu", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "menuTrigger", first: true, predicate: ["menuTrigger"], descendants: true }], ngImport: i0, template: "<mat-menu\n #dropdown=\"matMenu\"\n class=\"mat-dropdown-menu\"\n [class]=\"menuClass\"\n backdropClass=\"mat-dropdown-menu\"\n [xPosition]=\"position === 'right' ? 'after' : 'before'\"\n>\n <!-- MatMenu has role=\"menu\", so the only meaningful role of descendants is \"menuitem\" -->\n <ul role=\"none\">\n <ng-container *ngFor=\"let option of _options; let i = index\">\n <li *ngIf=\"option.isEnabled || showDisabled\" role=\"none\">\n <button\n mat-menu-item\n class=\"mat-menu-item collection-item-{{\n option.name | replaceChars : { search: '.', replace: '-' }\n }}\"\n matTooltip=\"{{ option | optionTooltip }}\"\n matTooltipPosition=\"right\"\n matTooltipTouchGestures=\"off\"\n [class.mat-menu-item-separate]=\"option.isSeparate || isNewGroup(i)\"\n [class.mat-menu-item-selected]=\"option.isSelected\"\n [disabled]=\"!option.isEnabled\"\n (click)=\"click(option)\"\n attr.data-test=\"menu-item-{{ option.name }}\"\n >\n <i [esIcon]=\"option.icon\"></i> {{ option.name | translate }}\n </button>\n </li>\n </ng-container>\n </ul>\n</mat-menu>\n<div #menuTrigger=\"matMenuTrigger\" [matMenuTriggerFor]=\"menu\" class=\"display-none\"></div>\n", styles: ["::ng-deep .mat-dropdown-menu .mat-mdc-menu-content{min-width:200px}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button{display:flex;align-items:center}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button:not(:disabled)>span{color:var(--primary)}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content>ul>li>button>i{width:35px}::ng-deep .mat-dropdown-menu .mat-mdc-menu-content:not(:empty){padding:0!important}::ng-deep .mat-dropdown-menu ul{margin:0;list-style:none;padding-left:0}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item .mat-mdc-menu-item-text{display:flex;align-items:center}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item .mat-mdc-menu-item-text i{margin-right:10px}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item:hover:not([disabled]),::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item.cdk-focused{color:var(--itemSelectedTextColor);background-color:var(--listItemSelectedBackground)}::ng-deep .mat-dropdown-menu ul li .mat-mdc-menu-item.cdk-keyboard-focused{outline:none;border:var(--focusWidth) solid var(--palette-primary-300)}::ng-deep .mat-dropdown-menu ul li .mat-menu-item-separate{border-top:1px solid #ccc}@media screen and (max-width: calc(var(--mobileWidth) - var(--mobileStage) * 1)){::ng-deep .mat-dropdown-menu ul li.cdk-overlay-backdrop{background:rgba(0,0,0,.8)}::ng-deep .mat-dropdown-menu ul li.mat-menu-panel{position:fixed;bottom:0;left:0;max-width:100%;width:100%;border-radius:0}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i5.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.OptionTooltipPipe, name: "optionTooltip" }, { kind: "pipe", type: i8.ReplaceCharsPipe, name: "replaceChars" }] }); }
|
|
49
49
|
}
|
|
50
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: DropdownComponent, decorators: [{
|
|
51
51
|
type: Component,
|
|
@@ -2,6 +2,13 @@ import { Injectable, InjectionToken } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export const EDU_SHARING_UI_CONFIG = new InjectionToken('EDU_SHARING_API_CONFIG');
|
|
4
4
|
export class EduSharingUiConfiguration {
|
|
5
|
+
constructor() {
|
|
6
|
+
/**
|
|
7
|
+
* Whether this Angular application is being used embedded as a web component by a third-party
|
|
8
|
+
* web page.
|
|
9
|
+
*/
|
|
10
|
+
this.isEmbedded = false;
|
|
11
|
+
}
|
|
5
12
|
static create(params = {}) {
|
|
6
13
|
return { ...new EduSharingUiConfiguration(), ...params };
|
|
7
14
|
}
|
|
@@ -38,4 +45,4 @@ export function getConfigProvider(params) {
|
|
|
38
45
|
},
|
|
39
46
|
];
|
|
40
47
|
}
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWR1LXNoYXJpbmctdWktY29uZmlndXJhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvZWR1LXNoYXJpbmctdWktY29uZmlndXJhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLGNBQWMsRUFBWSxNQUFNLGVBQWUsQ0FBQzs7QUFFckUsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsSUFBSSxjQUFjLENBQ25ELHdCQUF3QixDQUMzQixDQUFDO0FBS0YsTUFBTSxPQUFPLHlCQUF5QjtJQUh0QztRQUtJOzs7V0FHRztRQUNILGVBQVUsR0FBRyxLQUFLLENBQUM7S0FLdEI7SUFIRyxNQUFNLENBQUMsTUFBTSxDQUFDLFNBQTBDLEVBQUU7UUFDdEQsT0FBTyxFQUFFLEdBQUcsSUFBSSx5QkFBeUIsRUFBRSxFQUFFLEdBQUcsTUFBTSxFQUFFLENBQUM7SUFDN0QsQ0FBQzs4R0FWUSx5QkFBeUI7a0hBQXpCLHlCQUF5QixjQUZ0QixNQUFNOzsyRkFFVCx5QkFBeUI7a0JBSHJDLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCOztBQWdCRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsTUFBd0M7SUFDdEUsT0FBTztRQUNILHlGQUF5RjtRQUN6Riw2Q0FBNkM7UUFDN0M7WUFDSSxPQUFPLEVBQUUscUJBQXFCO1lBQzlCLFFBQVEsRUFBRSxNQUFNO1NBQ25CO1FBQ0QsK0ZBQStGO1FBQy9GLDBFQUEwRTtRQUMxRTtZQUNJLE9BQU8sRUFBRSx5QkFBeUI7WUFDbEMsSUFBSSxFQUFFLENBQUMscUJBQXFCLENBQUM7WUFDN0Isb0RBQW9EO1lBQ3BELFVBQVUsRUFBRSxDQUFDLFlBQTZDLEVBQUUsRUFBRSxDQUMxRCx5QkFBeUIsQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDO1NBQ3JEO1FBQ0Q7WUFDSSxPQUFPLEVBQUUseUJBQXlCO1lBQ2xDLElBQUksRUFBRSxDQUFDLHFCQUFxQixDQUFDO1lBQzdCLG9EQUFvRDtZQUNwRCxVQUFVLEVBQUUsQ0FBQyxZQUE2QyxFQUFFLEVBQUUsQ0FDMUQseUJBQXlCLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQztTQUNyRDtLQUNKLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0aW9uVG9rZW4sIFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBFRFVfU0hBUklOR19VSV9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48RWR1U2hhcmluZ1VpQ29uZmlndXJhdGlvblBhcmFtcz4oXG4gICAgJ0VEVV9TSEFSSU5HX0FQSV9DT05GSUcnLFxuKTtcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgRWR1U2hhcmluZ1VpQ29uZmlndXJhdGlvbiB7XG4gICAgcHJvZHVjdGlvbjogYm9vbGVhbjtcbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoaXMgQW5ndWxhciBhcHBsaWNhdGlvbiBpcyBiZWluZyB1c2VkIGVtYmVkZGVkIGFzIGEgd2ViIGNvbXBvbmVudCBieSBhIHRoaXJkLXBhcnR5XG4gICAgICogd2ViIHBhZ2UuXG4gICAgICovXG4gICAgaXNFbWJlZGRlZCA9IGZhbHNlO1xuXG4gICAgc3RhdGljIGNyZWF0ZShwYXJhbXM6IEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb25QYXJhbXMgPSB7fSk6IEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb24ge1xuICAgICAgICByZXR1cm4geyAuLi5uZXcgRWR1U2hhcmluZ1VpQ29uZmlndXJhdGlvbigpLCAuLi5wYXJhbXMgfTtcbiAgICB9XG59XG5cbmV4cG9ydCB0eXBlIEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb25QYXJhbXMgPSBQYXJ0aWFsPEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb24+O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q29uZmlnUHJvdmlkZXIocGFyYW1zPzogRWR1U2hhcmluZ1VpQ29uZmlndXJhdGlvblBhcmFtcyk6IFByb3ZpZGVyW10ge1xuICAgIHJldHVybiBbXG4gICAgICAgIC8vIFByb3ZpZGUgdGhlIHBhcmFtcyBnaXZlbiB0byBgZm9yUm9vdCgpYC4gVGhlc2UgY2FuIGJlIG92ZXJyaWRkZW4gYnkgdGhlIGFwcGxpY2F0aW9uIGJ5XG4gICAgICAgIC8vIHByb3ZpZGluZyBgRURVX1NIQVJJTkdfQVBJX0NPTkZJR2AgaXRzZWxmLlxuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBFRFVfU0hBUklOR19VSV9DT05GSUcsXG4gICAgICAgICAgICB1c2VWYWx1ZTogcGFyYW1zLFxuICAgICAgICB9LFxuICAgICAgICAvLyBJbmplY3QgYGNvbmZpZ3VyYXRpb25gIGFzIGJvdGgsIGBBcGlDb25maWd1cmF0aW9uYCBhbmQgYEVkdVNoYXJpbmdBcGlDb25maWd1cmF0aW9uYCwgdG8gcGFzc1xuICAgICAgICAvLyBgcm9vdFVybGAgb24gdG8gYEFwaU1vZHVsZWAgd2hpbGUgYWxzbyBhZGRpbmcgb3VyIGN1c3RvbSBjb25maWd1cmF0aW9uLlxuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBFZHVTaGFyaW5nVWlDb25maWd1cmF0aW9uLFxuICAgICAgICAgICAgZGVwczogW0VEVV9TSEFSSU5HX1VJX0NPTkZJR10sXG4gICAgICAgICAgICAvLyBkZXBzOiBbW25ldyBPcHRpb25hbCgpLCBFRFVfU0hBUklOR19BUElfQ09ORklHXV0sXG4gICAgICAgICAgICB1c2VGYWN0b3J5OiAoY29uZmlnUGFyYW1zOiBFZHVTaGFyaW5nVWlDb25maWd1cmF0aW9uUGFyYW1zKSA9PlxuICAgICAgICAgICAgICAgIEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb24uY3JlYXRlKGNvbmZpZ1BhcmFtcyksXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb24sXG4gICAgICAgICAgICBkZXBzOiBbRURVX1NIQVJJTkdfVUlfQ09ORklHXSxcbiAgICAgICAgICAgIC8vIGRlcHM6IFtbbmV3IE9wdGlvbmFsKCksIEVEVV9TSEFSSU5HX0FQSV9DT05GSUddXSxcbiAgICAgICAgICAgIHVzZUZhY3Rvcnk6IChjb25maWdQYXJhbXM6IEVkdVNoYXJpbmdVaUNvbmZpZ3VyYXRpb25QYXJhbXMpID0+XG4gICAgICAgICAgICAgICAgRWR1U2hhcmluZ1VpQ29uZmlndXJhdGlvbi5jcmVhdGUoY29uZmlnUGFyYW1zKSxcbiAgICAgICAgfSxcbiAgICBdO1xufVxuIl19
|
|
@@ -22,15 +22,15 @@ export class ListBaseComponent extends ListWidget {
|
|
|
22
22
|
ngOnChanges(changes) {
|
|
23
23
|
if (this.node && this.item) {
|
|
24
24
|
this.customTemplate = this.nodeEntriesGlobalService.getCustomFieldTemplate(this.item, this.node);
|
|
25
|
+
this.widgetType = Object.entries(AVAILABLE_LIST_WIDGETS).find(([id, w]) => w?.supportedItems?.filter((i) => i.type === this.item.type &&
|
|
26
|
+
(i.name === this.item.name || i.name === '*')).length > 0)?.[0];
|
|
25
27
|
if (this.customTemplate) {
|
|
26
28
|
this.widgetType = ListWidgetType.Custom;
|
|
27
29
|
}
|
|
28
30
|
else if (this.forceText) {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
this.widgetType = Object.entries(AVAILABLE_LIST_WIDGETS).find(([id, w]) => w?.supportedItems?.filter((i) => i.type === this.item.type &&
|
|
33
|
-
(i.name === this.item.name || i.name === '*')).length > 0)?.[0];
|
|
31
|
+
if (![ListWidgetType.NodeCounts, ListWidgetType.Text].includes(this.widgetType)) {
|
|
32
|
+
this.widgetType = ListWidgetType.Text;
|
|
33
|
+
}
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
36
|
}
|
|
@@ -43,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
43
43
|
}], ctorParameters: function () { return [{ type: i1.NodeEntriesGlobalService }]; }, propDecorators: { forceText: [{
|
|
44
44
|
type: Input
|
|
45
45
|
}] } });
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1iYXNlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LWJhc2UvbGlzdC1iYXNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LWJhc2UvbGlzdC1iYXNlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUF5QyxNQUFNLGVBQWUsQ0FBQztBQUN4RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7O0FBUTVDLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxVQUFVO0lBTzdDLFlBQW9CLHdCQUFrRDtRQUNsRSxLQUFLLEVBQUUsQ0FBQztRQURRLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7UUFOdEU7O1dBRUc7UUFDTSxjQUFTLEdBQUcsS0FBSyxDQUFDO0lBSzNCLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDOUIsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsd0JBQXdCLENBQUMsc0JBQXNCLENBQ3RFLElBQUksQ0FBQyxJQUFJLEVBQ1QsSUFBSSxDQUFDLElBQVksQ0FDcEIsQ0FBQztZQUNGLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLElBQUksQ0FDekQsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQ1IsQ0FBQyxFQUFFLGNBQWMsRUFBRSxNQUFNLENBQ3JCLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FDRixDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSTtnQkFDekIsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxJQUFJLEtBQUssR0FBRyxDQUFDLENBQ3BELENBQUMsTUFBTSxHQUFHLENBQUMsQ0FDbkIsRUFBRSxDQUFDLENBQUMsQ0FBbUIsQ0FBQztZQUN6QixJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUU7Z0JBQ3JCLElBQUksQ0FBQyxVQUFVLEdBQUcsY0FBYyxDQUFDLE1BQU0sQ0FBQzthQUMzQztpQkFBTSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7Z0JBQ3ZCLElBQUksQ0FBQyxDQUFDLGNBQWMsQ0FBQyxVQUFVLEVBQUUsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7b0JBQzdFLElBQUksQ0FBQyxVQUFVLEdBQUcsY0FBYyxDQUFDLElBQUksQ0FBQztpQkFDekM7YUFDSjtTQUNKO0lBQ0wsQ0FBQzs4R0FqQ1EsaUJBQWlCO2tHQUFqQixpQkFBaUIsb0lDVjlCLGk1Q0FvREE7OzJGRDFDYSxpQkFBaUI7a0JBSjdCLFNBQVM7K0JBQ0ksY0FBYzsrR0FPZixTQUFTO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBTaW1wbGVDaGFuZ2VzLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVZBSUxBQkxFX0xJU1RfV0lER0VUUywgTGlzdFdpZGdldFR5cGUgfSBmcm9tICcuLi9hdmFpbGFibGUtd2lkZ2V0cyc7XG5pbXBvcnQgeyBMaXN0V2lkZ2V0IH0gZnJvbSAnLi4vbGlzdC13aWRnZXQnO1xuaW1wb3J0IHsgTm9kZUVudHJpZXNHbG9iYWxTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vbm9kZS1lbnRyaWVzL25vZGUtZW50cmllcy1nbG9iYWwuc2VydmljZSc7XG5pbXBvcnQgeyBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtbGlzdC1iYXNlJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbGlzdC1iYXNlLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgTGlzdEJhc2VDb21wb25lbnQgZXh0ZW5kcyBMaXN0V2lkZ2V0IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcbiAgICAvKipcbiAgICAgKiB1c2UgdGV4dCBvbmx5IHdpZGdldHMgKGZvciB0YWJsZSlcbiAgICAgKi9cbiAgICBASW5wdXQoKSBmb3JjZVRleHQgPSBmYWxzZTtcbiAgICB3aWRnZXRUeXBlOiBMaXN0V2lkZ2V0VHlwZTtcbiAgICBjdXN0b21UZW1wbGF0ZTogVGVtcGxhdGVSZWY8dW5rbm93bj47XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBub2RlRW50cmllc0dsb2JhbFNlcnZpY2U6IE5vZGVFbnRyaWVzR2xvYmFsU2VydmljZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMubm9kZSAmJiB0aGlzLml0ZW0pIHtcbiAgICAgICAgICAgIHRoaXMuY3VzdG9tVGVtcGxhdGUgPSB0aGlzLm5vZGVFbnRyaWVzR2xvYmFsU2VydmljZS5nZXRDdXN0b21GaWVsZFRlbXBsYXRlKFxuICAgICAgICAgICAgICAgIHRoaXMuaXRlbSxcbiAgICAgICAgICAgICAgICB0aGlzLm5vZGUgYXMgTm9kZSxcbiAgICAgICAgICAgICk7XG4gICAgICAgICAgICB0aGlzLndpZGdldFR5cGUgPSBPYmplY3QuZW50cmllcyhBVkFJTEFCTEVfTElTVF9XSURHRVRTKS5maW5kKFxuICAgICAgICAgICAgICAgIChbaWQsIHddKSA9PlxuICAgICAgICAgICAgICAgICAgICB3Py5zdXBwb3J0ZWRJdGVtcz8uZmlsdGVyKFxuICAgICAgICAgICAgICAgICAgICAgICAgKGkpID0+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgaS50eXBlID09PSB0aGlzLml0ZW0udHlwZSAmJlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIChpLm5hbWUgPT09IHRoaXMuaXRlbS5uYW1lIHx8IGkubmFtZSA9PT0gJyonKSxcbiAgICAgICAgICAgICAgICAgICAgKS5sZW5ndGggPiAwLFxuICAgICAgICAgICAgKT8uWzBdIGFzIExpc3RXaWRnZXRUeXBlO1xuICAgICAgICAgICAgaWYgKHRoaXMuY3VzdG9tVGVtcGxhdGUpIHtcbiAgICAgICAgICAgICAgICB0aGlzLndpZGdldFR5cGUgPSBMaXN0V2lkZ2V0VHlwZS5DdXN0b207XG4gICAgICAgICAgICB9IGVsc2UgaWYgKHRoaXMuZm9yY2VUZXh0KSB7XG4gICAgICAgICAgICAgICAgaWYgKCFbTGlzdFdpZGdldFR5cGUuTm9kZUNvdW50cywgTGlzdFdpZGdldFR5cGUuVGV4dF0uaW5jbHVkZXModGhpcy53aWRnZXRUeXBlKSkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLndpZGdldFR5cGUgPSBMaXN0V2lkZ2V0VHlwZS5UZXh0O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxuZy1jb250YWluZXIgW25nU3dpdGNoXT1cIndpZGdldFR5cGVcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hDYXNlPVwiJ0N1c3RvbSdcIj5cbiAgICA8bmctY29udGFpbmVyXG4gICAgICAqbmdUZW1wbGF0ZU91dGxldD1cIlxuICAgICAgICBjdXN0b21UZW1wbGF0ZTtcbiAgICAgICAgY29udGV4dDoge1xuICAgICAgICAgIGl0ZW06IHRoaXMuaXRlbSxcbiAgICAgICAgICBub2RlOiB0aGlzLm5vZGUsXG4gICAgICAgICAgcHJvdmlkZUxhYmVsOiB0aGlzLnByb3ZpZGVMYWJlbCxcbiAgICAgICAgICBmb3JjZVRleHQ6IHRoaXMuZm9yY2VUZXh0XG4gICAgICAgIH1cbiAgICAgIFwiXG4gICAgPlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L25nLWNvbnRhaW5lcj5cbiAgPGVzLWxpc3QtY29sbGVjdGlvbi1pbmZvXG4gICAgKm5nU3dpdGNoQ2FzZT1cIidDb2xsZWN0aW9uSW5mbydcIlxuICAgIFtpdGVtXT1cIml0ZW1cIlxuICAgIFtub2RlXT1cIm5vZGVcIlxuICAgIFtwcm92aWRlTGFiZWxdPVwicHJvdmlkZUxhYmVsXCJcbiAgPjwvZXMtbGlzdC1jb2xsZWN0aW9uLWluZm8+XG4gIDxlcy1saXN0LXRleHRcbiAgICAqbmdTd2l0Y2hDYXNlPVwiJ1RleHQnXCJcbiAgICBbaXRlbV09XCJpdGVtXCJcbiAgICBbbm9kZV09XCJub2RlXCJcbiAgICBbcHJvdmlkZUxhYmVsXT1cInByb3ZpZGVMYWJlbFwiXG4gID48L2VzLWxpc3QtdGV4dD5cbiAgPGVzLWxpc3QtY291bnRzXG4gICAgKm5nU3dpdGNoQ2FzZT1cIidOb2RlQ291bnRzJ1wiXG4gICAgW2l0ZW1dPVwiaXRlbVwiXG4gICAgW25vZGVdPVwibm9kZVwiXG4gICAgW3Byb3ZpZGVMYWJlbF09XCJwcm92aWRlTGFiZWxcIlxuICA+PC9lcy1saXN0LWNvdW50cz5cbiAgPGVzLWxpc3Qtbm9kZS1saWNlbnNlXG4gICAgKm5nU3dpdGNoQ2FzZT1cIidOb2RlTGljZW5zZSdcIlxuICAgIFtpdGVtXT1cIml0ZW1cIlxuICAgIFtub2RlXT1cIm5vZGVcIlxuICAgIFtwcm92aWRlTGFiZWxdPVwicHJvdmlkZUxhYmVsXCJcbiAgPjwvZXMtbGlzdC1ub2RlLWxpY2Vuc2U+XG4gIDxlcy1saXN0LW5vZGUtcmVwbGljYXRpb24tc291cmNlXG4gICAgKm5nU3dpdGNoQ2FzZT1cIidOb2RlUmVwbGljYXRpb25Tb3VyY2UnXCJcbiAgICBbaXRlbV09XCJpdGVtXCJcbiAgICBbbm9kZV09XCJub2RlXCJcbiAgICBbcHJvdmlkZUxhYmVsXT1cInByb3ZpZGVMYWJlbFwiXG4gID48L2VzLWxpc3Qtbm9kZS1yZXBsaWNhdGlvbi1zb3VyY2U+XG4gIDxlcy1saXN0LW5vZGUtd29ya2Zsb3dcbiAgICAqbmdTd2l0Y2hDYXNlPVwiJ05vZGVXb3JrZmxvdydcIlxuICAgIFtpdGVtXT1cIml0ZW1cIlxuICAgIFtub2RlXT1cIm5vZGVcIlxuICAgIFtwcm92aWRlTGFiZWxdPVwicHJvdmlkZUxhYmVsXCJcbiAgPjwvZXMtbGlzdC1ub2RlLXdvcmtmbG93PlxuPC9uZy1jb250YWluZXI+XG4iXX0=
|
|
@@ -6,8 +6,10 @@ export class ListCountsComponent extends ListWidget {
|
|
|
6
6
|
static { this.supportedItems = [
|
|
7
7
|
new ListItem('NODE', 'counts.OVERALL'),
|
|
8
8
|
new ListItem('NODE', 'counts.VIEW_MATERIAL'),
|
|
9
|
+
new ListItem('NODE', 'counts.VIEW_COLLECTION'),
|
|
9
10
|
new ListItem('NODE', 'counts.VIEW_MATERIAL_EMBEDDED'),
|
|
10
11
|
new ListItem('NODE', 'counts.VIEW_MATERIAL_PLAY_MEDIA'),
|
|
12
|
+
new ListItem('NODE', 'counts.OPEN_EXTERNAL_LINK'),
|
|
11
13
|
new ListItem('NODE', 'counts.DOWNLOAD_MATERIAL'),
|
|
12
14
|
]; }
|
|
13
15
|
static getCountSingle(node, id, group = null) {
|
|
@@ -51,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
51
53
|
type: Component,
|
|
52
54
|
args: [{ selector: 'es-list-counts', template: "{{ getCount() }}\n", styles: [":host{white-space:pre-line}\n"] }]
|
|
53
55
|
}] });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1jb3VudHMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9saXN0LWl0ZW1zL2xpc3QtY291bnRzL2xpc3QtY291bnRzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbGlzdC1pdGVtcy9saXN0LWNvdW50cy9saXN0LWNvdW50cy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBUWpELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxVQUFVO2FBQ3hDLG1CQUFjLEdBQUc7UUFDcEIsSUFBSSxRQUFRLENBQUMsTUFBTSxFQUFFLGdCQUFnQixDQUFDO1FBQ3RDLElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRSxzQkFBc0IsQ0FBQztRQUM1QyxJQUFJLFFBQVEsQ0FBQyxNQUFNLEVBQUUsd0JBQXdCLENBQUM7UUFDOUMsSUFBSSxRQUFRLENBQUMsTUFBTSxFQUFFLCtCQUErQixDQUFDO1FBQ3JELElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRSxpQ0FBaUMsQ0FBQztRQUN2RCxJQUFJLFFBQVEsQ0FBQyxNQUFNLEVBQUUsMkJBQTJCLENBQUM7UUFDakQsSUFBSSxRQUFRLENBQUMsTUFBTSxFQUFFLDBCQUEwQixDQUFDO0tBQ25ELENBQUM7SUFFRixNQUFNLENBQUMsY0FBYyxDQUFDLElBQXFCLEVBQUUsRUFBVSxFQUFFLFFBQWdCLElBQUk7UUFDekUsTUFBTSxNQUFNLEdBQUksSUFBWSxDQUFDLE1BQU0sQ0FBQztRQUNwQyxJQUFJLEVBQUUsS0FBSyxTQUFTLEVBQUU7WUFDbEIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUM7aUJBQzVCLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2lCQUM5QyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7U0FDaEM7UUFDRCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUNELE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBcUIsRUFBRSxFQUFVO1FBQzdDLE1BQU0sTUFBTSxHQUFJLElBQVksQ0FBQyxNQUFNLENBQUM7UUFDcEMsSUFBSSxNQUFNLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDM0MsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQ3hDLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQztZQUNkLElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRTtnQkFDbkIsTUFBTSxFQUFFLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQzdDLElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUU7b0JBQzNCLE1BQU0sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO3lCQUMxQyxHQUFHLENBQ0EsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUNOLENBQUMsS0FBSyxJQUFJLEdBQUcsQ0FBQzt3QkFDZCxJQUFJO3dCQUNKLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUN0RTt5QkFDQSxJQUFJLENBQUMsSUFBSSxDQUFDO3lCQUNWLElBQUksRUFBRSxDQUFDO2lCQUNmO2FBQ0o7U0FDSjtRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxLQUFLO1FBQ0QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELFFBQVE7UUFDSixPQUFPLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBdUIsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNwRixDQUFDOzhHQWpEUSxtQkFBbUI7a0dBQW5CLG1CQUFtQiw2RUNWaEMsb0JBQ0E7OzJGRFNhLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDSSxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExpc3RXaWRnZXQgfSBmcm9tICcuLi9saXN0LXdpZGdldCc7XG5pbXBvcnQgeyBMaXN0SXRlbSB9IGZyb20gJy4uLy4uL3R5cGVzL2xpc3QtaXRlbSc7XG5pbXBvcnQgeyBTdGF0aXN0aWNzR3JvdXAgfSBmcm9tICduZ3gtZWR1LXNoYXJpbmctYXBpJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1saXN0LWNvdW50cycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xpc3QtY291bnRzLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9saXN0LWNvdW50cy5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBMaXN0Q291bnRzQ29tcG9uZW50IGV4dGVuZHMgTGlzdFdpZGdldCB7XG4gICAgc3RhdGljIHN1cHBvcnRlZEl0ZW1zID0gW1xuICAgICAgICBuZXcgTGlzdEl0ZW0oJ05PREUnLCAnY291bnRzLk9WRVJBTEwnKSxcbiAgICAgICAgbmV3IExpc3RJdGVtKCdOT0RFJywgJ2NvdW50cy5WSUVXX01BVEVSSUFMJyksXG4gICAgICAgIG5ldyBMaXN0SXRlbSgnTk9ERScsICdjb3VudHMuVklFV19DT0xMRUNUSU9OJyksXG4gICAgICAgIG5ldyBMaXN0SXRlbSgnTk9ERScsICdjb3VudHMuVklFV19NQVRFUklBTF9FTUJFRERFRCcpLFxuICAgICAgICBuZXcgTGlzdEl0ZW0oJ05PREUnLCAnY291bnRzLlZJRVdfTUFURVJJQUxfUExBWV9NRURJQScpLFxuICAgICAgICBuZXcgTGlzdEl0ZW0oJ05PREUnLCAnY291bnRzLk9QRU5fRVhURVJOQUxfTElOSycpLFxuICAgICAgICBuZXcgTGlzdEl0ZW0oJ05PREUnLCAnY291bnRzLkRPV05MT0FEX01BVEVSSUFMJyksXG4gICAgXTtcblxuICAgIHN0YXRpYyBnZXRDb3VudFNpbmdsZShub2RlOiBTdGF0aXN0aWNzR3JvdXAsIGlkOiBzdHJpbmcsIGdyb3VwOiBudW1iZXIgPSBudWxsKSB7XG4gICAgICAgIGNvbnN0IGNvdW50cyA9IChub2RlIGFzIGFueSkuY291bnRzO1xuICAgICAgICBpZiAoaWQgPT09ICdPVkVSQUxMJykge1xuICAgICAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKGNvdW50cy5jb3VudHMpXG4gICAgICAgICAgICAgICAgLm1hcCgoYykgPT4gKGdyb3VwID8gZ3JvdXAgOiBjb3VudHMuY291bnRzW2NdKSlcbiAgICAgICAgICAgICAgICAucmVkdWNlKChhLCBiKSA9PiBhICsgYik7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIChncm91cCA/IGdyb3VwIDogY291bnRzLmNvdW50c1tpZF0pIHx8IDA7XG4gICAgfVxuICAgIHN0YXRpYyBnZXRDb3VudChub2RlOiBTdGF0aXN0aWNzR3JvdXAsIGlkOiBzdHJpbmcpIHtcbiAgICAgICAgY29uc3QgY291bnRzID0gKG5vZGUgYXMgYW55KS5jb3VudHM7XG4gICAgICAgIGxldCByZXN1bHQgPSB0aGlzLmdldENvdW50U2luZ2xlKG5vZGUsIGlkKTtcbiAgICAgICAgaWYgKE9iamVjdC5rZXlzKGNvdW50cy5ncm91cHMpPy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBjb25zdCBpMSA9IGlkO1xuICAgICAgICAgICAgaWYgKGNvdW50cy5ncm91cHNbaTFdKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgaTIgPSBPYmplY3Qua2V5cyhjb3VudHMuZ3JvdXBzW2kxXSlbMF07XG4gICAgICAgICAgICAgICAgaWYgKGNvdW50cy5ncm91cHM/LltpMV0/LltpMl0pIHtcbiAgICAgICAgICAgICAgICAgICAgcmVzdWx0ID0gT2JqZWN0LmtleXMoY291bnRzLmdyb3Vwcz8uW2kxXT8uW2kyXSlcbiAgICAgICAgICAgICAgICAgICAgICAgIC5tYXAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgKGdyb3VwKSA9PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAoZ3JvdXAgfHwgJy0nKSArXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICc6ICcgK1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmdldENvdW50U2luZ2xlKG5vZGUsIGlkLCBjb3VudHMuZ3JvdXBzPy5baTFdPy5baTJdW2dyb3VwXSksXG4gICAgICAgICAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICAgICAgICAgICAgICAuam9pbignXFxuJylcbiAgICAgICAgICAgICAgICAgICAgICAgIC50cmltKCk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfVxuXG4gICAgZ2V0SWQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLml0ZW0ubmFtZS5zcGxpdCgnLicpWzFdO1xuICAgIH1cblxuICAgIGdldENvdW50KCkge1xuICAgICAgICByZXR1cm4gTGlzdENvdW50c0NvbXBvbmVudC5nZXRDb3VudCh0aGlzLm5vZGUgYXMgU3RhdGlzdGljc0dyb3VwLCB0aGlzLmdldElkKCkpO1xuICAgIH1cbn1cbiIsInt7IGdldENvdW50KCkgfX1cbiJdfQ==
|
|
@@ -9,15 +9,17 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
import * as i1 from "../../services/node-helper.service";
|
|
10
10
|
import * as i2 from "ngx-edu-sharing-api";
|
|
11
11
|
import * as i3 from "@angular/common";
|
|
12
|
-
import * as i4 from "
|
|
13
|
-
import * as i5 from "
|
|
14
|
-
import * as i6 from "
|
|
15
|
-
import * as i7 from "../../pipes/
|
|
16
|
-
import * as i8 from "../../pipes/
|
|
17
|
-
import * as i9 from "../../pipes/
|
|
18
|
-
import * as i10 from "
|
|
19
|
-
import * as i11 from "
|
|
20
|
-
import * as i12 from "
|
|
12
|
+
import * as i4 from "../../directives/check-text-overflow.directive";
|
|
13
|
+
import * as i5 from "@angular/material/tooltip";
|
|
14
|
+
import * as i6 from "../list-node-workflow/list-node-workflow.component";
|
|
15
|
+
import * as i7 from "../../pipes/format-date.pipe";
|
|
16
|
+
import * as i8 from "../../pipes/file-size.pipe";
|
|
17
|
+
import * as i9 from "../../pipes/node-image-size.pipe";
|
|
18
|
+
import * as i10 from "../../pipes/node-person-name.pipe";
|
|
19
|
+
import * as i11 from "../../pipes/vcard-name.pipe";
|
|
20
|
+
import * as i12 from "@ngx-translate/core";
|
|
21
|
+
import * as i13 from "../node-source.pipe";
|
|
22
|
+
import * as i14 from "../format-duration.pipe";
|
|
21
23
|
export class ListTextComponent extends ListWidget {
|
|
22
24
|
static { this.supportedItems = [
|
|
23
25
|
new ListItem('NODE', '*'),
|
|
@@ -79,7 +81,7 @@ export class ListTextComponent extends ListWidget {
|
|
|
79
81
|
: node.properties[this.item.name]?.join(', '));
|
|
80
82
|
const mds = await this.mds
|
|
81
83
|
.getMetadataSet({
|
|
82
|
-
repository: node.ref?.repo,
|
|
84
|
+
repository: node.ref?.repo || Constants.HOME_REPOSITORY,
|
|
83
85
|
metadataSet: node.metadataset || Constants.DEFAULT,
|
|
84
86
|
})
|
|
85
87
|
.toPromise();
|
|
@@ -97,10 +99,10 @@ export class ListTextComponent extends ListWidget {
|
|
|
97
99
|
*/
|
|
98
100
|
}
|
|
99
101
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: ListTextComponent, deps: [{ token: i1.NodeHelperService }, { token: i2.MdsService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
100
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: ListTextComponent, selector: "es-list-text", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile
|
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: ListTextComponent, selector: "es-list-text", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile?.displayName || $any(getNode()).authorityName }}\n </span>\n <span *ngSwitchCase=\"'groupType'\">\n {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile?.groupType | translate }}\n </span>\n <span *ngSwitchDefault>\n {{ $any(getNode())[item.name] }}\n </span>\n </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n <span *ngIf=\"isUserProfileAttribute(item.name)\">\n {{ $any(getNode()).profile?.[item.name] }}\n </span>\n <span *ngIf=\"item.name === 'status'\">\n {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n </span>\n <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n {{ $any(getNode())[item.name] }}\n </span>\n</ng-container>\n<ng-container\n [ngSwitch]=\"item.name\"\n *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n <span *ngSwitchCase=\"'name'\">\n {{ $any(getNode()).name }}\n </span>\n <span\n *ngSwitchCase=\"'mediatype'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n </span>\n <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).size | formatSize }}\n </span>\n <span\n *ngSwitchCase=\"'dimensions'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()) | NodeImageSize }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:wf_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <es-list-node-workflow\n [item]=\"item\"\n [node]=\"node\"\n [provideLabel]=\"false\"\n ></es-list-node-workflow>\n <!--<span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}-->\n </span>\n <span\n *ngSwitchCase=\"'cm:creator'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n {{ $any(getNode()).createdBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'cm:modifier'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cm:modifier' | translate }}:</span\n >\n {{ $any(getNode()).modifiedBy | nodePersonName }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:replicationsource'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n >\n {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span\n *ngSwitchDefault\n esCheckTextOverflow\n #text=\"esCheckTextOverflow\"\n [matTooltip]=\"\n provideLabel ? (getI18n(item) | translate) : text.hasTextOverflow() ? content.innerText : null\n \"\n #content\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container *ngIf=\"['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n {{ $any(getNode()).title || $any(getNode()).name }}\n </ng-container>\n <ng-container *ngIf=\"!['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true, time: true, relative: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}span{display:block}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.CheckTextOverflowDirective, selector: "[esCheckTextOverflow]", inputs: ["esCheckTextOverflow"], exportAs: ["esCheckTextOverflow"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i6.ListNodeWorkflowComponent, selector: "es-list-node-workflow" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.FormatDatePipe, name: "formatDate" }, { kind: "pipe", type: i8.FormatSizePipe, name: "formatSize" }, { kind: "pipe", type: i9.NodeImageSizePipe, name: "NodeImageSize" }, { kind: "pipe", type: i10.NodePersonNamePipe, name: "nodePersonName" }, { kind: "pipe", type: i11.VCardNamePipe, name: "vcardName" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.NodeSourcePipe, name: "appNodeSource" }, { kind: "pipe", type: i14.FormatDurationPipe, name: "formatDuration" }] }); }
|
|
101
103
|
}
|
|
102
104
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: ListTextComponent, decorators: [{
|
|
103
105
|
type: Component,
|
|
104
|
-
args: [{ selector: 'es-list-text', template: "<label *ngIf=\"item.config?.showLabel\">\n {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n <ng-container [ngSwitch]=\"item.name\">\n <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n {{ $any(getNode()).profile
|
|
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 : { mode: 'text' } }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:commonlicense_key'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n >\n <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n {{\n license[0] === 'CUSTOM'\n ? $any(getNode()).properties['cclom:rights_description']\n : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n }}\n </ng-container>\n <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n {{ 'LICENSE.NAMES.NONE' | translate }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n >\n <ng-container\n *ngIf=\"\n $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n \"\n >\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n </ng-container>\n </span>\n <span\n *ngSwitchCase=\"'cclom:duration'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.cclom:duration' | translate }}:</span\n >\n {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n </span>\n <span\n *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n >\n <!-- use node instead of getNode() to access the raw proposal data! -->\n {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n </span>\n <span\n *ngSwitchDefault\n esCheckTextOverflow\n #text=\"esCheckTextOverflow\"\n [matTooltip]=\"\n provideLabel ? (getI18n(item) | translate) : text.hasTextOverflow() ? content.innerText : null\n \"\n #content\n >\n <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n <ng-container *ngIf=\"['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n {{ $any(getNode()).title || $any(getNode()).name }}\n </ng-container>\n <ng-container *ngIf=\"!['title', 'cm:title', 'cclom:title'].includes(item.name)\">\n <ng-container\n *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n >\n {{ displayName$ | async }}\n </ng-container>\n <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true, time: true, relative: true } | async }}\n </ng-container>\n <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n {{\n $any(getNode()).properties[item.name]\n ? ($any(getNode()).properties[item.name][0] | vcardName)\n : ''\n }}\n </ng-container>\n </ng-container>\n </span>\n</ng-container>\n", styles: [".type-danger{color:var(--warning)}span{display:block}\n"] }]
|
|
105
107
|
}], ctorParameters: function () { return [{ type: i1.NodeHelperService }, { type: i2.MdsService }, { type: i0.ChangeDetectorRef }]; } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-text.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/list-items/list-text/list-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit, SimpleChanges } from '@angular/core';\nimport { MdsService, Node, Organization, RestConstants, ProposalNode } from 'ngx-edu-sharing-api';\nimport { BehaviorSubject, merge } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { ListItem } from '../../types/list-item';\nimport { ListWidget } from '../list-widget';\nimport { NodeHelperService } from '../../services/node-helper.service';\nimport * as Constants from 'ngx-edu-sharing-api';\n\n@Component({\n    selector: 'es-list-text',\n    templateUrl: './list-text.component.html',\n    styleUrls: ['./list-text.component.scss'],\n})\nexport class ListTextComponent extends ListWidget implements OnInit {\n    static supportedItems = [\n        new ListItem('NODE', '*'),\n        new ListItem('NODE_PROPOSAL', '*'),\n        new ListItem('COLLECTION', '*'),\n        new ListItem('ORG', '*'),\n        new ListItem('GROUP', '*'),\n        new ListItem('USER', '*'),\n    ];\n    readonly DATE_FIELDS = RestConstants.DATE_FIELDS;\n    readonly VCARD_FIELDS = RestConstants.getAllVCardFields();\n    displayName$ = new BehaviorSubject<string>(null);\n\n    constructor(\n        private nodeHelper: NodeHelperService,\n        private mds: MdsService,\n        private changeDetectorRef: ChangeDetectorRef,\n    ) {\n        super();\n    }\n\n    async ngOnChanges(changes: SimpleChanges) {}\n\n    async ngOnInit() {\n        merge([this.nodeSubject, this.itemSubject])\n            .pipe(switchMap(() => this.updateDisplayname()))\n            .subscribe((displayName) => {});\n    }\n    getNode() {\n        if (this.item.type === 'NODE_PROPOSAL') {\n            return (this.node as ProposalNode).proposal || this.node;\n        } else if ((this.node as Node).type === RestConstants.CCM_TYPE_COLLECTION_PROPOSAL) {\n            return (this.node as Node).relations?.Original ?? this.node;\n        }\n        return this.node;\n    }\n\n    isUserProfileAttribute(attribute: string) {\n        return (\n            [\n                RestConstants.AUTHORITY_FIRSTNAME,\n                RestConstants.AUTHORITY_LASTNAME,\n                RestConstants.AUTHORITY_EMAIL,\n            ].indexOf(attribute) !== -1\n        );\n    }\n    getWorkflowStatus() {\n        return this.nodeHelper.getWorkflowStatus(this.node as Node).current;\n    }\n\n    getI18n(item: ListItem) {\n        return (item.type === 'NODE_PROPOSAL' ? 'NODE_PROPOSAL' : 'NODE') + '.' + item.name;\n    }\n\n    isDangerousGroup() {\n        return (\n            (this.node as Organization).authorityName ===\n            RestConstants.GROUP_ALFRESCO_ADMINISTRATORS\n        );\n    }\n\n    private async updateDisplayname() {\n        const node = this.getNode() as Node;\n        if (!node.properties) {\n            this.displayName$.next('');\n            return;\n        }\n        this.displayName$.next(\n            node.properties[this.item.name + '_DISPLAYNAME']?.length > 0\n                ? node.properties[this.item.name + '_DISPLAYNAME'].join(', ')\n                : node.properties[this.item.name]?.join(', '),\n        );\n\n        const mds = await this.mds\n            .getMetadataSet({\n                repository: node.ref?.repo,\n                metadataSet: node.metadataset || Constants.DEFAULT,\n            })\n            .toPromise();\n        // @TODO\n        /*\n        const widget = MdsHelper.getWidget(this.item.name, null, mds.widgets);\n        if (widget?.values) {\n            const i18n = node.properties[this.item.name]\n                ?.map((prop) => widget.values.filter((v) => v.id === prop)?.[0]?.caption)\n                .filter((cap) => !!cap);\n            if (i18n) {\n                this.displayName$.next(i18n.join(', '));\n            }\n        }\n         */\n    }\n}\n","<label *ngIf=\"item.config?.showLabel\">\n  {{ getI18n(item) | translate }}\n</label>\n<ng-container *ngIf=\"item.type === 'ORG' || item.type === 'GROUP'\">\n  <ng-container [ngSwitch]=\"item.name\">\n    <span *ngSwitchCase=\"'displayName'\" [class.type-danger]=\"isDangerousGroup()\">\n      {{ $any(getNode()).profile.displayName }}\n    </span>\n    <span *ngSwitchCase=\"'groupType'\">\n      {{ 'PERMISSIONS.GROUP_TYPE.' + $any(getNode()).profile.groupType | translate }}\n    </span>\n    <span *ngSwitchDefault>\n      {{ $any(getNode())[item.name] }}\n    </span>\n  </ng-container>\n</ng-container>\n<ng-container *ngIf=\"item.type === 'USER'\">\n  <span *ngIf=\"isUserProfileAttribute(item.name)\">\n    {{ $any(getNode()).profile[item.name] }}\n  </span>\n  <span *ngIf=\"item.name === 'status'\">\n    {{ 'PERMISSIONS.USER_STATUS.' + $any(getNode()).status.status | translate }}\n  </span>\n  <span *ngIf=\"!isUserProfileAttribute(item.name) && item.name !== 'status'\">\n    {{ $any(getNode())[item.name] }}\n  </span>\n</ng-container>\n<ng-container\n  [ngSwitch]=\"item.name\"\n  *ngIf=\"item.type === 'NODE' || item.type === 'NODE_PROPOSAL' || item.type === 'COLLECTION'\"\n>\n  <span *ngSwitchCase=\"'name'\">\n    {{ $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cclom:title'\"\n    [matTooltip]=\"provideLabel ? $any(getNode()).title || $any(getNode()).name : null\"\n  >\n    {{ $any(getNode()).title || $any(getNode()).name }}\n  </span>\n  <span\n    *ngSwitchCase=\"'mediatype'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'MEDIATYPE.' + $any(getNode()).mediatype | translate }}\n  </span>\n  <span *ngSwitchCase=\"'size'\" [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).size | formatSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'dimensions'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()) | NodeImageSize }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:wf_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ 'WORKFLOW.' + getWorkflowStatus().id | translate }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:creator'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    {{ $any(getNode()).createdBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'cm:modifier'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cm:modifier' | translate }}:</span\n    >\n    {{ $any(getNode()).modifiedBy | nodePersonName }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:replicationsource'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:replicationsource' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['ccm:replicationsource'] | appNodeSource : { mode: 'text' } }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:commonlicense_key'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:commonlicense_key' | translate }}:</span\n    >\n    <ng-container *ngIf=\"$any(getNode()).properties['ccm:commonlicense_key'] as license\">\n      {{\n        license[0] === 'CUSTOM'\n          ? $any(getNode()).properties['cclom:rights_description']\n          : ('LICENSE.NAMES.' + $any(getNode()).properties['ccm:commonlicense_key']\n            | translate : { fallback: $any(getNode()).properties['ccm:commonlicense_key'] })\n      }}\n    </ng-container>\n    <ng-container *ngIf=\"!$any(getNode()).properties['ccm:commonlicense_key']\">\n      {{ 'LICENSE.NAMES.NONE' | translate }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:educationaltypicalagerange'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:educationaltypicalagerange' | translate }}:</span\n    >\n    <ng-container\n      *ngIf=\"\n        $any(getNode()).properties['ccm:educationaltypicalagerange_from'] ||\n        $any(getNode()).properties['ccm:educationaltypicalagerange_to']\n      \"\n    >\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_from'] }} -\n      {{ $any(getNode()).properties['ccm:educationaltypicalagerange_to'] }}\n    </ng-container>\n  </span>\n  <span\n    *ngSwitchCase=\"'cclom:duration'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.cclom:duration' | translate }}:</span\n    >\n    {{ $any(getNode()).properties['cclom:duration']?.[0] | formatDuration }}\n  </span>\n  <span\n    *ngSwitchCase=\"'ccm:collection_proposal_status'\"\n    [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\"\n  >\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\"\n      >{{ 'NODE.ccm:collection_proposal_status' | translate }}:</span\n    >\n    <!-- use node instead of getNode() to access the raw proposal data! -->\n    {{ ('PROPOSAL_STATUS.' + $any(node).properties['ccm:collection_proposal_status']?.[0]) | translate:{fallback: ''} }}\n  </span>\n  <span *ngSwitchDefault [matTooltip]=\"provideLabel ? (getI18n(item) | translate) : null\">\n    <span *ngIf=\"provideLabel\" class=\"cdk-visually-hidden\">{{ getI18n(item) | translate }}:</span>\n    <ng-container\n      *ngIf=\"DATE_FIELDS.indexOf(item.name) === -1 && VCARD_FIELDS.indexOf(item.name) === -1\"\n    >\n      {{ displayName$ | async }}\n    </ng-container>\n    <ng-container *ngIf=\"DATE_FIELDS.includes(item.name)\">\n      {{ $any(getNode()).properties[item.name]?.[0] | formatDate: { async: true } | async }}\n    </ng-container>\n    <ng-container *ngIf=\"VCARD_FIELDS.includes(item.name)\">\n      {{\n        $any(getNode()).properties[item.name]\n          ? ($any(getNode()).properties[item.name][0] | vcardName)\n          : ''\n      }}\n    </ng-container>\n  </span>\n</ng-container>\n"]}
|
|
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"]}
|
|
@@ -19,5 +19,6 @@ export var ClickSource;
|
|
|
19
19
|
ClickSource[ClickSource["Metadata"] = 2] = "Metadata";
|
|
20
20
|
ClickSource[ClickSource["Comments"] = 3] = "Comments";
|
|
21
21
|
ClickSource[ClickSource["Overlay"] = 4] = "Overlay";
|
|
22
|
+
ClickSource[ClickSource["Dropdown"] = 5] = "Dropdown";
|
|
22
23
|
})(ClickSource || (ClickSource = {}));
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cmllcy1tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL2VudHJpZXMtbW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JBLE1BQU0sQ0FBTixJQUFZLHNCQUlYO0FBSkQsV0FBWSxzQkFBc0I7SUFDOUIscUVBQUssQ0FBQTtJQUNMLG1FQUFJLENBQUE7SUFDSiw2RUFBUyxDQUFBO0FBQ2IsQ0FBQyxFQUpXLHNCQUFzQixLQUF0QixzQkFBc0IsUUFJakM7QUFFRCxNQUFNLENBQU4sSUFBWSxlQU1YO0FBTkQsV0FBWSxlQUFlO0lBQ3ZCLHFCQUFxQjtJQUNyQiwrRUFBaUIsQ0FBQTtJQUNqQixnQkFBZ0I7SUFDaEIsMkRBQU8sQ0FBQTtJQUNQLHFEQUFJLENBQUE7QUFDUixDQUFDLEVBTlcsZUFBZSxLQUFmLGVBQWUsUUFNMUI7QUE2QkQsTUFBTSxDQUFOLElBQVksV0FPWDtBQVBELFdBQVksV0FBVztJQUNuQixtREFBTyxDQUFBO0lBQ1AsNkNBQUksQ0FBQTtJQUNKLHFEQUFRLENBQUE7SUFDUixxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7QUFDWixDQUFDLEVBUFcsV0FBVyxLQUFYLFdBQVcsUUFPdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb3J0IH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5cbmltcG9ydCB7IFNlbGVjdGlvbk1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IEN1c3RvbU9wdGlvbnMsIE9wdGlvbkl0ZW0sIFRhcmdldCB9IGZyb20gJy4uL3R5cGVzL29wdGlvbi1pdGVtJztcbmltcG9ydCB7IExpc3RJdGVtLCBMaXN0SXRlbVNvcnQgfSBmcm9tICcuLi90eXBlcy9saXN0LWl0ZW0nO1xuaW1wb3J0IHsgQ2FuRHJvcCwgRHJhZ0RhdGEsIERyb3BBY3Rpb24gfSBmcm9tICcuLi90eXBlcy9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgTm9kZSwgR2VuZXJpY0F1dGhvcml0eSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgQWN0aW9uYmFyQ29tcG9uZW50IH0gZnJvbSAnLi4vYWN0aW9uYmFyL2FjdGlvbmJhci5jb21wb25lbnQnO1xuXG5leHBvcnQgdHlwZSBOb2RlUm9vdCA9XG4gICAgfCAnTVlfRklMRVMnXG4gICAgfCAnU0hBUkVEX0ZJTEVTJ1xuICAgIHwgJ01ZX1NIQVJFRF9GSUxFUydcbiAgICB8ICdUT19NRV9TSEFSRURfRklMRVMnXG4gICAgfCAnV09SS0ZMT1dfUkVDRUlWRSdcbiAgICB8ICdSRUNZQ0xFJ1xuICAgIHwgJ0FMTF9GSUxFUyc7XG5cbmV4cG9ydCBlbnVtIE5vZGVFbnRyaWVzRGlzcGxheVR5cGUge1xuICAgIFRhYmxlLFxuICAgIEdyaWQsXG4gICAgU21hbGxHcmlkLFxufVxuXG5leHBvcnQgZW51bSBJbnRlcmFjdGlvblR5cGUge1xuICAgIC8vIGNyZWF0ZSByb3V0ZXIgbGlua1xuICAgIERlZmF1bHRBY3Rpb25MaW5rLFxuICAgIC8vIGVtaXQgYW4gZXZlbnRcbiAgICBFbWl0dGVyLFxuICAgIE5vbmUsXG59XG5cbmV4cG9ydCB0eXBlIExpc3RPcHRpb25zID0geyBba2V5IGluIFRhcmdldF0/OiBPcHRpb25JdGVtW10gfTtcbmV4cG9ydCB0eXBlIExpc3RPcHRpb25zQ29uZmlnID0ge1xuICAgIGFjdGlvbmJhcj86IEFjdGlvbmJhckNvbXBvbmVudDtcbiAgICBwYXJlbnQ/OiBOb2RlO1xuICAgIGN1c3RvbU9wdGlvbnM/OiBDdXN0b21PcHRpb25zO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBMaXN0U29ydENvbmZpZyBleHRlbmRzIFNvcnQge1xuICAgIGNvbHVtbnM6IExpc3RJdGVtU29ydFtdO1xuICAgIGFsbG93ZWQ/OiBib29sZWFuO1xuICAgIGN1c3RvbVNvcnRpbmdJblByb2dyZXNzPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgRHJvcFRhcmdldCA9IE5vZGUgfCBOb2RlUm9vdDtcblxuZXhwb3J0IGludGVyZmFjZSBEcm9wU291cmNlPFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgZWxlbWVudDogVFtdO1xuICAgIC8vIHNvdXJjZUxpc3Q6IExpc3RFdmVudEludGVyZmFjZTxUPjtcbiAgICBtb2RlOiBEcm9wQWN0aW9uO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExpc3REcmFnR3JvcENvbmZpZzxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4ge1xuICAgIGRyYWdBbGxvd2VkOiBib29sZWFuO1xuICAgIGRyb3BBbGxvd2VkPzogKGRyYWdEYXRhOiBEcmFnRGF0YTxUPikgPT4gQ2FuRHJvcDtcbiAgICBkcm9wcGVkPzogKHRhcmdldDogTm9kZSwgc291cmNlOiBEcm9wU291cmNlPE5vZGVFbnRyaWVzRGF0YVR5cGU+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgZW51bSBDbGlja1NvdXJjZSB7XG4gICAgUHJldmlldyxcbiAgICBJY29uLFxuICAgIE1ldGFkYXRhLFxuICAgIENvbW1lbnRzLFxuICAgIE92ZXJsYXksXG4gICAgRHJvcGRvd24sIC8vIGtlZXA6IHVzZWQgaW4gZXh0ZW5zaW9uc1xufVxuXG5leHBvcnQgdHlwZSBOb2RlQ2xpY2tFdmVudDxUIGV4dGVuZHMgTm9kZUVudHJpZXNEYXRhVHlwZT4gPSB7XG4gICAgZWxlbWVudDogVDtcbiAgICBzb3VyY2U6IENsaWNrU291cmNlO1xuICAgIGF0dHJpYnV0ZT86IExpc3RJdGVtOyAvLyBvbmx5IHdoZW4gc291cmNlID09PSBNZXRhZGF0YVxufTtcbmV4cG9ydCB0eXBlIEZldGNoRXZlbnQgPSB7XG4gICAgb2Zmc2V0OiBudW1iZXI7XG4gICAgYW1vdW50PzogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIGlzIGEgcmVzZXQgb2YgdGhlIGN1cnJlbnQgZGF0YSByZXF1aXJlZD9cbiAgICAgKiB0aGlzIHNob3VsZCBiZSB0cnVlIGlmIHRoaXMgd2FzIGEgcGFnaW5hdGlvbiByZXF1ZXN0XG4gICAgICovXG4gICAgcmVzZXQ/OiBib29sZWFuO1xufTtcbmV4cG9ydCB0eXBlIE5vZGVFbnRyaWVzRGF0YVR5cGUgPSBOb2RlIHwgR2VuZXJpY0F1dGhvcml0eTtcbmV4cG9ydCB0eXBlIEdyaWRMYXlvdXQgPSAnZ3JpZCcgfCAnc2Nyb2xsJztcbmV4cG9ydCB0eXBlIEdyaWRDb25maWcgPSB7XG4gICAgLyoqXG4gICAgICogbWF4IGFtb3VudCBvZiByb3dzIHRoYXQgc2hvdWxkIGJlIHZpc2libGUsIHVuc2V0IGZvciBubyBsaW1pdFxuICAgICAqL1xuICAgIG1heFJvd3M/OiBudW1iZXI7XG4gICAgLyoqXG4gICAgICogbGF5b3V0LCBkZWZhdWx0cyB0byAnZ3JpZCdcbiAgICAgKiAnc2Nyb2xsJyBtYXkgb25seSBiZSB1c2VkIHdoZW4gbWF4Um93cyBpcyBub3Qgc2V0XG4gICAgICovXG4gICAgbGF5b3V0PzogR3JpZExheW91dDtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgTGlzdEV2ZW50SW50ZXJmYWNlPFQgZXh0ZW5kcyBOb2RlRW50cmllc0RhdGFUeXBlPiB7XG4gICAgdXBkYXRlTm9kZXMobm9kZXM6IHZvaWQgfCBUW10pOiB2b2lkO1xuXG4gICAgZ2V0RGlzcGxheVR5cGUoKTogTm9kZUVudHJpZXNEaXNwbGF5VHlwZTtcblxuICAgIHNldERpc3BsYXlUeXBlKGRpc3BsYXlUeXBlOiBOb2RlRW50cmllc0Rpc3BsYXlUeXBlKTogdm9pZDtcblxuICAgIHNob3dSZW9yZGVyQ29sdW1uc0RpYWxvZygpOiB2b2lkO1xuXG4gICAgYWRkVmlydHVhbE5vZGVzKHZpcnR1YWw6IFRbXSk6IHZvaWQ7XG5cbiAgICBzZXRPcHRpb25zKG9wdGlvbnM6IExpc3RPcHRpb25zKTogdm9pZDtcblxuICAgIC8qKlxuICAgICAqIGFjdGl2YXRlIG9wdGlvbiAoZHJvcGRvd24pIGdlbmVyYXRpb25cbiAgICAgKi9cbiAgICBpbml0T3B0aW9uc0dlbmVyYXRvcihjb25maWc6IExpc3RPcHRpb25zQ29uZmlnKTogdm9pZCB8IFByb21pc2U8dm9pZD47XG5cbiAgICBnZXRTZWxlY3Rpb24oKTogU2VsZWN0aW9uTW9kZWw8VD47XG5cbiAgICAvKipcbiAgICAgKiB0cmlnZ2VyZWQgd2hlbiBub2Rlcy9vYmplY3RzIGFyZSBkZWxldGVkIGFuZCBzaG91bGQgbm90IGJlIHNob3duIGluIHRoZSBsaXN0IGFueW1vcmVcbiAgICAgKi9cbiAgICBkZWxldGVOb2RlcyhvYmplY3RzOiBUW10pOiB2b2lkO1xufVxuIl19
|
|
@@ -18,6 +18,14 @@ export class NodeCache {
|
|
|
18
18
|
return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
|
+
// for the first request
|
|
22
|
+
console.warn('Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)', range, this._slices);
|
|
23
|
+
for (const slice of this._slices) {
|
|
24
|
+
if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {
|
|
25
|
+
return slice.data.slice(range.startIndex - slice.startIndex, range.endIndex - slice.startIndex);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
console.error('Could not find any slice for the range', range, this._slices);
|
|
21
29
|
return null;
|
|
22
30
|
}
|
|
23
31
|
getMissingRange(requestedRange) {
|
|
@@ -62,4 +70,4 @@ export class NodeCache {
|
|
|
62
70
|
};
|
|
63
71
|
}
|
|
64
72
|
}
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-cache.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-cache.ts"],"names":[],"mappings":"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","sourcesContent":["import { notNull } from '../util/functions';\n\nexport interface NodeCacheRange {\n    startIndex: number;\n    endIndex: number;\n}\n\nexport interface NodeCacheSlice<T> extends NodeCacheRange {\n    data: readonly T[];\n}\n\nexport class NodeCache<T> {\n    private _slices: readonly NodeCacheSlice<T>[] = [];\n\n    add(slice: NodeCacheSlice<T>): void {\n        if (slice.endIndex - slice.startIndex !== slice.data.length) {\n            throw new Error('Tried to add invalid slice to cache: ' + JSON.stringify(slice));\n        }\n        this._slices = this._normalizeSlices([...this._slices, slice]);\n    }\n\n    clear() {\n        this._slices = [];\n    }\n\n    get(range: NodeCacheRange): T[] | null {\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.endIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        // for the first request\n        console.warn(\n            'Requested range was not found in the slices cache, falling back to a smaller slice (the backend resolved too less data)',\n            range,\n            this._slices,\n        );\n        for (const slice of this._slices) {\n            if (slice.startIndex <= range.startIndex && slice.endIndex >= range.startIndex) {\n                return slice.data.slice(\n                    range.startIndex - slice.startIndex,\n                    range.endIndex - slice.startIndex,\n                );\n            }\n        }\n        console.error('Could not find any slice for the range', range, this._slices);\n        return null;\n    }\n\n    getMissingRange(requestedRange: NodeCacheRange): NodeCacheRange | null {\n        let fromIndex = requestedRange.startIndex;\n        let toIndex = requestedRange.endIndex;\n        for (const slice of this._slices) {\n            if (slice.startIndex <= fromIndex && slice.endIndex > fromIndex) {\n                fromIndex = slice.endIndex;\n            } else if (slice.startIndex < toIndex && slice.endIndex >= toIndex) {\n                toIndex = slice.startIndex;\n            }\n            if (fromIndex >= toIndex) {\n                return null;\n            }\n        }\n        return { startIndex: fromIndex, endIndex: toIndex };\n    }\n\n    private _normalizeSlices(slices: NodeCacheSlice<T>[]): NodeCacheSlice<T>[] {\n        slices.sort((lhs, rhs) => lhs.startIndex - rhs.startIndex);\n        for (let i = 0; i < slices.length - 1; i++) {\n            for (let j = i + 1; j < slices.length; j++) {\n                if (this._canMerge(slices[i], slices[j])) {\n                    slices[i] = this._merge(slices[i], slices[j]);\n                    slices[j] = null; // Mark for deletion\n                }\n            }\n        }\n        return slices.filter(notNull);\n    }\n\n    private _canMerge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): boolean {\n        if (!lhs || !rhs) {\n            return false;\n        }\n        return lhs.endIndex >= rhs.startIndex;\n    }\n\n    private _merge(lhs: NodeCacheSlice<T>, rhs: NodeCacheSlice<T>): NodeCacheSlice<T> {\n        return {\n            startIndex: lhs.startIndex,\n            endIndex: rhs.endIndex,\n            data: [...lhs.data, ...rhs.data.slice(lhs.endIndex - rhs.startIndex)],\n        };\n    }\n}\n"]}
|