|
@@ -2,56 +2,118 @@
|
|
<div class="detail-container">
|
|
<div class="detail-container">
|
|
<el-page-header @back="goBack" content="详情"></el-page-header>
|
|
<el-page-header @back="goBack" content="详情"></el-page-header>
|
|
|
|
|
|
- <div id="printData">
|
|
|
|
|
|
+ <div class="main-title">
|
|
|
|
+ <div class="title">发货申请单信息</div>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <div class="diy-table-1">
|
|
|
|
+ <el-row>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">发货申请单号</div>
|
|
|
|
+ <div class="value">{{detailData.id}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">申请日期</div>
|
|
|
|
+ <div class="value">{{detailData.createTime}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">单据状态</div>
|
|
|
|
+ <div class="value">{{detailData.examineStatus | statusFilter}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">经销商编号</div>
|
|
|
|
+ <div class="value">{{detailData.customerNumber}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">经销商名称</div>
|
|
|
|
+ <div class="value">{{detailData.customerName}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="8" class="item">
|
|
|
|
+ <div class="label">仓库</div>
|
|
|
|
+ <div class="value">{{detailData.correspondName}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="24" class="item">
|
|
|
|
+ <div class="label">备注</div>
|
|
|
|
+ <div class="value">{{detailData.remark}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="24" class="item file">
|
|
|
|
+ <div class="label">附件</div>
|
|
|
|
+ <div class="value">
|
|
|
|
+ <div class="file-list">
|
|
|
|
+ <div class="file-item">
|
|
|
|
+ <el-image v-if="checkFileType(detailData.fileUrl) == 'image'" class="img" :src="imageURL + detailData.fileUrl" :preview-src-list="[imageURL + detailData.fileUrl]"></el-image>
|
|
|
|
+ <div v-else class="box2" @click="openLink(detailData.fileUrl)">
|
|
|
|
+ <img src="@/assets/common/word.png" v-if="checkFileType(detailData.fileUrl) == 'word'" />
|
|
|
|
+ <img src="@/assets/common/excel.png" v-if="checkFileType(detailData.fileUrl) == 'excel'" />
|
|
|
|
+ <img src="@/assets/common/ppt.png" v-if="checkFileType(detailData.fileUrl) == 'ppt'" />
|
|
|
|
+ <img src="@/assets/common/pdf.png" v-if="checkFileType(detailData.fileUrl) == 'pdf'" />
|
|
|
|
+ <div class="name ellipsis-3">{{ detailData.fileName }}</div>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6" class="item">
|
|
|
|
+ <div class="label">制单人</div>
|
|
|
|
+ <div class="value">{{detailData.createBy}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6" class="item">
|
|
|
|
+ <div class="label">制单日期</div>
|
|
|
|
+ <div class="value">{{detailData.createTime}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6" class="item">
|
|
|
|
+ <div class="label">审核人</div>
|
|
|
|
+ <div class="value">{{detailData.approvalName}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6" class="item">
|
|
|
|
+ <div class="label">审核日期</div>
|
|
|
|
+ <div class="value">{{detailData.approvalTime}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="24" class="item">
|
|
|
|
+ <div class="label">审批说明</div>
|
|
|
|
+ <div class="value">{{detailData.approvalRemark}}</div>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <div class="main-title">
|
|
|
|
+ <div class="title">货品信息</div>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <div class="table" style="margin-top: 20px">
|
|
|
|
+ <el-table :data="detailData.orders" element-loading-text="Loading" border fit highlight-current-row stripe max-height="400">
|
|
|
|
+ <el-table-column align="center" label="序号" type="index" width="50"></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="销售类型" prop="saleTypeName" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="发货仓库" prop="stockIds" min-width="160" show-overflow-tooltip>
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ <el-tag size="mini" style="margin: 0 5px;" v-for="(item, index) in scope.row.stockIds" :key="index">{{item.name}}</el-tag>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column align="center" label="库存数" prop="stockNumber" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="销售订单号" prop="retailOrderId" min-width="180" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="产品编码" prop="materialCode" min-width="120" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="产品名称" prop="materialName" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="规格型号" prop="specification" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="计量单位" prop="unit" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="申请数量" prop="invoiceNum" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="审批数量" prop="approvalNumber" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
+ <el-table-column align="center" label="备注" prop="remark" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
+ </el-table>
|
|
|
|
+ </div>
|
|
|
|
+
|
|
|
|
+ <div v-if="isExamine">
|
|
<div class="main-title">
|
|
<div class="main-title">
|
|
- <div class="title">发货申请单信息</div>
|
|
|
|
|
|
+ <div class="title">审批记录</div>
|
|
</div>
|
|
</div>
|
|
-
|
|
|
|
<div class="diy-table-1">
|
|
<div class="diy-table-1">
|
|
- <el-row>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">发货申请单号</div>
|
|
|
|
- <div class="value">{{detailData.id}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">申请日期</div>
|
|
|
|
- <div class="value">{{detailData.createTime}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">单据状态</div>
|
|
|
|
- <div class="value">{{detailData.status | statusFilter}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">经销商编号</div>
|
|
|
|
- <div class="value">{{detailData.customerNumber}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">经销商名称</div>
|
|
|
|
- <div class="value">{{detailData.customerName}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="8" class="item">
|
|
|
|
- <div class="label">仓库</div>
|
|
|
|
- <div class="value">{{detailData.correspondName}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="24" class="item">
|
|
|
|
- <div class="label">备注</div>
|
|
|
|
- <div class="value">{{detailData.remark}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="6" class="item">
|
|
|
|
- <div class="label">制单人</div>
|
|
|
|
- <div class="value">{{detailData.createBy}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="6" class="item">
|
|
|
|
- <div class="label">制单日期</div>
|
|
|
|
- <div class="value">{{detailData.createTime}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="6" class="item">
|
|
|
|
- <div class="label">审核人</div>
|
|
|
|
|
|
+ <el-row :gutter="0">
|
|
|
|
+ <el-col :span="12" class="item">
|
|
|
|
+ <div class="label">审批人</div>
|
|
<div class="value">{{detailData.approvalName}}</div>
|
|
<div class="value">{{detailData.approvalName}}</div>
|
|
</el-col>
|
|
</el-col>
|
|
- <el-col :span="6" class="item">
|
|
|
|
- <div class="label">审核日期</div>
|
|
|
|
- <div class="value">{{detailData.approvalTime}}</div>
|
|
|
|
|
|
+ <el-col :span="12" class="item">
|
|
|
|
+ <div class="label">审批结果</div>
|
|
|
|
+ <div class="value">{{detailData.examineStatus | statusFilter}}</div>
|
|
</el-col>
|
|
</el-col>
|
|
<el-col :span="24" class="item">
|
|
<el-col :span="24" class="item">
|
|
<div class="label">审批说明</div>
|
|
<div class="label">审批说明</div>
|
|
@@ -59,54 +121,6 @@
|
|
</el-col>
|
|
</el-col>
|
|
</el-row>
|
|
</el-row>
|
|
</div>
|
|
</div>
|
|
-
|
|
|
|
- <div class="main-title">
|
|
|
|
- <div class="title">货品信息</div>
|
|
|
|
- </div>
|
|
|
|
-
|
|
|
|
- <div class="table" style="margin-top: 20px">
|
|
|
|
- <el-table :data="detailData.orders" element-loading-text="Loading" border fit highlight-current-row stripe max-height="400">
|
|
|
|
- <el-table-column align="center" label="序号" type="index" width="50"></el-table-column>
|
|
|
|
- <el-table-column align="center" label="销售类型" prop="saleTypeName" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="发货仓库" prop="stockIds" min-width="160" show-overflow-tooltip>
|
|
|
|
- <template slot-scope="scope">
|
|
|
|
- <el-tag size="mini" style="margin: 0 5px;" v-for="(item, index) in scope.row.stockIds" :key="index">{{item.name}}</el-tag>
|
|
|
|
- </template>
|
|
|
|
- </el-table-column>
|
|
|
|
- <el-table-column align="center" label="库存数" prop="stockNumber" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="销售订单号" prop="retailOrderId" min-width="180" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="产品编码" prop="materialCode" min-width="120" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="产品名称" prop="materialName" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="规格型号" prop="specification" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="计量单位" prop="unit" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="申请数量" prop="invoiceNum" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="审批数量" prop="approvalNumber" min-width="100" show-overflow-tooltip></el-table-column>
|
|
|
|
- <el-table-column align="center" label="备注" prop="remark" min-width="160" show-overflow-tooltip></el-table-column>
|
|
|
|
- </el-table>
|
|
|
|
- </div>
|
|
|
|
-
|
|
|
|
- <div v-if="isExamine">
|
|
|
|
- <div class="main-title">
|
|
|
|
- <div class="title">审批记录</div>
|
|
|
|
- </div>
|
|
|
|
- <div class="diy-table-1">
|
|
|
|
- <el-row :gutter="0">
|
|
|
|
- <el-col :span="12" class="item">
|
|
|
|
- <div class="label">审批人</div>
|
|
|
|
- <div class="value">{{detailData.approvalName}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="12" class="item">
|
|
|
|
- <div class="label">审批结果</div>
|
|
|
|
- <div class="value">{{detailData.status | statusFilter}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- <el-col :span="24" class="item">
|
|
|
|
- <div class="label">审批说明</div>
|
|
|
|
- <div class="value">{{detailData.approvalRemark}}</div>
|
|
|
|
- </el-col>
|
|
|
|
- </el-row>
|
|
|
|
- </div>
|
|
|
|
- </div>
|
|
|
|
-
|
|
|
|
</div>
|
|
</div>
|
|
|
|
|
|
<div class="page-footer">
|
|
<div class="page-footer">
|
|
@@ -185,23 +199,21 @@
|
|
</template>
|
|
</template>
|
|
|
|
|
|
<script>
|
|
<script>
|
|
-import print from 'vue-print-nb'
|
|
|
|
import { getApplyDetail } from "@/api/supply/apply";
|
|
import { getApplyDetail } from "@/api/supply/apply";
|
|
|
|
+import { getFileUrl } from '@/api/common';
|
|
|
|
|
|
export default {
|
|
export default {
|
|
name: 'ApplyDetail',
|
|
name: 'ApplyDetail',
|
|
componentName: 'ApplyDetail',
|
|
componentName: 'ApplyDetail',
|
|
props: ['listItem'],
|
|
props: ['listItem'],
|
|
- directives: {
|
|
|
|
- print
|
|
|
|
- },
|
|
|
|
filters: {
|
|
filters: {
|
|
statusFilter(val) {
|
|
statusFilter(val) {
|
|
const statusList = [
|
|
const statusList = [
|
|
- { label: '已保存', value: 1 },
|
|
|
|
- { label: '待审核', value: 2 },
|
|
|
|
- { label: '审核通过', value: 3 },
|
|
|
|
- { label: '审核驳回', value: 4 },
|
|
|
|
|
|
+ { label: '已保存', value: 'SAVE' },
|
|
|
|
+ { label: '待审核', value: 'WAIT' },
|
|
|
|
+ { label: '审核通过', value: 'OK' },
|
|
|
|
+ { label: '审核驳回', value: 'FAIL' },
|
|
|
|
+ { label: '已关闭', value: 'CLOSE' },
|
|
];
|
|
];
|
|
let obj = statusList.find(o => o.value == val);
|
|
let obj = statusList.find(o => o.value == val);
|
|
return obj ? obj.label : ''
|
|
return obj ? obj.label : ''
|
|
@@ -209,9 +221,7 @@ export default {
|
|
},
|
|
},
|
|
data() {
|
|
data() {
|
|
return {
|
|
return {
|
|
- printObj: {
|
|
|
|
- id: 'printData'
|
|
|
|
- },
|
|
|
|
|
|
+ imageURL: this.$imageUrl,
|
|
detailData: {},
|
|
detailData: {},
|
|
|
|
|
|
isShowDeliverDialog: false,
|
|
isShowDeliverDialog: false,
|
|
@@ -234,7 +244,7 @@ export default {
|
|
}
|
|
}
|
|
},
|
|
},
|
|
isExamine() {
|
|
isExamine() {
|
|
- return this.detailData.status === 3 || this.detailData.status === 4
|
|
|
|
|
|
+ return this.detailData.examineStatus === 'OK' || this.detailData.examineStatus === "FAIL"
|
|
},
|
|
},
|
|
},
|
|
},
|
|
|
|
|
|
@@ -255,6 +265,33 @@ export default {
|
|
})
|
|
})
|
|
},
|
|
},
|
|
|
|
|
|
|
|
+ // 检查文件类型
|
|
|
|
+ checkFileType(url) {
|
|
|
|
+ if(!url) return '';
|
|
|
|
+ const fileSuffix = url.substring(url.lastIndexOf(".") + 1);
|
|
|
|
+
|
|
|
|
+ if (['jpg', 'jpeg', 'png'].includes(fileSuffix)) {
|
|
|
|
+ return 'image';
|
|
|
|
+ }else if (['doc', 'docx', 'dot', 'wps', 'wpt'].includes(fileSuffix)) {
|
|
|
|
+ return 'word';
|
|
|
|
+ }else if(['xls', 'xlsx', 'xlt', 'et', 'ett'].includes(fileSuffix)) {
|
|
|
|
+ return 'excel';
|
|
|
|
+ }else if(['ppt', 'pptx', 'dps', 'dpt', 'pot', 'pps'].includes(fileSuffix)) {
|
|
|
|
+ return 'ppt';
|
|
|
|
+ }else if(['pdf'].includes(fileSuffix)) {
|
|
|
|
+ return 'pdf';
|
|
|
|
+ }else {
|
|
|
|
+ return '';
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+
|
|
|
|
+ // 打开链接
|
|
|
|
+ openLink(url) {
|
|
|
|
+ getFileUrl({key: url}).then(res => {
|
|
|
|
+ window.open(res.data);
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+
|
|
// 打开 直调发货
|
|
// 打开 直调发货
|
|
openDeliverDialog() {
|
|
openDeliverDialog() {
|
|
this.isShowDeliverDialog = true;
|
|
this.isShowDeliverDialog = true;
|