CycleCountDetailList.vue 10.3 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"
      >

        <!-- 内嵌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" :countType="countType"/>
            </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 @click="createMany()">
            <a-icon/>
            新增</a>
          <a-divider type="vertical"/>-->
          <a v-if="record.enableStatus == '1'" @click="selectPort(record)">生成盘点任务</a>
          <a-divider v-if="record.enableStatus == '1'" type="vertical"/>
          <a-popconfirm title="确定删除吗?" @confirm="() => remove(record)">
            <a v-if="record.enableStatus == '1'">删除</a>
          </a-popconfirm>
<!--          <a-divider v-if="record.enableStatus == '1'" type="vertical"/>
          <a @click="loadDatas(record.cycleCountHeadId)">
            <a-icon type="sync"/>
            刷新</a>-->
        </template>
      </a-table>
    </div>
    <!-- table区域 end -->

    <!-- 表单区域 -->

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

  </a-card>
</template>

<script>

import {JeecgListMixin} from '@/mixins/JeecgListMixin'
import {deleteAction, getAction} from '@api/manage'
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";

export default {
  name: 'CycleCountDetailList',
  mixins: [JeecgListMixin],
  components: {
    CycleCountDetailModal,
    CycleCountDetailChildSubTable,
    CycleCountSelectModal,
    CycleCountDetailChiIdModal,
  },
  props: {
    record: {
      type: Object,
      default: null,
    },
    isLoad: {
      type: Boolean,
      default: false,
    }
  },
  data() {
    return {
      description: '盘点明细表列表管理页面',
      // 表头
      columns: [
        {
          title: '盘点主单编码',
          align: 'center',
          dataIndex: 'cycleCountHeadCode',
        },
        {
          title: '库位',
          align: 'center',
          dataIndex: 'locationCode',
        },
        {
          title: '容器',
          align: 'center',
          dataIndex: 'containerCode',
        },
        /*{
          title: '库存状态',
          align: 'center',
          dataIndex: 'inventorySts_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: '状态',
          align: 'center',
          dataIndex: 'enableStatus_dictText',
        },
        {
          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: [],
      // 盘点类型
      countType: null
    }
  },
  created() {
    this.getSuperFieldList();
  },
  mounted() {
    let _this = this;
    Utils.$on('methodB', (data) => {
      _this.methodB(data);
    })
  },
  computed: {
    importExcelUrl() {
      return window._CONFIG['domianURL'] + this.url.importExcelUrl
    }
  },
  watch: {
    record: {
      immediate: true,
      handler() {
        if (this.record) {
          this.loadData(this.record)
          this.countType = this.record.countType;
        }
      }
    }
  },
  methods: {
    loadData(record) {
      if (!record) {
        return
      }
      this.loading === true
      this.dataSource = []
      getAction(this.url.list, {
        cycleCountHeadId: record.id
      }).then((res) => {
        if (res.success) {
          this.dataSource = res.result.records
        }
      }).finally(() => {
        this.loading = false
      })
    },
    selectPort(record) {
      this.$refs.modalForm2.edit(record);
      this.$refs.modalForm2.title = "选择出库口";
    },
    loadDatas(record) {
      this.loading = true
      this.dataSource = []
      getAction(this.url.list, {
        cycleCountHeadId: record
      }).then((res) => {
        if (res.success) {
          this.dataSource = res.result.records
        }
      }).finally(() => {
        this.loading = false
      })
    },
    remove(record) {
      deleteAction(this.url.delete, {
        id: record.id
      }).then((res) => {
        if (res.success) {
          this.$message.success(res.message);
          //this.loadDatas(record.cycleCountHeadId);
          this.$emit('ok');
        } else {
          this.$message.error(res.message);
        }
      }).catch((res) => {
        this.$message.error(res.message);
      }).finally(() => {
        this.loading = false
      })
    },
    selectPortOk() {
      this.$emit('ok');
    },
    methodB(data) {
      console.log("methodB:", data);
      let _this = this;
      _this.loadDatas(data);
    },
    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: '盘点主单code', 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 = "实盘登记";
    },
  }
}
</script>
<style lang="less" scoped>
@import '~@assets/less/common.less';
</style>