diff --git a/package.json b/package.json index 1b65dfc..1c2ade5 100644 --- a/package.json +++ b/package.json @@ -22,12 +22,17 @@ "@highlightjs/vue-plugin": "^2.1.0", "@kjgl77/datav-vue3": "^1.7.3", "axios": "^1.7.2", + "docxtemplater": "^3.60.2", "echarts": "^5.6.0", "element-plus": "^2.9.5", + "file-saver": "^2.0.5", "highlight.js": "^11.11.1", "insert-css": "^2.0.0", + "install": "^0.13.0", + "jszip-utils": "^0.1.0", "lib-flexible": "^0.3.2", "pinia": "^2.1.7", + "pizzip": "^3.1.8", "postcss-plugin-px2rem": "^0.8.1", "sass": "^1.77.6", "sass-loader": "^14.2.1", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 72ab804..88cf44a 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -47,24 +47,39 @@ importers: axios: specifier: ^1.7.2 version: 1.7.2 + docxtemplater: + specifier: ^3.60.2 + version: 3.60.2 echarts: specifier: ^5.6.0 version: 5.6.0 element-plus: specifier: ^2.9.5 version: 2.9.5(vue@3.4.29(typescript@5.2.2)) + file-saver: + specifier: ^2.0.5 + version: 2.0.5 highlight.js: specifier: ^11.11.1 version: 11.11.1 insert-css: specifier: ^2.0.0 version: 2.0.0 + install: + specifier: ^0.13.0 + version: 0.13.0 + jszip-utils: + specifier: ^0.1.0 + version: 0.1.0 lib-flexible: specifier: ^0.3.2 version: 0.3.2 pinia: specifier: ^2.1.7 version: 2.1.7(typescript@5.2.2)(vue@3.4.29(typescript@5.2.2)) + pizzip: + specifier: ^3.1.8 + version: 3.1.8 postcss-plugin-px2rem: specifier: ^0.8.1 version: 0.8.1 @@ -410,55 +425,46 @@ packages: resolution: {integrity: sha512-C/zbRYRXFjWvz9Z4haRxcTdnkPt1BtCkz+7RtBSuNmKzMzp3ZxdM28Mpccn6pt28/UWUCTXa+b0Mx1k3g6NOMA==} cpu: [arm] os: [linux] - libc: [glibc] '@rollup/rollup-linux-arm-musleabihf@4.18.0': resolution: {integrity: sha512-l3m9ewPgjQSXrUMHg93vt0hYCGnrMOcUpTz6FLtbwljo2HluS4zTXFy2571YQbisTnfTKPZ01u/ukJdQTLGh9A==} cpu: [arm] os: [linux] - libc: [musl] '@rollup/rollup-linux-arm64-gnu@4.18.0': resolution: {integrity: sha512-rJ5D47d8WD7J+7STKdCUAgmQk49xuFrRi9pZkWoRD1UeSMakbcepWXPF8ycChBoAqs1pb2wzvbY6Q33WmN2ftw==} cpu: [arm64] os: [linux] - libc: [glibc] '@rollup/rollup-linux-arm64-musl@4.18.0': resolution: {integrity: sha512-be6Yx37b24ZwxQ+wOQXXLZqpq4jTckJhtGlWGZs68TgdKXJgw54lUUoFYrg6Zs/kjzAQwEwYbp8JxZVzZLRepQ==} cpu: [arm64] os: [linux] - libc: [musl] '@rollup/rollup-linux-powerpc64le-gnu@4.18.0': resolution: {integrity: sha512-hNVMQK+qrA9Todu9+wqrXOHxFiD5YmdEi3paj6vP02Kx1hjd2LLYR2eaN7DsEshg09+9uzWi2W18MJDlG0cxJA==} cpu: [ppc64] os: [linux] - libc: [glibc] '@rollup/rollup-linux-riscv64-gnu@4.18.0': resolution: {integrity: sha512-ROCM7i+m1NfdrsmvwSzoxp9HFtmKGHEqu5NNDiZWQtXLA8S5HBCkVvKAxJ8U+CVctHwV2Gb5VUaK7UAkzhDjlg==} cpu: [riscv64] os: [linux] - libc: [glibc] '@rollup/rollup-linux-s390x-gnu@4.18.0': resolution: {integrity: sha512-0UyyRHyDN42QL+NbqevXIIUnKA47A+45WyasO+y2bGJ1mhQrfrtXUpTxCOrfxCR4esV3/RLYyucGVPiUsO8xjg==} cpu: [s390x] os: [linux] - libc: [glibc] '@rollup/rollup-linux-x64-gnu@4.18.0': resolution: {integrity: sha512-xuglR2rBVHA5UsI8h8UbX4VJ470PtGCf5Vpswh7p2ukaqBGFTnsfzxUBetoWBWymHMxbIG0Cmx7Y9qDZzr648w==} cpu: [x64] os: [linux] - libc: [glibc] '@rollup/rollup-linux-x64-musl@4.18.0': resolution: {integrity: sha512-LKaqQL9osY/ir2geuLVvRRs+utWUNilzdE90TpyoX0eNqPzWjRm14oMEE+YLve4k/NAqCdPkGYDaDF5Sw+xBfg==} cpu: [x64] os: [linux] - libc: [musl] '@rollup/rollup-win32-arm64-msvc@4.18.0': resolution: {integrity: sha512-7J6TkZQFGo9qBKH0pk2cEVSRhJbL6MtfWxth7Y5YmZs57Pi+4x6c2dStAUvaQkHQLnEQv1jzBUW43GvZW8OFqA==} @@ -579,6 +585,10 @@ packages: '@vueuse/shared@9.13.0': resolution: {integrity: sha512-UrnhU+Cnufu4S6JLCPZnkWh0WwZGUp72ktOF2DFptMlOs3TOdVv8xJN53zhHGARmVOsz5KqOls09+J1NR6sBKw==} + '@xmldom/xmldom@0.9.8': + resolution: {integrity: sha512-p96FSY54r+WJ50FIOsCOjyj/wavs8921hG5+kVMmZgKcvIKxMXHTrjNJvRgWa/zuX3B6t2lijLNFaOyuxUH+2A==} + engines: {node: '>=14.6'} + acorn@8.14.1: resolution: {integrity: sha512-OvQ/2pUDKmgfCg++xsTX1wGxfTaszcHVcTctW4UJB4hibJx2HXxxO5UmVgyjMa+ZDsiaf5wWLXYpRWMmBI0QHg==} engines: {node: '>=0.4.0'} @@ -702,6 +712,10 @@ packages: resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==} engines: {node: '>=0.4.0'} + docxtemplater@3.60.2: + resolution: {integrity: sha512-x6p8Vr5FgZn0ibmFJz4IS9u8KANQKLzhrp3EMxMvzBAxFW/c3kYhJKFNN8QzjJzXqKO2+XWCN1KTcaSKjqtnqg==} + engines: {node: '>=0.10'} + dom-serializer@2.0.0: resolution: {integrity: sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==} @@ -771,6 +785,9 @@ packages: picomatch: optional: true + file-saver@2.0.5: + resolution: {integrity: sha512-P9bmyZ3h/PRG+Nzga+rbdI4OEpNDzAVyy74uVO9ATgzLK6VtAsYybF/+TOCvrc0MO793d6+42lLyZTw7/ArVzA==} + fill-range@7.1.1: resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==} engines: {node: '>=8'} @@ -860,6 +877,10 @@ packages: insert-css@2.0.0: resolution: {integrity: sha512-xGq5ISgcUP5cvGkS2MMFLtPDBtrtQPSFfC6gA6U8wHKqfjTIMZLZNxOItQnoSjdOzlXOLU/yD32RKC4SvjNbtA==} + install@0.13.0: + resolution: {integrity: sha512-zDml/jzr2PKU9I8J/xyZBQn8rPCAY//UOYNmR01XwNwyfhEWObo2SWfSl1+0tm1u6PhxLwDnfsT/6jB7OUxqFA==} + engines: {node: '>= 0.10'} + is-binary-path@2.1.0: resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==} engines: {node: '>=8'} @@ -895,6 +916,9 @@ packages: jsonfile@2.4.0: resolution: {integrity: sha512-PKllAqbgLgxHaj8TElYymKCAgrASebJrWpTnEkOaTowt23VKXXN0sUeriJ+eh7y6ufb/CC5ap11pz71/cM0hUw==} + jszip-utils@0.1.0: + resolution: {integrity: sha512-tBNe0o3HAf8vo0BrOYnLPnXNo5A3KsRMnkBFYjh20Y3GPYGfgyoclEMgvVchx0nnL+mherPi74yLPIusHUQpZg==} + less@4.2.2: resolution: {integrity: sha512-tkuLHQlvWUTeQ3doAqnHbNn8T6WX1KA8yvbKG9x4VtKtIjHsVKQZCH11zRgAfbDAXC2UNIg/K9BYAAcEzUIrNg==} engines: {node: '>=6'} @@ -996,6 +1020,9 @@ packages: once@1.4.0: resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==} + pako@2.1.0: + resolution: {integrity: sha512-w+eufiZ1WuJYgPXbV/PO3NCMEc3xqylkKHzp8bxp1uW4qaSNQUkwmLLEc3kKsfz8lpV1F8Ht3U1Cm+9Srog2ug==} + parse-node-version@1.0.1: resolution: {integrity: sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==} engines: {node: '>= 0.10'} @@ -1037,6 +1064,9 @@ packages: typescript: optional: true + pizzip@3.1.8: + resolution: {integrity: sha512-Nynadaz6/o1cmXDQGKqmTnbeaY10BGNc1PPOZYJMfLcjWfVJQ1ARngpVO+BrrRl/WUNIj0V9uJNrP72mkfsY5A==} + pkg-types@1.3.1: resolution: {integrity: sha512-/Jm5M4RvtBFVkKWRu2BLUTNP8/M2a+UwuAX+ae4770q1qVGtfjG+WTCupoZixokjmHiry8uI+dlY8KXYV5HVVQ==} @@ -1083,8 +1113,8 @@ packages: resolution: {integrity: sha512-R+LQj3Evbjbpmglo7D0PBVsnAbKP4WSvZEZUnF8RGIpWkIHFeAT+BlDOxxBxKVyMDecmfv9qdzNLTZLMq32osA==} hasBin: true - quansync@0.2.10: - resolution: {integrity: sha512-t41VRkMYbkHyCYmOvx/6URnN80H7k4X0lLdBMGsz+maAwrJQYB1djpV6vHrQIBE0WBSGqhtEHrK9U3DWWH8v7A==} + quansync@0.2.8: + resolution: {integrity: sha512-4+saucphJMazjt7iOM27mbFCk+D9dd/zmgMDCzRZ8MEoBfYp7lAvoN38et/phRQF6wOPMy/OROBGgoWeSKyluA==} readdirp@3.6.0: resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==} @@ -1255,8 +1285,8 @@ packages: '@nuxt/kit': optional: true - unplugin@2.2.1: - resolution: {integrity: sha512-Q0YDhwViJaSnHf1cxLf+/VKhmfdr/ZAS/RL2GQVO0cAbAfJAVUef2bvNu+veyWcEPNwsTlFmMiFLjf8Xeqog8g==} + unplugin@2.2.0: + resolution: {integrity: sha512-m1ekpSwuOT5hxkJeZGRxO7gXbXT3gF26NjQ7GdVHoLoF8/nopLcd/QfPigpCy7i51oFHiRJg/CyHhj4vs2+KGw==} engines: {node: '>=18.12.0'} urix@0.1.0: @@ -1755,6 +1785,8 @@ snapshots: - '@vue/composition-api' - vue + '@xmldom/xmldom@0.9.8': {} + acorn@8.14.1: {} ansi-regex@0.2.1: {} @@ -1870,6 +1902,10 @@ snapshots: delayed-stream@1.0.0: {} + docxtemplater@3.60.2: + dependencies: + '@xmldom/xmldom': 0.9.8 + dom-serializer@2.0.0: dependencies: domelementtype: 2.3.0 @@ -1969,6 +2005,8 @@ snapshots: optionalDependencies: picomatch: 4.0.2 + file-saver@2.0.5: {} + fill-range@7.1.1: dependencies: to-regex-range: 5.0.1 @@ -2052,6 +2090,8 @@ snapshots: insert-css@2.0.0: {} + install@0.13.0: {} + is-binary-path@2.1.0: dependencies: binary-extensions: 2.3.0 @@ -2080,6 +2120,8 @@ snapshots: optionalDependencies: graceful-fs: 4.2.11 + jszip-utils@0.1.0: {} + less@4.2.2: dependencies: copy-anything: 2.0.6 @@ -2106,7 +2148,7 @@ snapshots: dependencies: mlly: 1.7.4 pkg-types: 2.1.0 - quansync: 0.2.10 + quansync: 0.2.8 lodash-es@4.17.21: {} @@ -2184,6 +2226,8 @@ snapshots: dependencies: wrappy: 1.0.2 + pako@2.1.0: {} + parse-node-version@1.0.1: {} path-browserify@1.0.1: {} @@ -2209,6 +2253,10 @@ snapshots: optionalDependencies: typescript: 5.2.2 + pizzip@3.1.8: + dependencies: + pako: 2.1.0 + pkg-types@1.3.1: dependencies: confbox: 0.1.8 @@ -2271,7 +2319,7 @@ snapshots: extend: 3.0.2 fs-extra: 0.16.5 - quansync@0.2.10: {} + quansync@0.2.8: {} readdirp@3.6.0: dependencies: @@ -2401,7 +2449,7 @@ snapshots: scule: 1.3.0 strip-literal: 3.0.0 tinyglobby: 0.2.12 - unplugin: 2.2.1 + unplugin: 2.2.0 unplugin-utils: 0.2.4 unplugin-auto-import@19.1.1(@vueuse/core@10.11.0(vue@3.4.29(typescript@5.2.2))): @@ -2410,7 +2458,7 @@ snapshots: magic-string: 0.30.17 picomatch: 4.0.2 unimport: 4.1.2 - unplugin: 2.2.1 + unplugin: 2.2.0 unplugin-utils: 0.2.4 optionalDependencies: '@vueuse/core': 10.11.0(vue@3.4.29(typescript@5.2.2)) @@ -2428,7 +2476,7 @@ snapshots: magic-string: 0.30.17 mlly: 1.7.4 tinyglobby: 0.2.12 - unplugin: 2.2.1 + unplugin: 2.2.0 unplugin-utils: 0.2.4 vue: 3.4.29(typescript@5.2.2) optionalDependencies: @@ -2436,7 +2484,7 @@ snapshots: transitivePeerDependencies: - supports-color - unplugin@2.2.1: + unplugin@2.2.0: dependencies: acorn: 8.14.1 webpack-virtual-modules: 0.6.2 diff --git a/public/template.docx b/public/template.docx new file mode 100644 index 0000000..9b5de61 Binary files /dev/null and b/public/template.docx differ diff --git a/src/api/index.ts b/src/api/index.ts index 2fc361f..b521b9e 100644 --- a/src/api/index.ts +++ b/src/api/index.ts @@ -51,6 +51,22 @@ export const checkapi = (params:any)=> { params }) } +// 获取实验报告 +export const getReport = () => { + return request({ + url: "/xnRecords/getSummarize", + method: "get", + + }) +} +// 保存实验报告 +export const saveReport = (data: any) => { + return request({ + url: "/xnRecords/saveSummarize", + method: "post", + data + })} + //获取实验目标 export const getExperiment = ()=>{ return request({ diff --git a/src/assets/images/ideaicon.png b/src/assets/images/ideaicon.png new file mode 100644 index 0000000..49317ca Binary files /dev/null and b/src/assets/images/ideaicon.png differ diff --git a/src/assets/images/idealeftbgc.png b/src/assets/images/idealeftbgc.png new file mode 100644 index 0000000..05939b9 Binary files /dev/null and b/src/assets/images/idealeftbgc.png differ diff --git a/src/router/index.ts b/src/router/index.ts index ff088d4..e9d09e4 100644 --- a/src/router/index.ts +++ b/src/router/index.ts @@ -25,6 +25,11 @@ const routerList: any = [ name: "Compiler", component: () => import("@/views/compiler/index.vue"), }, + { + path: "experimentalData", + name: "ExperimentalData", + component: () => import("@/views/experimentalData/index.vue"), + } ], }, { @@ -54,7 +59,8 @@ const routerList: any = [ path: '/knowledgePage', name: 'KnowledgePage', component: () => import('@/layout/knowledgePage.vue') - } + }, + ]; const router: any = createRouter({ diff --git a/src/store/modules/setting.ts b/src/store/modules/setting.ts index 74494ec..f06b7ec 100644 --- a/src/store/modules/setting.ts +++ b/src/store/modules/setting.ts @@ -1,4 +1,7 @@ import { defineStore } from "pinia"; +import { ElMessage } from "element-plus"; +import router from "@/router"; + const settingStore = defineStore("settingStore", { state: (): any => { return { @@ -16,11 +19,15 @@ const settingStore = defineStore("settingStore", { sdsz: 0, // 湿度数值 falg: false, timer: null, - experimentPreservation: false, // 是否设计好实验 - saveRoute: false, // 是否保存路由 + experimentPreservation: + Boolean(localStorage.getItem("experimentPreservation")) || false, // 是否设计好实验 + saveRoute: Boolean(localStorage.getItem("saveRoute")) || false, // 是否保存路由 stepIds: null, wenduCode: null, - shiduCode:null + shiduCode: null, + isRunning: false, + isRunCode: Boolean(localStorage.getItem("isRunCode")) || false, + shiyanData: [], }; }, actions: { @@ -70,6 +77,11 @@ const settingStore = defineStore("settingStore", { }, 1000); }, simulateHeatingAndHumidifying() { + // const router = useRouter(); + + if (this.isRunning) return; // 如果已经在运行,则直接返回 + this.isRunning = true; + this.shiyanData = []; // 计算时间常数 const a = (100000 * this.zl * this.srmj) / this.jrgl; const b = (10000 * this.jsmj) / this.jsgl; @@ -92,12 +104,34 @@ const settingStore = defineStore("settingStore", { 2 )}°C, 湿度: ${currentHumidity}%RH` ); + this.shiyanData.push({ + time, + currentTemp, + currentHumidity, + }); this.qw = currentTemp >= 100 ? 100 : currentTemp; - this.cssd = currentHumidity >= 100 ? 100 : Number(currentHumidity.toFixed(2)); + this.cssd = + currentHumidity >= 100 ? 100 : Number(currentHumidity.toFixed(2)); + // 停止加热 & 加湿 if (currentTemp >= 100 && currentHumidity >= 100) { console.log("温度和湿度均达到上限,停止模拟!"); + ElMessage.warning("温度和湿度均达到上限,停止模拟"); + if (this.isRunCode) { + router.push({ + path: "/experimentalData", + }); + } else { + router.push({ + path: "/", + query: { + idea: true, + }, + }); + } + clearInterval(interval); + this.isRunning = false; // 复位标志,允许再次触发 } time += 1; // 每秒增加 1s diff --git a/src/views/compiler/index.vue b/src/views/compiler/index.vue index d88adbf..be18db2 100644 --- a/src/views/compiler/index.vue +++ b/src/views/compiler/index.vue @@ -8,30 +8,26 @@
测量和仪器的图形化编程
-该组件将安装至本地硬盘
+测量和仪器的图形化编程
+该组件将安装至本地硬盘
总进度
-复制新文件
总进度
-复制新文件