title | tags | favorited | created | modified | ||||
---|---|---|---|---|---|---|---|---|
dev-log-repeat-solutions |
|
true |
2021-01-08 00:10:18 UTC |
2021-07-20 13:50:23 UTC |
-
tips
paas/rendering/web/benefitmay be the future- 抽空在线体验,工作专注代码
- 涉猎saas解决方案,积累算法、库、框架、模版项目、生态
- 尝试将算法和技术转化为可复用的产品, 参考yjs+hocuspocus
- 工具型框架离商业化应用太远, 直接从主流cms/saas中寻找架构或框架参考
- ⚒️🌰 深入一个项目,开发需要精力,建立生态更需要精力
- 视图+持久化,前端分析model/view/dataflow, 后端分析数据库设计和优化
- 分析api的设计,包括扩展ui、api,插件开发,热加载
- src-code, issues, pr, forks, extensions, most-commented-issues
- roadmap, open-issues, alternatives, 竞品
- 开放能力: extensions, scripts, marketplace
- pref: 索引、缓存、分库分表、读写分离
- 典型产品: editor + fileTree + workbenchLayout + search + cmdKeys + settings
- 🏘️ architecture-early 需要尽早考虑的架构问题,没有完美的架构
- 核心架构考虑 server/db/network-socket
- feature-flag
- 早期不要将系统架构设计得过于复杂,会影响开发进度, 甚至产品终止都用不上
- 重前端还是重服务端的设计
- collaborative的数据结构,冲突处理算法,客户端中心还是服务端中心
- scale水平扩展/多实例/多租户; http更适合scale; shared配置、缓存
- 数据通信,http/websocket
- 读多? 写多?
- sqlite的流行表明scaling要考虑场景, zulip/jupyterhub私有部署默认支持几千用户但不scale
- 没有完美的架构,优先支持迭代,不要执着于当下的问题,也许以后就突然想清楚了
- 先实现业务核心功能, 再考虑如何以sdk/paas的方式提供给使用方,再优化性能
- 系统的性能受第三方资源如github的fetch api的限制,设计初期要想办法避免
- 计算密集型的feature可尝试多层架构,如大模型llm/ocr
- 重技术型业务的开发稳定性兼容性比性能更重要
- frontend: animation, 多标签
- backend: orm vs sql
- data-app
- specification for pivot table
- 输入数据input-data-table, 开放数据api,开放应用app-builder
- 产品方向: 偏设计布局, 偏业务逻辑
- 网盘: 数据展示和回收站,非常经典的场景,常在cms中存储资源
-
lts-tech-stack 可协作、可同步(离线)、可撤销
- 🌰lts: vscode/ide, git/vcs
- vscode: monaco-editor + electron, code-server, sourcegraph
- codemirror/prosemirror: state + view + commands + transform/ot/collab + virtualized
- version-history: rrweb, diff, format(.fodt), video-but-auto-update
- rspack: js plugin; rspack/rolldown-wasm
- animation: motion(dom/svg)
-
技术细节: virtualized, draggable, table(eav)
-
技术产品: cm-devtools, noseditor, collab-hocuspocus
-
技术方向js: 协作/ver-
gitdb
/partial-sync, 编辑器/ide, 多维表格/excel; scaling/HA-socket; dnd, floating; 前端版/流式版/oplog; -
技术扩展js/py: 可拖拽的页面编辑器/lowcode, Excel/kanban, 图表
-
通用能力: collab, version-history+sync+replay, ai-search, ai-chat; auth, payment
-
技术扩展ai: rag, search, vector, 知识库搜索与对话
-
技术业务: client/server版; cms/wiki, airtable/table, db
-
技术可选1: 画板, pdf/ppt-editor, 图形编辑器
-
技术可选2: olap-bi, 大数据系统, 数据库
-
技术可选3: vscode, 可参考架构 extensions、capabilities
-
技术可选4: 侧重版本控制的数据库,如dolt, SirixDB, git-like-db
-
玩具尝试1: git+crdt+table+branch/version, 参考类似ckan的data-portal
-
🎯 roadmap: virtualized-draggable-table, cm-devtools, cm-noseditor, cm-hocus
- 📝 编辑器,协作同步,版本分支,
虚拟渲染, 分支版本, 协作冲突, undo/redo - 🔀🛢️ crdt版本历史, partial-replica、ivm, delta-db, 实时架构
- version-history+sync(for table/pdf), replay, motion-photo(标准)
- replay(editor+tree+layout), reproducible
- dynamic-schema/eav
- 基于ast的架构: reka, tango-lowcode, ast优化常使用bytecode(data+logic)
- sourcegraph
- 支持输出canvas,为了分享或安全
- 📝 编辑器,协作同步,版本分支,
-
🛢️ 数据存储架构
- file-first: vscode, obsidian, notable, hexo
- db-first: git, joplin, siyuan, 多维表格/nocodb
- 代码文件与数据库紧密结合的方案示例,可参考git/docx-zip
- 代码与数据库结合来更新应用程序(app/webapp)的方案,可参考aquameta/couchapp/reka/sourcegraph
-
🚀 产品落地
- 侧重表格的cms, 内容创作与管理
- 运营数据仪表板
- sharing table/data pieces/snippets
- 个人数据管理, 开放api,允许其他app获取,参考ckan
- tags
-
生态与集成, 业务方向考虑实时市场,不要凭空想象
- office365,从 word/excel 复制粘贴的表格,如果其中有合并的单元格,也能支持正常展示
- jupyter-notebook, observable-notebook
-
marketplace: vscode/jupyter
- browser-extensions
- table-capture/shot
- figma
- ocr
-
团队版/企业版-features
- 移动端优化的表格
- 表单/投票收集与统计,如features
- 编辑器内的时间变化动态表格
- 类似多个图表facet的多个表格
- table in table
-
design-system
- themeable; unstyled/headless; a11y/keyboard-ux
-
💎 editor/WYSIWYG
- collaborative, block-style, virtualized-render
- modular/extensible; collaborative; easy-pivotable
- 📌 prosemirror/tiptap/rich-md, quill/typewriter, slate/wang, lexical; cms/outline
- block-editor with slash-menu/backlinks
-
💎 excel/data-grid
- editing, group/pivot, multi-views
- pivotable; collaborative; formulas
- 📌 tanstack-table, ag-grid, handsontable, luckysheet/univer, ospreadsheet; undb/nocodb/ethercalc
- stream-updates/server-side-infinite-row-model
- scripting/themeable/canvas/viztable/apache-arrow
excel-like/headless
-
💎 collab
- crdt: yjs, automerge, logux, rga, fluid-framework, hlc
- log-based: ~~p/couchdb, ~~powersync, kappa-db, event-sourcing
- eav: triplitdb
-
通用能力/features
- collab, realtime
- version-history + Sync
- 操作与回放, time travel,倍速播放
- ai
-
✨ cms(content-mgmt)
- 👉🏻 outline (apache2/sequelize+prosemirror)
- 👉🏻 strapi (MIT/knex+slate)
- 👉🏻 directus (AGPL/knex+vue3+tinymce5)
- nocobase (apache2/sequelize+umi)
- payloadcms (MIT/mongoose+slate)
-
✨ airtable-like(data-mgmt)
- 👉🏻 nocodb (AGPL/knex+nuxt3)
- 👉🏻 ethercalc (MIT/nodejs+redis)
- locokit (MIT/knex+vue2)
- undb (AGPL/nestjs+mikro-orm+dnd-kit/table)
- apitable (AGPL/spring-mybatis+canvas)
- focalboard (AGPL/go+react-dnd)
- rowy (apache2/firebase+tinymce5)
- baserow (MIT/django+nuxt2)
- ckan/datapian
-
✨
workflow/automation> directus- n8n (AGPL/typeorm+vue2+jsplumb)
- budibase (AGPL/knex+svelte)
- automatisch (AGPL/knex+graphql+slate)
-
✨ bi
- 👉🏻 lightdash (MIT/knex+echarts)
- superset (apache2/flask+echarts)
-
more
- notion/confluence/outline
- airtable/nocodb
- trello/kanban/jira/linear/asana
- dropbox/google-drive
- chat, forum
-
✨ admin-dashboard > strapi
- react-admin
- tremor
-
✨ editor-wiki(web+pc)
- outline
- notesnook
- mdSilo
-
features
- local-first/offlineable/localizable
- collaborative
- easy pivot table in document
- interactive-contents: variable, attachment, viz
- backlinks/bidirectional: [[Wikilinks(stub)]], providing more context around backlink reference
- relations: trilium-relation-map, trilium-link-map, dendron-hierarchical
- scientific writing: latex, bibtex, citation,data
- rich-ui: collapsible, floating, emoji
- portable format: text format; no vendor lock in; partially export cuz mobile
- templates
- es search-ui experience, algolia-docsearch/autocomplete
-
byproduct-apps
- live/reactive-notebook
- cell-style/nonlinear; reproducible/computational; math
- dashboard/spaces
- themeable/configurable/widgets-blocks
- live/reactive-notebook
-
integrations/connections
- wechat-miniapp、公众号、实时通知
- github/gitee
- 腾讯文档
- 类似outline集成slack
- 类似superset支持各种数据源
-
to-try
- kibana for meilisearch
-
视图层的实现可参考: wangeditor/typewriter/autocomplete, 库和应用层不同在于ajax
-
架构参考
- immutable: prosemirror, slate, wangeditor, typewriter, ospreadsheet, maxgraph
- functional: wangeditor, typewriter
- 数据层: ivm-crsqlite/zero-sync
-
partial-sync
- 实现方案可参考成熟数据库的streaming,一般与业务表相关
- powersync
- triplit
-
ivm/incremental-view-maintenance
- zero-sync
- web前端的reactive实现
- 数据库的materialized view
- event sourcing
- bundler的热加载,如turbopack
- 编译器的热更新
-
系统提供很多配置项的设计
- webpack
- vscode settings
- npmrc
- 手机系统的设置
-
replay
- 回放时可与执行时显示不同的视图,如将edit显示为diff,显示debug信息
- 基于代码的回放能解决视频难以实时更新的问题, video-but-auto-update
-
重前端架构的优点
- 无需服务器,或对服务器要求低
- 容易快速响应用户交互
-
重前端架构的缺点
- 刷新页面或关闭页面容易导致数据丢失或数据不一致
-
多文件的app, 或多或少有点类似知识库
- 可以参考给普通数据库表添加crdt支持的场景
-
version-history
- 不仅是文档级别的history,还支持项目级别的history,采用branch+merge策略
-
collab-framework
- 所有的操作可由用户执行,也可由ai执行
-
high-availability / horizontal-scaling
- 实现参考: yjs-hocuspocus, y-redis, fluid-routerlicious 🤔 使用websocket通信是否是错误的架构(mq更好)
- strapi, nocobase
- fwk: nestjs, feathers-sync
- manual-ha: zulip
- more: overleaf(pro-only)
-
协同类产品要考虑数据和配置是否都要同步的问题
- 表格的过滤条件
- 回放操作的进度
- 搜索关键词
-
tips
- live edit
- 随意搭建ui的需求过于灵活,而基于controls的在线配置编辑更实用; 有限定制组件+专题场景
-
leading
- 微软 office/word/excel
- 腾讯 文档
- 字节 飞书
-
prosemirror
- atlassian editor
- rich-markdown-editor + outline
- milkdown
-
react-markdown-editor-lite
- 基于textarea和React的markdown编辑器,实现简单且清晰,非所见即所得
-
more-editor
- google-docs-like-editor
- monaco-editor
- code editor that powers desktop vscode
- not supported in mobile browsers. not for IE
-
支持多种前端框架的实现
- tanstack-table/virtual
- slate-editor, wangEditor, editablejs
- tiptap-editor, prosekit
-
tips
-
react-table /tannerlinsley
-
ag-grid /ag-grid
-
luckysheet
-
more-list-grid
- x-spreadsheet
- tabulator
- frappe-datatable /frappe
-
marijn /prosemirror/codemirror
- forum
-
Tanner Linsley /tanstack-table
-
胡文召 /univer
-
davidbrochart /jupyter
-
Kevin Jahns /yjs
-
Bartosz Sypytkowski /yjs
-
mweidner037 /fugue
-
Geoffrey Litt /peritext
-
powersync-partial
- discord
-
Matt Wonlaw /cr-sqlite
-
tinybase-crdt
- discord
-
triplitdb-eav
- discord
-
watching
- notion
- linear
-
job-hunting
- codemirror / prosemirror
- jupyter
- 协同 ot算法 开发 yjs 协同编辑
- 低代码(易商业化,技术框架很难商业化) automation/rpa
- 知识库 文档
-
charting-viz
- leading
- echarts
- d3
- vega
- more-charting
- antvis
- leading
-
faves
- design: adobe-spectrum, tailwind
- editor: prosemirror, codemirror, gutenberg
- geomapping:mapbox-gl, leaflet
- geoviz:deck.gl
- geoprocessing:turfjs, mapnik
- geo: gdal, esri,计算工具大部分都基于cpp
-
design-system
- tips
- material
- carbon
- spectrum
- ui: material-ui, ant design, atlaskit , theme-ui, bootstrap
- design-tokens: polaris-tokens
-
dashboard
- tips
- 实际仪表板常与业务紧密相关,建议结合window-layout和drag实现
- coreui
- creativetim
- olap(js intensive)
- tips
-
layout/window-manager
- tips
- 常作为app的基础组件
- golden-layout: 场景丰富功能全面的window
- elara: demo示例非常酷,特别是layer,dashboard, shell, pic-viewer
- ventus: 快速切换到窗口平铺预览
- rc-dock: 类似ide的拖拽停靠效果
- tips
-
format
- excel/csv/office open xml
- markdown
- json
-
rendering
- canvas
- webgl
- animation
- FLIP
-
针对具体业务的前端开发流程
- 分析需求的主要属性和状态变化临界点
- 定义数据结构和updateState方法,可以使用主流第三方库提供的api结构
- 设置初始值
- 设计action/op/cmd来触发updateState
- 更新视图
-
维护现有系统时修改与添加特性
- 添加属性不如添加方法,可以让使用方自定义方法的内容与具体逻辑,
- 一般可以分别提供get/set方法
- 提供配置方法可以让使用方随时随地调用方法,而提供配置属性的方案一般只在初始化时
- 添加属性或方法后要注意提供清理方法或实现自动清理
- 添加属性不如添加方法,可以让使用方自定义方法的内容与具体逻辑,
- ai的能力擅长在翻译 语言 转换
- 20240406: 想做的事情有 灵活的cms、协作系统、支持大量数据的编辑器
- cms需要在架构层支持 配置和存储 表和字段 的元数据, 可参考directus/nocodb
- 协作系统需要对文本使用特殊的数据结构,还要考虑版本历史/权限/yjs
- 编辑器在模型层要考虑db架构和更新op采用ot/crdt, 系统中编辑器大多可替换
- 协作只有部分文本需要YText这类复杂的crdt,表格使用llw-map足够
- 富文本编辑器和页面编辑器的区别,主要在是否使用conetenteditable、选区
- usecase
- replayable workspace
- solutions
- redux
- event-sourcing
-
usecase
- meetings-whiteboard
-
solutions
- ot
- crdt
-
why crdt is hard
-
u not need crdt
- usecase
- branching
- solutions
- fossil
-
usecase
- cms/lowcode
- notion
-
树形数据结构的4种表示
- 飞书功能的子集