85 lines
2.6 KiB
Markdown
85 lines
2.6 KiB
Markdown
# 工作流节点开发文档
|
||
> 参考示例:Markdown2HTML节点
|
||
|
||
## 节点入口文件
|
||
> composables/worklfow/node/Markdown2HtmlNode.ts
|
||
> 此文件定义了节点所需要的所有内容
|
||
- nodeType 节点类型
|
||
- getNodeList 节点清单,对应添加节点时,显示的内容
|
||
- initData 初始化数据,当前的插件节点,后端逻辑都是通过接口处理的
|
||
- 示例接口:`server/api/markdown2html.post.ts` **注意返回结果类型:NodeOutput**
|
||
- createOutputSpec 定义参数关联节点产出的路径
|
||
- 文本类型为 ['output_content', '*', 'content']
|
||
- 媒体类型为 ['output_content', '*', 'url']
|
||
- renderNode: 节点对应的前端组件`components/Markdown2Html/index.vue`
|
||
|
||
```typescript
|
||
import { NodeCategoryEnum, PluginBaseNode } from "./PluginBaseNode";
|
||
import {
|
||
Markdown2Html
|
||
} from '#components'
|
||
|
||
import { NodeTypeEnum } from "~/composables/worklfow/node/node.interface";
|
||
|
||
export default class Markdown2HtmlNode extends PluginBaseNode {
|
||
static override nodeType = NodeTypeEnum.Markdown2Html // 节点类型
|
||
|
||
static override getNodeList() {
|
||
return [
|
||
{
|
||
type: Markdown2HtmlNode.nodeType, // 节点类型
|
||
label: 'Markdown转HTML', // 标签
|
||
description: 'Markdown转HTML', // 描述
|
||
category: NodeCategoryEnum.BASE, // 分类
|
||
icon: 'material-symbols-light:markdown-paste' // 图标
|
||
}
|
||
]
|
||
}
|
||
|
||
initData() {
|
||
// 数据类型 IApiPluginNodeData
|
||
return {
|
||
method: 'POST', // 请求方法
|
||
url: 'http://localhost:3200/plugins/api/markdown2html', // 请求地址,节点的业务逻辑,需要在接口中完成
|
||
body: {
|
||
markdown: '' // 接口请求体内容,输入的markdown内容
|
||
},
|
||
headers: {
|
||
'Content-Type': 'application/json'
|
||
// 依据接口自行扩展,认证等信息
|
||
}
|
||
} // 初始化数据
|
||
}
|
||
|
||
/**
|
||
* 输入信息关联父节点产出的数据类型及数据路径
|
||
*/
|
||
override createOutputSpec(): INodeOutputSpec {
|
||
return {
|
||
type: 'text', // 文本类型
|
||
defaultPath: ['output_content', '*', 'content'] // 数据路径,文本为 ['output_content', '*', 'content'],媒体类型为 ['output_content', '*', 'url']
|
||
}
|
||
}
|
||
|
||
// 画布节点 UI
|
||
static override renderNode() {
|
||
return Markdown2Html // 节点组件
|
||
}
|
||
}
|
||
```
|
||
|
||
|
||
## 维护组件信息文件:
|
||
> manifest/Markdown2HtmlNode.ts
|
||
> 需要参照IComponentMateInfo类型约束文件进行定义
|
||
|
||
|
||
## 组件效果
|
||
|
||
1. 添加节点
|
||

|
||
2. 关联节点
|
||

|
||
|
||
|