settle_account_main.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. package settle_account_main
  2. import (
  3. "dashoo.cn/micro_libary/request"
  4. "errors"
  5. "fmt"
  6. "github.com/gogf/gf/os/gtime"
  7. "github.com/gogf/gf/util/gconv"
  8. "lims_adapter/dao/account"
  9. "lims_adapter/model"
  10. accountModel "lims_adapter/model/account"
  11. )
  12. // Service 会议室服务
  13. type Service struct {
  14. Dao *account.SettleAccountMainDao
  15. Tenant string
  16. }
  17. // NewSrv 服务初始化
  18. func NewService(tenant string) Service {
  19. return Service{Dao: account.NewSettleAccountMainDao(tenant), Tenant: tenant}
  20. }
  21. // List 会议室列表
  22. func (s Service) List(req model.ListReq) ([]accountModel.SettleAccountMain, int, error) {
  23. entityModel := s.Dao.M
  24. where := "1=1"
  25. if req.Entity != nil {
  26. entity := new(accountModel.SettleAccountMainReq)
  27. err := gconv.Struct(req.Entity, entity)
  28. if err != nil {
  29. return nil, 0, err
  30. }
  31. if entity.MainUserId != 0 {
  32. where += fmt.Sprintf(" AND MainUserId='%v'", entity.MainUserId)
  33. }
  34. if entity.AttachUserId != 0 {
  35. where += fmt.Sprintf(" AND AttachUserId='%v'", entity.AttachUserId)
  36. }
  37. if entity.InstrumentId != 0 {
  38. where += fmt.Sprintf(" AND InstrumentId='%v'", entity.InstrumentId)
  39. }
  40. if entity.Status != "" {
  41. where += fmt.Sprintf(" AND Status='%v'", entity.Status)
  42. }
  43. if entity.SettleStatus != "" {
  44. where += fmt.Sprintf(" AND SettleStatus='%v'", entity.SettleStatus)
  45. }
  46. if entity.FeeType != "" {
  47. where += fmt.Sprintf(" AND FeeType='%v'", entity.FeeType)
  48. }
  49. }
  50. entityModel = entityModel.Where(where)
  51. total, err := entityModel.Count()
  52. if err != nil {
  53. return nil, 0, err
  54. }
  55. if total == 0 {
  56. return nil, 0, nil
  57. }
  58. res, err := entityModel.Page(req.Current, req.Size).Order("settle_account_main.CreateOn DESC").Fields("settle_account_main.*").FindAll()
  59. if err != nil {
  60. return nil, 0, err
  61. }
  62. if res.IsEmpty() {
  63. return nil, 0, nil
  64. }
  65. list := make([]accountModel.SettleAccountMain, 0)
  66. err = res.Structs(&list)
  67. if err != nil {
  68. return nil, 0, err
  69. }
  70. return list, total, nil
  71. }
  72. // 新增
  73. func (s Service) Add(req accountModel.AccountMainAddReq, user request.UserInfo) error {
  74. now := gtime.Now() // 获取当前时间
  75. // 更新必要信息
  76. req.Main.CreateUserId = int(user.Id)
  77. req.Main.CreateBy = user.RealName
  78. req.Main.CreateOn = now
  79. req.Main.UpdateUserId = int(user.Id)
  80. req.Main.UpdateBy = user.RealName
  81. req.Main.UpdateOn = now
  82. tx, err := s.Dao.DB.Begin()
  83. if err != nil {
  84. return err
  85. }
  86. result, err := tx.Insert("settle_account_main", req.Main)
  87. if err != nil {
  88. tx.Rollback()
  89. return err
  90. }
  91. id , _ := result.LastInsertId()
  92. for index := range req.Details { // 更新必要信息
  93. req.Details[index].CreateUserId = int(user.Id)
  94. req.Details[index].CreateBy = user.RealName
  95. req.Details[index].CreateOn = now
  96. req.Details[index].UpdateUserId = int(user.Id)
  97. req.Details[index].UpdateBy = user.RealName
  98. req.Details[index].UpdateOn = now
  99. req.Details[index].Pid = int(id)
  100. }
  101. _, err = tx.Insert("settle_account_detail", req.Details)
  102. if err != nil {
  103. tx.Rollback()
  104. return err
  105. }
  106. return tx.Commit()
  107. }
  108. // 确认
  109. func (s Service) Confirm(req accountModel.AccountMainConfirmReq, user request.UserInfo) error {
  110. if req.MainId == 0 {
  111. return errors.New("参数缺失")
  112. }
  113. _, err := s.Dao.M.Update(fmt.Sprintf("SettleStatus='1',SettleUserId='%v',SettleUser='%v',SettleDate='%v'", user.Id, user.RealName, gtime.Now()), fmt.Sprintf("Id='%v'", req.MainId))
  114. return err
  115. }