mirror of
https://github.com/nocobase/nocobase
synced 2024-11-18 07:35:57 +00:00
b71bcc1889
* feat: rename plugin-collection-manager to plugin-data-source-main (#4136) * feat: rename plugin * feat: rename * chore: rename classes of data-source-main * chore: use name for migrating instead of packageName * chore: rename china-region to field-china-region (#4167) * chore: rename china-region to field-china-region * chore: update yarn.lock * chore: rename classes * chore: use name instead of pkgName * chore: rename export to action-export (#4169) * chore: rename export to action-export * chore: rename classes * chore: use name * chore: rename formula-field to field-formula (#4170) * chore: rename formula-field to field-formula * chore: use name * chore: rename localization-management to localization (#4173) * chore: rename localization-management to localization * fix: test * chore: rename sequence-field to field-sequence (#4174) * chore: rename sequence-field to field-sequence * chore: use name * chore: rename custom-request to action-custom-request (#4168) * chore: rename custom-request to action-custom-request * chore: rename classes * chore: use name * fix: ns * chore: rename iframe-block to block-iframe (#4171) * chore: rename iframe-block to block-iframe * chore: use name * chore: rename sms-auth to auth-sms (#4175) * chore: rename sms-auth to auth-sms * chore: use name * chore: rename import to action-import (#4172) * chore: rename import to action-import * chore: use name * fix: ns * fix: packages * test: add rename test * fix: move rename migrations to preset * fix: version * fix(localization): remove duplicate records (#4182) * fix: locale ns * fix(localization): remove duplicate records * chore: merge * fix: migration * fix: test * feat: improve pm add command (#4198) * chore: remove sso auth plugins and add upgrade warning (#4192) * chore: remove sso auth plugins and add upgrade warning * chore: remove sso plugins dir * chore: remove dependencies * fix: names * refactor: move to migration * chore: adjust log * feat: allows to remove plugins from sub apps * fix: pm remove * chore: add test * chore: just for pro plugins * refactor: optimize migration * test: add test * fix: auth-sms * fix: add transaction --------- Co-authored-by: chenos <chenlinxh@gmail.com> * chore: make e2e more stable * chore(license): update LICENSE to AGPL-3.0 (#4207) * fix: improve pm (#4200) * fix: improve pm * feat: improve pm update * fix: test error * fix: rename plugin * fix: remove only * refactor(e2e): extract * fix: await * fix: nameOrPkg * feat: remove multi-app-share-collection from local --------- Co-authored-by: Zeke Zhang <958414905@qq.com> * chore: add new line * chore: rename migration * fix: version * fix: test * feat: v1.0.0-alpha.1 * fix: multi-app-share-collection --------- Co-authored-by: chenos <chenlinxh@gmail.com> Co-authored-by: Chareice <chareice@live.com> Co-authored-by: katherinehhh <katherine_15995@163.com> Co-authored-by: Zeke Zhang <958414905@qq.com>
223 lines
3.5 KiB
Markdown
223 lines
3.5 KiB
Markdown
# import
|
||
|
||
[English](./README.md) | 中文
|
||
|
||
Excel 数据导入插件。
|
||
|
||
## 安装激活
|
||
|
||
内置插件无需手动安装激活。
|
||
|
||
## 导入说明
|
||
|
||
### 数字类型字段
|
||
|
||
支持数字和百分比,`N/A` 或 `-` 的文案会被过滤掉
|
||
|
||
| 数字1 | 百分比 | 数字2 | 数字3 |
|
||
| -- | -- | -- | -- |
|
||
| 123 | 25% | N/A | - |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"数字1": 123,
|
||
"百分比": 0.25,
|
||
"数字2": null,
|
||
"数字3": null,
|
||
}
|
||
```
|
||
|
||
### 布尔类型字段
|
||
|
||
输入文案支持(英文不区分大小写):
|
||
|
||
- `Yes` `Y` `True` `1` `是`
|
||
- `No` `N` `False` `0` `否`
|
||
|
||
| 字段1 | 字段2 | 字段3 | 字段4 | 字段4 |
|
||
| -- | -- | -- | -- | -- |
|
||
| 否 | 是 | Y | true | 0 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"字段1": false,
|
||
"字段2": true,
|
||
"字段3": true,
|
||
"字段4": true,
|
||
"字段5": false,
|
||
}
|
||
```
|
||
|
||
### 日期类型字段
|
||
|
||
| DateOnly | Local(+08:00) | GMT |
|
||
| -- | -- | -- |
|
||
| 2023-01-18 22:22:22 | 2023-01-18 22:22:22 | 2023-01-18 22:22:22 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"DateOnly": "2023-01-18T00:00:00.000Z",
|
||
"Local(+08:00)": "2023-01-18T14:22:22.000Z",
|
||
"GMT": "2023-01-18T22:22:22.000Z",
|
||
}
|
||
```
|
||
|
||
### 选择类型字段
|
||
|
||
选项值和选项标签都可作为导入文案,多个选项之间以以逗号(`,` `,`)或顿号(`、`)区分
|
||
|
||
如字段 `优先级` 的可选项包括:
|
||
|
||
| 选项值 | 选项标签 |
|
||
| -- | -- |
|
||
| low | 低 |
|
||
| medium | 中 |
|
||
| high | 低 |
|
||
|
||
选项值和选项标签都可作为导入文案
|
||
|
||
| 优先级 |
|
||
| -- |
|
||
| 高 |
|
||
| low |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
[
|
||
{ "优先级": "high" },
|
||
{ "优先级": "low" },
|
||
]
|
||
```
|
||
|
||
### 中国行政区字段
|
||
|
||
| 地区1 | 地区2 |
|
||
| -- | -- |
|
||
| 北京市/市辖区 | 天津市/市辖区 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"地区1": ["11","1101"],
|
||
"地区2": ["12","1201"]
|
||
}
|
||
```
|
||
|
||
### 附件字段
|
||
|
||
| 附件 |
|
||
| --|
|
||
| https://www.nocobase.com/images/logo.png |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"附件": [
|
||
{
|
||
"filename": "logo.png",
|
||
"title": "logo.png",
|
||
"extname": ".png",
|
||
"url": "https://www.nocobase.com/images/logo.png"
|
||
}
|
||
]
|
||
}
|
||
```
|
||
|
||
### 关系类型字段
|
||
|
||
多条数据以逗号(`,` `,`)或顿号(`、`)区分
|
||
|
||
| 部门/名称 | 分类/标题 |
|
||
| -- | -- |
|
||
| 开发组 | 分类1、分类2 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"部门": [1], // 1 为部门名称为「开发组」的记录 ID
|
||
"分类": [1,2], // 1,2 为分类标题为「分类1」和「分类2」的记录 ID
|
||
}
|
||
```
|
||
|
||
### JSON 类型字段
|
||
|
||
| JSON1 |
|
||
| -- |
|
||
| {"key":"value"} |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"JSON": {"key":"value"}
|
||
}
|
||
```
|
||
|
||
### 地图几何图形类型
|
||
|
||
| Point | Line | Polygon | Circle |
|
||
| -- | -- | -- | -- |
|
||
| 1,2 | (1,2),(3,4) | (1,2),(3,4),(1,2) | 1,2,3 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"Point": [1,2],
|
||
"Line": [[1,2], [3,4]],
|
||
"Polygon": [[1,2], [3,4], [1,2]],
|
||
"Circle": [1,2,3]
|
||
}
|
||
```
|
||
|
||
## 自定义导入格式
|
||
|
||
通过 `db.registerFieldValueParsers()` 方法注册自定义的 `ValueParser`,如:
|
||
|
||
```ts
|
||
import { BaseValueParser } from '@nocobase/database';
|
||
|
||
class PointValueParser extends BaseValueParser {
|
||
async setValue(value) {
|
||
if (Array.isArray(value)) {
|
||
this.value = value;
|
||
} else if (typeof value === 'string') {
|
||
this.value = value.split(',');
|
||
} else {
|
||
this.errors.push('Value invalid');
|
||
}
|
||
}
|
||
}
|
||
|
||
const db = new Database();
|
||
|
||
// type=point 的字段导入时,将通过 PointValueParser 解析数据
|
||
db.registerFieldValueParsers({
|
||
point: PointValueParser,
|
||
});
|
||
```
|
||
|
||
导入示例
|
||
|
||
| Point |
|
||
| --|
|
||
| 1,2 |
|
||
|
||
转 JSON 之后为
|
||
|
||
```ts
|
||
{
|
||
"Point": [1,2]
|
||
}
|
||
```
|