【新增】私有证书

This commit is contained in:
cai
2025-09-03 15:15:59 +08:00
parent efd052a297
commit 954cd1638d
442 changed files with 76787 additions and 7483 deletions

View File

@@ -0,0 +1,85 @@
import { defineComponent, ref } from 'vue'
import { useWorkflowStore } from '../../store/workflow'
import { NotifyNodeData } from '../../types'
import configStyles from './Config.module.css'
export default defineComponent({
name: 'NotifyNodeConfig',
props: {
nodeId: {
type: String,
required: true,
},
nodeData: {
type: Object as () => NotifyNodeData,
required: true,
},
},
setup(props) {
const workflowStore = useWorkflowStore()
const message = ref(props.nodeData.message || '')
const notifyType = ref(props.nodeData.notifyType || 'email')
// 更新节点标签
const updateNodeLabel = (value: string) => {
workflowStore.updateNodeData(props.nodeId, { label: value })
}
// 更新通知消息
const updateMessage = (value: string) => {
message.value = value
workflowStore.updateNodeData(props.nodeId, { message: value })
}
// 更新通知类型
const updateNotifyType = (value: string) => {
notifyType.value = value
workflowStore.updateNodeData(props.nodeId, { notifyType: value })
}
return () => (
<div class={configStyles.configContainer}>
<div class={configStyles.configField}>
<div class={configStyles.configLabel}></div>
<input
type="text"
value={props.nodeData.label}
onInput={(e) => updateNodeLabel((e.target as HTMLInputElement).value)}
class={configStyles.configInput}
/>
</div>
<div class={configStyles.configField}>
<div class={configStyles.configLabel}></div>
<select
value={notifyType.value}
onChange={(e) => updateNotifyType((e.target as HTMLSelectElement).value)}
class={configStyles.configSelect}
>
<option value="email"></option>
<option value="sms"></option>
<option value="wechat"></option>
<option value="dingding"></option>
</select>
</div>
<div class={configStyles.configField}>
<div class={configStyles.configLabel}></div>
<textarea
value={message.value}
onInput={(e) => updateMessage((e.target as HTMLTextAreaElement).value)}
class={configStyles.configTextarea}
placeholder="请输入通知内容"
></textarea>
</div>
<div class={configStyles.configInfo}>
<div class={configStyles.configInfoTitle}></div>
<div class={configStyles.configInfoContent}>
</div>
</div>
</div>
)
},
})