business.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. package proj
  2. import (
  3. "context"
  4. projDao "dashoo.cn/micro/app/dao/proj"
  5. model "dashoo.cn/micro/app/model/proj"
  6. "dashoo.cn/micro/app/service"
  7. "dashoo.cn/opms_libary/myerrors"
  8. "dashoo.cn/opms_libary/utils"
  9. "github.com/gogf/gf/database/gdb"
  10. "github.com/gogf/gf/errors/gerror"
  11. "github.com/gogf/gf/frame/g"
  12. "github.com/gogf/gf/os/gtime"
  13. "github.com/gogf/gf/util/gconv"
  14. "strconv"
  15. "strings"
  16. )
  17. type businessService struct {
  18. *service.ContextService
  19. Dao *projDao.ProjBusinessDao
  20. }
  21. func NewBusinessService(ctx context.Context) (svc *businessService, err error) {
  22. svc = new(businessService)
  23. if svc.ContextService, err = svc.Init(ctx); err != nil {
  24. return nil, err
  25. }
  26. svc.Dao = projDao.NewProjBusinessDao(svc.Tenant)
  27. return svc, nil
  28. }
  29. func (p *businessService) GetList(req *model.ProjBusinessSearchReq) (total int, businessList []*model.ProjBusiness, err error) {
  30. db := p.Dao.M
  31. if req.NboName != "" {
  32. db = db.WhereLike(p.Dao.Columns.NboName, "%"+req.NboName+"%")
  33. }
  34. if req.CustName != "" {
  35. db = db.WhereLike(p.Dao.Columns.CustName, "%"+req.CustName+"%")
  36. }
  37. if req.SaleName != "" {
  38. db = db.WhereLike(p.Dao.Columns.SaleName, "%"+req.SaleName+"%")
  39. }
  40. if req.NboType != "" {
  41. db = db.Where(p.Dao.Columns.NboType, req.NboType)
  42. }
  43. total, err = db.Count()
  44. if err != nil {
  45. g.Log().Error(err)
  46. err = gerror.New("获取总行数失败")
  47. return
  48. }
  49. err = db.Page(req.PageNum, req.PageSize).Order("id asc").Scan(&businessList)
  50. return
  51. }
  52. func (p *businessService) GetEntityById(id int64) (business *model.ProjBusiness, err error) {
  53. err = p.Dao.Where(projDao.ProjBusiness.Columns.Id, id).Scan(&business)
  54. return
  55. }
  56. func (p *businessService) GetBusinessProduct(id int64) (productList []*model.ProjBusinessProduct, err error) {
  57. productDao := projDao.NewProjBusinessProductDao(p.Tenant)
  58. err = productDao.Where(productDao.ProjBusinessProductDao.Columns.BusId, id).Scan(&productList)
  59. return
  60. }
  61. func (p *businessService) GetBusinessDynamics(req *model.BusinessReq) (total int, result g.MapStrAny, err error) {
  62. result = make(g.MapStrAny, 0)
  63. dynamicsDao := projDao.NewProjBusinessDynamicsDao(p.Tenant).ProjBusinessDynamicsDao.Where(projDao.ProjBusinessDynamics.Columns.BusId, req.BusId)
  64. total, err = dynamicsDao.Count()
  65. if err != nil {
  66. g.Log().Error(err)
  67. return
  68. }
  69. dynamicsList, err := dynamicsDao.Page(req.GetPage()).Order("created_time desc").All()
  70. if err != nil || dynamicsList == nil {
  71. return
  72. }
  73. // 数据树格式转换
  74. opnDateFlag := gtime.New(dynamicsList[0].OpnDate).Format("Y-m-d")
  75. for k, v := range dynamicsList {
  76. opnDate := gtime.New(v.OpnDate).Format("Y-m-d")
  77. if opnDateFlag == opnDate && k != 0 {
  78. result[opnDate] = append(result[opnDate].(g.ListStrAny), g.Map{
  79. "opnPeople": v.OpnPeople,
  80. "opnDate": v.OpnDate,
  81. "opnType": v.OpnType,
  82. "remark": v.Remark,
  83. "opnContent": gconv.Map(v.OpnContent),
  84. })
  85. } else {
  86. temp := make(g.ListStrAny, 0)
  87. temp = append(temp, g.Map{
  88. "opnPeople": v.OpnPeople,
  89. "opnDate": v.OpnDate,
  90. "opnType": v.OpnType,
  91. "remark": v.Remark,
  92. "opnContent": gconv.Map(v.OpnContent),
  93. })
  94. result[opnDate] = temp
  95. }
  96. }
  97. return
  98. }
  99. func (p *businessService) GetBusinessDynamicsList(req *model.BusinessReq) (total int, list []map[string]interface{}, err error) {
  100. dynamicsDao := projDao.NewProjBusinessDynamicsDao(p.Tenant).ProjBusinessDynamicsDao.Where(projDao.ProjBusinessDynamics.Columns.BusId, req.BusId)
  101. if req.OpnType != "" {
  102. dynamicsDao = dynamicsDao.Where(projDao.ProjBusinessDynamics.Columns.OpnType+" = ?", req.OpnType)
  103. }
  104. total, err = dynamicsDao.Count()
  105. if err != nil {
  106. g.Log().Error(err)
  107. return
  108. }
  109. dynamicsList, err := dynamicsDao.Page(req.GetPage()).Order("created_time desc").All()
  110. for _, v := range dynamicsList {
  111. val := gconv.Map(v)
  112. val["opnContent"] = gconv.Map(v.OpnContent)
  113. list = append(list, val)
  114. }
  115. return
  116. }
  117. func (p *businessService) Create(req *model.AddProjBusinessReq) (err error) {
  118. businessData := new(model.ProjBusiness)
  119. if err = gconv.Struct(req, businessData); err != nil {
  120. return
  121. }
  122. contact := g.Map{
  123. projDao.ProjBusinessContact.Columns.ContactId: req.ContactId,
  124. }
  125. service.SetCreatedInfo(contact, p.GetCxtUserId(), p.GetCxtUserName())
  126. products := make([]*model.ProjBusinessProduct, len(req.Products))
  127. if err = gconv.Structs(req.Products, &products); err != nil {
  128. return
  129. }
  130. var totalPrice float64
  131. for _, v := range products {
  132. v.TotalPrice = v.ProdPrice * float64(v.ProdNum)
  133. totalPrice += v.TotalPrice
  134. service.SetCreatedInfo(v, p.GetCxtUserId(), p.GetCxtUserName())
  135. }
  136. businessData.NboCode = "NBO" + strconv.Itoa(int(gtime.Timestamp()))
  137. businessData.NboStatus = "10"
  138. businessData.NboType = "C"
  139. businessData.ApproStatus = "10"
  140. businessData.EstTransPrice = totalPrice
  141. businessData.DeptId = p.GetCxtUserDeptId()
  142. service.SetCreatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  143. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  144. // 添加项目
  145. lastId, err := p.Dao.TX(tx).InsertAndGetId(businessData)
  146. if err != nil {
  147. return err
  148. }
  149. // 创建了联系人
  150. contact[projDao.ProjBusinessContact.Columns.BusId] = lastId
  151. _, err = projDao.NewProjBusinessContactDao(p.Tenant).TX(tx).Insert(contact)
  152. if err != nil {
  153. return err
  154. }
  155. // 处理项目产品信息
  156. for _, v := range products {
  157. v.BusId = int(lastId)
  158. }
  159. // 添加项目产品
  160. _, err = projDao.NewProjBusinessProductDao(p.Tenant).TX(tx).Insert(products)
  161. if err != nil {
  162. return err
  163. }
  164. // 添加项目动态
  165. dynamics := model.ProjBusinessDynamics{
  166. BusId: int(lastId),
  167. OpnType: "10",
  168. Remark: businessData.Remark,
  169. }
  170. err = p.CreateProjBusinessDynamics(tx, dynamics, businessData)
  171. return err
  172. })
  173. return
  174. }
  175. func (p *businessService) UpdateById(req *model.UpdateProjBusinessReq) (err error) {
  176. record, err := p.Dao.Count("Id", req.Id)
  177. if err != nil || record == 0 {
  178. err = gerror.New("该数据不存在")
  179. return err
  180. }
  181. businessData := gconv.Map(req)
  182. businessData = utils.MapKeySnakeCamelCase(businessData, "snake")
  183. products := make([]*model.ProjBusinessProduct, len(req.Products))
  184. if err = gconv.Structs(req.Products, &products); err != nil {
  185. return
  186. }
  187. var totalPrice float64
  188. for _, v := range products {
  189. v.Id = 0
  190. v.TotalPrice = v.ProdPrice * float64(v.ProdNum)
  191. totalPrice += v.TotalPrice
  192. service.SetCreatedInfo(v, p.GetCxtUserId(), p.GetCxtUserName())
  193. }
  194. service.SetUpdatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  195. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  196. // 更新项目
  197. _, err = p.Dao.TX(tx).FieldsEx(service.UpdateFieldEx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Update(businessData)
  198. if err != nil {
  199. return err
  200. }
  201. // 添加项目产品
  202. _, err = projDao.NewProjBusinessProductDao(p.Tenant).TX(tx).Where(projDao.ProjBusinessProduct.Columns.BusId, req.Id).Delete()
  203. if err != nil {
  204. return err
  205. }
  206. // 添加项目产品
  207. _, err = projDao.NewProjBusinessProductDao(p.Tenant).TX(tx).Insert(products)
  208. if err != nil {
  209. return err
  210. }
  211. // 添加项目动态
  212. dynamics := model.ProjBusinessDynamics{
  213. BusId: req.Id,
  214. OpnType: "20",
  215. Remark: req.Remark,
  216. }
  217. err = p.CreateProjBusinessDynamics(tx, dynamics, req)
  218. return err
  219. })
  220. return
  221. }
  222. func (p *businessService) DeleteByIds(ids []int64) (err error) {
  223. _, err = p.Dao.WhereIn(projDao.ProjBusiness.Columns.Id, ids).Delete()
  224. return
  225. }
  226. // BusinessTransfer 项目转移
  227. func (p *businessService) BusinessTransfer(req *model.BusinessTransferReq) error {
  228. business, err := p.Dao.WherePri(req.Id).One()
  229. if err != nil {
  230. return err
  231. }
  232. if business == nil {
  233. return myerrors.NewMsgError(nil, "项目不存在")
  234. }
  235. businessMap := g.Map{
  236. p.Dao.Columns.SaleId: req.UserId,
  237. p.Dao.Columns.SaleName: req.UserName,
  238. p.Dao.Columns.Remark: req.Remark,
  239. }
  240. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  241. opnContent := businessMap
  242. opnContent["origSaleId"] = business.SaleId
  243. opnContent["origSaleName"] = business.SaleName
  244. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  245. // 更新项目
  246. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  247. if err != nil {
  248. return err
  249. }
  250. // 添加项目动态
  251. dynamics := model.ProjBusinessDynamics{
  252. BusId: req.Id,
  253. OpnType: "30",
  254. Remark: req.Remark,
  255. }
  256. err = p.CreateProjBusinessDynamics(tx, dynamics, opnContent)
  257. return err
  258. })
  259. return err
  260. }
  261. // BusinessGradation 项目调级
  262. func (p *businessService) BusinessGradation(req *model.BusinessGradationReq) error {
  263. business, err := p.Dao.Where(projDao.ProjBusiness.Columns.Id, req.Id).One()
  264. if err != nil {
  265. return err
  266. }
  267. if business == nil {
  268. return myerrors.NewMsgError(nil, "项目不存在")
  269. }
  270. if business.NboType == req.NboType {
  271. return myerrors.NewMsgError(nil, "同级无法进行调级。")
  272. }
  273. opnType := "40"
  274. // A < B return -1 项目降级
  275. if strings.Compare(business.NboType, req.NboType) < 0 {
  276. opnType = "50"
  277. }
  278. businessMap := g.Map{
  279. p.Dao.Columns.NboType: req.NboType,
  280. }
  281. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  282. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  283. // 更新项目调级
  284. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  285. if err != nil {
  286. return err
  287. }
  288. // 添加项目动态
  289. dynamics := model.ProjBusinessDynamics{
  290. BusId: business.Id,
  291. OpnType: opnType,
  292. Remark: req.Remark,
  293. }
  294. err = p.CreateProjBusinessDynamics(tx, dynamics, g.Map{
  295. "origNboType": business.NboType,
  296. "nboType": req.NboType,
  297. })
  298. return err
  299. })
  300. return err
  301. }
  302. // SetPrimacyContact 项目设置首要联系人
  303. func (p *businessService) SetPrimacyContact(req *model.BusinessPrimacyContactReq) (err error) {
  304. business, err := p.Dao.Where(projDao.ProjBusiness.Columns.Id, req.Id).One()
  305. if err != nil {
  306. return err
  307. }
  308. if business == nil {
  309. return myerrors.NewMsgError(nil, "项目不存在")
  310. }
  311. businessMap := g.Map{
  312. p.Dao.Columns.ContactId: req.ContactId,
  313. p.Dao.Columns.ContactName: req.ContactName,
  314. p.Dao.Columns.ContactPostion: req.ContactPostion,
  315. p.Dao.Columns.ContactTelephone: req.ContactTelephone,
  316. }
  317. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  318. opnContent := businessMap
  319. opnContent["origContactId"] = business.ContactId
  320. opnContent["origContactName"] = business.ContactName
  321. opnContent["origContactPostion"] = business.ContactPostion
  322. opnContent["origContactTelephone"] = business.ContactTelephone
  323. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  324. // 更新项目
  325. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  326. if err != nil {
  327. return err
  328. }
  329. // 添加项目动态
  330. dynamics := model.ProjBusinessDynamics{
  331. BusId: req.Id,
  332. OpnType: "60",
  333. Remark: req.Remark,
  334. }
  335. err = p.CreateProjBusinessDynamics(tx, dynamics, opnContent)
  336. return err
  337. })
  338. return err
  339. }
  340. // CreateProjBusinessDynamics 创建项目动态
  341. func (p *businessService) CreateProjBusinessDynamics(tx *gdb.TX, dynamics model.ProjBusinessDynamics, opnContent interface{}) error {
  342. if v, ok := opnContent.(g.Map); ok {
  343. opnContent = utils.MapKeySnakeCamelCase(v)
  344. }
  345. // 添加项目动态
  346. dynamics.OpnPeopleId = p.GetCxtUserId()
  347. dynamics.OpnPeople = p.GetCxtUserName()
  348. dynamics.OpnDate = gtime.Now()
  349. dynamics.OpnContent = gconv.String(opnContent)
  350. service.SetCreatedInfo(&dynamics, p.GetCxtUserId(), p.GetCxtUserName())
  351. _, err := projDao.NewProjBusinessDynamicsDao(p.Tenant).TX(tx).Insert(&dynamics)
  352. return err
  353. }