## 项目目录与数据结构 ### 项目目录结构 ``` ├── assets // 静态资源 │ ├── fonts // 在线字体文件 │ └── styles // 样式 │ ├── antd.scss // antd默认样式覆盖 │ ├── font.scss // 在线字体定义 │ ├── global.scss // 通用全局样式 │ ├── mixin.scss // scss全局混入 │ ├── variable.scss // scss全局变量 │ └── prosemirror.scss // ProseMirror 富文本默认样式 ├── components // 与业务逻辑无关的通用组件 ├── configs // 配置文件,如:画布尺寸、字体、动画配置、快捷键配置、预置形状、预置线条等数据。 ├── hooks // 供多个组件(模块)使用的 hooks 方法 ├── mocks // mocks 数据 ├── plugins // 自定义的 Vue 插件 ├── services // API方法 ├── types // 类型定义文件 ├── store // Pinia store,参考:https://pinia.vuejs.org/ ├── utils // 通用的工具方法 └── views // 业务组件目录,分为 `编辑器` 和 `播放器` 两个部分。 ├── components // 公用的业务组件 ├── Editor // 编辑器模块 ├── Screen // 播放器模块 └── Mobile // 移动端模块 ``` ### 数据 幻灯片的数据主要存放在 `src/store/slides.ts` 中。 > 换句话说,在实际的生产环境中,一般需要将该文件内state中的数据(部分)保存到数据库。 包括: - `title` 幻灯片标题/文件名 - `slides` 幻灯片页面数据,包括每一页的ID、元素内容、备注、背景、动画、切页方式等信息 - `theme` 幻灯片主题数据,包括背景色、主题色、字体颜色、字体等信息 - `viewportSize` 幻灯片可视区域宽度基数(默认1000,即1000×562.5的画布) - `viewportRatio` 幻灯片可视区域比例(宽:高),默认16:9 - `templates` 幻灯片模板 具体类型的定义可见:[完整数据类型定义](https://github.com/pipipi-pikachu/PPTist/blob/master/src/types/slides.ts)