ng-zorro-antd-extension 17.1.0 → 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/nzx-print-content.directive.mjs +22 -0
  7. package/esm2022/print/nzx-print-v.component.mjs +300 -0
  8. package/esm2022/print/nzx-print.component.mjs +36 -27
  9. package/esm2022/print/nzx-print.directive.mjs +9 -6
  10. package/esm2022/print/nzx-print.module.mjs +20 -6
  11. package/esm2022/print/public-api.mjs +3 -1
  12. package/esm2022/table-select/page-table-select/page-table-select.component.mjs +3 -3
  13. package/esm2022/table-select/table-select/table-select.component.mjs +3 -3
  14. package/esm2022/util/lib/getElementByTag.mjs +31 -0
  15. package/esm2022/util/public-api.mjs +2 -1
  16. package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs +64 -40
  17. package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs.map +1 -1
  18. package/fesm2022/ng-zorro-antd-extension-print.mjs +368 -36
  19. package/fesm2022/ng-zorro-antd-extension-print.mjs.map +1 -1
  20. package/fesm2022/ng-zorro-antd-extension-table-select.mjs +4 -4
  21. package/fesm2022/ng-zorro-antd-extension-table-select.mjs.map +1 -1
  22. package/fesm2022/ng-zorro-antd-extension-util.mjs +32 -1
  23. package/fesm2022/ng-zorro-antd-extension-util.mjs.map +1 -1
  24. package/package.json +2 -1
  25. package/pipes/safe-url.pipe.d.ts +1 -1
  26. package/print/nzx-print-content.directive.d.ts +10 -0
  27. package/print/nzx-print-v.component.d.ts +45 -0
  28. package/print/nzx-print.component.d.ts +7 -7
  29. package/print/nzx-print.directive.d.ts +2 -1
  30. package/print/nzx-print.module.d.ts +7 -3
  31. package/print/public-api.d.ts +2 -0
  32. package/public-api.d.ts +1 -1
  33. package/table-select/abstract-table-select.d.ts +1 -1
  34. package/timer-button/timer-button.directive.d.ts +1 -1
  35. package/util/lib/getElementByTag.d.ts +8 -0
  36. package/util/public-api.d.ts +1 -0
  37. package/esm2022/print/util.mjs +0 -9
  38. package/print/util.d.ts +0 -1
@@ -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"]}
@@ -1,18 +1,9 @@
1
1
  import { DOCUMENT } from '@angular/common';
2
- import { Component, ContentChild, Directive, ElementRef, Inject, Input, } from '@angular/core';
3
- import { getElementTag } from './util';
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';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/cdk/platform";
6
- export class NzxPrintContentDirective {
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
8
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintContentDirective, selector: "[nzxPrintContent]", ngImport: i0 }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintContentDirective, decorators: [{
11
- type: Directive,
12
- args: [{
13
- selector: '[nzxPrintContent]',
14
- }]
15
- }] });
16
7
  /**
17
8
  * 使用Paged.js打印
18
9
  */
@@ -27,6 +18,8 @@ export class NzxPrintComponent {
27
18
  this.width = 814;
28
19
  this.height = 1143;
29
20
  this.enablePreview = true;
21
+ this.identifierStr = '';
22
+ this.pagedCDN = '';
30
23
  this._title = this.document.title;
31
24
  this.afterPrint = () => {
32
25
  this.iframeEl.contentWindow.parent.document.title = this._title;
@@ -35,6 +28,11 @@ export class NzxPrintComponent {
35
28
  this.iframeEl.contentWindow.parent.document.title = this.printTitle;
36
29
  };
37
30
  }
31
+ ngOnInit() {
32
+ if (!this.pagedCDN) {
33
+ throw new Error('pagedCDN is required');
34
+ }
35
+ }
38
36
  ngAfterViewInit() {
39
37
  this.render();
40
38
  }
@@ -50,10 +48,11 @@ export class NzxPrintComponent {
50
48
  }, 100);
51
49
  }
52
50
  render() {
53
- const container = this.document.getElementById('nzx-print-iframe-content');
54
51
  this.iframeEl = this.document.createElement('iframe');
55
52
  this.iframeEl.height = this.height + '';
56
53
  this.iframeEl.width = this.width + '';
54
+ this.iframeEl.style.border = '1px solid #ccc';
55
+ this.iframeEl.style.background = '#fff';
57
56
  if (!this.enablePreview) {
58
57
  this.iframeEl.style.visibility = 'hidden';
59
58
  if (this.platform.FIREFOX) {
@@ -63,9 +62,9 @@ export class NzxPrintComponent {
63
62
  this.iframeEl.setAttribute('style', 'visibility: hidden; height: 0; width: 0; position: absolute; border: 0');
64
63
  }
65
64
  }
66
- if (container) {
67
- container.innerHTML = '';
68
- container.appendChild(this.iframeEl);
65
+ if (this.containerRef) {
66
+ this.containerRef.nativeElement.innerHTML = '';
67
+ this.containerRef.nativeElement.appendChild(this.iframeEl);
69
68
  }
70
69
  if (this.iframeEl.contentWindow) {
71
70
  this.iframeEl.contentWindow.document.open();
@@ -77,9 +76,9 @@ export class NzxPrintComponent {
77
76
  }
78
77
  }
79
78
  getTemplateStr() {
80
- const styles = getElementTag('style');
79
+ const styles = getElementByTag('style', this.identifierStr);
81
80
  const scripts = `
82
- <script src="https://winkong-frontend.oss-cn-qingdao.aliyuncs.com/javascript/paged/paged.polyfill.min.js"></script>
81
+ <script src="${this.pagedCDN}"></script>
83
82
  <script>
84
83
  class RepeatingTableHeaders extends Paged.Handler {
85
84
  constructor(chunker, polisher, caller) {
@@ -151,17 +150,20 @@ export class NzxPrintComponent {
151
150
  return html;
152
151
  }
153
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 }); }
154
- 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" }, queries: [{ propertyName: "_printEl", first: true, predicate: NzxPrintContentDirective, descendants: true, read: ElementRef, static: true }], ngImport: i0, template: `
155
- <ng-content select="[nzxPrintHeader]"></ng-content>
156
- <div id="nzx-print-iframe-content"></div>
157
- `, isInline: true, styles: ["#nzx-print-iframe-content iframe{background:#fff;border:1px solid #ccc}\n"] }); }
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 }); }
158
157
  }
159
158
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintComponent, decorators: [{
160
159
  type: Component,
161
- args: [{ selector: 'nzx-print', template: `
162
- <ng-content select="[nzxPrintHeader]"></ng-content>
163
- <div id="nzx-print-iframe-content"></div>
164
- `, styles: ["#nzx-print-iframe-content iframe{background:#fff;border:1px solid #ccc}\n"] }]
160
+ args: [{
161
+ selector: 'nzx-print',
162
+ template: `
163
+ <ng-content select="[nzxPrintHeader]"></ng-content>
164
+ <div #iframeContainer></div>
165
+ `,
166
+ }]
165
167
  }], ctorParameters: () => [{ type: i1.Platform }, { type: Document, decorators: [{
166
168
  type: Inject,
167
169
  args: [DOCUMENT]
@@ -173,8 +175,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
173
175
  type: Input
174
176
  }], enablePreview: [{
175
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 }]
176
185
  }], _printEl: [{
177
186
  type: ContentChild,
178
187
  args: [NzxPrintContentDirective, { read: ElementRef, static: true }]
179
188
  }] } });
180
- //# 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  AfterViewInit,\n  Component,\n  ContentChild,\n  Directive,\n  ElementRef,\n  Inject,\n  Input,\n} from '@angular/core';\nimport { getElementTag } from './util';\n\n@Directive({\n  selector: '[nzxPrintContent]',\n})\nexport class NzxPrintContentDirective {}\n\n/**\n * 使用Paged.js打印\n */\n@Component({\n  selector: 'nzx-print',\n  template: `\n    <ng-content select=\"[nzxPrintHeader]\"></ng-content>\n    <div id=\"nzx-print-iframe-content\"></div>\n  `,\n  styles: [\n    `\n      #nzx-print-iframe-content {\n        iframe {\n          background: #fff;\n          border: 1px solid #ccc;\n        }\n      }\n    `,\n  ],\n})\nexport class NzxPrintComponent implements AfterViewInit {\n  @Input() printTitle = 'pdf';\n  /**\n   * a4 794px1123px\n   */\n  @Input() width = 814;\n  @Input() height = 1143;\n  @Input() enablePreview = true;\n\n  @ContentChild(NzxPrintContentDirective, { read: ElementRef, static: true })\n  private _printEl!: ElementRef;\n  private iframeEl!: HTMLIFrameElement;\n  private _title = this.document.title;\n\n  private afterPrint = () => {\n    this.iframeEl.contentWindow!.parent.document.title = this._title;\n  };\n  private beforePrint = () => {\n    this.iframeEl.contentWindow!.parent.document.title = this.printTitle;\n  };\n\n  constructor(\n    private platform: Platform,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.render();\n  }\n\n  print() {\n    if (this.iframeEl.contentWindow) {\n      this.iframeEl.contentWindow.focus();\n      this.iframeEl.contentWindow.print();\n    }\n  }\n\n  refresh() {\n    setTimeout(() => {\n      this.render();\n    }, 100);\n  }\n\n  private render() {\n    const container = this.document.getElementById('nzx-print-iframe-content');\n    this.iframeEl = this.document.createElement('iframe');\n    this.iframeEl.height = this.height + '';\n    this.iframeEl.width = this.width + '';\n    if (!this.enablePreview) {\n      this.iframeEl.style.visibility = 'hidden';\n      if (this.platform.FIREFOX) {\n        this.iframeEl.setAttribute(\n          'style',\n          'width: 1px; height: 100px; position: fixed; left: 0; top: 0; opacity: 0; border-width: 0; margin: 0; padding: 0'\n        );\n      } else {\n        this.iframeEl.setAttribute(\n          'style',\n          'visibility: hidden; height: 0; width: 0; position: absolute; border: 0'\n        );\n      }\n    }\n    if (container) {\n      container.innerHTML = '';\n      container.appendChild(this.iframeEl);\n    }\n\n    if (this.iframeEl.contentWindow) {\n      this.iframeEl.contentWindow.document.open();\n      this.iframeEl.contentWindow.document.write(this.getTemplateStr());\n      this.iframeEl.contentWindow.document.close();\n      // chorme bug\n      this.iframeEl.contentWindow.onbeforeprint = this.beforePrint;\n      this.iframeEl.contentWindow.onafterprint = this.afterPrint;\n    }\n  }\n\n  private getTemplateStr() {\n    const styles = getElementTag('style');\n\n    const scripts = `\n        <script src=\"https://winkong-frontend.oss-cn-qingdao.aliyuncs.com/javascript/paged/paged.polyfill.min.js\"></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    const 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    return html;\n  }\n}\n"]}
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"]}
@@ -1,5 +1,5 @@
1
1
  import { Directive, HostListener, Input, } from '@angular/core';
2
- import { getElementTag } from './util';
2
+ import { getElementByTag } from 'ng-zorro-antd-extension/util';
3
3
  import * as i0 from "@angular/core";
4
4
  /**
5
5
  * 常规打印
@@ -7,6 +7,7 @@ import * as i0 from "@angular/core";
7
7
  export class NzxPrintDirective {
8
8
  constructor() {
9
9
  this.printTitle = 'pdf';
10
+ this.identifierStr = '';
10
11
  }
11
12
  ngOnInit() {
12
13
  if (!this.printEl) {
@@ -19,9 +20,9 @@ export class NzxPrintDirective {
19
20
  print() {
20
21
  const newWin = window.open('', '_blank');
21
22
  if (newWin) {
22
- const styles = getElementTag('style');
23
- const links = getElementTag('link');
24
- const baseTag = getElementTag('base');
23
+ const styles = getElementByTag('style', this.identifierStr);
24
+ const links = getElementByTag('link');
25
+ const baseTag = getElementByTag('base');
25
26
  const scripts = `
26
27
  <script>
27
28
  window.onload = function () {
@@ -70,7 +71,7 @@ export class NzxPrintDirective {
70
71
  }
71
72
  }
72
73
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
73
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.3", type: NzxPrintDirective, selector: "button[nzxPrint]", inputs: { printEl: "printEl", printTitle: "printTitle" }, host: { listeners: { "click": "print()" } }, ngImport: i0 }); }
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 }); }
74
75
  }
75
76
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintDirective, decorators: [{
76
77
  type: Directive,
@@ -81,8 +82,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImpor
81
82
  type: Input
82
83
  }], printTitle: [{
83
84
  type: Input
85
+ }], identifierStr: [{
86
+ type: Input
84
87
  }], print: [{
85
88
  type: HostListener,
86
89
  args: ['click']
87
90
  }] } });
88
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvcHJpbnQvbnp4LXByaW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQzs7QUFFdkM7O0dBRUc7QUFJSCxNQUFNLE9BQU8saUJBQWlCO0lBSDlCO1FBS1csZUFBVSxHQUF1QixLQUFLLENBQUM7S0FzRWpEO0lBbkVDLFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixNQUFNLElBQUksS0FBSyxDQUNiLDZEQUE2RCxDQUM5RCxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBR08sS0FBSztRQUNYLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXpDLElBQUksTUFBTSxFQUFFO1lBQ1YsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3RDLE1BQU0sS0FBSyxHQUFHLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNwQyxNQUFNLE9BQU8sR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7WUFFdEMsTUFBTSxPQUFPLEdBQUc7Ozs7Ozs7OztPQVNmLENBQUM7WUFFRixNQUFNLElBQUksR0FBRzs7OztxQkFJRSxJQUFJLENBQUMsVUFBVTtjQUN0QixPQUFPO2NBQ1AsS0FBSztjQUNMLE1BQU07Y0FDTixPQUFPOzs7Y0FHUCxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVM7OztPQUc5QixDQUFDO1lBQ0YsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUN2QixNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM1QixNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQztJQUVPLFVBQVU7UUFDaEIsSUFBSSxPQUFPLElBQUksQ0FBQyxPQUFPLEtBQUssUUFBUSxFQUFFO1lBQ3BDLE1BQU0sRUFBRSxHQUF1QixRQUFRLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNwRSxJQUFJLEVBQUUsRUFBRTtnQkFDTixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQzthQUNwQjtpQkFBTTtnQkFDTCxNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7YUFDeEM7U0FDRjthQUFNLElBQUksSUFBSSxDQUFDLE9BQU8sWUFBWSxXQUFXLEVBQUU7WUFDOUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO1NBQzlCO2FBQU07WUFDTCxNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixDQUFDLENBQUM7U0FDdkM7SUFDSCxDQUFDOzhHQXZFVSxpQkFBaUI7a0dBQWpCLGlCQUFpQjs7MkZBQWpCLGlCQUFpQjtrQkFIN0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2lCQUM3Qjs4QkFFVSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFnQkUsS0FBSztzQkFEWixZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBEaXJlY3RpdmUsXG4gIEhvc3RMaXN0ZW5lcixcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBnZXRFbGVtZW50VGFnIH0gZnJvbSAnLi91dGlsJztcblxuLyoqXG4gKiDluLjop4TmiZPljbBcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnYnV0dG9uW256eFByaW50XScsXG59KVxuZXhwb3J0IGNsYXNzIE56eFByaW50RGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcbiAgQElucHV0KCkgcHJpbnRFbDogSFRNTEVsZW1lbnQgfCBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIHByaW50VGl0bGU6IHN0cmluZyB8IHVuZGVmaW5lZCA9ICdwZGYnO1xuICBwcml2YXRlIF9wcmludEVsITogSFRNTEVsZW1lbnQ7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLnByaW50RWwpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ1RoZSBcInByaW50RWxcIiBpbnB1dCBpcyByZXF1aXJlZCBmb3IgdGhlIG56eFByaW50IGRpcmVjdGl2ZS4nXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmdldEVsZW1lbnQoKTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcbiAgcHJpdmF0ZSBwcmludCgpOiB2b2lkIHtcbiAgICBjb25zdCBuZXdXaW4gPSB3aW5kb3cub3BlbignJywgJ19ibGFuaycpO1xuXG4gICAgaWYgKG5ld1dpbikge1xuICAgICAgY29uc3Qgc3R5bGVzID0gZ2V0RWxlbWVudFRhZygnc3R5bGUnKTtcbiAgICAgIGNvbnN0IGxpbmtzID0gZ2V0RWxlbWVudFRhZygnbGluaycpO1xuICAgICAgY29uc3QgYmFzZVRhZyA9IGdldEVsZW1lbnRUYWcoJ2Jhc2UnKTtcblxuICAgICAgY29uc3Qgc2NyaXB0cyA9IGBcbiAgICAgIDxzY3JpcHQ+XG4gICAgICAgIHdpbmRvdy5vbmxvYWQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LnByaW50KCk7XG4gICAgICAgIH07XG4gICAgICAgIHdpbmRvdy5vbmFmdGVycHJpbnQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LmNsb3NlKCk7XG4gICAgICAgIH07XG4gICAgICA8L3NjcmlwdD5cbiAgICAgIGA7XG5cbiAgICAgIGNvbnN0IGh0bWwgPSBgXG4gICAgICA8IURPQ1RZUEUgaHRtbD5cbiAgICAgICAgPGh0bWw+XG4gICAgICAgICAgPGhlYWQ+XG4gICAgICAgICAgICA8dGl0bGU+JHt0aGlzLnByaW50VGl0bGV9PC90aXRsZT5cbiAgICAgICAgICAgICR7YmFzZVRhZ31cbiAgICAgICAgICAgICR7bGlua3N9XG4gICAgICAgICAgICAke3N0eWxlc31cbiAgICAgICAgICAgICR7c2NyaXB0c31cbiAgICAgICAgICA8L2hlYWQ+XG4gICAgICAgICAgPGJvZHk+XG4gICAgICAgICAgICAke3RoaXMuX3ByaW50RWwub3V0ZXJIVE1MfVxuICAgICAgICAgIDwvYm9keT5cbiAgICAgICAgPC9odG1sPlxuICAgICAgYDtcbiAgICAgIG5ld1dpbi5kb2N1bWVudC5vcGVuKCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQud3JpdGUoaHRtbCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQuY2xvc2UoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldEVsZW1lbnQoKTogdm9pZCB7XG4gICAgaWYgKHR5cGVvZiB0aGlzLnByaW50RWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICBjb25zdCBlbDogSFRNTEVsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3Rvcih0aGlzLnByaW50RWwpO1xuICAgICAgaWYgKGVsKSB7XG4gICAgICAgIHRoaXMuX3ByaW50RWwgPSBlbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBub3QgZmluZCcpO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAodGhpcy5wcmludEVsIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQpIHtcbiAgICAgIHRoaXMuX3ByaW50RWwgPSB0aGlzLnByaW50RWw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBpbnZhbGlkJyk7XG4gICAgfVxuICB9XG59XG4iXX0=
91
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvcHJpbnQvbnp4LXByaW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQUUvRDs7R0FFRztBQUlILE1BQU0sT0FBTyxpQkFBaUI7SUFIOUI7UUFLVyxlQUFVLEdBQXVCLEtBQUssQ0FBQztRQUN2QyxrQkFBYSxHQUFzQixFQUFFLENBQUM7S0FzRWhEO0lBbkVDLFFBQVE7UUFDTixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixNQUFNLElBQUksS0FBSyxDQUNiLDZEQUE2RCxDQUM5RCxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBR08sS0FBSztRQUNYLE1BQU0sTUFBTSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXpDLElBQUksTUFBTSxFQUFFO1lBQ1YsTUFBTSxNQUFNLEdBQUcsZUFBZSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7WUFDNUQsTUFBTSxLQUFLLEdBQUcsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3RDLE1BQU0sT0FBTyxHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUV4QyxNQUFNLE9BQU8sR0FBRzs7Ozs7Ozs7O09BU2YsQ0FBQztZQUVGLE1BQU0sSUFBSSxHQUFHOzs7O3FCQUlFLElBQUksQ0FBQyxVQUFVO2NBQ3RCLE9BQU87Y0FDUCxLQUFLO2NBQ0wsTUFBTTtjQUNOLE9BQU87OztjQUdQLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUzs7O09BRzlCLENBQUM7WUFDRixNQUFNLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ3ZCLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzVCLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDekI7SUFDSCxDQUFDO0lBRU8sVUFBVTtRQUNoQixJQUFJLE9BQU8sSUFBSSxDQUFDLE9BQU8sS0FBSyxRQUFRLEVBQUU7WUFDcEMsTUFBTSxFQUFFLEdBQXVCLFFBQVEsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3BFLElBQUksRUFBRSxFQUFFO2dCQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO2FBQ3BCO2lCQUFNO2dCQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLENBQUMsQ0FBQzthQUN4QztTQUNGO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxZQUFZLFdBQVcsRUFBRTtZQUM5QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7U0FDOUI7YUFBTTtZQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztTQUN2QztJQUNILENBQUM7OEdBeEVVLGlCQUFpQjtrR0FBakIsaUJBQWlCOzsyRkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCOzhCQUVVLE9BQU87c0JBQWYsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBZ0JFLEtBQUs7c0JBRFosWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgRGlyZWN0aXZlLFxuICBIb3N0TGlzdGVuZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZ2V0RWxlbWVudEJ5VGFnIH0gZnJvbSAnbmctem9ycm8tYW50ZC1leHRlbnNpb24vdXRpbCc7XG5cbi8qKlxuICog5bi46KeE5omT5Y2wXG4gKi9cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2J1dHRvbltuenhQcmludF0nLFxufSlcbmV4cG9ydCBjbGFzcyBOenhQcmludERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIEBJbnB1dCgpIHByaW50RWw6IEhUTUxFbGVtZW50IHwgc3RyaW5nIHwgdW5kZWZpbmVkO1xuICBASW5wdXQoKSBwcmludFRpdGxlOiBzdHJpbmcgfCB1bmRlZmluZWQgPSAncGRmJztcbiAgQElucHV0KCkgaWRlbnRpZmllclN0cjogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcbiAgcHJpdmF0ZSBfcHJpbnRFbCE6IEhUTUxFbGVtZW50O1xuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5wcmludEVsKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgICdUaGUgXCJwcmludEVsXCIgaW5wdXQgaXMgcmVxdWlyZWQgZm9yIHRoZSBuenhQcmludCBkaXJlY3RpdmUuJ1xuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgdGhpcy5nZXRFbGVtZW50KCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdjbGljaycpXG4gIHByaXZhdGUgcHJpbnQoKTogdm9pZCB7XG4gICAgY29uc3QgbmV3V2luID0gd2luZG93Lm9wZW4oJycsICdfYmxhbmsnKTtcblxuICAgIGlmIChuZXdXaW4pIHtcbiAgICAgIGNvbnN0IHN0eWxlcyA9IGdldEVsZW1lbnRCeVRhZygnc3R5bGUnLCB0aGlzLmlkZW50aWZpZXJTdHIpO1xuICAgICAgY29uc3QgbGlua3MgPSBnZXRFbGVtZW50QnlUYWcoJ2xpbmsnKTtcbiAgICAgIGNvbnN0IGJhc2VUYWcgPSBnZXRFbGVtZW50QnlUYWcoJ2Jhc2UnKTtcblxuICAgICAgY29uc3Qgc2NyaXB0cyA9IGBcbiAgICAgIDxzY3JpcHQ+XG4gICAgICAgIHdpbmRvdy5vbmxvYWQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LnByaW50KCk7XG4gICAgICAgIH07XG4gICAgICAgIHdpbmRvdy5vbmFmdGVycHJpbnQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgd2luZG93LmNsb3NlKCk7XG4gICAgICAgIH07XG4gICAgICA8L3NjcmlwdD5cbiAgICAgIGA7XG5cbiAgICAgIGNvbnN0IGh0bWwgPSBgXG4gICAgICA8IURPQ1RZUEUgaHRtbD5cbiAgICAgICAgPGh0bWw+XG4gICAgICAgICAgPGhlYWQ+XG4gICAgICAgICAgICA8dGl0bGU+JHt0aGlzLnByaW50VGl0bGV9PC90aXRsZT5cbiAgICAgICAgICAgICR7YmFzZVRhZ31cbiAgICAgICAgICAgICR7bGlua3N9XG4gICAgICAgICAgICAke3N0eWxlc31cbiAgICAgICAgICAgICR7c2NyaXB0c31cbiAgICAgICAgICA8L2hlYWQ+XG4gICAgICAgICAgPGJvZHk+XG4gICAgICAgICAgICAke3RoaXMuX3ByaW50RWwub3V0ZXJIVE1MfVxuICAgICAgICAgIDwvYm9keT5cbiAgICAgICAgPC9odG1sPlxuICAgICAgYDtcbiAgICAgIG5ld1dpbi5kb2N1bWVudC5vcGVuKCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQud3JpdGUoaHRtbCk7XG4gICAgICBuZXdXaW4uZG9jdW1lbnQuY2xvc2UoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldEVsZW1lbnQoKTogdm9pZCB7XG4gICAgaWYgKHR5cGVvZiB0aGlzLnByaW50RWwgPT09ICdzdHJpbmcnKSB7XG4gICAgICBjb25zdCBlbDogSFRNTEVsZW1lbnQgfCBudWxsID0gZG9jdW1lbnQucXVlcnlTZWxlY3Rvcih0aGlzLnByaW50RWwpO1xuICAgICAgaWYgKGVsKSB7XG4gICAgICAgIHRoaXMuX3ByaW50RWwgPSBlbDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBub3QgZmluZCcpO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAodGhpcy5wcmludEVsIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQpIHtcbiAgICAgIHRoaXMuX3ByaW50RWwgPSB0aGlzLnByaW50RWw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcigncHJpbnRFbCBpcyBpbnZhbGlkJyk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -1,25 +1,39 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
- import { NzxPrintComponent, NzxPrintContentDirective, } from './nzx-print.component';
3
+ import { NzxPrintComponent } from './nzx-print.component';
4
4
  import { NzxPrintDirective } from './nzx-print.directive';
5
+ import { NzxPrintVComponent } from './nzx-print-v.component';
6
+ import { NzPaginationModule } from 'ng-zorro-antd/pagination';
7
+ import { NzGridModule } from 'ng-zorro-antd/grid';
8
+ import { NzxPrintContentDirective } from './nzx-print-content.directive';
5
9
  import * as i0 from "@angular/core";
6
10
  export class NzxPrintModule {
7
11
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
12
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintModule, declarations: [NzxPrintComponent,
13
+ NzxPrintVComponent,
14
+ NzxPrintDirective,
15
+ NzxPrintContentDirective], imports: [CommonModule, NzGridModule, NzPaginationModule], exports: [NzxPrintComponent,
16
+ NzxPrintVComponent,
9
17
  NzxPrintContentDirective,
10
- NzxPrintDirective], imports: [CommonModule], exports: [NzxPrintComponent, NzxPrintContentDirective, NzxPrintDirective] }); }
11
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintModule, imports: [CommonModule] }); }
18
+ NzxPrintDirective] }); }
19
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintModule, imports: [CommonModule, NzGridModule, NzPaginationModule] }); }
12
20
  }
13
21
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.3", ngImport: i0, type: NzxPrintModule, decorators: [{
14
22
  type: NgModule,
15
23
  args: [{
16
24
  declarations: [
17
25
  NzxPrintComponent,
26
+ NzxPrintVComponent,
27
+ NzxPrintDirective,
28
+ NzxPrintContentDirective,
29
+ ],
30
+ imports: [CommonModule, NzGridModule, NzPaginationModule],
31
+ exports: [
32
+ NzxPrintComponent,
33
+ NzxPrintVComponent,
18
34
  NzxPrintContentDirective,
19
35
  NzxPrintDirective,
20
36
  ],
21
- imports: [CommonModule],
22
- exports: [NzxPrintComponent, NzxPrintContentDirective, NzxPrintDirective],
23
37
  }]
24
38
  }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvcHJpbnQvbnp4LXByaW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQ0wsaUJBQWlCLEVBQ2pCLHdCQUF3QixHQUN6QixNQUFNLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQVcxRCxNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsaUJBUHZCLGlCQUFpQjtZQUNqQix3QkFBd0I7WUFDeEIsaUJBQWlCLGFBRVQsWUFBWSxhQUNaLGlCQUFpQixFQUFFLHdCQUF3QixFQUFFLGlCQUFpQjsrR0FFN0QsY0FBYyxZQUhmLFlBQVk7OzJGQUdYLGNBQWM7a0JBVDFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGlCQUFpQjt3QkFDakIsd0JBQXdCO3dCQUN4QixpQkFBaUI7cUJBQ2xCO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsaUJBQWlCLEVBQUUsd0JBQXdCLEVBQUUsaUJBQWlCLENBQUM7aUJBQzFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBOenhQcmludENvbXBvbmVudCxcbiAgTnp4UHJpbnRDb250ZW50RGlyZWN0aXZlLFxufSBmcm9tICcuL256eC1wcmludC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTnp4UHJpbnREaXJlY3RpdmUgfSBmcm9tICcuL256eC1wcmludC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBOenhQcmludENvbXBvbmVudCxcbiAgICBOenhQcmludENvbnRlbnREaXJlY3RpdmUsXG4gICAgTnp4UHJpbnREaXJlY3RpdmUsXG4gIF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBleHBvcnRzOiBbTnp4UHJpbnRDb21wb25lbnQsIE56eFByaW50Q29udGVudERpcmVjdGl2ZSwgTnp4UHJpbnREaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBOenhQcmludE1vZHVsZSB7fVxuIl19
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnp4LXByaW50Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2NvbXBvbmVudHMvcHJpbnQvbnp4LXByaW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBaUJ6RSxNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsaUJBYnpCLGlCQUFpQjtZQUNqQixrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLHdCQUF3QixhQUVmLFlBQVksRUFBRSxZQUFZLEVBQUUsa0JBQWtCLGFBRXZELGlCQUFpQjtZQUNqQixrQkFBa0I7WUFDbEIsd0JBQXdCO1lBQ3hCLGlCQUFpQjsrR0FHTixjQUFjLFlBUmhCLFlBQVksRUFBRSxZQUFZLEVBQUUsa0JBQWtCOzsyRkFRNUMsY0FBYztrQkFmMUIsUUFBUTttQkFBQztvQkFDVCxZQUFZLEVBQUU7d0JBQ2IsaUJBQWlCO3dCQUNqQixrQkFBa0I7d0JBQ2xCLGlCQUFpQjt3QkFDakIsd0JBQXdCO3FCQUN4QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLGtCQUFrQixDQUFDO29CQUN6RCxPQUFPLEVBQUU7d0JBQ1IsaUJBQWlCO3dCQUNqQixrQkFBa0I7d0JBQ2xCLHdCQUF3Qjt3QkFDeEIsaUJBQWlCO3FCQUNqQjtpQkFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTnp4UHJpbnRDb21wb25lbnQgfSBmcm9tICcuL256eC1wcmludC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTnp4UHJpbnREaXJlY3RpdmUgfSBmcm9tICcuL256eC1wcmludC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTnp4UHJpbnRWQ29tcG9uZW50IH0gZnJvbSAnLi9uengtcHJpbnQtdi5jb21wb25lbnQnO1xuaW1wb3J0IHsgTnpQYWdpbmF0aW9uTW9kdWxlIH0gZnJvbSAnbmctem9ycm8tYW50ZC9wYWdpbmF0aW9uJztcbmltcG9ydCB7IE56R3JpZE1vZHVsZSB9IGZyb20gJ25nLXpvcnJvLWFudGQvZ3JpZCc7XG5pbXBvcnQgeyBOenhQcmludENvbnRlbnREaXJlY3RpdmUgfSBmcm9tICcuL256eC1wcmludC1jb250ZW50LmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG5cdGRlY2xhcmF0aW9uczogW1xuXHRcdE56eFByaW50Q29tcG9uZW50LFxuXHRcdE56eFByaW50VkNvbXBvbmVudCxcblx0XHROenhQcmludERpcmVjdGl2ZSxcblx0XHROenhQcmludENvbnRlbnREaXJlY3RpdmUsXG5cdF0sXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE56R3JpZE1vZHVsZSwgTnpQYWdpbmF0aW9uTW9kdWxlXSxcblx0ZXhwb3J0czogW1xuXHRcdE56eFByaW50Q29tcG9uZW50LFxuXHRcdE56eFByaW50VkNvbXBvbmVudCxcblx0XHROenhQcmludENvbnRlbnREaXJlY3RpdmUsXG5cdFx0Tnp4UHJpbnREaXJlY3RpdmUsXG5cdF0sXG59KVxuZXhwb3J0IGNsYXNzIE56eFByaW50TW9kdWxlIHt9XG4iXX0=