cust_customer.go 37 KB

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