CycleCountDetailList.vue 11.2 KB
<template>
  <a-card class="j-inner-table-wrapper" :bordered="false">

    <!-- 查询区域 begin -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline">
        <a-row :gutter="24">
        </a-row>
      </a-form>
    </div>
    <!-- 查询区域 end -->

    <!-- 操作按钮区域 begin -->
    <div class="table-operator">
      <a-button v-has="'cycleCountHeader:export'" type="primary" icon="download" @click="handleExportXls('盘点明细表')">
        导出
      </a-button>
      <!-- 高级查询区域 -->

    </div>
    <!-- 操作按钮区域 end -->

    <!-- table区域 begin -->
    <div>

      <a-table
        ref="table"
        size="middle"
        bordered
        rowKey="id"
        class="j-table-force-nowrap"
        :loading="loading"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :expandedRowKeys="expandedRowKeys"
        :rowSelection="{selectedRowKeys, onChange: onSelectChange}"
        @expand="handleExpand"
        @change="handleTableChange"
      >

        <span slot="inventoryStatus_dictText" slot-scope="inventoryStatus_dictText">
          <a-tag :key="inventoryStatus_dictText" :color="getTagColor(inventoryStatus_dictText)">
            {{ inventoryStatus_dictText }}
          </a-tag>
        </span>

        <span slot="enableStatus_dictText" slot-scope="enableStatus_dictText">
          <a-tag :key="enableStatus_dictText" :color="getTagColor(enableStatus_dictText)">
            {{ enableStatus_dictText }}
          </a-tag>
        </span>

        <!-- 内嵌table区域 begin -->
        <template slot="expandedRowRender" slot-scope="record">
          <a-tabs tabPosition="top">
            <a-tab-pane tab="物料详情表" key="cycleCountDetailChild" forceRender>
              <cycle-count-detail-child-sub-table :record="record"/>
            </a-tab-pane>
          </a-tabs>
        </template>
        <!-- 内嵌table区域 end -->

        <template slot="htmlSlot" slot-scope="text">
          <div v-html="text"></div>
        </template>

        <template slot="imgSlot" slot-scope="text">
          <div style="font-size: 12px;font-style: italic;">
            <span v-if="!text">无图片</span>
            <img v-else :src="getImgView(text)" alt="" style="max-width:80px;height:25px;"/>
          </div>
        </template>

        <template slot="fileSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
          <a-button
            v-else
            ghost
            type="primary"
            icon="download"
            size="small"
            @click="downloadFile(text)"
          >
            <span>下载</span>
          </a-button>
        </template>
        <template slot="action" slot-scope="text, record">
          <cycle-count-detail-chi-id-modal ref="adjustmentModal" @ok="modalFormOk" :id="record.id"/>
          <a v-if="record.enableStatus != '100'" @click="createMany()">新增
            <a-divider type="vertical"/>
          </a>
          <a-popconfirm v-if="record.enableStatus === 1" v-has="'cycleCountHeader:delete'" title="确定删除吗?"
                        @confirm="() => handleDelete(record.id)">
            <a>删除
              <a-divider type="vertical"/>
            </a>
          </a-popconfirm>
          <a v-if="record.enableStatus == '1' && record.zoneType == 'L'" @click="selectPort(record)">生成盘点任务
            <a-divider type="vertical"/>
          </a>
          <a v-if="record.enableStatus != '100'" @click="cycleConfirm(record.id)">盘点登记
            <a-divider type="vertical"/>
          </a>
          <a @click="loadDatas(record.cycleCountHeadId)">
            <a-icon type="sync"/>
            刷新</a>
        </template>

      </a-table>
    </div>
    <!-- table区域 end -->

    <!-- 表单区域 -->

    <cycle-count-select-modal ref="modalForm2" @ok="modalFormOk"/>
    <cycle-count-detail-modal ref="modalForm" @ok="modalFormOk"/>
    <cycle-count-confirm-modal ref="modalForm3" @ok="modalFormOk"/>

  </a-card>
</template>

<script>

import {JeecgListMixin} from '@/mixins/JeecgListMixin'
import CycleCountDetailModal from './modules/CycleCountDetailModal'
import CycleCountSelectModal from './modules/CycleCountSelectModal'
import CycleCountDetailChildSubTable from './subTables/CycleCountDetailChildSubTable'
import '@/assets/less/TableExpand.less'
import Utils from "../../../components/jeecgbiz/JButtonBizComponent/util.js"
import CycleCountDetailChiIdModal from "./modules/CycleCountDetailChiIdModal";
import CycleCountConfirmModal from "@views/system/stocktaking/modules/CycleCountConfirmModal.vue";

export default {
  name: 'CycleCountDetailList',
  cycleCountDetailId: '',
  mixins: [JeecgListMixin],
  components: {
    CycleCountConfirmModal,
    CycleCountDetailModal,
    CycleCountDetailChildSubTable,
    CycleCountSelectModal,
    CycleCountDetailChiIdModal,
  },
  props: {
    record: {
      type: Object,
      default: null,
    },
    isLoad: {
      type: Boolean,
      default: false,
    }
  },
  data() {
    return {
      description: '盘点明细表列表管理页面',
      // 表头
      columns: [
        // {
        //   title: 'ID',
        //   key: 'rowIndex',
        //   width: 60,
        //   align: 'center',
        //   customRender: (t, r, index) => parseInt(index) + 1
        // },
        // {
        //   title: '盘点主单id',
        //   align: 'center',
        //   dataIndex: 'cycleCountHeadId',
        // },
        {
          title: '盘点主单编码',
          align: 'center',
          dataIndex: 'cycleCountHeadCode',
        },
        // {
        //   title: '任务表头',
        //   align: 'center',
        //   dataIndex: 'taskHeaderId',
        // },
        // {
        //   title: '任务明细头',
        //   align: 'center',
        //   dataIndex: 'taskDetailId',
        // },
        // {
        //   title: '仓库',
        //   align: 'center',
        //   dataIndex: 'warehouseCode',
        // },
        // {
        //   title: '货主',
        //   align: 'center',
        //   dataIndex: 'companyCode',
        // },
        // {
        //   title: '库存明细头',
        //   align: 'center',
        //   dataIndex: 'inventoryDetailId',
        // },
        {
          title: '库区类型',
          align: 'center',
          dataIndex: 'zoneType_dictText',
        },
        {
          title: '库位',
          align: 'center',
          dataIndex: 'locationCode',
        },
        {
          title: '容器',
          align: 'center',
          dataIndex: 'containerCode',
        },
        {
          title: '库存状态',
          align: 'center',
          dataIndex: 'inventorySts_dictText',
          scopedSlots: {customRender: 'inventoryStatus_dictText'}
        },
        {
          title: '状态',
          align: 'center',
          dataIndex: 'enableStatus_dictText',
          scopedSlots: {customRender: 'enableStatus_dictText'}
        },
        {
          title: '系统数量',
          align: 'center',
          dataIndex: 'systemQty',
        },
        {
          title: '实盘数量',
          align: 'center',
          dataIndex: 'countedQty',
        },
        {
          title: '差异数量',
          align: 'center',
          dataIndex: 'gapQty',
        },
        {
          title: '失败原因',
          align: 'center',
          dataIndex: 'rejectionNote',
        },
        {
          title: '完成用户',
          align: 'center',
          dataIndex: 'completedBy',
        },
        {
          title: '完成时间',
          align: 'center',
          dataIndex: 'completedAt',
        },
        {
          title: '操作',
          dataIndex: 'action',
          align: 'center',
          width: 147,
          scopedSlots: {customRender: 'action'},
        },
      ],
      // 字典选项
      dictOptions: {},
      // 展开的行test
      expandedRowKeys: [],
      url: {
        list: '/cycleCountDetail/cycleCountDetail/list',
        delete: '/cycleCountDetail/cycleCountDetail/delete',
        deleteBatch: '/cycleCountDetail/cycleCountDetail/deleteBatch',
        exportXlsUrl: '/cycleCountDetail/cycleCountDetail/exportXls',
        importExcelUrl: '/cycleCountDetail/cycleCountDetail/importExcel',
      },
      superFieldList: [],
    }
  },
  created() {
    this.getSuperFieldList();
  },
  mounted() {
    Utils.$on('methodB', (data) => {
      this.methodB(data);
      this.$emit('ok');
    })
  },
  computed: {
    importExcelUrl() {
      return window._CONFIG['domianURL'] + this.url.importExcelUrl
    }
  },
  methods: {
    selectPort(record) {
      this.$refs.modalForm2.edit(record);
      this.$refs.modalForm2.title = "选择出库口";
    },
    getOrderMain(cycleCountHeadId) {
      this.queryParam.cycleCountHeadId = cycleCountHeadId
      this.loadData(1)
    },
    methodB(data) {
      console.log("methodB" + data);
      var _this = this;
      _this.loadDatas(data);
    },
    initDictConfig() {
    },
    handleExpand(expanded, record) {
      this.expandedRowKeys = []
      if (expanded === true) {
        this.expandedRowKeys.push(record.id)
      }
    },
    getSuperFieldList() {
      let fieldList = [];
      fieldList.push({type: 'string', value: 'cycleCountHeadId', text: '盘点主单id', dictCode: ''})
      fieldList.push({type: 'string', value: 'cycleCountHeadCode', text: '盘点主单编码', dictCode: ''})
      fieldList.push({type: 'string', value: 'taskHeaderId', text: '任务表头', dictCode: ''})
      fieldList.push({type: 'string', value: 'taskDetailId', text: '任务明细头', dictCode: ''})
      fieldList.push({type: 'string', value: 'warehouseCode', text: '仓库', dictCode: ''})
      fieldList.push({type: 'string', value: 'companyCode', text: '货主', dictCode: ''})
      fieldList.push({type: 'string', value: 'inventoryDetailId', text: '库存明细头', dictCode: ''})
      fieldList.push({type: 'string', value: 'locationCode', text: '库位', dictCode: ''})
      fieldList.push({type: 'string', value: 'containerCode', text: '容器', dictCode: ''})
      fieldList.push({type: 'string', value: 'inventorySts', text: '库存状态', dictCode: ''})
      fieldList.push({type: 'string', value: 'systemQty', text: '系统数量', dictCode: ''})
      fieldList.push({type: 'string', value: 'countedQty', text: '实盘数量', dictCode: ''})
      fieldList.push({type: 'string', value: 'gapQty', text: '差异数量', dictCode: ''})
      fieldList.push({type: 'string', value: 'rejectionNote', text: '失败原因', dictCode: ''})
      fieldList.push({type: 'string', value: 'completedBy', text: '完成用户', dictCode: ''})
      fieldList.push({type: 'string', value: 'completedAt', text: '完成时间', dictCode: ''})
      fieldList.push({type: 'string', value: 'enableStatus', text: '盘点明细状态', dictCode: ''})
      this.superFieldList = fieldList
    },

    createMany() {
      this.$refs.adjustmentModal.edit();
      this.$refs.adjustmentModal.title = "新增";
    },

    cycleConfirm(record) {
      this.$refs.modalForm3.edit(record);
      this.$refs.modalForm3.title = "盘点登记";
    },
  }
}
</script>
<style scoped>
.ant-card {
  margin-left: -24px;
  margin-right: -24px;
}
</style>