@byzk/document-web-reader
TypeScript icon, indicating that this package has built-in type declarations

1.1.2 • Public • Published

在 web 中中阅读文件并对文件进行签章的视图展示库, 底层采用图片进行展示,文件转换功能以及印章操作相关功能需由调用方自行完成,本库只提供基础接口

目录

安装
示例

安装

浏览器中使用

<script src="https://raw.githubusercontent.com/SuLinXin66/bk-web-document-reader/main/dist/index-iife.min.js"></script>

注: 如果要兼容 IE 系列浏览器请引用如下 js

<script src="https://cdn.jsdelivr.net/npm/es6-promise@4/dist/es6-promise.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/es6-promise@4/dist/es6-promise.auto.min.js"></script>
<script src="https://raw.githubusercontent.com/SuLinXin66/bk-web-document-reader/main/dist/index-iife-ie.min.js"></script>

npm 中使用

npm install --save @byzk/document-web-reader

yarn 中使用

yarn add @byzk/document-web-reader

示例

浏览器中使用示例

<!DOCTYPE html>
<html lang="zh_CN">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <script type="text/javascript" src="./dist/index-iife-ie.min.js"></script>
    <style>
      #app {
        margin: 0;
        padding: 0;
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
      }
    </style>
    <style>
      .seal-list-content:first-child {
        margin-top: 18px;
      }

      .seal-list-content {
        padding: 12px 0;
        transition: all 0.5s;
        cursor: pointer;
      }

      .seal-list-content:hover,
      .seal-list-content.active {
        background-color: rgba(255, 255, 255, 0.8);
      }
    </style>
  </head>

  <body>
    <div id="app">我是APP</div>
    <input accept="application/pdf" type="file" id="file" />
  </body>

  <script>
    window.unitConversion = function () {
      /**
       * 获取DPI
       * @returns {Array}
       */
      this.conversion_getDPI = function () {
        var arrDPI = new Array();
        if (window.screen.deviceXDPI) {
          arrDPI[0] = window.screen.deviceXDPI;
          arrDPI[1] = window.screen.deviceYDPI;
        } else {
          var tmpNode = document.createElement("DIV");
          tmpNode.style.cssText =
            "width:1in;height:1in;position:absolute;left:0px;top:0px;z-index:99;visibility:hidden";
          document.body.appendChild(tmpNode);
          arrDPI[0] = parseInt(tmpNode.offsetWidth);
          arrDPI[1] = parseInt(tmpNode.offsetHeight);
          tmpNode.parentNode.removeChild(tmpNode);
        }
        return arrDPI;
      };
      /**
       * px转换为mm
       * @param value
       * @returns {number}
       */
      this.pxConversionMm = function (value) {
        var inch = value / this.conversion_getDPI()[0];
        var c_value = inch * 33.8;
        //      console.log(c_value);
        return c_value;
      };
      /**
       * mm转换为px
       * @param value
       * @returns {number}
       */
      this.mmConversionPx = function (value) {
        var inch = value / 26.4;
        var c_value = inch * this.conversion_getDPI()[0];
        //      console.log(c_value);
        return c_value;
      };
    };
  </script>
  <script>
    const usbkeyServerUrl = "https://192.168.85.140:48000/api";
    // const usbkeyServerUrl = "https://127.0.0.1:48000/api";
    const unitConversion = new window.unitConversion();
    window.getSealList = async () => {
      try {
        // const passwd = window.prompt("请输入Key密码")
        const passwd = "88888888";
        const getUsbkeyCertAlgResult = await (
          await fetch(`${usbkeyServerUrl}/EPSAPP_GetUsbKeyCertAlg`, {
            method: "post",
          })
        ).json();
        if (getUsbkeyCertAlgResult.code !== 0) {
          throw new Error(getUsbkeyCertAlgResult.msg);
        }

        const serverSealListData = new URLSearchParams();
        serverSealListData.append("password", passwd);
        serverSealListData.append("keyType", getUsbkeyCertAlgResult.keyType);
        const serverSealList = await (
          await fetch(`${usbkeyServerUrl}/EPSAPP_GetServerStampList`, {
            method: "post",
            body: serverSealListData,
          })
        ).json();
        if (serverSealList.code !== 0) {
          throw new Error(serverSealList.msg);
        }
        return serverSealList.sealImgList;
      } catch (e) {
        alert("获取签章列表失败: " + e.message);
      }
    };

    window.addSeal = async (sealInfo) => {
      try {
        debugger;
        const getUsbkeyCertAlgResult = await (
          await fetch(`${usbkeyServerUrl}/EPSAPP_GetUsbKeyCertAlg`, {
            method: "post",
          })
        ).json();
        if (getUsbkeyCertAlgResult.code !== 0) {
          throw getUsbkeyCertAlgResult.msg;
        }

        // fetch(`${usbkeyServerUrl}/EPSAPP_GetFile`, {
        //     method: "post"
        // })

        const x = parseInt(unitConversion.pxConversionMm(sealInfo.x)) + "";
        const y = parseInt(unitConversion.pxConversionMm(sealInfo.y)) + "";

        const signatureStampExData = new URLSearchParams();
        signatureStampExData.append("password", "88888888");
        signatureStampExData.append("file", window.pdfFileBase64);
        signatureStampExData.append("keyType", getUsbkeyCertAlgResult.keyType);
        signatureStampExData.append(
          "qzList",
          JSON.stringify([
            {
              sealID: sealInfo.sealInfo.id,
              pageNum: sealInfo.pageNum + "",
              x,
              y,
            },
          ])
        );
        const signatureStampExResult = await (
          await fetch(`${usbkeyServerUrl}/EPSAPP_SignatureStampEx`, {
            method: "post",
            body: signatureStampExData,
          })
        ).json();
        if (signatureStampExResult.code !== 0) {
          throw new Error(signatureStampExResult.msg);
        }

        const lastFileResult = await (
          await fetch(`${usbkeyServerUrl}/EPSAPP_GetLastFile`, {
            method: "post",
          })
        ).json();
        if (lastFileResult.code !== 0) {
          throw new Error(lastFileResult.msg);
        }

        const signFile = lastFileResult.lastFile;

        const data = new FormData();
        data.append("data", signFile);
        const result = await fetch(
          "http://127.0.0.1:8061/pdf/convert/bas464/png",
          {
            method: "post",
            body: data,
          }
        );
        const jsonData = await result.json();
        if (jsonData.error) {
          throw new Error(jsonData.msg);
        }

        window.pdfFileBase64 = jsonData.result.base64File;

        return jsonData.result;
      } catch (e) {
        alert("添加印章失败 => " + e.message);
        return undefined;
      }
    };
  </script>
  <script>
    window.h = readerLib.snabbdom.h;
    window.onload = function () {
      var reader = readerLib.newReader(document.getElementById("app"));
      const sealContentList = [];

      const readerParam = {
        toolbars: {
          btns: [
            {
              text: "打开",
              on: {
                click: function () {
                  document.getElementById("file").click();
                },
              },
            },
          ],
        },
        sideTollbars: {
          nodes: [
            {
              text: "印章列表",
              imageUrl:
                "",
              on: {
                click: async (event, isOpen) => {
                  if (!isOpen) {
                    return;
                  }
                  const sealList = await window.getSealList();
                  if (!sealList) {
                    return false;
                  }

                  const unitConversion = new window.unitConversion();
                  const width = unitConversion.mmConversionPx(30);
                  const height = unitConversion.mmConversionPx(30);
                  for (let i = 0; i < sealList.length; i++) {
                    const img = new Image();
                    sealList[i].sealImgUrl =
                      "data:image/png;base64," + sealList[i].sealImg;
                    // img.src = sealList[i].sealImgUrl;
                    sealList[i].width = width;
                    sealList[i].height = height;
                    sealList[i].positionBase = "leftBottom";
                  }

                  sealContentList.splice(0, sealList.length);
                  sealList.forEach((seal) => {
                    sealContentList.push({
                      ele: h(
                        "div.seal-list-content",
                        {
                          style: {
                            width: "100%",
                          },
                        },
                        h("img", {
                          props: {
                            src: seal.sealImgUrl,
                          },
                          style: {
                            width: "138px",
                            height: "138px",
                            display: "block",
                            margin: "0 auto",
                          },
                          on: {
                            click: (event) => {
                              event.preventDefault();
                              event.stopPropagation();
                              const ele = event.target.parentElement;

                              const sealListContents = document.getElementsByClassName(
                                "seal-list-content"
                              );
                              for (let sealContent of sealListContents) {
                                if (sealContent === ele) {
                                  continue;
                                }
                                sealContent.className = "";
                              }

                              const className = ele.className;
                              if (className.includes("active")) {
                                ele.className = "seal-list-content";
                                reader.cancelDragSeal();
                                return;
                              }

                              ele.className = "seal-list-content active";
                              reader.dragSeal(seal);
                              // reader.dragSeal({
                              //     sealImgUrl: "https://up.66152.com/allimg/2139/39_88909.jpg",
                              //     width: 138,
                              //     height: 138
                              // })
                            },
                          },
                        })
                      ),
                    });
                  });
                  reader.updateView();
                },
              },
              contents: sealContentList,
            },
          ],
          hide: true,
        },
        // bottomToolbars: {
        //     show: true
        // },
        reader: {
          type: 2,
          page: true,
          zoom: {
            show: true,
          },
          action: {
            loadFileInterface: {
              loadingOk: (loadAllOk, currentLoadPage) => {
                reader.updateView({
                  sideTollbars: {
                    hide: false,
                  },
                });
              },
              filePathConvertPng: async (path) => {
                const result = await fetch(
                  "http://127.0.0.1:8061/pdf/convert/path/png?p=" + path
                );
                const data = await result.json();
                if (data.error) {
                  throw data.msg;
                }
                return data.result;
              },
              fileConvertPng: async (file) => {
                const data = new FormData();
                data.append("file", file);
                const result = await fetch(
                  "http://127.0.0.1:8061/pdf/convert/file/png",
                  {
                    method: "post",
                    body: data,
                  }
                );
                const jsonData = await result.json();
                if (jsonData.error) {
                  throw jsonData.msg;
                }

                window.pdfFileBase64 = jsonData.result.base64File;

                return jsonData.result;
              },
              getPageInfo: async (fileId, currentPage) => {
                const result = await fetch("http://127.0.0.1:8061/get/png", {
                  method: "post",
                  body: JSON.stringify({
                    id: fileId,
                    currentPage: currentPage - 1,
                  }),
                });
                const data = await result.json();
                if (data.error) {
                  throw data.msg;
                }
                return data.result;
              },
            },
            sealInterface: {
              addSeal: async (data) => {
                try {
                  return await window.addSeal(data);
                } catch (e) {}
              },
            },
          },
          sealContextMenu: {
            menuItems: [
              {
                type: "text",
                text: "测试验章",
              },
            ],
          },
        },
      };

      document.getElementById("file").onchange = async function (event) {
        const file = event.target.files[0];
        file.path =
          "/Users/sulinxin/Documents/00-projects/01-博雅中科/02-电子签章应用平台/03-code/02-go/javaseal/test_datas/cs1_temp_temp.pdf";
        reader.updateView({
          sideToolbars: {
            hide: true,
          },
        });

        try {
          await reader.loadFile(file);
        } catch (e) {
          alert("文件加载出错: " + e.message);
          reader.updateView({
            sideToolbars: {
              hide: true,
            },
          });
        } finally {
          event.target.value = "";
        }
      };

      reader.initView(readerParam);
    };
  </script>
</html>

Package Sidebar

Install

npm i @byzk/document-web-reader

Weekly Downloads

5

Version

1.1.2

License

ISC

Unpacked Size

2.65 MB

Total Files

142

Last publish

Collaborators

  • wuhen68