Newer
Older
import {Component, OnInit, Input, ViewChild, EventEmitter, Output, OnDestroy} from '@angular/core';
import { HttpClient, HttpEventType } from '@angular/common/http';
import { LANG } from '../translate.component';
import { NotificationService } from '../../service/notification/notification.service';
import { HeaderService } from '../../service/header.service';
import { AppService } from '../../service/app.service';
import { tap, catchError, filter, map, exhaustMap, take, finalize } from 'rxjs/operators';
import { ConfirmComponent } from '../../plugins/modal/confirm.component';
import { MatDialogRef, MatDialog } from '@angular/material/dialog';
import { AlertComponent } from '../../plugins/modal/alert.component';
import { SortPipe } from '../../plugins/sorting.pipe';
import { PluginSelectSearchComponent } from '../../plugins/select-search/select-search.component';
import { FormControl } from '@angular/forms';
import { EcplOnlyofficeViewerComponent } from '../../plugins/onlyoffice-api-js/onlyoffice-viewer.component';
import { FunctionsService } from '../../service/functions.service';
import { DocumentViewerModalComponent } from './modal/document-viewer-modal.component';
import { PrivilegeService } from '../../service/privileges.service';
import { VisaWorkflowModalComponent } from '../visa/modal/visa-workflow-modal.component';
import { of } from 'rxjs/internal/observable/of';
import { CollaboraOnlineViewerComponent } from '../../plugins/collabora-online/collabora-online-viewer.component';
@Component({
selector: 'app-document-viewer',
templateUrl: 'document-viewer.component.html',
styleUrls: [
'document-viewer.component.scss',
'../indexation/indexing-form/indexing-form.component.scss',
export class DocumentViewerComponent implements OnInit, OnDestroy {
@Input() tmpFilename: string;
@Input() base64: any = null;
@Input() format: string = null;
@Input() mode: 'mainDocument' | 'attachment' = 'mainDocument';
/**
* Resource of document or attachment (based on @mode)
*/
@Input() resId: number = null;
/**
* Resource of document link to attachment (@mode = 'attachment' required!)
*/
@Input() resIdMaster: number = null;
/**
* Can manage document ? (create, delete, update)
*/
@Input() editMode: boolean = false;
/**
* Hide tool document viewer
*/
@Input() hideTools: boolean = false;
/**
* Title of new tab when open document in external tab
*/
@Input() title: string = '';
/**
* To load specific attachment type in template list (to create document)
*/
@Input() attachType: string = null;
@Output() triggerEvent = new EventEmitter<string>();
noConvertedFound: boolean = false;
file: any = {
name: '',
type: '',
contentMode: 'base64',
allowedExtensions: any[] = [];
maxFileSize: number = 0;
maxFileSizeLabel: string = '';
percentInProgress: number = 0;
intervalLockFile: any;
editInProgress: boolean = false;
externalId: any = {};
templateListForm = new FormControl();
percent: 0,
message: '',
};
editor: any = {
async: true,
options: {
docUrl: null,
dataToMerge: null
}
isDocModified: boolean = false;
@ViewChild('templateList', { static: true }) templateList: PluginSelectSearchComponent;
@ViewChild('onlyofficeViewer', { static: false }) onlyofficeViewer: EcplOnlyofficeViewerComponent;
@ViewChild('collaboraOnlineViewer', { static: false }) collaboraOnlineViewer: CollaboraOnlineViewerComponent;
docToUploadValue: any;
constructor(
public http: HttpClient,
private notify: NotificationService,
public appService: AppService,
private sortPipe: SortPipe,
public functions: FunctionsService,
public privilegeService: PrivilegeService,
(<any>window).pdfWorkerSrc = '../node_modules/pdfjs-dist/build/pdf.worker.min.js';
this.http.get('../rest/indexing/fileInformations').pipe(
tap((data: any) => {
this.allowedExtensions = data.informations.allowedFiles.map((ext: any) => {
return {
extension: '.' + ext.extension.toLowerCase(),
mimeType: ext.mimeType,

Alex ORLUC
committed
canConvert: ext.canConvert
});
this.allowedExtensions = this.sortPipe.transform(this.allowedExtensions, 'extension');
this.maxFileSize = data.informations.maximumSize;
this.maxFileSizeLabel = data.informations.maximumSizeLabel;
if (this.resId !== null) {
this.loadRessource(this.resId, this.mode);
if (this.editMode) {
if (this.attachType !== null && this.mode === 'attachment') {
this.loadTemplatesByResId(this.resIdMaster, this.attachType);
} else {
this.loadTemplates();
}
this.loadTemplates();
this.loading = false;
}
}),
catchError((err: any) => {
this.notify.handleErrors(err);
return of(false);
})
).subscribe();
if (!this.functions.empty(this.base64)) {
this.loadFileFromBase64();
} else if (this.tmpFilename !== '' && this.tmpFilename !== undefined) {
this.http.get('../rest/convertedFile/' + this.tmpFilename).pipe(
tap((data: any) => {
this.file = {
name: this.tmpFilename,
type: 'application/pdf',
contentMode: 'base64',
content: this.getBase64Document(this.base64ToArrayBuffer(data.encodedResource)),
src: this.base64ToArrayBuffer(data.encodedResource)
};
this.noConvertedFound = false;
this.loading = false;
}),
catchError((err: any) => {
this.notify.handleErrors(err);
return of(false);
})
).subscribe();
}
ngOnDestroy() {
if (this.intervalLockFile) {
this.cancelTemplateEdition();
}
}
loadFileFromBase64() {
this.loading = true;
this.file = {
name: 'maarch',
format: 'pdf',
type: 'application/pdf',
contentMode: 'base64',
content: this.base64,
src: this.base64ToArrayBuffer(this.base64)
};
this.loading = false;
}
loadTmpFile(filenameOnTmp: string) {
return new Promise((resolve, reject) => {
this.loading = true;
this.loadingInfo.mode = 'determinate';
this.requestWithLoader(`../rest/convertedFile/${filenameOnTmp}?convert=true`).subscribe(
(data: any) => {
if (data.encodedResource) {
this.file = {
name: filenameOnTmp,
format: data.extension,
type: data.type,
contentMode: 'base64',
content: data.encodedResource,
src: data.encodedConvertedResource !== undefined ? this.base64ToArrayBuffer(data.encodedConvertedResource) : null
};
this.editMode = true;
this.triggerEvent.emit();
if (data.encodedConvertedResource !== undefined) {
this.noConvertedFound = false;
} else {
this.noConvertedFound = true;
this.notify.error(data.convertedResourceErrors);
}
this.loading = false;
resolve(true);
},
(err: any) => {
this.noConvertedFound = true;
this.notify.handleErrors(err);
resolve(true);
return of(false);
uploadTrigger(fileInput: any) {
if (fileInput.target.files && fileInput.target.files[0] && this.isExtensionAllowed(fileInput.target.files[0])) {
this.initUpload();

Alex ORLUC
committed
const reader = new FileReader();
this.file.name = fileInput.target.files[0].name;
this.file.type = fileInput.target.files[0].type;
this.file.format = this.file.name.split('.').pop();
reader.readAsArrayBuffer(fileInput.target.files[0]);
reader.onload = (value: any) => {
this.file.content = this.getBase64Document(value.target.result);
this.triggerEvent.emit();
if (this.file.type !== 'application/pdf') {
this.convertDocument(this.file);
} else {
this.file.src = value.target.result;
} else {
this.loading = false;
initUpload() {
this.loading = true;
this.file = {
name: '',
type: '',
contentMode: 'base64',
content: null,
src: null
};
this.noConvertedFound = false;
this.loadingInfo.message = this.lang.loadingFile + '...';
this.loadingInfo.mode = 'indeterminate';
}
getBase64Document(buffer: ArrayBuffer) {
const TYPED_ARRAY = new Uint8Array(buffer);
const STRING_CHAR = TYPED_ARRAY.reduce((data, byte) => {
return data + String.fromCharCode(byte);
}, '');
return btoa(STRING_CHAR);
}
base64ToArrayBuffer(base64: string) {
const binary_string = window.atob(base64);
const len = binary_string.length;
const bytes = new Uint8Array(len);
for (let i = 0; i < len; i++) {
bytes[i] = binary_string.charCodeAt(i);
}
return bytes.buffer;
}
b64toBlob(b64Data: any, contentType = '', sliceSize = 512) {
const byteCharacters = atob(b64Data);
const byteArrays = [];
for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {
const slice = byteCharacters.slice(offset, offset + sliceSize);
const byteNumbers = new Array(slice.length);
for (let i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
const byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
const blob = new Blob(byteArrays, { type: contentType });
return blob;
}
convertDocument(file: any) {
if (this.canBeConverted(file)) {
const data = { name: file.name, base64: file.content };
this.upload(data).subscribe(
this.file.base64src = res.encodedResource;
this.file.src = this.base64ToArrayBuffer(res.encodedResource);
this.loading = false;
}
},
(err: any) => {

Alex ORLUC
committed
this.noConvertedFound = true;
this.notify.handleErrors(err);
this.loading = false;

Alex ORLUC
committed
return of(false);

Alex ORLUC
committed
} else {
this.noConvertedFound = true;
this.loading = false;

Alex ORLUC
committed
}
const uploadURL = `../rest/convertedFile`;
return this.http.post<any>(uploadURL, data, {
reportProgress: true,
observe: 'events'
}).pipe(map((event) => {
switch (event.type) {
case HttpEventType.DownloadProgress:
const downloadProgress = Math.round(100 * event.loaded / event.total);
this.loadingInfo.percent = downloadProgress;
this.loadingInfo.mode = 'determinate';
this.loadingInfo.message = `3/3 ${this.lang.downloadConvertedFile}...`;
return { status: 'progress', message: downloadProgress };
case HttpEventType.UploadProgress:
const progress = Math.round(100 * event.loaded / event.total);
this.loadingInfo.percent = progress;
if (progress === 100) {
this.loadingInfo.mode = 'indeterminate';
this.loadingInfo.message = `2/3 ${this.lang.convertingFile}...`;
} else {
this.loadingInfo.mode = 'determinate';
this.loadingInfo.message = `1/3 ${this.lang.loadingFile}...`;
}
return { status: 'progress', message: progress };
case HttpEventType.Response:
return event.body;
default:
return `Unhandled event: ${event.type}`;
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
}
})
);
}
requestWithLoader(url: string) {
this.loadingInfo.percent = 0;
return this.http.get<any>(url, {
reportProgress: true,
observe: 'events'
}).pipe(map((event) => {
switch (event.type) {
case HttpEventType.DownloadProgress:
const downloadProgress = Math.round(100 * event.loaded / event.total);
this.loadingInfo.percent = downloadProgress;
this.loadingInfo.mode = 'determinate';
this.loadingInfo.message = ``;
return { status: 'progressDownload', message: downloadProgress };
case HttpEventType.Response:
return event.body;
default:
return `Unhandled event: ${event.type}`;
}
})
);
}
onError(error: any) {
console.log(error);
}
cleanFile() {
this.dialogRef = this.dialog.open(ConfirmComponent, { panelClass: 'maarch-modal', autoFocus: false, disableClose: true, data: { title: this.lang.delete, msg: this.lang.confirmAction } });
this.dialogRef.afterClosed().pipe(
filter((data: string) => data === 'ok'),
tap(() => {
this.templateListForm.reset();
this.file = {
name: '',
type: '',
content: null,
src: null
};
this.docToUploadValue = '';
}),
catchError((err: any) => {
this.notify.handleErrors(err);
return of(false);
})
).subscribe();
}
async saveDocService() {
const data: any = await this.getFilePdf();
this.headerService.setLoadedFile(data);
if (this.editor.mode === 'onlyoffice' && this.onlyofficeViewer !== undefined) {
return this.onlyofficeViewer.getFile();
Guillaume Heurtier
committed
} else if (this.editor.mode === 'collaboraOnline' && this.collaboraOnlineViewer !== undefined) {
return this.collaboraOnlineViewer.getFile();
} else {
const objFile = JSON.parse(JSON.stringify(this.file));
objFile.content = objFile.contentMode === 'route' ? null : objFile.content;
getFilePdf() {
return new Promise((resolve, reject) => {
if (!this.functions.empty(this.file.src)) {
resolve(this.getBase64Document(this.file.src));
} else {
this.getFile().pipe(
take(1),
tap((data: any) => {
if (this.editor.mode === 'collaboraOnline' && this.collaboraOnlineViewer !== undefined) {
this.collaboraOnlineViewer.isSaving = false;
}
return data;
}),
exhaustMap((data: any) => this.http.post(`../rest/convertedFile`, { name: `${data.name}.${data.format}`, base64: `${data.content}` })),
tap((data: any) => {
resolve(data.encodedResource);
})
).subscribe();
}
});
}
dndUploadFile(event: any) {
const fileInput = {
target: {
files: [
event[0]
]
}
canBeConverted(file: any): boolean {
const fileExtension = '.' + file.name.toLowerCase().split('.').pop();
if (this.allowedExtensions.filter(ext => ext.canConvert === true && ext.mimeType === file.type && ext.extension === fileExtension).length > 0) {
return true;
} else {
return false;
}
}
isExtensionAllowed(file: any) {
const fileExtension = '.' + file.name.toLowerCase().split('.').pop();
if (this.allowedExtensions.filter(ext => ext.mimeType === file.type && ext.extension === fileExtension).length === 0) {
this.dialog.open(AlertComponent, { panelClass: 'maarch-modal', autoFocus: false, disableClose: true, data: { title: this.lang.notAllowedExtension + ' !', msg: this.lang.file + ' : <b>' + file.name + '</b>, ' + this.lang.type + ' : <b>' + file.type + '</b><br/><br/><u>' + this.lang.allowedExtensions + '</u> : <br/>' + this.allowedExtensions.map(ext => ext.extension).filter((elem: any, index: any, self: any) => index === self.indexOf(elem)).join(', ') } });
} else if (file.size > this.maxFileSize && this.maxFileSize > 0) {
this.dialog.open(AlertComponent, { panelClass: 'maarch-modal', autoFocus: false, disableClose: true, data: { title: this.lang.maxFileSizeReached + ' ! ', msg: this.lang.maxFileSize + ' : ' + this.maxFileSizeLabel } });
return false;
} else {
return true;
}
}
downloadOriginalFile() {
const downloadLink = document.createElement('a');
if (this.file.contentMode === 'base64') {
downloadLink.href = `data:${this.file.type};base64,${this.file.content}`;
downloadLink.setAttribute('download', this.file.name);
document.body.appendChild(downloadLink);
downloadLink.click();
this.http.get(this.file.content).pipe(
tap((data: any) => {
downloadLink.href = `data:${data.mimeType};base64,${data.encodedDocument}`;
downloadLink.setAttribute('download', this.file.name);
document.body.appendChild(downloadLink);
downloadLink.click();
}),
catchError((err: any) => {
this.notify.handleSoftErrors(err);
return of(false);
})
).subscribe();
let src = '';
if (this.file.contentMode === 'base64') {
src = `data:${this.file.type};base64,${this.file.content}`;
const newWindow = window.open();
newWindow.document.write(`<iframe style="width: 100%;height: 100%;margin: 0;padding: 0;" src="${src}" frameborder="0" allowfullscreen></iframe>`);
newWindow.document.title = this.title;
} else {
this.http.get(this.file.contentView).pipe(
tap((data: any) => {
src = `data:${data.mimeType};base64,${data.encodedDocument}`;
const newWindow = window.open();
newWindow.document.write(`<iframe style="width: 100%;height: 100%;margin: 0;padding: 0;" src="${src}" frameborder="0" allowfullscreen></iframe>`);
newWindow.document.title = this.title;
}),
catchError((err: any) => {
this.notify.handleSoftErrors(err);
return of(false);
})
).subscribe();
async loadRessource(resId: any, target: any = 'mainDocument') {
this.resId = resId;
this.mode = target;
this.requestWithLoader(`../rest/attachments/${resId}/content?mode=base64`).subscribe(
(data: any) => {
if (data.encodedDocument) {
this.file.contentMode = 'route';
this.file.name = `${resId}.${data.originalFormat}`;
this.file.format = data.originalFormat;
this.file.creatorId = data.originalCreatorId;
this.file.content = `../rest/attachments/${resId}/originalContent?mode=base64`;
this.file.contentView = `../rest/attachments/${resId}/content?mode=base64`;
this.file.src = this.base64ToArrayBuffer(data.encodedDocument);
this.loading = false;
Guillaume Heurtier
committed
this.noFile = false;
}
},
(err: any) => {
if (err.error.errors === 'Document has no file') {
this.noFile = true;
} else if (err.error.errors === 'Converted Document not found') {
this.file.contentMode = 'route';
this.file.content = `../rest/attachments/${resId}/originalContent?mode=base64`;
this.noConvertedFound = true;
} else {
this.notify.error(err.error.errors);
this.noFile = true;
}
} else {
await this.loadMainDocumentSubInformations();
if (this.file.subinfos.mainDocVersions.length === 0) {
this.noFile = true;
this.loading = false;
} else if (!this.file.subinfos.canConvert) {
this.file.contentMode = 'route';
this.file.content = `../rest/resources/${resId}/originalContent?mode=base64`;
this.noConvertedFound = true;
this.loading = false;
} else {
this.requestWithLoader(`../rest/resources/${resId}/content?mode=base64`).subscribe(
if (data.encodedDocument) {
this.file.contentMode = 'route';
this.file.name = `${resId}.${data.originalFormat}`;
this.file.format = data.originalFormat;
this.file.content = `../rest/resources/${resId}/originalContent?mode=base64`;
this.file.contentView = `../rest/resources/${resId}/content?mode=base64`;
this.file.src = this.base64ToArrayBuffer(data.encodedDocument);
Guillaume Heurtier
committed
this.noFile = false;
}
},
(err: any) => {
this.notify.error(err.error.errors);
this.noFile = true;
this.http.get(`../rest/resources/${this.resId}/fields/externalId`).pipe(
tap((data: any) => {
this.externalId = data.field;
}),
catchError((err: any) => {
this.notify.handleSoftErrors(err);
return of(false);
})
).subscribe();
loadMainDocumentSubInformations() {
return new Promise((resolve, reject) => {
this.http.get(`../rest/resources/${this.resId}/versionsInformations`).pipe(
tap((data: any) => {
const mainDocVersions = data.DOC;
let signedDocVersions = false;
let commentedDocVersions = false;
if (data.DOC[data.DOC.length - 1] !== undefined) {
signedDocVersions = data.SIGN.indexOf(data.DOC[data.DOC.length - 1]) > -1 ? true : false;
commentedDocVersions = data.NOTE.indexOf(data.DOC[data.DOC.length - 1]) > -1 ? true : false;
mainDocPDFVersions = data.PDF.indexOf(data.DOC[data.DOC.length - 1]) > -1 ? true : false;
this.file.subinfos = {
mainDocVersions: mainDocVersions,
signedDocVersions: signedDocVersions,
commentedDocVersions: commentedDocVersions,
mainDocPDFVersions: mainDocPDFVersions
}),
exhaustMap(() => this.http.get(`../rest/resources/${this.resId}/fileInformation`)),
tap((data: any) => {
this.file.subinfos.canConvert = data.information.canConvert;
resolve(true);
}),
catchError((err: any) => {
this.notify.handleSoftErrors(err);
return of(false);
})
).subscribe();
editTemplate(templateId: number) {
if (this.mode === 'attachment') {
confirmMsg = this.lang.editionAttachmentConfirmFirst + '<br><br>' + this.lang.editionAttachmentConfirmThird;
} else {
confirmMsg = this.lang.editionAttachmentConfirmFirst + '<br><br>' + this.lang.editionAttachmentConfirmSecond;
}
this.dialogRef = this.dialog.open(ConfirmComponent, { panelClass: 'maarch-modal', autoFocus: false, disableClose: true, data: { title: this.lang.templateEdition, msg: confirmMsg } });
this.dialogRef.afterClosed().pipe(
tap((data: string) => {
if (data !== 'ok') {
this.templateListForm.reset();
}
}),
filter((data: string) => data === 'ok'),
tap(() => {
this.triggerEvent.emit();
const template = this.listTemplates.filter(templateItem => templateItem.id === templateId)[0];
this.file.format = template.extension;
if (this.editor.mode === 'onlyoffice') {
this.editor.async = false;
this.editor.options = {
objectType: 'attachmentCreation',
objectId: template.id,
docUrl: `rest/onlyOffice/mergedFile`,
dataToMerge: this.resourceDatas
Guillaume Heurtier
committed
} else if (this.editor.mode === 'collaboraOnline') {
this.editor.async = false;
this.editInProgress = true;
this.editor.options = {
objectType: this.mode === 'attachment' ? 'attachmentCreation' : 'resourceCreation',
Guillaume Heurtier
committed
objectId: template.id,
dataToMerge: this.resourceDatas
};
} else {
this.editor.async = true;
this.editor.options = {
objectType: 'attachmentCreation',
objectId: template.id,
cookie: document.cookie,
data: this.resourceDatas,
};
this.editInProgress = true;
this.http.post('../rest/jnlp', this.editor.options).pipe(
window.location.href = '../rest/jnlp/' + data.generatedJnlp;
this.checkLockFile(data.jnlpUniqueId, template.extension);
})
).subscribe();
}
}),
catchError((err: any) => {
this.notify.handleErrors(err);
return of(false);
editResource() {
if (this.mode === 'attachment') {
this.editAttachment();
} else {
this.editMainDocument();
}
}
this.triggerEvent.emit('setData');
if (this.editor.mode === 'onlyoffice') {
this.editor.async = false;
this.editor.options = {
objectType: 'attachmentModification',
objectId: this.resId,
docUrl: `rest/onlyOffice/mergedFile`,
dataToMerge: this.resourceDatas
};
this.editInProgress = true;
Guillaume Heurtier
committed
} else if (this.editor.mode === 'collaboraOnline') {
this.editor.async = false;
this.editInProgress = true;
this.editor.options = {
objectType: 'attachmentModification',
Guillaume Heurtier
committed
objectId: this.resId,
Guillaume Heurtier
committed
dataToMerge: this.resourceDatas
Guillaume Heurtier
committed
};
} else {
this.editor.async = true;
this.editor.options = {
objectType: 'attachmentModification',
objectId: this.resId,
cookie: document.cookie,
data: this.resourceDatas,
};
this.editInProgress = true;
this.http.post('../rest/jnlp', this.editor.options).pipe(
tap((data: any) => {
window.location.href = '../rest/jnlp/' + data.generatedJnlp;
this.checkLockFile(data.jnlpUniqueId, this.file.format);
})
).subscribe();
}
editMainDocument() {
if (this.editor.mode === 'onlyoffice') {
this.editor.async = false;
this.editor.options = {
objectType: 'resourceModification',
docUrl: `rest/onlyOffice/mergedFile`
};
this.editInProgress = true;
} else if (this.editor.mode === 'collaboraOnline') {
this.editor.async = false;
this.editor.options = {
objectType: 'resourceModification',
objectId: this.resId,
Guillaume Heurtier
committed
dataToMerge: this.resourceDatas
};
this.editInProgress = true;
} else {
this.editor.async = true;
this.editor.options = {
objectType: 'resourceModification',
objectId: this.resId,
cookie: document.cookie
};
this.editInProgress = true;
this.http.post('../rest/jnlp', this.editor.options).pipe(
window.location.href = '../rest/jnlp/' + data.generatedJnlp;
this.checkLockFile(data.jnlpUniqueId, this.file.format);
})
).subscribe();
}
}
setDatas(resourceDatas: any) {
this.resourceDatas = resourceDatas;
}
checkLockFile(id: string, extension: string) {
this.intervalLockFile = setInterval(() => {
this.http.get('../rest/jnlp/lock/' + id)
.subscribe(async (data: any) => {
clearInterval(this.intervalLockFile);
await this.loadTmpFile(`${data.fileTrunk}.${extension}`);
if (this.mode === 'mainDocument') {
this.saveMainDocument();
}
cancelTemplateEdition() {
clearInterval(this.intervalLockFile);
this.editInProgress = false;
}
isEditingTemplate() {
if (this.editor.mode === 'onlyoffice') {
return this.onlyofficeViewer !== undefined;
} else if (this.editor.mode === 'collaboraOnline') {
Guillaume Heurtier
committed
return this.collaboraOnlineViewer !== undefined;
} else {
return this.editInProgress;
loadTemplatesByResId(resId: number, attachType: string) {
const arrValues: any[] = [];
let arrTypes: any = [];
this.listTemplates = [];
this.http.get('../rest/attachmentsTypes').pipe(
Object.keys(data.attachmentsTypes).forEach(templateType => {
arrTypes.push({
id: templateType,
label: data.attachmentsTypes[templateType].label
});
});
arrTypes = this.sortPipe.transform(arrTypes, 'label');
arrTypes.push({
id: 'all',
label: this.lang.others
});
exhaustMap(() => this.http.get(`../rest/resources/${resId}/templates?attachmentType=${attachType},all`)),
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
tap((data: any) => {
this.listTemplates = data.templates;
arrTypes = arrTypes.filter((type: any) => data.templates.map((template: any) => template.attachmentType).indexOf(type.id) > -1);
arrTypes.forEach((arrType: any) => {
arrValues.push({
id: arrType.id,
label: arrType.label,
title: arrType.label,
disabled: true,
isTitle: true,
color: '#135f7f'
});
data.templates.filter((template: any) => template.attachmentType === arrType.id).forEach((template: any) => {
arrValues.push({
id: template.id,
label: ' ' + template.label,
title: template.exists ? template.label : this.lang.fileDoesNotExists,
extension: template.extension,
disabled: !template.exists,
});
});
});
this.listTemplates = arrValues;
})
).subscribe();
}
loadTemplates() {
if (this.listTemplates.length === 0) {
const arrValues: any[] = [];
if (this.mode === 'mainDocument') {
this.http.get('../rest/currentUser/templates?target=indexingFile').pipe(
tap((data: any) => {
this.listTemplates = data.templates;
arrValues.push({
id: 'all',
label: this.lang.indexation,
title: this.lang.indexation,
disabled: true,
isTitle: true,
color: '#135f7f'
});
data.templates.forEach((template: any) => {
arrValues.push({
id: template.id,
label: ' ' + template.label,
title: template.exists ? template.label : this.lang.fileDoesNotExists,
extension: template.extension,
disabled: !template.exists,
});
});
this.listTemplates = arrValues;
})
).subscribe();
} else {
let arrTypes: any = [];
this.http.get('../rest/attachmentsTypes').pipe(
tap((data: any) => {
arrTypes.push({
id: 'all',
label: this.lang.others
});
Object.keys(data.attachmentsTypes).forEach(templateType => {
arrTypes.push({
id: templateType,
label: data.attachmentsTypes[templateType].label
});
arrTypes = this.sortPipe.transform(arrTypes, 'label');
});
}),
exhaustMap(() => {
return this.http.get('../rest/currentUser/templates?target=attachments&type=office');
}),
tap((data: any) => {
this.listTemplates = data.templates;
arrTypes = arrTypes.filter((type: any) => data.templates.map((template: any) => template.attachmentType).indexOf(type.id) > -1);
arrTypes.forEach((arrType: any) => {
arrValues.push({