follow.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <template>
  2. <div class="follow" style="margin-right:10px">
  3. <el-button size="mini" @click="followBtn" :disabled="disabled">跟进</el-button>
  4. <el-drawer title="线索跟进" append-to-body :visible.sync="dialogVisible" size="30%" :before-close="handleClose">
  5. <div class="drawer__panel">
  6. <el-form :model="param" :rules="rules" ref="ruleForm" label-width="110px" class="demo-ruleForm"
  7. label-position="right">
  8. <el-form-item label="跟进时间">
  9. <el-date-picker v-model="timer" type="date" format="yyyy-MM-dd HH:mm:ss" disabled size="small">
  10. </el-date-picker>
  11. </el-form-item>
  12. <el-form-item label="本次跟进方式" prop="followupmode">
  13. <el-select v-model="param.followupmode" placeholder="请选择方式" size="small">
  14. <el-option v-for="(item,index) in followTypeList" :key="index" :label="item.value" :value="item.value">
  15. </el-option>
  16. </el-select>
  17. </el-form-item>
  18. <!-- <el-form-item label="本次跟进结果" prop="logtype">
  19. <el-radio-group v-model="param.logtype">
  20. <el-radio label="跟进">跟进</el-radio>
  21. </el-radio-group>
  22. </el-form-item> -->
  23. <el-form-item label="跟进内容" prop="content" v-if="param.logtype == '跟进'">
  24. <el-input type="textarea" v-model="param.content" size="small"></el-input>
  25. </el-form-item>
  26. <upload
  27. ref="upload"
  28. :folderid="folderid"
  29. @onSuccess="onSuccess"
  30. :bindData="bindData"
  31. type="button">
  32. </upload>
  33. </el-form>
  34. </div>
  35. <div class="fixed__btn__panel">
  36. <el-button size="small" @click="dialogVisible = false" class="normal-btn-width">取 消</el-button>
  37. <el-button size="small" type="primary" @click="followAction" class="normal-btn-width" :loading="loading">确 定</el-button>
  38. </div>
  39. </el-drawer>
  40. </div>
  41. </template>
  42. <script>
  43. import upload from './upload'
  44. export default {
  45. components:{upload},
  46. name: '',
  47. data () {
  48. return {
  49. loading:false,
  50. bindData:{},
  51. folderid:JSON.parse(sessionStorage.getItem('folderid')).appfolderid,
  52. param: {
  53. "sat_orderclueid": 4,
  54. "content": "",
  55. "followupmode": "", //当面拜访、电话沟通
  56. "logtype": "跟进", //跟进、成交、丢单、无效
  57. "competitor": "",
  58. "latitude":"",//经度,可选
  59. "longitude":"",//纬度,可选
  60. "address":"",//解析地址,
  61. "sat_ordercluefollowuplogid":0//传0新增
  62. },
  63. timer: new Date(),
  64. rules: {
  65. content: [
  66. { required: true, message: '内容不能为空', trigger: 'blur' },
  67. ],
  68. followupmode: [
  69. { required: true, message: '内容不能为空', trigger: 'blur' },
  70. ],
  71. logtype: [
  72. { required: true, message: '内容不能为空', trigger: 'blur' },
  73. ],
  74. competitor: [
  75. { required: true, message: '内容不能为空', trigger: 'blur' },
  76. ],
  77. },
  78. time: '',
  79. dialogVisible: false,
  80. followTypeList: []
  81. }
  82. },
  83. props: {
  84. detailInfo: {
  85. default () {
  86. return []
  87. }
  88. },
  89. position: {
  90. type: String
  91. },
  92. updataList: {
  93. type: Function
  94. },
  95. getDetail: {
  96. type: Function
  97. },
  98. disabled: Boolean
  99. },
  100. watch: {
  101. dialogVisible(val) {
  102. if (!val) {
  103. this.$refs['ruleForm'].resetFields()
  104. this.$refs.upload.fileLinkList = []
  105. this.$refs.upload.fileList = []
  106. }
  107. }
  108. },
  109. computed: {
  110. },
  111. created () {
  112. this.getFollowType()
  113. },
  114. methods: {
  115. async getFollowType () {
  116. let res = await this.$store.dispatch('optiontypeselect', 'followupmode')
  117. this.followTypeList = res.data
  118. },
  119. followBtn () {
  120. this.dialogVisible = true
  121. },
  122. handleClose () {
  123. this.dialogVisible = false
  124. },
  125. followAction () {
  126. this.$refs.ruleForm.validate(async val => {
  127. if (!val) return
  128. this.param.sat_orderclueid = this.detailInfo.sat_orderclueid
  129. let res = await this.$api.requested({
  130. "id":20221208100602,
  131. "content": this.param
  132. })
  133. this.bindData = {
  134. "ownertable": 'sat_ordercluefollowuplog',
  135. "ownerid": res.data.sat_ordercluefollowuplogid,
  136. "usetype": 'default',
  137. }
  138. this.loading = true
  139. this.$refs['upload'].toUpload(() => {
  140. this.loading = false
  141. this.$emit('onSuccess')
  142. this.dialogVisible = false
  143. })
  144. })
  145. },
  146. onSuccess () {
  147. }
  148. },
  149. };
  150. </script>
  151. <style scoped>
  152. .follow {
  153. display: inline-block;
  154. }
  155. /deep/.el-input,.el-select {
  156. width: 100%;
  157. }
  158. </style>