Newer
Older
import { Component, OnInit, ViewChild, ElementRef, Input, Inject } from '@angular/core';
import { SignaturesContentService } from '../service/signatures.service';
import * as PDFJS from 'pdfjs-dist/build/pdf.js';
import { DomSanitizer } from '@angular/platform-browser';
import * as $ from 'jquery';
import { SignaturePad } from 'angular2-signaturepad/signature-pad';
import {
MatDialogRef,
MatDialog,
MAT_DIALOG_DATA,
MatBottomSheet,
MatBottomSheetRef,
MatBottomSheetConfig,
} from '@angular/material';
import { SignaturesComponent } from '../signatures/signatures.component';
import { ActivatedRoute, Router } from '@angular/router';
selector: 'app-document',
templateUrl: 'document.component.html',
styleUrls: ['document.component.styl'],
export class DocumentComponent implements OnInit {
pdf: any;
pageNum = 1;
signaturesContent: any = [];
pageRendering = false;
pageNumPending: null;
scale = 1;
totalPages: number;
draggable: boolean;
loadingDoc = true;
signaturePadPosY = 50;
annotationPadOptions = {
throttle: 0,
minWidth: 0.8,
maxWidth: 1,
backgroundColor: 'rgba(255, 255, 255, 0)',
penColors = [{ id: 'black' }, { id: '#1a75ff' }, { id: '#FF0000' }];
@Input() mainDocument: any = {};
@ViewChild('pdfpage') elPdfContainer: ElementRef;
@ViewChild('canvas') canvas: ElementRef;
@ViewChild('canvasWrapper') canvasWrapper: ElementRef;
@ViewChild(SignaturePad) signaturePad: SignaturePad;
public context: CanvasRenderingContext2D;
constructor(private router: Router, private route: ActivatedRoute, public http: HttpClient,
public snackBar: MatSnackBar, public signaturesService: SignaturesContentService,
private sanitization: DomSanitizer, public dialog: MatDialog, private bottomSheet: MatBottomSheet) {
this.draggable = false;
PDFJS.GlobalWorkerOptions.workerSrc = './node_modules/pdfjs-dist/build/pdf.worker.js';
// TO DO REMOVE DEFINE EXEMPLE
ngOnInit(): void {
this.route.params.subscribe(params => {
if (typeof params['id'] !== 'undefined') {
this.renderingDoc = true;
this.loadingDoc = true;
this.http.get('../rest/documents/' + params['id'])
.subscribe((data: any) => {
this.docList = [];
this.signaturesService.signaturesContent = [];
this.signaturesService.mainDocumentId = this.mainDocument.id;
if (this.signaturesService.signaturesList.length === 0) {
this.http.get('../rest/users/' + '1' + '/signatures')
.subscribe((dataSign: any) => {
this.signaturesService.signaturesList = dataSign.signatures;
this.signaturesService.loadingSign = false;
});
}
this.docList.push({ 'id': this.mainDocument.id, 'encodedDocument': this.mainDocument.encodedDocument, 'subject': this.mainDocument.subject });
this.mainDocument.attachments.forEach((attach: any, index: any) => {
this.docList.push({ 'id': attach.id, 'encodedDocument': '', 'title': '' });
this.pdfRender(this.docList[this.currentDoc]);
this.context = (<HTMLCanvasElement>this.canvas.nativeElement).getContext('2d');
setTimeout(() => {
this.renderingDoc = false;
}, 500);
}, (err: any) => {
if (err.status === 401) {
this.router.navigate(['/login']);
this.snackBar.open(err.error.errors, null,
{
duration: 3000,
panelClass: 'center-snackbar',
verticalPosition: 'top'
}
);
}
this.snav.open();
this.freezeSidenavClose = true;
const pdfData = atob(document.encodedDocument);
PDFJS.getDocument({ data: pdfData }).then((_pdfDoc: any) => {
this.pdf = _pdfDoc;
this.totalPages = this.pdf.pdfInfo.numPages;
this.signaturesService.totalPage = this.totalPages;
this.renderPage(this.pageNum, this.canvas.nativeElement, 1);
});
renderPage(pageNumber: any, canvas: any, scale: number) {
this.pdf.getPage(pageNumber).then((page: any) => {
const viewport = page.getViewport(scale);
const ctx = this.context;
canvas.height = viewport.height;
canvas.width = viewport.width;
const renderContext = {
canvasContext: ctx,
viewport: viewport
};
this.canvas.nativeElement.style.width = 768 * scale + 'px';
const renderTask = page.render(renderContext);
renderTask.then(() => {
this.signaturesService.signWidth = viewport.width / 5;
});
});
this.pageNum--;
if (this.pageNum === 0) {
this.pageNum = 1;
} else {
this.renderPage(this.pageNum, this.canvas, 1);
setTimeout(() => {
this.renderingDoc = false;
}, 500);
}
if (this.currentDoc === 0) {
this.signaturesService.currentPage = this.pageNum;
}
if (this.pageNum >= this.totalPages) {
this.pageNum = this.totalPages;
} else {
this.pageNum++;
this.renderPage(this.pageNum, this.canvas, 1);
setTimeout(() => {
this.renderingDoc = false;
}, 500);
}
// only for main document
if (this.currentDoc === 0) {
this.signaturesService.currentPage = this.pageNum;
}
this.signaturesService.isTaggable = false;
this.pageNum = 1;
this.currentDoc++;
setTimeout(() => {
this.renderingDoc = false;
}, 500);
this.pageNum = 1;
this.currentDoc--;
if (this.currentDoc === 0) {
this.signaturesService.currentPage = 1;
this.signaturesService.isTaggable = true;
}
this.pdfRender(this.docList[this.currentDoc]);
setTimeout(() => {
this.renderingDoc = false;
}, 500);
addAnnotation(e: any) {
if (!this.signaturesService.lockNote && this.currentDoc === 0) {
this.annotationPadOptions.canvasWidth = 768 * this.scale;
this.annotationPadOptions.canvasHeight = $('.pdf-page-canvas').height();
// this.renderPage(this.pageNum, this.canvas.nativeElement, this.scale);
this.signaturePadPosX = 0;
this.signaturePadPosY = 0;
this.signaturesService.lockNote = true;
}
}
this.signaturesService.signaturesContent[this.signaturesService.currentPage][i].positionX = event.x;
this.signaturesService.signaturesContent[this.signaturesService.currentPage][i].positionY = event.y;
}
this.signaturesService.notesContent[this.signaturesService.currentPage][i].positionX = event.x;
this.signaturesService.notesContent[this.signaturesService.currentPage][i].positionY = event.y;
}
movePad(event: any) {
this.signaturePadPosX = event.x;
this.signaturePadPosY = event.y;
$('.page-viewer, .canvas-wrapper, .mat-sidenav-content').css({ 'overflow': 'auto' });
}
deleteSignature(index: number) {
this.signaturesService.signaturesContent[this.signaturesService.currentPage].splice(index, 1);
}
deleteNote(index: number) {
this.signaturesService.notesContent[this.signaturesService.currentPage].splice(index, 1);
validateAnnotation() {
if (!this.signaturesService.notesContent[this.signaturesService.currentPage]) {
this.signaturesService.notesContent[this.signaturesService.currentPage] = [];
this.signaturesService.notesContent[this.signaturesService.currentPage].push(
{
'fullPath': this.signaturePad.toDataURL('image/npg'),
'positionX': this.signaturePadPosX,
'positionY': this.signaturePadPosY,
'height': this.annotationPadOptions.canvasHeight,
'width': this.annotationPadOptions.canvasWidth,
}
);
this.signaturePad.clear();
this.scale = 1;
this.signaturesService.annotationMode = false;
this.signaturesService.lockNote = false;
this.renderPage(this.pageNum, this.canvas.nativeElement, this.scale);
this.snackBar.open('Annotation ajoutée', null,
{
duration: 3000,
panelClass: 'center-snackbar',
verticalPosition: 'top'
}
);
}
cancelAnnotation() {
this.signaturePad.clear();
this.signaturesService.annotationMode = false;
this.signaturesService.lockNote = false;
// this.renderPage(this.pageNum, this.canvas.nativeElement, this.scale);
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
}
freezDoc() {
$('.page-viewer, .canvas-wrapper, .mat-sidenav-content').css({ 'overflow': 'hidden' });
}
onColorChange(entry: any) {
this.signaturePad.set('penColor', entry.id);
}
onDotChange(entry: any) {
this.signaturePad.set('minWidth', parseFloat(entry));
this.signaturePad.set('maxWidth', parseFloat(entry) + 2);
}
openDialog(): void {
const dialogRef = this.dialog.open(WarnModalComponent, {
width: '350px',
data: {}
});
dialogRef.afterClosed().subscribe(result => {
if (result === 'sucess') {
const config: MatBottomSheetConfig = {
disableClose: true,
direction: 'ltr'
};
this.bottomSheet.open(RejectInfoBottomSheetComponent, config);
} else if (result === 'annotation') {
this.signaturesService.annotationMode = true;
this.signaturesService.lockNote = true;
}
});
}
const dialogRef = this.dialog.open(ConfirmModalComponent, {
width: '350px',
});
dialogRef.afterClosed().subscribe(result => {
if (result) {
const config: MatBottomSheetConfig = {
disableClose: true,
direction: 'ltr'
};
this.bottomSheet.open(SuccessInfoValidBottomSheetComponent, config);
}
});
}
openDrawer(): void {
if (this.currentDoc > 0) {
this.currentDoc = 0;
this.pageNum = 1;
this.pdfRender(this.docList[this.currentDoc]);
}
this.signaturesService.showSign = true;
const config: MatBottomSheetConfig = {
disableClose: false,
direction: 'ltr'
};
this.bottomSheet.open(SignaturesComponent, config);
}
removeTags() {
const dialogRef = this.dialog.open(ConfirmModalComponent, {
width: '350px',
data: { msg: 'Effacer toutes les annotations et signatures ?' }
});
dialogRef.afterClosed().subscribe(result => {
console.log('The dialog was closed');
if (result) {
this.signaturesService.signaturesContent = [];
this.signaturesService.notesContent = [];
this.snackBar.open('Annotations / signatures supprimées du document', null,
{
duration: 3000,
panelClass: 'center-snackbar',
verticalPosition: 'top'
}
);
}
});
}
if (this.docList[this.currentDoc + 1] && this.docList[this.currentDoc + 1].id && this.docList[this.currentDoc + 1].encodedDocument === '') {
this.http.get('../rest/attachments/' + this.docList[this.currentDoc + 1].id)
.subscribe((dataPj: any) => {
this.docList[this.currentDoc + 1] = dataPj.attachment;
}, () => {
console.log('error !');
});
}
}
launchEvent(action: any) {
this.signaturesService.currentAction = action.id;
this[action.event]();
}
test() {
if (this.lockSignaturePad) {
this.lockSignaturePad = false;
this.signaturePad.on();
} else {
this.lockSignaturePad = true;
this.signaturePad.off();
}
zoomPlus() {
this.lockSignaturePad = true;
this.scale = 2;
this.renderPage(this.pageNum, this.canvas.nativeElement, this.scale);
this.signaturePad.set('canvasWidth', 768 * this.scale);
this.signaturePad.set('canvasHeight', this.annotationPadOptions.canvasHeight * this.scale);
this.scale = 1;
this.renderPage(this.pageNum, this.canvas.nativeElement, this.scale);
this.signaturePad.set('canvasWidth', 768 * this.scale);
this.signaturePad.set('canvasHeight', this.annotationPadOptions.canvasHeight * this.scale);
}
@Component({
templateUrl: '../modal/warn-modal.component.html',
styleUrls: ['../modal/warn-modal.component.styl']
})
export class WarnModalComponent {
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
constructor(@Inject(MAT_DIALOG_DATA) public data: any, public http: HttpClient, public dialogRef: MatDialogRef<WarnModalComponent>, public signaturesService: SignaturesContentService) { }
confirmDoc () {
const signatures: any[] = [];
console.log(this.signaturesService.currentAction);
if (this.signaturesService.currentAction > 0) {
for (let index = 1; index <= this.signaturesService.totalPage; index++) {
if (this.signaturesService.signaturesContent[index]) {
this.signaturesService.signaturesContent[index].forEach((signature: any) => {
signatures.push(
{
'fullPath': signature.encodedSignature,
'height': 'auto',
'width': this.signaturesService.signWidth,
'positionX': 1,
'positionY': 1,
'page': index,
}
);
});
}
if (this.signaturesService.notesContent[index]) {
this.signaturesService.notesContent[index].forEach((note: any) => {
signatures.push(
{
'fullPath': note.fullPath,
'height': note.height,
'width': note.width,
'positionX': note.positionX,
'positionY': note.positionY,
'page': index,
}
);
});
}
this.http.put('../rest/documents/' + this.signaturesService.mainDocumentId + '/action', {'action_id': this.signaturesService.currentAction, 'signatures': signatures})
.subscribe(() => {
this.signaturesService.documentsList.splice(this.signaturesService.indexDocumentsList, 1);
this.signaturesService.documentsListCount--;
this.dialogRef.close('sucess');
}, (err: any) => {
console.log(err);
});
}
} else {
this.dialogRef.close('sucess');
}
}
}
@Component({
templateUrl: '../modal/confirm-modal.component.html',
styleUrls: ['../modal/confirm-modal.component.styl']
})
export class ConfirmModalComponent {
constructor(@Inject(MAT_DIALOG_DATA) public data: any, public http: HttpClient, public dialogRef: MatDialogRef<ConfirmModalComponent>, public signaturesService: SignaturesContentService) { }
confirmDoc () {
const signatures: any[] = [];
console.log(this.signaturesService.currentAction);
if (this.signaturesService.currentAction > 0) {
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
for (let index = 1; index <= this.signaturesService.totalPage; index++) {
if (this.signaturesService.signaturesContent[index]) {
this.signaturesService.signaturesContent[index].forEach((signature: any) => {
signatures.push(
{
'fullPath': signature.encodedSignature,
'height': 'auto',
'width': this.signaturesService.signWidth,
'positionX': 1,
'positionY': 1,
'page': index,
}
);
});
}
if (this.signaturesService.notesContent[index]) {
this.signaturesService.notesContent[index].forEach((note: any) => {
signatures.push(
{
'fullPath': note.fullPath,
'height': note.height,
'width': note.width,
'positionX': note.positionX,
'positionY': note.positionY,
'page': index,
}
);
});
}
this.http.put('../rest/documents/' + this.signaturesService.mainDocumentId + '/action', {'action_id': this.signaturesService.currentAction, 'signatures': signatures})
.subscribe(() => {
this.dialogRef.close('sucess');
this.signaturesService.documentsList.splice(this.signaturesService.indexDocumentsList, 1);
this.signaturesService.documentsListCount--;
}, (err: any) => {
console.log(err);
});
}
} else {
this.dialogRef.close('sucess');
}
}
}
@Component({
templateUrl: '../modal/success-info-valid.html',
styleUrls: ['../modal/success-info-valid.styl']
})
export class SuccessInfoValidBottomSheetComponent implements OnInit {
constructor(private router: Router, public signaturesService: SignaturesContentService, private bottomSheetRef: MatBottomSheetRef<SuccessInfoValidBottomSheetComponent>) { }
ngOnInit(): void {
setTimeout(() => {
if (this.signaturesService.documentsList[this.signaturesService.indexDocumentsList]) {
this.router.navigate(['/document/' + this.signaturesService.documentsList[this.signaturesService.indexDocumentsList].id]);
}
this.bottomSheetRef.dismiss();
}, 2000);
}
}
@Component({
templateUrl: '../modal/reject-info.html',
styleUrls: ['../modal/reject-info.styl']
})
export class RejectInfoBottomSheetComponent implements OnInit {
date: Date = new Date();
constructor(private router: Router, public signaturesService: SignaturesContentService, private bottomSheetRef: MatBottomSheetRef<RejectInfoBottomSheetComponent>) { }
ngOnInit(): void {
setTimeout(() => {
if (this.signaturesService.documentsList[this.signaturesService.indexDocumentsList]) {
this.router.navigate(['/document/' + this.signaturesService.documentsList[this.signaturesService.indexDocumentsList].id]);
}
this.bottomSheetRef.dismiss();
}, 2000);
}