cust_customer.go 34 KB

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