首页 > 其他分享 >PagePlug企业版案例(二)—表单生成Excel文件并发送至邮箱中

PagePlug企业版案例(二)—表单生成Excel文件并发送至邮箱中

时间:2024-07-01 14:29:48浏览次数:21  
标签:10 发送至 PagePlug 代码 Excel 表单 开源 net

一、背景

PagePlug是appsmith中国化项目,一款面向研发开发使用、开源的、前后端一体的低代码工具,拥有强大的可视化建模、数据库和API集成能力,目前已有将近超千家企业将PagePlug低代码开发工具融入内部研发体系,相较于传统的产研开发,使用PagePlug可大幅提升研发效率,节省项目迭代维护成本。更多介绍可点击下方文章查阅:

国内优秀的开源低代码框架:PagePlug,面向研发使用,拒绝重复、低价值的工单循环开发_低代码开源框架-CSDN博客文章浏览阅读3.6k次,点赞15次,收藏22次。面向研发使用、更懂国内企业的开源低代码_低代码开源框架https://blog.csdn.net/AppsmithCN/article/details/131380008随着移动设备的普及和便携性的提升,移动端表单的应用场景越来越广泛,例如企业内部的流程管理、客户服务、用户营销、资料收集等,这些应用场景都能够为企业的工作效率、营收等带来很大的帮助;本次案例将围绕我们常见的一个表单场景——新会员注册,通过PagePlug来搭建会员填写的资料表单,并拓展生成对应的excel文件,并发送至业务部门邮箱中,大家更能体会到PagePlug相较于市面上的表单无代码/低代码(例如:轻流、简道云、宜搭、微搭等),PagePlug与高代码的融合能力,能够满足业务侧更多的个性化需求

目前PagePlug的企业伙伴也有在下列的场景,例如:

  • 业务数据分析:根据业务部门填写的表单据,生成对应的图表内容,并自动发送至各部门负责人的邮箱中

  • 员工请假申请:员工可以在表单中填写请假事由、请假时间等信息,并生成对应的请假申请表格,自动发送给上级审批人和人力资源部门

  • 出差报销表单:使用PagePlug搭建出差申请表单。员工可以填写报销表单(出差地点、时间、预算等),并上传相关发票和凭证。表单提交后,生成excel文件,交由HR和财务部门进行审批和报销处理

二、实战教程

2.1 前置准备

2.2 画布搭建移动端表单

本次案例搭建的表单是新会员在办理会籍时所填写的个人信息资料,在点击提交的时候,会生成一个excel文件发送至对应的业务部门邮箱中

  • 画布类型选择移动端

  • 在画布中可以先拖入一个Form表单组件,之后根据所需填写的资料及内容,选择对应的组件

2.3 生成邮箱测试密码

本次案例以阿里邮箱为例子,若使用其他的邮箱,可查阅相应的文档手册

  • 点击右上角的设置,进入到账户安全的设置中,点击新密码

  • 在邮箱设置中,可以查看发信/收信服务器地址

2.4 新建一个SMTP数据源

  • 在左侧菜单栏中,选择添加数据源,选择SMTP图标

  • 填写对应邮箱的Host address、Port、Username和PassWord(本次示例使用的是阿里云的邮箱服务),配置信息

2.5 新增一个Query查询

  • 配置成功后,点击新建查询

  • 会生成一个新的Query1,我们开始进行对应的内容配置

对应的功能字段介绍:

  • From email :设置消息发件人的邮件地址

  • Reply to email:设置接收对该邮件所有回复的邮件地址

  • To email(s):设置接收该邮件的邮箱地址,对于多个收件人,请用逗号分隔地址;

  • CC email(s):设置接收该邮件的抄送邮箱地址,对于多个抄送收件人,请用逗号分隔地址;

  • BCC email(s):设置接收该邮件的密件抄送邮箱地址,对于多个密件抄送收件人,请用逗号分隔地址;

  • Subject:设置邮件的主题内容

  • Body type:可以设置邮件的内容形式是富文本类型或者是HTML

  • Body:编辑邮件的具体内容

  • Attachment(s):可以将一个或多个文件添加到电子邮件,需要一个文件对象数组

2.6 安装第三方JS库

本次会使用到exceljs库进行excel的数据处理:

  1. 如果在国内的话,可以使用国内源进行安装:https://gcore.jsdelivr.net/npm/[email protected]/dist/exceljs.min.js

  2. 如果可以访问外网的话,可以使用:https://cdn.jsdelivr.net/npm/[email protected]/dist/exceljs.min.js

  • 在工具库中新增exceljs库

  • 可以自行选择上面的链接进行安装

2.7 新建一个JSobject

  • 在左侧菜单栏中,新建一个JS对象(这段代码主要将表单中的组件值通过exceljs处理后,生成对应的excel文件,也支持对单元格背景颜色设置),并命名为:exceljs2,代码如下:

export default {
  myVar1: [],
  myVar2: {},
  test: () => {
    console.log("test01")

  },
  blobToBase64 (blob) {
    return new Promise((resolve, reject) => {
      const fileReader = new FileReader();
      fileReader.onload = (e) => {
        resolve(e.target.result);
      };
      // readAsDataURL
      fileReader.readAsDataURL(blob);
      fileReader.onerror = () => {
        reject(new Error('blobToBase64 error'));
      };
    });
  },
  async handleXlsx () {
    const workbook = new ExcelJS.Workbook();
    workbook.creator = 'Me';
    workbook.lastModifiedBy = 'Her';
    workbook.created = new Date(1985, 8, 30);
    workbook.modified = new Date();
    workbook.lastPrinted = new Date(2016, 9, 27);
    const worksheet = workbook.addWorksheet('My Sheet');
    //这里是数据列表
    const data = [Form1.data];
    // 设置列,这里的width就是列宽
    worksheet.columns = [
      { "header": ["会员资料填写", "", "序号"], "key": "id", "width": 10, },
      { "header": ["", "", "中文姓名"], "key": "cname", "width": 10 },
      { "header": ["", "", "英文姓名"], "key": "ename", "width": 10 },
      { "header": ["", "", "证件类型"], "key": "IDType", "width": 10 },
      { "header": ["", "", "身份证号码"], "key": "IDNumber", "width": 10 },
      { "header": ["", "", "出生日期"], "key": "birthday", "width": 10 },
      { "header": ["", "", "年龄"], "key": "age", "width": 10 },
      { "header": ["", "", "性别"], "key": "gender", "width": 10 },
      { "header": ["", "", "电话号码"], "key": "phone", "width": 10 },
      { "header": ["", "", "国籍"], "key": "nationality", "width": 10 },
      { "header": ["", "", "籍贯"], "key": "nativePlace", "width": 10 },
      { "header": ["", "", "出生地"], "key": "birthPlace", "width": 10 },
      { "header": ["", "", "婚姻状况"], "key": "maritalStatus", "width": 10 },
      { "header": ["", "", "民族"], "key": "ethnicity", "width": 10 },
      { "header": ["", "", "家庭地址"], "key": "address", "width": 10 },
    ]

    // 批量插入数据
    data.forEach(item => worksheet.addRow(item));

    // 设置表头1
    worksheet.mergeCells('A1:O1');
    worksheet.getCell('A1').alignment = { vertical: 'middle', horizontal: 'center' };
    worksheet.getCell('A1').font = { bold: true };
    worksheet.getCell('A1').fill = {
      type: "pattern",
      pattern: "solid",
      fgColor: {
        argb: "ffff00",
      }
    };

    // 设置表头2
    worksheet.mergeCells('P1:W1');
    worksheet.mergeCells('P2:S2');
    worksheet.mergeCells('T2:W2');
    worksheet.getCell('P1').alignment = { vertical: 'middle', horizontal: 'center' };
    worksheet.getCell('P2').alignment = { vertical: 'middle', horizontal: 'center' };
    worksheet.getCell('P1').font = { bold: true };
    // 设置单元格样式
    // 注意:在 exceljs 中所有的的颜色值均为 argb 格式,且不带 # 符号
    worksheet.eachRow((row, rowNumber) => {
      //表头样式
      if (rowNumber <= 3) {
        row.eachCell((cell, colNumber) => {
          cell.font = { size: rowNumber === 3 ? 14 : 16, color: { argb: 'f6ef1b' }, bold: true }
          cell.alignment = { horizontal: 'center', vertical: 'middle' }
          cell.fill = {
            type: "pattern",
            pattern: "solid",
            fgColor: {
              argb: colNumber > 15 ? "5108d3" : "1178d3",
            }
          }
          cell.border = (rowNumber === 1 || rowNumber === 3 || colNumber > 15) ? {
            top: { style: 'thin' },
            left: { style: 'thin' },
            right: { style: 'thin' }
          } : {}
        })
      }
      //设置数据列表样式
      if (rowNumber > 3) {
        row.eachCell(cell => {
          cell.font = { size: 12 };
          cell.alignment = { horizontal: 'center', vertical: 'middle' }
        });
      }
      //设置所有行高
      row.height = 30;
    });

    const buf = await workbook.xlsx.writeBuffer("aaa.xlsx");
    const blob = new Blob([buf], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
    // 下载文件到本地 可以注释掉
    // const url = URL.createObjectURL(blob);
    // await download(url, `employee.xlsx`)
    const sheetName = `面试者-${Form1.data.cname}.xlsx`
    await this.blobToBase64(blob).then(base64data => {
      storeValue("fileData", [
        {
          "type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
          "id": "uppy-employees/xlsx-1e-application/vnd.openxmlformats-officedocument.spreadsheetml.sheet-7632-1712905306789",
          "meta": {
            "relativePath": null,
            "name": sheetName,
            "type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
          },
          "name": sheetName,
          "size": 7632,
          "dataFormat": "Base64",
          data: base64data
        }
      ]);
      sendemail.run({ name: Form1.data.cname }).then(res => {
        showAlert("邮件已发送!", "success")
      });
    })
  }
}

2.8 执行JS函数

  • 配置完JS逻辑后,在表单中的提交按钮绑定对应的JS执行事件

  • 如果需要校验表单填写内容或提交后重置表单,可以点击按钮,并在右下角的表单设置中进行配置

2.9 发送测试

  • 填写完表单内容并点击提交后,就会自动生成一个excel表格发送至对应的收件人邮箱中,我们可以去邮箱里面检查下

三、其他相关案例

  • 工程管理系统:优化数据源信息内容及审批流程

‍ 线上体验地址:工程管理系统

  • 跨境电商仓库管理系统案例:该系统允许用户管理多个仓库的产品和库存、以及跟踪供应商产品和管理供应商

‍ 线上体验地址:跨境电商仓库系统

四、企业版的介绍

如果想了解PagePlug企业版/商业版的价格及更多功能,可放大下方图片查看


对PagePlug上一些功能使用讲解及介绍,可以点击下方文章查看

1、PagePlug企业版开发案例(一)——企微定时群发工具

PagePlug企业版开发案例(一)——企微定时群发工具_pageplug开源低代码融合工作流开发教程——保姆级实战开发-CSDN博客文章浏览阅读944次,点赞31次,收藏16次。快速开发内部应用工具,告别SaaS数据存储安全问题及个性化需求问题_pageplug开源低代码融合工作流开发教程——保姆级实战开发https://blog.csdn.net/AppsmithCN/article/details/135380573icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1353805732、PagePlug开源低代码融合工作流开发教程——保姆级实战开发

PagePlug开源低代码融合工作流开发教程——保姆级实战开发-CSDN博客文章浏览阅读80次。PagePlug是一款面向研发开发使用、开源的、前后端一体的低代码工具,拥有强大的可视化建模和API集成能力,支持与工作流的融合,实现更强大的企业应用开发https://blog.csdn.net/AppsmithCN/article/details/134317961?spm=1001.2014.3001.5501icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/134317961?spm=1001.2014.3001.55013、Formily开发实战——3分钟完成一个登录页的开发,Formily表单与PagePlug低代码的完美融合

Formily开发实战——3分钟完成一个登录页的开发,Formily表单与PagePlug低代码的完美融合_formily github-CSDN博客文章浏览阅读706次,点赞3次,收藏7次。Formily——更高效的表单解决方案与开源低代码Pageplug的融合_formily githubhttps://blog.csdn.net/AppsmithCN/article/details/130765565icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1307655654、国内优秀的开源低代码框架:PagePlug,面向研发使用,拒绝重复、低价值的工单循环开发

国内优秀的开源低代码框架:PagePlug,面向研发使用,拒绝重复、低价值的工单循环开发_低代码开源框架-CSDN博客文章浏览阅读1.9k次,点赞2次,收藏7次。面向研发使用、更懂国内企业的开源低代码_低代码开源框架https://blog.csdn.net/AppsmithCN/article/details/131380008icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1313800085、保姆级低代码实战教程——玩转PagePlug表格开发,增删改查分页如此简单

保姆级开源低代码实战教程——玩转PagePlug表格开发,增删改查分页如此简单_pageplug github-CSDN博客文章浏览阅读997次,点赞3次,收藏7次。面向研发使用开发的开源低代码,比低代码区别很大的,相较于轻流、简道云、轻宜搭、微搭、帆软、活字格等等的低代码灵活性及维护更好_pageplug githubhttps://blog.csdn.net/AppsmithCN/article/details/131210730icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1312107306、PagePlug:低代码平台入门教程—10分钟搭建一个用户改查系统

PagePlug:低代码平台入门教程—10分钟搭建一个用户改查系统-CSDN博客文章浏览阅读635次,点赞2次,收藏5次。PagePlug,面向研发使用的开源低代码平台,10分钟搭建一个用户改查系统_pageplughttps://blog.csdn.net/AppsmithCN/article/details/131790256icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1317902567、PagePlug低代码入门教程——与Websocket的集成

PagePlug低代码入门教程——与Websocket的集成_websockets.send body-CSDN博客文章浏览阅读154次,点赞2次,收藏2次。通过PagePlug低代码与Websocket集成,实现前端页面的数据实时通信_websockets.send bodyhttps://blog.csdn.net/AppsmithCN/article/details/132511483icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/1325114838、PagePlug组件使用技巧(一)——Iframe组件开发日程管理功能

PagePlug组件使用技巧(一)——Iframe组件开发日程管理功能icon-default.png?t=N7T8https://blog.csdn.net/AppsmithCN/article/details/135654077

9、B站上也有一些案例教程,欢迎查看研究~~

​欢迎点赞、收藏、喜欢三连鼓励下哟 ,避免找不到文章啦

标签:10,发送至,PagePlug,代码,Excel,表单,开源,net
From: https://blog.csdn.net/AppsmithCN/article/details/140099192

相关文章

  • Java助力加固Excel文件,保障数据安全
    前言Excel文件保护是常用的一种功能,文件保护主要有三种:添加密码,如果没有密码不允许打开文件。添加密码,如果没有密码,不能修改文件,但可以打开,只读以及另存文件。只读推荐,通常推荐打开Excel文件的用户使用只读模式打开,这种方式仅是一种提示,并非强行保护文件。给Excel添加保护......
  • AI数据分析011:Excel表格智能判断数据起点来计算增长率
    文章目录一、介绍二、输入内容三、输出内容一、介绍计算Excel表格中2023年1月到2024年4月的总增长率和复合增长率。如果数据都有的情况下,公式很简单:总增长率=(O2-B2)/B2复合增长率=POWER((O2/B2),1/13)-1但是,2023年1月、2月、3月的数据,有些有,有些没有,是0......
  • EasyExcel 无法读取图片?用poi写了一个工具类
    在平时的开发中,经常要开发Excel的导入导出功能。一般使用poi或者EasyExcel开发,使用poi做excel比较复杂,大部分开发都会使用EasyExcel因为一行代码就能实现导入和导出的功能。但是EasyExcel不支持图片的读的操作,本文操作如何实现图片的读和写的功能。在EasyExcel......
  • 【java】解决EasyExcel读取InputStream时解析不到excel文件类型的问题
    正常利用EasyExcel读取excel中sheet时会调用如下接口:publicstaticExcelReaderBuilderread(StringpathName,ReadListenerreadListener){returnread((String)pathName,(Class)null,readListener);}publicstaticExcelReaderBuilderread(Stringp......
  • 【测试文章搬运】用selenium并从excel里面读取测试数据——采用数据驱动测试自动化框
    SeleniumFrameworkCreationAndAccessingTestDataFromExcel–SeleniumTutorial在本系列的当前教程中,我们将为您提供一个示例框架,用于存储测试数据及其Excel操作的Excel。同样,我们将继续前进并引入新的策略和资源来完善我们的框架。让我们学习一下:使用示例项目的......
  • 数据导出简单处理:Java中导出excel数据!!!
    达成的功能:查询出数据集合List,把集合内容导出成excel文件数据。直接上代码:1、pom.xml<!--阿里excel--><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId>......
  • excel2dbc工具
    简述:        excel2dbc工具用于将excel中的报文和信号数据转换成dbc文件,该工具仅用于功能展示,实际项目中涉及自定义属性更改,需要根据源码进行修改。1.用法:2.演示:input:exceloutput:dbc3.链接:【免费】excel2dbc工具资源-CSDN文库4.更多细节或技术支持请联系da......
  • excel 转json 工具、json检测工具(来自个人学习,编写,自己使用工具)
    推荐一款自己编写的一款软件,excel转json工具(绿色、纯净、免费、共享);因为游戏需要将excel或其它表格转成json工具,以供cocoscreator使用,其它一些工具的比较:1.cocoscreator插件,也有免费的,但主要是效率低,如果excels文件多的时候,转换时间特别的长,无法接受。就是入口方便自......
  • 向已有的excel表中追加数据存储(表头一致)
    在使用Pandas处理Excel文件时,如果需要在已有的Excel文件中向下添加新数据,可以使用openpyxl作为引擎来实现这一功能。下面是具体的步骤和代码示例:读取已有的Excel文件:使用pd.read_excel读取已有的Excel文件和数据。准备新数据:将新数据整理为DataFrame。将新数据追加到已有......
  • excel电子表格双表多列修改,点击式。
        excel的xlookup确实非常简单,有部分功能也非常快。但是有的人不会公式,或者不喜欢用公式,或者没有excel2021以上的版本。而且xlookup确实也有些还不是很完美的地方,比如对多列关联查询很慢。所以我们还是有必要增加类似的办法,hpctb提供了“双表多列修改”,我们来看一看。......