This project is a web-based NGINX management interface built with Go backend and Vue.js frontend.
- Use pnpm exclusively for all frontend package management operations
- Commands:
pnpm install,pnpm run dev,pnpm typecheck
- Go with Gin web framework
- GORM for database operations
- Gen for query simplification
- Cosy framework (https://cosy.uozi.org/)
- API Controllers: Implement in
api/$module_name/directory - Database Models: Define in
model/folder - Business Logic: Place complex logic and error handling in
internal/$module_name/ - Routing: Register routes in
router/directory - Configuration: Manage settings in
settings/directory
- Write concise, maintainable Go code with clear examples
- Use Gen to streamline database queries and reduce boilerplate
- Follow Cosy Error Handler best practices for error management
- Implement standardized CRUD operations using Cosy framework
- Apply efficient database pagination for large datasets
- Keep files modular and well-organized by functionality
- All comments and documentation must be in English
- TypeScript for all code
- Vue 3 with Composition API
- Vite build tool
- Vue Router for routing
- Pinia for state management
- VueUse for utilities
- Ant Design Vue for UI components
- UnoCSS for styling
- Use functional and declarative programming patterns (avoid classes)
- Prefer interfaces over types for better extendability
- Use descriptive variable names with auxiliary verbs (e.g.,
isLoading,hasError) - Always use Vue Composition API with
<script setup>syntax - Leverage Vue 3.4+ features:
defineModel(),useTemplateRef(), v-bind shorthand
- Components: Use CamelCase naming in
src/components/(e.g.,ChatGPT/ChatGPT.vue) - Views: Use lowercase with underscores for folders, CamelCase for components (e.g.,
src/views/system/About.vue) - API & Types: Define in
app/src/api/ - Exports: Favor named exports for functions
- Use Ant Design Vue components and UnoCSS for styling
- Implement responsive design with mobile-first approach
- Use Antdv Flex layout for responsive layouts
- Leverage VueUse functions for enhanced reactivity
- Wrap async components in Suspense with fallback UI
- Use dynamic loading for non-critical components
- Optimize images: WebP format, size data, lazy loading
- Implement code splitting and chunking strategy in Vite build
- Optimize Web Vitals (LCP, CLS, FID)
- Always use ESLint MCP after generating frontend code to ensure code quality and consistency
- Frontend:
pnpm run dev,pnpm typecheck,pnpm run build - Backend: Standard Go commands (
go run,go build,go test)
- All code comments, documentation, and communication must be in English
- Maintain consistency and accessibility across the codebase
- 优先使用 context7 mcp 搜索文档
- 生成 find 命令的时候应该排除掉 ./.go/ 这个文件夹,因为那里面是 devcontainer 的依赖