@colijnit/sharedcomponents 259.1.5 → 259.1.6
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/267.48755ac117fce8407070.js +1 -0
- package/358.645812766f7a400d0d38.js +1 -0
- package/3rdpartylicenses.txt +2222 -0
- package/977.bd6291f9ee6f6ddf91f1.js +1 -0
- package/bundles/colijnit-sharedcomponents.umd.js +77 -46
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/lib/components/custom-pdf/custom-pdf-dialog.component.js +55 -47
- package/esm2015/lib/components/custom-pdf/custom-pdf-dialog.module.js +3 -2
- package/favicon.ico +0 -0
- package/fesm2015/colijnit-sharedcomponents.js +56 -47
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/index.html +12 -0
- package/lib/components/custom-pdf/custom-pdf-dialog.component.d.ts +1 -0
- package/lib/components/custom-pdf/style/_layout.scss +12 -0
- package/main.26d227fd7f8d16716472.js +1 -0
- package/package.json +1 -1
- package/polyfills.907fe9d1887c5de17993.js +1 -0
- package/runtime.8e71661a9a96996bf63e.js +1 -0
- package/styles.3abd564826d6b43944b7.css +1 -0
|
@@ -18,6 +18,7 @@ export class CustomPdfDialogComponent {
|
|
|
18
18
|
this.additionalFileChangeEvent = new EventEmitter();
|
|
19
19
|
this.signaturePads = {};
|
|
20
20
|
this.signatureCanvases = {};
|
|
21
|
+
this.showLoader = false;
|
|
21
22
|
}
|
|
22
23
|
showClass() {
|
|
23
24
|
return true;
|
|
@@ -100,6 +101,7 @@ export class CustomPdfDialogComponent {
|
|
|
100
101
|
}
|
|
101
102
|
handleSaveClicked() {
|
|
102
103
|
return __awaiter(this, void 0, void 0, function* () {
|
|
104
|
+
this.showLoader = true;
|
|
103
105
|
const clearButton = document.getElementById('clearButton');
|
|
104
106
|
clearButton.hidden = true;
|
|
105
107
|
const doc = new jsPDF();
|
|
@@ -108,38 +110,39 @@ export class CustomPdfDialogComponent {
|
|
|
108
110
|
const sectionsCount = documentSection.length;
|
|
109
111
|
for (let i = 0; i < sectionsCount; i++) {
|
|
110
112
|
const html = documentSection[i];
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
113
|
+
try {
|
|
114
|
+
const dataUrl = yield toJpeg(html, {
|
|
115
|
+
quality: 1,
|
|
116
|
+
backgroundColor: 'white'
|
|
117
|
+
});
|
|
115
118
|
const img = new Image();
|
|
116
119
|
img.src = dataUrl;
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
fileAsCoDocument.reports = 1;
|
|
131
|
-
this.additionalFileChangeEvent.emit(fileAsCoDocument);
|
|
132
|
-
this.closePDFDialog.emit();
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
doc.addPage();
|
|
137
|
-
}
|
|
138
|
-
};
|
|
139
|
-
}).catch((error) => {
|
|
120
|
+
yield new Promise((resolve) => {
|
|
121
|
+
img.onload = () => {
|
|
122
|
+
const imgWidth = 218;
|
|
123
|
+
const imgHeight = (img.height * imgWidth) / img.width;
|
|
124
|
+
doc.addImage(dataUrl, 'JPG', -4, 0, imgWidth, imgHeight);
|
|
125
|
+
if (i < sectionsCount - 1) {
|
|
126
|
+
doc.addPage();
|
|
127
|
+
}
|
|
128
|
+
resolve();
|
|
129
|
+
};
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
catch (error) {
|
|
140
133
|
console.error('Error generating image:', error);
|
|
141
|
-
}
|
|
134
|
+
}
|
|
142
135
|
}
|
|
136
|
+
const tempFile = doc.output('datauristring');
|
|
137
|
+
const file = this.dataURItoBlob(tempFile);
|
|
138
|
+
const fileAsCoDocument = yield FileUtils.ReadFileAsNewCoDocument(file);
|
|
139
|
+
fileAsCoDocument.fileType = FileUtils.IsImageFile(file) ? FileType.Image : FileType.Document;
|
|
140
|
+
fileAsCoDocument.creationDate = new Date();
|
|
141
|
+
fileAsCoDocument.modifiedDate = new Date();
|
|
142
|
+
fileAsCoDocument.reports = 1;
|
|
143
|
+
this.additionalFileChangeEvent.emit(fileAsCoDocument);
|
|
144
|
+
this.showLoader = false;
|
|
145
|
+
this.closePDFDialog.emit();
|
|
143
146
|
clearButton.hidden = false;
|
|
144
147
|
});
|
|
145
148
|
}
|
|
@@ -170,24 +173,29 @@ CustomPdfDialogComponent.decorators = [
|
|
|
170
173
|
{ type: Component, args: [{
|
|
171
174
|
selector: 'co-custom-pdf-dialog',
|
|
172
175
|
template: `
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
176
|
+
<co-dialog
|
|
177
|
+
[footerTemplate]="footerTemplate"
|
|
178
|
+
id="custom-pdf-dialog"
|
|
179
|
+
(closeClick)="closePDFDialog.emit()">
|
|
180
|
+
<!-- create a nice container for loader so it is not random in the corner somewhere -->
|
|
181
|
+
<div *ngIf="showLoader" class="loader-container">
|
|
182
|
+
<co-loader *ngIf="showLoader"></co-loader>
|
|
183
|
+
</div>
|
|
184
|
+
|
|
185
|
+
<div #pdfBody id="pdfBody">
|
|
186
|
+
<section [innerHTML]="fileBody"></section>
|
|
187
|
+
</div>
|
|
188
|
+
<ng-template #footerTemplate>
|
|
189
|
+
<div class="co-dialog-footer-button-wrapper">
|
|
190
|
+
<co-button class="save-button"
|
|
191
|
+
[iconData]="iconCacheService.getIcon(icons.CheckDuotone)"
|
|
192
|
+
(click)="handleSaveClicked()"></co-button>
|
|
193
|
+
<co-button class="close-button"
|
|
194
|
+
[iconData]="iconCacheService.getIcon(icons.CrossSkinny)"
|
|
195
|
+
(click)="closePDFDialog.emit()"></co-button>
|
|
196
|
+
</div>
|
|
197
|
+
</ng-template>
|
|
198
|
+
</co-dialog>
|
|
191
199
|
`,
|
|
192
200
|
encapsulation: ViewEncapsulation.None
|
|
193
201
|
},] }
|
|
@@ -204,4 +212,4 @@ CustomPdfDialogComponent.propDecorators = {
|
|
|
204
212
|
closePDFDialog: [{ type: Output }],
|
|
205
213
|
additionalFileChangeEvent: [{ type: Output }]
|
|
206
214
|
};
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-pdf-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/custom-pdf/custom-pdf-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {jsPDF} from 'jspdf';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {DomSanitizer} from '@angular/platform-browser';\r\nimport SignaturePad from 'signature_pad';\r\nimport {toJpeg} from 'html-to-image';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\nimport {FileUtils} from '@colijnit/mainapi/build/utils/file-utils';\r\n\r\nimport {FileType} from '@colijnit/mainapi/build/enum/file-type.enum';\r\nimport {Icon} from '../../enum/icon.enum';\r\n\r\n@Component({\r\n  selector: 'co-custom-pdf-dialog',\r\n  template: `\r\n      <co-dialog\r\n              [footerTemplate]=\"footerTemplate\"\r\n              id=\"custom-pdf-dialog\"\r\n              (closeClick)=\"closePDFDialog.emit()\">\r\n          <div #pdfBody id=\"pdfBody\">\r\n              <section [innerHTML]=\"fileBody\"></section>\r\n          </div>\r\n          <ng-template #footerTemplate>\r\n              <div class=\"co-dialog-footer-button-wrapper\">\r\n                  <co-button class=\"save-button\"\r\n                             [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"\r\n                             (click)=\"handleSaveClicked()\"></co-button>\r\n                  <co-button class=\"close-button\"\r\n                             [iconData]=\"iconCacheService.getIcon(icons.CrossSkinny)\"\r\n                             (click)=\"closePDFDialog.emit()\"></co-button>\r\n              </div>\r\n          </ng-template>\r\n      </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CustomPdfDialogComponent implements OnInit, AfterViewInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding('class.co-custom-pdf-dialog')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @ViewChild('pdfBody')\r\n  public pdfBody: ElementRef;\r\n\r\n  @Input()\r\n  public additionalFileContents: any;\r\n\r\n  @Input()\r\n  public additionalFileName: string = '';\r\n\r\n  @Output()\r\n  public closePDFDialog: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public additionalFileChangeEvent: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n  public canvas: HTMLCanvasElement;\r\n  public context: CanvasRenderingContext2D;\r\n  public signaturePads: { [key: string]: SignaturePad } = {};\r\n  public signatureCanvases: { [key: string]: ElementRef } = {};\r\n  public fileBody: any;\r\n  public fileStyle: string;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _sanitizer: DomSanitizer\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.additionalFileContents) {\r\n      const head: HTMLHeadElement = document.getElementsByTagName('head')[0];\r\n      const styles: string[] = this.extractStyleParts(this.additionalFileContents);\r\n      this.fileStyle = styles[0];\r\n      const style: HTMLStyleElement = document.createElement('style');\r\n      style.appendChild(document.createTextNode(this.fileStyle));\r\n      head.appendChild(style);\r\n      const body: string[] = this.extractBodyContents(this.additionalFileContents);\r\n      this.fileBody = this._sanitizer.bypassSecurityTrustHtml(body[0]);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    ['signatureCanvas', 'signatureCanvas2'].forEach(id => {\r\n      const canvasElement = document.getElementById(id);\r\n      if (canvasElement) {\r\n        const canvasRef = new ElementRef(canvasElement);\r\n        const signaturePad = new SignaturePad(<HTMLCanvasElement>canvasRef.nativeElement);\r\n        this.signatureCanvases[id] = canvasRef;\r\n        this.signaturePads[id] = signaturePad;\r\n\r\n        setTimeout(() => {\r\n          this._resizeSignatureCanvas(signaturePad, canvasRef);\r\n        });\r\n      }\r\n    });\r\n    const clearButton = document.getElementById('clearButton');\r\n    clearButton?.addEventListener('click', () => this.handleClear());\r\n\r\n    // Due to a bug or known issue with html-to-image we need a bit of JS the fill in the checked value when selecting a checkbox.\r\n    // Handling the checkboxes and radiobuttons\r\n    const container: HTMLElement = this.pdfBody.nativeElement as HTMLElement;\r\n    container.addEventListener('change', (event: Event) => {\r\n      const target = event.target as HTMLElement;\r\n      if (target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'checkbox') {\r\n        const checkbox: HTMLInputElement = target as HTMLInputElement;\r\n        if (checkbox.checked) {\r\n          checkbox.setAttribute('checked', 'true');\r\n        } else {\r\n          checkbox.removeAttribute('checked');\r\n        }\r\n      } else if (target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'radio') {\r\n        const radio: HTMLInputElement = target as HTMLInputElement;\r\n        const groupName: string = radio.name;\r\n        const radios: NodeListOf<Element> = container.querySelectorAll(`input[type=\"radio\"][name=\"${groupName}\"]`);\r\n        radios.forEach((radio) => radio.removeAttribute('checked'));\r\n        if (radio.checked) {\r\n          radio.setAttribute('checked', 'true');\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public extractStyleParts(html: string): string[] {\r\n    const stylePattern: RegExp = /<style[^>]*>([\\s\\S]*?)<\\/style>/gi;\r\n    const matches: string[] = [];\r\n    let match: RegExpExecArray | null;\r\n    while ((match = stylePattern.exec(html)) !== null) {\r\n      matches.push(match[1].trim());\r\n    }\r\n    return matches;\r\n  }\r\n\r\n  public removeStyleAndScriptTags(html: string): string {\r\n    const styleTagPattern: RegExp = /<style[^>]*>[\\s\\S]*?<\\/style>/gi;\r\n    const scriptTagPattern: RegExp = /<script[^>]*>[\\s\\S]*?<\\/script>/gi;\r\n    return html.replace(styleTagPattern, '').replace(scriptTagPattern, '');\r\n  }\r\n\r\n  public extractBodyContents(html: string): string [] {\r\n    html = this.removeStyleAndScriptTags(html);\r\n    const stylePattern: RegExp = /<body[^>]*>([\\s\\S]*?)<\\/body>/gi;\r\n    const matches: string[] = [];\r\n    let match: RegExpExecArray | null;\r\n    while ((match = stylePattern.exec(html)) !== null) {\r\n      matches.push(match[1].trim());\r\n    }\r\n    return matches;\r\n  }\r\n\r\n  public async handleSaveClicked(): Promise<void> {\r\n    const clearButton: HTMLElement = document.getElementById('clearButton');\r\n    clearButton.hidden = true;\r\n    const doc: jsPDF = new jsPDF();\r\n    const htmlDocument: HTMLElement = document.querySelector(\"#pdfBody\");\r\n    const documentSection: HTMLCollectionOf<HTMLElement> = htmlDocument.getElementsByTagName('section');\r\n    const sectionsCount: number = documentSection.length;\r\n\r\n    for (let i: number = 0; i < sectionsCount; i++) {\r\n      const html: HTMLElement = documentSection[i];\r\n      toJpeg(html, {\r\n        quality: 1,\r\n        backgroundColor: 'white'\r\n      }).then((dataUrl: string) => {\r\n        const img: HTMLImageElement = new Image();\r\n        img.src = dataUrl;\r\n        img.onload = () => {\r\n          const imgWidth: number = 218;\r\n          const imgHeight: number = (img.height * imgWidth) / img.width;\r\n          doc.addImage(dataUrl, 'JPG', -4, 0, imgWidth, imgHeight);\r\n          if (i === sectionsCount - 1) {\r\n            // doc.save(this.additionalFileName + '.pdf');\r\n            const tempFile: string = doc.output('datauristring');\r\n            const file: File = this.dataURItoBlob(tempFile);\r\n            FileUtils.ReadFileAsNewCoDocument(file).then(fileAsCoDocument => {\r\n              // set some extra known fields for the codocument:\r\n              fileAsCoDocument.fileType = FileUtils.IsImageFile(file) ? FileType.Image : FileType.Document;\r\n              fileAsCoDocument.creationDate = new Date();\r\n              fileAsCoDocument.modifiedDate = new Date();\r\n              fileAsCoDocument.reports = 1;\r\n              this.additionalFileChangeEvent.emit(fileAsCoDocument);\r\n              this.closePDFDialog.emit();\r\n            });\r\n          } else {\r\n            doc.addPage();\r\n          }\r\n        };\r\n      }).catch((error) => {\r\n        console.error('Error generating image:', error);\r\n      });\r\n    }\r\n    clearButton.hidden = false;\r\n  }\r\n\r\n  public dataURItoBlob(dataURI): File {\r\n    const byteString: string = atob(dataURI.split(',')[1]);\r\n    const ab: ArrayBuffer = new ArrayBuffer(byteString.length);\r\n    const ia: Uint8Array = new Uint8Array(ab);\r\n    for (let i: number = 0; i < byteString.length; i++) {\r\n      ia[i] = byteString.charCodeAt(i);\r\n    }\r\n    return new File([ab], this.additionalFileName + '.pdf');\r\n  }\r\n\r\n  public handleClear(): void {\r\n    Object.values(this.signaturePads).forEach(signaturePad => {\r\n      signaturePad?.clear();\r\n    });\r\n  }\r\n\r\n  private _resizeSignatureCanvas(signature: SignaturePad, signatureCanvas: ElementRef): void {\r\n    const imageBeforeResize: string = signature.toDataURL();\r\n    const ratio: number = Math.max(window.devicePixelRatio || 1, 1);\r\n    signatureCanvas.nativeElement.width = signatureCanvas.nativeElement.offsetWidth * ratio;\r\n    signatureCanvas.nativeElement.height = signatureCanvas.nativeElement.offsetHeight * ratio;\r\n    signatureCanvas.nativeElement.getContext(\"2d\").scale(ratio, ratio);\r\n    signature.fromDataURL(imageBeforeResize);\r\n  }\r\n\r\n}\r\n"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-pdf-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/custom-pdf/custom-pdf-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, ElementRef, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {jsPDF} from 'jspdf';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {DomSanitizer} from '@angular/platform-browser';\r\nimport SignaturePad from 'signature_pad';\r\nimport {toJpeg} from 'html-to-image';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document.bo';\r\nimport {FileUtils} from '@colijnit/mainapi/build/utils/file-utils';\r\n\r\nimport {FileType} from '@colijnit/mainapi/build/enum/file-type.enum';\r\nimport {Icon} from '../../enum/icon.enum';\r\n\r\n@Component({\r\n  selector: 'co-custom-pdf-dialog',\r\n  template: `\r\n    <co-dialog\r\n      [footerTemplate]=\"footerTemplate\"\r\n      id=\"custom-pdf-dialog\"\r\n      (closeClick)=\"closePDFDialog.emit()\">\r\n      <!-- create a nice container for loader so it is not random in the corner somewhere -->\r\n      <div *ngIf=\"showLoader\" class=\"loader-container\">\r\n        <co-loader *ngIf=\"showLoader\"></co-loader>\r\n      </div>\r\n      \r\n      <div #pdfBody id=\"pdfBody\">\r\n        <section [innerHTML]=\"fileBody\"></section>\r\n      </div>\r\n      <ng-template #footerTemplate>\r\n        <div class=\"co-dialog-footer-button-wrapper\">\r\n          <co-button class=\"save-button\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"\r\n                     (click)=\"handleSaveClicked()\"></co-button>\r\n          <co-button class=\"close-button\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.CrossSkinny)\"\r\n                     (click)=\"closePDFDialog.emit()\"></co-button>\r\n        </div>\r\n      </ng-template>\r\n    </co-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class CustomPdfDialogComponent implements OnInit, AfterViewInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @HostBinding('class.co-custom-pdf-dialog')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @ViewChild('pdfBody')\r\n  public pdfBody: ElementRef;\r\n\r\n  @Input()\r\n  public additionalFileContents: any;\r\n\r\n  @Input()\r\n  public additionalFileName: string = '';\r\n\r\n  @Output()\r\n  public closePDFDialog: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  public additionalFileChangeEvent: EventEmitter<CoDocument> = new EventEmitter<CoDocument>();\r\n\r\n  public canvas: HTMLCanvasElement;\r\n  public context: CanvasRenderingContext2D;\r\n  public signaturePads: { [key: string]: SignaturePad } = {};\r\n  public signatureCanvases: { [key: string]: ElementRef } = {};\r\n  public fileBody: any;\r\n  public fileStyle: string;\r\n\r\n  public showLoader: boolean = false;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _sanitizer: DomSanitizer\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.additionalFileContents) {\r\n      const head: HTMLHeadElement = document.getElementsByTagName('head')[0];\r\n      const styles: string[] = this.extractStyleParts(this.additionalFileContents);\r\n      this.fileStyle = styles[0];\r\n      const style: HTMLStyleElement = document.createElement('style');\r\n      style.appendChild(document.createTextNode(this.fileStyle));\r\n      head.appendChild(style);\r\n      const body: string[] = this.extractBodyContents(this.additionalFileContents);\r\n      this.fileBody = this._sanitizer.bypassSecurityTrustHtml(body[0]);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    ['signatureCanvas', 'signatureCanvas2'].forEach(id => {\r\n      const canvasElement = document.getElementById(id);\r\n      if (canvasElement) {\r\n        const canvasRef = new ElementRef(canvasElement);\r\n        const signaturePad = new SignaturePad(<HTMLCanvasElement>canvasRef.nativeElement);\r\n        this.signatureCanvases[id] = canvasRef;\r\n        this.signaturePads[id] = signaturePad;\r\n\r\n        setTimeout(() => {\r\n          this._resizeSignatureCanvas(signaturePad, canvasRef);\r\n        });\r\n      }\r\n    });\r\n    const clearButton = document.getElementById('clearButton');\r\n    clearButton?.addEventListener('click', () => this.handleClear());\r\n\r\n    // Due to a bug or known issue with html-to-image we need a bit of JS the fill in the checked value when selecting a checkbox.\r\n    // Handling the checkboxes and radiobuttons\r\n    const container: HTMLElement = this.pdfBody.nativeElement as HTMLElement;\r\n    container.addEventListener('change', (event: Event) => {\r\n      const target = event.target as HTMLElement;\r\n      if (target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'checkbox') {\r\n        const checkbox: HTMLInputElement = target as HTMLInputElement;\r\n        if (checkbox.checked) {\r\n          checkbox.setAttribute('checked', 'true');\r\n        } else {\r\n          checkbox.removeAttribute('checked');\r\n        }\r\n      } else if (target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'radio') {\r\n        const radio: HTMLInputElement = target as HTMLInputElement;\r\n        const groupName: string = radio.name;\r\n        const radios: NodeListOf<Element> = container.querySelectorAll(`input[type=\"radio\"][name=\"${groupName}\"]`);\r\n        radios.forEach((radio) => radio.removeAttribute('checked'));\r\n        if (radio.checked) {\r\n          radio.setAttribute('checked', 'true');\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  public extractStyleParts(html: string): string[] {\r\n    const stylePattern: RegExp = /<style[^>]*>([\\s\\S]*?)<\\/style>/gi;\r\n    const matches: string[] = [];\r\n    let match: RegExpExecArray | null;\r\n    while ((match = stylePattern.exec(html)) !== null) {\r\n      matches.push(match[1].trim());\r\n    }\r\n    return matches;\r\n  }\r\n\r\n  public removeStyleAndScriptTags(html: string): string {\r\n    const styleTagPattern: RegExp = /<style[^>]*>[\\s\\S]*?<\\/style>/gi;\r\n    const scriptTagPattern: RegExp = /<script[^>]*>[\\s\\S]*?<\\/script>/gi;\r\n    return html.replace(styleTagPattern, '').replace(scriptTagPattern, '');\r\n  }\r\n\r\n  public extractBodyContents(html: string): string [] {\r\n    html = this.removeStyleAndScriptTags(html);\r\n    const stylePattern: RegExp = /<body[^>]*>([\\s\\S]*?)<\\/body>/gi;\r\n    const matches: string[] = [];\r\n    let match: RegExpExecArray | null;\r\n    while ((match = stylePattern.exec(html)) !== null) {\r\n      matches.push(match[1].trim());\r\n    }\r\n    return matches;\r\n  }\r\n\r\n  public async handleSaveClicked(): Promise<void> {\r\n    this.showLoader = true;\r\n    const clearButton: HTMLElement = document.getElementById('clearButton');\r\n    clearButton.hidden = true;\r\n    const doc: jsPDF = new jsPDF();\r\n    const htmlDocument: HTMLElement = document.querySelector(\"#pdfBody\");\r\n    const documentSection: HTMLCollectionOf<HTMLElement> = htmlDocument.getElementsByTagName('section');\r\n    const sectionsCount: number = documentSection.length;\r\n\r\n    for (let i: number = 0; i < sectionsCount; i++) {\r\n      const html: HTMLElement = documentSection[i];\r\n      try {\r\n        const dataUrl: string = await toJpeg(html, {\r\n          quality: 1,\r\n          backgroundColor: 'white'\r\n        });\r\n        const img: HTMLImageElement = new Image();\r\n        img.src = dataUrl;\r\n        await new Promise<void>((resolve) => {\r\n          img.onload = () => {\r\n            const imgWidth: number = 218;\r\n            const imgHeight: number = (img.height * imgWidth) / img.width;\r\n            doc.addImage(dataUrl, 'JPG', -4, 0, imgWidth, imgHeight);\r\n            if (i < sectionsCount - 1) {\r\n              doc.addPage();\r\n            }\r\n            resolve();\r\n          };\r\n        });\r\n      } catch (error) {\r\n        console.error('Error generating image:', error);\r\n      }\r\n    }\r\n    const tempFile: string = doc.output('datauristring');\r\n    const file: File = this.dataURItoBlob(tempFile);\r\n    const fileAsCoDocument = await FileUtils.ReadFileAsNewCoDocument(file);\r\n    fileAsCoDocument.fileType = FileUtils.IsImageFile(file) ? FileType.Image : FileType.Document;\r\n    fileAsCoDocument.creationDate = new Date();\r\n    fileAsCoDocument.modifiedDate = new Date();\r\n    fileAsCoDocument.reports = 1;\r\n    this.additionalFileChangeEvent.emit(fileAsCoDocument);\r\n    this.showLoader = false;\r\n    this.closePDFDialog.emit();\r\n    clearButton.hidden = false;\r\n  }\r\n\r\n  public dataURItoBlob(dataURI): File {\r\n    const byteString: string = atob(dataURI.split(',')[1]);\r\n    const ab: ArrayBuffer = new ArrayBuffer(byteString.length);\r\n    const ia: Uint8Array = new Uint8Array(ab);\r\n    for (let i: number = 0; i < byteString.length; i++) {\r\n      ia[i] = byteString.charCodeAt(i);\r\n    }\r\n    return new File([ab], this.additionalFileName + '.pdf');\r\n  }\r\n\r\n  public handleClear(): void {\r\n    Object.values(this.signaturePads).forEach(signaturePad => {\r\n      signaturePad?.clear();\r\n    });\r\n  }\r\n\r\n  private _resizeSignatureCanvas(signature: SignaturePad, signatureCanvas: ElementRef): void {\r\n    const imageBeforeResize: string = signature.toDataURL();\r\n    const ratio: number = Math.max(window.devicePixelRatio || 1, 1);\r\n    signatureCanvas.nativeElement.width = signatureCanvas.nativeElement.offsetWidth * ratio;\r\n    signatureCanvas.nativeElement.height = signatureCanvas.nativeElement.offsetHeight * ratio;\r\n    signatureCanvas.nativeElement.getContext(\"2d\").scale(ratio, ratio);\r\n    signature.fromDataURL(imageBeforeResize);\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { NgModule } from "@angular/core";
|
|
2
|
-
import { ButtonModule, CoDialogModule, IconModule } from
|
|
2
|
+
import { ButtonModule, CoDialogModule, IconModule, LoaderModule } from '@colijnit/corecomponents_v12';
|
|
3
3
|
import { CustomPdfDialogComponent } from "./custom-pdf-dialog.component";
|
|
4
4
|
import { CommonModule } from "@angular/common";
|
|
5
5
|
import { SharedComponentsTranslationModule } from "../../translation/shared-components-translation.module";
|
|
@@ -13,6 +13,7 @@ CustomPdfDialogModule.decorators = [
|
|
|
13
13
|
CommonModule,
|
|
14
14
|
ButtonModule,
|
|
15
15
|
SharedComponentsTranslationModule,
|
|
16
|
+
LoaderModule
|
|
16
17
|
],
|
|
17
18
|
declarations: [
|
|
18
19
|
CustomPdfDialogComponent
|
|
@@ -23,4 +24,4 @@ CustomPdfDialogModule.decorators = [
|
|
|
23
24
|
providers: []
|
|
24
25
|
},] }
|
|
25
26
|
];
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXBkZi1kaWFsb2cubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2hhcmVkY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLXBkZi9jdXN0b20tcGRmLWRpYWxvZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDcEcsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDdkUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLHdEQUF3RCxDQUFDO0FBcUJ6RyxNQUFNLE9BQU8scUJBQXFCOzs7WUFsQmpDLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsVUFBVTtvQkFDVixjQUFjO29CQUNkLFlBQVk7b0JBQ1osWUFBWTtvQkFDWixpQ0FBaUM7b0JBQ2pDLFlBQVk7aUJBQ2I7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLHdCQUF3QjtpQkFDekI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHdCQUF3QjtpQkFDekI7Z0JBQ0QsU0FBUyxFQUFFLEVBQ1Y7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7QnV0dG9uTW9kdWxlLCBDb0RpYWxvZ01vZHVsZSwgSWNvbk1vZHVsZSwgTG9hZGVyTW9kdWxlfSBmcm9tICdAY29saWpuaXQvY29yZWNvbXBvbmVudHNfdjEyJztcclxuaW1wb3J0IHtDdXN0b21QZGZEaWFsb2dDb21wb25lbnR9IGZyb20gXCIuL2N1c3RvbS1wZGYtZGlhbG9nLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge1NoYXJlZENvbXBvbmVudHNUcmFuc2xhdGlvbk1vZHVsZX0gZnJvbSBcIi4uLy4uL3RyYW5zbGF0aW9uL3NoYXJlZC1jb21wb25lbnRzLXRyYW5zbGF0aW9uLm1vZHVsZVwiO1xyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgSWNvbk1vZHVsZSxcclxuICAgIENvRGlhbG9nTW9kdWxlLFxyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgQnV0dG9uTW9kdWxlLFxyXG4gICAgU2hhcmVkQ29tcG9uZW50c1RyYW5zbGF0aW9uTW9kdWxlLFxyXG4gICAgTG9hZGVyTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEN1c3RvbVBkZkRpYWxvZ0NvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgQ3VzdG9tUGRmRGlhbG9nQ29tcG9uZW50XHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdXN0b21QZGZEaWFsb2dNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
package/favicon.ico
ADDED
|
Binary file
|
|
@@ -46,7 +46,7 @@ import { ArticleExtendedRequest } from '@colijnit/articleapi/build/model/article
|
|
|
46
46
|
import * as i1 from '@angular/platform-browser';
|
|
47
47
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
48
48
|
import { ArticleStockManagement } from '@colijnit/articleapi/build/model/article-stock-management';
|
|
49
|
-
import { BaseModuleScreenConfigService, IconModule, ListOfValuesModule, InputCheckboxModule, CoDialogModule, ButtonModule, ScreenConfigurationModule, OverlayService, ClickoutsideModule, OverlayModule, CoreDialogService, InputRadioButtonModule, SimpleGridModule, ImageModule, InputTextModule, InputNumberPickerModule, CoDialogWizardModule, InputTextareaModule, PopupModule, InputDatePickerModule, ResponsiveTextModule, InputSearchModule, PromptService, FormComponent, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, CoOrientation, CoreComponentsTranslationModule, TemplateWrapperModule, FormModule, FormMasterService, IconCacheService as IconCacheService$1, InputDateRangePickerModule, CollapsibleModule, ColorSequenceService, ListOfIconsModule } from '@colijnit/corecomponents_v12';
|
|
49
|
+
import { BaseModuleScreenConfigService, IconModule, ListOfValuesModule, InputCheckboxModule, CoDialogModule, ButtonModule, LoaderModule, ScreenConfigurationModule, OverlayService, ClickoutsideModule, OverlayModule, CoreDialogService, InputRadioButtonModule, SimpleGridModule, ImageModule, InputTextModule, InputNumberPickerModule, CoDialogWizardModule, InputTextareaModule, PopupModule, InputDatePickerModule, ResponsiveTextModule, InputSearchModule, PromptService, FormComponent, SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, CoOrientation, CoreComponentsTranslationModule, TemplateWrapperModule, FormModule, FormMasterService, IconCacheService as IconCacheService$1, InputDateRangePickerModule, CollapsibleModule, ColorSequenceService, ListOfIconsModule } from '@colijnit/corecomponents_v12';
|
|
50
50
|
import { ArticleTransaction as ArticleTransaction$1 } from '@colijnit/articleapi/build/model/article-transaction';
|
|
51
51
|
import { PrintPriceStickers } from '@colijnit/sharedapi/build/model/print-price-stickers.bo';
|
|
52
52
|
import { ReportingDocumentEmailSignDocBaseRequest } from '@colijnit/mainapi/build/model/reporting-document-email-sign-doc-base-request';
|
|
@@ -3449,6 +3449,7 @@ class CustomPdfDialogComponent {
|
|
|
3449
3449
|
this.additionalFileChangeEvent = new EventEmitter();
|
|
3450
3450
|
this.signaturePads = {};
|
|
3451
3451
|
this.signatureCanvases = {};
|
|
3452
|
+
this.showLoader = false;
|
|
3452
3453
|
}
|
|
3453
3454
|
showClass() {
|
|
3454
3455
|
return true;
|
|
@@ -3531,6 +3532,7 @@ class CustomPdfDialogComponent {
|
|
|
3531
3532
|
}
|
|
3532
3533
|
handleSaveClicked() {
|
|
3533
3534
|
return __awaiter(this, void 0, void 0, function* () {
|
|
3535
|
+
this.showLoader = true;
|
|
3534
3536
|
const clearButton = document.getElementById('clearButton');
|
|
3535
3537
|
clearButton.hidden = true;
|
|
3536
3538
|
const doc = new jsPDF();
|
|
@@ -3539,38 +3541,39 @@ class CustomPdfDialogComponent {
|
|
|
3539
3541
|
const sectionsCount = documentSection.length;
|
|
3540
3542
|
for (let i = 0; i < sectionsCount; i++) {
|
|
3541
3543
|
const html = documentSection[i];
|
|
3542
|
-
|
|
3543
|
-
|
|
3544
|
-
|
|
3545
|
-
|
|
3544
|
+
try {
|
|
3545
|
+
const dataUrl = yield toJpeg(html, {
|
|
3546
|
+
quality: 1,
|
|
3547
|
+
backgroundColor: 'white'
|
|
3548
|
+
});
|
|
3546
3549
|
const img = new Image();
|
|
3547
3550
|
img.src = dataUrl;
|
|
3548
|
-
|
|
3549
|
-
|
|
3550
|
-
|
|
3551
|
-
|
|
3552
|
-
|
|
3553
|
-
|
|
3554
|
-
|
|
3555
|
-
|
|
3556
|
-
|
|
3557
|
-
|
|
3558
|
-
|
|
3559
|
-
|
|
3560
|
-
|
|
3561
|
-
fileAsCoDocument.reports = 1;
|
|
3562
|
-
this.additionalFileChangeEvent.emit(fileAsCoDocument);
|
|
3563
|
-
this.closePDFDialog.emit();
|
|
3564
|
-
});
|
|
3565
|
-
}
|
|
3566
|
-
else {
|
|
3567
|
-
doc.addPage();
|
|
3568
|
-
}
|
|
3569
|
-
};
|
|
3570
|
-
}).catch((error) => {
|
|
3551
|
+
yield new Promise((resolve) => {
|
|
3552
|
+
img.onload = () => {
|
|
3553
|
+
const imgWidth = 218;
|
|
3554
|
+
const imgHeight = (img.height * imgWidth) / img.width;
|
|
3555
|
+
doc.addImage(dataUrl, 'JPG', -4, 0, imgWidth, imgHeight);
|
|
3556
|
+
if (i < sectionsCount - 1) {
|
|
3557
|
+
doc.addPage();
|
|
3558
|
+
}
|
|
3559
|
+
resolve();
|
|
3560
|
+
};
|
|
3561
|
+
});
|
|
3562
|
+
}
|
|
3563
|
+
catch (error) {
|
|
3571
3564
|
console.error('Error generating image:', error);
|
|
3572
|
-
}
|
|
3565
|
+
}
|
|
3573
3566
|
}
|
|
3567
|
+
const tempFile = doc.output('datauristring');
|
|
3568
|
+
const file = this.dataURItoBlob(tempFile);
|
|
3569
|
+
const fileAsCoDocument = yield FileUtils.ReadFileAsNewCoDocument(file);
|
|
3570
|
+
fileAsCoDocument.fileType = FileUtils.IsImageFile(file) ? FileType$1.Image : FileType$1.Document;
|
|
3571
|
+
fileAsCoDocument.creationDate = new Date();
|
|
3572
|
+
fileAsCoDocument.modifiedDate = new Date();
|
|
3573
|
+
fileAsCoDocument.reports = 1;
|
|
3574
|
+
this.additionalFileChangeEvent.emit(fileAsCoDocument);
|
|
3575
|
+
this.showLoader = false;
|
|
3576
|
+
this.closePDFDialog.emit();
|
|
3574
3577
|
clearButton.hidden = false;
|
|
3575
3578
|
});
|
|
3576
3579
|
}
|
|
@@ -3601,24 +3604,29 @@ CustomPdfDialogComponent.decorators = [
|
|
|
3601
3604
|
{ type: Component, args: [{
|
|
3602
3605
|
selector: 'co-custom-pdf-dialog',
|
|
3603
3606
|
template: `
|
|
3604
|
-
|
|
3605
|
-
|
|
3606
|
-
|
|
3607
|
-
|
|
3608
|
-
|
|
3609
|
-
|
|
3610
|
-
|
|
3611
|
-
|
|
3612
|
-
|
|
3613
|
-
|
|
3614
|
-
|
|
3615
|
-
|
|
3616
|
-
|
|
3617
|
-
|
|
3618
|
-
|
|
3619
|
-
|
|
3620
|
-
|
|
3621
|
-
|
|
3607
|
+
<co-dialog
|
|
3608
|
+
[footerTemplate]="footerTemplate"
|
|
3609
|
+
id="custom-pdf-dialog"
|
|
3610
|
+
(closeClick)="closePDFDialog.emit()">
|
|
3611
|
+
<!-- create a nice container for loader so it is not random in the corner somewhere -->
|
|
3612
|
+
<div *ngIf="showLoader" class="loader-container">
|
|
3613
|
+
<co-loader *ngIf="showLoader"></co-loader>
|
|
3614
|
+
</div>
|
|
3615
|
+
|
|
3616
|
+
<div #pdfBody id="pdfBody">
|
|
3617
|
+
<section [innerHTML]="fileBody"></section>
|
|
3618
|
+
</div>
|
|
3619
|
+
<ng-template #footerTemplate>
|
|
3620
|
+
<div class="co-dialog-footer-button-wrapper">
|
|
3621
|
+
<co-button class="save-button"
|
|
3622
|
+
[iconData]="iconCacheService.getIcon(icons.CheckDuotone)"
|
|
3623
|
+
(click)="handleSaveClicked()"></co-button>
|
|
3624
|
+
<co-button class="close-button"
|
|
3625
|
+
[iconData]="iconCacheService.getIcon(icons.CrossSkinny)"
|
|
3626
|
+
(click)="closePDFDialog.emit()"></co-button>
|
|
3627
|
+
</div>
|
|
3628
|
+
</ng-template>
|
|
3629
|
+
</co-dialog>
|
|
3622
3630
|
`,
|
|
3623
3631
|
encapsulation: ViewEncapsulation.None
|
|
3624
3632
|
},] }
|
|
@@ -3646,6 +3654,7 @@ CustomPdfDialogModule.decorators = [
|
|
|
3646
3654
|
CommonModule,
|
|
3647
3655
|
ButtonModule,
|
|
3648
3656
|
SharedComponentsTranslationModule,
|
|
3657
|
+
LoaderModule
|
|
3649
3658
|
],
|
|
3650
3659
|
declarations: [
|
|
3651
3660
|
CustomPdfDialogComponent
|