charles
2024-08-06 5ecb7958c96d3f0b6d47b79aff7eb306c2cf690f
src/views/reportForm/outboundDetail/index.vue
@@ -1,20 +1,53 @@
<template>
  <div class="rightContent">
    <div class="top">
      <SearchCommonView :add-title="'新建'" :showAdd="false" :placeholder="'请根据单号、产品、业务类型进行搜索'" :amount-view="false"
        @addCommonClick="addBtnClick" @searchClick="getList" />
      <SearchCommonView :add-title="'新建'" :showAdd="false" :placeholder="'请根据单号、产品、业务类型进行搜索'" :amount-view="false" :showDownload="true"
        @downloadClick="downHttpClick" @addCommonClick="addBtnClick" @searchClick="getList" />
    </div>
    <div class="list-view">
      <div class="table">
        <TableCommonView ref="tableListRef" :table-list="tableList" @selTableCol="selTableCol"
          @tableRowClick="tableRowClick"></TableCommonView>
          @tableRowClick="tableRowClick">
          <template slot="tableButton">
            <el-table-column label="数量" prop='amount'>
              <el-table-column v-for="unit in unitList" :label="unit.name" prop='amount' min="90">
                <template slot-scope="scope">
                  {{getUnitValue(scope.row.amountMoreUnits,unit.name,scope.row.amount,scope.row.unit)}}
                </template>
              </el-table-column>
              <!--<el-table-column label="件" prop='amount' min="90">
                <template slot-scope="scope">
                  {{getUnitValue(scope.row.amountMoreUnits,'件',scope.row.amount,scope.row.unit)}}
                </template>
              </el-table-column>
              <el-table-column label="匹" prop='amount' min="90">
                <template slot-scope="scope">
                  {{getUnitValue(scope.row.amountMoreUnits,'匹',scope.row.amount,scope.row.unit)}}
                </template>
              </el-table-column>
              <el-table-column label="米数" prop='amount' min="90">
                <template slot-scope="scope">
                  {{getUnitValue(scope.row.amountMoreUnits,'米数',scope.row.amount,scope.row.unit)}}
                </template>
              </el-table-column>
              <el-table-column label="重量" prop='amount' min="90">
                <template slot-scope="scope">
                  {{getUnitValue(scope.row.beginMoreUnitsArr,'重量',scope.row.beginAmount,scope.row.unit)}}
                </template>
              </el-table-column>-->
            </el-table-column>
          </template>
        </TableCommonView>
      </div>
      <div class="btn-pager">
        <PagerView class="page" :pager-options="pagerOptions" v-on="pagerEvents" />
      </div>
    </div>
    <!-- 编辑 -->
    <AddOverviewDialog v-if="editConfig.visible" :edit-common-config="editConfig" :add-name="this.$route.params.name" />
    <AddOverviewDialog :workType="workType"
                       v-if="editConfig.visible"
                       :edit-common-config="editConfig"
                       :add-name="this.$route.params.name" />
  </div>
</template>
@@ -23,8 +56,13 @@
import { getHistory,getOperationInfo } from "@/api/reportForm/inventoryRwport"
// import { getProductOperatonList } from "@/api/product/product"
import AddOverviewDialog from "@/views/reportForm/outboundDetail/AddOutboundDetailDialog.vue"
// import AddOverviewDialog from "@/views/reportForm/outboundDetail/AddOutboundDetailDialog.vue"
import AddOverviewDialog from "@/views/overview/AddOverviewDialog"
import { getDataByType } from "@/api/data"
import { downloadHistory } from "@/api/downFile"
import FileSaver from 'file-saver'
import _ from 'lodash'
import { getUnitInfo } from "@/api/basic/standard";
export default {
  name: "outboundDetail",
  props: {},
@@ -33,6 +71,8 @@
  computed: {},
  data() {
    return {
        unitList:[],
      workType:2,
      tableList: {},
      showcol: ["状态"],
      searchOptions: [],
@@ -62,13 +102,51 @@
      sessionStorage.setItem("paramsList", JSON.stringify(params))
    }
    this.params = params
    this.getData()
    this.getData();
    this.getUnitInfo();
  },
  // 页面销毁之前
  beforeDestroy() {
    sessionStorage.removeItem("paramsList")
  },
  methods: {
      async getUnitInfo(){
          const { code,data }=await getUnitInfo();
          if(code===200){
              this.unitList=data;
          }
      },
      getUnitValue(list,val,num,unit){
          let  string='--'
          if(list){
              if(list.length>0){
                  for(let i in list){
                      if(list[i].unit==val){
                          string=list[i].amount
                          break;
                      }
                  }
              }
          }
          if(unit==val){
              string=num
          }
          return string
      },
     // 下载
     downHttpClick: _.debounce(function(){
      downloadHistory({
        page: this.pagerOptions.currPage,
        pageSize: this.pagerOptions.pageSize,
        keyword:this.keyword,
        baseOperationType:2
      }).then(res => {
        if (res) {
          FileSaver.saveAs(res, '出库明细报表.xlsx');
          this.$message.success("下载成功!");
        }
      })
    }, 1000),
    setTable() {
      this.tableList = {
        tableInfomation: [],
@@ -115,11 +193,11 @@
        },
        {
          label: "业务类型",
          prop: "baseOperationType",
          prop: "operationTypeName",
          isShowColumn: true,
          default: true,
          conversion: true,
          getStatus: this.getBaseOperationTypeList
          // conversion: true,
          // getStatus: this.getBaseOperationTypeList
        },
        {
          label: "从",
@@ -133,7 +211,7 @@
          isShowColumn: true,
          default: true
        },
        {
        /*{
          label: "数量",
          prop: "amount",
          isShowColumn: true,
@@ -144,7 +222,7 @@
          prop: "unit",
          isShowColumn: true,
          default: true
        },
        },*/
        {
          label: "重量",
          prop: "weight",
@@ -196,15 +274,17 @@
          page: this.pagerOptions.currPage,
          pageSize: this.pagerOptions.pageSize
        }).then((res) => {
          if (res.code === 200) {
          if (res.code === 200&&res.data) {
            res.data.map((item) => {
              let dateObject = new Date(item.date);
              let formattedDateString = dateObject.toISOString().split('T')[0];
              item.date = formattedDateString
            })
            this.tableList.tableInfomation = res.data
            this.pagerOptions.totalCount = res.total
            this.tableList.tableInfomation = res.data||[]
          }else{
            this.tableList.tableInfomation = res.data||[]
          }
          this.pagerOptions.totalCount = res.total
        })
      } else {
        await getHistory({
@@ -213,7 +293,7 @@
          page: this.pagerOptions.currPage,
          pageSize: this.pagerOptions.pageSize
        }).then((res) => {
          if (res.code === 200) {
          if (res.code === 200&&res.data) {
            res.data.map((item) => {
              if(item.status===""){
                item.status=4
@@ -222,9 +302,11 @@
              let formattedDateString = dateObject.toISOString().split('T')[0];
              item.date = formattedDateString
            })
            this.tableList.tableInfomation = res.data ? res.data : []
            this.pagerOptions.totalCount = res.total
            this.tableList.tableInfomation = res.data || []
          }else{
            this.tableList.tableInfomation = res.data || []
          }
          this.pagerOptions.totalCount = res.total
        })
      }
    },
@@ -235,9 +317,15 @@
    },
    // 行点击
    async tableRowClick(row) {
      await getOperationInfo(row.operationId).then((res)=>{
        this.editConfig.infomation = { ...res.data }
      })
      await getOperationInfo(row.operationId).then(({data})=>{
          data.details.map((item) => {
              item.fromLocationId = item.fromLocation.name;
              item.toLocationId = item.toLocation.name;
              item.relAmount=item.amount;
              item.amount=item.stockAmount;
          });
        this.editConfig.infomation = { ...data }
      });
      this.editConfig.visible = true
      this.editConfig.title = "查看"
    },