sys_dictionary_detail.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. package system
  2. import (
  3. "github.com/flipped-aurora/gin-vue-admin/server/global"
  4. "github.com/flipped-aurora/gin-vue-admin/server/model/system"
  5. "github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
  6. )
  7. //@author: [piexlmax](https://github.com/piexlmax)
  8. //@function: CreateSysDictionaryDetail
  9. //@description: 创建字典详情数据
  10. //@param: sysDictionaryDetail model.SysDictionaryDetail
  11. //@return: err error
  12. type DictionaryDetailService struct{}
  13. var DictionaryDetailServiceApp = new(DictionaryDetailService)
  14. func (dictionaryDetailService *DictionaryDetailService) CreateSysDictionaryDetail(sysDictionaryDetail system.SysDictionaryDetail) (err error) {
  15. err = global.GVA_DB.Create(&sysDictionaryDetail).Error
  16. return err
  17. }
  18. //@author: [piexlmax](https://github.com/piexlmax)
  19. //@function: DeleteSysDictionaryDetail
  20. //@description: 删除字典详情数据
  21. //@param: sysDictionaryDetail model.SysDictionaryDetail
  22. //@return: err error
  23. func (dictionaryDetailService *DictionaryDetailService) DeleteSysDictionaryDetail(sysDictionaryDetail system.SysDictionaryDetail) (err error) {
  24. err = global.GVA_DB.Delete(&sysDictionaryDetail).Error
  25. return err
  26. }
  27. //@author: [piexlmax](https://github.com/piexlmax)
  28. //@function: UpdateSysDictionaryDetail
  29. //@description: 更新字典详情数据
  30. //@param: sysDictionaryDetail *model.SysDictionaryDetail
  31. //@return: err error
  32. func (dictionaryDetailService *DictionaryDetailService) UpdateSysDictionaryDetail(sysDictionaryDetail *system.SysDictionaryDetail) (err error) {
  33. err = global.GVA_DB.Save(sysDictionaryDetail).Error
  34. return err
  35. }
  36. //@author: [piexlmax](https://github.com/piexlmax)
  37. //@function: GetSysDictionaryDetail
  38. //@description: 根据id获取字典详情单条数据
  39. //@param: id uint
  40. //@return: sysDictionaryDetail system.SysDictionaryDetail, err error
  41. func (dictionaryDetailService *DictionaryDetailService) GetSysDictionaryDetail(id uint) (sysDictionaryDetail system.SysDictionaryDetail, err error) {
  42. err = global.GVA_DB.Where("id = ?", id).First(&sysDictionaryDetail).Error
  43. return
  44. }
  45. //@author: [piexlmax](https://github.com/piexlmax)
  46. //@function: GetSysDictionaryDetailInfoList
  47. //@description: 分页获取字典详情列表
  48. //@param: info request.SysDictionaryDetailSearch
  49. //@return: list interface{}, total int64, err error
  50. func (dictionaryDetailService *DictionaryDetailService) GetSysDictionaryDetailInfoList(info request.SysDictionaryDetailSearch) (list interface{}, total int64, err error) {
  51. limit := info.PageSize
  52. offset := info.PageSize * (info.Page - 1)
  53. // 创建db
  54. db := global.GVA_DB.Model(&system.SysDictionaryDetail{})
  55. var sysDictionaryDetails []system.SysDictionaryDetail
  56. // 如果有条件搜索 下方会自动创建搜索语句
  57. if info.Label != "" {
  58. db = db.Where("label LIKE ?", "%"+info.Label+"%")
  59. }
  60. if info.Value != "" {
  61. db = db.Where("value = ?", info.Value)
  62. }
  63. if info.Status != nil {
  64. db = db.Where("status = ?", info.Status)
  65. }
  66. if info.SysDictionaryID != 0 {
  67. db = db.Where("sys_dictionary_id = ?", info.SysDictionaryID)
  68. }
  69. err = db.Count(&total).Error
  70. if err != nil {
  71. return
  72. }
  73. err = db.Limit(limit).Offset(offset).Order("sort").Find(&sysDictionaryDetails).Error
  74. return sysDictionaryDetails, total, err
  75. }
  76. // 按照字典id获取字典全部内容的方法
  77. func (dictionaryDetailService *DictionaryDetailService) GetDictionaryList(dictionaryID uint) (list []system.SysDictionaryDetail, err error) {
  78. var sysDictionaryDetails []system.SysDictionaryDetail
  79. err = global.GVA_DB.Find(&sysDictionaryDetails, "sys_dictionary_id = ?", dictionaryID).Error
  80. return sysDictionaryDetails, err
  81. }
  82. // 按照字典type获取字典全部内容的方法
  83. func (dictionaryDetailService *DictionaryDetailService) GetDictionaryListByType(t string) (list []system.SysDictionaryDetail, err error) {
  84. var sysDictionaryDetails []system.SysDictionaryDetail
  85. db := global.GVA_DB.Model(&system.SysDictionaryDetail{}).Joins("JOIN sys_dictionaries ON sys_dictionaries.id = sys_dictionary_details.sys_dictionary_id")
  86. err = db.Debug().Find(&sysDictionaryDetails, "type = ?", t).Error
  87. return sysDictionaryDetails, err
  88. }
  89. // 按照字典id+字典内容value获取单条字典内容
  90. func (dictionaryDetailService *DictionaryDetailService) GetDictionaryInfoByValue(dictionaryID uint, value string) (detail system.SysDictionaryDetail, err error) {
  91. var sysDictionaryDetail system.SysDictionaryDetail
  92. err = global.GVA_DB.First(&sysDictionaryDetail, "sys_dictionary_id = ? and value = ?", dictionaryID, value).Error
  93. return sysDictionaryDetail, err
  94. }
  95. // 按照字典type+字典内容value获取单条字典内容
  96. func (dictionaryDetailService *DictionaryDetailService) GetDictionaryInfoByTypeValue(t string, value string) (detail system.SysDictionaryDetail, err error) {
  97. var sysDictionaryDetails system.SysDictionaryDetail
  98. db := global.GVA_DB.Model(&system.SysDictionaryDetail{}).Joins("JOIN sys_dictionaries ON sys_dictionaries.id = sys_dictionary_details.sys_dictionary_id")
  99. err = db.First(&sysDictionaryDetails, "sys_dictionaries.type = ? and sys_dictionary_details.value = ?", t, value).Error
  100. return sysDictionaryDetails, err
  101. }