build: 项目构建
						commit
						0abd3d6e86
					
				| @ -0,0 +1,4 @@ | |||||||
|  | # 变量必须以 VITE_ 为前缀才能暴露给外部读取 | ||||||
|  | NODE_ENV = 'development' | ||||||
|  | VITE_APP_TITLE = 'XXXX' | ||||||
|  | VITE_APP_BASE_API = '/dev-api' | ||||||
| @ -0,0 +1,3 @@ | |||||||
|  | NODE_ENV = 'production' | ||||||
|  | VITE_APP_TITLE = 'XXXXX' | ||||||
|  | VITE_APP_BASE_API = '/prod-api' | ||||||
| @ -0,0 +1,4 @@ | |||||||
|  | # 变量必须以 VITE_ 为前缀才能暴露给外部读取 | ||||||
|  | NODE_ENV = 'test' | ||||||
|  | VITE_APP_TITLE = 'XXXXX' | ||||||
|  | VITE_APP_BASE_API = '/test-api' | ||||||
| @ -0,0 +1,2 @@ | |||||||
|  | dist | ||||||
|  | node_modules | ||||||
| @ -0,0 +1,24 @@ | |||||||
|  | # 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? | ||||||
| @ -0,0 +1,4 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | . "$(dirname -- "$0")/_/husky.sh" | ||||||
|  | 
 | ||||||
|  | pnpm commitlint | ||||||
| @ -0,0 +1,4 @@ | |||||||
|  | #!/usr/bin/env sh | ||||||
|  | . "$(dirname -- "$0")/_/husky.sh" | ||||||
|  | 
 | ||||||
|  | pnpm run format | ||||||
| @ -0,0 +1,7 @@ | |||||||
|  | /dist/* | ||||||
|  | /html/* | ||||||
|  | .local | ||||||
|  | /node_modules/** | ||||||
|  | **/*.svg | ||||||
|  | **/*.sh | ||||||
|  | /public/* | ||||||
| @ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "singleQuote": true, | ||||||
|  |   "semi": false, | ||||||
|  |   "bracketSpacing": true, | ||||||
|  |   "htmlWhitespaceSensitivity": "ignore", | ||||||
|  |   "endOfLine": "auto", | ||||||
|  |   "trailingComma": "all", | ||||||
|  |   "tabWidth": 2 | ||||||
|  | } | ||||||
| @ -0,0 +1,4 @@ | |||||||
|  | /node_modules/* | ||||||
|  | /dist/* | ||||||
|  | /html/* | ||||||
|  | /public/* | ||||||
| @ -0,0 +1,3 @@ | |||||||
|  | { | ||||||
|  |   "recommendations": ["Vue.volar", "Vue.vscode-typescript-vue-plugin"] | ||||||
|  | } | ||||||
| @ -0,0 +1,18 @@ | |||||||
|  | # Vue 3 + TypeScript + Vite | ||||||
|  | 
 | ||||||
|  | This template should help get you started developing with Vue 3 and TypeScript in Vite. The template uses Vue 3 `<script setup>` SFCs, check out the [script setup docs](https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup) to learn more. | ||||||
|  | 
 | ||||||
|  | ## Recommended IDE Setup | ||||||
|  | 
 | ||||||
|  | - [VS Code](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (and disable Vetur) + [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin). | ||||||
|  | 
 | ||||||
|  | ## Type Support For `.vue` Imports in TS | ||||||
|  | 
 | ||||||
|  | TypeScript cannot handle type information for `.vue` imports by default, so we replace the `tsc` CLI with `vue-tsc` for type checking. In editors, we need [TypeScript Vue Plugin (Volar)](https://marketplace.visualstudio.com/items?itemName=Vue.vscode-typescript-vue-plugin) to make the TypeScript language service aware of `.vue` types. | ||||||
|  | 
 | ||||||
|  | If the standalone TypeScript plugin doesn't feel fast enough to you, Volar has also implemented a [Take Over Mode](https://github.com/johnsoncodehk/volar/discussions/471#discussioncomment-1361669) that is more performant. You can enable it by the following steps: | ||||||
|  | 
 | ||||||
|  | 1. Disable the built-in TypeScript Extension | ||||||
|  |    1. Run `Extensions: Show Built-in Extensions` from VSCode's command palette | ||||||
|  |    2. Find `TypeScript and JavaScript Language Features`, right click and select `Disable (Workspace)` | ||||||
|  | 2. Reload the VSCode window by running `Developer: Reload Window` from the command palette. | ||||||
| @ -0,0 +1,29 @@ | |||||||
|  | module.exports = { | ||||||
|  |   extends: ['@commitlint/config-conventional'], | ||||||
|  |   // 校验规则
 | ||||||
|  |   rules: { | ||||||
|  |     'type-enum': [ | ||||||
|  |       2, | ||||||
|  |       'always', | ||||||
|  |       [ | ||||||
|  |         'feat', | ||||||
|  |         'fix', | ||||||
|  |         'docs', | ||||||
|  |         'style', | ||||||
|  |         'refactor', | ||||||
|  |         'perf', | ||||||
|  |         'test', | ||||||
|  |         'chore', | ||||||
|  |         'revert', | ||||||
|  |         'build', | ||||||
|  |       ], | ||||||
|  |     ], | ||||||
|  |     'type-case': [0], | ||||||
|  |     'type-empty': [0], | ||||||
|  |     'scope-empty': [0], | ||||||
|  |     'scope-case': [0], | ||||||
|  |     'subject-full-stop': [0, 'never'], | ||||||
|  |     'subject-case': [0, 'never'], | ||||||
|  |     'header-max-length': [0, 'always', 72], | ||||||
|  |   }, | ||||||
|  | } | ||||||
| @ -0,0 +1,13 @@ | |||||||
|  | <!doctype html> | ||||||
|  | <html lang="en"> | ||||||
|  |   <head> | ||||||
|  |     <meta charset="UTF-8" /> | ||||||
|  |     <link rel="icon" type="image/svg+xml" href="/vite.svg" /> | ||||||
|  |     <meta name="viewport" content="width=device-width, initial-scale=1.0" /> | ||||||
|  |     <title>Vite + Vue + TS</title> | ||||||
|  |   </head> | ||||||
|  |   <body> | ||||||
|  |     <div id="app"></div> | ||||||
|  |     <script type="module" src="/src/main.ts"></script> | ||||||
|  |   </body> | ||||||
|  | </html> | ||||||
| @ -0,0 +1,59 @@ | |||||||
|  | { | ||||||
|  |   "name": "gcsgui", | ||||||
|  |   "private": true, | ||||||
|  |   "version": "0.0.0", | ||||||
|  |   "type": "module", | ||||||
|  |   "scripts": { | ||||||
|  |     "dev": "vite", | ||||||
|  |     "build": "vue-tsc && vite build", | ||||||
|  |     "preview": "vite preview", | ||||||
|  |     "lint": "eslint src", | ||||||
|  |     "fix": "eslint src --fix", | ||||||
|  |     "format": "prettier --write \"./**/*.{html,vue,ts,js,json,md}\"", | ||||||
|  |     "lint:eslint": "eslint src/**/*.{ts,vue} --cache --fix", | ||||||
|  |     "lint:style": "stylelint src/**/*.{css,scss,vue} --cache --fix", | ||||||
|  |     "prepare": "husky install", | ||||||
|  |     "commitlint": "commitlint --config commitlint.config.cjs -e -V", | ||||||
|  |     "preinstall": "node ./scripts/preinstall.js" | ||||||
|  |   }, | ||||||
|  |   "dependencies": { | ||||||
|  |     "axios": "^1.6.7", | ||||||
|  |     "pinia": "^2.1.7", | ||||||
|  |     "vue": "^3.4.19" | ||||||
|  |   }, | ||||||
|  |   "devDependencies": { | ||||||
|  |     "@babel/eslint-parser": "^7.23.10", | ||||||
|  |     "@commitlint/cli": "^19.0.3", | ||||||
|  |     "@commitlint/config-conventional": "^19.0.3", | ||||||
|  |     "@types/node": "^20.11.25", | ||||||
|  |     "@typescript-eslint/eslint-plugin": "^7.1.1", | ||||||
|  |     "@typescript-eslint/parser": "^7.1.1", | ||||||
|  |     "@vitejs/plugin-vue": "^5.0.4", | ||||||
|  |     "eslint": "^8.57.0", | ||||||
|  |     "eslint-config-prettier": "^9.1.0", | ||||||
|  |     "eslint-plugin-import": "^2.29.1", | ||||||
|  |     "eslint-plugin-node": "^11.1.0", | ||||||
|  |     "eslint-plugin-prettier": "^5.1.3", | ||||||
|  |     "eslint-plugin-vue": "^9.22.0", | ||||||
|  |     "husky": "^8.0.0", | ||||||
|  |     "postcss": "^8.4.35", | ||||||
|  |     "postcss-html": "^1.6.0", | ||||||
|  |     "postcss-scss": "^4.0.9", | ||||||
|  |     "prettier": "^3.2.5", | ||||||
|  |     "sass": "^1.71.1", | ||||||
|  |     "sass-loader": "^14.1.1", | ||||||
|  |     "stylelint": "^16.2.1", | ||||||
|  |     "stylelint-config-prettier": "^9.0.5", | ||||||
|  |     "stylelint-config-recess-order": "^5.0.0", | ||||||
|  |     "stylelint-config-recommended-scss": "^14.0.0", | ||||||
|  |     "stylelint-config-standard": "^36.0.0", | ||||||
|  |     "stylelint-config-standard-scss": "^13.0.0", | ||||||
|  |     "stylelint-config-standard-vue": "^1.0.0", | ||||||
|  |     "stylelint-order": "^6.0.4", | ||||||
|  |     "stylelint-scss": "^6.2.1", | ||||||
|  |     "typescript": "^5.2.2", | ||||||
|  |     "vite": "^5.1.4", | ||||||
|  |     "vite-plugin-svg-icons": "^2.0.1", | ||||||
|  |     "vue-tsc": "^1.8.27" | ||||||
|  |   } | ||||||
|  | } | ||||||
											
												
													File diff suppressed because it is too large
													Load Diff
												
											
										
									
								| @ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg> | ||||||
| After Width: | Height: | Size: 1.5 KiB | 
| @ -0,0 +1,7 @@ | |||||||
|  | if (!/pnpm/.test(process.env.npm_execpath || '')) { | ||||||
|  |   console.warn( | ||||||
|  |     `\u001b[33mThis repository must using pnpm as the package manager ` + | ||||||
|  |       ` for scripts to work properly.\u001b[39m\n`, | ||||||
|  |   ) | ||||||
|  |   process.exit(1) | ||||||
|  | } | ||||||
| @ -0,0 +1,7 @@ | |||||||
|  | <script setup lang="ts"></script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div></div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <style scoped></style> | ||||||
| @ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="37.07" height="36" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 198"><path fill="#41B883" d="M204.8 0H256L128 220.8L0 0h97.92L128 51.2L157.44 0h47.36Z"></path><path fill="#41B883" d="m0 0l128 220.8L256 0h-51.2L128 132.48L50.56 0H0Z"></path><path fill="#35495E" d="M50.56 0L128 133.12L204.8 0h-47.36L128 51.2L97.92 0H50.56Z"></path></svg> | ||||||
| After Width: | Height: | Size: 496 B | 
| @ -0,0 +1,6 @@ | |||||||
|  | import { createApp } from 'vue' | ||||||
|  | import './style.css' | ||||||
|  | import App from './App.vue' | ||||||
|  | import 'virtual:svg-icons-register' | ||||||
|  | 
 | ||||||
|  | createApp(App).mount('#app') | ||||||
| @ -0,0 +1,79 @@ | |||||||
|  | :root { | ||||||
|  |   font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif; | ||||||
|  |   line-height: 1.5; | ||||||
|  |   font-weight: 400; | ||||||
|  | 
 | ||||||
|  |   color-scheme: light dark; | ||||||
|  |   color: rgba(255, 255, 255, 0.87); | ||||||
|  |   background-color: #242424; | ||||||
|  | 
 | ||||||
|  |   font-synthesis: none; | ||||||
|  |   text-rendering: optimizeLegibility; | ||||||
|  |   -webkit-font-smoothing: antialiased; | ||||||
|  |   -moz-osx-font-smoothing: grayscale; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | a { | ||||||
|  |   font-weight: 500; | ||||||
|  |   color: #646cff; | ||||||
|  |   text-decoration: inherit; | ||||||
|  | } | ||||||
|  | a:hover { | ||||||
|  |   color: #535bf2; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | body { | ||||||
|  |   margin: 0; | ||||||
|  |   display: flex; | ||||||
|  |   place-items: center; | ||||||
|  |   min-width: 320px; | ||||||
|  |   min-height: 100vh; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | h1 { | ||||||
|  |   font-size: 3.2em; | ||||||
|  |   line-height: 1.1; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | button { | ||||||
|  |   border-radius: 8px; | ||||||
|  |   border: 1px solid transparent; | ||||||
|  |   padding: 0.6em 1.2em; | ||||||
|  |   font-size: 1em; | ||||||
|  |   font-weight: 500; | ||||||
|  |   font-family: inherit; | ||||||
|  |   background-color: #1a1a1a; | ||||||
|  |   cursor: pointer; | ||||||
|  |   transition: border-color 0.25s; | ||||||
|  | } | ||||||
|  | button:hover { | ||||||
|  |   border-color: #646cff; | ||||||
|  | } | ||||||
|  | button:focus, | ||||||
|  | button:focus-visible { | ||||||
|  |   outline: 4px auto -webkit-focus-ring-color; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .card { | ||||||
|  |   padding: 2em; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #app { | ||||||
|  |   max-width: 1280px; | ||||||
|  |   margin: 0 auto; | ||||||
|  |   padding: 2rem; | ||||||
|  |   text-align: center; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @media (prefers-color-scheme: light) { | ||||||
|  |   :root { | ||||||
|  |     color: #213547; | ||||||
|  |     background-color: #ffffff; | ||||||
|  |   } | ||||||
|  |   a:hover { | ||||||
|  |     color: #747bff; | ||||||
|  |   } | ||||||
|  |   button { | ||||||
|  |     background-color: #f9f9f9; | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1 @@ | |||||||
|  | /// <reference types="vite/client" />
 | ||||||
| @ -0,0 +1,11 @@ | |||||||
|  | { | ||||||
|  |   "compilerOptions": { | ||||||
|  |     "composite": true, | ||||||
|  |     "skipLibCheck": true, | ||||||
|  |     "module": "ESNext", | ||||||
|  |     "moduleResolution": "bundler", | ||||||
|  |     "allowSyntheticDefaultImports": true, | ||||||
|  |     "strict": true | ||||||
|  |   }, | ||||||
|  |   "include": ["vite.config.ts"] | ||||||
|  | } | ||||||
| @ -0,0 +1,21 @@ | |||||||
|  | import { defineConfig } from 'vite' | ||||||
|  | import vue from '@vitejs/plugin-vue' | ||||||
|  | import { createSvgIconsPlugin } from 'vite-plugin-svg-icons' | ||||||
|  | import path from 'path' | ||||||
|  | // https://vitejs.dev/config/
 | ||||||
|  | export default defineConfig({ | ||||||
|  |   plugins: [ | ||||||
|  |     vue(), | ||||||
|  |     createSvgIconsPlugin({ | ||||||
|  |       // Specify the icon folder to be cached
 | ||||||
|  |       iconDirs: [path.resolve(process.cwd(), 'src/assets/icons')], | ||||||
|  |       // Specify symbolId format
 | ||||||
|  |       symbolId: 'icon-[dir]-[name]', | ||||||
|  |     }), | ||||||
|  |   ], | ||||||
|  |   resolve: { | ||||||
|  |     alias: { | ||||||
|  |       '@': path.resolve('./src'), // 相对路径别名配置,使用 @ 代替 src
 | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | }) | ||||||
					Loading…
					
					
				
		Reference in New Issue