From a9e4d032eb46debe2891c09c01cb017901717d37 Mon Sep 17 00:00:00 2001 From: herenshan112 Date: Mon, 17 Nov 2025 08:18:59 +0800 Subject: [PATCH 1/3] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E6=9D=83=E9=99=90?= =?UTF-8?q?=E8=AE=BE=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/system/roleapi/postrole.ts | 37 + src/api/system/roleapi/power.ts | 13 + src/api/system/roleapi/types.ts | 37 + .../rolepower/setuprole/setuprolepower.vue | 3 + .../system/monitor/online/index copy 4.vue | 865 +++++++++++++++++ src/views/system/monitor/online/index.vue | 351 +------ src/views/system/monitor/online/index123.vue | 903 ++++++++++++++++++ src/views/system/monitor/online/index2.vue | 823 ++++++++++++++++ .../{index copy.vue => index_20251112.vue} | 0 src/views/system/monitor/online/page.vue | 283 ++++++ .../lowcodepage/pageFlow/appTableFlow.vue | 2 +- ....timestamp-1762732876054-97f8b5f7ef739.mjs | 215 +++++ 12 files changed, 3187 insertions(+), 345 deletions(-) create mode 100644 src/api/system/roleapi/power.ts create mode 100644 src/views/system/monitor/online/index copy 4.vue create mode 100644 src/views/system/monitor/online/index123.vue create mode 100644 src/views/system/monitor/online/index2.vue rename src/views/system/monitor/online/{index copy.vue => index_20251112.vue} (100%) create mode 100644 src/views/system/monitor/online/page.vue create mode 100644 vite.config.ts.timestamp-1762732876054-97f8b5f7ef739.mjs diff --git a/src/api/system/roleapi/postrole.ts b/src/api/system/roleapi/postrole.ts index e059889..a2e7874 100644 --- a/src/api/system/roleapi/postrole.ts +++ b/src/api/system/roleapi/postrole.ts @@ -103,6 +103,13 @@ export function gainAppTableList(data?: any){ data:data }); } +export function gainAppTableListNew(data?: any){ + return request({ + url: '/systemapi/grant/gainAppTableListNew', + method: 'post', + data:data + }); +} /** * 获取指定角色授权 */ @@ -113,3 +120,33 @@ export function setpAppTableForms(data?: any){ data:data }); } +/** + * 获取首层子行政组织和本组织下的人员 + */ +export function getMyPeoplceAndSunOrg(data?: any){ + return request({ + url: '/systemapi/authorize/getMyPeoplceAndSunOrg', + method: 'post', + data:data + }); +} +/** + * 获取首层子行政组织和本组织下的岗位及人员 + */ +export function getMyPeopleAndSunOrgPost(data?: any){ + return request({ + url: '/systemapi/authorize/getMyPeopleAndSunOrgPost', + method: 'post', + data:data + }); +} +/** + * 获取人员 + */ +export function getPowerPageUser(data?: any){ + return request({ + url: '/systemapi/authorize/getPowerPageUser', + method: 'post', + data:data + }); +} diff --git a/src/api/system/roleapi/power.ts b/src/api/system/roleapi/power.ts new file mode 100644 index 0000000..d629c11 --- /dev/null +++ b/src/api/system/roleapi/power.ts @@ -0,0 +1,13 @@ +import request from "@/utils/request"; +import { getSystemPower } from "./types"; + +/** + * 获取平台授权项目 + */ + export function appPowerUnit(data: getSystemPower){ + return request({ + url: '/systemapi/authorize/appPowerUnit', + method: 'post', + data:data + }); +} diff --git a/src/api/system/roleapi/types.ts b/src/api/system/roleapi/types.ts index 50ab1cc..630c9af 100644 --- a/src/api/system/roleapi/types.ts +++ b/src/api/system/roleapi/types.ts @@ -285,3 +285,40 @@ export interface custerAppTablePower extends custerAppInfo{ attribute:number[] }; } + +//获取平台授权项目 +export interface getSystemPower{ + powerType:string; + appType:string; + appSystem:string; + roleId:string; +} + + +// 平台授权结构体 +export interface AppPowerInfo { + id :number; + name :string; //菜单名称 + types :number; + perm :number; + sort :number; + parentId :number; + isTrue :boolean; +} + +// 分流 +export interface AppMenuBut extends AppPowerInfo { + buttenPower:AppPowerInfo[] +} + +// 平台授权结构树 +export interface AppPowerTree extends AppMenuBut { + children:AppPowerTree[] + visible :number; + visibleRange:VisibleRangeInfo[]; //当可见范围为自定义范围时。此辅助选项生效 +} + +export interface VisibleRangeInfo { + types:number; + val:string; +} diff --git a/src/views/powermanage/rolepower/setuprole/setuprolepower.vue b/src/views/powermanage/rolepower/setuprole/setuprolepower.vue index 72a164e..a386767 100644 --- a/src/views/powermanage/rolepower/setuprole/setuprolepower.vue +++ b/src/views/powermanage/rolepower/setuprole/setuprolepower.vue @@ -385,6 +385,7 @@ const pickOrgIdClick = () => { v-for="itemes in appList" :class="itemes.signCode == activeAppId ? 'active' : ''" @click="pickAppList(itemes)" + :key="itemes.id" > {{ itemes.name }} @@ -406,6 +407,7 @@ const pickOrgIdClick = () => { v-for="itemes in appList" :class="itemes.signCode == activeAppId ? 'active' : ''" @click="pickAppList(itemes)" + :key="itemes.id" > {{ itemes.name }} @@ -590,4 +592,5 @@ const pickOrgIdClick = () => { background-color: #a0cfff; } } + diff --git a/src/views/system/monitor/online/index copy 4.vue b/src/views/system/monitor/online/index copy 4.vue new file mode 100644 index 0000000..93caa87 --- /dev/null +++ b/src/views/system/monitor/online/index copy 4.vue @@ -0,0 +1,865 @@ + + + + diff --git a/src/views/system/monitor/online/index.vue b/src/views/system/monitor/online/index.vue index 47d6d78..08db74b 100644 --- a/src/views/system/monitor/online/index.vue +++ b/src/views/system/monitor/online/index.vue @@ -1,355 +1,18 @@ diff --git a/src/views/system/monitor/online/index123.vue b/src/views/system/monitor/online/index123.vue new file mode 100644 index 0000000..202d4b1 --- /dev/null +++ b/src/views/system/monitor/online/index123.vue @@ -0,0 +1,903 @@ + + + + diff --git a/src/views/system/monitor/online/index2.vue b/src/views/system/monitor/online/index2.vue new file mode 100644 index 0000000..dbe2f5c --- /dev/null +++ b/src/views/system/monitor/online/index2.vue @@ -0,0 +1,823 @@ + + + + diff --git a/src/views/system/monitor/online/index copy.vue b/src/views/system/monitor/online/index_20251112.vue similarity index 100% rename from src/views/system/monitor/online/index copy.vue rename to src/views/system/monitor/online/index_20251112.vue diff --git a/src/views/system/monitor/online/page.vue b/src/views/system/monitor/online/page.vue new file mode 100644 index 0000000..bce0bb3 --- /dev/null +++ b/src/views/system/monitor/online/page.vue @@ -0,0 +1,283 @@ + + + + diff --git a/src/views/sysworkflow/lowcodepage/pageFlow/appTableFlow.vue b/src/views/sysworkflow/lowcodepage/pageFlow/appTableFlow.vue index dc6670c..8e2c7d4 100644 --- a/src/views/sysworkflow/lowcodepage/pageFlow/appTableFlow.vue +++ b/src/views/sysworkflow/lowcodepage/pageFlow/appTableFlow.vue @@ -1,7 +1,7 @@ - diff --git a/src/views/hr/archives/index_251128.vue b/src/views/hr/archives/index_251128.vue new file mode 100644 index 0000000..921f7c4 --- /dev/null +++ b/src/views/hr/archives/index_251128.vue @@ -0,0 +1,1465 @@ + + + + diff --git a/src/views/system/monitor/online/index.vue b/src/views/system/monitor/online/index.vue index 08db74b..8ddbfdc 100644 --- a/src/views/system/monitor/online/index.vue +++ b/src/views/system/monitor/online/index.vue @@ -4,15 +4,1063 @@ @ 备注: --> - - {{ openOrClose }}======={{ openclosebox }} + @@ -200,4 +199,4 @@ const updateNode = (val:any) =>{ display:block; cursor:pointer; } - + diff --git a/vite.config.ts.timestamp-1763685117626-b9e83b063ec3.mjs b/vite.config.ts.timestamp-1763685117626-b9e83b063ec3.mjs new file mode 100644 index 0000000..6ffe830 --- /dev/null +++ b/vite.config.ts.timestamp-1763685117626-b9e83b063ec3.mjs @@ -0,0 +1,215 @@ +// vite.config.ts +import vue from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/@vitejs/plugin-vue/dist/index.mjs"; +import { loadEnv, defineConfig } from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/vite/dist/node/index.js"; +import AutoImport from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unplugin-auto-import/dist/vite.js"; +import Components from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unplugin-vue-components/dist/vite.mjs"; +import { ElementPlusResolver } from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unplugin-vue-components/dist/resolvers.mjs"; +import Icons from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unplugin-icons/dist/vite.mjs"; +import IconsResolver from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unplugin-icons/dist/resolver.mjs"; +import { createSvgIconsPlugin } from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/vite-plugin-svg-icons/dist/index.mjs"; +import UnoCSS from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/unocss/dist/vite.mjs"; +import { terser } from "file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/node_modules/rollup-plugin-terser/rollup-plugin-terser.mjs"; +import path from "path"; +var __vite_injected_original_dirname = "E:\\f_pang\\object\\my_object_html\\ShutongInterconnectedChemicalCloudPlatform"; +var pathSrc = path.resolve(__vite_injected_original_dirname, "src"); +var vite_config_default = defineConfig(({ mode }) => { + const env = loadEnv(mode, process.cwd()); + return { + resolve: { + alias: { + "@": pathSrc + } + }, + css: { + // CSS 预处理器 + preprocessorOptions: { + //define global scss variable + scss: { + javascriptEnabled: true, + additionalData: ` + @use "@/styles/variables.scss" as *; + ` + } + } + }, + server: { + host: "0.0.0.0", + port: Number(env.VITE_APP_PORT), + open: true, + // 运行是否自动打开浏览器 + proxy: { + // 反向代理解决跨域 + [env.VITE_APP_BASE_API]: { + target: env.VITE_APP_BASE_URL, + // 线上接口地址 + // target: "http://vapi.youlai.tech", // 线上接口地址 + // target: 'http://localhost:8989', // 本地接口地址 , 后端工程仓库地址:https://gitee.com/youlaiorg/youlai-boot + changeOrigin: true, + rewrite: (path2) => path2.replace(new RegExp("^" + env.VITE_APP_BASE_API), "") + // 替换 /dev-api 为 target 接口地址 + } + // '/dev-api/kpiapi': { + // target: 'http://127.0.0.1:6666', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/kpiapi'), ""), + // }, + // '/dev-api/systemapi': { + // target: 'http://127.0.0.1:17777', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/systemapi'), ""), + // }, + // '/dev-api/hrapi': { + // target: 'http://127.0.0.1:39168', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/hrapi'), ""), + // }, + // '/dev-api/api': { + // target: 'http://127.0.0.1:8888', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/api'), ""), + // }, + // '/dev-api/javasys': { + // target: 'http://172.20.2.87:8111', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/javasys'), ""), + // }, + // '/dev-api/javasys/lowCode ': { + // target: 'http://172.20.2.87:8112', + // changeOrigin: true, + // rewrite: (path) => + // path.replace(new RegExp("^" + '/dev-api/javasys/lowCode '), ""), + // } + } + }, + plugins: [ + vue(), + UnoCSS({ + /* options */ + }), + AutoImport({ + // 自动导入 Vue 相关函数,如:ref, reactive, toRef 等 + imports: ["vue", "@vueuse/core"], + //ignore: ['h'], // 自动添加 import { h } from '/node_modules/.vite/deps/vue.js 代码问题处理 + eslintrc: { + enabled: false, + // Default `false` + filepath: "./.eslintrc-auto-import.json", + // Default `./.eslintrc-auto-import.json` + globalsPropValue: true + // Default `true`, (true | false | 'readonly' | 'readable' | 'writable' | 'writeable') + }, + resolvers: [ + // 自动导入 Element Plus 相关函数,如:ElMessage, ElMessageBox... (带样式) + ElementPlusResolver(), + // 自动导入图标组件 + IconsResolver({}) + ], + vueTemplate: true, + // 是否在 vue 模板中自动导入 + dts: path.resolve(pathSrc, "types", "auto-imports.d.ts") + // 自动导入组件类型声明文件位置,默认根目录; false 关闭自动生成 + }), + Components({ + resolvers: [ + // 自动注册图标组件 + IconsResolver({ + enabledCollections: ["ep"] + //@iconify-json/ep 是 Element Plus 的图标库 + }), + // 自动导入 Element Plus 组件 + ElementPlusResolver() + ], + dts: path.resolve(pathSrc, "types", "components.d.ts") + // 自动导入组件类型声明文件位置,默认根目录; false 关闭自动生成 + }), + Icons({ + // 自动安装图标库 + autoInstall: true + }), + createSvgIconsPlugin({ + // 指定需要缓存的图标文件夹 + iconDirs: [path.resolve(pathSrc, "assets/icons")], + // 指定symbolId格式 + symbolId: "icon-[dir]-[name]" + }) + ], + build: { + terserOptions: { + compress: { + drop_console: true + // 关闭所有的 console.log 打印 + } + }, + rollupOptions: { + plugins: [ + terser({ + compress: { + drop_console: true + // 关闭所有的 console.log 打印 + } + }) + ] + } + }, + optimizeDeps: { + include: [ + "vue", + "vue-router", + "pinia", + "axios", + "element-plus/es/components/form/style/css", + "element-plus/es/components/form-item/style/css", + "element-plus/es/components/button/style/css", + "element-plus/es/components/input/style/css", + "element-plus/es/components/input-number/style/css", + "element-plus/es/components/switch/style/css", + "element-plus/es/components/upload/style/css", + "element-plus/es/components/menu/style/css", + "element-plus/es/components/col/style/css", + "element-plus/es/components/icon/style/css", + "element-plus/es/components/row/style/css", + "element-plus/es/components/tag/style/css", + "element-plus/es/components/dialog/style/css", + "element-plus/es/components/loading/style/css", + "element-plus/es/components/radio/style/css", + "element-plus/es/components/radio-group/style/css", + "element-plus/es/components/popover/style/css", + "element-plus/es/components/scrollbar/style/css", + "element-plus/es/components/tooltip/style/css", + "element-plus/es/components/dropdown/style/css", + "element-plus/es/components/dropdown-menu/style/css", + "element-plus/es/components/dropdown-item/style/css", + "element-plus/es/components/sub-menu/style/css", + "element-plus/es/components/menu-item/style/css", + "element-plus/es/components/divider/style/css", + "element-plus/es/components/card/style/css", + "element-plus/es/components/link/style/css", + "element-plus/es/components/breadcrumb/style/css", + "element-plus/es/components/breadcrumb-item/style/css", + "element-plus/es/components/table/style/css", + "element-plus/es/components/tree-select/style/css", + "element-plus/es/components/table-column/style/css", + "element-plus/es/components/select/style/css", + "element-plus/es/components/option/style/css", + "element-plus/es/components/pagination/style/css", + "element-plus/es/components/tree/style/css", + "element-plus/es/components/alert/style/css", + "@vueuse/core", + "path-to-regexp", + "echarts", + "@wangeditor/editor", + "@wangeditor/editor-for-vue", + "vue-i18n" + ] + } + }; +}); +export { + vite_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"E:\\\\f_pang\\\\object\\\\my_object_html\\\\ShutongInterconnectedChemicalCloudPlatform\";const __vite_injected_original_filename = \"E:\\\\f_pang\\\\object\\\\my_object_html\\\\ShutongInterconnectedChemicalCloudPlatform\\\\vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///E:/f_pang/object/my_object_html/ShutongInterconnectedChemicalCloudPlatform/vite.config.ts\";import vue from \"@vitejs/plugin-vue\";\r\n\r\nimport { UserConfig, ConfigEnv, loadEnv, defineConfig } from \"vite\";\r\n\r\nimport AutoImport from \"unplugin-auto-import/vite\";\r\nimport Components from \"unplugin-vue-components/vite\";\r\nimport { ElementPlusResolver } from \"unplugin-vue-components/resolvers\";\r\n\r\nimport Icons from \"unplugin-icons/vite\";\r\nimport IconsResolver from \"unplugin-icons/resolver\";\r\n\r\nimport { createSvgIconsPlugin } from \"vite-plugin-svg-icons\";\r\n\r\nimport UnoCSS from \"unocss/vite\";\r\n\r\nimport { terser } from 'rollup-plugin-terser';\r\n\r\nimport path from \"path\";\r\nconst pathSrc = path.resolve(__dirname, \"src\");\r\n\r\nexport default defineConfig(({ mode }: ConfigEnv): UserConfig => {\r\n  const env = loadEnv(mode, process.cwd());\r\n  return {\r\n    resolve: {\r\n      alias: {\r\n        \"@\": pathSrc,\r\n      },\r\n    },\r\n    css: {\r\n      // CSS \u9884\u5904\u7406\u5668\r\n      preprocessorOptions: {\r\n        //define global scss variable\r\n        scss: {\r\n          javascriptEnabled: true,\r\n          additionalData: `\r\n            @use \"@/styles/variables.scss\" as *;\r\n          `,\r\n        },\r\n      },\r\n    },\r\n    server: {\r\n      host: \"0.0.0.0\",\r\n      port: Number(env.VITE_APP_PORT),\r\n      open: true, // \u8FD0\u884C\u662F\u5426\u81EA\u52A8\u6253\u5F00\u6D4F\u89C8\u5668\r\n      proxy: {\r\n        // \u53CD\u5411\u4EE3\u7406\u89E3\u51B3\u8DE8\u57DF\r\n        [env.VITE_APP_BASE_API]: {\r\n          target: env.VITE_APP_BASE_URL, // \u7EBF\u4E0A\u63A5\u53E3\u5730\u5740\r\n          // target: \"http://vapi.youlai.tech\", // \u7EBF\u4E0A\u63A5\u53E3\u5730\u5740\r\n          // target: 'http://localhost:8989',  // \u672C\u5730\u63A5\u53E3\u5730\u5740 , \u540E\u7AEF\u5DE5\u7A0B\u4ED3\u5E93\u5730\u5740\uFF1Ahttps://gitee.com/youlaiorg/youlai-boot\r\n          changeOrigin: true,\r\n          rewrite: (path) =>\r\n            path.replace(new RegExp(\"^\" + env.VITE_APP_BASE_API), \"\"), // \u66FF\u6362 /dev-api \u4E3A target \u63A5\u53E3\u5730\u5740\r\n        },\r\n        // '/dev-api/kpiapi': {\r\n        //   target: 'http://127.0.0.1:6666',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/kpiapi'), \"\"),\r\n        // },\r\n\r\n        // '/dev-api/systemapi': {\r\n        //   target: 'http://127.0.0.1:17777',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/systemapi'), \"\"),\r\n        // },\r\n        // '/dev-api/hrapi': {\r\n        //   target: 'http://127.0.0.1:39168',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/hrapi'), \"\"),\r\n        // },\r\n        // '/dev-api/api': {\r\n        //   target: 'http://127.0.0.1:8888',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/api'), \"\"),\r\n        // },\r\n        // '/dev-api/javasys': {\r\n        //   target: 'http://172.20.2.87:8111',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/javasys'), \"\"),\r\n        // },\r\n        // '/dev-api/javasys/lowCode ': {\r\n        //   target: 'http://172.20.2.87:8112',\r\n        //   changeOrigin: true,\r\n        //   rewrite: (path) =>\r\n        //     path.replace(new RegExp(\"^\" + '/dev-api/javasys/lowCode '), \"\"),\r\n        // }\r\n      },\r\n    },\r\n\r\n    plugins: [\r\n\r\n      vue(),\r\n      UnoCSS({\r\n        /* options */\r\n      }),\r\n      AutoImport({\r\n        // \u81EA\u52A8\u5BFC\u5165 Vue \u76F8\u5173\u51FD\u6570\uFF0C\u5982\uFF1Aref, reactive, toRef \u7B49\r\n        imports: [\"vue\", \"@vueuse/core\"],\r\n        //ignore: ['h'], // \u81EA\u52A8\u6DFB\u52A0 import { h } from '/node_modules/.vite/deps/vue.js \u4EE3\u7801\u95EE\u9898\u5904\u7406\r\n        eslintrc: {\r\n          enabled: false, //  Default `false`\r\n          filepath: \"./.eslintrc-auto-import.json\", // Default `./.eslintrc-auto-import.json`\r\n          globalsPropValue: true, // Default `true`, (true | false | 'readonly' | 'readable' | 'writable' | 'writeable')\r\n        },\r\n        resolvers: [\r\n          // \u81EA\u52A8\u5BFC\u5165 Element Plus \u76F8\u5173\u51FD\u6570\uFF0C\u5982\uFF1AElMessage, ElMessageBox... (\u5E26\u6837\u5F0F)\r\n          ElementPlusResolver(),\r\n          // \u81EA\u52A8\u5BFC\u5165\u56FE\u6807\u7EC4\u4EF6\r\n          IconsResolver({}),\r\n        ],\r\n        vueTemplate: true, // \u662F\u5426\u5728 vue \u6A21\u677F\u4E2D\u81EA\u52A8\u5BFC\u5165\r\n        dts: path.resolve(pathSrc, \"types\", \"auto-imports.d.ts\"), //  \u81EA\u52A8\u5BFC\u5165\u7EC4\u4EF6\u7C7B\u578B\u58F0\u660E\u6587\u4EF6\u4F4D\u7F6E\uFF0C\u9ED8\u8BA4\u6839\u76EE\u5F55; false \u5173\u95ED\u81EA\u52A8\u751F\u6210\r\n      }),\r\n\r\n      Components({\r\n        resolvers: [\r\n          // \u81EA\u52A8\u6CE8\u518C\u56FE\u6807\u7EC4\u4EF6\r\n          IconsResolver({\r\n            enabledCollections: [\"ep\"], //@iconify-json/ep \u662F Element Plus \u7684\u56FE\u6807\u5E93\r\n          }),\r\n          // \u81EA\u52A8\u5BFC\u5165 Element Plus \u7EC4\u4EF6\r\n          ElementPlusResolver(),\r\n        ],\r\n        dts: path.resolve(pathSrc, \"types\", \"components.d.ts\"), //  \u81EA\u52A8\u5BFC\u5165\u7EC4\u4EF6\u7C7B\u578B\u58F0\u660E\u6587\u4EF6\u4F4D\u7F6E\uFF0C\u9ED8\u8BA4\u6839\u76EE\u5F55; false \u5173\u95ED\u81EA\u52A8\u751F\u6210\r\n      }),\r\n\r\n      Icons({\r\n        // \u81EA\u52A8\u5B89\u88C5\u56FE\u6807\u5E93\r\n        autoInstall: true,\r\n      }),\r\n\r\n      createSvgIconsPlugin({\r\n        // \u6307\u5B9A\u9700\u8981\u7F13\u5B58\u7684\u56FE\u6807\u6587\u4EF6\u5939\r\n        iconDirs: [path.resolve(pathSrc, \"assets/icons\")],\r\n        // \u6307\u5B9AsymbolId\u683C\u5F0F\r\n        symbolId: \"icon-[dir]-[name]\",\r\n      }),\r\n    ],\r\n    build: {\r\n      terserOptions: {\r\n        compress: {\r\n          drop_console: true, // \u5173\u95ED\u6240\u6709\u7684 console.log \u6253\u5370\r\n        },\r\n      },\r\n      rollupOptions: {\r\n        plugins: [\r\n          terser({\r\n            compress: {\r\n              drop_console: true, // \u5173\u95ED\u6240\u6709\u7684 console.log \u6253\u5370\r\n            },\r\n          }),\r\n        ],\r\n      },\r\n    },\r\n    optimizeDeps: {\r\n      include: [\r\n        \"vue\",\r\n        \"vue-router\",\r\n        \"pinia\",\r\n        \"axios\",\r\n        \"element-plus/es/components/form/style/css\",\r\n        \"element-plus/es/components/form-item/style/css\",\r\n        \"element-plus/es/components/button/style/css\",\r\n        \"element-plus/es/components/input/style/css\",\r\n        \"element-plus/es/components/input-number/style/css\",\r\n        \"element-plus/es/components/switch/style/css\",\r\n        \"element-plus/es/components/upload/style/css\",\r\n        \"element-plus/es/components/menu/style/css\",\r\n        \"element-plus/es/components/col/style/css\",\r\n        \"element-plus/es/components/icon/style/css\",\r\n        \"element-plus/es/components/row/style/css\",\r\n        \"element-plus/es/components/tag/style/css\",\r\n        \"element-plus/es/components/dialog/style/css\",\r\n        \"element-plus/es/components/loading/style/css\",\r\n        \"element-plus/es/components/radio/style/css\",\r\n        \"element-plus/es/components/radio-group/style/css\",\r\n        \"element-plus/es/components/popover/style/css\",\r\n        \"element-plus/es/components/scrollbar/style/css\",\r\n        \"element-plus/es/components/tooltip/style/css\",\r\n        \"element-plus/es/components/dropdown/style/css\",\r\n        \"element-plus/es/components/dropdown-menu/style/css\",\r\n        \"element-plus/es/components/dropdown-item/style/css\",\r\n        \"element-plus/es/components/sub-menu/style/css\",\r\n        \"element-plus/es/components/menu-item/style/css\",\r\n        \"element-plus/es/components/divider/style/css\",\r\n        \"element-plus/es/components/card/style/css\",\r\n        \"element-plus/es/components/link/style/css\",\r\n        \"element-plus/es/components/breadcrumb/style/css\",\r\n        \"element-plus/es/components/breadcrumb-item/style/css\",\r\n        \"element-plus/es/components/table/style/css\",\r\n        \"element-plus/es/components/tree-select/style/css\",\r\n        \"element-plus/es/components/table-column/style/css\",\r\n        \"element-plus/es/components/select/style/css\",\r\n        \"element-plus/es/components/option/style/css\",\r\n        \"element-plus/es/components/pagination/style/css\",\r\n        \"element-plus/es/components/tree/style/css\",\r\n        \"element-plus/es/components/alert/style/css\",\r\n        \"@vueuse/core\",\r\n\r\n        \"path-to-regexp\",\r\n        \"echarts\",\r\n        \"@wangeditor/editor\",\r\n        \"@wangeditor/editor-for-vue\",\r\n        \"vue-i18n\",\r\n      ],\r\n    },\r\n  };\r\n});\r\n"],
  "mappings": "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",
  "names": ["path"]
}
 From ef4f7e263b24fc4107d58dae7301e669a4f9dff9 Mon Sep 17 00:00:00 2001 From: herenshan112 Date: Thu, 4 Dec 2025 08:31:26 +0800 Subject: [PATCH 3/3] =?UTF-8?q?=E5=91=98=E5=B7=A5=E6=9D=83=E9=99=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/api/DesignForm/index.ts | 4 +- src/api/system/roleapi/power.ts | 24 + src/directive/permission/button.ts | 24 +- src/store/modules/user.ts | 2 +- src/views/hr/archives/archivescont.vue | 5 +- src/views/hr/archives/index.vue | 924 +++++++++++++++--- src/views/hr/archives/index_20251202.vue | 200 ++++ .../hr/archives/unitpage/addUserPage.vue | 274 ++++++ .../hr/archives/unitpage/batchImport.vue | 235 +++++ src/views/hr/archives/unitpage/lockInfo.vue | 96 ++ .../hr/archives/unitpage/uploadTemplate.vue | 222 +++++ src/views/nested/.editorconfig | 12 + .../lowcodepage/appPage/appSetUp/setup.vue | 1 + 13 files changed, 1892 insertions(+), 131 deletions(-) create mode 100644 src/views/hr/archives/index_20251202.vue create mode 100644 src/views/hr/archives/unitpage/addUserPage.vue create mode 100644 src/views/hr/archives/unitpage/batchImport.vue create mode 100644 src/views/hr/archives/unitpage/lockInfo.vue create mode 100644 src/views/hr/archives/unitpage/uploadTemplate.vue create mode 100644 src/views/nested/.editorconfig diff --git a/src/api/DesignForm/index.ts b/src/api/DesignForm/index.ts index 5410828..f35bbe0 100644 --- a/src/api/DesignForm/index.ts +++ b/src/api/DesignForm/index.ts @@ -63,7 +63,9 @@ export const getRequest = (apiKey: string, data?: any, options: any = {}) => { return request(obj) } // export const uploadUrl = '/api/' + allApi.upload -export const uploadUrl = import.meta.env.VITE_APP_BASE_API+"/api/upordown" +// export const uploadUrl = import.meta.env.VITE_APP_BASE_API+"/api/upordown" +export const uploadUrl = import.meta.env.VITE_APP_BASE_API+"/setupFile/uploads/oneFileUpload" +export const uploadUrlNew = import.meta.env.VITE_APP_BASE_API+"/setupFile/uploads/oneFileUpload" export function uploadFiledTinymce(data:any, url:any) { return request({ url: url || '/api/upordown', diff --git a/src/api/system/roleapi/power.ts b/src/api/system/roleapi/power.ts index 6a3037c..39bbd92 100644 --- a/src/api/system/roleapi/power.ts +++ b/src/api/system/roleapi/power.ts @@ -23,3 +23,27 @@ export function authorizeOrgTree(data?: getSystemPower){ data:data }); } +/** +@ 作者: 秦东 +@ 时间: 2025-11-28 10:24:09 +@ 功能: 根据权限获取数据 +*/ +export function authorizePeopleList(data?: getSystemPower){ + return request({ + url: '/systemapi/hr/authorizePeopleList', + method: 'post', + data:data + }); +} +/** +@ 作者: 秦东 +@ 时间: 2025-11-28 10:24:09 +@ 功能: 新增人员 +*/ +export function addNewPeople(data?: getSystemPower){ + return request({ + url: '/systemapi/hr/addNewPeople', + method: 'post', + data:data + }); +} diff --git a/src/directive/permission/button.ts b/src/directive/permission/button.ts index d57d71c..b44d998 100644 --- a/src/directive/permission/button.ts +++ b/src/directive/permission/button.ts @@ -7,17 +7,17 @@ import { useUserStore } from "@/store/modules/user"; export const hasButton: Directive = { mounted(el: HTMLElement, binding: DirectiveBinding) { const userStore = useUserStore(); - // const { value,oldValue } = binding; - // console.log("按钮权限",el,"-->",binding,"-->",value,"-->",oldValue,"-->",userStore.myPower); - console.log("按钮权限",el,"-->",binding,"-->","-->",userStore.myPower); - // if (value) { - // const requiredPerms = value; // DOM绑定需要的按钮权限标识 - // const hasPerm = userStore.myPower.menuIdAry.some((perm: any) => { - // return requiredPerms.includes(perm); - // }); - // if (!hasPerm) { - // el.parentNode?.removeChild(el); - // } - // } + const { value } = binding; + // console.log("按钮权限",el,"-->",binding,"-->",value,"-->",userStore.myPower.menuButIdAry,"-->",userStore.myPower); + + if (value) { + const requiredPerms = value; // DOM绑定需要的按钮权限标识 + const hasPerm = userStore.myPower.menuButIdAry.some((perm: any) => { + return requiredPerms.includes(perm); + }); + if (!hasPerm) { + el.parentNode?.removeChild(el); + } + } } } diff --git a/src/store/modules/user.ts b/src/store/modules/user.ts index f8db4d3..4863bda 100644 --- a/src/store/modules/user.ts +++ b/src/store/modules/user.ts @@ -96,7 +96,7 @@ export const useUserStore = defineStore("user", () => { // }); getUserInfoIng() .then(({data})=>{ - console.log("获取用户信息:角色必须是非null数组!",data); + // console.log("获取用户信息:角色必须是非null数组!",data); // debugger; if (!data) { return reject("验证失败,请重新登录。"); diff --git a/src/views/hr/archives/archivescont.vue b/src/views/hr/archives/archivescont.vue index 1a0e2b4..34ef36f 100644 --- a/src/views/hr/archives/archivescont.vue +++ b/src/views/hr/archives/archivescont.vue @@ -57,7 +57,7 @@ const userIcon = ref(); //人员头像 const boxTitle = ref(); //弹出框标题 const userConting = ref(""); //人员信息 const rowLoading = ref(false); -const imgUploadApiUrl = import.meta.env.VITE_APP_BASE_API + "/api/upordown"; //图片上传地址 +const imgUploadApiUrl = import.meta.env.VITE_APP_BASE_API+"/setupFile/uploads/oneFileUpload";//图片上传地址 const editMyOrgCont = ref(false); //编辑行政组织 const editMyCont = ref(false); //编辑个人信息 /** @@ -134,11 +134,14 @@ const handleAvatarSuccess: UploadProps["onSuccess"] = ( uploadFiles ) => { userIcon.value = URL.createObjectURL(uploadFile.raw!); + // console.log("上传成功-------------------->", uploadFile); + // console.log("上传成功-------------------->", props.archivesdata.id); //修改人员头像 editMyInfoIcon({ id: props.archivesdata.id, iconpath: response.data.url, }).then((data) => { + fileUploadIng.value = false; ElMessage.success("编辑成功"); emits("getarchivespageclick"); }); diff --git a/src/views/hr/archives/index.vue b/src/views/hr/archives/index.vue index 9f44a36..013825e 100644 --- a/src/views/hr/archives/index.vue +++ b/src/views/hr/archives/index.vue @@ -1,40 +1,96 @@ diff --git a/src/views/hr/archives/index_20251202.vue b/src/views/hr/archives/index_20251202.vue new file mode 100644 index 0000000..6cddce0 --- /dev/null +++ b/src/views/hr/archives/index_20251202.vue @@ -0,0 +1,200 @@ + + + + diff --git a/src/views/hr/archives/unitpage/addUserPage.vue b/src/views/hr/archives/unitpage/addUserPage.vue new file mode 100644 index 0000000..329a616 --- /dev/null +++ b/src/views/hr/archives/unitpage/addUserPage.vue @@ -0,0 +1,274 @@ + + + + diff --git a/src/views/hr/archives/unitpage/batchImport.vue b/src/views/hr/archives/unitpage/batchImport.vue new file mode 100644 index 0000000..9d66ac7 --- /dev/null +++ b/src/views/hr/archives/unitpage/batchImport.vue @@ -0,0 +1,235 @@ + + + + diff --git a/src/views/hr/archives/unitpage/lockInfo.vue b/src/views/hr/archives/unitpage/lockInfo.vue new file mode 100644 index 0000000..44f79ef --- /dev/null +++ b/src/views/hr/archives/unitpage/lockInfo.vue @@ -0,0 +1,96 @@ + + + + diff --git a/src/views/hr/archives/unitpage/uploadTemplate.vue b/src/views/hr/archives/unitpage/uploadTemplate.vue new file mode 100644 index 0000000..3f93580 --- /dev/null +++ b/src/views/hr/archives/unitpage/uploadTemplate.vue @@ -0,0 +1,222 @@ + + + + + diff --git a/src/views/nested/.editorconfig b/src/views/nested/.editorconfig new file mode 100644 index 0000000..b9c127d --- /dev/null +++ b/src/views/nested/.editorconfig @@ -0,0 +1,12 @@ +# EditorConfig is awesome: https://EditorConfig.org + +# top-most EditorConfig file +root = true + +[*] +indent_style = space +indent_size = 4 +end_of_line = crlf +charset = utf-8 +trim_trailing_whitespace = false +insert_final_newline = false \ No newline at end of file diff --git a/src/views/sysworkflow/lowcodepage/appPage/appSetUp/setup.vue b/src/views/sysworkflow/lowcodepage/appPage/appSetUp/setup.vue index cd5b270..11676ae 100644 --- a/src/views/sysworkflow/lowcodepage/appPage/appSetUp/setup.vue +++ b/src/views/sysworkflow/lowcodepage/appPage/appSetUp/setup.vue @@ -85,6 +85,7 @@ const submitForm = () => { // console.log("提交数据",appSetupCont) appBasicSettings(appSetupCont) .then(() => { + // eslint-disable-next-line vue/no-mutating-props props.appCont.appName = appSetupCont.title; props.appCont.appSvg = appSetupCont.appSvg; props.appCont.describe = appSetupCont.appdescribe;