base_district.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package base
  2. import (
  3. "context"
  4. "github.com/gogf/gf/frame/g"
  5. "github.com/gogf/gf/util/gconv"
  6. "dashoo.cn/micro/app/dao/base"
  7. model "dashoo.cn/micro/app/model/base"
  8. "dashoo.cn/micro/app/service"
  9. )
  10. type districtService struct {
  11. *service.ContextService
  12. Dao *base.BaseDistrictDao
  13. DetailDao *base.BaseSalesRegionDetailDao
  14. RegionDao *base.BaseSalesRegionDao
  15. }
  16. func NewDistrictService(ctx context.Context) (svc *districtService, err error) {
  17. svc = new(districtService)
  18. if svc.ContextService, err = svc.Init(ctx); err != nil {
  19. return nil, err
  20. }
  21. svc.Dao = base.NewBaseDistrictDao(svc.Tenant)
  22. svc.DetailDao = base.NewBaseSalesRegionDetailDao(svc.Tenant)
  23. svc.RegionDao = base.NewBaseSalesRegionDao(svc.Tenant)
  24. return svc, nil
  25. }
  26. //ListToTree 所属区域列表
  27. func (s *districtService) ListToTree(Id int64) (treeList []*model.T, err error) {
  28. ms := make(map[int]*model.T)
  29. var distributorList []model.BaseDistrict
  30. err = s.Dao.Order("parent_id asc").Scan(&distributorList)
  31. if err != nil {
  32. g.Log().Error(err)
  33. return
  34. }
  35. for _, v := range distributorList {
  36. ms[v.Id] = &model.T{
  37. Id: v.Id,
  38. ParentId: v.ParentId,
  39. DistName: v.DistName,
  40. }
  41. }
  42. for _, v := range ms {
  43. if _, ok := ms[v.ParentId]; ok {
  44. ms[v.ParentId].Children = append(ms[v.ParentId].Children, v)
  45. continue
  46. }
  47. treeList = append(treeList, v)
  48. }
  49. return
  50. }
  51. // GetProvinceList 返回所有省份的
  52. func (s *districtService) GetProvinceList() (list []*model.Province, err error) {
  53. err = s.Dao.Where(base.BaseDistrict.Columns.ParentId, 0).Scan(&list)
  54. if err != nil {
  55. g.Log().Error(err)
  56. return
  57. }
  58. return
  59. }
  60. //ListToRegions 区域下所有的省份
  61. func (s *districtService) ListToRegions() (region []*model.Region, err error) {
  62. err = s.RegionDao.Fields(s.RegionDao.Columns.RegionDesc, s.RegionDao.Columns.Id).Scan(&region)
  63. if err != nil {
  64. g.Log().Error(err)
  65. return
  66. }
  67. var districtList []int
  68. for _, v := range region {
  69. districtList = append(districtList, v.Id)
  70. }
  71. list, err := s.Dao.M.As("dis").RightJoin("base_sales_region_detail deftail", "dis.id = deftail.province_code").
  72. Fields("dis.dist_name,dis.id,deftail.region_id").Where("deftail.region_id in (?)", districtList).All()
  73. if err != nil {
  74. g.Log().Error(err)
  75. return
  76. }
  77. ms := make(map[int][]*model.District)
  78. for _, v := range list.List() {
  79. ms[gconv.Int(v["region_id"])] = append(ms[gconv.Int(v["region_id"])], &model.District{
  80. Id: gconv.Int(v["id"]),
  81. RegionDesc: gconv.String(v["dist_name"]),
  82. RegionId: gconv.Int(v["region_id"]),
  83. })
  84. }
  85. for _, v := range region {
  86. v.Children = ms[v.Id]
  87. }
  88. g.Log().Info("return", region)
  89. return
  90. }