index.vue 11.6 KB
<template>
  <div class="app-container">
    <el-tabs v-model="activeName" type="card">
      <el-tab-pane label="主表" name="first">
        <el-form
          :model="queryParams"
          ref="queryForm"
          :inline="true"
          v-show="showSearch"
          label-width="68px"
        >
          <el-form-item label="入库单号" prop="code">
            <el-input
              v-model="queryParams.code"
              placeholder="请输入入库单号"
              clearable
              size="small"
              style="width: 240px"
              @keyup.enter.native="handleQuery"
            />
          </el-form-item>
          <el-form-item label="上游单号" prop="referCode">
            <el-input
              v-model="queryParams.referCode"
              placeholder="请输入上游单号"
              clearable
              size="small"
              style="width: 240px"
              @keyup.enter.native="handleQuery"
            />
          </el-form-item>
          <el-form-item label="入库类型" size="small" prop="type">
            <el-select
              v-model="queryParams.type"
              placeholder="入库类型"
              clearable
              size="small"
              style="width: 240px"
            >
              <el-option
                v-for="attr in typeOptions"
                :key="attr.id"
                :value="attr.code"
                :label="attr.name"
              ></el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="头状态" size="small" prop="firstStatus">
            <el-select
              v-model="queryParams.firstStatus"
              placeholder="头状态"
              clearable
              size="small"
              style="width: 240px"
            >
              <el-option
                v-for="dict in statusOptions"
                :key="dict.dictValue"
                :label="dict.dictLabel"
                :value="dict.dictValue"
              ></el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="尾状态" size="small" prop="lastStatus">
            <el-select
              v-model="queryParams.lastStatus"
              placeholder="尾状态"
              clearable
              size="small"
              style="width: 240px"
            >
              <el-option
                v-for="dict in statusOptions"
                :key="dict.dictValue"
                :label="dict.dictLabel"
                :value="dict.dictValue"
              ></el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="创建时间">
            <el-date-picker
              v-model="dateRange"
              size="small"
              style="width: 240px"
              value-format="yyyy-MM-dd"
              type="daterange"
              range-separator="-"
              start-placeholder="开始日期"
              end-placeholder="结束日期"
            ></el-date-picker>
          </el-form-item>
          <el-form-item size="small">
            <el-button
              size="mini"
              type="cyan"
              icon="el-icon-search"
              @click="handleQuery"
              >搜索</el-button
            >
            <el-button size="mini" @click="resetQuery">重置</el-button>
          </el-form-item>
        </el-form>
        <el-row :gutter="10" class="mb8">
          <right-toolbar
            :showSearch.sync="showSearch"
            @queryTable="getHeaderList"
          ></right-toolbar>
        </el-row>
        <el-table :data="HeaderList" v-loading="headerLoading">
          <el-table-column prop="id" label="入库单id" align="center" />
          <el-table-column
            prop="code"
            label="入库单号"
            align="center"
            :show-overflow-tooltip="true"
          />
          <el-table-column prop="companyCode" label="货主编码" align="center" />
          <el-table-column prop="referCode" label="上游单号" align="center" />
          <el-table-column prop="receiptType" label="入库类型" align="center">
            <template slot-scope="scope">
              <el-button
                size="mini"
                :type="scope.row.receiptType | receiptTypeFilter"
                round
                >{{ receiptTypeFormat(scope.row, scope.column) }}</el-button
              >
            </template>
          </el-table-column>

          <el-table-column prop="totalQty" label="总数量" align="center" />
          <el-table-column prop="totalLines" label="总行数" align="center" />
          <el-table-column prop="firstStatus" label="头状态" align="center">
            <template slot-scope="scope">
              <el-button size="mini" type="primary" round
                >{{ firstStatusFormat(scope.row, scope.column) }}
              </el-button>
            </template>
          </el-table-column>
          <el-table-column prop="lastStatus" label="尾状态" align="center">
            <template slot-scope="scope">
              <el-button size="mini" type="primary" round
                >{{ lastStatusFormat(scope.row, scope.column) }}
              </el-button>
            </template>
          </el-table-column>
          <el-table-column
            prop="created"
            label="创建时间"
            align="center"
            sortable
            min-width="160"
          >
            <template slot-scope="scope">
              {{ parseTime(scope.row.created) }}
            </template>
          </el-table-column>
          <el-table-column
            prop="createdBy"
            label="创建用户"
            align="center"
            :show-overflow-tooltip="true"
          />
          <el-table-column
            prop="center"
            label="操作"
            align="center"
            class-name="small-padding fixed-width"
            width="120"
          >
            <template slot-scope="scope">
              <el-button
                size="mini"
                type="text"
                icon="el-icon-my-detail"
                @click="handleDetail(scope.row)"
                v-hasPermi="['receipt:history:list']"
                >明细</el-button
              >
            </template>
          </el-table-column>
        </el-table>

        <pagination
          v-show="headerTotal > 0"
          :total="headerTotal"
          :page.sync="queryParams.pageNum"
          :limit.sync="queryParams.pageSize"
          @pagination="getHeaderList"
        />
      </el-tab-pane>
      <el-tab-pane
        label="明细"
        name="second"
        v-if="this.queryDetailParams.receiptId !== undefined"
      >
        <el-row :gutter="10" class="mb8">
          <right-toolbar
            :showSearch.sync="showSearch"
            @queryTable="getDetailList"
          ></right-toolbar>
        </el-row>
        <el-table v-loading="detailLoading" :data="DetailList">
          <el-table-column prop="id" label="入库单id" align="center" />
          <el-table-column
            prop="receiptCode"
            label="入库单编码"
            align="center"
            min-width="100"
          />
          <el-table-column
            prop="materialCode"
            label="物料编码"
            align="center"
          />
          <el-table-column
            prop="materialName"
            label="物料名称"
            align="center"
          />
          <el-table-column
            prop="materialSpec"
            label="物料规格"
            align="center"
          />
          <el-table-column
            prop="materialUnit"
            label="物料单位"
            align="center"
          />
          <el-table-column prop="batch" label="批次" align="center" />
          <el-table-column prop="lot" label="批号" align="center" />
          <el-table-column prop="projectNo" label="项目号" align="center" />
          <el-table-column prop="totalQty" label="总数量" align="center" />
          <el-table-column prop="openQty" label="已收数量" align="center" />
          <el-table-column
            prop="created"
            label="创建时间"
            align="center"
            min-width="160"
          >
            <template slot-scope="scope">
              {{ parseTime(scope.row.created) }}
            </template>
          </el-table-column>
        </el-table>
        <pagination
          v-show="detailTotal > 0"
          :total="detailTotal"
          :page.sync="queryDetailParams.pageNum"
          :limit.sync="queryDetailParams.pageSize"
          @pagination="getDetailList"
        />
      </el-tab-pane>
    </el-tabs>
  </div>
</template>

<script>
import {
  listReceiptHeaderHistory,
  listReceiptDetailHistory,
} from "@/api/receipt/receiptHeaderHistory";

import { listRectype } from "@/api/config/receipt/receiptType";
export default {
  name: "receiptHeaderHistory",
  data() {
    return {
      activeName: "first",
      // 遮罩层
      headerLoading: true,

      // 显示搜索条件
      showSearch: true,
      // 总条数
      headerTotal: 0,
      // 主表表格数据
      HeaderList: [],

      // 入库类型数据字典
      typeOptions: [],

      // 头状态、尾状态数据字典
      statusOptions: [],
      // 日期范围
      dateRange: [],
      // 主表查询参数
      queryParams: {
        pageNum: 1,
        pageSize: 10,
        code: undefined,
        referCode: undefined,
        type: undefined,
        firstStatus: undefined,
        lastStatus: undefined,
      },

      // 明细遮罩层
      detailLoading: true,

      // 明细显示搜索条件
      showDetailSearch: true,
      // 明细总条数
      detailTotal: 0,
      // 明细表格数据
      DetailList: [],

      // 明细查询参数
      queryDetailParams: {
        receiptId: undefined,
        pageNum: 1,
        pageSize: 10,
      },
    };
  },
  created() {
    this.getHeaderList();
    listRectype().then((response) => {
      this.typeOptions = response.rows;
    });
    this.getDicts("receiptHeaderStatus").then((response) => {
      this.statusOptions = response.data;
    });
  },
  methods: {
    /** 查询主表列表 */
    getHeaderList() {
      this.headerLoading = true;
      listReceiptHeaderHistory(
        this.addDateRange(this.queryParams, this.dateRange)
      ).then((response) => {
        this.HeaderList = response.rows;
        this.headerTotal = response.total;
        this.headerLoading = false;
      });
    },

    //入库类型字典翻译
    receiptTypeFormat(row, column) {
      return this.selectCommonLabel(this.typeOptions, row.receiptType);
    },
    //入库单头状态字典翻译
    firstStatusFormat(row, column) {
      return this.selectDictLabel(this.statusOptions, row.firstStatus);
    },
    //入库单尾状态字典翻译
    lastStatusFormat(row, column) {
      return this.selectDictLabel(this.statusOptions, row.lastStatus);
    },

    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.pageNum = 1;
      this.getHeaderList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.dateRange = [];
      this.resetForm("queryForm");
      this.handleQuery();
    },
    /** 主表明细按钮操作 */
    handleDetail(row) {
      this.queryDetailParams.receiptId = row.id;
      this.activeName = "second";

      this.getDetailList();
    },
    /** 查询明细列表 */
    getDetailList() {
      this.detailLoading = true;
      listReceiptDetailHistory(this.queryDetailParams).then((response) => {
        this.DetailList = response.rows;
        this.DetailTotal = response.total;
        this.detailLoading = false;
      });
    },
  },
};
</script>