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.
Files changed (32) hide show
  1. package/environments/environment.d.ts +5 -0
  2. package/esm2022/environments/environment.mjs +6 -0
  3. package/esm2022/index.mjs +13 -0
  4. package/esm2022/lib/dto/AssetStateData.mjs +2 -0
  5. package/esm2022/lib/module/RenderModule.mjs +2 -0
  6. package/esm2022/lib/module/eduhtml/eduHtml.component.mjs +34 -0
  7. package/esm2022/lib/module/image/image.component.mjs +51 -0
  8. package/esm2022/lib/module/pdf/pdf.component.mjs +81 -0
  9. package/esm2022/lib/module/spreadsheet/spreadsheet.component.mjs +47 -0
  10. package/esm2022/lib/module/url/url.component.mjs +118 -0
  11. package/esm2022/lib/module/video/video.component.mjs +61 -0
  12. package/esm2022/lib/render.component.mjs +145 -0
  13. package/esm2022/lib/rendering-api.module.mjs +23 -0
  14. package/esm2022/lib/rendering.module.mjs +25 -0
  15. package/esm2022/ngx-rendering-service-lib.mjs +5 -0
  16. package/esm2022/rendering-service-lib.module.mjs +32 -0
  17. package/fesm2022/ngx-rendering-service-lib.mjs +613 -0
  18. package/fesm2022/ngx-rendering-service-lib.mjs.map +1 -0
  19. package/index.d.ts +9 -0
  20. package/lib/dto/AssetStateData.d.ts +10 -0
  21. package/lib/module/RenderModule.d.ts +6 -0
  22. package/lib/module/eduhtml/eduHtml.component.d.ts +14 -0
  23. package/lib/module/image/image.component.d.ts +17 -0
  24. package/lib/module/pdf/pdf.component.d.ts +21 -0
  25. package/lib/module/spreadsheet/spreadsheet.component.d.ts +17 -0
  26. package/lib/module/url/url.component.d.ts +29 -0
  27. package/lib/module/video/video.component.d.ts +15 -0
  28. package/lib/render.component.d.ts +25 -0
  29. package/lib/rendering-api.module.d.ts +7 -0
  30. package/lib/rendering.module.d.ts +8 -0
  31. package/package.json +39 -0
  32. 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==