Flowmix/Docx 多模态文档编辑器:V1.3.5版本,全面升级!

科技   2024-11-15 08:43   重庆  

嗨, 大家好, 我是徐小夕.

最近一直在研究多模态文档引擎, 最近2周对 flowmix/docx文档编辑器又进行了一波功能迭代, 在迭代的过程中也学到很多新的技术, 接下来就和大家一起分享一下, 如果你恰好也在研究类似的产品, 相信会有很多收获.

演示地址: http://flowmix.tunrtip.cn/docx

先说一下1.3.5版本迭代的内容:

  • 编辑器支持AI侧边栏, 可以轻松集成各种AI模型实现内容生成
  • 文档支持划词评论功能
  • 文档支持一键导入Docx文件
  • 支持实时获取当前光标在文档中的位置
  • 优化文档元素插入文档的顺序
  • 新增高级思维导图组件
  • 内联工具条UI优化

后面还会持续迭代更多功能, 比如多人协同, 一键生成PPT等, 如果大家有好的建议也可以随时在评论区反馈.

最新版Demo演示

接下来我会具体介绍一下更新的功能和技术实现, 给大家一个参考.

1. 编辑器支持AI侧边栏

编辑器之前虽然支持了AI问答组件, 但是为了更好的挖掘文的价值, 我集成了AI侧边栏, 大家可以轻松集成市面上的AI大模型, 来实现AI辅助创作.

我们可以轻松的点击右下角的AI按钮, 打开侧边栏和AI对话:

对话组件我采用的是开源的方案 @ant-design/pro-chat , 大家有其他好的插件也可以分享一下哈~

2. 文档支持划词评论功能

划词评论我在之前的文章中有详细的分析, 感兴趣的可以参考一下:

市面上大多数文档编辑器的【划线评论】功能,是如何实现的?

3. 文档支持一键导入Docx文件

文档一键导入docx文件功能可以高效的帮助我们解析docx的内容, 并在flowmix/docx中快速编辑. 接下来给大家看看原始的word文件:

在第一个版本中其实也实现了docx文件的导入, 但是之前对图片, 表格这些docx特有的格式无法支持, 最近研究出来了一个方案, 可以很好的支持docx文件中的表格, 图片等, 并一键转化为flowmix/docx 中支持的数据结构.

在实现Docx解析方案中我采用了DOMParser API, 这里我给大家介绍一下这个兼容性良好且功能强大的浏览器API.

DOMParser 可以将存储在字符串中的 XML 或 HTML 源代码解析为一个 DOM Document

我的实现思路是将 Docx 文件解析为 html 字符串, 在基于DOMParser 将html 字符串转化为Dom, 最后对Dom进行分割, 输出 flowmix/docx 支持的json结构.

将 html 字符串转化为 dom 的案例如下:

const parser = new DOMParser()
const doc = parser.parseFromString(html, 'text/html')

这样, 我们就能通过节点遍历的方式一键将dom转化为json结构了:

目前 flowmix/docx 已经支持解析的docx格式有:

  • 标题(h1-h6)
  • 文本段落(p)
  • 序号(ul, lo)
  • 图片
  • 表格

后续还会支持更多docx元素, 大家感兴趣的可以参考一下这个方案.

4. 支持实时获取当前光标在文档中的位置

实时获取光标位置的方案主要是为了实现多人协同的光标位置确认, 这里我也基本实现了. 主要是用到了 window.getSelection API, 后续我会详细和大家分享它的应用场景. 实现代码如下:

const saveSelection = () => {
        const selection = window.getSelection()
        if (selection && selection.rangeCount > 0) {
            const range = selection.getRangeAt(0)
            return {
            anchorNode: range.startContainer,
            anchorOffset: range.startOffset,
            focusNode: range.endContainer,
            focusOffset: range.endOffset
            }
        }
        return null    }

5. 优化文档元素插入文档的顺序

这个问题主要是为了解决文档编辑器当失去焦点时, 仍能争取插入到文档光标最近停留的位置. 之前一直用了“比较笨”的方案, 最近研究了一下,终于用 window.getSelection 实现了.(其实也是用的上述获取光标位置的方式实现的)

6. 新增高级思维导图组件

思维导图的实现方式我也在之前文章中有详细的分享, 大家感兴趣可以参考我之前的文章.

7. 内联工具条UI优化

内联工具条我最近对样式做了进一步统一和优化.

后续规划

最近我们也在花时间做一款文档管理类Saas系统, 底层基于Flowmix/Docx 多模态文档引擎, 这里简单和大家分享一下:

每个月我们都会根据用户的需求和规划的迭代计划持续迭代, 大家可以关注flowmix视界公众号获取最新更新的信息.

后面的一些规划:

这个月除了会上线文档Saas版1.0之外, 在下个月带给大家更强大的编辑器体验:

  • 支持文档图层面板
  • 支持高级可视化组件
  • 支持文档AI工作流
  • 文档支持演示模式
  • 支持多人协同编辑
  • 支持一键生成PPT

当然从体验上来讲, 文档还有很多优化的空间, 这块我们会持续优化和迭代, 并结合业界最佳体验实践, 将文档搭建能力发挥出最大的价值.

编辑器版本体验地址: http://flowmix.turntip.cn/docx

如果你有好的想法和建议, 也欢迎随时留言区交流讨论~

往期精彩:

flowmix/flow, 一款高度可配的可视化流程编辑器
零代码平台创业, 阶段性复盘
从零到一打造面向AI的文档可视化搭建引擎

趣谈前端
徐小夕【知乎专栏作家】掘金签约作者,定期分享前端工程化,可视化,企业实战项目知识,深度复盘企业中经常遇到的500+技术问题解决方案。【关注趣谈前端,前端路上不迷茫】
 最新文章