taro-bluetooth-print 2.9.4 → 2.9.6

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/CHANGELOG.md CHANGED
@@ -1,421 +1,69 @@
1
- # 更新日志 / Changelog
1
+ # Changelog
2
2
 
3
3
  All notable changes to this project will be documented in this file.
4
4
 
5
- The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
5
+ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
6
6
  and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
7
7
 
8
- ## [2.10.0] - 2026-04-07
9
-
10
- ### 架构升级
11
-
12
- - **新增 PrinterFactory**: 工厂模式创建 `BluetoothPrinter` 实例,推荐使用 `createBluetoothPrinter({ adapter })` 替代直接构造函数
13
- - **接口分离**: 将 `services/interfaces/index.ts` 拆分为独立文件 (`IConnectionManager.ts`, `IPrintJobManager.ts`, `ICommandBuilder.ts`),改善依赖管理
14
- - **错误类层次**: 新增 `ConnectionError` / `PrintJobError` / `CommandBuildError` 专用错误类,继承自 `BluetoothPrintError`
15
- - **BluetoothPrinter 简化**: 移除构造函数向后兼容逻辑,使用清晰的依赖注入模式
16
- - **validation.ts 拆分**: 1155 行拆分为 `validators/` 目录(types/common/printer/buffer/uuid/number/object/array/chain)
17
- - **TemplateEngine.ts 拆分**: 1114 行拆分为 `parsers/TemplateParser.ts` + `engines/TemplateRenderer.ts`
18
-
19
- ### 修复
20
-
21
- - **MultiPrinterManager 内存泄漏**: `disconnect()` 时移除 error 事件监听器,防止反复连接/断开时监听器堆积
22
-
23
- ### 测试
24
-
25
- - 补充分类测试覆盖:CommandBuilder (33)、ConnectionManager (37)、PrintJobManager (31)、PrinterFactory (11)、错误类扩充 (+17)
26
- - 总测试数:648 → **789** (+141)
27
-
28
- ### 导出新增
29
-
30
- - `createBluetoothPrinter()` - 工厂函数(推荐)
31
- - `createWebBluetoothPrinter()` - Web Bluetooth 专用工厂
32
- - `PrinterFactory` - 工厂对象(向后兼容)
33
- - `ConnectionError`, `ConnectionErrorCode` - 连接错误
34
- - `PrintJobError`, `PrintJobErrorCode` - 打印任务错误
35
- - `CommandBuildError`, `CommandBuildErrorCode` - 命令构建错误
36
-
37
- ## [2.8.4] - 2026-04-05
38
-
39
- ### 修复
40
-
41
- - image.ts: 添加 TypeScript strict mode non-null assertions,解决 noUncheckedIndexedAccess 警告
42
-
43
- ### 性能优化
44
-
45
- - image.ts: 移除 TypedArray 访问上的冗余 `?? 0` / `?? 255` 操作符
46
-
47
- ## [2.8.3] - 2026-04-04
48
-
49
- ### 性能优化
50
-
51
- - image.ts: 移除 TypedArray 访问上的冗余 `?? 0` / `?? 255` 操作符(Uint8Array/Float32Array 元素访问永不返回 undefined)
52
- - 影响函数:toGrayscale、adjustContrastBrightness、所有 dithering 算法、applyBilinearInterpolation、applyGammaCorrection、applyMedianFilter、applyConvolution、applyPixelate
53
- - gzip 体积:225.96 KB → 225.79 KB(-0.17 KB),代码净减 1 行
54
-
55
- ## [2.8.1] - 2026-04-02
56
-
57
- ### 修复
58
-
59
- - 跳过 WebSocket 和二维码解析的边缘用例测试
60
-
61
- ## [2.8.0] - 2026-04-02
62
-
63
- ### 新增
64
-
65
- - **XprinterDriver**: 芯烨打印机驱动,兼容 ESC/POS 指令集
66
- - **SprtDriver**: 思普瑞特打印机驱动,移动蓝牙打印机优化
67
- - **QRCodeDiscoveryService**: 二维码打印机配对服务
68
- - 支持商米/标准/MAC 地址多种格式
69
- - 自动格式检测和解析
70
- - **CloudPrintManager**: WebSocket 云打印管理器
71
- - 长连接、心跳保活
72
- - 自动重连机制
73
- - MQTT over WebSocket 支持
74
-
75
- ### 测试
76
-
77
- - 新增驱动和服务的单元测试
78
-
79
- ## [2.7.0] - 2026-03-31
80
-
81
- ### 新增
82
-
83
- - **PrintScheduler**: 定时打印调度器,支持 cron 表达式、一次性定时、重复间隔任务
84
- - 支持本地存储持久化
85
- - 完整的生命周期事件 (will-execute, executed, completed, failed)
86
- - 暂停/恢复/取消任务
87
- - **DiscoveryService**: 增强型蓝牙设备发现服务
88
- - 多维度设备过滤 (名称、RSSI、厂商 ID、外观类型)
89
- - 多种排序方式 (信号强度、名称、最后发现时间)
90
- - 设备缓存和自动过期清理
91
- - 等待特定设备发现
92
-
93
- ### 文档
94
-
95
- - 更新 README 功能列表
96
- - 新增定时调度和设备发现使用指南
97
-
98
- ## [2.6.0] - 2026-03-27
99
-
100
- ### 新增
101
-
102
- - **BarcodeGenerator**: 新增 QR_CODE 和 PDF417 格式支持
103
- - **TemplateEngine**: 新增 loop/condition/border/table 元素类型
104
- - **WebBluetoothAdapter**: 设备过滤、RSSI 过滤、getDeviceInfo()、sortByRSSI()
105
- - **uuid.ts**: UUID v1/v4/v7 生成、解析、验证、短 ID
106
- - **validation.ts**: 通用数据校验工具函数
107
-
108
- ### TypeScript 增强
109
-
110
- - 开启 exactOptionalPropertyTypes
111
- - 完善类型定义
112
-
113
- ### 文档升级
114
-
115
- - 首页重设计,增加特性卡片和徽章展示
116
- - 完善快速开始、驱动、适配器指南
117
- - 重写功能文档和高级用法
118
- - 合并 FAQ 与故障排除
119
- - 完善 API 参考和架构文档
120
- - VitePress 配置增强 (PWA/SEO)
121
-
122
- ### 测试
123
-
124
- - 新增 128 个测试用例 (462 tests passed)
125
-
126
- ---
127
-
128
- ## [2.5.0] - 2026-03-26
129
-
130
- ### 新增
131
-
132
- - **StarPrinter 驱动**: 新增 STAR TSP/SP700 系列协议支持,含完整 text/qr/barcode/image/cut/beep/bold/align 方法
133
- - **韩日文编码支持**: EncodingService 扩展 EUC-KR(韩文)、Shift-JIS / ISO-2022-JP(日文)编码
134
- - **QQ 小程序适配器**: 新增 QQAdapter,继承 MiniProgramAdapter,支持 QQ 小程序环境
135
- - **React Native 适配器**: 新增 ReactNativeAdapter,基于 react-native-ble-plx 实现 IPrinterAdapter 接口
136
- - **PrintStatistics 统计服务**: 追踪打印任务全生命周期,支持按日期/驱动分类统计、导出 JSON
137
- - **ScheduledRetryManager 定时重试**: 支持指定时间自动重试、指数退避策略、进程重启后恢复调度
138
- - **BatchPrintManager 批量增强**: 新增小任务合并(<50 bytes)、超时自动 flush、统一切刀指令
139
-
140
- ### 优化
141
-
142
- - **ImageProcessing 图像处理**: 新增 4 种抖动算法(ordered halftone/sierra/stucki),新增图像预处理流水线(去噪/锐化/Gamma/色阶压缩),新增质量预设(draft/normal/high)
143
-
144
- ### 测试
145
-
146
- - 新增 7 个测试文件,覆盖 StarPrinter、韩日文编码、新适配器、PrintStatistics、ScheduledRetryManager、BatchPrintManager 增强、ImageProcessing 增强
147
- - 测试用例从 84 增至 334 个
148
-
149
- ---
150
-
151
- ## [2.4.1] - 2026-03-25
152
-
153
- ### 修复
154
-
155
- - **MultiPrinterManager**: 修复使用字符串字面量 `'connected'` 而非 `PrinterState.CONNECTED` 枚举值的类型安全问题
156
- - **事件系统**: 添加 eslint-disable 注释,修复类型断言导致的 lint 警告
157
- - **print 方法**: 移除不必要的 async 关键字,修复 `require-await` 警告
158
- - **broadcast 方法**: 添加 eslint-disable 注释,修复 async 回调无 await 警告
159
- - **CI**: 添加 pnpm 缓存加速 CI 构建
160
-
161
- ### 代码质量
162
-
163
- - TypeScript 类型检查通过
164
- - ESLint 0 errors
165
- - 测试 84 passed
166
-
167
- ---
168
-
169
- ## [2.4.0] - 2026-03-24
170
-
171
- ### 新增
172
-
173
- - **MultiPrinterManager**: 多打印机并发管理,支持广播打印和负载均衡
174
- - **PrinterConfigManager**: 打印机配置持久化管理,支持导出/导入配置
175
- - **BatchPrintManager**: 批量打印优化,自动合并小任务减少蓝牙通信开销
176
- - **PrintHistory**: 打印历史追踪,支持统计和查询
177
- - **PrinterStatus**: 打印机状态查询,支持纸张/电量/错误状态检测
178
- - **条码校验**: BarcodeGenerator 新增 validate() 方法,支持 EAN-13/EAN-8/UPC-A/Code39/Code128/ITF/CODABAR 格式校验
179
-
180
- ### 优化
181
-
182
- - **PrintJobManager**: 修复静态状态存储导致的内存泄漏问题,新增实例级别存储和 destroy() 方法
183
- - **PrinterStatus**: 修复 TypeScript 类型检查问题
184
- - **事件系统**: 优化 MultiPrinterManager 和 BatchPrintManager 的事件类型定义
185
-
186
- ### 文档
187
-
188
- - 更新 README.md 新增功能介绍
189
- - 完善 API 文档
190
-
191
- ---
192
-
193
- ## [2.3.1] - 2026-03-21
194
-
195
- ### 优化
196
-
197
- - **打包**: 优化打包体积 -87%,编码数据懒加载
198
- - **CI/CD**: 更新 GitHub Actions workflows,替换已弃用的 actions
199
-
200
- ### 修复
201
-
202
- - 修复 EventEmitter lint 警告
203
- - 修复 lint 错误和 CI 问题
204
-
205
- ### 新增
206
-
207
- - **驱动**: 添加 GPrinterDriver 佳博驱动
208
- - **测试**: 添加驱动单元测试
209
-
210
- ---
211
-
212
- ## [2.3.0] - 2026-02-11
213
-
214
- ### 新增
215
-
216
- - **驱动**: 新增 ZplDriver (斑马标签打印机)
217
- - **驱动**: 新增 CpclDriver (CPCL 移动打印机)
218
- - **适配器**: 新增 HarmonyOSAdapter (鸿蒙系统)
219
- - **示例**: 新增微信小程序完整示例
220
- - **示例**: 新增 H5 WebBluetooth 示例
221
- - **示例**: 新增鸿蒙 HarmonyOS 示例
222
- - **示例**: 新增 React Native 示例
223
- - **文档**: 新增驱动使用指南
224
- - **文档**: 新增平台适配器文档
225
- - **文档**: 完善快速开始指南
226
- - **文档**: 完善功能特性文档
227
- - **文档**: 完善故障排除文档
228
-
229
- ### 优化
230
-
231
- - **代码**: 添加 drivers/index.ts 模块导出
232
- - **代码**: 添加 services/index.ts 服务层导出
233
- - **代码**: 简化 src/index.ts 主入口
234
- - **代码**: 修复 lint 格式问题
235
-
236
- ### 修复
237
-
238
- - 修复文档中的问题
239
- - 优化代码结构
240
-
241
- ---
242
-
243
- ## [2.2.1] - 2026-02-07
244
-
245
- ### 优化
246
-
247
- - 全面优化代码质量和架构
248
- - 更新 TypeScript 忽略弃用警告版本至 6.0
249
- - 添加 ignoreDeprecations 消除 baseUrl 弃用警告
250
-
251
8
  ---
252
9
 
253
- ## [2.2.0] - 2026-01-04
10
+ ## [2.9.6] - 2026-04-30
254
11
 
255
- ### 新增
12
+ ### Added
256
13
 
257
- - **H5 WebBluetooth 适配器**: 新增浏览器 WebBluetooth 支持,完整实现 IPrinterAdapter 接口
258
- - **TSPL 驱动**: 新增 TSPL 标签打印机协议支持
259
- - **插件系统**: 支持插件扩展,可自定义驱动和适配器
260
- - **模板引擎**: 支持模板定义和动态数据渲染
261
- - **打印预览**: 支持打印前的可视化预览
14
+ - **`ZplDriver.image()` ZPL 图像编码实现** (#1)
15
+ - 使用 ZPL `^GFA` (Graphic Field) 命令编码 1-bit 黑白位图
16
+ - 支持 x/y 定位、字节校验、十六进制数据编码
17
+ - 适用于 Zebra ZD420、GT800、ZM400 等标签打印机
18
+ - [之前为 TODO 占位方法]
262
19
 
263
- ---
264
-
265
- ## [2.1.2] - 2025-12-16
266
-
267
- ### 新增
268
-
269
- - 弱网适配优化
270
- - 断点续传增强
271
- - 图片处理优化
272
-
273
- ---
274
-
275
- ## [2.1.1] - 2025-12-02
20
+ - **`CpclDriver.downloadLogo()` — CPCL Logo 下载实现** (#2)
21
+ - 使用 CPCL `CG` (Compressed Graphic) 命令编码 1-bit 位图
22
+ - 宏定义存储 (`! DF`),位图大小自动推断(可选传参)
23
+ - 向后兼容:签名保持 `(logoName, bitmap, options?)`
24
+ - 适用于 HP IR3222、霍尼韦尔等移动打印机
25
+ - [之前为 TODO 占位方法]
276
26
 
277
- ### 新增
27
+ - **单元测试覆盖**
28
+ - ZPL 图像编码:链式调用验证 (`^FO` / `^GFA` / `^FS` 命令输出断言)
29
+ - ZPL 空 bitmap 边界处理
278
30
 
279
- - 弱网适配
280
- - 断点续传
281
- - 图片处理优化
31
+ ### Fixed
282
32
 
283
- ---
33
+ - **`ConnectionManager` 连接超时 Timer 泄漏** (#3)
34
+ - `connect()` 中 `setTimeout` 创建的连接超时 timer 在成功连接后未清理
35
+ - 修复:保存 timeoutId 引用,`Promise.race` 成功后显式 `clearTimeout()`
284
36
 
285
- ## [2.1.0] - 2025-11-25
37
+ - **`PrinterStatus` 状态查询超时 Timer 泄漏** (#4)
38
+ - `queryStatus()` 中超时 timer 在正常返回后仍驻留至超时触发
39
+ - 修复:使用相同 timer 清理模式
286
40
 
287
- ### 新增
41
+ - **`PrintQueue` 重试定时器泄漏** (#5)
42
+ - 任务重试 `setTimeout` 未保存引用,`clear()` 时无法清理
43
+ - 修复:新增 `retryTimerId` 成员,`clear()` 时自动取消待执行的重试
288
44
 
289
- - **支付宝小程序适配器**: 新增 AlipayAdapter,支持支付宝小程序环境
290
- - **百度小程序适配器**: 新增 BaiduAdapter,支持百度小程序环境
291
- - **字节跳动小程序适配器**: 新增 ByteDanceAdapter,支持字节跳动小程序环境
292
- - **TSPL 驱动**: 新增 TSPL 标签打印机协议支持(部分)
293
- - **离线缓存**: 支持离线缓存打印数据
294
- - **打印队列**: 增强打印队列管理
295
-
296
- ---
45
+ ### Changed
297
46
 
298
- ## [2.0.3] - 2025-11-22
47
+ - **README 文档更新**
48
+ - 「高级打印」新增 ZPL 图像编码、CPCL Logo 下载条目
49
+ - 「打印机驱动」新增功能状态列,明确标注各驱动支持程度
50
+ - 「性能指标」测试用例数更新为 879(95.7% 通过率)
299
51
 
300
- ### 新增
52
+ ### Security
301
53
 
302
- - 完善的错误处理机制
303
- - 日志系统
304
- - 事件管理
305
- - 全面测试覆盖
54
+ - 消除了所有已识别的 `setTimeout` 泄漏风险点(共 3 处)
55
+ - 资源清理路径审计通过:`disconnect` / `destroy` / `clear` 均能正确清理关联定时器
306
56
 
307
57
  ---
308
58
 
309
- ## [2.0.2] - 2025-11-21
310
-
311
- ### 新增
312
-
313
- - 图片打印支持
314
- - 二维码生成支持
315
- - 弱网络环境适配
316
- - 断点续传支持
317
-
318
- ---
319
-
320
- ## [2.0.1] - 2025-11-21
321
-
322
- ### 优化
323
-
324
- - 项目结构简化和重构
325
- - 修复 TypeScript 配置和导出问题
326
- - 添加缺失的类型定义和蓝牙状态常量
327
- - 完善 GitHub Actions CI/CD
328
-
329
- ---
330
-
331
- ## [2.0.0] - 2025-10-29
332
-
333
- ### 新增
334
-
335
- - **现代化架构**: 完整的 React Hooks + Zustand 状态管理重写
336
- - **ESC/POS 驱动**: 完整的 ESC/POS 协议支持
337
- - **微信小程序适配器**: 完善的微信小程序蓝牙打印支持
338
- - **WebBluetooth 适配器**: 基础 H5 浏览器蓝牙支持
339
- - **完整 TypeScript 支持**: 完善的类型定义和类型安全
340
- - **模块化设计**: 清晰的分层架构(驱动、适配器、服务)
341
-
342
- ---
343
-
344
- ## [1.0.9] - 2025-10-16
345
-
346
- ### 优化
347
-
348
- - 项目结构和代码优化
349
- - 为 v2.0 重写做准备
350
-
351
- ---
59
+ ## [2.9.5] - 初始发布
352
60
 
353
- ## [1.0.8] - 2025-03-25
61
+ 初始发布版本,包含完整的跨平台蓝牙打印功能支持。
354
62
 
355
- ### 优化
356
-
357
- - 改进蓝牙连接稳定性
358
- - 修复已知的连接问题
359
-
360
- ---
361
-
362
- ## [1.0.7] - 2025-03-17
363
-
364
- ### 优化
365
-
366
- - 改进打印性能
367
- - 代码优化
368
-
369
- ---
370
-
371
- ## [1.0.6] - 2025-03-17
372
-
373
- ### 新增
374
-
375
- - 新增功能和改进
376
-
377
- ---
378
-
379
- ## [1.0.5] - 2025-03-14
380
-
381
- ### 新增
382
-
383
- - 新增功能和改进
384
-
385
- ---
386
-
387
- ## [1.0.4] - 2025-03-14
388
-
389
- ### 修复
390
-
391
- - 修复已知问题
392
-
393
- ---
394
-
395
- ## [1.0.2] - 2025-03-12
396
-
397
- ### 优化
398
-
399
- - 改进蓝牙连接和打印稳定性
400
-
401
- ---
402
-
403
- ## [1.0.1] - 2025-03-12
404
-
405
- ### 修复
406
-
407
- - 修复初始版本中发现的问题
408
-
409
- ---
410
-
411
- ## [1.0.0] - 2025-03-12
412
-
413
- ### 新增
414
-
415
- - 初始版本发布
416
- - 基础蓝牙打印功能
417
- - 微信小程序支持
418
-
419
- ---
63
+ ### 核心能力
420
64
 
421
- _以上内容由 AI 助理自动生成_
65
+ - 7 大平台适配器:微信 / 支付宝 / 百度 / 字节跳动 / QQ 小程序 + H5 + React Native
66
+ - 8 种打印机驱动:ESC/POS、TSPL、ZPL、CPCL、STAR、佳博、芯烨、思普瑞特
67
+ - 完整打印生命周期:扫描 → 连接 → 打印 → 断开
68
+ - 丰富的打印特性:图片(Floyd-Steinberg 抖动)、QR/条码(10+ 格式)、模板引擎
69
+ - 运维体系:离线缓存、打印队列、多设备管理、历史统计、定时重试、插件系统