business.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  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. "strings"
  15. )
  16. type businessService struct {
  17. *service.ContextService
  18. Dao *projDao.ProjBusinessDao
  19. }
  20. func NewBusinessService(ctx context.Context) (svc *businessService, err error) {
  21. svc = new(businessService)
  22. if svc.ContextService, err = svc.Init(ctx); err != nil {
  23. return nil, err
  24. }
  25. svc.Dao = projDao.NewProjBusinessDao(svc.Tenant)
  26. return svc, nil
  27. }
  28. func (p *businessService) GetList(req *model.ProjBusinessSearchReq) (total int, businessList []*model.ProjBusiness, err error) {
  29. db := p.Dao.M
  30. if req.NboName != "" {
  31. db = db.WhereLike(p.Dao.Columns.NboName, "%"+req.NboName+"%")
  32. }
  33. if req.CustName != "" {
  34. db = db.WhereLike(p.Dao.Columns.CustName, "%"+req.CustName+"%")
  35. }
  36. if req.SaleName != "" {
  37. db = db.WhereLike(p.Dao.Columns.SaleName, "%"+req.SaleName+"%")
  38. }
  39. if req.NboType != "" {
  40. db = db.Where(p.Dao.Columns.NboType, req.NboType)
  41. }
  42. total, err = db.Count()
  43. if err != nil {
  44. g.Log().Error(err)
  45. err = gerror.New("获取总行数失败")
  46. return
  47. }
  48. err = db.Page(req.PageNum, req.PageSize).Order("id asc").Scan(&businessList)
  49. return
  50. }
  51. func (p *businessService) GetEntityById(id int64) (business *model.ProjBusiness, err error) {
  52. err = p.Dao.Where(projDao.ProjBusiness.Columns.Id, id).Scan(&business)
  53. return
  54. }
  55. func (p *businessService) GetBusinessProduct(id int64) (productList []*model.ProjBusinessProduct, err error) {
  56. productDao := projDao.NewProjBusinessProductDao(p.Tenant)
  57. err = productDao.Where(productDao.ProjBusinessProductDao.Columns.BusId, id).Scan(&productList)
  58. return
  59. }
  60. func (p *businessService) GetBusinessDynamics(req *model.BusinessReq) (total int, result g.ListStrAny, err error) {
  61. result = make(g.ListStrAny, 0)
  62. dynamicsDao := projDao.NewProjBusinessDynamicsDao(p.Tenant).ProjBusinessDynamicsDao.Where(projDao.ProjBusinessDynamics.Columns.BusId, req.BusId)
  63. total, err = dynamicsDao.Count()
  64. if err != nil {
  65. g.Log().Error(err)
  66. return
  67. }
  68. dynamicsList, err := dynamicsDao.Page(req.GetPage()).Order("created_time desc").All()
  69. if err != nil || len(dynamicsList) == 0 {
  70. g.Log().Error(err)
  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[len(result)-1][opnDate] = append(result[len(result)-1][opnDate].(g.ListStrAny), g.Map{
  79. "opnPeople": v.OpnPeople,
  80. "opnDate": v.OpnDate,
  81. "opnType": v.OpnType,
  82. "opnContent": gconv.Map(v.OpnContent),
  83. })
  84. } else {
  85. temp := make(g.ListStrAny, 0)
  86. temp = append(temp, g.Map{
  87. "opnPeople": v.OpnPeople,
  88. "opnDate": v.OpnDate,
  89. "opnType": v.OpnType,
  90. "opnContent": gconv.Map(v.OpnContent),
  91. })
  92. result = append(result, g.Map{
  93. opnDate: temp,
  94. })
  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. products := make([]*model.ProjBusinessProduct, len(req.Products))
  123. if err = gconv.Structs(req.Products, &products); err != nil {
  124. return
  125. }
  126. var totalPrice float64
  127. for _, v := range products {
  128. v.TotalPrice = v.ProdPrice * float64(v.ProdNum)
  129. totalPrice += v.TotalPrice
  130. service.SetCreatedInfo(v, p.GetCxtUserId(), p.GetCxtUserName())
  131. }
  132. businessData.NboType = "C"
  133. businessData.ApproStatus = "10"
  134. businessData.EstTransPrice = totalPrice
  135. businessData.DeptId = p.GetCxtUserDeptId()
  136. service.SetCreatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  137. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  138. // 添加项目
  139. lastId, err := p.Dao.TX(tx).InsertAndGetId(businessData)
  140. if err != nil {
  141. return err
  142. }
  143. // 处理项目产品信息
  144. for _, v := range products {
  145. v.BusId = int(lastId)
  146. }
  147. // 添加项目产品
  148. _, err = projDao.NewProjBusinessProductDao(p.Tenant).TX(tx).Insert(products)
  149. if err != nil {
  150. return err
  151. }
  152. // 添加项目动态
  153. dynamics := model.ProjBusinessDynamics{
  154. BusId: int(lastId),
  155. OpnType: "10",
  156. Remark: businessData.Remark,
  157. }
  158. err = p.CreateProjBusinessDynamics(tx, dynamics, businessData)
  159. return err
  160. })
  161. return
  162. }
  163. func (p *businessService) UpdateById(req *model.UpdateProjBusinessReq) (err error) {
  164. record, err := p.Dao.Count("Id", req.Id)
  165. if err != nil || record == 0 {
  166. err = gerror.New("该数据不存在")
  167. return err
  168. }
  169. businessData := new(model.ProjBusiness)
  170. if err = gconv.Struct(req, businessData); err != nil {
  171. return
  172. }
  173. service.SetUpdatedInfo(businessData, p.GetCxtUserId(), p.GetCxtUserName())
  174. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  175. // 更新项目
  176. _, err = p.Dao.TX(tx).FieldsEx(service.UpdateFieldEx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Update(businessData)
  177. if err != nil {
  178. return err
  179. }
  180. // 添加项目动态
  181. dynamics := model.ProjBusinessDynamics{
  182. BusId: req.Id,
  183. OpnType: "20",
  184. Remark: businessData.Remark,
  185. }
  186. err = p.CreateProjBusinessDynamics(tx, dynamics, businessData)
  187. return err
  188. })
  189. return
  190. }
  191. func (p *businessService) DeleteByIds(ids []int64) (err error) {
  192. _, err = p.Dao.WhereIn(projDao.ProjBusiness.Columns.Id, ids).Delete()
  193. return
  194. }
  195. // BusinessTransfer 项目转移
  196. func (p *businessService) BusinessTransfer(req *model.BusinessTransferReq) error {
  197. business, err := p.Dao.WherePri(req.Id).One()
  198. if err != nil {
  199. return err
  200. }
  201. if business == nil {
  202. return myerrors.NewMsgError(nil, "项目不存在")
  203. }
  204. businessMap := g.Map{
  205. p.Dao.Columns.SaleId: req.UserId,
  206. p.Dao.Columns.SaleName: req.UserName,
  207. p.Dao.Columns.Remark: req.Remark,
  208. }
  209. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  210. opnContent := businessMap
  211. opnContent["origSaleId"] = business.SaleId
  212. opnContent["origSaleName"] = business.SaleName
  213. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  214. // 更新项目
  215. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  216. if err != nil {
  217. return err
  218. }
  219. // 添加项目动态
  220. dynamics := model.ProjBusinessDynamics{
  221. BusId: req.Id,
  222. OpnType: "30",
  223. Remark: req.Remark,
  224. }
  225. err = p.CreateProjBusinessDynamics(tx, dynamics, opnContent)
  226. return err
  227. })
  228. return err
  229. }
  230. // BusinessGradation 项目调级
  231. func (p *businessService) BusinessGradation(req *model.BusinessGradationReq) error {
  232. business, err := p.Dao.Where(projDao.ProjBusiness.Columns.Id, req.Id).One()
  233. if err != nil {
  234. return err
  235. }
  236. if business == nil {
  237. return myerrors.NewMsgError(nil, "项目不存在")
  238. }
  239. if business.NboType == req.NboType {
  240. return myerrors.NewMsgError(nil, "同级无法进行调级。")
  241. }
  242. opnType := "40"
  243. opnContent := "项目升级 " + business.NboType + " => " + req.NboType
  244. // A < B return -1 项目降级
  245. if strings.Compare(business.NboType, req.NboType) < 0 {
  246. opnContent = "项目降级 " + business.NboType + " => " + req.NboType
  247. opnType = "50"
  248. }
  249. businessMap := g.Map{
  250. p.Dao.Columns.NboType: req.NboType,
  251. }
  252. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  253. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  254. // 更新项目调级
  255. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  256. if err != nil {
  257. return err
  258. }
  259. // 添加项目动态
  260. dynamics := model.ProjBusinessDynamics{
  261. BusId: business.Id,
  262. OpnType: opnType,
  263. }
  264. err = p.CreateProjBusinessDynamics(tx, dynamics, opnContent)
  265. return err
  266. })
  267. return err
  268. }
  269. // SetPrimacyContact 项目设置首要联系人
  270. func (p *businessService) SetPrimacyContact(req *model.BusinessPrimacyContactReq) (err error) {
  271. business, err := p.Dao.Where(projDao.ProjBusiness.Columns.Id, req.Id).One()
  272. if err != nil {
  273. return err
  274. }
  275. if business == nil {
  276. return myerrors.NewMsgError(nil, "项目不存在")
  277. }
  278. businessMap := g.Map{
  279. p.Dao.Columns.ContactId: req.ContactId,
  280. p.Dao.Columns.ContactName: req.ContactName,
  281. p.Dao.Columns.ContactPostion: req.ContactPostion,
  282. p.Dao.Columns.ContactTelephone: req.ContactTelephone,
  283. }
  284. service.SetUpdatedInfo(businessMap, p.GetCxtUserId(), p.GetCxtUserName())
  285. opnContent := businessMap
  286. opnContent["origContactId"] = business.ContactId
  287. opnContent["origContactName"] = business.ContactName
  288. opnContent["origContactPostion"] = business.ContactPostion
  289. opnContent["origContactTelephone"] = business.ContactTelephone
  290. err = p.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  291. // 更新项目
  292. _, err = p.Dao.TX(tx).WherePri(projDao.ProjBusiness.Columns.Id, req.Id).Data(businessMap).Update()
  293. if err != nil {
  294. return err
  295. }
  296. // 添加项目动态
  297. dynamics := model.ProjBusinessDynamics{
  298. BusId: req.Id,
  299. OpnType: "60",
  300. Remark: req.Remark,
  301. }
  302. err = p.CreateProjBusinessDynamics(tx, dynamics, opnContent)
  303. return err
  304. })
  305. return err
  306. }
  307. // CreateProjBusinessDynamics 创建项目动态
  308. func (p *businessService) CreateProjBusinessDynamics(tx *gdb.TX, dynamics model.ProjBusinessDynamics, opnContent interface{}) error {
  309. if v, ok := opnContent.(g.Map); ok {
  310. opnContent = utils.MapKeySnakeCamelCase(v)
  311. }
  312. // 添加项目动态
  313. dynamics.OpnPeopleId = p.GetCxtUserId()
  314. dynamics.OpnPeople = p.GetCxtUserName()
  315. dynamics.OpnDate = gtime.Now()
  316. dynamics.OpnContent = gconv.String(opnContent)
  317. service.SetCreatedInfo(&dynamics, p.GetCxtUserId(), p.GetCxtUserName())
  318. _, err := projDao.NewProjBusinessDynamicsDao(p.Tenant).TX(tx).Insert(&dynamics)
  319. return err
  320. }