package member_center import ( "applet/app/db" "applet/app/e" md "applet/app/md/institutional_management/member_center" "applet/app/utils" "code.fnuoos.com/EggPlanet/egg_models.git/src/implement" "code.fnuoos.com/EggPlanet/egg_models.git/src/model" "code.fnuoos.com/EggPlanet/egg_system_rules.git/enum" "errors" "github.com/gin-gonic/gin" "time" ) // GetLevelList // @Summary 制度中心-会员中心-等级管理(获取) // @Tags 会员中心 // @Description 标签管理(获取) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param limit query int true "每页大小" // @Param page query int true "页数" // @Success 200 {object} md.GetLevelListResp "具体数据" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/getLevelList [get] func GetLevelList(c *gin.Context) { page := c.DefaultQuery("page", "1") limit := c.DefaultQuery("limit", "10") levelDb := implement.NewUserLevelDb(db.Db) levels, total, err := levelDb.UserLevelAllByAscByPage(utils.StrToInt(page), utils.StrToInt(limit)) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } sql := "SElECT count(distinct id) as total, level FROM `user` GROUP BY level" results, err := db.QueryNativeString(db.Db, sql) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } var countMap = map[int]string{} for _, res := range results { countMap[utils.StrToInt(res["level"])] = res["total"] } list := make([]md.LevelListNode, 0) for i, level := range levels { list[i].LevelWeight = level.LevelWeight list[i].LevelID = level.Id list[i].LevelName = level.LevelName list[i].Count = countMap[level.Id] list[i].CreateAt = level.CreateAt list[i].IsUse = level.IsUse list[i].Memo = level.Memo } resp := md.GetLevelListResp{ List: list, Paginate: md.Paginate{ Limit: utils.StrToInt(limit), Page: utils.StrToInt(page), Total: total, }, } e.OutSuc(c, resp, nil) } // GetOneLevel // @Summary 制度中心-会员中心-等级管理-等级明细(获取) // @Tags 会员中心 // @Description 等级明细(获取) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param level_id query int true "等级 ID" // @Success 200 {object} md.GetOneLevelResp "具体数据" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/getOneLevel [get] func GetOneLevel(c *gin.Context) { id := c.Query("level_id") if id == "" { e.OutErr(c, e.ERR_INVALID_ARGS, errors.New("必须传入等级ID")) return } taskType := []map[string]interface{}{ { "name": enum.UserLevelTaskType.String(enum.DirectPushMembersNum), "value": enum.DirectPushMembersNum, }, { "name": enum.UserLevelTaskType.String(enum.DirectPushActiveDayNum), "value": enum.DirectPushMembersNum, }, { "name": enum.UserLevelTaskType.String(enum.DirectPushLevel), "value": enum.DirectPushLevel, }, } levelDb := implement.NewUserLevelDb(db.Db) level, err := levelDb.UserLevelByID(id) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } userLevelTaskDb := implement.NewUserLevelTaskDb(db.Db) tasks, err := userLevelTaskDb.UserLevelTaskFindByParams(map[string]interface{}{ "key": "level_id", "value": id, }) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } resp := md.GetOneLevelResp{ TaskType: taskType, LevelID: level.Id, IsUse: level.IsUse, LevelName: level.LevelName, Memo: level.Memo, AutoUpdate: level.AutoUpdate, ChoosableNum: level.ChoosableNum, LevelWeight: level.LevelWeight, UserLevelTasks: tasks, } e.OutSuc(c, resp, nil) } // AddLevelTask // @Summary 制度中心-会员中心-等级明细-等级任务(新增) // @Tags 会员中心 // @Description 等级任务(新增) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.AddLevelTaskReq true "需要新增的任务信息" // @Success 200 {int} "新增的任务ID" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/addLevelTask [post] func AddLevelTask(c *gin.Context) { var req *md.AddLevelTaskReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } task := model.UserLevelTask{ Id: 0, LevelId: utils.StrToInt(req.LevelID), CreateAt: time.Now().Format("2006-01-02 15:04:05"), } if req.IsMustTask != "" { task.IsMustTask = utils.StrToInt(req.IsMustTask) } if req.TaskType != "" { task.TaskType = utils.StrToInt(req.TaskType) } if req.WithinDays != "" { task.WithinDays = utils.StrToInt(req.WithinDays) } if req.FinishCount != "" { task.FinishCount = utils.StrToInt(req.FinishCount) } if req.TaskTypeLevelId != "" { task.TaskTypeLevelId = utils.StrToInt(req.TaskTypeLevelId) } taskDb := implement.NewUserLevelTaskDb(db.Db) taskID, err := taskDb.UserLevelTaskInsert(&task) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } e.OutSuc(c, taskID, nil) } // UpdateLevelTask // @Summary 制度中心-会员中心-等级明细-等级任务(更新) // @Tags 会员中心 // @Description 等级任务(更新) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.UpdateLevelTaskReq true "需要修改的等级任务信息" // @Success 200 {int} "成功修改数据条数" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/updateLevelTask [post] func UpdateLevelTask(c *gin.Context) { var req *md.UpdateLevelTaskReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } task := &model.UserLevelTask{ Id: utils.StrToInt(req.TaskID), } if req.IsMustTask != "" { task.IsMustTask = utils.StrToInt(req.IsMustTask) } if req.TaskType != "" { task.TaskType = utils.StrToInt(req.TaskType) } if req.WithinDays != "" { task.WithinDays = utils.StrToInt(req.WithinDays) } if req.FinishCount != "" { task.FinishCount = utils.StrToInt(req.FinishCount) } if req.TaskTypeLevelId != "" { task.TaskTypeLevelId = utils.StrToInt(req.TaskTypeLevelId) } taskDb := implement.NewUserLevelTaskDb(db.Db) affected, err := taskDb.UserLevelTaskUpdate(task) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } e.OutSuc(c, affected, nil) } // UpdateLevel // @Summary 制度中心-会员中心-等级管理(更新) // @Tags 会员中心 // @Description 等级管理(更新) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.UpdateLevelReq true "需要修改的等级信息" // @Success 200 {int} "成功修改数据条数" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/updateLevel [post] func UpdateLevel(c *gin.Context) { var req *md.UpdateLevelReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } level := &model.UserLevel{ Id: utils.StrToInt(req.LevelID), LevelName: req.LevelName, Memo: req.Memo, ChoosableNum: utils.StrToInt(req.ChoosableNum), } if req.LevelWeight != "" { level.LevelWeight = utils.StrToInt(req.LevelWeight) } if req.IsUse == "0" || req.IsUse == "1" { level.LevelWeight = utils.StrToInt(req.IsUse) } if req.AutoUpdate == "0" || req.AutoUpdate == "1" { level.AutoUpdate = utils.StrToInt(req.AutoUpdate) } forceColumns := []string{"level_weight", "is_use"} levelDb := implement.NewUserLevelDb(db.Db) affected, err := levelDb.UserLevelUpdate(req.LevelID, level, forceColumns...) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } e.OutSuc(c, affected, nil) } // AddLevel // @Summary 制度中心-会员中心-等级管理(新增) // @Tags 会员中心 // @Description 等级管理(新增) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.AddLevelReq true "需要新增的等级信息" // @Success 200 {int} "新增等级ID" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/addLevel [post] func AddLevel(c *gin.Context) { var req *md.AddLevelReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } level := &model.UserLevel{ LevelName: req.LevelName, Memo: req.Memo, ChoosableNum: utils.StrToInt(req.ChoosableNum), CreateAt: time.Now().Format("2006-01-02 15:04:05"), } if req.LevelWeight != "" { level.LevelWeight = utils.StrToInt(req.LevelWeight) } if req.IsUse == "0" || req.IsUse == "1" { level.LevelWeight = utils.StrToInt(req.IsUse) } if req.AutoUpdate == "0" || req.AutoUpdate == "1" { level.AutoUpdate = utils.StrToInt(req.AutoUpdate) } levelDb := implement.NewUserLevelDb(db.Db) id, err := levelDb.UserLevelInsert(level) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } e.OutSuc(c, id, nil) } // DeleteLevelTask // @Summary 制度中心-会员中心-等级管理-等级任务(删除) // @Tags 会员中心 // @Description 等级任务(删除) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.DeleteTaskReq true "需要删除的等级任务ID" // @Success 200 {int} "成功删除数据数量" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/deleteLevelTask [delete] func DeleteLevelTask(c *gin.Context) { var req *md.DeleteTaskReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } taskDb := implement.NewUserLevelTaskDb(db.Db) affected, err := taskDb.UserLevelTaskDelete(req.TaskID) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } e.OutSuc(c, affected, nil) } // DeleteLevel // @Summary 制度中心-会员中心-等级管理(删除) // @Tags 会员中心 // @Description 等级管理(删除) // @Accept json // @Produce json // @param Authorization header string true "验证参数Bearer和token空格拼接" // @Param req body md.DeleteLevelReq true "需要删除的等级 ID" // @Success 200 {int} "成功删除数据数量" // @Failure 400 {object} md.Response "具体错误" // @Router /api/memberCenter/levelManagement/deleteLevel [delete] func DeleteLevel(c *gin.Context) { var req *md.DeleteLevelReq if err := c.ShouldBindJSON(&req); err != nil { e.OutErr(c, e.ERR_INVALID_ARGS, err.Error()) return } session := db.Db.NewSession() defer session.Close() session.Begin() levelDb := implement.NewUserLevelDb(db.Db) affected, err := levelDb.UserLevelDeleteBySession(session, req.LevelID) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } sql := "UPDATE `user` SET level = 0 WHERE level = ?" _, err = session.QueryString(sql, req.LevelID) if err != nil { e.OutErr(c, e.ERR_DB_ORM, err.Error()) return } session.Commit() e.OutSuc(c, affected, nil) }