Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

「WIP」:memo: feat: add more docs #117

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
74 changes: 14 additions & 60 deletions docs/guide/intro.zh-CN.md
Original file line number Diff line number Diff line change
@@ -1,75 +1,29 @@
---
title: 快速开始
title: 简介
group:
title: 快速上手
order: 1
title: 基础介绍
order: 0
nav:
title: 文档
order: 1
order: 0
---

# 快速开始
`ProEditor` 定位编辑器 `UI` 框架,期望为「编辑」场景提供丰富、易用的基础组件与原子能力。

ProEditor 定位编辑器 UI 框架,期望为「编辑」场景提供丰富、易用的基础组件与原子能力。
## ProEditor 的理念

## 安装
`AntDesign` 定义了基础的设计规范,对应也提供了大量的基础组件。但是对于编辑器场景下,我们希望提供更高程度的抽象,提供更上层的设计规范,并且提供相应的组件使得开发者可以快速搭建出高质量的页面。

```bash
# @ant-design/pro-editor 基于 antd 和 antd-style,需要在项目中安装
$ npm install antd antd-style -S
$ npm install @ant-design/pro-editor -S
```
和 `ProComponents` 类似,我们希望在编辑器场景下成为一套编辑器组件。囊括你可以想到的所有编辑器场景下所需要的组件(或解决方案)。

### 使用组件
## 设计思路

ProEditor 提供了一系列针对「编辑」场景优化的组件,包括但不限于 「SortableList」、「SortableTree」、「DraggablePanel」、「Highlight」、「ContextMenu」等。完整的组件文档详见: [基础组件](/components/action-icon)
相比于普通的业务场景,在编辑器场景下,有些业务思路是不太一样的。这就导致了代码结构和技术选型也不尽相同。

以下则是一个典型的数组对象编辑场景,我们提供的 ColumnList 可以帮助开发者快速实现一个高质量的数组编辑组件。
### 页面布局

<code src="./demos/ColumnList/index.tsx" ></code>
抛开那些自定义程度很高的官网页面,在大部分的业务场景下,你可以使用 `AntDesign - Layout` 编写出一个你满意的业务布局。

### 组件装配器
但是在大部分编辑器场景下,你可能还需要自动拖动的布局能力。甚至在某些特殊情况下,你要让某个面板脱离当前布局,成为一个浮动窗口。

ProEditor 最初的定位是作为组件的可视化配置框架。因此在 ProEditor 中提供了一系列便于可视化组件装配的容器与原子组件,帮助开发者快速实现一个可视化配置的组件。

详见:[ProEditor 装配器容器](/pro-editor)

### 🚧 使用原子化能力

> Working in Progress

ProEditor 将会提供编辑场景需要的各类原子化能力,包括但不限于「撤销重做」、「实时协同」、「键盘快捷键」、「选择能力」等。

当前该部分能力仍处于高速开发中,敬请期待。

## 与框架集成

### 与 Umi 集成

在中后台的研发场景, umi 是一个非常不错的选择。ProEditor 与 umi 的集成非常容易。安装后直接使用即可。

### 与 Next.js 集成

[Next.js](https://nextjs.org/) 是社区中非常流行的研发框架。ProEditor 与 Next.js 的集成也非常容易。

由于 Next.js 是一个 CSR、SSR 同构的 React 框架,而 ProEditor 默认只提供 esm 模块,因此在安装后,需要在 `next.config.(m)js` 中 `transpilePackages` 中加入相关依赖:

```js
/** @type {import('next').NextConfig} */
const nextConfig = {
// 将纯 esm 模块转为 node 兼容模块
transpilePackages: ['@ant-design/pro-editor', 'leva'], // leva 为 ProEditor 依赖模块
};
```

接下来和其他组件一样使用即可。

## 工程化能力

### 按需加载

ProEditor 默认支持基于 ES modules 的 tree shaking,直接引入 `import { ActionIcon } from '@ant-design/pro-editor`; 就会有按需加载的效果。

### TypeScript

ProEditor 使用 TypeScript 进行开发,因此提供了完整的类型定义。
「WIP」添加部分 Demo 示例
File renamed without changes.
75 changes: 75 additions & 0 deletions docs/guide/start.zh-CN.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
---
title: 快速开始
group:
title: 快速上手
order: 1
nav:
title: 文档
order: 1
---

# 快速开始

ProEditor 定位编辑器 UI 框架,期望为「编辑」场景提供丰富、易用的基础组件与原子能力。

## 安装

```bash
# @ant-design/pro-editor 基于 antd 和 antd-style,需要在项目中安装
$ npm install antd antd-style -S
$ npm install @ant-design/pro-editor -S
```

### 使用组件

ProEditor 提供了一系列针对「编辑」场景优化的组件,包括但不限于 「SortableList」、「SortableTree」、「DraggablePanel」、「Highlight」、「ContextMenu」等。完整的组件文档详见: [基础组件](/components/action-icon)

以下则是一个典型的数组对象编辑场景,我们提供的 ColumnList 可以帮助开发者快速实现一个高质量的数组编辑组件。

<code src="./demos/ColumnList/index.tsx" ></code>

### 组件装配器

ProEditor 最初的定位是作为组件的可视化配置框架。因此在 ProEditor 中提供了一系列便于可视化组件装配的容器与原子组件,帮助开发者快速实现一个可视化配置的组件。

详见:[ProEditor 装配器容器](/pro-editor)

### 🚧 使用原子化能力

> Working in Progress

ProEditor 将会提供编辑场景需要的各类原子化能力,包括但不限于「撤销重做」、「实时协同」、「键盘快捷键」、「选择能力」等。

当前该部分能力仍处于高速开发中,敬请期待。

## 与框架集成

### 与 Umi 集成

在中后台的研发场景, umi 是一个非常不错的选择。ProEditor 与 umi 的集成非常容易。安装后直接使用即可。

### 与 Next.js 集成

[Next.js](https://nextjs.org/) 是社区中非常流行的研发框架。ProEditor 与 Next.js 的集成也非常容易。

由于 Next.js 是一个 CSR、SSR 同构的 React 框架,而 ProEditor 默认只提供 esm 模块,因此在安装后,需要在 `next.config.(m)js` 中 `transpilePackages` 中加入相关依赖:

```js
/** @type {import('next').NextConfig} */
const nextConfig = {
// 将纯 esm 模块转为 node 兼容模块
transpilePackages: ['@ant-design/pro-editor', 'leva'], // leva 为 ProEditor 依赖模块
};
```

接下来和其他组件一样使用即可。

## 工程化能力

### 按需加载

ProEditor 默认支持基于 ES modules 的 tree shaking,直接引入 `import { ActionIcon } from '@ant-design/pro-editor`; 就会有按需加载的效果。

### TypeScript

ProEditor 使用 TypeScript 进行开发,因此提供了完整的类型定义。