From b7ebccdbc4f29cc7663582213886579091c84dd5 Mon Sep 17 00:00:00 2001
From: 祖安之光 <11848914+light-of-zuan@user.noreply.gitee.com>
Date: 星期五, 04 七月 2025 15:38:56 +0800
Subject: [PATCH] 修改新增
---
src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/industryTemplate/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue | 38 ++++
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue | 2
src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue | 39 ++++
src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue | 6
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue | 35 +++
src/main.js | 2
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue | 33 +++
src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue | 43 +++-
src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue | 16 +
src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue | 33 +++
package.json | 1
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue | 2
src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue | 72 ++++++-
src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue | 26 ++
19 files changed, 452 insertions(+), 61 deletions(-)
diff --git a/package.json b/package.json
index bc40b46..a6694ea 100644
--- a/package.json
+++ b/package.json
@@ -23,6 +23,7 @@
"@wangeditor/editor-for-vue": "^5.1.12",
"@wangeditor/plugin-upload-attachment": "^1.1.0",
"axios": "0.27.2",
+ "docx-preview": "^0.3.5",
"docxtemplater": "^3.63.2",
"echarts": "5.4.0",
"element-plus": "2.2.27",
diff --git a/src/main.js b/src/main.js
index d0d0667..57a30a7 100644
--- a/src/main.js
+++ b/src/main.js
@@ -45,7 +45,7 @@
import preReClick from "@/utils/preReClick";
-import vue3JsonExcel from 'vue3-json-excel';
+import vue3JsonExcel from 'vue3-json-excel';
import { Boot } from '@wangeditor/editor'
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue
index 62b6b90..d918268 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/appFile/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue
index 8e3c3c3..39e50d1 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/qualityManual/index.vue
@@ -42,7 +42,8 @@
</template>
</el-table-column>
</el-table>
-
+<!-- <org-tree :data="companyInfo.deptList" />-->
+ <button @click="exportOrgChart">导出组织架构图</button>
<pagination
v-show="total > 0"
:total="total"
@@ -50,8 +51,6 @@
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
-
- <edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
</div>
</template>
@@ -59,17 +58,10 @@
import {getCurrentInstance, onMounted, onUnmounted, reactive, ref, toRefs} from "vue";
import {ElMessage, ElMessageBox} from "element-plus";
import {delCompany, getCompany} from "@/api/onlineEducation/company";
-import {delUser, getUser} from "@/api/onlineEducation/user";
-import Cookies from "js-cookie";
-import editDialog from './components/editDialog.vue'
import {generateWordDocument} from './components/exportDoc.js'
-
-
-import {
- addIndustryTemp,
- delIndustryTemp,
- getIndustryTemp,
-} from "@/api/staffManage/staff";
+// import OrgTree from 'vue-org-tree'
+import html2canvas from 'html2canvas'
+import { saveAs } from 'file-saver'
import useUserStore from "@/store/modules/user";
import {
addStandardQuality,
@@ -77,8 +69,6 @@
getStandardDetail,
getStandardQuality
} from "@/api/standardSys/standardSys";
-import {getBasic} from "@/api/companyInfo/basicInfo";
-import {getCom} from "@/api/companyInfo/overview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
@@ -126,7 +116,7 @@
]
});
-const { queryParams, total, dataList,companyList, isAdmin } = toRefs(data);
+const { queryParams, total, dataList,companyList, isAdmin, companyInfo } = toRefs(data);
const userInfo = ref()
onMounted(async ()=>{
if(userStore.roles.includes('admin')){
@@ -143,6 +133,27 @@
})
+const exportOrgChart=()=> {
+ const element = document.querySelector('.org-tree'); // 获取组织架构图的容器元素
+ html2canvas(element).then(canvas => {
+ // 创建一个图片元素
+ let img = new Image();
+ img.src = canvas.toDataURL('image/png');
+
+ // 创建并触发下载
+ img.onload = () => {
+ let w = img.width;
+ let h = img.height;
+ let canvas2 = document.createElement('canvas');
+ let ctx = canvas2.getContext('2d');
+ canvas2.width = w;
+ canvas2.height = h;
+ ctx.drawImage(img, 0, 0, w, h);
+ saveAs(canvas2.toDataURL('image/png'), '组织架构图.png');
+ };
+ });
+}
+
const getList = async () => {
loading.value = true
const res = await getStandardQuality(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue
index 217d3a2..8f5a249 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/recordSheets/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -97,6 +99,37 @@
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
+
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue
index 573cf60..83d4ad7 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/manageType/workInstruct/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue
index c2c75a7..5a37f94 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/otherIntellFile/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue
index 6083f90..b1bc46c 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/productType/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue b/src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue
index 5a15405..e20fb49 100644
--- a/src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue
+++ b/src/views/build/conpanyFunctionConsult/digitalFileDep/techType/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="名称" prop="templateName" align="center"/>
<el-table-column label="文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/industryTemplate/index.vue b/src/views/build/conpanyFunctionConsult/industryTemplate/index.vue
index f53ebab..58ae920 100644
--- a/src/views/build/conpanyFunctionConsult/industryTemplate/index.vue
+++ b/src/views/build/conpanyFunctionConsult/industryTemplate/index.vue
@@ -48,13 +48,14 @@
<el-table-column label="行业" prop="industryName" align="center" />
<el-table-column label="模板" prop="fileName" align="center">
<template #default="scope">
- <el-link style="" type="primary" @click="downloadFile(scope.row)">{{scope.row.fileName}}</el-link>
+ <el-link style="" type="primary" @click="openFile(scope.row.filePath)">{{scope.row.fileName}}</el-link>
</template>
</el-table-column>
<el-table-column label="分类" prop="type" align="center" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -122,6 +123,7 @@
import axios from "axios";
import {getToken} from "@/utils/auth";
import {getIndustry} from "@/api/system/industry";
+import {renderAsync} from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -181,7 +183,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank')
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getIndustryTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue
index 05e4b12..581774d 100644
--- a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue
+++ b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/departDialog.vue
@@ -32,12 +32,13 @@
/>
</el-select>
</el-form-item>
- <el-form-item label="主要负责部门:" prop="parentId">
+ <el-form-item label="主要负责部门:" prop="childDeptIds">
<el-select
clearable
- v-model="state.form.parentId"
+ v-model="state.form.childDeptIds"
:disabled="state.title =='查看'"
filterable
+ multiple
placeholder="主要负责部门"
style="width: 100%"
>
@@ -68,6 +69,12 @@
/>
</el-select>
</el-form-item>
+ <el-form-item label="是否加入职能分配表" prop="responsType">
+ <el-radio-group v-model="state.form.responsType" :disabled="disabled">
+ <el-radio :label="1">是</el-radio>
+ <el-radio :label="2">否</el-radio>
+ </el-radio-group>
+ </el-form-item>
</el-form>
<template #footer v-if="state.title !='查看'">
<span class="dialog-footer">
@@ -96,7 +103,9 @@
parentId: null,
caluseVO1List: [],
delCaluseIds: [],
- companyId: null
+ companyId: null,
+ responsType: 1,
+ childDeptIds: []
},
isAdmin: false,
companyList: [],
@@ -109,7 +118,7 @@
deptName: [{ required: true, message: '请输入部门名称', trigger: 'blur' }],
// leaderUserId: [{ required: true, message: '请选择负责人', trigger: 'blur' }],
// parentId: [{ required: true, message: '请选择负责部门', trigger: 'blur' }],
- caluseVO1List: [{ required: true, message: '请选择涉及条款', trigger: 'blur' }],
+ // caluseVO1List: [{ required: true, message: '请选择涉及条款', trigger: 'blur' }],
}
})
@@ -135,7 +144,8 @@
}
});
state.oldClauseList = value.caluseVO1List
- console.log(state.oldClauseList,'old')
+ state.form.childDeptIds = value.sysDeptManageVoList?.map(i=>i.subDeptId)
+ state.form.responsType = Number(value.responsType)
}else{
state.form.companyId = companyId
}
@@ -143,7 +153,7 @@
}
const getUserList = async ()=> {
- const res = await listUser()
+ const res = await listUser({pageIndex: 1,pageSize: 999})
if(res.code == 200){
state.userList = res.data.list?res.data.list:[]
}else{
@@ -215,7 +225,9 @@
parentId: null,
caluseVO1List: [],
delCaluseIds: [],
- companyId: null
+ companyId: null,
+ responsType: 1,
+ childDeptIds: []
}
superRef.value.clearValidate();
diff --git a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue
index ee5e014..4820123 100644
--- a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue
+++ b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/components/dutyDialog.vue
@@ -203,7 +203,7 @@
oldResponsibilityList: [],
formRules:{
personNum: [{ required: true, message: '请输入部门人数', trigger: 'blur' }],
- internalAuditors: [{ required: true, message: '请选择内审员', trigger: 'blur' }],
+ // internalAuditors: [{ required: true, message: '请选择内审员', trigger: 'blur' }],
responsibilities: [{ required: true, message: '请输入部门职责', trigger: 'blur' }]
},
firstFive: [
diff --git a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue
index f66da1c..7963c91 100644
--- a/src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue
+++ b/src/views/build/conpanyFunctionConsult/orgStructure/departManage/index.vue
@@ -27,14 +27,18 @@
<el-table-column label="序号" type="index" align="center" width="80" />
<el-table-column label="部门名称" prop="deptName" align="center" />
<el-table-column label="负责人" prop="leaderName" align="center" />
- <el-table-column label="主要负责部门" prop="parentName" align="center"/>
+ <el-table-column label="主要负责部门" prop="parentName" align="center">
+ <template #default="scope">
+ <span>
+ {{scope.row.sysDeptManageVoList?.map(i=>i.subDeptName).join('、')}}
+ </span>
+ </template>
+ </el-table-column>
<el-table-column label="部门涉及条款" prop="userTypeName" align="center" width="150">
<template #default="scope">
- <div v-if="scope.row.caluseVO1List">
- <div v-for="(item,index) in scope.row.caluseVO1List" :key="index">
- {{ item.clauseNum + ' ' + item.content}}
- </div>
- </div>
+ <span>
+ {{scope.row.caluseVO1List?.map(i=>i.clauseNum).join('、')}}
+ </span>
</template>
</el-table-column>
<el-table-column label="部门职责表" prop="userTypeName" align="center" width="150">
diff --git a/src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue b/src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue
index b67b257..9fa37aa 100644
--- a/src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue
+++ b/src/views/build/conpanyFunctionConsult/orgStructure/dutyDistributeChart/index.vue
@@ -38,16 +38,16 @@
<el-table v-loading="loading" :data="caluseList" class="caluseTable" :border="true" :span-method="arraySpanMethod">
<el-table-column label="条款号" prop="clauseNum" align="center"/>
<el-table-column label="条款内容/要素" prop="content" align="left"/>
- <el-table-column label="总经理" prop="manage" align="center">
- <template #default="scope">
- <el-checkbox v-model="scope.row.manage" disabled size="large" />
- </template>
- </el-table-column>
- <el-table-column label="管理者代表" prop="represent" align="center">
- <template #default="scope">
- <el-checkbox v-model="scope.row.represent" disabled size="large" />
- </template>
- </el-table-column>
+<!-- <el-table-column label="总经理" prop="manage" align="center">-->
+<!-- <template #default="scope">-->
+<!-- <el-checkbox v-model="scope.row.manage" disabled size="large" />-->
+<!-- </template>-->
+<!-- </el-table-column>-->
+<!-- <el-table-column label="管理者代表" prop="represent" align="center">-->
+<!-- <template #default="scope">-->
+<!-- <el-checkbox v-model="scope.row.represent" disabled size="large" />-->
+<!-- </template>-->
+<!-- </el-table-column>-->
<el-table-column v-for="column in deptList" :key="column.deptId" :prop="column.deptId" :label="column.deptName" align="center">
<template #default="scope">
<el-checkbox v-model="scope.row[column.deptId]" :disabled="!isEdit" size="large" @change="changeStatus(scope.row)"/>
@@ -97,7 +97,50 @@
{clauseNum: '7.1.3', content: '基础设施',manage: false,represent: true},
{clauseNum: '7.1.4', content: '过程运行环境',manage: false,represent: true},
{clauseNum: '7.1.5', content: '监视和测量资源',manage: false,represent: true},
- {clauseNum: '7.1.6', content: '组织的知识',manage: false,represent: true}
+ {clauseNum: '7.1.6', content: '组织的知识',manage: false,represent: true},
+ {clauseNum: '7.2', content: '能力'},
+ {clauseNum: '7.3', content: '意识'},
+ {clauseNum: '7.4', content: '沟通'},
+ {clauseNum: '7.5', content: '成文信息'},
+ {clauseNum: '7.6', content: '质量信息'},
+ {clauseNum: '8', content: '运行'},
+ {clauseNum: '8.1', content: '运行策划和控制'},
+ {clauseNum: '8.2', content: '产品和服务的要求'},
+ {clauseNum: '8.2.1', content: '顾客沟通'},
+ {clauseNum: '8.2.2', content: '与产品和服务有关的要求的确定'},
+ {clauseNum: '8.2.3', content: '与产品和服务有关的要求的评审'},
+ {clauseNum: '8.2.4', content: '产品和服务要求的更改'},
+ {clauseNum: '8.3', content: '产品和服务的设计和开发'},
+ {clauseNum: '8.3.1', content: '总则'},
+ {clauseNum: '8.3.2', content: '设计和开发策划'},
+ {clauseNum: '8.3.3', content: '设计和开发输入'},
+ {clauseNum: '8.3.4', content: '设计和开发控制'},
+ {clauseNum: '8.3.5', content: '设计和开发输出'},
+ {clauseNum: '8.3.6', content: '设计和开发更改'},
+ {clauseNum: '8.3.7', content: '新产品试制'},
+ {clauseNum: '8.3.8', content: '设计和开发的试验控制'},
+ {clauseNum: '8.4', content: '外部提供过程、产品和服务的控制'},
+ {clauseNum: '8.4.1', content: '总则'},
+ {clauseNum: '8.4.2', content: '控制类型和程度'},
+ {clauseNum: '8.4.3', content: '提供给外部供方的信息'},
+ {clauseNum: '8.5', content: '生产和服务提供'},
+ {clauseNum: '8.5.1', content: '生产和服务提供的控制'},
+ {clauseNum: '8.5.2', content: '标识和可追溯性'},
+ {clauseNum: '8.5.3', content: '顾客或外部供方的财产'},
+ {clauseNum: '8.5.4', content: '防护'},
+ {clauseNum: '8.5.5', content: '交付后的活动'},
+ {clauseNum: '8.5.6', content: '更改控制'},
+ {clauseNum: '8.5.7', content: '关键过程'},
+ {clauseNum: '8.6', content: '产品和服务的放行'},
+ {clauseNum: '8.7', content: '不合格输出的控制'},
+ {clauseNum: '9', content: '绩效评价'},
+ {clauseNum: '9.1', content: '监视、测量、分析和评价'},
+ {clauseNum: '9.1.1', content: '总则'},
+ {clauseNum: '9.1.2', content: '顾客满意'},
+ {clauseNum: '9.1.3', content: '分析和评价'},
+ {clauseNum: '9.2', content: '内部审核'},
+ {clauseNum: '9.3', content: '管理评审'},
+ {clauseNum: '10', content: '持续改进'}
],
form: {
companyId: null,
@@ -170,7 +213,8 @@
rowIndex,
columnIndex,
}) => {
- if (rowIndex === 0 || rowIndex === 5 ||rowIndex === 9 ||rowIndex === 13) {
+ const mergeValues = ['4','5','6','7','7.1','8','8.2','8.3','8.4','8.5','9','9.1','10']
+ if (mergeValues.includes(row.clauseNum)) {
if (columnIndex === 0) {
return [1, 1]
} else if(columnIndex === 1){
@@ -287,7 +331,7 @@
<style lang="scss">
.caluseTable{
.el-table__cell{
- padding: 4px 0 !important;
+ padding: 0 !important;
.is-disabled{
.el-checkbox__label{
color: #606266 !important
@@ -313,7 +357,7 @@
}
}
.cell{
- padding: 0 6px !important;
+ padding: 0 4px !important;
}
}
</style>
\ No newline at end of file
diff --git a/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue b/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue
index bf956a2..254c45f 100644
--- a/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue
+++ b/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/components/staffDialog.vue
@@ -43,9 +43,9 @@
</el-form-item>
<el-form-item label="用户类型:" v-if="state.title !== '修改密码'" prop="userType">
<el-radio-group v-model="state.form.userType" :disabled="disabled" @change="changeType" v-if="state.title == '新增'">
- <el-radio :label="0" v-if="state.currentUserType == 0">管理员</el-radio>
- <el-radio :label="1" v-if="state.currentUserType == 0 ">企业级</el-radio>
- <el-radio :label="2" v-if="state.currentUserType == 1 ">部门级</el-radio>
+ <el-radio :label="0" v-if="state.currentUserType == 0">系统管理员</el-radio>
+ <el-radio :label="1" v-if="state.currentUserType == 0 ">企业管理员</el-radio>
+ <el-radio :label="2" v-if="state.currentUserType == 1 ">企业用户</el-radio>
<el-radio :label="3" v-if="!state.isAdmin">车间(岗位)级</el-radio>
<el-radio :label="4" v-if="state.currentUserType == 0">其他</el-radio>
</el-radio-group>
diff --git a/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue b/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue
index c5b0ba8..5f3498e 100644
--- a/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue
+++ b/src/views/build/conpanyFunctionConsult/staffManage/staffRegister/index.vue
@@ -214,7 +214,7 @@
companyId: null
})
if(res.code == 200){
- data.expertData = res.data.list.map((item,index) => {
+ data.expertData = res.data.list?.map((item,index) => {
return {
...item,
index: index + 1,
diff --git a/src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue b/src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue
index a75f169..0e81ff4 100644
--- a/src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue
+++ b/src/views/build/conpanyFunctionConsult/standardSysTemp/appStandardModule/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="模板名称" prop="templateName" align="center"/>
<el-table-column label="模板文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,9 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import { renderAsync } from "docx-preview";
+
+
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -101,7 +105,6 @@
loading.value = true
const res = await getStandardTemp(data.queryParams)
if(res.code == 200){
- console.log(res.data,'data')
data.dataList = res.data.list || []
data.total = res.data.total
}else{
@@ -128,6 +131,37 @@
window.open(import.meta.env.VITE_APP_BASE_API + '/' + path)
}
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
+
const openDialog = (type, value) => {
dialogRef.value.openDialog(type, value, data.queryParams.companyId, data.isAdmin, data.companyList);
}
diff --git a/src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue b/src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue
index b7e2c7c..b608d4a 100644
--- a/src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue
+++ b/src/views/build/conpanyFunctionConsult/standardSysTemp/sysStandardModule/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="模板名称" prop="templateName" align="center"/>
<el-table-column label="模板文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -50,7 +51,7 @@
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
-
+ <div id="docx-preview-container" style="width: 100%; height: auto; border: 1px solid #ccc;"></div>
<edit-dialog ref="dialogRef" @getList=getList></edit-dialog>
</div>
</template>
@@ -63,6 +64,8 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import { renderAsync } from "docx-preview";
+
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -97,6 +100,38 @@
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank');
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
+
+
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
diff --git a/src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue b/src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue
index 4bb25c3..f5dc611 100644
--- a/src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue
+++ b/src/views/build/conpanyFunctionConsult/standardSysTemp/techStandardModule/index.vue
@@ -32,11 +32,12 @@
<el-table-column label="模板名称" prop="templateName" align="center"/>
<el-table-column label="模板文件" align="center">
<template #default="scope">
- <el-button link type="primary" @click="downloadFile(scope.row.filePath)">{{scope.row.templateName + '模板'}}</el-button>
+ <el-link type="primary" @click="openFile(scope.row.filePath)">{{scope.row.templateName + '模板' + scope.row.format}}</el-link>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" >
<template #default="scope">
+ <el-button link type="primary" @click="downloadFile(scope.row.filePath)">下载</el-button>
<el-button link type="primary" @click="openDialog('edit',scope.row)">编辑</el-button>
<el-button link type="danger" @click="handleDelete(scope.row)">删除</el-button>
</template>
@@ -63,6 +64,7 @@
import editDialog from './components/editDialog.vue'
import useUserStore from "@/store/modules/user";
import {getStandardTemp,delStandardTemp} from "@/api/standardSys/standardSys";
+import { renderAsync } from "docx-preview";
const userStore = useUserStore()
const { proxy } = getCurrentInstance();
const loading = ref(false);
@@ -96,7 +98,36 @@
onUnmounted(()=>{
})
+const openFile = async(path)=>{
+ try {
+ // 1. 获取文件
+ const response = await fetch(import.meta.env.VITE_APP_BASE_API + '/' + path);
+ const arrayBuffer = await response.arrayBuffer();
+ // 2. 创建新窗口
+ const win = window.open('', '_blank')
+ win.document.write(`
+ <!DOCTYPE html>
+ <html>
+ <head>
+ <title>预览</title>
+ <style>
+ body { margin: 20px; font-family: Arial; }
+ .docx-container { width: 100%; height: 100%; }
+ </style>
+ </head>
+ <body>
+ <div id="container" class="docx-container"></div>
+ </body>
+ </html>
+ `);
+ // 3. 渲染 DOCX
+ await renderAsync(arrayBuffer, win.document.getElementById('container'));
+ } catch (error) {
+ console.error('预览失败:', error);
+ alert(`预览失败: ${error.message}`);
+ }
+}
const getList = async () => {
loading.value = true
const res = await getStandardTemp(data.queryParams)
--
Gitblit v1.9.2