410 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			410 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			Vue
		
	
	
	
<template>
 | 
						|
    <div class="app-container" id="">
 | 
						|
      <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="80px">
 | 
						|
        <el-form-item prop="time">
 | 
						|
            <el-date-picker
 | 
						|
                v-model="queryParams.time"
 | 
						|
                range-separator="至"
 | 
						|
                start-placeholder="开始日期"
 | 
						|
                end-placeholder="结束日期"
 | 
						|
                type="daterange"
 | 
						|
                value-format="yyyy-MM-dd"
 | 
						|
                style="width: 300px"
 | 
						|
            ></el-date-picker>
 | 
						|
        </el-form-item>
 | 
						|
        <!-- <el-form-item label="关键字" prop="keyWord">
 | 
						|
          <el-input
 | 
						|
            v-model="queryParams.keyWord"
 | 
						|
            placeholder="请输入关键字"
 | 
						|
            clearable :maxlength="20"
 | 
						|
            style="width: 200px"
 | 
						|
          />
 | 
						|
        </el-form-item> -->
 | 
						|
        <el-form-item prop="unitId">
 | 
						|
            <treeselect
 | 
						|
                v-model="queryParams.unitId"
 | 
						|
                :options="unitList" :normalizer="normalizer"
 | 
						|
                :show-count="true" style="width: 240px" :disable-branch-nodes="true"
 | 
						|
                noChildrenText="没有数据了" noOptionsText="没有数据" noResultsText="没有搜索结果"
 | 
						|
                placeholder="请选择往来单位" @select="unitChange"
 | 
						|
            />
 | 
						|
                    <!-- <el-cascader v-model="unitId"
 | 
						|
                        :show-all-levels="false"
 | 
						|
                        :options="unitList"
 | 
						|
                        :props="selectTreeProps"
 | 
						|
                        filterable
 | 
						|
                        clearable
 | 
						|
                        collapse-tags
 | 
						|
                        @change="unitChange"
 | 
						|
                        placeholder="请选择往来单位"
 | 
						|
                    ></el-cascader>  -->
 | 
						|
        </el-form-item>
 | 
						|
        <el-form-item prop="proId">
 | 
						|
            <treeselect
 | 
						|
                v-model="queryParams.proId"
 | 
						|
                :options="proList" :normalizer="normalizer"
 | 
						|
                :show-count="true" style="width: 240px" :disable-branch-nodes="true"
 | 
						|
                noChildrenText="没有数据了" noOptionsText="没有数据" noResultsText="没有搜索结果"
 | 
						|
                placeholder="请选择工程名称" @select="proChange"
 | 
						|
            />
 | 
						|
            <!-- <el-cascader v-model="projectId"
 | 
						|
                    :show-all-levels="false"
 | 
						|
                    :options="proList"
 | 
						|
                    :props="selectTreeProps"
 | 
						|
                    filterable clearable
 | 
						|
                    collapse-tags
 | 
						|
                    @change="proChange"
 | 
						|
                    placeholder="请选择工程名称"
 | 
						|
                ></el-cascader> -->
 | 
						|
        </el-form-item>
 | 
						|
        <el-form-item >
 | 
						|
            <el-select v-model="queryParams.firstTypeIdList" multiple placeholder="请选择一级设备类型" collapse-tags>
 | 
						|
                <el-option
 | 
						|
                v-for="item in optionList"
 | 
						|
                :key="item.value"
 | 
						|
                :label="item.label"
 | 
						|
                :value="item.value">
 | 
						|
                </el-option>
 | 
						|
            </el-select>
 | 
						|
        </el-form-item>
 | 
						|
 | 
						|
        <el-form-item prop="typeName">
 | 
						|
            <el-input
 | 
						|
                v-model="queryParams.typeName"
 | 
						|
                placeholder="请输入物资名称"
 | 
						|
                clearable :maxlength="20"
 | 
						|
                style="width: 200px"
 | 
						|
            />
 | 
						|
        </el-form-item>
 | 
						|
        <el-form-item prop="typeModelName">
 | 
						|
            <el-input
 | 
						|
                v-model="queryParams.typeModelName"
 | 
						|
                placeholder="请输入规格型号"
 | 
						|
                clearable :maxlength="20"
 | 
						|
                style="width: 200px"
 | 
						|
            />
 | 
						|
        </el-form-item>
 | 
						|
        <el-form-item prop="outStyle">
 | 
						|
          <el-select
 | 
						|
              v-model="queryParams.outStyle"
 | 
						|
              filterable clearable
 | 
						|
              style="width: 200px"
 | 
						|
              placeholder="请选择出库方式"
 | 
						|
          >
 | 
						|
              <el-option
 | 
						|
                  v-for="item in outStyleList"
 | 
						|
                  :key="item.id"
 | 
						|
                  :label="item.name"
 | 
						|
                  :value="item.id"
 | 
						|
              >
 | 
						|
              </el-option>
 | 
						|
          </el-select>
 | 
						|
        </el-form-item>
 | 
						|
 | 
						|
        <el-form-item>
 | 
						|
            <el-button
 | 
						|
                type="primary"
 | 
						|
                icon="el-icon-search"
 | 
						|
                size="mini"
 | 
						|
                @click="handleQuery"
 | 
						|
                >查询</el-button
 | 
						|
            >
 | 
						|
            <el-button
 | 
						|
                icon="el-icon-refresh"
 | 
						|
                size="mini"
 | 
						|
                @click="resetQuery"
 | 
						|
                >重置</el-button
 | 
						|
            >
 | 
						|
            <el-button
 | 
						|
                type="warning"
 | 
						|
                plain
 | 
						|
                icon="el-icon-download"
 | 
						|
                size="mini"
 | 
						|
                @click="handleExport"
 | 
						|
                >导出</el-button
 | 
						|
            >
 | 
						|
        </el-form-item>
 | 
						|
      </el-form>
 | 
						|
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
						|
      <el-table v-loading="loading" :data="tableList" border :max-height="650">
 | 
						|
          <el-table-column label="序号" align="center" type="index">
 | 
						|
                <template scope="scope">
 | 
						|
                    <span>{{ (queryParams.pageNum - 1) * 10 + scope.$index+1 }}</span>
 | 
						|
                </template>
 | 
						|
          </el-table-column>
 | 
						|
          <el-table-column label="工程名称" align="center" prop="proName" width="180"/>
 | 
						|
          <el-table-column label="往来单位" align="center" prop="unitName" width="180"/>
 | 
						|
          <el-table-column label="协议号" align="center" prop="agreementCode" width="140"/>
 | 
						|
          <el-table-column label="实施单位" align="center" prop="impUnitName" width="150px" :show-overflow-tooltip="true"/>
 | 
						|
          <!-- <el-table-column label="合同主体" align="center" prop="contractPart" width="150px" :show-overflow-tooltip="true"/> -->
 | 
						|
          <el-table-column label="物资名称" align="center" prop="typeName" :show-overflow-tooltip="true"/>
 | 
						|
          <el-table-column label="规格型号" align="center" prop="typeModelName" width="110"/>
 | 
						|
          <el-table-column label="设备编码" align="center" prop="maCode" :show-overflow-tooltip="true"/>
 | 
						|
          <el-table-column label="计量单位" align="center" prop="unit" :show-overflow-tooltip="true"/>
 | 
						|
          <el-table-column label="出库数量" align="center" prop="outNum" :show-overflow-tooltip="true"></el-table-column>
 | 
						|
          <el-table-column label="出库人员" align="center" prop="outUser" :show-overflow-tooltip="true"></el-table-column>
 | 
						|
          <el-table-column label="出库时间" align="center" prop="outTime" width="100"></el-table-column>
 | 
						|
          <el-table-column label="领料单号" align="center" prop="leaseCode" width="140">
 | 
						|
            <template slot-scope="scope">
 | 
						|
              <span class="clickText" @click="jumpLease(scope.row.leaseCode)">
 | 
						|
              {{ scope.row.leaseCode }}
 | 
						|
              </span>
 | 
						|
            </template>
 | 
						|
          </el-table-column>
 | 
						|
          <el-table-column label="出库方式" align="center" prop="outStyle" :show-overflow-tooltip="true"/>
 | 
						|
      </el-table>
 | 
						|
      <pagination
 | 
						|
          v-show="total > 0"
 | 
						|
          :total="total"
 | 
						|
          :page.sync="queryParams.pageNum"
 | 
						|
          :limit.sync="queryParams.pageSize"
 | 
						|
          :page-sizes="[10, 20, 50, 100]"
 | 
						|
          @pagination="getList"
 | 
						|
      />
 | 
						|
    </div>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
import {
 | 
						|
  getOutRecordListApi,getOptionListApi,
 | 
						|
} from '@/api/stquery/stquery';
 | 
						|
import {
 | 
						|
    getProjectList,
 | 
						|
    getUnitList,
 | 
						|
} from '@/api/back/index.js'
 | 
						|
import Treeselect from "@riophae/vue-treeselect";
 | 
						|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 | 
						|
export default {
 | 
						|
    name: 'DeviceOutBound',
 | 
						|
    dicts: [],
 | 
						|
    components: { Treeselect },
 | 
						|
    data() {
 | 
						|
        return {
 | 
						|
            // 遮罩层
 | 
						|
            loading: false,
 | 
						|
            // 选中数组
 | 
						|
            ids: [],
 | 
						|
            // 弹出层标题
 | 
						|
            title: '查看',
 | 
						|
            // 非单个禁用
 | 
						|
            single: true,
 | 
						|
            // 非多个禁用
 | 
						|
            multiple: true,
 | 
						|
            // 显示搜索条件
 | 
						|
            showSearch: true,
 | 
						|
            selectTreeProps: {
 | 
						|
                children: 'children',
 | 
						|
                label: 'name',
 | 
						|
                // multiple: false,
 | 
						|
                value: 'id',
 | 
						|
                // multiple: true,
 | 
						|
            },
 | 
						|
            unitId: null,
 | 
						|
            projectId: null,
 | 
						|
            unitList: [],
 | 
						|
            proList: [],
 | 
						|
            outStyleList:[{id:'标准箱',name:'标准箱'},{id:'编码',name:'编码'},{id:'二维码',name:'二维码'},{id:'数量',name:'数量'},{id:'未知出库方式',name:'未知出库方式'}],
 | 
						|
            // 总条数
 | 
						|
            total: 0,
 | 
						|
            // 主表格数据
 | 
						|
            tableList: [],
 | 
						|
            // 查询参数
 | 
						|
            queryParams: {
 | 
						|
                pageNum: 1,
 | 
						|
                pageSize: 10,
 | 
						|
                time: null,
 | 
						|
                keyWord: null,
 | 
						|
                unitId: null,
 | 
						|
                proId: null,
 | 
						|
                typeName: null, //物资名称
 | 
						|
                typeModelName: null, //
 | 
						|
                outStyle:null,
 | 
						|
                companyId:null,
 | 
						|
                firstTypeIdList:[]
 | 
						|
            },
 | 
						|
            optionList: []
 | 
						|
        }
 | 
						|
    },
 | 
						|
    created() {
 | 
						|
        const end = new Date()
 | 
						|
        let start = new Date()
 | 
						|
        start.setMonth(start.getMonth() - 1)
 | 
						|
        this.queryParams.time = [this.format(start), this.format(end)]
 | 
						|
        this.initSelectData()
 | 
						|
        this.getList()
 | 
						|
    },
 | 
						|
    methods: {
 | 
						|
      format(date) {
 | 
						|
        const y = date.getFullYear()
 | 
						|
        const m = String(date.getMonth() + 1).padStart(2, '0')
 | 
						|
        const day = String(date.getDate()).padStart(2, '0')
 | 
						|
        return `${y}-${m}-${day}`
 | 
						|
      },
 | 
						|
      initSelectData() {
 | 
						|
          this.GetUnitData()
 | 
						|
          this.GetProData()
 | 
						|
          this.getOptionListApi()
 | 
						|
      },
 | 
						|
      /** 转换菜单数据结构 */
 | 
						|
      normalizer(node) {
 | 
						|
            if (node.children && !node.children.length) {
 | 
						|
                delete node.children;
 | 
						|
            }
 | 
						|
            return {
 | 
						|
                id: node.id,
 | 
						|
                label: node.name,
 | 
						|
                children: node.children,
 | 
						|
            };
 | 
						|
        },
 | 
						|
      // 获取 来往单位 列表数据
 | 
						|
      async GetUnitData() {
 | 
						|
              const params = {
 | 
						|
                //   projectId: this.queryParams.proId /*  */,
 | 
						|
              }
 | 
						|
              const res = await getUnitList(params)
 | 
						|
              this.unitList = res.data
 | 
						|
      },
 | 
						|
      unitChange(val){
 | 
						|
        //   if(val&&val.length>0){
 | 
						|
        //       this.queryParams.unitId=this.unitId[this.unitId.length - 1]
 | 
						|
        //   }else if(val&&val.length==0){
 | 
						|
        //       this.queryParams.unitId=""
 | 
						|
        //   }
 | 
						|
        //   this.GetProData()
 | 
						|
        setTimeout(()=>{
 | 
						|
            this.GetProData()
 | 
						|
        },500)
 | 
						|
      },
 | 
						|
      // 获取 工程名称 列表数据
 | 
						|
      async GetProData() {
 | 
						|
              const params = { unitId: this.queryParams.unitId}
 | 
						|
              const res = await getProjectList(params)
 | 
						|
              this.proList = res.data
 | 
						|
              this.queryParams.proId=null
 | 
						|
      },
 | 
						|
      async getOptionListApi() {
 | 
						|
          const res = await getOptionListApi()
 | 
						|
          if (res.code == 200) {
 | 
						|
              this.optionList = res.data.map((item) => {
 | 
						|
                  return {
 | 
						|
                      value: item.typeId,
 | 
						|
                      label: item.typeName,
 | 
						|
                  }
 | 
						|
               }
 | 
						|
          )}
 | 
						|
      },
 | 
						|
      proChange(val){
 | 
						|
        //   if(val&&val.length>0){
 | 
						|
        //       this.queryParams.proId=this.projectId[this.projectId.length - 1]
 | 
						|
        //   }else if(val&&val.length==0){
 | 
						|
        //       this.queryParams.proId=""
 | 
						|
        //   }
 | 
						|
        //   this.GetUnitData()
 | 
						|
        setTimeout(()=>{
 | 
						|
            this.GetUnitData()
 | 
						|
        },500)
 | 
						|
      },
 | 
						|
      //跳转领料
 | 
						|
      jumpLease(code){
 | 
						|
        this.$router.push({ path: "/lease/outBound", query: {'code':code} });
 | 
						|
      },
 | 
						|
      // 获取列表
 | 
						|
      async getList() {
 | 
						|
          this.loading = true
 | 
						|
          const params = {
 | 
						|
                unitId: this.queryParams.unitId,
 | 
						|
                proId: this.queryParams.proId,
 | 
						|
                keyWord: this.queryParams.keyWord,
 | 
						|
                outStyle: this.queryParams.outStyle,
 | 
						|
                typeName: this.queryParams.typeName,
 | 
						|
                typeModelName: this.queryParams.typeModelName,
 | 
						|
                firstTypeIdList: this.queryParams.firstTypeIdList,
 | 
						|
                startTime: this.queryParams.time && this.queryParams.time[0],
 | 
						|
                endTime: this.queryParams.time && this.queryParams.time[1],
 | 
						|
                pageSize: this.queryParams.pageSize,
 | 
						|
                pageNum: this.queryParams.pageNum
 | 
						|
            }
 | 
						|
          const res = await getOutRecordListApi(params)
 | 
						|
          this.loading = false
 | 
						|
          if(res.data.rows.length>0){
 | 
						|
            this.tableList = res.data.rows;
 | 
						|
            // let obj = {
 | 
						|
            //   leaseNum: res.data.rows[0].projUsingDto.totalLeaseNum||0,
 | 
						|
            //   backNum: res.data.rows[0].projUsingDto.totalBackNum||0,
 | 
						|
            //   usNum: res.data.rows[0].projUsingDto.totalUsNum||0,
 | 
						|
            //   usPrice: res.data.rows[0].projUsingDto.totalUsPrice||0,
 | 
						|
            //   totalPrice: res.data.rows[0].projUsingDto.totalTotalPrice||0,
 | 
						|
            //   isSltName:''
 | 
						|
            // }
 | 
						|
            // this.tableList.unshift(obj)
 | 
						|
          }else{
 | 
						|
            this.tableList=[]
 | 
						|
          }
 | 
						|
          this.total = res.data.total;
 | 
						|
      },
 | 
						|
      /** 搜索按钮操作 */
 | 
						|
      handleQuery() {
 | 
						|
          this.queryParams.pageNum = 1
 | 
						|
          this.getList()
 | 
						|
      },
 | 
						|
      /** 重置按钮操作 */
 | 
						|
      resetQuery() {
 | 
						|
        const end = new Date()
 | 
						|
        let start = new Date()
 | 
						|
        start.setMonth(start.getMonth() - 1)
 | 
						|
        this.queryParams.time = [this.format(start), this.format(end)]
 | 
						|
        this.unitId=[]
 | 
						|
        this.projectId=[]
 | 
						|
        this.queryParams.firstTypeIdList=[]
 | 
						|
        this.resetForm('queryForm')
 | 
						|
        this.handleQuery()
 | 
						|
      },
 | 
						|
      /** 导出按钮操作 */
 | 
						|
      handleExport() {
 | 
						|
        const formatTime = (date) => {
 | 
						|
          const year = date.getFullYear();
 | 
						|
          const month = String(date.getMonth() + 1).padStart(2, '0');
 | 
						|
          const day = String(date.getDate()).padStart(2, '0');
 | 
						|
          const hours = String(date.getHours()).padStart(2, '0');
 | 
						|
          const minutes = String(date.getMinutes()).padStart(2, '0');
 | 
						|
          const seconds = String(date.getSeconds()).padStart(2, '0');
 | 
						|
          return `${year}${month}${day}_${hours}${minutes}${seconds}`;
 | 
						|
        };
 | 
						|
 | 
						|
        const params = {
 | 
						|
            unitId: this.queryParams.unitId,
 | 
						|
            proId: this.queryParams.proId,
 | 
						|
            keyWord: this.queryParams.keyWord,
 | 
						|
            outStyle: this.queryParams.outStyle,
 | 
						|
            typeName: this.queryParams.typeName,
 | 
						|
            typeModelName: this.queryParams.typeModelName,
 | 
						|
            firstTypeIdList: this.queryParams.firstTypeIdList,
 | 
						|
            startTime: this.queryParams.time && this.queryParams.time[0],
 | 
						|
            endTime: this.queryParams.time && this.queryParams.time[1],
 | 
						|
            pageSize: this.queryParams.pageSize,
 | 
						|
            pageNum: this.queryParams.pageNum
 | 
						|
        }
 | 
						|
        const currentTime = formatTime(new Date());
 | 
						|
          this.download(
 | 
						|
              'material/complex_query/exportOutRecord',
 | 
						|
              {
 | 
						|
                  ...params,
 | 
						|
              },
 | 
						|
              `综合查询_出库记录_${currentTime}.xlsx`,
 | 
						|
          )
 | 
						|
      },
 | 
						|
 | 
						|
    },
 | 
						|
}
 | 
						|
</script>
 | 
						|
<style lang="scss" scoped>
 | 
						|
::v-deep.el-table .fixed-width .el-button--mini {
 | 
						|
    width: 60px !important;
 | 
						|
    margin-bottom: 10px;
 | 
						|
}
 | 
						|
.clickText {
 | 
						|
  color: #02a7f0;
 | 
						|
  cursor: pointer;
 | 
						|
}
 | 
						|
</style>
 |