<template>
|
<el-popover
|
v-model="showPopover"
|
:disabled="disabled"
|
placement="bottom"
|
width="700"
|
popper-class="no-padding-popover"
|
trigger="click">
|
<crm-relative
|
v-if="!disabled&&showSelectView"
|
ref="crmrelative"
|
:crm-type="item.data.formType"
|
:action="relationAction"
|
@close="showPopover=false"
|
@changeCheckout="checkInfos"/>
|
<flexbox
|
slot="reference"
|
:class="[disabled ? 'is_disabled' : 'is_valid']"
|
wrap="wrap"
|
class="user-container"
|
@click.native="contentClick">
|
<div
|
v-for="(aitem, aindex) in dataValue"
|
:key="aindex"
|
class="user-item"
|
@click.stop="deleteinfo(aindex)">{{ getShowName(aitem) }}
|
<i class="delete-icon el-icon-close"/>
|
</div>
|
<div
|
v-if="dataValue.length === 0"
|
class="add-item">+添加</div>
|
</flexbox>
|
</el-popover>
|
</template>
|
<script type="text/javascript">
|
import CrmRelative from './CrmRelative'
|
import arrayMixin from './arrayMixin'
|
|
export default {
|
name: 'CrmRelativeCell', // 相关模块CRMCell
|
components: {
|
CrmRelative
|
},
|
mixins: [arrayMixin],
|
props: {
|
relation: {
|
// 相关ID
|
type: Object,
|
default: () => {
|
return {}
|
}
|
}
|
},
|
data () {
|
return {
|
showPopover: false, // 展示popover
|
showSelectView: false, // 内容
|
radio: true, // 是否单选
|
relationAction: { type: 'default' }
|
}
|
},
|
computed: {
|
// 如果有相关ID 展示相关效果 例如客户下的商机和合同
|
isRelationShow () {
|
return this.item && this.item.data && this.item.data.relation_id
|
}
|
},
|
watch: {
|
relation: function (val) {
|
if (val.moduleType) {
|
this.relationAction = { type: 'condition', data: val }
|
} else {
|
this.relationAction = { type: 'default' }
|
}
|
}
|
},
|
mounted () {
|
if (this.relation && this.relation.moduleType) {
|
this.relationAction = { type: 'condition', data: this.relation }
|
} else {
|
this.relationAction = { type: 'default' }
|
}
|
},
|
methods: {
|
/** 选中 */
|
checkInfos (data) {
|
this.dataValue = data.data ? data.data : []
|
this.$emit('value-change', {
|
index: this.index,
|
value: data.data
|
})
|
},
|
/** 删除 */
|
deleteinfo (index) {
|
if (this.disabled) return
|
if (this.radio && this.$refs.crmrelative) {
|
// 如果单选告知删除
|
this.$refs.crmrelative.clearAll()
|
}
|
if (this.dataValue.length === 1) {
|
this.dataValue = []
|
} else {
|
this.dataValue.splice(index, 1)
|
}
|
|
this.$emit('value-change', {
|
index: this.index,
|
value: this.dataValue
|
})
|
},
|
contentClick () {
|
this.showSelectView = true
|
},
|
getShowName (data) {
|
if (this.item.data.formType === 'receivables') {
|
return data.number
|
} else if (this.item.data.formType === 'customer') {
|
return data.customerName
|
} else if (this.item.data.formType === 'business') {
|
return data.businessName
|
} else if (this.item.data.formType === 'contract') {
|
return data.contractNum || data.num
|
}
|
return data.name
|
}
|
}
|
}
|
</script>
|
<style lang="less" scoped>
|
.user-container {
|
min-height: 34px;
|
position: relative;
|
border-radius: 3px;
|
font-size: 12px;
|
border: 1px solid #ddd;
|
color: #333333;
|
padding: 5px;
|
line-height: 15px;
|
.user-item {
|
padding: 5px;
|
background-color: #e2ebf9;
|
border-radius: 3px;
|
margin: 3px;
|
cursor: pointer;
|
}
|
.add-item {
|
padding: 5px;
|
color: #4D88FF;
|
cursor: pointer;
|
}
|
.delete-icon {
|
color: #999;
|
cursor: pointer;
|
}
|
}
|
|
.user-container.is_disabled {
|
background-color: #f5f7fa;
|
border-color: #e4e7ed;
|
cursor: not-allowed;
|
.user-item {
|
background-color: #f0f4f8ea;
|
color: #c0c4cc;
|
cursor: not-allowed;
|
}
|
.delete-icon {
|
color: #c0c4cc;
|
cursor: not-allowed;
|
}
|
.add-item {
|
color: #c0c4cc;
|
cursor: not-allowed;
|
}
|
}
|
|
.user-container.is_valid:hover {
|
border-color: #c0c4cc;
|
}
|
</style>
|