Browse Source

Merge branch 'dev' into pre-production

pre-production
pref_mail@163.com 5 months ago
parent
commit
6c5b625c2c
  1. 39
      src/api/distribution/packageNodeSearch.js
  2. 5
      src/components/SelectBox/SelectBox.vue
  3. 118
      src/components/Tableexportcomponent/Tableexportcomponent.vue
  4. 8
      src/components/edittablehead/index.vue
  5. 665
      src/components/newTablecmt/newTablecmt.vue
  6. 44
      src/components/tablecmt/tablecmt.vue
  7. 86
      src/option/aftersales/vueTvemp.js
  8. 36
      src/option/basicdata/BackStockTask.js
  9. 743
      src/option/basicdata/basicdataWarehouseTemp.js
  10. 98
      src/option/finance/ReconciliationDepositSlip.js
  11. 64
      src/option/reportforms/DeliveryDetailsVtwo.js
  12. 4
      src/router/views/index.js
  13. 7
      src/utils/util.js
  14. 6890
      src/views/aftersales/aftersalesWorkOrder.vue
  15. 4
      src/views/aftersales/aftersalesWorkOrderAdd.vue
  16. 61
      src/views/aftersales/aftersalesWorkOrderInfo.vue
  17. 6759
      src/views/aftersales/aftersalesWorkOrderTemp.vue
  18. 731
      src/views/aftersales/aftersalesWorkOrderend.vue
  19. 216
      src/views/basicdata/warehouse/tray/basicdataTrayedt.vue
  20. 2
      src/views/distribution/artery/VehicleStowageDetails.vue
  21. 7
      src/views/distribution/artery/truckLoadingDetails.vue
  22. 108
      src/views/distribution/inventory/BookingNote.vue
  23. 4
      src/views/reportforms/DeliveryDetailsVtwo.vue
  24. 31
      src/views/warehouse/parcelList/distributionParcelList.vue
  25. 5
      src/views/waybill/CreateZeroOrder.vue
  26. 2
      src/views/waybill/orderPackageList.vue

39
src/api/distribution/packageNodeSearch.js

@ -1,5 +1,4 @@
/** 流转节点 */
/** 流转节点 */
export const columnList = [
// {
// prop: 'createUserName',
@ -22,7 +21,7 @@ export const columnList = [
{
prop: 'warehouseName',
label: '仓库',
type: 1,
type: 30,
values: '',
width: '130',
checkarr: [],
@ -32,7 +31,7 @@ export const columnList = [
// {
// prop: 'createTime',
// label: '订单自编号',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -42,7 +41,7 @@ export const columnList = [
{
prop: 'orderPackageCode',
label: '包条码',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -52,7 +51,7 @@ export const columnList = [
{
prop: 'operator',
label: '操作人',
type: 1,
type: 30,
values: '',
width: '130',
checkarr: [],
@ -62,7 +61,7 @@ export const columnList = [
{
prop: 'content',
label: '描述',
type: 1,
type: 30,
values: '',
width: '250',
checkarr: [],
@ -72,7 +71,7 @@ export const columnList = [
{
prop: 'createTime',
label: '操作时间',
type: 1,
type: 30,
values: '',
width: '250',
checkarr: [],
@ -82,7 +81,7 @@ export const columnList = [
{
prop: 'workNodeName',
label: '节点',
type: 1,
type: 30,
values: '',
width: '130',
checkarr: [],
@ -92,7 +91,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '是否干仓配',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -102,7 +101,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '服务类型',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -112,7 +111,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '流转节点',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -122,7 +121,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '库位',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -132,7 +131,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '托盘码',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -142,7 +141,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '一级品名称',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -152,7 +151,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '二级品名称',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -162,7 +161,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '三级品名称',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -172,7 +171,7 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '物料名称',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
@ -182,11 +181,11 @@ export const columnList = [
// {
// prop: 'createUserName',
// label: '物料编码',
// type: 1,
// type: 30,
// values: '',
// width: '130',
// checkarr: [],
// fixed: false,
// sortable: true,
// },
];
];

5
src/components/SelectBox/SelectBox.vue

@ -21,7 +21,7 @@
: 'min-width:' + props.minWidth
: ''
"
v-if="isShowBox"
v-if="isShowBox && !props.disabled"
>
<div class="content">
<SelectComponent
@ -67,6 +67,9 @@ const props = defineProps([
/** 是否禁用 : 默认false */
'disabled',
]);
console.log('props :>> ', props);
const $emit = defineEmits(['update:modelValue']);
const _computed = computed({

118
src/components/Tableexportcomponent/Tableexportcomponent.vue

@ -3,9 +3,15 @@
<span>表格导出名称</span>
<el-input
v-model="exportFileName"
placeholder="请输入导出的表格名称"
placeholder="请输入导出的表格名称,不填写则默认导出名称"
style="margin-bottom: 10px"
/>
<el-tabs v-model="radio" class="el_TablePage_radio">
<el-tab-pane label="当前页全部导出" name="1"></el-tab-pane>
<el-tab-pane label="当前页勾选导出" name="2"></el-tab-pane>
</el-tabs>
<el-transfer
v-model="checkedColumns"
:data="transferData"
@ -26,13 +32,17 @@ import { ref, computed } from 'vue';
import { ElMessage } from 'element-plus';
import * as XLSX from 'xlsx';
import { Download } from '@element-plus/icons-vue';
const radio = ref('1');
//
const props = defineProps({
data: {
type: Array,
required: true,
},
checkedData: {
type: Array,
required: true,
},
menuData: {
type: Array,
required: true,
@ -42,12 +52,13 @@ const props = defineProps({
// menuData 便 setup
const menuData = ref([...props.menuData]);
//
const removeColumn = (columnLabel) => {
const removeColumn = columnLabel => {
const index = menuData.value.findIndex(item => item.label === columnLabel);
if (index !== -1) {
menuData.value.splice(index, 1);
}
};
// ''
removeColumn('序号');
removeColumn('操作');
@ -81,96 +92,40 @@ const transferProps = {
// Excel
const exportToExcel = () => {
//
if (checkedColumns.value.length === 0) {
ElMessage.warning('请选择要导出的字段');
return;
}
//
if (!exportFileName.value) {
ElMessage({
message: '请输入导出名称',
type: 'warning',
});
return;
exportFileName.value = '默认导出名称';
}
const selectedColumns = transferData.value.filter(item =>
checkedColumns.value.includes(item.key)
);
const headers = selectedColumns.map(col => col.label);
const fields = selectedColumns.map(col => col.prop);
//
const selectedColumns = transferData.value
.filter(item => checkedColumns.value.includes(item.key))
.map(col => ({ label: col.label, prop: col.prop }));
//
let exportData = props.data.map(item => {
return fields.map(field => {
const value = item[field];
return value !== undefined && value !== null ? value : '';
});
});
//
exportData = fillEmptyCells(exportData);
const exportData = (radio.value == 1 ? props.data : props.checkedData).map(item =>
selectedColumns.map(col =>
item[col.prop] !== undefined && item[col.prop] !== null ? item[col.prop] : ''
)
);
//
exportData.unshift(headers);
exportData.unshift(selectedColumns.map(col => col.label));
//
// 簿
const worksheet = XLSX.utils.aoa_to_sheet(exportData);
//
applyStyles(worksheet, exportData);
const workbook = XLSX.utils.book_new();
XLSX.utils.book_append_sheet(workbook, worksheet, exportFileName.value);
//
//
XLSX.writeFile(workbook, `${exportFileName.value}.xlsx`);
};
//
const fillEmptyCells = (data) => {
return data;
};
//
const applyStyles = (worksheet, data) => {
const rowCount = data.length;
const colCount = data[0].length;
//
const colWidths = new Array(colCount).fill(0);
data.forEach(row => {
row.forEach((cell, index) => {
const cellWidth = cell ? cell.toString().length : 0;
if (cellWidth > colWidths[index]) {
colWidths[index] = cellWidth;
}
});
});
//
const wscols = colWidths.map(width => ({ wch: Math.min(width + 2, 50) })); // 250
worksheet['!cols'] = wscols;
//
const range = XLSX.utils.decode_range(worksheet['!ref']);
for (let col = range.s.c; col <= range.e.c; col++) {
for (let row = range.s.r; row <= range.e.r; row++) {
const cellRef = XLSX.utils.encode_cell({ c: col, r: row });
if (!worksheet[cellRef]) worksheet[cellRef] = { v: '' };
if (!worksheet[cellRef].s) worksheet[cellRef].s = {};
worksheet[cellRef].s.alignment = {
vertical: 'center',
horizontal: 'center',
wrapText: true,
};
//
if (row === 0) {
worksheet[cellRef].s.font = { bold: true };
}
}
}
};
</script>
<style lang="scss" scoped>
@ -186,4 +141,15 @@ const applyStyles = (worksheet, data) => {
text-align: right;
margin-top: 10px;
}
</style>
:deep(.el_TablePage_radio) {
width: 100%;
display: flex;
align-items: center;
justify-content: space-evenly;
height: 51px;
border: 1px solid #ccc;
.is-checked {
border-color: none;
}
}
</style>

8
src/components/edittablehead/index.vue

@ -163,7 +163,13 @@ const initTable = async () => {
if (item.prop + item.label + item.type !== value.prop + value.label + value.type) continue;
item.checkarr = value.checkarr || [];
_setArr.push({ ...value, width: item.width });
_setArr.push({
...value,
width: item.width,
fixed: item.fixed,
head: item.head,
sortable: item.sortable,
});
_oldArr.splice(i, 1);
break;
}

665
src/components/newTablecmt/newTablecmt.vue

@ -1,665 +0,0 @@
<template>
<div class="maboxhi" id="bodys">
<el-table
:data="tableData"
style="width: 100%"
:show-summary="shownm"
:summary-method="getSummaries"
v-loading="loading"
@selection-change="handleSelectionChange"
border
height="100%"
:row-class-name="tableRowClassName"
ref="selecttable"
>
<el-table-column
:type="column.type == 0 ? 'selection' : ''"
:min-width="column.width"
v-for="(column, index) in newcolumnList"
:key="column.prop"
:prop="column.prop"
:label="column.label"
:fixed="column.fixed"
:sortable="column.sortable"
:selectable="isselectfun"
v-show="column.head"
>
<el-table-column
:type="column.type == 12 ? 'index' : ''"
:min-width="column.width"
:prop="column.prop"
:label="column.label"
v-if="column.type != 0"
flexible
show-overflow-tooltip
>
<template #header>
<!-- <el-text class="mx-1">{{ column.label }}</el-text> -->
<el-input
v-if="column.type == 2"
v-model="column.values"
clearable
:placeholder="`请输入${column.label}`"
@change="inputchange($event, column)"
@blur="inputchange($event, column)"
@clear="inputclear($event, column)"
/>
<el-select
v-if="column.type == 3"
v-model="column.values"
class="m-2 selectbr"
clearable
:placeholder="`请选择${column.label}`"
@change="selectchange($event, column)"
@clear="selectclear($event, column)"
>
<el-option
v-for="item in column.checkarr"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-date-picker
v-model="column.values"
v-if="column.type == 4"
type="date"
clearable
style="width: auto"
:placeholder="`请选择${column.label}`"
@change="timechange($event, column)"
@clear="timeclear($event, column)"
/>
<el-date-picker
v-model="column.values"
v-if="column.type == 5"
type="datetime"
clearable
style="width: auto"
:placeholder="`请选择${column.label}`"
format="YYYY/MM/DD HH:mm:ss"
@change="timechange($event, column)"
@clear="timeclear($event, column)"
/>
</template>
<template #default="scope">
<el-text
class="mx-2 tabculconte"
v-if="Number(column.type) < 6 && Number(column.type) > 0"
>{{ scope.row[column.prop] }}</el-text
>
<el-switch
@change="makeCargo(scope.row, column)"
v-if="column.type == 11"
v-model="scope.row[column.prop]"
/>
<el-text
style=""
class="mx-2 tabculconte colors"
v-if="column.type == 9"
@click="godowns(scope.row[column.downprop])"
>{{ scope.row[column.prop] }}</el-text
>
<el-input
@blur="handleNumberRange(column, scope.row)"
v-if="column.type == 10"
v-model="scope.row[column.prop]"
type="number"
:min="0"
:max="scope.row.residueNumber"
></el-input>
<div class="slotbuts" v-if="column.type == 6">
<slot v-if="column.type == 6" :scope="scope"> </slot>
</div>
<el-image
preview-teleported
v-if="column.type == 7"
style="width: 60px; height: 60px; margin-left: 10px"
:initial-index="index"
:z-index="100"
v-for="(item, index) in scope.row[column.prop].split(',')"
:src="item"
:preview-src-list="scope.row[column.prop].split(',')"
/>
</template>
</el-table-column>
<template #header>
<div style="display: inline-block">
<div class="tilbox">
<el-text class="mx-1 tabtitles" @click.stop @dblclick.stop="copyalls(column)">{{
column.label
}}</el-text>
</div>
</div>
</template>
</el-table-column>
</el-table>
</div>
</template>
<script lang="ts" setup>
import { computed, ref, watchEffect, getCurrentInstance, onMounted, defineExpose } from 'vue';
import type { PropType } from 'vue';
const { proxy } = getCurrentInstance() as any;
const selecttable = ref(null);
/**
* 对应通知事件
* inputTxt:输入框输入的确认事件
* timeCheck:时间选择器选择事件
* selectCheck:下拉框选中事件
* selection:勾选框事件
*/
onMounted(() => {
function getWinHight() {
var windowHight = 0;
if (document.body.clientHeight && document.documentElement.clientHeight) {
windowHight =
document.body.clientHeight < document.documentElement.clientHeight
? document.body.clientHeight
: document.documentElement.clientHeight;
} else {
// windowHight=(document.body.clientHeight>document.documentElement.clientHeight)?document.body.clientHeight:document.documentElement.clientHeight;
}
// return windowHight;
return document.documentElement.clientHeight;
}
var bodyContent = document.querySelectorAll('.maboxhi');
const _height = getWinHight();
console.log('bodyContent :>> ', bodyContent);
//
bodyContent.forEach(val => {
val.style.height = _height - val.getBoundingClientRect().top - 65 + 'px';
});
});
interface TableColumnType {
/** 表格列的key */
prop: string;
/** 表格列的名字 */
label: string;
/**
* 对应列表头的类型
* 0:直接显示为单选proplabel全部传空
* 1:普通表格正常显示
* 2:带输入框表格
* 3:带下拉框表格
* 4:带日期选择器列
* 5:带日期时间选择器
* 6:操作栏proplabel全部传空
* 7:图片
* 8:带背景的文字
* 9:下载附件
* 10.输入框的表格内容
* 11.开关类型
*/
type: number | string;
/** 用于接受表头的值 */
values: number | string;
/** 表头宽度 number string undefined */
width: number | string | undefined;
/** 下拉框可选项 */
checkarr?: {
value: string | number;
label: string | number;
}[];
/**
* true false
* left right
*/
fixed: boolean | string;
/**
* true false 或者直接不写该参数
*/
isshowSummary?: boolean;
/**
* true false 或者直接不写该参数
*/
sortable?: boolean;
/**
* true false 或者直接不写该参数
*/
head?: boolean;
/**
* 默认超出隐藏
* true是不隐藏
* false 隐藏
*/
isextrahide?: boolean;
/** urlkey
*/
downprop?: string;
/**
*/
lessThanNum?: string;
}
interface TableDataType {
[key: string]: any;
}
let props = defineProps({
columnList: {
type: Array as PropType<TableColumnType[]>,
required: true,
},
tableData: {
type: Array as PropType<TableDataType[]>,
required: true,
},
loading: {
type: Boolean as PropType<boolean>,
required: true,
},
//
checkselect: {
type: Array as PropType<TableDataType[]>,
required: false,
},
//
isselectfun: {
type: Function as PropType<(row: TableDataType) => boolean>,
required: false,
default: null,
},
});
let selectarr = ref([]);
const tableRowClassName = ({ row, rowIndex }: { row: TableDataType; rowIndex: number }) => {
let sfcheck = false;
selectarr.value.map(item => {
if (item == row) {
sfcheck = true;
}
});
if (sfcheck) {
return 'table-SelectedRow-bgcolor';
}
return '';
};
let emit = defineEmits(['inputTxt', 'timeCheck', 'selectCheck', 'selection', 'makeCargo']);
let newcolumnList = ref<TableColumnType[]>([]);
watchEffect(() => {
newcolumnList.value = [];
props.columnList.map(item => {
if (!item.head) {
newcolumnList.value.push(item);
}
});
});
onMounted(() => {
if (props.checkselect) {
props.checkselect.map(item => {
if (props.isselectfun) {
if (props.isselectfun(item)) {
selecttable.value.toggleRowSelection(item, true);
}
} else {
selecttable.value.toggleRowSelection(item, true);
}
});
}
});
function godowns(url) {
let a = document.createElement('a'); //a
a.href = url; //myurl
// a.target = '_blank';
a.download = 'xixi.zip'; //
document.body.appendChild(a); //DOM
a.click();
window.URL.revokeObjectURL(url); // url
document.body.removeChild(a);
}
let shownm = ref(false);
function copyalls(column: TableColumnType) {
const _isReturn = column.type == 1 || column.type == 2 || column.type == 3;
if (!_isReturn) return;
let text = '';
props.tableData.map((item, index) => {
if (index < props.tableData.length - 1) {
if (item[column.prop]) {
text += `${item[column.prop]}\n`;
}
} else {
if (item[column.prop]) {
text += `${item[column.prop]}`;
} else {
}
}
});
copyContent(text);
}
function handleNumberRange(column: TableColumnType, row: TableDataType) {
row[column.prop] = row[column.prop].replace(/[^\.\d]/g, ''); //
if (row[column.prop]) {
//
row[column.prop] = parseInt(row[column.prop]); //
}
// if (column.lessThanNum) {
// if (row[column.prop] > row[column.lessThanNum]) {
// row[column.prop] = row[column.lessThanNum];
// proxy.$message({
// type: 'error',
// message: '',
// });
// }
// }
//
if (row.residueNumber) {
if (row.enterNum > row.residueNumber) {
proxy.$message({
type: 'error',
message: '数量不能大于可上架总数,已调整为最大数量!',
});
row.enterNum = row.residueNumber;
}
}
//
if (row.num) {
if (row.enterNum > row.num) {
proxy.$message({
type: 'error',
message: '数量不能大于可下架总数,已调整为最大数量!',
});
row.enterNum = row.num;
}
}
console.log(row, 'row');
}
function handleEdit(index: number, row: TableDataType) {
console.log(index, row);
}
function makeCargo(value, column: TableColumnType) {
emit('makeCargo', value, column);
}
function inputchange(value, column: TableColumnType) {
if (typeof value == 'string') {
console.log(value, column);
emit('inputTxt', value, column);
}
}
function selectchange(value, column: TableColumnType) {
console.log(value, column);
emit('selectCheck', value, column);
}
function timechange(value, column: TableColumnType) {
console.log(value, column);
emit('timeCheck', value, column);
}
const handleSelectionChange = (param: TableDataType[]) => {
// console.log(param)
selectarr.value = param;
emit('selection', param);
};
function inputclear(value, column: TableColumnType) {
console.log('', column);
emit('inputTxt', '', column);
}
function selectclear(value, column: TableColumnType) {
console.log('', column);
emit('selectCheck', '', column);
}
function timeclear(value, column: TableColumnType) {
console.log('', column);
emit('timeCheck', '', column);
}
function handleDelete(index: number, row: TableDataType) {
console.log(index, row);
}
const getSummaries = (param: any) => {
const { columns, data } = param;
let newarr = [];
let tji = 0;
console.log(columns, data);
columns.map((item, index) => {
if (index == 0) {
newarr[index] = '总计';
return;
}
tji = 0;
if (props.columnList[index]?.isshowSummary) {
data.map(ite => {
tji += Number(ite[props.columnList[index]?.prop] || 0);
});
newarr[index] = tji;
// shownm.value=true
} else {
newarr[index] = null;
}
});
// console.log(columns)
console.log(newarr);
return newarr;
};
watchEffect(() => {
props.columnList.map(item => {
if (item.isshowSummary) {
shownm.value = true;
}
});
});
//
function copyContent(content: string) {
//
let copyResult = true;
//
const text = content || '让我们一起快乐的敲代码吧~';
// clipboard
if (!!window.navigator.clipboard) {
// clipboardpromise
window.navigator.clipboard
.writeText(text)
.then(res => {
proxy.$message({
type: 'success',
message: '复制成功',
});
//
return copyResult;
})
.catch(err => {
copyResult = false;
console.log('复制失败', err);
proxy.$message({
type: 'error',
message: '复制失败',
});
//
return copyResult;
});
} else {
// clipboard document.execCommand()
// input
let inputDom = document.createElement('textarea');
//
inputDom.setAttribute('readonly', 'readonly');
// input
inputDom.value = text;
// inputbody
document.body.appendChild(inputDom);
// input
inputDom.select();
//
// input
// Input
const result = document.execCommand('copy');
//
if (result) {
proxy.$message({
type: 'success',
message: '复制成功',
});
} else {
console.log('复制失败');
proxy.$message({
type: 'error',
message: '复制失败',
});
copyResult = false;
}
//
document.body.removeChild(inputDom);
//
return copyResult;
}
}
defineExpose({});
</script>
<style lang="scss" scoped>
// :root{
// --el-checkbox-checked-bg-color:'#D3832A';
// --el-checkbox-checked-input-border-color:'#D3832A';
// }
.el-table {
//
--el-table-row-hover-bg-color: #d3832a;
}
// .el-table .warning-row {
// --el-table-tr-bg-color: var(--el-color-warning-light-9);
// }
// .el-table .success-row {
// --el-table-tr-bg-color: var(--el-color-success-light-9);
// }
.maboxhi {
width: 100%;
// min-height: 950px;
// height: 841px;
// flex:1;
// min-height: 100%;
}
.on {
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
font-size: 12px !important;
}
.selectbr {
border: none !important;
font-size: 12px !important;
}
.tabtitles {
color: #092c4d !important;
font-size: 12px !important;
margin-right: 5px !important;
}
.el-table .ascending .sort-caret.ascending {
border-bottom-color: #d3832a !important;
font-size: 12px !important;
}
.el-table .descending .sort-caret.descending {
border-top-color: #d3832a !important;
font-size: 12px !important;
}
.tabculconte {
color: #333333 !important;
font-size: 12px !important;
}
.slotbuts {
height: 25px;
display: flex;
align-items: center;
justify-content: center;
font-size: 12px !important;
}
.slotbuts .el-text {
color: #d3832a !important;
margin-right: 10px !important;
cursor: pointer;
font-size: 12px !important;
&:nth-last-child(1) {
margin-right: 0px !important;
}
}
.el-popper.is-pure.is-light.el-dropdown__popper .el-text {
color: #d3832a !important;
margin-right: 10px !important;
cursor: pointer;
font-size: 12px !important;
&:nth-last-child(1) {
margin-right: 0px !important;
}
}
.el-table .el-input__inner {
height: 23px !important;
}
// .el-checkbox__input.is-checked .el-checkbox__inner{
// background-color: #D3832A !important;
// border-color: #D3832A !important;
// }
// .is .el-checkbox__input.is-checked .el-checkbox__inner{
// background-color: #D3832A !important;
// border-color: #D3832A !important;
// }
// .is-checked .el-checkbox__inner:hover{
// border-color: #D3832A !important;
// }
// .el-checkbox__input.is-indeterminate .el-checkbox__inner{
// background-color: #D3832A !important;
// border-color: #D3832A !important;
// }
.el-table .el-table__cell {
padding: 0px !important;
}
.el-checkbox__input.is-checked .el-checkbox__inner,
.el-checkbox__input.is-indeterminate .el-checkbox__inner {
border-color: #d3832a !important;
background-color: #d3832a !important;
}
.el-checkbox__input.is-focus .el-checkbox__inner {
border-color: #d3832a !important;
}
//
.el-checkbox__input.is-checked + .el-checkbox__label {
color: #d3832a !important;
}
.el-checkbox__inner:hover {
border-color: #d3832a !important;
font-size: 12px !important;
}
.table-SelectedRow-bgcolor {
> td {
background-color: #f7e8d7 !important;
}
}
.colors {
color: #409eff !important;
cursor: pointer !important;
}
.el-table .cell {
line-height: 22px !important;
}
.el-table .el-input__inner {
font-size: 12px !important;
}
.el-table__body tr.hover-row.current-row > td,
.el-table__body tr.hover-row.el-table__row--striped.current-row > td,
.el-table__body tr.hover-row.el-table__row--striped > td,
.el-table__body tr.hover-row > td {
background-color: #d3d8e1 !important;
}
.el-date-editor.el-input,
.el-date-editor.el-input__wrapper {
// height: 23px !important;
}
.copys {
display: inline-block;
margin-left: 5px;
padding-top: 5px;
margin-right: 5px;
}
.tilbox {
display: flex;
align-items: center;
}
.el-table .el-popper {
max-width: 20% !important;
}
.el-input {
// width: 200px !important;
}
</style>

44
src/components/tablecmt/tablecmt.vue

@ -24,6 +24,7 @@
:label="column.label"
:fixed="column.fixed"
:sortable="column.sortable"
:show-overflow-tooltip="column.isextrahide === false ? false : true"
:selectable="isselectfun"
v-show="column.head"
>
@ -37,7 +38,7 @@
:prop="column.prop"
:label="column.label"
flexible
show-overflow-tooltip
:show-overflow-tooltip="column.isextrahide === false ? false : true"
class="el_boxsa"
>
<template #header>
@ -112,8 +113,9 @@
"
:id="scope.row[column.prop]"
v-if="Number(column.type) < 6 && Number(column.type) > 0"
>{{ scope.row[column.prop] }}</el-text
>
>{{ scope.row[column.prop] }}
</el-text>
<el-switch
@change="makeCargo(scope.row, column)"
v-else-if="column.type == 11"
@ -127,7 +129,7 @@
>
<span v-if="item.value==scope.row[column.prop]">{{ item.label }}</span>
</el-text
> -->
> -->
<el-text
style=""
class="mx-2 tabculconte colors"
@ -167,7 +169,7 @@
v-for="(item, index) in scope.row[column.prop].split(',')"
:src="item"
:preview-src-list="scope.row[column.prop].split(',')"
/> -->
/> -->
<el-image
preview-teleported
v-else-if="column.type == 7"
@ -181,6 +183,22 @@
</template>
</el-table-column>
</template>
<template v-if="column.type === 30" #default="scope">
<el-text
@click.stop
@dblclick.stop="Copytxt(scope.row[column.prop])"
class="mx-2 tabculconte"
:class="
scope.row[column.prop] == props.searchInput && scope.row[column.prop]
? 'static-class'
: ''
"
:id="scope.row[column.prop]"
>{{ scope.row[column.prop] }}
</el-text>
</template>
<template #header>
<div style="display: inline-block">
<div class="tilbox">
@ -375,6 +393,12 @@ let props = defineProps({
required: false,
default: true,
},
/** 是否保存表头宽度设置 */
isSave: {
type: Boolean as PropType<Boolean>,
required: false,
default: false,
},
});
/** 勾选数据统计 */
const selectCount = ref([]);
@ -736,10 +760,12 @@ const handleWidthChange = (newWidth, oldWidth, column, event) => {
console.log('props.columnListName :>> ', props.columnListName);
// postSaveTableSeting({
// tableKey: $route.path + props.columnListName,
// tableSetCongig: JSON.stringify(props.columnList),
// });
if (props.isSave) return;
postSaveTableSeting({
tableKey: $route.path + props.columnListName,
tableSetCongig: JSON.stringify(props.columnList),
});
};
defineExpose({ handleCheckSelect, handleClearSelect });

86
src/option/aftersales/vueTvemp.js

@ -207,28 +207,29 @@ export const columnList = [
// sortable: true,
// head: false,
// },
// {
// prop: 'a',
// label: '处理结果',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'a',
// label: '处理结果—理赔金额',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'resultTypes',
label: '处理结果',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'totalAmountNum',
label: '处理结果—理赔金额',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
// {
// prop: 'a',
// label: '营业部处理客服',
@ -329,17 +330,7 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'totalAmount',
label: '赔款金额',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'operator',
@ -1846,16 +1837,17 @@ export const columnList2 = [
head: false,
},
{
prop: 'a', //discoveryNode
label: '工单创建仓',
prop: 'ceator',
label: '创建人',
type: 1,
values: '',
width: '140',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'workOrderNumber',
@ -1969,17 +1961,17 @@ export const columnList2 = [
sortable: true,
head: false,
},
{
prop: 'a',
label: '责任方',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'a',
// label: '责任方',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'createTime',
label: '工单创建时间',

36
src/option/basicdata/BackStockTask.js

@ -17,7 +17,7 @@ export default [
{
label: '配送回库任务编号',
prop: 'taskCode',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -27,7 +27,7 @@ export default [
{
label: '回库任务类型',
prop: 'retentionTypeName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -37,7 +37,7 @@ export default [
{
label: '包条码',
prop: 'orderPackageCode',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -47,7 +47,7 @@ export default [
{
label: '订单编号',
prop: 'orderCode',
type: 1,
type: 30,
values: '',
width: '300',
checkarr: [],
@ -57,7 +57,7 @@ export default [
{
label: '运单编号',
prop: 'waybillNumber',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -67,7 +67,7 @@ export default [
{
label: '配送类型',
prop: 'deliveryTypeName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -77,7 +77,7 @@ export default [
{
label: '货物类型',
prop: 'conditionsName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -87,7 +87,7 @@ export default [
{
label: '预约编号',
prop: 'reservationCode',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -97,7 +97,7 @@ export default [
{
label: '配送车次',
prop: 'trainNumber',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -107,7 +107,7 @@ export default [
{
label: '装车车牌',
prop: 'vehicleNumber',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -117,7 +117,7 @@ export default [
{
label: '件数',
prop: 'retentionQuantity',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -127,7 +127,7 @@ export default [
{
label: '物料编码',
prop: 'materialNumber',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -137,7 +137,7 @@ export default [
{
label: '物料名称',
prop: 'materialName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -147,7 +147,7 @@ export default [
{
label: '创建时间',
prop: 'createTime',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -157,7 +157,7 @@ export default [
{
label: '仓库名称',
prop: 'warehouseName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -167,7 +167,7 @@ export default [
{
label: '回库任务状态',
prop: 'confirmStatusName',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -177,7 +177,7 @@ export default [
{
label: '回库操作人员',
prop: 'retentionScanUsername',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -187,7 +187,7 @@ export default [
{
label: '回库时间',
prop: 'retentionScanTime',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],

743
src/option/basicdata/basicdataWarehouseTemp.js

@ -1,377 +1,374 @@
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'name',
label: '仓库名称',
type: 1,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseCode',
label: '仓库编码',
type:1,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'abbreviation',
label: '仓库简称',
type: 1,
values: '',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'linkman',
label: '联系人',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'contactNumber',
label: '联系电话',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'legalPerson',
label: '法人',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'legalPersonPhone',
label: '法人联系电话',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deposit',
label: '押金',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'functionType',
label: '职能类型',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseAddress',
label: '仓库地址',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'departmentName',
label: '所属部门',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseType',
label: '仓库类型',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'fireGrade',
label: '消防等级',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'fireRatingNot',
label: '是否有消防等级',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseStructure',
label: '仓库结构',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'elevatedNot',
label: '是否高架',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'storeyHeight',
label: '仓库层高',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'powerCondition',
label: '电力类型',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'unitPrice',
label: '租金单价',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'acreage',
label: '面积',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'startDate',
label: '开始时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'endDate',
label: '到期时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'rentType',
label: '租金类型',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'grade',
label: '仓库等级',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'administrativeFee',
label: '管理费',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'seating',
label: '库位数',
type: 1,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'name',
label: '仓库名称',
type: 30,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseCode',
label: '仓库编码',
type: 1,
values: '',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'abbreviation',
label: '仓库简称',
type: 30,
values: '',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'linkman',
label: '联系人',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'contactNumber',
label: '联系电话',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'legalPerson',
label: '法人',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'legalPersonPhone',
label: '法人联系电话',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'deposit',
label: '押金',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'functionType',
label: '职能类型',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseAddress',
label: '仓库地址',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'departmentName',
label: '所属部门',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseType',
label: '仓库类型',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'fireGrade',
label: '消防等级',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'fireRatingNot',
label: '是否有消防等级',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseStructure',
label: '仓库结构',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'elevatedNot',
label: '是否高架',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'storeyHeight',
label: '仓库层高',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'temporaryTurnoverArea',
label: '临时周转面积(m²)',
type: 1,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'singleStorageLocationArea',
label: '单库位面积(m²)',
type: 1,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'handlingStorageEntranceFee',
label: '代作业入库费(元/件)',
type: 1,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'handlingStorageExitFee',
label: '代作业出库费(元/件)',
type: 1,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'powerCondition',
label: '电力类型',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'unitPrice',
label: '租金单价',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'acreage',
label: '面积',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'startDate',
label: '开始时间',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'endDate',
label: '到期时间',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'remarks',
label: '备注',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createUserName',
label: '操作',
type: 6,
values: '',
width: '180',
checkarr: [],
fixed: 'right',
sortable: false,
},
]
{
prop: 'rentType',
label: '租金类型',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'grade',
label: '仓库等级',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'administrativeFee',
label: '管理费',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'seating',
label: '库位数',
type: 30,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'temporaryTurnoverArea',
label: '临时周转面积(m²)',
type: 30,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'singleStorageLocationArea',
label: '单库位面积(m²)',
type: 30,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'handlingStorageEntranceFee',
label: '代作业入库费(元/件)',
type: 30,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'handlingStorageExitFee',
label: '代作业出库费(元/件)',
type: 30,
values: '',
width: '170',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'remarks',
label: '备注',
type: 30,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createUserName',
label: '操作',
type: 6,
values: '',
width: '180',
checkarr: [],
fixed: 'right',
sortable: false,
},
];

98
src/option/finance/ReconciliationDepositSlip.js

@ -157,7 +157,7 @@ export const columnList = [
label: '品类件数',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -168,7 +168,7 @@ export const columnList = [
label: '品类单价',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -179,7 +179,7 @@ export const columnList = [
label: '总件数',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -191,7 +191,7 @@ export const columnList = [
label: '总重量',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -203,7 +203,7 @@ export const columnList = [
label: '总体积',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -215,7 +215,7 @@ export const columnList = [
label: '订单开单价',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -226,7 +226,7 @@ export const columnList = [
label: '实际费用',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -238,7 +238,7 @@ export const columnList = [
label: '开单运费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -250,7 +250,7 @@ export const columnList = [
label: '实际运费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -262,7 +262,7 @@ export const columnList = [
label: '开单提货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -274,7 +274,7 @@ export const columnList = [
label: '实际提货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -298,7 +298,7 @@ export const columnList = [
label: '仓储费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -310,7 +310,7 @@ export const columnList = [
label: '仓储管理费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -322,7 +322,7 @@ export const columnList = [
label: '仓储分拣费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -334,7 +334,7 @@ export const columnList = [
label: '仓储操作费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -370,7 +370,7 @@ export const columnList = [
label: '实际配送费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -382,7 +382,7 @@ export const columnList = [
label: '配送装卸费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -394,7 +394,7 @@ export const columnList = [
label: '配送分货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -406,7 +406,7 @@ export const columnList = [
label: '配送上楼费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -418,7 +418,7 @@ export const columnList = [
label: '配送平移费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -430,7 +430,7 @@ export const columnList = [
label: '配送其它费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -442,7 +442,7 @@ export const columnList = [
label: '超区公里费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -454,7 +454,7 @@ export const columnList = [
label: '安装费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -466,7 +466,7 @@ export const columnList = [
label: '其他费用',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -815,7 +815,7 @@ export const columnListB = [
label: '品类件数',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -826,7 +826,7 @@ export const columnListB = [
label: '品类单价',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -837,7 +837,7 @@ export const columnListB = [
label: '总件数',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -849,7 +849,7 @@ export const columnListB = [
label: '总重量',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -861,7 +861,7 @@ export const columnListB = [
label: '总体积',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -873,7 +873,7 @@ export const columnListB = [
label: '订单开单价',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -885,7 +885,7 @@ export const columnListB = [
label: '实际费用',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -897,7 +897,7 @@ export const columnListB = [
label: '开单运费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -909,7 +909,7 @@ export const columnListB = [
label: '实际运费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -921,7 +921,7 @@ export const columnListB = [
label: '开单提货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -933,7 +933,7 @@ export const columnListB = [
label: '实际提货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -957,7 +957,7 @@ export const columnListB = [
label: '仓储费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -969,7 +969,7 @@ export const columnListB = [
label: '仓储管理费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -981,7 +981,7 @@ export const columnListB = [
label: '仓储分拣费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -993,7 +993,7 @@ export const columnListB = [
label: '仓储操作费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1017,7 +1017,7 @@ export const columnListB = [
label: '开单配送费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1029,7 +1029,7 @@ export const columnListB = [
label: '实际配送费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1041,7 +1041,7 @@ export const columnListB = [
label: '配送装卸费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1053,7 +1053,7 @@ export const columnListB = [
label: '配送分货费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1065,7 +1065,7 @@ export const columnListB = [
label: '配送上楼费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1077,7 +1077,7 @@ export const columnListB = [
label: '配送平移费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1089,7 +1089,7 @@ export const columnListB = [
label: '配送其它费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1101,7 +1101,7 @@ export const columnListB = [
label: '超区公里费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1113,7 +1113,7 @@ export const columnListB = [
label: '安装费',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
@ -1125,7 +1125,7 @@ export const columnListB = [
label: '其他费用',
type: 1,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: false,
sortable: true,

64
src/option/reportforms/DeliveryDetailsVtwo.js

@ -39,7 +39,7 @@ export const columnList = [
{
prop: 'taskTime',
label: '配送日期',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -51,7 +51,7 @@ export const columnList = [
{
prop: 'warehouseName',
label: '仓库',
type: 2,
type:1,
values: '',
width: '150',
checkarr: [],
@ -62,7 +62,7 @@ export const columnList = [
{
prop: 'brand',
label: '品牌',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -74,7 +74,7 @@ export const columnList = [
{
prop: 'type',
label: '配送类型',
type: 3,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -85,7 +85,7 @@ export const columnList = [
{
prop: 'kind',
label: '配送种类',
type: 3,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -96,7 +96,7 @@ export const columnList = [
{
prop: 'vehicleName',
label: '配送车辆',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -107,7 +107,7 @@ export const columnList = [
{
prop: 'driverName',
label: '配送司机',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -118,7 +118,7 @@ export const columnList = [
{
prop: 'distributionCompany',
label: '配送公司',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -129,7 +129,7 @@ export const columnList = [
{
prop: 'drConsignee',
label: '客户名称',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -140,7 +140,7 @@ export const columnList = [
{
prop: 'deliveryPhone',
label: '客户电话',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -151,7 +151,7 @@ export const columnList = [
{
prop: 'deliveryAddress',
label: '地址',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -162,7 +162,7 @@ export const columnList = [
{
prop: 'consignee',
label: '运单收货单位',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -173,7 +173,7 @@ export const columnList = [
{
prop: 'consigneeName',
label: '运单收货人',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -184,7 +184,7 @@ export const columnList = [
{
prop: 'consigneeMobile',
label: '运单收货电话',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -195,7 +195,7 @@ export const columnList = [
{
prop: 'waybillNo',
label: '运单号',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -228,7 +228,7 @@ export const columnList = [
{
prop: 'customerTrain',
label: '客户车次号',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -250,7 +250,7 @@ export const columnList = [
{
prop: 'firsts',
label: '一级品',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -261,7 +261,7 @@ export const columnList = [
{
prop: 'decond',
label: '二级品',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -272,7 +272,7 @@ export const columnList = [
{
prop: 'thirdProduct',
label: '三级品',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -283,7 +283,7 @@ export const columnList = [
{
prop: 'materialCode',
label: '物料编码',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -294,7 +294,7 @@ export const columnList = [
{
prop: 'materialName',
label: '物料名称',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -305,7 +305,7 @@ export const columnList = [
{
prop: 'startWar',
label: '始发仓',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -316,7 +316,7 @@ export const columnList = [
{
prop: 'startWarInTime',
label: '始发仓入库日期',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -327,7 +327,7 @@ export const columnList = [
{
prop: 'startWarOutTime',
label: '始发仓发货日期',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -338,7 +338,7 @@ export const columnList = [
{
prop: 'warehouseEntryTimeEnd',
label: '入库时间',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -361,7 +361,7 @@ export const columnList = [
{
prop: 'unloadTime',
label: '装车时间',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -372,7 +372,7 @@ export const columnList = [
{
prop: 'unAdministratorsName',
label: '装车人',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -383,7 +383,7 @@ export const columnList = [
{
prop: 'driverSigning',
label: '司机签收状态',
type: 3,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -394,7 +394,7 @@ export const columnList = [
{
prop: 'sjsigningTime',
label: '签收时间',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -405,7 +405,7 @@ export const columnList = [
{
prop: 'ldsSigneeName',
label: '签收人',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -450,7 +450,7 @@ export const columnList = [
{
prop: 'signingTime',
label: '文员审核时间',
type: 4,
type: 1,
values: '',
width: '150',
checkarr: [],
@ -461,7 +461,7 @@ export const columnList = [
{
prop: 'examineUserName',
label: '审核人名称',
type: 2,
type: 1,
values: '',
width: '150',
checkarr: [],

4
src/router/views/index.js

@ -1483,7 +1483,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive: false,
keepAlive: true,
},
path: '/aftersales/aftersalesWorkOrderInfo',
name: '工单详情查看',
@ -1550,7 +1550,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive: false,
keepAlive: true,
},
path: '/aftersales/aftersalesWorkOrderend',
name: '工单完结',

7
src/utils/util.js

@ -665,7 +665,7 @@ export const isNumber = value => {
* 向下保留小数位
* @param {*} num -- 被截取数
* @param {*} decimalPlaces -- 保留小数位
* @returns
* @returns
*/
export function floorToDecimalPlaces(num, decimalPlaces) {
const factor = Math.pow(10, decimalPlaces);
@ -812,9 +812,10 @@ export function handleTranslationDataSeclect(data, columnList, fn = (value, item
* @param {object} col 每列的配置
* @param {object} query 存储查询条件的对象
* @param {Boolean} isRegExp 是否将输入的值转换为正则表达式
* @param {Boolean} isStart 正则是否从头开始匹配
* @returns
*/
export const handleInputQuery = (value, col, query, isRegExp = false) => {
export const handleInputQuery = (value, col, query, isRegExp = false, isStart = true) => {
if (getObjType(query) !== 'object') return;
if (getObjType(col) !== 'object') return;
if (!value && value !== 0) {
@ -822,7 +823,7 @@ export const handleInputQuery = (value, col, query, isRegExp = false) => {
return;
}
const _value = isRegExp ? new RegExp('^' + value) : value;
const _value = isRegExp ? new RegExp(isStart ? '^' : '' + value) : value;
query[col.prop] = _value;
};

6890
src/views/aftersales/aftersalesWorkOrder.vue

File diff suppressed because it is too large Load Diff

4
src/views/aftersales/aftersalesWorkOrderAdd.vue

@ -1135,7 +1135,7 @@ const Responsemoval = index => {
};
const calculateMaxValues = () => {
return
return;
//
let data = form.value.responsibilitiesList;
let totalUsed = data.reduce((acc, item) => acc + item.responsibilityRatio, 0);
@ -1749,7 +1749,7 @@ const onSubmit = () => {
$useStore.commit('EDIT_REFRESHITEM', {
title: 'aftersalesWorkOrder',
status: true,
});
}); //
$useStore.commit('Customer_Menu', 0); //
$useStore.commit('DEL_TAG_CURRENT'); //
$router.push({

61
src/views/aftersales/aftersalesWorkOrderInfo.vue

@ -3,8 +3,8 @@
<el-card class="box-card el_last">
<div>
<el-tabs type="border-card" class="topClass" v-model="identifying">
<el-tab-pane label="订单信息" :name="1"></el-tab-pane>
<el-tab-pane label="零担信息" :name="2"></el-tab-pane>
<el-tab-pane label="订单信息" :name="1" :disabled="identifying == 2"></el-tab-pane>
<el-tab-pane label="零担信息" :name="2" :disabled="identifying == 1"></el-tab-pane>
</el-tabs>
<el-form :model="Indexform" class="IndexFrom" ref="IndexForm" disabled>
@ -42,11 +42,7 @@
/>
</el-form-item>
<el-form-item label="创建时间" class="el_inputTop el_Workordernumber">
<el-input
v-model="Indexform.createTime"
disabled
clearable
/>
<el-input v-model="Indexform.createTime" disabled clearable />
</el-form-item>
</div>
<el-tabs type="border-card" class="PackageInformation">
@ -67,6 +63,7 @@
placement="top"
>
<el-input
v-if="identifying == 1"
v-model="item.packageCode"
placeholder="请输入包条码"
clearable
@ -314,7 +311,7 @@
<el-input v-else v-model="item.personResponsibleName" placeholder="责任人" />
</el-form-item>
<el-form-item label="责任占比" class="title">
<el-form-item label="金额(元)" class="title">
<el-input :controls="false" v-model="item.responsibilityRatio" />
</el-form-item>
@ -334,9 +331,9 @@
</el-form-item>
</div>
</template>
<div class="Proportion">
<!-- <div class="Proportion">
<span class="title">公司占比:{{ companyProportion }}%</span>
</div>
</div> -->
</div>
</el-tab-pane>
</el-tabs>
@ -805,12 +802,16 @@
</template>
</el-dialog>
</template>
<script>
export default {
name: '/aftersales/aftersalesWorkOrderInfo',
};
</script>
<script setup>
import { ElMessage, ElMessageBox } from 'element-plus';
import { useRouter, useRoute } from 'vue-router';
import { useStore } from 'vuex';
const $useStore = useStore();
import { getDictionaryBiz } from '@/api/system/dict'; //
import { getDeptWarehouse } from '@/api/basicdata/basicdataWarehouse'; //
import {
@ -827,6 +828,7 @@ import { ref, reactive, computed, onMounted } from 'vue';
import { getToken } from '@/utils/auth';
import { compressImageBlob } from '@/components/IMGcompressor/imgcompressor.js';
import { AddressClosed, deepClone } from '@/utils/util';
const $useStore = useStore();
const $router = useRouter();
const $route = useRoute();
const Indexform = ref({
@ -834,7 +836,7 @@ const Indexform = ref({
decreaseImageEntityList: [], //
discoveryNode: '1',
}); //
const pageState = ref(true); //
const pageState = ref(false); //
const ProcessingResults = ref([]); //
const IndexException = ref([]); //
const ZFname = ref(''); //
@ -875,6 +877,7 @@ const UserPermissions = ref(); //当前登录人角色身份
// ======
const MessageContent = ref([]); //
const scrollContainer = ref(null); //
const QueryId = ref(null);
const msgHight = ref(100); //
const msgTop = ref(0); //
const msgState = ref(0);
@ -1250,6 +1253,7 @@ const onLoad = async () => {
PackageInfo.value = res.data.data.abnormalPackageVOList;
console.log(res.data.data.abnormalPackageVOList, '包件信息');
NumberPackages.value = res.data.data.abnormalPackageVOList.length; //
PackageInfo.value[0].packageCode ? (identifying.value = 1) : (identifying.value = 2);
//
FangAddList.value = res.data.data.processorVOList
@ -1264,14 +1268,14 @@ const onLoad = async () => {
groundlineType.value = res.data.data.discoveryNode; //
if (res.data.data.personResponsibleVOS?.length) {
res.data.data.personResponsibleVOS.forEach(item => {
sum = Number(item.responsibilityRatio) + sum;
});
// res.data.data.personResponsibleVOS.forEach(item => {
// sum = Number(item.responsibilityRatio) + sum;
// });
FangAddList.value = res.data.data.personResponsibleVOS.map(res => {
return {
businessName: res.businessId, //ID
personResponsibleName: res.personResponsibleName, //
responsibilityRatio: res.responsibilityRatio + '%', //
responsibilityRatio: res.responsibilityRatio, //
description: res.description, //
tripartite: res.tripartite, //
};
@ -1386,8 +1390,20 @@ const onLoad = async () => {
Paymentmethod.value = res.data.data;
});
};
onLoad(); //
onMounted(() => {
watch(
() => $route.path, //
(newParams, oldParams) => {
console.log($route, '路由参数');
if (newParams == oldParams) {
onLoad();
}
},
{ deep: true, immediate: true } //
);
});
onLoad();
let isAppeal = appeal.value;
let userRole = UserPermissions.value; //
let routeIndex = $route.query.RouteIndexs; //
@ -1421,7 +1437,7 @@ const isWorkOrderCompletion = () => {
//
const isRepulse = () => {
if (UserPermissions.value == '总部客服经理') {
if (workOrderStatus == '40') {
if (['40', '80'].includes($route.query.workOrderStatus)) {
return true;
}
}
@ -1461,7 +1477,7 @@ const isInformationEditing = () => {
//
const isProcessingConfirmation = () => {
if (UserPermissions.value != '仓库客服') {
if (workOrderStatus == '40') {
if (['40'].includes(workOrderStatus)) {
return true;
}
}
@ -1560,6 +1576,7 @@ const beforeAvatarUpload = async rawFile => {
//
//
const addireply = () => {
$useStore.commit('DEL_ONCE_TAG', '/aftersales/aftersalesWorkOrderend');
$router.push({
path: '/aftersales/aftersalesWorkOrderend',
query: {
@ -2593,12 +2610,12 @@ const ResultDetermination = () => {
}
.img {
width: 100%;
height:20%;
height: 20%;
overflow: scroll;
.el-image{
.el-image {
width: 20%;
height: 100%;
margin: 4px;
}
img {

6759
src/views/aftersales/aftersalesWorkOrderTemp.vue

File diff suppressed because it is too large Load Diff

731
src/views/aftersales/aftersalesWorkOrderend.vue

@ -3,8 +3,8 @@
<div class="contemtMax">
<div class="left">
<el-tabs type="border-card" class="topClass" v-model="identifying">
<el-tab-pane label="订单信息" :name="1"></el-tab-pane>
<el-tab-pane label="零担信息" :name="2"></el-tab-pane>
<el-tab-pane label="订单信息" :name="1" :disabled="identifying == 2"></el-tab-pane>
<el-tab-pane label="零担信息" :name="2" :disabled="identifying == 1"></el-tab-pane>
</el-tabs>
<el-form :model="endFrom" :rules="ruleForm" ref="ruleFormRef">
@ -39,13 +39,16 @@
clearable
/>
</el-form-item>
<el-form-item label="创建时间" class="el_inputTop el_Workordernumber">
<el-input v-model="endFrom.createTime" disabled clearable />
</el-form-item>
</div>
<el-tabs type="border-card" class="PackageInformation">
<el-tab-pane label="包件信息">
<div class="ResponsibilityBoxS">
<div class="el_btbox" v-for="(item, index) in PackageInfo" :key="index">
<div class="leftbox">
<el-form-item label="包条码">
<el-form-item label="包条码" v-if="identifying == 1">
<el-tooltip :content="item.packageCode" placement="top">
<el-input v-model="item.packageCode" disabled />
</el-tooltip>
@ -290,7 +293,7 @@
</el-select>
</div>
<div class="maxBox">
<span class="title">责任占比:</span>
<span class="title">金额</span>
<el-input
v-model="item.responsibilityRatio"
placeholder="请输入占比 "
@ -316,9 +319,9 @@
</div>
</div>
</div>
<div class="Proportion">
<!-- <div class="Proportion">
<span class="title">公司占比:{{ companyProportion }}%</span>
</div>
</div> -->
</div>
</el-tab-pane>
</el-tabs>
@ -425,139 +428,152 @@
</el-tabs>
</div>
</div>
<el-form :disabled="PermissionButton.Completed_presentation">
<el-tabs
type="border-card"
class="demo-tabs el-endtabs"
v-if="PermissionButton.Completed_submission"
>
<el-tab-pane>
<template #label>
<span class="custom-tabs-label">
<el-icon><calendar /></el-icon>
<span>完结信息</span>
</span>
</template>
<el-tabs type="border-card" class="demo-tabs el-endtabs" v-if="routerState == 'end'">
<el-tab-pane>
<template #label>
<span class="custom-tabs-label">
<el-icon><calendar /></el-icon>
<span>完结信息</span>
</span>
</template>
<div class="el-ckbtn">
<div class="Compensationamount">
<el-button type="primary" @click="AddCompensation">添加赔款方</el-button>
<span>{{ CompensationNum }}</span>
</div>
<div class="Compensationamount">
<el-button type="primary" @click="AddPayee">添加受款方</el-button>
<span>{{ PayeeNum }}</span>
<div class="el-ckbtn" v-if="!PermissionButton.Completed_presentation">
<div class="Compensationamount">
<el-button type="primary" @click="AddCompensation">添加赔款方</el-button>
<span>{{ CompensationNum }}</span>
</div>
<div class="Compensationamount">
<el-button type="primary" @click="AddPayee">添加受款方</el-button>
<span>{{ PayeeNum }}</span>
</div>
</div>
</div>
<div class="payanindemnity" v-for="(item, index) in CompensationParty" :key="index">
<div style="display: flex">
<el-form-item
:class="{
payanindemnity_title: item.state == 0,
payanindemnity_titlecheck: item.warehouseIdcheck,
}"
:label="item.state == 0 ? '赔款方' : '受款方'"
>
<el-select
style="width: 200px"
v-model="item.warehouseId"
filterable
placeholder="请选择仓库"
@change="warehouseChange(item, index)"
<div
class="payanindemnity"
v-for="(item, index) in CompensationParty"
:key="index"
>
<div style="display: flex">
<el-form-item
:class="{
payanindemnity_title: item.state == 0,
payanindemnity_titlecheck: item.warehouseIdcheck,
}"
:label="item.state == 0 ? '赔款方' : '受款方'"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-select
style="width: 200px"
v-model="item.warehouseId"
filterable
placeholder="请选择仓库"
@change="warehouseChange(item, index)"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="责任人" v-if="item.state == 0">
<el-input
v-model="item.compensationPersonnel"
placeholder="请填写责任人"
:rows="2"
/>
</el-form-item>
<el-form-item label="责任人" v-if="item.state == 0">
<el-input
v-model="item.compensationPersonnel"
placeholder="请填写责任人"
:rows="2"
/>
</el-form-item>
<el-form-item
label="原 . 因"
:class="{
payanindemnity_reason: item.state == 0,
payanindemnity_reasoncheck: item.reasoncheck,
}"
>
<el-input
v-model="item.reason"
placeholder="请填写原因"
@blur="reasonChange(item, index)"
/>
</el-form-item>
<el-form-item
label="原 . 因"
:class="{
payanindemnity_reason: item.state == 0,
payanindemnity_reasoncheck: item.reasoncheck,
}"
>
<el-input
v-model="item.reason"
placeholder="请填写原因"
@blur="reasonChange(item, index)"
/>
</el-form-item>
<el-form-item label="金额(元)">
<el-input-number
v-model="item.num"
:min="0"
:controls="false"
:value-on-clear="0"
:precision="2"
@change="amountMoney"
/>
</el-form-item>
</div>
<div style="display: flex">
<div class="el_cwBtn">
<!-- <el-button
<el-form-item label="金额(元)">
<el-input-number
v-model="item.num"
:min="0"
:controls="false"
:value-on-clear="0"
:precision="2"
@change="amountMoney"
/>
</el-form-item>
</div>
<div style="display: flex">
<div class="el_cwBtn">
<!-- <el-button
type="primary"
v-if="item.state == 0 && UserPermissions != '职能客服' && item.accounting!='1'"
@click="accountingBtn(item)"
>
财务处理
</el-button> -->
<el-button type="primary" v-if="item.button" @click="payremove(item, index)">
移除
</el-button>
<el-button
type="primary"
v-if="item.button && !PermissionButton.Completed_presentation"
@click="payremove(item, index)"
>
移除
</el-button>
</div>
</div>
</div>
</div>
<div class="paySum">
<span>
<el-icon><Coin /></el-icon>:<b>{{
TotalamountCompensation
}}</b></span
>
<span>
<el-icon><Coin /></el-icon>:<b>{{ TotalamountReceived }}</b></span
>
</div>
</el-tab-pane>
</el-tabs>
<!-- 仲裁原因说明 -->
<div class="arbitrate" v-if="routerState == 'end'">
<el-tabs
type="border-card"
:class="{
Reason_arbitration_tip: ReasonarbClass,
'demo-tabs Reason_arbitration': true,
}"
>
<el-tab-pane>
<template #label>
<span class="custom-tabs-label">
<el-icon><calendar /></el-icon>
<span>仲裁原因</span>
</span>
</template>
<el-input
v-model="endFrom.arbitrate"
type="textarea"
:autosize="{ minRows: 5, maxRows: 4 }"
placeholder="请输入仲裁原因"
/>
<div class="paySum">
<span>
<el-icon><Coin /></el-icon>:<b>{{
TotalamountCompensation
}}</b></span
>
<span>
<el-icon><Coin /></el-icon>:<b>{{ TotalamountReceived }}</b></span
>
</div>
</el-tab-pane>
</el-tabs>
</div>
<!-- 仲裁原因说明 -->
<div class="arbitrate" v-if="PermissionButton.Completed_submission">
<el-tabs
type="border-card"
:class="{
Reason_arbitration_tip: ReasonarbClass,
'demo-tabs Reason_arbitration': true,
}"
>
<el-tab-pane>
<template #label>
<span class="custom-tabs-label">
<el-icon><calendar /></el-icon>
<span>仲裁原因</span>
</span>
</template>
<el-input
v-model="endFrom.arbitrate"
type="textarea"
:autosize="{ minRows: 5, maxRows: 4 }"
placeholder="请输入仲裁原因"
/>
</el-tab-pane>
</el-tabs>
</div>
</el-form>
<!-- 图片 -->
<el-tabs
class="Transport_damage_photos"
@ -606,7 +622,14 @@
<div class="el_sub">
<el-button
v-if="PermissionButton.Completed_submission"
v-if="PermissionButton.Headquarters_completion"
type="primary"
class="button"
@click="resultreturnedFun"
>结果驳回</el-button
>
<el-button
v-if="PermissionButton.Headquarters_completion"
type="primary"
class="button"
@click="submitCompletion"
@ -632,7 +655,7 @@
type="primary"
class="button"
@click="submitresults(3)"
>处理结果修改提交</el-button
>处理结果提交</el-button
>
<el-button
v-if="PermissionButton.Processing_result_modification"
@ -662,6 +685,27 @@
@click="CustomerServiceCompleted"
>客服仲裁完结</el-button
>
<el-button type="primary" v-if="PermissionButton.repulse" @click="BatchReturn"
>完结打回</el-button
>
<el-button
type="primary"
v-if="PermissionButton.Processing_confirmation"
@click="ResultConfirmation"
>完结审核确认</el-button
>
<el-button
type="primary"
v-if="PermissionButton.Appeal_establishment_button"
@click="AppealEstablished"
>申诉成立</el-button
>
<el-button
type="primary"
v-if="PermissionButton.Appeal_rejection_button"
@click="AppealRejection"
>申诉驳回</el-button
>
<!-- <el-button
v-if="$route.query.RouteIndexs == '0' && $route.query.workOrderStatus != '21'"
type="primary"
@ -807,7 +851,7 @@
:action="doubledCount"
:headers="headers"
:on-success="fellSuccess"
:limit="3"
:limit="4"
multiple
>
<template #trigger>
@ -834,9 +878,9 @@
/>
</el-select> -->
</div>
<el-button type="primary" class="el_next" @click="NextRecord()">
<!-- <el-button type="primary" class="el_next" @click="NextRecord()">
下一条
</el-button>
</el-button> -->
</div>
<el-input
@ -899,8 +943,51 @@
</span>
</template>
</el-dialog>
<!-- 结果打回弹窗 -->
<el-dialog v-model="dialogReturn" title="结果驳回" width="40%" draggable class="plAllret">
<el-form
v-loading="repulse"
element-loading-text="正在打回中..."
label-position="top"
label-width="100px"
:model="BatchFrom"
>
<el-form-item label="打回原因">
<el-input v-model="BatchFrom.txt" type="textarea" :rows="4" />
</el-form-item>
<el-form-item label="流转营业部">
<el-select
v-model="BatchFrom.businessDepartment"
multiple
filterable
default-first-option
:reserve-keyword="false"
placeholder="请选择活动区域"
>
<el-option
v-for="item in warehouseData"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<span class="dialog-footer">
<el-button @click="dialogReturn = false">取消</el-button>
<el-button type="primary" @click="ConfirmReturn" :disabled="repulse"> 确定 </el-button>
</span>
</template>
</el-dialog>
</el-card>
</template>
<script>
export default {
name: '/aftersales/aftersalesWorkOrderend',
};
</script>
<script setup>
import { ElMessage } from 'element-plus';
@ -919,10 +1006,13 @@ import {
$_getTrackRecord,
$_accounting,
$_getList,
$_batchReturn,
$_getProcessor,
$_updateWorkOrderStatus,
$_updateManagerConfirmed,
$_updateProcessingParty,
$_batchRepulseCompleted,
$_Cancelappeal,
} from '@/api/aftersales/aftersalesWorkOrder';
import { columnList, recordList } from '@/option/aftersales/vueTvemp.js';
import { getToken } from '@/utils/auth';
@ -936,7 +1026,9 @@ const $useStore = useStore();
const identifying = ref(1); //
const ZFdialog = ref(false); //
const $route = useRoute();
const $router = useRouter();
const Paymentmethod = ref([]); //
const ZFname = ref(''); //
const routeData = ref(false); //
@ -975,6 +1067,9 @@ const IndexException = ref([]); //异常类型
const Pageloading = ref(false); //load
const TotalClaimAmount = ref(0); //
const TotalamountReceived = ref(0); //
const dialogReturn = ref(false);
const repulse = ref(false);
const BatchFrom = ref({});
const userInfo = ref({}); //
const ruleForm = reactive({
reason: [{ required: true, message: '请填写原因', trigger: ['blur', 'change'] }],
@ -1053,7 +1148,7 @@ const FangAddList = ref([
{
businessName: '',
personResponsibleName: '',
responsibilityRatio: '' + '%',
responsibilityRatio: '',
description: '',
tripartite: '',
},
@ -1143,10 +1238,6 @@ const details = reactive({
},
});
const TransportChange = val => {
console.log(val, '运损触发事件');
};
const warehouseIdState = ref(false); //
//
async function updateDictionary(targetArray, dictionaryType) {
@ -1161,13 +1252,24 @@ async function updateDictionary(targetArray, dictionaryType) {
});
}
//
//
const Completedsubmission = () => {
if (UserPermissions.value == '仓库客服' && endFrom.value.arbitrate) {
return true;
}
if (UserPermissions.value != '仓库客服') {
if ($route.query.workOrderStatus == '30') {
return true;
return true;
}
return false;
};
const CompletedPresentation = () => {
if (UserPermissions.value != '仓库客服') {
if (['30'].includes($route.query.workOrderStatus)) {
return false;
}
}
return true;
};
//
const Submissionresults = () => {
@ -1212,16 +1314,66 @@ const isInformationEditing = () => {
}
return false;
};
//
const isRepulse = () => {
if (UserPermissions.value == '总部客服经理') {
if (['40', '80'].includes($route.query.workOrderStatus)) {
return true;
}
}
return false;
};
//
const isProcessingConfirmation = () => {
if (UserPermissions.value != '仓库客服') {
if (['40'].includes($route.query.workOrderStatus)) {
return true;
}
}
return false;
};
//
const Headquarterscompletion = () => {
if (UserPermissions.value != '仓库客服') {
if (['30'].includes($route.query.workOrderStatus)) {
return true;
}
}
return false;
};
//
const AppealRejectionButton = () => {
if (UserPermissions.value == '总部客服经理') {
if ($route.query.typesOf == '0') {
return true;
}
}
return false;
};
//
const AppealEstablishmentButton = () => {
if (UserPermissions.value == '总部客服经理') {
if ($route.query.typesOf == '0') {
return true;
}
}
return false;
};
//
const PermissionButton = computed(() => ({
Completed_submission: Completedsubmission(), //
Headquarters_completion: Headquarterscompletion(),
Completed_submission: Completedsubmission(), //
Completed_presentation: CompletedPresentation(), ///
Submission_results: Submissionresults(), //
Save_results: Saveresults(), //
Arbitration_completed: Arbitrationcompleted(), //
Processing_result_modification: Processingresultmodification(), //
Processing_result_disabled: Processingresultdisabled(), //
information_editing: isInformationEditing(), //
repulse: isRepulse(), //
Processing_confirmation: isProcessingConfirmation(), //
Appeal_rejection_button: AppealRejectionButton(), //
Appeal_establishment_button: AppealEstablishmentButton(), //
}));
//
@ -1272,6 +1424,8 @@ const onLoad = async () => {
} else {
warehouseIdState.value = false;
}
//
identifying.value = res.data.data.identifying;
//
if (res.data.data.discoveryNode == '1') {
groundlineType.value = '1';
@ -1287,6 +1441,9 @@ const onLoad = async () => {
});
//
PackageInfo.value = res.data.data.abnormalPackageVOList;
console.log(PackageInfo.value, ' PackageInfo.value');
PackageInfo.value[0].packageCode ? (identifying.value = 1) : (identifying.value = 2);
//
//
FangAddList.value = res.data.data.processorVOList
@ -1352,17 +1509,19 @@ const onLoad = async () => {
//
let sum = 0;
if (FangAddList.value.length) {
FangAddList.value.forEach(item => {
if (item.responsibilityRatio) {
item.responsibilityRatio = item.responsibilityRatio.replace(/%/g, '');
sum = Number(item.responsibilityRatio) + sum;
}
});
FangAddList.value.forEach(item => {
item.responsibilityRatio =item.responsibilityRatio? item.responsibilityRatio + '%':item.responsibilityRatio;
});
// FangAddList.value.forEach(item => {
// if (item.responsibilityRatio) {
// item.responsibilityRatio = item.responsibilityRatio.replace(/%/g, '');
// sum = Number(item.responsibilityRatio) + sum;
// }
// });
// FangAddList.value.forEach(item => {
// item.responsibilityRatio = item.responsibilityRatio
// ? item.responsibilityRatio + '%'
// : item.responsibilityRatio;
// });
}
companyProportion.value = 100 - sum;
// companyProportion.value = 100 - sum;
//
if (res.data.data.processingResultsVO.processingMoneyEntityList) {
ProcessingList.value = res.data.data.processingResultsVO.processingMoneyEntityList.map(
@ -1448,12 +1607,31 @@ const onLoad = async () => {
Pageloading.value = false;
});
};
//
watch($route, (to, from) => {
onLoad();
onMounted(() => {
watch(
$route.fullPath,
(newRoute, oldRoute) => {
if (oldRoute) {
console.log(newRoute, 'newRoute');
console.log(oldRoute, 'oldRoute');
if (newRoute.fullPath === oldRoute.fullPath) {
console.log('当前页面和上一个页面相同');
} else {
console.log('当前页面和上一个页面不同');
onLoad();
}
} else {
console.log('这是初始渲染,没有上一个页面');
onLoad();
}
},
{ immediate: true, deep: true }
);
});
//
//
const Fileidentifier = val => {
if (val) {
@ -1462,7 +1640,7 @@ const Fileidentifier = val => {
const fileName = url.substring(url.lastIndexOf('/') + 1);
//
const extension = fileName.substring(fileName.lastIndexOf('.') + 1).toLowerCase();
//
if (extension === 'mp4') {
return 'mp4';
@ -1473,7 +1651,7 @@ const Fileidentifier = val => {
if (extension === 'docx') {
return 'docx';
}
// undefined
return undefined;
}
@ -1588,8 +1766,7 @@ const Chathistory = res => {
.finally(handleFinally);
}
};
onLoad();
//
onMounted(() => {
msgHight.value = window.innerHeight * 0.76;
console.log(msgHight.value, '处理好的页面高度');
@ -1693,7 +1870,7 @@ const ImgSuccess = (response, uploadFile) => {
//
const fellSuccess = (response, uploadFile) => {
console.log('上成功');
console.log('上成功');
console.log(response, uploadFile);
if (response.data.link) {
KFfeel.value.push(response.data.link);
@ -1715,7 +1892,7 @@ const ViodSuccess = response => {
//
const beforeAvatarUpload = async rawFile => {
if (!/^image\/(png|jpeg|gif)$|^video\/mp4$/.test(rawFile.type)) {
ElMessage.error('上传格式只支持 png、jpeg、gif 和 mp4 类型!');
ElMessage.error('上传格式只支持 png、jpeg、gif、image 和 mp4 类型!');
return false;
} else if (rawFile.size / 1024 / 1024 > 40) {
ElMessage.error('上传大小不能超过 40MB!');
@ -1780,9 +1957,12 @@ const AddPayee = () => {
//
const Totalamount = () => {
TotalClaimAmount.value = ProcessingList.value
.map(res => res.money)
.reduce((accumulator, currentValue) => accumulator + currentValue, 0);
TotalClaimAmount.value = parseFloat(
ProcessingList.value
.map(res => res.money)
.reduce((accumulator, currentValue) => accumulator + currentValue, 0)
.toFixed(2)
);
};
//
const payremove = (item, index) => {
@ -1956,7 +2136,8 @@ const submitresults = async value => {
ProcessingList.value.forEach(item => {
let _DATA = item.Paymentmethod.find(res => res.value == item.compensationMethod);
data.aftersalesProcessingResultsDTO['processingMoneyEntityList'].push({
resultType: ProcessingResults.value.find(res => res.dictValue == item.title).dictKey, //key
resultType:
ProcessingResults.value.find(res => res.dictValue == item.title)?.dictKey || '', //key
resultName: item.title, //
money: item.money, //
compensationMethod: item.compensationMethod, //Value
@ -2375,6 +2556,201 @@ const CustomerServiceCompleted = () => {
});
$useStore.commit('DEL_TAG_CURRENT');
};
//
const resultreturnedFun = () => {
BatchFrom.value.businessDepartment = [];
BatchFrom.value.txt = null;
dialogReturn.value = true;
};
//
const ConfirmReturn = async () => {
//
let data = {
processorList: [],
};
//
if (BatchFrom.value.businessDepartment.length) {
let foundObjs = warehouseData.value.filter(obj =>
BatchFrom.value.businessDepartment.includes(obj.value)
);
data['businessId'] = foundObjs.map(item => item.value).join(',');
data['businessName'] = foundObjs.map(item => item.label).join(',');
//
foundObjs.forEach(item => {
data['processorList'].push({ id: item.value, name: item.label });
});
}
data.reasonReturn = BatchFrom.value.txt; //
data.workOrderIds = [$route.query.id]; //
console.log(data, '处理好的值');
data.typesOf = '1'; //
repulse.value = true; //
dialogReturn.value = false; //
await $_batchReturn(data)
.then(res => {
console.log(res, '批量打回返回值');
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
//
$useStore.commit('EDIT_REFRESHITEM', { title: 'aftersalesWorkOrder', status: true }); //
$useStore.commit('Customer_Menu', Number($route.query.RouteIndexs)); //
$router.push('/aftersales/aftersalesWorkOrder');
AddressClosed('/aftersales/aftersalesWorkOrderend'); //
}
})
.catch(error => {
console.log(error, 'error');
})
.finally(() => {
repulse.value = false; //
dialogReturn.value = false; //
});
};
//
const BatchReturn = () => {
ElMessageBox.prompt('请输入打回原因', {
confirmButtonText: '确定',
cancelButtonText: '取消',
inputPattern: /^(?!\s*$).+/,
inputErrorMessage: '内容不能为空哦',
})
.then(async ({ value }) => {
Pageloading.value = true;
await $_batchRepulseCompleted({
workOrderIds: [$route.query.id],
reasonReturn: value,
})
.then(res => {
if (res.data.code == 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
$useStore.commit('EDIT_REFRESHITEM', {
title: 'aftersalesWorkOrder',
status: true,
});
$useStore.commit('Customer_Menu', Number($route.query.RouteIndexs)); //
$useStore.commit('DEL_TAG_CURRENT'); //
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
}
})
.catch(error => {
console.log(error);
})
.finally(() => {
Pageloading.value = false;
});
})
.catch(() => {});
};
//
const ResultConfirmation = async () => {
ElMessageBox.confirm('是否确认审核?请注意查验数据正确性!', '提示', {
confirmButtonText: '确认',
cancelButtonText: '取消',
type: 'warning',
})
.then(async () => {
const data = {
assignList: [$route.query.id],
};
if ($route.query.workOrderStatus !== '40') {
ElMessage({
message: '状态错误',
type: 'warning',
});
return;
}
Pageloading.value = true; //
try {
const res = await $_updateManagerConfirmed(data);
if (res.data.code === 200) {
ElMessage({
message: res.data.msg,
type: 'success',
});
}
$useStore.commit('EDIT_REFRESHITEM', {
title: 'aftersalesWorkOrder',
status: true,
});
$useStore.commit('Customer_Menu', Number($route.query.RouteIndexs)); //
$useStore.commit('DEL_TAG_CURRENT'); //
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
} catch (error) {
console.log('错误信息:', error);
} finally {
Pageloading.value = false; //
}
})
.catch(() => {});
};
//
const AppealRejection = () => {
ElMessageBox.prompt('请填写驳回原因', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
inputPattern: /^(?!\s*$).+/,
inputErrorMessage: '内容不能为空哦',
})
.then(async ({ value }) => {
try {
let data = {
id: $route.query.workOrderId, //ID
typesOf: '2', //
workOrderId: $route.query.id, //ID
handlingReason: value, //
};
let _res = await $_Cancelappeal(data);
if (_res.data.code == 200) {
ElMessage({
message: _res.data.msg,
type: 'success',
});
$useStore.commit('EDIT_REFRESHITEM', {
title: 'aftersalesWorkOrder',
status: true,
});
$useStore.commit('Customer_Menu', Number($route.query.RouteIndexs)); //
$useStore.commit('DEL_TAG_CURRENT'); //
$router.push({
path: '/aftersales/aftersalesWorkOrder',
});
}
} catch (e) {
} finally {
}
})
.catch(() => {});
};
//
const AppealEstablished = () => {
$router.push({
path: '/aftersales/aftersalesWorkOrdermodify',
query: {
id: $route.query.id, //idworkOrderId
name: $route.query.workOrderNumber + '-申诉编辑',
RouterState: 'Kfend',
workOrderStatus: $route.query.workOrderStatus, //
Appealeditor: 'appeal', //
appealID: $route.query.workOrderId, //ID
typesOf: $route.query.typesOf, //012
},
});
};
</script>
<style scoped lang="scss">
@ -2440,6 +2816,8 @@ const CustomerServiceCompleted = () => {
flex-direction: column;
justify-content: space-between;
margin-bottom: 16px;
border-radius: 16px;
box-shadow: 0px 0px 6px 0px #00000029;
.title {
position: absolute;
top: -20px;
@ -2825,12 +3203,12 @@ const CustomerServiceCompleted = () => {
}
.img {
width: 100%;
height:20%;
height: 20%;
overflow: scroll;
.el-image{
.el-image {
width: 20%;
height: 100%;
margin: 4px;
}
img {
@ -3086,7 +3464,7 @@ const CustomerServiceCompleted = () => {
display: flex;
flex-direction: row;
align-items: center;
width: auto;
width: 22%;
}
}
:deep(.el_resj) {
@ -3195,6 +3573,7 @@ const CustomerServiceCompleted = () => {
}
}
.el-endtabs {
width: 100%;
margin-top: 10px;
:deep(.is-active) {
font-weight: bold;
@ -3246,4 +3625,26 @@ const CustomerServiceCompleted = () => {
border: 1px solid #f00;
}
}
:deep(.plAllret) {
.el-form {
flex-direction: column;
.el-form-item {
flex-direction: column;
}
.el-form-item__content {
flex-direction: column;
}
.el-form-item__label {
font-weight: bold;
}
}
.el-select {
width: 100%;
}
.el-loading-mask {
position: absolute;
left: 0;
top: 0;
}
}
</style>

216
src/views/basicdata/warehouse/tray/basicdataTrayedt.vue

@ -169,6 +169,7 @@ import option from '@/option/basic/basicPdarecords';
import { mapGetters } from 'vuex';
import { getDictionaryBiz } from '@/api/system/dict';
import dayjs from 'dayjs';
import { handleTranslationDataSeclect } from '@/utils/util';
export default {
data() {
@ -615,7 +616,7 @@ export default {
{
prop: 'serviceNumber',
label: '服务号',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -626,7 +627,7 @@ export default {
{
prop: 'waybillNumber',
label: '运单号',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -637,7 +638,7 @@ export default {
{
prop: 'orderCode',
label: '订单自编号',
type: 1,
type: 30,
values: '',
width: '300',
checkarr: [],
@ -648,7 +649,7 @@ export default {
{
prop: 'orderPackageCode',
label: '包条码',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -656,10 +657,24 @@ export default {
sortable: true,
head: false,
},
{
prop: 'isFleeingName',
label: '是否窜货',
type: 30,
values: '',
width: '80',
checkarr: [
{ value: 0, label: '否' },
{ value: 1, label: '是' },
],
fixed: false,
sortable: false,
head: false,
},
{
prop: 'warehouse',
label: '仓库',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -670,7 +685,7 @@ export default {
{
prop: 'firsts',
label: '一级品类',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -681,7 +696,7 @@ export default {
{
prop: 'second',
label: '二级品类',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -692,7 +707,7 @@ export default {
{
prop: 'thirdProduct',
label: '三级品类',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -703,7 +718,7 @@ export default {
{
prop: 'materialCode',
label: '物品编号',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -714,7 +729,7 @@ export default {
{
prop: 'materialName',
label: '物品名称',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -725,73 +740,7 @@ export default {
{
prop: 'brandName',
label: '品牌',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageStatusName',
label: '包件状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageFreezeStatusName',
label: '包件冻结状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageGroundingStatusName',
label: '包件上架状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageStockupStatusName',
label: '包件备货状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageReservationStatusName',
label: '包件预约状态',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderPackageLoadingStatusName',
label: '包件装车状态',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -799,10 +748,76 @@ export default {
sortable: true,
head: false,
},
// {
// prop: 'orderPackageStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'orderPackageFreezeStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'orderPackageGroundingStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'orderPackageStockupStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'orderPackageReservationStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'orderPackageLoadingStatusName',
// label: '',
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'positionCode',
label: '所在库位',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -813,7 +828,7 @@ export default {
// {
// prop: 'columnNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -824,7 +839,7 @@ export default {
// {
// prop: 'layerNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -847,7 +862,7 @@ export default {
{
prop: 'sku',
label: 'sku',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -858,7 +873,7 @@ export default {
{
prop: 'descriptionGoods',
label: '物料名称',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -869,7 +884,7 @@ export default {
{
prop: 'cargoNumber',
label: '物料编号',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -880,7 +895,7 @@ export default {
{
prop: 'cargoNorms',
label: '规格',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -891,7 +906,7 @@ export default {
{
prop: 'cargoUnit',
label: '单位',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -902,7 +917,7 @@ export default {
{
prop: 'warehouseName',
label: '仓库',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -913,7 +928,7 @@ export default {
{
prop: 'marketName',
label: '商场名称',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -924,7 +939,7 @@ export default {
{
prop: 'positionCode',
label: '所在库位',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -935,7 +950,7 @@ export default {
// {
// prop: 'columnNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -946,7 +961,7 @@ export default {
// {
// prop: 'layerNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -957,7 +972,7 @@ export default {
{
prop: 'num',
label: '数量',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -980,7 +995,7 @@ export default {
{
prop: 'dealerName',
label: '经销商名称',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -991,7 +1006,7 @@ export default {
{
prop: 'waybillNo',
label: '运单号',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1002,7 +1017,7 @@ export default {
{
prop: 'dealerCode',
label: '经销商编码',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1013,7 +1028,7 @@ export default {
{
prop: 'consigneePerson',
label: '运单收货人',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1024,7 +1039,7 @@ export default {
{
prop: 'consigneeAddress',
label: '运单收货地址',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1035,7 +1050,7 @@ export default {
{
prop: 'consigneeMobile',
label: '运单收货电话',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1046,7 +1061,7 @@ export default {
{
prop: 'positionCode',
label: '所在库位',
type: 1,
type: 30,
values: '',
width: '150',
checkarr: [],
@ -1057,7 +1072,7 @@ export default {
// {
// prop: 'columnNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -1068,7 +1083,7 @@ export default {
// {
// prop: 'layerNum',
// label: '',
// type: 1,
// type: 30,
// values: '',
// width: '150',
// checkarr: [],
@ -1245,6 +1260,7 @@ export default {
getpackList(page.currentPage, page.pageSize, Object.assign(params, this.query)).then(res => {
const data = res.data.data;
this.packdata = data.records;
handleTranslationDataSeclect(this.packdata, this.wrapoptioncolumn);
this.packpage.total = data.total;
});
},

2
src/views/distribution/artery/VehicleStowageDetails.vue

@ -950,7 +950,7 @@ const handleData = async () => {
/** 表格表头输入框搜索 */
const inputsc = (value, row) => {
handleInputQuery(value, row, details.query.inputQuery, true);
handleInputQuery(value, row, details.query.inputQuery, true, false);
handleData();
};

7
src/views/distribution/artery/truckLoadingDetails.vue

@ -85,9 +85,9 @@
<!-- 零担批量卸车确认 -->
<el-button
v-if="permissionObj.truckLoadingDetails_delete"
v-if="permissionObj.truckLoadingDetails_zeroUnload"
type="primary"
icon="Delete"
icon="CircleCheck"
@click="handleBatchLoadConfirm"
>零担批量卸车确认
</el-button>
@ -398,6 +398,7 @@ import {
handleClearTableQuery,
getObjType,
ChecksWhetherTheWarehouseIsSelected,
isNumber,
} from '@/utils/util';
import { detailsColumnList } from '@/option/distribution/TripartiteTransfer';
import { useRouter, useRoute } from 'vue-router';
@ -1617,6 +1618,8 @@ const handleBatchLoadConfirm = () => {
for (let i = 0; i < details.selectionList.length; i++) {
const val = details.selectionList[i];
if (!isNumber(val.unloadNum) || val.unloadNum <= 0)
return ElMessage.warning('零担卸车确认需要卸车数大于0');
if (Number(val.type) !== 2) return ElMessage.warning('请勿选择包件数据');
loadScanIds.push(val.id);
}

108
src/views/distribution/inventory/BookingNote.vue

@ -71,9 +71,50 @@
></el-input>
</el-form-item>
<el-form-item label="发站:" prop="departure">
<el-input readonly v-model="query['departure']" placeholder="到站地址"></el-input>
</el-form-item>
<el-form-item label="到站:" prop="destination">
<el-input readonly v-model="query['destination']" placeholder="到站地址"></el-input>
</el-form-item>
<!-- <el-form-item label="发站:" prop="departure">
<div class="w100">
<el-cascader
pleceholder="请选择到站地址"
:options="details.regionOptione"
style="width: 100%"
v-model="query.departure"
:props="{
checkStrictly: true,
}"
>
<template #default="{ node, data }">
<span>{{ data.label }}</span>
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
</template>
</el-cascader>
</div>
</el-form-item>
<el-form-item label="到站:" prop="destination">
<div class="w100">
<el-cascader
pleceholder="请选择到站地址"
:options="details.regionOptione"
style="width: 100%"
v-model="query.destination"
:props="{
checkStrictly: true,
}"
>
<template #default="{ node, data }">
<span>{{ data.label }}</span>
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
</template>
</el-cascader>
</div>
</el-form-item> -->
<el-form-item label="目的仓:" class="el-times" prop="queryDestinationWarehouseName">
<el-input
@ -972,9 +1013,6 @@
:columnList="details.WaybillTrackingColumnList"
:tableData="data"
:loading="loadingObj.stowageLoading"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
>
</tablecmt>
</el-tab-pane>
@ -986,8 +1024,6 @@
:columnList="details.FinancialRecordColumnList"
:tableData="data"
:loading="loadingObj.stowageLoading"
@inputTxt="inputsc"
@timeCheck="timesc"
>
</tablecmt>
</el-tab-pane>
@ -999,8 +1035,6 @@
:columnList="details.ChangeOrderColumnList"
:tableData="data"
:loading="loadingObj.stowageLoading"
@inputTxt="inputsc"
@timeCheck="timesc"
>
</tablecmt>
</el-tab-pane>
@ -1029,8 +1063,6 @@
:columnList="details.TransactionColumnList"
:tableData="data"
:loading="loadingObj.stowageLoading"
@inputTxt="inputsc"
@timeCheck="timesc"
>
</tablecmt>
</el-tab-pane>
@ -1042,8 +1074,6 @@
:columnList="details.columnList"
:tableData="data"
:loading="loadingObj.stowageLoading"
@inputTxt="inputsc"
@timeCheck="timesc"
>
</tablecmt>
</el-tab-pane>
@ -1260,6 +1290,7 @@ const details = reactive<any>({
receiptImgList: [],
/** 打印html */
html: '',
regionOptione: [],
});
const info = ref<any>({});
@ -1322,10 +1353,57 @@ const handleComputed = (row: any) => {
//
getLazyTreeAll().then(res => {
if (res.data.success) {
details.regionOptione = res.data.data;
details.regionOptione = getObjType(res.data.data) === 'array' ? res.data.data : [];
//
if (details.regionOptione.length !== 0) {
handleTranslationLocation('departure');
handleTranslationLocation('destination');
}
}
});
// ,
const handleTranslationLocation = key => {
//
const _location = details.query[key];
let _arr = [];
//
for (const iterator of details.regionOptione) {
let isBreak = false;
if (iterator.label === _location) {
_arr = [iterator.label];
isBreak = true;
} else if (getObjType(iterator.children) === 'array') {
for (const item of iterator.children) {
if (item.label === _location) {
_arr = [iterator.label, item.label];
isBreak = true;
break;
} else if (getObjType(item.children) === 'array') {
for (const value of item.children) {
if (value.label === _location) {
_arr = [iterator.label, item.label, value.label];
isBreak = true;
break;
}
}
}
}
if (isBreak) break;
}
if (isBreak) break;
}
const _label = _arr.slice(1).join('/');
details.query[key] = _label;
};
/** 请求页面数据 */
const onLoad = async () => {
try {
@ -1360,8 +1438,12 @@ const onLoad = async () => {
details.query.daoPay = isNumber(data.warehouseWaybill.dPay)
? Number(data.warehouseWaybill.dPay)
: data.warehouseWaybill.dPay;
//
console.log('details.query :>> ', details.query);
if (details.regionOptione.length !== 0) {
handleTranslationLocation('departure');
handleTranslationLocation('destination');
}
// goodsList
if (data.warehouseWaybill.detailList.length === 0)

4
src/views/reportforms/DeliveryDetailsVtwo.vue

@ -63,7 +63,7 @@
</el-select>
</el-form-item>
<el-form-item label="配送车辆">
<!-- <el-form-item label="配送车辆">
<el-input
v-model="TopQuery.vehicleNameRange"
style="width: 240px"
@ -103,7 +103,7 @@
clearable
placeholder="多个运单收货人请用逗号隔开"
/>
</el-form-item>
</el-form-item> -->
</div>
</el-form>
</el-row>

31
src/views/warehouse/parcelList/distributionParcelList.vue

@ -202,7 +202,13 @@ import {
import { getDictionaryBiz } from '@/api/system/dict';
import option from '@/option/distribution/distributionParcelList';
import { mapGetters } from 'vuex';
import { downloadXls, debounce, setNodeHeight, handleClearTableQuery } from '@/utils/util';
import {
downloadXls,
debounce,
setNodeHeight,
handleClearTableQuery,
handleInputQuery,
} from '@/utils/util';
import { showInventoryPackgeCode } from '@/api/distribution/distributionStockList';
import { showOrderPackgeCode } from '@/api/distribution/distributionStockArticle';
import print from '@/utils/print';
@ -672,7 +678,7 @@ export default {
label: '操作',
type: 6,
values: '',
width: '130',
width: '200',
checkarr: [],
fixed: 'right',
sortable: true,
@ -721,13 +727,19 @@ export default {
this.loading = true;
this.loadingObj.pageLoading = true;
try {
if (Object.keys(this.query).length === 0) return (this.data = []);
const _submitData = { ...params, ...this.query };
const keys = Object.keys(_submitData);
for (let i = 0; i < keys.length; i++) {
const _key = keys[i];
const _val = _submitData[_key];
if (_val || _val === 0) continue;
delete _submitData[_key];
}
if (Object.keys(_submitData).length === 0) return (this.data = []);
const res = await getpage(
page.currentPage,
page.pageSize,
Object.assign(params, this.query)
);
const res = await getpage(page.currentPage, page.pageSize, _submitData);
const { code, data } = res.data;
if (code !== 200) return;
console.log(res, '获取到的页面初始值');
@ -863,8 +875,7 @@ export default {
},
inputsc(index, row) {
this.query[row.prop] = index;
if (!index) delete this.query[row.prop];
handleInputQuery(index, row, this.query);
this.page.currentPage = 1;
this.onLoad(this.page);
},

5
src/views/waybill/CreateZeroOrder.vue

@ -543,6 +543,7 @@
:focus="handleCloseSelcet"
v-model="item.goodsName"
:class="!item.goodsId ? 'is-error' : ''"
:disabled="query.zeroEditStatus === 0"
placeholder="货物名称"
>
<div v-loading="item.loading">
@ -565,6 +566,7 @@
<el-form-item label="件数:" label-width="fit-content" prop="num" class="el-times">
<el-input-number
:disabled="query.zeroEditStatus === 0"
:value-on-clear="0"
:controls="false"
v-model="item.num"
@ -1811,6 +1813,9 @@ const initPageInfo = async () => {
handleTranslationLocation('destination');
}
if (details.query.zeroEditStatus === 0)
ElMessage.warning('该零担运单始发仓或目的仓未齐套,禁止编辑货物名称和件数');
// goodsList
if (data.warehouseWaybill.detailList.length === 0)
details.goodsList = [

2
src/views/waybill/orderPackageList.vue

@ -490,7 +490,7 @@ const {
for (let i = 0; i < details.packageListColumnList.length; i++) {
const item = details.packageListColumnList[i];
if (item.type !== 0 && item.type !== 12 && item.type !== 6 && item.type !== 13) item.type = 1;
if (item.type !== 0 && item.type !== 12 && item.type !== 6 && item.type !== 13) item.type = 30;
console.log('item :>> ', item);
}

Loading…
Cancel
Save