Merge remote-tracking branch 'origin/0.8.X' into 0.8.X
This commit is contained in:
282
klp-ui/src/components/KLPService/Renderer/CoilCard.vue
Normal file
282
klp-ui/src/components/KLPService/Renderer/CoilCard.vue
Normal file
@@ -0,0 +1,282 @@
|
|||||||
|
<template>
|
||||||
|
<div class="material-card" :style="cardStyle">
|
||||||
|
<div class="card-header">
|
||||||
|
<div class="header-left">
|
||||||
|
<current-coil-no :current-coil-no="coil.currentCoilNo"></current-coil-no>
|
||||||
|
<!-- <span class="material-type">{{ coil.materialType || '原料' }}</span> -->
|
||||||
|
<el-popover placement="top" width="280" trigger="hover" popper-class="material-params-popover">
|
||||||
|
<div class="material-params-content">
|
||||||
|
<div class="params-title">
|
||||||
|
{{ coil.coilName || '—' }}
|
||||||
|
</div>
|
||||||
|
<div class="params-list">
|
||||||
|
<div class="param-coil">
|
||||||
|
<div class="param-row" v-if="coil.specification">
|
||||||
|
<span class="param-label">规格:</span>
|
||||||
|
<span class="param-value">{{ coil.specification }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.material">
|
||||||
|
<span class="param-label">材质:</span>
|
||||||
|
<span class="param-value">{{ coil.material }}</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="param-row" v-if="coil.surfaceTreatmentDesc">
|
||||||
|
<span class="param-label">表面处理:</span>
|
||||||
|
<span class="param-value">{{ coil.surfaceTreatmentDesc }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.zincLayer">
|
||||||
|
<span class="param-label">镀层质量:</span>
|
||||||
|
<span class="param-value">{{ coil.zincLayer }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.manufacturer">
|
||||||
|
<span class="param-label">厂家:</span>
|
||||||
|
<span class="param-value">{{ coil.manufacturer }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="param-divider"></div>
|
||||||
|
<div class="param-coil">
|
||||||
|
<div class="param-row" v-if="coil.qualityStatus">
|
||||||
|
<span class="param-label">质量状态:</span>
|
||||||
|
<span class="param-value">{{ coil.qualityStatus }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.trimmingRequirement">
|
||||||
|
<span class="param-label">切边要求:</span>
|
||||||
|
<span class="param-value">{{ coil.trimmingRequirement }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.packingStatus">
|
||||||
|
<span class="param-label">原料材质:</span>
|
||||||
|
<span class="param-value">{{ coil.packingStatus }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.packagingRequirement">
|
||||||
|
<span class="param-label">包装要求:</span>
|
||||||
|
<span class="param-value">{{ coil.packagingRequirement }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.grossWeight">
|
||||||
|
<span class="param-label">毛重:</span>
|
||||||
|
<span class="param-value">{{ coil.grossWeight }}t</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.netWeight">
|
||||||
|
<span class="param-label">净重:</span>
|
||||||
|
<span class="param-value">{{ coil.netWeight }}t</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.length">
|
||||||
|
<span class="param-label">长度:</span>
|
||||||
|
<span class="param-value">{{ coil.length }}米</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.actualLength">
|
||||||
|
<span class="param-label">实测长度:</span>
|
||||||
|
<span class="param-value">{{ coil.actualLength }}米</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.actualThickness">
|
||||||
|
<span class="param-label">实测厚度:</span>
|
||||||
|
<span class="param-value">{{ coil.actualThickness }}米</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.actualWidth">
|
||||||
|
<span class="param-label">实测宽度:</span>
|
||||||
|
<span class="param-value">{{ coil.actualWidth }}米</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.temperGrade">
|
||||||
|
<span class="param-label">调制度:</span>
|
||||||
|
<span class="param-value">{{ coil.temperGrade }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.coatingType">
|
||||||
|
<span class="param-label">镀层种类:</span>
|
||||||
|
<span class="param-value">{{ coil.coatingType }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.coilSurfaceTreatment">
|
||||||
|
<span class="param-label">钢卷表面处理:</span>
|
||||||
|
<span class="param-value">{{ coil.coilSurfaceTreatment }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.team">
|
||||||
|
<span class="param-label">班组:</span>
|
||||||
|
<span class="param-value">{{ coil.team }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.updateTime">
|
||||||
|
<span class="param-label">更新时间:</span>
|
||||||
|
<span class="param-value">{{ parseTime(coil.updateTime, '{y}-{m}-{d} {h}:{i}') }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.updateBy">
|
||||||
|
<span class="param-label">更新人:</span>
|
||||||
|
<span class="param-value">{{ coil.updateBy }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.transferType">
|
||||||
|
<span class="param-label">调拨标记:</span>
|
||||||
|
<span class="param-value">{{ coil.transferType }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="param-row" v-if="coil.remark">
|
||||||
|
<span class="param-label">备注:</span>
|
||||||
|
<span class="param-value">{{ coil.remark }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<i slot="reference" class="el-icon-setting param-icon"></i>
|
||||||
|
</el-popover>
|
||||||
|
|
||||||
|
<slot name="header"></slot>
|
||||||
|
<!-- <i class="el-icon-view param-icon" @click="handlePreviewLabel(coil)" title="查看标签"></i>
|
||||||
|
<el-button v-loading="buttonLoading" style="margin-left: 0px; padding: 4px !important;" type="text" size="mini"
|
||||||
|
@click="handlePrintLabel(coil)" title="打印标签">打印</el-button> -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-body" style="position: relative;">
|
||||||
|
<slot name="body">
|
||||||
|
<div class="info-list">
|
||||||
|
<div class="info-coil">
|
||||||
|
<span class="info-label">入场:</span>
|
||||||
|
<span class="info-value" :title="coil.enterCoilNo">{{ coil.enterCoilNo || '—' }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="info-coil">
|
||||||
|
<span class="info-label">厂家:</span>
|
||||||
|
<span class="info-value" :title="coil.supplierCoilNo">{{ coil.supplierCoilNo || '—' }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="info-coil">
|
||||||
|
<span class="info-label">库位:</span>
|
||||||
|
<span class="info-value" :title="coil.warehouseName">{{ coil.warehouseName || '—' }}</span>
|
||||||
|
</div>
|
||||||
|
<div class="info-coil">
|
||||||
|
<span class="info-label">库区:</span>
|
||||||
|
<span class="info-value" :title="coil.actualWarehouseName">{{ coil.actualWarehouseName || '—'
|
||||||
|
}}</span>
|
||||||
|
</div>
|
||||||
|
<div class="info-coil">
|
||||||
|
<span class="info-label">重量:</span>
|
||||||
|
<span class="info-value">{{ coil.netWeight || '—' }}t</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</slot>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="card-footer">
|
||||||
|
<slot name="footer"></slot>
|
||||||
|
<!-- <el-button v-if="useSpecialSplit" :style="splitButtonStyle" icon="el-icon-scissors" size="mini"
|
||||||
|
@click="handleStartSplit(coil)" :loading="buttonLoading" class="action-btn">加工</el-button>
|
||||||
|
<el-button v-else type="primary" icon="el-icon-check" size="mini" @click="handlePickMaterial(coil)"
|
||||||
|
:loading="buttonLoading" class="action-btn">领料</el-button>
|
||||||
|
<el-button type="danger" icon="el-icon-alarm-clock" :plain="coil.abnormalCount == 0" size="mini"
|
||||||
|
@click="handleAddAbnormal(coil)" :loading="buttonLoading" class="action-btn">
|
||||||
|
缺陷明细
|
||||||
|
<span v-if="coil.abnormalCount > 0">({{ coil.abnormalCount }})</span>
|
||||||
|
</el-button> -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'CoilCard',
|
||||||
|
props: {
|
||||||
|
coil: {
|
||||||
|
type: Object,
|
||||||
|
default: () => { }
|
||||||
|
},
|
||||||
|
cardStyle: {
|
||||||
|
type: Object,
|
||||||
|
default: () => { }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.material-card {
|
||||||
|
background-color: #ffffff;
|
||||||
|
border: 1px solid #e4e7ed;
|
||||||
|
border-radius: 3px;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
transition: all 0.3s ease;
|
||||||
|
height: 100%;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
border-color: #409eff;
|
||||||
|
box-shadow: 0 2px 6px rgba(64, 158, 255, 0.12);
|
||||||
|
}
|
||||||
|
|
||||||
|
.card-header {
|
||||||
|
padding: 6px 8px;
|
||||||
|
border-bottom: 1px solid #e4e7ed;
|
||||||
|
background-color: #fafafa;
|
||||||
|
|
||||||
|
.header-left {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
gap: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.coil-no-tag {
|
||||||
|
font-weight: 600;
|
||||||
|
font-size: 11px;
|
||||||
|
padding: 2px 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.material-type {
|
||||||
|
font-size: 11px;
|
||||||
|
color: #606266;
|
||||||
|
font-weight: 500;
|
||||||
|
}
|
||||||
|
|
||||||
|
.param-icon {
|
||||||
|
font-size: 13px;
|
||||||
|
color: #909399;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: color 0.3s;
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
color: #409eff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.card-body {
|
||||||
|
padding: 8px;
|
||||||
|
flex: 1;
|
||||||
|
|
||||||
|
.info-list {
|
||||||
|
.info-item {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
margin-bottom: 4px;
|
||||||
|
font-size: 11px;
|
||||||
|
line-height: 1.4;
|
||||||
|
|
||||||
|
&:last-child {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.info-label {
|
||||||
|
color: #909399;
|
||||||
|
white-space: nowrap;
|
||||||
|
margin-right: 4px;
|
||||||
|
min-width: 40px;
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.info-value {
|
||||||
|
color: #303133;
|
||||||
|
flex: 1;
|
||||||
|
overflow: hidden;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.card-footer {
|
||||||
|
padding: 6px 8px;
|
||||||
|
border-top: 1px solid #e4e7ed;
|
||||||
|
background-color: #fafafa;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
|
||||||
|
.action-btn {
|
||||||
|
width: 100%;
|
||||||
|
padding: 5px 10px;
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
@@ -50,126 +50,16 @@
|
|||||||
<i class="el-icon-box"></i>
|
<i class="el-icon-box"></i>
|
||||||
<p>暂无待领物料</p>
|
<p>暂无待领物料</p>
|
||||||
</div>
|
</div>
|
||||||
<div v-for="(item, index) in materialCoilList" :key="item.coilId || index" class="material-card"
|
<coil-card v-for="(item, index) in materialCoilList" :key="item.coilId || index" :coil="item"
|
||||||
:style="getBorderStyle(item)">
|
:card-style="getBorderStyle(item)">
|
||||||
<div class="card-header">
|
<template slot="header">
|
||||||
<div class="header-left">
|
|
||||||
<current-coil-no :current-coil-no="item.currentCoilNo"></current-coil-no>
|
|
||||||
<el-tag type="info" size="small" class="coil-no-tag" :style="getBorderStyle(item)">{{
|
<el-tag type="info" size="small" class="coil-no-tag" :style="getBorderStyle(item)">{{
|
||||||
getTypeLabel(item) }}</el-tag>
|
getTypeLabel(item) }}</el-tag>
|
||||||
<span class="material-type">{{ item.materialType || '原料' }}</span>
|
<span class="material-type">{{ item.materialType || '原料' }}</span>
|
||||||
<el-popover placement="top" width="280" trigger="hover" popper-class="material-params-popover">
|
|
||||||
<div class="material-params-content">
|
|
||||||
<div class="params-title">
|
|
||||||
{{ item.itemName || '—' }}
|
|
||||||
</div>
|
|
||||||
<div class="params-list">
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.specification">
|
|
||||||
<span class="param-label">规格:</span>
|
|
||||||
<span class="param-value">{{ item.specification }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.material">
|
|
||||||
<span class="param-label">材质:</span>
|
|
||||||
<span class="param-value">{{ item.material }}</span>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="param-row" v-if="item.surfaceTreatmentDesc">
|
|
||||||
<span class="param-label">表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.surfaceTreatmentDesc }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.zincLayer">
|
|
||||||
<span class="param-label">镀层质量:</span>
|
|
||||||
<span class="param-value">{{ item.zincLayer }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.manufacturer">
|
|
||||||
<span class="param-label">厂家:</span>
|
|
||||||
<span class="param-value">{{ item.manufacturer }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="param-divider"></div>
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.qualityStatus">
|
|
||||||
<span class="param-label">质量状态:</span>
|
|
||||||
<span class="param-value">{{ item.qualityStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.trimmingRequirement">
|
|
||||||
<span class="param-label">切边要求:</span>
|
|
||||||
<span class="param-value">{{ item.trimmingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packingStatus">
|
|
||||||
<span class="param-label">原料材质:</span>
|
|
||||||
<span class="param-value">{{ item.packingStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packagingRequirement">
|
|
||||||
<span class="param-label">包装要求:</span>
|
|
||||||
<span class="param-value">{{ item.packagingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.grossWeight">
|
|
||||||
<span class="param-label">毛重:</span>
|
|
||||||
<span class="param-value">{{ item.grossWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.netWeight">
|
|
||||||
<span class="param-label">净重:</span>
|
|
||||||
<span class="param-value">{{ item.netWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.length">
|
|
||||||
<span class="param-label">长度:</span>
|
|
||||||
<span class="param-value">{{ item.length }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualLength">
|
|
||||||
<span class="param-label">实测长度:</span>
|
|
||||||
<span class="param-value">{{ item.actualLength }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualThickness">
|
|
||||||
<span class="param-label">实测厚度:</span>
|
|
||||||
<span class="param-value">{{ item.actualThickness }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualWidth">
|
|
||||||
<span class="param-label">实测宽度:</span>
|
|
||||||
<span class="param-value">{{ item.actualWidth }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.temperGrade">
|
|
||||||
<span class="param-label">调制度:</span>
|
|
||||||
<span class="param-value">{{ item.temperGrade }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coatingType">
|
|
||||||
<span class="param-label">镀层种类:</span>
|
|
||||||
<span class="param-value">{{ item.coatingType }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coilSurfaceTreatment">
|
|
||||||
<span class="param-label">钢卷表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.coilSurfaceTreatment }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.team">
|
|
||||||
<span class="param-label">班组:</span>
|
|
||||||
<span class="param-value">{{ item.team }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateTime">
|
|
||||||
<span class="param-label">更新时间:</span>
|
|
||||||
<span class="param-value">{{ parseTime(item.updateTime, '{y}-{m}-{d} {h}:{i}') }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateBy">
|
|
||||||
<span class="param-label">更新人:</span>
|
|
||||||
<span class="param-value">{{ item.updateBy }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.remark">
|
|
||||||
<span class="param-label">备注:</span>
|
|
||||||
<span class="param-value">{{ item.remark }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<i slot="reference" class="el-icon-setting param-icon"></i>
|
|
||||||
</el-popover>
|
|
||||||
|
|
||||||
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
||||||
|
|
||||||
<i class="el-icon-time param-icon" @click="handleTrace(item)" title="追溯"></i>
|
<i class="el-icon-time param-icon" @click="handleTrace(item)" title="追溯"></i>
|
||||||
</div>
|
</template>
|
||||||
</div>
|
<template slot="body">
|
||||||
|
|
||||||
<div class="card-body" style="position: relative;">
|
|
||||||
<div class="info-list">
|
<div class="info-list">
|
||||||
<div class="info-item">
|
<div class="info-item">
|
||||||
<span class="info-label">入场:</span>
|
<span class="info-label">入场:</span>
|
||||||
@@ -201,20 +91,14 @@
|
|||||||
style="position: absolute; bottom: 10px; right: 10px;" type="success" icon="el-icon-refresh"
|
style="position: absolute; bottom: 10px; right: 10px;" type="success" icon="el-icon-refresh"
|
||||||
size="mini" @click="handleForceInMaterial(item)" :loading="item.cancelling"
|
size="mini" @click="handleForceInMaterial(item)" :loading="item.cancelling"
|
||||||
class="action-btn">强制入库</el-button>
|
class="action-btn">强制入库</el-button>
|
||||||
</div>
|
</template>
|
||||||
|
<template slot="footer">
|
||||||
<div class="card-footer">
|
|
||||||
<el-button type="primary" icon="el-icon-check" size="mini" @click="handleCorrectMaterial(item)"
|
<el-button type="primary" icon="el-icon-check" size="mini" @click="handleCorrectMaterial(item)"
|
||||||
:loading="item.picking" class="action-btn">修正</el-button>
|
:loading="item.picking" class="action-btn">修正</el-button>
|
||||||
<el-button type="danger" icon="el-icon-delete" size="mini" @click="hanleDeleteMaterial(item)"
|
<el-button type="danger" icon="el-icon-delete" size="mini" @click="hanleDeleteMaterial(item)"
|
||||||
:loading="item.picking" class="action-btn">删除</el-button>
|
:loading="item.picking" class="action-btn">删除</el-button>
|
||||||
<!-- <el-button type="warning" icon="el-icon-alarm-clock" :plain="item.abnormalCount == 0" size="mini"
|
</template>
|
||||||
@click="handleAddAbnormal(item)" :loading="item.cancelling" class="action-btn">
|
</coil-card>
|
||||||
异常
|
|
||||||
<span v-if="item.abnormalCount > 0">({{ item.abnormalCount }})</span>
|
|
||||||
</el-button> -->
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 分页 -->
|
<!-- 分页 -->
|
||||||
@@ -396,6 +280,7 @@ import { listPendingAction, startProcess, cancelAction, delPendingAction } from
|
|||||||
import { parseTime } from '@/utils/klp'
|
import { parseTime } from '@/utils/klp'
|
||||||
import ProductInfo from '@/components/KLPService/Renderer/ProductInfo'
|
import ProductInfo from '@/components/KLPService/Renderer/ProductInfo'
|
||||||
import RawMaterialInfo from '@/components/KLPService/Renderer/RawMaterialInfo'
|
import RawMaterialInfo from '@/components/KLPService/Renderer/RawMaterialInfo'
|
||||||
|
import CoilCard from '@/components/KLPService/Renderer/CoilCard.vue'
|
||||||
import { addCoilAbnormal } from '@/api/wms/coilAbnormal'
|
import { addCoilAbnormal } from '@/api/wms/coilAbnormal'
|
||||||
import LabelRender from '../panels/LabelRender/index.vue'
|
import LabelRender from '../panels/LabelRender/index.vue'
|
||||||
import WarehouseSelect from "@/components/KLPService/WarehouseSelect";
|
import WarehouseSelect from "@/components/KLPService/WarehouseSelect";
|
||||||
@@ -421,6 +306,7 @@ export default {
|
|||||||
components: {
|
components: {
|
||||||
ProductInfo,
|
ProductInfo,
|
||||||
RawMaterialInfo,
|
RawMaterialInfo,
|
||||||
|
CoilCard,
|
||||||
LabelRender,
|
LabelRender,
|
||||||
WarehouseSelect,
|
WarehouseSelect,
|
||||||
ActualWarehouseSelect,
|
ActualWarehouseSelect,
|
||||||
@@ -1151,44 +1037,6 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 物料卡片
|
|
||||||
.material-card {
|
|
||||||
background-color: #ffffff;
|
|
||||||
border: 1px solid #e4e7ed;
|
|
||||||
border-radius: 3px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #409eff;
|
|
||||||
box-shadow: 0 2px 6px rgba(64, 158, 255, 0.12);
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-header {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-bottom: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
|
|
||||||
.header-left {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.coil-no-tag {
|
|
||||||
font-weight: 600;
|
|
||||||
font-size: 11px;
|
|
||||||
padding: 2px 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.material-type {
|
|
||||||
font-size: 11px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
|
|
||||||
.param-icon {
|
.param-icon {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
color: #909399;
|
color: #909399;
|
||||||
@@ -1199,11 +1047,18 @@ export default {
|
|||||||
color: #409eff;
|
color: #409eff;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.material-type {
|
||||||
|
font-size: 11px;
|
||||||
|
color: #606266;
|
||||||
|
font-weight: 500;
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-body {
|
.coil-no-tag {
|
||||||
padding: 8px;
|
font-weight: 600;
|
||||||
flex: 1;
|
font-size: 11px;
|
||||||
|
padding: 2px 6px;
|
||||||
|
}
|
||||||
|
|
||||||
.info-list {
|
.info-list {
|
||||||
.info-item {
|
.info-item {
|
||||||
@@ -1235,130 +1090,6 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
.card-footer {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-top: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
.action-btn {
|
|
||||||
width: 100%;
|
|
||||||
padding: 5px 10px;
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 待操作卡片
|
|
||||||
.action-card {
|
|
||||||
background-color: #ffffff;
|
|
||||||
border: 1px solid #e4e7ed;
|
|
||||||
border-radius: 4px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #67c23a;
|
|
||||||
box-shadow: 0 2px 8px rgba(103, 194, 58, 0.15);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.urgent-card {
|
|
||||||
border-left: 4px solid #f56c6c;
|
|
||||||
background-color: #fef0f0;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #f56c6c;
|
|
||||||
box-shadow: 0 2px 8px rgba(245, 108, 108, 0.2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.important-card {
|
|
||||||
border-left: 4px solid #e6a23c;
|
|
||||||
background-color: #fdf6ec;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #e6a23c;
|
|
||||||
box-shadow: 0 2px 8px rgba(230, 162, 60, 0.2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-header {
|
|
||||||
padding: 10px 12px;
|
|
||||||
border-bottom: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
display: flex;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items: center;
|
|
||||||
|
|
||||||
.coil-no-tag {
|
|
||||||
font-weight: 600;
|
|
||||||
font-size: 12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.status-tags {
|
|
||||||
display: flex;
|
|
||||||
gap: 4px;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-body {
|
|
||||||
padding: 12px;
|
|
||||||
flex: 1;
|
|
||||||
|
|
||||||
.info-list {
|
|
||||||
.info-item {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
margin-bottom: 8px;
|
|
||||||
font-size: 12px;
|
|
||||||
|
|
||||||
&:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.info-label {
|
|
||||||
color: #909399;
|
|
||||||
white-space: nowrap;
|
|
||||||
margin-right: 6px;
|
|
||||||
min-width: 50px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.info-value {
|
|
||||||
color: #303133;
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
.action-type-tag {
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-footer {
|
|
||||||
padding: 10px 12px;
|
|
||||||
border-top: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
gap: 6px;
|
|
||||||
|
|
||||||
.action-btn {
|
|
||||||
flex: 1;
|
|
||||||
font-size: 12px;
|
|
||||||
padding: 6px 8px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 分页样式
|
// 分页样式
|
||||||
::v-deep .pagination-container {
|
::v-deep .pagination-container {
|
||||||
|
|||||||
@@ -41,126 +41,16 @@
|
|||||||
<i class="el-icon-box"></i>
|
<i class="el-icon-box"></i>
|
||||||
<p>未找到钢卷数据</p>
|
<p>未找到钢卷数据</p>
|
||||||
</div>
|
</div>
|
||||||
<div v-for="(item, index) in materialCoilList" :key="item.coilId || index" class="material-card"
|
<coil-card v-for="(item, index) in materialCoilList" :key="item.coilId || index" :coil="item"
|
||||||
:style="getBorderStyle(item)">
|
:card-style="getBorderStyle(item)">
|
||||||
<div class="card-header">
|
<template slot="header">
|
||||||
<div class="header-left">
|
|
||||||
<current-coil-no :current-coil-no="item.currentCoilNo"></current-coil-no>
|
|
||||||
<el-tag type="info" size="small" class="coil-no-tag" :style="getBorderStyle(item)">{{
|
<el-tag type="info" size="small" class="coil-no-tag" :style="getBorderStyle(item)">{{
|
||||||
getTypeLabel(item) }}</el-tag>
|
getTypeLabel(item) }}</el-tag>
|
||||||
<span class="material-type">{{ item.materialType || '原料' }}</span>
|
<span class="material-type">{{ item.materialType || '原料' }}</span>
|
||||||
<el-popover placement="top" width="280" trigger="hover" popper-class="material-params-popover">
|
|
||||||
<div class="material-params-content">
|
|
||||||
<div class="params-title">
|
|
||||||
{{ item.itemName || '—' }}
|
|
||||||
</div>
|
|
||||||
<div class="params-list">
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.specification">
|
|
||||||
<span class="param-label">规格:</span>
|
|
||||||
<span class="param-value">{{ item.specification }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.material">
|
|
||||||
<span class="param-label">材质:</span>
|
|
||||||
<span class="param-value">{{ item.material }}</span>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="param-row" v-if="item.surfaceTreatmentDesc">
|
|
||||||
<span class="param-label">表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.surfaceTreatmentDesc }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.zincLayer">
|
|
||||||
<span class="param-label">镀层质量:</span>
|
|
||||||
<span class="param-value">{{ item.zincLayer }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.manufacturer">
|
|
||||||
<span class="param-label">厂家:</span>
|
|
||||||
<span class="param-value">{{ item.manufacturer }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="param-divider"></div>
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.qualityStatus">
|
|
||||||
<span class="param-label">质量状态:</span>
|
|
||||||
<span class="param-value">{{ item.qualityStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.trimmingRequirement">
|
|
||||||
<span class="param-label">切边要求:</span>
|
|
||||||
<span class="param-value">{{ item.trimmingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packingStatus">
|
|
||||||
<span class="param-label">原料材质:</span>
|
|
||||||
<span class="param-value">{{ item.packingStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packagingRequirement">
|
|
||||||
<span class="param-label">包装要求:</span>
|
|
||||||
<span class="param-value">{{ item.packagingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.grossWeight">
|
|
||||||
<span class="param-label">毛重:</span>
|
|
||||||
<span class="param-value">{{ item.grossWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.netWeight">
|
|
||||||
<span class="param-label">净重:</span>
|
|
||||||
<span class="param-value">{{ item.netWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.length">
|
|
||||||
<span class="param-label">长度:</span>
|
|
||||||
<span class="param-value">{{ item.length }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualLength">
|
|
||||||
<span class="param-label">实测长度:</span>
|
|
||||||
<span class="param-value">{{ item.actualLength }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualThickness">
|
|
||||||
<span class="param-label">实测厚度:</span>
|
|
||||||
<span class="param-value">{{ item.actualThickness }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualWidth">
|
|
||||||
<span class="param-label">实测宽度:</span>
|
|
||||||
<span class="param-value">{{ item.actualWidth }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.temperGrade">
|
|
||||||
<span class="param-label">调制度:</span>
|
|
||||||
<span class="param-value">{{ item.temperGrade }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coatingType">
|
|
||||||
<span class="param-label">镀层种类:</span>
|
|
||||||
<span class="param-value">{{ item.coatingType }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coilSurfaceTreatment">
|
|
||||||
<span class="param-label">钢卷表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.coilSurfaceTreatment }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.team">
|
|
||||||
<span class="param-label">班组:</span>
|
|
||||||
<span class="param-value">{{ item.team }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateTime">
|
|
||||||
<span class="param-label">更新时间:</span>
|
|
||||||
<span class="param-value">{{ parseTime(item.updateTime, '{y}-{m}-{d} {h}:{i}') }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateBy">
|
|
||||||
<span class="param-label">更新人:</span>
|
|
||||||
<span class="param-value">{{ item.updateBy }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.remark">
|
|
||||||
<span class="param-label">备注:</span>
|
|
||||||
<span class="param-value">{{ item.remark }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<i slot="reference" class="el-icon-setting param-icon"></i>
|
|
||||||
</el-popover>
|
|
||||||
|
|
||||||
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
||||||
|
|
||||||
<i class="el-icon-time param-icon" @click="handleTrace(item)" title="追溯"></i>
|
<i class="el-icon-time param-icon" @click="handleTrace(item)" title="追溯"></i>
|
||||||
</div>
|
</template>
|
||||||
</div>
|
<template slot="body">
|
||||||
|
|
||||||
<div class="card-body" style="position: relative;">
|
|
||||||
<div class="info-list">
|
<div class="info-list">
|
||||||
<div class="info-item">
|
<div class="info-item">
|
||||||
<span class="info-label">入场:</span>
|
<span class="info-label">入场:</span>
|
||||||
@@ -190,13 +80,12 @@
|
|||||||
<el-button v-if="item.dataType == 10 && item.status == 0"
|
<el-button v-if="item.dataType == 10 && item.status == 0"
|
||||||
style="position: absolute; bottom: 10px; right: 10px;" type="success" icon="el-icon-refresh" size="mini"
|
style="position: absolute; bottom: 10px; right: 10px;" type="success" icon="el-icon-refresh" size="mini"
|
||||||
@click="handleForceInMaterial(item)" :loading="item.cancelling" class="action-btn">强制入库</el-button>
|
@click="handleForceInMaterial(item)" :loading="item.cancelling" class="action-btn">强制入库</el-button>
|
||||||
</div>
|
</template>
|
||||||
|
<template slot="footer">
|
||||||
<div class="card-footer">
|
|
||||||
<el-button type="primary" icon="el-icon-check" size="mini" @click="handleCorrectMaterial(item)"
|
<el-button type="primary" icon="el-icon-check" size="mini" @click="handleCorrectMaterial(item)"
|
||||||
:loading="item.picking" class="action-btn">修正</el-button>
|
:loading="item.picking" class="action-btn">修正</el-button>
|
||||||
</div>
|
</template>
|
||||||
</div>
|
</coil-card>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -468,6 +357,7 @@ import { listMaterialCoil, getMaterialCoilTrace, updateMaterialCoilSimple, check
|
|||||||
import { listPendingAction, getPendingAction, delPendingAction, addPendingAction, updatePendingAction, startProcess, cancelAction, restorePendingAction } from '@/api/wms/pendingAction'
|
import { listPendingAction, getPendingAction, delPendingAction, addPendingAction, updatePendingAction, startProcess, cancelAction, restorePendingAction } from '@/api/wms/pendingAction'
|
||||||
import { listUser } from '@/api/system/user'
|
import { listUser } from '@/api/system/user'
|
||||||
import { parseTime } from '@/utils/klp'
|
import { parseTime } from '@/utils/klp'
|
||||||
|
import CoilCard from '@/components/KLPService/Renderer/CoilCard.vue'
|
||||||
import LabelRender from '../panels/LabelRender/index.vue'
|
import LabelRender from '../panels/LabelRender/index.vue'
|
||||||
import WarehouseSelect from "@/components/KLPService/WarehouseSelect";
|
import WarehouseSelect from "@/components/KLPService/WarehouseSelect";
|
||||||
import ActualWarehouseSelect from "@/components/KLPService/ActualWarehouseSelect";
|
import ActualWarehouseSelect from "@/components/KLPService/ActualWarehouseSelect";
|
||||||
@@ -482,6 +372,7 @@ export default {
|
|||||||
name: 'CorrentAllPage',
|
name: 'CorrentAllPage',
|
||||||
dicts: ['action_type', 'coil_quality_status', 'coil_business_purpose'],
|
dicts: ['action_type', 'coil_quality_status', 'coil_business_purpose'],
|
||||||
components: {
|
components: {
|
||||||
|
CoilCard,
|
||||||
LabelRender,
|
LabelRender,
|
||||||
WarehouseSelect,
|
WarehouseSelect,
|
||||||
ActualWarehouseSelect,
|
ActualWarehouseSelect,
|
||||||
@@ -1250,44 +1141,6 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 物料卡片
|
|
||||||
.material-card {
|
|
||||||
background-color: #ffffff;
|
|
||||||
border: 1px solid #e4e7ed;
|
|
||||||
border-radius: 3px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #409eff;
|
|
||||||
box-shadow: 0 2px 6px rgba(64, 158, 255, 0.12);
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-header {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-bottom: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
|
|
||||||
.header-left {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.coil-no-tag {
|
|
||||||
font-weight: 600;
|
|
||||||
font-size: 11px;
|
|
||||||
padding: 2px 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.material-type {
|
|
||||||
font-size: 11px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
|
|
||||||
.param-icon {
|
.param-icon {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
color: #909399;
|
color: #909399;
|
||||||
@@ -1298,11 +1151,18 @@ export default {
|
|||||||
color: #409eff;
|
color: #409eff;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.material-type {
|
||||||
|
font-size: 11px;
|
||||||
|
color: #606266;
|
||||||
|
font-weight: 500;
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-body {
|
.coil-no-tag {
|
||||||
padding: 8px;
|
font-weight: 600;
|
||||||
flex: 1;
|
font-size: 11px;
|
||||||
|
padding: 2px 6px;
|
||||||
|
}
|
||||||
|
|
||||||
.info-list {
|
.info-list {
|
||||||
.info-item {
|
.info-item {
|
||||||
@@ -1334,22 +1194,6 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
.card-footer {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-top: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
.action-btn {
|
|
||||||
width: 100%;
|
|
||||||
padding: 5px 10px;
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 分页样式
|
// 分页样式
|
||||||
::v-deep .pagination-container {
|
::v-deep .pagination-container {
|
||||||
|
|||||||
@@ -63,7 +63,7 @@
|
|||||||
],
|
],
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.actionType === '镀锌工序' || this.actionType === '脱脂工序' || this.actionType === '拉矫平整工序' || this.actionType === '双机架工序' || this.actionType === '镀铬工序' || this.actionType === '纵剪分条工序') {
|
if (this.actionType === '镀锌工序' || this.actionType === '脱脂工序' || this.actionType === '拉矫平整工序' || this.actionType === '双机架工序' || this.actionType === '镀铬工序' || this.actionType === '纵剪分条工序' || this.actionType === '拉矫修复工序') {
|
||||||
this.useSpecialSplit = true
|
this.useSpecialSplit = true
|
||||||
}
|
}
|
||||||
// 从map中获取默认的查询参数
|
// 从map中获取默认的查询参数
|
||||||
|
|||||||
@@ -48,6 +48,13 @@
|
|||||||
<MaterialSelect :hideType="hideType" :itemId.sync="queryParams.itemIds" :itemType.sync="queryParams.itemType"
|
<MaterialSelect :hideType="hideType" :itemId.sync="queryParams.itemIds" :itemType.sync="queryParams.itemType"
|
||||||
:multiple="true" />
|
:multiple="true" />
|
||||||
|
|
||||||
|
<el-form-item v-if="showWaybill" label="发货状态">
|
||||||
|
<el-select v-model="queryParams.status" placeholder="请选择发货状态" clearable>
|
||||||
|
<el-option :value="0" label="未发货">未发货</el-option>
|
||||||
|
<el-option :value="1" label="已发货">已发货</el-option>
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item v-if="showWaybill" label="发货单时间">
|
<el-form-item v-if="showWaybill" label="发货单时间">
|
||||||
<el-date-picker v-model="queryParams.shipmentTime" type="daterange" value-format="yyyy-MM-dd HH:mm:ss"
|
<el-date-picker v-model="queryParams.shipmentTime" type="daterange" value-format="yyyy-MM-dd HH:mm:ss"
|
||||||
range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" />
|
range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" />
|
||||||
|
|||||||
@@ -37,152 +37,14 @@
|
|||||||
<p>暂无待领物料</p>
|
<p>暂无待领物料</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div v-for="(item, index) in materialCoilList" :key="item.coilId || index" class="material-card"
|
<coil-card v-for="(item, index) in materialCoilList" :key="item.coilId || index" :coil="item"
|
||||||
:style="{ border: item.abnormalCount > 0 ? '1px solid red' : ' 1px solid #e4e7ed' }">
|
:card-style="{ border: item.abnormalCount > 0 ? '1px solid red' : ' 1px solid #e4e7ed' }">
|
||||||
<div class="card-header">
|
<template slot="header">
|
||||||
<div class="header-left">
|
|
||||||
<current-coil-no :current-coil-no="item.currentCoilNo"></current-coil-no>
|
|
||||||
<!-- <span class="material-type">{{ item.materialType || '原料' }}</span> -->
|
|
||||||
<el-popover placement="top" width="280" trigger="hover"
|
|
||||||
popper-class="material-params-popover">
|
|
||||||
<div class="material-params-content">
|
|
||||||
<div class="params-title">
|
|
||||||
{{ item.itemName || '—' }}
|
|
||||||
</div>
|
|
||||||
<div class="params-list">
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.specification">
|
|
||||||
<span class="param-label">规格:</span>
|
|
||||||
<span class="param-value">{{ item.specification }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.material">
|
|
||||||
<span class="param-label">材质:</span>
|
|
||||||
<span class="param-value">{{ item.material }}</span>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="param-row" v-if="item.surfaceTreatmentDesc">
|
|
||||||
<span class="param-label">表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.surfaceTreatmentDesc }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.zincLayer">
|
|
||||||
<span class="param-label">镀层质量:</span>
|
|
||||||
<span class="param-value">{{ item.zincLayer }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.manufacturer">
|
|
||||||
<span class="param-label">厂家:</span>
|
|
||||||
<span class="param-value">{{ item.manufacturer }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="param-divider"></div>
|
|
||||||
<div class="param-item">
|
|
||||||
<div class="param-row" v-if="item.qualityStatus">
|
|
||||||
<span class="param-label">质量状态:</span>
|
|
||||||
<span class="param-value">{{ item.qualityStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.trimmingRequirement">
|
|
||||||
<span class="param-label">切边要求:</span>
|
|
||||||
<span class="param-value">{{ item.trimmingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packingStatus">
|
|
||||||
<span class="param-label">原料材质:</span>
|
|
||||||
<span class="param-value">{{ item.packingStatus }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.packagingRequirement">
|
|
||||||
<span class="param-label">包装要求:</span>
|
|
||||||
<span class="param-value">{{ item.packagingRequirement }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.grossWeight">
|
|
||||||
<span class="param-label">毛重:</span>
|
|
||||||
<span class="param-value">{{ item.grossWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.netWeight">
|
|
||||||
<span class="param-label">净重:</span>
|
|
||||||
<span class="param-value">{{ item.netWeight }}t</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.length">
|
|
||||||
<span class="param-label">长度:</span>
|
|
||||||
<span class="param-value">{{ item.length }}米</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualLength">
|
|
||||||
<span class="param-label">实测长度:</span>
|
|
||||||
<span class="param-value">{{ item.actualLength }}米</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualThickness">
|
|
||||||
<span class="param-label">实测厚度:</span>
|
|
||||||
<span class="param-value">{{ item.actualThickness }}米</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.actualWidth">
|
|
||||||
<span class="param-label">实测宽度:</span>
|
|
||||||
<span class="param-value">{{ item.actualWidth }}米</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.temperGrade">
|
|
||||||
<span class="param-label">调制度:</span>
|
|
||||||
<span class="param-value">{{ item.temperGrade }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coatingType">
|
|
||||||
<span class="param-label">镀层种类:</span>
|
|
||||||
<span class="param-value">{{ item.coatingType }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.coilSurfaceTreatment">
|
|
||||||
<span class="param-label">钢卷表面处理:</span>
|
|
||||||
<span class="param-value">{{ item.coilSurfaceTreatment }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.team">
|
|
||||||
<span class="param-label">班组:</span>
|
|
||||||
<span class="param-value">{{ item.team }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateTime">
|
|
||||||
<span class="param-label">更新时间:</span>
|
|
||||||
<span class="param-value">{{ parseTime(item.updateTime, '{y}-{m}-{d} {h}:{i}') }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.updateBy">
|
|
||||||
<span class="param-label">更新人:</span>
|
|
||||||
<span class="param-value">{{ item.updateBy }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="param-row" v-if="item.remark">
|
|
||||||
<span class="param-label">备注:</span>
|
|
||||||
<span class="param-value">{{ item.remark }}</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<i slot="reference" class="el-icon-setting param-icon"></i>
|
|
||||||
</el-popover>
|
|
||||||
|
|
||||||
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
<i class="el-icon-view param-icon" @click="handlePreviewLabel(item)" title="查看标签"></i>
|
||||||
<!-- <el-button style="margin-left: 0px; padding: 4px !important;" type="text" size="mini" @click="handlePreviewLabel(item)" title="查看标签">预览</el-button> -->
|
|
||||||
<el-button v-loading="buttonLoading" style="margin-left: 0px; padding: 4px !important;" type="text"
|
<el-button v-loading="buttonLoading" style="margin-left: 0px; padding: 4px !important;" type="text"
|
||||||
size="mini" @click="handlePrintLabel(item)" title="打印标签">打印</el-button>
|
size="mini" @click="handlePrintLabel(item)" title="打印标签">打印</el-button>
|
||||||
</div>
|
</template>
|
||||||
</div>
|
<template slot="footer">
|
||||||
|
|
||||||
<div class="card-body" style="position: relative;">
|
|
||||||
<div class="info-list">
|
|
||||||
<div class="info-item">
|
|
||||||
<span class="info-label">入场:</span>
|
|
||||||
<span class="info-value" :title="item.enterCoilNo">{{ item.enterCoilNo || '—' }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="info-item">
|
|
||||||
<span class="info-label">厂家:</span>
|
|
||||||
<span class="info-value" :title="item.supplierCoilNo">{{ item.supplierCoilNo || '—' }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="info-item">
|
|
||||||
<span class="info-label">库位:</span>
|
|
||||||
<span class="info-value" :title="item.warehouseName">{{ item.warehouseName || '—' }}</span>
|
|
||||||
</div>
|
|
||||||
<div class="info-item">
|
|
||||||
<span class="info-label">库区:</span>
|
|
||||||
<span class="info-value" :title="item.actualWarehouseName">{{ item.actualWarehouseName || '—'
|
|
||||||
}}</span>
|
|
||||||
</div>
|
|
||||||
<div class="info-item">
|
|
||||||
<span class="info-label">重量:</span>
|
|
||||||
<span class="info-value">{{ item.netWeight || '—' }}t</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="card-footer">
|
|
||||||
<el-button v-if="useSpecialSplit" :style="splitButtonStyle" icon="el-icon-scissors" size="mini"
|
<el-button v-if="useSpecialSplit" :style="splitButtonStyle" icon="el-icon-scissors" size="mini"
|
||||||
@click="handleStartSplit(item)" :loading="buttonLoading" class="action-btn">加工</el-button>
|
@click="handleStartSplit(item)" :loading="buttonLoading" class="action-btn">加工</el-button>
|
||||||
<el-button v-else type="primary" icon="el-icon-check" size="mini" @click="handlePickMaterial(item)"
|
<el-button v-else type="primary" icon="el-icon-check" size="mini" @click="handlePickMaterial(item)"
|
||||||
@@ -192,8 +54,8 @@
|
|||||||
缺陷明细
|
缺陷明细
|
||||||
<span v-if="item.abnormalCount > 0">({{ item.abnormalCount }})</span>
|
<span v-if="item.abnormalCount > 0">({{ item.abnormalCount }})</span>
|
||||||
</el-button>
|
</el-button>
|
||||||
</div>
|
</template>
|
||||||
</div>
|
</coil-card>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!-- 分页 -->
|
<!-- 分页 -->
|
||||||
@@ -438,6 +300,7 @@ import { listPendingAction, startProcess, cancelAction, delPendingAction, addPen
|
|||||||
import { parseTime } from '@/utils/klp'
|
import { parseTime } from '@/utils/klp'
|
||||||
import ProductInfo from '@/components/KLPService/Renderer/ProductInfo'
|
import ProductInfo from '@/components/KLPService/Renderer/ProductInfo'
|
||||||
import RawMaterialInfo from '@/components/KLPService/Renderer/RawMaterialInfo'
|
import RawMaterialInfo from '@/components/KLPService/Renderer/RawMaterialInfo'
|
||||||
|
import CoilCard from '@/components/KLPService/Renderer/CoilCard.vue'
|
||||||
import LabelRender from './LabelRender/index.vue'
|
import LabelRender from './LabelRender/index.vue'
|
||||||
import StepSplit from './stepSplit.vue'
|
import StepSplit from './stepSplit.vue'
|
||||||
import ExceptionManager from '../components/ExceptionManager'
|
import ExceptionManager from '../components/ExceptionManager'
|
||||||
@@ -463,6 +326,7 @@ export default {
|
|||||||
components: {
|
components: {
|
||||||
ProductInfo,
|
ProductInfo,
|
||||||
RawMaterialInfo,
|
RawMaterialInfo,
|
||||||
|
CoilCard,
|
||||||
LabelRender,
|
LabelRender,
|
||||||
StepSplit,
|
StepSplit,
|
||||||
ExceptionManager
|
ExceptionManager
|
||||||
@@ -502,36 +366,6 @@ export default {
|
|||||||
buttonLoading: false,
|
buttonLoading: false,
|
||||||
exceptionDialogVisible: false,
|
exceptionDialogVisible: false,
|
||||||
currentCoilId: null,
|
currentCoilId: null,
|
||||||
tagSizeMap: {
|
|
||||||
'2': {
|
|
||||||
width: 100,
|
|
||||||
height: 80,
|
|
||||||
},
|
|
||||||
'3': {
|
|
||||||
width: 180,
|
|
||||||
height: 100,
|
|
||||||
},
|
|
||||||
'4': {
|
|
||||||
width: 180,
|
|
||||||
height: 100,
|
|
||||||
},
|
|
||||||
'ge': {
|
|
||||||
width: 180,
|
|
||||||
height: 80,
|
|
||||||
},
|
|
||||||
'where': {
|
|
||||||
width: 100,
|
|
||||||
height: 80,
|
|
||||||
},
|
|
||||||
'5': {
|
|
||||||
width: 180,
|
|
||||||
height: 100,
|
|
||||||
},
|
|
||||||
'6': {
|
|
||||||
width: 180,
|
|
||||||
height: 100,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
stepSpilt: {
|
stepSpilt: {
|
||||||
list: [],
|
list: [],
|
||||||
loading: false,
|
loading: false,
|
||||||
@@ -591,7 +425,15 @@ export default {
|
|||||||
border: '1px solid #2bf',
|
border: '1px solid #2bf',
|
||||||
color: '#fff'
|
color: '#fff'
|
||||||
}
|
}
|
||||||
} else {
|
} else if (this.acidRollingActionType == 507) {
|
||||||
|
return {
|
||||||
|
// 亮粉色
|
||||||
|
backgroundColor: '#FFAACC',
|
||||||
|
border: '1px solid #FFAACC',
|
||||||
|
color: '#fff'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
return {}
|
return {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1098,43 +940,7 @@ export default {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 物料卡片
|
|
||||||
.material-card {
|
|
||||||
background-color: #ffffff;
|
|
||||||
border: 1px solid #e4e7ed;
|
|
||||||
border-radius: 3px;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
transition: all 0.3s ease;
|
|
||||||
height: 100%;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
border-color: #409eff;
|
|
||||||
box-shadow: 0 2px 6px rgba(64, 158, 255, 0.12);
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-header {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-bottom: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
|
|
||||||
.header-left {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
gap: 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.coil-no-tag {
|
|
||||||
font-weight: 600;
|
|
||||||
font-size: 11px;
|
|
||||||
padding: 2px 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.material-type {
|
|
||||||
font-size: 11px;
|
|
||||||
color: #606266;
|
|
||||||
font-weight: 500;
|
|
||||||
}
|
|
||||||
|
|
||||||
.param-icon {
|
.param-icon {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
@@ -1146,58 +952,6 @@ export default {
|
|||||||
color: #409eff;
|
color: #409eff;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
.card-body {
|
|
||||||
padding: 8px;
|
|
||||||
flex: 1;
|
|
||||||
|
|
||||||
.info-list {
|
|
||||||
.info-item {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
margin-bottom: 4px;
|
|
||||||
font-size: 11px;
|
|
||||||
line-height: 1.4;
|
|
||||||
|
|
||||||
&:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.info-label {
|
|
||||||
color: #909399;
|
|
||||||
white-space: nowrap;
|
|
||||||
margin-right: 4px;
|
|
||||||
min-width: 40px;
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.info-value {
|
|
||||||
color: #303133;
|
|
||||||
flex: 1;
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.card-footer {
|
|
||||||
padding: 6px 8px;
|
|
||||||
border-top: 1px solid #e4e7ed;
|
|
||||||
background-color: #fafafa;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
.action-btn {
|
|
||||||
width: 100%;
|
|
||||||
padding: 5px 10px;
|
|
||||||
font-size: 11px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// 待操作卡片
|
// 待操作卡片
|
||||||
.action-card {
|
.action-card {
|
||||||
|
|||||||
@@ -149,14 +149,14 @@
|
|||||||
v-if="scope.row.approveStatus == '1'"
|
v-if="scope.row.approveStatus == '1'"
|
||||||
icon="el-icon-refresh"
|
icon="el-icon-refresh"
|
||||||
>撤回</el-button>
|
>撤回</el-button>
|
||||||
<!-- <el-button
|
<el-button
|
||||||
size="mini"
|
size="mini"
|
||||||
type="text"
|
type="text"
|
||||||
plain
|
plain
|
||||||
@click="handleReSubmit(scope.row)"
|
@click="handleReSubmit(scope.row)"
|
||||||
v-if="scope.row.approveStatus == '3' || scope.row.approveStatus == '2'"
|
v-if="scope.row.approveStatus == '3'"
|
||||||
icon="el-icon-refresh"
|
icon="el-icon-refresh"
|
||||||
>二次调整</el-button> -->
|
>二次调整</el-button>
|
||||||
<el-button
|
<el-button
|
||||||
size="mini"
|
size="mini"
|
||||||
type="text"
|
type="text"
|
||||||
@@ -220,7 +220,7 @@
|
|||||||
<div style="margin-bottom: 10px; display: flex; align-items: center;">
|
<div style="margin-bottom: 10px; display: flex; align-items: center;">
|
||||||
<el-button icon="el-icon-download" type="warning" plain @click="handleExportDetail">导出</el-button>
|
<el-button icon="el-icon-download" type="warning" plain @click="handleExportDetail">导出</el-button>
|
||||||
<el-button style="margin-right: 10px;" icon="el-icon-refresh" type="success" plain @click="handleRefreshDetailList">刷新</el-button>
|
<el-button style="margin-right: 10px;" icon="el-icon-refresh" type="success" plain @click="handleRefreshDetailList">刷新</el-button>
|
||||||
<el-button :loading="buttonLoading" style="margin-right: 10px;" icon="el-icon-check" type="primary" plain @click="handleConfirmAll" v-if="currentOrderStatus == '2'">执行全部</el-button>
|
<!-- <el-button :loading="buttonLoading" style="margin-right: 10px;" icon="el-icon-check" type="primary" plain @click="handleConfirmAll" v-if="currentOrderStatus == '2'">执行全部</el-button> -->
|
||||||
<coil-selector v-loading="buttonLoading" ref="coilSelector" multiple @confirm="handleCoilChange" v-if="canAddCoils"></coil-selector>
|
<coil-selector v-loading="buttonLoading" ref="coilSelector" multiple @confirm="handleCoilChange" v-if="canAddCoils"></coil-selector>
|
||||||
</div>
|
</div>
|
||||||
<transfer-item-table ref="transferItemTable" :data="transferOrderItems" @refreshData="getDetailList" :orderStatus="currentOrderStatus" :canEdit="canAddCoils" />
|
<transfer-item-table ref="transferItemTable" :data="transferOrderItems" @refreshData="getDetailList" :orderStatus="currentOrderStatus" :canEdit="canAddCoils" />
|
||||||
@@ -410,7 +410,7 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 重新提交 */
|
/** 重新提交 */
|
||||||
handleReSubmit(row) {
|
handleReSubmit(row) {
|
||||||
this.$confirm('确定要重新提交审批吗?', '提示', {
|
this.$confirm('确定要调整后重新提交审批吗?', '提示', {
|
||||||
confirmButtonText: '确定',
|
confirmButtonText: '确定',
|
||||||
cancelButtonText: '取消',
|
cancelButtonText: '取消',
|
||||||
type: 'info'
|
type: 'info'
|
||||||
@@ -422,7 +422,7 @@ export default {
|
|||||||
...row,
|
...row,
|
||||||
approveStatus: '0',
|
approveStatus: '0',
|
||||||
}).then(response => {
|
}).then(response => {
|
||||||
this.$modal.msgSuccess('重新提交成功');
|
this.$modal.msgSuccess('请调整后重新提交审批');
|
||||||
this.getList();
|
this.getList();
|
||||||
}).finally(() => {
|
}).finally(() => {
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
|
|||||||
@@ -49,7 +49,7 @@
|
|||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="warehouseIdAfter" label="调拨后库区" width="200">
|
<el-table-column prop="warehouseIdAfter" label="调拨后库区" width="200">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-select v-if="!scope.row.isConfirmed && canEdit" v-model="scope.row.warehouseIdAfter" placeholder="请选择">
|
<el-select v-if="!scope.row.isConfirmed && canEdit" v-model="scope.row.warehouseIdAfter" @change="handleWarehouseChange(scope.row)" placeholder="请选择">
|
||||||
<el-option v-for="item in warehouseList" :disabled="!item.isEnabled" :key="item.warehouseId"
|
<el-option v-for="item in warehouseList" :disabled="!item.isEnabled" :key="item.warehouseId"
|
||||||
:label="item.warehouseName" :value="item.warehouseId" />
|
:label="item.warehouseName" :value="item.warehouseId" />
|
||||||
</el-select>
|
</el-select>
|
||||||
@@ -62,14 +62,14 @@
|
|||||||
<el-table-column type="action" label="操作" width="180">
|
<el-table-column type="action" label="操作" width="180">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<div v-if="orderStatus == 0">
|
<div v-if="orderStatus == 0">
|
||||||
<el-button icon="el-icon-check" size="mini" v-if="!scope.row.isConfirmed" @click="handleUpdate(scope.row)"
|
<!-- <el-button icon="el-icon-check" size="mini" v-if="!scope.row.isConfirmed" @click="handleUpdate(scope.row)"
|
||||||
:loading="buttonLoading">保存</el-button>
|
:loading="buttonLoading">保存</el-button> -->
|
||||||
<el-button icon="el-icon-close" size="mini" @click="handleCancel(scope.row)"
|
<el-button icon="el-icon-close" size="mini" @click="handleCancel(scope.row)"
|
||||||
:loading="buttonLoading">删除</el-button>
|
:loading="buttonLoading">删除</el-button>
|
||||||
</div>
|
</div>
|
||||||
<div v-else>
|
<div v-else>
|
||||||
<el-button icon="el-icon-check" size="mini" v-if="!scope.row.isConfirmed" @click="handleConfirm(scope.row)"
|
<!-- <el-button icon="el-icon-check" size="mini" v-if="!scope.row.isConfirmed" @click="handleConfirm(scope.row)"
|
||||||
:loading="buttonLoading" :disabled="orderStatus != '2'">执行</el-button>
|
:loading="buttonLoading" :disabled="orderStatus != '2'">执行</el-button> -->
|
||||||
<!-- <el-button icon="el-icon-close" size="mini" @click="handleCancel(scope.row)"
|
<!-- <el-button icon="el-icon-close" size="mini" @click="handleCancel(scope.row)"
|
||||||
:loading="buttonLoading" :disabled="orderStatus !== '2'">取消</el-button> -->
|
:loading="buttonLoading" :disabled="orderStatus !== '2'">取消</el-button> -->
|
||||||
</div>
|
</div>
|
||||||
@@ -278,10 +278,14 @@ export default {
|
|||||||
itemId: row.itemIdAfter
|
itemId: row.itemIdAfter
|
||||||
}).then(res => {
|
}).then(res => {
|
||||||
row.itemIdAfter = res.data
|
row.itemIdAfter = res.data
|
||||||
|
updateTransferOrderItem(row)
|
||||||
this.materialLoading = false
|
this.materialLoading = false
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
this.materialLoading = false
|
this.materialLoading = false
|
||||||
})
|
})
|
||||||
|
},
|
||||||
|
handleWarehouseChange(row) {
|
||||||
|
updateTransferOrderItem(row)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user