base_sales_region_detail.go 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. package base
  2. import (
  3. "context"
  4. "github.com/gogf/gf/errors/gerror"
  5. "github.com/gogf/gf/frame/g"
  6. "github.com/gogf/gf/os/gtime"
  7. "github.com/gogf/gf/util/gconv"
  8. "dashoo.cn/micro/app/dao/base"
  9. "dashoo.cn/micro/app/dao/cust"
  10. model "dashoo.cn/micro/app/model/base"
  11. "dashoo.cn/micro/app/service"
  12. )
  13. var EgionDetailFieldEx = []interface{}{
  14. "id", "created_by",
  15. "created_name",
  16. "created_time",
  17. "province_code",
  18. "remark",
  19. "updated_by",
  20. "updated_name",
  21. "updated_time",
  22. }
  23. type salesRegionDetailService struct {
  24. *service.ContextService
  25. Dao *base.BaseSalesRegionDetailDao
  26. District *base.BaseDistrictDao
  27. CustomerDao *cust.CustCustomerDao
  28. }
  29. func NewSalesRegionDetailService(ctx context.Context) (svc *salesRegionDetailService, err error) {
  30. svc = new(salesRegionDetailService)
  31. if svc.ContextService, err = svc.Init(ctx); err != nil {
  32. return nil, err
  33. }
  34. svc.Dao = base.NewBaseSalesRegionDetailDao(svc.Tenant)
  35. svc.District = base.NewBaseDistrictDao(svc.Tenant)
  36. svc.CustomerDao = cust.NewCustCustomerDao(svc.Tenant)
  37. return svc, nil
  38. }
  39. func (p *salesRegionDetailService) GetList(req *model.SecBaseRegionDetailReq) (total int, RegionList []*model.BaseRegionDetailRep, err error) {
  40. Model := p.Dao.M
  41. Model = Model.Where(p.Dao.Columns.RegionId, req.RegionId).Where(p.Dao.Columns.DeletedTime + " is null")
  42. total, err = Model.Count()
  43. if err != nil {
  44. g.Log().Error(err)
  45. err = gerror.New("获取总行数失败")
  46. return
  47. }
  48. if req.PageNum == 0 {
  49. req.PageNum = 1
  50. }
  51. err = Model.Page(req.PageNum, req.PageSize).Order("id asc").Scan(&RegionList)
  52. if err != nil {
  53. g.Log().Error(err)
  54. err = gerror.New("获取数据失败")
  55. return
  56. }
  57. var districtList []int
  58. for _, v := range RegionList {
  59. districtList = append(districtList, v.ProvinceCode)
  60. }
  61. CustModel := p.CustomerDao.M
  62. CustModel = CustModel.Fields("count(*) as count,cust_dist_code").Where("cust_dist_code in (?)", districtList)
  63. if req.CustName != "" {
  64. g.Log().Info("custName", req.CustName)
  65. CustModel = CustModel.Where(p.CustomerDao.Columns.CustName+" like ?", "%"+req.CustName+"%")
  66. }
  67. if req.CustCode != "" {
  68. g.Log().Info("客户编码搜索", req)
  69. CustModel = CustModel.Where(p.CustomerDao.Columns.CustCode+" like ?", "%"+req.CustCode+"%")
  70. }
  71. if req.CustIndustry != "" {
  72. CustModel = CustModel.Where(p.CustomerDao.Columns.CustIndustry+" like ?", "%"+req.CustIndustry+"%")
  73. }
  74. total, err = Model.Fields().Count()
  75. dist, _ := p.District.M.Fields("dist_name,dist_code").Where("dist_code in (?)", districtList).All()
  76. custDist, _ := CustModel.Group("cust_dist_code").All()
  77. for _, v := range RegionList {
  78. for _, v2 := range dist {
  79. if v.ProvinceCode == gconv.Int(v2["dist_code"]) {
  80. v.DistName = gconv.String(v2["dist_name"])
  81. }
  82. }
  83. for _, v3 := range custDist {
  84. if v.ProvinceCode == gconv.Int(v3["cust_dist_code"]) {
  85. v.Count = gconv.Int(v3["count"])
  86. }
  87. }
  88. }
  89. g.Log().Info("List", RegionList)
  90. return
  91. }
  92. //创建区域
  93. func (p *salesRegionDetailService) Create(req *model.AddBaseRegionDetailReq) (err error) {
  94. Model := p.Dao.M
  95. detailData := new(model.BaseSalesRegionDetail)
  96. if err = gconv.Struct(req, detailData); err != nil {
  97. return
  98. }
  99. detailData.RegionId = req.RegionId
  100. detailData.ProvinceCode = req.ProvinceCode
  101. service.SetCreatedInfo(detailData, p.GetCxtUserId(), p.GetCxtUserName())
  102. _, err = Model.Insert(detailData)
  103. if err != nil {
  104. return err
  105. }
  106. return nil
  107. }
  108. //更新
  109. func (p *salesRegionDetailService) UpdateById(req *model.UpdateBaseRegionDetailReq) (err error) {
  110. //uptime := gtime.New(time.Now())
  111. db := p.Dao.M
  112. record, err := db.FindOne("Id", req.Id)
  113. if err != nil || record.IsEmpty() {
  114. err = gerror.New("该数据不存在")
  115. return err
  116. }
  117. productData := new(model.BaseSalesRegionDetail)
  118. if err = gconv.Struct(req, productData); err != nil {
  119. return
  120. }
  121. service.SetUpdatedInfo(productData, p.GetCxtUserId(), p.GetCxtUserName())
  122. _, err = db.FieldsEx(base.BaseSalesRegionDetail.Columns.CreatedTime, base.BaseSalesRegionDetail.Columns.CreatedBy, base.BaseSalesRegionDetail.Columns.CreatedName).
  123. WherePri(base.BaseSalesRegionDetail.Columns.Id, req.Id).Update(productData)
  124. if err != nil {
  125. g.Log().Error(err)
  126. err = gerror.New("修改信息失败")
  127. return
  128. }
  129. return
  130. }
  131. //删除
  132. func (p *salesRegionDetailService) DeleteById(req int) (err error) {
  133. Model := p.Dao.M
  134. regionDetail := new(model.BaseSalesRegionDetail)
  135. err = Model.Where(p.Dao.Columns.Id, req).Scan(&regionDetail)
  136. //g.Log().Info("DeleteByIds", one)
  137. if err != nil {
  138. g.Log().Error(err)
  139. err = gerror.New("没有要删除的数据")
  140. return
  141. }
  142. regionDetail.DeletedTime = gtime.Now()
  143. _, err = Model.FieldsEx(EgionDetailFieldEx).
  144. WherePri(p.Dao.Columns.Id, req).Update(regionDetail)
  145. if err != nil {
  146. g.Log().Error(err)
  147. err = gerror.New("删除数据失败")
  148. return err
  149. }
  150. return
  151. }
  152. //省份客户
  153. //func (p *salesRegionDetailService) GetCustomerList(distributor []string) (list []*model.BaseRegionCustomer, err error) {
  154. // Model := p.CustomerDao.M
  155. // Model.Where("cust_location", "%%")
  156. //
  157. // //if req.CustName != "" {
  158. // // Model = Model.Where("cust_name ", req.CustName)
  159. // //}
  160. // ////客户编码
  161. // //if req.CustCode != "" {
  162. // // Model = Model.Where("cust_name ", req.CustCode)
  163. // //}
  164. // //err = Model.Fields("count(*) counts").Page(req.PageNum, req.PageSize).Order("id desc").Scan($list)
  165. // return
  166. //}