/vz-vue

vz vue project template.

Primary LanguageTypeScript

vz project template.

This is a typescript+vue3+vite project template for abp (as backend).

Usage

git clone https://github.com/personball/vz-vue.git
dotnet tool install vz-generator -g
vz rn vz-vue -r ProjectName=Demo -o ./demo/

Project Setup

yarn
npx simple-git-hooks  # setup git hooks
npm run dev           # develop 
npm run build:prod    # build production

Custom theme

See src/styles/element/index.scss.

Features

Folder Structure

src/
├── api/        # nswag 生成 api 代理到该目录
├── components/ # 全局组件(自动注册)
├── composables/# 自定义组合函数:基于 vue3.0 带状态的可复用逻辑封装
├── directives/ # 自定义指令(自动注册)
├── layouts/    # 布局组件,详见 vite-plugin-vue-layouts
├── locales/    # 本项目静态的多语言文件
├── modules/    # 加载插件或各种应用级别初始化逻辑 (会由 main.ts 自动加载, 为 main.ts 瘦身)
├── routes/     # 业务逻辑主要放这 (基于文件系统的路由,详见: unplugin-vue-router)
├── stores/     # pinia stores
├── styles/
├── App.vue
├── main.ts
└── oidc.ts     # vue3-oidc 初始化, 由 main.ts 加载

In English:

src/
├── api/        # nswag generate target
├── components/ # global components (will auto import)
├── composables/# functions
├── directives/ # custom directives (will auto register)
├── layouts/    # see vite-plugin-vue-layouts
├── locales/    # static languages file
├── modules/    # load plugins or do some app init logic (will auto load in main.ts)
├── routes/     # your business place (file-based router: unplugin-vue-router)
├── stores/     # pinia stores
├── styles/
├── App.vue
├── main.ts
└── oidc.ts     # vue3-oidc init, load by main.ts

Remark

Base on element-plus-vite-starter

alternative ui:

alternative form fw:

TODO:

  • 表单设计器
  • 分离前后端代码库,保留 element-plus,单独拎一个前端项目切换到 antdv
  • 尝试 formily/form-builder (这是个 react 项目)
  • 为 formily 适配 naiveui, formily/naiveui ?

keep eye on shoelace

ProjectName

C4Context
    title System Context diagram for ProjectName

    Person(user,"User")
    
    Enterprise_Boundary(b0,"ProjectName System"){
        Person(admin,"Admin")
        System(home,"ProjectName System")
    }

    Rel(user, home, "View")
    Rel(admin,home,"Management")

Loading
C4Container
    title Container diagram for ProjectName System

    Person(user,"User")
    Person(admin,"Admin")

    System_Boundary(c1,"ProjectName System"){
        Container(home,"ProjectName Web","MPA PC Web","PC Web")
        Container(spa,"Management","SPA Vue","Admin Management")
        Container(auth,"ProjectName AuthServer","OAuth2.0")    
        Boundary(b9,"internal"){
          Container(api,"ProjectName HttpApi.Host","ProjectName Api","Apis for Management and PC Web")
          ContainerDb(db0,"postgresql","Database")
        }
    }

    Rel(user,home,"HTTPS")
  
    Rel(home,api,"Access Apis")
    Rel(api,db0,"Access Data")

    Rel(admin,spa,"HTTPS")
    BiRel(spa,auth,"HTTPS<br>OIDC Login")
    Rel(spa,api,"HTTPS")

Loading