mirror of https://github.com/allinssl/allinssl
56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
import { defineComponent } from 'vue'
|
|
import BaseNodeWithAddButton from './BaseNodeWithAddButton'
|
|
import styles from './Node.module.css'
|
|
import { NodeProps } from '@vue-flow/core'
|
|
|
|
export default defineComponent({
|
|
name: 'NewUploadNode',
|
|
props: {
|
|
id: { type: String, required: true },
|
|
data: { type: Object, required: true },
|
|
selected: { type: Boolean, default: false },
|
|
connectable: { type: Boolean, default: true },
|
|
},
|
|
setup(props) {
|
|
const handleNodeClick = (nodeData: any) => {
|
|
// 在这里可以打开节点配置面板
|
|
console.log('配置上传证书节点', nodeData)
|
|
// 触发事件通知父组件打开配置面板
|
|
const event = new CustomEvent('open-node-config', {
|
|
detail: {
|
|
nodeId: nodeData.id,
|
|
nodeType: 'upload',
|
|
nodeData: nodeData,
|
|
},
|
|
})
|
|
window.dispatchEvent(event)
|
|
}
|
|
|
|
const handleAddNode = (data: any) => {
|
|
console.log('添加节点成功', data)
|
|
}
|
|
|
|
return () => (
|
|
<BaseNodeWithAddButton
|
|
id={props.id}
|
|
data={props.data}
|
|
selected={props.selected}
|
|
connectable={props.connectable}
|
|
nodeClassName={styles.uploadNode}
|
|
icon="📤"
|
|
isClickable={true}
|
|
onClick={handleNodeClick}
|
|
onAdd-node={handleAddNode}
|
|
>
|
|
{/* 上传节点可以显示文件状态 */}
|
|
{props.data.certificateFile && (
|
|
<div class={styles.nodeMessage}>已上传: {props.data.certificateFile.name || '证书文件'}</div>
|
|
)}
|
|
{!props.data.certificateFile && props.data.certificateContent && (
|
|
<div class={styles.nodeMessage}>已填写证书内容</div>
|
|
)}
|
|
</BaseNodeWithAddButton>
|
|
)
|
|
},
|
|
})
|