diff --git a/src/api/basicdata/basicClient.js b/src/api/basicdata/basicClient.js index 8c0419fd..b4a0d0e4 100644 --- a/src/api/basicdata/basicClient.js +++ b/src/api/basicdata/basicClient.js @@ -8,25 +8,25 @@ export const getList = (current, size, params) => { ...params, current, size, - } - }) -} + }, + }); +}; -export const getListCode = (params) => { +export const getListCode = params => { return request({ url: '/api/logpm-basicdata/basicdataClient/getFinallyClientCode', method: 'get', - params - }) -} + params, + }); +}; -export const $_getListlistName = (params) => { +export const $_getListlistName = params => { return request({ url: '/api/logpm-basicdata/basicdataClient/listName', method: 'get', - params - }) -} + params, + }); +}; export const getListClient = (current, size, params) => { return request({ url: '/api/logpm-basicdata/basicdataClient/list', @@ -35,53 +35,53 @@ export const getListClient = (current, size, params) => { ...params, current, size, - } - }) -} + }, + }); +}; -export const getDetail = (id) => { +export const getDetail = id => { return request({ url: '/api/logpm-basicdata/basicdataClient/detail', method: 'get', params: { - id - } - }) -} + id, + }, + }); +}; -export const remove = (ids) => { +export const remove = ids => { return request({ url: '/api/logpm-basicdata/basicdataClient/remove', method: 'post', params: { ids, - } - }) -} + }, + }); +}; -export const add = (row) => { +export const add = row => { return request({ url: '/api/logpm-basicdata/basicdataClient/submit', method: 'post', - data: row - }) -} + data: row, + }); +}; -export const update = (row) => { +export const update = row => { return request({ url: '/api/logpm-basicdata/basicdataClient/submit', method: 'post', - data: row - }) -} + data: row, + }); +}; -export const updateCargoControl = (row) => { +export const updateCargoControl = row => { return request({ url: '/api/logpm-basicdata/basicdataClient/update', method: 'post', - data: row - }) -} + data: row, + }); +}; export const selectName = (current, size, params) => { return request({ @@ -91,8 +91,15 @@ export const selectName = (current, size, params) => { ...params, current, size, - } - }) -} - + }, + }); +}; +/** 获取客户日志 */ +export const getClientLogList = params => { + return request({ + url: '/api/logpm-basicdata/clientLog/list', + method: 'get', + params, + }); +}; diff --git a/src/api/basicdata/basicdataTray.js b/src/api/basicdata/basicdataTray.js index bee5c8bc..9b870435 100644 --- a/src/api/basicdata/basicdataTray.js +++ b/src/api/basicdata/basicdataTray.js @@ -86,6 +86,7 @@ export const getDownloadTrayCode = ids => { params: { ids, }, + responseType: 'blob', }); }; diff --git a/src/components/tablecmt/tablecmt.vue b/src/components/tablecmt/tablecmt.vue index 84af6699..f4f43fe1 100644 --- a/src/components/tablecmt/tablecmt.vue +++ b/src/components/tablecmt/tablecmt.vue @@ -394,9 +394,7 @@ const isHaveSelection = ref(false); let selectarr = ref([]); /** 设置每行颜色 */ const tableRowClassName = ({ row, rowIndex }: { row: TableDataType; rowIndex: number }) => { - // console.log('selectarr.value :>> ', selectarr.value); for (let i = 0; i < selectarr.value.length; i++) { - // console.log('row :>> ', row); if (selectarr.value[i] === row) return 'table-SelectedRow-bgcolor'; } @@ -755,6 +753,8 @@ const handleWidthChange = (newWidth, oldWidth, column, event) => { break; } + console.log('props.columnListName :>> ', props.columnListName); + functions.setStorage($route.fullPath + (props.columnListName || 'columnList'), props.columnList); }; diff --git a/src/option/distribution/abnormalList.js b/src/option/distribution/abnormalList.js index 69ed5b55..f20e689d 100644 --- a/src/option/distribution/abnormalList.js +++ b/src/option/distribution/abnormalList.js @@ -40,6 +40,7 @@ export const columnList = [ { value: 2, label: '无装车计划' }, { value: 3, label: '无装车记录' }, { value: 4, label: '无卸车记录' }, + { value: 5, label: '卸车数据异常' }, ], fixed: false, sortable: true, diff --git a/src/option/distribution/arteryDistrilbutionBillLadingList.js b/src/option/distribution/arteryDistrilbutionBillLadingList.js index ee74213c..f10d21e2 100644 --- a/src/option/distribution/arteryDistrilbutionBillLadingList.js +++ b/src/option/distribution/arteryDistrilbutionBillLadingList.js @@ -636,7 +636,7 @@ export const columnOldList = [ }, { prop: 'noBillladingNum', - label: '未入库件数', + label: '未提货件数', type: 1, values: '', width: '130', diff --git a/src/option/finance/CustomerSettlement.js b/src/option/finance/CustomerSettlement.js index 8530420c..4f2eb5f3 100644 --- a/src/option/finance/CustomerSettlement.js +++ b/src/option/finance/CustomerSettlement.js @@ -14,6 +14,17 @@ export const columnList = [ width: 55, fixed: true, }, + { + prop: 'balanceOrderNo', + label: '结算单号', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: true, + sortable: true, + head: false, + }, { prop: 'brand', label: '品牌', @@ -106,6 +117,17 @@ export const columnList = [ sortable: true, head: false, }, + { + prop: 'balanceTime', + label: '结算时间', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, { prop: 'totalBalanceFee', label: '结算单总金额', diff --git a/src/utils/util.js b/src/utils/util.js index cdfdc66a..fb54449f 100644 --- a/src/utils/util.js +++ b/src/utils/util.js @@ -438,6 +438,29 @@ export const downloadXls = (fileArrayBuffer, filename) => { window.open(URL.createObjectURL(file)); } }; +/** + * 下载excel + * @param {blob} fileArrayBuffer 文件流 + * @param {String} filename 文件名称 + */ +export const downloadPdf = (fileArrayBuffer, filename) => { + let data = new Blob([fileArrayBuffer], { type: 'application/pdf,charset=utf-8' }); + if (typeof window.chrome !== 'undefined') { + // Chrome + var link = document.createElement('a'); + link.href = window.URL.createObjectURL(data); + link.download = filename; + link.click(); + } else if (typeof window.navigator.msSaveBlob !== 'undefined') { + // IE + var blob = new Blob([data], { type: 'application/force-download' }); + window.navigator.msSaveBlob(blob, filename); + } else { + // Firefox + var file = new File([data], filename, { type: 'application/force-download' }); + window.open(URL.createObjectURL(file)); + } +}; /** 获取视口高度 */ export const getWinHeight = () => { @@ -635,9 +658,9 @@ export function debounce(func, delay) { /** 去除零宽字符 */ export const removeZeroWidth = str => { - if(str){ + if (str) { return str.replace(/[\u200B-\u200D\uFEFF]/g, ''); - }else{ + } else { return str; } }; diff --git a/src/views/basicdata/brand/basicClient.vue b/src/views/basicdata/brand/basicClient.vue index f15c1c82..b3c026de 100644 --- a/src/views/basicdata/brand/basicClient.vue +++ b/src/views/basicdata/brand/basicClient.vue @@ -1,6 +1,6 @@ @@ -212,8 +215,6 @@ - -
文件校验 @@ -330,10 +331,18 @@ --> - + - + @@ -510,6 +519,13 @@
+ + + + + + + @@ -523,6 +539,7 @@ import { remove, getListCode, $_getListlistName, + getClientLogList, } from '@/api/basicdata/basicClient'; import option from '@/option/basicdata/basicClient'; import { mapGetters } from 'vuex'; @@ -545,8 +562,8 @@ export default { excelForm: {}, fromloading: true, excelBox: false, - Fileverification:false, - FileverificationLoadong:false, + Fileverification: false, + FileverificationLoadong: false, excelOption: { submitBtn: false, emptyBtn: false, @@ -892,7 +909,68 @@ export default { submitLoading: false, /** 上传文件 */ UploadLoadong: false, + pageLoading: false, + }, + popUpShow: { + logVisted: false, }, + // 日志 + columnLogList: [ + { + prop: '', + label: '序号', + type: 12, + values: '', + width: 55, + checkarr: [], + fixed: true, + }, + { + prop: 'clientName', + label: '客户名称', + type: 2, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'operator', + label: '操作人', + type: 2, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'content', + label: '操作描述', + type: 2, + values: '', + width: '500', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'createTime', + label: '操作时间', + type: 2, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + ], + logData: [], }; }, created() {}, @@ -1008,6 +1086,9 @@ export default { case 7: this.openAcount(row); break; + case 8: + this.handleShowLog(row); + break; } }, //远程校验 @@ -1089,6 +1170,33 @@ export default { }); }, + /** + * 日志 + */ + async handleShowLog(row) { + try { + this.loadingObj.pageLoading = true; + + const res = await getClientLogList({ clientId: row.id }); + + const { code, data } = res.data; + if (code !== 200) return; + this.logData = data; + // this.openAcountform.name = row.linkman; + // this.openAcountform.phone = row.phone; + // this.openAcountStatus = true; + this.popUpShow.logVisted = true; + + await this.$nextTick(); + console.log(this.$refs.tableLogNode.$el); + // getClientLogList + } catch (error) { + console.log('error :>> ', error); + } finally { + this.loadingObj.pageLoading = false; + } + }, + // handleMall(row) { // console.log('>>>', row); @@ -1169,8 +1277,8 @@ export default { this.showImgViewer = false; }, // 文件校验 - ckFileverification(){ - this.Fileverification=true;//开启弹窗 + ckFileverification() { + this.Fileverification = true; //开启弹窗 }, //文件上传前的一些业务需要的校验 beforeUploadFn(file, fileList) { @@ -1724,10 +1832,10 @@ export default { /** 上传文件 */ handleBeforeUpload(file) { console.log('file :>> ', file); - if(this.Fileverification){ - this.FileverificationLoadong=true + if (this.Fileverification) { + this.FileverificationLoadong = true; // 文件校验 - }else{ + } else { this.loadingObj.UploadLoadong = true; } @@ -1742,11 +1850,11 @@ export default { if (whiteArr.indexOf(_fileType) !== -1) return true; this.$message.warning('请传入xls或xlsx格式的文件'); - if(this.Fileverification){ - this.FileverificationLoadong=false + if (this.Fileverification) { + this.FileverificationLoadong = false; // 文件校验 - }else{ - this.loadingObj.UploadLoadong = false; + } else { + this.loadingObj.UploadLoadong = false; } return false; }, @@ -1754,25 +1862,25 @@ export default { /** 长传成功 */ handleSuccess(res) { console.log('res :>> ', res); - if(this.Fileverification){ - this.FileverificationLoadong=true + if (this.Fileverification) { + this.FileverificationLoadong = true; // 文件校验 - }else{ + } else { this.loadingObj.UploadLoadong = true; } if (res.code !== 200) return this.$message.warning('上传失败'); this.$message.success('上传成功'); - if(this.loadingObj.submitLoading){ + if (this.loadingObj.submitLoading) { onLoad(this.page); } }, /** 上传失败 */ handleClose(res) { - if(this.Fileverification){ - this.FileverificationLoadong=false + if (this.Fileverification) { + this.FileverificationLoadong = false; // 文件校验 - }else{ + } else { this.loadingObj.UploadLoadong = false; } // UploadAjaxError diff --git a/src/views/basicdata/warehouse/tray/basicdataTray.vue b/src/views/basicdata/warehouse/tray/basicdataTray.vue index 0c7e0545..783c029b 100644 --- a/src/views/basicdata/warehouse/tray/basicdataTray.vue +++ b/src/views/basicdata/warehouse/tray/basicdataTray.vue @@ -90,9 +90,9 @@ 查看二维码 - + 报 损 @@ -283,7 +283,7 @@ import { mapGetters } from 'vuex'; /** 获取字典 */ import { getDictionaryBiz } from '@/api/system/dict'; import { - downloadXls, + downloadPdf, setNodeHeight, getHtmls, deepClone, @@ -662,9 +662,10 @@ const handleDownLoadTrayCode = async () => { let qr = details.selectionList.map(item => item.id).join(','); console.log(qr); const res = await getDownloadTrayCode(qr); - console.log(res.data); - const { code, data } = res.data; - if (code !== 200) return; + console.log(res); + const { status, data } = res; + if (status !== 200) return; + downloadPdf(data, '托盘码.pdf'); console.log('data :>> ', data); } catch (error) { console.log('error :>> ', error); diff --git a/src/views/distribution/artery/abnormalList.vue b/src/views/distribution/artery/abnormalList.vue index c226556e..214e053e 100644 --- a/src/views/distribution/artery/abnormalList.vue +++ b/src/views/distribution/artery/abnormalList.vue @@ -110,7 +110,7 @@ @@ -163,6 +163,7 @@ 同步数据 + + + +
@@ -255,7 +290,7 @@ const details = reactive({ /** 列表 */ columnList: deepClone(columnList), /** 列表数据 */ - data: [{}], + data: [], /** 页面loading */ loadingObj: { /** 列表加载loading */ @@ -434,7 +469,8 @@ const beforeClose = done => { /** 处理异常 */ const handleAnException = ({ row }) => { - details.abnormalInfo = row; + details.abnormalInfo = { ...row }; + details.abnormalInfo.handleNum = 0; details.popUpShow.abnormalVisited = true; }; @@ -450,6 +486,10 @@ const handleAbnormal = (dealType, title) => { try { details.loadingObj.pageLoading = true; const submitData = { abnormalRecordId: details.abnormalInfo.id, dealType }; + if (dealType === 6) { + if (!submitData.num) return ElMessage.warning('请输入入库数量'); + submitData.num = details.abnormalInfo.handleNum; + } const res = await postDealAbnormal(submitData); const { code, msg } = res.data; diff --git a/src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue b/src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue index 2ceac17e..3a6a2b2a 100644 --- a/src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue +++ b/src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue @@ -69,7 +69,7 @@ type="primary" v-if="permissionObj.arteryDistrilbutionBillLadingList_confirmBill" icon="el-icon-check" - @click="handleEditBillladingStatus(2)" + @click="handleShowConfirm" > 提货完成 @@ -267,6 +267,40 @@ + + + + + + + + + + + + + 1) return this.$message.error('暂时只支持单条数据操作'); + + this.popUpShow.confirmBillLading = true; + const item = this.selectionList[0]; + this.form = { + minTime: new Date(item.startTime).getTime(), + time: dayjs(new Date()).format('YYYY-MM-DD HH:mm:ss'), + id: item.id, + }; + console.log('this.form :>> ', this.form); + }, + async handleConfirmSubmit() { + try { + if (new Date(this.form.time).getTime() <= this.form.minTime) + return this.$message.warning('完成时间请大于提货开始时间'); + this.popUpShow.confirmBillLading = false; + this.loadingObj.pageLoading = true; + + const res = await postUpdateBillladingStatus({ + id: this.form.id, + type: 2, + completeTime: this.form.time, + }); + + const { code, msg } = res.data; + + if (code !== 200) return; + this.$message.success(msg); + // 清空复选框 + this.selectionClear(); + // 刷新表格 + this.onLoad(this.page); + } catch (error) { + console.log('error :>> ', error); + } finally { + this.loadingObj.pageLoading = false; + } + }, /** 开启添加提货数据弹窗 */ handleAddDistrilbution() { if (!ChecksWhetherTheWarehouseIsSelected()) diff --git a/src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue b/src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue index 439813f7..66fbbe95 100644 --- a/src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue +++ b/src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue @@ -73,7 +73,10 @@
编辑 + 编辑 + diff --git a/src/views/finance/CustomerSettlement.vue b/src/views/finance/CustomerSettlement.vue index 47d3e4d7..9c2f69ef 100644 --- a/src/views/finance/CustomerSettlement.vue +++ b/src/views/finance/CustomerSettlement.vue @@ -170,7 +170,7 @@ const details = reactive({ /** 列表 */ columnList: deepClone(columnList), /** 列表数据 */ - data: [{}], + data: [], /** 页面loading */ loadingObj: { /** 列表加载loading */