cust_customer.go 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364
  1. package cust
  2. import (
  3. "bytes"
  4. "context"
  5. "encoding/json"
  6. "fmt"
  7. "github.com/gogf/gf/container/garray"
  8. "math"
  9. "strconv"
  10. "strings"
  11. "time"
  12. "dashoo.cn/opms_libary/plugin/dingtalk/workflow"
  13. "dashoo.cn/opms_libary/request"
  14. "dashoo.cn/opms_libary/utils"
  15. "dashoo.cn/opms_libary/myerrors"
  16. "dashoo.cn/opms_libary/plugin/dingtalk/message"
  17. "github.com/360EntSecGroup-Skylar/excelize"
  18. "github.com/gogf/gf/database/gdb"
  19. "github.com/gogf/gf/encoding/gjson"
  20. "github.com/gogf/gf/frame/g"
  21. "github.com/gogf/gf/os/gtime"
  22. "github.com/gogf/gf/util/gconv"
  23. "github.com/mozillazg/go-pinyin"
  24. "dashoo.cn/micro/app/dao/cust"
  25. platdao "dashoo.cn/micro/app/dao/plat"
  26. model "dashoo.cn/micro/app/model/cust"
  27. workflowModel "dashoo.cn/micro/app/model/workflow"
  28. "dashoo.cn/micro/app/service"
  29. workflowService "dashoo.cn/micro/app/service/workflow"
  30. )
  31. type CustomerService struct {
  32. *service.ContextService
  33. Dao *cust.CustCustomerDao
  34. BelongDao *cust.CustCustomerBelongDao
  35. DynamicsDao *cust.CustCustomerDynamicsDao
  36. ContactDao *cust.CustCustomerContactDao
  37. FollowDao *platdao.PlatFollowupDao
  38. BelongServer *CustomerbelongService
  39. ContanctServer *CustomercontactService
  40. }
  41. var isPublic, noPublic = "10", "20" // 公海,非公海
  42. var AllocaTion, OperaTion, Receive, Merge = "10", "20", "30", "40" // 10分配20转移30领取40合并
  43. type OpnType struct {
  44. OperaTion string
  45. }
  46. func NewCustomerService(ctx context.Context) (svc *CustomerService, err error) {
  47. svc = new(CustomerService)
  48. if svc.ContextService, err = svc.Init(ctx); err != nil {
  49. return nil, err
  50. }
  51. svc.Dao = cust.NewCustCustomerDao(svc.Tenant)
  52. svc.BelongDao = cust.NewCustCustomerBelongDao(svc.Tenant)
  53. svc.DynamicsDao = cust.NewCustCustomerDynamicsDao(svc.Tenant)
  54. svc.ContactDao = cust.NewCustCustomerContactDao(svc.Tenant)
  55. svc.FollowDao = platdao.NewPlatFollowupDao(svc.Tenant)
  56. svc.BelongServer, _ = NewCustomerBelongService(ctx)
  57. svc.ContanctServer, _ = NewCustomerContactService(ctx)
  58. return svc, nil
  59. }
  60. // GetList 客户列表列表
  61. func (s *CustomerService) GetList(req *model.CustCustomerSearchReq) (total int, customerList []*model.CustList, err error) {
  62. Model := s.Dao.FieldsEx(s.Dao.C.DeletedTime)
  63. if req.IsPublic {
  64. Model = Model.Where(s.Dao.C.IsPublic, isPublic)
  65. } else {
  66. Model = Model.Where(s.Dao.C.IsPublic, noPublic)
  67. if req.TargetType == "self" {
  68. Model = Model.Where(s.Dao.C.SalesId, s.CxtUser.Id)
  69. } else if req.TargetType == "other" {
  70. Model = Model.Where(s.Dao.C.SalesId, s.DataScope["userIds"]).WhereNot(s.Dao.C.SalesId, s.CxtUser.Id)
  71. } else {
  72. Model = Model.DataScope(s.Ctx, "sales_id").Where(s.Dao.C.IsPublic, noPublic)
  73. }
  74. }
  75. //客户名称
  76. if req.CustName != "" {
  77. Model = Model.Where(s.Dao.C.CustName+" like ?", "%"+req.CustName+"%")
  78. }
  79. //客户编码
  80. if req.CustCode != "" {
  81. Model = Model.Where(s.Dao.C.CustCode+" like ?", "%"+req.CustCode+"%")
  82. }
  83. //客户行业
  84. if req.CustIndustry != "" {
  85. Model = Model.Where(s.Dao.C.CustIndustry, req.CustIndustry)
  86. }
  87. //客户级别
  88. if req.CustLevel != "" {
  89. Model = Model.Where(s.Dao.C.CustLevel, req.CustLevel)
  90. }
  91. //
  92. //if req.FollowUpDate != "" {
  93. // Model = Model.Where(s.Dao.C.FollowUpDate+" like ? ", req.FollowUpDate+"%")
  94. //}
  95. //省份
  96. if req.CustProvince != "" {
  97. Model = Model.Where(s.Dao.C.CustProvince, req.CustProvince)
  98. }
  99. //市
  100. if req.CustCity != "" {
  101. Model = Model.Where(s.Dao.C.CustCity, req.CustCity)
  102. }
  103. //所属销售
  104. if req.SalesName != "" {
  105. Model = Model.Where(s.Dao.C.SalesName+" like ?", "%"+req.SalesName+"%")
  106. }
  107. // 获取日期区间范围内的记录
  108. if req.BeginTime != "" && req.EndTime != "" {
  109. begin := strings.Split(req.BeginTime, " ")[0] + " 00:00:00"
  110. end := strings.Split(req.EndTime, " ")[0] + " 23:59:59"
  111. Model = Model.WhereBetween(s.Dao.C.FollowUpDate, begin, end)
  112. }
  113. if req.IsRemovePage {
  114. Model = Model
  115. } else {
  116. Model = Model.Page(req.GetPage())
  117. }
  118. total, err = Model.Count()
  119. if err != nil {
  120. g.Log().Error(err)
  121. err = myerrors.DbError("获取总行数失败。")
  122. return
  123. }
  124. err = Model.Order("id desc").Scan(&customerList)
  125. if err != nil {
  126. g.Log().Error(err)
  127. return
  128. }
  129. return
  130. }
  131. func (s *CustomerService) customerCode(province, industry string) (string, error) {
  132. sequence, err := service.Sequence(s.Dao.DB, "customer_code")
  133. if err != nil {
  134. return "", err
  135. }
  136. return s.customerProvinceCode(province) + industry + sequence, nil
  137. }
  138. func (s *CustomerService) customerProvinceCode(province string) string {
  139. if province == "重庆市" {
  140. return "CQ"
  141. }
  142. province = strings.Trim(province, "市")
  143. province = strings.Trim(province, "省")
  144. province = strings.Trim(province, "特别行政区")
  145. province = strings.Trim(province, "自治区")
  146. province = strings.Trim(province, "壮族")
  147. province = strings.Trim(province, "回族")
  148. province = strings.Trim(province, "维吾尔")
  149. pinyinArg := pinyin.NewArgs()
  150. pinyinArg.Style = pinyin.FIRST_LETTER
  151. provincePinyin := pinyin.Pinyin(province, pinyinArg)
  152. provinceFirstletter := []string{}
  153. for _, i := range provincePinyin {
  154. provinceFirstletter = append(provinceFirstletter, i[0])
  155. }
  156. provinceCode := strings.Join(provinceFirstletter, "")
  157. provinceCode = strings.ToUpper(provinceCode)
  158. fmt.Println(provincePinyin, provinceFirstletter, provinceCode)
  159. return provinceCode
  160. }
  161. // Create 创建客户
  162. func (s *CustomerService) Create(req *model.CustomerAddSeq) (insertId int64, err error) {
  163. cusTomer := new(model.CustCustomer)
  164. count, err := s.Dao.Where(s.Dao.C.CustName, req.CustName).Count()
  165. if err != nil {
  166. g.Log().Error(err)
  167. return
  168. }
  169. if count > 0 {
  170. return 0, myerrors.TipsError("该客户信息已存在,不可重复添加")
  171. }
  172. if err = gconv.Struct(req, cusTomer); err != nil {
  173. return
  174. }
  175. service.SetCreatedInfo(cusTomer, s.GetCxtUserId(), s.CxtUser.NickName)
  176. custCode, err := s.customerCode(req.CustProvince, req.CustIndustry)
  177. if err != nil {
  178. return 0, err
  179. }
  180. cusTomer.CustCode = custCode
  181. cusTomer.CustStatus = "10"
  182. roles := s.GetCxtUserRoles()
  183. isSales := false
  184. for _, v := range roles {
  185. if v == "SalesEngineer" || v == "ProductLineManager" { // 销售角色
  186. isSales = true
  187. break
  188. }
  189. }
  190. if _, ok := s.DataScope["is_big"]; ok {
  191. isSales = true
  192. }
  193. // 销售角色
  194. if isSales {
  195. cusTomer.IsPublic = noPublic
  196. cusTomer.SalesId = s.GetCxtUserId()
  197. cusTomer.SalesName = s.CxtUser.NickName
  198. cusTomer.CustStatus = "30"
  199. insertId, err = s.Dao.InsertAndGetId(cusTomer)
  200. if err != nil {
  201. g.Log().Error(err)
  202. return 0, err
  203. }
  204. err = s.CreateBelong(gconv.Int(insertId))
  205. return insertId, err
  206. } else {
  207. cusTomer.IsPublic = isPublic
  208. insertId, err = s.Dao.InsertAndGetId(cusTomer)
  209. if err != nil {
  210. g.Log().Error(err)
  211. return 0, err
  212. }
  213. }
  214. return insertId, err
  215. }
  216. // CreateBelong 创建客户归属信息
  217. func (s *CustomerService) CreateBelong(custId int) (err error) {
  218. belong := new(model.CustomerBelongAddSeq)
  219. belong.CustId = custId
  220. belong.SaleName = s.CxtUser.NickName
  221. belong.OpnType = AllocaTion
  222. belong.OpnPeople = s.CxtUser.NickName
  223. err = s.BelongServer.Create(belong)
  224. if err != nil {
  225. g.Log().Error(err)
  226. return
  227. }
  228. return
  229. }
  230. // 删除客户
  231. func (s *CustomerService) DeleteByIds(Ids []int64) (err error) {
  232. customerCount, err := s.Dao.Where(" id in (?)", Ids).Count()
  233. if err != nil {
  234. g.Log().Error(err)
  235. return
  236. }
  237. if customerCount == 0 {
  238. err = myerrors.TipsError("客户信息不存在")
  239. return
  240. }
  241. //删除客户表
  242. s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  243. //客户表
  244. _, err = s.Dao.TX(tx).Where("id in (?)", Ids).Delete()
  245. if err != nil {
  246. g.Log().Error(err)
  247. return err
  248. }
  249. //客户联系人表
  250. _, err = s.ContactDao.Where("cust_id in (?)", Ids).Delete()
  251. if err != nil {
  252. g.Log().Error(err)
  253. return err
  254. }
  255. //客户归属表
  256. _, err = s.BelongDao.Where("cust_id in (?)", Ids).Delete()
  257. if err != nil {
  258. g.Log().Error(err)
  259. return err
  260. }
  261. return nil
  262. })
  263. return
  264. }
  265. // UpdateById 修改客户
  266. func (s *CustomerService) UpdateById(req *model.UpdateCustomer) (err error) {
  267. //判断数据是否存在
  268. count, err := s.Dao.Where("id = ", req.Id).Count()
  269. if err != nil {
  270. g.Log().Error(err)
  271. return
  272. }
  273. if count == 0 {
  274. return
  275. }
  276. //新的客户名字是否存在
  277. num, err := s.Dao.Where(s.Dao.C.CustName, req.CustName).WhereNot(s.Dao.C.Id, req.Id).Count()
  278. if err != nil {
  279. g.Log().Error(err)
  280. return err
  281. }
  282. if num > 0 {
  283. return myerrors.TipsError(fmt.Sprintf("客户名称[%s]已存在", req.CustName))
  284. }
  285. CustomertData := new(model.CustomerAddSeq)
  286. if err = gconv.Struct(req, CustomertData); err != nil {
  287. return
  288. }
  289. service.SetUpdatedInfo(CustomertData, s.GetCxtUserId(), s.CxtUser.NickName)
  290. _, err = s.Dao.FieldsEx(s.Dao.C.CreatedTime, s.Dao.C.CreatedBy, s.Dao.C.CreatedName, s.Dao.C.Id, s.Dao.C.CustCode, s.Dao.C.SalesName, s.Dao.C.SalesId).
  291. WherePri(s.Dao.C.Id, req.Id).Update(CustomertData)
  292. if err != nil {
  293. g.Log().Error(err)
  294. return
  295. }
  296. return
  297. }
  298. var AssignCustomerRequestProcessCode = "PROC-FE42B2D1-6097-4DE8-8AC5-23541B7D5C8A" // BizCode: 11
  299. var MoveToPubicRequestProcessCode = "PROC-C030BD3D-74A3-4FE5-9EBA-DF3BA9F8AEF9" // BizCode: 12
  300. var TransCustomerRequestProcessCode = "PROC-03BE93D3-9A44-43A1-BA6D-D1BB75702542" // BizCode: 13
  301. // AssignCustomerRequest 领取客户申请
  302. func (s *CustomerService) AssignCustomerRequest(ctx context.Context, req *model.AssignCustomerReq) error {
  303. if req.ApplyRemark == "" {
  304. return myerrors.TipsError("请输入申请说明")
  305. }
  306. data, err := s.Dao.Where("id in (?)", req.Ids).LockShared().All()
  307. if err != nil {
  308. return err
  309. }
  310. if len(data) == 0 {
  311. return myerrors.TipsError("领取用户不能为空")
  312. }
  313. for _, v := range data {
  314. if v.CustStatus != "10" {
  315. return myerrors.TipsError(fmt.Sprintf("客户: %s 已被领取", v.CustName))
  316. }
  317. if v.CustProvince == "" {
  318. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在省信息", v.CustName))
  319. }
  320. if v.CustCity == "" {
  321. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在市信息", v.CustName))
  322. }
  323. if v.CustIndustry == "" {
  324. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的客户类型信息", v.CustName))
  325. }
  326. }
  327. city := []string{}
  328. cityData := s.DataScope["cust_city_id"]
  329. if cityData != nil {
  330. for _, i := range cityData.([]interface{}) {
  331. city = append(city, i.(string))
  332. }
  333. }
  334. fmt.Println(city)
  335. cust := []*model.CustCustomer{}
  336. noNeedApprovalCust := []*model.CustCustomer{}
  337. noNeedApprovalCustId := []int64{}
  338. for _, v := range data {
  339. if service.StringSlicecontains(city, strconv.Itoa(v.CustCityId)) {
  340. noNeedApprovalCust = append(noNeedApprovalCust, v)
  341. noNeedApprovalCustId = append(noNeedApprovalCustId, int64(v.Id))
  342. } else {
  343. cust = append(cust, v)
  344. }
  345. }
  346. if len(noNeedApprovalCustId) != 0 {
  347. err = s.ChangeCustBelong(noNeedApprovalCustId, req.SalesId, req.SalesName)
  348. if err != nil {
  349. return err
  350. }
  351. req.Receive = AllocaTion
  352. err = s.BatchCreatebelong(data, req)
  353. if err != nil {
  354. return err
  355. }
  356. err = s.CreateDynamics("领取客户", &model.AssignCustomerReq{
  357. Ids: noNeedApprovalCustId,
  358. SalesId: req.SalesId,
  359. SalesName: req.SalesName,
  360. Remark: "",
  361. Receive: Receive,
  362. }, noNeedApprovalCustId...)
  363. if err != nil {
  364. return err
  365. }
  366. }
  367. remark, err := json.Marshal(map[string]string{
  368. "applyUserId": strconv.Itoa(s.GetCxtUserId()),
  369. "applyUserName": s.GetCxtUserName(),
  370. })
  371. if err != nil {
  372. return err
  373. }
  374. workflowSrv, err := workflowService.NewFlowService(ctx)
  375. if err != nil {
  376. return err
  377. }
  378. for _, u := range cust {
  379. bizCode := strconv.Itoa(u.Id) + ":" + strconv.Itoa(s.GetCxtUserId())
  380. _, err = workflowSrv.StartProcessInstance(bizCode, "11", string(remark), &workflow.StartProcessInstanceRequest{
  381. ProcessCode: &AssignCustomerRequestProcessCode,
  382. FormComponentValues: []*workflow.StartProcessInstanceRequestFormComponentValues{
  383. {
  384. Id: utils.String("TextField_1QEXO83G7GDC0"),
  385. Name: utils.String("客户编码"),
  386. Value: utils.String(u.CustCode),
  387. },
  388. {
  389. Id: utils.String("TextField_13MDZ97RV16K0"),
  390. Name: utils.String("客户名称"),
  391. Value: utils.String(u.CustName),
  392. },
  393. {
  394. Id: utils.String("TextField_Q32G87K9Y680"),
  395. Name: utils.String("所在省"),
  396. Value: utils.String(u.CustProvince),
  397. },
  398. {
  399. Id: utils.String("TextField_1C81AAVZELY80"),
  400. Name: utils.String("所在市"),
  401. Value: utils.String(u.CustCity),
  402. },
  403. {
  404. Id: utils.String("TextField_7EF74WG6AJ40"),
  405. Name: utils.String("客户类别"),
  406. Value: utils.String(u.CustIndustry),
  407. },
  408. {
  409. Id: utils.String("TextField_1ZY48VZY6WG00"),
  410. Name: utils.String("申请人"),
  411. Value: utils.String(s.GetCxtUserName()),
  412. },
  413. {
  414. Id: utils.String("TextareaField_5U6VKA6N1VK0"),
  415. Name: utils.String("申请说明"),
  416. Value: utils.String(req.ApplyRemark),
  417. },
  418. },
  419. })
  420. if err != nil {
  421. return err
  422. }
  423. _, err = s.Dao.Where("id = ?", u.Id).Data(map[string]interface{}{
  424. "is_public": noPublic,
  425. "cust_status": "20",
  426. }).Update()
  427. if err != nil {
  428. return err
  429. }
  430. }
  431. return nil
  432. }
  433. func (s *CustomerService) AssignCustomerRequestApproval(flow *workflowModel.PlatWorkflow, msg *message.MixMessage) error {
  434. remark := map[string]string{}
  435. err := json.Unmarshal([]byte(flow.Remark), &remark)
  436. if err != nil {
  437. return err
  438. }
  439. userName := remark["applyUserName"]
  440. bizCode := strings.Split(flow.BizCode, ":")
  441. if len(bizCode) != 2 {
  442. return fmt.Errorf("客户领取审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  443. }
  444. custId, err := strconv.Atoi(bizCode[0])
  445. if err != nil {
  446. return fmt.Errorf("客户领取审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  447. }
  448. userId, err := strconv.Atoi(bizCode[1])
  449. if err != nil {
  450. return fmt.Errorf("客户领取审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  451. }
  452. cust, err := s.Dao.Where("id = ?", custId).One()
  453. if err != nil {
  454. return err
  455. }
  456. if cust == nil {
  457. return fmt.Errorf("客户不存在:%s Id: %d", flow.BizCode, flow.Id)
  458. }
  459. if msg.ProcessType != "finish" && msg.ProcessType != "terminate" {
  460. return fmt.Errorf("无法识别的 ProcessType :%s", msg.ProcessType)
  461. }
  462. if msg.Result != "agree" && msg.Result != "refuse" && msg.Result != "" {
  463. return fmt.Errorf("无法识别的 Result :%s", msg.Result)
  464. }
  465. if msg.ProcessType == "terminate" {
  466. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  467. "is_public": isPublic,
  468. "cust_status": "10",
  469. }).Update()
  470. return err
  471. }
  472. pass := msg.Result == "agree"
  473. if !pass {
  474. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  475. "is_public": isPublic,
  476. "cust_status": "10",
  477. }).Update()
  478. return err
  479. }
  480. s.CxtUser = &request.UserInfo{Id: userId, UserName: userName}
  481. err = s.ChangeCustBelong([]int64{int64(custId)}, int64(userId), remark["applyUserName"])
  482. if err != nil {
  483. return err
  484. }
  485. err = s.BatchCreatebelong([]*model.CustCustomer{cust}, &model.AssignCustomerReq{
  486. Ids: []int64{int64(custId)},
  487. SalesId: int64(userId),
  488. SalesName: userName,
  489. Remark: "",
  490. Receive: Receive,
  491. })
  492. if err != nil {
  493. return err
  494. }
  495. s.CxtUser = &request.UserInfo{Id: userId, UserName: userName}
  496. return s.CreateDynamics("领取客户", map[string]interface{}{
  497. "userId": userId,
  498. "custId": cust.Id,
  499. }, int64(cust.Id))
  500. }
  501. // 移回公海
  502. func (s *CustomerService) MoveToPublicRequest(ctx context.Context, req *model.MoveToPubicRep) error {
  503. if req.Remark == "" {
  504. return myerrors.TipsError("请输入移回原因")
  505. }
  506. data, err := s.Dao.Where("id in (?)", req.Ids).All()
  507. if err != nil {
  508. return err
  509. }
  510. if len(data) == 0 {
  511. return myerrors.TipsError("移回用户不能为空")
  512. }
  513. cusType, err := service.GetDictDataByType(ctx, "cust_idy")
  514. if err != nil {
  515. return err
  516. }
  517. for _, v := range data {
  518. if v.CustStatus == "10" {
  519. return myerrors.TipsError(fmt.Sprintf("客户: %s 已被移回公海", v.CustName))
  520. }
  521. if v.CustStatus == "20" {
  522. return myerrors.TipsError(fmt.Sprintf("客户: %s 正在等待审批", v.CustName))
  523. }
  524. if v.CustProvince == "" {
  525. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在省信息", v.CustName))
  526. }
  527. if v.CustCity == "" {
  528. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在市信息", v.CustName))
  529. }
  530. if v.CustIndustry == "" {
  531. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的客户类型信息", v.CustName))
  532. }
  533. }
  534. remark, err := json.Marshal(map[string]string{
  535. "applyUserId": strconv.Itoa(s.GetCxtUserId()),
  536. "applyUserName": s.GetCxtUserName(),
  537. })
  538. if err != nil {
  539. return err
  540. }
  541. workflowSrv, err := workflowService.NewFlowService(ctx)
  542. if err != nil {
  543. return err
  544. }
  545. for _, u := range data {
  546. bizCode := strconv.Itoa(u.Id) + ":" + strconv.Itoa(s.GetCxtUserId())
  547. _, err = workflowSrv.StartProcessInstance(bizCode, "12", string(remark), &workflow.StartProcessInstanceRequest{
  548. ProcessCode: &MoveToPubicRequestProcessCode,
  549. FormComponentValues: []*workflow.StartProcessInstanceRequestFormComponentValues{
  550. {
  551. Id: utils.String("TextField_JFWRAP0D1IO0"),
  552. Name: utils.String("客户编码"),
  553. Value: utils.String(u.CustCode),
  554. },
  555. {
  556. Id: utils.String("TextField-K2AD4O5B"),
  557. Name: utils.String("客户名称"),
  558. Value: utils.String(u.CustName),
  559. },
  560. {
  561. Id: utils.String("TextField_1THUAFLY5RGG0"),
  562. Name: utils.String("所在省"),
  563. Value: utils.String(u.CustProvince),
  564. },
  565. {
  566. Id: utils.String("TextField_15SRKAQIYY680"),
  567. Name: utils.String("所在市"),
  568. Value: utils.String(u.CustCity),
  569. },
  570. {
  571. Id: utils.String("TextField_S966SSJHCCG0"),
  572. Name: utils.String("客户类别"),
  573. Value: utils.String(cusType[u.CustIndustry]),
  574. },
  575. {
  576. Id: utils.String("TextField_Y3EQ11P49LC0"),
  577. Name: utils.String("申请人"),
  578. Value: utils.String(s.GetCxtUserName()),
  579. },
  580. {
  581. Id: utils.String("TextareaField_1790F8J2SPJ40"),
  582. Name: utils.String("移回原因"),
  583. Value: utils.String(req.Remark),
  584. },
  585. },
  586. })
  587. if err != nil {
  588. return err
  589. }
  590. _, err = s.Dao.Where("id = ?", u.Id).Data(map[string]interface{}{
  591. "cust_status": "20",
  592. }).Update()
  593. if err != nil {
  594. return err
  595. }
  596. }
  597. return nil
  598. }
  599. // 移入公海回调
  600. func (s *CustomerService) MoveToPublicApproval(flow *workflowModel.PlatWorkflow, msg *message.MixMessage) error {
  601. remark := map[string]string{}
  602. err := json.Unmarshal([]byte(flow.Remark), &remark)
  603. if err != nil {
  604. return err
  605. }
  606. userName := remark["applyUserName"]
  607. bizCode := strings.Split(flow.BizCode, ":")
  608. if len(bizCode) != 2 {
  609. return fmt.Errorf("客户移回审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  610. }
  611. custId, err := strconv.Atoi(bizCode[0])
  612. if err != nil {
  613. return fmt.Errorf("客户移回审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  614. }
  615. userId, err := strconv.Atoi(bizCode[1])
  616. if err != nil {
  617. return fmt.Errorf("客户移回审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  618. }
  619. cust, err := s.Dao.Where("id = ?", custId).One()
  620. if err != nil {
  621. return err
  622. }
  623. if cust == nil {
  624. return fmt.Errorf("客户不存在:%s Id: %d", flow.BizCode, flow.Id)
  625. }
  626. if msg.ProcessType != "finish" && msg.ProcessType != "terminate" {
  627. return fmt.Errorf("无法识别的 ProcessType :%s", msg.ProcessType)
  628. }
  629. if msg.Result != "agree" && msg.Result != "refuse" && msg.Result != "" {
  630. return fmt.Errorf("无法识别的 Result :%s", msg.Result)
  631. }
  632. if msg.ProcessType == "terminate" {
  633. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  634. "cust_status": "30",
  635. }).Update()
  636. return err
  637. }
  638. pass := msg.Result == "agree"
  639. if !pass {
  640. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  641. "cust_status": "30",
  642. }).Update()
  643. return err
  644. }
  645. now := gtime.Now()
  646. err = s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  647. //更新客户信息
  648. _, err = s.Dao.TX(tx).Data(g.Map{
  649. "cust_status": "10",
  650. "is_public": isPublic,
  651. "sales_id": 0,
  652. "dept_id": 0,
  653. "dept_name": "",
  654. "updated_time": now,
  655. }).Where("id = ?", cust.Id).Update()
  656. if err != nil {
  657. return err
  658. }
  659. //更新销售归属表结束时间
  660. _, err = s.BelongDao.TX(tx).Data(g.Map{
  661. "end_date": now,
  662. }).Where("cust_id = ?", cust.Id).Update()
  663. if err != nil {
  664. return err
  665. }
  666. return nil
  667. })
  668. if err != nil {
  669. return err
  670. }
  671. s.CxtUser = &request.UserInfo{Id: userId, UserName: userName}
  672. return s.CreateDynamics("移入公海", map[string]interface{}{
  673. "userId": userId,
  674. "custId": cust.Id,
  675. }, int64(cust.Id))
  676. }
  677. // SysAdminTransCustomer 系统管理员转移客户(不走审批)
  678. func (s *CustomerService) SysAdminTransCustomer(ctx context.Context, req *model.AssignCustomerReq) error {
  679. // 校验用户是否有修改权限
  680. arr := garray.NewStrArrayFrom(s.CxtUser.Roles, true)
  681. if !arr.Contains("SysAdmin") {
  682. return myerrors.TipsError("权限不足")
  683. }
  684. if req.Remark == "" {
  685. return myerrors.TipsError("请输入转移原因")
  686. }
  687. customerList, err := s.Dao.WherePri(req.Ids).Where(s.Dao.C.IsPublic, "20").All()
  688. if err != nil {
  689. return err
  690. }
  691. if len(customerList) == 0 {
  692. return myerrors.TipsError("转移客户不能为空")
  693. }
  694. var customerIds []int64
  695. for _, item := range customerList {
  696. customerIds = append(customerIds, int64(item.Id))
  697. }
  698. err = s.ChangeCustBelong(customerIds, req.SalesId, req.SalesName)
  699. if err != nil {
  700. return err
  701. }
  702. err = s.BatchCreatebelong(customerList, &model.AssignCustomerReq{
  703. Ids: customerIds,
  704. SalesId: req.SalesId,
  705. SalesName: req.SalesName,
  706. Remark: req.Remark,
  707. Receive: OperaTion,
  708. })
  709. if err != nil {
  710. return err
  711. }
  712. s.CreateDynamics("转移客户", map[string]interface{}{
  713. "toUserId": req.SalesId,
  714. "toUserNickName": req.SalesName,
  715. "remark": "系统管理员转移客户",
  716. }, customerIds...)
  717. return nil
  718. }
  719. // 转移客户
  720. func (s *CustomerService) TransCustomerRequest(ctx context.Context, req *model.AssignCustomerReq) error {
  721. if req.Remark == "" {
  722. return myerrors.TipsError("请输入转移原因")
  723. }
  724. data, err := s.Dao.Where("id in (?)", req.Ids).All()
  725. if err != nil {
  726. return err
  727. }
  728. if len(data) == 0 {
  729. return myerrors.TipsError("转移用户不能为空")
  730. }
  731. for _, v := range data {
  732. if v.CustStatus == "10" {
  733. return myerrors.TipsError(fmt.Sprintf("客户: %s 为公海客户", v.CustName))
  734. }
  735. if v.CustStatus == "20" {
  736. return myerrors.TipsError(fmt.Sprintf("客户: %s 正在等待审批", v.CustName))
  737. }
  738. if v.CustProvince == "" {
  739. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在省信息", v.CustName))
  740. }
  741. if v.CustCity == "" {
  742. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的所在市信息", v.CustName))
  743. }
  744. if v.CustIndustry == "" {
  745. return myerrors.TipsError(fmt.Sprintf("请先完善客户: %s 的客户类型信息", v.CustName))
  746. }
  747. }
  748. remark, err := json.Marshal(map[string]string{
  749. "applyUserId": strconv.Itoa(s.GetCxtUserId()),
  750. "applyUserName": s.GetCxtUserName(),
  751. "toUserId": strconv.FormatInt(req.SalesId, 10),
  752. "toUserName": req.SalesName,
  753. })
  754. if err != nil {
  755. return err
  756. }
  757. workflowSrv, err := workflowService.NewFlowService(ctx)
  758. if err != nil {
  759. return err
  760. }
  761. for _, u := range data {
  762. bizCode := strings.Join([]string{
  763. strconv.Itoa(u.Id),
  764. strconv.Itoa(s.GetCxtUserId()),
  765. strconv.FormatInt(req.SalesId, 10),
  766. }, ":")
  767. _, err = workflowSrv.StartProcessInstance(bizCode, "13", string(remark), &workflow.StartProcessInstanceRequest{
  768. ProcessCode: &TransCustomerRequestProcessCode,
  769. FormComponentValues: []*workflow.StartProcessInstanceRequestFormComponentValues{
  770. {
  771. Id: utils.String("TextField-K2AD4O5B"),
  772. Name: utils.String("客户编码"),
  773. Value: utils.String(u.CustCode),
  774. },
  775. {
  776. Id: utils.String("TextField_HMF1CTLP55S0"),
  777. Name: utils.String("客户名称"),
  778. Value: utils.String(u.CustName),
  779. },
  780. {
  781. Id: utils.String("TextField_SAITVT7MNF40"),
  782. Name: utils.String("所在省"),
  783. Value: utils.String(u.CustProvince),
  784. },
  785. {
  786. Id: utils.String("TextField_12DGEUTR74NK0"),
  787. Name: utils.String("所在市"),
  788. Value: utils.String(u.CustCity),
  789. },
  790. {
  791. Id: utils.String("TextField_16FDRGG3URCW0"),
  792. Name: utils.String("客户类别"),
  793. Value: utils.String(u.CustIndustry),
  794. },
  795. {
  796. Id: utils.String("TextField_1JSO6EU9XQCG0"),
  797. Name: utils.String("申请人"),
  798. Value: utils.String(s.GetCxtUserName()),
  799. },
  800. {
  801. Id: utils.String("TextareaField_1ZSSTZFCT0G00"),
  802. Name: utils.String("转移原因"),
  803. Value: utils.String(req.Remark),
  804. },
  805. },
  806. })
  807. if err != nil {
  808. return err
  809. }
  810. _, err = s.Dao.Where("id = ?", u.Id).Data(map[string]interface{}{
  811. "cust_status": "20",
  812. }).Update()
  813. if err != nil {
  814. return err
  815. }
  816. }
  817. return nil
  818. }
  819. // 转移客户回调
  820. func (s *CustomerService) TransCustomerApproval(flow *workflowModel.PlatWorkflow, msg *message.MixMessage) error {
  821. remark := map[string]string{}
  822. err := json.Unmarshal([]byte(flow.Remark), &remark)
  823. if err != nil {
  824. return err
  825. }
  826. userName := remark["applyUserName"]
  827. toUserName := remark["toUserName"]
  828. bizCode := strings.Split(flow.BizCode, ":")
  829. if len(bizCode) != 3 {
  830. return fmt.Errorf("转移客户审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  831. }
  832. custId, err := strconv.Atoi(bizCode[0])
  833. if err != nil {
  834. return fmt.Errorf("转移客户审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  835. }
  836. userId, err := strconv.Atoi(bizCode[1])
  837. if err != nil {
  838. return fmt.Errorf("转移客户审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  839. }
  840. toUserId, err := strconv.Atoi(bizCode[2])
  841. if err != nil {
  842. return fmt.Errorf("转移客户审批 bizCode 不合法:%s Id: %d", flow.BizCode, flow.Id)
  843. }
  844. // user, err := s.UserDao.Where("id = ?", userId).One()
  845. // if err != nil {
  846. // return err
  847. // }
  848. // if user == nil {
  849. // return fmt.Errorf("用户不存在:%s Id: %d", flow.BizCode, flow.Id)
  850. // }
  851. // toUser, err := s.UserDao.Where("id = ?", toUserId).One()
  852. // if err != nil {
  853. // return err
  854. // }
  855. // if toUser == nil {
  856. // return fmt.Errorf("用户不存在:%s Id: %d", flow.BizCode, flow.Id)
  857. // }
  858. cust, err := s.Dao.Where("id = ?", custId).One()
  859. if err != nil {
  860. return err
  861. }
  862. if cust == nil {
  863. return fmt.Errorf("客户不存在:%s Id: %d", flow.BizCode, flow.Id)
  864. }
  865. if msg.ProcessType != "finish" && msg.ProcessType != "terminate" {
  866. return fmt.Errorf("无法识别的 ProcessType :%s", msg.ProcessType)
  867. }
  868. if msg.Result != "agree" && msg.Result != "refuse" && msg.Result != "" {
  869. return fmt.Errorf("无法识别的 Result :%s", msg.Result)
  870. }
  871. if msg.ProcessType == "terminate" {
  872. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  873. "cust_status": "30",
  874. }).Update()
  875. return err
  876. }
  877. pass := msg.Result == "agree"
  878. if !pass {
  879. _, err = s.Dao.Where("id = ?", custId).Data(map[string]interface{}{
  880. "cust_status": "30",
  881. }).Update()
  882. return err
  883. }
  884. s.CxtUser = &request.UserInfo{Id: userId, UserName: userName}
  885. err = s.ChangeCustBelong([]int64{int64(custId)}, int64(toUserId), toUserName)
  886. if err != nil {
  887. return err
  888. }
  889. err = s.BatchCreatebelong([]*model.CustCustomer{cust}, &model.AssignCustomerReq{
  890. Ids: []int64{int64(custId)},
  891. SalesId: int64(toUserId),
  892. SalesName: toUserName,
  893. Remark: "",
  894. Receive: OperaTion,
  895. })
  896. if err != nil {
  897. return err
  898. }
  899. s.CxtUser = &request.UserInfo{Id: userId, UserName: userName}
  900. return s.CreateDynamics("转移客户", map[string]interface{}{
  901. "userId": userId,
  902. "custId": cust.Id,
  903. "toUserId": toUserId,
  904. }, int64(cust.Id))
  905. }
  906. // AssignCustomer 分配客户
  907. func (s *CustomerService) AssignCustomer(ctx context.Context, req *model.AssignCustomerReq) (err error) {
  908. if req.Receive != "" {
  909. return s.AssignCustomerRequest(ctx, req)
  910. }
  911. data, err := s.Dao.Where("id in (?)", req.Ids).LockShared().All()
  912. if err != nil {
  913. g.Log().Error(err)
  914. return
  915. }
  916. if len(data) == 0 {
  917. return myerrors.TipsError("无可分配客户")
  918. }
  919. customerNames := ""
  920. for _, v := range data {
  921. if v.SalesId != 0 {
  922. return myerrors.TipsError(fmt.Sprintf("客户名称[%s]已被领取或分配", v.CustName))
  923. }
  924. if customerNames == "" {
  925. customerNames = v.CustName
  926. } else {
  927. customerNames += "、" + v.CustName
  928. }
  929. }
  930. err = s.ChangeCustBelong(req.Ids, req.SalesId, req.SalesName)
  931. if err != nil {
  932. return
  933. }
  934. req.Receive = AllocaTion
  935. err = s.BatchCreatebelong(data, req)
  936. if err != nil {
  937. return err
  938. }
  939. // 消息提醒
  940. msg := g.MapStrStr{
  941. "msgTitle": "公海客户分配提醒",
  942. "msgContent": fmt.Sprintf("客户%v已分配给您,请前往查看", customerNames),
  943. "msgType": "20",
  944. "recvUserIds": gconv.String(req.SalesId),
  945. "msgStatus": "10",
  946. "sendType": "30",
  947. }
  948. if err := service.CreateSystemMessage(msg); err != nil {
  949. g.Log().Error("公海客户分配提醒异常:", err)
  950. }
  951. return s.CreateDynamics("分配客户", req, req.Ids...)
  952. }
  953. // GetEntityById 客户详情
  954. func (s *CustomerService) GetEntityById(Ids []int64) (entityInfo []*model.CustList, err error) {
  955. Model := s.Dao //
  956. err = Model.Where(" id in (?)", Ids).Scan(&entityInfo)
  957. if err != nil {
  958. g.Log().Error(err)
  959. return
  960. }
  961. return
  962. }
  963. // GetCustNameIsExist 判断客户名称是否存在
  964. func (s *CustomerService) GetCustNameIsExist(req *model.IsExistsCustName) (exist bool, err error) {
  965. custDao := s.Dao.M
  966. if req.Id > 0 {
  967. custDao = custDao.Where("cust_name = ", req.CustName).WhereNot(" id ", req.Id)
  968. } else {
  969. custDao = custDao.Where("cust_name = ", req.CustName)
  970. }
  971. count, err := custDao.Count()
  972. if err != nil {
  973. g.Log().Error(err)
  974. return
  975. }
  976. exist = false
  977. if count > 0 {
  978. exist = true
  979. }
  980. return
  981. }
  982. // CustAbstract 客户摘要
  983. func (s *CustomerService) CustAbstract(Id int64) (followInfo *model.Follow, err error) {
  984. count, err := s.FollowDao.Where(s.FollowDao.C.CustId, Id).Count()
  985. if err != nil {
  986. g.Log().Error(err)
  987. return
  988. }
  989. followInfo = new(model.Follow)
  990. followInfo.FollowCount = count
  991. followTime, err := s.Dao.Fields(s.Dao.C.FollowUpDate, s.Dao.C.CreatedTime).FindOne(Id)
  992. if err != nil {
  993. g.Log().Error(err)
  994. return
  995. }
  996. if followTime == nil {
  997. err = myerrors.TipsError("获取客户信息不存在")
  998. return
  999. }
  1000. now := gtime.Now()
  1001. var difference time.Duration
  1002. if followTime.FollowUpDate.IsZero() {
  1003. difference = now.Sub(gtime.New(followTime.CreatedTime))
  1004. } else {
  1005. difference = now.Sub(gtime.New(followTime.FollowUpDate))
  1006. }
  1007. days := difference.Hours() / 24
  1008. if days < 0 {
  1009. followInfo.NotFollowDay = 0
  1010. } else {
  1011. followInfo.NotFollowDay = int(math.Floor(days))
  1012. }
  1013. return
  1014. }
  1015. // // TransCustomer 转移客户
  1016. // func (s *CustomerService) TransCustomer(req *model.AssignCustomerReq) (err error) {
  1017. // data, err := s.Dao.Fields("sales_id,sales_name,id").Where("id in (?)", req.Ids).All()
  1018. // if err != nil {
  1019. // g.Log().Error(err)
  1020. // return err
  1021. // }
  1022. // if len(data) == 0 {
  1023. // return myerrors.TipsError("数据不存在")
  1024. // }
  1025. // err = s.ChangeCustBelong(req.Ids, req.SalesId, req.SalesName)
  1026. // if err != nil {
  1027. // g.Log().Error(err)
  1028. // return
  1029. // }
  1030. // req.Receive = OperaTion
  1031. // s.BatchCreatebelong(data, req)
  1032. // return
  1033. // }
  1034. // ChangeCustBelong 变更客户所属关系
  1035. func (s *CustomerService) ChangeCustBelong(Ids []int64, salesId int64, salesName string) (err error) {
  1036. _, err = s.Dao.Data(g.Map{
  1037. "cust_status": "30",
  1038. "sales_id": salesId,
  1039. "is_public": noPublic,
  1040. "sales_name": salesName,
  1041. "updated_by": s.GetCxtUserId(),
  1042. "updated_name": s.GetCxtUserName(),
  1043. "updated_time": gtime.Now(),
  1044. }).Where("id in (?)", Ids).Update()
  1045. return err
  1046. }
  1047. // CreateDynamics 创建客户动态信息
  1048. func (s *CustomerService) CreateDynamics(opnTpye string, content interface{}, ids ...int64) (err error) {
  1049. datas := make([]*model.CustCustomerDynamics, 0)
  1050. for _, id := range ids {
  1051. dynameics := new(model.CustCustomerDynamics)
  1052. dynameics.CustId = int(id)
  1053. dynameics.OpnPeopleId = s.GetCxtUserId()
  1054. dynameics.OpnPeople = s.GetCxtUserName()
  1055. dynameics.OpnDate = gtime.Now()
  1056. dynameics.OpnType = opnTpye
  1057. v, _ := gjson.Encode(content)
  1058. dynameics.OpnContent = gconv.String(v)
  1059. service.SetCreatedInfo(dynameics, s.GetCxtUserId(), s.GetCxtUserName())
  1060. datas = append(datas, dynameics)
  1061. }
  1062. _, err = s.DynamicsDao.Insert(datas)
  1063. if err != nil {
  1064. g.Log().Error(err)
  1065. return
  1066. }
  1067. return
  1068. }
  1069. // GetDynamicsList 客户动态
  1070. func (s *CustomerService) GetDynamicsList(req *model.CustomerDynameicsReq) (total int, result []interface{}, err error) {
  1071. total, err = s.DynamicsDao.Where("cust_id = ", req.CustId).Count()
  1072. if err != nil {
  1073. g.Log().Error(err)
  1074. return
  1075. }
  1076. dynamics := []*model.CustomerDynameicsRep{}
  1077. err = s.DynamicsDao.Where("cust_id = ", req.CustId).Order("created_time desc").Scan(&dynamics)
  1078. if err != nil {
  1079. g.Log().Error(err)
  1080. return
  1081. }
  1082. dynamicsList := make(map[string][]*model.CustomerDynameicsRep)
  1083. for _, v := range dynamics {
  1084. opnDate := gtime.New(v.OpnDate).Format("Y-m-d")
  1085. dynamicsList[opnDate] = append(dynamicsList[opnDate], &model.CustomerDynameicsRep{
  1086. OpnPeople: v.OpnPeople,
  1087. OpnDate: v.OpnDate,
  1088. OpnType: v.OpnType,
  1089. OpnContent: v.OpnContent,
  1090. })
  1091. }
  1092. result = append(result, dynamicsList)
  1093. return
  1094. }
  1095. // MergeCustomer 合并客户
  1096. func (s *CustomerService) MergeCustomer(req *model.MergeCustomerRep) (err error) {
  1097. //当前目标客户是否存在并取出合并前的销售
  1098. customer, err := s.Dao.Where("id = ", req.Id).One()
  1099. if err != nil {
  1100. g.Log().Error(err)
  1101. return
  1102. }
  1103. if customer == nil {
  1104. return myerrors.TipsError("该客户不存在")
  1105. }
  1106. _, err = s.ContactDao.Where(" cust_id in (?)", req.ChooseId).Delete()
  1107. if err != nil {
  1108. g.Log().Error(err)
  1109. return
  1110. }
  1111. CustomertData := new(model.CustomerAddSeq)
  1112. if err = gconv.Struct(req, CustomertData); err != nil {
  1113. g.Log().Error(err)
  1114. return
  1115. }
  1116. service.SetUpdatedInfo(CustomertData, s.GetCxtUserId(), s.GetCxtUserName())
  1117. _, err = s.Dao.FieldsEx(s.Dao.C.CreatedTime, s.Dao.C.CreatedBy,
  1118. s.Dao.C.CreatedName, s.Dao.C.Id,
  1119. s.Dao.C.CustCode).WherePri(s.Dao.C.Id, req.Id).Update(CustomertData)
  1120. if err != nil {
  1121. g.Log().Error(err)
  1122. return
  1123. }
  1124. //删除被合并的客户信息
  1125. _, err = s.Dao.Where(" id in (?)", req.ChooseId).Delete()
  1126. if err != nil {
  1127. g.Log().Error(err)
  1128. return
  1129. }
  1130. //删除 所选客户销售联系人
  1131. _, err = s.BelongDao.Where(" cust_id in (?)", req.ChooseId).Delete()
  1132. if err != nil {
  1133. g.Log().Error(err)
  1134. return
  1135. }
  1136. //插入一条合并成功的归属记录
  1137. //更新销售归属表销售结束时间
  1138. _, err = s.BelongDao.Data(
  1139. g.Map{
  1140. "updated_by": s.GetCxtUserId(),
  1141. "updated_name": s.GetCxtUserName(),
  1142. "end_date": gtime.Now(),
  1143. }).WhereIn(s.BelongDao.C.CustId, req.Id).Update()
  1144. if err != nil {
  1145. g.Log().Error(err)
  1146. return
  1147. }
  1148. req.CustomerBelongAddSeq.CustId = int(req.Id)
  1149. req.CustomerBelongAddSeq.OpnType = Merge
  1150. req.CustomerBelongAddSeq.OpnPeople = s.GetCxtUserName()
  1151. req.CustomerBelongAddSeq.OrigSaleName = customer.SalesName
  1152. req.CustomerBelongAddSeq.SaleName = req.SalesName
  1153. s.BelongServer.Create(req.CustomerBelongAddSeq)
  1154. return
  1155. }
  1156. // CreateContact 联系人(合并)预留
  1157. func (s *CustomerService) CreateContact(Ids []int64, req *model.CustCustomerContactSeq) (err error) {
  1158. _, err = s.ContactDao.Where(" cust_id in (?)", Ids).Delete()
  1159. if err != nil {
  1160. g.Log().Error(err)
  1161. return
  1162. }
  1163. s.ContanctServer.Create(req)
  1164. return
  1165. }
  1166. // BatchCreatebelong 批量插入客户归属记录表
  1167. func (s *CustomerService) BatchCreatebelong(rep []*model.CustCustomer, req *model.AssignCustomerReq, n ...interface{}) (err error) {
  1168. //更新销售归属表销售结束时间
  1169. _, err = s.BelongDao.Data(
  1170. g.Map{
  1171. "updated_by": s.GetCxtUserId(),
  1172. "updated_name": s.GetCxtUserName(),
  1173. "end_date": gtime.Now(),
  1174. }).WhereIn(s.BelongDao.C.CustId, req.Ids).Update()
  1175. if err != nil {
  1176. return err
  1177. }
  1178. var belongData []*model.CustCustomerBelong
  1179. userName := s.GetCxtUserName()
  1180. for _, v := range rep {
  1181. orig_sale_name := v.SalesName
  1182. belong := new(model.CustCustomerBelong)
  1183. belong.CustId = v.Id
  1184. belong.SaleName = req.SalesName
  1185. belong.OrigSaleName = orig_sale_name
  1186. belong.OpnType = req.Receive
  1187. belong.OpnPeople = userName
  1188. belong.CreatedName = userName
  1189. belong.StartDate = gtime.Now() //新增开始时间
  1190. belong.OpnDatetime = gtime.Now()
  1191. belong.Remark = req.Remark
  1192. belong.CreatedBy = s.GetCxtUserId()
  1193. belongData = append(belongData, belong)
  1194. }
  1195. _, err = s.BelongDao.Insert(belongData)
  1196. return err
  1197. }
  1198. // 导出数据
  1199. func (s *CustomerService) Export(ctx context.Context, req *model.CustCustomerExport) (content *model.CustExport, err error) {
  1200. var con model.CustExport
  1201. req.IsRemovePage = true // 去掉分页标识
  1202. total, data, err := s.GetList(&req.CustCustomerSearchReq)
  1203. if err != nil {
  1204. return
  1205. }
  1206. cusType, err := service.GetDictDataByType(ctx, "cust_idy")
  1207. if err != nil {
  1208. return nil, err
  1209. }
  1210. f := excelize.NewFile()
  1211. index := f.NewSheet("Sheet1")
  1212. for index, item := range req.Columns {
  1213. sheetPosition := service.Div(index+1) + "1"
  1214. f.SetCellValue("Sheet1", sheetPosition, item)
  1215. }
  1216. if total > 0 {
  1217. for ck, item := range data {
  1218. for index, v := range req.Columns {
  1219. if v == "客户编码" {
  1220. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustCode)
  1221. }
  1222. if v == "客户名称" {
  1223. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustName)
  1224. }
  1225. if v == "助记名" {
  1226. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.AbbrName)
  1227. }
  1228. if v == "助记名" {
  1229. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.AbbrName)
  1230. }
  1231. if v == "所在地区" {
  1232. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustLocation)
  1233. }
  1234. if v == "客户类型" {
  1235. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), cusType[item.CustIndustry])
  1236. }
  1237. if v == "客户级别" {
  1238. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustLevel)
  1239. }
  1240. if v == "客户状态" {
  1241. var CustStatus string
  1242. CustStatus = "正常"
  1243. if item.CustStatus != "10" {
  1244. CustStatus = "异常"
  1245. }
  1246. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), CustStatus)
  1247. }
  1248. if v == "创建人" {
  1249. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CreatedName)
  1250. }
  1251. if v == "最后跟进时间" {
  1252. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.FollowUpDate)
  1253. }
  1254. if v == "创建时间" {
  1255. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CreatedTime)
  1256. }
  1257. if v == "所在省" {
  1258. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustProvince)
  1259. }
  1260. if v == "所在市" {
  1261. f.SetCellValue("Sheet1", service.Div(index+1)+strconv.Itoa(ck+2), item.CustCity)
  1262. }
  1263. }
  1264. }
  1265. }
  1266. f.SetActiveSheet(index)
  1267. var buffer *bytes.Buffer
  1268. buffer, _ = f.WriteToBuffer()
  1269. con.Content = buffer.Bytes()
  1270. return &con, err
  1271. }