| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- package service
- import (
- "dashoo.cn/micro/app/common/global"
- comModel "dashoo.cn/micro/app/common/model"
- comService "dashoo.cn/micro/app/common/service"
- "dashoo.cn/micro/app/dao"
- "dashoo.cn/micro/app/model"
- "database/sql"
- "github.com/gogf/gf/errors/gerror"
- "github.com/gogf/gf/frame/g"
- "github.com/gogf/gf/text/gstr"
- "github.com/gogf/gf/util/gconv"
- )
- type sysDictData struct{}
- var SysDictData = new(sysDictData)
- func (s sysDictData) DictDataList(req *model.SelectDictPageReq) (total, page int, list []*model.SysDictData, err error) {
- d := dao.SysDictData.Ctx(req.Ctx)
- if req != nil {
- if req.DictLabel != "" {
- d = d.Where(dao.SysDictData.Columns.DictLabel+" like ?", "%"+req.DictLabel+"%")
- }
- if req.Status != "" {
- d = d.Where(dao.SysDictData.Columns.Status+" = ", gconv.Int(req.Status))
- }
- if req.DictType != "" {
- d = d.Where(dao.SysDictData.Columns.DictType+" = ?", req.DictType)
- }
- total, err = d.Count()
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("获取总行数失败")
- return
- }
- if req.PageNum == 0 {
- req.PageNum = 1
- }
- }
- page = req.PageNum
- if req.PageSize == 0 {
- req.PageSize = comModel.PageSize
- }
- list, err = d.Page(page, req.PageSize).Order(dao.SysDictData.Columns.DictSort + " asc," +
- dao.SysDictData.Columns.DictCode + " asc").All()
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("获取数据失败")
- return
- }
- return
- }
- // GetDictWithDataByType 通过字典键类型获取选项
- func (s sysDictData) GetDictWithDataByType(req *model.GetDictReq) (dict *model.DictRes, err error) {
- cache := comService.Cache.New()
- cacheKey := global.SysDict + "_" + req.DictType
- //从缓存获取
- iDict := cache.Get(cacheKey)
- if iDict != nil {
- err = gconv.Struct(iDict, &dict)
- if err != nil {
- return
- }
- } else {
- //从数据库获取
- dict = &model.DictRes{}
- //获取类型数据
- err = dao.SysDictType.Ctx(req.Ctx).Where(dao.SysDictType.Columns.DictType, req.DictType).
- And(dao.SysDictType.Columns.Status, 1).Fields(model.DictTypeRes{}).Scan(&dict.Info)
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("获取字典类型失败")
- }
- err = dao.SysDictData.Ctx(req.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)
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("获取字典数据失败")
- }
- //缓存菜单
- if dict.Info != nil && dict.Values != nil {
- cache.Set(cacheKey, dict, 0, global.SysDictTag)
- }
- }
- //设置给定的默认值
- for _, v := range dict.Values {
- if req.DefaultValue != "" {
- if gstr.Equal(req.DefaultValue, v.DictValue) {
- v.IsDefault = 1
- } else {
- v.IsDefault = 0
- }
- }
- }
- return
- }
- // CheckDictTypeUniqueAll 检查字典类型是否唯一
- func (s *sysDictData) CheckDictTypeUniqueAll(dictType string) bool {
- dict, err := dao.SysDictData.FindOne(dao.SysDictData.Columns.DictType+"=?", dictType)
- if err != nil {
- g.Log().Error(err)
- return false
- }
- if dict != nil {
- return false
- }
- return true
- }
- // AddSave 添加保存字典数据
- func (s *sysDictData) AddSave(req *model.DictDataAddReq) (id int64, err error) {
- var res sql.Result
- res, err = dao.SysDictData.Data(req).Insert()
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("添加字典数据失败")
- return
- }
- id, err = res.LastInsertId()
- return
- }
- // GetDictDataById 通过字典数据id获取字典数据
- func (s sysDictData) GetDictDataById(id int) (data *model.SysDictData, err error) {
- data, err = dao.SysDictData.FindOne(dao.SysDictData.Columns.DictCode, id)
- if err != nil {
- g.Log().Error(err)
- err = gerror.New("获取字典数据失败")
- return
- }
- if data == nil {
- err = gerror.New("获取字典数据失败")
- }
- return
- }
- // EditSaveData 修改字典数据
- func (s sysDictData) EditSaveData(req *model.EditDictDataReq) (err error) {
- _, err = dao.SysDictData.FieldsEx(dao.SysDictData.Columns.DictCode, dao.SysDictData.Columns.CreatedBy).
- WherePri(req.DictCode).Update(req)
- return
- }
- // DeleteDictDataByIds 删除字典数据
- func (s sysDictData) DeleteDictDataByIds(ids []int) error {
- _, err := dao.SysDictData.Where(dao.SysDictData.Columns.DictCode+" in(?)", ids).Delete()
- if err != nil {
- g.Log().Error(err)
- return gerror.New("删除失败")
- }
- return nil
- }
|