sys_dict_data.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. package service
  2. import (
  3. "context"
  4. "dashoo.cn/micro/app/common/global"
  5. comService "dashoo.cn/micro/app/common/service"
  6. "dashoo.cn/micro/app/dao"
  7. "dashoo.cn/micro/app/model"
  8. "database/sql"
  9. "github.com/gogf/gf/errors/gerror"
  10. "github.com/gogf/gf/frame/g"
  11. "github.com/gogf/gf/text/gstr"
  12. "github.com/gogf/gf/util/gconv"
  13. )
  14. type dictDataService struct {
  15. *contextService
  16. Dao *dao.SysDictTypeDao
  17. }
  18. func NewDictDataService(ctx context.Context) (svc *dictDataService, err error) {
  19. svc = new(dictDataService)
  20. if svc.contextService, err = svc.Init(ctx); err != nil {
  21. return nil, err
  22. }
  23. svc.Dao = dao.NewSysDictTypeDao(svc.Tenant)
  24. return svc, nil
  25. }
  26. func (s *dictDataService) GetDictDataList(req *model.SelectDictPageReq) (total int, list []*model.SysDictData, err error) {
  27. d := dao.SysDictData.Ctx(req.Ctx)
  28. if req != nil {
  29. if req.DictLabel != "" {
  30. d = d.Where(dao.SysDictData.Columns.DictLabel+" like ?", "%"+req.DictLabel+"%")
  31. }
  32. if req.Status != "" {
  33. d = d.Where(dao.SysDictData.Columns.Status+" = ", gconv.Int(req.Status))
  34. }
  35. if req.DictType != "" {
  36. d = d.Where(dao.SysDictData.Columns.DictType+" = ?", req.DictType)
  37. }
  38. total, err = d.Count()
  39. if err != nil {
  40. g.Log().Error(err)
  41. err = gerror.New("获取总行数失败")
  42. return
  43. }
  44. if req.PageNum == 0 {
  45. req.PageNum = 1
  46. }
  47. }
  48. list, err = d.Page(req.GetPage()).Order(dao.SysDictData.Columns.DictSort + " asc," +
  49. dao.SysDictData.Columns.DictCode + " asc").All()
  50. if err != nil {
  51. g.Log().Error(err)
  52. err = gerror.New("获取数据失败")
  53. return
  54. }
  55. return
  56. }
  57. // GetDictDataById 通过字典数据id获取字典数据
  58. func (s *dictDataService) GetDictDataById(id int64) (data *model.SysDictData, err error) {
  59. data, err = dao.SysDictData.FindOne(dao.SysDictData.Columns.DictCode, id)
  60. if err != nil {
  61. g.Log().Error(err)
  62. err = gerror.New("获取字典数据失败")
  63. return
  64. }
  65. if data == nil {
  66. err = gerror.New("获取字典数据失败")
  67. }
  68. return
  69. }
  70. // GetDictWithDataByType 通过字典键类型获取选项
  71. func (s *dictDataService) GetDictWithDataByType(req *model.GetDictReq) (dict *model.DictRes, err error) {
  72. cache := comService.Cache.New()
  73. cacheKey := global.SysDict + "_" + req.DictType
  74. //从缓存获取
  75. iDict := cache.Get(cacheKey)
  76. if iDict != nil {
  77. err = gconv.Struct(iDict, &dict)
  78. if err != nil {
  79. return
  80. }
  81. } else {
  82. //从数据库获取
  83. dict = &model.DictRes{}
  84. //获取类型数据
  85. err = dao.SysDictType.Ctx(req.Ctx).Where(dao.SysDictType.Columns.DictType, req.DictType).
  86. And(dao.SysDictType.Columns.Status, 1).Fields(model.DictTypeRes{}).Scan(&dict.Info)
  87. if err != nil {
  88. g.Log().Error(err)
  89. err = gerror.New("获取字典类型失败")
  90. }
  91. err = dao.SysDictData.Ctx(req.Ctx).Fields(model.DictDataRes{}).
  92. Where(dao.SysDictData.Columns.DictType, req.DictType).
  93. Order(dao.SysDictData.Columns.DictSort + " asc," +
  94. dao.SysDictData.Columns.DictCode + " asc").
  95. Scan(&dict.Values)
  96. if err != nil {
  97. g.Log().Error(err)
  98. err = gerror.New("获取字典数据失败")
  99. }
  100. //缓存菜单
  101. if dict.Info != nil && dict.Values != nil {
  102. cache.Set(cacheKey, dict, 0, global.SysDictTag)
  103. }
  104. }
  105. //设置给定的默认值
  106. for _, v := range dict.Values {
  107. if req.DefaultValue != "" {
  108. if gstr.Equal(req.DefaultValue, v.DictValue) {
  109. v.IsDefault = 1
  110. } else {
  111. v.IsDefault = 0
  112. }
  113. }
  114. }
  115. return
  116. }
  117. // CheckDictTypeUniqueAll 检查字典类型是否唯一
  118. func (s *dictDataService) CheckDictTypeUniqueAll(dictType string) bool {
  119. dict, err := dao.SysDictData.FindOne(dao.SysDictData.Columns.DictType+"=?", dictType)
  120. if err != nil {
  121. g.Log().Error(err)
  122. return false
  123. }
  124. if dict != nil {
  125. return false
  126. }
  127. return true
  128. }
  129. // Create 添加保存字典数据
  130. func (s *dictDataService) Create(req *model.DictDataAddReq) (id int64, err error) {
  131. var res sql.Result
  132. data := new(model.SysDictData)
  133. if err := gconv.Struct(req, data); err != nil {
  134. return -1, err
  135. }
  136. SetCreatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
  137. res, err = dao.SysDictData.Data(data).Insert()
  138. if err != nil {
  139. g.Log().Error(err)
  140. err = gerror.New("添加字典数据失败")
  141. return
  142. }
  143. id, err = res.LastInsertId()
  144. return
  145. }
  146. // UpdateByDict 修改字典数据
  147. func (s *dictDataService) UpdateByDict(req *model.EditDictDataReq) (err error) {
  148. data := new(model.SysDictData)
  149. if err := gconv.Struct(req, data); err != nil {
  150. return err
  151. }
  152. SetUpdatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
  153. updateFieldEx := append(CommonUpdateFieldEx, dao.SysDictData.Columns.DictCode)
  154. _, err = dao.SysDictData.FieldsEx(updateFieldEx...).WherePri(req.DictCode).Update(data)
  155. return
  156. }
  157. // DeleteDictDataByIds 删除字典数据
  158. func (s *dictDataService) DeleteDictDataByIds(ids []int64) error {
  159. _, err := dao.SysDictData.Where(dao.SysDictData.Columns.DictCode+" in(?)", ids).Delete()
  160. if err != nil {
  161. g.Log().Error(err)
  162. return gerror.New("删除失败")
  163. }
  164. return nil
  165. }