使用此版本 请更新最新的 print-lock.css
感谢各位提交 PR 的码友们! 感谢~
同时希望各位多看看文档、文章、更新日志; 📢 本页面支持 Ctrl/Command + F 搜索
- 点击 ▶ 可查看详情
01. 🌈 新增面板排列功能 (横向、纵向 支持间距)
- 小模板 传数组 铺满 对应纸张
02. 🌈 新增支持 barcode、qrcode 条码颜色设置
03. 🌈 新增支持 表格列 条形码/二维码值显示设置
04. 🌈 新增支持 全选元素API 可批量删除
hiprintTemplate.selectAllElements();
05. 🌈 新增支持 根据字段名 选中元素
hiprintTemplate.selectElementsByField(['name']);
06. 🌈 新增支持 获取打印机纸张信息 API (客户端^1.0.10)
❗️ node-hiprint-transit 中转暂未添加支持
// 获取指定打印机纸张信息
hiprint.getPaperInfo(printerName);
// 获取所有打印机纸张信息
hiprint.getPaperInfo();
// 获取纸张信息方法是异步请求的,没有返回值,你可以使用 hinnn.event.on("paperSizeInfo", () => {}) 监听数据返回
hinnn.event.on("paperSizeInfo", (paperSize) => {
console.log(paperSize);
});
// [
// {
// "PrinterName": "Microsoft Print to PDF",
// "TaskNumber": 0, // 打印队列数
// "Status": 0, // 设备状态码
// "StatusMsg": "准备就绪(Ready)", // 设备状态信息
// "PaperSizes": [
// {
// "Height": 1100, // 单位 mm
// "Kind": 1,
// "PaperName": "信纸",
// "RawKind": 1,
// "Width": 850 // 单位 mm
// }
// ]
// }
// ]
```> ❗️ node-hiprint-transit 中转暂未添加支持
```js
// 获取指定打印机纸张信息
hiprint.getPaperInfo(printerName);
// 获取所有打印机纸张信息
hiprint.getPaperInfo();
// 获取纸张信息方法是异步请求的,没有返回值,你可以使用 hinnn.event.on("paperSizeInfo", () => {}) 监听数据返回
hinnn.event.on("paperSizeInfo", (paperSize) => {
console.log(paperSize);
});
// [
// {
// "PrinterName": "Microsoft Print to PDF",
// "TaskNumber": 0, // 打印队列数
// "Status": 0, // 设备状态码
// "StatusMsg": "准备就绪(Ready)", // 设备状态信息
// "PaperSizes": [
// {
// "Height": 1100, // 单位 mm
// "Kind": 1,
// "PaperName": "信纸",
// "RawKind": 1,
// "Width": 850 // 单位 mm
// }
// ]
// }
// ]
07. 🌈 新增支持 print2支持分批打印(需客户端 v1.0.11)
支持单模版大单据量连续打印 @george-hong (#138)
hiprintTemplate.print2(printDataList, {
printer: '打印机名称',
title: '打印标题',
printByFragments: true, // 是否需要分批打印,分批打印能够支持连续打印大量数据,但会增加打印所需时间
generateHTMLInterval: 30, // 多条数据生成HTML的间隔,单位ms,默认10
fragmentSize: 10000, // 分片字符长度,默认50000
sendInterval: 20, // 分片传输间隔,单位ms,默认10
})
08. ✨ 调整优化 text、barcode 类型条码自动增加宽度优化
09. ✨ 调整优化 text条形码: 支持设置条码文本模式: 单独文本、svg文本
10. ✨ 调整优化 API 更新元素时 属性同步
11. ✨ 调整优化 缩放时 框选框 移动偏差问题
12. ✨ 调整优化 分组头/脚函数 自动判断return是否包含 tr、td
13. ✨ 调整优化 hiprint.setConfig API
- 支持隐藏参数分组
- 隐藏部分参数分组
14. ✨ 调整优化 update 更新模板时 尺寸跟着改变
15. ✨ 调整优化 静默打印 图片默认不转 base64
16. ✨ 调整优化 表格 分组序号 支持续编
17. ⚠️ 修改 print2 打印成功回调事件为 success
项目初始时 print2 打印成功回调事件即为 successs
事件 (手抖多打了个 s),electron-hiprint v1.0.8 重构关键代码时发现了该问题,为了标准及向下兼容,同时保留了 succsss
和 success
事件,经过 8 个多月的过渡期,现统一改为 success
,该改动仅对 electron-hiprint 1.0.7 及以前的客户端版本造成破坏性更新,后续版本无影响,我们也推荐大家及时更新至 1.0.11 以后的版本,体验更多优秀的功能。
18. 🐛✨🐛✨🐛✨🐛 其他修复或优化见详情(或见 git history)
- 修复选择图片后refresh方法参数real属性无效,以及回调函数可能不会执行的问题
- i18n相关修复优化
- fix: 修复复制元素自动聚焦的bug
- 将图片的缩放控制点从[se,r]改为[s,e,se,r] (#98)
- 修复双击文本出现冒号的bug (#102)
- fix #104 修复表格中存在多列rowSpan时多页rowSpan错误
- 修复表格分页colspan问题
- fix: 修复新添加的条形码/二维码元素-左右对齐参数不生效的问题
- add 表格添加 colgroup 解决分页不显示表头时列宽各种问题
- fix 表格 样式参数设置不生效的 bug
- fix 表格里面当字段类型为图片时,单元格高度设置无效BUG修复,并设置最小高度避免表单高度计算失败
01. 🌈 新增支持 print2支持分批打印(需客户端 v1.0.11)
支持单模版大单据量连续打印 @george-hong (#138)
hiprintTemplate.print2(printDataList, {
printer: '打印机名称',
title: '打印标题',
printByFragments: true, // 是否需要分批打印,分批打印能够支持连续打印大量数据,但会增加打印所需时间
generateHTMLInterval: 30, // 多条数据生成HTML的间隔,单位ms,默认10
fragmentSize: 10000, // 分片字符长度,默认50000
sendInterval: 20, // 分片传输间隔,单位ms,默认10
})
02. ⚠️ 修改 print2 打印成功回调事件为 success
项目初始时 print2 打印成功回调事件即为 successs
事件 (手抖多打了个 s),electron-hiprint v1.0.8 重构关键代码时发现了该问题,为了标准及向下兼容,同时保留了 succsss
和 success
事件,经过 8 个多月的过渡期,现统一改为 success
,该改动仅对 electron-hiprint 1.0.7 及以前的客户端版本造成破坏性更新,后续版本无影响,我们也推荐大家及时更新至 1.0.11 以后的版本,体验更多优秀的功能。
01. 🐛️ fix 表格字段为图片,单元格高度无效修复
表格里面当字段类型为图片时,单元格高度设置无效 BUG 修复,并设置最小高度避免表单高度计算失败 @zhmlsj (#131)
01. ✨ 调整优化 水印 打印无需在浏览器预览勾选背景图案
需要支持 -webkit-print-color-adjust 样式 @Xavier (#129)
01. ✨ 调整优化 setConfig API & 支持隐藏全部/部分参数分组
详细使用查看 demo
01. 🌈 新增支持 添加 selectElementsByField 属性,通过传入field的字符串数组选中文本类型的元素
@xiaolonggee (#123)
hiprintTemplate.selectElementsByField(['name'])
01. ✨ 调整优化 text、barcode 类型条码自动增加宽度优化
经过一段时间的测试及实验,找到了 JsBarcode 与 bwip-js 两个库实现条码宽度自动增加的较优方案。(感谢Q群用户 【︶ㄣ夏^熟 。】的测试)
现在你可以在 text[textType='barcode']、barCode 元素中设置 barAutoWidth 属性,使条码以渲染时 svg 提供的最小尺寸自动增加宽度。
0.0.57-beta20 版本中 条码宽度 = svg宽度 * 1.2,该倍率不是很合理,在此版本中修改为 1.05
02. ✨ 调整优化 模版中心预览图片资源调整
01. 🌈 新增支持 添加 barWidth、barAutoWidth 属性
❗️ 表格中的条码暂未添加这两个属性,待测试验证后在添加
关于条码(barCode),无论是 text[textType='barcode'] 元素还是 0.0.56 新添加的 barCode 元素,一直都有人反馈存在扫码枪无法识别的问题,关于这一问题近期深入研究了一下,以下是对该问题出现原因的猜测:
插件在使用 JsBarcode 这个库生成条码时 #L1972 设置了 width 属性为 1,而生成的条码 svg 又宽度自适应为元素宽度,当元素宽度小于条码包所生成的 svg 宽度时,width 属性实际低于 1,导致扫码枪无法正常识别。
另外也有可能是元素、面板被设置了缩放,导致整体元素尺寸变小,导致条码单位宽度 width 小于 1。
浏览器打印预览的缩放也有可能导致这一问题的产生。
所以为此我们添加了 barWidth、barAutoWidth 两个属性,旨在解决这一问题。
1. 你可以通过设置 barWidth 以调整 text[textType='barcode'] 的单条宽度,以适应不同尺寸的需求(建议的值为 1)。
2. 同时也可以通过设置 barAutoWidth 使条码在渲染时以 svg 提供的最小尺寸自动增加宽度。
- 小于渲染最小尺寸时将自动增加宽度以保障扫码识别
- 大于此尺寸时不进行任何操作
- svg 最小尺寸与 barWidth 有密切关系
另外以 bwip-js 渲染的条码 barCode 元素不支持设置单条宽度,它接收元素 width、height 后会自动渲染,还提供了一个 scale 的参数,用于控制渲染比例(bwip-js对于width这块的描述看了几遍没看懂),为了方便也复用了 barWidth 这个属性,通过改变 barWidth 也能调整条码的识别成功率。
写在最后:
关于条码无法正确识别问题,以上猜测和添加的属性欢迎大家积极测试和讨论,如有不对的地方欢迎指正。
01. 🌈 新增支持 获取打印机纸张信息 Beta ❗️
当客户端运行在 window 系统环境时可以获取打印机纸张信息,你需要自行拉取最新客户端代码electron-hiprint,自行构建最新版本(v1.0.10)
❗️ node-hiprint-transit 中转暂未添加支持
// 获取指定打印机纸张信息
hiprint.getPaperInfo(printerName);
// 获取所有打印机纸张信息
hiprint.getPaperInfo();
// 获取纸张信息方法是异步请求的,没有返回值,你可以使用 hinnn.event.on("paperSizeInfo", () => {}) 监听数据返回
hinnn.event.on("paperSizeInfo", (paperSize) => {
console.log(paperSize);
});
// [
// {
// "PrinterName": "Microsoft Print to PDF",
// "TaskNumber": 0, // 打印队列数
// "Status": 0, // 设备状态码
// "StatusMsg": "准备就绪(Ready)", // 设备状态信息
// "PaperSizes": [
// {
// "Height": 1100, // 单位 mm
// "Kind": 1,
// "PaperName": "信纸",
// "RawKind": 1,
// "Width": 850 // 单位 mm
// }
// ]
// }
// ]
01. ✨ 调整优化 表格添加 colgroup 解决列宽跨页不齐问题
02. ✨ 调整优化 表格分组头、脚格式化函数自动判断 tr、td 包裹
现在你可以直接 return content 内容、td(s) 字符串、tr(s) 字符串,插件将自动检测是否包裹 td、tr 标签,自动补全代码01. 🌈 新增支持 模版 控制元素是否可超出面板
new hiprint.PrintTemplate({
template: panel,
willOutofBounds: true, // 是否允许组件内的控件超出范围
})
02. 🌈 新增支持 拖拽元素 生成 类 QT Designer 唯一 field
new hiprint.PrintTemplate({
template: panel,
qtDesigner: true, // 是否开启类似QT Designer的唯一field生成模式
})
{
"options": {
// ... 省略其他属性 ...
"field": "textType",
"title": "单据类型",
"qid": "textType_1", // 唯一 id
// ... 省略其他属性 ...
},
"printElementType": {
"title": "单据类型",
"type": "text"
}
}
03. ✨ 调整优化 bwip 条码、二维码 填充色统一
设置移入 样式面板 => "条码颜色"
{
"options": {
"barColor": "#000", // 条码、二维码 填充颜色
}
}
04. 🐛️ fix 面板缩放后 框选框不跟鼠标问题
01. 🌈 新增支持 添加全选 api
const template = new hiprint.PrintTemplate({
template: panel,
})
template.selectAllElements()
01. 🌈 新增支持 近期社区 pr 部分中文 i18n 机翻
02. ✨ 调整优化 条形码、二维码,增强条形码、二维码优化
- 基础条形码 标题 改为在元素容器内显示
- 基础二维码 添加 标题
- 增强条形码、二维码 标题 改为在元素容器内显示
- 优化增强二维码始终显示为正方形,防止变形
- 增强二维码添加 eclevel(容错率) 设置
- 优化 resize 控制点
03. 🐛️ fix 修复表格空间不够分页显示错误信息无法正确i18n显示问题
使用此版本 请更新最新的 print-lock.css
- 点击 ▶ 可查看详情
01. 🌈 新增支持 条形码、二维码独立元素,使用 bwip-js 库生成 svg
- 解决原 text 元素中的条形码、二维码 类型不全,生成条码、二维码不清晰的问题
02. 🌈 新增支持 元素参数 国际化 i18n
- 原生为简体中文,英语、德语、西班牙语、法语、意大利语、日语、俄语、繁体中文皆为 AI 机翻,欢迎帮助 订正。
hiprint.init({
lang: 'en', // 设置语言 ['cn', 'en', 'de', 'es', 'fr', 'it', 'ja', 'ru', 'cn_tw']
});
03. 🌈 新增支持 中转服务 node-hiprint-transit
import { hiprint } from 'vue-plugin-hiprint'
hiprint.init({
host: 'https://printjs.cn:17521', // 此处输入服务启动后的地址
token: 'vue-plugin-hiprint', // 用于鉴权的token
});
// or
hiwebSocket.setHost("https://printjs.cn:17521", "vue-plugin-hiprint")
console.log(hiwebSocket.clients, hiwebSocket.printerList)
// 中转服务专有的 api,可获取所有连接中转服务的客户端 v1.0.7
hiprint.getClients()
hiwebSocket.getClients()
// 监听数据返回
hinnn.event.on("clientInfo", (clients) => {
console.log(clients);
});
详情转至 文档说明
04. 🌈 新增支持 客户端信息获取(需客户端^1.0.7)
原本你可以通过 hiprint.getAddress 或 hiwebSocket.getAddress 获取客户端的 ip、ipv6、mac、dns、all、interface、vboxnext 信息,但是需要你主动调用方法去获取。
在 v1.0.7 中我们仍然保留该方式,但移除了用处不大的 dns、interface、vboxnext 类型,同时在连接成功后自动返回客户端 clientInfo 信息
// 手动获取方法
hiprint.getClientInfo()
// or
hiwebSocket.getClientInfo()
// 监听数据返回
hinnn.event.on("clientInfo", (clientInfo) => {
console.log(clientInfo);
});
console.log(hiwebSocket.clientInfo)
{
arch: "x64",
clientUrl: "http://192.168.0.2:17521",
ip: "192.168.0.2",
ipv6: "fe80::13f:eb0f:e426:7c92",
mac: "a1:a2:a3:a4:a5:a6",
machineId: "12c90ff9-b9f4-4178-9099-9dd326b70c2e",
platform: "win32",
printerList: [{
description: "",
displayName: "Microsoft Print to PDF",
isDefault: true,
name: "Microsoft Print to PDF",
options: {,
"printer-location": "",
"printer-make-and-model": "Microsoft Print To PDF",
"system_driverinfo": "Microsoft Print To PDF;10.0.19041.3570 (WinBuild.160101.0800);Microsoft® Windows® Operating System;10.0.19041.3570"
},
status: 0
}, {…}, {…}, {…}, {…}, {…}],
version: "1.0.7",
}
05. 🌈 新增支持 底部聚合格式化函数 tableSummaryFormatter
06. 🌈 新增支持 表格支持设置测试数据 设计时可设置模拟数据
07. ✨ 调整优化 分组表格头/脚函数 返回更多参数,不再局限于td标签内
08. 🐛️ fix 表格最后列(多行表头时) 左边框不显示问题
09. 🐛️ fix 修复表格脚计数 将分组头、脚 计算入内的bug
10. 🐛️ fix 表格脚设置最后显示,前面分页的页脚位置占位空白
11. 🐛️ fix 参数字体大小问题、标尺img max-width 问题(样式问题)
12. 🐛️ fix 参数栏删除按钮未触发数据更新问题
13. 🐛️ fix 更新多面板模板时, 其他面板点击元素 属性渲染问题
14. 🐛️ fix 更新模板json 水印未更新的 bug
15. 🐛️ fix 表格合并列后无法自动撑满整个表格容器
16. 🐛️ fix 空白表格 卡死bug
01. 🌈 新增支持 中转服务 node-hiprint-transit
import { hiprint } from 'vue-plugin-hiprint'
hiprint.init({
host: 'https://printjs.cn:17521', // 此处输入服务启动后的地址
token: 'vue-plugin-hiprint', // 用于鉴权的token
});
// or
hiwebSocket.setHost("https://printjs.cn:17521", "vue-plugin-hiprint")
console.log(hiwebSocket.clients, hiwebSocket.printerList)
// 中转服务专有的 api,可获取所有连接中转服务的客户端 v1.0.7
hiprint.getClients()
hiwebSocket.getClients()
详情转至 文档说明
02. 🌈 新增支持 客户端信息获取
原本你可以通过 hiprint.getAddress 或 hiwebSocket.getAddress 获取客户端的 ip、ipv6、mac、dns、all、interface、vboxnext 信息,但是需要你主动调用方法去获取。
在 v1.0.7 中我们仍然保留该方式,但移除了用处不大的 dns、interface、vboxnext 类型,同时在连接成功后自动返回客户端 clientInfo 信息
// 手动获取方法
hiprint.getClientInfo()
// or
hiwebSocket.getClientInfo()
console.log(hiwebSocket.clientInfo)
{
arch: "x64",
clientUrl: "http://192.168.0.2:17521",
ip: "192.168.0.2",
ipv6: "fe80::13f:eb0f:e426:7c92",
mac: "a1:a2:a3:a4:a5:a6",
machineId: "12c90ff9-b9f4-4178-9099-9dd326b70c2e",
platform: "win32",
printerList: [{
description: "",
displayName: "Microsoft Print to PDF",
isDefault: true,
name: "Microsoft Print to PDF",
options: {,
"printer-location": "",
"printer-make-and-model": "Microsoft Print To PDF",
"system_driverinfo": "Microsoft Print To PDF;10.0.19041.3570 (WinBuild.160101.0800);Microsoft® Windows® Operating System;10.0.19041.3570"
},
status: 0
}, {…}, {…}, {…}, {…}, {…}],
version: "1.0.7",
}
01. 🌈 新增支持 国际化 i18n
原生为简体中文,英语、德语、西班牙语、法语、意大利语、日语、俄语、繁体中文皆为 AI 机翻,欢迎帮助 订正。
hiprint.init({
lang: 'en', // 设置语言 ['cn', 'en', 'de', 'es', 'fr', 'it', 'ja', 'ru', 'cn_tw']
});
01. ✨ 调整优化 与打印服务链接添加 token 可选项
该功能需要 v1.0.7 之后的 客户端(electron-hiprint) 配合使用// 无需自定义 token
hiprint.hiwebSocket.setHost('http://localhost:17521',(connected, e) => {
console.log('connected', connected);
console.log('e', e);
})
// 添加自定义 token
hiprint.hiwebSocket.setHost('http://localhost:17521', 'token',(connected, e) => {
console.log('connected', connected);
console.log('e', e);
})
02. ✨ 调整优化 hiprint.init 初始化 可以传入 host 、token
hiprint.init({
providers: [provider.f],
host: 'http://localhost:17521', // 可在此处设置连接地址与端口号
token: 'token' // 可在此处设置连接 token
});
01. 🌈 新增支持 条形码、二维码独立元素,使用 bwip-js 库生成 svg
解决原 text 元素中的条形码、二维码 类型不全,生成条码、二维码不清晰的问题
⚠️ 使用此版本 请更新最新的 print-lock.css
01. 🌈 新增支持 文本换行参数(不换行、隐藏、省略)
02. 🌈 新增支持 多面板/批量打印 页码续排/重排 选项
03. 🌈 新增支持 多面板选中回调 onSelectPanel 使用场景:当选择回调的时候刷新相关界面设置。
hinnn.event.clear("onSelectPanel");
hinnn.event.on("onSelectPanel", (panel, index, li) => {
console.log("onSelectPanel", panel, index, li);
});
04. ✨ 调整优化 toPdf 支持导出 指定类型(blob、bloburi、dataurl等)见 demo 示例
05. ✨ 调整优化 当表格某一行数据超出最大分页高度时, 无限循环卡死问题(同时给出提示)
06. ✨ 调整优化 行/列合并函数 回调新增 tableData, printData
07. ✨ 调整优化 表格表头 边框参数
08. ✨ 调整优化 旋转角度, input类型为number
09. ✨ 调整优化 文本 上下对齐 参数(改用 grid 实现)
10. ✨ 调整优化 图片元素 显示 隐藏规则 参数
11. 🐛️ fix 缩放后 撤销/重做 再点击元素位置跳动问题
12. 🐛️ fix setConfig 参数不生效 bug
13. 🐛️ fix 聚合函数 最大/小值 显示 Infinity 问题
1. 🌈 新增支持 表格设置"每页最大行数"功能
2. 🌈 新增支持 双击"格式化函数"等, 填充placeholder
3. 🌈 新增支持 "底部聚合合并列数"参数,实现自定义合并列
4. ✨ 调整优化 分页规则:不分页时, 移除thead,tfoot. 直接插入到tbody
5. ✨ 调整优化 默认provider 新增defaultModule.emptyTable
6. 🐛️ fix 框选框 点击时跳位的问题
7. 🐛️ fix updateElementType 错误
8. 🐛️ fix 设计时 清空水印内容 水印未销毁问题
9. 🐛️ fix 行/列合并函数 placeholder 错误
10. 🐛️ fix provider 配置表格列,样式函数等参数是函数时,默认getJson未返回其值的问题
1. 🌈️ 新增支持 水印功能
let json = {
panels:[
// 面板设置 水印参数
// 更多参数可查看本项目 src/hiprint/plugins/watermark.js
"watermarkOptions": {
"content": "vue-plugin-hiprint",
"rotate": 25,
"timestamp": true,
"format": "YYYY-MM-DD HH:mm"
},
]
}
2. ✨ 调整优化 多行表头字段渲染问题
3. ✨ 调整优化 表头合并问题
4. ✨ 调整优化 表格列 部分参数返回默认值问题(getJson不需要返回的值)
5. ✨ 调整优化 支持撤销重做 调整表头/调整列字段 操作
6. ✨ 调整优化 "行/列合并函数" 添加"rowIndex" 行下标回调
7. 🐛️ fix 当有"行/列合并函数" 设置表体行高无效问题
8. 🐛️ fix "行/列合并函数" 分页列缺少/塌陷问题 并支持设置 分页是否清除合并内容
9. 🐛️ fix tableColumn 参数多次提交问题
1. ✨ 调整优化 setHost 支持回调
hiprint.hiwebSocket.setHost('http://localhost:17521',(connected, e) => {
console.log('connected', connected);
console.log('e', e);
})
2. ✨ 调整优化 参数 draggable:false 时,不显示删除按钮
3. ✨ 调整优化 design 网格线支持多面板
4. 🐛️ fix 竖线无法旋转 bug
5. 🐛️ fix hiprint.init error
01. 🌈️ 新增支持 多面板名称自定义功能(创建模板添加 "onPanelAddClick" 和 "defaultPanelName" 属性)
let hiprintTemplate = new hiprint.PrintTemplate({
template: {},
settingContainer: '#PrintElementOptionSetting',
paginationContainer: '.hiprint-printPagination',
defaultPanelName: '默认面板名称', // 默认面板名称(当面板没有 name 属性时)
onPanelAddClick: (panel, createPanel) => {
// 修改名称, 可以弹出输入框, 也可以直接修改
panel.name = '新面板' + (panel.index+1);
// 记得 调用 createPanel 创建面板
createPanel(panel);
},
});
02. 🌈️ 新增支持 吸附线功能 && 优化调整吸附功能 支持设置 吸附阈值等 adsorbMin、showAdsorbLine、adsorbLineMin
hiprint.setConfig({
adsorbMin: 3, //吸附最小距离pt
showAdsorbLine: true, //显示吸附线
adsorbLineMin: 6, //吸附线显示最小距离pt
})
03. 🌈️ 新增支持 table 分组字段函数 和 分组头/脚格式化函数
{
options: {
// 分组统计字段
groupFieldsFormatter: function(groupData,options) {
return ["name"];
}
// 分组表头
groupFormatter: function(groupData,options) {
return '<td></td>';
}
// 分组表脚
groupFooterFormatter: function(groupData,options) {
return '<td></td>';
}
}
}
04. 🌈️ 新增支持 design 显示网格 -> design('#id',{ grid: true })
let hiprintTemplate = new hiprint.PrintTemplate({
template: {},
settingContainer: '#PrintElementOptionSetting',
});
hiprintTemplate.design('#id',{ grid: true });
05. 🌈️ 新增支持 模板获取测试数据Api getTestData
06. 🌈 新增支持 表格列 表格头样式函数 @PromiseAll
07. ✨ 调整优化 update功能,支持更新多面板,并选中默认面板 eg: update({},1)
08. ✨ 调整优化 更改纸张大小时,按比例设置页脚线高度
09. ✨ 调整优化 双击编辑文本时 hover 显示问题
10. ✨ 调整优化 多面板 样式美化
11. 🐛️ fix 多表格 并排问题
12. 🐛️ fix 页眉线/页尾线 宽度问题
13. 🐛️ fix 多选元素 拖拽未选中元素 bug
14. 🐛️ fix 元素旋转 缩放后 点击跳动问题
15. 🐛️ fix 框选时遇hover停滞问题
16. 🐛️ fix 其他一些已知小bug
1. 🌈️ 选中元素新增删除按钮
2. ✨ 调整优化 页码格式 支持 ${paperNo+1} 增量页码
3. ✨ 调整优化 新拖拽元素宽高大小显示
4. ✨ 调整优化 hover元素时显示删除按钮及宽高大小
5. ✨ 调整优化 当图片元素没设置宽高时,获取宽高大小
6. ✨ 调整优化 常见错误 Error 中文提示; 如 tableCustom
7. 🐛️ fix 框选后 getSelectEls 无法获取选中元素 bug
8. 🐛️ fix table 设置表体行高 自动填充 bug
1. 🌈️ 新增支持 文本、表格聚合添加「转大小写」功能 同时提供 hinnn.toUpperCase 方法
hinnn.toUpperCase('0',10.8) // 十点八
hinnn.toUpperCase('5',10.8) // 人民币壹拾元捌角
hinnn.toUpperCase('7',10.8) // 壹拾元捌角零分
2. 🌈️ 新增 表格列"单元格渲染函数"实现自定义单元格内容
// eg: 自定义渲染进度条样式
function(value,row,index,options) {
return `<progress value='${value}' max="1000"></progress>`;
}
3. ✨ 调整优化 放大/缩小时拖拽元素偏移问题, 缩放后拖拽不进设计器的问题
4. ✨ 调整优化 table列 编辑相关问题
5. 🐛️ fix 表格"自动补全"导致底部元素重叠bug
6. 🐛️ fix 'table' 默认可编辑,插入 bug
1. 🌈️ 新增支持 设置 table列 底部聚合文本(tableSummaryText: '自定义文本)
2. 🌈️ 新增支持 设置 table列 底部聚合类型左右对齐方式(tableSummaryAlign: 'left/center/right')
3. 🌈️ 新增支持 设置 table列 底部聚合小数位(tableSummaryNumFormat: '0/1/2/3/4/5/6')
4. 🌈️ 新增支持 编辑查看 table "空白列"
5. ✨ 调整优化 table【多行表头合并】导致"数据错位"及"底部聚合函数"问题
6. ✨ 调整优化 table ⚠️ options: "fields"(列字段列表) "tableFields"(表格字段列表)
7. ✨ 调整优化 table列 底部聚合类型(tableSummary) 支持 text (仅显示设置的文本)
8. 🐛️ fix 模板内"多表格"分页/卡死问题
9. 🐛️ fix 一些已知bug (点击看详情)
1.fix toPdf options isDownload bug (toPdf 传3个参数时未正常导出pdf问题)
2.fix size-box font-family bug
3.fix 多行表头编辑bug
4.fix table 卡死问题(模板内"多表格"分页问题)
5.fix table tableSummaryTitle(底部聚合标题) 参数bug
1. 🐛️ fix webpack/vue2.x npm 引入错误
1. ⚠️ 移除 'tableCustom' 元素 'table' 默认可编辑,插入
2. 🐛 fix 辅助元素 错位问题
3. ✨ 调整优化 支持 cdn 引入 (非vue环境也可正常使用)
<head>
<!-- 打印样式是必须的,你可以调整成自由链接, 注意名称 print-lock.css -->
<link rel="stylesheet" type="text/css" media="print" href="https://unpkg.com/[email protected]/dist/print-lock.css" />
<!-- 下列使用的都是 unpkg提供的 稳定性未知, 建议下载自行处理 -->
<!-- jquery 必须 -->
<script src="https://unpkg.com/[email protected]/dist/jquery.js"></script>
<!-- 条形码 -->
<script src="https://unpkg.com/[email protected]/dist/JsBarcode.all.min.js"></script>
<!-- 颜色选择器 -->
<script src="https://unpkg.com/@claviska/[email protected]/jquery.minicolors.min.js"></script>
<!-- 直接打印(print2)需要 -->
<script src="https://unpkg.com/[email protected]/dist/socket.io.min.js"></script>
<!-- toPdf需要 -->
<script src="https://unpkg.com/[email protected]/lib/umd.js"></script>
<script src="https://unpkg.com/[email protected]/dist/jspdf.umd.min.js"></script>
<script src="https://unpkg.com/[email protected]/dist/html2canvas.js"></script>
<!-- vue-plugin-hiprint 😃 -->
<script src="https://unpkg.com/[email protected]/dist/vue-plugin-hiprint.js"></script>
</head>
<body>
<!-- 注意 defer -->
<script defer>
console.log('vue-plugin-hiprint')
console.log(window['vue-plugin-hiprint'])
console.log('hiprint')
// hiprint 以注入 全局
console.log(hiprint)
var autoConnect = window['vue-plugin-hiprint'].autoConnect,
disAutoConnect = window['vue-plugin-hiprint'].disAutoConnect,
defaultElementTypeProvider = window['vue-plugin-hiprint'].defaultElementTypeProvider;
</script>
</body>
1. ⚠️ 移除 'tableCustom' 元素 'table' 默认可编辑,插入
1. 🐛 fix 辅助元素 错位问题
2. ✨ 调整优化 支持 cdn 引入 (非vue环境也可正常使用)
<head>
<!-- 打印样式是必须的,你可以调整成自由链接, 注意名称 print-lock.css -->
<link rel="stylesheet" type="text/css" media="print" href="https://unpkg.com/[email protected]/dist/print-lock.css" />
<!-- 下列使用的都是 unpkg提供的 稳定性未知, 建议下载自行处理 -->
<!-- jquery 必须 -->
<script src="https://unpkg.com/[email protected]/dist/jquery.js"></script>
<!-- 条形码 -->
<script src="https://unpkg.com/[email protected]/dist/JsBarcode.all.min.js"></script>
<!-- 颜色选择器 -->
<script src="https://unpkg.com/@claviska/[email protected]/jquery.minicolors.min.js"></script>
<!-- 直接打印(print2)需要 -->
<script src="https://unpkg.com/[email protected]/dist/socket.io.min.js"></script>
<!-- toPdf需要 -->
<script src="https://unpkg.com/browse/[email protected]/dist/index.cjs"></script>
<script src="https://unpkg.com/[email protected]/dist/jspdf.umd.min.js"></script>
<script src="https://unpkg.com/[email protected]/dist/html2canvas.js"></script>
<!-- vue-plugin-hiprint 😃 -->
<script src="https://unpkg.com/[email protected]/dist/vue-plugin-hiprint.js"></script>
</head>
1. 🐛 fix 双击编辑后 拖拽/选中 系列bug
2. 🐛 fix 双击编辑 回车/点击其他元素/面板 确认编辑的bug
1. 🌈 新增支持 双击编辑 text 元素
2. 🌈 新增 列参数: tableSummaryTitle 设置是否显示聚合函数标题
3. 🌈 新增 参数: pageBreak 强制分页(让元素下一页开始打印)
4. 🐛 fix 旋转后 拖拽 边界限制 bug
5. 🐛 fix 表格 "一行多组" bug
1. 🌈 新增支持 选择图片后根据原始宽高自定义调整元素宽高
hiprintTemplate = new hiprint.PrintTemplate({
onImageChooseClick: (target) => {
// 测试 3秒后修改图片地址值
setTimeout(() => {
// target.refresh(url,options,callback)
// 自定义处理
// target.refresh(url,false,(el,width,height)=>{
// el.options.width = width;
// el.designTarget.css('width', width + "pt");
// el.designTarget.children('.resize-panel').trigger($.Event('click'));
// })
target.refresh("https://portrait.gitee.com/uploads/avatars/user/1800/5400665_CcSimple_1591166830.png!avatar200", {
// auto: true, // 根据图片宽高自动等比(宽>高?width:height)
// width: true, // 按宽调整高
// height: true, // 按高调整宽
real: true // 根据图片实际尺寸调整(转pt)
})
}, 3000)
}
})
2. ✨ 调整优化 页脚线/页眉线时相互超过时 进行偏移处理
3. ✨ 调整优化 页眉/页脚过近,表格分页卡死情况(无法正常分页计算)
4. 🐛 fix 表格分页高度问题(未计算表格脚高度)
5. 🐛 fix 表格脚"最后显示"及"底部聚合类型"问题
6. 🐛 fix 表格头仅首页显示/不显示时 列宽拖拽调整问题
1. 🐛 socket.io-client 更新到 4.x
2. 🐛 fix 打印预览(getHtml) 页码可拖拽问题
3. 🐛 fix 模板不分页时, table design时模板高度问题
4. 🐛 fix 分页后辅助元素错位问题
5. 🐛 fix getJson 隐藏列未返回问题
6. 🐛 fix 表格脚函数'最后显示'无效问题
7. ✨ 调整优化 样式引入问题(当没有print-lock.css情况现默认空样式)
8. ✨ 调整优化 页眉线问题(小于0时分页显示问题)
9. 🐛 fix 新插入列,选择字段后,'列属性' 空白问题
1. 🌈 新增支持参数面板tabs分组(默认已分组支持自定义分组)
hiprint.setConfig({
text: {
tabs: [
// 隐藏部分 (根据已有分组顺序来)
{
name: '测试', options: [
{
name: 'title',
hidden: false
},
{
name: 'field',
hidden: true
},
]
},
],
},
image: {
tabs: [
{
// 整体替换 及当前选项卡 按新参数设定
replace: true,
name: '基本', options: [
{
name: 'field',
hidden: false
},
{
name: 'src',
hidden: false
},
{
name: 'fit',
hidden: false
}
]
},
],
}
});
2. 🌈 新增支持拖拽元素 "吸附 / 对齐" 功能
3. 🌈 新增Api获取选中元素 "getSelectEls" (框选/按住ctrl/command多选)
// 单选时 返回 [e]
let els = hiprintTemplate.getSelectEls();
console.log(els)
4. 🌈 新增Api更新选中元素参数 "updateOption"
// 更新当前选中元素字体为 12pt
hiprintTemplate.updateOption('fontSize', 12);
// 更新当前选中元素字体粗细为 bolder
hiprintTemplate.updateOption('fontWeight', 'bolder');
5. 🌈 新增Api IPP打印(需客户端1.0.4及以上) "ippPrint","ippRequest"
/**
* 通过IPP 可以调用打印机所提供的功能
* 如:创建打印任务,取消打印任务,通过uri打印文档等等 (需要打印机支持)
* 详见 IPP: https://github.com/williamkapke/ipp
*/
// 不知道打印机 ipp 情况, 可通过 '客户端' 获取一下
const printerList = hiprintTemplate.getPrinterList();
console.log(printerList)
if (!printerList.length) return;
let p = printerList[0];
console.log(p)
// 系统不同, 参数可能不同
let url = p.options['printer-uri-supported'];
// 测试 打印文本
hiprint.ippPrint({
url: url,
// 打印机参数: {version,uri,charset,language}
opt: {},
action: 'Print-Job',
// ipp参数
message: {
"operation-attributes-tag": {
"requesting-user-name": "hiPrint", // 用户名
"job-name": "ipp Test Job", // 任务名
"document-format": "text/plain" // 文档类型
},
// data 需为 Buffer (客户端简单处理了string 转 Buffer), 支持设置 encoding
// data 需为 Buffer (客户端简单处理了string 转 Buffer), 支持设置 encoding
// data 需为 Buffer (客户端简单处理了string 转 Buffer), 支持设置 encoding
// 其他 Uint8Array/ArrayBuffer 默认仅 使用 Buffer.from(data)
// 其他 Uint8Array/ArrayBuffer 默认仅 使用 Buffer.from(data)
// 其他 Uint8Array/ArrayBuffer 默认仅 使用 Buffer.from(data)
// 其他 Uint8Array/ArrayBuffer 默认仅 使用 Buffer.from(data)
data: 'test test test test test test test',
encoding: 'utf-8' // 默认可不传
}
}, (res) => {
// 执行的ipp 任务回调 / 错误回调
console.log(res)
}, (printer) => {
// ipp连接成功 回调 打印机信息
console.log(printer)
})
6. ✨ 调整优化"拖动方向"功能, 支持按住shift 横向拖动, shift+alt 竖向拖动
7. 🌈 新增支持添加自定义/重写参数 通过setConfig
hiprint.setConfig({
optionItems: [
// 自定义添加一个scale参数 (重写及定义一个已存在的name)
function () {
function t() {
// json模板 options 对应键值
this.name = "scale";
}
return t.prototype.css = function (t, e) { // t: 元素对象, e 参数值
if (t && t.length) {
if (e) return t.css('transform', 'scale(' + e + ')');
}
return null;
}, t.prototype.createTarget = function (t,i,e) { // t: 元素对象,i: 元素options, e: 元素printElementType
return this.target = $('<div class="hiprint-option-item">\n <div class="hiprint-option-item-label">\n 缩放\n </div>\n <div class="hiprint-option-item-field">\n <input type="number" class="auto-submit"/>\n </div>\n </div>'), this.target;
}, t.prototype.getValue = function () {
var t = this.target.find("input").val();
if (t) return parseFloat(t.toString());
}, t.prototype.setValue = function (t) { // t: options 对应键的值
this.target.find("input").val(t);
}, t.prototype.destroy = function () {
this.target.remove();
}, t;
}(),
],
// 添加到 样式 tab 下的 transform 后面
text: {
tabs: [
{
name: '基础', options: []
},
{
name: '样式', options: [
{
name: 'scale',
after: 'transform', // 自定义参数,插入在 transform 之后
hidden: false
},
]
}
]
}
})
8. 🌈 新增支持 二维码 "容错率" 参数 {L:1, M:0, Q:3, H:2}
// json模板中配置
options: {
qrcodeLevel: 1 // {L:1, M:0, Q:3, H:2}
}
8. 🐛 一些问题的修复及调整
1. fix 不显示表头时,样式问题
2. fix 元素参数(字体、字间距)对宽高大小框的影响
3. fix printerList、address 回调越来越多的问题
4. fix printSuccess、printError 回调越来越多的问题
5. fix 多选元素 拖拽 辅助线 问题
6. 调整优化 宽高大小/坐标位置 样式 (居中)
7. fix 表格列排序样式问题
8. fix 部分参数设置未及时生效问题(左/右/下边框;上/下/右内边距)
1. 🌈 新增支持设置字体列表fontList
hiprintTemplate = new hiprint.PrintTemplate({
...,
// 自定义可选字体(本机已安装字体)
// 或者使用 hiprintTemplate.setFontList([])
// 或元素中 options.fontList: []
fontList: [
{title:'微软雅黑',value:'Microsoft YaHei'},
{title:'黑体',value:'STHeitiSC-Light'},
{title:'思源黑体',value:'SourceHanSansCN-Normal'},
{title:'王羲之书法体',value:'王羲之书法体'},
{title:'宋体',value:'SimSun'},
{title:'华为楷体',value:'STKaiti'},
{title:'cursive',value:'cursive'},
],
2. ✨ 调整优化横/竖线参数,虚线->长虚线、短虚线
详见参数配置
3. 🐛 fix元素多时卡机的问题(hinnn.event导致)
元素多卡顿问题(hinnn.event导致)
4. ✨ 调整优化部分样式问题,并支持重写(辅助线,始终隐藏元素)样式
始终隐藏元素 重写 .alwaysHide css
position/size-box的样式(层级及元素行高影响问题)
/* 拖拽时元素辅助线 */
.toplineOfPosition, .bottomlineOfPosition {
border: 0;
border-top: 1px dashed rgb(169, 169, 169);
}
.leftlineOfPosition, .rightlineOfPosition {
border: 0;
border-left: 1px dashed rgb(169, 169, 169);
}
5. 🐛 ️fix优化表格列显示隐藏/列排序相关问题
6. ✨ 调整优化列选择/列宽调整的问题
7. 🌈 新增支持设置面板参数显示/隐藏
hiprint.setConfig({
movingDistance: 2.5,
panel: {
supportOptions: [
{
name: 'firstPaperFooter', // 隐藏 首页页尾
hidden: true
},
{
name: 'evenPaperFooter', // 隐藏 偶数页页尾
hidden: true
},
]
}
})
1. 新增支持不打印功能
设置元素 options.showInPage: 'none' 打印时不打印
或在右侧参数 '显示规则' 下列选择 '始终隐藏'
2. 新增刷新获取打印机列表api
// 连接上客户端时 获取最新打印机列表
hiprint.refreshPrinterList((list)=>{
console.log(list)
})
3. 新增获取IP、IPv6、MAC的api
// 连接上客户端时 获取MAC地址等
/**
* 参数格式:
* 1. 类型(ip、ipv6、mac、dns、all、interface、vboxnet)
* 2. 回调 data => {addr, e} addr: 返回的数据 e:错误信息
* 3. 其他参数 ...args
*/
hiprint.getAddress('mac',(data)=>{
console.log('mac')
console.log(data)
})
4. 新增支持设置元素层级
options.zIndex: 10 调整元素层级
或在右侧参数 '元素层级' 中输入 10
5. 调整优化元素设置fields问题
(原无法返回此fields列表,且需设置在元素的printElementType中)
设置元素字段名 options.fields: [{"text":'id',"field":'id']
字段名将变成下列选择样式, getJson() 将返回此列表
6. 新增支持图片地址选择按钮
hiprintTemplate = new hiprint.PrintTemplate({
template: panel,
// 图片选择功能
onImageChooseClick: (target) => {
// target.getValue()
// 测试 3秒后修改图片地址值
setTimeout(()=>{
target.refresh("url")
},3000)
},
settingContainer: '#PrintElementOptionSetting',
});
7. 新增支持图片元素设置缩放格式fit
图片元素设置 options.bject-fix: fill|contain|cover|none
或右侧参数 '图片缩放' 下拉选择
8. 调整优化控制点等比缩放功能
text元素修改为barcode/qrcode时调整控制按钮
右下控制点拖动时等比缩放, 按住shift时可自由缩放
9. 调整优化元素框选功能
从右侧参数栏快速从右往左选择时鼠标移动到design内时框选框的大小问题
-
vue 插件
发布npm包,方便直接使用 -
Ant Design Vue demo
默认拖拽设计、自定义设计、队列打印 -
优化删除元素功能
支持 backSpace/delete 按键删除 -
优化拖动功能
调整优化 不允许元素拖出窗口 按住ctrl/command允许拖出窗口外 -
优化框选功能
fix 原只能从上往下框选问题 -
支持修改默认直接打印主机
window.hiwebSocket.setHost("xxx:17521") -
print优化调整
支持设置callback 见demo的preview.vue -
table/tableCustom优化调整
支持设置options.fields 双击选择字段, -
table优化调整
支持设置isEnableInsertColumn/isEnableDeleteColumn等参数,支持插入/删除列 -
table/tableCustom优化调整
支持设置options.tableHeaderRepeat/tableFooterRepeat 表头/表脚显示模式 -
table优化调整
支持设置 不显示表头 -
条形码优化调整
fix 条码格式错误的问题(EAN-13、ITF、UPC等) -
字段名优化调整
元素的字段名(field) 支持嵌套(eg: a.b.c.d) -
新增支持不分页(小票打印)
可设置不分页 table、longText处理 -
新增支持复制/粘贴
支持 基本元素的ctrl+c/v(复制/粘贴) -
新增支持设置是否自动连接客户端
支持 不自动连接'直接打印'客户端 -
新增支持表格设置列显示类型
支持 设置表格列显示图片、二维码、条形码 -
调整优化表格列拖拽列宽限制
fix 设置旋转角度后 拖拽、跳动、辅助线相关问题 -
npm包新增提供Api打印方法
main.js引入时,Vue原型添加print、print2Api,方便直接打印 -
新增支持多选功能
按住ctrl/command 多选元素 键盘/鼠标拖动 移动 -
调整优化元素设置旋转角度问题
fix 设置旋转角度后 拖拽、跳动、辅助线相关问题 -
新增支持元素拖拽旋转
基本元素上新增旋转控制点,拖拽旋转、双击还原 -
调整优化标尺
使用svg替换原图片标尺,让标尺更清晰 -
新增支持放大缩小功能
提供模板新增zoom方法(transform:scale),放大缩小拖动不乱跳 -
调整优化以支持Vue3.x
调整qrcode.js fix vite项目报错问题 -
元素添加禁止拖拽
panels[n]printElements[m]options.draggable true、false -
添加对齐api
hiprintTemplate.setElsAlign -
表格字段添加聚合功能
表格字段配置 options.columns[n]tableSummary -
新增支持操作历史记录
支持ctrl/command+(shift)+z 撤销重做, 并提供hiprintTemplate的undo,redo方法 -
新增坐标位置参数设置
参数面板新增坐标位置参数,支持同步设置XY坐标,并提供coordinateSync设置默认同步与否 -
新增宽高大小参数设置
参数面板新增宽高大小参数,支持同步设置宽高,并提供widthHeightSync设置默认同步与否 -
新增显示元素坐标位置
拖拽时显示XY坐标位置,并支持两种显示默认,设置positionLineMode,坐标显示在辅助线上 -
新增显示元素宽高大小
点击元素时显示宽高大小,支持重新样式(.resize-panel .size-box) -
新增设置元素距离api
多选元素后设置每个元素的间隔(垂直/水平) hiprintTemplate.setElsSpace(10,true) -
调整优化table表头
支持动态显示/隐藏表头列, getJson时也返回了所有设置的列 -
新增支持更新拖拽元素api
通过tid获取拖拽元素/更新拖拽元素 hiprint.updateElementType(tid,(e)=>e) -
新增支持不打印功能
设置元素 showInPage: 'none' 打印时不打印 -
新增刷新获取打印机列表api
连接上客户端时 通过 hiprint.refreshPrinterList 获取最新打印机列表 -
新增获取IP、IPv6、MAC的api
连接上客户端时 通过 hiprint.getAddress('mac',(data)=>{}) 获取MAC地址 -
新增支持设置元素层级
设置元素 zIndex: 10 调整元素层级 -
调整优化元素设置fields问题
设置元素 options.fields: [{"text":'id',"field":'id']; getJson将返回此列表 -
新增支持图片地址选择按钮
new PrintTemplate时 指定 onImageChooseClick: (target) => {target.refresh('url')} 更新图片地址 -
新增支持图片元素设置缩放格式fit
object-fix: fill|contain|cover|none -
新增支持text元素修改为barcode/qrcode时调整控制按钮
右和下控制点 变成 右下控制点(等比缩放) -
调整优化控制点等比缩放功能
右下控制点拖动时等比缩放, 按住shift时可自由缩放 -
调整优化元素框选功能
从右侧参数栏快速从右往左选择时鼠标移动到design内时框选框的大小问题
setElsAlign 参数说明 | 说明 |
---|---|
left | 左对齐 |
vertical | 居中 |
right | 右对齐 |
top | 顶部对齐 |
horizontal | 垂直居中 |
bottom | 底部对齐 |
distributeHor | 横向分散 |
distributeVer | 纵向分散 |
tableSummary 参数说明 | 说明 |
---|---|
-(缺省或不匹配) | 不聚合 |
count | 计数 |
sum | 合计 |
avg | 平均值 |
min | 最小值 |
max | 最大值 |
setElsSpace 使用示例 | 说明 |
---|---|
.setElsSpace(10) | 垂直距离10(pt) |
.setElsSpace(10,true) | 水平距离10(pt) |