From e1e01358530ea0cae9bd09aab1b6e2c371f2dd1c Mon Sep 17 00:00:00 2001 From: dongyukun <1208714201@qq.com> Date: 星期一, 11 十一月 2024 15:10:13 +0800 Subject: [PATCH] opcua选择是否更新当前值功能 --- src/views/model/mpk/file/index.vue | 244 ++++++++++++++++++++++++++++-------------------- 1 files changed, 140 insertions(+), 104 deletions(-) diff --git a/src/views/model/mpk/file/index.vue b/src/views/model/mpk/file/index.vue index 8f20674..8e98f7f 100644 --- a/src/views/model/mpk/file/index.vue +++ b/src/views/model/mpk/file/index.vue @@ -1,133 +1,157 @@ <template> - <!-- 搜索工作栏 --> - <ContentWrap> - <el-form - class="-mb-15px" - :model="queryParams" - ref="queryFormRef" - :inline="true" - label-width="68px" - > - <el-form-item label="模型名称" prop="pyName"> - <el-input - v-model="queryParams.pyName" - placeholder="请输入模型名称" - clearable - class="!w-240px" + <el-row :gutter="20"> + <!-- 左侧树 --> + <el-col :span="4" :xs="24"> + <ContentWrap class="h-1/1"> + <el-tree + style="max-width: 600px" + :data="treeData" + :props="treeProps" + default-expand-all + highlight-current + @node-click="handleNodeClick" /> - </el-form-item> - <el-form-item> - <el-button @click="handleQuery"> - <Icon icon="ep:search" class="mr-5px"/> - 搜索 - </el-button> - <el-button @click="resetQuery"> - <Icon icon="ep:refresh" class="mr-5px"/> - 重置 - </el-button> - <div class="ml-12px"> - <router-link :to="'/file/form'"> - <el-button type="primary" plain v-hasPermi="['mpk:file:create']"> - <Icon icon="ep:plus" class="mr-5px"/>新增</el-button> - </router-link> - </div> - - </el-form-item> - </el-form> - </ContentWrap> - - <!-- 列表 --> - <ContentWrap> - <el-table - v-loading="loading" - :data="list" - row-key="id" - > - <el-table-column prop="pyChineseName" label="模型中文名称"/> - <el-table-column prop="pyName" label="模型名称"/> - <el-table-column prop="pyType" label="模型类型" :formatter="(r,c,v) => getDictLabel(DICT_TYPE.MODEL_TYPE,v)"/> - <el-table-column prop="menuName" label="所属菜单" width="120px"/> - <el-table-column prop="groupName" label="所属组" width="120px"/> - <el-table-column prop="remark" label="备注" width="200px"/> - <el-table-column prop="createDate" label="创建时间" :formatter="dateFormatter" width="170px"/> - <el-table-column label="操作" align="center" width="200px"> - <template #default="scope"> - <div class="flex items-center justify-center"> - <router-link :to="'/file/form/' + scope.row.id"> - <el-button type="primary" link v-hasPermi="['mpk:file:update']"> - <Icon icon="ep:edit"/>修改 - </el-button> - </router-link> - <el-button link type="danger" @click="handleDelete(scope.row.id)" v-hasPermi="['mpk:file:delete']"> - <Icon icon="ep:delete"/>删除 + </ContentWrap> + </el-col> + <el-col :span="20" :xs="24"> + <!-- 搜索工作栏 --> + <ContentWrap> + <el-form + class="-mb-15px" + :model="queryParams" + ref="queryFormRef" + :inline="true" + label-width="68px" + > + <el-form-item label="模型名称" prop="pyName"> + <el-input + v-model="queryParams.pyName" + placeholder="请输入模型名称" + clearable + class="!w-240px" + /> + </el-form-item> + <el-form-item> + <el-button @click="handleQuery"> + <Icon icon="ep:search" class="mr-5px"/> + 搜索 </el-button> - <div class="pl-12px"> - <el-dropdown @command="(command) => handleCommand(command, scope.row)" trigger="click"> - <el-button type="primary" link> - <Icon icon="ep:d-arrow-right" /> 更多 - </el-button> - <template #dropdown> - <el-dropdown-menu> - <el-dropdown-item - command="generatorCode" - > - 生成代码 - </el-dropdown-item> - <el-dropdown-item - command="generatorHistory" - > - 生成历史 - </el-dropdown-item> - <el-dropdown-item - command="mpkRunDialog" - > - 运行 - </el-dropdown-item> - </el-dropdown-menu> - </template> - </el-dropdown> + <el-button @click="resetQuery"> + <Icon icon="ep:refresh" class="mr-5px"/> + 重置 + </el-button> + <div class="ml-12px"> + <router-link :to="'/file/form'"> + <el-button type="primary" plain v-hasPermi="['mpk:file:create']"> + <Icon icon="ep:plus" class="mr-5px"/>新增</el-button> + </router-link> </div> - </div> - </template> - </el-table-column> - </el-table> - <!-- 分页 --> - <Pagination - v-model:limit="queryParams.pageSize" - v-model:page="queryParams.page" - :total="total" - @pagination="getList" - /> - </ContentWrap> - <MpkGenerator ref="mpkGenerator"/> - <GeneratorCodeHistory ref="generatorCodeHistory"/> - <MpkRun ref="mpkRun"/> + </el-form-item> + </el-form> + </ContentWrap> + + <!-- 列表 --> + <ContentWrap> + <el-table + v-loading="loading" + :data="list" + row-key="id" + > + <el-table-column prop="pyChineseName" label="模型名称" header-align="center" align="center" min-width="100" /> + <el-table-column prop="pyName" label="模型文件" header-align="center" align="center" min-width="300"/> + <el-table-column prop="pyType" label="模型类型" :formatter="(r,c,v) => getDictLabel(DICT_TYPE.MODEL_TYPE,v)"/> + <el-table-column prop="menuName" label="所属菜单" min-width="120px"/> + <el-table-column prop="groupName" label="所属组" min-width="120px"/> + <el-table-column prop="remark" label="备注" min-width="100px"/> + <el-table-column prop="createDate" label="创建时间" :formatter="dateFormatter" width="180px"/> + <el-table-column label="操作" align="center" width="200px"> + <template #default="scope"> + <div class="flex items-center justify-center"> + <router-link :to="'/file/form/' + scope.row.id"> + <el-button type="primary" link v-hasPermi="['mpk:file:update']"> + <Icon icon="ep:edit"/>修改 + </el-button> + </router-link> + <el-button link type="danger" @click="handleDelete(scope.row.id)" v-hasPermi="['mpk:file:delete']"> + <Icon icon="ep:delete"/>删除 + </el-button> + <div class="pl-12px"> + <el-dropdown @command="(command) => handleCommand(command, scope.row)" trigger="click"> + <el-button type="primary" link> + <Icon icon="ep:d-arrow-right" /> 更多 + </el-button> + <template #dropdown> + <el-dropdown-menu> + <el-dropdown-item + command="generatorCode" + > + 生成代码 + </el-dropdown-item> + <el-dropdown-item + command="generatorHistory" + > + 生成历史 + </el-dropdown-item> + <el-dropdown-item + command="mpkRunDialog" + > + 运行 + </el-dropdown-item> + </el-dropdown-menu> + </template> + </el-dropdown> + </div> + </div> + </template> + </el-table-column> + </el-table> + <!-- 分页 --> + <Pagination + v-model:limit="queryParams.limit" + v-model:page="queryParams.page" + :total="total" + @pagination="getList" + /> + </ContentWrap> + + <MpkGenerator ref="mpkGenerator"/> + <GeneratorCodeHistory ref="generatorCodeHistory"/> + <MpkRun ref="mpkRun"/> + </el-col> + </el-row> </template> <script lang="ts" setup> import {dateFormatter} from '@/utils/formatTime' import * as MpkApi from '@/api/model/mpk/mpk' + import * as MpkMenuApi from '@/api/model/mpk/menu' import MpkGenerator from './MpkGenerator.vue' import GeneratorCodeHistory from './MpkGeneratorHistory.vue' import MpkRun from './MpkRun.vue' - import * as UserApi from "@/api/system/user"; import { DICT_TYPE, getDictLabel } from '@/utils/dict' - import {useAppStoreWithOut} from "@/store/modules/app"; + import {ElTree} from "element-plus"; defineOptions({name: 'MpkFile'}) const message = useMessage() // 消息弹窗 const {t} = useI18n() // 国际化 + const treeProps = { + children: 'children', + label: 'label', + } + const loading = ref(true) // 列表的加载中 const total = ref(0) // 列表的总页数 const list = ref([]) // 字典表格数据 const queryParams = reactive({ page: 1, - pageSize: 10, - pyName: '' + limit: 10, + pyName: '', + label: '' }) const queryFormRef = ref() // 搜索的表单 + const treeData = ref([]) const getList = async () => { loading.value = true @@ -138,6 +162,11 @@ } finally { loading.value = false } + } + + const getTree = async () => { + const data = await MpkMenuApi.getTree() + treeData.value = data } /** 操作分发 */ @@ -198,12 +227,19 @@ } } + const handleNodeClick = (data: Tree) => { + queryParams.label = data.label + getList() + } + onActivated((to) => { getList() + getTree() }) /** 初始化 **/ onMounted(async () => { await getList() + await getTree() }) </script> -- Gitblit v1.9.3