Bladeren bron

垛位管理

dxq 1 week geleden
bovenliggende
commit
41363b455a
1 gewijzigde bestanden met toevoegingen van 623 en 0 verwijderingen
  1. 623
    0
      src/views/sto/main/stack.vue

+ 623
- 0
src/views/sto/main/stack.vue Bestand weergeven

@@ -0,0 +1,623 @@
1
+<template>
2
+  <div>
3
+    <el-card :body-style="cardBodyStyle">
4
+      <el-form :model="query" label-width="auto" label-position="right">
5
+        <el-row :gutter="10">
6
+          <el-col :span="5">
7
+            <el-form-item label="所属库房" style="margin-bottom: 0px;">
8
+              <el-select
9
+                v-model="queryWare"
10
+                placeholder="请选择库房"
11
+                clearable
12
+                style="width: 100%;"
13
+                @change="change"
14
+                @clear="clear"
15
+              >
16
+                <el-option
17
+                  v-for="item in options"
18
+                  :key="item.id"
19
+                  :label="item.label"
20
+                  :value="item.value"
21
+                />
22
+              </el-select>
23
+            </el-form-item>
24
+          </el-col>
25
+          <el-col :span="5">
26
+            <el-form-item label="名称/编码" style="margin-bottom: 0px;">
27
+              <el-input v-model="query" clearable placeholder="请输入名称或编码" style="width: 100%;"></el-input>
28
+            </el-form-item>
29
+          </el-col>
30
+          <el-col :span="9">
31
+            <el-form-item label="" style="margin-bottom: 0px; margin-top: 5px;">
32
+              <el-button type="primary" @click="search">查询</el-button>
33
+              <el-button type="success" @click="handleAdd">新增</el-button>
34
+            </el-form-item>
35
+          </el-col>
36
+        </el-row>
37
+      </el-form>
38
+    </el-card>
39
+
40
+<!--    <el-card :body-style="cardBodyStyle" v-show="isShowLayout">-->
41
+<!--      <div id="wareLayout" style="margin: 10px; width: 600px; height: 300px; background-color: #00FFFF;"></div>-->
42
+<!--    </el-card>-->
43
+
44
+    <el-card :body-style="cardBodyStyle">
45
+      <el-table v-loading="loading" :data="tableData" border highlight-current-row>
46
+        <el-table-column type="index" label="序号" align="center" width="60">
47
+          <template #default="scope">
48
+            <span>{{ scope.$index + (currentPage - 1) * pageSize + 1 }}</span>
49
+          </template>
50
+        </el-table-column>
51
+        <el-table-column prop="wareName" label="所属库房" width="120" header-align="center" align="center" show-overflow-tooltip />
52
+        <el-table-column prop="name" label="垛位名称" width="120" header-align="center" align="center" show-overflow-tooltip />
53
+        <el-table-column prop="code" label="垛位编码" width="120" header-align="center" align="center" show-overflow-tooltip />
54
+        <el-table-column prop="stackX" label="起始X" width="120" header-align="center" align="center" />
55
+        <el-table-column prop="stackY" label="起始Y" width="120" header-align="center" align="center" />
56
+        <el-table-column prop="width" label="垛位长度" width="120" header-align="center" align="center" />
57
+        <el-table-column prop="height" label="垛位宽度" width="120" header-align="center" align="center" />
58
+        <el-table-column prop="isLayer" label="是否分层" width="120" header-align="center" align="center" :formatter="typeFormatter" />
59
+        <el-table-column label="操作" header-align="center" align="center" width="200" fixed="right">
60
+          <template #default="scope">
61
+            <el-button plain type="warning" size="small" @click="handleEdit(scope.row)">编辑</el-button>
62
+            <el-button plain type="danger" size="small" @click="handleDelete(scope.row.id)">删除</el-button>
63
+          </template>
64
+        </el-table-column>
65
+      </el-table>
66
+    </el-card>
67
+
68
+    <el-card :body-style="cardBodyStyle">
69
+      <el-pagination
70
+        :current-page="currentPage"
71
+        :page-size="pageSize"
72
+        :page-sizes="pageSizes"
73
+        :total="totalRows"
74
+        background="background"
75
+        layout="total, sizes, prev, pager, next, jumper"
76
+        @size-change="handleSizeChange"
77
+        @current-change="handleCurrentChange"
78
+      />
79
+    </el-card>
80
+
81
+    <el-dialog
82
+      class="diaClass"
83
+      :close-on-click-modal="false"
84
+      draggable
85
+      :title="stack.id ? '编辑' : '新增'"
86
+      v-model="dialogVisible"
87
+      width="40%"
88
+      top="5vh"
89
+    >
90
+      <el-card :body-style="cardBodyStyle">
91
+        <el-form :model="stack" label-width="120px" label-position="right" inline>
92
+          <el-row>
93
+            <el-col :span="12">
94
+              <el-form-item label="所属库房">
95
+                <el-select v-model="stack.wareId" clearable placeholder="请选择库房" style="width: 100%;">
96
+                  <el-option
97
+                    v-for="item in options"
98
+                    :key="item.id"
99
+                    :label="item.label"
100
+                    :value="item.value"
101
+                  />
102
+                </el-select>
103
+              </el-form-item>
104
+            </el-col>
105
+            <el-col :span="12">
106
+              <el-form-item label="垛位名称">
107
+                <el-input v-model="stack.name" maxlength="100" placeholder="请输入垛位名称"></el-input>
108
+              </el-form-item>
109
+            </el-col>
110
+            <el-col :span="12">
111
+              <el-form-item label="垛位编码">
112
+                <el-input v-model="stack.code" maxlength="50" placeholder="请输入垛位编码"></el-input>
113
+              </el-form-item>
114
+            </el-col>
115
+            <el-col :span="12">
116
+              <el-form-item label="起始X">
117
+                <el-input v-model.number="stack.stackX" type="number" placeholder="请输入起始X"></el-input>
118
+              </el-form-item>
119
+            </el-col>
120
+            <el-col :span="12">
121
+              <el-form-item label="起始Y">
122
+                <el-input v-model.number="stack.stackY" type="number" placeholder="请输入起始Y"></el-input>
123
+              </el-form-item>
124
+            </el-col>
125
+            <el-col :span="12">
126
+              <el-form-item label="垛位长度">
127
+                <el-input v-model.number="stack.width" type="number" placeholder="请输入垛位长度"></el-input>
128
+              </el-form-item>
129
+            </el-col>
130
+            <el-col :span="12">
131
+              <el-form-item label="垛位宽度">
132
+                <el-input v-model.number="stack.height" type="number" placeholder="请输入垛位宽度"></el-input>
133
+              </el-form-item>
134
+            </el-col>
135
+            <el-col :span="24">
136
+              <el-form-item label="是否分层">
137
+                <el-radio-group v-model="stack.isLayer">
138
+                  <el-radio label="0">不分层</el-radio>
139
+                  <el-radio label="1">自动分层</el-radio>
140
+                  <el-radio label="2">手动分层</el-radio>
141
+                </el-radio-group>
142
+              </el-form-item>
143
+            </el-col>
144
+          </el-row>
145
+        </el-form>
146
+      </el-card>
147
+      <template #footer>
148
+        <div class="dialog-footer">
149
+          <el-button type="success" plain @click="handleSave">保存</el-button>
150
+          <el-button type="danger" plain @click="handleCancelSave">取消</el-button>
151
+        </div>
152
+      </template>
153
+    </el-dialog>
154
+  </div>
155
+</template>
156
+
157
+<script>
158
+	import axios from '@/axios'
159
+	// import zrender from 'zrender'
160
+	// import {
161
+	// 	mapState
162
+	// } from 'vuex'
163
+	import tools from '@/tools'
164
+
165
+	export default {
166
+		computed: {
167
+			// ...mapState({
168
+			// 	wareBackgroundColor: state => state.color.wareBackgroundColor,
169
+			// 	stackColor: state => state.color.stackColor,
170
+			// 	stackSelectedColor: state => state.color.stackSelectedColor
171
+			// }),
172
+			cardBodyStyle() {
173
+				return tools.style.card
174
+			}
175
+		},
176
+		components: {
177
+
178
+		},
179
+		data() {
180
+			return {
181
+				//表格初始化参数
182
+				tableData: [],
183
+				currentPage: 1,
184
+				totalRows: 0,
185
+				pageSizes: [ 10, 20, 30, 40],
186
+				pageSize: 10,
187
+				//查询条件
188
+				query: '',
189
+				queryWare: '',
190
+				queryByWareId: '',
191
+				//录入框
192
+				dialogVisible: false,
193
+				stack: {
194
+					id: '',
195
+					name: '',
196
+					code: '',
197
+					wareId: '',
198
+					stackX: 0,
199
+					stackY: 0,
200
+					width: 0,
201
+					height: 0,
202
+					isLayer: "0"
203
+				},
204
+				isShow: false,
205
+				isShowLayout: false,
206
+				loading: true,
207
+				options: [],
208
+				maintStackLayout: {},
209
+				isMouseDown: false,
210
+				isChild: false,
211
+				rectNew: {},
212
+				startX: 0,
213
+				startY: 0,
214
+				rectSelect: {},
215
+				stackSelect: {},
216
+				disX: 0,
217
+				disY: 0,
218
+			}
219
+		},
220
+		//界面渲染完毕调用   初始化表格参数
221
+		mounted() {
222
+			this.getTableData()
223
+			this.getAllWare()
224
+		},
225
+		// 组件销毁时清理资源
226
+		beforeDestroy() {
227
+			if (this.maintStackLayout && this.maintStackLayout.dispose) {
228
+				this.maintStackLayout.dispose()
229
+			}
230
+		},
231
+		methods: {
232
+			typeFormatter: function(row, column) {
233
+				switch (row.isLayer) {
234
+					case "0":
235
+						return "不分层";
236
+						break;
237
+					case "1":
238
+						return "自动分层";
239
+						break;
240
+					case "2":
241
+						return "手动分层";
242
+						break;
243
+				}
244
+			},
245
+			// 获取table数据
246
+			getTableData() {
247
+				this.loading = true
248
+				var url = 'sto/MaintStack/query.do'
249
+				this.queryByWareId = this.queryWare
250
+				var param = {
251
+					page: this.currentPage,
252
+					rows: this.pageSize,
253
+					query: this.query,
254
+					queryWare: this.queryByWareId
255
+				}
256
+				axios.get(url, param).then(response => {
257
+					if (response.data.code == 0) {
258
+						this.tableData = response.data.data.records
259
+						this.totalRows = response.data.data.total
260
+					} else {
261
+						this.$message({
262
+							type: 'error',
263
+							message: '查询失败:' + response.data.msg,
264
+						});
265
+					}
266
+					this.loading = false
267
+				}).catch(error => {
268
+					this.$message({
269
+						type: 'error',
270
+						message: '查询失败:' + error.message,
271
+					});
272
+					this.loading = false
273
+				});
274
+			},
275
+			getAllWare() {
276
+				var url = 'sto/Ware/options'
277
+				var param = {}
278
+				axios.get(url, param).then(response => {
279
+					if (response.data.code == 0) {
280
+						this.options = response.data.data || []
281
+					} else {
282
+						this.$message({
283
+							type: 'error',
284
+							message: '获取库房选项失败:' + response.data.msg,
285
+						});
286
+					}
287
+				}).catch(error => {
288
+					this.$message({
289
+						type: 'error',
290
+						message: '获取库房选项失败:' + error.message,
291
+					});
292
+				});
293
+			},
294
+			handleSizeChange(val) {
295
+				console.log(`每页 ${val} 条`);
296
+				this.pageSize = val
297
+				this.getTableData()
298
+			},
299
+			// 修改当前页事件
300
+			handleCurrentChange(val) {
301
+				console.log(`当前页: ${val}`);
302
+				this.currentPage = val
303
+				this.getTableData()
304
+			},
305
+			//保存按钮事件
306
+			handleSave() {
307
+				var tempStack = JSON.parse(JSON.stringify(this.stack));
308
+				// 从 options 中找到对应的库房名称
309
+				var wareOption = this.options.find(item => item.id === tempStack.ware.id);
310
+				if (wareOption) {
311
+					tempStack.ware.name = wareOption.name;
312
+				} else {
313
+					tempStack.ware.name = tempStack.ware.id;
314
+				}
315
+				var json = JSON.stringify(tempStack)
316
+				var url = 'sto/MaintStack/save.do'
317
+				var param = {
318
+					json: json
319
+				}
320
+				this.loading = true
321
+				axios.post(url, param).then(response => {
322
+					if (response.data.code == 0) {
323
+						this.$message({
324
+							type: 'success',
325
+							message: '保存成功!',
326
+						});
327
+						this.getTableData()
328
+						if (this.queryWare) {
329
+							// this.getAllStackByWareName(this.queryWare)
330
+						}
331
+						this.dialogVisible = false
332
+						this.loading = false
333
+					} else {
334
+						this.$message({
335
+							type: 'error',
336
+							message: '保存失败:' + response.data.msg,
337
+						});
338
+						this.loading = false
339
+					}
340
+				}).catch(error => {
341
+					this.$message({
342
+						type: 'error',
343
+						message: '保存失败:' + error.message,
344
+					});
345
+					this.loading = false
346
+				});
347
+			},
348
+			//保存取消按钮事件   关闭编辑对话框
349
+			handleCancelSave(row) {
350
+				this.dialogVisible = false
351
+			},
352
+			// 新增按钮事件
353
+			handleAdd() {
354
+				// 从 options 中找到对应的库房名称
355
+				var wareName = '';
356
+				if (this.queryWare) {
357
+					var wareOption = this.options.find(item => item.id === this.queryWare);
358
+					wareName = wareOption ? wareOption.name : this.queryWare;
359
+				}
360
+				this.dialogVisible = true
361
+				this.stack = {
362
+					id: '',
363
+					name: '',
364
+					code: '',
365
+					ware: {
366
+						id: this.queryWare || '',
367
+						name: wareName
368
+					},
369
+					stackX: 0,
370
+					stackY: 0,
371
+					width: 0,
372
+					height: 0,
373
+					isLayer: "0"
374
+				}
375
+			},
376
+			// 编辑按钮事件
377
+			handleEdit(row) {
378
+				var tempRow = JSON.parse(JSON.stringify(row));
379
+				// 确保 ware 对象存在
380
+				if (!tempRow.ware) {
381
+					tempRow.ware = { id: '', name: '' };
382
+				}
383
+				this.dialogVisible = true
384
+				this.stack = tempRow
385
+			},
386
+
387
+			// 删除按钮事件
388
+			handleDelete(id) {
389
+				this.$confirm('此操作将删除该数据, 是否继续?', '提示', {
390
+					confirmButtonText: '确定',
391
+					cancelButtonText: '取消',
392
+					type: 'warning'
393
+				}).then(() => {
394
+
395
+					var url = 'sto/MaintStack/remove.do'
396
+					var param = {
397
+						id: id
398
+					}
399
+					axios.post(url, param).then(response => {
400
+						if (response.data.code == 0) {
401
+							this.$message({
402
+								type: 'success',
403
+								message: '删除成功!',
404
+							});
405
+							this.getTableData()
406
+						} else {
407
+							this.$message({
408
+								type: 'error',
409
+								message: '删除失败;' + response.data.msg
410
+							});
411
+						}
412
+					});
413
+				}).catch(() => {
414
+					this.$message({
415
+						type: 'info',
416
+						message: '已取消删除'
417
+					});
418
+				});
419
+			},
420
+			// 查询按钮事件
421
+			search() {
422
+				this.currentPage = 1
423
+				this.getTableData()
424
+			},
425
+			change(val) {
426
+				//console.log("change(val)"+val)
427
+
428
+				if (val != '') {
429
+					this.isShowLayout = true
430
+					this.getTableData()
431
+					// this.getAllStackByWareName(val)
432
+				}
433
+			},
434
+			clear() {
435
+				this.isShowLayout = false
436
+			},
437
+			// getAllStackByWareName(val) {
438
+			// 	var url = 'sto/MaintStack/queryByWareId.do'
439
+			// 	var param = {
440
+			// 		wareId: val
441
+			// 	}
442
+			// 	axios.get(url, param).then(response => {
443
+			// 		if (response.data.code == 0) {
444
+			// 			this.drawWareLayout(response.data.data)
445
+			// 		} else {
446
+			// 			this.$message({
447
+			// 				type: 'error',
448
+			// 				message: '获取垛位布局失败:' + response.data.msg,
449
+			// 			});
450
+			// 		}
451
+			// 	}).catch(error => {
452
+			// 		this.$message({
453
+			// 			type: 'error',
454
+			// 			message: '获取垛位布局失败:' + error.message,
455
+			// 		});
456
+			// 	});
457
+			// },
458
+
459
+			// drawWareLayout(data) {
460
+			// 	// 如果已经初始化过,先清空
461
+			// 	if (this.maintStackLayout && this.maintStackLayout.dispose) {
462
+			// 		this.maintStackLayout.dispose()
463
+			// 	}
464
+			// 	// 重置状态
465
+			// 	this.isMouseDown = false
466
+			// 	this.isChild = false
467
+			// 	this.maintStackLayout = zrender.init(document.getElementById('wareLayout'))
468
+			// 	this.maintStackLayout.on('mousedown', (e) => {
469
+			// 		this.isMouseDown = true
470
+			// 		var startX = 0
471
+			// 		var endX = 0
472
+			// 		var startY = 0
473
+			// 		var endY = 0
474
+			// 		var width = 0
475
+			// 		var height = 0
476
+			// 		for (let i = 0; i < this.maintStackLayout.storage._roots.length; i++) {
477
+			// 			startX = this.maintStackLayout.storage._roots[i].shape.x
478
+			// 			startY = this.maintStackLayout.storage._roots[i].shape.y
479
+			// 			endX = this.maintStackLayout.storage._roots[i].shape.x + this.maintStackLayout.storage._roots[i].shape.width
480
+			// 			endY = this.maintStackLayout.storage._roots[i].shape.y + this.maintStackLayout.storage._roots[i].shape.height
481
+			// 			width = this.maintStackLayout.storage._roots[i].shape.width
482
+			// 			height = this.maintStackLayout.storage._roots[i].shape.height
483
+			// 		if (e.offsetX >= startX && e.offsetX <= endX && e.offsetY >= startY && e.offsetY <= endY) {
484
+			// 			console.log(i)
485
+			// 			this.isChild = true
486
+			// 			this.rectSelect = this.maintStackLayout.storage._roots[i]
487
+			// 			this.stackSelect = JSON.parse(JSON.stringify(data[i]))
488
+			// 			this.disX = e.offsetX - this.rectSelect.shape.x
489
+			// 			this.disY = e.offsetY - this.rectSelect.shape.y
490
+			// 			break
491
+			// 		}
492
+			// 		}
493
+
494
+			// 		if (this.isChild) {
495
+			// 			console.log("click rect:" + this.isChild)
496
+			// 		} else {
497
+
498
+			// 			this.startX = e.offsetX
499
+			// 			this.startY = e.offsetY
500
+			// 			this.rectNew = new zrender.Rect({
501
+			// 				shape: {
502
+			// 					x: e.offsetX, //data[i].stackX * 600 / data[i].ware.width,
503
+			// 					y: e.offsetY, //data[i].stackY * 300 / data[i].ware.height,
504
+			// 					width: 1, // data[i].width * 600 / data[i].ware.width,
505
+			// 					height: 1, //data[i].height * 300 / data[i].ware.height,
506
+			// 				},
507
+			// 				style: {
508
+			// 					text: 'A', //data[i].name,
509
+			// 					textAlign: 'center',
510
+			// 					textVerticalAlign: 'middle',
511
+			// 					fill: this.stackColor,
512
+			// 					stroke: '#000000',
513
+			// 				},
514
+			// 			})
515
+			// 			this.maintStackLayout.add(this.rectNew);
516
+			// 		}
517
+
518
+			// 	});
519
+			// 	this.maintStackLayout.on('mousemove', (e) => {
520
+
521
+			// 		if (this.isMouseDown) {
522
+
523
+			// 			if (this.isChild) {
524
+			// 				//console.log(" this.rectSelect.shape.x:" + this.rectSelect.shape.x)
525
+			// 				this.rectSelect.attr('shape', {
526
+			// 					x: e.offsetX - this.disX,
527
+			// 					y: e.offsetY - this.disY
528
+			// 				})
529
+			// 			} else {
530
+			// 				var width = e.offsetX - this.startX
531
+			// 				var height = e.offsetY - this.startY
532
+			// 				this.rectNew.attr('shape', {
533
+			// 					width: width,
534
+			// 					height: height
535
+			// 				})
536
+			// 			}
537
+			// 		}
538
+
539
+			// 	});
540
+			// 	this.maintStackLayout.on('mouseup', (e) => {
541
+			// 		this.isMouseDown = false
542
+			// 		if (this.isChild) {
543
+			// 			this.stackSelect.stackX = e.offsetX - this.disX
544
+			// 			this.stackSelect.stackY = e.offsetY - this.disY
545
+			// 			//
546
+			// 			this.stack = this.stackSelect
547
+			// 			console.log(JSON.stringify(this.stack))
548
+			// 			this.handleSave()
549
+			// 		} else {
550
+			// 			var width = e.offsetX - this.startX
551
+			// 			var height = e.offsetY - this.startY
552
+			// 			this.dialogVisible = true
553
+			// 			this.stack = {
554
+			// 				id: '',
555
+			// 				name: '',
556
+			// 				code: '',
557
+			// 				ware: {
558
+			// 					id: this.queryWare,
559
+			// 					name: this.queryWare
560
+			// 				},
561
+			// 				stackX: this.startX,
562
+			// 				stackY: this.startY,
563
+			// 				width: width,
564
+			// 				height: height,
565
+			// 				isLayer: "0"
566
+			// 			}
567
+			// 		}
568
+			// 		this.isChild = false
569
+			// 	});
570
+			// 	for (let i = 0; i < data.length; i++) {
571
+			// 		this.rectNew = new zrender.Rect({
572
+			// 			shape: {
573
+			// 				x: data[i].stackX, // * 600 / data[i].ware.width,
574
+			// 				y: data[i].stackY, //* 300 / data[i].ware.height,
575
+			// 				width: data[i].width, //* 600 / data[i].ware.width,
576
+			// 				height: data[i].height, //* 300 / data[i].ware.height,
577
+			// 			},
578
+			// 			style: {
579
+			// 				text: data[i].name,
580
+			// 				textAlign: 'center',
581
+			// 				textVerticalAlign: 'middle',
582
+			// 				fill: this.stackColor,
583
+			// 				stroke: '#000000',
584
+
585
+			// 			}
586
+			// 		})
587
+			// 		// rect.on('mousedown', (e) => {
588
+			// 		// 	this.isMouseDown = true
589
+			// 		// })
590
+			// 		// rect.on('mousemove', (e) => {
591
+			// 		// 	if (this.isMouseDown) {
592
+			// 		// 		 var disX = e.offsetX - e.target.shape.x
593
+			// 		// 		 var disY = e.offsetY - e.target.shape.y
594
+			// 		// 		e.target.attr('shape', {
595
+			// 		// 			x: e.target.offsetX +disX,
596
+			// 		// 			y: e.target.offsetY+disY
597
+			// 		// 		})
598
+			// 		// 	}
599
+			// 		// });
600
+			// 		// rect.on('mouseup', (e) => {
601
+			// 		// 	this.isMouseDown = false
602
+			// 		// })
603
+			// 		this.maintStackLayout.add(this.rectNew);
604
+			// 	}
605
+			// },
606
+
607
+		}
608
+	}
609
+</script>
610
+<style scoped>
611
+::v-deep .diaClass .el-form-item {
612
+  width: 100%;
613
+}
614
+::v-deep .el-autocomplete {
615
+  width: 100%;
616
+}
617
+::v-deep .el-dialog__body {
618
+  background-color: #F2F6FC;
619
+}
620
+.el-select-dropdown .el-scrollbar .el-scrollbar__wrap {
621
+  overflow: scroll !important;
622
+}
623
+</style>

Laden…
Annuleren
Opslaan