sys_dict_data.go 4.1 KB

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