10.28.6 • Published 4 months ago

gm-printer v10.28.6

Weekly downloads
309
License
ISC
Repository
github
Last release
4 months ago

gm-printer

gm-printer 是一个实现开发者自定义网页打印的人类高质量开源库,你可以根据业务需要自定义打印字段配置(配置详情),完成高质量网页打印功能。

开发指南

以下操作将帮助你在本地机器上安装和运行该项目,进行开发

# 先安装依赖
yarn
# 项目启动
yarn start
# 项目构建(基本不怎么使用)
yarn build

安装使用指南

# npm
npm i gm-printer
# 或使用 yarn
yarn add gm-printer

配置目录简述

├── src
│   ├── index.js
│   ├── add_fields # 右侧对应的字段配置
│   ├── data_to_key # 原始数据转换成打印数据
│   ├── mock_data # 模拟数据
│   ├── printer # 打印区域
│   └── template_config # 打印模板配置文件
│       └── config.js # 一些printer配置信息
├── locales # 多语言文件

版本管理

所有的版本都有 3 个数字:x.y.z。

  • 第一个数字是主版本。
  • 第二个数字是次版本。
  • 第三个数字是补丁版本。

当发布新的版本时,不仅仅是随心所欲地增加数字,还要遵循以下规则:

  • 当进行不兼容的 API 更改时,则升级主版本。
  • 当以向后兼容的方式添加功能时,则升级次版本。
  • 当进行向后兼容的缺陷修复时,则升级补丁版本。

该约定在所有编程语言中均被采用,每个 npm 软件包都必须遵守该约定,这一点非常重要,因为整个系统都依赖于此。

版本发布

gm-printer 是一个单独的打印库,使用 github action 发布版本

  1. beta 版本包的版本发布(在自己的 feature|fix 分支),执行 yarn release 后选择 beta 版本

    image-20230509125111428

  2. 正式版本的发布

    1. 提 pr 到 master
    2. 切换到 master,之后执行 yarn release 选择正式版本(注意 minor 和 patch 的区别)image-20230509125629476
  3. 选择后版本后再输入 y,会自动生成 tag 和 push,触发 github action 的 release.yml,且生成 changelogimage-20230509125812166

image-20230509125922115

image-20230509130332523

自此自动发包完成! 上述操作在自己的分支上进行发布版本即可,发完后,将分支合并到 master 上!!!

模板文件(template_config)

config 主要是有下面 6 大部分组成

export default {
  name: '模板名称', // 模板名称
  page: {}, // 模板整体的配置信息
  header: {}, // 页眉(每页都会渲染)
  contents: {}, // 主要内容(contents只渲染一次!第一页放不下,会顺延到次页继续渲染,直至全部渲染)
  sign: {}, // 签名(只在最后一页渲染)
  footer: {} // 页脚(每页都会渲染)
}

一个简单模板配置如下

export default {
  name: '模板名称',
  page: {
    name: 'A4', // 打印纸张名称
    type: 'A4', // 打印纸张规格(如:A5,A6...)
    size: {
      width: '210mm', // 纸张宽度
      height: '297mm' // 纸张高度
    },
    printDirection: 'vertical', // 打印布局方向(两种: vertical, horizontal)
    gap: {
      // 纸张内边距
      paddingRight: '5mm',
      paddingLeft: '5mm',
      paddingBottom: '5mm',
      paddingTop: '5mm'
    }
  },
  header: {
    // 页眉
    blocks: [
      // blocks数组,里面元素
      {
        text: '收货人: {{收货人}}', // 文本块
        style: {
          // 文本块样式
          right: '',
          left: '450px',
          position: 'absolute',
          top: '6px'
        }
      }
    ],
    style: {
      // header 的样式
      height: '97px'
    }
  },
  contents: [
    // contents数组,元素是object.
    {
      blocks: [
        {
          text: '收货人: {{收货人}}', // 模板字符串用{{}}表示
          style: {
            right: '',
            left: '450px',
            position: 'absolute',
            top: '6px'
          }
        }
      ],
      style: {
        height: '78px'
      }
    },
    {
      className: '',
      type: 'table', // type 表明是table
      dataKey: 'orders_category', // table的接受哪些数据. dataKey详细看下文
      subtotal: {
        // 是否显示table每页合计
        show: false
      },
      columns: [
        // 表单列配置
        {
          head: '序号',
          headStyle: {
            // 表头样式
            textAlign: 'center'
          },
          style: {
            // 表格样式
            textAlign: 'center'
          },
          text: '{{列.序号}}' // 表格内容
        }
      ]
    }
  ],
  sign: {
    // 签名(只在最后一页打印)
    blocks: [
      {
        text: '签收人:',
        style: {
          left: '600px',
          position: 'absolute',
          top: '5px'
        }
      }
    ],
    style: {
      height: '46px'
    }
  },
  footer: {
    // 页脚
    blocks: [
      {
        text: '页码: {{当前页码}} / {{页码总数}}',
        style: {
          right: '',
          left: '48%',
          position: 'absolute',
          top: '0px'
        }
      }
    ],
    style: {
      height: '15px'
    }
  }
}

addFields

右侧的添加字段数据

├── commonFields # 块区域的添加字段
├── summaryFields # 合计汇总字段
├── tableFields # 表格区域的添加字段

data 数据

  {
    common: object, // 非表格数据
    _origin: object, // 原始数据
    _counter: object, //
    _table: { // 表格数据(根据模板的不同,进行整理数据)
      orders: kOrders, // 普通
      orders_multi: kOrdersMulti, // 双栏
      orders_multi_vertical: kOrdersMultiVertical, // 双栏(纵向)
      orders_category: kCategory, // 分类
      orders_category_multi: kCategoryMulti, // 分类 + 双栏
      orders_category_multi_vertical: kCategoryMultiVertical, // 分类+双栏(纵向)
      ...
    },
  }

区域表示

header
header.block.0
contents.panel.0 //区域块
contents.panel.0.block.0 //区域块的每一个块
contents.table.0 //区域表格
contents.table.0.column.0 // 区域表格的每一个表格
10.28.6-beta.0

4 months ago

10.28.4-beta.5

4 months ago

10.28.4-beta.4

6 months ago

10.28.5

5 months ago

10.28.6

4 months ago

10.28.3

7 months ago

10.28.4

5 months ago

10.28.1

7 months ago

10.28.2

7 months ago

10.28.0-beta.6

9 months ago

10.28.0-beta.4

9 months ago

10.28.0-beta.5

9 months ago

10.28.0-beta.3

9 months ago

10.28.0-beta.2

9 months ago

10.28.0-beta.1

9 months ago

10.27.7-beta.0

9 months ago

10.27.4-beta.2

10 months ago

10.27.4-beta.1

10 months ago

10.27.4-beta.0

10 months ago

10.27.6

10 months ago

10.27.7

9 months ago

10.27.4

10 months ago

10.27.5

10 months ago

10.27.3

10 months ago

10.27.3-beta.3

10 months ago

10.27.3-beta.4

10 months ago

10.27.3-beta.1

10 months ago

10.27.0-beta.0

11 months ago

10.26.1

11 months ago

10.26.0

12 months ago

10.27.0

11 months ago

10.27.2

11 months ago

10.24.0

1 year ago

10.25.2

12 months ago

10.25.0

12 months ago

10.26.0-beta.1

12 months ago

10.26.0-beta.0

12 months ago

10.25.0-beta.0

1 year ago

10.25.0-beta.1

1 year ago

10.23.0

1 year ago

10.23.0-beta.0

1 year ago

10.22.0-beta.1

1 year ago

10.22.0-beta.0

1 year ago

10.21.0-beta.0

1 year ago

10.18.0-beta.0

1 year ago

10.19.0

1 year ago

10.20.0-beta

1 year ago

10.18.0

1 year ago

10.16.1

1 year ago

10.17.0

1 year ago

10.16.1-beta.0

1 year ago

10.16.0

2 years ago

10.15.6

2 years ago

10.16.0-beta.1

2 years ago

10.16.0-beta.2

2 years ago

10.16.0-beta.0

2 years ago

10.15.6-beta.0

2 years ago

10.15.5-beta.0

3 years ago

10.15.5

3 years ago

10.15.4

3 years ago

10.15.3

3 years ago

10.14.7-beta.3

3 years ago

10.14.11-alpha.0

3 years ago

10.14.10

3 years ago

10.14.4-alpha.0

3 years ago

10.14.4-alpha.1

3 years ago

10.15.2-alpha.2

3 years ago

10.15.2-alpha.0

3 years ago

10.14.10-alpha.0

3 years ago

10.14.9-beta.4

3 years ago

10.14.9-beta.3

3 years ago

10.15.1

3 years ago

10.14.6-alpha.0

3 years ago

10.14.4-beta.1

3 years ago

10.14.4-beta.2

3 years ago

10.14.4-beta.3

3 years ago

10.14.4-beta.0

3 years ago

10.15.1-alpha.1

3 years ago

10.15.1-alpha.2

3 years ago

10.15.1-alpha.0

3 years ago

10.15.1-alpha.3

3 years ago

10.14.8

3 years ago

10.14.9

3 years ago

10.14.6

3 years ago

10.14.7

3 years ago

10.14.5

3 years ago

10.15.9-beta.0

3 years ago

10.15.1-beta.1

3 years ago

10.14.8-alpha.0

3 years ago

10.13.13-alpha.1

3 years ago

10.14.5-alpha.2

3 years ago

10.14.3

3 years ago

10.14.4

3 years ago

10.14.5-alpha.1

3 years ago

10.14.5-alpha.0

3 years ago

10.13.12-alpha.3

3 years ago

10.13.12-alpha.4

3 years ago

10.13.15-alpha.0

3 years ago

10.14.3-alpha.1

3 years ago

10.13.14-alpha.0

3 years ago

10.14.1-alpha.7

3 years ago

10.14.1-alpha.6

3 years ago

10.14.1-alpha.5

3 years ago

10.14.1-alpha.4

3 years ago

10.14.1-alpha.3

3 years ago

10.14.1-alpha.2

3 years ago

10.14.1-alpha.1

3 years ago

10.14.1-alpha.0

3 years ago

10.14.1-alpha.8

3 years ago

10.14.2

3 years ago

10.14.1

3 years ago

10.13.17-alpha.0

3 years ago

10.14.2-alpha.1

3 years ago

10.14.2-alpha.2

3 years ago

10.14.2-alpha.0

3 years ago

10.14.2-alpha.5

3 years ago

10.14.2-alpha.3

3 years ago

10.14.2-alpha.4

3 years ago

10.13.16-alpha.0

3 years ago

10.13.19-alpha.0

3 years ago

10.13.15

3 years ago

10.13.14

3 years ago

10.13.17

3 years ago

10.13.16

3 years ago

10.13.19

3 years ago

10.13.12

3 years ago

10.13.18-alpha.0

3 years ago

10.13.13-alpha.0

3 years ago

10.13.12-alpha.1

3 years ago

10.13.12-alpha.2

3 years ago

10.13.12-alpha.0

3 years ago

10.13.9-beta.1

4 years ago

10.13.9-beta.0

4 years ago

10.13.7

4 years ago

10.13.8

4 years ago

10.13.8-alpha.1

4 years ago

10.13.8-alpha.0

4 years ago

10.13.8-alpha.7

4 years ago

10.13.8-alpha.6

4 years ago

10.13.8-alpha.8

4 years ago

10.13.8-alpha.3

4 years ago

10.13.8-alpha.2

4 years ago

10.13.8-alpha.5

4 years ago

10.13.8-alpha.4

4 years ago

10.13.11-alpha.0

3 years ago

10.13.11

3 years ago

10.13.10

4 years ago

10.13.7-beta.10

4 years ago

10.13.7-beta.11

4 years ago

10.13.3

4 years ago

10.13.4

4 years ago

10.13.5

4 years ago

10.13.6

4 years ago

10.13.7-beta.1

4 years ago

10.13.7-beta.2

4 years ago

10.13.7-beta.5

4 years ago

10.13.7-beta.6

4 years ago

10.13.7-beta.3

4 years ago

10.13.7-beta.4

4 years ago

10.13.7-beta.9

4 years ago

10.13.7-beta.7

4 years ago

10.13.7-beta.8

4 years ago

10.13.2-alpha.5

4 years ago

10.13.2-alpha.4

4 years ago

10.13.2-alpha.3

4 years ago

10.13.2-alpha.2

4 years ago

10.13.2-alpha.1

4 years ago

10.13.2

4 years ago

10.13.1-alpha.1

4 years ago

10.13.1

4 years ago

10.13.0

4 years ago

10.12.0

4 years ago

10.12.1

4 years ago

10.11.5

4 years ago

10.11.4-alpha.2

4 years ago

10.11.4-alpha.0

4 years ago

10.11.4-alpha.1

4 years ago

10.11.4

4 years ago

10.11.1

4 years ago

10.11.2

4 years ago

10.11.0-alpha-0

4 years ago

10.11.0-alpha-1

4 years ago

10.11.0-alpha.1

4 years ago

10.11.0

4 years ago

10.10.15

4 years ago

10.11.0-alpha.0

4 years ago

10.10.14

4 years ago

10.10.13-beta.0

4 years ago

10.10.13

4 years ago

10.10.12-beta.0

4 years ago

10.10.12

4 years ago

10.11.5-beta2

4 years ago

10.10.11-beta1

4 years ago

10.10.11-beta0

4 years ago

10.10.11

4 years ago

10.10.10

4 years ago

10.10.9

4 years ago

10.11.5-beta1

4 years ago

10.10.9-beta1

4 years ago

10.10.9-beta3

4 years ago

10.10.9-beta2

4 years ago

10.11.4-beta

4 years ago

10.11.4-beta1

4 years ago

10.10.8

4 years ago

10.10.6-beta2

4 years ago

10.10.6-beta1

4 years ago

10.10.6-beta4

4 years ago

10.11.3

4 years ago

10.10.6

4 years ago

10.10.7

4 years ago

10.10.5

4 years ago

10.10.6-beta.0

4 years ago

10.11.3-beta

4 years ago

10.10.4

4 years ago

10.10.7-beta3

4 years ago

10.10.6-beta3

4 years ago

10.10.5-beta

4 years ago

10.10.2

4 years ago

10.10.3

4 years ago

10.11.2-beta2

4 years ago

10.11.2-beta

4 years ago

10.11.1-beta7

4 years ago

10.10.1

4 years ago

10.11.1-beta6

5 years ago

10.11.1-beta5

5 years ago

10.11.1-beta4

5 years ago

10.11.1-beta3

5 years ago

10.11.1-beta2

5 years ago

10.11.0-beta

5 years ago

10.11.1-beta

5 years ago

10.10.0

5 years ago

10.10.0-beta5

5 years ago

10.9.2

5 years ago

10.10.0-beta4

5 years ago

10.10.0-beta3

5 years ago

10.10.0-beta2

5 years ago

10.10.0-beta

5 years ago

10.9.1

5 years ago

10.3.1-beta.5

5 years ago

10.9.0

5 years ago

10.8.9

5 years ago

10.9.0-beta

5 years ago

10.9.0-beta2

5 years ago

10.8.8

5 years ago

10.8.9-beta

5 years ago

10.8.8-beta

5 years ago

10.8.7

5 years ago

10.8.7-beta

5 years ago

10.8.6

5 years ago

10.8.6-beta

5 years ago

10.8.5

5 years ago

10.8.5-beta5

5 years ago

10.8.4

5 years ago

10.8.5-beta1

5 years ago

10.8.5-beta2

5 years ago

10.8.5-beta3

5 years ago

10.8.5-beta4

5 years ago

10.8.4-beta.2

5 years ago

10.8.4-beta.1

5 years ago

10.8.3

5 years ago

10.8.3-beta

5 years ago

10.8.1

5 years ago

10.8.2

5 years ago

10.8.1-beta

5 years ago

10.8.1-beta2

5 years ago

10.8.0

5 years ago

10.8.0-qrCode.1

5 years ago

10.8.0-qrCode.0

5 years ago

10.8.0-beta2

5 years ago

10.7.4

5 years ago

10.8.0-beta

5 years ago

10.7.4-beta.1

5 years ago

10.7.3

5 years ago

10.7.2

5 years ago

10.7.1

5 years ago

10.7.0

5 years ago

10.6.1

5 years ago

10.7.0-qrCode.0

5 years ago

10.7.0-beta

5 years ago

10.6.1-beta.1

5 years ago

10.7.0-beta.1

5 years ago

10.7.0-beta.0

5 years ago

10.6.0

5 years ago

10.5.1-beta.7

5 years ago

10.5.1-beta.6

5 years ago

10.5.1-beta.5

5 years ago

10.5.1-beta.4

5 years ago

10.5.1-beta.3

5 years ago

10.5.1

5 years ago

10.5.1-beta.2

5 years ago

10.5.1-beta.1

5 years ago

10.5.0

5 years ago

10.4.0

5 years ago

10.4.0-beta.0

5 years ago

10.4.0-beta

5 years ago

10.3.0

5 years ago

10.2.1-beta

5 years ago

10.2.0-beta3

5 years ago

10.2.0-beta2

6 years ago

10.2.0-beta

6 years ago

10.1.0

6 years ago

10.0.0

6 years ago

10.0.0-beta3

6 years ago

10.0.0-beta2

6 years ago

10.0.0-beta

6 years ago

9.7.1

6 years ago

9.7.1-stock

6 years ago

9.6.6-beta

6 years ago

9.6.5-beta

6 years ago

9.5.3-date

6 years ago

9.7.0

6 years ago

9.6.4-beta

6 years ago

9.6.3-beta

6 years ago

9.6.2-beta

6 years ago

9.5.2

6 years ago

9.7.0-beta

6 years ago

9.5.1

6 years ago

9.5.4-beta

6 years ago

9.6.1-beta

6 years ago

9.6.0-beta

6 years ago

9.5.5-beta2

6 years ago

9.5.3-beta

6 years ago

9.5.2-beta

6 years ago

9.5.1-beta

6 years ago

9.5.0

6 years ago

9.4.0-ka2

6 years ago

9.4.0-ka

6 years ago

9.4.0

6 years ago

9.4.0-beta

6 years ago

9.3.8-beta2

6 years ago

9.3.7-beta2

6 years ago

9.3.6-beta2

6 years ago

9.3.6-beta

6 years ago

9.3.7-ka

6 years ago

9.3.6-ka

6 years ago

9.3.5-beta

6 years ago

9.3.4-beta

6 years ago

9.3.3-beta

6 years ago

9.3.2

6 years ago

9.3.1

6 years ago

9.3.0

6 years ago

9.3.0-beta

6 years ago

9.2.2

6 years ago

9.2.1

6 years ago

9.2.0

6 years ago

9.1.2

6 years ago

9.1.1

6 years ago

9.1.0

6 years ago

9.0.3

6 years ago

9.0.2

6 years ago

9.0.1

6 years ago

9.0.0

6 years ago

9.0.0-beta8

6 years ago

9.0.0-beta7

6 years ago

9.0.0-beta6

6 years ago

9.0.0-beta5

6 years ago

9.0.0-beta4

6 years ago

9.0.0-beta3

6 years ago

9.0.0-beta2

6 years ago

9.0.0-beta1

6 years ago

9.0.0-beta

6 years ago

8.0.1

6 years ago

8.0.0

6 years ago

7.1.0

6 years ago

8.0.0-beta

6 years ago

7.0.1

6 years ago

7.0.0

6 years ago

6.1.0-beta2

6 years ago

6.1.0-beta1

6 years ago

6.2.0-beta

6 years ago

6.1.0-beta

6 years ago

6.1.0

6 years ago

6.0.0

6 years ago

5.2.1

6 years ago

6.0.0-beta4

6 years ago

6.0.0-beta3

6 years ago

6.0.0-beta1

6 years ago

6.0.0-beta

6 years ago

5.2.0

6 years ago

5.1.0

6 years ago

5.0.0

6 years ago

5.0.0-beta10

6 years ago

4.0.3

6 years ago

5.0.0-beta9

6 years ago

5.0.0-beta8

6 years ago

5.0.0-beta7

6 years ago

5.0.0-beta6

6 years ago

5.0.0-beta5

6 years ago

5.0.0-beta4

6 years ago

5.0.0-beta3

6 years ago

5.0.0-beta2

6 years ago

4.0.2

6 years ago

4.0.1

6 years ago

4.0.0

6 years ago

5.0.0-beta

6 years ago

3.0.1-beta

6 years ago

3.0.1

6 years ago

3.0.0

6 years ago

2.1.0

6 years ago

2.0.2

6 years ago

2.0.1

6 years ago

2.0.0-beta1

6 years ago

2.0.0

6 years ago

1.0.0-beta4

6 years ago

1.0.0-beta3

6 years ago

1.0.0-beta2

6 years ago

2.0.0-beta

6 years ago

1.0.0-beta1

6 years ago

1.0.0

6 years ago

1.0.0-beta

6 years ago

0.2.26

6 years ago

0.2.25

6 years ago

0.2.24

6 years ago

0.2.23

6 years ago

0.2.23-beta

6 years ago

0.2.22

6 years ago

0.2.21

6 years ago

0.2.20

6 years ago

0.2.19

7 years ago

0.2.18

7 years ago

0.2.17

7 years ago

0.2.16

7 years ago

0.2.15

7 years ago

0.2.14

7 years ago

0.2.13

7 years ago

0.2.12

7 years ago

0.2.11

7 years ago

0.2.10

7 years ago

0.2.9

7 years ago

0.2.8

7 years ago

0.2.7

7 years ago

0.2.6

7 years ago

0.2.5

7 years ago

0.2.4

7 years ago

0.2.3

7 years ago

0.2.2

7 years ago

0.2.1

7 years ago

0.2.0

7 years ago

0.1.17

7 years ago

0.1.16

7 years ago

0.1.15

7 years ago

0.1.14

7 years ago

0.1.13

7 years ago

0.1.12

7 years ago

0.1.11

7 years ago

0.1.10

7 years ago

0.1.9

7 years ago

0.1.8

7 years ago

0.1.7

7 years ago

0.1.6

7 years ago

0.1.5

7 years ago

0.1.4

7 years ago

0.1.3

7 years ago

0.1.2

7 years ago

0.1.1

7 years ago

0.1.0

7 years ago

0.0.13

7 years ago

0.0.12

7 years ago

0.0.11

7 years ago

0.0.10

7 years ago

0.0.9

7 years ago

0.0.8

7 years ago

0.0.7

7 years ago

0.0.6

7 years ago

0.0.5

7 years ago

0.0.4

7 years ago

0.0.2

7 years ago