You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kaohe/ruoyi-ui/src/components/RecursiveTree/index.vue

93 lines
2.7 KiB

<template>
<div class="tree-node">
<div class="node-content">
<el-input v-model="nodeData.hz_name" placeholder="请输入标题名称" style="width: 250px;" v-if="isRoot"/>
<el-input v-model="nodeData.title" placeholder="请输入标题名称" style="width: 250px;" v-if="nodeData.type===0"/>
<el-input placeholder="请选择引用考核任务" readonly v-if="nodeData.type===1" style="width: 250px;"
v-model="nodeData.pcTitle" @focus.stop="changeKaohe">
<i slot="suffix" class="el-input__icon el-icon-search" style="color: #1890ff; font-weight: bolder"></i>
</el-input>
<!--评分占比-->
<el-input-number style="margin-left: 5px;" v-model="nodeData.zb" :precision="2" :step="0.01" :min="0.01"
:max="1" v-if="nodeData.type||nodeData.type===0"></el-input-number>
<el-button type="primary" icon="el-icon-plus" size="mini" @click.stop="addChild(0)"
v-if="isRoot||nodeData.type===0">子级标题</el-button>
<el-button type="primary" icon="el-icon-plus" size="mini" @click.stop="addChild(1)"
v-if="isRoot||nodeData.type===0">子级引用</el-button>
<el-button type="danger" icon="el-icon-delete" size="mini" @click.stop="removeNode" v-if="!isRoot"></el-button>
</div>
<div class="children" v-if="nodeData.data && nodeData.data.length">
<recursive-tree
v-for="(child, index) in nodeData.data"
:key="index"
:node-data="child"
@add-child="onAddChild"
@remove-node="onRemoveNode"
@change-kaohe="onChangeKaohe"
></recursive-tree>
</div>
</div>
</template>
<script>
export default {
name: 'RecursiveTree',
props: {
nodeData: {
type: Object,
required: true
},
isRoot: {
type: Boolean,
default: false
}
},
methods: {
// 选择引用考核任务
changeKaohe(){
this.$emit('change-kaohe', this.nodeData)
},
// 选择引用考核任务
onChangeKaohe(parentNode){
this.$emit('change-kaohe', parentNode)
},
addChild(type) {
this.$emit('add-child', this.nodeData, type)
},
removeNode() {
this.$emit('remove-node', this.nodeData)
},
onAddChild(parentNode, type) {
this.$emit('add-child', parentNode, type)
},
onRemoveNode(nodeToRemove) {
this.$emit('remove-node', nodeToRemove)
},
}
}
</script>
<style scoped lang="scss">
.tree-node {
margin-left: 35px;
padding: 5px 0px 5px 5px;
border-left: 1px solid #ccc;
}
.node-content {
padding: 5px;
background: #f5f5f5;
margin-bottom: 5px;
}
button {
margin-left: 10px;
}
.el-radio{
margin-right: 10px;
}
</style>