| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- package base
- import (
- "context"
- "github.com/gogf/gf/frame/g"
- "github.com/gogf/gf/util/gconv"
- "dashoo.cn/micro/app/dao/base"
- model "dashoo.cn/micro/app/model/base"
- "dashoo.cn/micro/app/service"
- )
- type districtService struct {
- *service.ContextService
- Dao *base.BaseDistrictDao
- DetailDao *base.BaseSalesRegionDetailDao
- RegionDao *base.BaseSalesRegionDao
- }
- func NewDistrictService(ctx context.Context) (svc *districtService, err error) {
- svc = new(districtService)
- if svc.ContextService, err = svc.Init(ctx); err != nil {
- return nil, err
- }
- svc.Dao = base.NewBaseDistrictDao(svc.Tenant)
- svc.DetailDao = base.NewBaseSalesRegionDetailDao(svc.Tenant)
- svc.RegionDao = base.NewBaseSalesRegionDao(svc.Tenant)
- return svc, nil
- }
- //ListToTree 所属区域列表
- func (s *districtService) ListToTree(Id int64) (treeList []*model.T, err error) {
- ms := make(map[int]*model.T)
- var distributorList []model.BaseDistrict
- err = s.Dao.Order("parent_id asc").Scan(&distributorList)
- if err != nil {
- g.Log().Error(err)
- return
- }
- for _, v := range distributorList {
- ms[v.Id] = &model.T{
- Id: v.Id,
- ParentId: v.ParentId,
- DistName: v.DistName,
- }
- }
- for _, v := range ms {
- if _, ok := ms[v.ParentId]; ok {
- ms[v.ParentId].Children = append(ms[v.ParentId].Children, v)
- continue
- }
- treeList = append(treeList, v)
- }
- return
- }
- // GetProvinceList 返回所有省份的
- func (s *districtService) GetProvinceList() (list []*model.Province, err error) {
- err = s.Dao.Where(base.BaseDistrict.Columns.ParentId, 0).Scan(&list)
- if err != nil {
- g.Log().Error(err)
- return
- }
- return
- }
- //ListToRegions 区域下所有的省份
- func (s *districtService) ListToRegions() (region []*model.Region, err error) {
- err = s.RegionDao.Fields(s.RegionDao.Columns.RegionDesc, s.RegionDao.Columns.Id).Scan(®ion)
- if err != nil {
- g.Log().Error(err)
- return
- }
- var districtList []int
- for _, v := range region {
- districtList = append(districtList, v.Id)
- }
- list, err := s.Dao.M.As("dis").RightJoin("base_sales_region_detail deftail", "dis.id = deftail.province_code").
- Fields("dis.dist_name,dis.id,deftail.region_id").Where("deftail.region_id in (?)", districtList).All()
- if err != nil {
- g.Log().Error(err)
- return
- }
- ms := make(map[int][]*model.District)
- for _, v := range list.List() {
- ms[gconv.Int(v["region_id"])] = append(ms[gconv.Int(v["region_id"])], &model.District{
- Id: gconv.Int(v["id"]),
- RegionDesc: gconv.String(v["dist_name"]),
- RegionId: gconv.Int(v["region_id"]),
- })
- }
- for _, v := range region {
- v.Children = ms[v.Id]
- }
- g.Log().Info("return", region)
- return
- }
|