printing.dart
4.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
* Copyright (C) 2017, David PHAM-VAN <dev.nfet.net@gmail.com>
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
part of printing;
typedef LayoutCallback = FutureOr<List<int>> Function(PdfPageFormat format);
mixin Printing {
static const MethodChannel _channel = MethodChannel('printing');
static LayoutCallback _onLayout;
static Completer<List<int>> _onHtmlRendered;
static Future<void> _handleMethod(MethodCall call) async {
switch (call.method) {
case 'onLayout':
final List<int> bytes = await _onLayout(PdfPageFormat(
call.arguments['width'],
call.arguments['height'],
marginLeft: call.arguments['marginLeft'],
marginTop: call.arguments['marginTop'],
marginRight: call.arguments['marginRight'],
marginBottom: call.arguments['marginBottom'],
));
final Map<String, dynamic> params = <String, dynamic>{
'doc': Uint8List.fromList(bytes),
};
return await _channel.invokeMethod('writePdf', params);
case 'onHtmlRendered':
_onHtmlRendered.complete(call.arguments);
break;
case 'onHtmlError':
_onHtmlRendered.completeError(call.arguments);
break;
}
}
/// Prints a Pdf document to a local printer using the platform UI
/// the Pdf document is re-built in a [LayoutCallback] each time the
/// user changes a setting like the page format or orientation.
static Future<void> layoutPdf(
{@required LayoutCallback onLayout, String name = 'Document'}) async {
_onLayout = onLayout;
_channel.setMethodCallHandler(_handleMethod);
final Map<String, dynamic> params = <String, dynamic>{'name': name};
return await _channel.invokeMethod('printPdf', params);
}
/// Prints a [PdfDocument] or a pdf stream to a local printer using the platform UI
@Deprecated('use Printing.layoutPdf(onLayout: (_) => document.save());')
static Future<void> printPdf(
{@Deprecated('use bytes with document.save()') PdfDocument document,
List<int> bytes}) async {
assert(document != null || bytes != null);
assert(!(document == null && bytes == null));
layoutPdf(
onLayout: (PdfPageFormat format) =>
document != null ? document.save() : bytes);
}
/// Displays a platform popup to share the Pdf document to another application
static Future<void> sharePdf(
{@Deprecated('use bytes with document.save()') PdfDocument document,
List<int> bytes,
String filename,
Rect bounds}) async {
assert(document != null || bytes != null);
assert(!(document == null && bytes == null));
if (document != null) {
bytes = document.save();
}
bounds ??= Rect.fromCircle(center: Offset.zero, radius: 10);
final Map<String, dynamic> params = <String, dynamic>{
'doc': Uint8List.fromList(bytes),
'name': filename,
'x': bounds.left,
'y': bounds.top,
'w': bounds.width,
'h': bounds.height,
};
return await _channel.invokeMethod('sharePdf', params);
}
static Future<List<int>> convertHtml(
{@required String html,
String baseUrl,
PdfPageFormat format = PdfPageFormat.a4}) async {
final Map<String, dynamic> params = <String, dynamic>{
'html': html,
'baseUrl': baseUrl,
'width': format.width,
'height': format.height,
'marginLeft': format.marginLeft,
'marginTop': format.marginTop,
'marginRight': format.marginRight,
'marginBottom': format.marginBottom,
};
_channel.setMethodCallHandler(_handleMethod);
_onHtmlRendered = Completer<List<int>>();
await _channel.invokeMethod<void>('convertHtml', params);
return _onHtmlRendered.future;
}
}