business.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package proj
  2. import (
  3. "context"
  4. "github.com/gogf/gf/database/gdb"
  5. "github.com/gogf/gf/errors/gerror"
  6. "github.com/gogf/gf/frame/g"
  7. "github.com/gogf/gf/util/gconv"
  8. projDao "dashoo.cn/micro/app/dao/proj"
  9. model "dashoo.cn/micro/app/model/proj"
  10. "dashoo.cn/micro/app/service"
  11. )
  12. type businessService struct {
  13. *service.ContextService
  14. Dao *projDao.ProjBusinessDao
  15. }
  16. func NewBusinessService(ctx context.Context) (svc *businessService, err error) {
  17. svc = new(businessService)
  18. if svc.ContextService, err = svc.Init(ctx); err != nil {
  19. return nil, err
  20. }
  21. svc.Dao = projDao.NewProjBusinessDao(svc.Tenant)
  22. return svc, nil
  23. }
  24. func (p *businessService) GetList(req *model.ProjBusinessSearchReq) (total int, businessList []*model.ProjBusiness, err error) {
  25. db := p.Dao.M
  26. if req.NboName != "" {
  27. db = db.WhereLike(p.Dao.Columns.NboName, "%"+req.NboName+"%")
  28. }
  29. if req.CustName != "" {
  30. db = db.WhereLike(p.Dao.Columns.CustName, "%"+req.CustName+"%")
  31. }
  32. if req.SaleName != "" {
  33. db = db.WhereLike(p.Dao.Columns.SaleName, "%"+req.SaleName+"%")
  34. }
  35. if req.NboType != "" {
  36. db = db.Where(p.Dao.Columns.NboType, req.NboType)
  37. }
  38. total, err = db.Count()
  39. if err != nil {
  40. g.Log().Error(err)
  41. err = gerror.New("获取总行数失败")
  42. return
  43. }
  44. err = db.Page(req.PageNum, req.PageSize).Order("id asc").Scan(&businessList)
  45. return
  46. }
  47. func (p *businessService) GetEntityById(id int64) (business *model.ProjBusiness, err error) {
  48. err = p.Dao.Where(projDao.ProjBusiness.Columns.Id, id).Scan(&business)
  49. return
  50. }
  51. func (p *businessService) GetBusinessProduct(id int64) (productList []*model.ProjBusinessProduct, err error) {
  52. productDao := projDao.NewProjBusinessProductDao(p.Tenant)
  53. err = productDao.Where(productDao.ProjBusinessProductDao.Columns.BusId, id).Scan(&productList)
  54. return
  55. }
  56. func (p *businessService) Create(req *model.AddProjBusinessReq) (err error) {
  57. businessData := new(model.ProjBusiness)
  58. if err = gconv.Struct(req, businessData); err != nil {
  59. return
  60. }
  61. products := make([]*model.ProjBusinessProduct, len(req.Products))
  62. if err = gconv.Structs(req.Products, &products); err != nil {
  63. return
  64. }
  65. service.SetCreatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  66. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  67. res, err := p.Dao.TX(tx).Insert(businessData)
  68. if err != nil {
  69. return err
  70. }
  71. lastId, _ := res.LastInsertId()
  72. for _, v := range products {
  73. v.BusId = int(lastId)
  74. v.TotalPrice = v.SellingPrice * v.Quantity
  75. service.SetCreatedInfo(v, p.GetCxtUserId(), p.GetCxtUserName())
  76. }
  77. productDao := projDao.NewProjBusinessProductDao(p.Tenant)
  78. _, err = productDao.TX(tx).Insert(products)
  79. return err
  80. })
  81. return
  82. }
  83. func (p *businessService) UpdateById(req *model.UpdateProjBusinessReq) (err error) {
  84. record, err := p.Dao.Count("Id", req.Id)
  85. if err != nil || record == 0 {
  86. err = gerror.New("该数据不存在")
  87. return err
  88. }
  89. businessData := new(model.ProjBusiness)
  90. if err = gconv.Struct(req, businessData); err != nil {
  91. return
  92. }
  93. service.SetUpdatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  94. _, err = p.Dao.FieldsEx(service.UpdateFieldEx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Update(businessData)
  95. return
  96. }
  97. func (p *businessService) DeleteByIds(ids []int64) (err error) {
  98. _, err = p.Dao.WhereIn(projDao.ProjBusiness.Columns.Id, ids).Delete()
  99. return
  100. }