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.
- package/README.md +1 -0
- package/configurable-query/configurable-query.component.d.ts +13 -14
- package/configurable-query/type.d.ts +2 -2
- package/esm2022/configurable-query/configurable-query.component.mjs +66 -42
- package/esm2022/configurable-query/type.mjs +1 -1
- package/esm2022/print/ng-zorro-antd-extension-print.mjs +5 -0
- package/esm2022/print/nzx-print-content.directive.mjs +22 -0
- package/esm2022/print/nzx-print-v.component.mjs +300 -0
- package/esm2022/print/nzx-print.component.mjs +189 -0
- package/esm2022/print/nzx-print.directive.mjs +91 -0
- package/esm2022/print/nzx-print.module.mjs +39 -0
- package/esm2022/print/public-api.mjs +10 -0
- package/esm2022/table-select/page-table-select/page-table-select.component.mjs +3 -3
- package/esm2022/table-select/table-select/table-select.component.mjs +3 -3
- package/esm2022/util/lib/getElementByTag.mjs +31 -0
- package/esm2022/util/public-api.mjs +2 -1
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs +64 -40
- package/fesm2022/ng-zorro-antd-extension-configurable-query.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-print.mjs +637 -0
- package/fesm2022/ng-zorro-antd-extension-print.mjs.map +1 -0
- package/fesm2022/ng-zorro-antd-extension-table-select.mjs +4 -4
- package/fesm2022/ng-zorro-antd-extension-table-select.mjs.map +1 -1
- package/fesm2022/ng-zorro-antd-extension-util.mjs +32 -1
- package/fesm2022/ng-zorro-antd-extension-util.mjs.map +1 -1
- package/package.json +14 -7
- package/pipes/safe-url.pipe.d.ts +1 -1
- package/print/index.d.ts +5 -0
- package/print/nzx-print-content.directive.d.ts +10 -0
- package/print/nzx-print-v.component.d.ts +45 -0
- package/print/nzx-print.component.d.ts +34 -0
- package/print/nzx-print.directive.d.ts +17 -0
- package/print/nzx-print.module.d.ts +13 -0
- package/print/public-api.d.ts +9 -0
- package/public-api.d.ts +1 -1
- package/table-select/abstract-table-select.d.ts +1 -1
- package/timer-button/timer-button.directive.d.ts +1 -1
- package/util/lib/getElementByTag.d.ts +8 -0
- 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=
|