2021-07-17 06:18:52 +00:00
|
|
|
|
package system
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
|
|
|
|
|
import (
|
2020-06-28 13:23:06 +00:00
|
|
|
|
"errors"
|
2021-08-21 03:01:34 +00:00
|
|
|
|
|
2025-10-19 05:27:48 +00:00
|
|
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/system/request"
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
|
|
2021-08-23 15:13:24 +00:00
|
|
|
|
"github.com/flipped-aurora/gin-vue-admin/server/global"
|
|
|
|
|
|
"github.com/flipped-aurora/gin-vue-admin/server/model/system"
|
2020-08-23 07:13:23 +00:00
|
|
|
|
"gorm.io/gorm"
|
2020-06-24 12:41:36 +00:00
|
|
|
|
)
|
|
|
|
|
|
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
2024-06-05 12:30:08 +00:00
|
|
|
|
//@function: CreateSysDictionary
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@description: 创建字典数据
|
|
|
|
|
|
//@param: sysDictionary model.SysDictionary
|
|
|
|
|
|
//@return: err error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
2021-12-06 04:44:26 +00:00
|
|
|
|
type DictionaryService struct{}
|
2021-07-17 06:18:52 +00:00
|
|
|
|
|
2024-07-21 03:33:25 +00:00
|
|
|
|
var DictionaryServiceApp = new(DictionaryService)
|
|
|
|
|
|
|
2021-07-17 06:18:52 +00:00
|
|
|
|
func (dictionaryService *DictionaryService) CreateSysDictionary(sysDictionary system.SysDictionary) (err error) {
|
2021-07-16 12:08:11 +00:00
|
|
|
|
if (!errors.Is(global.GVA_DB.First(&system.SysDictionary{}, "type = ?", sysDictionary.Type).Error, gorm.ErrRecordNotFound)) {
|
2020-06-28 13:23:06 +00:00
|
|
|
|
return errors.New("存在相同的type,不允许创建")
|
|
|
|
|
|
}
|
2020-11-23 04:02:18 +00:00
|
|
|
|
err = global.GVA_DB.Create(&sysDictionary).Error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
|
|
|
|
//@function: DeleteSysDictionary
|
|
|
|
|
|
//@description: 删除字典数据
|
|
|
|
|
|
//@param: sysDictionary model.SysDictionary
|
|
|
|
|
|
//@return: err error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
2021-07-17 06:18:52 +00:00
|
|
|
|
func (dictionaryService *DictionaryService) DeleteSysDictionary(sysDictionary system.SysDictionary) (err error) {
|
2022-01-14 04:11:49 +00:00
|
|
|
|
err = global.GVA_DB.Where("id = ?", sysDictionary.ID).Preload("SysDictionaryDetails").First(&sysDictionary).Error
|
|
|
|
|
|
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
|
|
|
|
|
|
return errors.New("请不要搞事")
|
|
|
|
|
|
}
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
err = global.GVA_DB.Delete(&sysDictionary).Error
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-03-24 02:28:19 +00:00
|
|
|
|
if sysDictionary.SysDictionaryDetails != nil {
|
|
|
|
|
|
return global.GVA_DB.Where("sys_dictionary_id=?", sysDictionary.ID).Delete(sysDictionary.SysDictionaryDetails).Error
|
|
|
|
|
|
}
|
|
|
|
|
|
return
|
2020-06-24 12:41:36 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
|
|
|
|
//@function: UpdateSysDictionary
|
|
|
|
|
|
//@description: 更新字典数据
|
|
|
|
|
|
//@param: sysDictionary *model.SysDictionary
|
|
|
|
|
|
//@return: err error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
2021-07-17 06:18:52 +00:00
|
|
|
|
func (dictionaryService *DictionaryService) UpdateSysDictionary(sysDictionary *system.SysDictionary) (err error) {
|
2021-07-16 12:08:11 +00:00
|
|
|
|
var dict system.SysDictionary
|
2020-06-24 13:53:54 +00:00
|
|
|
|
sysDictionaryMap := map[string]interface{}{
|
2025-10-19 05:27:48 +00:00
|
|
|
|
"Name": sysDictionary.Name,
|
|
|
|
|
|
"Type": sysDictionary.Type,
|
|
|
|
|
|
"Status": sysDictionary.Status,
|
|
|
|
|
|
"Desc": sysDictionary.Desc,
|
|
|
|
|
|
"ParentID": sysDictionary.ParentID,
|
2020-06-24 13:53:54 +00:00
|
|
|
|
}
|
2024-04-13 10:46:58 +00:00
|
|
|
|
err = global.GVA_DB.Where("id = ?", sysDictionary.ID).First(&dict).Error
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
global.GVA_LOG.Debug(err.Error())
|
|
|
|
|
|
return errors.New("查询字典数据失败")
|
|
|
|
|
|
}
|
2021-09-04 14:59:13 +00:00
|
|
|
|
if dict.Type != sysDictionary.Type {
|
|
|
|
|
|
if !errors.Is(global.GVA_DB.First(&system.SysDictionary{}, "type = ?", sysDictionary.Type).Error, gorm.ErrRecordNotFound) {
|
2020-06-28 13:23:06 +00:00
|
|
|
|
return errors.New("存在相同的type,不允许创建")
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-10-19 05:27:48 +00:00
|
|
|
|
|
|
|
|
|
|
// 检查是否会形成循环引用
|
|
|
|
|
|
if sysDictionary.ParentID != nil && *sysDictionary.ParentID != 0 {
|
|
|
|
|
|
if err := dictionaryService.checkCircularReference(sysDictionary.ID, *sysDictionary.ParentID); err != nil {
|
|
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-04-13 10:46:58 +00:00
|
|
|
|
err = global.GVA_DB.Model(&dict).Updates(sysDictionaryMap).Error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
|
|
|
|
//@function: GetSysDictionary
|
|
|
|
|
|
//@description: 根据id或者type获取字典单条数据
|
|
|
|
|
|
//@param: Type string, Id uint
|
|
|
|
|
|
//@return: err error, sysDictionary model.SysDictionary
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
2022-06-12 12:23:08 +00:00
|
|
|
|
func (dictionaryService *DictionaryService) GetSysDictionary(Type string, Id uint, status *bool) (sysDictionary system.SysDictionary, err error) {
|
|
|
|
|
|
var flag = false
|
|
|
|
|
|
if status == nil {
|
|
|
|
|
|
flag = true
|
|
|
|
|
|
} else {
|
|
|
|
|
|
flag = *status
|
|
|
|
|
|
}
|
2023-03-25 12:04:05 +00:00
|
|
|
|
err = global.GVA_DB.Where("(type = ? OR id = ?) and status = ?", Type, Id, flag).Preload("SysDictionaryDetails", func(db *gorm.DB) *gorm.DB {
|
2025-10-19 05:27:48 +00:00
|
|
|
|
return db.Where("status = ? and deleted_at is null", true).Order("sort")
|
2023-03-25 12:04:05 +00:00
|
|
|
|
}).First(&sysDictionary).Error
|
2020-06-24 12:41:36 +00:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2020-11-08 05:30:12 +00:00
|
|
|
|
//@author: [piexlmax](https://github.com/piexlmax)
|
|
|
|
|
|
//@author: [SliverHorn](https://github.com/SliverHorn)
|
|
|
|
|
|
//@function: GetSysDictionaryInfoList
|
|
|
|
|
|
//@description: 分页获取字典列表
|
|
|
|
|
|
//@param: info request.SysDictionarySearch
|
|
|
|
|
|
//@return: err error, list interface{}, total int64
|
2020-06-24 12:41:36 +00:00
|
|
|
|
|
2025-10-19 05:27:48 +00:00
|
|
|
|
func (dictionaryService *DictionaryService) GetSysDictionaryInfoList(c *gin.Context, req request.SysDictionarySearch) (list interface{}, err error) {
|
2021-07-16 12:08:11 +00:00
|
|
|
|
var sysDictionarys []system.SysDictionary
|
2025-10-19 05:27:48 +00:00
|
|
|
|
query := global.GVA_DB.WithContext(c)
|
|
|
|
|
|
if req.Name != "" {
|
|
|
|
|
|
query = query.Where("name LIKE ? OR type LIKE ?", "%"+req.Name+"%", "%"+req.Name+"%")
|
|
|
|
|
|
}
|
|
|
|
|
|
// 预加载子字典
|
|
|
|
|
|
query = query.Preload("Children")
|
|
|
|
|
|
err = query.Find(&sysDictionarys).Error
|
2023-10-22 12:52:52 +00:00
|
|
|
|
return sysDictionarys, err
|
2020-06-24 13:53:54 +00:00
|
|
|
|
}
|
2025-10-19 05:27:48 +00:00
|
|
|
|
|
|
|
|
|
|
// checkCircularReference 检查是否会形成循环引用
|
|
|
|
|
|
func (dictionaryService *DictionaryService) checkCircularReference(currentID uint, parentID uint) error {
|
|
|
|
|
|
if currentID == parentID {
|
|
|
|
|
|
return errors.New("不能将字典设置为自己的父级")
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 递归检查父级链条
|
|
|
|
|
|
var parent system.SysDictionary
|
|
|
|
|
|
err := global.GVA_DB.Where("id = ?", parentID).First(&parent).Error
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
if errors.Is(err, gorm.ErrRecordNotFound) {
|
|
|
|
|
|
return nil // 父级不存在,允许设置
|
|
|
|
|
|
}
|
|
|
|
|
|
return err
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 如果父级还有父级,继续检查
|
|
|
|
|
|
if parent.ParentID != nil && *parent.ParentID != 0 {
|
|
|
|
|
|
return dictionaryService.checkCircularReference(currentID, *parent.ParentID)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
|
}
|