From 8520e36378e8e88cbbc45586bb31d1fec3be87ac Mon Sep 17 00:00:00 2001 From: wxw <Administrator@DESKTOP-5BIMHQ3> Date: 星期三, 21 八月 2024 10:11:48 +0800 Subject: [PATCH] Merge branch 'master' of http://47.95.120.53:8083/r/WCSNet6 --- Web/src/views/wcs/wcsPlc/index.vue | 279 ++++++++++++++++++++++++++++--------------------------- 1 files changed, 141 insertions(+), 138 deletions(-) diff --git a/Web/src/views/wcs/wcsPlc/index.vue b/Web/src/views/wcs/wcsPlc/index.vue index 9de7109..1ef2c39 100644 --- a/Web/src/views/wcs/wcsPlc/index.vue +++ b/Web/src/views/wcs/wcsPlc/index.vue @@ -1,203 +1,206 @@ 锘�<template> <div class="wcsPlc-container"> - <el-card shadow="hover" :body-style="{ paddingBottom: '0' }"> + <el-card shadow="hover" :body-style="{ paddingBottom: '0' }"> <el-form :model="queryParams" ref="queryForm" labelWidth="90"> <el-row> <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10"> <el-form-item label="鍏抽敭瀛�"> - <el-input v-model="queryParams.searchKey" clearable="" placeholder="璇疯緭鍏ユā绯婃煡璇㈠叧閿瓧"/> - + <el-input v-model="queryParams.searchKey" clearable="" placeholder="璇疯緭鍏ユā绯婃煡璇㈠叧閿瓧" /> + </el-form-item> </el-col> <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="showAdvanceQueryUI"> <el-form-item label="PLCIP鍦板潃"> - <el-input v-model="queryParams.ip" clearable="" placeholder="璇疯緭鍏LCIP鍦板潃"/> - + <el-input v-model="queryParams.ip" clearable="" placeholder="璇疯緭鍏LCIP鍦板潃" /> + + </el-form-item> + </el-col> + <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="showAdvanceQueryUI"> + <el-form-item label="PLC绫诲瀷"> + <el-select clearable="" v-model="queryParams.plcType" placeholder="璇烽�夋嫨PLC绫诲瀷"> + <el-option v-for="(item, index) in dl('PLCEnum')" :key="index" :value="item.value" + :label="`${item.name} (${item.code}) [${item.value}] `" /> + + </el-select> + </el-form-item> </el-col> <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10" v-if="showAdvanceQueryUI"> <el-form-item label="璁惧绫诲瀷"> <el-select clearable="" v-model="queryParams.type" placeholder="璇烽�夋嫨璁惧绫诲瀷"> - <el-option v-for="(item,index) in dl('PLCTypeEnum')" :key="index" :value="item.value" :label="`${item.name} (${item.code}) [${item.value}] `" /> - + <el-option v-for="(item, index) in dl('PLCTypeEnum')" :key="index" :value="item.value" + :label="`${item.name} (${item.code}) [${item.value}] `" /> + </el-select> - + </el-form-item> </el-col> <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10"> - <el-form-item > + <el-form-item> <el-button-group style="display: flex; align-items: center;"> - <el-button type="primary" icon="ele-Search" @click="handleQuery" v-auth="'wcsPlc:page'"> 鏌ヨ </el-button> - <el-button icon="ele-Refresh" @click="() => queryParams = {}"> 閲嶇疆 </el-button> - <el-button icon="ele-ZoomIn" @click="changeAdvanceQueryUI" v-if="!showAdvanceQueryUI" style="margin-left:5px;"> 楂樼骇鏌ヨ </el-button> - <el-button icon="ele-ZoomOut" @click="changeAdvanceQueryUI" v-if="showAdvanceQueryUI" style="margin-left:5px;"> 闅愯棌 </el-button> - <el-button type="primary" style="margin-left:5px;" icon="ele-Plus" @click="openAddWcsPlc" v-auth="'wcsPlc:add'"> 鏂板 </el-button> - + <el-button type="primary" icon="ele-Search" @click="handleQuery" v-auth="'wcsPlc:page'"> 鏌ヨ </el-button> + <el-button icon="ele-Refresh" @click="() => queryParams = {}"> 閲嶇疆 </el-button> + <el-button icon="ele-ZoomIn" @click="changeAdvanceQueryUI" v-if="!showAdvanceQueryUI" + style="margin-left:5px;"> 楂樼骇鏌ヨ </el-button> + <el-button icon="ele-ZoomOut" @click="changeAdvanceQueryUI" v-if="showAdvanceQueryUI" + style="margin-left:5px;"> 闅愯棌 </el-button> + <el-button type="primary" style="margin-left:5px;" icon="ele-Plus" @click="openAddWcsPlc" + v-auth="'wcsPlc:add'"> 鏂板 </el-button> + </el-button-group> </el-form-item> - + </el-col> </el-row> </el-form> </el-card> <el-card class="full-table" shadow="hover" style="margin-top: 5px"> - <el-table - :data="tableData" - style="width: 100%" - v-loading="loading" - tooltip-effect="light" - row-key="id" - @sort-change="sortChange" - border=""> - <el-table-column type="index" label="搴忓彿" width="55" align="center"/> - <el-table-column prop="ip" label="PLCIP鍦板潃" show-overflow-tooltip="" /> - <el-table-column prop="type" label="璁惧绫诲瀷" show-overflow-tooltip="" > - <template #default="scope"> - <el-tag :type="dv('PLCTypeEnum', scope.row.type)?.tagType"> {{dv('PLCTypeEnum', scope.row.type)?.name}}</el-tag> - </template> - </el-table-column> - <el-table-column prop="wareHouseNo" label="浠撳簱鍙�" show-overflow-tooltip="" /> - <el-table-column prop="text" label="鎻忚堪" show-overflow-tooltip="" /> + <el-table :data="tableData" style="width: 100%" v-loading="loading" tooltip-effect="light" row-key="id" + @sort-change="sortChange" border=""> + <el-table-column type="index" label="搴忓彿" width="55" align="center" /> + <el-table-column prop="ip" label="PLCIP鍦板潃" show-overflow-tooltip="" /> + <el-table-column prop="plcType" label="PLC绫诲瀷" show-overflow-tooltip=""> + <template #default="scope"> + <el-tag :type="dv('PLCEnum', scope.row.plcType)?.tagType"> {{ dv('PLCEnum', + scope.row.plcType)?.name}}</el-tag> + </template> + </el-table-column> + <el-table-column prop="type" label="璁惧绫诲瀷" show-overflow-tooltip=""> + <template #default="scope"> + <el-tag :type="dv('PLCTypeEnum', scope.row.type)?.tagType"> {{ dv('PLCTypeEnum', + scope.row.type)?.name }}</el-tag> + </template> + </el-table-column> + <el-table-column prop="wareHouseNo" label="浠撳簱鍙�" show-overflow-tooltip="" /> + <el-table-column prop="text" label="鎻忚堪" show-overflow-tooltip="" /> <el-table-column label="淇敼璁板綍" width="80" align="center" show-overflow-tooltip> <template #default="scope"> <ModifyRecord :data="scope.row" /> </template> </el-table-column> - <el-table-column label="鎿嶄綔" width="140" align="center" fixed="right" show-overflow-tooltip="" v-if="auth('wcsPlc:update') || auth('wcsPlc:delete')"> + <el-table-column label="鎿嶄綔" width="140" align="center" fixed="right" show-overflow-tooltip="" + v-if="auth('wcsPlc:update') || auth('wcsPlc:delete')"> <template #default="scope"> - <el-button icon="ele-Edit" size="small" text="" type="primary" @click="openEditWcsPlc(scope.row)" v-auth="'wcsPlc:update'"> 缂栬緫 </el-button> - <el-button icon="ele-Delete" size="small" text="" type="primary" @click="delWcsPlc(scope.row)" v-auth="'wcsPlc:delete'"> 鍒犻櫎 </el-button> + <el-button icon="ele-Edit" size="small" text="" type="primary" @click="openEditWcsPlc(scope.row)" + v-auth="'wcsPlc:update'"> 缂栬緫 </el-button> + <el-button icon="ele-Delete" size="small" text="" type="primary" @click="delWcsPlc(scope.row)" + v-auth="'wcsPlc:delete'"> 鍒犻櫎 </el-button> </template> </el-table-column> </el-table> - <el-pagination - v-model:currentPage="tableParams.page" - v-model:page-size="tableParams.pageSize" - :total="tableParams.total" - :page-sizes="[10, 20, 50, 100, 200, 500]" - size="small" - background="" - @size-change="handleSizeChange" - @current-change="handleCurrentChange" - layout="total, sizes, prev, pager, next, jumper" - /> - <printDialog - ref="printDialogRef" - :title="printWcsPlcTitle" - @reloadTable="handleQuery" /> - <editDialog - ref="editDialogRef" - :title="editWcsPlcTitle" - @reloadTable="handleQuery" - /> + <el-pagination v-model:currentPage="tableParams.page" v-model:page-size="tableParams.pageSize" + :total="tableParams.total" :page-sizes="[10, 20, 50, 100, 200, 500]" size="small" background="" + @size-change="handleSizeChange" @current-change="handleCurrentChange" + layout="total, sizes, prev, pager, next, jumper" /> + <printDialog ref="printDialogRef" :title="printWcsPlcTitle" @reloadTable="handleQuery" /> + <editDialog ref="editDialogRef" :title="editWcsPlcTitle" @reloadTable="handleQuery" /> </el-card> </div> </template> <script lang="ts" setup="" name="wcsPlc"> - import { ref } from "vue"; - import { ElMessageBox, ElMessage } from "element-plus"; - import { auth } from '/@/utils/authFunction'; +import { ref } from "vue"; +import { ElMessageBox, ElMessage } from "element-plus"; +import { auth } from '/@/utils/authFunction'; - import { getDictDataItem as di, getDictDataList as dl } from '/@/utils/dict-utils'; - import { getDictLabelByVal as dv } from '/@/utils/dict-utils'; +import { getDictDataItem as di, getDictDataList as dl } from '/@/utils/dict-utils'; +import { getDictLabelByVal as dv } from '/@/utils/dict-utils'; - import ModifyRecord from '/@/components/table/modifyRecord.vue'; +import ModifyRecord from '/@/components/table/modifyRecord.vue'; - import printDialog from '/@/views/system/print/component/hiprint/preview.vue' - import editDialog from '/@/views/wcs/wcsPlc/component/editDialog.vue' - import { pageWcsPlc, deleteWcsPlc } from '/@/api/wcs/wcsPlc'; - import { getAPI } from '/@/utils/axios-utils'; - import { SysEnumApi } from '/@/api-services/api'; - import commonFunction from '/@/utils/commonFunction'; +import printDialog from '/@/views/system/print/component/hiprint/preview.vue' +import editDialog from '/@/views/wcs/wcsPlc/component/editDialog.vue' +import { pageWcsPlc, deleteWcsPlc } from '/@/api/wcs/wcsPlc'; +import { getAPI } from '/@/utils/axios-utils'; +import { SysEnumApi } from '/@/api-services/api'; +import commonFunction from '/@/utils/commonFunction'; - const showAdvanceQueryUI = ref(false); - const printDialogRef = ref(); - const editDialogRef = ref(); - const loading = ref(false); - const tableData = ref<any>([]); - const queryParams = ref<any>({}); - const tableParams = ref({ - page: 1, - pageSize: 10, - total: 0, - }); +const showAdvanceQueryUI = ref(false); +const printDialogRef = ref(); +const editDialogRef = ref(); +const loading = ref(false); +const tableData = ref<any>([]); +const queryParams = ref<any>({}); +const tableParams = ref({ + page: 1, + pageSize: 10, + total: 0, +}); - const printWcsPlcTitle = ref(""); - const editWcsPlcTitle = ref(""); +const printWcsPlcTitle = ref(""); +const editWcsPlcTitle = ref(""); - // 鏀瑰彉楂樼骇鏌ヨ鐨勬帶浠舵樉绀虹姸鎬� - const changeAdvanceQueryUI = () => { - showAdvanceQueryUI.value = !showAdvanceQueryUI.value; - } +// 鏀瑰彉楂樼骇鏌ヨ鐨勬帶浠舵樉绀虹姸鎬� +const changeAdvanceQueryUI = () => { + showAdvanceQueryUI.value = !showAdvanceQueryUI.value; +} - // 鏌ヨ鎿嶄綔 - const handleQuery = async () => { - loading.value = true; - var res = await pageWcsPlc(Object.assign(queryParams.value, tableParams.value)); - tableData.value = res.data.result?.items ?? []; - tableParams.value.total = res.data.result?.total; - loading.value = false; - }; +// 鏌ヨ鎿嶄綔 +const handleQuery = async () => { + loading.value = true; + var res = await pageWcsPlc(Object.assign(queryParams.value, tableParams.value)); + tableData.value = res.data.result?.items ?? []; + tableParams.value.total = res.data.result?.total; + loading.value = false; +}; - // 鍒楁帓搴� - const sortChange = async (column: any) => { - queryParams.value.field = column.prop; - queryParams.value.order = column.order; - await handleQuery(); - }; +// 鍒楁帓搴� +const sortChange = async (column: any) => { + queryParams.value.field = column.prop; + queryParams.value.order = column.order; + await handleQuery(); +}; - // 鎵撳紑鏂板椤甸潰 - const openAddWcsPlc = () => { - editWcsPlcTitle.value = '娣诲姞PLC'; - editDialogRef.value.openDialog({}); - }; +// 鎵撳紑鏂板椤甸潰 +const openAddWcsPlc = () => { + editWcsPlcTitle.value = '娣诲姞PLC'; + editDialogRef.value.openDialog({}); +}; - // 鎵撳紑鎵撳嵃椤甸潰 - const openPrintWcsPlc = async (row: any) => { - printWcsPlcTitle.value = '鎵撳嵃PLC'; - } - - // 鎵撳紑缂栬緫椤甸潰 - const openEditWcsPlc = (row: any) => { - editWcsPlcTitle.value = '缂栬緫PLC'; - editDialogRef.value.openDialog(row); - }; +// 鎵撳紑鎵撳嵃椤甸潰 +const openPrintWcsPlc = async (row: any) => { + printWcsPlcTitle.value = '鎵撳嵃PLC'; +} - // 鍒犻櫎 - const delWcsPlc = (row: any) => { - ElMessageBox.confirm(`纭畾瑕佸垹闄ゅ悧?`, "鎻愮ず", { +// 鎵撳紑缂栬緫椤甸潰 +const openEditWcsPlc = (row: any) => { + editWcsPlcTitle.value = '缂栬緫PLC'; + editDialogRef.value.openDialog(row); +}; + +// 鍒犻櫎 +const delWcsPlc = (row: any) => { + ElMessageBox.confirm(`纭畾瑕佸垹闄ゅ悧?`, "鎻愮ず", { confirmButtonText: "纭畾", cancelButtonText: "鍙栨秷", type: "warning", }) - .then(async () => { - await deleteWcsPlc(row); - handleQuery(); - ElMessage.success("鍒犻櫎鎴愬姛"); - }) - .catch(() => {}); - }; + .then(async () => { + await deleteWcsPlc(row); + handleQuery(); + ElMessage.success("鍒犻櫎鎴愬姛"); + }) + .catch(() => { }); +}; - // 鏀瑰彉椤甸潰瀹归噺 - const handleSizeChange = (val: number) => { - tableParams.value.pageSize = val; - handleQuery(); - }; - - // 鏀瑰彉椤电爜搴忓彿 - const handleCurrentChange = (val: number) => { - tableParams.value.page = val; - handleQuery(); - }; - +// 鏀瑰彉椤甸潰瀹归噺 +const handleSizeChange = (val: number) => { + tableParams.value.pageSize = val; handleQuery(); +}; + +// 鏀瑰彉椤电爜搴忓彿 +const handleCurrentChange = (val: number) => { + tableParams.value.page = val; + handleQuery(); +}; + +handleQuery(); </script> <style scoped> :deep(.el-input), :deep(.el-select), :deep(.el-input-number) { - width: 100%; + width: 100%; } </style> - -- Gitblit v1.8.0