Files
ss-crm-manage-web/src/views/Clue/Pool/Comp/DialogFollow.vue

183 lines
5.5 KiB
Vue
Raw Normal View History

2024-04-28 16:20:45 +08:00
<template>
2024-05-23 14:08:08 +08:00
<Dialog :title="dialogTitle" v-model="dialogVisible" width="1000px">
2024-07-23 14:39:55 +08:00
<template #btn>
<el-button class="mr-20px" type="primary" size="small" @click="handleSave">保存</el-button>
</template>
2024-04-28 16:20:45 +08:00
<div class="flex">
2024-06-13 17:12:38 +08:00
<el-form style="flex: 1" :model="form" ref="formRef" :rules="rules" label-width="120px">
<el-row :gutter="20">
<el-col :span="12" :offset="0">
<el-form-item label="本次跟进时间" prop="operateTime">
<el-date-picker
v-model="form.operateTime"
type="datetime"
format="YYYY-MM-DD HH:mm"
valueFormat="YYYY-MM-DD HH:mm"
placeholder="本次跟进时间"
/>
</el-form-item>
</el-col>
2024-06-26 18:24:45 +08:00
<el-col :span="12">
<el-form-item label="意向状态" prop="intentionState">
<el-select v-model="form.intentionState" filterable>
<el-option
v-for="item in intentionOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-col>
2025-09-05 11:52:30 +08:00
<el-col
:span="12"
:offset="0"
v-if="form.intentionState != 74 && form.intentionState != '1956731237364404224'"
>
<el-form-item label="下次跟进时间" prop="nextFollowTime">
<el-date-picker
v-model="form.nextFollowTime"
type="date"
format="YYYY-MM-DD"
valueFormat="YYYY-MM-DD"
placeholder="下次跟进时间"
/>
</el-form-item>
</el-col>
2024-06-13 17:12:38 +08:00
</el-row>
<el-row :gutter="20">
<el-col :span="24" :offset="0">
<el-form-item label="跟进内容" prop="content">
<el-input
v-model="form.content"
type="textarea"
:autosize="{ minRows: 4 }"
placeholder="请输入跟进内容"
clearable
/>
</el-form-item>
</el-col>
</el-row>
</el-form>
2024-04-28 16:20:45 +08:00
<div class="ml-20px" style="width: 300px">
<el-input
2024-06-13 17:31:52 +08:00
v-model="skillSearch.question"
2024-04-28 16:20:45 +08:00
placeholder="请输入关键字查询关键话术"
clearable
2024-06-13 17:31:52 +08:00
@keyup.enter="getSkillList"
2024-04-28 16:20:45 +08:00
/>
<el-collapse v-model="activeQues" :accordion="false">
<el-collapse-item
2024-06-13 17:31:52 +08:00
v-for="item in skillList"
2024-04-28 16:20:45 +08:00
:key="item.skillId"
:title="item.question"
:name="item.skillId"
>
<div v-dompurify-html="item.content"></div>
</el-collapse-item>
</el-collapse>
2024-06-13 17:31:52 +08:00
<Pagination
v-model:limit="skillSearch.pageSize"
v-model:page="skillSearch.pageNo"
:total="skillCount"
small
layout="total, prev, pager, next, jumper"
@pagination="getSkillList"
/>
2024-04-28 16:20:45 +08:00
</div>
</div>
2024-05-10 16:21:07 +08:00
<template #footer>
<span>
<el-button @click="dialogVisible = false"> </el-button>
2024-06-13 17:12:38 +08:00
<el-button :disabled="formLoading" type="primary" @click="handleSave"> </el-button>
2024-05-10 16:21:07 +08:00
</span>
</template>
2024-05-23 14:08:08 +08:00
</Dialog>
2024-04-28 16:20:45 +08:00
</template>
2024-06-13 17:12:38 +08:00
<script setup name="DialogFollow">
2024-06-13 17:31:52 +08:00
import { getSkillPage } from '@/api/clue/skill'
2024-06-13 17:12:38 +08:00
import { createFollow } from '@/api/clue/followRecord'
2024-06-26 18:24:45 +08:00
import { getDictOptions } from '@/utils/dict'
import { formatDate } from '@/utils/formatTime'
2024-06-13 17:12:38 +08:00
const { t } = useI18n() // 国际化
const message = useMessage() // 消息弹窗
2024-06-26 18:24:45 +08:00
const intentionOptions = getDictOptions('intention_state')
2024-04-28 16:20:45 +08:00
const dialogVisible = ref(false) // 弹窗的是否展示
const dialogTitle = ref('') // 弹窗的标题
const formLoading = ref(false) // 表单的加载中1修改时的数据加载2提交的按钮禁用
const formRef = ref() // 表单 Ref
2024-06-13 17:12:38 +08:00
const form = ref({})
const rules = {
operateTime: { required: true, message: '本次跟进时间不可为空', trigger: 'change' },
nextFollowTime: { required: true, message: '下次跟进时间不可为空', trigger: 'change' },
content: { required: true, message: '跟进内容不可为空', trigger: 'blur' }
}
2024-06-26 18:24:45 +08:00
const open = async (clueId, status) => {
2024-04-28 16:20:45 +08:00
dialogVisible.value = true
2024-06-13 17:12:38 +08:00
dialogTitle.value = '新增跟进记录'
2024-06-26 18:24:45 +08:00
resetForm(clueId, status)
2024-04-28 16:20:45 +08:00
}
defineExpose({ open }) // 提供 open 方法,用于打开弹窗
2024-06-26 18:24:45 +08:00
function resetForm(clueId, status) {
2024-06-13 17:12:38 +08:00
form.value = {
clueId,
2024-06-26 18:24:45 +08:00
operateTime: formatDate(new Date(), 'YYYY-MM-DD HH:mm'),
2024-06-13 17:12:38 +08:00
nextFollowTime: undefined,
2024-06-26 18:24:45 +08:00
intentionState: status,
2024-06-13 17:12:38 +08:00
content: undefined
}
}
2024-04-28 16:20:45 +08:00
2024-06-13 17:31:52 +08:00
const skillList = ref([])
2024-04-28 16:20:45 +08:00
const activeQues = ref('')
2024-06-13 17:31:52 +08:00
const skillSearch = ref({
pageNo: 1,
pageSize: 10,
question: undefined
})
const skillCount = ref(0)
function getSkillList() {
getSkillPage(skillSearch.value).then((data) => {
skillList.value = data.list
skillCount.value = data.total
})
2024-04-28 16:20:45 +08:00
}
2024-05-10 16:21:07 +08:00
2024-07-01 12:08:00 +08:00
const emit = defineEmits(['success'])
2024-06-13 17:12:38 +08:00
async function handleSave() {
// 校验表单
if (!formRef.value) return
const valid = await formRef.value.validate()
if (!valid) return
// 提交请求
formLoading.value = true
try {
await createFollow(form.value)
message.success(t('common.createSuccess'))
dialogVisible.value = false
// 发送操作成功的事件
emit('success')
} finally {
formLoading.value = false
}
2024-05-10 16:21:07 +08:00
}
2024-06-13 17:31:52 +08:00
onMounted(() => {
getSkillList()
})
2024-04-28 16:20:45 +08:00
</script>
<style lang="scss" scoped></style>