mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* remove deprecated code part 1 * remove deprecation step 2 * fix spellcheck * fix * fix lint * fix not used import * remove deprecation * fix test first part after remove deprecation * fix test * fix sidebar demo shell
126 lines
4.7 KiB
TypeScript
126 lines
4.7 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2016 Alfresco Software, Ltd.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { Injectable } from '@angular/core';
|
|
import { RenditionEntry, RenditionPaging } from '@alfresco/js-api';
|
|
import { Observable, from, interval, empty } from 'rxjs';
|
|
import { AlfrescoApiService } from './alfresco-api.service';
|
|
import { concatMap, switchMap, takeWhile, map } from 'rxjs/operators';
|
|
|
|
@Injectable({
|
|
providedIn: 'root'
|
|
})
|
|
export class RenditionsService {
|
|
|
|
constructor(private apiService: AlfrescoApiService) {
|
|
}
|
|
|
|
getAvailableRenditionForNode(nodeId: string): Observable<RenditionEntry> {
|
|
return from(this.apiService.renditionsApi.getRenditions(nodeId)).pipe(
|
|
map((availableRenditions: RenditionPaging) => {
|
|
let renditionsAvailable: RenditionEntry[] = availableRenditions.list.entries.filter(
|
|
(rendition) => (rendition.entry.id === 'pdf' || rendition.entry.id === 'imgpreview'));
|
|
let existingRendition = renditionsAvailable.find((rend) => rend.entry.status === 'CREATED');
|
|
return existingRendition ? existingRendition : renditionsAvailable[0];
|
|
}));
|
|
}
|
|
|
|
generateRenditionForNode(nodeId: string): Observable<any> {
|
|
return this.getAvailableRenditionForNode(nodeId).pipe(
|
|
map((rendition: RenditionEntry) => {
|
|
if (rendition.entry.status !== 'CREATED') {
|
|
return from(this.apiService.renditionsApi.createRendition(nodeId, { id: rendition.entry.id }));
|
|
} else {
|
|
return empty();
|
|
}
|
|
})
|
|
);
|
|
}
|
|
|
|
isRenditionAvailable(nodeId: string, encoding: string): Observable<boolean> {
|
|
return new Observable((observer) => {
|
|
this.getRendition(nodeId, encoding).subscribe(
|
|
(res) => {
|
|
let isAvailable = true;
|
|
if (res.entry.status.toString() === 'NOT_CREATED') {
|
|
isAvailable = false;
|
|
}
|
|
observer.next(isAvailable);
|
|
observer.complete();
|
|
},
|
|
() => {
|
|
observer.next(false);
|
|
observer.complete();
|
|
}
|
|
);
|
|
});
|
|
}
|
|
|
|
isConversionPossible(nodeId: string, encoding: string): Observable<boolean> {
|
|
return new Observable((observer) => {
|
|
this.getRendition(nodeId, encoding).subscribe(
|
|
() => {
|
|
observer.next(true);
|
|
observer.complete();
|
|
},
|
|
() => {
|
|
observer.next(false);
|
|
observer.complete();
|
|
}
|
|
);
|
|
});
|
|
}
|
|
|
|
getRenditionUrl(nodeId: string, encoding: string): string {
|
|
return this.apiService.contentApi.getRenditionUrl(nodeId, encoding);
|
|
}
|
|
|
|
getRendition(nodeId: string, encoding: string): Observable<RenditionEntry> {
|
|
return from(this.apiService.renditionsApi.getRendition(nodeId, encoding));
|
|
}
|
|
|
|
getRenditionsListByNodeId(nodeId: string): Observable<RenditionPaging> {
|
|
return from(this.apiService.renditionsApi.getRenditions(nodeId));
|
|
}
|
|
|
|
createRendition(nodeId: string, encoding: string): Observable<{}> {
|
|
return from(this.apiService.renditionsApi.createRendition(nodeId, { id: encoding }));
|
|
}
|
|
|
|
convert(nodeId: string, encoding: string, pollingInterval: number = 1000, retries: number = 5) {
|
|
return this.createRendition(nodeId, encoding)
|
|
.pipe(
|
|
concatMap(() => this.pollRendition(nodeId, encoding, pollingInterval, retries))
|
|
);
|
|
}
|
|
|
|
private pollRendition(nodeId: string, encoding: string, intervalSize: number = 1000, retries: number = 5) {
|
|
let attempts = 0;
|
|
return interval(intervalSize)
|
|
.pipe(
|
|
switchMap(() => this.getRendition(nodeId, encoding)),
|
|
takeWhile((renditionEntry: RenditionEntry) => {
|
|
attempts += 1;
|
|
if (attempts > retries) {
|
|
return false;
|
|
}
|
|
return (renditionEntry.entry.status.toString() !== 'CREATED');
|
|
})
|
|
);
|
|
}
|
|
}
|