ng-zorro-antd-extension 17.0.2 → 17.2.0

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 (38) hide show
  1. package/README.md +1 -0
  2. package/configurable-query/configurable-query.component.d.ts +13 -14
  3. package/configurable-query/type.d.ts +2 -2
  4. package/esm2022/configurable-query/configurable-query.component.mjs +66 -42
  5. package/esm2022/configurable-query/type.mjs +1 -1
  6. package/esm2022/print/ng-zorro-antd-extension-print.mjs +5 -0
  7. package/esm2022/print/nzx-print-content.directive.mjs +22 -0
  8. package/esm2022/print/nzx-print-v.component.mjs +300 -0
  9. package/esm2022/print/nzx-print.component.mjs +189 -0
  10. package/esm2022/print/nzx-print.directive.mjs +91 -0
  11. package/esm2022/print/nzx-print.module.mjs +39 -0
  12. package/esm2022/print/public-api.mjs +10 -0
  13. package/esm2022/table-select/page-table-select/page-table-select.component.mjs +3 -3
  14. package/esm2022/table-select/table-select/table-select.component.mjs +3 -3
  15. package/esm2022/util/lib/getElementByTag.mjs +31 -0
  16. package/esm2022/util/public-api.mjs +2 -1
  17. package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs +64 -40
  18. package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs.map +1 -1
  19. package/fesm2022/ng-zorro-antd-extension-print.mjs +637 -0
  20. package/fesm2022/ng-zorro-antd-extension-print.mjs.map +1 -0
  21. package/fesm2022/ng-zorro-antd-extension-table-select.mjs +4 -4
  22. package/fesm2022/ng-zorro-antd-extension-table-select.mjs.map +1 -1
  23. package/fesm2022/ng-zorro-antd-extension-util.mjs +32 -1
  24. package/fesm2022/ng-zorro-antd-extension-util.mjs.map +1 -1
  25. package/package.json +14 -7
  26. package/pipes/safe-url.pipe.d.ts +1 -1
  27. package/print/index.d.ts +5 -0
  28. package/print/nzx-print-content.directive.d.ts +10 -0
  29. package/print/nzx-print-v.component.d.ts +45 -0
  30. package/print/nzx-print.component.d.ts +34 -0
  31. package/print/nzx-print.directive.d.ts +17 -0
  32. package/print/nzx-print.module.d.ts +13 -0
  33. package/print/public-api.d.ts +9 -0
  34. package/public-api.d.ts +1 -1
  35. package/table-select/abstract-table-select.d.ts +1 -1
  36. package/timer-button/timer-button.directive.d.ts +1 -1
  37. package/util/lib/getElementByTag.d.ts +8 -0
  38. package/util/public-api.d.ts +1 -0
@@ -0,0 +1,300 @@
1
+ import { Component, ContentChildren, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { CoreViewer, Navigation, PageViewMode, } from '@vivliostyle/core';
3
+ import { NzxPrintContentDirective } from './nzx-print-content.directive';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "ng-zorro-antd/grid";
7
+ import * as i3 from "ng-zorro-antd/pagination";
8
+ /**
9
+ * Vivliostyle 打印
10
+ */
11
+ export class NzxPrintVComponent {
12
+ constructor(cd) {
13
+ this.cd = cd;
14
+ this.printTitle = 'pdf';
15
+ /**
16
+ * a4 794px1123px
17
+ */
18
+ this.width = 814;
19
+ this.height = 1143;
20
+ this.enablePreview = true;
21
+ this.pixelRatio = 8;
22
+ this.pageRenderComplete = new EventEmitter();
23
+ this.pageTotal = 0;
24
+ this._title = document.title;
25
+ this._isRenderComplete = false;
26
+ this.handleError = (payload) => {
27
+ console.log('error::', payload);
28
+ };
29
+ this.handleReadyStateChange = (payload) => {
30
+ this._isRenderComplete = false;
31
+ this.pageRenderComplete.emit(false);
32
+ if (this.viewer && this.viewer.readyState === 'complete') {
33
+ const intervalTag = setInterval(() => {
34
+ if (this.iframeEl &&
35
+ this.iframeEl.contentWindow &&
36
+ this.iframeEl.contentWindow.document) {
37
+ const images = this.iframeEl.contentWindow.document.getElementsByTagName('img');
38
+ let allImagesLoaded = true;
39
+ for (let i = 0; i < images.length; i++) {
40
+ if (!images[i].complete) {
41
+ allImagesLoaded = false;
42
+ break;
43
+ }
44
+ }
45
+ if (allImagesLoaded) {
46
+ console.log('All images in iframe loaded successfully');
47
+ this.pageRenderComplete.emit(true);
48
+ this._isRenderComplete = true;
49
+ clearInterval(intervalTag);
50
+ }
51
+ }
52
+ }, 1000);
53
+ }
54
+ };
55
+ this.handleHyperlink = (payload) => {
56
+ console.log('handleHyperlink::', payload);
57
+ };
58
+ this.handleLoaded = (payload) => {
59
+ console.log('handleLoaded::', payload);
60
+ };
61
+ this.handleNavigation = (payload) => {
62
+ this.pageTotal = payload.epageCount;
63
+ this.cd.markForCheck();
64
+ };
65
+ }
66
+ ngAfterViewInit() {
67
+ setTimeout(() => {
68
+ this.createIframeWrapper();
69
+ }, 1000);
70
+ }
71
+ ngOnDestroy() {
72
+ if (this.viewer) {
73
+ this.clearView();
74
+ }
75
+ }
76
+ onPageIndexChange(num) {
77
+ if (this.viewer) {
78
+ this.viewer.navigateToPage(Navigation.EPAGE, num - 1);
79
+ }
80
+ }
81
+ print() {
82
+ if (this._isRenderComplete) {
83
+ this.iframeEl.contentWindow.print();
84
+ }
85
+ else {
86
+ console.warn('rending...');
87
+ }
88
+ }
89
+ refresh() {
90
+ setTimeout(() => {
91
+ this.createIframeWrapper();
92
+ }, 100);
93
+ }
94
+ createIframeWrapper() {
95
+ if (this.vivViewRef) {
96
+ this.clearView();
97
+ this.iframeEl = document.createElement('iframe');
98
+ this.iframeEl.height = this.height + '';
99
+ this.iframeEl.width = this.width + '';
100
+ this.iframeEl.style.border = '1px solid #ccc';
101
+ this.iframeEl.style.background = '#fff';
102
+ const template = `
103
+ <!DOCTYPE html>
104
+ <html data-vivliostyle-paginated="true">
105
+ <head>
106
+ <meta charset="utf-8" />
107
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
108
+ <base href="/" />
109
+ <title>${this.printTitle}</title>
110
+ <style>
111
+ html[data-vivliostyle-paginated] {
112
+ width: 100%;
113
+ height: 100%;
114
+ }
115
+ html[data-vivliostyle-paginated] body,
116
+ html[data-vivliostyle-paginated] [data-vivliostyle-viewer-viewport] {
117
+ width: 100% !important;
118
+ height: 100% !important;
119
+ background: #fff;
120
+ }
121
+ html[data-vivliostyle-paginated],
122
+ html[data-vivliostyle-paginated] body {
123
+ margin: 0;
124
+ padding: 0;
125
+ }
126
+ </style>
127
+ <style id="vivliostyle-page-rules"></style>
128
+ </head>
129
+ <body>
130
+ <div id="vivliostyle-viewer-viewport"></div>
131
+ </body>
132
+ </html>
133
+ `;
134
+ this.iframeEl.srcdoc = template;
135
+ this.vivViewRef.nativeElement.appendChild(this.iframeEl);
136
+ this.iframeEl.contentWindow.onbeforeprint = () => {
137
+ this.iframeEl.contentWindow.parent.document.title = this.printTitle;
138
+ };
139
+ this.iframeEl.contentWindow.onafterprint = () => {
140
+ this.iframeEl.contentWindow.parent.document.title = this._title;
141
+ };
142
+ this.createVivViewer();
143
+ }
144
+ }
145
+ createVivViewer() {
146
+ this.iframeEl.onload = () => {
147
+ const els = this._printElQueryList.toArray();
148
+ const templates = this.getVivTemplates(els);
149
+ const options = [];
150
+ templates.forEach((template) => {
151
+ const docBlob = new Blob([template], {
152
+ type: 'text/html',
153
+ });
154
+ const docURL = URL.createObjectURL(docBlob);
155
+ options.push({ url: docURL });
156
+ });
157
+ this.viewer = new CoreViewer({
158
+ viewportElement: this.iframeEl.contentWindow?.document.body
159
+ .firstElementChild,
160
+ }, {
161
+ pageViewMode: PageViewMode.SINGLE_PAGE,
162
+ pixelRatio: this.pixelRatio,
163
+ });
164
+ this.viewer.loadDocument(options);
165
+ this.createListener(this.viewer);
166
+ };
167
+ }
168
+ createListener(viewer) {
169
+ viewer.addListener('error', this.handleError);
170
+ viewer.addListener('readystatechange', this.handleReadyStateChange);
171
+ viewer.addListener('loaded', this.handleLoaded);
172
+ viewer.addListener('hyperlink', this.handleHyperlink);
173
+ viewer.addListener('nav', this.handleNavigation);
174
+ }
175
+ removeListeners(viewer) {
176
+ viewer.removeListener('error', this.handleError);
177
+ viewer.removeListener('readystatechange', this.handleReadyStateChange);
178
+ viewer.removeListener('loaded', this.handleLoaded);
179
+ viewer.removeListener('hyperlink', this.handleHyperlink);
180
+ viewer.removeListener('nav', this.handleNavigation);
181
+ }
182
+ getStyles(identifierStr) {
183
+ const stylesArray = [];
184
+ const styleElements = document.getElementsByTagName('style');
185
+ const length = styleElements.length;
186
+ let identifiers = [];
187
+ if (Array.isArray(identifierStr)) {
188
+ identifiers = [...identifierStr];
189
+ }
190
+ else {
191
+ identifiers = [identifierStr];
192
+ }
193
+ for (let index = 0; index < length; index++) {
194
+ identifiers.forEach((s) => {
195
+ if (styleElements[index].outerHTML.includes(s)) {
196
+ const formateStr = styleElements[index].outerHTML.replace(/\/\*[\s\S]*?\*\//g, '');
197
+ stylesArray.push(formateStr);
198
+ }
199
+ });
200
+ }
201
+ return stylesArray.join('\r\n');
202
+ }
203
+ getVivTemplates(directives) {
204
+ const templates = [];
205
+ directives.forEach((d) => {
206
+ let styles = '';
207
+ if (d.identifierStr || d.identifierStr.length > 0) {
208
+ styles = this.getStyles(d.identifierStr);
209
+ }
210
+ const html = `
211
+ <!DOCTYPE html>
212
+ <html>
213
+ <head>
214
+ <meta charset="utf-8" />
215
+ <title>${this.printTitle}</title>
216
+ <base href="/" />
217
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
218
+ ${d.customStyle}
219
+ ${styles}
220
+ </head>
221
+ <body>
222
+ ${d.elementRef.nativeElement.outerHTML}
223
+ </body>
224
+ </html>
225
+ `;
226
+ templates.push(html);
227
+ });
228
+ return templates;
229
+ }
230
+ clearView() {
231
+ if (this.viewer) {
232
+ this.removeListeners(this.viewer);
233
+ }
234
+ this.vivViewRef.nativeElement.innerHTML = '';
235
+ this.viewer = undefined;
236
+ this._isRenderComplete = false;
237
+ }
238
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintVComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
239
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintVComponent, selector: "nzx-print-v", inputs: { printTitle: "printTitle", width: "width", height: "height", enablePreview: "enablePreview", pixelRatio: "pixelRatio" }, outputs: { pageRenderComplete: "pageRenderComplete" }, queries: [{ propertyName: "_printElQueryList", predicate: NzxPrintContentDirective }], viewQueries: [{ propertyName: "vivViewRef", first: true, predicate: ["vivView"], descendants: true }], ngImport: i0, template: `
240
+ <ng-content select="[nzxPrintHeader]"></ng-content>
241
+
242
+ <div #vivView [ngStyle]="{ margin: '10px 0' }"></div>
243
+
244
+ <div nz-row nzJustify="end">
245
+ <ng-template #totalTemplate let-total>共 {{ total }} 页</ng-template>
246
+ <nz-pagination
247
+ [nzPageIndex]="1"
248
+ [nzTotal]="pageTotal"
249
+ [nzPageSize]="1"
250
+ [nzSize]="'small'"
251
+ [nzShowTotal]="totalTemplate"
252
+ nzShowQuickJumper
253
+ (nzPageIndexChange)="onPageIndexChange($event)"
254
+ ></nz-pagination>
255
+ </div>
256
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "component", type: i3.NzPaginationComponent, selector: "nz-pagination", inputs: ["nzShowTotal", "nzItemRender", "nzSize", "nzPageSizeOptions", "nzShowSizeChanger", "nzShowQuickJumper", "nzSimple", "nzDisabled", "nzResponsive", "nzHideOnSinglePage", "nzTotal", "nzPageIndex", "nzPageSize"], outputs: ["nzPageSizeChange", "nzPageIndexChange"], exportAs: ["nzPagination"] }] }); }
257
+ }
258
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintVComponent, decorators: [{
259
+ type: Component,
260
+ args: [{
261
+ selector: 'nzx-print-v',
262
+ template: `
263
+ <ng-content select="[nzxPrintHeader]"></ng-content>
264
+
265
+ <div #vivView [ngStyle]="{ margin: '10px 0' }"></div>
266
+
267
+ <div nz-row nzJustify="end">
268
+ <ng-template #totalTemplate let-total>共 {{ total }} 页</ng-template>
269
+ <nz-pagination
270
+ [nzPageIndex]="1"
271
+ [nzTotal]="pageTotal"
272
+ [nzPageSize]="1"
273
+ [nzSize]="'small'"
274
+ [nzShowTotal]="totalTemplate"
275
+ nzShowQuickJumper
276
+ (nzPageIndexChange)="onPageIndexChange($event)"
277
+ ></nz-pagination>
278
+ </div>
279
+ `,
280
+ }]
281
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { printTitle: [{
282
+ type: Input
283
+ }], width: [{
284
+ type: Input
285
+ }], height: [{
286
+ type: Input
287
+ }], enablePreview: [{
288
+ type: Input
289
+ }], pixelRatio: [{
290
+ type: Input
291
+ }], pageRenderComplete: [{
292
+ type: Output
293
+ }], vivViewRef: [{
294
+ type: ViewChild,
295
+ args: ['vivView']
296
+ }], _printElQueryList: [{
297
+ type: ContentChildren,
298
+ args: [NzxPrintContentDirective]
299
+ }] } });
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nzx-print-v.component.js","sourceRoot":"","sources":["../../../../components/print/nzx-print-v.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tChangeDetectorRef,\n\tComponent,\n\tContentChildren,\n\tElementRef,\n\tEventEmitter,\n\tInput,\n\tOnDestroy,\n\tOutput,\n\tQueryList,\n\tViewChild,\n} from '@angular/core';\nimport {\n\tCoreViewer,\n\tNavigation,\n\tPageViewMode,\n\tPayload,\n\tSingleDocumentOptions,\n} from '@vivliostyle/core';\nimport { NzxPrintContentDirective } from './nzx-print-content.directive';\n\n/**\n * Vivliostyle 打印\n */\n@Component({\n\tselector: 'nzx-print-v',\n\ttemplate: `\n\t\t<ng-content select=\"[nzxPrintHeader]\"></ng-content>\n\n\t\t<div #vivView [ngStyle]=\"{ margin: '10px 0' }\"></div>\n\n\t\t<div nz-row nzJustify=\"end\">\n\t\t\t<ng-template #totalTemplate let-total>共 {{ total }} 页</ng-template>\n\t\t\t<nz-pagination\n\t\t\t\t[nzPageIndex]=\"1\"\n\t\t\t\t[nzTotal]=\"pageTotal\"\n\t\t\t\t[nzPageSize]=\"1\"\n\t\t\t\t[nzSize]=\"'small'\"\n\t\t\t\t[nzShowTotal]=\"totalTemplate\"\n\t\t\t\tnzShowQuickJumper\n\t\t\t\t(nzPageIndexChange)=\"onPageIndexChange($event)\"\n\t\t\t></nz-pagination>\n\t\t</div>\n\t`,\n})\nexport class NzxPrintVComponent implements OnDestroy, AfterViewInit {\n\t@Input() printTitle = 'pdf';\n\t/**\n\t * a4 794px1123px\n\t */\n\t@Input() width = 814;\n\t@Input() height = 1143;\n\t@Input() enablePreview = true;\n\t@Input() pixelRatio = 8;\n\t@Output() pageRenderComplete = new EventEmitter<boolean>();\n\n\tviewer: CoreViewer | undefined;\n\tpageTotal = 0;\n\n\t@ViewChild('vivView')\n\tprivate vivViewRef!: ElementRef<HTMLDivElement>;\n\n\t@ContentChildren(NzxPrintContentDirective)\n\tprivate _printElQueryList!: QueryList<NzxPrintContentDirective>;\n\tprivate _title = document.title;\n\tprivate iframeEl!: HTMLIFrameElement;\n\tprivate _isRenderComplete = false;\n\n\tconstructor(private cd: ChangeDetectorRef) {}\n\n\tngAfterViewInit(): void {\n\t\tsetTimeout(() => {\n\t\t\tthis.createIframeWrapper();\n\t\t}, 1000);\n\t}\n\n\tngOnDestroy(): void {\n\t\tif (this.viewer) {\n\t\t\tthis.clearView();\n\t\t}\n\t}\n\n\tonPageIndexChange(num: number) {\n\t\tif (this.viewer) {\n\t\t\tthis.viewer.navigateToPage(Navigation.EPAGE, num - 1);\n\t\t}\n\t}\n\n\tprint() {\n\t\tif (this._isRenderComplete) {\n\t\t\tthis.iframeEl.contentWindow!.print();\n\t\t} else {\n\t\t\tconsole.warn('rending...');\n\t\t}\n\t}\n\n\trefresh() {\n\t\tsetTimeout(() => {\n\t\t\tthis.createIframeWrapper();\n\t\t}, 100);\n\t}\n\n\tprivate createIframeWrapper() {\n\t\tif (this.vivViewRef) {\n\t\t\tthis.clearView();\n\n\t\t\tthis.iframeEl = document.createElement('iframe');\n\t\t\tthis.iframeEl.height = this.height + '';\n\t\t\tthis.iframeEl.width = this.width + '';\n\t\t\tthis.iframeEl.style.border = '1px solid #ccc';\n\t\t\tthis.iframeEl.style.background = '#fff';\n\n\t\t\tconst template = `\n        <!DOCTYPE html>\n        <html data-vivliostyle-paginated=\"true\">\n          <head>\n            <meta charset=\"utf-8\" />\n            <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\" />\n            <base href=\"/\" />\n            <title>${this.printTitle}</title>\n            <style>\n              html[data-vivliostyle-paginated] {\n                width: 100%;\n                height: 100%;\n              }\n              html[data-vivliostyle-paginated] body,\n              html[data-vivliostyle-paginated] [data-vivliostyle-viewer-viewport] {\n                width: 100% !important;\n                height: 100% !important;\n                background: #fff;\n              }\n              html[data-vivliostyle-paginated],\n              html[data-vivliostyle-paginated] body {\n                margin: 0;\n                padding: 0;\n              }\n            </style>\n            <style id=\"vivliostyle-page-rules\"></style>\n          </head>\n          <body>\n            <div id=\"vivliostyle-viewer-viewport\"></div>\n          </body>\n        </html>\n      `;\n\n\t\t\tthis.iframeEl.srcdoc = template;\n\t\t\tthis.vivViewRef.nativeElement.appendChild(this.iframeEl);\n\t\t\tthis.iframeEl.contentWindow!.onbeforeprint = () => {\n\t\t\t\tthis.iframeEl.contentWindow!.parent.document.title = this.printTitle;\n\t\t\t};\n\t\t\tthis.iframeEl.contentWindow!.onafterprint = () => {\n\t\t\t\tthis.iframeEl.contentWindow!.parent.document.title = this._title;\n\t\t\t};\n\t\t\tthis.createVivViewer();\n\t\t}\n\t}\n\n\tprivate createVivViewer() {\n\t\tthis.iframeEl.onload = () => {\n\t\t\tconst els: NzxPrintContentDirective[] = this._printElQueryList.toArray();\n\t\t\tconst templates = this.getVivTemplates(els);\n\t\t\tconst options: SingleDocumentOptions[] = [];\n\t\t\ttemplates.forEach((template) => {\n\t\t\t\tconst docBlob = new Blob([template], {\n\t\t\t\t\ttype: 'text/html',\n\t\t\t\t});\n\t\t\t\tconst docURL = URL.createObjectURL(docBlob);\n\t\t\t\toptions.push({ url: docURL });\n\t\t\t});\n\t\t\tthis.viewer = new CoreViewer(\n\t\t\t\t{\n\t\t\t\t\tviewportElement: this.iframeEl.contentWindow?.document.body\n\t\t\t\t\t\t.firstElementChild as HTMLElement,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tpageViewMode: PageViewMode.SINGLE_PAGE,\n\t\t\t\t\tpixelRatio: this.pixelRatio,\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.viewer.loadDocument(options);\n\t\t\tthis.createListener(this.viewer);\n\t\t};\n\t}\n\n\tprivate handleError = (payload: Payload) => {\n\t\tconsole.log('error::', payload);\n\t};\n\n\tprivate handleReadyStateChange = (payload: Payload) => {\n\t\tthis._isRenderComplete = false;\n\t\tthis.pageRenderComplete.emit(false);\n\t\tif (this.viewer && this.viewer.readyState === 'complete') {\n\t\t\tconst intervalTag = setInterval(() => {\n\t\t\t\tif (\n\t\t\t\t\tthis.iframeEl &&\n\t\t\t\t\tthis.iframeEl.contentWindow &&\n\t\t\t\t\tthis.iframeEl.contentWindow.document\n\t\t\t\t) {\n\t\t\t\t\tconst images =\n\t\t\t\t\t\tthis.iframeEl.contentWindow.document.getElementsByTagName('img');\n\n\t\t\t\t\tlet allImagesLoaded = true;\n\t\t\t\t\tfor (let i = 0; i < images.length; i++) {\n\t\t\t\t\t\tif (!images[i].complete) {\n\t\t\t\t\t\t\tallImagesLoaded = false;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif (allImagesLoaded) {\n\t\t\t\t\t\tconsole.log('All images in iframe loaded successfully');\n\t\t\t\t\t\tthis.pageRenderComplete.emit(true);\n\t\t\t\t\t\tthis._isRenderComplete = true;\n\t\t\t\t\t\tclearInterval(intervalTag);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}, 1000);\n\t\t}\n\t};\n\n\tprivate handleHyperlink = (payload: Payload) => {\n\t\tconsole.log('handleHyperlink::', payload);\n\t};\n\n\tprivate handleLoaded = (payload: Payload) => {\n\t\tconsole.log('handleLoaded::', payload);\n\t};\n\n\tprivate handleNavigation = (payload: Payload) => {\n\t\tthis.pageTotal = payload.epageCount;\n\t\tthis.cd.markForCheck();\n\t};\n\n\tprivate createListener(viewer: CoreViewer) {\n\t\tviewer.addListener('error', this.handleError);\n\t\tviewer.addListener('readystatechange', this.handleReadyStateChange);\n\t\tviewer.addListener('loaded', this.handleLoaded);\n\t\tviewer.addListener('hyperlink', this.handleHyperlink);\n\t\tviewer.addListener('nav', this.handleNavigation);\n\t}\n\n\tprivate removeListeners(viewer: CoreViewer) {\n\t\tviewer.removeListener('error', this.handleError);\n\t\tviewer.removeListener('readystatechange', this.handleReadyStateChange);\n\t\tviewer.removeListener('loaded', this.handleLoaded);\n\t\tviewer.removeListener('hyperlink', this.handleHyperlink);\n\t\tviewer.removeListener('nav', this.handleNavigation);\n\t}\n\n\tprivate getStyles(identifierStr: string | string[]): string {\n\t\tconst stylesArray: string[] = [];\n\t\tconst styleElements = document.getElementsByTagName('style');\n\t\tconst length = styleElements.length;\n\t\tlet identifiers: string[] = [];\n\t\tif (Array.isArray(identifierStr)) {\n\t\t\tidentifiers = [...identifierStr];\n\t\t} else {\n\t\t\tidentifiers = [identifierStr];\n\t\t}\n\t\tfor (let index = 0; index < length; index++) {\n\t\t\tidentifiers.forEach((s) => {\n\t\t\t\tif (styleElements[index].outerHTML.includes(s)) {\n\t\t\t\t\tconst formateStr = styleElements[index].outerHTML.replace(\n\t\t\t\t\t\t/\\/\\*[\\s\\S]*?\\*\\//g,\n\t\t\t\t\t\t''\n\t\t\t\t\t);\n\t\t\t\t\tstylesArray.push(formateStr);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t\treturn stylesArray.join('\\r\\n');\n\t}\n\n\tprivate getVivTemplates(directives: NzxPrintContentDirective[]) {\n\t\tconst templates: string[] = [];\n\t\tdirectives.forEach((d) => {\n\t\t\tlet styles = '';\n\t\t\tif (d.identifierStr || d.identifierStr.length > 0) {\n\t\t\t\tstyles = this.getStyles(d.identifierStr);\n\t\t\t}\n\n\t\t\tconst html = `\n          <!DOCTYPE html>\n          <html>\n            <head>\n            <meta charset=\"utf-8\" />\n            <title>${this.printTitle}</title>\n            <base href=\"/\" />\n            <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n             ${d.customStyle}\n             ${styles}\n            </head>\n            <body>\n              ${d.elementRef.nativeElement.outerHTML}\n            </body>\n          </html>\n        `;\n\t\t\ttemplates.push(html);\n\t\t});\n\n\t\treturn templates;\n\t}\n\n\tprivate clearView() {\n\t\tif (this.viewer) {\n\t\t\tthis.removeListeners(this.viewer);\n\t\t}\n\t\tthis.vivViewRef.nativeElement.innerHTML = '';\n\t\tthis.viewer = undefined;\n\t\tthis._isRenderComplete = false;\n\t}\n}\n"]}
@@ -0,0 +1,189 @@
1
+ import { DOCUMENT } from '@angular/common';
2
+ import { Component, ContentChild, ElementRef, Inject, Input, ViewChild, } from '@angular/core';
3
+ import { getElementByTag } from 'ng-zorro-antd-extension/util';
4
+ import { NzxPrintContentDirective } from './nzx-print-content.directive';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/cdk/platform";
7
+ /**
8
+ * 使用Paged.js打印
9
+ */
10
+ export class NzxPrintComponent {
11
+ constructor(platform, document) {
12
+ this.platform = platform;
13
+ this.document = document;
14
+ this.printTitle = 'pdf';
15
+ /**
16
+ * a4 794px1123px
17
+ */
18
+ this.width = 814;
19
+ this.height = 1143;
20
+ this.enablePreview = true;
21
+ this.identifierStr = '';
22
+ this.pagedCDN = '';
23
+ this._title = this.document.title;
24
+ this.afterPrint = () => {
25
+ this.iframeEl.contentWindow.parent.document.title = this._title;
26
+ };
27
+ this.beforePrint = () => {
28
+ this.iframeEl.contentWindow.parent.document.title = this.printTitle;
29
+ };
30
+ }
31
+ ngOnInit() {
32
+ if (!this.pagedCDN) {
33
+ throw new Error('pagedCDN is required');
34
+ }
35
+ }
36
+ ngAfterViewInit() {
37
+ this.render();
38
+ }
39
+ print() {
40
+ if (this.iframeEl.contentWindow) {
41
+ this.iframeEl.contentWindow.focus();
42
+ this.iframeEl.contentWindow.print();
43
+ }
44
+ }
45
+ refresh() {
46
+ setTimeout(() => {
47
+ this.render();
48
+ }, 100);
49
+ }
50
+ render() {
51
+ this.iframeEl = this.document.createElement('iframe');
52
+ this.iframeEl.height = this.height + '';
53
+ this.iframeEl.width = this.width + '';
54
+ this.iframeEl.style.border = '1px solid #ccc';
55
+ this.iframeEl.style.background = '#fff';
56
+ if (!this.enablePreview) {
57
+ this.iframeEl.style.visibility = 'hidden';
58
+ if (this.platform.FIREFOX) {
59
+ this.iframeEl.setAttribute('style', 'width: 1px; height: 100px; position: fixed; left: 0; top: 0; opacity: 0; border-width: 0; margin: 0; padding: 0');
60
+ }
61
+ else {
62
+ this.iframeEl.setAttribute('style', 'visibility: hidden; height: 0; width: 0; position: absolute; border: 0');
63
+ }
64
+ }
65
+ if (this.containerRef) {
66
+ this.containerRef.nativeElement.innerHTML = '';
67
+ this.containerRef.nativeElement.appendChild(this.iframeEl);
68
+ }
69
+ if (this.iframeEl.contentWindow) {
70
+ this.iframeEl.contentWindow.document.open();
71
+ this.iframeEl.contentWindow.document.write(this.getTemplateStr());
72
+ this.iframeEl.contentWindow.document.close();
73
+ // chorme bug
74
+ this.iframeEl.contentWindow.onbeforeprint = this.beforePrint;
75
+ this.iframeEl.contentWindow.onafterprint = this.afterPrint;
76
+ }
77
+ }
78
+ getTemplateStr() {
79
+ const styles = getElementByTag('style', this.identifierStr);
80
+ const scripts = `
81
+ <script src="${this.pagedCDN}"></script>
82
+ <script>
83
+ class RepeatingTableHeaders extends Paged.Handler {
84
+ constructor(chunker, polisher, caller) {
85
+ super(chunker, polisher, caller);
86
+ }
87
+
88
+ afterPageLayout(pageElement, page, breakToken, chunker) {
89
+ let tables = pageElement.querySelectorAll('table[data-split-from]');
90
+ tables.forEach((table) => {
91
+ let ref = table.dataset.ref;
92
+ let sourceTable = chunker.source.querySelector(
93
+ "[data-ref='" + ref + "']"
94
+ );
95
+ let header = sourceTable.querySelector('thead');
96
+ if (header) {
97
+ let clonedHeader = header.cloneNode(true);
98
+ table.insertBefore(clonedHeader, table.firstChild);
99
+ }
100
+ });
101
+ }
102
+ }
103
+ Paged.registerHandlers(RepeatingTableHeaders);
104
+ </script>
105
+ `;
106
+ const html = `
107
+ <!DOCTYPE html>
108
+ <html>
109
+ <head>
110
+ <meta charset="utf-8" />
111
+ <title>${this.printTitle}</title>
112
+ <base href="/" />
113
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
114
+ <link
115
+ rel="preconnect"
116
+ href="https://winkong-frontend.oss-cn-qingdao.aliyuncs.com"
117
+ />
118
+ <style>
119
+ ::-webkit-scrollbar {
120
+ width: 5px;
121
+ height: 5px;
122
+ }
123
+ ::-webkit-scrollbar-thumb {
124
+ background-color: #999;
125
+ -webkit-border-radius: 5px;
126
+ border-radius: 5px;
127
+ }
128
+ ::-webkit-scrollbar-thumb:vertical:hover {
129
+ background-color: #666;
130
+ }
131
+ ::-webkit-scrollbar-thumb:vertical:active {
132
+ background-color: #666;
133
+ }
134
+ ::-webkit-scrollbar-button {
135
+ display: none;
136
+ }
137
+ ::-webkit-scrollbar-track {
138
+ background-color: #f1f1f1;
139
+ }
140
+ </style>
141
+
142
+ ${styles}
143
+ ${scripts}
144
+ </head>
145
+ <body>
146
+ ${this._printEl.nativeElement.outerHTML}
147
+ </body>
148
+ </html>
149
+ `;
150
+ return html;
151
+ }
152
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintComponent, deps: [{ token: i1.Platform }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
153
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintComponent, selector: "nzx-print", inputs: { printTitle: "printTitle", width: "width", height: "height", enablePreview: "enablePreview", identifierStr: "identifierStr", pagedCDN: "pagedCDN" }, queries: [{ propertyName: "_printEl", first: true, predicate: NzxPrintContentDirective, descendants: true, read: ElementRef, static: true }], viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["iframeContainer"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: `
154
+ <ng-content select="[nzxPrintHeader]"></ng-content>
155
+ <div #iframeContainer></div>
156
+ `, isInline: true }); }
157
+ }
158
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintComponent, decorators: [{
159
+ type: Component,
160
+ args: [{
161
+ selector: 'nzx-print',
162
+ template: `
163
+ <ng-content select="[nzxPrintHeader]"></ng-content>
164
+ <div #iframeContainer></div>
165
+ `,
166
+ }]
167
+ }], ctorParameters: () => [{ type: i1.Platform }, { type: Document, decorators: [{
168
+ type: Inject,
169
+ args: [DOCUMENT]
170
+ }] }], propDecorators: { printTitle: [{
171
+ type: Input
172
+ }], width: [{
173
+ type: Input
174
+ }], height: [{
175
+ type: Input
176
+ }], enablePreview: [{
177
+ type: Input
178
+ }], identifierStr: [{
179
+ type: Input
180
+ }], pagedCDN: [{
181
+ type: Input
182
+ }], containerRef: [{
183
+ type: ViewChild,
184
+ args: ['iframeContainer', { read: ElementRef, static: true }]
185
+ }], _printEl: [{
186
+ type: ContentChild,
187
+ args: [NzxPrintContentDirective, { read: ElementRef, static: true }]
188
+ }] } });
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nzx-print.component.js","sourceRoot":"","sources":["../../../../components/print/nzx-print.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport { DOCUMENT } from '@angular/common';\nimport {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tInject,\n\tInput,\n\tOnInit,\n\tViewChild,\n} from '@angular/core';\nimport { getElementByTag } from 'ng-zorro-antd-extension/util';\nimport { NzxPrintContentDirective } from './nzx-print-content.directive';\n\n/**\n * 使用Paged.js打印\n */\n@Component({\n\tselector: 'nzx-print',\n\ttemplate: `\n\t\t<ng-content select=\"[nzxPrintHeader]\"></ng-content>\n\t\t<div #iframeContainer></div>\n\t`,\n})\nexport class NzxPrintComponent implements OnInit, AfterViewInit {\n\t@Input() printTitle = 'pdf';\n\t/**\n\t * a4 794px1123px\n\t */\n\t@Input() width = 814;\n\t@Input() height = 1143;\n\t@Input() enablePreview = true;\n\t@Input() identifierStr: string | string[] = '';\n\t@Input() pagedCDN = '';\n\n\t@ViewChild('iframeContainer', { read: ElementRef, static: true })\n\tprivate containerRef!: ElementRef;\n\n\t@ContentChild(NzxPrintContentDirective, { read: ElementRef, static: true })\n\tprivate _printEl!: ElementRef;\n\tprivate iframeEl!: HTMLIFrameElement;\n\tprivate _title = this.document.title;\n\n\tprivate afterPrint = () => {\n\t\tthis.iframeEl.contentWindow!.parent.document.title = this._title;\n\t};\n\tprivate beforePrint = () => {\n\t\tthis.iframeEl.contentWindow!.parent.document.title = this.printTitle;\n\t};\n\n\tconstructor(\n\t\tprivate platform: Platform,\n\t\t@Inject(DOCUMENT) private document: Document\n\t) {}\n\n\tngOnInit(): void {\n\t\tif (!this.pagedCDN) {\n\t\t\tthrow new Error('pagedCDN is required');\n\t\t}\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.render();\n\t}\n\n\tprint() {\n\t\tif (this.iframeEl.contentWindow) {\n\t\t\tthis.iframeEl.contentWindow.focus();\n\t\t\tthis.iframeEl.contentWindow.print();\n\t\t}\n\t}\n\n\trefresh() {\n\t\tsetTimeout(() => {\n\t\t\tthis.render();\n\t\t}, 100);\n\t}\n\n\tprivate render() {\n\t\tthis.iframeEl = this.document.createElement('iframe');\n\t\tthis.iframeEl.height = this.height + '';\n\t\tthis.iframeEl.width = this.width + '';\n\t\tthis.iframeEl.style.border = '1px solid #ccc';\n\t\tthis.iframeEl.style.background = '#fff';\n\n\t\tif (!this.enablePreview) {\n\t\t\tthis.iframeEl.style.visibility = 'hidden';\n\t\t\tif (this.platform.FIREFOX) {\n\t\t\t\tthis.iframeEl.setAttribute(\n\t\t\t\t\t'style',\n\t\t\t\t\t'width: 1px; height: 100px; position: fixed; left: 0; top: 0; opacity: 0; border-width: 0; margin: 0; padding: 0'\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tthis.iframeEl.setAttribute(\n\t\t\t\t\t'style',\n\t\t\t\t\t'visibility: hidden; height: 0; width: 0; position: absolute; border: 0'\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t\tif (this.containerRef) {\n\t\t\tthis.containerRef.nativeElement.innerHTML = '';\n\t\t\tthis.containerRef.nativeElement.appendChild(this.iframeEl);\n\t\t}\n\n\t\tif (this.iframeEl.contentWindow) {\n\t\t\tthis.iframeEl.contentWindow.document.open();\n\t\t\tthis.iframeEl.contentWindow.document.write(this.getTemplateStr());\n\t\t\tthis.iframeEl.contentWindow.document.close();\n\t\t\t// chorme bug\n\t\t\tthis.iframeEl.contentWindow.onbeforeprint = this.beforePrint;\n\t\t\tthis.iframeEl.contentWindow.onafterprint = this.afterPrint;\n\t\t}\n\t}\n\n\tprivate getTemplateStr() {\n\t\tconst styles = getElementByTag('style', this.identifierStr);\n\n\t\tconst scripts = `\n        <script src=\"${this.pagedCDN}\"></script>\n        <script>\n          class RepeatingTableHeaders extends Paged.Handler {\n            constructor(chunker, polisher, caller) {\n              super(chunker, polisher, caller);\n            }\n\n            afterPageLayout(pageElement, page, breakToken, chunker) {\n              let tables = pageElement.querySelectorAll('table[data-split-from]');\n              tables.forEach((table) => {\n                let ref = table.dataset.ref;\n                let sourceTable = chunker.source.querySelector(\n                  \"[data-ref='\" + ref + \"']\"\n                );\n                let header = sourceTable.querySelector('thead');\n                if (header) {\n                  let clonedHeader = header.cloneNode(true);\n                  table.insertBefore(clonedHeader, table.firstChild);\n                }\n              });\n            }\n          }\n          Paged.registerHandlers(RepeatingTableHeaders);\n        </script>\n      `;\n\n\t\tconst html = `\n        <!DOCTYPE html>\n        <html>\n          <head>\n          <meta charset=\"utf-8\" />\n          <title>${this.printTitle}</title>\n          <base href=\"/\" />\n          <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n          <link\n            rel=\"preconnect\"\n            href=\"https://winkong-frontend.oss-cn-qingdao.aliyuncs.com\"\n          />\n          <style>\n              ::-webkit-scrollbar {\n                width: 5px;\n                height: 5px;\n              }\n              ::-webkit-scrollbar-thumb {\n                background-color: #999;\n                -webkit-border-radius: 5px;\n                border-radius: 5px;\n              }\n              ::-webkit-scrollbar-thumb:vertical:hover {\n                background-color: #666;\n              }\n              ::-webkit-scrollbar-thumb:vertical:active {\n                background-color: #666;\n              }\n              ::-webkit-scrollbar-button {\n                display: none;\n              }\n              ::-webkit-scrollbar-track {\n                background-color: #f1f1f1;\n              }\n          </style>\n\n            ${styles}\n            ${scripts}\n          </head>\n          <body>\n            ${this._printEl.nativeElement.outerHTML}\n          </body>\n        </html>\n      `;\n\n\t\treturn html;\n\t}\n}\n"]}
@@ -0,0 +1,91 @@
1
+ import { Directive, HostListener, Input, } from '@angular/core';
2
+ import { getElementByTag } from 'ng-zorro-antd-extension/util';
3
+ import * as i0 from "@angular/core";
4
+ /**
5
+ * 常规打印
6
+ */
7
+ export class NzxPrintDirective {
8
+ constructor() {
9
+ this.printTitle = 'pdf';
10
+ this.identifierStr = '';
11
+ }
12
+ ngOnInit() {
13
+ if (!this.printEl) {
14
+ throw new Error('The "printEl" input is required for the nzxPrint directive.');
15
+ }
16
+ }
17
+ ngAfterViewInit() {
18
+ this.getElement();
19
+ }
20
+ print() {
21
+ const newWin = window.open('', '_blank');
22
+ if (newWin) {
23
+ const styles = getElementByTag('style', this.identifierStr);
24
+ const links = getElementByTag('link');
25
+ const baseTag = getElementByTag('base');
26
+ const scripts = `
27
+ <script>
28
+ window.onload = function () {
29
+ window.print();
30
+ };
31
+ window.onafterprint = function () {
32
+ window.close();
33
+ };
34
+ </script>
35
+ `;
36
+ const html = `
37
+ <!DOCTYPE html>
38
+ <html>
39
+ <head>
40
+ <title>${this.printTitle}</title>
41
+ ${baseTag}
42
+ ${links}
43
+ ${styles}
44
+ ${scripts}
45
+ </head>
46
+ <body>
47
+ ${this._printEl.outerHTML}
48
+ </body>
49
+ </html>
50
+ `;
51
+ newWin.document.open();
52
+ newWin.document.write(html);
53
+ newWin.document.close();
54
+ }
55
+ }
56
+ getElement() {
57
+ if (typeof this.printEl === 'string') {
58
+ const el = document.querySelector(this.printEl);
59
+ if (el) {
60
+ this._printEl = el;
61
+ }
62
+ else {
63
+ throw new Error('printEl is not find');
64
+ }
65
+ }
66
+ else if (this.printEl instanceof HTMLElement) {
67
+ this._printEl = this.printEl;
68
+ }
69
+ else {
70
+ throw new Error('printEl is invalid');
71
+ }
72
+ }
73
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
74
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintDirective, selector: "button[nzxPrint]", inputs: { printEl: "printEl", printTitle: "printTitle", identifierStr: "identifierStr" }, host: { listeners: { "click": "print()" } }, ngImport: i0 }); }
75
+ }
76
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintDirective, decorators: [{
77
+ type: Directive,
78
+ args: [{
79
+ selector: 'button[nzxPrint]',
80
+ }]
81
+ }], propDecorators: { printEl: [{
82
+ type: Input
83
+ }], printTitle: [{
84
+ type: Input
85
+ }], identifierStr: [{
86
+ type: Input
87
+ }], print: [{
88
+ type: HostListener,
89
+ args: ['click']
90
+ }] } });
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvcHJpbnQvbnp4LXByaW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQUUvRDs7R0FFRztBQUlILE1BQU0sT0FBTyxpQkFBaUI7SUFIOUI7UUFLVyxlQUFVLEdBQXVCLEtBQUssQ0FBQztRQUN2QyxrQkFBYSxHQUFzQixFQUFFLENBQUM7S0FzRWhEO0lBbkVDLFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixNQUFNLElBQUksS0FBSyxDQUNiLDZEQUE2RCxDQUM5RCxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBR08sS0FBSztRQUNYLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXpDLElBQUksTUFBTSxFQUFFO1lBQ1YsTUFBTSxNQUFNLEdBQUcsZUFBZSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDNUQsTUFBTSxLQUFLLEdBQUcsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3RDLE1BQU0sT0FBTyxHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUV4QyxNQUFNLE9BQU8sR0FBRzs7Ozs7Ozs7O09BU2YsQ0FBQztZQUVGLE1BQU0sSUFBSSxHQUFHOzs7O3FCQUlFLElBQUksQ0FBQyxVQUFVO2NBQ3RCLE9BQU87Y0FDUCxLQUFLO2NBQ0wsTUFBTTtjQUNOLE9BQU87OztjQUdQLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUzs7O09BRzlCLENBQUM7WUFDRixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3ZCLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDekI7SUFDSCxDQUFDO0lBRU8sVUFBVTtRQUNoQixJQUFJLE9BQU8sSUFBSSxDQUFDLE9BQU8sS0FBSyxRQUFRLEVBQUU7WUFDcEMsTUFBTSxFQUFFLEdBQXVCLFFBQVEsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3BFLElBQUksRUFBRSxFQUFFO2dCQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO2FBQ3BCO2lCQUFNO2dCQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLENBQUMsQ0FBQzthQUN4QztTQUNGO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxZQUFZLFdBQVcsRUFBRTtZQUM5QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7U0FDOUI7YUFBTTtZQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztTQUN2QztJQUNILENBQUM7OEdBeEVVLGlCQUFpQjtrR0FBakIsaUJBQWlCOzsyRkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCOzhCQUVVLE9BQU87c0JBQWYsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBZ0JFLEtBQUs7c0JBRFosWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgRGlyZWN0aXZlLFxuICBIb3N0TGlzdGVuZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZ2V0RWxlbWVudEJ5VGFnIH0gZnJvbSAnbmctem9ycm8tYW50ZC1leHRlbnNpb24vdXRpbCc7XG5cbi8qKlxuICog5bi46KeE5omT5Y2wXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2J1dHRvbltuenhQcmludF0nLFxufSlcbmV4cG9ydCBjbGFzcyBOenhQcmludERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIHByaW50RWw6IEhUTUxFbGVtZW50IHwgc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBASW5wdXQoKSBwcmludFRpdGxlOiBzdHJpbmcgfCB1bmRlZmluZWQgPSAncGRmJztcbiAgQElucHV0KCkgaWRlbnRpZmllclN0cjogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcbiAgcHJpdmF0ZSBfcHJpbnRFbCE6IEhUTUxFbGVtZW50O1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5wcmludEVsKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICdUaGUgXCJwcmludEVsXCIgaW5wdXQgaXMgcmVxdWlyZWQgZm9yIHRoZSBuenhQcmludCBkaXJlY3RpdmUuJ1xuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgdGhpcy5nZXRFbGVtZW50KCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdjbGljaycpXG4gIHByaXZhdGUgcHJpbnQoKTogdm9pZCB7XG4gICAgY29uc3QgbmV3V2luID0gd2luZG93Lm9wZW4oJycsICdfYmxhbmsnKTtcblxuICAgIGlmIChuZXdXaW4pIHtcbiAgICAgIGNvbnN0IHN0eWxlcyA9IGdldEVsZW1lbnRCeVRhZygnc3R5bGUnLCB0aGlzLmlkZW50aWZpZXJTdHIpO1xuICAgICAgY29uc3QgbGlua3MgPSBnZXRFbGVtZW50QnlUYWcoJ2xpbmsnKTtcbiAgICAgIGNvbnN0IGJhc2VUYWcgPSBnZXRFbGVtZW50QnlUYWcoJ2Jhc2UnKTtcblxuICAgICAgY29uc3Qgc2NyaXB0cyA9IGBcbiAgICAgIDxzY3JpcHQ+XG4gICAgICAgIHdpbmRvdy5vbmxvYWQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LnByaW50KCk7XG4gICAgICAgIH07XG4gICAgICAgIHdpbmRvdy5vbmFmdGVycHJpbnQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LmNsb3NlKCk7XG4gICAgICAgIH07XG4gICAgICA8L3NjcmlwdD5cbiAgICAgIGA7XG5cbiAgICAgIGNvbnN0IGh0bWwgPSBgXG4gICAgICA8IURPQ1RZUEUgaHRtbD5cbiAgICAgICAgPGh0bWw+XG4gICAgICAgICAgPGhlYWQ+XG4gICAgICAgICAgICA8dGl0bGU+JHt0aGlzLnByaW50VGl0bGV9PC90aXRsZT5cbiAgICAgICAgICAgICR7YmFzZVRhZ31cbiAgICAgICAgICAgICR7bGlua3N9XG4gICAgICAgICAgICAke3N0eWxlc31cbiAgICAgICAgICAgICR7c2NyaXB0c31cbiAgICAgICAgICA8L2hlYWQ+XG4gICAgICAgICAgPGJvZHk+XG4gICAgICAgICAgICAke3RoaXMuX3ByaW50RWwub3V0ZXJIVE1MfVxuICAgICAgICAgIDwvYm9keT5cbiAgICAgICAgPC9odG1sPlxuICAgICAgYDtcbiAgICAgIG5ld1dpbi5kb2N1bWVudC5vcGVuKCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQud3JpdGUoaHRtbCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQuY2xvc2UoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldEVsZW1lbnQoKTogdm9pZCB7XG4gICAgaWYgKHR5cGVvZiB0aGlzLnByaW50RWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICBjb25zdCBlbDogSFRNTEVsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3Rvcih0aGlzLnByaW50RWwpO1xuICAgICAgaWYgKGVsKSB7XG4gICAgICAgIHRoaXMuX3ByaW50RWwgPSBlbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBub3QgZmluZCcpO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAodGhpcy5wcmludEVsIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQpIHtcbiAgICAgIHRoaXMuX3ByaW50RWwgPSB0aGlzLnByaW50RWw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBpbnZhbGlkJyk7XG4gICAgfVxuICB9XG59XG4iXX0=