@colijnit/sharedcomponents 256.2.3 → 256.2.5
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/bundles/colijnit-sharedcomponents.umd.js +52 -15
- package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
- package/colijnit-sharedcomponents.metadata.json +1 -1
- package/esm2015/lib/components/docsign/docsign.component.js +33 -12
- package/esm2015/lib/components/preferred-planning/preferred-planning.component.js +12 -4
- package/esm2015/lib/res/dictionary/dictionaries.js +3 -3
- package/fesm2015/colijnit-sharedcomponents.js +45 -16
- package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
- package/lib/components/docsign/docsign.component.d.ts +9 -4
- package/lib/res/dictionary/dictionaries.d.ts +6 -51
- package/package.json +2 -2
- package/358.645812766f7a400d0d38.js +0 -1
- package/3rdpartylicenses.txt +0 -2219
- package/762.de7137adb145a849dcf7.js +0 -1
- package/977.bd6291f9ee6f6ddf91f1.js +0 -1
- package/favicon.ico +0 -0
- package/index.html +0 -12
- package/main.22d36feb19eb4279f65b.js +0 -1
- package/polyfills.907fe9d1887c5de17993.js +0 -1
- package/runtime.2ce74fec69845ef1e3ad.js +0 -1
- package/styles.fc08d8045bc786e9e35f.css +0 -1
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from
|
|
2
|
+
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { animate, state, style, transition, trigger } from "@angular/animations";
|
|
4
4
|
import { PDFDocument } from "pdf-lib";
|
|
5
5
|
import * as PDFJS from "pdfjs-dist/legacy/build/pdf";
|
|
6
6
|
import pdfjsWorker from "pdfjs-dist/build/pdf.worker.entry";
|
|
7
7
|
export class DocsignComponent {
|
|
8
|
-
constructor() {
|
|
8
|
+
constructor(_changeDetector) {
|
|
9
|
+
this._changeDetector = _changeDetector;
|
|
9
10
|
this.saveButtonLabel = 'SAVE';
|
|
10
11
|
this.clearButtonLabel = 'CLEAR';
|
|
11
12
|
this.signDocumentButtonLabel = 'SIGN_DOCUMENT';
|
|
@@ -71,13 +72,32 @@ export class DocsignComponent {
|
|
|
71
72
|
*/
|
|
72
73
|
set pdf(value) {
|
|
73
74
|
if (value) {
|
|
74
|
-
|
|
75
|
+
if (typeof value === 'string') {
|
|
76
|
+
this._preparePDF(value);
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this._pdf = value;
|
|
80
|
+
}
|
|
75
81
|
this._openPDF();
|
|
76
82
|
}
|
|
77
83
|
}
|
|
78
84
|
get pdf() {
|
|
79
85
|
return this._pdf;
|
|
80
86
|
}
|
|
87
|
+
set firstSignatureField(value) {
|
|
88
|
+
this._firstSignatureField = value;
|
|
89
|
+
this._checkSignatures();
|
|
90
|
+
}
|
|
91
|
+
get firstSignatureField() {
|
|
92
|
+
return this._firstSignatureField;
|
|
93
|
+
}
|
|
94
|
+
set secondSignatureField(value) {
|
|
95
|
+
this._secondSignatureField = value;
|
|
96
|
+
this._checkSignatures();
|
|
97
|
+
}
|
|
98
|
+
get secondSignatureField() {
|
|
99
|
+
return this._secondSignatureField;
|
|
100
|
+
}
|
|
81
101
|
showClass() {
|
|
82
102
|
return true;
|
|
83
103
|
}
|
|
@@ -100,6 +120,7 @@ export class DocsignComponent {
|
|
|
100
120
|
});
|
|
101
121
|
const pdfDataUri = yield this.pdfDoc.saveAsBase64({ dataUri: true });
|
|
102
122
|
this.iframe.nativeElement.src = pdfDataUri;
|
|
123
|
+
this._changeDetector.detectChanges();
|
|
103
124
|
});
|
|
104
125
|
}
|
|
105
126
|
_savePdf() {
|
|
@@ -113,6 +134,9 @@ export class DocsignComponent {
|
|
|
113
134
|
}
|
|
114
135
|
_checkSignatures() {
|
|
115
136
|
return __awaiter(this, void 0, void 0, function* () {
|
|
137
|
+
if (!this._pdf) {
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
116
140
|
let pdfWorkerSrc;
|
|
117
141
|
if (window.hasOwnProperty('pdfWorkerSrc') &&
|
|
118
142
|
typeof window.pdfWorkerSrc === 'string' &&
|
|
@@ -134,6 +158,7 @@ export class DocsignComponent {
|
|
|
134
158
|
if (this.sigBuyerPosition.width > 0 && this.sigBuyerPosition.height > 0) {
|
|
135
159
|
this.sigBuyerPosition.page = i;
|
|
136
160
|
this.showSigBuyer = true;
|
|
161
|
+
this._changeDetector.detectChanges();
|
|
137
162
|
}
|
|
138
163
|
}
|
|
139
164
|
if (this.secondSignatureField) {
|
|
@@ -141,6 +166,7 @@ export class DocsignComponent {
|
|
|
141
166
|
if (this.sigSellerPosition.width > 0 && this.sigSellerPosition.height > 0) {
|
|
142
167
|
this.sigSellerPosition.page = i;
|
|
143
168
|
this.showSigSeller = true;
|
|
169
|
+
this._changeDetector.detectChanges();
|
|
144
170
|
}
|
|
145
171
|
}
|
|
146
172
|
}
|
|
@@ -172,14 +198,6 @@ export class DocsignComponent {
|
|
|
172
198
|
});
|
|
173
199
|
});
|
|
174
200
|
}
|
|
175
|
-
_handlePdfData(pdfData) {
|
|
176
|
-
if (typeof pdfData === 'string') {
|
|
177
|
-
this._preparePDF(pdfData);
|
|
178
|
-
}
|
|
179
|
-
else {
|
|
180
|
-
this._pdf = pdfData;
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
201
|
_preparePDF(base64) {
|
|
184
202
|
var binary_string = window.atob(base64);
|
|
185
203
|
var len = binary_string.length;
|
|
@@ -224,6 +242,9 @@ DocsignComponent.decorators = [
|
|
|
224
242
|
encapsulation: ViewEncapsulation.None
|
|
225
243
|
},] }
|
|
226
244
|
];
|
|
245
|
+
DocsignComponent.ctorParameters = () => [
|
|
246
|
+
{ type: ChangeDetectorRef }
|
|
247
|
+
];
|
|
227
248
|
DocsignComponent.propDecorators = {
|
|
228
249
|
iframe: [{ type: ViewChild, args: ["iframe", { read: ElementRef },] }],
|
|
229
250
|
pdf: [{ type: Input }],
|
|
@@ -239,4 +260,4 @@ DocsignComponent.propDecorators = {
|
|
|
239
260
|
cancelClick: [{ type: Output }],
|
|
240
261
|
showClass: [{ type: HostBinding, args: ['class.co-docsign',] }]
|
|
241
262
|
};
|
|
242
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docsign.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/docsign/docsign.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation} from \"@angular/core\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {PDFDocument} from \"pdf-lib\";\r\nimport * as PDFJS from \"pdfjs-dist/legacy/build/pdf\";\r\nimport pdfjsWorker from \"pdfjs-dist/build/pdf.worker.entry\";\r\nimport {TextItem} from \"pdfjs-dist/types/src/display/api\";\r\n\r\nexport interface TextDimension {\r\n  x: number,\r\n  y: number,\r\n  width: number,\r\n  height: number,\r\n  page: number\r\n}\r\n\r\n@Component({\r\n  selector: \"co-docsign\",\r\n  template: `\r\n    <iframe #iframe></iframe>\r\n    <co-signatures *ngIf=\"showSignatures\" @showHideSignature\r\n                     [showFirstSignature]=\"showSigBuyer\"\r\n                     [firstSignatureTitle]=\"firstSignatureLabel\"\r\n                     [showSecondSignature]=\"showSigSeller\"\r\n                     [secondSignatureTitle]=\"secondSignatureLabel\"\r\n                     [saveButtonLabel]=\"saveButtonLabel\"\r\n                     [clearButtonLabel]=\"clearButtonLabel\"\r\n                     (saveFirstSignature)=\"saveFirstSignature($event)\"\r\n                     (saveSecondSignature)=\"saveSecondSignature($event)\"\r\n    ></co-signatures>\r\n    <input type=\"button\" *ngIf=\"(showSigBuyer || showSigSeller) && !showSignatures\" class=\"button button-sign-document\"\r\n           [value]=\"signDocumentButtonLabel\"\r\n           (click)=\"showSignatures = true\"\r\n    />\r\n    <input type=\"button\" class=\"button button-cancel\"\r\n           [value]=\"cancelButtonLabel\"\r\n           (click)=\"cancelClick.emit($event)\"\r\n    />\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideSignature\", [\r\n      state(\"void\", style({transform: \"translate(-50%, -50%) scale(0)\"})),\r\n      state(\"*\", style({transform: \"translate(-50%, -50%) scale(1)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\")),\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DocsignComponent {\r\n  @ViewChild(\"iframe\", { read: ElementRef })\r\n  public iframe: ElementRef;\r\n\r\n  /**\r\n   * Load an existing [[PDFDocument]]. The input data can be provided in\r\n   * multiple formats:\r\n   *\r\n   * | Type          | Contents                                               |\r\n   * | ------------- | ------------------------------------------------------ |\r\n   * | `string`      | A base64 encoded string (or data URI) containing a PDF |\r\n   * | `Uint8Array`  | The raw bytes of a PDF                                 |\r\n   * | `ArrayBuffer` | The raw bytes of a PDF                                 |\r\n   *\r\n   * For example:\r\n   * ```js\r\n   * import { PDFDocument } from 'pdf-lib'\r\n   *\r\n   * // pdf=string\r\n   * const base64 =\r\n   *  'JVBERi0xLjcKJYGBgYEKCjUgMCBvYmoKPDwKL0ZpbHRlciAvRmxhdGVEZWNvZGUKL0xlbm' +\r\n   *  'd0aCAxMDQKPj4Kc3RyZWFtCniccwrhMlAAwaJ0Ln2P1Jyy1JLM5ERdc0MjCwUjE4WQNC4Q' +\r\n   *  '6cNlCFZkqGCqYGSqEJLLZWNuYGZiZmbkYuZsZmlmZGRgZmluDCQNzc3NTM2NzdzMXMxMjQ' +\r\n   *  'ztFEKyuEK0uFxDuAAOERdVCmVuZHN0cmVhbQplbmRvYmoKCjYgMCBvYmoKPDwKL0ZpbHRl' +\r\n   *  'ciAvRmxhdGVEZWNvZGUKL1R5cGUgL09ialN0bQovTiA0Ci9GaXJzdCAyMAovTGVuZ3RoID' +\r\n   *  'IxNQo+PgpzdHJlYW0KeJxVj9GqwjAMhu/zFHkBzTo3nCCCiiKIHPEICuJF3cKoSCu2E8/b' +\r\n   *  '20wPIr1p8v9/8kVhgilmGfawX2CGaVrgcAi0/bsy0lrX7IGWpvJ4iJYEN3gEmrrGBlQwGs' +\r\n   *  'HHO9VBX1wNrxAqMX87RBD5xpJuddqwd82tjAHxzV1U5LPgy52DKXWnr1Lheg+j/c/pzGVr' +\r\n   *  'iqV0VlwZPXGPCJjElw/ybkwUmeoWgxesDXGhHJC/D/iikp1Av80ptKU0FdBEe25pPihAM1' +\r\n   *  'u6ytgaaWfs2Hrz35CJT1+EWmAKZW5kc3RyZWFtCmVuZG9iagoKNyAwIG9iago8PAovU2l6' +\r\n   *  'ZSA4Ci9Sb290IDIgMCBSCi9GaWx0ZXIgL0ZsYXRlRGVjb2RlCi9UeXBlIC9YUmVmCi9MZW' +\r\n   *  '5ndGggMzgKL1cgWyAxIDIgMiBdCi9JbmRleCBbIDAgOCBdCj4+CnN0cmVhbQp4nBXEwREA' +\r\n   *  'EBAEsCwz3vrvRmOOyyOoGhZdutHN2MT55fIAVocD+AplbmRzdHJlYW0KZW5kb2JqCgpzdG' +\r\n   *  'FydHhyZWYKNTEwCiUlRU9G'\r\n   *\r\n   * const dataUri = 'data:application/pdf;base64,' + base64\r\n   *\r\n   * const pdfDoc1 = await PDFDocument.load(base64)\r\n   * const pdfDoc2 = await PDFDocument.load(dataUri)\r\n   *\r\n   * // pdf=Uint8Array\r\n   * import fs from 'fs'\r\n   * const uint8Array = fs.readFileSync('with_update_sections.pdf')\r\n   * const pdfDoc3 = await PDFDocument.load(uint8Array)\r\n   *\r\n   * // pdf=ArrayBuffer\r\n   * const url = 'https://pdf-lib.js.org/assets/with_update_sections.pdf'\r\n   * const arrayBuffer = await fetch(url).then(res => res.arrayBuffer())\r\n   * const pdfDoc4 = await PDFDocument.load(arrayBuffer)\r\n   *\r\n   * ```\r\n   *\r\n   * @param pdf The input data containing a PDF document.\r\n   * @param options The options to be used when loading the document.\r\n   * @returns Resolves with a document loaded from the input.\r\n   */\r\n  @Input()\r\n  public set pdf(value: any) {\r\n    if (value) {\r\n      this._handlePdfData(value);\r\n      this._openPDF();\r\n    }\r\n  }\r\n\r\n  public get pdf(): any {\r\n    return this._pdf;\r\n  }\r\n\r\n  @Input()\r\n  public firstSignatureLabel: string;\r\n\r\n  @Input()\r\n  public firstSignatureField: string;\r\n\r\n  @Input()\r\n  public secondSignatureLabel: string;\r\n\r\n  @Input()\r\n  public secondSignatureField: string;\r\n\r\n  @Input()\r\n  public saveButtonLabel: string = 'SAVE';\r\n\r\n  @Input()\r\n  public clearButtonLabel: string = 'CLEAR';\r\n\r\n  @Input()\r\n  public signDocumentButtonLabel: string = 'SIGN_DOCUMENT';\r\n\r\n  @Input()\r\n  public cancelButtonLabel: string = 'CANCEL';\r\n\r\n  @Output()\r\n  public pdfSaved: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding('class.co-docsign')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public showSignaturePopup: boolean = false;\r\n  public showSigBuyer: boolean = false;\r\n  public sigBuyerPosition: TextDimension;\r\n  public showSigSeller: boolean = false;\r\n  public sigSellerPosition: TextDimension;\r\n  public showSignatures: boolean = false;\r\n\r\n  public pdfDoc: PDFDocument;\r\n\r\n  private _pdf: any;\r\n\r\n  public saveFirstSignature(sig: string): void {\r\n    this._saveSignature(sig, this.sigBuyerPosition);\r\n    this.showSigBuyer = false;\r\n    this._savePdf();\r\n  }\r\n\r\n  public saveSecondSignature(sig: string): void {\r\n    this._saveSignature(sig, this.sigSellerPosition);\r\n    this.showSigSeller = false;\r\n    this._savePdf();\r\n  }\r\n\r\n  private async _openPDF(): Promise<void> {\r\n    // first create reader to check signatures\r\n    this._checkSignatures();\r\n\r\n    this.pdfDoc = await PDFDocument.load(this._pdf, {\r\n      updateMetadata: false\r\n    });\r\n    const pdfDataUri = await this.pdfDoc.saveAsBase64({ dataUri: true });\r\n    this.iframe.nativeElement.src = pdfDataUri;\r\n  }\r\n\r\n  private async _savePdf(): Promise<void> {\r\n    if (!this.showSigBuyer && !this.showSigSeller) {\r\n      // ready, save the pdf and emit result\r\n      const result = await this.pdfDoc.saveAsBase64();\r\n      this.pdfSaved.next(result);\r\n    }\r\n  }\r\n\r\n  private async _checkSignatures(): Promise<void> {\r\n    let pdfWorkerSrc;\r\n    if (window.hasOwnProperty('pdfWorkerSrc') &&\r\n      typeof (window as any).pdfWorkerSrc === 'string' &&\r\n      (window as any).pdfWorkerSrc) {\r\n      pdfWorkerSrc = (window as any).pdfWorkerSrc;\r\n    }\r\n    else {\r\n      pdfWorkerSrc = pdfjsWorker;\r\n    }\r\n    PDFJS.GlobalWorkerOptions.workerSrc = pdfWorkerSrc;\r\n    const pdfReader = await PDFJS.getDocument(this._pdf).promise;\r\n    const numPages = pdfReader.numPages;\r\n    for (let i = 0; i < numPages; i++) {\r\n      const page = await pdfReader.getPage(i + 1);\r\n      const text = await page.getTextContent();\r\n      page.cleanup();\r\n      if (this.firstSignatureField) {\r\n        this.sigBuyerPosition = this._getPositionSignature(text, this.firstSignatureField);\r\n        if (this.sigBuyerPosition.width > 0 && this.sigBuyerPosition.height > 0) {\r\n          this.sigBuyerPosition.page = i;\r\n          this.showSigBuyer = true;\r\n        }\r\n      }\r\n      if (this.secondSignatureField) {\r\n        this.sigSellerPosition = this._getPositionSignature(text, this.secondSignatureField);\r\n        if (this.sigSellerPosition.width > 0 && this.sigSellerPosition.height > 0) {\r\n          this.sigSellerPosition.page = i;\r\n          this.showSigSeller = true;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPositionSignature(textItem: any, signatureField: string): TextDimension {\r\n    const sigItem: TextItem = <TextItem>textItem.items.find((i: any) => i.str.toLowerCase() === signatureField.toLowerCase());\r\n    if (sigItem) {\r\n      textItem.items.slice(textItem.items.indexOf(sigItem), 1);\r\n      return {\r\n        x: sigItem.transform[4],\r\n        y: sigItem.transform[5],\r\n        width: sigItem.width,\r\n        height: sigItem.height,\r\n        page: 0\r\n      };\r\n    }\r\n    return {x: 0, y: 0, width: 0, height: 0, page: 0}\r\n  }\r\n\r\n  private async _saveSignature(sig: string, dimensions: TextDimension): Promise<void> {\r\n    const jpgImage = await this.pdfDoc.embedPng(sig);\r\n    const page = await this.pdfDoc.getPage(dimensions.page);\r\n    page.drawImage(jpgImage, {\r\n      x: ((dimensions.x + (dimensions.width / 2)) - (200 / 2)),\r\n      y: ((dimensions.y + (dimensions.height / 2)) - (100 / 2)),\r\n      width: 200,\r\n      height: 100\r\n    });\r\n  }\r\n\r\n  private _handlePdfData(pdfData: any) {\r\n    if (typeof pdfData === 'string') {\r\n      this._preparePDF(pdfData);\r\n    } else {\r\n      this._pdf = pdfData;\r\n    }\r\n  }\r\n\r\n  private _preparePDF(base64: string): void {\r\n    var binary_string = window.atob(base64);\r\n    var len = binary_string.length;\r\n    var bytes = new Uint8Array(len);\r\n    for (var i = 0; i < len; i++) {\r\n      bytes[i] = binary_string.charCodeAt(i);\r\n    }\r\n    this._pdf = bytes;\r\n  }\r\n}\r\n"]}
|
|
263
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docsign.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/docsign/docsign.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {PDFDocument} from \"pdf-lib\";\r\nimport * as PDFJS from \"pdfjs-dist/legacy/build/pdf\";\r\nimport pdfjsWorker from \"pdfjs-dist/build/pdf.worker.entry\";\r\nimport {TextItem} from \"pdfjs-dist/types/src/display/api\";\r\n\r\nexport interface TextDimension {\r\n  x: number,\r\n  y: number,\r\n  width: number,\r\n  height: number,\r\n  page: number\r\n}\r\n\r\n@Component({\r\n  selector: \"co-docsign\",\r\n  template: `\r\n    <iframe #iframe></iframe>\r\n    <co-signatures *ngIf=\"showSignatures\" @showHideSignature\r\n                     [showFirstSignature]=\"showSigBuyer\"\r\n                     [firstSignatureTitle]=\"firstSignatureLabel\"\r\n                     [showSecondSignature]=\"showSigSeller\"\r\n                     [secondSignatureTitle]=\"secondSignatureLabel\"\r\n                     [saveButtonLabel]=\"saveButtonLabel\"\r\n                     [clearButtonLabel]=\"clearButtonLabel\"\r\n                     (saveFirstSignature)=\"saveFirstSignature($event)\"\r\n                     (saveSecondSignature)=\"saveSecondSignature($event)\"\r\n    ></co-signatures>\r\n    <input type=\"button\" *ngIf=\"(showSigBuyer || showSigSeller) && !showSignatures\" class=\"button button-sign-document\"\r\n           [value]=\"signDocumentButtonLabel\"\r\n           (click)=\"showSignatures = true\"\r\n    />\r\n    <input type=\"button\" class=\"button button-cancel\"\r\n           [value]=\"cancelButtonLabel\"\r\n           (click)=\"cancelClick.emit($event)\"\r\n    />\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideSignature\", [\r\n      state(\"void\", style({transform: \"translate(-50%, -50%) scale(0)\"})),\r\n      state(\"*\", style({transform: \"translate(-50%, -50%) scale(1)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\")),\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DocsignComponent {\r\n  @ViewChild(\"iframe\", { read: ElementRef })\r\n  public iframe: ElementRef;\r\n\r\n  /**\r\n   * Load an existing [[PDFDocument]]. The input data can be provided in\r\n   * multiple formats:\r\n   *\r\n   * | Type          | Contents                                               |\r\n   * | ------------- | ------------------------------------------------------ |\r\n   * | `string`      | A base64 encoded string (or data URI) containing a PDF |\r\n   * | `Uint8Array`  | The raw bytes of a PDF                                 |\r\n   * | `ArrayBuffer` | The raw bytes of a PDF                                 |\r\n   *\r\n   * For example:\r\n   * ```js\r\n   * import { PDFDocument } from 'pdf-lib'\r\n   *\r\n   * // pdf=string\r\n   * const base64 =\r\n   *  'JVBERi0xLjcKJYGBgYEKCjUgMCBvYmoKPDwKL0ZpbHRlciAvRmxhdGVEZWNvZGUKL0xlbm' +\r\n   *  'd0aCAxMDQKPj4Kc3RyZWFtCniccwrhMlAAwaJ0Ln2P1Jyy1JLM5ERdc0MjCwUjE4WQNC4Q' +\r\n   *  '6cNlCFZkqGCqYGSqEJLLZWNuYGZiZmbkYuZsZmlmZGRgZmluDCQNzc3NTM2NzdzMXMxMjQ' +\r\n   *  'ztFEKyuEK0uFxDuAAOERdVCmVuZHN0cmVhbQplbmRvYmoKCjYgMCBvYmoKPDwKL0ZpbHRl' +\r\n   *  'ciAvRmxhdGVEZWNvZGUKL1R5cGUgL09ialN0bQovTiA0Ci9GaXJzdCAyMAovTGVuZ3RoID' +\r\n   *  'IxNQo+PgpzdHJlYW0KeJxVj9GqwjAMhu/zFHkBzTo3nCCCiiKIHPEICuJF3cKoSCu2E8/b' +\r\n   *  '20wPIr1p8v9/8kVhgilmGfawX2CGaVrgcAi0/bsy0lrX7IGWpvJ4iJYEN3gEmrrGBlQwGs' +\r\n   *  'HHO9VBX1wNrxAqMX87RBD5xpJuddqwd82tjAHxzV1U5LPgy52DKXWnr1Lheg+j/c/pzGVr' +\r\n   *  'iqV0VlwZPXGPCJjElw/ybkwUmeoWgxesDXGhHJC/D/iikp1Av80ptKU0FdBEe25pPihAM1' +\r\n   *  'u6ytgaaWfs2Hrz35CJT1+EWmAKZW5kc3RyZWFtCmVuZG9iagoKNyAwIG9iago8PAovU2l6' +\r\n   *  'ZSA4Ci9Sb290IDIgMCBSCi9GaWx0ZXIgL0ZsYXRlRGVjb2RlCi9UeXBlIC9YUmVmCi9MZW' +\r\n   *  '5ndGggMzgKL1cgWyAxIDIgMiBdCi9JbmRleCBbIDAgOCBdCj4+CnN0cmVhbQp4nBXEwREA' +\r\n   *  'EBAEsCwz3vrvRmOOyyOoGhZdutHN2MT55fIAVocD+AplbmRzdHJlYW0KZW5kb2JqCgpzdG' +\r\n   *  'FydHhyZWYKNTEwCiUlRU9G'\r\n   *\r\n   * const dataUri = 'data:application/pdf;base64,' + base64\r\n   *\r\n   * const pdfDoc1 = await PDFDocument.load(base64)\r\n   * const pdfDoc2 = await PDFDocument.load(dataUri)\r\n   *\r\n   * // pdf=Uint8Array\r\n   * import fs from 'fs'\r\n   * const uint8Array = fs.readFileSync('with_update_sections.pdf')\r\n   * const pdfDoc3 = await PDFDocument.load(uint8Array)\r\n   *\r\n   * // pdf=ArrayBuffer\r\n   * const url = 'https://pdf-lib.js.org/assets/with_update_sections.pdf'\r\n   * const arrayBuffer = await fetch(url).then(res => res.arrayBuffer())\r\n   * const pdfDoc4 = await PDFDocument.load(arrayBuffer)\r\n   *\r\n   * ```\r\n   *\r\n   * @param pdf The input data containing a PDF document.\r\n   * @param options The options to be used when loading the document.\r\n   * @returns Resolves with a document loaded from the input.\r\n   */\r\n  @Input()\r\n  public set pdf(value: any) {\r\n    if (value) {\r\n      if (typeof value === 'string') {\r\n        this._preparePDF(value);\r\n      } else {\r\n        this._pdf = value;\r\n      }\r\n      this._openPDF();\r\n    }\r\n  }\r\n\r\n  public get pdf(): any {\r\n    return this._pdf;\r\n  }\r\n\r\n  @Input()\r\n  public firstSignatureLabel: string;\r\n\r\n  @Input()\r\n  public set firstSignatureField(value: string) {\r\n    this._firstSignatureField = value;\r\n    this._checkSignatures();\r\n  }\r\n\r\n  public get firstSignatureField(): string {\r\n    return this._firstSignatureField;\r\n  }\r\n\r\n  @Input()\r\n  public secondSignatureLabel: string;\r\n\r\n  @Input()\r\n  public set secondSignatureField(value: string) {\r\n    this._secondSignatureField = value;\r\n    this._checkSignatures();\r\n  }\r\n\r\n  public get secondSignatureField(): string {\r\n    return this._secondSignatureField;\r\n  }\r\n\r\n  @Input()\r\n  public saveButtonLabel: string = 'SAVE';\r\n\r\n  @Input()\r\n  public clearButtonLabel: string = 'CLEAR';\r\n\r\n  @Input()\r\n  public signDocumentButtonLabel: string = 'SIGN_DOCUMENT';\r\n\r\n  @Input()\r\n  public cancelButtonLabel: string = 'CANCEL';\r\n\r\n  @Output()\r\n  public pdfSaved: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding('class.co-docsign')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public showSignaturePopup: boolean = false;\r\n  public showSigBuyer: boolean = false;\r\n  public sigBuyerPosition: TextDimension;\r\n  public showSigSeller: boolean = false;\r\n  public sigSellerPosition: TextDimension;\r\n  public showSignatures: boolean = false;\r\n\r\n  public pdfDoc: PDFDocument;\r\n\r\n  private _pdf: any;\r\n  private _firstSignatureField: string;\r\n  private _secondSignatureField: string;\r\n\r\n  constructor(\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  public saveFirstSignature(sig: string): void {\r\n    this._saveSignature(sig, this.sigBuyerPosition);\r\n    this.showSigBuyer = false;\r\n    this._savePdf();\r\n  }\r\n\r\n  public saveSecondSignature(sig: string): void {\r\n    this._saveSignature(sig, this.sigSellerPosition);\r\n    this.showSigSeller = false;\r\n    this._savePdf();\r\n  }\r\n\r\n  private async _openPDF(): Promise<void> {\r\n    // first create reader to check signatures\r\n    this._checkSignatures();\r\n\r\n    this.pdfDoc = await PDFDocument.load(this._pdf, {\r\n      updateMetadata: false\r\n    });\r\n    const pdfDataUri = await this.pdfDoc.saveAsBase64({ dataUri: true });\r\n    this.iframe.nativeElement.src = pdfDataUri;\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _savePdf(): Promise<void> {\r\n    if (!this.showSigBuyer && !this.showSigSeller) {\r\n      // ready, save the pdf and emit result\r\n      const result = await this.pdfDoc.saveAsBase64();\r\n      this.pdfSaved.next(result);\r\n    }\r\n  }\r\n\r\n  private async _checkSignatures(): Promise<void> {\r\n    if (!this._pdf) {\r\n      return;\r\n    }\r\n    let pdfWorkerSrc;\r\n    if (window.hasOwnProperty('pdfWorkerSrc') &&\r\n      typeof (window as any).pdfWorkerSrc === 'string' &&\r\n      (window as any).pdfWorkerSrc) {\r\n      pdfWorkerSrc = (window as any).pdfWorkerSrc;\r\n    }\r\n    else {\r\n      pdfWorkerSrc = pdfjsWorker;\r\n    }\r\n    PDFJS.GlobalWorkerOptions.workerSrc = pdfWorkerSrc;\r\n    const pdfReader = await PDFJS.getDocument(this._pdf).promise;\r\n    const numPages = pdfReader.numPages;\r\n    for (let i = 0; i < numPages; i++) {\r\n      const page = await pdfReader.getPage(i + 1);\r\n      const text = await page.getTextContent();\r\n      page.cleanup();\r\n      if (this.firstSignatureField) {\r\n        this.sigBuyerPosition = this._getPositionSignature(text, this.firstSignatureField);\r\n        if (this.sigBuyerPosition.width > 0 && this.sigBuyerPosition.height > 0) {\r\n          this.sigBuyerPosition.page = i;\r\n          this.showSigBuyer = true;\r\n          this._changeDetector.detectChanges();\r\n        }\r\n      }\r\n      if (this.secondSignatureField) {\r\n        this.sigSellerPosition = this._getPositionSignature(text, this.secondSignatureField);\r\n        if (this.sigSellerPosition.width > 0 && this.sigSellerPosition.height > 0) {\r\n          this.sigSellerPosition.page = i;\r\n          this.showSigSeller = true;\r\n          this._changeDetector.detectChanges();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPositionSignature(textItem: any, signatureField: string): TextDimension {\r\n    const sigItem: TextItem = <TextItem>textItem.items.find((i: any) => i.str.toLowerCase() === signatureField.toLowerCase());\r\n    if (sigItem) {\r\n      textItem.items.slice(textItem.items.indexOf(sigItem), 1);\r\n      return {\r\n        x: sigItem.transform[4],\r\n        y: sigItem.transform[5],\r\n        width: sigItem.width,\r\n        height: sigItem.height,\r\n        page: 0\r\n      };\r\n    }\r\n    return {x: 0, y: 0, width: 0, height: 0, page: 0}\r\n  }\r\n\r\n  private async _saveSignature(sig: string, dimensions: TextDimension): Promise<void> {\r\n    const jpgImage = await this.pdfDoc.embedPng(sig);\r\n    const page = await this.pdfDoc.getPage(dimensions.page);\r\n    page.drawImage(jpgImage, {\r\n      x: ((dimensions.x + (dimensions.width / 2)) - (200 / 2)),\r\n      y: ((dimensions.y + (dimensions.height / 2)) - (100 / 2)),\r\n      width: 200,\r\n      height: 100\r\n    });\r\n  }\r\n\r\n  private _preparePDF(base64: string): void {\r\n    var binary_string = window.atob(base64);\r\n    var len = binary_string.length;\r\n    var bytes = new Uint8Array(len);\r\n    for (var i = 0; i < len; i++) {\r\n      bytes[i] = binary_string.charCodeAt(i);\r\n    }\r\n    this._pdf = bytes;\r\n  }\r\n}\r\n"]}
|
|
@@ -104,20 +104,28 @@ export class PreferredPlanningComponent {
|
|
|
104
104
|
}
|
|
105
105
|
}
|
|
106
106
|
handleOptionSelect(event, selectedOption, date, index) {
|
|
107
|
+
this.events.forEach(day => {
|
|
108
|
+
day.events.forEach(opt => opt.checked = false);
|
|
109
|
+
});
|
|
110
|
+
const target = document.getElementById('event-' + index);
|
|
107
111
|
const olderItems = document.getElementsByClassName('eventOption');
|
|
108
112
|
for (let i = 0; i < olderItems.length; i++) {
|
|
109
113
|
olderItems[i].classList.remove('day-selected');
|
|
110
114
|
}
|
|
111
115
|
if (event) {
|
|
116
|
+
selectedOption.checked = true;
|
|
112
117
|
this.selectedOption = selectedOption;
|
|
113
118
|
const agendaEventPerDay = new AgendaEventPerDay();
|
|
114
119
|
agendaEventPerDay.date = date;
|
|
115
120
|
agendaEventPerDay.events.push(selectedOption);
|
|
116
121
|
this.selected.emit(agendaEventPerDay);
|
|
117
|
-
|
|
118
|
-
target.classList.add('day-selected');
|
|
119
|
-
this.checkDisabled = true;
|
|
122
|
+
target === null || target === void 0 ? void 0 : target.classList.add('day-selected');
|
|
120
123
|
}
|
|
124
|
+
else {
|
|
125
|
+
this.selectedOption = null;
|
|
126
|
+
this.selected.emit(null);
|
|
127
|
+
}
|
|
128
|
+
this._changeDetector.detectChanges();
|
|
121
129
|
}
|
|
122
130
|
loadMore() {
|
|
123
131
|
this.limit = this.limit += 4;
|
|
@@ -207,4 +215,4 @@ PreferredPlanningComponent.propDecorators = {
|
|
|
207
215
|
selected: [{ type: Output }],
|
|
208
216
|
showClass: [{ type: HostBinding, args: ["class.co-preferred-planning",] }]
|
|
209
217
|
};
|
|
210
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preferred-planning.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/preferred-planning/preferred-planning.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {AgendaEventPerDay} from \"../../model/agenda-event-per-day.model\";\r\nimport {AgendaEvent} from \"../../model/agenda-event.model\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\n\r\n@Component({\r\n  selector: \"co-preferred-planning\",\r\n  template: `\r\n    <div class=\"co-preferred-planning\">\r\n      <div class=\"content-wrapper\">\r\n        <p [textContent]=\"headerDescription\"></p>\r\n        <div class=\"planning-container\">\r\n          <div class=\"planning-options\" *ngIf=\"events\">\r\n            <ng-container *ngFor=\"let event of events | slice:0:limit; let i=index\">\r\n              <div class=\"eventOption\" id=\"event-{{i}}\">\r\n                <p [textContent]=\"event.date | date:'EEEE dd MMMM':'nl'\"></p>\r\n                <ng-container *ngFor=\"let option of event.events\">\r\n                  <div class=\"planning-option\">\r\n                    <co-input-checkbox\r\n                      [disabled]=\"checkDisabled\"\r\n                      [model]=\"option.checked\"\r\n                      [label]=\"option.description\"\r\n                      (modelChange)=\"handleOptionSelect($event, option, event.date, i)\"\r\n                    ></co-input-checkbox>\r\n                  </div>\r\n                </ng-container>\r\n              </div>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"planning-disclaimer\">\r\n            <h2 [textContent]=\"disclaimerHeader\"></h2>\r\n            <div class=\"planning-disclaimer-contents\">\r\n              <co-icon class=\"disclaimer-icon\" [iconData]=\"iconCacheService.getIcon(icons.CheckRound)\"></co-icon>\r\n              <p [textContent]=\"disclaimerDescription\"></p>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div (click)=\"loadMore()\" class=\"load-more-container\"\r\n             [ngClass]=\"!moreLoadable ? 'load-more-container-disabled':''\">\r\n          <p>\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(icons.ArrowFatRight)\"></co-icon>\r\n            <span [textContent]=\"loadMoreButtonText\"></span>\r\n          </p>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <co-button class=\"submit-button\"\r\n               [label]=\"buttonLabel\"\r\n               (click)=\"buttonClick.emit($event)\">\r\n    </co-button>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideWindow\", [\r\n      state(\"void\", style({transform: \"scaleY(0)\"})),\r\n      state(\"*\", style({transform: \"scaleY(1)\"})),\r\n      transition(\":enter, :leave\", [\r\n        animate(\"200ms ease-in-out\")\r\n      ])\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class PreferredPlanningComponent implements OnInit {\r\n  @ViewChild(\"dayStart\", {static: true})\r\n  public dayStart: ElementRef;\r\n\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public firstAvailableDate: Date;\r\n\r\n  @Input()\r\n  public buttonLabel: string = \"\";\r\n\r\n  @Input()\r\n  public headerText: string = \"\";\r\n\r\n  @Input()\r\n  public headerDescription: string = \"\";\r\n\r\n  @Input()\r\n  public disclaimerHeader: string = \"\";\r\n\r\n  @Input()\r\n  public disclaimerDescription: string = \"\";\r\n\r\n  @Input()\r\n  public loadMoreButtonText: string = \"\";\r\n\r\n  @Input()\r\n  public eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n  @Input()\r\n  public selectedDate: Date;\r\n\r\n  @Output()\r\n  public readonly buttonClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public selected: EventEmitter<AgendaEventPerDay> = new EventEmitter<AgendaEventPerDay>();\r\n\r\n  @HostBinding(\"class.co-preferred-planning\")\r\n  public showClass: boolean = true;\r\n\r\n  public days: Date[] = [];\r\n  public events: AgendaEventPerDay[] = [];\r\n  public limit: number = 4;\r\n  public selectedOption: AgendaEvent;\r\n  public moreLoadable: boolean = true;\r\n\r\n  public checkDisabled: boolean = false;\r\n\r\n  constructor(\r\n    @Inject(LOCALE_ID) public locale: string,\r\n    public iconCacheService: IconCacheService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    // const eventone = new AgendaEvent();\r\n    // eventone.checked = false;\r\n    // eventone.showCheckbox = true;\r\n    // eventone.draggable = false;\r\n    // eventone.id = 2;\r\n    // eventone.dayPartNo = 2;\r\n    // eventone.date = new Date('2024-10-21T00:00:00');\r\n    // eventone.from = new Date('2024-10-21T09:00:00');\r\n    // eventone.to = new Date('2024-10-21T12:00:00');\r\n    // eventone.fromString = \"09:00 AM\";\r\n    // eventone.toString = \"12:00 PM\";\r\n    // eventone.fromToRepresentation = \"09:00 AM - 12:00 PM\";\r\n    // eventone.description = \"Morgen van 9.00- 12.00 uur\";\r\n    //\r\n    // const eventwo = new AgendaEvent();\r\n    // eventwo.checked = false;\r\n    // eventwo.showCheckbox = true;\r\n    // eventwo.draggable = false;\r\n    // eventwo.id = 3;\r\n    // eventwo.dayPartNo = 3;\r\n    // eventwo.date = new Date('2024-10-21T00:00:00');\r\n    // eventwo.from = new Date('2024-10-21T12:00:00');\r\n    // eventwo.to = new Date('2024-10-21T15:00:00');\r\n    // eventwo.fromString = \"12:00 PM\";\r\n    // eventwo.toString = \"03:00 PM\";\r\n    // eventwo.fromToRepresentation = \"12:00 PM - 03:00 PM\";\r\n    // eventwo.description = \"Hele dag\";\r\n    //\r\n    //\r\n    // const eventthree = new AgendaEvent();\r\n    // eventthree.checked = false;\r\n    // eventthree.showCheckbox = true;\r\n    // eventthree.draggable = false;\r\n    // eventthree.id = 7;\r\n    // eventthree.dayPartNo = 1;\r\n    // eventthree.date = new Date('2024-10-21T00:00:00');\r\n    // eventthree.from = new Date('2024-10-21T09:00:00');\r\n    // eventthree.to = new Date('2024-10-21T12:00:00');\r\n    // eventthree.fromString = \"09:00 AM\";\r\n    // eventthree.toString = \"12:00 PM\";\r\n    // eventthree.fromToRepresentation = \"09:00 AM - 12:00 PM\";\r\n    // eventthree.description = \"Morgen van 9.00- 12.00 uur\";\r\n    //\r\n    // const evenfour = new AgendaEvent();\r\n    // evenfour.checked = false;\r\n    // evenfour.showCheckbox = true;\r\n    // evenfour.draggable = false;\r\n    // evenfour.id = 8;\r\n    // evenfour.dayPartNo = 2;\r\n    // evenfour.date = new Date('2024-10-21T00:00:00');\r\n    // evenfour.from = new Date('2024-10-21T12:00:00');\r\n    // evenfour.to = new Date('2024-10-21T15:00:00');\r\n    // evenfour.fromString = \"12:00 PM\";\r\n    // evenfour.toString = \"03:00 PM\";\r\n    // evenfour.fromToRepresentation = \"12:00 PM - 03:00 PM\";\r\n    // evenfour.description = \"Hele dag\";\r\n    //\r\n    // const testData = new AgendaEventPerDay();\r\n    // testData.date = new Date('2024-10-21T00:00:00');\r\n    // testData.events.push(eventone);\r\n    // testData.events.push(eventwo);\r\n    //\r\n    // const testDataTwo = new AgendaEventPerDay();\r\n    // testDataTwo.date = new Date('2024-11-21T00:00:00');\r\n    // testDataTwo.events.push(eventthree);\r\n    // testDataTwo.events.push(evenfour);\r\n    //\r\n    // this.events.push(testData);\r\n    // this.events.push(testDataTwo);\r\n\r\n    if (this.eventsPerDay) {\r\n      this.events = this.eventsPerDay;\r\n      if (this.eventsPerDay.length <= this.limit) {\r\n        this.moreLoadable = false;\r\n      }\r\n      this._changeDetector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public handleOptionSelect(event: boolean, selectedOption: AgendaEvent, date: Date, index: number): void {\r\n    const olderItems = document.getElementsByClassName('eventOption');\r\n    for (let i: number = 0; i < olderItems.length; i++) {\r\n      olderItems[i].classList.remove('day-selected');\r\n    }\r\n    if (event) {\r\n      this.selectedOption = selectedOption;\r\n      const agendaEventPerDay: AgendaEventPerDay = new AgendaEventPerDay();\r\n      agendaEventPerDay.date = date;\r\n      agendaEventPerDay.events.push(selectedOption);\r\n      this.selected.emit(agendaEventPerDay);\r\n      const target: HTMLElement = document.getElementById('event-' + index);\r\n      target.classList.add('day-selected');\r\n      this.checkDisabled = true;\r\n    }\r\n  }\r\n\r\n  public loadMore(): void {\r\n    this.limit = this.limit += 4;\r\n    if (this.eventsPerDay.length <= this.limit) {\r\n      this.moreLoadable = false;\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preferred-planning.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/preferred-planning/preferred-planning.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Inject,\r\n  Input,\r\n  LOCALE_ID,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {AgendaEventPerDay} from \"../../model/agenda-event-per-day.model\";\r\nimport {AgendaEvent} from \"../../model/agenda-event.model\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\n\r\n@Component({\r\n  selector: \"co-preferred-planning\",\r\n  template: `\r\n    <div class=\"co-preferred-planning\">\r\n      <div class=\"content-wrapper\">\r\n        <p [textContent]=\"headerDescription\"></p>\r\n        <div class=\"planning-container\">\r\n          <div class=\"planning-options\" *ngIf=\"events\">\r\n            <ng-container *ngFor=\"let event of events | slice:0:limit; let i=index\">\r\n              <div class=\"eventOption\" id=\"event-{{i}}\">\r\n                <p [textContent]=\"event.date | date:'EEEE dd MMMM':'nl'\"></p>\r\n                <ng-container *ngFor=\"let option of event.events\">\r\n                  <div class=\"planning-option\">\r\n                    <co-input-checkbox\r\n                      [disabled]=\"checkDisabled\"\r\n                      [model]=\"option.checked\"\r\n                      [label]=\"option.description\"\r\n                      (modelChange)=\"handleOptionSelect($event, option, event.date, i)\"\r\n                    ></co-input-checkbox>\r\n                  </div>\r\n                </ng-container>\r\n              </div>\r\n            </ng-container>\r\n          </div>\r\n          <div class=\"planning-disclaimer\">\r\n            <h2 [textContent]=\"disclaimerHeader\"></h2>\r\n            <div class=\"planning-disclaimer-contents\">\r\n              <co-icon class=\"disclaimer-icon\" [iconData]=\"iconCacheService.getIcon(icons.CheckRound)\"></co-icon>\r\n              <p [textContent]=\"disclaimerDescription\"></p>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div (click)=\"loadMore()\" class=\"load-more-container\"\r\n             [ngClass]=\"!moreLoadable ? 'load-more-container-disabled':''\">\r\n          <p>\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(icons.ArrowFatRight)\"></co-icon>\r\n            <span [textContent]=\"loadMoreButtonText\"></span>\r\n          </p>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <co-button class=\"submit-button\"\r\n               [label]=\"buttonLabel\"\r\n               (click)=\"buttonClick.emit($event)\">\r\n    </co-button>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideWindow\", [\r\n      state(\"void\", style({transform: \"scaleY(0)\"})),\r\n      state(\"*\", style({transform: \"scaleY(1)\"})),\r\n      transition(\":enter, :leave\", [\r\n        animate(\"200ms ease-in-out\")\r\n      ])\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class PreferredPlanningComponent implements OnInit {\r\n  @ViewChild(\"dayStart\", {static: true})\r\n  public dayStart: ElementRef;\r\n\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public firstAvailableDate: Date;\r\n\r\n  @Input()\r\n  public buttonLabel: string = \"\";\r\n\r\n  @Input()\r\n  public headerText: string = \"\";\r\n\r\n  @Input()\r\n  public headerDescription: string = \"\";\r\n\r\n  @Input()\r\n  public disclaimerHeader: string = \"\";\r\n\r\n  @Input()\r\n  public disclaimerDescription: string = \"\";\r\n\r\n  @Input()\r\n  public loadMoreButtonText: string = \"\";\r\n\r\n  @Input()\r\n  public eventsPerDay: AgendaEventPerDay[] = [];\r\n\r\n  @Input()\r\n  public selectedDate: Date;\r\n\r\n  @Output()\r\n  public readonly buttonClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public selected: EventEmitter<AgendaEventPerDay> = new EventEmitter<AgendaEventPerDay>();\r\n\r\n  @HostBinding(\"class.co-preferred-planning\")\r\n  public showClass: boolean = true;\r\n\r\n  public days: Date[] = [];\r\n  public events: AgendaEventPerDay[] = [];\r\n  public limit: number = 4;\r\n  public selectedOption: AgendaEvent;\r\n  public moreLoadable: boolean = true;\r\n\r\n  public checkDisabled: boolean = false;\r\n\r\n  constructor(\r\n    @Inject(LOCALE_ID) public locale: string,\r\n    public iconCacheService: IconCacheService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    // const eventone = new AgendaEvent();\r\n    // eventone.checked = false;\r\n    // eventone.showCheckbox = true;\r\n    // eventone.draggable = false;\r\n    // eventone.id = 2;\r\n    // eventone.dayPartNo = 2;\r\n    // eventone.date = new Date('2024-10-21T00:00:00');\r\n    // eventone.from = new Date('2024-10-21T09:00:00');\r\n    // eventone.to = new Date('2024-10-21T12:00:00');\r\n    // eventone.fromString = \"09:00 AM\";\r\n    // eventone.toString = \"12:00 PM\";\r\n    // eventone.fromToRepresentation = \"09:00 AM - 12:00 PM\";\r\n    // eventone.description = \"Morgen van 9.00- 12.00 uur\";\r\n    //\r\n    // const eventwo = new AgendaEvent();\r\n    // eventwo.checked = false;\r\n    // eventwo.showCheckbox = true;\r\n    // eventwo.draggable = false;\r\n    // eventwo.id = 3;\r\n    // eventwo.dayPartNo = 3;\r\n    // eventwo.date = new Date('2024-10-21T00:00:00');\r\n    // eventwo.from = new Date('2024-10-21T12:00:00');\r\n    // eventwo.to = new Date('2024-10-21T15:00:00');\r\n    // eventwo.fromString = \"12:00 PM\";\r\n    // eventwo.toString = \"03:00 PM\";\r\n    // eventwo.fromToRepresentation = \"12:00 PM - 03:00 PM\";\r\n    // eventwo.description = \"Hele dag\";\r\n    //\r\n    //\r\n    // const eventthree = new AgendaEvent();\r\n    // eventthree.checked = false;\r\n    // eventthree.showCheckbox = true;\r\n    // eventthree.draggable = false;\r\n    // eventthree.id = 7;\r\n    // eventthree.dayPartNo = 1;\r\n    // eventthree.date = new Date('2024-10-21T00:00:00');\r\n    // eventthree.from = new Date('2024-10-21T09:00:00');\r\n    // eventthree.to = new Date('2024-10-21T12:00:00');\r\n    // eventthree.fromString = \"09:00 AM\";\r\n    // eventthree.toString = \"12:00 PM\";\r\n    // eventthree.fromToRepresentation = \"09:00 AM - 12:00 PM\";\r\n    // eventthree.description = \"Morgen van 9.00- 12.00 uur\";\r\n    //\r\n    // const evenfour = new AgendaEvent();\r\n    // evenfour.checked = false;\r\n    // evenfour.showCheckbox = true;\r\n    // evenfour.draggable = false;\r\n    // evenfour.id = 8;\r\n    // evenfour.dayPartNo = 2;\r\n    // evenfour.date = new Date('2024-10-21T00:00:00');\r\n    // evenfour.from = new Date('2024-10-21T12:00:00');\r\n    // evenfour.to = new Date('2024-10-21T15:00:00');\r\n    // evenfour.fromString = \"12:00 PM\";\r\n    // evenfour.toString = \"03:00 PM\";\r\n    // evenfour.fromToRepresentation = \"12:00 PM - 03:00 PM\";\r\n    // evenfour.description = \"Hele dag\";\r\n    //\r\n    // const testData = new AgendaEventPerDay();\r\n    // testData.date = new Date('2024-10-21T00:00:00');\r\n    // testData.events.push(eventone);\r\n    // testData.events.push(eventwo);\r\n    //\r\n    // const testDataTwo = new AgendaEventPerDay();\r\n    // testDataTwo.date = new Date('2024-11-21T00:00:00');\r\n    // testDataTwo.events.push(eventthree);\r\n    // testDataTwo.events.push(evenfour);\r\n    //\r\n    // this.events.push(testData);\r\n    // this.events.push(testDataTwo);\r\n\r\n    if (this.eventsPerDay) {\r\n      this.events = this.eventsPerDay;\r\n      if (this.eventsPerDay.length <= this.limit) {\r\n        this.moreLoadable = false;\r\n      }\r\n      this._changeDetector.detectChanges();\r\n    }\r\n  }\r\n\r\n  public handleOptionSelect(event: boolean, selectedOption: AgendaEvent, date: Date, index: number): void {\r\n    this.events.forEach(day => {\r\n      day.events.forEach(opt => opt.checked = false);\r\n    });\r\n\r\n    const target: HTMLElement = document.getElementById('event-' + index);\r\n    const olderItems = document.getElementsByClassName('eventOption');\r\n    for (let i = 0; i < olderItems.length; i++) {\r\n      olderItems[i].classList.remove('day-selected');\r\n    }\r\n\r\n    if (event) {\r\n      selectedOption.checked = true;\r\n      this.selectedOption = selectedOption;\r\n\r\n      const agendaEventPerDay: AgendaEventPerDay = new AgendaEventPerDay();\r\n      agendaEventPerDay.date = date;\r\n      agendaEventPerDay.events.push(selectedOption);\r\n      this.selected.emit(agendaEventPerDay);\r\n\r\n      target?.classList.add('day-selected');\r\n    } else {\r\n      this.selectedOption = null;\r\n      this.selected.emit(null);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  public loadMore(): void {\r\n    this.limit = this.limit += 4;\r\n    if (this.eventsPerDay.length <= this.limit) {\r\n      this.moreLoadable = false;\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n}\r\n"]}
|