|
@@ -1,272 +1,173 @@
|
|
|
<template>
|
|
|
- <div class="app-container">
|
|
|
- <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
|
|
|
- <el-form-item label="仓库" prop="warehouseId">
|
|
|
- <el-select v-model="queryParams.warehouseId" placeholder="请选择所属仓库" clearable size="small" style="width: 100%">
|
|
|
- <el-option
|
|
|
- v-for="dict in this.warehouseCombo"
|
|
|
- :key="dict.warehouseId"
|
|
|
- :label="dict.warehouseName"
|
|
|
- :value="dict.warehouseId"
|
|
|
- />
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="区域" prop="zoneId">
|
|
|
- <el-select v-model="queryParams.zoneId" placeholder="请选择库区" clearable size="small" style="width: 100%">
|
|
|
- <el-option
|
|
|
- v-for="dict in this.locationZoneCombo"
|
|
|
- :key="dict.zoneId"
|
|
|
- :label="dict.zoneName"
|
|
|
- :value="dict.zoneId"
|
|
|
- />
|
|
|
- </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-form-item>
|
|
|
- </el-form>
|
|
|
- <el-row>
|
|
|
- <right-toolbar :showSearch.sync="showSearch" @queryTable="search"></right-toolbar>
|
|
|
- </el-row>
|
|
|
- <div style="overflow-scrolling: auto">
|
|
|
- <ul class="wall-row"
|
|
|
- :style="{'width':(this.tableAttr.cols * 145)+'px', 'height':(this.tableAttr.rows * 95) + 'px'}">
|
|
|
- <li
|
|
|
- v-for="(item, index) in divList"
|
|
|
- :key="index"
|
|
|
- @click="selected(item)">
|
|
|
- <div v-if="!item.locationNo" style="background-color: #fff;"><!--空格没有的库位--></div>
|
|
|
- <div class="div" v-else-if="item.stockStatus === '10'" style="background-color: yellow">
|
|
|
- <div style="text-align: center;font-weight: bold;">{{item.locationNo}}</div>
|
|
|
- <div v-for="(lot, index) in item.lotattVOList" style="font-size: 8px;">
|
|
|
- <div v-if="lot.sku">物料:{{lot.sku}}</div>
|
|
|
- <div v-if="lot.sku">数量:{{lot.qty}}</div>
|
|
|
- </div>
|
|
|
+ <el-container>
|
|
|
+ <el-header style="height: 40px">
|
|
|
+ <div>
|
|
|
+ <div class="divLeft colorYellow">
|
|
|
+ 任务中
|
|
|
+ </div>
|
|
|
+ <div class="divLeft colorGreen">
|
|
|
+ 空
|
|
|
+ </div>
|
|
|
+ <div class="divLeft colorRed">
|
|
|
+ 占用
|
|
|
+ </div>
|
|
|
+<!-- <div class="divLeft">-->
|
|
|
+<!-- 库存<icon-svg name="steel" class="site-sidebar__menu-icon"></icon-svg>-->
|
|
|
+<!-- </div>-->
|
|
|
+<!-- <div class="divLeft">-->
|
|
|
+<!-- 空托盘<icon-svg name="pallet" class="site-sidebar__menu-icon"></icon-svg>-->
|
|
|
+<!-- </div>-->
|
|
|
+ </div>
|
|
|
+ </el-header>
|
|
|
+ <el-main>
|
|
|
+ <el-card v-for="zone in locationZoneList" v-bind:key="zone.zoneName" class="box-card">
|
|
|
+ <div slot="header" class="clearfix">
|
|
|
+ <span style="font-weight: bold">{{zone.zoneName}}</span>
|
|
|
</div>
|
|
|
- <div class="div" v-else style="background-color: #ebf0f4">
|
|
|
- <div style="text-align: center;font-weight: bold;">{{item.locationNo}}</div>
|
|
|
- <div v-for="(lot, index) in item.lotattVOList" style="font-size: 8px;">
|
|
|
- <div v-if="lot.sku">物料:{{lot.sku}}</div>
|
|
|
- <div v-if="lot.sku">数量:{{lot.qty}}</div>
|
|
|
+ <div class="divBoxCol" v-for="col in zone.basLocationGuiColDTOS">
|
|
|
+ <div v-for="o in col.baseLocationGuiDTOList" v-bind:key="o.id" class="text item divBox" @click="changeLocation(o)">
|
|
|
+ <div class="divMinBox">
|
|
|
+ {{o.locationNo}}<!--(<font class="pointcss">{{o.agvStation}}</font>)-->
|
|
|
+ </div>
|
|
|
+ <div>
|
|
|
+ <div v-show="o.isEmpty=='Y'" :class="{'locDiv': true,'colorGreen': true, 'colorYellow': o.stockStatus!='00'}">
|
|
|
+ </div>
|
|
|
+ <div v-show="o.isEmpty=='N'" :class="{'locDiv': true,'colorRed': o.isEmptyPlate != 'Y', 'colorYellow': o.stockStatus!='00'}">
|
|
|
+ <div class="divMinFontBox" v-show="o.isEmpty=='N' && o.isEmptyPlate != 'Y' ">
|
|
|
+ <div style="color: #FFFFFF">{{o.lotatt01}} </div>
|
|
|
+ <div v-show="o.lotatt01!=null" style="color: #FFFFFF">{{o.lotatt01}}</div>
|
|
|
+ <div v-show="o.lotatt05!=null" style="color: #FFFFFF">{{o.lotatt05}}</div>
|
|
|
+ <div v-show="o.lotatt08!=null" style="color: #FFFFFF">{{o.lotatt08}}</div>
|
|
|
+ </div>
|
|
|
+ <div class="divMinFontBoxEmptyPlate" v-show="o.isEmptyPlate == 'Y'">
|
|
|
+<!-- <icon-svg name="pallet" class="site-sidebar__menu-icon" style="width: 60px;height: 35px">{{o.id}}</icon-svg>-->
|
|
|
+<!-- <div style="color: #191970">{{o.skuName}} </div>-->
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
- </li>
|
|
|
- </ul>
|
|
|
- </div>
|
|
|
- <el-dialog title="操作" :visible.sync="open" width="1000px" append-to-body>
|
|
|
- <el-form>
|
|
|
- <el-form-item>
|
|
|
- <el-button type="primary" @click="lockLoc()">锁定/解锁</el-button>
|
|
|
- <!--<el-button type="primary" @click="occupyLoc()">占用</el-button>-->
|
|
|
- <el-button type="primary" @click="clearLoc()">清空</el-button>
|
|
|
- <!--<el-button type="primary" @click="submitForm">初始化一个空托盘</el-button>-->
|
|
|
- </el-form-item>
|
|
|
- </el-form>
|
|
|
- <el-divider content-position="center">批次属性信息</el-divider>
|
|
|
- <el-table v-loading="loading" :data="form.lotattList">
|
|
|
- <el-table-column label="物料" align="center" prop="sku" width="200"/>
|
|
|
- <el-table-column label="物料名称" align="center" prop="skuName" width="200"/>
|
|
|
- <el-table-column label="库位" align="center" prop="locationNo" width="200"/>
|
|
|
- <el-table-column label="库存数量" align="center" prop="qty"/>
|
|
|
- <el-table-column label="已分配数量" align="center" prop="qtyallocated" width="200"/>
|
|
|
- <el-table-column
|
|
|
- v-for="(item, index) in itemOption"
|
|
|
- :key="index"
|
|
|
- :label="item.label"
|
|
|
- align="center" :prop="item.prop" width="200">
|
|
|
- </el-table-column>
|
|
|
- </el-table>
|
|
|
- <!--<el-descriptions title="批次属性" :column="2" border>
|
|
|
- <el-descriptions-item v-for="(item, index) in itemOption" :label="item.label">{{form[`${item.prop}`]}}</el-descriptions-item>
|
|
|
- </el-descriptions>-->
|
|
|
- </el-dialog>
|
|
|
- </div>
|
|
|
+ </el-card>
|
|
|
+ </el-main>
|
|
|
+ </el-container>
|
|
|
</template>
|
|
|
-
|
|
|
<script>
|
|
|
- import { locationView, lockLocRequest, occupyLocRequest, clearLocRequest } from "@/api/ams/locationView";
|
|
|
- import { queryLocationZoneDict } from "@/api/base/locationZone";
|
|
|
- import { queryWarehouseDict } from "@/api/base/warehouse";
|
|
|
- import { lotattConfigList } from "@/api/ams/config";
|
|
|
- import { lotattInfo } from "@/api/ams/invLotLocId";
|
|
|
+import { locationInvView } from "@/api/ams/locationView";
|
|
|
|
|
|
export default {
|
|
|
- name: "LocationView",
|
|
|
- data() {
|
|
|
+ data () {
|
|
|
return {
|
|
|
- divList: [],
|
|
|
- // 遮罩层
|
|
|
- loading: true,
|
|
|
- showSearch: true,
|
|
|
- open: false,
|
|
|
- // 查询参数
|
|
|
- queryParams: {
|
|
|
- zoneId: 2,
|
|
|
- warehouseId: 1
|
|
|
- },
|
|
|
- // 表单参数
|
|
|
- form: {
|
|
|
- lotatt01: '',
|
|
|
- lotatt02: '',
|
|
|
- lotatt03: '',
|
|
|
- lotatt04: '',
|
|
|
- lotatt05: '',
|
|
|
- lotatt06: '',
|
|
|
- lotatt07: '',
|
|
|
- lotatt08: '',
|
|
|
- lotatt09: '',
|
|
|
- lotatt10: '',
|
|
|
- lotatt11: '',
|
|
|
- lotatt12: '',
|
|
|
- lotatt13: '',
|
|
|
- lotatt14: '',
|
|
|
- lotatt15: '',
|
|
|
- lotatt16: '',
|
|
|
- lotatt17: '',
|
|
|
- lotatt18: '',
|
|
|
- lotattList: null
|
|
|
+ dataForm: {
|
|
|
+ zoneId: ''
|
|
|
},
|
|
|
- // 表单校验
|
|
|
- rules: {},
|
|
|
- tableAttr: {
|
|
|
- rows: 3,
|
|
|
- cols: 3
|
|
|
+ queryParams: {
|
|
|
+ zoneId: '',
|
|
|
+ warehouseId: ''
|
|
|
},
|
|
|
- currentSelect: null,
|
|
|
- locationZoneCombo: [],
|
|
|
- warehouseCombo: [],
|
|
|
- itemOption: [],
|
|
|
- timer: null // 定时器
|
|
|
- };
|
|
|
+ locationZoneList: [],
|
|
|
+ locationList: {'a': [1, 2, 3]},
|
|
|
+ locationClearVisible: false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ mounted () {
|
|
|
},
|
|
|
- created() {
|
|
|
- this.init();
|
|
|
- this.search();
|
|
|
- this.timer = setInterval(() =>{
|
|
|
- this.search();
|
|
|
- },1000 * 5)
|
|
|
+ activated () {
|
|
|
+ },
|
|
|
+ created () {
|
|
|
+ this.getDataList()
|
|
|
+ this.timer = setInterval(this.getDataList, 5000)
|
|
|
+ },
|
|
|
+ beforeDestroy () {
|
|
|
+ clearInterval(this.timer)
|
|
|
},
|
|
|
methods: {
|
|
|
- init() {
|
|
|
- queryWarehouseDict().then(response => {
|
|
|
- this.warehouseCombo = response.data
|
|
|
- });
|
|
|
- queryLocationZoneDict().then(response => {
|
|
|
- this.locationZoneCombo = response.data
|
|
|
- });
|
|
|
- lotattConfigList().then(response => {
|
|
|
- let data = response.data
|
|
|
- for(let i=0;i<data.length;i++) {
|
|
|
- let obj = new Object();
|
|
|
- obj.label = data[i].lotattName
|
|
|
- obj.prop = data[i].lotattId
|
|
|
- this.itemOption.push(obj)
|
|
|
- }
|
|
|
- })
|
|
|
- },
|
|
|
- search() {
|
|
|
- locationView(this.queryParams).then(response => {
|
|
|
- let data = response.data
|
|
|
- this.tableAttr.rows = data.rows
|
|
|
- this.tableAttr.cols = data.cols
|
|
|
- this.divList = data.locationViewInfoVOList
|
|
|
+ getDataList () {
|
|
|
+ this.dataListLoading = true
|
|
|
+ locationInvView(this.queryParams).then(response => {
|
|
|
+ this.locationZoneList = response.data
|
|
|
})
|
|
|
- },
|
|
|
- selected(item) {
|
|
|
- if (item.locationNo) {
|
|
|
- this.currentSelect = parseInt(item.id)
|
|
|
- this.open = true;
|
|
|
- lotattInfo(this.currentSelect).then(response => {
|
|
|
- this.form.lotattList = response.data
|
|
|
- this.loading = false;
|
|
|
- })
|
|
|
- }
|
|
|
- },
|
|
|
- handleQuery() {
|
|
|
- this.search()
|
|
|
- },
|
|
|
- resetQuery() {
|
|
|
- this.resetForm("queryForm");
|
|
|
- this.handleQuery();
|
|
|
- },
|
|
|
- lockLoc() {
|
|
|
- let that = this
|
|
|
- this.$modal.confirm('是否确认要锁定').then(function() {
|
|
|
- lockLocRequest(that.currentSelect).then(response => {
|
|
|
- if (response.code === 200) {
|
|
|
- that.$modal.msgSuccess(response.msg);
|
|
|
- that.search();
|
|
|
- that.open = false
|
|
|
- } else {
|
|
|
- that.$modal.msgError(response.msg);
|
|
|
- }
|
|
|
- });
|
|
|
- });
|
|
|
- },
|
|
|
- occupyLoc() {
|
|
|
- occupyLocRequest(this.currentSelect).then(response => {
|
|
|
- if (response.code === 200) {
|
|
|
- this.$modal.msgSuccess(response.msg);
|
|
|
- this.search();
|
|
|
- this.open = false
|
|
|
- } else {
|
|
|
- this.$modal.msgError(response.msg);
|
|
|
- }
|
|
|
- });
|
|
|
- },
|
|
|
- clearLoc() {
|
|
|
- let that = this
|
|
|
- this.$modal.confirm('是否确认要清空').then(function() {
|
|
|
- clearLocRequest(that.currentSelect).then(response => {
|
|
|
- if (response.code === 200) {
|
|
|
- that.$modal.msgSuccess(response.msg);
|
|
|
- that.search();
|
|
|
- that.open = false
|
|
|
- } else {
|
|
|
- that.$modal.msgError(response.msg);
|
|
|
- }
|
|
|
- });
|
|
|
- });
|
|
|
- },
|
|
|
- destroyed () {
|
|
|
- clearInterval(this.timer)
|
|
|
+ this.dataListLoading = false
|
|
|
}
|
|
|
}
|
|
|
- };
|
|
|
+ }
|
|
|
</script>
|
|
|
|
|
|
-<style scoped lang="css">
|
|
|
+<style>
|
|
|
|
|
|
- .word span {
|
|
|
- line-height: 20px;
|
|
|
- text-align: center;
|
|
|
- }
|
|
|
+.pointcss{
|
|
|
+ color: hotpink;
|
|
|
+}
|
|
|
|
|
|
- .wall-row {
|
|
|
- padding: 0;
|
|
|
- margin: 0;
|
|
|
- display: block;
|
|
|
- position: relative;
|
|
|
- }
|
|
|
+.divBoxCol {
|
|
|
+ width: 170px;
|
|
|
+ display: block;
|
|
|
+ float: left;
|
|
|
+}
|
|
|
|
|
|
- .wall-row li {
|
|
|
- list-style: none;
|
|
|
- width: 130px;
|
|
|
- height: 90px;
|
|
|
- border: 0.5px solid #fff;
|
|
|
- float: left;
|
|
|
- margin-top: 5px;
|
|
|
- margin-bottom: 5px;
|
|
|
- margin-right: 5px;
|
|
|
- margin-left: 5px;
|
|
|
- overflow: hidden;
|
|
|
- }
|
|
|
+.divBox {
|
|
|
+ width: 130px;
|
|
|
+ height: 90px;
|
|
|
+ display: block;
|
|
|
+ float: left;
|
|
|
+ margin-left: 2px;
|
|
|
+}
|
|
|
|
|
|
- .div {
|
|
|
- width:130px;
|
|
|
- height:90px;
|
|
|
- font-weight: bold;
|
|
|
- }
|
|
|
+.divMinBox {
|
|
|
+ margin-top: 0px;
|
|
|
+ height: 15px;
|
|
|
+ width: 115%;
|
|
|
+ text-align: center;
|
|
|
+ font-weight: bold;
|
|
|
+}
|
|
|
+
|
|
|
+.divMinFontBox {
|
|
|
+ margin-top: 2px;
|
|
|
+ height: 10px;
|
|
|
+ width: 100%;
|
|
|
+ text-align: center;
|
|
|
+ /*font-size: 1px;*/
|
|
|
+}
|
|
|
+
|
|
|
+.locDiv {
|
|
|
+ float: left;
|
|
|
+ display: inline-block;
|
|
|
+ width: 150px;
|
|
|
+ height: 70px;
|
|
|
+ margin-top: 1px;
|
|
|
+ text-align: center;
|
|
|
+ margin-left: 1px;
|
|
|
+ border: solid 1px;
|
|
|
+}
|
|
|
|
|
|
+.colorGreen {
|
|
|
+ background-color: #19a708;
|
|
|
+}
|
|
|
+
|
|
|
+.colorRed {
|
|
|
+ background-color: #c73c2d;
|
|
|
+}
|
|
|
+
|
|
|
+.colorYellow {
|
|
|
+ background-color: #e2cd0f;
|
|
|
+}
|
|
|
+
|
|
|
+.divLeft {
|
|
|
+ border-top: 1px;
|
|
|
+ border-color: #2b373d;
|
|
|
+ text-align: left;
|
|
|
+ display: inline-block;
|
|
|
+ height: 30px;
|
|
|
+ width: 80px;
|
|
|
+ text-align: center;
|
|
|
+ margin-top: 10px;
|
|
|
+ padding-top: 5px;
|
|
|
+}
|
|
|
+
|
|
|
+.box-card{
|
|
|
+ width: 100%;
|
|
|
+ display:inline-block;
|
|
|
+ overflow: hidden;
|
|
|
+}
|
|
|
</style>
|
|
|
+
|
|
|
+
|