二级出库弹框逻辑调整

master
zhangdi 3 months ago
parent 600cb05a8e
commit 4d57f9ee26
  1. 23
      src/api/secondOrder/outbound.js
  2. 433
      src/views/secondOrder/components/outDialog.vue

@ -76,3 +76,26 @@ export const getStatistics = data => {
data: data,
})
}
// 获取物资分组数据 twoOutStorage/getOutGroupName
export const getOutGroupName = params => {
return request({
url: '/smartpark/twoOutStorage/getOutGroupName',
method: 'get',
params: params,
cryptoToken: false,
cryptoData: false
})
}
// 获取分组中的数据物资数据 twoOutStorage/getGroupMaterial
export const getGroupMaterial = params => {
return request({
url: '/smartpark/twoOutStorage/getGroupMaterial',
method: 'get',
params: params,
cryptoToken: false,
cryptoData: false
})
}

@ -1,30 +1,56 @@
<template>
<div>
<el-dialog :close-on-click-modal="false" :title="outDialogTiltle" :visible.sync="outDialogVisible"
:append-to-body="true" @close="handleCloseDetail" fullscreen>
<el-dialog
:close-on-click-modal="false"
:title="outDialogTiltle"
:visible.sync="outDialogVisible"
:append-to-body="true"
@close="handleCloseDetail"
fullscreen
>
<div class="dialog-content">
<!-- 基本信息 -->
<el-form :model="sizeForm" ref="dynamicValidateForm" label-width="100px" class="demo-dynamic"
:rules="dynamicRules">
<el-form
:model="sizeForm"
ref="dynamicValidateForm"
label-width="100px"
class="demo-dynamic"
:rules="dynamicRules"
>
<div class="form-title">基本信息</div>
<el-row>
<el-col :span="12">
<el-form-item label="出库申请时间">
<el-date-picker v-model="sizeForm.ldTwoOutStorage.outDate" type="date" placeholder="选择日期"
style="width: 100%" disabled>
<el-date-picker
v-model="sizeForm.ldTwoOutStorage.outDate"
type="date"
placeholder="选择日期"
style="width: 100%"
disabled
>
</el-date-picker>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="事由" prop="ldTwoOutStorage.reason">
<el-input v-model="sizeForm.ldTwoOutStorage.reason" :disabled="outDialogType != 'add'"
placeholder="请输入"></el-input>
<el-input
v-model="sizeForm.ldTwoOutStorage.reason"
:disabled="outDialogType != 'add'"
placeholder="请输入"
></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="物资类型" prop="ldTwoOutStorage.materialType">
<el-select v-model="sizeForm.ldTwoOutStorage.materialType" placeholder="请选择" style="width: 100%"
:disabled="outDialogType != 'add'">
<el-form-item
label="物资类型"
prop="ldTwoOutStorage.materialType"
>
<el-select
v-model="sizeForm.ldTwoOutStorage.materialType"
placeholder="请选择"
style="width: 100%"
:disabled="outDialogType != 'add'"
>
<el-option label="办公室物资" value="1"></el-option>
<el-option label="其他物资" value="2"></el-option>
</el-select>
@ -32,77 +58,241 @@
</el-col>
<el-col :span="12">
<el-form-item label="部门" prop="ldTwoOutStorage.departmentInfo">
<el-select v-model="sizeForm.ldTwoOutStorage.departmentInfo" placeholder="请选择" style="width: 100%"
:disabled="outDialogType != 'add'" @change="deptChange" clearable filterable value-key="departmentId">
<el-option v-for="item in departmentOptions" :key="item.departmentId" :label="item.department"
:value="item"></el-option>
<el-select
v-model="sizeForm.ldTwoOutStorage.departmentInfo"
placeholder="请选择"
style="width: 100%"
:disabled="outDialogType != 'add'"
@change="deptChange"
clearable
filterable
value-key="departmentId"
>
<el-option
v-for="item in departmentOptions"
:key="item.departmentId"
:label="item.department"
:value="item"
></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="领用人" prop="ldTwoOutStorage.proposerInfo">
<el-select v-model="sizeForm.ldTwoOutStorage.proposerInfo" placeholder="请选择" style="width: 100%"
:disabled="sizeForm.departmentId == '' || outDialogType == 'details'
" clearable filterable value-key="userId" @change="proposerChange">
<el-option v-for="item in userOptions" :key="item.userId" :label="item.name" :value="item">
<el-select
v-model="sizeForm.ldTwoOutStorage.proposerInfo"
placeholder="请选择"
style="width: 100%"
:disabled="
sizeForm.departmentId == '' || outDialogType == 'details'
"
clearable
filterable
value-key="userId"
@change="proposerChange"
>
<el-option
v-for="item in userOptions"
:key="item.userId"
:label="item.name"
:value="item"
>
</el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="物资分组" prop="ldTwoOutStorage.groupName">
<el-select
v-model="sizeForm.ldTwoOutStorage.groupName"
placeholder="请选择"
style="width: 100%"
:disabled="outDialogType != 'add'"
clearable
filterable
value-key="departmentId"
@change="groupNameChange"
>
<el-option
v-for="item in groupNameOptions"
:key="item.groupIds"
:label="item.groupName"
:value="item.groupIds"
></el-option>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12" v-if="outDialogType == 'details'">
<el-form-item label="填报人">
<el-input v-model="sizeForm.ldTwoOutStorage.shipperName" :disabled="outDialogType != 'add'"></el-input>
<el-input
v-model="sizeForm.ldTwoOutStorage.shipperName"
:disabled="outDialogType != 'add'"
></el-input>
</el-form-item>
</el-col>
</el-row>
<div class="form-title">{{ outDateInfo }} 出库信息</div>
<div v-if="sizeForm.ldTwoOutStorage.groupName != null">
<el-table :data="groupTableData" style="width: 100%" border>
<!-- 展开行详情 -->
<el-table-column type="expand">
<template slot-scope="props">
<!-- 关联表单列表带复选框 -->
<el-table
:data="props.row.twoInventoryVOList || []"
size="mini"
style="width: 100%"
@selection-change="
(val) => handleSelectionChange(val, props.row)
"
border
>
<el-table-column type="selection" width="55" />
<el-table-column type="index" label="#" width="55" />
<el-table-column label="物料名称" prop="materialName" />
<el-table-column label="物料编码" prop="materialCode" />
<el-table-column label="规格型号" prop="model" />
<el-table-column label="数量" prop="num" />
<el-table-column label="本次出库数量" prop="num">
<template slot-scope="scope">
<el-input-number
size="mini"
v-model="scope.row.num"
:min="0"
:max="getMaxQuantity(scope.row)"
style="width: 100%"
:disabled="
outDialogType != 'add' || scope.row.type === 'NY'
"
@change="
(newValue) =>
handleQuantityChange(newValue, scope.$index)
"
></el-input-number>
</template>
</el-table-column>
<el-table-column label="单价" prop="unitPrice" width="80" />
</el-table>
</template>
</el-table-column>
<el-button type="primary" size="mini" style="margin-bottom: 18px" @click="categoryHandle"
v-if="outDialogType != 'details'">新增</el-button>
<el-table :data="sizeForm.ldTwoOutStorageDetailList" border style="width: 100%">
<el-table-column prop="materialCode" label="物资编码">
</el-table-column>
<!-- 常规列展示 -->
<el-table-column label="物料编码" prop="materialCode" />
<el-table-column label="物料名称" prop="materialName" />
<el-table-column label="规格型号" prop="model" />
<el-table-column label="申请数量" prop="applyNum" />
<el-table-column label="单位" prop="unit" />
</el-table>
</div>
<el-table-column prop="materialName" label="物资名称"></el-table-column>
<el-table-column prop="model" label="规格/型号"> </el-table-column>
<el-table-column prop="type" label="类别">
<template slot-scope="scope">
{{
scope.row.type === "NY"
? "耐用品"
: scope.row.type === "YH"
<div v-if="sizeForm.ldTwoOutStorage.groupName == null">
<el-button
type="primary"
size="mini"
style="margin-bottom: 18px"
@click="categoryHandle"
v-if="outDialogType != 'details'"
>新增</el-button
>
<el-table
:data="sizeForm.ldTwoOutStorageDetailList"
border
style="width: 100%"
>
<el-table-column
type="expand"
v-if="sizeForm.ldTwoOutStorage.groupName != null"
>
<template slot-scope="props">
<el-table
:data="scope.row.twoInventoryVOList"
border
style="width: 100%"
>
<el-table-column
prop="materialName"
label="物资名称"
></el-table-column>
<el-table-column
prop="materialCode"
label="物资编码"
></el-table-column>
<el-table-column
prop="type"
label="物资类型"
></el-table-column>
<el-table-column prop="num" label="数量"></el-table-column>
</el-table>
</template>
</el-table-column>
<el-table-column prop="materialCode" label="物资编码">
</el-table-column>
<el-table-column
prop="materialName"
label="物资名称"
></el-table-column>
<el-table-column prop="model" label="规格/型号">
</el-table-column>
<el-table-column prop="type" label="类别">
<template slot-scope="scope">
{{
scope.row.type === "NY"
? "耐用品"
: scope.row.type === "YH"
? "易耗品"
: ""
}}
</template>
</el-table-column>
<el-table-column prop="unit" label="单位"> </el-table-column>
<el-table-column prop="num" label="数量">
<template slot-scope="scope">
<el-input-number size="mini" v-model="scope.row.num"
:min="0"
:max="getMaxQuantity(scope.row)"
style="width: 100%"
:disabled="outDialogType != 'add' || scope.row.type === 'NY'" @change="
(newValue) => handleQuantityChange(newValue, scope.$index)
"></el-input-number>
</template>
</el-table-column>
<el-table-column label="操作" width="100" v-if="outDialogType != 'details'">
<template slot-scope="scope">
<div :disabled="outDialogType == 'details'">
<el-button type="text" size="mini" @click="handleDelete(scope.$index, scope.row)">
删除
</el-button>
</div>
</template>
</el-table-column>
</el-table>
}}
</template>
</el-table-column>
<el-table-column prop="unit" label="单位"> </el-table-column>
<el-table-column prop="num" label="数量">
<template slot-scope="scope">
<el-input-number
size="mini"
v-model="scope.row.num"
:min="0"
:max="getMaxQuantity(scope.row)"
style="width: 100%"
:disabled="
outDialogType != 'add' || scope.row.type === 'NY'
"
@change="
(newValue) => handleQuantityChange(newValue, scope.$index)
"
></el-input-number>
</template>
</el-table-column>
<el-table-column
label="操作"
width="100"
v-if="outDialogType != 'details'"
>
<template slot-scope="scope">
<div :disabled="outDialogType == 'details'">
<el-button
type="text"
size="mini"
@click="handleDelete(scope.$index, scope.row)"
>
删除
</el-button>
</div>
</template>
</el-table-column>
</el-table>
</div>
<div class="form-title" v-if="outDialogType != 'details'">
出库账目表格
</div>
<el-table :data="statisticsList" border style="width: 100%" v-if="outDialogType != 'details'">
<el-table
:data="statisticsList"
border
style="width: 100%"
v-if="outDialogType != 'details'"
>
<el-table-column prop="date" label="当前库存">
<el-table-column prop="materialCode" label="编码">
</el-table-column>
@ -111,23 +301,25 @@
<el-table-column prop="model" label="规格"> </el-table-column>
<el-table-column prop="type" label="类别">
<template slot-scope="scope">
{{
scope.row.type === "NY"
? "耐用品"
: scope.row.type === "YH"
{{
scope.row.type === "NY"
? "耐用品"
: scope.row.type === "YH"
? "易耗品"
: ""
}}
</template>
}}
</template>
</el-table-column>
<el-table-column prop="unit" label="单位"> </el-table-column>
<el-table-column prop="num" label="数量"> </el-table-column>
</el-table-column>
<el-table-column prop="date" label="出库信息">
<el-table-column prop="theOutboundQuantity" label="数量"> </el-table-column>
<el-table-column prop="theOutboundQuantity" label="数量">
</el-table-column>
</el-table-column>
<el-table-column prop="date" label="出库后库存">
<el-table-column prop="totalQuantity" label="数量"> </el-table-column>
<el-table-column prop="totalQuantity" label="数量">
</el-table-column>
</el-table-column>
<el-table-column prop="date" label="出库信息">
<el-table-column label="出库人">
@ -151,13 +343,24 @@
<span slot="footer" class="dialog-footer">
<el-button @click="handleCloseDetail()"> </el-button>
<el-button v-if="outDialogType != 'details'" type="primary" @click="sumbit()"> </el-button>
<el-button
v-if="outDialogType != 'details'"
type="primary"
@click="sumbit()"
> </el-button
>
</span>
</el-dialog>
<!-- 新增数据 -->
<categoryDialog v-if="categoryVisible" :categoryVisible="categoryVisible" :selectionData="selectionData"
:departmentId="sizeForm.ldTwoOutStorage.departmentId" :categoryDialogTitle="categoryDialogTitle"
@confirm="confirm" @categoryClose="categoryClose"></categoryDialog>
<categoryDialog
v-if="categoryVisible"
:categoryVisible="categoryVisible"
:selectionData="selectionData"
:departmentId="sizeForm.ldTwoOutStorage.departmentId"
:categoryDialogTitle="categoryDialogTitle"
@confirm="confirm"
@categoryClose="categoryClose"
></categoryDialog>
</div>
</template>
<script>
@ -169,6 +372,8 @@ import {
submit,
getDetails,
getStatistics,
getOutGroupName,
getGroupMaterial,
} from "@/api/secondOrder/outbound";
export default {
components: {
@ -237,6 +442,7 @@ export default {
departmentInfo: null,
proposerInfo: null,
optionType: "YH",
groupName: "", //
},
ldTwoOutStorageDetailList: [], //
inAccountsTableData: [], //
@ -287,6 +493,9 @@ export default {
departmentOptions: [], //
dynamicRules: {}, //
statisticsList: [], //
groupNameOptions: [], //
groupTableData: [], //
selectedGroupMap: {}, // key: group materialId indexvalue:
};
},
mounted() {
@ -298,8 +507,55 @@ export default {
}
this.getDetailedItems();
this.getOutGroupName();
},
methods: {
//
handleSelectionChange(selection, parentRow) {
// 使 parentRow key materialId materialCode
const key =
parentRow.materialId || parentRow.materialCode || parentRow.id;
if (!key) {
console.warn("Parent row has no unique key for selection tracking");
return;
}
//
this.$set(this.selectedGroupMap, key, selection);
//
let allDetails = [];
Object.values(this.selectedGroupMap).forEach((selectedList) => {
allDetails = allDetails.concat(
selectedList.map((item) => ({
...item,
// num 0 1
num: item.num || (item.type === "NY" ? 1 : 0),
}))
);
});
//
this.sizeForm.ldTwoOutStorageDetailList = allDetails;
console.log(this.sizeForm.ldTwoOutStorageDetailList,'批量数据');
//
this.getStatistics();
},
groupNameChange() {
if (this.sizeForm.ldTwoOutStorage.groupName != null) {
getGroupMaterial(this.sizeForm.ldTwoOutStorage).then((res) => {
this.groupTableData = res.data.result;
});
}
},
getOutGroupName() {
getOutGroupName().then((res) => {
this.groupNameOptions = res.data.result;
});
},
//
getStatistics() {
getStatistics(this.sizeForm.ldTwoOutStorageDetailList).then((res) => {
@ -319,32 +575,37 @@ export default {
},
//
getMaxQuantity(row) {
const stockInfo = this.statisticsList.find(stat => stat.materialCode === row.materialCode)
if (row.type === 'NY') {
return 1
const stockInfo = this.statisticsList.find(
(stat) => stat.materialCode === row.materialCode
);
if (row.type === "NY") {
return 1;
} else {
return stockInfo ? stockInfo.num : 999999;
}
},
categoryHandle() {
if ((!this.sizeForm.ldTwoOutStorage.proposerInfo) || (!this.sizeForm.ldTwoOutStorage.departmentInfo)) {
this.$message.error('请先选择部门和领用人');
return false
if (
!this.sizeForm.ldTwoOutStorage.proposerInfo ||
!this.sizeForm.ldTwoOutStorage.departmentInfo
) {
this.$message.error("请先选择部门和领用人");
return false;
}
this.categoryVisible = true;
},
confirm(allSelectedList) {
//
const existingQuantities = {};
this.sizeForm.ldTwoOutStorageDetailList.forEach(item => {
existingQuantities[item.id] = item.num
})
const updatedList = allSelectedList.map(item => {
this.sizeForm.ldTwoOutStorageDetailList.forEach((item) => {
existingQuantities[item.id] = item.num;
});
const updatedList = allSelectedList.map((item) => {
const existingNum = existingQuantities[item.id];
if (existingNum !== undefined) {
return {
...item,
num: existingNum
num: existingNum,
};
}
return item;
@ -358,7 +619,7 @@ export default {
//
handleDelete(index, row) {
this.sizeForm.ldTwoOutStorageDetailList.splice(index, 1);
this.getStatistics()
this.getStatistics();
},
// inAccountsTableData
summaryTableData() {
@ -367,7 +628,7 @@ export default {
);
},
handleQuantityChange(newValue, index) {
console.log(newValue, '点击数量变化数量的值')
console.log(newValue, "点击数量变化数量的值");
const currentRow = this.sizeForm.ldTwoOutStorageDetailList[index];
if (!currentRow) return;
@ -375,7 +636,7 @@ export default {
currentRow.num = newValue;
this.$set(this.sizeForm.ldTwoOutStorageDetailList, index, currentRow);
this.$set(this.sizeForm.inAccountsTableData, index, { ...currentRow });
this.getStatistics()
this.getStatistics();
},
//

Loading…
Cancel
Save