@hitsoft/e-donusum 1.0.115 → 1.0.117

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.
Files changed (25) hide show
  1. package/esm2020/lib/components/hit-despatches/hit-despatch.component.mjs +40 -38
  2. package/esm2020/lib/components/hit-inbound-despatches/hit-inbound-despatch.component.mjs +56 -52
  3. package/esm2020/lib/components/hit-inbound-invoices/hit-inbound-invoice.component.mjs +99 -38
  4. package/esm2020/lib/components/hit-invoices/hit-invoice.component.mjs +46 -42
  5. package/esm2020/lib/components/hit-params-companies/hit-params-company.component.mjs +4 -3
  6. package/esm2020/lib/components/hit-setup-wizard/hit-setup-wizard.component.mjs +2 -2
  7. package/esm2020/lib/hit-proxy/hit-despatches/hit-despatch.service.mjs +5 -28
  8. package/esm2020/lib/hit-proxy/hit-inbound-despatches/hit-inbound-despatch.service.mjs +21 -6
  9. package/esm2020/lib/hit-proxy/hit-inbound-invoices/hit-inbound-invoice.service.mjs +8 -16
  10. package/esm2020/lib/hit-proxy/hit-invoices/hit-invoice.service.mjs +8 -44
  11. package/esm2020/lib/hit-proxy/shared/hit-shared.service.mjs +45 -96
  12. package/fesm2015/hitsoft-e-donusum.mjs +327 -355
  13. package/fesm2015/hitsoft-e-donusum.mjs.map +1 -1
  14. package/fesm2020/hitsoft-e-donusum.mjs +326 -353
  15. package/fesm2020/hitsoft-e-donusum.mjs.map +1 -1
  16. package/lib/components/hit-despatches/hit-despatch.component.d.ts +1 -0
  17. package/lib/components/hit-inbound-despatches/hit-inbound-despatch.component.d.ts +3 -0
  18. package/lib/components/hit-inbound-invoices/hit-inbound-invoice.component.d.ts +4 -0
  19. package/lib/components/hit-invoices/hit-invoice.component.d.ts +5 -1
  20. package/lib/hit-proxy/hit-despatches/hit-despatch.service.d.ts +2 -7
  21. package/lib/hit-proxy/hit-inbound-despatches/hit-inbound-despatch.service.d.ts +5 -1
  22. package/lib/hit-proxy/hit-inbound-invoices/hit-inbound-invoice.service.d.ts +2 -4
  23. package/lib/hit-proxy/hit-invoices/hit-invoice.service.d.ts +2 -11
  24. package/lib/hit-proxy/shared/hit-shared.service.d.ts +1 -1
  25. package/package.json +1 -1
@@ -3,102 +3,51 @@ import * as i0 from "@angular/core";
3
3
  export class HitSharedService {
4
4
  constructor() {
5
5
  this.apiName = 'eDonusum';
6
- /*previewFile = (base64, filename: string = 'fatura.pdf') => {
7
- const cleanBase64 = base64.includes(',') ? base64.split(',')[1] : base64;
8
- const bytes = Uint8Array.from(atob(cleanBase64), c => c.charCodeAt(0));
9
-
10
- // File objesi blob'a filename metadata'sı ekler
11
- const file = new File([bytes], filename, { type: 'application/pdf' });
12
- const url = URL.createObjectURL(file);
13
-
14
- const newTab = window.open('', '_blank');
15
- newTab.history.pushState({}, filename, `/${filename}`);
16
- newTab.document.write(`
17
- <html>
18
- <head><title>${filename}</title></head>
19
- <body style="margin:0;overflow:hidden">
20
- <iframe
21
- src="${url}#toolbar=1"
22
- style="width:100%;height:100vh;border:none;"
23
- ></iframe>
24
- </body>
25
- </html>
26
- `);
27
-
28
- setTimeout(() => URL.revokeObjectURL(url), 60_000);
29
- }*/
30
- this.previewFile = (base64, filename = 'fatura.pdf') => {
6
+ this.previewFile = (base64, fileName = 'fatura.pdf') => {
31
7
  const cleanBase64 = base64.includes(',') ? base64.split(',')[1] : base64;
32
- const bytes = Uint8Array.from(atob(cleanBase64), c => c.charCodeAt(0));
33
- const file = new File([bytes], filename, { type: 'application/pdf' });
34
- const url = URL.createObjectURL(file);
35
- const newTab = window.open('', '_blank');
36
- newTab.history.pushState({}, filename, `/${filename}`);
37
- newTab.document.write(`<!DOCTYPE html>
38
- <html>
39
- <head>
40
- <title>${filename}</title>
41
- <style>
42
- * { margin:0; padding:0; box-sizing:border-box; }
43
- body { background:#525659; font-family:sans-serif; }
44
- #toolbar {
45
- position:fixed; top:0; left:0; right:0; height:48px;
46
- background:#323639; display:flex; align-items:center;
47
- padding:0 16px; gap:16px; z-index:99;
48
- color:white; font-size:14px;
49
- }
50
- #pages { margin-top:56px; display:flex; flex-direction:column; align-items:center; padding:16px; gap:16px; }
51
- canvas { box-shadow:0 2px 8px #0006; background:white; }
52
- </style>
53
- </head>
54
- <body>
55
- <div id="toolbar">
56
- <span>${filename}</span>
57
- <span id="pageInfo"></span>
58
- <button onclick="changePage(-1)" style="background:#555;color:white;border:none;padding:4px 10px;cursor:pointer;border-radius:4px">◀</button>
59
- <button onclick="changePage(1)" style="background:#555;color:white;border:none;padding:4px 10px;cursor:pointer;border-radius:4px">▶</button>
60
- <a href="${url}" download="${filename}"
61
- style="margin-left:auto;background:#1976d2;color:white;padding:6px 14px;border-radius:4px;text-decoration:none">
62
- İndir (${filename})
63
- </a>
64
- </div>
65
- <div id="pages"></div>
66
- <script src="https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.min.js"></script>
67
- <script>
68
- pdfjsLib.GlobalWorkerOptions.workerSrc = 'https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.worker.min.js';
69
- let currentPage = 1, totalPages = 0, pdfDoc = null;
70
-
71
- pdfjsLib.getDocument('${url}').promise.then(pdf => {
72
- pdfDoc = pdf;
73
- totalPages = pdf.numPages;
74
- renderPage(currentPage);
75
- });
76
-
77
- function renderPage(num) {
78
- pdfDoc.getPage(num).then(page => {
79
- const viewport = page.getViewport({ scale: 1.5 });
80
- const canvas = document.createElement('canvas');
81
- canvas.width = viewport.width;
82
- canvas.height = viewport.height;
83
- document.getElementById('pages').innerHTML = '';
84
- document.getElementById('pages').appendChild(canvas);
85
- page.render({ canvasContext: canvas.getContext('2d'), viewport });
86
- document.getElementById('pageInfo').textContent = num + ' / ' + totalPages;
87
- });
88
- }
89
-
90
- function changePage(delta) {
91
- const next = currentPage + delta;
92
- if (next >= 1 && next <= totalPages) {
93
- currentPage = next;
94
- renderPage(currentPage);
95
- }
96
- }
97
- </script>
98
- </body>
99
- </html>
100
- `);
101
- setTimeout(() => URL.revokeObjectURL(url), 60000);
8
+ const dataUrl = `data:application/pdf;base64,${cleanBase64}`;
9
+ const win = window.open('', '_blank');
10
+ if (!win)
11
+ return;
12
+ win.document.open();
13
+ win.document.write(`
14
+ <!doctype html>
15
+ <html>
16
+ <head>
17
+ <title>${fileName}</title>
18
+ <style>
19
+ * { margin: 0; padding: 0; box-sizing: border-box; }
20
+ body { display: flex; flex-direction: column; height: 100vh; font-family: sans-serif; }
21
+ .bar {
22
+ background: #1976d2; color: white;
23
+ padding: 6px 16px; display: flex;
24
+ align-items: center; justify-content: space-between;
25
+ flex-shrink: 0;
26
+ }
27
+ .bar span { font-size: 14px; }
28
+ .bar a {
29
+ color: white; text-decoration: none; font-size: 13px;
30
+ background: rgba(255,255,255,0.2); padding: 4px 14px;
31
+ border-radius: 4px; border: 1px solid rgba(255,255,255,0.4);
32
+ }
33
+ iframe { flex: 1; border: none; width: 100%; }
34
+ </style>
35
+ </head>
36
+ <body>
37
+ <div class="bar">
38
+ <span>📄 ${fileName}</span>
39
+ <a id="dlBtn" download="${fileName}">⬇ İndir</a>
40
+ </div>
41
+ <iframe id="previewFrame"></iframe>
42
+ <script>
43
+ const dataUrl = ${JSON.stringify(dataUrl)};
44
+ document.getElementById('previewFrame').src = dataUrl;
45
+ document.getElementById('dlBtn').href = dataUrl;
46
+ </script>
47
+ </body>
48
+ </html>
49
+ `);
50
+ win.document.close();
102
51
  };
103
52
  }
104
53
  }
@@ -110,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
110
59
  providedIn: 'root',
111
60
  }]
112
61
  }] });
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hit-shared.service.js","sourceRoot":"","sources":["../../../../../../projects/e-donusum/src/lib/hit-proxy/shared/hit-shared.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;AAO3C,MAAM,OAAO,gBAAgB;IAH7B;QAII,YAAO,GAAG,UAAU,CAAC;QAEvB;;;;;;;;;;;;;;;;;;;;;;;SAuBC;QAEH,gBAAW,GAAG,CAAC,MAAM,EAAE,WAAmB,YAAY,EAAE,EAAE;YACtD,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;YACzE,MAAM,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;YACvE,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,CAAC,CAAC;YACtE,MAAM,GAAG,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAEtC,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;YACzC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,QAAQ,EAAE,CAAC,CAAC;YACvD,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;;;qBAGL,QAAQ;;;;;;;;;;;;;;;;wBAgBL,QAAQ;;;;2BAIL,GAAG,eAAe,QAAQ;;8BAEvB,QAAQ;;;;;;;;;wCASE,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA6BtC,CAAC,CAAC;YAEH,UAAU,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,KAAM,CAAC,CAAC;QACvD,CAAC,CAAA;KAGA;;6GAzGY,gBAAgB;iHAAhB,gBAAgB,cAFb,MAAM;2FAET,gBAAgB;kBAH5B,UAAU;mBAAC;oBACR,UAAU,EAAE,MAAM;iBACrB","sourcesContent":["\r\nimport { RestService } from \"@abp/ng.core\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { DevexpressRestService } from \"../devexpress-query-builder/devexpress-query-builder\";\r\n\r\n \r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class HitSharedService {\r\n    apiName = 'eDonusum';\r\n\r\n  /*previewFile = (base64, filename: string = 'fatura.pdf') => {\r\n    const cleanBase64 = base64.includes(',') ? base64.split(',')[1] : base64;\r\n    const bytes = Uint8Array.from(atob(cleanBase64), c => c.charCodeAt(0));\r\n    \r\n    // File objesi blob'a filename metadata'sı ekler\r\n    const file = new File([bytes], filename, { type: 'application/pdf' });\r\n    const url = URL.createObjectURL(file);\r\n\r\n    const newTab = window.open('', '_blank');\r\n    newTab.history.pushState({}, filename, `/${filename}`);\r\n    newTab.document.write(`\r\n        <html>\r\n        <head><title>${filename}</title></head>\r\n        <body style=\"margin:0;overflow:hidden\">\r\n            <iframe \r\n                src=\"${url}#toolbar=1\" \r\n                style=\"width:100%;height:100vh;border:none;\"\r\n            ></iframe>\r\n        </body>\r\n        </html>\r\n    `);\r\n\r\n    setTimeout(() => URL.revokeObjectURL(url), 60_000);\r\n}*/\r\n\r\npreviewFile = (base64, filename: string = 'fatura.pdf') => {\r\n    const cleanBase64 = base64.includes(',') ? base64.split(',')[1] : base64;\r\n    const bytes = Uint8Array.from(atob(cleanBase64), c => c.charCodeAt(0));\r\n    const file = new File([bytes], filename, { type: 'application/pdf' });\r\n    const url = URL.createObjectURL(file);\r\n\r\n    const newTab = window.open('', '_blank');\r\n    newTab.history.pushState({}, filename, `/${filename}`);\r\n    newTab.document.write(`<!DOCTYPE html>\r\n        <html>\r\n        <head>\r\n            <title>${filename}</title>\r\n            <style>\r\n                * { margin:0; padding:0; box-sizing:border-box; }\r\n                body { background:#525659; font-family:sans-serif; }\r\n                #toolbar { \r\n                    position:fixed; top:0; left:0; right:0; height:48px;\r\n                    background:#323639; display:flex; align-items:center; \r\n                    padding:0 16px; gap:16px; z-index:99;\r\n                    color:white; font-size:14px;\r\n                }\r\n                #pages { margin-top:56px; display:flex; flex-direction:column; align-items:center; padding:16px; gap:16px; }\r\n                canvas { box-shadow:0 2px 8px #0006; background:white; }\r\n            </style>\r\n        </head>\r\n        <body>\r\n            <div id=\"toolbar\">\r\n                <span>${filename}</span>\r\n                <span id=\"pageInfo\"></span>\r\n                <button onclick=\"changePage(-1)\" style=\"background:#555;color:white;border:none;padding:4px 10px;cursor:pointer;border-radius:4px\">◀</button>\r\n                <button onclick=\"changePage(1)\" style=\"background:#555;color:white;border:none;padding:4px 10px;cursor:pointer;border-radius:4px\">▶</button>\r\n                <a href=\"${url}\" download=\"${filename}\" \r\n                   style=\"margin-left:auto;background:#1976d2;color:white;padding:6px 14px;border-radius:4px;text-decoration:none\">\r\n                   ⬇ İndir (${filename})\r\n                </a>\r\n            </div>\r\n            <div id=\"pages\"></div>\r\n            <script src=\"https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.min.js\"></script>\r\n            <script>\r\n                pdfjsLib.GlobalWorkerOptions.workerSrc = 'https://cdnjs.cloudflare.com/ajax/libs/pdf.js/3.11.174/pdf.worker.min.js';\r\n                let currentPage = 1, totalPages = 0, pdfDoc = null;\r\n\r\n                pdfjsLib.getDocument('${url}').promise.then(pdf => {\r\n                    pdfDoc = pdf;\r\n                    totalPages = pdf.numPages;\r\n                    renderPage(currentPage);\r\n                });\r\n\r\n                function renderPage(num) {\r\n                    pdfDoc.getPage(num).then(page => {\r\n                        const viewport = page.getViewport({ scale: 1.5 });\r\n                        const canvas = document.createElement('canvas');\r\n                        canvas.width = viewport.width;\r\n                        canvas.height = viewport.height;\r\n                        document.getElementById('pages').innerHTML = '';\r\n                        document.getElementById('pages').appendChild(canvas);\r\n                        page.render({ canvasContext: canvas.getContext('2d'), viewport });\r\n                        document.getElementById('pageInfo').textContent = num + ' / ' + totalPages;\r\n                    });\r\n                }\r\n\r\n                function changePage(delta) {\r\n                    const next = currentPage + delta;\r\n                    if (next >= 1 && next <= totalPages) {\r\n                        currentPage = next;\r\n                        renderPage(currentPage);\r\n                    }\r\n                }\r\n            </script>\r\n        </body>\r\n        </html>\r\n    `);\r\n\r\n    setTimeout(() => URL.revokeObjectURL(url), 60_000);\r\n}\r\n\r\n\r\n}\r\n\r\n"]}
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGl0LXNoYXJlZC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZS1kb251c3VtL3NyYy9saWIvaGl0LXByb3h5L3NoYXJlZC9oaXQtc2hhcmVkLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUg3QjtRQUlJLFlBQU8sR0FBRyxVQUFVLENBQUM7UUFFdEIsZ0JBQVcsR0FBRyxDQUFDLE1BQU0sRUFBRSxRQUFRLEdBQUcsWUFBWSxFQUFFLEVBQUU7WUFDbkQsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO1lBRXpFLE1BQU0sT0FBTyxHQUFHLCtCQUErQixXQUFXLEVBQUUsQ0FBQztZQUU3RCxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUN0QyxJQUFJLENBQUMsR0FBRztnQkFBRSxPQUFPO1lBRWpCLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDcEIsR0FBRyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUM7Ozs7aUJBSUosUUFBUTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O3FCQXFCSixRQUFRO29DQUNPLFFBQVE7Ozs7NEJBSWhCLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDOzs7Ozs7R0FNaEQsQ0FBQyxDQUFDO1lBQ0gsR0FBRyxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN2QixDQUFDLENBQUE7S0FFQTs7NkdBcERZLGdCQUFnQjtpSEFBaEIsZ0JBQWdCLGNBRmIsTUFBTTsyRkFFVCxnQkFBZ0I7a0JBSDVCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmltcG9ydCB7IFJlc3RTZXJ2aWNlIH0gZnJvbSBcIkBhYnAvbmcuY29yZVwiO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgRGV2ZXhwcmVzc1Jlc3RTZXJ2aWNlIH0gZnJvbSBcIi4uL2RldmV4cHJlc3MtcXVlcnktYnVpbGRlci9kZXZleHByZXNzLXF1ZXJ5LWJ1aWxkZXJcIjtcclxuXHJcbiBcclxuQEluamVjdGFibGUoe1xyXG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSGl0U2hhcmVkU2VydmljZSB7XHJcbiAgICBhcGlOYW1lID0gJ2VEb251c3VtJztcclxuXHJcbiAgIHByZXZpZXdGaWxlID0gKGJhc2U2NCwgZmlsZU5hbWUgPSAnZmF0dXJhLnBkZicpID0+IHtcclxuICBjb25zdCBjbGVhbkJhc2U2NCA9IGJhc2U2NC5pbmNsdWRlcygnLCcpID8gYmFzZTY0LnNwbGl0KCcsJylbMV0gOiBiYXNlNjQ7XHJcblxyXG4gIGNvbnN0IGRhdGFVcmwgPSBgZGF0YTphcHBsaWNhdGlvbi9wZGY7YmFzZTY0LCR7Y2xlYW5CYXNlNjR9YDtcclxuXHJcbiAgY29uc3Qgd2luID0gd2luZG93Lm9wZW4oJycsICdfYmxhbmsnKTtcclxuICBpZiAoIXdpbikgcmV0dXJuO1xyXG5cclxuICB3aW4uZG9jdW1lbnQub3BlbigpO1xyXG4gIHdpbi5kb2N1bWVudC53cml0ZShgXHJcbiAgICA8IWRvY3R5cGUgaHRtbD5cclxuICAgIDxodG1sPlxyXG4gICAgICA8aGVhZD5cclxuICAgICAgICA8dGl0bGU+JHtmaWxlTmFtZX08L3RpdGxlPlxyXG4gICAgICAgICAgPHN0eWxlPlxyXG4gICAgICAgICAgKiB7IG1hcmdpbjogMDsgcGFkZGluZzogMDsgYm94LXNpemluZzogYm9yZGVyLWJveDsgfVxyXG4gICAgICAgICAgYm9keSB7IGRpc3BsYXk6IGZsZXg7IGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47IGhlaWdodDogMTAwdmg7IGZvbnQtZmFtaWx5OiBzYW5zLXNlcmlmOyB9XHJcbiAgICAgICAgICAuYmFyIHtcclxuICAgICAgICAgICAgYmFja2dyb3VuZDogIzE5NzZkMjsgY29sb3I6IHdoaXRlO1xyXG4gICAgICAgICAgICBwYWRkaW5nOiA2cHggMTZweDsgZGlzcGxheTogZmxleDtcclxuICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjsganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xyXG4gICAgICAgICAgICBmbGV4LXNocmluazogMDtcclxuICAgICAgICAgIH1cclxuICAgICAgICAgIC5iYXIgc3BhbiB7IGZvbnQtc2l6ZTogMTRweDsgfVxyXG4gICAgICAgICAgLmJhciBhIHtcclxuICAgICAgICAgICAgY29sb3I6IHdoaXRlOyB0ZXh0LWRlY29yYXRpb246IG5vbmU7IGZvbnQtc2l6ZTogMTNweDtcclxuICAgICAgICAgICAgYmFja2dyb3VuZDogcmdiYSgyNTUsMjU1LDI1NSwwLjIpOyBwYWRkaW5nOiA0cHggMTRweDtcclxuICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogNHB4OyBib3JkZXI6IDFweCBzb2xpZCByZ2JhKDI1NSwyNTUsMjU1LDAuNCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICBpZnJhbWUgeyBmbGV4OiAxOyBib3JkZXI6IG5vbmU7IHdpZHRoOiAxMDAlOyB9XHJcbiAgICAgICAgPC9zdHlsZT5cclxuICAgICAgPC9oZWFkPlxyXG4gICAgIDxib2R5PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJiYXJcIj5cclxuICAgICAgICAgIDxzcGFuPvCfk4QgJHtmaWxlTmFtZX08L3NwYW4+XHJcbiAgICAgICAgICA8YSBpZD1cImRsQnRuXCIgZG93bmxvYWQ9XCIke2ZpbGVOYW1lfVwiPuKshyDEsG5kaXI8L2E+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGlmcmFtZSBpZD1cInByZXZpZXdGcmFtZVwiPjwvaWZyYW1lPlxyXG4gICAgICAgIDxzY3JpcHQ+XHJcbiAgICAgICAgICBjb25zdCBkYXRhVXJsID0gJHtKU09OLnN0cmluZ2lmeShkYXRhVXJsKX07XHJcbiAgICAgICAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgncHJldmlld0ZyYW1lJykuc3JjID0gZGF0YVVybDtcclxuICAgICAgICAgIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdkbEJ0bicpLmhyZWYgPSBkYXRhVXJsO1xyXG4gICAgICAgIDwvc2NyaXB0PlxyXG4gICAgICA8L2JvZHk+XHJcbiAgICA8L2h0bWw+XHJcbiAgYCk7XHJcbiAgd2luLmRvY3VtZW50LmNsb3NlKCk7XHJcbn1cclxuICAgICBcclxufVxyXG4iXX0=