12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096 |
- package main
- import (
- "database/sql"
- "fmt"
- "github.com/gogf/gf/v2/util/gconv"
- "log"
- "strings"
- "time"
- "app.yhyue.com/moapp/jybase/date"
- "app.yhyue.com/moapp/jybase/redis"
- "app.yhyue.com/moapp/jybase/common"
- "app.yhyue.com/moapp/jybase/mongodb"
- )
- func FormatData(data map[string]interface{}, item string) (bool, bool, bool) {
- userId, uId, positionId, source, cluename, phone, sourceCode, keyword, s_sourceid := common.ObjToString(data["user_id"]), "", "", "", "", "", "", []string{}, ""
- role, industry, department, departments, position, name, top_cluetype, sub_cluetype, follow_project_area, level := "", "", "", "", "", "", "", "", "", ""
- query, topname, subname, belong_to, sourceName, remark, sourceId := map[string]interface{}{}, "", "", "01", "", "", int64(0)
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- if item == "orders" { //订单
- if !mongodb.IsObjectIdHex(userId) {
- positionId = userId
- userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userId}, "", "")
- if userMapping != nil && len(*userMapping) > 0 {
- userId = common.ObjToString((*userMapping)["userid"])
- }
- }
- query["userid"] = userId
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"]) //用户来源
- belong_to = common.ObjToString((*userInfo)["belong_to"]) //用户归属
- }
- cluename = common.ObjToString(data["company_name"])
- phone = common.ObjToString(data["user_phone"])
- } else if item == "message" {
- userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"base_user_id": common.Int64All(data["own_id"])}, "", "")
- if userMapping != nil && len(*userMapping) > 0 {
- userId = common.ObjToString((*userMapping)["userid"])
- positionId = fmt.Sprint((*userMapping)["position_id"])
- }
- query["userid"] = userId
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- phone = common.ObjToString((*userInfo)["phone"])
- if phone != "" {
- phoneMapping := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"phone": phone}, "", "")
- if phoneMapping != nil && len(*phoneMapping) > 0 {
- cluename = common.ObjToString((*phoneMapping)["cluename"])
- }
- }
- }
- } else if item == "users" || item == "xcxusers" { //注册用户
- if Mgo.Count("user_share", map[string]interface{}{
- "shared_uid": userId,
- }) > 0 {
- return true, true, true
- }
- userId = mongodb.BsonIdToSId(data["userid"])
- //新用户没有uid、source要等5分钟
- cluename = common.ObjToString(data["company_name"])
- phone = common.ObjToString(data["phone"])
- if phone != "" {
- contactsData := TiDb.SelectBySql("select * from dwd_f_userbase_contacts where phone = ? and is_delete = 1", phone)
- if contactsData != nil && len(*contactsData) > 0 {
- if common.ObjToString((*contactsData)[0]["baseinfo_id"]) != "" {
- uId = common.ObjToString((*contactsData)[0]["baseinfo_id"])
- query["uid"] = uId
- } else {
- query["userid"] = userId
- }
- } else {
- query["userid"] = userId
- }
- //createtimeStr := ""
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- s_sourceid = common.ObjToString((*userInfo)["s_sourceid"])
- //createtimeStr = common.ObjToString((*userInfo)["l_registedate"])
- }
- if item == "xcxusers" {
- sourceCode = common.ObjToString(data["industry"])
- //t, _ := time.Parse("2006-01-02 15:04:05", createtimeStr)
- if sourceCode == "" {
- log.Println("留资没有source", phone)
- return true, true, true
- }
- /* 安防代码
- if t.Unix() > db.NewRegistration && sourceCode == "安防" {
- return true, true, false
- }*/
- //线索名称查询处理
- clueData, _ := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, "", ""), true //查当前线索是否已存在
- if clueData != nil && len(*clueData) > 0 {
- cluename = gconv.String((*clueData)["cluename"])
- } else {
- cluename = phone
- }
- }
- }
- } else if item == "allocation" || item == "rebind" {
- userId = mongodb.BsonIdToSId(data["mogUserId"])
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{
- "userid": userId,
- }, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- phone = common.ObjToString((*userInfo)["phone"])
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- }
- } else if item == "saleLeads" { //留资
- //线索名称打印
- log.Println(1111, common.ObjToString(data["company"]))
- userId = common.ObjToString(data["userid"])
- if !mongodb.IsObjectIdHex(userId) {
- positionId = userId
- userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userId}, "", "")
- if userMapping != nil && len(*userMapping) > 0 {
- userId = common.ObjToString((*userMapping)["userid"])
- }
- }
- cluename = common.ObjToString(data["company"])
- phone = common.ObjToString(data["phone"])
- role = common.ObjToString(data["companyType"])
- industry = common.ObjToString(data["industry"])
- department = common.ObjToString(data["branch"])
- departments = common.ObjToString(data["department"])
- position = common.ObjToString(data["position"])
- name = common.ObjToString(data["name"])
- sourceCode = common.ObjToString(data["source"])
- if sourceCode == "" {
- log.Println("留资没有source", phone)
- return true, true, true
- }
- remark = common.ObjToString(data["jyRemark"]) //荟聚线索备注
- keywordArr := data["keyword"]
- if keywordArr != nil {
- keyword = common.ObjArrToStringArr(data["keyword"].([]interface{}))
- }
- contactsData := TiDb.SelectBySql("select * from dwd_f_userbase_contacts where phone = ? and is_delete = 1", phone)
- if contactsData != nil && len(*contactsData) > 0 {
- if common.ObjToString((*contactsData)[0]["baseinfo_id"]) != "" {
- uId = common.ObjToString((*contactsData)[0]["baseinfo_id"])
- query["uid"] = uId
- } else {
- query["userid"] = userId
- }
- } else {
- query["userid"] = userId
- }
- if userId != "" || uId != "" {
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- userId = common.ObjToString((*userInfo)["userid"])
- s_sourceid = common.ObjToString((*userInfo)["s_sourceid"])
- }
- } else {
- if sourceCode == "report_retention" || sourceCode == "marketing_retention" { //荟聚线索来源,不是剑鱼用户,需要等待用户归集
- log.Println("不是剑鱼用户留资,等待用户", phone)
- return false, false, true
- } else if remark != "" {
- log.Println("留资source过滤", phone, sourceCode)
- return true, true, true
- }
- }
- } else if item == "eventReg" { //渠道
- userId = common.ObjToString(data["userid"])
- cluename = common.ObjToString(data["company"])
- phone = common.ObjToString(data["sign_phone"])
- role = common.ObjToString(data["company_type"])
- department = common.ObjToString(data["branch"])
- position = common.ObjToString(data["position"])
- name = common.ObjToString(data["sign_name"])
- sourceCode = common.ObjToString(data["source_code"])
- sourceName = common.ObjToString(data["source_name"])
- log.Println(sourceName)
- contactsData := TiDb.SelectBySql("select * from dwd_f_userbase_contacts where phone = ? and is_delete = 1", phone)
- if contactsData != nil && len(*contactsData) > 0 {
- if common.ObjToString((*contactsData)[0]["baseinfo_id"]) != "" {
- uId = common.ObjToString((*contactsData)[0]["baseinfo_id"])
- query["uid"] = uId
- } else {
- query["userid"] = userId
- }
- } else {
- query["userid"] = userId
- }
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- userId = common.ObjToString((*userInfo)["userid"])
- }
- if role == "集成商" || role == "设计院" {
- role = "其他-" + role
- }
- } else if item == "readClue" {
- userId = common.ObjToString(data["userId"])
- query["userid"] = userId
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"])
- belong_to = common.ObjToString((*userInfo)["belong_to"])
- }
- // cluename = common.ObjToString(data["companyName"])
- phone = common.ObjToString(data["phone"])
- sourceId = common.Int64All(data["sourceId"])
- } else if item == "invite" {
- query["userid"] = userId
- userInfo := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
- if userInfo != nil && len(*userInfo) > 0 {
- uId = common.ObjToString((*userInfo)["uid"])
- source = common.ObjToString((*userInfo)["source"]) //用户来源
- belong_to = common.ObjToString((*userInfo)["belong_to"]) //用户归属
- } else {
- log.Println("邀请用户,用户归集没数据", data)
- return true, true, true
- }
- cluename = common.ObjToString((*userInfo)["company_name"])
- phone = common.ObjToString((*userInfo)["phone"])
- sourceCode = common.ObjToString(data["sourceCode"])
- }
- log.Println(222, cluename)
- if cluename == "" && item != "message" && item != "orders" && item != "readClue" && item != "rebind" && item != "allocation" {
- cluename = phone //没有线索名,手机号代替
- }
- log.Println(333, cluename)
- cluename = strings.ReplaceAll(cluename, " ", "")
- isGroup, isCommerce := GetCompanyType(cluename) //判断是否集团公司、工商库
- if source == "0104" || strings.HasPrefix(belong_to, "02") || source == "0102" || source == "0103" || phone == "" { //参照用户来源代码表
- //log.Println("线索分配失败,线索过滤!!", item, source, phone, userId)
- //saveHlyj(belong_to, item, phone, name, sourceName, cluename, position, nowTime, isGroup, isCommerce)
- return true, true, true
- }
- //安博会
- if s_sourceid == db.Sourceid {
- return true, true, false
- }
- if uId == "" { //没有进用户归集,等待进入,结束任务,放在下次继续执行
- if isExists, _ := redis.Exists("bidx", "bidx_userId_"+userId); isExists {
- redisInt := redis.GetInt("bidx", "bidx_userId_"+userId)
- if redisInt > 4 {
- log.Println("线索分配失败,线索缺少信息,任务已执行超过1次", item, userId, phone)
- return true, true, true
- } else {
- redis.Incr("bidx", "bidx_userId_"+userId)
- }
- } else {
- redis.Put("bidx", "bidx_userId_"+userId, 1, 3600)
- }
- log.Println("线索分配失败,线索缺少信息", item, phone, userId)
- return false, false, true
- }
- if item == "orders" { //订单没信息再查一遍留资
- qid := positionId
- if qid == "" {
- qid = userId
- }
- saleLeadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"userid": qid}, map[string]interface{}{"_id": -1}, nil, false, 0, 1)
- if ok && saleLeadsData != nil && len(*saleLeadsData) > 0 {
- sdata := (*saleLeadsData)[0]
- role = common.ObjToString(sdata["companyType"])
- industry = common.ObjToString(sdata["industry"])
- department = common.ObjToString(sdata["branch"])
- departments = common.ObjToString(sdata["department"])
- position = common.ObjToString(sdata["position"])
- name = common.ObjToString(sdata["name"])
- }
- }
- top_cluetype, sub_cluetype, level, topname, subname = getClueType(item, data, sourceCode, sourceId) //查留资来源名字
- if topname == "市场活动" && item == "saleLeads" { //市场活动的不要
- log.Println("市场活动留资过滤 ", userId, phone)
- return true, true, true
- }
- if strings.HasPrefix(belong_to, "03") { //一切都好的不进
- isOk := saveEverything(userId, phone, item, subname, sourceCode)
- log.Println("渠道线索电销", userId, phone, item, subname, sourceCode)
- if !isOk {
- return true, true, true
- }
- }
- follow_project_area = getAreaCode(userId) //关注项目区域
- log.Println("data +++", top_cluetype, sub_cluetype, level, follow_project_area, isGroup, isCommerce)
- if top_cluetype == "" || sub_cluetype == "" || level == "" {
- log.Println("线索分配失败,线索过滤top_cluetype!!", item, uId, phone, userId)
- return true, true, true
- }
- log.Println("人员选择", level, cluename, phone, isGroup, isCommerce)
- position_id, seatNumber, saleName, saleData, pIsOk, isFreeze, noticePositionId := autoDraw(level, cluename, phone, isGroup, isCommerce) //查询当前分配次数最少的,如果当前线索有销售,此次找出的不会+1
- log.Println("data -------", position_id, seatNumber, saleName, pIsOk, isFreeze, noticePositionId)
- if position_id > 0 && seatNumber != "" {
- uCount, oks := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, "", ""), true //查当前线索是否已存在
- if uCount != nil && len(*uCount) > 0 {
- isUpdate := gconv.Int64((*uCount)["is_artificially_modified"])
- if isUpdate == 1 {
- cluename = ""
- }
- //已存在,走更新
- batch_import := common.ObjToString((*uCount)["batch_import"])
- if batch_import != "" && item == "users" { //有导入批次号还是新用户,不执行
- return true, true, true
- }
- oks = UpdateClue(*uCount, saleData, item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, level, position_id, source, sourceCode, remark, keyword, belong_to, isGroup, isCommerce, pIsOk)
- } else { //不存在走新增
- oks = SaveClue(item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, position_id, source, sourceCode, remark, keyword, belong_to, isGroup, isCommerce, isFreeze, "")
- if oks { //新增成功,销售分配次数+1
- TiDb.UpdateOrDeleteBySql(`update dwd_f_crm_clue_autodraw_record set count = count + 1 where position_id = ? and clue_level = ?`, position_id, level)
- }
- }
- if !oks {
- log.Println("线索分配失败!!", item, position_id, seatNumber, uId, userId, phone)
- return false, false, true
- }
- } else {
- if isFreeze {
- //达上限放公海处理
- uCount, oks := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, "", ""), true //查当前线索是否已存在
- if uCount == nil || len(*uCount) == 0 {
- oks = SaveClue0(item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, position_id, source, sourceCode, remark, keyword, belong_to, isGroup, isCommerce, isFreeze)
- log.Println(oks)
- } else {
- //留资线索更新
- if item != "orders" && item != "users" { //新用户和订单之外的替换一下新的留资信息
- BCPCID := common.GetRandom(32)
- clueId := common.Int64All((*uCount)["id"])
- old_name := common.ObjToString((*uCount)["name"])
- old_position := common.ObjToString((*uCount)["position"])
- old_department := common.ObjToString((*uCount)["department"])
- old_follow_project_area := common.ObjToString((*uCount)["follow_project_area"])
- old_role := common.ObjToString((*uCount)["role"])
- old_cluename := common.ObjToString((*uCount)["cluename"])
- old_top_cluetype := common.ObjToString((*uCount)["top_cluetype"])
- old_sub_cluetype := common.ObjToString((*uCount)["sub_cluetype"])
- clueUpdateData := map[string]interface{}{}
- if old_name != name && name != "" {
- clueUpdateData["name"] = name
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "name",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_name != "", old_name, "/"),
- "new_value": common.If(name != "", name, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_position != position && position != "" {
- clueUpdateData["position"] = position
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "position",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_position != "", old_position, "/"),
- "new_value": common.If(position != "", position, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_department != department && department != "" {
- clueUpdateData["department"] = department
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "department",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_department != "", old_department, "/"),
- "new_value": common.If(department != "", department, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_follow_project_area != follow_project_area && follow_project_area != "" {
- clueUpdateData["follow_project_area"] = follow_project_area
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "follow_project_area",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_follow_project_area != "", old_follow_project_area, "/"),
- "new_value": common.If(follow_project_area != "", follow_project_area, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_role != role && role != "" {
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "role",
- "change_type": "基本信息变更",
- "old_value": common.If(old_role != "", old_role, "/"),
- "new_value": common.If(role != "", role, "/"),
- "createtime": nowTime,
- "position_id": 0,
- "BCPCID": BCPCID,
- "operator_id": -1})
- clueUpdateData["role"] = role
- }
- if old_cluename != cluename && cluename != "" {
- clueUpdateData["cluename"] = cluename //新的线索名不为空才替换
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "cluename",
- "change_type": "基本信息变更",
- "old_value": common.If(old_cluename != "", old_cluename, "/"),
- "new_value": common.If(cluename != "", cluename, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "position_id": 0,
- "operator_id": -1})
- }
- old_topname := ""
- old_subname := ""
- if old_top_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_top_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_topname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if old_sub_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_sub_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_subname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if old_top_cluetype != top_cluetype && top_cluetype != "" {
- clueUpdateData["top_cluetype"] = top_cluetype //新的线索名不为空才替换
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "top_cluetype",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_topname != "", old_topname, "/"),
- "new_value": common.If(topname != "", topname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_sub_cluetype != sub_cluetype && sub_cluetype != "" {
- clueUpdateData["sub_cluetype"] = sub_cluetype //新的线索名不为空才替换
- TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "change_field": "sub_cluetype",
- "position_id": 0,
- "change_type": "基本信息变更",
- "old_value": common.If(old_subname != "", old_subname, "/"),
- "new_value": common.If(subname != "", subname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- clueUpdateData["company_nature"] = isGroup
- clueUpdateData["company_verification"] = isCommerce
- TiDb.Update("dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, clueUpdateData)
- }
- }
- AssFail(noticePositionId, cluename, phone)
- return true, true, true
- }
- return true, false, true
- }
- return true, true, true
- }
- func SaveClue(item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber string, positionId int64, source, sourceCode, remark string, keyword []string, belong_to string, isGroup, isCommerce int, isFreeze bool, demand string) bool {
- log.Println("线索修改前", item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, positionId, source, sourceCode, remark)
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- nowTimes := time.Unix(time.Now().Unix()+3600*12, 0).Format("2006-01-02 15:04:05")
- clueId, uodateId1, uodateId2, uodateId3, uodateId4, uodateId5, uodateId6 := int64(0), int64(0), int64(0), int64(0), int64(0), int64(0), int64(0)
- if TiDb.ExecTx("保存线索", func(tx *sql.Tx) bool {
- keywords := ""
- if sourceCode == "app_xzcyh" {
- if len(keyword) > 0 && keyword[0] != "" {
- keywords = strings.Join(keyword, ",")
- }
- }
- if cluename == "" {
- cluename = phone
- }
- clueId = TiDb.InsertByTx(tx, "dwd_f_crm_clue_info", map[string]interface{}{
- "userid": userId,
- "uid": uId,
- "seatNumber": seatNumber,
- "position_id": positionId,
- "is_assign": common.If(isFreeze, -3, 1),
- "comeintime": nowTime,
- "createtime": nowTime,
- "updatetime": nowTime,
- "cluename": cluename,
- "top_cluetype": top_cluetype,
- "sub_cluetype": sub_cluetype,
- "trailstatus": "01",
- "name": name,
- "phone": phone,
- "position": position,
- "department": common.If(sourceCode == "app_xzcyh", departments, department),
- "industry": industry,
- "follow_project_area": follow_project_area,
- "role": role,
- "comeinsource_private": 2,
- "is_task": 1,
- "task_time": nowTime,
- "tasktime": common.If(item == "users", nowTimes, nowTime),
- "taskstatus": 0,
- "tasksource": "线索自动分配" + "-" + topname + "-" + subname,
- "business_scope": common.If(sourceCode == "app_xzcyh", keywords, nil),
- "company_nature": isGroup,
- "company_verification": isCommerce,
- "remark": remark,
- "customer_demand": demand,
- "FREEZE_TIME": nowTime,
- })
- uodateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_type": "创建线索",
- "new_value": "系统自动创建",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId2 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": "/",
- "new_value": saleName,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_type": "加入任务车",
- "new_value": "线索自动分配" + "-" + topname + "-" + subname,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId5 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "top_cluetype",
- "change_type": "基本信息变更",
- "old_value": "/",
- "new_value": topname,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId6 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "sub_cluetype",
- "change_type": "基本信息变更",
- "old_value": "/",
- "new_value": subname,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- //冻结处理
- return clueId > -1 && uodateId1 > -1 && uodateId2 > -1 && uodateId3 > -1 && uodateId4 > -1 && uodateId5 > -1 && uodateId6 > -1
- }) {
- log.Println("线索分配成功")
- if TiDb.Count("dwd_f_userbase_contacts", map[string]interface{}{"phone": phone}) == 0 {
- TiDb.Insert("dwd_f_userbase_contacts", map[string]interface{}{
- "status": 1,
- "is_delete": 1,
- "createtime": nowTime,
- "updatetime": nowTime,
- "phone": phone,
- "baseinfo_id": uId,
- "SOURCE": source,
- })
- }
- return true
- } else {
- log.Println("线索分配失败!!!", clueId, uodateId1, uodateId2, uodateId3, uodateId4, uodateId5, uodateId6, " 用户信息 ", item, position, seatNumber, uId, userId, phone)
- return false
- }
- }
- func SaveClue0(item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber string, positionId int64, source, sourceCode, remark string, keyword []string, belong_to string, isGroup, isCommerce int, isFreeze bool) bool {
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- clueId, uodateId1, uodateId2, uodateId3 := int64(0), int64(0), int64(0), int64(0)
- if TiDb.ExecTx("保存线索", func(tx *sql.Tx) bool {
- keywords := ""
- if sourceCode == "app_xzcyh" {
- if len(keyword) > 0 && keyword[0] != "" {
- keywords = strings.Join(keyword, ",")
- }
- }
- if cluename == "" {
- cluename = phone
- }
- clueId = TiDb.InsertByTx(tx, "dwd_f_crm_clue_info", map[string]interface{}{
- "userid": userId,
- "uid": uId,
- "seatNumber": "",
- "position_id": 0,
- "is_assign": 0,
- "comeintime": nowTime,
- "createtime": nowTime,
- "updatetime": nowTime,
- "cluename": cluename,
- "top_cluetype": top_cluetype,
- "sub_cluetype": sub_cluetype,
- "trailstatus": "01",
- "name": name,
- "phone": phone,
- "position": position,
- "department": common.If(sourceCode == "app_xzcyh", departments, department),
- "industry": industry,
- "follow_project_area": follow_project_area,
- "role": role,
- "comeinsource_private": 2,
- "business_scope": common.If(sourceCode == "app_xzcyh", keywords, nil),
- "company_nature": isGroup,
- "company_verification": isCommerce,
- "remark": remark,
- "FREEZE_TIME": nowTime,
- })
- uodateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_type": "创建线索",
- "new_value": "系统自动创建",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId2 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": "",
- "new_value": "/",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- uodateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- return clueId > -1 && uodateId1 > -1 && uodateId2 > -1 && uodateId3 > -1
- }) {
- log.Println("线索分配成功")
- if TiDb.Count("dwd_f_userbase_contacts", map[string]interface{}{"phone": phone}) == 0 {
- TiDb.Insert("dwd_f_userbase_contacts", map[string]interface{}{
- "status": 1,
- "is_delete": 1,
- "createtime": nowTime,
- "updatetime": nowTime,
- "phone": phone,
- "baseinfo_id": uId,
- "SOURCE": source,
- })
- }
- return true
- } else {
- log.Println("线索分配失败!!!", clueId, uodateId1, uodateId2, uodateId3, " 用户信息 ", item, position, seatNumber, uId, userId, phone)
- return false
- }
- }
- func WorkUpdateClue(data map[string]interface{}, saleData []map[string]interface{}, item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, level string, positionId int64, source, sourceCode, remark string, keyword []string, belong_to string, isGroup, isCommerce int, pIsOk bool, demand string) bool {
- log.Println("工单线索修改前", data)
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- nowTimes := time.Unix(time.Now().Unix()+3600*12, 0).Format("2006-01-02 15:04:05")
- trailstatus := common.ObjToString(data["trailstatus"]) //data都为原线索数据
- trailstatusTime := common.ObjToString(data["trailstatus_time"])
- var trailstatusTimes time.Time
- if trailstatusTime != "" {
- trailstatusTimes, _ = time.ParseInLocation(date.Date_Full_Layout, trailstatusTime, time.Local)
- }
- clueId := common.Int64All(data["id"])
- is_assign := common.IntAll(data["is_assign"])
- oldsaleName, oldTaskTime, taskTime, is_task, taskstatus := "", "", "", 0, 0
- old_position_id, old_seatNumber := common.Int64All(data["position_id"]), common.ObjToString(data["seatNumber"])
- oldTaskTime = common.ObjToString(data["tasktime"])
- is_task = common.IntAll(data["is_task"])
- taskstatus = common.IntAll(data["taskstatus"])
- BCPCID := common.GetRandom(32)
- old_name := common.ObjToString(data["name"])
- old_position := common.ObjToString(data["position"])
- old_department := common.ObjToString(data["department"])
- old_follow_project_area := common.ObjToString(data["follow_project_area"])
- old_role := common.ObjToString(data["role"])
- old_cluename := common.ObjToString(data["cluename"])
- old_top_cluetype := common.ObjToString(data["top_cluetype"])
- old_sub_cluetype := common.ObjToString(data["sub_cluetype"])
- old_topname, old_subname := "", ""
- is_transfer := common.IntAll(data["is_transfer"])
- if taskstatus == 1 || is_task == 0 {
- taskTime = common.ObjToString(common.If(item != "users", nowTime, nowTimes)) //任务时间,正常的是当前时间,新用户是当前时间+12个小时
- } else {
- if is_task == 1 {
- if oldTaskTime != "" { //以最新的任务时间为主
- t1, err := time.Parse("2006-01-02 15:04:05", oldTaskTime)
- if err == nil && time.Now().Before(t1) {
- taskTime = nowTime
- } else {
- taskTime = oldTaskTime
- }
- }
- }
- }
- count, counts, t := 0, 0, time.Now() //加入任务车判断节假日
- for {
- count++
- currentTime := t.AddDate(0, 0, -count)
- if currentTime.Weekday() == time.Sunday || currentTime.Weekday() == time.Saturday {
- isok := false
- for k, v := range DateMap {
- if currentTime.Format(date.Date_Short_Layout) == k && v == 2 {
- isok = true
- }
- }
- if isok {
- counts++
- }
- } else {
- isok := true
- for k, v := range DateMap {
- if currentTime.Format(date.Date_Short_Layout) == k && v == 1 {
- isok = false
- }
- }
- if isok {
- counts++
- }
- }
- if counts >= 2 {
- break
- }
- }
- //两天之前不包含节假日,有没有跟进记录
- recordCount := TiDb.CountBySql(`select count(1) from dwd_f_crm_trail_content where clue_id = ? and createtime > ?`, clueId, t.AddDate(0, 0, -count).Format(date.Date_Full_Layout))
- //
- clueUpdateData := map[string]interface{}{
- "updatetime": nowTime,
- "top_cluetype": top_cluetype,
- "sub_cluetype": sub_cluetype,
- "userid": userId,
- "comeinsource_private": 2,
- "tasksource": gconv.String(common.If(gconv.Int64(data["position_id"]) == 0, "线索自动分配", "线索来源自动更新")) + "-" + topname + "-" + subname,
- "company_nature": isGroup,
- "company_verification": isCommerce,
- }
- old_remark := common.ObjToString(data["remark"])
- if old_remark != "" {
- remark = old_remark + ";" + remark //备注不能替换,只能往上拼接
- }
- clueUpdateData["remark"] = remark
- old_demand := common.ObjToString(data["customer_demand"])
- if demand != old_demand {
- clueUpdateData["customer_demand"] = demand
- }
- if cluename != "" {
- clueUpdateData["cluename"] = cluename //新的线索名不为空才替换
- }
- if item != "orders" && item != "users" { //新用户和订单之外的替换一下新的留资信息
- if name != "" {
- clueUpdateData["name"] = name
- }
- if position != "" {
- clueUpdateData["position"] = position
- }
- if department != "" {
- clueUpdateData["department"] = department
- }
- if follow_project_area != "" {
- clueUpdateData["follow_project_area"] = follow_project_area
- }
- if role != "" {
- clueUpdateData["role"] = role
- }
- // clueUpdateData["industry"] = industry
- }
- if sourceCode == "app_xzcyh" { //这个留资单独处理一下
- if departments != "" {
- clueUpdateData["department"] = departments
- department = departments
- }
- business_scope := common.ObjToString(data["business_scope"])
- keywords := ""
- if len(keyword) > 0 && keyword[0] != "" {
- keywords = strings.Join(keyword, ",")
- if business_scope != "" {
- clueUpdateData["business_scope"] = business_scope + "," + keywords
- } else {
- clueUpdateData["business_scope"] = keywords
- }
- }
- }
- if old_position_id != 0 {
- for _, v := range saleData {
- if old_position_id == common.Int64All(v["position_id"]) {
- oldsaleName = common.ObjToString(v["name"])
- }
- }
- }
- if trailstatus == "00" || old_position_id == 0 || is_assign != 1 || (pIsOk && old_cluename != cluename && cluename != "") {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else {
- clueUpdateData["seatNumber"] = seatNumber
- clueUpdateData["position_id"] = positionId
- clueUpdateData["comeintime"] = nowTime
- clueUpdateData["is_assign"] = 1
- clueUpdateData["comeinsource_open"] = nil
- clueUpdateData["level_open"] = nil
- clueUpdateData["clue_level"] = nil
- }
- } else if is_assign == 1 && positionId != old_position_id {
- clueUpdateData["seatNumber"] = seatNumber
- clueUpdateData["position_id"] = positionId
- clueUpdateData["comeintime"] = nowTime
- clueUpdateData["is_assign"] = 1
- clueUpdateData["comeinsource_open"] = nil
- clueUpdateData["level_open"] = nil
- clueUpdateData["clue_level"] = nil
- } else { //不属于上边情况就还是属于原来的销售,不更换销售
- clueUpdateData["seatNumber"] = old_seatNumber
- clueUpdateData["position_id"] = old_position_id
- clueUpdateData["is_assign"] = 1
- clueUpdateData["comeinsource_open"] = nil
- clueUpdateData["level_open"] = nil
- clueUpdateData["clue_level"] = nil
- }
- if is_assign == 0 { //在公海的成交客户
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else {
- clueUpdateData["trailstatus"] = "01"
- clueUpdateData["trailstatus_time"] = nowTime
- }
- }
- if trailstatus == "02" { //在公海的成交客户
- clueUpdateData["trailstatus"] = "01"
- clueUpdateData["trailstatus_time"] = nowTime
- }
- is_ok := false
- if recordCount <= 0 || is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else {
- if item == "eventReg" {
- eData := TiDb.Find("dwd_f_crm_clue_change_record", map[string]interface{}{"clue_id": clueId, "change_type": "加入任务车"}, "", "", -1, -1)
- if eData != nil && len(*eData) > 0 {
- for _, e := range *eData {
- new_value := common.ObjToString(e["new_value"])
- if strings.Contains(new_value, subname) {
- is_ok = true
- }
- }
- }
- if !is_ok {
- if old_sub_cluetype != sub_cluetype || is_assign == 0 {
- if taskTime == "" {
- taskTime = nowTime
- }
- clueUpdateData["task_time"] = nowTime
- clueUpdateData["tasktime"] = taskTime
- clueUpdateData["taskstatus"] = 0
- }
- if is_transfer != 1 {
- clueUpdateData["is_task"] = 1
- }
- }
- } else {
- if old_sub_cluetype != sub_cluetype || is_assign == 0 {
- if taskTime == "" {
- taskTime = nowTime
- }
- clueUpdateData["task_time"] = nowTime
- clueUpdateData["tasktime"] = taskTime
- clueUpdateData["taskstatus"] = 0
- }
- if is_transfer != 1 {
- clueUpdateData["is_task"] = 1
- }
- }
- }
- }
- ok, updateId14 := true, true
- updateId1, updateId2, updateId3, updateId4, updateId5 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId6, updateId7, updateId8, updateId9, updateId10 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId11, updateId12, updateId13 := int64(0), int64(0), int64(0)
- if TiDb.ExecTx("更新线索", func(tx *sql.Tx) bool {
- //线索
- ok = TiDb.UpdateByTx(tx, "dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, clueUpdateData)
- //变更记录
- if (trailstatus == "00" || old_position_id == 0 || (pIsOk && old_cluename != cluename && cluename != "")) && is_assign == 1 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if old_position_id == 0 {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- } else {
- if pIsOk && old_cluename != cluename && cluename != "" {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- } else {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId2 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.Int64All(data["position_id"]),
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "无意向客户",
- "new_value": "流失",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "无意向客户",
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- }
- } else if is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- if trailstatus != "01" {
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- } else if is_assign == -1 {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- } else if (pIsOk && old_cluename == cluename && cluename != "") && is_assign == 1 && positionId != old_position_id {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- if recordCount <= 0 || is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else {
- if is_transfer == 1 {
- if old_sub_cluetype != sub_cluetype && !is_ok {
- cdata := TiDb.FindOne("dwd_f_csm_customer_info", map[string]interface{}{"clue_id": clueId}, "", "")
- if cdata != nil && len(*cdata) > 0 {
- kcpositionId := common.Int64All((*cdata)["position_id"])
- tasksource := common.ObjToString((*cdata)["tasksource"])
- taskstatus := common.IntAll((*cdata)["taskstatus"])
- updateId5 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": kcpositionId,
- "change_type": "加入任务车",
- "new_value": "线上主动留资",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- if taskstatus == 1 {
- tasksource = "10"
- } else {
- if tasksource != "" && !strings.Contains(tasksource, "10") {
- if !strings.Contains(tasksource, "10") {
- tasksource += ",10"
- }
- } else {
- tasksource = "10"
- }
- }
- updateId14 = TiDb.UpdateByTx(tx, "dwd_f_csm_customer_info", map[string]interface{}{"clue_id": clueId}, map[string]interface{}{
- "tasksource": tasksource,
- "tasktime": nowTime,
- "is_task": 1,
- "taskstatus": 0,
- })
- }
- }
- } else if !is_ok {
- updateId5 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" || is_assign == 0 || is_assign == -1, positionId, common.Int64All(data["position_id"])),
- "change_type": "加入任务车",
- "new_value": gconv.String(common.If(gconv.Int64(data["position_id"]) == 0, "线索自动分配", "线索来源自动更新")) + "-" + topname + "-" + subname,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- }
- }
- if old_top_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_top_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_topname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if old_sub_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_sub_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_subname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if item != "orders" {
- if old_name != name && name != "" {
- updateId6 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "name",
- "change_type": "基本信息变更",
- "old_value": common.If(old_name != "", old_name, "/"),
- "new_value": common.If(name != "", name, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_position != position && position != "" {
- updateId7 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "position",
- "change_type": "基本信息变更",
- "old_value": common.If(old_position != "", old_position, "/"),
- "new_value": common.If(position != "", position, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_department != department && department != "" {
- updateId8 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "department",
- "change_type": "基本信息变更",
- "old_value": common.If(old_department != "", old_department, "/"),
- "new_value": common.If(department != "", department, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_role != role && role != "" {
- updateId9 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{"clue_id": clueId, "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))), "change_field": "role", "change_type": "基本信息变更", "old_value": common.If(old_role != "", old_role, "/"), "new_value": common.If(role != "", role, "/"), "createtime": nowTime, "BCPCID": BCPCID, "operator_id": -1})
- }
- if old_follow_project_area != follow_project_area && follow_project_area != "" {
- old_area, old_area_arr := "", []string{}
- new_area, new_area_arr := "", []string{}
- for _, v := range strings.Split(old_follow_project_area, ",") {
- old_area_arr = append(old_area_arr, CodeArea[v])
- }
- for _, v := range strings.Split(follow_project_area, ",") {
- new_area_arr = append(new_area_arr, CodeArea[v])
- }
- old_area = strings.Join(old_area_arr, ",")
- new_area = strings.Join(new_area_arr, ",")
- updateId10 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "follow_project_area",
- "change_type": "基本信息变更",
- "old_value": common.If(old_area != "", old_area, "/"),
- "new_value": common.If(new_area != "", new_area, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_cluename != cluename && cluename != "" {
- updateId11 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "cluename",
- "change_type": "基本信息变更",
- "old_value": common.If(old_cluename != "", old_cluename, "/"),
- "new_value": common.If(cluename != "", cluename, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- }
- if old_top_cluetype != top_cluetype {
- updateId12 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"])))),
- "change_field": "top_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_topname != "", old_topname, "/"),
- "new_value": common.If(topname != "", topname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_sub_cluetype != sub_cluetype {
- updateId13 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.If(is_assign == 1, positionId, common.If(is_assign == 1, positionId, common.Int64All(data["position_id"]))))),
- "change_field": "sub_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_subname != "", old_subname, "/"),
- "new_value": common.If(subname != "", subname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- return ok && updateId1 > -1 && updateId2 > -1 && updateId3 > -1 && updateId4 > -1 && updateId5 > -1 && updateId6 > -1 && updateId7 > -1 && updateId8 > -1 && updateId9 > -1 && updateId10 > -1 && updateId11 > -1 && updateId12 > -1 && updateId13 > -1 && updateId14
- }) {
- log.Println("线索更新成功")
- if TiDb.Count("dwd_f_userbase_contacts", map[string]interface{}{"phone": phone}) == 0 {
- TiDb.Insert("dwd_f_userbase_contacts", map[string]interface{}{
- "status": 1,
- "is_delete": 1,
- "createtime": nowTime,
- "updatetime": nowTime,
- "phone": phone,
- "baseinfo_id": uId,
- "SOURCE": source,
- })
- }
- if old_position_id == 0 {
- TiDb.UpdateOrDeleteBySql(`update dwd_f_crm_clue_autodraw_record set count = count + 1 where position_id = ? and clue_level = ?`, positionId, level)
- }
- return true
- } else {
- log.Println("线索更新失败!!!", ok, updateId1, updateId2, updateId3, updateId4, updateId5, updateId6, updateId7, updateId8, updateId9, updateId10, updateId11, updateId12, updateId13, updateId14, " 用户信息 ", item, position, seatNumber, uId, userId, phone)
- return false
- }
- }
- func UpdateClue(data map[string]interface{}, saleData []map[string]interface{}, item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, level string, positionId int64, source, sourceCode, remark string, keyword []string, belong_to string, isGroup, isCommerce int, pIsOk bool) bool {
- log.Println("线索修改前", data, item, userId, uId, top_cluetype, sub_cluetype, topname, subname, cluename, name, saleName, phone, position, department, departments, industry, follow_project_area, role, seatNumber, level, positionId, source, sourceCode, remark)
- name = strings.ReplaceAll(name, " ", "")
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- nowTimes := time.Unix(time.Now().Unix()+3600*12, 0).Format("2006-01-02 15:04:05")
- trailstatus := common.ObjToString(data["trailstatus"]) //data都为原线索数据
- trailstatusTime := common.ObjToString(data["trailstatus_time"])
- var trailstatusTimes time.Time
- if trailstatusTime != "" {
- trailstatusTimes, _ = time.ParseInLocation(date.Date_Full_Layout, trailstatusTime, time.Local)
- }
- clueId := common.Int64All(data["id"])
- is_assign := common.IntAll(data["is_assign"])
- oldsaleName, oldTaskTime, taskTime, is_task, taskstatus := "", "", "", 0, 0
- old_position_id, old_seatNumber := common.Int64All(data["position_id"]), common.ObjToString(data["seatNumber"])
- oldTaskTime = common.ObjToString(data["tasktime"])
- is_task = common.IntAll(data["is_task"])
- taskstatus = common.IntAll(data["taskstatus"])
- BCPCID := common.GetRandom(32)
- old_name := common.ObjToString(data["name"])
- old_position := common.ObjToString(data["position"])
- old_department := common.ObjToString(data["department"])
- old_follow_project_area := common.ObjToString(data["follow_project_area"])
- old_role := common.ObjToString(data["role"])
- old_cluename := common.ObjToString(data["cluename"])
- old_top_cluetype := common.ObjToString(data["top_cluetype"])
- old_sub_cluetype := common.ObjToString(data["sub_cluetype"])
- old_topname, old_subname := "", ""
- is_transfer := common.IntAll(data["is_transfer"])
- if taskstatus == 1 || is_task == 0 {
- taskTime = common.ObjToString(common.If(item != "users", nowTime, nowTimes)) //任务时间,正常的是当前时间,新用户是当前时间+12个小时
- } else {
- if is_task == 1 {
- if oldTaskTime != "" { //以最新的任务时间为主
- t1, err := time.Parse("2006-01-02 15:04:05", oldTaskTime)
- if err == nil && time.Now().Before(t1) {
- taskTime = nowTime
- } else {
- taskTime = oldTaskTime
- }
- }
- }
- }
- count, counts, t := 0, 0, time.Now() //加入任务车判断节假日
- for {
- count++
- currentTime := t.AddDate(0, 0, -count)
- if currentTime.Weekday() == time.Sunday || currentTime.Weekday() == time.Saturday {
- isok := false
- for k, v := range DateMap {
- if currentTime.Format(date.Date_Short_Layout) == k && v == 2 {
- isok = true
- }
- }
- if isok {
- counts++
- }
- } else {
- isok := true
- for k, v := range DateMap {
- if currentTime.Format(date.Date_Short_Layout) == k && v == 1 {
- isok = false
- }
- }
- if isok {
- counts++
- }
- }
- if counts >= 2 {
- break
- }
- }
- //两天之前不包含节假日,有没有跟进记录
- recordCount := TiDb.CountBySql(`select count(1) from dwd_f_crm_trail_content where clue_id = ? and createtime > ?`, clueId, t.AddDate(0, 0, -count).Format(date.Date_Full_Layout))
- //
- clueUpdateData := map[string]interface{}{
- "updatetime": nowTime,
- "top_cluetype": top_cluetype,
- "sub_cluetype": sub_cluetype,
- "userid": userId,
- "comeinsource_private": 2,
- "tasksource": "线索来源自动更新" + "-" + topname + "-" + subname,
- "company_nature": isGroup,
- "company_verification": isCommerce,
- }
- old_remark := common.ObjToString(data["remark"])
- if old_remark != "" {
- remark = old_remark + ";" + remark //备注不能替换,只能往上拼接
- }
- clueUpdateData["remark"] = remark
- if cluename != "" {
- clueUpdateData["cluename"] = cluename //新的线索名不为空才替换
- }
- if item != "orders" && item != "users" { //新用户和订单之外的替换一下新的留资信息
- if name != "" {
- clueUpdateData["name"] = name
- }
- if position != "" {
- clueUpdateData["position"] = position
- }
- if department != "" {
- clueUpdateData["department"] = department
- }
- if follow_project_area != "" {
- clueUpdateData["follow_project_area"] = follow_project_area
- }
- if role != "" {
- clueUpdateData["role"] = role
- }
- // clueUpdateData["industry"] = industry
- }
- if sourceCode == "app_xzcyh" { //这个留资单独处理一下
- if departments != "" {
- clueUpdateData["department"] = departments
- department = departments
- }
- business_scope := common.ObjToString(data["business_scope"])
- keywords := ""
- if len(keyword) > 0 && keyword[0] != "" {
- keywords = strings.Join(keyword, ",")
- if business_scope != "" {
- clueUpdateData["business_scope"] = business_scope + "," + keywords
- } else {
- clueUpdateData["business_scope"] = keywords
- }
- }
- }
- //只更新线索不更新人员信息
- if is_assign != 1 && is_assign != 0 && is_assign != -1 {
- clueUpdateData["comeintime"] = nowTime
- clueMapEntity := ClueMapEntity{
- UId: uId,
- OldTopCluetype: old_top_cluetype,
- OldSubCluetype: old_sub_cluetype,
- NewTopCluetype: top_cluetype,
- NewSubCluetype: sub_cluetype,
- Item: item,
- OldName: old_name,
- NewName: name,
- ClueUpdateData: clueUpdateData,
- ClueId: clueId,
- OldPosition: old_position,
- NewPosition: position,
- OldDepartment: old_department,
- NewDepartment: department,
- OldRole: old_role,
- NewRole: role,
- OldFollowProjectArea: old_follow_project_area,
- NewFollowProjectArea: follow_project_area,
- NewCluename: cluename,
- OldCluename: old_cluename,
- Subname: subname,
- Topname: topname,
- Phone: phone,
- Source: source,
- PositionId: old_position_id,
- }
- return clueInfoUpdate(clueMapEntity)
- }
- if trailstatus == "00" || trailstatus == "09" || old_position_id == 0 || is_assign != 1 || (pIsOk && old_cluename != cluename && cluename != "") {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- //无意向几天以内不参与分配
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- //线索状态为“拒绝沟通客户”,则仅针对线索来源一级分类为“付费产品落地页主动留资”和“受理系统”产生的线索进行线索分配,其他类线上线索只做线索更新但不再自动分配。
- positionId = 0
- seatNumber = ""
- } else {
- clueUpdateData["seatNumber"] = seatNumber
- clueUpdateData["position_id"] = positionId
- clueUpdateData["comeintime"] = nowTime
- clueUpdateData["is_assign"] = 1
- clueUpdateData["is_assign"] = 1
- clueUpdateData["comeinsource_open"] = nil
- clueUpdateData["level_open"] = nil
- clueUpdateData["clue_level"] = nil
- for _, v := range saleData {
- if common.Int64All(data["position_id"]) == common.Int64All(v["position_id"]) {
- oldsaleName = common.ObjToString(v["name"])
- }
- }
- }
- } else { //不属于上边情况就还是属于原来的销售,不更换销售
- clueUpdateData["seatNumber"] = old_seatNumber
- clueUpdateData["position_id"] = old_position_id
- //clueUpdateData["is_assign"] = 1
- clueUpdateData["comeinsource_open"] = nil
- clueUpdateData["level_open"] = nil
- clueUpdateData["clue_level"] = nil
- }
- if is_assign == 0 { //在公海的成交客户
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- //线索状态为“拒绝沟通客户”,则仅针对线索来源一级分类为“付费产品落地页主动留资”和“受理系统”产生的线索进行线索分配,其他类线上线索只做线索更新但不再自动分配。
- positionId = 0
- seatNumber = ""
- } else {
- clueUpdateData["trailstatus"] = "01"
- clueUpdateData["trailstatus_time"] = nowTime
- }
- }
- if trailstatus == "02" { //在公海的成交客户
- clueUpdateData["trailstatus"] = "01"
- clueUpdateData["trailstatus_time"] = nowTime
- }
- is_ok := false
- if recordCount <= 0 || is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- //线索状态为“拒绝沟通客户”,则仅针对线索来源一级分类为“付费产品落地页主动留资”和“受理系统”产生的线索进行线索分配,其他类线上线索只做线索更新但不再自动分配。
- positionId = 0
- seatNumber = ""
- } else {
- if item == "eventReg" {
- eData := TiDb.Find("dwd_f_crm_clue_change_record", map[string]interface{}{"clue_id": clueId, "change_type": "加入任务车"}, "", "", -1, -1)
- if eData != nil && len(*eData) > 0 {
- for _, e := range *eData {
- new_value := common.ObjToString(e["new_value"])
- if strings.Contains(new_value, subname) {
- is_ok = true
- }
- }
- }
- if !is_ok {
- if old_sub_cluetype != sub_cluetype || is_assign == 0 {
- if taskTime == "" {
- taskTime = nowTime
- }
- clueUpdateData["task_time"] = nowTime
- clueUpdateData["tasktime"] = taskTime
- clueUpdateData["taskstatus"] = 0
- }
- if is_transfer != 1 {
- clueUpdateData["is_task"] = 1
- }
- }
- } else {
- if old_sub_cluetype != sub_cluetype || is_assign == 0 {
- if taskTime == "" {
- taskTime = nowTime
- }
- clueUpdateData["task_time"] = nowTime
- clueUpdateData["tasktime"] = taskTime
- clueUpdateData["taskstatus"] = 0
- }
- if is_transfer != 1 {
- clueUpdateData["is_task"] = 1
- }
- }
- }
- }
- ok, updateId14 := true, true
- updateId1, updateId2, updateId3, updateId4, updateId5 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId6, updateId7, updateId8, updateId9, updateId10 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId11, updateId12, updateId13 := int64(0), int64(0), int64(0)
- if TiDb.ExecTx("更新线索", func(tx *sql.Tx) bool {
- //线索
- ok = TiDb.UpdateByTx(tx, "dwd_f_crm_clue_info", map[string]interface{}{"uid": uId}, clueUpdateData)
- //变更记录
- if (trailstatus == "00" || old_position_id == 0 || (pIsOk && old_cluename != cluename && cluename != "")) && is_assign == 1 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- positionId = 0
- seatNumber = ""
- } else if old_position_id == 0 {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- } else {
- if pIsOk && old_cluename != cluename && cluename != "" {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- } else {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId2 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.Int64All(data["position_id"]),
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "无意向客户",
- "new_value": "流失",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "无意向客户",
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- }
- } else if is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- positionId = 0
- seatNumber = ""
- } else {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- if trailstatus != "01" {
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- updateId3 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": "商机线索",
- "new_value": "新增",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- } else if is_assign == -1 {
- updateId1 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "position_id",
- "change_type": "所属人变更",
- "old_value": common.If(oldsaleName != "", oldsaleName, "/"),
- "new_value": common.If(saleName != "", saleName, "/"),
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- updateId4 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": positionId,
- "change_field": "trailstatus",
- "change_type": "基本信息变更",
- "old_value": CodeTrail[trailstatus],
- "new_value": "商机线索",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- if recordCount <= 0 || is_assign == 0 {
- if trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400 {
- } else if trailstatus == "09" && (topname != "付费产品落地页主动留资" && topname != "受理系统") {
- positionId = 0
- seatNumber = ""
- } else {
- if is_transfer == 1 {
- if old_sub_cluetype != sub_cluetype && !is_ok {
- cdata := TiDb.FindOne("dwd_f_csm_customer_info", map[string]interface{}{"clue_id": clueId}, "", "")
- if cdata != nil && len(*cdata) > 0 {
- kcpositionId := common.Int64All((*cdata)["position_id"])
- tasksource := common.ObjToString((*cdata)["tasksource"])
- taskstatus := common.IntAll((*cdata)["taskstatus"])
- updateId5 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": kcpositionId,
- "change_type": "加入任务车",
- "new_value": "线上主动留资",
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- if taskstatus == 1 {
- tasksource = "10"
- } else {
- if tasksource != "" && !strings.Contains(tasksource, "10") {
- if !strings.Contains(tasksource, "10") {
- tasksource += ",10"
- }
- } else {
- tasksource = "10"
- }
- }
- updateId14 = TiDb.UpdateByTx(tx, "dwd_f_csm_customer_info", map[string]interface{}{"clue_id": clueId}, map[string]interface{}{
- "tasksource": tasksource,
- "tasktime": nowTime,
- "is_task": 1,
- "taskstatus": 0,
- })
- }
- }
- } else if !is_ok {
- updateId5 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" || is_assign == 0 || is_assign == -1, positionId, common.Int64All(data["position_id"])),
- "change_type": "加入任务车",
- "new_value": gconv.String(common.If(gconv.Int64(data["position_id"]) == 0, "线索自动分配", "线索来源自动更新")) + "-" + topname + "-" + subname,
- "createtime": nowTime,
- "BCPCID": common.GetRandom(32),
- "operator_id": -1,
- })
- }
- }
- }
- if old_top_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_top_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_topname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if old_sub_cluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": old_sub_cluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_subname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if item != "orders" {
- if old_name != name && name != "" {
- updateId6 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "name",
- "change_type": "基本信息变更",
- "old_value": common.If(old_name != "", old_name, "/"),
- "new_value": common.If(name != "", name, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_position != position && position != "" {
- updateId7 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "position",
- "change_type": "基本信息变更",
- "old_value": common.If(old_position != "", old_position, "/"),
- "new_value": common.If(position != "", position, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_department != department && department != "" {
- updateId8 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "department",
- "change_type": "基本信息变更",
- "old_value": common.If(old_department != "", old_department, "/"),
- "new_value": common.If(department != "", department, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_role != role && role != "" {
- updateId9 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "role",
- "change_type": "基本信息变更",
- "old_value": common.If(old_role != "", old_role, "/"),
- "new_value": common.If(role != "", role, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if old_follow_project_area != follow_project_area && follow_project_area != "" {
- old_area, old_area_arr := "", []string{}
- new_area, new_area_arr := "", []string{}
- for _, v := range strings.Split(old_follow_project_area, ",") {
- old_area_arr = append(old_area_arr, CodeArea[v])
- }
- for _, v := range strings.Split(follow_project_area, ",") {
- new_area_arr = append(new_area_arr, CodeArea[v])
- }
- old_area = strings.Join(old_area_arr, ",")
- new_area = strings.Join(new_area_arr, ",")
- updateId10 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "follow_project_area",
- "change_type": "基本信息变更",
- "old_value": common.If(old_area != "", old_area, "/"),
- "new_value": common.If(new_area != "", new_area, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_cluename != cluename && cluename != "" {
- updateId11 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "cluename",
- "change_type": "基本信息变更",
- "old_value": common.If(old_cluename != "", old_cluename, "/"),
- "new_value": common.If(cluename != "", cluename, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- }
- if old_top_cluetype != top_cluetype {
- updateId12 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "top_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_topname != "", old_topname, "/"),
- "new_value": common.If(topname != "", topname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if old_sub_cluetype != sub_cluetype {
- updateId13 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": clueId,
- "position_id": common.If(trailstatus == "00" && trailstatusTime != "" && time.Now().Unix()-trailstatusTimes.Unix() < 86400, -1, common.If(trailstatus == "00" || is_assign == 0, positionId, common.Int64All(data["position_id"]))),
- "change_field": "sub_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_subname != "", old_subname, "/"),
- "new_value": common.If(subname != "", subname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- return ok && updateId1 > -1 && updateId2 > -1 && updateId3 > -1 && updateId4 > -1 && updateId5 > -1 && updateId6 > -1 && updateId7 > -1 && updateId8 > -1 && updateId9 > -1 && updateId10 > -1 && updateId11 > -1 && updateId12 > -1 && updateId13 > -1 && updateId14
- }) {
- log.Println("线索更新成功")
- if TiDb.Count("dwd_f_userbase_contacts", map[string]interface{}{"phone": phone}) == 0 {
- TiDb.Insert("dwd_f_userbase_contacts", map[string]interface{}{
- "status": 1,
- "is_delete": 1,
- "createtime": nowTime,
- "updatetime": nowTime,
- "phone": phone,
- "baseinfo_id": uId,
- "SOURCE": source,
- })
- }
- if old_position_id == 0 {
- TiDb.UpdateOrDeleteBySql(`update dwd_f_crm_clue_autodraw_record set count = count + 1 where position_id = ? and clue_level = ?`, positionId, level)
- }
- return true
- } else {
- log.Println("线索更新失败!!!", ok, updateId1, updateId2, updateId3, updateId4, updateId5, updateId6, updateId7, updateId8, updateId9, updateId10, updateId11, updateId12, updateId13, updateId14, " 用户信息 ", item, position, seatNumber, uId, userId, phone)
- return false
- }
- }
- type ClueMapEntity struct {
- UId string
- OldTopCluetype string
- OldSubCluetype string
- NewTopCluetype string
- NewSubCluetype string
- Item string
- OldName string
- NewName string
- ClueUpdateData map[string]interface{}
- ClueId int64
- Trailstatus string
- OldPosition string
- NewPosition string
- OldDepartment string
- NewDepartment string
- OldRole string
- NewRole string
- OldFollowProjectArea string
- NewFollowProjectArea string
- NewCluename string
- OldCluename string
- Subname string
- Topname string
- Phone string
- Source string
- PositionId int64
- }
- // 基本信息变更
- func clueInfoUpdate(data ClueMapEntity) bool {
- ok := false
- updateId1, updateId2, updateId3, updateId4, updateId5 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId6, updateId7, updateId8, updateId9, updateId10 := int64(0), int64(0), int64(0), int64(0), int64(0)
- updateId11, updateId12, updateId13 := int64(0), int64(0), int64(0)
- nowTime := time.Now().Format("2006-01-02 15:04:05")
- if TiDb.ExecTx("更新线索", func(tx *sql.Tx) bool {
- log.Println("修改线索", data)
- BCPCID := common.GetRandom(32)
- old_topname, old_subname := "", ""
- //线索
- ok = TiDb.UpdateByTx(tx, "dwd_f_crm_clue_info", map[string]interface{}{"uid": data.UId}, data.ClueUpdateData)
- //变更记录
- if data.OldTopCluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": data.OldTopCluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_topname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if data.OldSubCluetype != "" {
- pcodeData := TiDb.FindOne("dwd_d_crm_cluetype_code", map[string]interface{}{"code": data.OldSubCluetype}, "", "")
- if pcodeData != nil && len(*pcodeData) > 0 {
- old_subname = common.ObjToString((*pcodeData)["name"])
- }
- }
- if data.Item != "orders" {
- if data.OldName != data.NewName && data.NewName != "" {
- updateId6 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "name",
- "change_type": "基本信息变更",
- "old_value": common.If(data.OldName != "", data.OldName, "/"),
- "new_value": common.If(data.NewName != "", data.NewName, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if data.OldPosition != data.NewPosition && data.NewPosition != "" {
- updateId7 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "position",
- "change_type": "基本信息变更",
- "old_value": common.If(data.OldPosition != "", data.OldPosition, "/"),
- "new_value": common.If(data.NewPosition != "", data.NewPosition, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if data.OldDepartment != data.NewDepartment && data.NewDepartment != "" {
- updateId8 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "department",
- "change_type": "基本信息变更",
- "old_value": common.If(data.OldDepartment != "", data.OldDepartment, "/"),
- "new_value": common.If(data.NewDepartment != "", data.NewDepartment, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if data.OldRole != data.NewRole && data.NewRole != "" {
- updateId9 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "role",
- "change_type": "基本信息变更",
- "old_value": common.If(data.OldRole != "", data.OldRole, "/"),
- "new_value": common.If(data.NewRole != "", data.NewRole, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1})
- }
- if data.OldFollowProjectArea != data.NewFollowProjectArea && data.NewFollowProjectArea != "" {
- old_area, old_area_arr := "", []string{}
- new_area, new_area_arr := "", []string{}
- for _, v := range strings.Split(data.OldFollowProjectArea, ",") {
- old_area_arr = append(old_area_arr, CodeArea[v])
- }
- for _, v := range strings.Split(data.NewFollowProjectArea, ",") {
- new_area_arr = append(new_area_arr, CodeArea[v])
- }
- old_area = strings.Join(old_area_arr, ",")
- new_area = strings.Join(new_area_arr, ",")
- updateId10 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "follow_project_area",
- "change_type": "基本信息变更",
- "old_value": common.If(old_area != "", old_area, "/"),
- "new_value": common.If(new_area != "", new_area, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if data.OldCluename != data.NewCluename && data.NewCluename != "" {
- updateId11 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "cluename",
- "change_type": "基本信息变更",
- "old_value": common.If(data.OldCluename != "", data.OldCluename, "/"),
- "new_value": common.If(data.NewCluename != "", data.NewCluename, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- }
- if data.OldTopCluetype != data.NewTopCluetype {
- updateId12 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "top_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_topname != "", old_topname, "/"),
- "new_value": common.If(data.Topname != "", data.Topname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- if data.OldTopCluetype != data.NewTopCluetype {
- updateId13 = TiDb.InsertByTx(tx, "dwd_f_crm_clue_change_record", map[string]interface{}{
- "clue_id": data.ClueId,
- "position_id": data.PositionId,
- "change_field": "sub_cluetype",
- "change_type": "基本信息变更",
- "old_value": common.If(old_subname != "", old_subname, "/"),
- "new_value": common.If(data.Subname != "", data.Subname, "/"),
- "createtime": nowTime,
- "BCPCID": BCPCID,
- "operator_id": -1,
- })
- }
- return ok && updateId1 > -1 && updateId2 > -1 && updateId3 > -1 && updateId4 > -1 && updateId5 > -1 && updateId6 > -1 && updateId7 > -1 && updateId8 > -1 && updateId9 > -1 && updateId10 > -1 && updateId11 > -1 && updateId12 > -1 && updateId13 > -1
- }) {
- log.Println("线索更新成功")
- if TiDb.Count("dwd_f_userbase_contacts", map[string]interface{}{"phone": data.Phone}) == 0 {
- TiDb.Insert("dwd_f_userbase_contacts", map[string]interface{}{
- "status": 1,
- "is_delete": 1,
- "createtime": nowTime,
- "updatetime": nowTime,
- "phone": data.Phone,
- "baseinfo_id": data.UId,
- "SOURCE": data.Source,
- })
- }
- return true
- } else {
- log.Println("线索更新失败!!!", ok, updateId1, updateId2, updateId3, updateId4, updateId5, updateId6, updateId7, updateId8, updateId9, updateId10, updateId11, updateId12, updateId13)
- return false
- }
- }
|