| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- /*
- * @desc:字典数据管理
- * @company:云南奇讯科技有限公司
- * @Author: yixiaohu<yxh669@qq.com>
- * @Date: 2022/9/28 9:22
- */
- package sysDictData
- import (
- "context"
- "github.com/gogf/gf/v2/frame/g"
- "github.com/gogf/gf/v2/text/gstr"
- "github.com/gogf/gf/v2/util/gconv"
- "github.com/tiger1103/gfast/v3/api/v1/system"
- "github.com/tiger1103/gfast/v3/internal/app/common/consts"
- "github.com/tiger1103/gfast/v3/internal/app/common/dao"
- "github.com/tiger1103/gfast/v3/internal/app/common/model"
- "github.com/tiger1103/gfast/v3/internal/app/common/model/do"
- "github.com/tiger1103/gfast/v3/internal/app/common/service"
- systemConsts "github.com/tiger1103/gfast/v3/internal/app/system/consts"
- "github.com/tiger1103/gfast/v3/library/liberr"
- )
- func init() {
- service.RegisterSysDictData(New())
- }
- func New() *sSysDictData {
- return &sSysDictData{}
- }
- type sSysDictData struct {
- }
- // GetDictWithDataByType 通过字典键类型获取选项
- func (s *sSysDictData) GetDictWithDataByType(ctx context.Context, req *system.GetDictReq) (dict *system.GetDictRes,
- err error) {
- cache := service.Cache()
- cacheKey := consts.CacheSysDict + "_" + req.DictType
- //从缓存获取
- iDict := cache.GetOrSetFuncLock(ctx, cacheKey, func(ctx context.Context) (value interface{}, err error) {
- err = g.Try(ctx, func(ctx context.Context) {
- //从数据库获取
- dict = &system.GetDictRes{}
- //获取类型数据
- err = dao.SysDictType.Ctx(ctx).Where(dao.SysDictType.Columns().DictType, req.DictType).
- Where(dao.SysDictType.Columns().Status, 1).Fields(model.DictTypeRes{}).Scan(&dict.Info)
- liberr.ErrIsNil(ctx, err, "获取字典类型失败")
- err = dao.SysDictData.Ctx(ctx).Fields(model.DictDataRes{}).
- Where(dao.SysDictData.Columns().DictType, req.DictType).
- Order(dao.SysDictData.Columns().DictSort + " asc," +
- dao.SysDictData.Columns().DictCode + " asc").
- Scan(&dict.Values)
- liberr.ErrIsNil(ctx, err, "获取字典数据失败")
- })
- value = dict
- return
- }, 0, consts.CacheSysDictTag)
- if iDict != nil {
- err = gconv.Struct(iDict, &dict)
- if err != nil {
- return
- }
- }
- //设置给定的默认值
- for _, v := range dict.Values {
- if req.DefaultValue != "" {
- if gstr.Equal(req.DefaultValue, v.DictValue) {
- v.IsDefault = 1
- } else {
- v.IsDefault = 0
- }
- }
- }
- return
- }
- // List 获取字典数据
- func (s *sSysDictData) List(ctx context.Context, req *system.DictDataSearchReq) (res *system.DictDataSearchRes, err error) {
- res = new(system.DictDataSearchRes)
- err = g.Try(ctx, func(ctx context.Context) {
- m := dao.SysDictData.Ctx(ctx)
- if req != nil {
- if req.DictLabel != "" {
- m = m.Where(dao.SysDictData.Columns().DictLabel+" like ?", "%"+req.DictLabel+"%")
- }
- if req.Status != "" {
- m = m.Where(dao.SysDictData.Columns().Status+" = ", gconv.Int(req.Status))
- }
- if req.DictType != "" {
- m = m.Where(dao.SysDictData.Columns().DictType+" = ?", req.DictType)
- }
- res.Total, err = m.Count()
- liberr.ErrIsNil(ctx, err, "获取字典数据失败")
- if req.PageNum == 0 {
- req.PageNum = 1
- }
- res.CurrentPage = req.PageNum
- }
- if req.PageSize == 0 {
- req.PageSize = systemConsts.PageSize
- }
- err = m.Page(req.PageNum, req.PageSize).Order(dao.SysDictData.Columns().DictSort + " asc," +
- dao.SysDictData.Columns().DictCode + " asc").Scan(&res.List)
- liberr.ErrIsNil(ctx, err, "获取字典数据失败")
- })
- return
- }
- func (s *sSysDictData) Add(ctx context.Context, req *system.DictDataAddReq, userId uint64) (err error) {
- err = g.Try(ctx, func(ctx context.Context) {
- _, err = dao.SysDictData.Ctx(ctx).Insert(do.SysDictData{
- DictSort: req.DictSort,
- DictLabel: req.DictLabel,
- DictValue: req.DictValue,
- DictType: req.DictType,
- CssClass: req.CssClass,
- ListClass: req.ListClass,
- IsDefault: req.IsDefault,
- Status: req.Status,
- CreateBy: userId,
- Remark: req.Remark,
- })
- liberr.ErrIsNil(ctx, err, "添加字典数据失败")
- //清除缓存
- service.Cache().RemoveByTag(ctx, consts.CacheSysDictTag)
- })
- return
- }
- // Get 获取字典数据
- func (s *sSysDictData) Get(ctx context.Context, dictCode uint) (res *system.DictDataGetRes, err error) {
- res = new(system.DictDataGetRes)
- err = g.Try(ctx, func(ctx context.Context) {
- err = dao.SysDictData.Ctx(ctx).WherePri(dictCode).Scan(&res.Dict)
- liberr.ErrIsNil(ctx, err, "获取字典数据失败")
- })
- return
- }
- // Edit 修改字典数据
- func (s *sSysDictData) Edit(ctx context.Context, req *system.DictDataEditReq, userId uint64) (err error) {
- err = g.Try(ctx, func(ctx context.Context) {
- _, err = dao.SysDictData.Ctx(ctx).WherePri(req.DictCode).Update(do.SysDictData{
- DictSort: req.DictSort,
- DictLabel: req.DictLabel,
- DictValue: req.DictValue,
- DictType: req.DictType,
- CssClass: req.CssClass,
- ListClass: req.ListClass,
- IsDefault: req.IsDefault,
- Status: req.Status,
- UpdateBy: userId,
- Remark: req.Remark,
- })
- liberr.ErrIsNil(ctx, err, "修改字典数据失败")
- //清除缓存
- service.Cache().RemoveByTag(ctx, consts.CacheSysDictTag)
- })
- return
- }
- // Delete 删除字典数据
- func (s *sSysDictData) Delete(ctx context.Context, ids []int) (err error) {
- err = g.Try(ctx, func(ctx context.Context) {
- _, err = dao.SysDictData.Ctx(ctx).Where(dao.SysDictData.Columns().DictCode+" in(?)", ids).Delete()
- liberr.ErrIsNil(ctx, err, "删除字典数据失败")
- //清除缓存
- service.Cache().RemoveByTag(ctx, consts.CacheSysDictTag)
- })
- return
- }
|