ngx-rendering-service-lib 0.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/environments/environment.d.ts +5 -0
- package/esm2022/environments/environment.mjs +6 -0
- package/esm2022/index.mjs +13 -0
- package/esm2022/lib/dto/AssetStateData.mjs +2 -0
- package/esm2022/lib/module/RenderModule.mjs +2 -0
- package/esm2022/lib/module/eduhtml/eduHtml.component.mjs +34 -0
- package/esm2022/lib/module/image/image.component.mjs +51 -0
- package/esm2022/lib/module/pdf/pdf.component.mjs +81 -0
- package/esm2022/lib/module/spreadsheet/spreadsheet.component.mjs +47 -0
- package/esm2022/lib/module/url/url.component.mjs +118 -0
- package/esm2022/lib/module/video/video.component.mjs +61 -0
- package/esm2022/lib/render.component.mjs +145 -0
- package/esm2022/lib/rendering-api.module.mjs +23 -0
- package/esm2022/lib/rendering.module.mjs +25 -0
- package/esm2022/ngx-rendering-service-lib.mjs +5 -0
- package/esm2022/rendering-service-lib.module.mjs +32 -0
- package/fesm2022/ngx-rendering-service-lib.mjs +613 -0
- package/fesm2022/ngx-rendering-service-lib.mjs.map +1 -0
- package/index.d.ts +9 -0
- package/lib/dto/AssetStateData.d.ts +10 -0
- package/lib/module/RenderModule.d.ts +6 -0
- package/lib/module/eduhtml/eduHtml.component.d.ts +14 -0
- package/lib/module/image/image.component.d.ts +17 -0
- package/lib/module/pdf/pdf.component.d.ts +21 -0
- package/lib/module/spreadsheet/spreadsheet.component.d.ts +17 -0
- package/lib/module/url/url.component.d.ts +29 -0
- package/lib/module/video/video.component.d.ts +15 -0
- package/lib/render.component.d.ts +25 -0
- package/lib/rendering-api.module.d.ts +7 -0
- package/lib/rendering.module.d.ts +8 -0
- package/package.json +39 -0
- package/rendering-service-lib.module.d.ts +10 -0
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { RenderingModule } from "./rendering.module";
|
|
3
|
+
import { BehaviorSubject, firstValueFrom, interval, Subject, switchMap, takeUntil } from "rxjs";
|
|
4
|
+
import { RenderingApiModule } from "./rendering-api.module";
|
|
5
|
+
import { MatProgressSpinnerModule } from "@angular/material/progress-spinner";
|
|
6
|
+
import { MatProgressBarModule } from "@angular/material/progress-bar";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "ngx-rendering-service-api";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
import * as i3 from "@angular/material/progress-spinner";
|
|
11
|
+
import * as i4 from "@angular/material/progress-bar";
|
|
12
|
+
export class RenderComponent {
|
|
13
|
+
constructor(renderControllerService, jobInfoControllerService) {
|
|
14
|
+
this.renderControllerService = renderControllerService;
|
|
15
|
+
this.jobInfoControllerService = jobInfoControllerService;
|
|
16
|
+
this.renderData$ = new BehaviorSubject(null);
|
|
17
|
+
this.finished = new Subject();
|
|
18
|
+
this.someButNotAllFinished = new Subject();
|
|
19
|
+
this.progress$ = new BehaviorSubject(null);
|
|
20
|
+
this.useUrlModule = false;
|
|
21
|
+
}
|
|
22
|
+
async ngOnChanges(changes) {
|
|
23
|
+
if (this.node === undefined || !this.checkIfBackendModule()) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const renderResponseData = (await firstValueFrom(this.renderControllerService.getRenderData({
|
|
27
|
+
body: this.request
|
|
28
|
+
})));
|
|
29
|
+
// It is possible that there is completed data AND a job id (if there).
|
|
30
|
+
// We need the data then AND trigger the progress logic to keep loading the unfinished resolutions.
|
|
31
|
+
if (renderResponseData.jobId === null) {
|
|
32
|
+
const items = renderResponseData.objectLinks?.map(item => {
|
|
33
|
+
const assetItem = {
|
|
34
|
+
link: item.link,
|
|
35
|
+
progress: 100,
|
|
36
|
+
height: item.height,
|
|
37
|
+
width: item.width
|
|
38
|
+
};
|
|
39
|
+
return assetItem;
|
|
40
|
+
});
|
|
41
|
+
const data = {
|
|
42
|
+
module: renderResponseData.module,
|
|
43
|
+
items: items
|
|
44
|
+
};
|
|
45
|
+
renderResponseData.objectLinks !== undefined && this.renderData$.next(data);
|
|
46
|
+
this.finished.next();
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.progress$.next({ module: renderResponseData.module });
|
|
50
|
+
interval(500).pipe(takeUntil(this.finished), switchMap(() => this.jobInfoControllerService.getJobInfo({ jobId: renderResponseData.jobId }).pipe())).subscribe(async (status) => {
|
|
51
|
+
// Some, but not all, jobs are finished ->
|
|
52
|
+
if (status.jobs.some(j => j.status === 'FINISHED') && status.status !== 'FINISHED') {
|
|
53
|
+
const items = status.jobs.map(subJob => {
|
|
54
|
+
const assetItem = {
|
|
55
|
+
link: subJob.objectLink?.link ?? "",
|
|
56
|
+
progress: subJob.status !== 'QUEUED' ? subJob.progress : -(subJob.progress + 1),
|
|
57
|
+
height: subJob.objectLink?.height ?? subJob.quality,
|
|
58
|
+
width: subJob.objectLink?.width ?? 0
|
|
59
|
+
};
|
|
60
|
+
return assetItem;
|
|
61
|
+
});
|
|
62
|
+
const data = {
|
|
63
|
+
module: renderResponseData.module,
|
|
64
|
+
items: items
|
|
65
|
+
};
|
|
66
|
+
this.renderData$.next(data);
|
|
67
|
+
this.someButNotAllFinished.next(true);
|
|
68
|
+
// all finished and/or failed
|
|
69
|
+
}
|
|
70
|
+
else if (status.status === 'FINISHED' || status.status === 'FAILED') {
|
|
71
|
+
const items = status.jobs.map(subJob => {
|
|
72
|
+
const assetItem = {
|
|
73
|
+
link: subJob.objectLink?.link ?? "",
|
|
74
|
+
progress: subJob.progress,
|
|
75
|
+
height: subJob.objectLink?.height ?? subJob.quality,
|
|
76
|
+
width: subJob.objectLink?.width ?? 0
|
|
77
|
+
};
|
|
78
|
+
return assetItem;
|
|
79
|
+
});
|
|
80
|
+
const data = {
|
|
81
|
+
module: renderResponseData.module,
|
|
82
|
+
items: items
|
|
83
|
+
};
|
|
84
|
+
this.renderData$.next(data);
|
|
85
|
+
this.finished.next();
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
// no finished jobs -> show either one progress bar with race leader (progress 0-100)
|
|
89
|
+
// or queue position (progress (-inf,-1])
|
|
90
|
+
let progress = 0;
|
|
91
|
+
if (status.jobs.some(j => j.status === 'PROCESSING')) {
|
|
92
|
+
progress = Math.max(...status.jobs.map(j => j.progress));
|
|
93
|
+
}
|
|
94
|
+
else if (status.jobs.some(j => j.status === 'QUEUED')) {
|
|
95
|
+
progress = -(Math.min(...status.jobs.map(j => j.progress + 1)));
|
|
96
|
+
}
|
|
97
|
+
this.progress$.next({
|
|
98
|
+
module: status.module,
|
|
99
|
+
progress: progress
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
checkIfBackendModule() {
|
|
106
|
+
if (["youtube", "pixabay"].includes((this.node?.remote?.repository?.repositoryType ?? "").toLowerCase())) {
|
|
107
|
+
this.useUrlModule = true;
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
if (this.node?.properties === undefined) {
|
|
111
|
+
return true;
|
|
112
|
+
}
|
|
113
|
+
if (this.node?.properties["ccm:replicationsource"] !== undefined && (this.node.properties["ccm:replicationsource"][0] ?? "") === "oai:dmglib.org") {
|
|
114
|
+
this.useUrlModule = true;
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
if (this.node?.properties["ccm:wwwurl"].length > 0) {
|
|
118
|
+
this.useUrlModule = true;
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
return true;
|
|
122
|
+
}
|
|
123
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderComponent, deps: [{ token: i1.RenderControllerService }, { token: i1.JobInfoControllerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
124
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: RenderComponent, isStandalone: true, selector: "rs-root", inputs: { request: "request", node: "node" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"module\">\n <ng-container *ngIf=\"renderData$ | async as data\">\n @defer (when data?.module === 'IMAGE'){\n <rs-module-image [data]=\"data\" [node]=\"node\"></rs-module-image>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'VIDEO' || data?.module === 'AUDIO'){\n <rs-module-video [data]=\"data\" [node]=\"node\"></rs-module-video>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'PDF' || data?.module === 'DOCUMENT') {\n <rs-module-pdf [data]=\"data\" [node]=\"node\"></rs-module-pdf>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'EDUHTML') {\n <rs-module-eduHtml [data]=\"data\" [node]=\"node\"></rs-module-eduHtml>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'SPREADSHEET') {\n <rs-module-spreadsheet [data]=\"data\" [node]=\"node\"></rs-module-spreadsheet>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n </ng-container>\n <ng-container *ngIf=\"useUrlModule\">\n @defer (when useUrlModule) {\n <rs-module-url [node]=\"node\"></rs-module-url>\n }\n </ng-container>\n <div class=\"progress\" *ngIf=\"(renderData$ | async) === null;\">\n <ng-container *ngIf=\"progress$ | async as progress\">\n <ng-container [ngSwitch]=\"['VIDEO', 'AUDIO'].includes(progress.module) ? 'bar' : 'spinner'\">\n <ng-container *ngSwitchCase=\"'bar'\">\n <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}}</div>\n <mat-progress-bar [value]=\"(progress.progress ?? 0)\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-progress-bar>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spinner'\">\n <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}</div>\n <mat-spinner [diameter]=\"50\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-spinner>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #loading>\n <div class=\"progress\">\n <mat-spinner></mat-spinner>\n </div>\n</ng-template>\n", styles: [":host{display:flex;flex-direction:column;gap:20px;padding:10px 30px}.module{overflow:auto;display:flex;flex-grow:1;height:auto;border:1px solid #aaa;padding:20px}.module rs-module-image,.module rs-module-video{width:100%}.module .progress{display:flex;justify-content:center;flex-grow:1}\n"], dependencies: [{ kind: "ngmodule", type: RenderingApiModule }, { kind: "ngmodule", type: RenderingModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i3.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: MatProgressBarModule }, { kind: "component", type: i4.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }], deferBlockDependencies: [() => [import("./module/image/image.component").then(m => m.ImageComponent)], () => [import("./module/video/video.component").then(m => m.VideoComponent)], () => [import("./module/pdf/pdf.component").then(m => m.PdfComponent)], () => [import("./module/eduhtml/eduHtml.component").then(m => m.EduHtmlComponent)], () => [import("./module/spreadsheet/spreadsheet.component").then(m => m.SpreadsheetComponent)], () => [import("./module/url/url.component").then(m => m.UrlComponent)]] }); }
|
|
125
|
+
}
|
|
126
|
+
i0.ɵɵngDeclareClassMetadataAsync({ minVersion: "18.0.0", version: "18.2.6", ngImport: i0, type: RenderComponent, resolveDeferredDeps: () => [import("./module/image/image.component").then(m => m.ImageComponent), import("./module/video/video.component").then(m => m.VideoComponent), import("./module/pdf/pdf.component").then(m => m.PdfComponent), import("./module/eduhtml/eduHtml.component").then(m => m.EduHtmlComponent), import("./module/spreadsheet/spreadsheet.component").then(m => m.SpreadsheetComponent), import("./module/url/url.component").then(m => m.UrlComponent)], resolveMetadata: (ImageComponent, VideoComponent, PdfComponent, EduHtmlComponent, SpreadsheetComponent, UrlComponent) => ({ decorators: [{
|
|
127
|
+
type: Component,
|
|
128
|
+
args: [{ selector: 'rs-root', standalone: true, imports: [
|
|
129
|
+
RenderingApiModule,
|
|
130
|
+
RenderingModule,
|
|
131
|
+
ImageComponent,
|
|
132
|
+
VideoComponent,
|
|
133
|
+
MatProgressSpinnerModule,
|
|
134
|
+
MatProgressBarModule,
|
|
135
|
+
PdfComponent,
|
|
136
|
+
UrlComponent,
|
|
137
|
+
EduHtmlComponent,
|
|
138
|
+
SpreadsheetComponent,
|
|
139
|
+
], template: "<div class=\"module\">\n <ng-container *ngIf=\"renderData$ | async as data\">\n @defer (when data?.module === 'IMAGE'){\n <rs-module-image [data]=\"data\" [node]=\"node\"></rs-module-image>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'VIDEO' || data?.module === 'AUDIO'){\n <rs-module-video [data]=\"data\" [node]=\"node\"></rs-module-video>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'PDF' || data?.module === 'DOCUMENT') {\n <rs-module-pdf [data]=\"data\" [node]=\"node\"></rs-module-pdf>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'EDUHTML') {\n <rs-module-eduHtml [data]=\"data\" [node]=\"node\"></rs-module-eduHtml>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n @defer (when data?.module === 'SPREADSHEET') {\n <rs-module-spreadsheet [data]=\"data\" [node]=\"node\"></rs-module-spreadsheet>\n } @loading {\n <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n }\n </ng-container>\n <ng-container *ngIf=\"useUrlModule\">\n @defer (when useUrlModule) {\n <rs-module-url [node]=\"node\"></rs-module-url>\n }\n </ng-container>\n <div class=\"progress\" *ngIf=\"(renderData$ | async) === null;\">\n <ng-container *ngIf=\"progress$ | async as progress\">\n <ng-container [ngSwitch]=\"['VIDEO', 'AUDIO'].includes(progress.module) ? 'bar' : 'spinner'\">\n <ng-container *ngSwitchCase=\"'bar'\">\n <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}}</div>\n <mat-progress-bar [value]=\"(progress.progress ?? 0)\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-progress-bar>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spinner'\">\n <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}</div>\n <mat-spinner [diameter]=\"50\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-spinner>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #loading>\n <div class=\"progress\">\n <mat-spinner></mat-spinner>\n </div>\n</ng-template>\n", styles: [":host{display:flex;flex-direction:column;gap:20px;padding:10px 30px}.module{overflow:auto;display:flex;flex-grow:1;height:auto;border:1px solid #aaa;padding:20px}.module rs-module-image,.module rs-module-video{width:100%}.module .progress{display:flex;justify-content:center;flex-grow:1}\n"] }]
|
|
140
|
+
}], ctorParameters: () => [{ type: i1.RenderControllerService }, { type: i1.JobInfoControllerService }], propDecorators: { request: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], node: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}] } }) });
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"render.component.js","sourceRoot":"","sources":["../../../src/lib/render.component.ts","../../../src/lib/render.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnChanges, SimpleChanges} from '@angular/core';\nimport {RenderingModule} from \"./rendering.module\";\nimport {\n  JobInfoControllerService,\n  RenderControllerService,\n  RenderDataRequest\n} from \"ngx-rendering-service-api\";\nimport {BehaviorSubject, firstValueFrom, interval, Subject, switchMap, takeUntil} from \"rxjs\";\nimport {ImageComponent} from \"./module/image/image.component\";\nimport {RenderingApiModule} from \"./rendering-api.module\";\nimport {VideoComponent} from \"./module/video/video.component\";\nimport {MatProgressSpinnerModule} from \"@angular/material/progress-spinner\";\nimport {Node} from \"ngx-edu-sharing-api\";\nimport {MatProgressBarModule} from \"@angular/material/progress-bar\";\nimport {AssetStateData, AssetStateItem} from \"./dto/AssetStateData\";\nimport {PdfComponent} from \"./module/pdf/pdf.component\";\nimport {UrlComponent} from \"./module/url/url.component\";\nimport {EduHtmlComponent} from \"./module/eduhtml/eduHtml.component\";\nimport {SpreadsheetComponent} from \"./module/spreadsheet/spreadsheet.component\";\n\n@Component({\n  selector: 'rs-root',\n  standalone: true,\n  imports: [\n    RenderingApiModule,\n    RenderingModule,\n    ImageComponent,\n    VideoComponent,\n    MatProgressSpinnerModule,\n    MatProgressBarModule,\n    PdfComponent,\n    UrlComponent,\n    EduHtmlComponent,\n    SpreadsheetComponent,\n  ],\n  templateUrl: './render.component.html',\n  styleUrl: './render.component.scss'\n})\nexport class RenderComponent implements OnChanges {\n  // @TODO: Use enum provided by Backend!\n  @Input() request: RenderDataRequest | undefined;\n  @Input() node: Node | undefined;\n  renderData$ = new BehaviorSubject<AssetStateData | null>(null);\n  finished = new Subject<void>();\n  someButNotAllFinished = new Subject<Boolean>()\n  progress$ = new BehaviorSubject<{ module: string, progress?: number } | null>(null);\n  useUrlModule = false\n\n  constructor(\n    private renderControllerService: RenderControllerService,\n    private jobInfoControllerService: JobInfoControllerService,\n  ) {\n  }\n\n  async ngOnChanges(changes: SimpleChanges) {\n    if (this.node === undefined || ! this.checkIfBackendModule()) {\n      return;\n    }\n    const renderResponseData = (await firstValueFrom(this.renderControllerService.getRenderData({\n      body: this.request!!\n    })));\n    // It is possible that there is completed data AND a job id (if there).\n    // We need the data then AND trigger the progress logic to keep loading the unfinished resolutions.\n    if (renderResponseData.jobId === null) {\n      const items = renderResponseData.objectLinks?.map(item => {\n        const assetItem: AssetStateItem = {\n          link: item.link,\n          progress: 100,\n          height: item.height,\n          width: item.width\n        }\n        return assetItem\n      })\n      const data: AssetStateData = {\n        module: renderResponseData.module,\n        items: items\n      }\n      renderResponseData.objectLinks !== undefined && this.renderData$.next(data);\n      this.finished.next();\n    } else {\n      this.progress$.next({module: renderResponseData.module});\n      interval(500).pipe(\n        takeUntil(this.finished),\n        switchMap(() => this.jobInfoControllerService.getJobInfo({jobId: renderResponseData.jobId!!}).pipe()),\n      ).subscribe(async (status) => {\n        // Some, but not all, jobs are finished ->\n        if (status.jobs.some(j => j.status === 'FINISHED') && status.status !== 'FINISHED') {\n          const items = status.jobs.map(subJob => {\n            const assetItem: AssetStateItem = {\n              link: subJob.objectLink?.link ?? \"\",\n              progress: subJob.status !== 'QUEUED' ? subJob.progress : -(subJob.progress +1),\n              height: subJob.objectLink?.height ?? subJob.quality,\n              width: subJob.objectLink?.width ?? 0\n            }\n            return assetItem\n          })\n          const data: AssetStateData = {\n            module: renderResponseData.module,\n            items: items\n          }\n          this.renderData$.next(data)\n          this.someButNotAllFinished.next(true)\n          // all finished and/or failed\n        } else if (status.status === 'FINISHED' || status.status === 'FAILED') {\n          const items = status.jobs.map(subJob => {\n            const assetItem: AssetStateItem = {\n              link: subJob.objectLink?.link ?? \"\",\n              progress: subJob.progress,\n              height: subJob.objectLink?.height ?? subJob.quality,\n              width: subJob.objectLink?.width ?? 0\n            }\n            return assetItem\n          })\n          const data: AssetStateData = {\n            module: renderResponseData.module,\n            items: items\n          }\n          this.renderData$.next(data)\n          this.finished.next()\n        } else {\n          // no finished jobs -> show either one progress bar with race leader (progress 0-100)\n          // or queue position (progress (-inf,-1])\n          let progress = 0\n          if (status.jobs.some(j => j.status === 'PROCESSING')) {\n            progress = Math.max(...status.jobs.map(j => j.progress))\n          } else if (status.jobs.some(j => j.status === 'QUEUED')) {\n            progress = -(Math.min(...status.jobs.map(j => j.progress + 1)))\n          }\n          this.progress$.next({\n            module: status.module,\n            progress: progress\n          });\n        }\n      });\n    }\n  }\n\n  checkIfBackendModule(): boolean {\n    if ([\"youtube\", \"pixabay\"].includes((this.node?.remote?.repository?.repositoryType ?? \"\").toLowerCase())) {\n      this.useUrlModule = true\n      return false\n    }\n    if (this.node?.properties === undefined) {\n      return true;\n    }\n    if (this.node?.properties[\"ccm:replicationsource\"] !== undefined && (this.node.properties[\"ccm:replicationsource\"][0] ?? \"\") === \"oai:dmglib.org\") {\n      this.useUrlModule = true\n      return false\n    }\n    if (this.node?.properties[\"ccm:wwwurl\"].length > 0) {\n      this.useUrlModule = true\n      return false\n    }\n    return true\n  }\n}\n","<div class=\"module\">\n  <ng-container *ngIf=\"renderData$ | async as data\">\n    @defer (when data?.module === 'IMAGE'){\n      <rs-module-image [data]=\"data\" [node]=\"node\"></rs-module-image>\n    } @loading {\n      <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n    }\n    @defer (when data?.module === 'VIDEO' || data?.module === 'AUDIO'){\n      <rs-module-video [data]=\"data\" [node]=\"node\"></rs-module-video>\n    } @loading {\n      <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n    }\n    @defer (when data?.module === 'PDF' || data?.module === 'DOCUMENT') {\n      <rs-module-pdf [data]=\"data\" [node]=\"node\"></rs-module-pdf>\n    } @loading {\n      <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n    }\n    @defer (when data?.module === 'EDUHTML') {\n      <rs-module-eduHtml [data]=\"data\" [node]=\"node\"></rs-module-eduHtml>\n    } @loading {\n      <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n    }\n    @defer (when data?.module === 'SPREADSHEET') {\n      <rs-module-spreadsheet [data]=\"data\" [node]=\"node\"></rs-module-spreadsheet>\n    } @loading {\n      <ng-container *ngTemplateOutlet=\"loading\"></ng-container>\n    }\n  </ng-container>\n  <ng-container *ngIf=\"useUrlModule\">\n  @defer (when useUrlModule) {\n    <rs-module-url [node]=\"node\"></rs-module-url>\n  }\n  </ng-container>\n  <div class=\"progress\" *ngIf=\"(renderData$ | async) === null;\">\n    <ng-container *ngIf=\"progress$ | async as progress\">\n      <ng-container [ngSwitch]=\"['VIDEO', 'AUDIO'].includes(progress.module) ? 'bar' : 'spinner'\">\n        <ng-container *ngSwitchCase=\"'bar'\">\n          <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}}</div>\n          <mat-progress-bar [value]=\"(progress.progress ?? 0)\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-progress-bar>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'spinner'\">\n          <div *ngIf=\"(progress.progress ?? 0) < 0\">Queue position: {{-(progress.progress ?? 0)}</div>\n          <mat-spinner [diameter]=\"50\" *ngIf=\"(progress.progress ?? 0) >= 0\"></mat-spinner>\n        </ng-container>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #loading>\n  <div class=\"progress\">\n    <mat-spinner></mat-spinner>\n  </div>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { RenderingServiceApiModule } from "ngx-rendering-service-api";
|
|
3
|
+
import { environment } from "../environments/environment";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "ngx-rendering-service-api";
|
|
6
|
+
export class RenderingApiModule {
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingApiModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: RenderingApiModule, imports: [i1.RenderingServiceApiModule] }); }
|
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingApiModule, imports: [RenderingServiceApiModule.forRoot({
|
|
10
|
+
rootUrl: environment.rootUrl
|
|
11
|
+
})] }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingApiModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [
|
|
17
|
+
RenderingServiceApiModule.forRoot({
|
|
18
|
+
rootUrl: environment.rootUrl
|
|
19
|
+
})
|
|
20
|
+
]
|
|
21
|
+
}]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyaW5nLWFwaS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3JlbmRlcmluZy1hcGkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDcEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLDZCQUE2QixDQUFDOzs7QUFTeEQsTUFBTSxPQUFPLGtCQUFrQjs4R0FBbEIsa0JBQWtCOytHQUFsQixrQkFBa0I7K0dBQWxCLGtCQUFrQixZQUwzQix5QkFBeUIsQ0FBQyxPQUFPLENBQUM7Z0JBQ2hDLE9BQU8sRUFBRSxXQUFXLENBQUMsT0FBTzthQUM3QixDQUFDOzsyRkFHTyxrQkFBa0I7a0JBUDlCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLHlCQUF5QixDQUFDLE9BQU8sQ0FBQzs0QkFDaEMsT0FBTyxFQUFFLFdBQVcsQ0FBQyxPQUFPO3lCQUM3QixDQUFDO3FCQUNIO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7UmVuZGVyaW5nU2VydmljZUFwaU1vZHVsZX0gZnJvbSBcIm5neC1yZW5kZXJpbmctc2VydmljZS1hcGlcIjtcbmltcG9ydCB7ZW52aXJvbm1lbnR9IGZyb20gXCIuLi9lbnZpcm9ubWVudHMvZW52aXJvbm1lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIFJlbmRlcmluZ1NlcnZpY2VBcGlNb2R1bGUuZm9yUm9vdCh7XG4gICAgICByb290VXJsOiBlbnZpcm9ubWVudC5yb290VXJsXG4gICAgfSlcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBSZW5kZXJpbmdBcGlNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { EduSharingApiModule } from "ngx-edu-sharing-api";
|
|
4
|
+
import { environment } from "../environments/environment";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "ngx-edu-sharing-api";
|
|
7
|
+
export class RenderingModule {
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: RenderingModule, imports: [CommonModule, i1.EduSharingApiModule], exports: [CommonModule] }); }
|
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingModule, imports: [CommonModule,
|
|
11
|
+
EduSharingApiModule.forRoot({ rootUrl: environment.esRootUrl }), CommonModule] }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
imports: [
|
|
17
|
+
CommonModule,
|
|
18
|
+
EduSharingApiModule.forRoot({ rootUrl: environment.esRootUrl })
|
|
19
|
+
],
|
|
20
|
+
exports: [
|
|
21
|
+
CommonModule
|
|
22
|
+
]
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvcmVuZGVyaW5nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN4RCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sNkJBQTZCLENBQUM7OztBQVd4RCxNQUFNLE9BQU8sZUFBZTs4R0FBZixlQUFlOytHQUFmLGVBQWUsWUFQeEIsWUFBWSxxQ0FJWixZQUFZOytHQUdILGVBQWUsWUFQeEIsWUFBWTtZQUNaLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxFQUFDLE9BQU8sRUFBRSxXQUFXLENBQUMsU0FBUyxFQUFDLENBQUMsRUFHN0QsWUFBWTs7MkZBR0gsZUFBZTtrQkFUM0IsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixtQkFBbUIsQ0FBQyxPQUFPLENBQUMsRUFBQyxPQUFPLEVBQUUsV0FBVyxDQUFDLFNBQVMsRUFBQyxDQUFDO3FCQUM5RDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTtxQkFDYjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHtFZHVTaGFyaW5nQXBpTW9kdWxlfSBmcm9tIFwibmd4LWVkdS1zaGFyaW5nLWFwaVwiO1xuaW1wb3J0IHtlbnZpcm9ubWVudH0gZnJvbSBcIi4uL2Vudmlyb25tZW50cy9lbnZpcm9ubWVudFwiO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEVkdVNoYXJpbmdBcGlNb2R1bGUuZm9yUm9vdCh7cm9vdFVybDogZW52aXJvbm1lbnQuZXNSb290VXJsfSlcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFJlbmRlcmluZ01vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LXJlbmRlcmluZy1zZXJ2aWNlLWxpYi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uZ3gtcmVuZGVyaW5nLXNlcnZpY2UtbGliLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { RenderComponent } from "./lib/render.component";
|
|
3
|
+
import { CommonModule } from "@angular/common";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class RenderingServiceLibModule {
|
|
6
|
+
static forRoot() {
|
|
7
|
+
return {
|
|
8
|
+
ngModule: RenderingServiceLibModule,
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingServiceLibModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.6", ngImport: i0, type: RenderingServiceLibModule, imports: [RenderComponent,
|
|
13
|
+
CommonModule], exports: [CommonModule,
|
|
14
|
+
RenderComponent] }); }
|
|
15
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingServiceLibModule, imports: [RenderComponent,
|
|
16
|
+
CommonModule, CommonModule] }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: RenderingServiceLibModule, decorators: [{
|
|
19
|
+
type: NgModule,
|
|
20
|
+
args: [{
|
|
21
|
+
declarations: [],
|
|
22
|
+
imports: [
|
|
23
|
+
RenderComponent,
|
|
24
|
+
CommonModule,
|
|
25
|
+
],
|
|
26
|
+
exports: [
|
|
27
|
+
CommonModule,
|
|
28
|
+
RenderComponent
|
|
29
|
+
],
|
|
30
|
+
}]
|
|
31
|
+
}] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyaW5nLXNlcnZpY2UtbGliLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJpbmctc2VydmljZS1saWIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBc0IsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBYTdDLE1BQU0sT0FBTyx5QkFBeUI7SUFDN0IsTUFBTSxDQUFDLE9BQU87UUFFbkIsT0FBTztZQUNMLFFBQVEsRUFBRSx5QkFBeUI7U0FDcEMsQ0FBQztJQUNKLENBQUM7OEdBTlUseUJBQXlCOytHQUF6Qix5QkFBeUIsWUFSbEMsZUFBZTtZQUNmLFlBQVksYUFHWixZQUFZO1lBQ1osZUFBZTsrR0FHTix5QkFBeUIsWUFSbEMsZUFBZTtZQUNmLFlBQVksRUFHWixZQUFZOzsyRkFJSCx5QkFBeUI7a0JBWHJDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxlQUFlO3dCQUNmLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osZUFBZTtxQkFDaEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge01vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHtSZW5kZXJDb21wb25lbnR9IGZyb20gXCIuL2xpYi9yZW5kZXIuY29tcG9uZW50XCI7XG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBpbXBvcnRzOiBbXG4gICAgUmVuZGVyQ29tcG9uZW50LFxuICAgIENvbW1vbk1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBSZW5kZXJDb21wb25lbnRcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgUmVuZGVyaW5nU2VydmljZUxpYk1vZHVsZSB7XG4gIHB1YmxpYyBzdGF0aWMgZm9yUm9vdChcbiAgKTogTW9kdWxlV2l0aFByb3ZpZGVyczxSZW5kZXJpbmdTZXJ2aWNlTGliTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBSZW5kZXJpbmdTZXJ2aWNlTGliTW9kdWxlLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|