cust_customer.go 36 KB

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