sale_apply_summary.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. package train
  2. import (
  3. "context"
  4. dao "dashoo.cn/micro/app/dao/train"
  5. model "dashoo.cn/micro/app/model/train"
  6. "dashoo.cn/micro/app/service"
  7. "dashoo.cn/opms_libary/myerrors"
  8. "github.com/gogf/gf/database/gdb"
  9. "github.com/gogf/gf/frame/g"
  10. "github.com/gogf/gf/util/gconv"
  11. )
  12. type SaleApplySummaryService struct {
  13. *service.ContextService
  14. Dao *dao.TrainSaleApplySummaryDao
  15. }
  16. func NewSaleApplySummaryService(ctx context.Context) (svc *SaleApplySummaryService, err error) {
  17. svc = new(SaleApplySummaryService)
  18. if svc.ContextService, err = svc.Init(ctx); err != nil {
  19. return nil, err
  20. }
  21. svc.Dao = dao.NewTrainSaleApplySummaryDao(svc.Tenant)
  22. return svc, nil
  23. }
  24. // GetList 销售申请总结信息列表
  25. func (s *SaleApplySummaryService) GetList(ctx context.Context, req *model.TraSaleApplySummarySearchReq) (total int, distributorList []*model.TraSaleApplySummaryRes, err error) {
  26. distributorModel := s.Dao.FieldsEx(s.Dao.C.DeletedTime)
  27. if req.ApplyId != 0 {
  28. distributorModel = distributorModel.Where(s.Dao.C.ApplyId, req.ApplyId)
  29. }
  30. total, _ = distributorModel.Count()
  31. err = distributorModel.Order("id desc").Scan(&distributorList)
  32. if err != nil {
  33. return 0, nil, err
  34. }
  35. return
  36. }
  37. // GetEntityById 详情
  38. func (s *SaleApplySummaryService) GetEntityById(ctx context.Context, id int64) (distributorInfo *model.TraSaleApplySummaryRes, err error) {
  39. err = s.Dao.Where(s.Dao.C.Id, id).Scan(&distributorInfo)
  40. if err != nil {
  41. return nil, err
  42. }
  43. return
  44. }
  45. // CreateSupport
  46. // Create 支持人员反馈创建
  47. func (s *SaleApplySummaryService) CreateSupport(ctx context.Context, req *model.TraSaleSupportReq) (lastId int64, err error) {
  48. DistributorData := new(model.TrainSaleApplySummary)
  49. if err = gconv.Struct(req, DistributorData); err != nil {
  50. return 0, err
  51. }
  52. service.SetCreatedInfo(DistributorData, s.GetCxtUserId(), s.GetCxtUserName())
  53. svc, _ := NewSaleApplyService(ctx)
  54. txerr := s.Dao.DB.Transaction(ctx, func(ctx context.Context, tx *gdb.TX) error {
  55. count, e := s.Dao.Ctx(ctx).TX(tx).Where(s.Dao.C.ApplyId, req.ApplyId).Count()
  56. if e != nil {
  57. return e
  58. }
  59. if count == 0 {
  60. lastId, e = tx.InsertAndGetId("train_sale_apply_summary", DistributorData)
  61. if e != nil {
  62. return e
  63. }
  64. _, e = svc.Dao.Ctx(ctx).TX(tx).WherePri(req.ApplyId).Data(g.Map{svc.Dao.C.ApplyType: "25"}).Update()
  65. if e != nil {
  66. return e
  67. }
  68. } else {
  69. _, e = s.Dao.Ctx(ctx).TX(tx).FieldsEx(s.Dao.C.Id, s.Dao.C.CreatedName, s.Dao.C.CreatedBy, s.Dao.C.CreatedTime).
  70. Where(s.Dao.C.ApplyId, req.ApplyId).
  71. Data(g.Map{s.Dao.C.ApplyId: req.ApplyId, s.Dao.C.WorkOrderId: req.WorkOrderId, s.Dao.C.FeedbackSupportTime: req.FeedbackSupportTime, s.Dao.C.FeedbackSupportContent: req.FeedbackSupportContent}).Update()
  72. if e != nil {
  73. return e
  74. }
  75. _, e = svc.Dao.Ctx(ctx).TX(tx).WherePri(req.ApplyId).Data(g.Map{svc.Dao.C.ApplyType: "40"}).Update()
  76. if e != nil {
  77. return e
  78. }
  79. }
  80. return e
  81. })
  82. if txerr != nil {
  83. return 0, txerr
  84. }
  85. return lastId, nil
  86. }
  87. // Create 销售申请总结创建
  88. func (s *SaleApplySummaryService) Create(ctx context.Context, req *model.TraSaleApplySummaryCreateReq) (lastId int64, err error) {
  89. DistributorData := new(model.TrainSaleApplySummary)
  90. if err = gconv.Struct(req, DistributorData); err != nil {
  91. return 0, err
  92. }
  93. service.SetCreatedInfo(DistributorData, s.GetCxtUserId(), s.GetCxtUserName())
  94. svc, _ := NewSaleApplyService(ctx)
  95. txerr := s.Dao.DB.Transaction(ctx, func(ctx context.Context, tx *gdb.TX) error {
  96. count, e := s.Dao.Ctx(ctx).TX(tx).Where(s.Dao.C.ApplyId, req.ApplyId).Count()
  97. if e != nil {
  98. return e
  99. }
  100. if count == 0 {
  101. lastId, e = tx.InsertAndGetId("train_sale_apply_summary", DistributorData)
  102. if e != nil {
  103. return e
  104. }
  105. _, e = svc.Dao.Ctx(ctx).TX(tx).WherePri(req.ApplyId).Data(g.Map{svc.Dao.C.ApplyType: "30"}).Update()
  106. if e != nil {
  107. return e
  108. }
  109. } else {
  110. _, e = s.Dao.Ctx(ctx).TX(tx).FieldsEx(s.Dao.C.Id, s.Dao.C.CreatedName, s.Dao.C.CreatedBy, s.Dao.C.CreatedTime).
  111. Where(s.Dao.C.ApplyId, req.ApplyId).
  112. Data(g.Map{s.Dao.C.ApplyId: req.ApplyId, s.Dao.C.ExplainDuration: req.ExplainDuration, s.Dao.C.QuestionRecord: req.QuestionRecord, s.Dao.C.TrainSummary: req.TrainSummary, s.Dao.C.NextStep: req.NextStep}).Update()
  113. if e != nil {
  114. return e
  115. }
  116. _, e = svc.Dao.Ctx(ctx).TX(tx).WherePri(req.ApplyId).Data(g.Map{svc.Dao.C.ApplyType: "40"}).Update()
  117. if e != nil {
  118. return e
  119. }
  120. }
  121. return err
  122. })
  123. if txerr != nil {
  124. return 0, txerr
  125. }
  126. return lastId, nil
  127. }
  128. // UpdateById 修改数据
  129. func (s *SaleApplySummaryService) UpdateById(ctx context.Context, req *model.TraSaleApplySummaryUpdateReq) (err error) {
  130. ent, err := s.Dao.Where("id = ", req.Id).One()
  131. if err != nil {
  132. g.Log().Error(err)
  133. return
  134. }
  135. if ent == nil {
  136. err = myerrors.TipsError("无修改数据")
  137. return
  138. }
  139. distData := new(model.TrainSaleApplySummary)
  140. if err = gconv.Struct(req, distData); err != nil {
  141. return
  142. }
  143. service.SetUpdatedInfo(distData, s.GetCxtUserId(), s.GetCxtUserName())
  144. _, err = s.Dao.FieldsEx(s.Dao.C.Id, s.Dao.C.CreatedName, s.Dao.C.CreatedBy, s.Dao.C.CreatedTime).
  145. WherePri(s.Dao.C.Id, req.Id).Update(distData)
  146. if err != nil {
  147. g.Log().Error(err)
  148. return
  149. }
  150. return
  151. }
  152. // DeleteByIds 删除
  153. func (s *SaleApplySummaryService) DeleteByIds(ctx context.Context, ids []int64) (err error) {
  154. _, err = s.Dao.WhereIn(s.Dao.C.Id, ids).Delete()
  155. if err != nil {
  156. return err
  157. }
  158. return
  159. }