activity_signup.go 95 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983
  1. package cygx
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/rdlucklib/rdluck_tools/paging"
  6. "github.com/tealeg/xlsx"
  7. "hongze/hz_crm_api/controllers"
  8. "hongze/hz_crm_api/models"
  9. "hongze/hz_crm_api/models/cygx"
  10. "hongze/hz_crm_api/models/system"
  11. "hongze/hz_crm_api/services"
  12. cygxService "hongze/hz_crm_api/services/cygx"
  13. "hongze/hz_crm_api/utils"
  14. "html/template"
  15. "os"
  16. "path/filepath"
  17. "strconv"
  18. "strings"
  19. "time"
  20. )
  21. // 活动
  22. type ActivitySignupCoAntroller struct {
  23. controllers.BaseAuthController
  24. }
  25. // @Title 报名管理列表
  26. // @Description 获取报名管理列表接口
  27. // @Param PageSize query int true "每页数据条数"
  28. // @Param CurrentIndex query int true "当前页页码,从1开始"
  29. // @Param ChartPermissionId query string false "行业id"
  30. // @Param ActivityTypeId query string false "活动类型id 多个用 , 隔开列如: 1,2"
  31. // @Param StartDate query string false "开始时间 ,列如2021-03-06 "
  32. // @Param EndDate query string false "结束时间,列如2021-03-06 "
  33. // @Param KeyWord query string false "搜索关键词"
  34. // @Param SearchType query int true "筛选类型 1专家/分析师电话会、2专家/分析师线下沙龙 、3公司调研/、4C类电话会"
  35. // @Param ActiveState query int false "发布状态 ,1未开始、2进行中、3已结束 ,默认1未开始"
  36. // @Param PublishStatus query int false "发布状态 ,0未发布,1已发布,3已取消,传2查询所有"
  37. // @Param IsResearch query bool true "是否为研选"
  38. // @Success 200 {object} cygx.GetCygxSignupListRep
  39. // @router /activitySignup/list [get]
  40. func (this *ActivitySignupCoAntroller) SignupList() {
  41. br := new(models.BaseResponse).Init()
  42. defer func() {
  43. this.Data["json"] = br
  44. this.ServeJSON()
  45. }()
  46. sysUser := this.SysUser
  47. if sysUser == nil {
  48. br.Msg = "请登录"
  49. br.ErrMsg = "请登录,SysUser Is Empty"
  50. return
  51. }
  52. pageSize, _ := this.GetInt("PageSize")
  53. currentIndex, _ := this.GetInt("CurrentIndex")
  54. chartPermissionId, _ := this.GetInt("ChartPermissionId")
  55. ActivityTypeId := this.GetString("ActivityTypeId")
  56. startDate := this.GetString("StartDate")
  57. endDate := this.GetString("EndDate")
  58. keyWord := this.GetString("KeyWord")
  59. activeState, _ := this.GetInt("ActiveState")
  60. searchType, _ := this.GetInt("SearchType")
  61. publishStatus, _ := this.GetInt("PublishStatus")
  62. isResearch, _ := this.GetBool("IsResearch", false) // 是否为研选 查研观向11.0 (研选活动独立显示)
  63. if activeState == 0 {
  64. activeState = 1
  65. }
  66. var startSize int
  67. if pageSize <= 0 {
  68. pageSize = utils.PageSize20
  69. }
  70. if currentIndex <= 0 {
  71. currentIndex = 1
  72. }
  73. startSize = utils.StartIndex(currentIndex, pageSize)
  74. var condition string
  75. var pars []interface{}
  76. if keyWord != "" {
  77. template.HTMLEscapeString(keyWord)
  78. keyWord = "%" + keyWord + "%"
  79. condition += ` AND (art.activity_name LIKE ? ) `
  80. pars = append(pars, keyWord)
  81. }
  82. condition += ` AND art.active_state = ? `
  83. pars = append(pars, activeState)
  84. if ActivityTypeId == "" {
  85. if searchType == 4 {
  86. condition += ` AND art.activity_type_id IN (7) `
  87. } else if searchType == 3 {
  88. condition += ` AND art.activity_type_id IN (3,4) `
  89. } else if searchType == 2 {
  90. condition += ` AND art.activity_type_id IN (5,6) `
  91. } else {
  92. condition += ` AND art.activity_type_id IN (1,2) ` //默认
  93. }
  94. }
  95. if ActivityTypeId != "" {
  96. condition += ` AND art.activity_type_id IN (` + ActivityTypeId + `) `
  97. }
  98. if isResearch {
  99. chartPermissionId = utils.CHART_PERMISSION_ID_YANXUAN
  100. } else {
  101. //condition += ` AND art.chart_permission_id != '` + strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) + `'`
  102. }
  103. //行业名称
  104. if chartPermissionId > 0 {
  105. condition += ` AND art.chart_permission_id = '` + strconv.Itoa(chartPermissionId) + `'`
  106. }
  107. if startDate != "" {
  108. condition += ` AND art.activity_time >= ` + "'" + startDate + " 00:00:00'"
  109. }
  110. if endDate != "" {
  111. condition += ` AND art.activity_time <= ` + "'" + endDate + " 23:59:59'"
  112. }
  113. if publishStatus == 0 {
  114. condition += ` AND art.publish_status = 0 AND art.is_cancel = 0 `
  115. } else if publishStatus == 1 {
  116. condition += ` AND art.publish_status = 1 `
  117. } else if publishStatus == 3 {
  118. condition += ` AND art.publish_status = 0 AND art.is_cancel = 1 `
  119. }
  120. //C类电话会,仅本组销售、部门管理员、admin、权益研究员账号能看到。
  121. if sysUser.Role != "admin" {
  122. conditionPermission, err := cygxService.GetAdminActivityPermission(sysUser, condition)
  123. if err != nil {
  124. br.Msg = "获取失败"
  125. br.ErrMsg = "获取失败,GetAdminActivityPermission Err:" + err.Error()
  126. return
  127. }
  128. condition += ` AND art.visible_range != 1 `
  129. condition += conditionPermission
  130. pars = append(pars, pars)
  131. }
  132. //condition += ` AND a.publish_status = 1 `
  133. total, err := cygx.GetCygxSignupCount(condition, pars)
  134. if err != nil {
  135. br.Msg = "获取失败"
  136. br.ErrMsg = "获取失败,Err:" + err.Error()
  137. return
  138. }
  139. if activeState == 3 {
  140. condition += ` ORDER BY art.activity_time DESC `
  141. } else {
  142. condition += ` ORDER BY art.activity_time ASC `
  143. }
  144. list, errList := cygx.GetCygxSignupListAll(condition, pars, startSize, pageSize)
  145. if errList != nil {
  146. br.Msg = "获取失败"
  147. br.ErrMsg = "获取失败,Err:" + errList.Error()
  148. return
  149. }
  150. var activityIds string
  151. for k, v := range list {
  152. if v.ChartPermissionNames != "" {
  153. list[k].ChartPermissionName = v.ChartPermissionNames
  154. }
  155. //if v.IsHideAppointment == 0 {
  156. // list[k].IsShowAppointment = cygxService.IsShowAppointmentByadminSet(v.IsCanAppointmentMinutes)
  157. //}
  158. activityIds += strconv.Itoa(v.ActivityId) + ","
  159. }
  160. activityIds = strings.TrimRight(activityIds, ",")
  161. mapIndustrial := make(map[int]string)
  162. mapSubject := make(map[string]string)
  163. if activityIds != "" {
  164. industrialList, err := cygx.GetIndustrialActivityGroupListByactivityIds(activityIds)
  165. if err != nil {
  166. br.Msg = "获取失败"
  167. br.ErrMsg = "获取失败,GetIndustrialActivityGroupListByactivityIds Err:" + err.Error()
  168. return
  169. }
  170. subjectList, err := cygx.GetSubjectActivityGroupListByactivityIds(activityIds)
  171. if err != nil {
  172. br.Msg = "获取失败"
  173. br.ErrMsg = "获取失败,GetSubjectActivityGroupListByactivityIds Err:" + err.Error()
  174. return
  175. }
  176. //合并活动对应的多个标的
  177. for _, v := range subjectList {
  178. mapSubject[fmt.Sprint(v.ActivityId, "_", v.IndustrialManagementId)] += v.SubjectName + "/"
  179. }
  180. //活动对应的产业
  181. for _, v := range industrialList {
  182. var labelSubject string
  183. labelSubject = mapSubject[fmt.Sprint(v.ActivityId, "_", v.IndustrialManagementId)]
  184. if labelSubject != "" {
  185. mapIndustrial[v.ActivityId] += v.IndustryName + "--" + strings.TrimRight(labelSubject, "/") + ","
  186. } else {
  187. mapIndustrial[v.ActivityId] += v.IndustryName + ","
  188. }
  189. }
  190. }
  191. for k, v := range list {
  192. if mapIndustrial[v.ActivityId] != "" && v.TemporaryLabel == "" {
  193. list[k].Label = strings.TrimRight(mapIndustrial[v.ActivityId], ",")
  194. }
  195. if v.IsCancel == 1 {
  196. v.PublishStatus = 3
  197. }
  198. if v.YidongActivityId != "" {
  199. list[k].ActivityTypeName += utils.YI_DONG_NAME
  200. list[k].LimitPeopleNum = 10000 // 前端根据这个字段是否大于0来处理是新增报名还是预约外呼
  201. }
  202. if v.IsYidongConduct == 1 {
  203. v.ActivityTypeName += utils.YI_DONG_NAME_TWO
  204. }
  205. if v.IsCanAppointmentMinutes == 1 {
  206. v.IsShowAppointment = true
  207. }
  208. }
  209. if len(list) == 0 {
  210. list = make([]*cygx.CygxSignupList, 0)
  211. }
  212. page := paging.GetPaging(currentIndex, pageSize, total)
  213. resp := new(cygx.GetCygxSignupListRep)
  214. resp.List = list
  215. resp.Paging = page
  216. br.Ret = 200
  217. br.Success = true
  218. br.Msg = "获取成功"
  219. br.Data = resp
  220. }
  221. // @Title 几种类型报名详情列表
  222. // @Description 获取几种类型报名详情列表接口
  223. // @Param ActivityId query int true "活动ID"
  224. // @Success 200 {object} cygx.GetAppointmentListRep
  225. // @router /activitySignup/appointmentList [get]
  226. func (this *ActivitySignupCoAntroller) AppointmentList() {
  227. br := new(models.BaseResponse).Init()
  228. defer func() {
  229. this.Data["json"] = br
  230. this.ServeJSON()
  231. }()
  232. sysUser := this.SysUser
  233. if sysUser == nil {
  234. br.Msg = "请登录"
  235. br.ErrMsg = "请登录,SysUser Is Empty"
  236. return
  237. }
  238. activityId, _ := this.GetInt("ActivityId")
  239. if activityId < 1 {
  240. br.Msg = "活动不存在"
  241. return
  242. }
  243. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  244. if activityInfo == nil {
  245. br.Msg = "活动不存在"
  246. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  247. return
  248. }
  249. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  250. resp := new(cygx.CanDownload)
  251. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  252. if errAdmin != nil {
  253. br.Msg = "获取失败"
  254. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  255. return
  256. }
  257. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  258. resp.IsCanDownload = true
  259. }
  260. memberType := "Admin"
  261. sqlStr := ` AND s.do_fail_type = 0 `
  262. totalStr := sqlStr
  263. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 || activityInfo.IsYidongConduct == 1) {
  264. if adminInfo.RoleTypeCode == "rai_group" {
  265. //组长查看本组所有组员
  266. memberType = "GroupLeader"
  267. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  268. } else {
  269. //组员查看自己
  270. memberType = "Sale"
  271. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  272. }
  273. }
  274. list, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  275. if err != nil {
  276. br.Msg = "获取失败"
  277. br.ErrMsg = "获取失败,Err:" + err.Error()
  278. return
  279. }
  280. totalStr += " AND s.company_id != 16 "
  281. total, errtotal := cygx.GetCygxAppointmentCount(activityId, totalStr)
  282. if errtotal != nil {
  283. br.Msg = "获取失败"
  284. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  285. return
  286. }
  287. myTotal, errmyTotal := cygx.GetCygxAppointmentCount(activityId, sqlStr)
  288. if errmyTotal != nil {
  289. br.Msg = "获取失败"
  290. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  291. return
  292. }
  293. for k, v := range list {
  294. //公司调研电话会的活动,研选扣点的展示自主拨入,非扣点的展示预约外呼
  295. if activityInfo.ActivityTypeId == 3 {
  296. if activityInfo.IsResearchPoints == 1 {
  297. v.SignupType = 2
  298. } else {
  299. v.SignupType = 1
  300. }
  301. }
  302. list[k].SellerName = v.PsellerName
  303. }
  304. respList := new(cygx.GetAppointmentListRep)
  305. respList.List = list
  306. respList.Total = total
  307. respList.MyTotal = myTotal
  308. respList.ActivityId = activityId
  309. respList.IsLimitPeople = activityInfo.IsLimitPeople
  310. respList.MemberType = memberType
  311. respList.IsResearchPoints = activityInfo.IsResearchPoints
  312. activityTypeId := activityInfo.ActivityTypeId
  313. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  314. if activityTypeId == 1 || activityTypeId == 2 {
  315. respList.ExcelType = "AppointmentCall"
  316. } else if activityTypeId == 5 || activityTypeId == 6 {
  317. respList.ExcelType = "ExpertSalon"
  318. } else if activityTypeId == 3 {
  319. respList.ExcelType = "Teleconference"
  320. } else if activityTypeId == 4 {
  321. respList.ExcelType = "OfflineResearch"
  322. } else if activityTypeId == 7 {
  323. respList.ExcelType = "CClass"
  324. }
  325. if activityInfo.YidongActivityId != "" {
  326. respList.ExcelType = "YiDong"
  327. }
  328. respList.IsYidongConduct = activityInfo.IsYidongConduct
  329. br.Ret = 200
  330. br.Success = true
  331. br.Msg = "获取成功"
  332. br.Data = respList
  333. }
  334. // @Title 外呼人员列表
  335. // @Description 获取外呼人员列表接口
  336. // @Param KeyWord query string false "搜索关键词"
  337. // @Success 200 {object} cygx.GetOutboundPersonnelListRep
  338. // @router /activitySignup/userList [get]
  339. func (this *ActivitySignupCoAntroller) OutboundPersonnelList() {
  340. br := new(models.BaseResponse).Init()
  341. defer func() {
  342. this.Data["json"] = br
  343. this.ServeJSON()
  344. }()
  345. keyWord := this.GetString("KeyWord")
  346. sysUser := this.SysUser
  347. if sysUser == nil {
  348. br.Msg = "请登录"
  349. br.ErrMsg = "请登录,SysUser Is Empty"
  350. return
  351. }
  352. if keyWord == "" {
  353. br.Msg = "请输入姓名"
  354. return
  355. }
  356. list, err := cygx.GetOutboundPersonnelList(keyWord)
  357. if err != nil {
  358. br.Msg = "获取失败"
  359. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  360. return
  361. }
  362. for k, v := range list {
  363. if len(v.Mobile) > 7 {
  364. list[k].Mobile = v.Mobile[0:3] + "****" + v.Mobile[7:]
  365. }
  366. }
  367. resp := new(cygx.GetOutboundPersonnelListRep)
  368. resp.List = list
  369. br.Ret = 200
  370. br.Success = true
  371. br.Msg = "获取成功"
  372. br.Data = resp
  373. }
  374. // @Title 新增外呼人员
  375. // @Description 新增外呼人员接口
  376. // @Param request body cygx.AddMeetingReminderReq true "type json string"
  377. // @Success 200 操作成功
  378. // @router /activitySignup/addUser [post]
  379. func (this *ActivitySignupCoAntroller) AddUser() {
  380. br := new(models.BaseResponse).Init()
  381. defer func() {
  382. this.Data["json"] = br
  383. this.ServeJSON()
  384. }()
  385. AdminUser := this.SysUser
  386. if AdminUser == nil {
  387. br.Msg = "请登录"
  388. br.ErrMsg = "请登录,SysUser Is Empty"
  389. return
  390. }
  391. var req cygx.AddMeetingReminderReq
  392. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  393. if err != nil {
  394. br.Msg = "参数解析异常!"
  395. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  396. return
  397. }
  398. var items []*cygx.CygxActivitySignup
  399. var itemsYidong []*cygx.YidongActivitySignup
  400. var itemsAppointment []*cygx.CygxActivityAppointment
  401. activityIds := req.ActivityIds
  402. uidList := req.List
  403. if activityIds == "" {
  404. br.Msg = "请选择活动"
  405. br.ErrMsg = "活动ID不能为空"
  406. return
  407. }
  408. activityIdList := strings.Split(activityIds, ",")
  409. var uids string
  410. for _, v := range uidList {
  411. uids += strconv.Itoa(v.UserId) + ","
  412. }
  413. uids = strings.TrimRight(uids, ",")
  414. for _, v := range uidList {
  415. uid := v.UserId
  416. wxUser, userErr := models.GetWxUserByUserId(uid)
  417. if userErr != nil {
  418. br.Msg = "编辑失败!查询用户信息失败"
  419. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  420. return
  421. }
  422. for _, vact := range activityIdList {
  423. activityId, _ := strconv.Atoi(vact)
  424. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  425. if err != nil {
  426. br.Msg = "活动不存在"
  427. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  428. return
  429. }
  430. if activityInfo.YidongActivityId != "" {
  431. errMsg := cygxService.CheckYidongActivitySignupTime(activityInfo)
  432. if errMsg != "" {
  433. br.Msg = errMsg
  434. br.ErrMsg = errMsg + "Err:activityId:" + strconv.Itoa(activityId)
  435. return
  436. }
  437. }
  438. limitPeopleNum, _ := strconv.Atoi(activityInfo.LimitPeopleNum)
  439. //if limitPeopleNum > 0 {
  440. if AdminUser.RoleTypeCode != "admin" {
  441. //havePower := cygxService.CheckaddSignuUserPower(wxUser.CompanyId, activityId, activityInfo)
  442. havePower, err := cygxService.GetActivityDetailUserPower(wxUser, AdminUser, activityInfo)
  443. if err != nil {
  444. br.Msg = "用户权限校验失败!"
  445. br.ErrMsg = "GetActivityDetailUserPower,Err:" + err.Error() + fmt.Sprint("UserId", wxUser.UserId, "ActivityId:", activityInfo.ActivityId)
  446. return
  447. }
  448. if !havePower {
  449. br.Msg = "当前活动对该客户不可见,无法报名"
  450. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  451. return
  452. }
  453. //}
  454. if activityInfo.IsLimitPeople == 1 {
  455. //获取这个活动已经报名的用户数量
  456. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  457. if errSignup != nil {
  458. br.Msg = "获取失败"
  459. br.ErrMsg = "获取失败,Err:" + errSignup.Error()
  460. return
  461. }
  462. //获取这个活动中输入的这些用户的报名数量
  463. totalThisUser, errThisUser := cygx.GetActivitySignupCountByThisUser(activityId, uids)
  464. if errThisUser != nil {
  465. br.Msg = "获取失败"
  466. br.ErrMsg = "获取失败,Err:" + errThisUser.Error()
  467. return
  468. }
  469. //如果是限制人数的就做报名人数限制判断
  470. if activityInfo.IsLimitPeople == 1 {
  471. if limitPeopleNum < totalSignup+len(uidList)-totalThisUser {
  472. br.Msg = "新增失败,活动人数超限"
  473. br.ErrMsg = "当前活动报名人数已满,活动:" + activityInfo.ActivityName
  474. return
  475. }
  476. }
  477. }
  478. }
  479. total, errtotal := cygx.GetActivitySignupCount(uid, activityId)
  480. if errtotal != nil {
  481. br.Msg = "获取失败"
  482. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  483. return
  484. }
  485. if total == 0 {
  486. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  487. if err != nil {
  488. br.Msg = "获取失败"
  489. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  490. return
  491. }
  492. item := new(cygx.CygxActivitySignup)
  493. item.UserId = infoUser.UserId
  494. item.RealName = infoUser.RealName
  495. item.SellerName = infoUser.SellerName
  496. item.ActivityId = activityId
  497. item.CreateTime = time.Now()
  498. item.Mobile = infoUser.Mobile
  499. item.Email = infoUser.Email
  500. item.CompanyId = infoUser.CompanyId
  501. item.CompanyName = infoUser.CompanyName
  502. item.Source = 2
  503. //优先绑定用户修改过的外呼手机号
  504. if infoUser.OutboundMobile != "" {
  505. item.OutboundMobile = infoUser.OutboundMobile
  506. if infoUser.OutboundCountryCode == "" {
  507. item.CountryCode = "86"
  508. } else {
  509. item.CountryCode = infoUser.OutboundCountryCode
  510. }
  511. } else {
  512. item.OutboundMobile = infoUser.Mobile
  513. if infoUser.CountryCode == "" {
  514. item.CountryCode = "86"
  515. } else {
  516. item.CountryCode = infoUser.CountryCode
  517. }
  518. }
  519. item.SignupType = 1
  520. items = append(items, item)
  521. if activityInfo.YidongActivityId != "" {
  522. //测试环境下弘则下面的用户才收到消息
  523. if utils.RunMode != "release" && item.CompanyId == 16 {
  524. itemYidong := new(cygx.YidongActivitySignup)
  525. itemYidong.YidongActivityId = activityInfo.YidongActivityId
  526. itemYidong.Mobile = item.Mobile
  527. itemYidong.RealName = item.RealName
  528. itemYidong.CompanyName = item.CompanyName
  529. itemYidong.CountryCode = item.CountryCode
  530. itemsYidong = append(itemsYidong, itemYidong)
  531. }
  532. }
  533. }
  534. if v.IsAppointment == 1 {
  535. //var isHideAppointment bool
  536. //if activityInfo.IsHideAppointment == 0 {
  537. // isHideAppointment = cygxService.IsShowAppointmentByadminSet(activityInfo.IsCanAppointmentMinutes)
  538. //}
  539. if activityInfo.IsCanAppointmentMinutes == 0 {
  540. br.Msg = "该活动无法预约纪要"
  541. br.ErrMsg = "该活动无法预约纪要,Err:" + activityInfo.ActivityName
  542. return
  543. }
  544. total, errtotal := cygx.GetUserCygxActivityAppointmentCount(uid, activityId)
  545. if errtotal != nil {
  546. br.Msg = "获取失败"
  547. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  548. return
  549. }
  550. //判断这个用户是否报名了,如果没有报名则写入报名数据
  551. if total == 0 {
  552. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  553. if err != nil {
  554. br.Msg = "获取失败"
  555. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  556. return
  557. }
  558. itemAppointment := new(cygx.CygxActivityAppointment)
  559. itemAppointment.UserId = infoUser.UserId
  560. itemAppointment.RealName = infoUser.RealName
  561. itemAppointment.SellerName = infoUser.SellerName
  562. itemAppointment.ActivityId = activityId
  563. itemAppointment.CreateTime = time.Now()
  564. itemAppointment.Mobile = infoUser.Mobile
  565. itemAppointment.Email = infoUser.Email
  566. itemAppointment.CompanyId = infoUser.CompanyId
  567. itemAppointment.CompanyName = infoUser.CompanyName
  568. itemAppointment.AdminId = AdminUser.AdminId
  569. itemAppointment.Source = 2
  570. itemsAppointment = append(itemsAppointment, itemAppointment)
  571. }
  572. }
  573. }
  574. }
  575. mapYidongActivity := make(map[int]int)
  576. err = cygx.AddCygxActivitySignup(items, itemsAppointment, mapYidongActivity)
  577. if err != nil {
  578. br.Msg = "操作失败"
  579. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  580. return
  581. }
  582. //如果有值就向易董推送后台添加的报名信息
  583. if len(itemsYidong) > 0 {
  584. go cygxService.YidongActivityUserSingnUp(itemsYidong)
  585. }
  586. //添加操作日志记录
  587. br.Ret = 200
  588. br.Success = true
  589. br.Msg = "操作成功"
  590. br.IsAddLog = true
  591. }
  592. // @Title 报名失败详情列表
  593. // @Description 获取沙龙报名失败详情列表接口
  594. // @Param ActivityId query int true "活动ID"
  595. // @Success 200 {object} cygx.GetFailSignupListRep
  596. // @router /activitySignup/salonFailSignupList [get]
  597. func (this *ActivitySignupCoAntroller) SalonFailSignupList() {
  598. br := new(models.BaseResponse).Init()
  599. defer func() {
  600. this.Data["json"] = br
  601. this.ServeJSON()
  602. }()
  603. sysUser := this.SysUser
  604. if sysUser == nil {
  605. br.Msg = "请登录"
  606. br.ErrMsg = "请登录,SysUser Is Empty"
  607. return
  608. }
  609. respList := new(cygx.GetFailSignupListRep)
  610. activityId, _ := this.GetInt("ActivityId")
  611. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  612. if activityInfo == nil {
  613. br.Msg = "活动不存在"
  614. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  615. return
  616. }
  617. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  618. resp := new(cygx.CanDownload)
  619. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  620. if errAdmin != nil {
  621. br.Msg = "获取失败"
  622. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  623. return
  624. }
  625. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  626. resp.IsCanDownload = true
  627. }
  628. memberType := "Admin"
  629. sqlStr := ""
  630. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  631. if adminInfo.RoleTypeCode == "rai_group" {
  632. //组长查看本组所有组员
  633. memberType = "GroupLeader"
  634. sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  635. } else {
  636. //组员查看自己
  637. memberType = "Sale"
  638. sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  639. }
  640. }
  641. sqlStr += ` AND s.fail_type >0 `
  642. list, err := cygx.GetFailSignupList(activityId, sqlStr)
  643. if err != nil {
  644. br.Msg = "获取失败"
  645. br.ErrMsg = "获取失败,Err:" + err.Error()
  646. return
  647. }
  648. sqlStrtotal := ` AND s.fail_type >0 `
  649. total, errtotal := cygx.GetCygxAppointmentCount(activityId, sqlStrtotal)
  650. if errtotal != nil {
  651. br.Msg = "获取失败"
  652. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  653. return
  654. }
  655. myTotalsqlStr := ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) AND s.fail_type >0 `
  656. myTotal, errmyTotal := cygx.GetCygxAppointmentCount(activityId, myTotalsqlStr)
  657. if errmyTotal != nil {
  658. br.Msg = "获取失败"
  659. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  660. return
  661. }
  662. if activityInfo.IsLimitPeople > 0 {
  663. //获取这个活动已经报名的用户数量
  664. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  665. if errSignup != nil {
  666. br.Msg = "获取信息失败"
  667. br.ErrMsg = "获取数量失败,Err:" + errSignup.Error()
  668. return
  669. }
  670. limitPeopleNum, err := strconv.Atoi(activityInfo.LimitPeopleNum)
  671. if err != nil {
  672. br.Msg = "获取信息失败"
  673. br.ErrMsg = "数据转换失败,Err:" + err.Error()
  674. return
  675. }
  676. //如果报名人数不小于限制人数,则报名人数已满
  677. if limitPeopleNum <= totalSignup {
  678. respList.IsFull = true
  679. }
  680. }
  681. for k, v := range list {
  682. if v.DoFailType == 0 {
  683. list[k].SalonOperation = true
  684. list[k].CallOperation = v.SignupType
  685. } else {
  686. list[k].CallOperation = 3
  687. }
  688. }
  689. respList.List = list
  690. respList.Total = total
  691. respList.MyTotal = myTotal
  692. respList.IsLimitPeople = activityInfo.IsLimitPeople
  693. respList.MemberType = memberType
  694. activityTypeId := activityInfo.ActivityTypeId
  695. if activityTypeId == 1 || activityTypeId == 2 {
  696. respList.ExcelType = "AppointmentCall"
  697. } else if activityTypeId == 5 || activityTypeId == 6 {
  698. respList.ExcelType = "ExpertSalon"
  699. } else if activityTypeId == 3 {
  700. respList.ExcelType = "Teleconference"
  701. } else if activityTypeId == 4 {
  702. respList.ExcelType = "OfflineResearch"
  703. }
  704. br.Ret = 200
  705. br.Success = true
  706. br.Msg = "获取成功"
  707. br.Data = respList
  708. }
  709. // @Title 沙龙限制报名、加入报名
  710. // @Description 修改沙龙限制报名、加入报名接口
  711. // @Param request body cygx.SignupId true "type json string"
  712. // @Success 200 操作成功
  713. // @router /activitySignup/salonSignupEdit [post]
  714. func (this *ActivitySignupCoAntroller) SalonSignupEdit() {
  715. br := new(models.BaseResponse).Init()
  716. defer func() {
  717. this.Data["json"] = br
  718. this.ServeJSON()
  719. }()
  720. AdminUser := this.SysUser
  721. if AdminUser == nil {
  722. br.Msg = "请登录"
  723. br.ErrMsg = "请登录,SysUser Is Empty"
  724. return
  725. }
  726. var req cygx.SignupId
  727. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  728. if err != nil {
  729. br.Msg = "参数解析异常!"
  730. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  731. return
  732. }
  733. id := req.Id
  734. total, err := cygx.GetCygxSignupCountFile(id)
  735. if err != nil {
  736. br.Msg = "获取失败"
  737. br.ErrMsg = "获取失败,Err:" + err.Error()
  738. return
  739. }
  740. if total == 0 {
  741. br.Msg = "获取报名信息失败"
  742. br.ErrMsg = "获取失败,id:" + strconv.Itoa(id)
  743. return
  744. }
  745. detail, err := cygx.GetCygxSignupDetailById(id)
  746. if err != nil {
  747. br.Msg = "操作失败"
  748. br.ErrMsg = "操作失败,Err:" + err.Error()
  749. return
  750. }
  751. newIsAdminAddSignup := 0
  752. if detail.IsAdminAddSignup == 1 {
  753. newIsAdminAddSignup = 0
  754. } else {
  755. newIsAdminAddSignup = 1
  756. activityInfo, err := cygx.GetAddActivityInfoById(detail.ActivityId)
  757. if err != nil {
  758. br.Msg = "活动不存在"
  759. br.ErrMsg = "活动ID错误,Err:" + err.Error() + "activityId:" + strconv.Itoa(detail.ActivityId)
  760. return
  761. }
  762. if activityInfo.IsLimitPeople > 0 {
  763. //获取这个活动已经报名的用户数量
  764. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(detail.ActivityId)
  765. if errSignup != nil {
  766. br.Msg = "操作失败"
  767. br.ErrMsg = "获取数量失败,Err:" + errSignup.Error()
  768. return
  769. }
  770. limitPeopleNum, err := strconv.Atoi(activityInfo.LimitPeopleNum)
  771. if err != nil {
  772. br.Msg = "操作失败"
  773. br.ErrMsg = "数据转换失败,Err:" + err.Error()
  774. return
  775. }
  776. if limitPeopleNum <= totalSignup {
  777. br.Msg = "新增失败,活动人数超限"
  778. return
  779. }
  780. adminInfo, errAdmin := system.GetSysUserById(AdminUser.AdminId)
  781. if errAdmin != nil {
  782. br.Msg = "获取失败"
  783. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  784. return
  785. }
  786. //如果操作的不是管理员就做下面的限制
  787. if adminInfo.Role != "admin" {
  788. activityId := detail.ActivityId
  789. //单机构两人限制
  790. {
  791. totalSignupCompany, err := cygx.GetActivitySignupCompanyCount(activityId, detail.CompanyId)
  792. if err != nil {
  793. br.Msg = "获取信息失败"
  794. br.ErrMsg = "获取客户信息失败,Err:" + err.Error()
  795. return
  796. }
  797. if totalSignupCompany >= 2 {
  798. br.Msg = "新增失败,单机构最多2人报名同一活动。"
  799. br.ErrMsg = "新增失败,单机构最多2人报名同一活动。" + fmt.Sprint("activityId:", activityId, detail.Mobile)
  800. return
  801. }
  802. }
  803. //爽约限制
  804. //{
  805. // totalRestrict, err := cygx.GetUserRestrictCount(detail.Mobile)
  806. // if err != nil {
  807. // br.Msg = "获取信息失败"
  808. // br.ErrMsg = "获取客户信息失败,Err:" + err.Error()
  809. // return
  810. // }
  811. // if totalRestrict >= 1 {
  812. // br.Msg = "新增失败," + detail.RealName + "爽约次数过多。"
  813. // br.ErrMsg = detail.RealName + "由于爽约次数过多,暂时被限制报名资格"
  814. // return
  815. // }
  816. //}
  817. }
  818. }
  819. }
  820. var doFailType int
  821. if newIsAdminAddSignup == 1 {
  822. doFailType = 0
  823. } else {
  824. doFailType = detail.FailType
  825. }
  826. infoUser, err := cygx.GetUserAndCompanyNameList(detail.UserId)
  827. if err != nil {
  828. br.Msg = "获取失败"
  829. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  830. return
  831. }
  832. item := new(cygx.CygxActivitySignup)
  833. item.UserId = infoUser.UserId
  834. item.RealName = infoUser.RealName
  835. item.SellerName = infoUser.SellerName
  836. item.ActivityId = detail.ActivityId
  837. item.CreateTime = time.Now()
  838. item.Mobile = infoUser.Mobile
  839. item.Email = infoUser.Email
  840. item.CompanyId = infoUser.CompanyId
  841. item.CompanyName = infoUser.CompanyName
  842. err = cygx.SalonSignupEdit(newIsAdminAddSignup, doFailType, id, item)
  843. if err != nil {
  844. br.Msg = "修改失败"
  845. br.ErrMsg = "修改失败 Err:" + err.Error()
  846. return
  847. }
  848. var itemsSendWxMsg []*cygx.CygxSignupUser
  849. itemsSendWxMsg = append(itemsSendWxMsg, &cygx.CygxSignupUser{UserId: infoUser.UserId, ActivityId: detail.ActivityId})
  850. //销售或后台管理员给用户添加报名之后,进行模版消息推送
  851. if doFailType == 0 {
  852. go cygxService.SendWxMsgWithCygxActivitySignUpBySell(itemsSendWxMsg)
  853. }
  854. //添加操作日志记录
  855. br.Ret = 200
  856. br.Success = true
  857. br.Msg = "操作成功"
  858. br.IsAddLog = true
  859. }
  860. // @Title 公司调研电话会报名失败详情列表
  861. // @Description 获取公司调研电话会报名失败详情列表接口
  862. // @Param ActivityId query int true "活动ID"
  863. // @Success 200 {object} cygx.GetFailSignupListRep
  864. // @router /activitySignup/callFailSignupList [get]
  865. func (this *ActivitySignupCoAntroller) FailSignupList() {
  866. br := new(models.BaseResponse).Init()
  867. defer func() {
  868. this.Data["json"] = br
  869. this.ServeJSON()
  870. }()
  871. sysUser := this.SysUser
  872. if sysUser == nil {
  873. br.Msg = "请登录"
  874. br.ErrMsg = "请登录,SysUser Is Empty"
  875. return
  876. }
  877. activityId, _ := this.GetInt("ActivityId")
  878. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  879. if activityInfo == nil {
  880. br.Msg = "活动不存在"
  881. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  882. return
  883. }
  884. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  885. resp := new(cygx.CanDownload)
  886. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  887. if errAdmin != nil {
  888. br.Msg = "获取失败"
  889. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  890. return
  891. }
  892. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  893. resp.IsCanDownload = true
  894. }
  895. var list []*cygx.FailSignupListRep
  896. memberType := "Admin"
  897. var err error
  898. sqlStr := ""
  899. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  900. if adminInfo.RoleTypeCode == "rai_group" {
  901. //组长查看本组所有组员
  902. memberType = "GroupLeader"
  903. sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  904. } else {
  905. //组员查看自己
  906. memberType = "Sale"
  907. sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  908. }
  909. }
  910. sqlStr += ` AND s.fail_type >0 `
  911. listSeller, errSeller := cygx.GetFailSignupList(activityId, sqlStr)
  912. list = listSeller
  913. err = errSeller
  914. if err != nil {
  915. br.Msg = "获取失败"
  916. br.ErrMsg = "获取失败,Err:" + err.Error()
  917. return
  918. }
  919. total, errtotal := cygx.GetCygxAppointmentCount(activityId, "")
  920. if errtotal != nil {
  921. br.Msg = "获取失败"
  922. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  923. return
  924. }
  925. myTotalsqlStr := ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  926. myTotal, errmyTotal := cygx.GetCygxAppointmentCount(activityId, myTotalsqlStr)
  927. if errmyTotal != nil {
  928. br.Msg = "获取失败"
  929. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  930. return
  931. }
  932. var listNew []*cygx.FailSignupListRep
  933. for k, v := range list {
  934. if k > 0 && list[k].Id == list[k-1].Id {
  935. list[k-1].SellerName = list[k-1].SellerName + "/" + v.SellerName
  936. }
  937. }
  938. for k, v := range list {
  939. if k > 0 && list[k].Id != list[k-1].Id {
  940. listNew = append(listNew, v)
  941. }
  942. if k == 0 && len(list) >= 2 && list[1].Id == list[0].Id {
  943. listNew = append(listNew, v)
  944. }
  945. }
  946. for k, v := range listNew {
  947. if v.IsAdminAddSignup == 0 {
  948. listNew[k].CallOperation = 3
  949. } else {
  950. listNew[k].CallOperation = v.MeetingType
  951. }
  952. }
  953. respList := new(cygx.GetFailSignupListRep)
  954. respList.List = listNew
  955. respList.Total = total
  956. respList.MyTotal = myTotal
  957. respList.IsLimitPeople = activityInfo.IsLimitPeople
  958. respList.MemberType = memberType
  959. activityTypeId := activityInfo.ActivityTypeId
  960. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  961. if activityTypeId == 1 || activityTypeId == 2 {
  962. respList.ExcelType = "AppointmentCall"
  963. } else if activityTypeId == 5 || activityTypeId == 6 {
  964. respList.ExcelType = "ExpertSalon"
  965. } else if activityTypeId == 3 {
  966. respList.ExcelType = "Teleconference"
  967. } else if activityTypeId == 4 {
  968. respList.ExcelType = "OfflineResearch"
  969. }
  970. br.Ret = 200
  971. br.Success = true
  972. br.Msg = "获取成功"
  973. br.Data = respList
  974. }
  975. // @Title 修改公司调研电话会限制报名、预约外呼、自主拨入
  976. // @Description 修改公司调研电话会限制报名、预约外呼、自主拨入接口
  977. // @Param request body cygx.SignupIdCall true "type json string"
  978. // @Success 200 操作成功
  979. // @router /activitySignup/callSignupEdit [post]
  980. func (this *ActivitySignupCoAntroller) CallSignupEdit() {
  981. br := new(models.BaseResponse).Init()
  982. defer func() {
  983. this.Data["json"] = br
  984. this.ServeJSON()
  985. }()
  986. sysUser := this.SysUser
  987. if sysUser == nil {
  988. br.Msg = "请登录"
  989. br.ErrMsg = "请登录,SysUser Is Empty"
  990. return
  991. }
  992. var req cygx.SignupIdCall
  993. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  994. if err != nil {
  995. br.Msg = "参数解析异常!"
  996. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  997. return
  998. }
  999. id := req.Id
  1000. operationStatus := req.OperationStatus
  1001. total, err := cygx.GetCygxSignupCountFile(id)
  1002. if err != nil {
  1003. br.Msg = "获取失败"
  1004. br.ErrMsg = "获取失败,Err:" + err.Error()
  1005. return
  1006. }
  1007. if total == 0 {
  1008. br.Msg = "获取报名信息失败"
  1009. br.ErrMsg = "获取失败,id:" + strconv.Itoa(id)
  1010. return
  1011. }
  1012. detail, err := cygx.GetCygxSignupDetailById(id)
  1013. if err != nil {
  1014. br.Msg = "操作失败"
  1015. br.ErrMsg = "操作失败,Err:" + err.Error()
  1016. return
  1017. }
  1018. uid := detail.UserId
  1019. var doFailType int
  1020. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  1021. if err != nil {
  1022. br.Msg = "获取失败"
  1023. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  1024. return
  1025. }
  1026. item := new(cygx.CygxMySchedule)
  1027. item.UserId = infoUser.UserId
  1028. item.CreateTime = time.Now()
  1029. item.Mobile = infoUser.Mobile
  1030. item.ActivityId = detail.ActivityId
  1031. item.Email = infoUser.Email
  1032. item.CompanyId = infoUser.CompanyId
  1033. item.CompanyName = infoUser.CompanyName
  1034. if operationStatus == 1 {
  1035. doFailType = 0
  1036. } else {
  1037. doFailType = detail.FailType
  1038. }
  1039. var errEdit error
  1040. if operationStatus == 3 {
  1041. err3 := cygx.CallSignupEditByStatus3(id, doFailType, item)
  1042. errEdit = err3
  1043. } else {
  1044. err1_2 := cygx.CallSignupEditByStatus1_2(operationStatus, id, item)
  1045. errEdit = err1_2
  1046. }
  1047. if errEdit != nil {
  1048. br.Msg = "修改失败"
  1049. br.ErrMsg = "修改失败 Err:" + errEdit.Error()
  1050. return
  1051. }
  1052. br.Ret = 200
  1053. br.Success = true
  1054. br.Msg = "操作成功"
  1055. br.IsAddLog = true
  1056. }
  1057. // @Title 预约外呼详情、公司调研电话会excel表格下载
  1058. // @Description 获取预约外呼详情、公司调研电话会excel表格下载接口
  1059. // @Param ActivityId query int true "活动ID"
  1060. // @Success 200 导出成功
  1061. // @router /activitySignup/callExport [get]
  1062. func (this *ActivitySignupCoAntroller) CallExport() {
  1063. br := new(models.BaseResponse).Init()
  1064. defer func() {
  1065. this.Data["json"] = br
  1066. this.ServeJSON()
  1067. }()
  1068. sysUser := this.SysUser
  1069. if sysUser == nil {
  1070. br.Msg = "请登录"
  1071. br.ErrMsg = "请登录,SysUser Is Empty"
  1072. return
  1073. }
  1074. activityId, _ := this.GetInt("ActivityId")
  1075. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1076. if activityInfo == nil {
  1077. br.Msg = "活动不存在"
  1078. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1079. return
  1080. }
  1081. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  1082. resp := new(cygx.CanDownload)
  1083. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  1084. if errAdmin != nil {
  1085. br.Msg = "获取失败"
  1086. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  1087. return
  1088. }
  1089. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  1090. resp.IsCanDownload = true
  1091. }
  1092. //var err error
  1093. sqlStr := " "
  1094. //if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  1095. // if adminInfo.RoleTypeCode == "rai_group" {
  1096. // //组长查看本组所有组员
  1097. // sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  1098. // } else {
  1099. // //组员查看自己
  1100. // sqlStr = ` AND s.user_id IN (SELECT user_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  1101. // }
  1102. //}
  1103. //sqlStr += ` AND s.do_fail_type = 0 GROUP BY s.id`
  1104. //list, errSeller := cygx.GetSignupExport(activityId, sqlStr)
  1105. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  1106. if adminInfo.RoleTypeCode == "rai_group" {
  1107. //组长查看本组所有组员
  1108. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  1109. } else {
  1110. //组员查看自己
  1111. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  1112. }
  1113. }
  1114. //公司调研电话会下载全部
  1115. if activityInfo.ActivityTypeId != 3 {
  1116. sqlStr += " AND s.signup_type = 1 "
  1117. }
  1118. list, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  1119. //err = errSeller
  1120. if err != nil {
  1121. br.Msg = "获取失败"
  1122. br.ErrMsg = "获取失败,Err:" + err.Error()
  1123. return
  1124. }
  1125. //会议提醒
  1126. listReminder, err := cygx.GetCygxActivityMeetingReminderList(activityId, sqlStr)
  1127. if err != nil {
  1128. br.Msg = "获取失败"
  1129. br.ErrMsg = "获取失败,Err:" + err.Error()
  1130. return
  1131. }
  1132. //预约纪要
  1133. listSummary, err := cygx.GetCygxAppointmentSummaryList(activityId, sqlStr)
  1134. if err != nil {
  1135. br.Msg = "获取失败"
  1136. br.ErrMsg = "获取失败,Err:" + err.Error()
  1137. return
  1138. }
  1139. //创建excel
  1140. dir, err := os.Executable()
  1141. exPath := filepath.Dir(dir)
  1142. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  1143. xlsxFile := xlsx.NewFile()
  1144. if err != nil {
  1145. br.Msg = "生成文件失败"
  1146. br.ErrMsg = "生成文件失败"
  1147. return
  1148. }
  1149. style := xlsx.NewStyle()
  1150. alignment := xlsx.Alignment{
  1151. Horizontal: "center",
  1152. Vertical: "center",
  1153. WrapText: true,
  1154. }
  1155. style.Alignment = alignment
  1156. style.ApplyAlignment = true
  1157. for pidIndex := 0; pidIndex <= 2; pidIndex++ {
  1158. var sheetName string
  1159. var listDate []*cygx.CygxAppointmentList
  1160. if pidIndex == 0 {
  1161. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 {
  1162. sheetName = "预约外呼"
  1163. } else {
  1164. sheetName = "名单"
  1165. }
  1166. listDate = list
  1167. } else if pidIndex == 1 {
  1168. sheetName = "会议提醒"
  1169. listDate = listReminder
  1170. } else {
  1171. sheetName = "预约纪要"
  1172. listDate = listSummary
  1173. }
  1174. sheet, err := xlsxFile.AddSheet(sheetName)
  1175. if err != nil {
  1176. br.Msg = "新增Sheet失败"
  1177. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  1178. return
  1179. }
  1180. //标头
  1181. if pidIndex == 0 {
  1182. //如果是公司调研电话会就下载邮箱
  1183. if activityInfo.ActivityTypeId == 3 {
  1184. rowTitle := sheet.AddRow()
  1185. cellA := rowTitle.AddCell()
  1186. cellA.Value = "姓名"
  1187. cellB := rowTitle.AddCell()
  1188. cellB.Value = "外呼号码"
  1189. cellC := rowTitle.AddCell()
  1190. cellC.Value = "国际代码"
  1191. cellD := rowTitle.AddCell()
  1192. cellD.Value = "邮箱"
  1193. cellE := rowTitle.AddCell()
  1194. cellE.Value = "公司名称"
  1195. cellF := rowTitle.AddCell()
  1196. cellF.Value = "所属销售"
  1197. for _, item := range listDate {
  1198. row := sheet.AddRow()
  1199. cellA := row.AddCell()
  1200. cellA.Value = item.RealName
  1201. cellB := row.AddCell()
  1202. cellB.Value = item.OutboundMobile
  1203. cellC := row.AddCell()
  1204. if item.CountryCode == "" {
  1205. cellC.Value = "86"
  1206. } else {
  1207. cellC.Value = item.CountryCode
  1208. }
  1209. cellD := row.AddCell()
  1210. cellD.Value = item.Email
  1211. cellE := row.AddCell()
  1212. cellE.Value = item.CompanyName
  1213. cellF := row.AddCell()
  1214. cellF.Value = item.SellerName
  1215. }
  1216. } else {
  1217. rowTitle := sheet.AddRow()
  1218. cellA := rowTitle.AddCell()
  1219. cellA.Value = "姓名"
  1220. cellB := rowTitle.AddCell()
  1221. cellB.Value = "外呼号码"
  1222. cellC := rowTitle.AddCell()
  1223. cellC.Value = "国际代码"
  1224. cellD := rowTitle.AddCell()
  1225. cellD.Value = "公司名称"
  1226. cellE := rowTitle.AddCell()
  1227. cellE.Value = "所属销售"
  1228. for _, item := range listDate {
  1229. row := sheet.AddRow()
  1230. cellA := row.AddCell()
  1231. cellA.Value = item.RealName
  1232. cellB := row.AddCell()
  1233. cellB.Value = item.OutboundMobile
  1234. cellC := row.AddCell()
  1235. if item.CountryCode == "" {
  1236. cellC.Value = "86"
  1237. } else {
  1238. cellC.Value = item.CountryCode
  1239. }
  1240. cellD := row.AddCell()
  1241. cellD.Value = item.CompanyName
  1242. cellE := row.AddCell()
  1243. cellE.Value = item.SellerName
  1244. }
  1245. }
  1246. } else {
  1247. rowTitle := sheet.AddRow()
  1248. cellA := rowTitle.AddCell()
  1249. cellA.Value = "姓名"
  1250. cellB := rowTitle.AddCell()
  1251. cellB.Value = "公司名称"
  1252. cellC := rowTitle.AddCell()
  1253. cellC.Value = "所属销售"
  1254. for _, item := range listDate {
  1255. row := sheet.AddRow()
  1256. cellA := row.AddCell()
  1257. cellA.Value = item.RealName
  1258. cellB := row.AddCell()
  1259. cellB.Value = item.CompanyName
  1260. cellC := row.AddCell()
  1261. cellC.Value = item.SellerName
  1262. }
  1263. }
  1264. }
  1265. err = xlsxFile.Save(downLoadnFilePath)
  1266. if err != nil {
  1267. br.Msg = "保存文件失败"
  1268. br.ErrMsg = "保存文件失败"
  1269. return
  1270. }
  1271. //randStr := time.Now().Format(utils.FormatDateTimeUnSpace)
  1272. downloadFileName := activityInfo.ActivityName + ".xlsx"
  1273. this.Ctx.Output.Download(downLoadnFilePath, downloadFileName)
  1274. defer func() {
  1275. os.Remove(downLoadnFilePath)
  1276. }()
  1277. br.Success = true
  1278. br.Ret = 200
  1279. br.IsAddLog = true
  1280. }
  1281. // @Title 公司线下调研、报名excel表格下载
  1282. // @Description 获取公司线下调研、报名excel表格下载接口
  1283. // @Param ActivityId query int true "活动ID"
  1284. // @Param ExcelType query int true "下载方式 0:全部名单、1:预约外呼名单、2:自主入会(自主拨入)名单"
  1285. // @Success 200 导出成功
  1286. // @router /activitySignup/signupFailExport [get]
  1287. func (this *ActivitySignupCoAntroller) SignupFailExport() {
  1288. br := new(models.BaseResponse).Init()
  1289. defer func() {
  1290. this.Data["json"] = br
  1291. this.ServeJSON()
  1292. }()
  1293. AdminUser := this.SysUser
  1294. if AdminUser == nil {
  1295. br.Msg = "请登录"
  1296. br.ErrMsg = "请登录,SysUser Is Empty"
  1297. return
  1298. }
  1299. activityId, _ := this.GetInt("ActivityId")
  1300. excelType, _ := this.GetInt("ExcelType")
  1301. //signupType := this.GetString("SignupType")
  1302. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1303. if activityInfo == nil {
  1304. br.Msg = "活动不存在"
  1305. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1306. return
  1307. }
  1308. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  1309. resp := new(cygx.CanDownload)
  1310. adminInfo, errAdmin := system.GetSysUserById(AdminUser.AdminId)
  1311. if errAdmin != nil {
  1312. br.Msg = "获取失败"
  1313. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  1314. return
  1315. }
  1316. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  1317. resp.IsCanDownload = true
  1318. }
  1319. sqlStr := ""
  1320. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 || activityInfo.IsYidongConduct == 1) {
  1321. if adminInfo.RoleTypeCode == "rai_group" {
  1322. //组长查看本组所有组员
  1323. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(AdminUser.AdminId) + ` ) )) `
  1324. } else {
  1325. //组员查看自己
  1326. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(AdminUser.AdminId) + `) `
  1327. }
  1328. }
  1329. sqlStrOther := sqlStr
  1330. var listReminder []*cygx.CygxAppointmentList
  1331. var summaryList []*cygx.CygxAppointmentList
  1332. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 {
  1333. var err error
  1334. //消息提醒
  1335. listReminder, err = cygx.GetCygxActivityMeetingReminderList(activityId, sqlStrOther)
  1336. if err != nil {
  1337. br.Msg = "获取失败"
  1338. br.ErrMsg = "获取失败,Err:" + err.Error()
  1339. return
  1340. }
  1341. //预约纪要
  1342. summaryList, err = cygx.GetCygxAppointmentSummaryList(activityId, sqlStrOther)
  1343. if err != nil {
  1344. br.Msg = "获取失败"
  1345. br.ErrMsg = "获取失败,Err:" + err.Error()
  1346. return
  1347. }
  1348. if excelType == 1 {
  1349. sqlStr += ` AND s.signup_type = 1 `
  1350. } else if excelType == 2 {
  1351. sqlStr += ` AND s.signup_type != 1 `
  1352. }
  1353. }
  1354. list, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  1355. if err != nil {
  1356. br.Msg = "获取失败"
  1357. br.ErrMsg = "获取失败,Err:" + err.Error()
  1358. return
  1359. }
  1360. //创建excel
  1361. dir, err := os.Executable()
  1362. exPath := filepath.Dir(dir)
  1363. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  1364. xlsxFile := xlsx.NewFile()
  1365. if err != nil {
  1366. br.Msg = "生成文件失败"
  1367. br.ErrMsg = "生成文件失败"
  1368. return
  1369. }
  1370. style := xlsx.NewStyle()
  1371. alignment := xlsx.Alignment{
  1372. Horizontal: "center",
  1373. Vertical: "center",
  1374. WrapText: true,
  1375. }
  1376. style.Alignment = alignment
  1377. style.ApplyAlignment = true
  1378. for pidIndex := 0; pidIndex <= 2; pidIndex++ {
  1379. //只做专家电话会,分析师电话会的多Sheel下载
  1380. if activityInfo.ActivityTypeId != 1 && activityInfo.ActivityTypeId != 2 {
  1381. if pidIndex > 0 {
  1382. continue
  1383. }
  1384. }
  1385. var sheetName string
  1386. var listDate []*cygx.CygxAppointmentList
  1387. if pidIndex == 0 {
  1388. sheetName = "报名名单"
  1389. listDate = list
  1390. } else if pidIndex == 1 {
  1391. sheetName = "消息提醒名单"
  1392. listDate = listReminder
  1393. } else if pidIndex == 2 {
  1394. sheetName = "预约纪要名单"
  1395. listDate = summaryList
  1396. }
  1397. sheet, err := xlsxFile.AddSheet(sheetName)
  1398. if err != nil {
  1399. br.Msg = "新增Sheet失败"
  1400. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  1401. return
  1402. }
  1403. //标头
  1404. if pidIndex == 0 {
  1405. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 || (activityInfo.ActivityTypeId == 7 && activityInfo.IsYidongConduct == 1) {
  1406. rowTitle := sheet.AddRow()
  1407. cellA := rowTitle.AddCell()
  1408. cellA.Value = "姓名"
  1409. cellB := rowTitle.AddCell()
  1410. cellB.Value = "外呼号码"
  1411. cellC := rowTitle.AddCell()
  1412. cellC.Value = "国际代码"
  1413. cellD := rowTitle.AddCell()
  1414. cellD.Value = "公司名称"
  1415. cellE := rowTitle.AddCell()
  1416. cellE.Value = "所属销售"
  1417. for _, item := range listDate {
  1418. row := sheet.AddRow()
  1419. cellA := row.AddCell()
  1420. cellA.Value = item.RealName
  1421. cellB := row.AddCell()
  1422. cellB.Value = item.OutboundMobile
  1423. cellC := row.AddCell()
  1424. cellC.Value = item.CountryCode
  1425. cellD := row.AddCell()
  1426. cellD.Value = item.CompanyName
  1427. cellE := row.AddCell()
  1428. cellE.Value = item.SellerName
  1429. }
  1430. } else {
  1431. rowTitle := sheet.AddRow()
  1432. cellA := rowTitle.AddCell()
  1433. cellA.Value = "姓名"
  1434. cellB := rowTitle.AddCell()
  1435. cellB.Value = "公司名称"
  1436. cellC := rowTitle.AddCell()
  1437. cellC.Value = "所属销售"
  1438. for _, item := range listDate {
  1439. row := sheet.AddRow()
  1440. cellA := row.AddCell()
  1441. cellA.Value = item.RealName
  1442. cellB := row.AddCell()
  1443. cellB.Value = item.CompanyName
  1444. cellC := row.AddCell()
  1445. cellC.Value = item.SellerName
  1446. }
  1447. }
  1448. } else {
  1449. rowTitle := sheet.AddRow()
  1450. cellA := rowTitle.AddCell()
  1451. cellA.Value = "姓名"
  1452. cellB := rowTitle.AddCell()
  1453. cellB.Value = "公司名称"
  1454. cellC := rowTitle.AddCell()
  1455. cellC.Value = "所属销售"
  1456. for _, item := range listDate {
  1457. row := sheet.AddRow()
  1458. cellA := row.AddCell()
  1459. cellA.Value = item.RealName
  1460. cellB := row.AddCell()
  1461. cellB.Value = item.CompanyName
  1462. cellC := row.AddCell()
  1463. cellC.Value = item.SellerName
  1464. }
  1465. }
  1466. }
  1467. err = xlsxFile.Save(downLoadnFilePath)
  1468. if err != nil {
  1469. br.Msg = "保存文件失败"
  1470. br.ErrMsg = "保存文件失败"
  1471. return
  1472. }
  1473. //randStr := time.Now().Format(utils.FormatDateTimeUnSpace)
  1474. downloadFileName := activityInfo.ActivityName + ".xlsx"
  1475. this.Ctx.Output.Download(downLoadnFilePath, downloadFileName)
  1476. defer func() {
  1477. os.Remove(downLoadnFilePath)
  1478. }()
  1479. //添加操作日志记录
  1480. br.Success = true
  1481. br.Ret = 200
  1482. br.Msg = "导出成功"
  1483. br.IsAddLog = true
  1484. }
  1485. // @Title 修改外呼号码
  1486. // @Description 修改外呼号码接口
  1487. // @Param request body cygx.OutboundMobileEditResp true "type json string"
  1488. // @Success 200 操作成功
  1489. // @router /activitySignup/outboundMobileEdit [post]
  1490. func (this *ActivitySignupCoAntroller) OutboundMobileEdit() {
  1491. br := new(models.BaseResponse).Init()
  1492. defer func() {
  1493. this.Data["json"] = br
  1494. this.ServeJSON()
  1495. }()
  1496. sysUser := this.SysUser
  1497. if sysUser == nil {
  1498. br.Msg = "请登录"
  1499. br.ErrMsg = "请登录,SysUser Is Empty"
  1500. return
  1501. }
  1502. var req cygx.OutboundMobileEditResp
  1503. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1504. if err != nil {
  1505. br.Msg = "参数解析异常!"
  1506. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1507. return
  1508. }
  1509. id := req.Id
  1510. outboundMobile := req.OutboundMobile
  1511. countryCode := req.CountryCode
  1512. total, err := cygx.GetCygxSignupCountFile(id)
  1513. if err != nil {
  1514. br.Msg = "获取失败"
  1515. br.ErrMsg = "获取失败,Err:" + err.Error()
  1516. return
  1517. }
  1518. if total == 0 {
  1519. br.Msg = "获取报名信息失败"
  1520. br.ErrMsg = "获取失败,id:" + strconv.Itoa(id)
  1521. return
  1522. }
  1523. err = cygx.OutboundMobileEdit(id, outboundMobile, countryCode)
  1524. if err != nil {
  1525. br.Msg = "修改失败"
  1526. br.ErrMsg = "修改失败 Err:" + err.Error()
  1527. return
  1528. }
  1529. br.Ret = 200
  1530. br.Success = true
  1531. br.Msg = "操作成功"
  1532. br.IsAddLog = true
  1533. }
  1534. // @Title 单条报名详情
  1535. // @Description 获取单条报名详情接口
  1536. // @Param Id query int true "报名ID"
  1537. // @Success Ret=200 {object} cygx.CygxActivitySignup
  1538. // @router /activitySignup/signupDetail [get]
  1539. func (this *ActivitySignupCoAntroller) SignupDetail() {
  1540. br := new(models.BaseResponse).Init()
  1541. defer func() {
  1542. this.Data["json"] = br
  1543. this.ServeJSON()
  1544. }()
  1545. AdminUser := this.SysUser
  1546. if AdminUser == nil {
  1547. br.Msg = "请登录"
  1548. br.ErrMsg = "请登录,用户信息为空"
  1549. br.Ret = 408
  1550. return
  1551. }
  1552. id, _ := this.GetInt("Id")
  1553. if id < 1 {
  1554. br.Msg = "请输入报名ID"
  1555. return
  1556. }
  1557. detail, err := cygx.GetActivitySignupInfoById(id)
  1558. if err != nil {
  1559. br.Msg = "报名信息不存在"
  1560. br.ErrMsg = "报名信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(id)
  1561. return
  1562. }
  1563. br.Ret = 200
  1564. br.Success = true
  1565. br.Msg = "获取成功"
  1566. br.Data = detail
  1567. }
  1568. // @Title 新增报名人员
  1569. // @Description 新增报名人员接口
  1570. // @Param request body cygx.AddMeetingReminderReq true "type json string"
  1571. // @Success 200 操作成功
  1572. // @router /activitySignup/addSignuUser [post]
  1573. func (this *ActivitySignupCoAntroller) AddSignuUser() {
  1574. br := new(models.BaseResponse).Init()
  1575. defer func() {
  1576. this.Data["json"] = br
  1577. this.ServeJSON()
  1578. }()
  1579. AdminUser := this.SysUser
  1580. if AdminUser == nil {
  1581. br.Msg = "请登录"
  1582. br.ErrMsg = "请登录,SysUser Is Empty"
  1583. return
  1584. }
  1585. var req cygx.AddMeetingReminderReq
  1586. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1587. if err != nil {
  1588. br.Msg = "参数解析异常!"
  1589. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1590. return
  1591. }
  1592. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  1593. if err != nil {
  1594. br.Msg = "添加失败"
  1595. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  1596. return
  1597. }
  1598. var items []*cygx.CygxActivitySignup
  1599. var itemsYidong []*cygx.YidongActivitySignup
  1600. var itemsAppointment []*cygx.CygxActivityAppointment
  1601. mapYidongActivity := make(map[int]int)
  1602. activityIds := req.ActivityIds
  1603. uidList := req.List
  1604. if activityIds == "" {
  1605. br.Msg = "请选择活动"
  1606. br.ErrMsg = "活动ID不能为空"
  1607. return
  1608. }
  1609. //获取已经报名成功的用户,给没有成功的或者没有报名的用户发送模版消息
  1610. mapSignupSuccess := make(map[string]int)
  1611. var itemsSendWxMsg []*cygx.CygxSignupUser
  1612. var condition string
  1613. var pars []interface{}
  1614. condition = ` AND do_fail_type = 0 AND activity_id IN (` + activityIds + `) `
  1615. listSignup, err := cygx.GetActivitySignupList(condition, pars)
  1616. if err != nil && err.Error() != utils.ErrNoRow() {
  1617. br.Msg = "添加报名失败"
  1618. br.ErrMsg = "添加报名失败,Err:GetActivitySignupList:" + err.Error()
  1619. }
  1620. for _, v := range listSignup {
  1621. mapSignupSuccess[fmt.Sprint("UID_", v.UserId, "AID_", v.ActivityId)] = v.ActivityId
  1622. }
  1623. activityIdList := strings.Split(activityIds, ",")
  1624. var uids string
  1625. for _, v := range uidList {
  1626. uids += strconv.Itoa(v.UserId) + ","
  1627. }
  1628. uids = strings.TrimRight(uids, ",")
  1629. mapCompanyPeople := make(map[string]int)
  1630. checkIsYidongConduct := make(map[string]int)
  1631. for _, v := range uidList {
  1632. uid := v.UserId
  1633. wxUser, userErr := models.GetWxUserByUserId(uid)
  1634. if userErr != nil {
  1635. br.Msg = "编辑失败!查询用户信息失败"
  1636. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  1637. return
  1638. }
  1639. for _, vact := range activityIdList {
  1640. activityId, _ := strconv.Atoi(vact)
  1641. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  1642. if err != nil {
  1643. br.Msg = "活动不存在"
  1644. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1645. return
  1646. }
  1647. // 如果是易董的办会,且不提供外呼,而且管理员还勾选了预约外呼,那么做判断
  1648. if activityInfo.IsYidongConduct == 1 && activityInfo.IsCanOutboundCall == 0 && v.SignupType == 1 {
  1649. br.Msg = "此活动不提供外呼"
  1650. br.ErrMsg = "此活动不提供外呼,Err:activityId:" + strconv.Itoa(activityId)
  1651. return
  1652. }
  1653. //同时 勾选一个易懂办会,一个非易懂办会的活动 的判断
  1654. checkIsYidongConduct[strconv.Itoa(activityInfo.IsYidongConduct)] = activityInfo.IsYidongConduct
  1655. if len(checkIsYidongConduct) > 1 {
  1656. br.Msg = "活动类型不同,无法同时新增报名"
  1657. br.ErrMsg = "活动类型不同,Err:activityIds:" + activityIds
  1658. return
  1659. }
  1660. if activityInfo.YidongActivityId != "" {
  1661. errMsg := cygxService.CheckYidongActivitySignupTime(activityInfo)
  1662. if errMsg != "" {
  1663. br.Msg = errMsg
  1664. br.ErrMsg = errMsg + "Err:activityId:" + strconv.Itoa(activityId)
  1665. return
  1666. }
  1667. mapYidongActivity[activityInfo.ActivityId] = activityInfo.ActivityId
  1668. }
  1669. activityTypeId := activityInfo.ActivityTypeId
  1670. if adminInfo.RoleTypeCode != "admin" {
  1671. havePower, err := cygxService.GetActivityDetailUserPower(wxUser, adminInfo, activityInfo)
  1672. if err != nil {
  1673. br.Msg = "用户权限校验失败!"
  1674. br.ErrMsg = "GetActivityDetailUserPower,Err:" + err.Error() + fmt.Sprint("UserId", wxUser.UserId, "ActivityId:", activityInfo.ActivityId)
  1675. return
  1676. }
  1677. if !havePower {
  1678. br.Msg = "当前活动对该客户不可见,无法报名"
  1679. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  1680. return
  1681. }
  1682. popupMsg, err := cygxService.CheckActivityUserAll(activityInfo, wxUser)
  1683. if err != nil {
  1684. br.Msg = "报名失败!"
  1685. br.ErrMsg = "CheckActivityUserAll,Err:" + err.Error()
  1686. return
  1687. }
  1688. if popupMsg != "" {
  1689. br.Msg = fmt.Sprint("报名失败!用户:", wxUser.RealName, popupMsg)
  1690. return
  1691. }
  1692. if activityInfo.YidongActivityId == "" {
  1693. if activityTypeId == 1 || activityTypeId == 2 {
  1694. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  1695. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  1696. br.Msg = "报名名单已发送至办会平台,请联系相关人员处理。"
  1697. return
  1698. }
  1699. }
  1700. }
  1701. //弘则的不做校验
  1702. if activityInfo.IsLimitPeople == 1 && wxUser.CompanyId != utils.HZ_COMPANY_ID {
  1703. //单机构两人限制
  1704. {
  1705. sqlStr := ` AND s.do_fail_type = 0`
  1706. listSignUp, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  1707. if err != nil && err.Error() != utils.ErrNoRow() {
  1708. br.Msg = "获取失败"
  1709. br.ErrMsg = "获取失败,Err:" + err.Error()
  1710. return
  1711. }
  1712. for _, v := range listSignUp {
  1713. mapCompanyPeople[fmt.Sprint("CID_", v.CompanyId, "AID_", activityId)]++
  1714. }
  1715. mapCompanyPeople[fmt.Sprint("CID_", wxUser.CompanyId, "AID_", activityId)]++
  1716. if mapCompanyPeople[fmt.Sprint("CID_", wxUser.CompanyId, "AID_", activityId)] > 2 {
  1717. br.Msg = "新增失败," + wxUser.RealName + "单机构2人限制。"
  1718. br.ErrMsg = wxUser.RealName + "单机构2人限制"
  1719. return
  1720. }
  1721. }
  1722. //爽约限制
  1723. //{
  1724. // totalRestrict, err := cygx.GetUserRestrictCount(wxUser.Mobile)
  1725. // if err != nil {
  1726. // br.Msg = "获取信息失败"
  1727. // br.ErrMsg = "获取客户信息失败,Err:" + err.Error()
  1728. // return
  1729. // }
  1730. // if totalRestrict >= 1 {
  1731. // br.Msg = "新增失败," + wxUser.RealName + "爽约次数过多。"
  1732. // br.ErrMsg = wxUser.RealName + "由于爽约次数过多,暂时被限制报名资格"
  1733. // return
  1734. // }
  1735. //}
  1736. }
  1737. }
  1738. limitPeopleNum, _ := strconv.Atoi(activityInfo.LimitPeopleNum)
  1739. //获取这个活动已经报名的用户数量
  1740. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  1741. if errSignup != nil {
  1742. br.Msg = "获取失败"
  1743. br.ErrMsg = "获取失败,Err:" + errSignup.Error()
  1744. return
  1745. }
  1746. //获取这个活动中输入的这些用户的报名数量
  1747. totalThisUser, errThisUser := cygx.GetActivitySignupCountByThisUser(activityId, uids)
  1748. if errThisUser != nil {
  1749. br.Msg = "获取失败"
  1750. br.ErrMsg = "获取失败,Err:" + errThisUser.Error()
  1751. return
  1752. }
  1753. //如果是限制人数的就做报名人数限制判断
  1754. if activityInfo.IsLimitPeople == 1 {
  1755. if limitPeopleNum < totalSignup+len(uidList)-totalThisUser {
  1756. br.Msg = "新增失败,活动人数超限"
  1757. br.ErrMsg = "当前活动报名人数已满,活动:" + activityInfo.ActivityName
  1758. return
  1759. }
  1760. }
  1761. total, errtotal := cygx.GetActivitySignupCount(uid, activityId)
  1762. if errtotal != nil {
  1763. br.Msg = "获取失败"
  1764. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  1765. return
  1766. }
  1767. //判断这个用户是否报名了,如果没有报名则写入报名数据
  1768. if total == 0 {
  1769. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  1770. if err != nil {
  1771. br.Msg = "获取失败"
  1772. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  1773. return
  1774. }
  1775. item := new(cygx.CygxActivitySignup)
  1776. item.UserId = infoUser.UserId
  1777. item.RealName = infoUser.RealName
  1778. item.SellerName = infoUser.SellerName
  1779. item.ActivityId = activityId
  1780. item.CreateTime = time.Now()
  1781. item.Mobile = infoUser.Mobile
  1782. item.Mobile = infoUser.Mobile
  1783. item.Email = infoUser.Email
  1784. item.CompanyId = infoUser.CompanyId
  1785. item.CompanyName = infoUser.CompanyName
  1786. //优先绑定用户修改过的外呼手机号
  1787. if infoUser.OutboundMobile != "" {
  1788. item.OutboundMobile = infoUser.OutboundMobile
  1789. if infoUser.OutboundCountryCode == "" {
  1790. item.CountryCode = "86"
  1791. } else {
  1792. item.CountryCode = infoUser.OutboundCountryCode
  1793. }
  1794. } else {
  1795. item.OutboundMobile = infoUser.Mobile
  1796. if infoUser.CountryCode == "" {
  1797. item.CountryCode = "86"
  1798. } else {
  1799. item.CountryCode = infoUser.CountryCode
  1800. }
  1801. }
  1802. //如果不填报名方式,则默认为我要报名这种方式
  1803. if v.SignupType == 0 {
  1804. item.SignupType = 3
  1805. } else {
  1806. item.SignupType = v.SignupType
  1807. }
  1808. item.Source = 2
  1809. items = append(items, item)
  1810. if activityInfo.YidongActivityId != "" {
  1811. itemYidong := new(cygx.YidongActivitySignup)
  1812. itemYidong.YidongActivityId = activityInfo.YidongActivityId
  1813. itemYidong.Mobile = item.Mobile
  1814. itemYidong.RealName = item.RealName
  1815. itemYidong.CompanyName = item.CompanyName
  1816. itemYidong.CountryCode = item.CountryCode
  1817. itemYidong.ActivityJoinType = activityInfo.ActivityJoinType
  1818. itemsYidong = append(itemsYidong, itemYidong)
  1819. }
  1820. }
  1821. if v.IsAppointment == 1 {
  1822. total, errtotal := cygx.GetUserCygxActivityAppointmentCount(uid, activityId)
  1823. if errtotal != nil {
  1824. br.Msg = "获取失败"
  1825. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  1826. return
  1827. }
  1828. //var isHideAppointment bool
  1829. //if activityInfo.IsCanAppointmentMinutes == 1 {
  1830. // isHideAppointment = cygxService.IsShowAppointmentByadminSet(activityInfo.IsCanAppointmentMinutes)
  1831. //}
  1832. if activityInfo.IsCanAppointmentMinutes == 0 {
  1833. br.Msg = "该活动无法预约纪要"
  1834. br.ErrMsg = "该活动无法预约纪要,Err:" + activityInfo.ActivityName
  1835. return
  1836. }
  1837. //判断这个用户是否报名了,如果没有报名则写入报名数据
  1838. if total == 0 {
  1839. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  1840. if err != nil {
  1841. br.Msg = "获取失败"
  1842. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  1843. return
  1844. }
  1845. itemAppointment := new(cygx.CygxActivityAppointment)
  1846. itemAppointment.UserId = infoUser.UserId
  1847. itemAppointment.RealName = infoUser.RealName
  1848. itemAppointment.SellerName = infoUser.SellerName
  1849. itemAppointment.ActivityId = activityId
  1850. itemAppointment.CreateTime = time.Now()
  1851. itemAppointment.Mobile = infoUser.Mobile
  1852. itemAppointment.Email = infoUser.Email
  1853. itemAppointment.CompanyId = infoUser.CompanyId
  1854. itemAppointment.CompanyName = infoUser.CompanyName
  1855. itemAppointment.Source = 2
  1856. itemAppointment.AdminId = adminInfo.AdminId
  1857. itemsAppointment = append(itemsAppointment, itemAppointment)
  1858. }
  1859. }
  1860. if mapSignupSuccess[fmt.Sprint("UID_", uid, "AID_", activityId)] == 0 {
  1861. itemsSendWxMsg = append(itemsSendWxMsg, &cygx.CygxSignupUser{UserId: uid, ActivityId: activityId})
  1862. }
  1863. }
  1864. }
  1865. //mapYidongActivity := make(map[int]int)
  1866. err = cygx.AddCygxActivitySignup(items, itemsAppointment, mapYidongActivity)
  1867. if err != nil {
  1868. br.Msg = "操作失败"
  1869. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  1870. return
  1871. }
  1872. //如果有值就向易董推送后台添加的报名信息
  1873. if len(itemsYidong) > 0 {
  1874. go cygxService.YidongActivityUserSingnUp(itemsYidong)
  1875. }
  1876. //销售或后台管理员给用户添加报名之后,进行模版消息推送
  1877. if len(itemsSendWxMsg) > 0 {
  1878. go cygxService.SendWxMsgWithCygxActivitySignUpBySell(itemsSendWxMsg)
  1879. }
  1880. if len(items) > 0 {
  1881. //1用户报名添加到处理研选扣点
  1882. for _, v := range items {
  1883. go cygxService.YanXuanActivityPointsBillSignupAdd(v.ActivityId, v.UserId, adminInfo.AdminId)
  1884. }
  1885. }
  1886. //添加操作日志记录
  1887. br.IsAddLog = true
  1888. br.IsSendEmail = false
  1889. br.Ret = 200
  1890. br.Success = true
  1891. br.Msg = "操作成功"
  1892. }
  1893. // @Title 带问列表详情
  1894. // @Description 获取带问列表详情接口
  1895. // @Param ActivityId query int true "活动ID"
  1896. // @Success 200 {object} cygx.ActivityHelpAskListResp
  1897. // @router /activitySignup/askList [get]
  1898. func (this *ActivitySignupCoAntroller) AskList() {
  1899. br := new(models.BaseResponse).Init()
  1900. defer func() {
  1901. this.Data["json"] = br
  1902. this.ServeJSON()
  1903. }()
  1904. sysUser := this.SysUser
  1905. if sysUser == nil {
  1906. br.Msg = "请登录"
  1907. br.ErrMsg = "请登录,SysUser Is Empty"
  1908. return
  1909. }
  1910. activityId, _ := this.GetInt("ActivityId")
  1911. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1912. if activityInfo == nil {
  1913. br.Msg = "活动不存在"
  1914. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1915. return
  1916. }
  1917. list, err := cygx.GetActivityHelpAskList(activityId)
  1918. respist := new(cygx.ActivityHelpAskListResp)
  1919. if err != nil {
  1920. br.Msg = "获取失败"
  1921. br.ErrMsg = "获取失败,Err:" + err.Error()
  1922. return
  1923. }
  1924. respist.List = list
  1925. br.Ret = 200
  1926. br.Success = true
  1927. br.Msg = "获取成功"
  1928. br.Data = respist
  1929. }
  1930. // @Title 带问详情excel表格下载
  1931. // @Description 带问详情excel表格下载接口
  1932. // @Param ActivityId query int true "活动ID"
  1933. // @Success 200 导出成功
  1934. // @router /activitySignup/askListExport [get]
  1935. func (this *ActivitySignupCoAntroller) AskListExport() {
  1936. br := new(models.BaseResponse).Init()
  1937. defer func() {
  1938. this.Data["json"] = br
  1939. this.ServeJSON()
  1940. }()
  1941. AdminUser := this.SysUser
  1942. if AdminUser == nil {
  1943. br.Msg = "请登录"
  1944. br.ErrMsg = "请登录,SysUser Is Empty"
  1945. return
  1946. }
  1947. activityId, _ := this.GetInt("ActivityId")
  1948. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1949. if activityInfo == nil {
  1950. br.Msg = "活动不存在"
  1951. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1952. return
  1953. }
  1954. list, err := cygx.GetActivityHelpAskList(activityId)
  1955. if err != nil {
  1956. br.Msg = "获取失败"
  1957. br.ErrMsg = "获取失败,Err:" + err.Error()
  1958. return
  1959. }
  1960. //创建excel
  1961. dir, err := os.Executable()
  1962. exPath := filepath.Dir(dir)
  1963. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  1964. xlsxFile := xlsx.NewFile()
  1965. if err != nil {
  1966. br.Msg = "生成文件失败"
  1967. br.ErrMsg = "生成文件失败"
  1968. return
  1969. }
  1970. style := xlsx.NewStyle()
  1971. alignment := xlsx.Alignment{
  1972. Horizontal: "center",
  1973. Vertical: "center",
  1974. WrapText: true,
  1975. }
  1976. style.Alignment = alignment
  1977. style.ApplyAlignment = true
  1978. sheet, err := xlsxFile.AddSheet("名单")
  1979. if err != nil {
  1980. br.Msg = "新增Sheet失败"
  1981. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  1982. return
  1983. }
  1984. //标头
  1985. rowTitle := sheet.AddRow()
  1986. cellA := rowTitle.AddCell()
  1987. cellA.Value = "姓名"
  1988. cellB := rowTitle.AddCell()
  1989. cellB.Value = "公司名称"
  1990. cellC := rowTitle.AddCell()
  1991. cellC.Value = "问题"
  1992. cellD := rowTitle.AddCell()
  1993. cellD.Value = "提交时间"
  1994. for _, item := range list {
  1995. row := sheet.AddRow()
  1996. cellA := row.AddCell()
  1997. cellA.Value = item.RealName
  1998. cellB := row.AddCell()
  1999. cellB.Value = item.CompanyName
  2000. cellC := row.AddCell()
  2001. cellC.Value = item.Content
  2002. cellD := row.AddCell()
  2003. cellD.Value = item.CreateTime
  2004. }
  2005. err = xlsxFile.Save(downLoadnFilePath)
  2006. if err != nil {
  2007. br.Msg = "保存文件失败"
  2008. br.ErrMsg = "保存文件失败"
  2009. return
  2010. }
  2011. randStr := time.Now().Format(utils.FormatDateTimeUnSpace)
  2012. downloadFileName := "问题列表" + randStr + ".xlsx"
  2013. this.Ctx.Output.Download(downLoadnFilePath, downloadFileName)
  2014. defer func() {
  2015. os.Remove(downLoadnFilePath)
  2016. }()
  2017. //添加操作日志记录
  2018. br.IsAddLog = true
  2019. br.Success = true
  2020. br.Ret = 200
  2021. br.Msg = "导出成功"
  2022. }
  2023. // @Title 新增报名人员(可择报名方式)
  2024. // @Description 新增报名人员(可择报名方式)接口
  2025. // @Param request body cygx.AddOutboundPersonnelJsonItm true "type json string"
  2026. // @Success 200 操作成功
  2027. // @router /activitySignup/addSignuUserOptType [post]
  2028. func (this *ActivitySignupCoAntroller) AddSignuUserOptType() {
  2029. br := new(models.BaseResponse).Init()
  2030. defer func() {
  2031. this.Data["json"] = br
  2032. this.ServeJSON()
  2033. }()
  2034. AdminUser := this.SysUser
  2035. if AdminUser == nil {
  2036. br.Msg = "请登录"
  2037. br.ErrMsg = "请登录,SysUser Is Empty"
  2038. return
  2039. }
  2040. var req cygx.AddOutboundPersonnelJsonItm
  2041. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2042. if err != nil {
  2043. br.Msg = "参数解析异常!"
  2044. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2045. return
  2046. }
  2047. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2048. if err != nil {
  2049. br.Msg = "添加失败"
  2050. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2051. return
  2052. }
  2053. jsonStr := req.JsonStar
  2054. var config cygx.RequestCommonPolicyConfig
  2055. err = json.Unmarshal([]byte(jsonStr), &config.CommonPolicyconfigs)
  2056. if err != nil {
  2057. br.Msg = "参数解析异常!"
  2058. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2059. return
  2060. }
  2061. var uids string
  2062. for _, v := range config.CommonPolicyconfigs {
  2063. uids += strconv.Itoa(v.Uid) + ","
  2064. }
  2065. uids = strings.TrimRight(uids, ",")
  2066. var items []*cygx.CygxActivitySignup
  2067. activityIds := req.ActivityIds
  2068. uidList := strings.Split(uids, ",")
  2069. activityIdList := strings.Split(activityIds, ",")
  2070. for _, v := range config.CommonPolicyconfigs {
  2071. uid := v.Uid
  2072. wxUser, userErr := models.GetWxUserByUserId(uid)
  2073. if userErr != nil {
  2074. br.Msg = "编辑失败!查询用户信息失败"
  2075. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  2076. return
  2077. }
  2078. for _, vact := range activityIdList {
  2079. activityId, _ := strconv.Atoi(vact)
  2080. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  2081. if err != nil {
  2082. br.Msg = "活动不存在"
  2083. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2084. return
  2085. }
  2086. if adminInfo.RoleTypeCode != "admin" {
  2087. havePower := cygxService.CheckaddSignuUserPower(wxUser.CompanyId, activityId, activityInfo)
  2088. if !havePower {
  2089. br.Msg = "当前活动对该客户不可见,无法报名"
  2090. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  2091. return
  2092. }
  2093. }
  2094. limitPeopleNum, _ := strconv.Atoi(activityInfo.LimitPeopleNum)
  2095. //获取这个活动已经报名的用户数量
  2096. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  2097. if errSignup != nil {
  2098. br.Msg = "获取失败"
  2099. br.ErrMsg = "获取失败,Err:" + errSignup.Error()
  2100. return
  2101. }
  2102. //获取这个活动中输入的这些用户的报名数量
  2103. totalThisUser, errThisUser := cygx.GetActivitySignupCountByThisUser(activityId, uids)
  2104. if errThisUser != nil {
  2105. br.Msg = "获取失败"
  2106. br.ErrMsg = "获取失败,Err:" + errThisUser.Error()
  2107. return
  2108. }
  2109. if limitPeopleNum < totalSignup+len(uidList)-totalThisUser {
  2110. br.Msg = "当前活动报名人数已满"
  2111. br.ErrMsg = "当前活动报名人数已满,活动:" + activityInfo.ActivityName
  2112. return
  2113. }
  2114. total, errtotal := cygx.GetActivitySignupCount(uid, activityId)
  2115. if errtotal != nil {
  2116. br.Msg = "获取失败"
  2117. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  2118. return
  2119. }
  2120. //判断这个用户是否报名了,如果没有报名则写入报名数据
  2121. if total == 0 {
  2122. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  2123. if err != nil {
  2124. br.Msg = "获取失败"
  2125. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  2126. return
  2127. }
  2128. item := new(cygx.CygxActivitySignup)
  2129. item.UserId = infoUser.UserId
  2130. item.RealName = infoUser.RealName
  2131. item.SellerName = infoUser.SellerName
  2132. item.ActivityId = activityId
  2133. item.CreateTime = time.Now()
  2134. item.Mobile = infoUser.Mobile
  2135. item.Email = infoUser.Email
  2136. item.CompanyId = infoUser.CompanyId
  2137. item.CompanyName = infoUser.CompanyName
  2138. //优先绑定用户修改过的外呼手机号
  2139. if infoUser.OutboundMobile != "" {
  2140. item.OutboundMobile = infoUser.OutboundMobile
  2141. if infoUser.OutboundCountryCode == "" {
  2142. item.CountryCode = "86"
  2143. } else {
  2144. item.CountryCode = infoUser.OutboundCountryCode
  2145. }
  2146. } else {
  2147. item.OutboundMobile = infoUser.Mobile
  2148. if infoUser.CountryCode == "" {
  2149. item.CountryCode = "86"
  2150. } else {
  2151. item.CountryCode = infoUser.CountryCode
  2152. }
  2153. }
  2154. signupType, _ := strconv.Atoi(v.Type)
  2155. item.SignupType = signupType
  2156. item.Source = 2
  2157. items = append(items, item)
  2158. }
  2159. }
  2160. }
  2161. err = cygx.AddCygxActivitySignupUser(items)
  2162. if err != nil {
  2163. br.Msg = "操作失败"
  2164. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  2165. return
  2166. }
  2167. //添加操作日志记录
  2168. br.IsAddLog = true
  2169. br.Ret = 200
  2170. br.Success = true
  2171. br.Msg = "操作成功"
  2172. }
  2173. // @Title 活动取消报名
  2174. // @Description 活动取消报名接口
  2175. // @Param request body cygx.CygxSignupId true "type json string"
  2176. // @Success Ret=200
  2177. // @router /activitySignup/cancel [post]
  2178. func (this *ActivitySignupCoAntroller) SignupCancel() {
  2179. br := new(models.BaseResponse).Init()
  2180. defer func() {
  2181. this.Data["json"] = br
  2182. this.ServeJSON()
  2183. }()
  2184. AdminUser := this.SysUser
  2185. if AdminUser == nil {
  2186. br.Msg = "请登录"
  2187. br.ErrMsg = "请登录,SysUser Is Empty"
  2188. return
  2189. }
  2190. var req cygx.CygxSignupId
  2191. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2192. if err != nil {
  2193. br.Msg = "参数解析异常!"
  2194. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2195. return
  2196. }
  2197. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2198. if err != nil {
  2199. br.Msg = "添加失败"
  2200. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2201. return
  2202. }
  2203. signupId := req.SignupId
  2204. cancelClass := req.CancelClass
  2205. detail, err := cygx.GetActivitySignupInfoById(signupId)
  2206. if err != nil {
  2207. br.Msg = "报名信息不存在"
  2208. br.ErrMsg = "报名信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2209. return
  2210. }
  2211. activityInfo, err := cygx.GetAddActivityInfoById(detail.ActivityId)
  2212. if err != nil {
  2213. br.Msg = "操作失败"
  2214. br.ErrMsg = "活动ID错误,不存在activityId:" + strconv.Itoa(detail.ActivityId)
  2215. return
  2216. }
  2217. if cancelClass == 1 {
  2218. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  2219. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  2220. br.Msg = "活动开始前1小时内无法取消外呼,提示:外呼名单已发送专家组,请联系专家组取消"
  2221. return
  2222. }
  2223. }
  2224. activityTypeId := activityInfo.ActivityTypeId
  2225. if adminInfo.RoleTypeCode != "admin" {
  2226. if activityTypeId == 1 || activityTypeId == 2 {
  2227. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  2228. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  2229. br.Msg = "报名名单已发送至办会平台,请联系相关人员处理。"
  2230. return
  2231. }
  2232. }
  2233. }
  2234. _, err = cygx.CancelActivitySignup(detail)
  2235. if err != nil {
  2236. br.Msg = "操作失败"
  2237. br.ErrMsg = "操作失败,Err:" + err.Error()
  2238. return
  2239. }
  2240. go cygxService.YanXuanActivityPointsBillSignupCancel(detail.ActivityId, detail.UserId, adminInfo.AdminId)
  2241. //添加操作日志记录
  2242. br.IsAddLog = true
  2243. br.Ret = 200
  2244. br.Success = true
  2245. br.Msg = "操作成功"
  2246. }
  2247. // @Title 预约纪要详情
  2248. // @Description 预约纪要详情列表接口
  2249. // @Param ActivityId query int true "活动ID"
  2250. // @Success 200 {object} cygx.GetAppointmentListRep
  2251. // @router /activitySignup/appointment/summaryList [get]
  2252. func (this *ActivitySignupCoAntroller) SummaryList() {
  2253. br := new(models.BaseResponse).Init()
  2254. defer func() {
  2255. this.Data["json"] = br
  2256. this.ServeJSON()
  2257. }()
  2258. sysUser := this.SysUser
  2259. if sysUser == nil {
  2260. br.Msg = "请登录"
  2261. br.ErrMsg = "请登录,SysUser Is Empty"
  2262. return
  2263. }
  2264. activityId, _ := this.GetInt("ActivityId")
  2265. if activityId < 1 {
  2266. br.Msg = "活动不存在"
  2267. return
  2268. }
  2269. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  2270. if activityInfo == nil {
  2271. br.Msg = "活动不存在"
  2272. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2273. return
  2274. }
  2275. var isShowMobile bool
  2276. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 {
  2277. isShowMobile = true
  2278. }
  2279. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  2280. resp := new(cygx.CanDownload)
  2281. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  2282. if errAdmin != nil {
  2283. br.Msg = "获取失败"
  2284. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  2285. return
  2286. }
  2287. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  2288. resp.IsCanDownload = true
  2289. }
  2290. memberType := "Admin"
  2291. sqlStr := ""
  2292. totalStr := sqlStr
  2293. if isShowMobile {
  2294. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  2295. if adminInfo.RoleTypeCode == "rai_group" {
  2296. //组长查看本组所有组员
  2297. memberType = "GroupLeader"
  2298. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  2299. } else {
  2300. //组员查看自己
  2301. memberType = "Sale"
  2302. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  2303. }
  2304. }
  2305. }
  2306. list, err := cygx.GetCygxAppointmentSummaryList(activityId, sqlStr)
  2307. if err != nil {
  2308. br.Msg = "获取失败"
  2309. br.ErrMsg = "获取失败,Err:" + err.Error()
  2310. return
  2311. }
  2312. total, errtotal := cygx.GetCygxAppointmentSummaryCount(activityId, totalStr)
  2313. if errtotal != nil {
  2314. br.Msg = "获取失败"
  2315. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  2316. return
  2317. }
  2318. myTotal, errmyTotal := cygx.GetCygxAppointmentSummaryCount(activityId, sqlStr)
  2319. if errmyTotal != nil {
  2320. br.Msg = "获取失败"
  2321. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  2322. return
  2323. }
  2324. for k, v := range list {
  2325. list[k].SellerName = v.PsellerName
  2326. if !isShowMobile {
  2327. list[k].Mobile = ""
  2328. }
  2329. }
  2330. respList := new(cygx.GetAppointmentListRep)
  2331. respList.List = list
  2332. respList.Total = total
  2333. respList.MyTotal = myTotal
  2334. respList.ActivityId = activityId
  2335. respList.IsLimitPeople = activityInfo.IsLimitPeople
  2336. respList.MemberType = memberType
  2337. activityTypeId := activityInfo.ActivityTypeId
  2338. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  2339. if activityTypeId == 1 || activityTypeId == 2 {
  2340. respList.ExcelType = "AppointmentCall"
  2341. } else if activityTypeId == 5 || activityTypeId == 6 {
  2342. respList.ExcelType = "ExpertSalon"
  2343. } else if activityTypeId == 3 {
  2344. respList.ExcelType = "Teleconference"
  2345. } else if activityTypeId == 4 {
  2346. respList.ExcelType = "OfflineResearch"
  2347. }
  2348. if isShowMobile {
  2349. respList.ActivityType = 1
  2350. }
  2351. br.Ret = 200
  2352. br.Success = true
  2353. br.Msg = "获取成功"
  2354. br.Data = respList
  2355. }
  2356. // @Title 新增预约纪要人员
  2357. // @Description 新增预约纪要人员接口
  2358. // @Param request body cygx.AddOutboundPersonnelItm true "type json string"
  2359. // @Success 200 操作成功
  2360. // @router /activitySignup/appointment/addSummaryUser [post]
  2361. func (this *ActivitySignupCoAntroller) AddSummaryUser() {
  2362. br := new(models.BaseResponse).Init()
  2363. defer func() {
  2364. this.Data["json"] = br
  2365. this.ServeJSON()
  2366. }()
  2367. AdminUser := this.SysUser
  2368. if AdminUser == nil {
  2369. br.Msg = "请登录"
  2370. br.ErrMsg = "请登录,SysUser Is Empty"
  2371. return
  2372. }
  2373. var req cygx.AddOutboundPersonnelItm
  2374. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2375. if err != nil {
  2376. br.Msg = "参数解析异常!"
  2377. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2378. return
  2379. }
  2380. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2381. if err != nil {
  2382. br.Msg = "添加失败"
  2383. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2384. return
  2385. }
  2386. var items []*cygx.CygxActivityAppointment
  2387. uids := req.UserIds
  2388. activityIds := req.ActivityIds
  2389. uidList := strings.Split(uids, ",")
  2390. activityIdList := strings.Split(activityIds, ",")
  2391. for _, v := range uidList {
  2392. uid, err := strconv.Atoi(v)
  2393. if err != nil {
  2394. br.Msg = "操作失败"
  2395. br.ErrMsg = "查询用户信息失败,Err:" + err.Error()
  2396. return
  2397. }
  2398. wxUser, userErr := models.GetWxUserByUserId(uid)
  2399. if userErr != nil {
  2400. br.Msg = "编辑失败!查询用户信息失败"
  2401. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  2402. return
  2403. }
  2404. for _, vact := range activityIdList {
  2405. activityId, _ := strconv.Atoi(vact)
  2406. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  2407. if err != nil {
  2408. br.Msg = "活动不存在"
  2409. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2410. return
  2411. }
  2412. if adminInfo.RoleTypeCode != "admin" {
  2413. //havePower := cygxService.CheckaddSignuUserPower(wxUser.CompanyId, activityId, activityInfo)
  2414. havePower, err := cygxService.GetActivityDetailUserPower(wxUser, AdminUser, activityInfo)
  2415. if err != nil {
  2416. br.Msg = "用户权限校验失败!"
  2417. br.ErrMsg = "GetActivityDetailUserPower,Err:" + err.Error() + fmt.Sprint("UserId", wxUser.UserId, "ActivityId:", activityInfo.ActivityId)
  2418. return
  2419. }
  2420. if !havePower {
  2421. br.Msg = "当前活动对该客户不可见,无法报名"
  2422. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  2423. return
  2424. }
  2425. }
  2426. //isHideAppointment := cygxService.IsShowAppointmentByadminSet(activityInfo.IsCanAppointmentMinutes)
  2427. if activityInfo.IsCanAppointmentMinutes == 0 {
  2428. br.Msg = "当前活动无法新增预约纪要" + activityInfo.ActivityName
  2429. return
  2430. }
  2431. //if cygxService.CheckActivityAddAppointment(activityInfo) {
  2432. // br.Msg = "当前活动无法新增预约纪要" + activityInfo.ActivityName
  2433. // return
  2434. //}
  2435. total, errtotal := cygx.GetUserCygxActivityAppointmentCount(uid, activityId)
  2436. if errtotal != nil {
  2437. br.Msg = "获取失败"
  2438. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  2439. return
  2440. }
  2441. //判断这个用户是否报名了,如果没有报名则写入报名数据
  2442. if total == 0 {
  2443. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  2444. if err != nil {
  2445. br.Msg = "获取失败"
  2446. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  2447. return
  2448. }
  2449. item := new(cygx.CygxActivityAppointment)
  2450. item.UserId = infoUser.UserId
  2451. item.RealName = infoUser.RealName
  2452. item.SellerName = infoUser.SellerName
  2453. item.ActivityId = activityId
  2454. item.CreateTime = time.Now()
  2455. item.Mobile = infoUser.Mobile
  2456. item.Email = infoUser.Email
  2457. item.CompanyId = infoUser.CompanyId
  2458. item.CompanyName = infoUser.CompanyName
  2459. item.Source = 2
  2460. items = append(items, item)
  2461. }
  2462. }
  2463. }
  2464. err = cygx.AddCygxActivityAppointmentUser(items)
  2465. if err != nil {
  2466. br.Msg = "操作失败"
  2467. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  2468. return
  2469. }
  2470. //添加操作日志记录
  2471. br.IsAddLog = true
  2472. br.Ret = 200
  2473. br.Success = true
  2474. br.Msg = "操作成功"
  2475. }
  2476. // @Title 取消纪要纪要预约
  2477. // @Description 取消纪要纪要预约接口
  2478. // @Param request body cygx.CygxSignupId true "type json string"
  2479. // @Success Ret=200
  2480. // @router /activitySignup/appointment/cancel [post]
  2481. func (this *ActivitySignupCoAntroller) SummaryCancel() {
  2482. br := new(models.BaseResponse).Init()
  2483. defer func() {
  2484. this.Data["json"] = br
  2485. this.ServeJSON()
  2486. }()
  2487. AdminUser := this.SysUser
  2488. if AdminUser == nil {
  2489. br.Msg = "请登录"
  2490. br.ErrMsg = "请登录,SysUser Is Empty"
  2491. return
  2492. }
  2493. var req cygx.CygxSignupId
  2494. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2495. if err != nil {
  2496. br.Msg = "参数解析异常!"
  2497. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2498. return
  2499. }
  2500. signupId := req.SignupId
  2501. detail, err := cygx.GetCygxAppointmentSummaryInfoById(signupId)
  2502. if err != nil {
  2503. br.Msg = "预约信息不存在"
  2504. br.ErrMsg = "预约信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2505. return
  2506. }
  2507. _, err = cygx.CancelcygxActivityAppointment(detail)
  2508. if err != nil {
  2509. br.Msg = "操作失败"
  2510. br.ErrMsg = "操作失败,Err:" + err.Error()
  2511. return
  2512. }
  2513. //添加操作日志记录
  2514. br.IsAddLog = true
  2515. br.Ret = 200
  2516. br.Success = true
  2517. br.Msg = "操作成功"
  2518. }
  2519. // @Title 会议提醒人数详情
  2520. // @Description 会议提醒人数详情列表接口
  2521. // @Param ActivityId query int true "活动ID"
  2522. // @Success 200 {object} cygx.GetAppointmentListRep
  2523. // @router /activitySignup/reminder/list [get]
  2524. func (this *ActivitySignupCoAntroller) ReminderList() {
  2525. br := new(models.BaseResponse).Init()
  2526. defer func() {
  2527. this.Data["json"] = br
  2528. this.ServeJSON()
  2529. }()
  2530. sysUser := this.SysUser
  2531. if sysUser == nil {
  2532. br.Msg = "请登录"
  2533. br.ErrMsg = "请登录,SysUser Is Empty"
  2534. return
  2535. }
  2536. activityId, _ := this.GetInt("ActivityId")
  2537. if activityId < 1 {
  2538. br.Msg = "活动不存在"
  2539. return
  2540. }
  2541. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  2542. if activityInfo == nil {
  2543. br.Msg = "活动不存在"
  2544. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2545. return
  2546. }
  2547. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  2548. resp := new(cygx.CanDownload)
  2549. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  2550. if errAdmin != nil {
  2551. br.Msg = "获取失败"
  2552. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  2553. return
  2554. }
  2555. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  2556. resp.IsCanDownload = true
  2557. }
  2558. memberType := "Admin"
  2559. sqlStr := ""
  2560. totalStr := sqlStr
  2561. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  2562. if adminInfo.RoleTypeCode == "rai_group" {
  2563. //组长查看本组所有组员
  2564. memberType = "GroupLeader"
  2565. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id IN (SELECT admin_id FROM admin WHERE group_id = (SELECT group_id FROM admin WHERE admin_id = ` + strconv.Itoa(sysUser.AdminId) + ` ) )) `
  2566. } else {
  2567. //组员查看自己
  2568. memberType = "Sale"
  2569. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  2570. }
  2571. }
  2572. list, err := cygx.GetCygxActivityMeetingReminderList(activityId, sqlStr)
  2573. if err != nil {
  2574. br.Msg = "获取失败"
  2575. br.ErrMsg = "获取失败,Err:" + err.Error()
  2576. return
  2577. }
  2578. total, errtotal := cygx.GetCygxActivityMeetingReminderCount(activityId, totalStr)
  2579. if errtotal != nil {
  2580. br.Msg = "获取失败"
  2581. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  2582. return
  2583. }
  2584. myTotal, errmyTotal := cygx.GetCygxActivityMeetingReminderCount(activityId, sqlStr)
  2585. if errmyTotal != nil {
  2586. br.Msg = "获取失败"
  2587. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  2588. return
  2589. }
  2590. if len(list) > 0 {
  2591. for k, v := range list {
  2592. list[k].SellerName = v.PsellerName
  2593. }
  2594. } else {
  2595. list = make([]*cygx.CygxAppointmentList, 0)
  2596. }
  2597. respList := new(cygx.GetAppointmentListRep)
  2598. respList.List = list
  2599. respList.Total = total
  2600. respList.MyTotal = myTotal
  2601. respList.ActivityId = activityId
  2602. respList.IsLimitPeople = activityInfo.IsLimitPeople
  2603. respList.MemberType = memberType
  2604. activityTypeId := activityInfo.ActivityTypeId
  2605. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  2606. if activityTypeId == 1 || activityTypeId == 2 {
  2607. respList.ExcelType = "AppointmentCall"
  2608. } else if activityTypeId == 5 || activityTypeId == 6 {
  2609. respList.ExcelType = "ExpertSalon"
  2610. } else if activityTypeId == 3 {
  2611. respList.ExcelType = "Teleconference"
  2612. } else if activityTypeId == 4 {
  2613. respList.ExcelType = "OfflineResearch"
  2614. }
  2615. br.Ret = 200
  2616. br.Success = true
  2617. br.Msg = "获取成功"
  2618. br.Data = respList
  2619. }
  2620. // @Title 取消会议提醒
  2621. // @Description 取消会议提醒接口
  2622. // @Param request body cygx.CygxSignupId true "type json string"
  2623. // @Success Ret=200
  2624. // @router /activitySignup/reminder/cancel [post]
  2625. func (this *ActivitySignupCoAntroller) ReminderCancel() {
  2626. br := new(models.BaseResponse).Init()
  2627. defer func() {
  2628. this.Data["json"] = br
  2629. this.ServeJSON()
  2630. }()
  2631. AdminUser := this.SysUser
  2632. if AdminUser == nil {
  2633. br.Msg = "请登录"
  2634. br.ErrMsg = "请登录,SysUser Is Empty"
  2635. return
  2636. }
  2637. var req cygx.CygxSignupId
  2638. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2639. if err != nil {
  2640. br.Msg = "参数解析异常!"
  2641. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2642. return
  2643. }
  2644. signupId := req.SignupId
  2645. detail, err := cygx.GetCygxActivityMeetingReminderInfoById(signupId)
  2646. if err != nil {
  2647. br.Msg = "预约信息不存在"
  2648. br.ErrMsg = "预约信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2649. return
  2650. }
  2651. _, err = cygx.CancelActivityMeetingReminder(detail)
  2652. if err != nil {
  2653. br.Msg = "操作失败"
  2654. br.ErrMsg = "操作失败,Err:" + err.Error()
  2655. return
  2656. }
  2657. //添加操作日志记录
  2658. br.IsAddLog = true
  2659. br.Ret = 200
  2660. br.Success = true
  2661. br.Msg = "操作成功"
  2662. }
  2663. // @Title 发送模版消息
  2664. // @Description 发送模版消息接口
  2665. // @Param request body cygx.AddOutboundPersonnelItm true "type json string"
  2666. // @Success 200 操作成功
  2667. // @router /activitySignup/tempMsg [post]
  2668. func (this *ActivitySignupCoAntroller) TempMsg() {
  2669. br := new(models.BaseResponse).Init()
  2670. defer func() {
  2671. this.Data["json"] = br
  2672. this.ServeJSON()
  2673. }()
  2674. AdminUser := this.SysUser
  2675. if AdminUser == nil {
  2676. br.Msg = "请登录"
  2677. br.ErrMsg = "请登录,SysUser Is Empty"
  2678. return
  2679. }
  2680. var req cygx.ActivitySignupTempMsgReq
  2681. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2682. if err != nil {
  2683. br.Msg = "参数解析异常!"
  2684. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2685. return
  2686. }
  2687. //adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2688. //if err != nil {
  2689. // br.Msg = "添加失败"
  2690. // br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2691. // return
  2692. //}
  2693. idSlice := strings.Split(req.ActivityIds, ",")
  2694. for _, sId := range idSlice {
  2695. id, e := strconv.Atoi(sId)
  2696. if e != nil {
  2697. br.Msg = "活动Id参数异常"
  2698. br.ErrMsg = "参数解析异常, Err:" + e.Error()
  2699. return
  2700. }
  2701. var openIdList []*models.OpenIdList
  2702. idMap := make(map[string]string, 0)
  2703. if strings.Contains(req.SendGroup, "1") {
  2704. list, err := models.GetCygxUserIndustryFllowOpneidByActivityIds(id)
  2705. if err != nil {
  2706. br.Msg = "查询openId失败"
  2707. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2708. return
  2709. }
  2710. for _, idList := range list {
  2711. openIdList = append(openIdList, idList)
  2712. idMap[idList.OpenId] = idList.OpenId
  2713. }
  2714. }
  2715. if strings.Contains(req.SendGroup, "2") {
  2716. list, err := models.GetCygxForeverUserIndustryFllowOpneidByActivityIds(id)
  2717. if err != nil {
  2718. br.Msg = "查询openId失败"
  2719. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2720. return
  2721. }
  2722. for _, idList := range openIdList {
  2723. idMap[idList.OpenId] = idList.OpenId
  2724. }
  2725. for _, idList := range list {
  2726. if _, ok := idMap[idList.OpenId]; !ok {
  2727. openIdList = append(openIdList, idList)
  2728. idMap[idList.OpenId] = idList.OpenId
  2729. }
  2730. }
  2731. }
  2732. if strings.Contains(req.SendGroup, "3") {
  2733. list, err := cygxService.GetCygxBigTypeUserIndustryFllowOpneidByActivityIds(id)
  2734. if err != nil {
  2735. br.Msg = "查询openId失败"
  2736. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2737. return
  2738. }
  2739. for _, idList := range openIdList {
  2740. idMap[idList.OpenId] = idList.OpenId
  2741. }
  2742. for _, idList := range list {
  2743. if _, ok := idMap[idList.OpenId]; !ok {
  2744. openIdList = append(openIdList, idList)
  2745. idMap[idList.OpenId] = idList.OpenId
  2746. }
  2747. }
  2748. }
  2749. if strings.Contains(req.SendGroup, "4") {
  2750. list, err := cygxService.GetCygxIndustryPackageUserIndustryFllowOpneidByActivityIds(id)
  2751. if err != nil {
  2752. br.Msg = "查询openId失败"
  2753. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2754. return
  2755. }
  2756. for _, idList := range openIdList {
  2757. idMap[idList.OpenId] = idList.OpenId
  2758. }
  2759. for _, idList := range list {
  2760. if _, ok := idMap[idList.OpenId]; !ok {
  2761. openIdList = append(openIdList, idList)
  2762. idMap[idList.OpenId] = idList.OpenId
  2763. }
  2764. }
  2765. }
  2766. if strings.Contains(req.SendGroup, "5") {
  2767. list, err := cygxService.GetCygxOtherIndustryPackageUserIndustryFllowOpneidByActivityIds(id)
  2768. if err != nil {
  2769. br.Msg = "查询openId失败"
  2770. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2771. return
  2772. }
  2773. for _, idList := range openIdList {
  2774. idMap[idList.OpenId] = idList.OpenId
  2775. }
  2776. for _, idList := range list {
  2777. if _, ok := idMap[idList.OpenId]; !ok {
  2778. openIdList = append(openIdList, idList)
  2779. idMap[idList.OpenId] = idList.OpenId
  2780. }
  2781. }
  2782. }
  2783. if strings.Contains(req.SendGroup, "6") {
  2784. list, err := models.GetCygxTryOutUserIndustryFllowOpneidByActivityIds(id)
  2785. if err != nil {
  2786. br.Msg = "查询openId失败"
  2787. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2788. return
  2789. }
  2790. for _, idList := range openIdList {
  2791. idMap[idList.OpenId] = idList.OpenId
  2792. }
  2793. for _, idList := range list {
  2794. if _, ok := idMap[idList.OpenId]; !ok {
  2795. openIdList = append(openIdList, idList)
  2796. idMap[idList.OpenId] = idList.OpenId
  2797. }
  2798. }
  2799. }
  2800. if strings.Contains(req.SendGroup, "7") {
  2801. list, err := cygxService.GetCygxInteractiveUserOpneidByActivityIds(id)
  2802. if err != nil {
  2803. br.Msg = "查询openId失败"
  2804. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2805. return
  2806. }
  2807. for _, idList := range openIdList {
  2808. idMap[idList.OpenId] = idList.OpenId
  2809. }
  2810. for _, idList := range list {
  2811. if _, ok := idMap[idList.OpenId]; !ok {
  2812. openIdList = append(openIdList, idList)
  2813. idMap[idList.OpenId] = idList.OpenId
  2814. }
  2815. }
  2816. }
  2817. if len(openIdList) > 0 {
  2818. openIdArr := make([]string, len(openIdList))
  2819. for i, v := range openIdList {
  2820. openIdArr[i] = v.OpenId
  2821. }
  2822. sendInfo := new(services.SendWxTemplate)
  2823. //sendInfo.First = req.FirstText
  2824. sendInfo.Keyword1 = req.ActivityName
  2825. sendInfo.Keyword2 = req.Content
  2826. //sendInfo.Keyword3 = meetingTime
  2827. sendInfo.Remark = "点击查看活动详情"
  2828. sendInfo.TemplateId = utils.WxMsgTemplateIdActivityChangeApplyXzs
  2829. sendInfo.RedirectUrl = utils.WX_MSG_PATH_ACTIVITY_DETAIL + strconv.Itoa(id)
  2830. sendInfo.RedirectTarget = 3
  2831. sendInfo.Resource = strconv.Itoa(id)
  2832. sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_ACTIVITY_CUSTOMIZE
  2833. sendInfo.OpenIdArr = openIdArr
  2834. e = services.SendTemplateMsg(sendInfo)
  2835. if e != nil {
  2836. br.Msg = "推送模板消息失败!"
  2837. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  2838. return
  2839. }
  2840. }
  2841. }
  2842. br.Ret = 200
  2843. br.Success = true
  2844. br.Msg = "发送成功"
  2845. }
  2846. // @Title 模版消息发送客户类型列表
  2847. // @Description 模版消息发送客户类型列表接口
  2848. // @Success Ret=200
  2849. // @router /activitySignup/tempMsg/sendGroupList [get]
  2850. func (this *ActivitySignupCoAntroller) SendGroupList() {
  2851. br := new(models.BaseResponse).Init()
  2852. defer func() {
  2853. this.Data["json"] = br
  2854. this.ServeJSON()
  2855. }()
  2856. AdminUser := this.SysUser
  2857. if AdminUser == nil {
  2858. br.Msg = "请登录"
  2859. br.ErrMsg = "请登录,SysUser Is Empty"
  2860. return
  2861. }
  2862. list := make([]cygx.SendGroup, 0)
  2863. list = append(list, cygx.SendGroup{
  2864. Id: 1,
  2865. Name: "全部客户",
  2866. })
  2867. list = append(list, cygx.SendGroup{
  2868. Id: 2,
  2869. Name: "永续客户",
  2870. })
  2871. list = append(list, cygx.SendGroup{
  2872. Id: 3,
  2873. Name: "大套餐客户",
  2874. })
  2875. list = append(list, cygx.SendGroup{
  2876. Id: 4,
  2877. Name: "行业套餐客户",
  2878. })
  2879. list = append(list, cygx.SendGroup{
  2880. Id: 5,
  2881. Name: "其他行业正式客户",
  2882. })
  2883. list = append(list, cygx.SendGroup{
  2884. Id: 6,
  2885. Name: "试用客户",
  2886. })
  2887. list = append(list, cygx.SendGroup{
  2888. Id: 7,
  2889. Name: "已参与互动的客户",
  2890. })
  2891. br.Ret = 200
  2892. br.Success = true
  2893. br.Data = list
  2894. }