From 5e43f3a78f1530e1682bb8642ca703f5b244f2db Mon Sep 17 00:00:00 2001 From: Guarp Date: Fri, 14 Feb 2025 23:14:54 +0800 Subject: [PATCH] 123 --- .gitignore | 25 + blog.md | 0 index.html | 13 + package-lock.json | 1260 +++++++++++++++++ package.json | 25 + public/fonts/Netron.ttf | Bin 0 -> 23392 bytes public/log.md | 25 + public/vite.svg | 1 + services/auth.js | 87 ++ src/App.vue | 47 + src/assets/styles/fonts.css | 6 + src/assets/vue.svg | 1 + src/components/AccountWorkPiece.vue | 128 ++ src/components/Blog_box.vue | 91 ++ src/components/HelloWorld.vue | 43 + src/components/LoadingSpinner.vue | 71 + src/components/NavBar.vue | 310 ++++ src/components/Projects_projectBox.vue | 120 ++ src/components/Tools_box.vue | 115 ++ src/components/mdRenderer.vue | 67 + src/main.js | 10 + src/pages/About.vue | 49 + src/pages/Blog_home.vue | 219 +++ src/pages/Home.vue | 51 + src/pages/Login.vue | 315 +++++ src/pages/Projects_home.vue | 195 +++ src/pages/Tools_home.vue | 160 +++ src/pages/accountPages/Account.vue | 203 +++ .../accountPages/Account_admin_uploadLog.vue | 42 + src/pages/accountPages/Account_draft.vue | 100 ++ src/pages/accountPages/Account_selfpage.vue | 109 ++ src/pages/accountPages/Account_setting.vue | 484 +++++++ src/pages/accountPages/Account_userInfo.vue | 59 + .../accountPages/Account_worksmanage.vue | 103 ++ src/plugins/vuexLocalStorage.js | 25 + src/router/index.js | 78 + src/store/index.js | 53 + src/style.css | 106 ++ src/utils/axios.js | 31 + src/utils/getDomain.js | 3 + src/utils/sweetalert.js | 38 + test.html | 146 ++ vite.config.js | 7 + 43 files changed, 5021 insertions(+) create mode 100644 .gitignore create mode 100644 blog.md create mode 100644 index.html create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 public/fonts/Netron.ttf create mode 100644 public/log.md create mode 100644 public/vite.svg create mode 100644 services/auth.js create mode 100644 src/App.vue create mode 100644 src/assets/styles/fonts.css create mode 100644 src/assets/vue.svg create mode 100644 src/components/AccountWorkPiece.vue create mode 100644 src/components/Blog_box.vue create mode 100644 src/components/HelloWorld.vue create mode 100644 src/components/LoadingSpinner.vue create mode 100644 src/components/NavBar.vue create mode 100644 src/components/Projects_projectBox.vue create mode 100644 src/components/Tools_box.vue create mode 100644 src/components/mdRenderer.vue create mode 100644 src/main.js create mode 100644 src/pages/About.vue create mode 100644 src/pages/Blog_home.vue create mode 100644 src/pages/Home.vue create mode 100644 src/pages/Login.vue create mode 100644 src/pages/Projects_home.vue create mode 100644 src/pages/Tools_home.vue create mode 100644 src/pages/accountPages/Account.vue create mode 100644 src/pages/accountPages/Account_admin_uploadLog.vue create mode 100644 src/pages/accountPages/Account_draft.vue create mode 100644 src/pages/accountPages/Account_selfpage.vue create mode 100644 src/pages/accountPages/Account_setting.vue create mode 100644 src/pages/accountPages/Account_userInfo.vue create mode 100644 src/pages/accountPages/Account_worksmanage.vue create mode 100644 src/plugins/vuexLocalStorage.js create mode 100644 src/router/index.js create mode 100644 src/store/index.js create mode 100644 src/style.css create mode 100644 src/utils/axios.js create mode 100644 src/utils/getDomain.js create mode 100644 src/utils/sweetalert.js create mode 100644 test.html create mode 100644 vite.config.js diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1096c54 --- /dev/null +++ b/.gitignore @@ -0,0 +1,25 @@ +# Logs +logs +*.log +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* +lerna-debug.log* + +node_modules +dist +dist-ssr +*.local + +# Editor directories and files +.vscode/* +!.vscode/extensions.json +.idea +.DS_Store +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? +*.bat diff --git a/blog.md b/blog.md new file mode 100644 index 0000000..e69de29 diff --git a/index.html b/index.html new file mode 100644 index 0000000..f878a95 --- /dev/null +++ b/index.html @@ -0,0 +1,13 @@ + + + + + + + CYBER-2215 + + +
+ + + diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..75e433b --- /dev/null +++ b/package-lock.json @@ -0,0 +1,1260 @@ +{ + "name": "mva-cyberv2", + "version": "0.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "mva-cyberv2", + "version": "0.0.0", + "dependencies": { + "axios": "^1.7.9", + "js-cookie": "^3.0.5", + "marked": "^15.0.7", + "sweetalert2": "^11.16.0", + "vue": "^3.5.13", + "vue-router": "^4.5.0", + "vuex": "^4.0.2" + }, + "devDependencies": { + "@vitejs/plugin-vue": "^5.2.1", + "vite": "^6.1.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.25.9", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz", + "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.25.9", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz", + "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.26.8", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.8.tgz", + "integrity": "sha512-TZIQ25pkSoaKEYYaHbbxkfL36GNsQ6iFiBbeuzAkLnXayKR1yP1zFe+NxuZWWsUyvt8icPU9CCq0sgWGXR1GEw==", + "dependencies": { + "@babel/types": "^7.26.8" + }, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/types": { + "version": "7.26.8", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.8.tgz", + "integrity": "sha512-eUuWapzEGWFEpHFxgEaBG8e3n6S8L3MSu0oda755rOfabWPnh0Our1AozNFVUxGFIhbKgd1ksprsoDGMinTOTA==", + "dependencies": { + "@babel/helper-string-parser": "^7.25.9", + "@babel/helper-validator-identifier": "^7.25.9" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@esbuild/aix-ppc64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.24.2.tgz", + "integrity": "sha512-thpVCb/rhxE/BnMLQ7GReQLLN8q9qbHmI55F4489/ByVg2aQaQ6kbcLb6FHkocZzQhxc4gx0sCk0tJkKBFzDhA==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/android-arm": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.24.2.tgz", + "integrity": "sha512-tmwl4hJkCfNHwFB3nBa8z1Uy3ypZpxqxfTQOcHX+xRByyYgunVbZ9MzUUfb0RxaHIMnbHagwAxuTL+tnNM+1/Q==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.24.2.tgz", + "integrity": "sha512-cNLgeqCqV8WxfcTIOeL4OAtSmL8JjcN6m09XIgro1Wi7cF4t/THaWEa7eL5CMoMBdjoHOTh/vwTO/o2TRXIyzg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.24.2.tgz", + "integrity": "sha512-B6Q0YQDqMx9D7rvIcsXfmJfvUYLoP722bgfBlO5cGvNVb5V/+Y7nhBE3mHV9OpxBf4eAS2S68KZztiPaWq4XYw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.24.2.tgz", + "integrity": "sha512-kj3AnYWc+CekmZnS5IPu9D+HWtUI49hbnyqk0FLEJDbzCIQt7hg7ucF1SQAilhtYpIujfaHr6O0UHlzzSPdOeA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.24.2.tgz", + "integrity": "sha512-WeSrmwwHaPkNR5H3yYfowhZcbriGqooyu3zI/3GGpF8AyUdsrrP0X6KumITGA9WOyiJavnGZUwPGvxvwfWPHIA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.24.2.tgz", + "integrity": "sha512-UN8HXjtJ0k/Mj6a9+5u6+2eZ2ERD7Edt1Q9IZiB5UZAIdPnVKDoG7mdTVGhHJIeEml60JteamR3qhsr1r8gXvg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.24.2.tgz", + "integrity": "sha512-TvW7wE/89PYW+IevEJXZ5sF6gJRDY/14hyIGFXdIucxCsbRmLUcjseQu1SyTko+2idmCw94TgyaEZi9HUSOe3Q==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.24.2.tgz", + "integrity": "sha512-n0WRM/gWIdU29J57hJyUdIsk0WarGd6To0s+Y+LwvlC55wt+GT/OgkwoXCXvIue1i1sSNWblHEig00GBWiJgfA==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.24.2.tgz", + "integrity": "sha512-7HnAD6074BW43YvvUmE/35Id9/NB7BeX5EoNkK9obndmZBUk8xmJJeU7DwmUeN7tkysslb2eSl6CTrYz6oEMQg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.24.2.tgz", + "integrity": "sha512-sfv0tGPQhcZOgTKO3oBE9xpHuUqguHvSo4jl+wjnKwFpapx+vUDcawbwPNuBIAYdRAvIDBfZVvXprIj3HA+Ugw==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.24.2.tgz", + "integrity": "sha512-CN9AZr8kEndGooS35ntToZLTQLHEjtVB5n7dl8ZcTZMonJ7CCfStrYhrzF97eAecqVbVJ7APOEe18RPI4KLhwQ==", + "cpu": [ + "loong64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.24.2.tgz", + "integrity": "sha512-iMkk7qr/wl3exJATwkISxI7kTcmHKE+BlymIAbHO8xanq/TjHaaVThFF6ipWzPHryoFsesNQJPE/3wFJw4+huw==", + "cpu": [ + "mips64el" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.24.2.tgz", + "integrity": "sha512-shsVrgCZ57Vr2L8mm39kO5PPIb+843FStGt7sGGoqiiWYconSxwTiuswC1VJZLCjNiMLAMh34jg4VSEQb+iEbw==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.24.2.tgz", + "integrity": "sha512-4eSFWnU9Hhd68fW16GD0TINewo1L6dRrB+oLNNbYyMUAeOD2yCK5KXGK1GH4qD/kT+bTEXjsyTCiJGHPZ3eM9Q==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.24.2.tgz", + "integrity": "sha512-S0Bh0A53b0YHL2XEXC20bHLuGMOhFDO6GN4b3YjRLK//Ep3ql3erpNcPlEFed93hsQAjAQDNsvcK+hV90FubSw==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.24.2.tgz", + "integrity": "sha512-8Qi4nQcCTbLnK9WoMjdC9NiTG6/E38RNICU6sUNqK0QFxCYgoARqVqxdFmWkdonVsvGqWhmm7MO0jyTqLqwj0Q==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/netbsd-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.24.2.tgz", + "integrity": "sha512-wuLK/VztRRpMt9zyHSazyCVdCXlpHkKm34WUyinD2lzK07FAHTq0KQvZZlXikNWkDGoT6x3TD51jKQ7gMVpopw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.24.2.tgz", + "integrity": "sha512-VefFaQUc4FMmJuAxmIHgUmfNiLXY438XrL4GDNV1Y1H/RW3qow68xTwjZKfj/+Plp9NANmzbH5R40Meudu8mmw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/openbsd-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.24.2.tgz", + "integrity": "sha512-YQbi46SBct6iKnszhSvdluqDmxCJA+Pu280Av9WICNwQmMxV7nLRHZfjQzwbPs3jeWnuAhE9Jy0NrnJ12Oz+0A==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.24.2.tgz", + "integrity": "sha512-+iDS6zpNM6EnJyWv0bMGLWSWeXGN/HTaF/LXHXHwejGsVi+ooqDfMCCTerNFxEkM3wYVcExkeGXNqshc9iMaOA==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.24.2.tgz", + "integrity": "sha512-hTdsW27jcktEvpwNHJU4ZwWFGkz2zRJUz8pvddmXPtXDzVKTTINmlmga3ZzwcuMpUvLw7JkLy9QLKyGpD2Yxig==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.24.2.tgz", + "integrity": "sha512-LihEQ2BBKVFLOC9ZItT9iFprsE9tqjDjnbulhHoFxYQtQfai7qfluVODIYxt1PgdoyQkz23+01rzwNwYfutxUQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.24.2.tgz", + "integrity": "sha512-q+iGUwfs8tncmFC9pcnD5IvRHAzmbwQ3GPS5/ceCyHdjXubwQWI12MKWSNSMYLJMq23/IUCvJMS76PDqXe1fxA==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.24.2.tgz", + "integrity": "sha512-7VTgWzgMGvup6aSqDPLiW5zHaxYJGTO4OokMjIlrCtf+VpEL+cXKtCvg723iguPYI5oaUNdS+/V7OU2gvXVWEg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=18" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==" + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.34.6.tgz", + "integrity": "sha512-+GcCXtOQoWuC7hhX1P00LqjjIiS/iOouHXhMdiDSnq/1DGTox4SpUvO52Xm+div6+106r+TcvOeo/cxvyEyTgg==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.34.6.tgz", + "integrity": "sha512-E8+2qCIjciYUnCa1AiVF1BkRgqIGW9KzJeesQqVfyRITGQN+dFuoivO0hnro1DjT74wXLRZ7QF8MIbz+luGaJA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.34.6.tgz", + "integrity": "sha512-z9Ib+OzqN3DZEjX7PDQMHEhtF+t6Mi2z/ueChQPLS/qUMKY7Ybn5A2ggFoKRNRh1q1T03YTQfBTQCJZiepESAg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.34.6.tgz", + "integrity": "sha512-PShKVY4u0FDAR7jskyFIYVyHEPCPnIQY8s5OcXkdU8mz3Y7eXDJPdyM/ZWjkYdR2m0izD9HHWA8sGcXn+Qrsyg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-freebsd-arm64": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.34.6.tgz", + "integrity": "sha512-YSwyOqlDAdKqs0iKuqvRHLN4SrD2TiswfoLfvYXseKbL47ht1grQpq46MSiQAx6rQEN8o8URtpXARCpqabqxGQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ] + }, + "node_modules/@rollup/rollup-freebsd-x64": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.34.6.tgz", + "integrity": "sha512-HEP4CgPAY1RxXwwL5sPFv6BBM3tVeLnshF03HMhJYCNc6kvSqBgTMmsEjb72RkZBAWIqiPUyF1JpEBv5XT9wKQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.34.6.tgz", + "integrity": "sha512-88fSzjC5xeH9S2Vg3rPgXJULkHcLYMkh8faix8DX4h4TIAL65ekwuQMA/g2CXq8W+NJC43V6fUpYZNjaX3+IIg==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.34.6.tgz", + "integrity": "sha512-wM4ztnutBqYFyvNeR7Av+reWI/enK9tDOTKNF+6Kk2Q96k9bwhDDOlnCUNRPvromlVXo04riSliMBs/Z7RteEg==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.34.6.tgz", + "integrity": "sha512-9RyprECbRa9zEjXLtvvshhw4CMrRa3K+0wcp3KME0zmBe1ILmvcVHnypZ/aIDXpRyfhSYSuN4EPdCCj5Du8FIA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.34.6.tgz", + "integrity": "sha512-qTmklhCTyaJSB05S+iSovfo++EwnIEZxHkzv5dep4qoszUMX5Ca4WM4zAVUMbfdviLgCSQOu5oU8YoGk1s6M9Q==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-loongarch64-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.34.6.tgz", + "integrity": "sha512-4Qmkaps9yqmpjY5pvpkfOerYgKNUGzQpFxV6rnS7c/JfYbDSU0y6WpbbredB5cCpLFGJEqYX40WUmxMkwhWCjw==", + "cpu": [ + "loong64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.34.6.tgz", + "integrity": "sha512-Zsrtux3PuaxuBTX/zHdLaFmcofWGzaWW1scwLU3ZbW/X+hSsFbz9wDIp6XvnT7pzYRl9MezWqEqKy7ssmDEnuQ==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.34.6.tgz", + "integrity": "sha512-aK+Zp+CRM55iPrlyKiU3/zyhgzWBxLVrw2mwiQSYJRobCURb781+XstzvA8Gkjg/hbdQFuDw44aUOxVQFycrAg==", + "cpu": [ + "riscv64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.34.6.tgz", + "integrity": "sha512-WoKLVrY9ogmaYPXwTH326+ErlCIgMmsoRSx6bO+l68YgJnlOXhygDYSZe/qbUJCSiCiZAQ+tKm88NcWuUXqOzw==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.34.6.tgz", + "integrity": "sha512-Sht4aFvmA4ToHd2vFzwMFaQCiYm2lDFho5rPcvPBT5pCdC+GwHG6CMch4GQfmWTQ1SwRKS0dhDYb54khSrjDWw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.34.6.tgz", + "integrity": "sha512-zmmpOQh8vXc2QITsnCiODCDGXFC8LMi64+/oPpPx5qz3pqv0s6x46ps4xoycfUiVZps5PFn1gksZzo4RGTKT+A==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.34.6.tgz", + "integrity": "sha512-3/q1qUsO/tLqGBaD4uXsB6coVGB3usxw3qyeVb59aArCgedSF66MPdgRStUd7vbZOsko/CgVaY5fo2vkvPLWiA==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.34.6.tgz", + "integrity": "sha512-oLHxuyywc6efdKVTxvc0135zPrRdtYVjtVD5GUm55I3ODxhU/PwkQFD97z16Xzxa1Fz0AEe4W/2hzRtd+IfpOA==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.34.6.tgz", + "integrity": "sha512-0PVwmgzZ8+TZ9oGBmdZoQVXflbvuwzN/HRclujpl4N/q3i+y0lqLw8n1bXA8ru3sApDjlmONaNAuYr38y1Kr9w==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@types/estree": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", + "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "dev": true + }, + "node_modules/@vitejs/plugin-vue": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/@vitejs/plugin-vue/-/plugin-vue-5.2.1.tgz", + "integrity": "sha512-cxh314tzaWwOLqVes2gnnCtvBDcM1UMdn+iFR+UjAn411dPT3tOmqrJjbMd7koZpMAmBM/GqeV4n9ge7JSiJJQ==", + "dev": true, + "engines": { + "node": "^18.0.0 || >=20.0.0" + }, + "peerDependencies": { + "vite": "^5.0.0 || ^6.0.0", + "vue": "^3.2.25" + } + }, + "node_modules/@vue/compiler-core": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.5.13.tgz", + "integrity": "sha512-oOdAkwqUfW1WqpwSYJce06wvt6HljgY3fGeM9NcVA1HaYOij3mZG9Rkysn0OHuyUAGMbEbARIpsG+LPVlBJ5/Q==", + "dependencies": { + "@babel/parser": "^7.25.3", + "@vue/shared": "3.5.13", + "entities": "^4.5.0", + "estree-walker": "^2.0.2", + "source-map-js": "^1.2.0" + } + }, + "node_modules/@vue/compiler-dom": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.5.13.tgz", + "integrity": "sha512-ZOJ46sMOKUjO3e94wPdCzQ6P1Lx/vhp2RSvfaab88Ajexs0AHeV0uasYhi99WPaogmBlRHNRuly8xV75cNTMDA==", + "dependencies": { + "@vue/compiler-core": "3.5.13", + "@vue/shared": "3.5.13" + } + }, + "node_modules/@vue/compiler-sfc": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.5.13.tgz", + "integrity": "sha512-6VdaljMpD82w6c2749Zhf5T9u5uLBWKnVue6XWxprDobftnletJ8+oel7sexFfM3qIxNmVE7LSFGTpv6obNyaQ==", + "dependencies": { + "@babel/parser": "^7.25.3", + "@vue/compiler-core": "3.5.13", + "@vue/compiler-dom": "3.5.13", + "@vue/compiler-ssr": "3.5.13", + "@vue/shared": "3.5.13", + "estree-walker": "^2.0.2", + "magic-string": "^0.30.11", + "postcss": "^8.4.48", + "source-map-js": "^1.2.0" + } + }, + "node_modules/@vue/compiler-ssr": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.5.13.tgz", + "integrity": "sha512-wMH6vrYHxQl/IybKJagqbquvxpWCuVYpoUJfCqFZwa/JY1GdATAQ+TgVtgrwwMZ0D07QhA99rs/EAAWfvG6KpA==", + "dependencies": { + "@vue/compiler-dom": "3.5.13", + "@vue/shared": "3.5.13" + } + }, + "node_modules/@vue/devtools-api": { + "version": "6.6.4", + "resolved": "https://registry.npmjs.org/@vue/devtools-api/-/devtools-api-6.6.4.tgz", + "integrity": "sha512-sGhTPMuXqZ1rVOk32RylztWkfXTRhuS7vgAKv0zjqk8gbsHkJ7xfFf+jbySxt7tWObEJwyKaHMikV/WGDiQm8g==" + }, + "node_modules/@vue/reactivity": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/reactivity/-/reactivity-3.5.13.tgz", + "integrity": "sha512-NaCwtw8o48B9I6L1zl2p41OHo/2Z4wqYGGIK1Khu5T7yxrn+ATOixn/Udn2m+6kZKB/J7cuT9DbWWhRxqixACg==", + "dependencies": { + "@vue/shared": "3.5.13" + } + }, + "node_modules/@vue/runtime-core": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/runtime-core/-/runtime-core-3.5.13.tgz", + "integrity": "sha512-Fj4YRQ3Az0WTZw1sFe+QDb0aXCerigEpw418pw1HBUKFtnQHWzwojaukAs2X/c9DQz4MQ4bsXTGlcpGxU/RCIw==", + "dependencies": { + "@vue/reactivity": "3.5.13", + "@vue/shared": "3.5.13" + } + }, + "node_modules/@vue/runtime-dom": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/runtime-dom/-/runtime-dom-3.5.13.tgz", + "integrity": "sha512-dLaj94s93NYLqjLiyFzVs9X6dWhTdAlEAciC3Moq7gzAc13VJUdCnjjRurNM6uTLFATRHexHCTu/Xp3eW6yoog==", + "dependencies": { + "@vue/reactivity": "3.5.13", + "@vue/runtime-core": "3.5.13", + "@vue/shared": "3.5.13", + "csstype": "^3.1.3" + } + }, + "node_modules/@vue/server-renderer": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/server-renderer/-/server-renderer-3.5.13.tgz", + "integrity": "sha512-wAi4IRJV/2SAW3htkTlB+dHeRmpTiVIK1OGLWV1yeStVSebSQQOwGwIq0D3ZIoBj2C2qpgz5+vX9iEBkTdk5YA==", + "dependencies": { + "@vue/compiler-ssr": "3.5.13", + "@vue/shared": "3.5.13" + }, + "peerDependencies": { + "vue": "3.5.13" + } + }, + "node_modules/@vue/shared": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.5.13.tgz", + "integrity": "sha512-/hnE/qP5ZoGpol0a5mDi45bOd7t3tjYJBjsgCsivow7D48cJeV5l05RD82lPqi7gRiphZM37rnhW1l6ZoCNNnQ==" + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + }, + "node_modules/axios": { + "version": "1.7.9", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.9.tgz", + "integrity": "sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw==", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==" + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/entities": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", + "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", + "engines": { + "node": ">=0.12" + }, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/esbuild": { + "version": "0.24.2", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.24.2.tgz", + "integrity": "sha512-+9egpBW8I3CD5XPe0n6BfT5fxLzxrlDzqydF3aviG+9ni1lDC/OvMHcxqEFV0+LANZG5R1bFMWfUrjVsdwxJvA==", + "dev": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=18" + }, + "optionalDependencies": { + "@esbuild/aix-ppc64": "0.24.2", + "@esbuild/android-arm": "0.24.2", + "@esbuild/android-arm64": "0.24.2", + "@esbuild/android-x64": "0.24.2", + "@esbuild/darwin-arm64": "0.24.2", + "@esbuild/darwin-x64": "0.24.2", + "@esbuild/freebsd-arm64": "0.24.2", + "@esbuild/freebsd-x64": "0.24.2", + "@esbuild/linux-arm": "0.24.2", + "@esbuild/linux-arm64": "0.24.2", + "@esbuild/linux-ia32": "0.24.2", + "@esbuild/linux-loong64": "0.24.2", + "@esbuild/linux-mips64el": "0.24.2", + "@esbuild/linux-ppc64": "0.24.2", + "@esbuild/linux-riscv64": "0.24.2", + "@esbuild/linux-s390x": "0.24.2", + "@esbuild/linux-x64": "0.24.2", + "@esbuild/netbsd-arm64": "0.24.2", + "@esbuild/netbsd-x64": "0.24.2", + "@esbuild/openbsd-arm64": "0.24.2", + "@esbuild/openbsd-x64": "0.24.2", + "@esbuild/sunos-x64": "0.24.2", + "@esbuild/win32-arm64": "0.24.2", + "@esbuild/win32-ia32": "0.24.2", + "@esbuild/win32-x64": "0.24.2" + } + }, + "node_modules/estree-walker": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", + "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==" + }, + "node_modules/follow-redirects": { + "version": "1.15.9", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", + "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz", + "integrity": "sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/js-cookie": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/js-cookie/-/js-cookie-3.0.5.tgz", + "integrity": "sha512-cEiJEAEoIbWfCZYKWhVwFuvPX1gETRYPw6LlaTKoxD3s2AkXzkCjnp6h0V77ozyqj0jakteJ4YqDJT830+lVGw==", + "engines": { + "node": ">=14" + } + }, + "node_modules/magic-string": { + "version": "0.30.17", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.17.tgz", + "integrity": "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.5.0" + } + }, + "node_modules/marked": { + "version": "15.0.7", + "resolved": "https://registry.npmjs.org/marked/-/marked-15.0.7.tgz", + "integrity": "sha512-dgLIeKGLx5FwziAnsk4ONoGwHwGPJzselimvlVskE9XLN4Orv9u2VA3GWw/lYUqjfA0rUT/6fqKwfZJapP9BEg==", + "bin": { + "marked": "bin/marked.js" + }, + "engines": { + "node": ">= 18" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/nanoid": { + "version": "3.3.8", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.8.tgz", + "integrity": "sha512-WNLf5Sd8oZxOm+TzppcYk8gVOgP+l58xNy58D0nbUnOxOWRWvlcCV4kUF7ltmI6PsrLl/BgKEyS4mqsGChFN0w==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/picocolors": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", + "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==" + }, + "node_modules/postcss": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.1.tgz", + "integrity": "sha512-6oz2beyjc5VMn/KV1pPw8fliQkhBXrVn1Z3TVyqZxU8kZpzEKhBdmCFqI6ZbmGtamQvQGuU1sgPTk8ZrXDD7jQ==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.8", + "picocolors": "^1.1.1", + "source-map-js": "^1.2.1" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + }, + "node_modules/rollup": { + "version": "4.34.6", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.34.6.tgz", + "integrity": "sha512-wc2cBWqJgkU3Iz5oztRkQbfVkbxoz5EhnCGOrnJvnLnQ7O0WhQUYyv18qQI79O8L7DdHrrlJNeCHd4VGpnaXKQ==", + "dev": true, + "dependencies": { + "@types/estree": "1.0.6" + }, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=18.0.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.34.6", + "@rollup/rollup-android-arm64": "4.34.6", + "@rollup/rollup-darwin-arm64": "4.34.6", + "@rollup/rollup-darwin-x64": "4.34.6", + "@rollup/rollup-freebsd-arm64": "4.34.6", + "@rollup/rollup-freebsd-x64": "4.34.6", + "@rollup/rollup-linux-arm-gnueabihf": "4.34.6", + "@rollup/rollup-linux-arm-musleabihf": "4.34.6", + "@rollup/rollup-linux-arm64-gnu": "4.34.6", + "@rollup/rollup-linux-arm64-musl": "4.34.6", + "@rollup/rollup-linux-loongarch64-gnu": "4.34.6", + "@rollup/rollup-linux-powerpc64le-gnu": "4.34.6", + "@rollup/rollup-linux-riscv64-gnu": "4.34.6", + "@rollup/rollup-linux-s390x-gnu": "4.34.6", + "@rollup/rollup-linux-x64-gnu": "4.34.6", + "@rollup/rollup-linux-x64-musl": "4.34.6", + "@rollup/rollup-win32-arm64-msvc": "4.34.6", + "@rollup/rollup-win32-ia32-msvc": "4.34.6", + "@rollup/rollup-win32-x64-msvc": "4.34.6", + "fsevents": "~2.3.2" + } + }, + "node_modules/source-map-js": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sweetalert2": { + "version": "11.16.0", + "resolved": "https://registry.npmjs.org/sweetalert2/-/sweetalert2-11.16.0.tgz", + "integrity": "sha512-4CGgNMpQHcwV+Gov0j4u3lDc/5lyl04NBsa1vW0Se9cqsrQoUimD6/Z5UyZiRP4kMbwQGyb7wsp0x3ytybti6w==", + "funding": { + "type": "individual", + "url": "https://github.com/sponsors/limonte" + } + }, + "node_modules/vite": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/vite/-/vite-6.1.0.tgz", + "integrity": "sha512-RjjMipCKVoR4hVfPY6GQTgveinjNuyLw+qruksLDvA5ktI1150VmcMBKmQaEWJhg/j6Uaf6dNCNA0AfdzUb/hQ==", + "dev": true, + "dependencies": { + "esbuild": "^0.24.2", + "postcss": "^8.5.1", + "rollup": "^4.30.1" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^18.0.0 || ^20.0.0 || >=22.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.3" + }, + "peerDependencies": { + "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0", + "jiti": ">=1.21.0", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "sass-embedded": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.16.0", + "tsx": "^4.8.1", + "yaml": "^2.4.2" + }, + "peerDependenciesMeta": { + "@types/node": { + "optional": true + }, + "jiti": { + "optional": true + }, + "less": { + "optional": true + }, + "lightningcss": { + "optional": true + }, + "sass": { + "optional": true + }, + "sass-embedded": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "terser": { + "optional": true + }, + "tsx": { + "optional": true + }, + "yaml": { + "optional": true + } + } + }, + "node_modules/vue": { + "version": "3.5.13", + "resolved": "https://registry.npmjs.org/vue/-/vue-3.5.13.tgz", + "integrity": "sha512-wmeiSMxkZCSc+PM2w2VRsOYAZC8GdipNFRTsLSfodVqI9mbejKeXEGr8SckuLnrQPGe3oJN5c3K0vpoU9q/wCQ==", + "dependencies": { + "@vue/compiler-dom": "3.5.13", + "@vue/compiler-sfc": "3.5.13", + "@vue/runtime-dom": "3.5.13", + "@vue/server-renderer": "3.5.13", + "@vue/shared": "3.5.13" + }, + "peerDependencies": { + "typescript": "*" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/vue-router": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.5.0.tgz", + "integrity": "sha512-HDuk+PuH5monfNuY+ct49mNmkCRK4xJAV9Ts4z9UFc4rzdDnxQLyCMGGc8pKhZhHTVzfanpNwB/lwqevcBwI4w==", + "dependencies": { + "@vue/devtools-api": "^6.6.4" + }, + "funding": { + "url": "https://github.com/sponsors/posva" + }, + "peerDependencies": { + "vue": "^3.2.0" + } + }, + "node_modules/vuex": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/vuex/-/vuex-4.0.2.tgz", + "integrity": "sha512-M6r8uxELjZIK8kTKDGgZTYX/ahzblnzC4isU1tpmEuOIIKmV+TRdc+H4s8ds2NuZ7wpUTdGRzJRtoj+lI+pc0Q==", + "dependencies": { + "@vue/devtools-api": "^6.0.0-beta.11" + }, + "peerDependencies": { + "vue": "^3.0.2" + } + }, + "node_modules/yaml": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.7.0.tgz", + "integrity": "sha512-+hSoy/QHluxmC9kCIJyL/uyFmLmc+e5CFR5Wa+bpIhIj85LVb9ZH2nVnqrHoSvKogwODv0ClqZkmiSSaIH5LTA==", + "dev": true, + "optional": true, + "peer": true, + "bin": { + "yaml": "bin.mjs" + }, + "engines": { + "node": ">= 14" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..418729e --- /dev/null +++ b/package.json @@ -0,0 +1,25 @@ +{ + "name": "mva-cyberv2", + "private": true, + "version": "0.0.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "vite build", + "preview": "vite preview", + "prepare": "husky install" + }, + "dependencies": { + "axios": "^1.7.9", + "js-cookie": "^3.0.5", + "marked": "^15.0.7", + "sweetalert2": "^11.16.0", + "vue": "^3.5.13", + "vue-router": "^4.5.0", + "vuex": "^4.0.2" + }, + "devDependencies": { + "@vitejs/plugin-vue": "^5.2.1", + "vite": "^6.1.0" + } +} diff --git a/public/fonts/Netron.ttf b/public/fonts/Netron.ttf new file mode 100644 index 0000000000000000000000000000000000000000..3d3362b83da49d5602627cf63347c3dc14143792 GIT binary patch literal 23392 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 literal 0 HcmV?d00001 diff --git a/public/log.md b/public/log.md new file mode 100644 index 0000000..6ea9d2e --- /dev/null +++ b/public/log.md @@ -0,0 +1,25 @@ + +## 网站更新日志 + +--- +### 2025/2/13 16:30 - [v0.0.2] 测试效果 +- 优化布局 +- 优化双端切换逻辑 +- 新增项目展示页面 - 测试(未完成) +- 新增在线工具罗列页面 - 测试(未完成) +- 新增管理员上传日志 - 测试(未完成) + +### 2025/2/12 22:30 - [v0.0.1] 测试功能 + - 制作导航栏手机电脑双端模式 + - 新增黑白双色模式 + - 新增账户管理页面 + - 账号设置 - 基本完成 + - 头像系统 + - 基本信息显示 + - 双色模式切换 + - 个人主页设置 - 测试(未完成) + - 稿件管理 - 测试(未完成) + - 草稿箱 - 测试(未完成) + - 博客界面 + - 关键词标签 + - 关键词搜索 \ No newline at end of file diff --git a/public/vite.svg b/public/vite.svg new file mode 100644 index 0000000..e7b8dfb --- /dev/null +++ b/public/vite.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/services/auth.js b/services/auth.js new file mode 100644 index 0000000..718ba29 --- /dev/null +++ b/services/auth.js @@ -0,0 +1,87 @@ +import axios from 'axios'; +import api from "../src/utils/axios.js"; +import store from "../src/store/index.js"; +import Cookies from 'js-cookie'; + +export default class AuthService { + static async login(username, password) { + let result = {} + let isEmail = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(username); + try { + const data = { + LOGIN_METHOD: isEmail ? "email" : "username", + LOGIN_NAME: username, + PASSWORD: password + }; + await api.post('/login', data).then(res => { + result = res; + }); + Cookies.set('Token', result.token, {path: '/', expires: 1}) + } catch (e) { + result.code = 3; + } + return result; + } + static async sendMessage(username, email, password){ + let result = {} + const data = { + USER_NAME: username, + EMAIL: email, + PASSWORD: password + }; + await api.post('/postmessage', data).then(res=>{ + result = res; + }) + return result; + } + static logout() { + Cookies.remove('Token'); + store.commit('setToken', null) + store.commit('setUserInfo', null) + } + + static getToken() { + return Cookies.get('Token'); + } + + static async setSelfInfo() { + let info = {}; + if (!store.state.token) { + store.commit('setToken', await this.getToken()); + } + try { + await api.post('/selfinfo', { + TOKEN: store.state.token + }).then((res) => { + info = res; + }) + if (info.code !== 0) { + throw new Error('error') + } + if (store.state.token) { + store.commit('setUserInfo', info.info) + } + + } catch (e) { + console.error(e) + // this.logout(); + } + + } + + static isTokenExpired() { + const token = this.getToken(); + if (!token) return true; + + // const payload = JSON.parse(atob(token.split('.')[1])); // 解码JWT的payload部分 + // const exp = payload.exp * 1000; // 转换为毫秒 + // return Date.now() >= exp; + } + + // static async refreshToken() { + // const refreshToken = localStorage.getItem('refreshToken'); + // const response = await axios.post('/api/refresh-token', {refreshToken}); + // localStorage.setItem('token', response.data.token); + // return response.data.token; + // } +} diff --git a/src/App.vue b/src/App.vue new file mode 100644 index 0000000..9c17fec --- /dev/null +++ b/src/App.vue @@ -0,0 +1,47 @@ + + + diff --git a/src/assets/styles/fonts.css b/src/assets/styles/fonts.css new file mode 100644 index 0000000..2a7166e --- /dev/null +++ b/src/assets/styles/fonts.css @@ -0,0 +1,6 @@ +@font-face { + font-family: 'Netron'; + src: url('/fonts/Netron.ttf') format('truetype'); + font-weight: normal; + font-style: normal; +} diff --git a/src/assets/vue.svg b/src/assets/vue.svg new file mode 100644 index 0000000..770e9d3 --- /dev/null +++ b/src/assets/vue.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/components/AccountWorkPiece.vue b/src/components/AccountWorkPiece.vue new file mode 100644 index 0000000..39f5a7a --- /dev/null +++ b/src/components/AccountWorkPiece.vue @@ -0,0 +1,128 @@ + + + + + diff --git a/src/components/Blog_box.vue b/src/components/Blog_box.vue new file mode 100644 index 0000000..1253e66 --- /dev/null +++ b/src/components/Blog_box.vue @@ -0,0 +1,91 @@ + + + + + diff --git a/src/components/HelloWorld.vue b/src/components/HelloWorld.vue new file mode 100644 index 0000000..546ebbc --- /dev/null +++ b/src/components/HelloWorld.vue @@ -0,0 +1,43 @@ + + + + + diff --git a/src/components/LoadingSpinner.vue b/src/components/LoadingSpinner.vue new file mode 100644 index 0000000..9fb1004 --- /dev/null +++ b/src/components/LoadingSpinner.vue @@ -0,0 +1,71 @@ + + + + + diff --git a/src/components/NavBar.vue b/src/components/NavBar.vue new file mode 100644 index 0000000..f242eeb --- /dev/null +++ b/src/components/NavBar.vue @@ -0,0 +1,310 @@ + + + + + diff --git a/src/components/Projects_projectBox.vue b/src/components/Projects_projectBox.vue new file mode 100644 index 0000000..ffc3e54 --- /dev/null +++ b/src/components/Projects_projectBox.vue @@ -0,0 +1,120 @@ + + + + + diff --git a/src/components/Tools_box.vue b/src/components/Tools_box.vue new file mode 100644 index 0000000..a7591f0 --- /dev/null +++ b/src/components/Tools_box.vue @@ -0,0 +1,115 @@ + + + + + diff --git a/src/components/mdRenderer.vue b/src/components/mdRenderer.vue new file mode 100644 index 0000000..2abc17a --- /dev/null +++ b/src/components/mdRenderer.vue @@ -0,0 +1,67 @@ + + + + + diff --git a/src/main.js b/src/main.js new file mode 100644 index 0000000..36440be --- /dev/null +++ b/src/main.js @@ -0,0 +1,10 @@ +import { createApp } from 'vue' +import App from './App.vue' +import store from './store' +import router from './router' +import './style.css' + +const app = createApp(App); +app.use(router); +app.use(store); +app.mount('#app') diff --git a/src/pages/About.vue b/src/pages/About.vue new file mode 100644 index 0000000..de612fc --- /dev/null +++ b/src/pages/About.vue @@ -0,0 +1,49 @@ + + + + + \ No newline at end of file diff --git a/src/pages/Blog_home.vue b/src/pages/Blog_home.vue new file mode 100644 index 0000000..9919165 --- /dev/null +++ b/src/pages/Blog_home.vue @@ -0,0 +1,219 @@ + + + + + diff --git a/src/pages/Home.vue b/src/pages/Home.vue new file mode 100644 index 0000000..e875035 --- /dev/null +++ b/src/pages/Home.vue @@ -0,0 +1,51 @@ + + + + + \ No newline at end of file diff --git a/src/pages/Login.vue b/src/pages/Login.vue new file mode 100644 index 0000000..6a11396 --- /dev/null +++ b/src/pages/Login.vue @@ -0,0 +1,315 @@ + + + + + diff --git a/src/pages/Projects_home.vue b/src/pages/Projects_home.vue new file mode 100644 index 0000000..7de781c --- /dev/null +++ b/src/pages/Projects_home.vue @@ -0,0 +1,195 @@ + + + + + diff --git a/src/pages/Tools_home.vue b/src/pages/Tools_home.vue new file mode 100644 index 0000000..7082dda --- /dev/null +++ b/src/pages/Tools_home.vue @@ -0,0 +1,160 @@ + + + + + diff --git a/src/pages/accountPages/Account.vue b/src/pages/accountPages/Account.vue new file mode 100644 index 0000000..a532df7 --- /dev/null +++ b/src/pages/accountPages/Account.vue @@ -0,0 +1,203 @@ + + + + + diff --git a/src/pages/accountPages/Account_admin_uploadLog.vue b/src/pages/accountPages/Account_admin_uploadLog.vue new file mode 100644 index 0000000..9762e16 --- /dev/null +++ b/src/pages/accountPages/Account_admin_uploadLog.vue @@ -0,0 +1,42 @@ + + + + + \ No newline at end of file diff --git a/src/pages/accountPages/Account_draft.vue b/src/pages/accountPages/Account_draft.vue new file mode 100644 index 0000000..7f05fe8 --- /dev/null +++ b/src/pages/accountPages/Account_draft.vue @@ -0,0 +1,100 @@ + + + + + diff --git a/src/pages/accountPages/Account_selfpage.vue b/src/pages/accountPages/Account_selfpage.vue new file mode 100644 index 0000000..25c286c --- /dev/null +++ b/src/pages/accountPages/Account_selfpage.vue @@ -0,0 +1,109 @@ + + + + + diff --git a/src/pages/accountPages/Account_setting.vue b/src/pages/accountPages/Account_setting.vue new file mode 100644 index 0000000..c1fa926 --- /dev/null +++ b/src/pages/accountPages/Account_setting.vue @@ -0,0 +1,484 @@ + + + + + diff --git a/src/pages/accountPages/Account_userInfo.vue b/src/pages/accountPages/Account_userInfo.vue new file mode 100644 index 0000000..51c8255 --- /dev/null +++ b/src/pages/accountPages/Account_userInfo.vue @@ -0,0 +1,59 @@ + + + + + diff --git a/src/pages/accountPages/Account_worksmanage.vue b/src/pages/accountPages/Account_worksmanage.vue new file mode 100644 index 0000000..9a46070 --- /dev/null +++ b/src/pages/accountPages/Account_worksmanage.vue @@ -0,0 +1,103 @@ + + + + + diff --git a/src/plugins/vuexLocalStorage.js b/src/plugins/vuexLocalStorage.js new file mode 100644 index 0000000..2b61e47 --- /dev/null +++ b/src/plugins/vuexLocalStorage.js @@ -0,0 +1,25 @@ +export default function createPersistedStatePlugin(options = {}) { + const storageKey = options.key || 'vuex-partial-state' + const whitelist = options.whitelist || [] // 需要存储的 state key 列表 + + return store => { + // 1. 在 store 初始化时恢复数据 + const savedState = JSON.parse(localStorage.getItem(storageKey) || '{}') + Object.keys(savedState).forEach(key => { + if (whitelist.includes(key)) { + store.state[key] = savedState[key] + } + }) + + // 2. 监听 mutation,每次变更后存入 localStorage + store.subscribe((mutation, state) => { + const partialState = {} + whitelist.forEach(key => { + if (state[key] !== undefined) { + partialState[key] = state[key] + } + }) + localStorage.setItem(storageKey, JSON.stringify(partialState)) + }) + } +} diff --git a/src/router/index.js b/src/router/index.js new file mode 100644 index 0000000..eaac92e --- /dev/null +++ b/src/router/index.js @@ -0,0 +1,78 @@ +import {createRouter, createWebHistory} from 'vue-router'; +import store from '../store'; +import AuthService from "../../services/auth.js"; +import Home from '../pages/Home.vue'; +import Login from "../pages/Login.vue"; +import Blog_home from "../pages/Blog_home.vue"; +import Account from "../pages/accountPages/Account.vue"; +import Account_selfpage from "../pages/accountPages/Account_selfpage.vue"; +import Account_worksmanage from "../pages/accountPages/Account_worksmanage.vue"; +import Account_setting from "../pages/accountPages/Account_setting.vue"; +import Account_draft from "../pages/accountPages/Account_draft.vue"; +import Account_userInfo from "../pages/accountPages/Account_userInfo.vue"; +import Account_admin_uploadLog from "../pages/accountPages/Account_admin_uploadLog.vue"; +import Projects from "../pages/Projects_home.vue"; +import Tools_home from "../pages/Tools_home.vue"; +import About from "../pages/About.vue"; + +const routes = [ + { + path: '/', + name: 'Home', + component: Home, + }, { + path: '/login', + name: 'Login', + component: Login + }, { + path: '/blog', + name: 'Blog', + component: Blog_home + }, { + path: '/projects', + name: 'Projects', + component: Projects + }, { + path: '/tools', + name: 'Tools', + component: Tools_home + }, { + path: '/about', + name: 'About', + component: About + }, { + path: '/account', + component: Account, + children: [ + {path: 'self-page', component: Account_selfpage}, + {path: 'works-manage', component: Account_worksmanage}, + {path: 'draft', component: Account_draft}, + {path: 'setting', component: Account_setting}, + {path: '', component: Account_userInfo}, + {path: 'upload-log', component: Account_admin_uploadLog} + ] + } +]; + +const router = createRouter({ + history: createWebHistory(), // 使用HTML5历史模式 + routes +}); + +router.beforeEach((to, from, next) => { + if (!store.state.userInfo.uid && store.state.token) { + AuthService.setSelfInfo(); + } + if (to.path === '/login' && store.state.userInfo.uid) { + next('/account'); + } + if (to.path === '/account' && !store.state.userInfo.uid) { + next('/login'); + } + if (to.path === '/account/upload-log' && store.state.userInfo.role_id < 1) { + next('/account') + } + next(); +}); + +export default router; \ No newline at end of file diff --git a/src/store/index.js b/src/store/index.js new file mode 100644 index 0000000..42fac0e --- /dev/null +++ b/src/store/index.js @@ -0,0 +1,53 @@ +import { createStore } from 'vuex'; +import createPersistedStatePlugin from '../plugins/vuexLocalStorage'; +import api from "../utils/axios.js"; +import {getDomain} from "../utils/getDomain.js"; + +const store = createStore({ + state: { + theme: localStorage.getItem('theme') || 'dark', + loading: {}, + token: null, + userInfo: {} + }, + mutations: { + toggleTheme(state) { + state.theme = state.theme === 'dark' ? 'light' : 'dark' + }, + setToken(state, token) { + state.token = token; + }, + setUserInfo(state, obj) { + if (obj === {} || !obj) { + state.userInfo = {}; + } + state.userInfo = {...state.userInfo, ...obj}; + }, + startLoading(state, text) { + state.loading.isLoading = {isLoading: true, text: '请稍后...'}; + if (text) { + state.loading.text = text; + } + }, + stopLoading(state) { + state.loading.isLoading = false; + } + }, + getters: { + currentTheme: state => state.theme, + hasUserInfo: state => !!state.userInfo.uid, + profileImage: state => { + if (state.userInfo.profile) { + return `https://${getDomain()}/data/user/profile/` + state.userInfo.profile; + }else { + return `https://${getDomain()}/data/user/profile/default.jpg` + } + } + }, + plugins: [createPersistedStatePlugin({ + key: 'cyberStorage', + whitelist: ['theme', 'userInfo'], + })] +}) + +export default store; diff --git a/src/style.css b/src/style.css new file mode 100644 index 0000000..5532536 --- /dev/null +++ b/src/style.css @@ -0,0 +1,106 @@ +/* 全局样式:默认夜间模式 */ +body { + margin: 0; + padding: 0; + background-color: rgb(20, 20, 20); /* 夜间背景 */ + color: #0ff; /* 夜间文字颜色 */ + font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; + overflow: hidden; +} +/* 白天模式 */ +body.theme-light { + background-color: #fff; + color: #333; +} + +/* 全局链接样式 */ +a { + text-decoration: none; + transition: color 0.3s; +} +body:not(.theme-light) a { + color: #0ff; +} +body.theme-light a { + color: #232323; +} +a:hover { + color: #fff; +} + +/* 通用容器 */ +.container { + width: 90%; + max-width: 1200px; + margin: 0 auto; +} + +/* 按钮基础样式 */ +button { + font-family: inherit; + background: none; + border: none; + cursor: pointer; +} + +.loader { + border: 8px solid #f3f3f3; /* 背景色 */ + border-top: 8px solid #3498db; /* 动画颜色 */ + border-radius: 50%; + width: 50px; + height: 50px; + animation: spin 2s linear infinite; +} + +/* 动画效果 */ +@keyframes spin { + 0% { + transform: rotate(0deg); + } + 100% { + transform: rotate(360deg); + } +} + +/*::-webkit-scrollbar {*/ +/* display: none;*/ +/*}*/ + + /*滚动条 */ + +/* 深色模式:默认 */ +::-webkit-scrollbar { + width: 8px; +} + +::-webkit-scrollbar-thumb { + background-color: #444; + border-radius: 10px; +} + +::-webkit-scrollbar-track { + background-color: #222; + border-radius: 10px; +} + +::-webkit-scrollbar-corner { + background-color: transparent; +} + +/* 亮色模式 */ +.theme-light ::-webkit-scrollbar-thumb { + background-color: #ccc; +} + +.theme-light ::-webkit-scrollbar-track { + background-color: #e0e0e0; +} + +/* 选中的滚动条滑块效果 */ +::-webkit-scrollbar-thumb:hover { + background-color: #888; +} + +.theme-light ::-webkit-scrollbar-thumb:hover { + background-color: #aaa; +} diff --git a/src/utils/axios.js b/src/utils/axios.js new file mode 100644 index 0000000..1e19f63 --- /dev/null +++ b/src/utils/axios.js @@ -0,0 +1,31 @@ +import axios from 'axios'; +import store from '../store'; +import {getDomain} from "./getDomain.js"; + +const api = axios.create({ + baseURL: `https://${getDomain()}:5001`, + timeout: 6000, +}); + +// 请求拦截器:自动加Token +api.interceptors.request.use( + (config) => { + const token = store.state.token; + if (token) { + config.headers['Authorization'] = `Bearer ${token}`; + } + return config; + }, + (error) => Promise.reject(error) +); + +// 响应拦截器:处理错误 & 统一返回数据格式 +api.interceptors.response.use( + (response) => response.data, + (error) => { + console.error('请求出错:', error); + return Promise.reject(error); + } +); + +export default api; diff --git a/src/utils/getDomain.js b/src/utils/getDomain.js new file mode 100644 index 0000000..9396446 --- /dev/null +++ b/src/utils/getDomain.js @@ -0,0 +1,3 @@ +export function getDomain() { + return window.location.hostname === 'localhost' ? 'mva-cyber.club' : window.location.hostname; +} diff --git a/src/utils/sweetalert.js b/src/utils/sweetalert.js new file mode 100644 index 0000000..2e6826c --- /dev/null +++ b/src/utils/sweetalert.js @@ -0,0 +1,38 @@ +import Swal from 'sweetalert2'; + + +const swalInstantiations = { + tip: Swal.mixin({ + toast: true, // 弹窗类型为 Toast + position: 'top', // 弹窗显示位置 + + showConfirmButton: false, // 不显示确认按钮 + timer: 3000, // 弹窗显示3秒后自动关闭 + didOpen: (toast) => { + toast.addEventListener('mouseenter', Swal.stopTimer); + toast.addEventListener('mouseleave', Swal.resumeTimer); + } + }), + window: Swal.mixin({ + title: '确认?', + text: '您确定吗?', + icon: 'warning', + showCancelButton: true, + confirmButtonText: '删除', + cancelButtonText: '取消', + didOpen: (toast) => { + toast.addEventListener('mouseenter', Swal.stopTimer); + toast.addEventListener('mouseleave', Swal.resumeTimer); + } + }) +}; +const swal = { + tip: (icon, title, text, position) => { + swalInstantiations.tip.fire({icon: icon, title: title, text: text}) + }, + window: (icon, title, text, confirm, cancel) => { + return swalInstantiations.window.fire({icon: icon, title: title, text: text, confirmButtonText: confirm, cancelButtonText: cancel}) + } +} + +export default swal \ No newline at end of file diff --git a/test.html b/test.html new file mode 100644 index 0000000..c734f64 --- /dev/null +++ b/test.html @@ -0,0 +1,146 @@ + + + + + + GSAP 多元素滚动触发 + 视差效果 + + + + + + +
+ +
⬇️ 向下滚动看看动画效果 ⬇️
+ +
+
1
+
2
+
3
+
+ +
🎉 滚动结束 🎉
+ + + + + diff --git a/vite.config.js b/vite.config.js new file mode 100644 index 0000000..bbcf80c --- /dev/null +++ b/vite.config.js @@ -0,0 +1,7 @@ +import { defineConfig } from 'vite' +import vue from '@vitejs/plugin-vue' + +// https://vite.dev/config/ +export default defineConfig({ + plugins: [vue()], +})