activity_signup.go 95 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997
  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. var err error
  1333. //消息提醒
  1334. listReminder, err = cygx.GetCygxActivityMeetingReminderList(activityId, sqlStrOther)
  1335. if err != nil {
  1336. br.Msg = "获取失败"
  1337. br.ErrMsg = "获取失败,Err:" + err.Error()
  1338. return
  1339. }
  1340. //预约纪要
  1341. summaryList, err = cygx.GetCygxAppointmentSummaryList(activityId, sqlStrOther)
  1342. if err != nil {
  1343. br.Msg = "获取失败"
  1344. br.ErrMsg = "获取失败,Err:" + err.Error()
  1345. return
  1346. }
  1347. if excelType == 1 {
  1348. sqlStr += ` AND s.signup_type = 1 `
  1349. } else if excelType == 2 {
  1350. sqlStr += ` AND s.signup_type IN (2,4) `
  1351. }
  1352. //}
  1353. list, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  1354. if err != nil {
  1355. br.Msg = "获取失败"
  1356. br.ErrMsg = "获取失败,Err:" + err.Error()
  1357. return
  1358. }
  1359. //创建excel
  1360. dir, err := os.Executable()
  1361. exPath := filepath.Dir(dir)
  1362. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  1363. xlsxFile := xlsx.NewFile()
  1364. if err != nil {
  1365. br.Msg = "生成文件失败"
  1366. br.ErrMsg = "生成文件失败"
  1367. return
  1368. }
  1369. style := xlsx.NewStyle()
  1370. alignment := xlsx.Alignment{
  1371. Horizontal: "center",
  1372. Vertical: "center",
  1373. WrapText: true,
  1374. }
  1375. style.Alignment = alignment
  1376. style.ApplyAlignment = true
  1377. for pidIndex := 0; pidIndex <= 2; pidIndex++ {
  1378. //只做专家电话会,分析师电话会的多Sheel下载
  1379. if activityInfo.ActivityTypeId != 1 && activityInfo.ActivityTypeId != 2 {
  1380. if pidIndex > 0 {
  1381. continue
  1382. }
  1383. }
  1384. var sheetName string
  1385. var listDate []*cygx.CygxAppointmentList
  1386. if pidIndex == 0 {
  1387. sheetName = "报名名单"
  1388. listDate = list
  1389. } else if pidIndex == 1 {
  1390. sheetName = "消息提醒名单"
  1391. listDate = listReminder
  1392. } else if pidIndex == 2 {
  1393. sheetName = "预约纪要名单"
  1394. listDate = summaryList
  1395. }
  1396. sheet, err := xlsxFile.AddSheet(sheetName)
  1397. if err != nil {
  1398. br.Msg = "新增Sheet失败"
  1399. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  1400. return
  1401. }
  1402. //标头
  1403. if pidIndex == 0 {
  1404. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 || (activityInfo.ActivityTypeId == 7 && activityInfo.IsYidongConduct == 1) {
  1405. rowTitle := sheet.AddRow()
  1406. cellA := rowTitle.AddCell()
  1407. cellA.Value = "姓名"
  1408. cellB := rowTitle.AddCell()
  1409. cellB.Value = "外呼号码"
  1410. cellC := rowTitle.AddCell()
  1411. cellC.Value = "国际代码"
  1412. cellD := rowTitle.AddCell()
  1413. cellD.Value = "邮箱"
  1414. cellE := rowTitle.AddCell()
  1415. cellE.Value = "公司名称"
  1416. cellF := rowTitle.AddCell()
  1417. cellF.Value = "所属销售"
  1418. for _, item := range listDate {
  1419. row := sheet.AddRow()
  1420. cellA := row.AddCell()
  1421. cellA.Value = item.RealName
  1422. cellB := row.AddCell()
  1423. cellB.Value = item.OutboundMobile
  1424. cellC := row.AddCell()
  1425. cellC.Value = item.CountryCode
  1426. cellD := row.AddCell()
  1427. cellD.Value = item.Email
  1428. cellE := row.AddCell()
  1429. cellE.Value = item.CompanyName
  1430. cellF := row.AddCell()
  1431. cellF.Value = item.SellerName
  1432. }
  1433. } else {
  1434. rowTitle := sheet.AddRow()
  1435. cellA := rowTitle.AddCell()
  1436. cellA.Value = "姓名"
  1437. cellB := rowTitle.AddCell()
  1438. cellB.Value = "公司名称"
  1439. cellC := rowTitle.AddCell()
  1440. cellC.Value = "所属销售"
  1441. for _, item := range listDate {
  1442. row := sheet.AddRow()
  1443. cellA := row.AddCell()
  1444. cellA.Value = item.RealName
  1445. cellB := row.AddCell()
  1446. cellB.Value = item.CompanyName
  1447. cellC := row.AddCell()
  1448. cellC.Value = item.SellerName
  1449. }
  1450. }
  1451. } else {
  1452. rowTitle := sheet.AddRow()
  1453. cellA := rowTitle.AddCell()
  1454. cellA.Value = "姓名"
  1455. cellB := rowTitle.AddCell()
  1456. cellB.Value = "公司名称"
  1457. cellC := rowTitle.AddCell()
  1458. cellC.Value = "所属销售"
  1459. for _, item := range listDate {
  1460. row := sheet.AddRow()
  1461. cellA := row.AddCell()
  1462. cellA.Value = item.RealName
  1463. cellB := row.AddCell()
  1464. cellB.Value = item.CompanyName
  1465. cellC := row.AddCell()
  1466. cellC.Value = item.SellerName
  1467. }
  1468. }
  1469. }
  1470. err = xlsxFile.Save(downLoadnFilePath)
  1471. if err != nil {
  1472. br.Msg = "保存文件失败"
  1473. br.ErrMsg = "保存文件失败"
  1474. return
  1475. }
  1476. //randStr := time.Now().Format(utils.FormatDateTimeUnSpace)
  1477. downloadFileName := activityInfo.ActivityName + ".xlsx"
  1478. this.Ctx.Output.Download(downLoadnFilePath, downloadFileName)
  1479. defer func() {
  1480. os.Remove(downLoadnFilePath)
  1481. }()
  1482. //添加操作日志记录
  1483. br.Success = true
  1484. br.Ret = 200
  1485. br.Msg = "导出成功"
  1486. br.IsAddLog = true
  1487. }
  1488. // @Title 修改外呼号码
  1489. // @Description 修改外呼号码接口
  1490. // @Param request body cygx.OutboundMobileEditResp true "type json string"
  1491. // @Success 200 操作成功
  1492. // @router /activitySignup/outboundMobileEdit [post]
  1493. func (this *ActivitySignupCoAntroller) OutboundMobileEdit() {
  1494. br := new(models.BaseResponse).Init()
  1495. defer func() {
  1496. this.Data["json"] = br
  1497. this.ServeJSON()
  1498. }()
  1499. sysUser := this.SysUser
  1500. if sysUser == nil {
  1501. br.Msg = "请登录"
  1502. br.ErrMsg = "请登录,SysUser Is Empty"
  1503. return
  1504. }
  1505. var req cygx.OutboundMobileEditResp
  1506. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1507. if err != nil {
  1508. br.Msg = "参数解析异常!"
  1509. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1510. return
  1511. }
  1512. id := req.Id
  1513. outboundMobile := req.OutboundMobile
  1514. countryCode := req.CountryCode
  1515. total, err := cygx.GetCygxSignupCountFile(id)
  1516. if err != nil {
  1517. br.Msg = "获取失败"
  1518. br.ErrMsg = "获取失败,Err:" + err.Error()
  1519. return
  1520. }
  1521. if total == 0 {
  1522. br.Msg = "获取报名信息失败"
  1523. br.ErrMsg = "获取失败,id:" + strconv.Itoa(id)
  1524. return
  1525. }
  1526. err = cygx.OutboundMobileEdit(id, outboundMobile, countryCode)
  1527. if err != nil {
  1528. br.Msg = "修改失败"
  1529. br.ErrMsg = "修改失败 Err:" + err.Error()
  1530. return
  1531. }
  1532. br.Ret = 200
  1533. br.Success = true
  1534. br.Msg = "操作成功"
  1535. br.IsAddLog = true
  1536. }
  1537. // @Title 单条报名详情
  1538. // @Description 获取单条报名详情接口
  1539. // @Param Id query int true "报名ID"
  1540. // @Success Ret=200 {object} cygx.CygxActivitySignup
  1541. // @router /activitySignup/signupDetail [get]
  1542. func (this *ActivitySignupCoAntroller) SignupDetail() {
  1543. br := new(models.BaseResponse).Init()
  1544. defer func() {
  1545. this.Data["json"] = br
  1546. this.ServeJSON()
  1547. }()
  1548. AdminUser := this.SysUser
  1549. if AdminUser == nil {
  1550. br.Msg = "请登录"
  1551. br.ErrMsg = "请登录,用户信息为空"
  1552. br.Ret = 408
  1553. return
  1554. }
  1555. id, _ := this.GetInt("Id")
  1556. if id < 1 {
  1557. br.Msg = "请输入报名ID"
  1558. return
  1559. }
  1560. detail, err := cygx.GetActivitySignupInfoById(id)
  1561. if err != nil {
  1562. br.Msg = "报名信息不存在"
  1563. br.ErrMsg = "报名信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(id)
  1564. return
  1565. }
  1566. br.Ret = 200
  1567. br.Success = true
  1568. br.Msg = "获取成功"
  1569. br.Data = detail
  1570. }
  1571. // @Title 新增报名人员
  1572. // @Description 新增报名人员接口
  1573. // @Param request body cygx.AddMeetingReminderReq true "type json string"
  1574. // @Success 200 操作成功
  1575. // @router /activitySignup/addSignuUser [post]
  1576. func (this *ActivitySignupCoAntroller) AddSignuUser() {
  1577. br := new(models.BaseResponse).Init()
  1578. defer func() {
  1579. this.Data["json"] = br
  1580. this.ServeJSON()
  1581. }()
  1582. AdminUser := this.SysUser
  1583. if AdminUser == nil {
  1584. br.Msg = "请登录"
  1585. br.ErrMsg = "请登录,SysUser Is Empty"
  1586. return
  1587. }
  1588. var req cygx.AddMeetingReminderReq
  1589. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1590. if err != nil {
  1591. br.Msg = "参数解析异常!"
  1592. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1593. return
  1594. }
  1595. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  1596. if err != nil {
  1597. br.Msg = "添加失败"
  1598. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  1599. return
  1600. }
  1601. var items []*cygx.CygxActivitySignup
  1602. var itemsYidong []*cygx.YidongActivitySignup
  1603. var itemsAppointment []*cygx.CygxActivityAppointment
  1604. mapYidongActivity := make(map[int]int)
  1605. activityIds := req.ActivityIds
  1606. uidList := req.List
  1607. if activityIds == "" {
  1608. br.Msg = "请选择活动"
  1609. br.ErrMsg = "活动ID不能为空"
  1610. return
  1611. }
  1612. //获取已经报名成功的用户,给没有成功的或者没有报名的用户发送模版消息
  1613. mapSignupSuccess := make(map[string]int)
  1614. var itemsSendWxMsg []*cygx.CygxSignupUser
  1615. var condition string
  1616. var pars []interface{}
  1617. condition = ` AND do_fail_type = 0 AND activity_id IN (` + activityIds + `) `
  1618. listSignup, err := cygx.GetActivitySignupList(condition, pars)
  1619. if err != nil && err.Error() != utils.ErrNoRow() {
  1620. br.Msg = "添加报名失败"
  1621. br.ErrMsg = "添加报名失败,Err:GetActivitySignupList:" + err.Error()
  1622. }
  1623. for _, v := range listSignup {
  1624. mapSignupSuccess[fmt.Sprint("UID_", v.UserId, "AID_", v.ActivityId)] = v.ActivityId
  1625. }
  1626. activityIdList := strings.Split(activityIds, ",")
  1627. var uids string
  1628. for _, v := range uidList {
  1629. uids += strconv.Itoa(v.UserId) + ","
  1630. }
  1631. uids = strings.TrimRight(uids, ",")
  1632. mapCompanyPeople := make(map[string]int)
  1633. checkIsYidongConduct := make(map[string]int)
  1634. for _, v := range uidList {
  1635. uid := v.UserId
  1636. wxUser, userErr := models.GetWxUserByUserId(uid)
  1637. if userErr != nil {
  1638. br.Msg = "编辑失败!查询用户信息失败"
  1639. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  1640. return
  1641. }
  1642. for _, vact := range activityIdList {
  1643. activityId, _ := strconv.Atoi(vact)
  1644. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  1645. if err != nil {
  1646. br.Msg = "活动不存在"
  1647. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1648. return
  1649. }
  1650. // 如果是易董的办会,且不提供外呼,而且管理员还勾选了预约外呼,那么做判断
  1651. if activityInfo.IsYidongConduct == 1 && activityInfo.IsCanOutboundCall == 0 && v.SignupType == 1 {
  1652. br.Msg = "此活动不提供外呼"
  1653. br.ErrMsg = "此活动不提供外呼,Err:activityId:" + strconv.Itoa(activityId)
  1654. return
  1655. }
  1656. //同时 勾选一个易懂办会,一个非易懂办会的活动 的判断
  1657. checkIsYidongConduct[strconv.Itoa(activityInfo.IsYidongConduct)] = activityInfo.IsYidongConduct
  1658. if len(checkIsYidongConduct) > 1 {
  1659. br.Msg = "活动类型不同,无法同时新增报名"
  1660. br.ErrMsg = "活动类型不同,Err:activityIds:" + activityIds
  1661. return
  1662. }
  1663. if activityInfo.YidongActivityId != "" {
  1664. errMsg := cygxService.CheckYidongActivitySignupTime(activityInfo)
  1665. if errMsg != "" {
  1666. br.Msg = errMsg
  1667. br.ErrMsg = errMsg + "Err:activityId:" + strconv.Itoa(activityId)
  1668. return
  1669. }
  1670. mapYidongActivity[activityInfo.ActivityId] = activityInfo.ActivityId
  1671. }
  1672. activityTypeId := activityInfo.ActivityTypeId
  1673. if adminInfo.RoleTypeCode != "admin" {
  1674. havePower, err := cygxService.GetActivityDetailUserPower(wxUser, adminInfo, activityInfo)
  1675. if err != nil {
  1676. br.Msg = "用户权限校验失败!"
  1677. br.ErrMsg = "GetActivityDetailUserPower,Err:" + err.Error() + fmt.Sprint("UserId", wxUser.UserId, "ActivityId:", activityInfo.ActivityId)
  1678. return
  1679. }
  1680. if !havePower {
  1681. br.Msg = "当前活动对该客户不可见,无法报名"
  1682. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  1683. return
  1684. }
  1685. popupMsg, err := cygxService.CheckActivityUserAll(activityInfo, wxUser)
  1686. if err != nil {
  1687. br.Msg = "报名失败!"
  1688. br.ErrMsg = "CheckActivityUserAll,Err:" + err.Error()
  1689. return
  1690. }
  1691. if popupMsg != "" {
  1692. br.Msg = fmt.Sprint("报名失败!用户:", wxUser.RealName, popupMsg)
  1693. return
  1694. }
  1695. if activityInfo.YidongActivityId == "" {
  1696. if activityTypeId == 1 || activityTypeId == 2 {
  1697. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  1698. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  1699. br.Msg = "报名名单已发送至办会平台,请联系相关人员处理。"
  1700. return
  1701. }
  1702. }
  1703. }
  1704. //弘则的不做校验
  1705. if activityInfo.IsLimitPeople == 1 && wxUser.CompanyId != utils.HZ_COMPANY_ID {
  1706. //单机构两人限制
  1707. {
  1708. sqlStr := ` AND s.do_fail_type = 0`
  1709. listSignUp, err := cygx.GetCygxAppointmentList(activityId, sqlStr)
  1710. if err != nil && err.Error() != utils.ErrNoRow() {
  1711. br.Msg = "获取失败"
  1712. br.ErrMsg = "获取失败,Err:" + err.Error()
  1713. return
  1714. }
  1715. for _, v := range listSignUp {
  1716. mapCompanyPeople[fmt.Sprint("CID_", v.CompanyId, "AID_", activityId)]++
  1717. }
  1718. mapCompanyPeople[fmt.Sprint("CID_", wxUser.CompanyId, "AID_", activityId)]++
  1719. if mapCompanyPeople[fmt.Sprint("CID_", wxUser.CompanyId, "AID_", activityId)] > 2 {
  1720. br.Msg = "新增失败," + wxUser.RealName + "单机构2人限制。"
  1721. br.ErrMsg = wxUser.RealName + "单机构2人限制"
  1722. return
  1723. }
  1724. }
  1725. //爽约限制
  1726. //{
  1727. // totalRestrict, err := cygx.GetUserRestrictCount(wxUser.Mobile)
  1728. // if err != nil {
  1729. // br.Msg = "获取信息失败"
  1730. // br.ErrMsg = "获取客户信息失败,Err:" + err.Error()
  1731. // return
  1732. // }
  1733. // if totalRestrict >= 1 {
  1734. // br.Msg = "新增失败," + wxUser.RealName + "爽约次数过多。"
  1735. // br.ErrMsg = wxUser.RealName + "由于爽约次数过多,暂时被限制报名资格"
  1736. // return
  1737. // }
  1738. //}
  1739. }
  1740. }
  1741. limitPeopleNum, _ := strconv.Atoi(activityInfo.LimitPeopleNum)
  1742. //获取这个活动已经报名的用户数量
  1743. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  1744. if errSignup != nil {
  1745. br.Msg = "获取失败"
  1746. br.ErrMsg = "获取失败,Err:" + errSignup.Error()
  1747. return
  1748. }
  1749. //获取这个活动中输入的这些用户的报名数量
  1750. totalThisUser, errThisUser := cygx.GetActivitySignupCountByThisUser(activityId, uids)
  1751. if errThisUser != nil {
  1752. br.Msg = "获取失败"
  1753. br.ErrMsg = "获取失败,Err:" + errThisUser.Error()
  1754. return
  1755. }
  1756. //如果是限制人数的就做报名人数限制判断
  1757. if activityInfo.IsLimitPeople == 1 {
  1758. if limitPeopleNum < totalSignup+len(uidList)-totalThisUser {
  1759. br.Msg = "新增失败,活动人数超限"
  1760. br.ErrMsg = "当前活动报名人数已满,活动:" + activityInfo.ActivityName
  1761. return
  1762. }
  1763. }
  1764. total, errtotal := cygx.GetActivitySignupCount(uid, activityId)
  1765. if errtotal != nil {
  1766. br.Msg = "获取失败"
  1767. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  1768. return
  1769. }
  1770. //判断这个用户是否报名了,如果没有报名则写入报名数据
  1771. if total == 0 {
  1772. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  1773. if err != nil {
  1774. br.Msg = "获取失败"
  1775. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  1776. return
  1777. }
  1778. item := new(cygx.CygxActivitySignup)
  1779. item.UserId = infoUser.UserId
  1780. item.RealName = infoUser.RealName
  1781. item.SellerName = infoUser.SellerName
  1782. item.ActivityId = activityId
  1783. item.CreateTime = time.Now()
  1784. item.Mobile = infoUser.Mobile
  1785. item.Mobile = infoUser.Mobile
  1786. item.Email = infoUser.Email
  1787. item.CompanyId = infoUser.CompanyId
  1788. item.CompanyName = infoUser.CompanyName
  1789. //优先绑定用户修改过的外呼手机号
  1790. if infoUser.OutboundMobile != "" {
  1791. item.OutboundMobile = infoUser.OutboundMobile
  1792. if infoUser.OutboundCountryCode == "" {
  1793. item.CountryCode = "86"
  1794. } else {
  1795. item.CountryCode = infoUser.OutboundCountryCode
  1796. }
  1797. } else {
  1798. item.OutboundMobile = infoUser.Mobile
  1799. if infoUser.CountryCode == "" {
  1800. item.CountryCode = "86"
  1801. } else {
  1802. item.CountryCode = infoUser.CountryCode
  1803. }
  1804. }
  1805. //如果不填报名方式,则默认为我要报名这种方式
  1806. if v.SignupType == 0 {
  1807. item.SignupType = 3
  1808. } else {
  1809. item.SignupType = v.SignupType
  1810. }
  1811. item.Source = 2
  1812. items = append(items, item)
  1813. if activityInfo.YidongActivityId != "" {
  1814. itemYidong := new(cygx.YidongActivitySignup)
  1815. itemYidong.YidongActivityId = activityInfo.YidongActivityId
  1816. itemYidong.Mobile = item.Mobile
  1817. itemYidong.RealName = item.RealName
  1818. itemYidong.CompanyName = item.CompanyName
  1819. itemYidong.CountryCode = item.CountryCode
  1820. itemYidong.ActivityJoinType = activityInfo.ActivityJoinType
  1821. itemsYidong = append(itemsYidong, itemYidong)
  1822. }
  1823. }
  1824. if v.IsAppointment == 1 {
  1825. total, errtotal := cygx.GetUserCygxActivityAppointmentCount(uid, activityId)
  1826. if errtotal != nil {
  1827. br.Msg = "获取失败"
  1828. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  1829. return
  1830. }
  1831. //var isHideAppointment bool
  1832. //if activityInfo.IsCanAppointmentMinutes == 1 {
  1833. // isHideAppointment = cygxService.IsShowAppointmentByadminSet(activityInfo.IsCanAppointmentMinutes)
  1834. //}
  1835. if activityInfo.IsCanAppointmentMinutes == 0 {
  1836. br.Msg = "该活动无法预约纪要"
  1837. br.ErrMsg = "该活动无法预约纪要,Err:" + activityInfo.ActivityName
  1838. return
  1839. }
  1840. //判断这个用户是否报名了,如果没有报名则写入报名数据
  1841. if total == 0 {
  1842. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  1843. if err != nil {
  1844. br.Msg = "获取失败"
  1845. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  1846. return
  1847. }
  1848. itemAppointment := new(cygx.CygxActivityAppointment)
  1849. itemAppointment.UserId = infoUser.UserId
  1850. itemAppointment.RealName = infoUser.RealName
  1851. itemAppointment.SellerName = infoUser.SellerName
  1852. itemAppointment.ActivityId = activityId
  1853. itemAppointment.CreateTime = time.Now()
  1854. itemAppointment.Mobile = infoUser.Mobile
  1855. itemAppointment.Email = infoUser.Email
  1856. itemAppointment.CompanyId = infoUser.CompanyId
  1857. itemAppointment.CompanyName = infoUser.CompanyName
  1858. itemAppointment.Source = 2
  1859. itemAppointment.AdminId = adminInfo.AdminId
  1860. itemsAppointment = append(itemsAppointment, itemAppointment)
  1861. }
  1862. }
  1863. if mapSignupSuccess[fmt.Sprint("UID_", uid, "AID_", activityId)] == 0 {
  1864. itemsSendWxMsg = append(itemsSendWxMsg, &cygx.CygxSignupUser{UserId: uid, ActivityId: activityId})
  1865. }
  1866. }
  1867. }
  1868. //mapYidongActivity := make(map[int]int)
  1869. err = cygx.AddCygxActivitySignup(items, itemsAppointment, mapYidongActivity)
  1870. if err != nil {
  1871. br.Msg = "操作失败"
  1872. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  1873. return
  1874. }
  1875. //如果有值就向易董推送后台添加的报名信息
  1876. if len(itemsYidong) > 0 {
  1877. go cygxService.YidongActivityUserSingnUp(itemsYidong)
  1878. }
  1879. //销售或后台管理员给用户添加报名之后,进行模版消息推送
  1880. if len(itemsSendWxMsg) > 0 {
  1881. go cygxService.SendWxMsgWithCygxActivitySignUpBySell(itemsSendWxMsg)
  1882. }
  1883. if len(items) > 0 {
  1884. //1用户报名添加到处理研选扣点
  1885. for _, v := range items {
  1886. go cygxService.YanXuanActivityPointsBillSignupAdd(v.ActivityId, v.UserId, adminInfo.AdminId)
  1887. }
  1888. }
  1889. //添加操作日志记录
  1890. br.IsAddLog = true
  1891. br.IsSendEmail = false
  1892. br.Ret = 200
  1893. br.Success = true
  1894. br.Msg = "操作成功"
  1895. }
  1896. // @Title 带问列表详情
  1897. // @Description 获取带问列表详情接口
  1898. // @Param ActivityId query int true "活动ID"
  1899. // @Success 200 {object} cygx.ActivityHelpAskListResp
  1900. // @router /activitySignup/askList [get]
  1901. func (this *ActivitySignupCoAntroller) AskList() {
  1902. br := new(models.BaseResponse).Init()
  1903. defer func() {
  1904. this.Data["json"] = br
  1905. this.ServeJSON()
  1906. }()
  1907. sysUser := this.SysUser
  1908. if sysUser == nil {
  1909. br.Msg = "请登录"
  1910. br.ErrMsg = "请登录,SysUser Is Empty"
  1911. return
  1912. }
  1913. activityId, _ := this.GetInt("ActivityId")
  1914. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1915. if activityInfo == nil {
  1916. br.Msg = "活动不存在"
  1917. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1918. return
  1919. }
  1920. list, err := cygx.GetActivityHelpAskList(activityId)
  1921. respist := new(cygx.ActivityHelpAskListResp)
  1922. if err != nil {
  1923. br.Msg = "获取失败"
  1924. br.ErrMsg = "获取失败,Err:" + err.Error()
  1925. return
  1926. }
  1927. respist.List = list
  1928. br.Ret = 200
  1929. br.Success = true
  1930. br.Msg = "获取成功"
  1931. br.Data = respist
  1932. }
  1933. // @Title 带问详情excel表格下载
  1934. // @Description 带问详情excel表格下载接口
  1935. // @Param ActivityId query int true "活动ID"
  1936. // @Success 200 导出成功
  1937. // @router /activitySignup/askListExport [get]
  1938. func (this *ActivitySignupCoAntroller) AskListExport() {
  1939. br := new(models.BaseResponse).Init()
  1940. defer func() {
  1941. this.Data["json"] = br
  1942. this.ServeJSON()
  1943. }()
  1944. AdminUser := this.SysUser
  1945. if AdminUser == nil {
  1946. br.Msg = "请登录"
  1947. br.ErrMsg = "请登录,SysUser Is Empty"
  1948. return
  1949. }
  1950. activityId, _ := this.GetInt("ActivityId")
  1951. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  1952. if activityInfo == nil {
  1953. br.Msg = "活动不存在"
  1954. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  1955. return
  1956. }
  1957. list, err := cygx.GetActivityHelpAskList(activityId)
  1958. if err != nil {
  1959. br.Msg = "获取失败"
  1960. br.ErrMsg = "获取失败,Err:" + err.Error()
  1961. return
  1962. }
  1963. //创建excel
  1964. dir, err := os.Executable()
  1965. exPath := filepath.Dir(dir)
  1966. downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx"
  1967. xlsxFile := xlsx.NewFile()
  1968. if err != nil {
  1969. br.Msg = "生成文件失败"
  1970. br.ErrMsg = "生成文件失败"
  1971. return
  1972. }
  1973. style := xlsx.NewStyle()
  1974. alignment := xlsx.Alignment{
  1975. Horizontal: "center",
  1976. Vertical: "center",
  1977. WrapText: true,
  1978. }
  1979. style.Alignment = alignment
  1980. style.ApplyAlignment = true
  1981. sheet, err := xlsxFile.AddSheet("名单")
  1982. if err != nil {
  1983. br.Msg = "新增Sheet失败"
  1984. br.ErrMsg = "新增Sheet失败,Err:" + err.Error()
  1985. return
  1986. }
  1987. //标头
  1988. rowTitle := sheet.AddRow()
  1989. cellA := rowTitle.AddCell()
  1990. cellA.Value = "姓名"
  1991. cellB := rowTitle.AddCell()
  1992. cellB.Value = "公司名称"
  1993. cellC := rowTitle.AddCell()
  1994. cellC.Value = "问题"
  1995. cellD := rowTitle.AddCell()
  1996. cellD.Value = "提交时间"
  1997. for _, item := range list {
  1998. row := sheet.AddRow()
  1999. cellA := row.AddCell()
  2000. cellA.Value = item.RealName
  2001. cellB := row.AddCell()
  2002. cellB.Value = item.CompanyName
  2003. cellC := row.AddCell()
  2004. cellC.Value = item.Content
  2005. cellD := row.AddCell()
  2006. cellD.Value = item.CreateTime
  2007. }
  2008. err = xlsxFile.Save(downLoadnFilePath)
  2009. if err != nil {
  2010. br.Msg = "保存文件失败"
  2011. br.ErrMsg = "保存文件失败"
  2012. return
  2013. }
  2014. randStr := time.Now().Format(utils.FormatDateTimeUnSpace)
  2015. downloadFileName := "问题列表" + randStr + ".xlsx"
  2016. this.Ctx.Output.Download(downLoadnFilePath, downloadFileName)
  2017. defer func() {
  2018. os.Remove(downLoadnFilePath)
  2019. }()
  2020. //添加操作日志记录
  2021. br.IsAddLog = true
  2022. br.Success = true
  2023. br.Ret = 200
  2024. br.Msg = "导出成功"
  2025. }
  2026. // @Title 新增报名人员(可择报名方式)
  2027. // @Description 新增报名人员(可择报名方式)接口
  2028. // @Param request body cygx.AddOutboundPersonnelJsonItm true "type json string"
  2029. // @Success 200 操作成功
  2030. // @router /activitySignup/addSignuUserOptType [post]
  2031. func (this *ActivitySignupCoAntroller) AddSignuUserOptType() {
  2032. br := new(models.BaseResponse).Init()
  2033. defer func() {
  2034. this.Data["json"] = br
  2035. this.ServeJSON()
  2036. }()
  2037. AdminUser := this.SysUser
  2038. if AdminUser == nil {
  2039. br.Msg = "请登录"
  2040. br.ErrMsg = "请登录,SysUser Is Empty"
  2041. return
  2042. }
  2043. var req cygx.AddOutboundPersonnelJsonItm
  2044. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2045. if err != nil {
  2046. br.Msg = "参数解析异常!"
  2047. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2048. return
  2049. }
  2050. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2051. if err != nil {
  2052. br.Msg = "添加失败"
  2053. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2054. return
  2055. }
  2056. jsonStr := req.JsonStar
  2057. var config cygx.RequestCommonPolicyConfig
  2058. err = json.Unmarshal([]byte(jsonStr), &config.CommonPolicyconfigs)
  2059. if err != nil {
  2060. br.Msg = "参数解析异常!"
  2061. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2062. return
  2063. }
  2064. var uids string
  2065. for _, v := range config.CommonPolicyconfigs {
  2066. uids += strconv.Itoa(v.Uid) + ","
  2067. }
  2068. uids = strings.TrimRight(uids, ",")
  2069. var items []*cygx.CygxActivitySignup
  2070. activityIds := req.ActivityIds
  2071. uidList := strings.Split(uids, ",")
  2072. activityIdList := strings.Split(activityIds, ",")
  2073. for _, v := range config.CommonPolicyconfigs {
  2074. uid := v.Uid
  2075. wxUser, userErr := models.GetWxUserByUserId(uid)
  2076. if userErr != nil {
  2077. br.Msg = "编辑失败!查询用户信息失败"
  2078. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  2079. return
  2080. }
  2081. for _, vact := range activityIdList {
  2082. activityId, _ := strconv.Atoi(vact)
  2083. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  2084. if err != nil {
  2085. br.Msg = "活动不存在"
  2086. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2087. return
  2088. }
  2089. if adminInfo.RoleTypeCode != "admin" {
  2090. havePower := cygxService.CheckaddSignuUserPower(wxUser.CompanyId, activityId, activityInfo)
  2091. if !havePower {
  2092. br.Msg = "当前活动对该客户不可见,无法报名"
  2093. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  2094. return
  2095. }
  2096. }
  2097. limitPeopleNum, _ := strconv.Atoi(activityInfo.LimitPeopleNum)
  2098. //获取这个活动已经报名的用户数量
  2099. totalSignup, errSignup := cygx.GetActivitySignupCountByActivityId(activityId)
  2100. if errSignup != nil {
  2101. br.Msg = "获取失败"
  2102. br.ErrMsg = "获取失败,Err:" + errSignup.Error()
  2103. return
  2104. }
  2105. //获取这个活动中输入的这些用户的报名数量
  2106. totalThisUser, errThisUser := cygx.GetActivitySignupCountByThisUser(activityId, uids)
  2107. if errThisUser != nil {
  2108. br.Msg = "获取失败"
  2109. br.ErrMsg = "获取失败,Err:" + errThisUser.Error()
  2110. return
  2111. }
  2112. if limitPeopleNum < totalSignup+len(uidList)-totalThisUser {
  2113. br.Msg = "当前活动报名人数已满"
  2114. br.ErrMsg = "当前活动报名人数已满,活动:" + activityInfo.ActivityName
  2115. return
  2116. }
  2117. total, errtotal := cygx.GetActivitySignupCount(uid, activityId)
  2118. if errtotal != nil {
  2119. br.Msg = "获取失败"
  2120. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  2121. return
  2122. }
  2123. //判断这个用户是否报名了,如果没有报名则写入报名数据
  2124. if total == 0 {
  2125. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  2126. if err != nil {
  2127. br.Msg = "获取失败"
  2128. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  2129. return
  2130. }
  2131. item := new(cygx.CygxActivitySignup)
  2132. item.UserId = infoUser.UserId
  2133. item.RealName = infoUser.RealName
  2134. item.SellerName = infoUser.SellerName
  2135. item.ActivityId = activityId
  2136. item.CreateTime = time.Now()
  2137. item.Mobile = infoUser.Mobile
  2138. item.Email = infoUser.Email
  2139. item.CompanyId = infoUser.CompanyId
  2140. item.CompanyName = infoUser.CompanyName
  2141. //优先绑定用户修改过的外呼手机号
  2142. if infoUser.OutboundMobile != "" {
  2143. item.OutboundMobile = infoUser.OutboundMobile
  2144. if infoUser.OutboundCountryCode == "" {
  2145. item.CountryCode = "86"
  2146. } else {
  2147. item.CountryCode = infoUser.OutboundCountryCode
  2148. }
  2149. } else {
  2150. item.OutboundMobile = infoUser.Mobile
  2151. if infoUser.CountryCode == "" {
  2152. item.CountryCode = "86"
  2153. } else {
  2154. item.CountryCode = infoUser.CountryCode
  2155. }
  2156. }
  2157. signupType, _ := strconv.Atoi(v.Type)
  2158. item.SignupType = signupType
  2159. item.Source = 2
  2160. items = append(items, item)
  2161. }
  2162. }
  2163. }
  2164. err = cygx.AddCygxActivitySignupUser(items)
  2165. if err != nil {
  2166. br.Msg = "操作失败"
  2167. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  2168. return
  2169. }
  2170. //添加操作日志记录
  2171. br.IsAddLog = true
  2172. br.Ret = 200
  2173. br.Success = true
  2174. br.Msg = "操作成功"
  2175. }
  2176. // @Title 活动取消报名
  2177. // @Description 活动取消报名接口
  2178. // @Param request body cygx.CygxSignupId true "type json string"
  2179. // @Success Ret=200
  2180. // @router /activitySignup/cancel [post]
  2181. func (this *ActivitySignupCoAntroller) SignupCancel() {
  2182. br := new(models.BaseResponse).Init()
  2183. defer func() {
  2184. this.Data["json"] = br
  2185. this.ServeJSON()
  2186. }()
  2187. AdminUser := this.SysUser
  2188. if AdminUser == nil {
  2189. br.Msg = "请登录"
  2190. br.ErrMsg = "请登录,SysUser Is Empty"
  2191. return
  2192. }
  2193. var req cygx.CygxSignupId
  2194. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2195. if err != nil {
  2196. br.Msg = "参数解析异常!"
  2197. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2198. return
  2199. }
  2200. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2201. if err != nil {
  2202. br.Msg = "添加失败"
  2203. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2204. return
  2205. }
  2206. signupId := req.SignupId
  2207. cancelClass := req.CancelClass
  2208. detail, err := cygx.GetActivitySignupInfoById(signupId)
  2209. if err != nil {
  2210. br.Msg = "报名信息不存在"
  2211. br.ErrMsg = "报名信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2212. return
  2213. }
  2214. activityInfo, err := cygx.GetAddActivityInfoById(detail.ActivityId)
  2215. if err != nil {
  2216. br.Msg = "操作失败"
  2217. br.ErrMsg = "活动ID错误,不存在activityId:" + strconv.Itoa(detail.ActivityId)
  2218. return
  2219. }
  2220. if cancelClass == 1 {
  2221. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  2222. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  2223. br.Msg = "活动开始前1小时内无法取消外呼,提示:外呼名单已发送专家组,请联系专家组取消"
  2224. return
  2225. }
  2226. }
  2227. activityTypeId := activityInfo.ActivityTypeId
  2228. if adminInfo.RoleTypeCode != "admin" {
  2229. if activityTypeId == 1 || activityTypeId == 2 {
  2230. resultTime := utils.StrTimeToTime(activityInfo.ActivityTime) //时间字符串格式转时间格式
  2231. if time.Now().After(resultTime.Add(-time.Minute * 60)) {
  2232. br.Msg = "报名名单已发送至办会平台,请联系相关人员处理。"
  2233. br.ErrMsg = fmt.Sprint("UserId:", detail.UserId, "ActivityId:", detail.ActivityId)
  2234. return
  2235. }
  2236. }
  2237. //取消报名截止时间校验
  2238. //if activityInfo.CancelDeadline != utils.EmptyDateTimeStr {
  2239. // cancelDeadline := utils.StrTimeToTime(activityInfo.CancelDeadline) //时间字符串格式转时间格式
  2240. // if time.Now().After(cancelDeadline) {
  2241. // br.Msg = "当前时间晚于取消报名截止时间,已无法取消报名。"
  2242. // br.ErrMsg = fmt.Sprint("UserId:", detail.UserId, "ActivityId:", detail.ActivityId)
  2243. // return
  2244. // }
  2245. //}
  2246. }
  2247. _, err = cygx.CancelActivitySignup(detail)
  2248. if err != nil {
  2249. br.Msg = "操作失败"
  2250. br.ErrMsg = "操作失败,Err:" + err.Error()
  2251. return
  2252. }
  2253. go cygxService.YanXuanActivityPointsBillSignupCancel(detail.ActivityId, detail.UserId, adminInfo.AdminId)
  2254. //添加操作日志记录
  2255. br.IsAddLog = true
  2256. br.Ret = 200
  2257. br.Success = true
  2258. br.Msg = "操作成功"
  2259. }
  2260. // @Title 预约纪要详情
  2261. // @Description 预约纪要详情列表接口
  2262. // @Param ActivityId query int true "活动ID"
  2263. // @Success 200 {object} cygx.GetAppointmentListRep
  2264. // @router /activitySignup/appointment/summaryList [get]
  2265. func (this *ActivitySignupCoAntroller) SummaryList() {
  2266. br := new(models.BaseResponse).Init()
  2267. defer func() {
  2268. this.Data["json"] = br
  2269. this.ServeJSON()
  2270. }()
  2271. sysUser := this.SysUser
  2272. if sysUser == nil {
  2273. br.Msg = "请登录"
  2274. br.ErrMsg = "请登录,SysUser Is Empty"
  2275. return
  2276. }
  2277. activityId, _ := this.GetInt("ActivityId")
  2278. if activityId < 1 {
  2279. br.Msg = "活动不存在"
  2280. return
  2281. }
  2282. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  2283. if activityInfo == nil {
  2284. br.Msg = "活动不存在"
  2285. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2286. return
  2287. }
  2288. var isShowMobile bool
  2289. if activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3 {
  2290. isShowMobile = true
  2291. }
  2292. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  2293. resp := new(cygx.CanDownload)
  2294. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  2295. if errAdmin != nil {
  2296. br.Msg = "获取失败"
  2297. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  2298. return
  2299. }
  2300. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  2301. resp.IsCanDownload = true
  2302. }
  2303. memberType := "Admin"
  2304. sqlStr := ""
  2305. totalStr := sqlStr
  2306. if isShowMobile {
  2307. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  2308. if adminInfo.RoleTypeCode == "rai_group" {
  2309. //组长查看本组所有组员
  2310. memberType = "GroupLeader"
  2311. 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) + ` ) )) `
  2312. } else {
  2313. //组员查看自己
  2314. memberType = "Sale"
  2315. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  2316. }
  2317. }
  2318. }
  2319. list, err := cygx.GetCygxAppointmentSummaryList(activityId, sqlStr)
  2320. if err != nil {
  2321. br.Msg = "获取失败"
  2322. br.ErrMsg = "获取失败,Err:" + err.Error()
  2323. return
  2324. }
  2325. total, errtotal := cygx.GetCygxAppointmentSummaryCount(activityId, totalStr)
  2326. if errtotal != nil {
  2327. br.Msg = "获取失败"
  2328. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  2329. return
  2330. }
  2331. myTotal, errmyTotal := cygx.GetCygxAppointmentSummaryCount(activityId, sqlStr)
  2332. if errmyTotal != nil {
  2333. br.Msg = "获取失败"
  2334. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  2335. return
  2336. }
  2337. for k, v := range list {
  2338. list[k].SellerName = v.PsellerName
  2339. if !isShowMobile {
  2340. list[k].Mobile = ""
  2341. }
  2342. }
  2343. respList := new(cygx.GetAppointmentListRep)
  2344. respList.List = list
  2345. respList.Total = total
  2346. respList.MyTotal = myTotal
  2347. respList.ActivityId = activityId
  2348. respList.IsLimitPeople = activityInfo.IsLimitPeople
  2349. respList.MemberType = memberType
  2350. activityTypeId := activityInfo.ActivityTypeId
  2351. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  2352. if activityTypeId == 1 || activityTypeId == 2 {
  2353. respList.ExcelType = "AppointmentCall"
  2354. } else if activityTypeId == 5 || activityTypeId == 6 {
  2355. respList.ExcelType = "ExpertSalon"
  2356. } else if activityTypeId == 3 {
  2357. respList.ExcelType = "Teleconference"
  2358. } else if activityTypeId == 4 {
  2359. respList.ExcelType = "OfflineResearch"
  2360. }
  2361. if isShowMobile {
  2362. respList.ActivityType = 1
  2363. }
  2364. br.Ret = 200
  2365. br.Success = true
  2366. br.Msg = "获取成功"
  2367. br.Data = respList
  2368. }
  2369. // @Title 新增预约纪要人员
  2370. // @Description 新增预约纪要人员接口
  2371. // @Param request body cygx.AddOutboundPersonnelItm true "type json string"
  2372. // @Success 200 操作成功
  2373. // @router /activitySignup/appointment/addSummaryUser [post]
  2374. func (this *ActivitySignupCoAntroller) AddSummaryUser() {
  2375. br := new(models.BaseResponse).Init()
  2376. defer func() {
  2377. this.Data["json"] = br
  2378. this.ServeJSON()
  2379. }()
  2380. AdminUser := this.SysUser
  2381. if AdminUser == nil {
  2382. br.Msg = "请登录"
  2383. br.ErrMsg = "请登录,SysUser Is Empty"
  2384. return
  2385. }
  2386. var req cygx.AddOutboundPersonnelItm
  2387. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2388. if err != nil {
  2389. br.Msg = "参数解析异常!"
  2390. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2391. return
  2392. }
  2393. adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2394. if err != nil {
  2395. br.Msg = "添加失败"
  2396. br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2397. return
  2398. }
  2399. var items []*cygx.CygxActivityAppointment
  2400. uids := req.UserIds
  2401. activityIds := req.ActivityIds
  2402. uidList := strings.Split(uids, ",")
  2403. activityIdList := strings.Split(activityIds, ",")
  2404. for _, v := range uidList {
  2405. uid, err := strconv.Atoi(v)
  2406. if err != nil {
  2407. br.Msg = "操作失败"
  2408. br.ErrMsg = "查询用户信息失败,Err:" + err.Error()
  2409. return
  2410. }
  2411. wxUser, userErr := models.GetWxUserByUserId(uid)
  2412. if userErr != nil {
  2413. br.Msg = "编辑失败!查询用户信息失败"
  2414. br.ErrMsg = "查询用户信息失败,Err:" + userErr.Error() + "用户UID:" + strconv.Itoa(uid) + "不存在"
  2415. return
  2416. }
  2417. for _, vact := range activityIdList {
  2418. activityId, _ := strconv.Atoi(vact)
  2419. activityInfo, err := cygx.GetAddActivityInfoById(activityId)
  2420. if err != nil {
  2421. br.Msg = "活动不存在"
  2422. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2423. return
  2424. }
  2425. if adminInfo.RoleTypeCode != "admin" {
  2426. //havePower := cygxService.CheckaddSignuUserPower(wxUser.CompanyId, activityId, activityInfo)
  2427. havePower, err := cygxService.GetActivityDetailUserPower(wxUser, AdminUser, activityInfo)
  2428. if err != nil {
  2429. br.Msg = "用户权限校验失败!"
  2430. br.ErrMsg = "GetActivityDetailUserPower,Err:" + err.Error() + fmt.Sprint("UserId", wxUser.UserId, "ActivityId:", activityInfo.ActivityId)
  2431. return
  2432. }
  2433. if !havePower {
  2434. br.Msg = "当前活动对该客户不可见,无法报名"
  2435. br.ErrMsg = "活动ID:" + strconv.Itoa(activityId) + "活动名称:" + activityInfo.ActivityName + "用户ID:" + strconv.Itoa(int(wxUser.UserId))
  2436. return
  2437. }
  2438. }
  2439. //isHideAppointment := cygxService.IsShowAppointmentByadminSet(activityInfo.IsCanAppointmentMinutes)
  2440. if activityInfo.IsCanAppointmentMinutes == 0 {
  2441. br.Msg = "当前活动无法新增预约纪要" + activityInfo.ActivityName
  2442. return
  2443. }
  2444. //if cygxService.CheckActivityAddAppointment(activityInfo) {
  2445. // br.Msg = "当前活动无法新增预约纪要" + activityInfo.ActivityName
  2446. // return
  2447. //}
  2448. total, errtotal := cygx.GetUserCygxActivityAppointmentCount(uid, activityId)
  2449. if errtotal != nil {
  2450. br.Msg = "获取失败"
  2451. br.ErrMsg = "获取失败,Err:" + errtotal.Error()
  2452. return
  2453. }
  2454. //判断这个用户是否报名了,如果没有报名则写入报名数据
  2455. if total == 0 {
  2456. infoUser, err := cygx.GetUserAndCompanyNameList(uid)
  2457. if err != nil {
  2458. br.Msg = "获取失败"
  2459. br.ErrMsg = "获取数据失败,Err:" + err.Error()
  2460. return
  2461. }
  2462. item := new(cygx.CygxActivityAppointment)
  2463. item.UserId = infoUser.UserId
  2464. item.RealName = infoUser.RealName
  2465. item.SellerName = infoUser.SellerName
  2466. item.ActivityId = activityId
  2467. item.CreateTime = time.Now()
  2468. item.Mobile = infoUser.Mobile
  2469. item.Email = infoUser.Email
  2470. item.CompanyId = infoUser.CompanyId
  2471. item.CompanyName = infoUser.CompanyName
  2472. item.Source = 2
  2473. items = append(items, item)
  2474. }
  2475. }
  2476. }
  2477. err = cygx.AddCygxActivityAppointmentUser(items)
  2478. if err != nil {
  2479. br.Msg = "操作失败"
  2480. br.ErrMsg = "新增用户失败,Err:" + err.Error()
  2481. return
  2482. }
  2483. //添加操作日志记录
  2484. br.IsAddLog = true
  2485. br.Ret = 200
  2486. br.Success = true
  2487. br.Msg = "操作成功"
  2488. }
  2489. // @Title 取消纪要纪要预约
  2490. // @Description 取消纪要纪要预约接口
  2491. // @Param request body cygx.CygxSignupId true "type json string"
  2492. // @Success Ret=200
  2493. // @router /activitySignup/appointment/cancel [post]
  2494. func (this *ActivitySignupCoAntroller) SummaryCancel() {
  2495. br := new(models.BaseResponse).Init()
  2496. defer func() {
  2497. this.Data["json"] = br
  2498. this.ServeJSON()
  2499. }()
  2500. AdminUser := this.SysUser
  2501. if AdminUser == nil {
  2502. br.Msg = "请登录"
  2503. br.ErrMsg = "请登录,SysUser Is Empty"
  2504. return
  2505. }
  2506. var req cygx.CygxSignupId
  2507. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2508. if err != nil {
  2509. br.Msg = "参数解析异常!"
  2510. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2511. return
  2512. }
  2513. signupId := req.SignupId
  2514. detail, err := cygx.GetCygxAppointmentSummaryInfoById(signupId)
  2515. if err != nil {
  2516. br.Msg = "预约信息不存在"
  2517. br.ErrMsg = "预约信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2518. return
  2519. }
  2520. _, err = cygx.CancelcygxActivityAppointment(detail)
  2521. if err != nil {
  2522. br.Msg = "操作失败"
  2523. br.ErrMsg = "操作失败,Err:" + err.Error()
  2524. return
  2525. }
  2526. //添加操作日志记录
  2527. br.IsAddLog = true
  2528. br.Ret = 200
  2529. br.Success = true
  2530. br.Msg = "操作成功"
  2531. }
  2532. // @Title 会议提醒人数详情
  2533. // @Description 会议提醒人数详情列表接口
  2534. // @Param ActivityId query int true "活动ID"
  2535. // @Success 200 {object} cygx.GetAppointmentListRep
  2536. // @router /activitySignup/reminder/list [get]
  2537. func (this *ActivitySignupCoAntroller) ReminderList() {
  2538. br := new(models.BaseResponse).Init()
  2539. defer func() {
  2540. this.Data["json"] = br
  2541. this.ServeJSON()
  2542. }()
  2543. sysUser := this.SysUser
  2544. if sysUser == nil {
  2545. br.Msg = "请登录"
  2546. br.ErrMsg = "请登录,SysUser Is Empty"
  2547. return
  2548. }
  2549. activityId, _ := this.GetInt("ActivityId")
  2550. if activityId < 1 {
  2551. br.Msg = "活动不存在"
  2552. return
  2553. }
  2554. activityInfo, _ := cygx.GetAddActivityInfoById(activityId)
  2555. if activityInfo == nil {
  2556. br.Msg = "活动不存在"
  2557. br.ErrMsg = "活动ID错误,Err:activityId:" + strconv.Itoa(activityId)
  2558. return
  2559. }
  2560. //超级管理员和权益管理员、权益研究员可以下载所有客户,销售组长能下载本组客户,销售只能下载本人名下客户
  2561. resp := new(cygx.CanDownload)
  2562. adminInfo, errAdmin := system.GetSysUserById(sysUser.AdminId)
  2563. if errAdmin != nil {
  2564. br.Msg = "获取失败"
  2565. br.ErrMsg = "获取失败,Err:" + errAdmin.Error()
  2566. return
  2567. }
  2568. if adminInfo.Role == "admin" || adminInfo.Role == "researcher" {
  2569. resp.IsCanDownload = true
  2570. }
  2571. memberType := "Admin"
  2572. sqlStr := ""
  2573. totalStr := sqlStr
  2574. if resp.IsCanDownload == false && (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 3) {
  2575. if adminInfo.RoleTypeCode == "rai_group" {
  2576. //组长查看本组所有组员
  2577. memberType = "GroupLeader"
  2578. 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) + ` ) )) `
  2579. } else {
  2580. //组员查看自己
  2581. memberType = "Sale"
  2582. sqlStr += ` AND s.company_id IN (SELECT company_id FROM user_seller_relation WHERE seller_id = ` + strconv.Itoa(sysUser.AdminId) + `) `
  2583. }
  2584. }
  2585. list, err := cygx.GetCygxActivityMeetingReminderList(activityId, sqlStr)
  2586. if err != nil {
  2587. br.Msg = "获取失败"
  2588. br.ErrMsg = "获取失败,Err:" + err.Error()
  2589. return
  2590. }
  2591. total, errtotal := cygx.GetCygxActivityMeetingReminderCount(activityId, totalStr)
  2592. if errtotal != nil {
  2593. br.Msg = "获取失败"
  2594. br.ErrMsg = "客户总数获取失败,Err:" + errtotal.Error()
  2595. return
  2596. }
  2597. myTotal, errmyTotal := cygx.GetCygxActivityMeetingReminderCount(activityId, sqlStr)
  2598. if errmyTotal != nil {
  2599. br.Msg = "获取失败"
  2600. br.ErrMsg = "我的客户总数获取失败,Err:" + errmyTotal.Error()
  2601. return
  2602. }
  2603. if len(list) > 0 {
  2604. for k, v := range list {
  2605. list[k].SellerName = v.PsellerName
  2606. }
  2607. } else {
  2608. list = make([]*cygx.CygxAppointmentList, 0)
  2609. }
  2610. respList := new(cygx.GetAppointmentListRep)
  2611. respList.List = list
  2612. respList.Total = total
  2613. respList.MyTotal = myTotal
  2614. respList.ActivityId = activityId
  2615. respList.IsLimitPeople = activityInfo.IsLimitPeople
  2616. respList.MemberType = memberType
  2617. activityTypeId := activityInfo.ActivityTypeId
  2618. //ExcelType string `description:"EXcel下载类型 AppointmentCall:预约外呼、ExpertSalon:专家沙龙报名、Teleconference:公司调研电话会、OfflineResearch:公司线下调研 "`
  2619. if activityTypeId == 1 || activityTypeId == 2 {
  2620. respList.ExcelType = "AppointmentCall"
  2621. } else if activityTypeId == 5 || activityTypeId == 6 {
  2622. respList.ExcelType = "ExpertSalon"
  2623. } else if activityTypeId == 3 {
  2624. respList.ExcelType = "Teleconference"
  2625. } else if activityTypeId == 4 {
  2626. respList.ExcelType = "OfflineResearch"
  2627. }
  2628. br.Ret = 200
  2629. br.Success = true
  2630. br.Msg = "获取成功"
  2631. br.Data = respList
  2632. }
  2633. // @Title 取消会议提醒
  2634. // @Description 取消会议提醒接口
  2635. // @Param request body cygx.CygxSignupId true "type json string"
  2636. // @Success Ret=200
  2637. // @router /activitySignup/reminder/cancel [post]
  2638. func (this *ActivitySignupCoAntroller) ReminderCancel() {
  2639. br := new(models.BaseResponse).Init()
  2640. defer func() {
  2641. this.Data["json"] = br
  2642. this.ServeJSON()
  2643. }()
  2644. AdminUser := this.SysUser
  2645. if AdminUser == nil {
  2646. br.Msg = "请登录"
  2647. br.ErrMsg = "请登录,SysUser Is Empty"
  2648. return
  2649. }
  2650. var req cygx.CygxSignupId
  2651. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2652. if err != nil {
  2653. br.Msg = "参数解析异常!"
  2654. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2655. return
  2656. }
  2657. signupId := req.SignupId
  2658. detail, err := cygx.GetCygxActivityMeetingReminderInfoById(signupId)
  2659. if err != nil {
  2660. br.Msg = "预约信息不存在"
  2661. br.ErrMsg = "预约信息ID错误,Err:" + err.Error() + "id:" + strconv.Itoa(signupId)
  2662. return
  2663. }
  2664. _, err = cygx.CancelActivityMeetingReminder(detail)
  2665. if err != nil {
  2666. br.Msg = "操作失败"
  2667. br.ErrMsg = "操作失败,Err:" + err.Error()
  2668. return
  2669. }
  2670. //添加操作日志记录
  2671. br.IsAddLog = true
  2672. br.Ret = 200
  2673. br.Success = true
  2674. br.Msg = "操作成功"
  2675. }
  2676. // @Title 发送模版消息
  2677. // @Description 发送模版消息接口
  2678. // @Param request body cygx.AddOutboundPersonnelItm true "type json string"
  2679. // @Success 200 操作成功
  2680. // @router /activitySignup/tempMsg [post]
  2681. func (this *ActivitySignupCoAntroller) TempMsg() {
  2682. br := new(models.BaseResponse).Init()
  2683. defer func() {
  2684. this.Data["json"] = br
  2685. this.ServeJSON()
  2686. }()
  2687. AdminUser := this.SysUser
  2688. if AdminUser == nil {
  2689. br.Msg = "请登录"
  2690. br.ErrMsg = "请登录,SysUser Is Empty"
  2691. return
  2692. }
  2693. var req cygx.ActivitySignupTempMsgReq
  2694. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2695. if err != nil {
  2696. br.Msg = "参数解析异常!"
  2697. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2698. return
  2699. }
  2700. //adminInfo, err := system.GetSysUserById(AdminUser.AdminId)
  2701. //if err != nil {
  2702. // br.Msg = "添加失败"
  2703. // br.ErrMsg = "获取管理员信息失败,Err:" + err.Error()
  2704. // return
  2705. //}
  2706. idSlice := strings.Split(req.ActivityIds, ",")
  2707. for _, sId := range idSlice {
  2708. id, e := strconv.Atoi(sId)
  2709. if e != nil {
  2710. br.Msg = "活动Id参数异常"
  2711. br.ErrMsg = "参数解析异常, Err:" + e.Error()
  2712. return
  2713. }
  2714. var openIdList []*models.OpenIdList
  2715. idMap := make(map[string]string, 0)
  2716. if strings.Contains(req.SendGroup, "1") {
  2717. list, err := models.GetCygxUserIndustryFllowOpneidByActivityIds(id)
  2718. if err != nil {
  2719. br.Msg = "查询openId失败"
  2720. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2721. return
  2722. }
  2723. for _, idList := range list {
  2724. openIdList = append(openIdList, idList)
  2725. idMap[idList.OpenId] = idList.OpenId
  2726. }
  2727. }
  2728. if strings.Contains(req.SendGroup, "2") {
  2729. list, err := models.GetCygxForeverUserIndustryFllowOpneidByActivityIds(id)
  2730. if err != nil {
  2731. br.Msg = "查询openId失败"
  2732. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2733. return
  2734. }
  2735. for _, idList := range openIdList {
  2736. idMap[idList.OpenId] = idList.OpenId
  2737. }
  2738. for _, idList := range list {
  2739. if _, ok := idMap[idList.OpenId]; !ok {
  2740. openIdList = append(openIdList, idList)
  2741. idMap[idList.OpenId] = idList.OpenId
  2742. }
  2743. }
  2744. }
  2745. if strings.Contains(req.SendGroup, "3") {
  2746. list, err := cygxService.GetCygxBigTypeUserIndustryFllowOpneidByActivityIds(id)
  2747. if err != nil {
  2748. br.Msg = "查询openId失败"
  2749. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2750. return
  2751. }
  2752. for _, idList := range openIdList {
  2753. idMap[idList.OpenId] = idList.OpenId
  2754. }
  2755. for _, idList := range list {
  2756. if _, ok := idMap[idList.OpenId]; !ok {
  2757. openIdList = append(openIdList, idList)
  2758. idMap[idList.OpenId] = idList.OpenId
  2759. }
  2760. }
  2761. }
  2762. if strings.Contains(req.SendGroup, "4") {
  2763. list, err := cygxService.GetCygxIndustryPackageUserIndustryFllowOpneidByActivityIds(id)
  2764. if err != nil {
  2765. br.Msg = "查询openId失败"
  2766. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2767. return
  2768. }
  2769. for _, idList := range openIdList {
  2770. idMap[idList.OpenId] = idList.OpenId
  2771. }
  2772. for _, idList := range list {
  2773. if _, ok := idMap[idList.OpenId]; !ok {
  2774. openIdList = append(openIdList, idList)
  2775. idMap[idList.OpenId] = idList.OpenId
  2776. }
  2777. }
  2778. }
  2779. if strings.Contains(req.SendGroup, "5") {
  2780. list, err := cygxService.GetCygxOtherIndustryPackageUserIndustryFllowOpneidByActivityIds(id)
  2781. if err != nil {
  2782. br.Msg = "查询openId失败"
  2783. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2784. return
  2785. }
  2786. for _, idList := range openIdList {
  2787. idMap[idList.OpenId] = idList.OpenId
  2788. }
  2789. for _, idList := range list {
  2790. if _, ok := idMap[idList.OpenId]; !ok {
  2791. openIdList = append(openIdList, idList)
  2792. idMap[idList.OpenId] = idList.OpenId
  2793. }
  2794. }
  2795. }
  2796. if strings.Contains(req.SendGroup, "6") {
  2797. list, err := models.GetCygxTryOutUserIndustryFllowOpneidByActivityIds(id)
  2798. if err != nil {
  2799. br.Msg = "查询openId失败"
  2800. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2801. return
  2802. }
  2803. for _, idList := range openIdList {
  2804. idMap[idList.OpenId] = idList.OpenId
  2805. }
  2806. for _, idList := range list {
  2807. if _, ok := idMap[idList.OpenId]; !ok {
  2808. openIdList = append(openIdList, idList)
  2809. idMap[idList.OpenId] = idList.OpenId
  2810. }
  2811. }
  2812. }
  2813. if strings.Contains(req.SendGroup, "7") {
  2814. list, err := cygxService.GetCygxInteractiveUserOpneidByActivityIds(id)
  2815. if err != nil {
  2816. br.Msg = "查询openId失败"
  2817. br.ErrMsg = "查询openId失败,Err:" + err.Error()
  2818. return
  2819. }
  2820. for _, idList := range openIdList {
  2821. idMap[idList.OpenId] = idList.OpenId
  2822. }
  2823. for _, idList := range list {
  2824. if _, ok := idMap[idList.OpenId]; !ok {
  2825. openIdList = append(openIdList, idList)
  2826. idMap[idList.OpenId] = idList.OpenId
  2827. }
  2828. }
  2829. }
  2830. if len(openIdList) > 0 {
  2831. openIdArr := make([]string, len(openIdList))
  2832. for i, v := range openIdList {
  2833. openIdArr[i] = v.OpenId
  2834. }
  2835. sendInfo := new(services.SendWxTemplate)
  2836. //sendInfo.First = req.FirstText
  2837. sendInfo.Keyword1 = req.ActivityName
  2838. sendInfo.Keyword2 = req.Content
  2839. //sendInfo.Keyword3 = meetingTime
  2840. sendInfo.Remark = "点击查看活动详情"
  2841. sendInfo.TemplateId = utils.WxMsgTemplateIdActivityChangeApplyXzs
  2842. sendInfo.RedirectUrl = utils.WX_MSG_PATH_ACTIVITY_DETAIL + strconv.Itoa(id)
  2843. sendInfo.RedirectTarget = 3
  2844. sendInfo.Resource = strconv.Itoa(id)
  2845. sendInfo.SendType = utils.TEMPLATE_MSG_CYGX_ACTIVITY_CUSTOMIZE
  2846. sendInfo.OpenIdArr = openIdArr
  2847. e = services.SendTemplateMsg(sendInfo)
  2848. if e != nil {
  2849. br.Msg = "推送模板消息失败!"
  2850. br.ErrMsg = "参数解析失败,Err:" + e.Error()
  2851. return
  2852. }
  2853. }
  2854. }
  2855. br.Ret = 200
  2856. br.Success = true
  2857. br.Msg = "发送成功"
  2858. }
  2859. // @Title 模版消息发送客户类型列表
  2860. // @Description 模版消息发送客户类型列表接口
  2861. // @Success Ret=200
  2862. // @router /activitySignup/tempMsg/sendGroupList [get]
  2863. func (this *ActivitySignupCoAntroller) SendGroupList() {
  2864. br := new(models.BaseResponse).Init()
  2865. defer func() {
  2866. this.Data["json"] = br
  2867. this.ServeJSON()
  2868. }()
  2869. AdminUser := this.SysUser
  2870. if AdminUser == nil {
  2871. br.Msg = "请登录"
  2872. br.ErrMsg = "请登录,SysUser Is Empty"
  2873. return
  2874. }
  2875. list := make([]cygx.SendGroup, 0)
  2876. list = append(list, cygx.SendGroup{
  2877. Id: 1,
  2878. Name: "全部客户",
  2879. })
  2880. list = append(list, cygx.SendGroup{
  2881. Id: 2,
  2882. Name: "永续客户",
  2883. })
  2884. list = append(list, cygx.SendGroup{
  2885. Id: 3,
  2886. Name: "大套餐客户",
  2887. })
  2888. list = append(list, cygx.SendGroup{
  2889. Id: 4,
  2890. Name: "行业套餐客户",
  2891. })
  2892. list = append(list, cygx.SendGroup{
  2893. Id: 5,
  2894. Name: "其他行业正式客户",
  2895. })
  2896. list = append(list, cygx.SendGroup{
  2897. Id: 6,
  2898. Name: "试用客户",
  2899. })
  2900. list = append(list, cygx.SendGroup{
  2901. Id: 7,
  2902. Name: "已参与互动的客户",
  2903. })
  2904. br.Ret = 200
  2905. br.Success = true
  2906. br.Data = list
  2907. }