CycleCountHeaderList.vue 13.1 KB
<template>
  <a-card :bordered="false">
    <!-- 查询区域 -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <a-form-item label="库区">
              <a-form-model-item prop="zoneOptions">
                <j-multi-select-tag
                  v-model="queryParam.zoneCode"
                  :options="zoneOptions"
                  placeholder="请选择">
                </j-multi-select-tag>
              </a-form-model-item>
            </a-form-item>
          </a-col>
          <a-col :xl='6' :lg='7' :md='8' :sm='24'>
            <span style='float: left;overflow: hidden;' class='table-page-search-submitButtons'>
              <a-button type='primary' @click='searchQuery' icon='search'>查询</a-button>
              <a-button type='primary' @click='searchReset' icon='reload' style='margin-left: 8px'>重置</a-button>
              <a @click='handleToggleSearch' style='margin-left: 8px'>
                {{ toggleSearchStatus ? '收起' : '展开' }}
                <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>
              </a>
            </span>
          </a-col>
        </a-row>
      </a-form>
    </div>
    <!-- 查询区域-END -->

    <!-- 操作按钮区域 -->
    <div class="table-operator">
      <!--      <a-button v-has="'cycleCountHeader:add'" @click="handleAdd" type="primary" icon="plus">新增</a-button>-->
      <a-button v-has="'cycleCountHeader:export'" type="primary" icon="download" @click="handleExportXls('盘点主表')">
        导出
      </a-button>
      <!--      <a-upload v-has="'cycleCountHeader:import'" name="file" :showUploadList="false" :multiple="false"-->
      <!--                :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">-->
      <!--        <a-button type="primary" icon="import">导入</a-button>-->
      <!--      </a-upload>-->
      <a-dropdown v-if="selectedRowKeys.length > 0">
        <a-menu slot="overlay">
          <!--          <a-menu-item key="1" @click="batchDel">-->
          <!--            <a-icon type="delete"/>-->
          <!--            删除-->
          <!--          </a-menu-item>-->
        </a-menu>
        <a-button style="margin-left: 8px"> 批量操作
          <a-icon type="down"/>
        </a-button>
      </a-dropdown>
    </div>

    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a
        style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>

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


        <!-- 内嵌table区域 begin -->
        <!--        <template slot="expandedRowRender" slot-scope="record">-->
        <!--          <a-tabs tabPosition="top">-->
        <!--            <a-tab-pane tab="盘点明细" key="cycleCountDetailId" forceRender>-->
        <!--              <cycle-count-detail-list :record="record" :isLoad="true"/>-->
        <!--            </a-tab-pane>-->
        <!--          </a-tabs>-->
        <!--        </template>-->

        <template slot="expandedRowRender" slot-scope="record">
          <a-tabs tabPosition="top">
            <a-tab-pane tab="盘点明细" forceRender>
              <InventoryCircleDetailChildList :record="record" :isLoad="true"/>
            </a-tab-pane>
          </a-tabs>
        </template>
        <!-- 内嵌table区域 end -->


        <span slot="companyCode" slot-scope="companyCode">
          <a-tag :key="companyCode" color=blue>
            {{ solutionCompany(companyCode) }}
          </a-tag>
        </span>

        <span slot='zoneCode' slot-scope='zoneCode'>
          <a-tag :key='zoneCode' color='blue'>
            {{ solutionZoneCode(zoneCode) }}
          </a-tag>
        </span>

        <span slot="countType" slot-scope="countType">
          <a-tag :key="countType" color=pink>
            {{ solutionCountType(countType) }}
          </a-tag>
        </span>

        <template slot="htmlSlot" slot-scope="text">
          <div v-html="text"></div>
        </template>
        <template slot="imgSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
          <img v-else :src="getImgView(text)" height="25px" alt=""
               style="max-width:80px;font-size: 12px;font-style: italic;"/>
        </template>
        <template slot="fileSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
          <a-button
            v-else
            :ghost="true"
            type="primary"
            icon="download"
            size="small"
            @click="downloadFile(text)">
            下载
          </a-button>
        </template>
        <span slot="action" slot-scope="text, record">
          <j-select-multi-cycle-count v-if="record.statusCyc!=100" :query-config="selectUserQueryConfig"
                                      :test-config="record.id" :header-code="record.code"/>
                    <a-divider type="vertical" v-if="record.statusCyc!=100"/>
          <a-dropdown>
            <a class="ant-dropdown-link">更多 <a-icon type="down"/></a>
            <a-menu slot="overlay">
              <a-menu-item>
                <a v-has="'cycleCountHeader:edit'" @click="handleEdit(record)">编辑</a>
              </a-menu-item>
              <a-menu-item>
                <a @click="handleDetail(record)">详情</a>
              </a-menu-item>
                            <a-menu-item>
                              <a-popconfirm v-has="'cycleCountHeader:delete'" title="确定删除吗?"
                                            @confirm="() => handleDelete(record.id)">
                                <a>删除</a>
                              </a-popconfirm>
                            </a-menu-item>
            </a-menu>
          </a-dropdown>
        </span>
      </a-table>
    </div>

    <cycle-count-header-modal ref="modalForm" @ok="modalFormOk"></cycle-count-header-modal>

  </a-card>
</template>

<script>

import '@/assets/less/TableExpand.less'
import {mixinDevice} from '@/utils/mixin'
import {JeecgListMixin} from '@/mixins/JeecgListMixin'
import {getCompanyList, getCountTypeList, getZoneList} from '@/api/api'
import CycleCountHeaderModal from './modules/CycleCountHeaderModal'
import CycleCountDetailList from "./CycleCountDetailList";
import InventoryCircleDetailChildList from "@views/system/inventory/InventoryCircleDetailChildList.vue";

export default {
  name: 'CycleCountHeaderList',
  mixins: [JeecgListMixin, mixinDevice],
  components: {
    CycleCountHeaderModal,
    CycleCountDetailList,
    InventoryCircleDetailChildList
  },
  data() {
    return {
      // 选择用户查询条件配置
      selectUserQueryConfig: [
        {key: 'materialCode', label: '物料编码', defaultValue: '123123'},
        {key: 'locationCode', label: '库位号'}
      ],
      description: '盘点主表管理页面',
      companyList: [],
      CountTypeList: [],
      zoneOptions: [],
      zoneList: [],
      // 表头
      columns: [
        {
          title: 'ID',
          dataIndex: '',
          key: 'rowIndex',
          width: 60,
          align: "center",
          customRender: function (t, r, index) {
            return parseInt(index) + 1;
          }
        },
        {
          title: '库区',
          align: 'center',
          dataIndex: 'zoneCode',
          key: 'zoneCode',
          scopedSlots: {customRender: 'zoneCode'}
        },
        {
          title: '盘点单编码',
          align: "center",
          dataIndex: 'code'
        },
        {
          title: '货主编码',
          align: "center",
          dataIndex: 'companyCode',
          key: 'companyCode',
          scopedSlots: {customRender: 'companyCode'}
        },
        {
          title: '总托数',
          align: "center",
          dataIndex: 'totalLocs'
        },
        {
          title: '总行数',
          align: "center",
          dataIndex: 'totalItems'
        },
        {
          title: '盘点类型',
          align: "center",
          dataIndex: 'countType',
          key: 'countType',
          scopedSlots: {customRender: 'countType'}
        },
        {
          title: '盘点主单状态',
          align: "center",
          dataIndex: 'statusCyc_dictText'
        },
        {
          title: '备注',
          align: "center",
          dataIndex: 'remark'
        },
        {
          title: '创建人',
          align: "center",
          dataIndex: 'createBy'
        },
        {
          title: '创建日期',
          align: "center",
          dataIndex: 'createTime'
        },
        // {
        //   title: '操作',
        //   dataIndex: 'action',
        //   align: "center",
        //   // fixed:"right",
        //   width: 147,
        //   scopedSlots: {customRender: 'action'}
        // }
      ],
      url: {
        list: "/cycleCountHeader/cycleCountHeader/list",
        delete: "/cycleCountHeader/cycleCountHeader/delete",
        deleteBatch: "/cycleCountHeader/cycleCountHeader/deleteBatch",
        exportXlsUrl: "/cycleCountHeader/cycleCountHeader/exportXls",
        importExcelUrl: "cycleCountHeader/cycleCountHeader/importExcel",

      },
      dictOptions: {
        status: [],
      },
      superFieldList: [],
    }
  },
  created() {
    this.getSuperFieldList();
    this.loadFrom();
  },
  computed: {
    importExcelUrl: function () {
      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
    },
  },
  methods: {
    initDictConfig() {
    },
    getSuperFieldList() {
      let fieldList = [];
      fieldList.push({type: 'string', value: 'code', text: '盘点主表编号', dictCode: ''})
      fieldList.push({type: 'string', value: 'companyCode', text: '货主编码', dictCode: ''})
      fieldList.push({type: 'string', value: 'countType', text: '盘点类型', dictCode: ''})
      fieldList.push({type: 'int', value: 'statusCyc', text: '盘点状态', dictCode: 'cyclecount_status'})
      fieldList.push({type: 'string', value: 'remark', text: '备注', dictCode: ''})
      fieldList.push({type: 'int', value: 'totalLocs', text: '总货位数', dictCode: ''})
      fieldList.push({type: 'int', value: 'totalItems', text: '总物料数', dictCode: ''})
      fieldList.push({type: 'string', value: 'stocktakingAs', text: '指定盘点人员', dictCode: ''})
      fieldList.push({type: 'string', value: 'stocktakingAc', text: '实际盘点人员', dictCode: ''})
      fieldList.push({type: 'int', value: 'enable', text: '是否有效', dictCode: 'valid_status'})
      fieldList.push({type: 'datetime', value: 'uploadTime', text: '回传时间'})
      fieldList.push({type: 'int', value: 'uploadStatus', text: '回传状态', dictCode: 'valid_status'})
      fieldList.push({type: 'string', value: 'closedBy', text: '关闭人', dictCode: ''})
      this.superFieldList = fieldList
    },
    loadFrom() {
      getCompanyList().then((res) => {
        if (res.success) {
          this.companyList = res.result
        }
      });
      getCountTypeList().then((res) => {
        if (res.success) {
          this.CountTypeList = res.result
        }
      });
      getZoneList().then((res) => {
        if (res.success) {
          this.zoneList = res.result
          //延迟半秒执行,避免组件未加载完,数据已经加载完
          setTimeout(() => {
            //slice可以在数组的任何位置进行删除/添加操作
            this.zoneOptions.splice(0, 1);
            for (let i = 0; i < res.result.length; i++) {
              this.zoneOptions.push({value: res.result[i].code, text: res.result[i].name})
            }
          }, 500)
        }
      });
    },

    loadDataaa() {
      var _this = this;
      _this.testaa();
    },
    solutionCompany(value) {
      var actions = []
      Object.keys(this.companyList).some((key) => {
        if (this.companyList[key].code == ('' + value)) {
          actions.push(this.companyList[key].name)
          return true
        }
      })
      return actions.join('')
    },

    solutionCountType(value) {
      var actions = []
      Object.keys(this.CountTypeList).some((key) => {
        if (this.CountTypeList[key].code == ('' + value)) {
          actions.push(this.CountTypeList[key].name)
          return true
        }
      })
      return actions.join('')
    },
    solutionZoneCode(value) {
      let actions = []
      Object.keys(this.zoneList).some((key) => {
        if (this.zoneList[key].code === ('' + value)) {
          actions.push(this.zoneList[key].name)
          return true
        }
      })
      return actions.join('')
    },

  }
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>