<template> <div class="app-container"> <div class="search"> <el-select v-model="table.getdataListParm.parammaps.feedid" filterable placeholder="饲料名称" class="filter-item" style="width: 150px;" clearable> <el-option v-for="item in feedNameList" :key="item.id" :label="item.fname" :value="item.id" /> </el-select> <el-button class="successBorder" @click="handleSearch">查询</el-button> <el-button class="successBorder" @click="handleRefresh">重置</el-button> </div> <div class="table"> <el-table :key="table.tableKey" v-loading="table.listLoading" element-loading-text="给我一点时间" :data="table.list" border fit highlight-current-row style="width: 100%;" :row-style="rowStyle" :cell-style="cellStyle" class="elTable table-fixed" > <el-table-column label="序号" align="center" type="index" width="50px"> <template slot-scope="scope"> <span>{{ scope.$index + (table.pageNum-1) * table.pageSize + 1 }}</span> </template> </el-table-column> <el-table-column label="饲料名称" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.feedname }}</span> </template> </el-table-column> <el-table-column label="批号" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.pcpde }}</span> </template> </el-table-column> <el-table-column label="当前库存重量(kg)" min-width="110px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.stockweight }}</span> </template> </el-table-column> <el-table-column label="金额(元)" min-width="110px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.sumprice }}</span> </template> </el-table-column> <el-table-column label="操作" align="center" width="120" class-name="small-padding fixed-width" fixed="right"> <template slot-scope="{row}"> <el-button class="miniPrimary" :disabled="isokDisable" @click="handleSee(row)">查看</el-button> </template> </el-table-column> </el-table> <pagination v-show="table.total>=0" :total="table.total" :page.sync="table.getdataListParm.offset" :limit.sync="table.getdataListParm.pagecount" @pagination="getList" /> </div> <el-dialog :title="textMap[see.dialogStatus]" :visible.sync="see.dialogFormVisible" :close-on-click-modal="false" width="90%"> <div class="app-see"> <el-tabs v-model="see.activeName" @tab-click="handleTabClick"> <el-tab-pane label="入库记录" name="first"> <div class="search"> <el-date-picker v-model="see.getdataListParm.parammaps.inputDatetime" class="inputDatetime filter-item" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" style="width: 250px;" /> <el-button class="successBorder" @click="handleSearch1">查询</el-button> </div> <div class="table"> <el-table :key="see.tableKey" v-loading="see.listLoading" element-loading-text="给我一点时间" :data="see.list" border fit highlight-current-row style="width: 100%;" :row-style="rowStyle" :cell-style="cellStyle" class="elTable table-fixed" > <el-table-column label="序号" align="center" type="index" width="50px"> <template slot-scope="scope"> <span>{{ scope.$index + (see.pageNum-1) * see.pageSize + 1 }}</span> </template> </el-table-column> <el-table-column label="入库日期" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.laiddate }}</span> </template> </el-table-column> <el-table-column label="操作重量(kg)" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.operateweight }}</span> </template> </el-table-column> <el-table-column label="金额(元)" min-width="110px" align="center"> <template slot-scope="scope"> <span> {{ scope.row.sumprice }}</span> </template> </el-table-column> <el-table-column label="备注" min-width="110px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.remark }}</span> </template> </el-table-column> </el-table> </div> <pagination v-show="see.total>=0" style="margin-bottom: 50px;" :total="see.total" :page.sync="see.getdataListParm.offset" :limit.sync="see.getdataListParm.pagecount" @pagination="getSeeList" /> </el-tab-pane> <el-tab-pane label="出库记录" name="second"> <div class="search"> <el-select v-model="see.getdataListParm2.parammaps.usetype" placeholder="出库类型" class="filter-item" style="width: 150px;" clearable> <el-option v-for="item in deliveryTypeList" :key="item.id" :label="item.label" :value="item.value" /> </el-select> <el-date-picker v-model="see.getdataListParm2.parammaps.inputDatetime" class="inputDatetime filter-item" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" style="width: 250px;" /> <el-button class="successBorder" @click="handleSearch2">查询</el-button> </div> <div class="table"> <el-table :key="see.tableKey2" v-loading="see.listLoading2" element-loading-text="给我一点时间" :data="see.list2" border fit highlight-current-row style="width: 100%;" :row-style="rowStyle" :cell-style="cellStyle" class="elTable table-fixed" > <el-table-column label="序号" align="center" type="index" width="50px"> <template slot-scope="scope"> <span>{{ scope.$index + (see.pageNum2-1) * see.pageSize2 + 1 }}</span> </template> </el-table-column> <el-table-column label="出库日期" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.usedate }}</span> </template> </el-table-column> <el-table-column label="出库类型" min-width="130px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.usetype }}</span> </template> </el-table-column> <el-table-column label="牲畜类别" min-width="110px" align="center"> <template slot-scope="scope"> <span> {{ scope.row.cowclass }}</span> </template> </el-table-column> <el-table-column label="操作重量(kg)" min-width="110px" align="center"> <template slot-scope="scope"> <span> {{ scope.row.operateweight }}</span> </template> </el-table-column> <el-table-column label="备注" min-width="110px" align="center"> <template slot-scope="scope"> <span>{{ scope.row.remark }}</span> </template> </el-table-column> </el-table> </div> <pagination v-show="see.total2>=0" style="margin-bottom: 50px;" :total="see.total2" :page.sync="see.getdataListParm2.offset" :limit.sync="see.getdataListParm2.pagecount" @pagination="getSeeList2" /> </el-tab-pane> </el-tabs> <div slot="footer" class="dialog-footer"> <el-button class="cancelClose" @click="see.dialogFormVisible = false; ">关闭</el-button> </div> </div> </el-dialog> </div> </template> <script> import { GetDataByName, GetDataByNames, checkButtons } from '@/api/common' import Pagination from '@/components/Pagination' import Cookies from 'js-cookie' import { parseTime } from '@/utils/index.js' export default { name: 'Statistics', components: { Pagination }, data() { return { isRoleEdit: [], requestParams: [ { name: 'getFeedListEnable', offset: 0, pagecount: 0, parammaps: { pastureid: Cookies.get('pastureid') }}, { name: 'getDictByNameUse', offset: 0, pagecount: 0, params: ['人工用量操作类型'] } ], feedNameList: [], // 饲料名称 deliveryTypeList: [], // 出库类型 table: { getdataListParm: { name: 'getFeedstorageList', page: 1, offset: 1, pagecount: 10, returntype: 'Map', parammaps: { pastureid: Cookies.get('pastureid'), feedid: '' } }, tableKey: 0, list: [], total: 0, listLoading: true }, textMap: { see: '库存' }, see: { dialogFormVisible: false, dialogStatus: '', temp: {}, rules: {}, getdataListParm: { name: 'getFsLaidList', page: 1, offset: 1, pagecount: 10, returntype: 'Map', parammaps: { pastureid: '', feedid: '', inputDatetime: '', startTime: '', stopTime: '' } }, tableKey: 0, list: [], total: 0, listLoading: true, activeName: 'first', getdataListParm2: { name: 'getFsUseList', page: 1, offset: 1, pagecount: 10, returntype: 'Map', parammaps: { pastureid: '', feedid: '', inputDatetime: '', startTime: '', stopTime: '', usetype: '' } }, tableKey2: 0, list2: [], total2: 0, listLoading2: true }, requestParam: {}, isokDisable: false, rowStyle: { maxHeight: 50 + 'px', height: 45 + 'px' }, cellStyle: { padding: 0 + 'px' } } }, created() { this.getButtons() this.getDownList() this.getList() }, methods: { getButtons() { const Edit = 'Statistics' const isRoleEdit = checkButtons(JSON.parse(sessionStorage.getItem('buttons')), Edit) this.isRoleEdit = isRoleEdit }, getDownList() { GetDataByNames(this.requestParams).then(response => { this.feedNameList = response.data.getFeedListEnable.list this.deliveryTypeList = response.data.getDictByNameUse.list }) }, getList() { this.table.listLoading = true GetDataByName(this.table.getdataListParm).then(response => { console.log('table数据', response.data.list) if (response.data.list !== null) { this.table.list = response.data.list this.table.pageNum = response.data.pageNum this.table.pageSize = response.data.pageSize this.table.total = response.data.total } else { this.table.list = [] } setTimeout(() => { this.table.listLoading = false }, 100) }) }, handleSearch() { console.log('点击了查询') this.table.getdataListParm.offset = 1 this.getList() }, handleRefresh() { console.log('点击了重置') this.table.getdataListParm.offset = 1 this.table.getdataListParm.parammaps.feedid = '' }, handleSee(row) { this.see.dialogStatus = 'see' this.see.dialogFormVisible = true this.see.list = [] this.see.getdataListParm.offset = 1 this.see.getdataListParm2.offset = 1 this.see.getdataListParm.parammaps.pastureid = row.pastureid this.see.getdataListParm.parammaps.feedid = row.feedid this.see.getdataListParm2.parammaps.pastureid = row.pastureid this.see.getdataListParm2.parammaps.feedid = row.feedid this.see.activeName = 'first' this.getSeeList() this.getSeeList2() }, getSeeList() { this.see.listLoading = true GetDataByName(this.see.getdataListParm).then(response => { console.log('table数据', response.data.list) if (response.data.list !== null) { this.see.list = response.data.list this.see.pageNum = response.data.pageNum this.see.pageSize = response.data.pageSize this.see.total = response.data.total } else { this.see.list = [] } setTimeout(() => { this.see.listLoading = false }, 100) }) }, getSeeList2() { this.see.listLoading2 = true GetDataByName(this.see.getdataListParm2).then(response => { console.log('table数据2', response.data.list) if (response.data.list !== null) { this.see.list2 = response.data.list this.see.pageNum2 = response.data.pageNum this.see.pageSize2 = response.data.pageSize this.see.total2 = response.data.total } else { this.see.list2 = [] } setTimeout(() => { this.see.listLoading2 = false }, 100) }) }, handleTabClick(val) { if (val.name === 'first') { this.getSeeList() } else if (val.name === 'second') { this.getSeeList2() } }, handleSearch1() { console.log('点击了库存入库记录查询') if (this.see.getdataListParm.parammaps.inputDatetime !== '' && this.see.getdataListParm.parammaps.inputDatetime !== null) { this.see.getdataListParm.parammaps.startTime = parseTime(this.see.getdataListParm.parammaps.inputDatetime[0], '{y}-{m}-{d}') this.see.getdataListParm.parammaps.stopTime = parseTime(this.see.getdataListParm.parammaps.inputDatetime[1], '{y}-{m}-{d}') } else { this.see.getdataListParm.parammaps.inputDatetime = '' this.see.getdataListParm.parammaps.startTime = '' this.see.getdataListParm.parammaps.stopTime = '' } this.getSeeList() }, handleSearch2() { console.log('点击了库存出库记录查询') if (this.see.getdataListParm2.parammaps.inputDatetime !== '' && this.see.getdataListParm2.parammaps.inputDatetime !== null) { this.see.getdataListParm2.parammaps.startTime = parseTime(this.see.getdataListParm2.parammaps.inputDatetime[0], '{y}-{m}-{d}') this.see.getdataListParm2.parammaps.stopTime = parseTime(this.see.getdataListParm2.parammaps.inputDatetime[1], '{y}-{m}-{d}') } else { this.see.getdataListParm2.parammaps.inputDatetime = '' this.see.getdataListParm2.parammaps.startTime = '' this.see.getdataListParm2.parammaps.stopTime = '' } this.getSeeList2() } } } </script> <style lang="scss" scoped> .search{margin-top:10px;} .table{margin-top:10px;} </style>