10.23.0 • Published 1 month ago

gm-printer v10.23.0

Weekly downloads
309
License
ISC
Repository
github
Last release
1 month 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 软件包都必须遵守该约定,这一点非常重要,因为整个系统都依赖于此。

版本发布 参考链接

一般版本发布分为如下几个版:

  • 内测版本(alpha)
  • 公测版本(beta)
  • 正式版本的候选版本(rc: release candiate)
  • 正式版本

发布操作如下:

前情提要:

  • 发布重大版本或版本改动较大时,先发布alpha、beta、rc等先行版本。
  • pageage.json中的version修改为X.X.X-beta.0,或者运行 npm version X.X.X-beta.0来更新package.json,同时创建一个 git 标签参考
npm login # 输入用户名和密码

# 之后发布你要发布的测试版本
npm publish --tag (alpha | beta)

# 或发布正式版用
npm publish

上述操作在自己的分支上进行发布版本即可,发完后,将分支合并到 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.23.0

1 month ago

10.23.0-beta.0

1 month ago

10.22.0-beta.1

1 month ago

10.22.0-beta.0

1 month ago

10.21.0-beta.0

2 months ago

10.18.0-beta.0

2 months ago

10.19.0

2 months ago

10.20.0-beta

2 months ago

10.18.0

2 months ago

10.16.1

2 months ago

10.17.0

2 months ago

10.16.1-beta.0

2 months ago

10.16.0

7 months ago

10.15.6

7 months ago

10.16.0-beta.1

8 months ago

10.16.0-beta.2

8 months ago

10.16.0-beta.0

8 months ago

10.15.6-beta.0

12 months ago

10.15.5-beta.0

1 year ago

10.15.5

1 year ago

10.15.4

2 years ago

10.15.3

2 years ago

10.14.7-beta.3

2 years ago

10.14.11-alpha.0

2 years ago

10.14.10

2 years ago

10.14.4-alpha.0

2 years ago

10.14.4-alpha.1

2 years ago

10.15.2-alpha.2

2 years ago

10.15.2-alpha.0

2 years ago

10.14.10-alpha.0

2 years ago

10.14.9-beta.4

2 years ago

10.14.9-beta.3

2 years ago

10.15.1

2 years ago

10.14.6-alpha.0

2 years ago

10.14.4-beta.1

2 years ago

10.14.4-beta.2

2 years ago

10.14.4-beta.3

2 years ago

10.14.4-beta.0

2 years ago

10.15.1-alpha.1

2 years ago

10.15.1-alpha.2

2 years ago

10.15.1-alpha.0

2 years ago

10.15.1-alpha.3

2 years ago

10.14.8

2 years ago

10.14.9

2 years ago

10.14.6

2 years ago

10.14.7

2 years ago

10.14.5

2 years ago

10.15.9-beta.0

2 years ago

10.15.1-beta.1

2 years ago

10.14.8-alpha.0

2 years ago

10.13.13-alpha.1

2 years ago

10.14.5-alpha.2

2 years ago

10.14.3

2 years ago

10.14.4

2 years ago

10.14.5-alpha.1

2 years ago

10.14.5-alpha.0

2 years ago

10.13.12-alpha.3

2 years ago

10.13.12-alpha.4

2 years ago

10.13.15-alpha.0

2 years ago

10.14.3-alpha.1

2 years ago

10.13.14-alpha.0

2 years ago

10.14.1-alpha.7

2 years ago

10.14.1-alpha.6

2 years ago

10.14.1-alpha.5

2 years ago

10.14.1-alpha.4

2 years ago

10.14.1-alpha.3

2 years ago

10.14.1-alpha.2

2 years ago

10.14.1-alpha.1

2 years ago

10.14.1-alpha.0

2 years ago

10.14.1-alpha.8

2 years ago

10.14.2

2 years ago

10.14.1

2 years ago

10.13.17-alpha.0

2 years ago

10.14.2-alpha.1

2 years ago

10.14.2-alpha.2

2 years ago

10.14.2-alpha.0

2 years ago

10.14.2-alpha.5

2 years ago

10.14.2-alpha.3

2 years ago

10.14.2-alpha.4

2 years ago

10.13.16-alpha.0

2 years ago

10.13.19-alpha.0

2 years ago

10.13.15

2 years ago

10.13.14

2 years ago

10.13.17

2 years ago

10.13.16

2 years ago

10.13.19

2 years ago

10.13.12

2 years ago

10.13.18-alpha.0

2 years ago

10.13.13-alpha.0

2 years ago

10.13.12-alpha.1

2 years ago

10.13.12-alpha.2

2 years ago

10.13.12-alpha.0

2 years ago

10.13.9-beta.1

2 years ago

10.13.9-beta.0

2 years ago

10.13.7

2 years ago

10.13.8

2 years ago

10.13.8-alpha.1

2 years ago

10.13.8-alpha.0

2 years ago

10.13.8-alpha.7

2 years ago

10.13.8-alpha.6

2 years ago

10.13.8-alpha.8

2 years ago

10.13.8-alpha.3

2 years ago

10.13.8-alpha.2

2 years ago

10.13.8-alpha.5

2 years ago

10.13.8-alpha.4

2 years ago

10.13.11-alpha.0

2 years ago

10.13.11

2 years ago

10.13.10

2 years ago

10.13.7-beta.10

2 years ago

10.13.7-beta.11

2 years ago

10.13.3

3 years ago

10.13.4

3 years ago

10.13.5

3 years ago

10.13.6

3 years ago

10.13.7-beta.1

3 years ago

10.13.7-beta.2

3 years ago

10.13.7-beta.5

2 years ago

10.13.7-beta.6

2 years ago

10.13.7-beta.3

3 years ago

10.13.7-beta.4

2 years ago

10.13.7-beta.9

2 years ago

10.13.7-beta.7

2 years ago

10.13.7-beta.8

2 years ago

10.13.2-alpha.5

3 years ago

10.13.2-alpha.4

3 years ago

10.13.2-alpha.3

3 years ago

10.13.2-alpha.2

3 years ago

10.13.2-alpha.1

3 years ago

10.13.2

3 years ago

10.13.1-alpha.1

3 years ago

10.13.1

3 years ago

10.13.0

3 years ago

10.12.0

3 years ago

10.12.1

3 years ago

10.11.5

3 years ago

10.11.4-alpha.2

3 years ago

10.11.4-alpha.0

3 years ago

10.11.4-alpha.1

3 years ago

10.11.4

3 years ago

10.11.1

3 years ago

10.11.2

3 years ago

10.11.0-alpha-0

3 years ago

10.11.0-alpha-1

3 years ago

10.11.0-alpha.1

3 years ago

10.11.0

3 years ago

10.10.15

3 years ago

10.11.0-alpha.0

3 years ago

10.10.14

3 years ago

10.10.13-beta.0

3 years ago

10.10.13

3 years ago

10.10.12-beta.0

3 years ago

10.10.12

3 years ago

10.11.5-beta2

3 years ago

10.10.11-beta1

3 years ago

10.10.11-beta0

3 years ago

10.10.11

3 years ago

10.10.10

3 years ago

10.10.9

3 years ago

10.11.5-beta1

3 years ago

10.10.9-beta1

3 years ago

10.10.9-beta3

3 years ago

10.10.9-beta2

3 years ago

10.11.4-beta

3 years ago

10.11.4-beta1

3 years ago

10.10.8

3 years ago

10.10.6-beta2

3 years ago

10.10.6-beta1

3 years ago

10.10.6-beta4

3 years ago

10.11.3

3 years ago

10.10.6

3 years ago

10.10.7

3 years ago

10.10.5

3 years ago

10.10.6-beta.0

3 years ago

10.11.3-beta

3 years ago

10.10.4

3 years ago

10.10.7-beta3

3 years ago

10.10.6-beta3

3 years ago

10.10.5-beta

3 years ago

10.10.2

3 years ago

10.10.3

3 years ago

10.11.2-beta2

3 years ago

10.11.2-beta

3 years ago

10.11.1-beta7

3 years ago

10.10.1

3 years ago

10.11.1-beta6

3 years ago

10.11.1-beta5

3 years ago

10.11.1-beta4

4 years ago

10.11.1-beta3

4 years ago

10.11.1-beta2

4 years ago

10.11.0-beta

4 years ago

10.11.1-beta

4 years ago

10.10.0

4 years ago

10.10.0-beta5

4 years ago

10.9.2

4 years ago

10.10.0-beta4

4 years ago

10.10.0-beta3

4 years ago

10.10.0-beta2

4 years ago

10.10.0-beta

4 years ago

10.9.1

4 years ago

10.3.1-beta.5

4 years ago

10.9.0

4 years ago

10.8.9

4 years ago

10.9.0-beta

4 years ago

10.9.0-beta2

4 years ago

10.8.8

4 years ago

10.8.9-beta

4 years ago

10.8.8-beta

4 years ago

10.8.7

4 years ago

10.8.7-beta

4 years ago

10.8.6

4 years ago

10.8.6-beta

4 years ago

10.8.5

4 years ago

10.8.5-beta5

4 years ago

10.8.4

4 years ago

10.8.5-beta1

4 years ago

10.8.5-beta2

4 years ago

10.8.5-beta3

4 years ago

10.8.5-beta4

4 years ago

10.8.4-beta.2

4 years ago

10.8.4-beta.1

4 years ago

10.8.3

4 years ago

10.8.3-beta

4 years ago

10.8.1

4 years ago

10.8.2

4 years ago

10.8.1-beta

4 years ago

10.8.1-beta2

4 years ago

10.8.0

4 years ago

10.8.0-qrCode.1

4 years ago

10.8.0-qrCode.0

4 years ago

10.8.0-beta2

4 years ago

10.7.4

4 years ago

10.8.0-beta

4 years ago

10.7.4-beta.1

4 years ago

10.7.3

4 years ago

10.7.2

4 years ago

10.7.1

4 years ago

10.7.0

4 years ago

10.6.1

4 years ago

10.7.0-qrCode.0

4 years ago

10.7.0-beta

4 years ago

10.6.1-beta.1

4 years ago

10.7.0-beta.1

4 years ago

10.7.0-beta.0

4 years ago

10.6.0

4 years ago

10.5.1-beta.7

4 years ago

10.5.1-beta.6

4 years ago

10.5.1-beta.5

4 years ago

10.5.1-beta.4

4 years ago

10.5.1-beta.3

4 years ago

10.5.1

4 years ago

10.5.1-beta.2

4 years ago

10.5.1-beta.1

4 years ago

10.5.0

4 years ago

10.4.0

4 years ago

10.4.0-beta.0

4 years ago

10.4.0-beta

4 years ago

10.3.0

4 years ago

10.2.1-beta

4 years ago

10.2.0-beta3

4 years ago

10.2.0-beta2

4 years ago

10.2.0-beta

4 years ago

10.1.0

4 years ago

10.0.0

4 years ago

10.0.0-beta3

4 years ago

10.0.0-beta2

4 years ago

10.0.0-beta

4 years ago

9.7.1

4 years ago

9.7.1-stock

4 years ago

9.6.6-beta

4 years ago

9.6.5-beta

4 years ago

9.5.3-date

4 years ago

9.7.0

4 years ago

9.6.4-beta

4 years ago

9.6.3-beta

4 years ago

9.6.2-beta

4 years ago

9.5.2

4 years ago

9.7.0-beta

4 years ago

9.5.1

4 years ago

9.5.4-beta

4 years ago

9.6.1-beta

4 years ago

9.6.0-beta

4 years ago

9.5.5-beta2

4 years ago

9.5.3-beta

4 years ago

9.5.2-beta

4 years ago

9.5.1-beta

4 years ago

9.5.0

4 years ago

9.4.0-ka2

4 years ago

9.4.0-ka

4 years ago

9.4.0

4 years ago

9.4.0-beta

4 years ago

9.3.8-beta2

4 years ago

9.3.7-beta2

4 years ago

9.3.6-beta2

4 years ago

9.3.6-beta

4 years ago

9.3.7-ka

4 years ago

9.3.6-ka

4 years ago

9.3.5-beta

4 years ago

9.3.4-beta

4 years ago

9.3.3-beta

4 years ago

9.3.2

5 years ago

9.3.1

5 years ago

9.3.0

5 years ago

9.3.0-beta

5 years ago

9.2.2

5 years ago

9.2.1

5 years ago

9.2.0

5 years ago

9.1.2

5 years ago

9.1.1

5 years ago

9.1.0

5 years ago

9.0.3

5 years ago

9.0.2

5 years ago

9.0.1

5 years ago

9.0.0

5 years ago

9.0.0-beta8

5 years ago

9.0.0-beta7

5 years ago

9.0.0-beta6

5 years ago

9.0.0-beta5

5 years ago

9.0.0-beta4

5 years ago

9.0.0-beta3

5 years ago

9.0.0-beta2

5 years ago

9.0.0-beta1

5 years ago

9.0.0-beta

5 years ago

8.0.1

5 years ago

8.0.0

5 years ago

7.1.0

5 years ago

8.0.0-beta

5 years ago

7.0.1

5 years ago

7.0.0

5 years ago

6.1.0-beta2

5 years ago

6.1.0-beta1

5 years ago

6.2.0-beta

5 years ago

6.1.0-beta

5 years ago

6.1.0

5 years ago

6.0.0

5 years ago

5.2.1

5 years ago

6.0.0-beta4

5 years ago

6.0.0-beta3

5 years ago

6.0.0-beta1

5 years ago

6.0.0-beta

5 years ago

5.2.0

5 years ago

5.1.0

5 years ago

5.0.0

5 years ago

5.0.0-beta10

5 years ago

4.0.3

5 years ago

5.0.0-beta9

5 years ago

5.0.0-beta8

5 years ago

5.0.0-beta7

5 years ago

5.0.0-beta6

5 years ago

5.0.0-beta5

5 years ago

5.0.0-beta4

5 years ago

5.0.0-beta3

5 years ago

5.0.0-beta2

5 years ago

4.0.2

5 years ago

4.0.1

5 years ago

4.0.0

5 years ago

5.0.0-beta

5 years ago

3.0.1-beta

5 years ago

3.0.1

5 years ago

3.0.0

5 years ago

2.1.0

5 years ago

2.0.2

5 years ago

2.0.1

5 years ago

2.0.0-beta1

5 years ago

2.0.0

5 years ago

1.0.0-beta4

5 years ago

1.0.0-beta3

5 years ago

1.0.0-beta2

5 years ago

2.0.0-beta

5 years ago

1.0.0-beta1

5 years ago

1.0.0

5 years ago

1.0.0-beta

5 years ago

0.2.26

5 years ago

0.2.25

5 years ago

0.2.24

5 years ago

0.2.23

5 years ago

0.2.23-beta

5 years ago

0.2.22

5 years ago

0.2.21

5 years ago

0.2.20

5 years ago

0.2.19

5 years ago

0.2.18

5 years ago

0.2.17

5 years ago

0.2.16

5 years ago

0.2.15

5 years ago

0.2.14

5 years ago

0.2.13

5 years ago

0.2.12

5 years ago

0.2.11

5 years ago

0.2.10

5 years ago

0.2.9

5 years ago

0.2.8

5 years ago

0.2.7

5 years ago

0.2.6

5 years ago

0.2.5

5 years ago

0.2.4

5 years ago

0.2.3

5 years ago

0.2.2

5 years ago

0.2.1

5 years ago

0.2.0

5 years ago

0.1.17

5 years ago

0.1.16

5 years ago

0.1.15

5 years ago

0.1.14

5 years ago

0.1.13

5 years ago

0.1.12

5 years ago

0.1.11

5 years ago

0.1.10

5 years ago

0.1.9

5 years ago

0.1.8

5 years ago

0.1.7

5 years ago

0.1.6

5 years ago

0.1.5

5 years ago

0.1.4

5 years ago

0.1.3

5 years ago

0.1.2

5 years ago

0.1.1

5 years ago

0.1.0

5 years ago

0.0.13

6 years ago

0.0.12

6 years ago

0.0.11

6 years ago

0.0.10

6 years ago

0.0.9

6 years ago

0.0.8

6 years ago

0.0.7

6 years ago

0.0.6

6 years ago

0.0.5

6 years ago

0.0.4

6 years ago

0.0.2

6 years ago