|
@@ -71,15 +71,16 @@
|
|
|
/>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="创建时间" prop="customerCreateTime">
|
|
|
+ <el-form-item label="客户创建时间" prop="createTimeRange">
|
|
|
<el-date-picker
|
|
|
- style="width:220px"
|
|
|
- clearable size="small"
|
|
|
- v-model="queryParams.customerCreateTime"
|
|
|
- value-format="yyyy-MM-dd"
|
|
|
- placeholder="创建时间"
|
|
|
- >
|
|
|
- </el-date-picker>
|
|
|
+ style="width:205.4px"
|
|
|
+ clearable size="small"
|
|
|
+ v-model="createTimeRange"
|
|
|
+ type="daterange"
|
|
|
+ value-format="yyyy-MM-dd"
|
|
|
+ start-placeholder="开始日期"
|
|
|
+ end-placeholder="结束日期">
|
|
|
+ </el-date-picker>
|
|
|
</el-form-item>
|
|
|
<el-form-item label="领取时间" prop="receiveTime">
|
|
|
<el-date-picker
|
|
@@ -142,6 +143,15 @@
|
|
|
v-hasPermi="['crm:customer:sendBatchSms']"
|
|
|
>批量发送短信</el-button>
|
|
|
</el-col>
|
|
|
+ <el-col :span="1.5">
|
|
|
+ <el-button
|
|
|
+ type="warning"
|
|
|
+ icon="el-icon-upload2"
|
|
|
+ size="mini"
|
|
|
+ @click="handleImport"
|
|
|
+ v-hasPermi="['crm:customer:importVisit']"
|
|
|
+ >导入跟进阶段</el-button>
|
|
|
+ </el-col>
|
|
|
<el-col :span="1.5">
|
|
|
<el-button
|
|
|
type="warning"
|
|
@@ -199,6 +209,7 @@
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
<el-table-column label="进线客户详情" align="center" :show-overflow-tooltip="true" prop="registerDesc" />
|
|
|
+ <el-table-column label="最新跟进时间" align="center" prop="lastTime" />
|
|
|
<el-table-column label="领取时间" align="center" prop="receiveTime" />
|
|
|
<el-table-column label="进线客户提交日期" align="center" prop="registerSubmitTime" />
|
|
|
<el-table-column label="创建时间" align="center" prop="customerCreateTime" width="180">
|
|
@@ -267,14 +278,38 @@
|
|
|
<el-dialog :title="addVisitStatus.title" :visible.sync="addVisitStatus.open" width="600px" append-to-body>
|
|
|
<add-visit-status ref="visitStatus" @close="closeVisitStatus()"></add-visit-status>
|
|
|
</el-dialog>
|
|
|
+
|
|
|
+ <el-dialog :title="upload.title" :visible.sync="upload.open" width="400px" append-to-body>
|
|
|
+ <el-upload ref="upload" :limit="1" accept=".xlsx, .xls" :headers="upload.headers" :action="upload.url + '?updateSupport=' + upload.updateSupport" :disabled="upload.isUploading" :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess" :auto-upload="false" drag>
|
|
|
+ <i class="el-icon-upload"></i>
|
|
|
+ <div class="el-upload__text">
|
|
|
+ 将文件拖到此处,或
|
|
|
+ <em>点击上传</em>
|
|
|
+ </div>
|
|
|
+ <div class="el-upload__tip" slot="tip">
|
|
|
+ <el-link type="info" style="font-size:12px" @click="importTemplate">下载模板</el-link>
|
|
|
+ </div>
|
|
|
+ <div class="el-upload__tip" style="color:red" slot="tip">提示:仅允许导入“xls”或“xlsx”格式文件!</div>
|
|
|
+ </el-upload>
|
|
|
+ <div slot="footer" class="dialog-footer">
|
|
|
+ <el-button type="primary" @click="submitFileForm">确 定</el-button>
|
|
|
+ <el-button @click="upload.open = false">取 消</el-button>
|
|
|
+ </div>
|
|
|
+ </el-dialog>
|
|
|
+
|
|
|
+ <el-dialog title="导入结果" :close-on-press-escape="false" :close-on-click-modal="false" :visible.sync="importMsgOpen" width="500px" append-to-body>
|
|
|
+ <div class="import-msg" v-html="importMsg">
|
|
|
+ </div>
|
|
|
+ </el-dialog>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
-import { getMyCustomerList,recover,exportCustomer } from "@/api/crm/customer";
|
|
|
+import { getMyCustomerList,recover,exportCustomer,importVisitTemplate } from "@/api/crm/customer";
|
|
|
import customerDetails from '../components/customerDetails.vue';
|
|
|
import addVisit from '../components/addVisit.vue';
|
|
|
import {getCitys} from "@/api/store/city";
|
|
|
+import { getToken } from "@/utils/auth";
|
|
|
import addBatchSms from '../components/addBatchSms.vue';
|
|
|
import editSource from '../components/editSource.vue';
|
|
|
import addOrEditCustomer from '../components/addOrEditCustomer.vue';
|
|
@@ -309,6 +344,7 @@ export default {
|
|
|
ctsTypeArr:[],
|
|
|
sourceArr:[],
|
|
|
tagsOptions:[],
|
|
|
+ createTimeRange:[],
|
|
|
customer:{
|
|
|
open:false,
|
|
|
title:"新增客户"
|
|
@@ -326,6 +362,20 @@ export default {
|
|
|
title:"分配客户",
|
|
|
open:false,
|
|
|
},
|
|
|
+ upload: {
|
|
|
+ // 是否显示弹出层(用户导入)
|
|
|
+ open: false,
|
|
|
+ // 弹出层标题(用户导入)
|
|
|
+ title: "",
|
|
|
+ // 是否禁用上传
|
|
|
+ isUploading: false,
|
|
|
+ // 设置上传的请求头部
|
|
|
+ headers: { Authorization: "Bearer " + getToken() },
|
|
|
+ // 上传的地址
|
|
|
+ url: process.env.VUE_APP_BASE_API + "/crm/customer/importVisitData",
|
|
|
+ },
|
|
|
+ importMsgOpen:false,
|
|
|
+ importMsg:"",
|
|
|
assignForm: {
|
|
|
},
|
|
|
// 表单校验
|
|
@@ -594,6 +644,12 @@ export default {
|
|
|
/** 查询客户列表 */
|
|
|
getList() {
|
|
|
this.loading = true;
|
|
|
+ if(this.createTimeRange!=null&&this.createTimeRange.length==2){
|
|
|
+ this.queryParams.createTimeRange=this.createTimeRange[0]+"--"+this.createTimeRange[1]
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ this.queryParams.createTimeRange=null;
|
|
|
+ }
|
|
|
if(this.statusArr.length>0){
|
|
|
this.queryParams.status=this.statusArr.toString();
|
|
|
}
|
|
@@ -678,6 +734,35 @@ export default {
|
|
|
this.download(response.msg);
|
|
|
}).catch(function() {});
|
|
|
},
|
|
|
+ /** 导入按钮操作 */
|
|
|
+ handleImport() {
|
|
|
+ this.upload.title = "客户跟进情况导入";
|
|
|
+ this.upload.open = true;
|
|
|
+
|
|
|
+ },
|
|
|
+ /** 下载模板操作 */
|
|
|
+ importTemplate() {
|
|
|
+ importVisitTemplate().then((response) => {
|
|
|
+ this.download(response.msg);
|
|
|
+ });
|
|
|
+ },
|
|
|
+ // 文件上传中处理
|
|
|
+ handleFileUploadProgress(event, file, fileList) {
|
|
|
+ this.upload.isUploading = true;
|
|
|
+ },
|
|
|
+ // 文件上传成功处理
|
|
|
+ handleFileSuccess(response, file, fileList) {
|
|
|
+ this.upload.open = false;
|
|
|
+ this.upload.isUploading = false;
|
|
|
+ this.$refs.upload.clearFiles();
|
|
|
+ this.importMsgOpen=true;
|
|
|
+ this.importMsg=response.msg
|
|
|
+ this.getList();
|
|
|
+ },
|
|
|
+ // 提交上传文件
|
|
|
+ submitFileForm() {
|
|
|
+ this.$refs.upload.submit();
|
|
|
+ },
|
|
|
}
|
|
|
};
|
|
|
</script>
|