diff --git a/angular.json b/angular.json
index deb0b41..76ab956 100644
--- a/angular.json
+++ b/angular.json
@@ -72,7 +72,8 @@
"browserTarget": "admin:build:production"
},
"development": {
- "browserTarget": "admin:build:development"
+ "browserTarget": "admin:build:development",
+ "port": 4200
}
},
"defaultConfiguration": "development"
@@ -125,6 +126,97 @@
}
}
}
+ },
+ "client": {
+ "projectType": "application",
+ "schematics": {
+ "@schematics/angular:component": {
+ "style": "less"
+ }
+ },
+ "root": "projects/client",
+ "sourceRoot": "projects/client/src",
+ "prefix": "app",
+ "architect": {
+ "build": {
+ "builder": "@angular-devkit/build-angular:browser",
+ "options": {
+ "outputPath": "dist/client",
+ "index": "projects/client/src/index.html",
+ "main": "projects/client/src/main.ts",
+ "polyfills": ["zone.js"],
+ "tsConfig": "projects/client/tsconfig.app.json",
+ "inlineStyleLanguage": "less",
+ "assets": [
+ "projects/client/src/favicon.ico",
+ "projects/client/src/assets",
+ {
+ "glob": "**/*",
+ "input": "./node_modules/@ant-design/icons-angular/src/inline-svg/",
+ "output": "/assets/"
+ }
+ ],
+ "styles": ["projects/client/src/styles.less"],
+ "scripts": []
+ },
+ "configurations": {
+ "production": {
+ "budgets": [
+ {
+ "type": "initial",
+ "maximumWarning": "500kb",
+ "maximumError": "1mb"
+ },
+ {
+ "type": "anyComponentStyle",
+ "maximumWarning": "2kb",
+ "maximumError": "4kb"
+ }
+ ],
+ "outputHashing": "all"
+ },
+ "development": {
+ "buildOptimizer": false,
+ "optimization": false,
+ "vendorChunk": true,
+ "extractLicenses": false,
+ "sourceMap": true,
+ "namedChunks": true
+ }
+ },
+ "defaultConfiguration": "production"
+ },
+ "serve": {
+ "builder": "@angular-devkit/build-angular:dev-server",
+ "configurations": {
+ "production": {
+ "browserTarget": "client:build:production"
+ },
+ "development": {
+ "browserTarget": "client:build:development",
+ "port": 4201
+ }
+ },
+ "defaultConfiguration": "development"
+ },
+ "extract-i18n": {
+ "builder": "@angular-devkit/build-angular:extract-i18n",
+ "options": {
+ "browserTarget": "client:build"
+ }
+ },
+ "test": {
+ "builder": "@angular-devkit/build-angular:karma",
+ "options": {
+ "polyfills": ["zone.js", "zone.js/testing"],
+ "tsConfig": "projects/client/tsconfig.spec.json",
+ "inlineStyleLanguage": "less",
+ "assets": ["projects/client/src/favicon.ico", "projects/client/src/assets"],
+ "styles": ["projects/client/src/styles.less"],
+ "scripts": []
+ }
+ }
+ }
}
}
}
diff --git a/doc/basic.md b/doc/basic.md
new file mode 100644
index 0000000..db4dec9
--- /dev/null
+++ b/doc/basic.md
@@ -0,0 +1,182 @@
+# 基础部分
+
+# 1. 登录
+
+> GET /user/login?uid=xxx&pwd=BE56E057F20F883E
+> MD5加密后大写取后16位,示例原密码为123456
+
+### 输出:
+```
+{
+ "body": {
+ "roleName": "超级管理员",
+ "uid": "xxx",
+ "admin": false, // 是否管理端,true-是管理端, false-业务端
+ "name": "业务端测试账号",
+ "phone": "13919103409",
+ "roleId": 2,
+ "roleItems": [
+ {
+ "category": "基础权限",
+ "id": 18,
+ "itemName": "使用流程",
+ "itemType": "业务端"
+ }
+ ],
+ "vender": {
+ "account": "13919103408",
+ "address": "百仁路",
+ "contacts": "曹先生",
+ "expire": 1693651185000,
+ "icon": "",
+ "id": 1, // 单位编号,后续操作都需要这个单位编号
+ "name": "成都实验小学",
+ "phone": "13919103408",
+ "status": true
+ }
+ },
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 2. 登出
+
+> GET /user/logout
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 3. 修改自己的账号
+
+> POST /api/basic/user
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+name=曹 // 修改姓名
+password=BE56E057F20F883E // 修改密码
+```
+
+### 输出:
+```
+{
+"code": 200,
+"desc": "成功",
+"success": true
+}
+```
+
+# 4. 获取所有枚举信息
+
+> GET /api/basic/enum
+
+### 输出:
+```
+{
+ "body": {
+ "nutrient": [
+ {
+ "key": "vitamin-a",
+ "measurement": "μgRAE",
+ "nrv": 1.10,
+ "value": "维生素A"
+ },
+ {
+ "key": "calcium",
+ "measurement": "mg",
+ "nrv": 2.20,
+ "value": "钙"
+ },
+ {
+ "key": "protein",
+ "measurement": "g",
+ "nrv": 3.30,
+ "value": "蛋白质"
+ },
+ {
+ "key": "energy",
+ "measurement": "kcal",
+ "nrv": 5.00,
+ "value": "能量"
+ },
+ {
+ "key": "fat",
+ "measurement": "g",
+ "nrv": 8.80,
+ "value": "脂肪"
+ }
+ ],
+ "category": [
+ {
+ "key": "谷薯类",
+ "value": "谷薯类"
+ },
+ {
+ "key": "大豆类及其制品",
+ "value": "大豆类及其制品"
+ },
+ {
+ "key": "蔬菜类",
+ "value": "蔬菜类"
+ },
+ {
+ "key": "水果类",
+ "value": "水果类"
+ },
+ {
+ "key": "坚果",
+ "value": "坚果"
+ },
+ {
+ "key": "畜禽肉类",
+ "value": "畜禽肉类"
+ },
+ {
+ "key": "奶及奶制品",
+ "value": "奶及奶制品"
+ },
+ {
+ "key": "蛋类",
+ "value": "蛋类"
+ },
+ {
+ "key": "鱼虾类",
+ "value": "鱼虾类"
+ },
+ {
+ "key": "婴幼儿食品",
+ "value": "婴幼儿食品"
+ }
+ ],
+ "mark": [
+ {
+ "key": "汤类",
+ "value": "汤类"
+ },
+ {
+ "key": "主食",
+ "value": "主食"
+ },
+ {
+ "key": "主荤",
+ "value": "主荤"
+ },
+ {
+ "key": "次荤",
+ "value": "次荤"
+ }
+ ]
+ },
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
\ No newline at end of file
diff --git a/doc/change.md b/doc/change.md
new file mode 100644
index 0000000..0756f7d
--- /dev/null
+++ b/doc/change.md
@@ -0,0 +1,15 @@
+# 修改记录
+
+> 9.10
+```
+基础协议
+用户协议
+角色协议
+单位协议
+```
+
+> 9.11
+```
+食材
+菜品
+食谱
diff --git a/doc/index.md b/doc/index.md
new file mode 100644
index 0000000..9c04ae5
--- /dev/null
+++ b/doc/index.md
@@ -0,0 +1,42 @@
+# 协议约定
+>协议格式: restfull + json + utf-8
+
+>协议格式中,凡是用 * 标识字段均为必须字段,否则为可选字段。
+
+>密码:协议中涉及password字段全部使用16位的MD5加密传输(MD5加密后取后16位,大写)
+
+### 协议列表
+```
+* [协议约定](protocol.md)
+* [修改记录](change.md)
+* [基础协议](basic.md)
+* [用户权限](user.md)
+* [单位协议](vender.md)
+```
+
+### 响应示例
+```
+{
+ "body": {......}, //返回的业务数据
+ "code":*1, //结果码
+ "desc":*"成功", //结果描述
+}
+```
+
+### 返回码表
+```
+基础返回码:
+ success (200, "成功"),
+
+ invalid_user_password (300, "用户名或者密码错误!"),
+
+ expired_vender (301, "账户过期,请联系管理员续费!"),
+
+ illegal_argument (400, "参数错误!"),
+ need_login (401, "未登录!"),
+ not_support_operate (404, "不支持的请求!"),
+ not_privileged (405, "无权限执行该操作!"),
+ system_error (500, "系统异常!"),
+ operate_failure (503, "操作失败!");
+
+```
diff --git a/projects/admin/src/app/shared/components/index.ts b/doc/readme.md
similarity index 100%
rename from projects/admin/src/app/shared/components/index.ts
rename to doc/readme.md
diff --git a/doc/user.md b/doc/user.md
new file mode 100644
index 0000000..4eb2bc8
--- /dev/null
+++ b/doc/user.md
@@ -0,0 +1,303 @@
+# 用户部分
+
+# 1. 检查UID的是否重复
+
+> GET /api/user/check?uid=zzz
+
+### 输出:
+```
+{
+ "body": false, // true标识uid未被占用
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+
+# 2. 添加用户
+
+> PUT /api/user
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+uid=ccc // 必填, 用户ID, 不能重复
+name=曹 // 必填, 用户姓名
+password=BE56E057F20F883E // 必填, MD5加密后大写取后16位,示例原密码为123456
+roleId=2 //角色编号,只能是自己单位的角色,必填,从角色列表选择一个
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 3. 删除用户
+
+> DELETE /api/user
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+uid=ccc // 必填,
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 4. 修改用户
+
+> POST /api/user
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+uid=ccc // 用户ID, 必填
+name=曹 // 修改姓名
+password=BE56E057F20F883E // 修改密码
+roleId=2 //修改角色, 0-标识回收角色,其他-标识分配角色
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+
+# 5. 获取用户列表
+
+> GET /api/user
+
+### 输出:
+```
+{
+ "body": [
+ {
+ "name": "业务端测试账号",
+ "phone": "13919103409",
+ "roleId": 2,
+ "roleName": "超级管理员",
+ "uid": "xxx"
+ }
+ ],
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+
+# 6. 获取当前用户所在端的权限项列表
+
+> GET /api/role/item
+
+### 输出:
+```
+{
+ "body": [
+ {
+ "category": "基础权限",
+ "id": 18,
+ "itemName": "使用流程",
+ "itemType": "业务端"
+ },
+ {
+ "category": "基础权限",
+ "id": 19,
+ "itemName": "数据大屏-大屏显示",
+ "itemType": "业务端"
+ },
+ {
+ "category": "基础权限",
+ "id": 20,
+ "itemName": "数据大屏-大屏显示(LED)",
+ "itemType": "业务端"
+ },
+ {
+ "category": "配餐设置",
+ "id": 21,
+ "itemName": "配餐设置-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "配餐设置",
+ "id": 22,
+ "itemName": "配餐设置-编辑",
+ "itemType": "业务端"
+ },
+ {
+ "category": "食材管理",
+ "id": 23,
+ "itemName": "食材列表-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "食材管理",
+ "id": 24,
+ "itemName": "食材-常用/忌用",
+ "itemType": "业务端"
+ },
+ {
+ "category": "菜品管理",
+ "id": 25,
+ "itemName": "菜品列表-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "菜品管理",
+ "id": 26,
+ "itemName": "菜品-新增/编辑/删除",
+ "itemType": "业务端"
+ },
+ {
+ "category": "食谱管理",
+ "id": 27,
+ "itemName": "食谱列表-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "食谱管理",
+ "id": 28,
+ "itemName": "食谱-新增/编辑/删除",
+ "itemType": "业务端"
+ },
+ {
+ "category": "食谱管理",
+ "id": 29,
+ "itemName": "食谱审核记录-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "基础信息管理",
+ "id": 30,
+ "itemName": "单位基础信息-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "基础信息管理",
+ "id": 31,
+ "itemName": "单位基础信息-修改",
+ "itemType": "业务端"
+ },
+ {
+ "category": "系统设置",
+ "id": 32,
+ "itemName": "用户列表-查看",
+ "itemType": "业务端"
+ },
+ {
+ "category": "系统设置",
+ "id": 33,
+ "itemName": "用户-新增/编辑/删除",
+ "itemType": "业务端"
+ },
+ {
+ "category": "系统设置",
+ "id": 34,
+ "itemName": "角色权限-查看/新增/编辑/删除",
+ "itemType": "业务端"
+ }
+ ],
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 7. 添加角色
+
+> PUT /api/role
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+roleName=ccc // 必填, 角色名称
+items=1,2,3 // 必填, 赋予的权限项
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 8. 删除角色
+
+> DELETE /api/role
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+roleId=1 // 必填
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 9. 修改角色
+
+> POST /api/role
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+roleId=1 // 必填
+roleName=ccc // 角色名称
+items=1,2,3 // 赋予的权限项
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+
+# 10. 获取角色列表
+
+> GET /api/role
+
+### 输出:
+```
+{
+ "body": [
+ {
+ "id": 2,
+ "roleItems": "[18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34]",
+ "roleName": "超级管理员",
+ "roleType": "系统",
+ "vender": 1
+ }
+ ],
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
\ No newline at end of file
diff --git a/doc/vender.md b/doc/vender.md
new file mode 100644
index 0000000..db68537
--- /dev/null
+++ b/doc/vender.md
@@ -0,0 +1,180 @@
+# 单位部分
+
+# 1. 检验账号重复性
+
+> GET /api/vender/check/account?account=xxx
+
+### 输出:
+```
+{
+ "body": false, // true未被占用,可用
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 2. 检查单位名称重复性
+
+> GET /api/vender/check/name?name=xxx
+
+### 输出:
+```
+{
+ "body": false, // true未被占用,可用
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 3. 查询单位配置
+
+> GET /api/vender/config
+
+### 输出:
+```
+{
+ "body": {
+ "breakfast": 10.00,
+ "dinner": 10.00,
+ "lunch": 10.00
+ },
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 4. 修改单位配置
+
+> POST /api/vender/config
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+vender=1 // 必填
+breakfast=10.00 // 必填
+dinner=10 // 必填
+lunch=10 // 必填
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 5. 添加企业
+
+> PUT /api/vender
+>
+> 管理端接口
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+account=ccc // 必填, 初始管理员账号, 不能重复
+password=BE56E057F20F883E // 必填, MD5加密后大写取后16位,示例原密码为123456
+name=曹 // 必填, 单位名称
+expire=2019-10-10 // 必填, 过期时间
+icon=23423 //单位logo, 前端可用的base64字符串
+address=
+contacts=
+phone=
+email=
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 6. 删除企业
+
+> DELETE /api/vender
+>
+> 管理端接口
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+vender=1 // 必填
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+# 7. 修改企业
+
+> POST /api/vender
+>
+> 续费和开关仅管理端,其他管理端或者业务端主账号操作
+
+### 输入:
+```
+Content-Type:application/x-www-form-urlencoded
+expire=2019-10-10 // 仅管理端可以改过期时间
+status=false // 仅管理端可以改状态, false-关闭,true-打开
+
+account=ccc // 改绑定的主账户, 将自动为改账户赋管理员权限, 不能重复
+name=曹 // 改单位名称
+icon=23423 //单位logo, 前端可用的base64字符串, 最大好像就几十KB吧,不能太大
+address=
+contacts=
+phone=
+email=
+```
+
+### 输出:
+```
+{
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
+
+
+# 8. 获取企业列表
+
+> GET /api/vender
+>
+> 管理端接口
+
+### 输出:
+```
+{
+ "body": [
+ {
+ "account": "xxx",
+ "address": "百仁路",
+ "area": "青羊区",
+ "category": "小学",
+ "city": "成都市",
+ "contacts": "曹先生",
+ "expire": 1695033585000,
+ "icon": "",
+ "id": 1,
+ "name": "成都实验小学",
+ "phone": "13919103408",
+ "province": "四川省",
+ "status": true
+ }
+ ],
+ "code": 200,
+ "desc": "成功",
+ "success": true
+}
+```
\ No newline at end of file
diff --git a/package.json b/package.json
index 60f30f0..a2d9663 100644
--- a/package.json
+++ b/package.json
@@ -3,8 +3,10 @@
"version": "0.0.0",
"scripts": {
"ng": "ng",
- "start": "ng serve",
- "build": "ng build",
+ "start:admin": "ng serve admin",
+ "start:client": "ng serve client",
+ "build:admin": "ng build admin",
+ "build:client": "ng build client",
"watch": "ng build --watch --configuration development",
"test": "ng test"
},
diff --git a/projects/admin/src/app/app.module.ts b/projects/admin/src/app/app.module.ts
index 750fa44..3be3e7d 100644
--- a/projects/admin/src/app/app.module.ts
+++ b/projects/admin/src/app/app.module.ts
@@ -10,12 +10,9 @@ import zh from "@angular/common/locales/zh";
import { FormsModule } from "@angular/forms";
import { HTTP_INTERCEPTORS, HttpClientModule } from "@angular/common/http";
import { BrowserAnimationsModule } from "@angular/platform-browser/animations";
-import { IconsProviderModule } from "./icons-provider.module";
-import { SharedModule } from "./shared/shared.module";
import {
AppLayoutComponent,
- AppPageComponent,
FoodFormComponent,
DishFormComponent,
IngredientFormBasicComponent,
@@ -39,6 +36,9 @@ import {
StandardSettingComponent,
} from "./pages";
import { HTTPInterceptor } from "./services/http.interceptor";
+import { IconsProviderModule } from "@cdk/public-api";
+import { SharedModule } from "@cdk/shared/shared.module";
+import { IngredientModule } from "@cdk/ingredient/ingredient.module";
registerLocaleData(zh);
@@ -46,7 +46,6 @@ registerLocaleData(zh);
declarations: [
AppComponent,
AppLayoutComponent,
- AppPageComponent,
FoodFormComponent,
DishFormComponent,
IngredientFormBasicComponent,
@@ -80,6 +79,7 @@ registerLocaleData(zh);
BrowserAnimationsModule,
IconsProviderModule,
SharedModule,
+ IngredientModule,
],
providers: [
{ provide: NZ_I18N, useValue: zh_CN },
diff --git a/projects/admin/src/app/components/app-layout/app-layout.component.html b/projects/admin/src/app/components/app-layout/app-layout.component.html
index f00263a..bcc85ba 100644
--- a/projects/admin/src/app/components/app-layout/app-layout.component.html
+++ b/projects/admin/src/app/components/app-layout/app-layout.component.html
@@ -1,18 +1,34 @@