eta_trial.go 54 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/mozillazg/go-pinyin"
  6. "github.com/rdlucklib/rdluck_tools/paging"
  7. "hongze/hz_crm_api/models"
  8. "hongze/hz_crm_api/models/company"
  9. "hongze/hz_crm_api/models/eta_trial"
  10. "hongze/hz_crm_api/models/system"
  11. "hongze/hz_crm_api/services"
  12. "hongze/hz_crm_api/utils"
  13. "sort"
  14. "strconv"
  15. "strings"
  16. "time"
  17. )
  18. type ETATrialController struct {
  19. BaseAuthController
  20. }
  21. // @Title 获取所有ETA试用客户列表
  22. // @Description 获取所有ETA试用客户列表 接口
  23. // @Param PageSize query int true "每页数据条数"
  24. // @Param CurrentIndex query int true "当前页页码,从1开始"
  25. // @Param KeyWord query string true "搜索关键词"
  26. // @Param IsOnlyMe query bool false "是否只看我的"
  27. // @Param SortParam query string false "排序字段参数,用来排序的字段, 枚举值:'Expiration':账号到期时长 、 'ModifyTime':账号更新时间 、 'LastLoginTime':最近一次登陆时间 、`ActiveTime:累计活跃时长` 、`IndexNum:累计添加指标` 、`ChartNum:累计添加图表`、`LoginNum:累计登录次数`"
  28. // @Param SortType query string true "如何排序,是正序还是倒序,枚举值:`asc 正序`,`desc 倒叙`"
  29. // @Success 200 {object} models.ETATrialListRespList
  30. // @router /list [get]
  31. func (this *ETATrialController) List() {
  32. br := new(models.BaseResponse).Init()
  33. defer func() {
  34. this.Data["json"] = br
  35. this.ServeJSON()
  36. }()
  37. sysUser := this.SysUser
  38. if sysUser == nil {
  39. br.Msg = "请登录"
  40. br.ErrMsg = "请登录,SysUser Is Empty"
  41. br.Ret = 408
  42. return
  43. }
  44. isOnlyMe, _ := this.GetBool("IsOnlyMe")
  45. pageSize, _ := this.GetInt("PageSize")
  46. currentIndex, _ := this.GetInt("CurrentIndex")
  47. keyWord := this.GetString("KeyWord")
  48. keyWord = strings.Trim(keyWord, " ")
  49. keyWord = strings.Replace(keyWord, "'", "", -1)
  50. //排序参数
  51. sortParam := this.GetString("SortParam")
  52. sortType := this.GetString("SortType")
  53. var total int
  54. page := paging.GetPaging(currentIndex, pageSize, total)
  55. var startSize int
  56. if pageSize <= 0 {
  57. pageSize = utils.PageSize20
  58. }
  59. if currentIndex <= 0 {
  60. currentIndex = 1
  61. }
  62. startSize = paging.StartIndex(currentIndex, pageSize)
  63. var condition string
  64. var pars []interface{}
  65. if isOnlyMe {
  66. condition += ` AND seller_id = ? `
  67. pars = append(pars, sysUser.AdminId)
  68. }
  69. if keyWord != "" {
  70. condition += ` AND (user_name LIKE '%` + keyWord + `%' OR company_name LIKE '%` + keyWord + `%' ) `
  71. }
  72. total, err := eta_trial.GetETATrialListCount(condition, pars)
  73. if err != nil {
  74. br.Msg = "获取失败"
  75. br.ErrMsg = "获取数据总数失败,Err:" + err.Error()
  76. return
  77. }
  78. sortStr := ``
  79. if sortParam != "" && sortType != "" {
  80. if sortParam == "Expiration" {
  81. if sortType == "asc" {
  82. sortStr = "ORDER BY modify_time ASC "
  83. } else {
  84. sortStr = "ORDER BY modify_time DESC "
  85. }
  86. } else if sortParam == "ModifyTime" {
  87. if sortType == "asc" {
  88. sortStr = "ORDER BY modify_time ASC "
  89. } else {
  90. sortStr = "ORDER BY modify_time DESC "
  91. }
  92. } else if sortParam == "LastLoginTime" {
  93. if sortType == "asc" {
  94. sortStr = "ORDER BY last_login_time ASC "
  95. } else {
  96. sortStr = "ORDER BY last_login_time DESC "
  97. }
  98. } else if sortParam == "ActiveTime" {
  99. if sortType == "asc" {
  100. sortStr = "ORDER BY active_time ASC"
  101. } else {
  102. sortStr = "ORDER BY active_time DESC"
  103. }
  104. } else if sortParam == "IndexNum" {
  105. if sortType == "asc" {
  106. sortStr = "ORDER BY index_num ASC"
  107. } else {
  108. sortStr = "ORDER BY index_num DESC"
  109. }
  110. } else if sortParam == "ChartNum" {
  111. if sortType == "asc" {
  112. sortStr = "ORDER BY chart_num ASC"
  113. } else {
  114. sortStr = "ORDER BY chart_num DESC"
  115. }
  116. } else if sortParam == "LoginNum" {
  117. if sortType == "asc" {
  118. sortStr = "ORDER BY login_num ASC"
  119. } else {
  120. sortStr = "ORDER BY login_num DESC"
  121. }
  122. } else if sortParam == "LastLoginDuration" {
  123. if sortType == "asc" {
  124. sortStr = "ORDER BY last_login_duration ASC"
  125. } else {
  126. sortStr = "ORDER BY last_login_duration DESC"
  127. }
  128. }
  129. } else {
  130. sortStr = "ORDER BY create_time DESC "
  131. }
  132. list, err := eta_trial.GetETATrialList(condition, sortStr, pars, startSize, pageSize)
  133. if err != nil {
  134. br.Msg = "获取权限列表失败"
  135. br.ErrMsg = "获取权限列表失败,Err:" + err.Error()
  136. return
  137. }
  138. mobileSlice := make([]string, 0)
  139. for _, item := range list {
  140. activeTime, _ := strconv.Atoi(item.ActiveTime)
  141. item.ActiveTime = utils.GetDurationFormatBySecond(activeTime)
  142. // 最近一次登录时长
  143. loginDuration, _ := strconv.Atoi(item.LastLoginDuration)
  144. item.LastLoginDuration = utils.GetDurationFormatBySecond(loginDuration)
  145. //到期时间
  146. modifyTime, err := time.Parse(utils.FormatDateTime, item.ModifyTime)
  147. if err != nil {
  148. br.Msg = "时间转化失败"
  149. br.ErrMsg = "时间转化失败,Err:" + err.Error()
  150. return
  151. }
  152. var expired int
  153. expiredTime := modifyTime.AddDate(0, 0, 14).Format(utils.FormatDate)
  154. expired, err = utils.GetDaysBetween2Date(utils.FormatDate, expiredTime, time.Now().Format(utils.FormatDate))
  155. if err != nil {
  156. br.Msg = "时间计算失败"
  157. br.ErrMsg = "时间计算失败,CalculationDate Err:" + err.Error()
  158. return
  159. }
  160. item.Expiration = expired
  161. mobileSlice = append(mobileSlice, "'"+item.Mobile+"'")
  162. }
  163. if len(mobileSlice) > 0 {
  164. mobiles := strings.Join(mobileSlice, ",")
  165. recordList, err := eta_trial.GetEtaTrialRecordParts(mobiles)
  166. if err != nil {
  167. br.Msg = "获取记录失败"
  168. br.ErrMsg = "获取记录失败,GetEtaTrialRecordParts Err:" + err.Error()
  169. return
  170. }
  171. recordMap := make(map[string]string)
  172. for _, v := range recordList {
  173. if _, ok := recordMap[v.Mobile]; !ok {
  174. recordMap[v.Mobile] = v.Part
  175. }
  176. }
  177. for _, item := range list {
  178. item.InterestModule = recordMap[item.Mobile]
  179. }
  180. }
  181. //待审批数量
  182. condition = ` AND approval_status = '待审批' `
  183. pars = []interface{}{}
  184. totalApproval, err := eta_trial.GetETATrialApprovalListCount(condition, pars)
  185. if err != nil {
  186. br.Msg = "获取失败"
  187. br.ErrMsg = "获取数据总数失败,Err:" + err.Error()
  188. return
  189. }
  190. page = paging.GetPaging(currentIndex, pageSize, total)
  191. resp := new(eta_trial.ETATrialListRespList)
  192. resp.List = list
  193. resp.Paging = page
  194. resp.ApprovalNum = totalApproval
  195. br.Ret = 200
  196. br.Success = true
  197. br.Msg = "获取成功"
  198. br.Data = resp
  199. return
  200. }
  201. // @Title 新增用户
  202. // @Description 新增用户 接口
  203. // @Success 200 {object} models.ETATrialAddReq
  204. // @router /add [post]
  205. func (this *ETATrialController) Add() {
  206. br := new(models.BaseResponse).Init()
  207. defer func() {
  208. this.Data["json"] = br
  209. this.ServeJSON()
  210. }()
  211. sysUser := this.SysUser
  212. if sysUser == nil {
  213. br.Msg = "请登录"
  214. br.ErrMsg = "请登录,SysUser Is Empty"
  215. br.Ret = 408
  216. return
  217. }
  218. var req eta_trial.ETATrialAddReq
  219. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  220. if err != nil {
  221. br.Msg = "参数解析异常!"
  222. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  223. return
  224. }
  225. resp := new(eta_trial.ETATrialListResp)
  226. //提交审批
  227. approvalIds := make([]int, 0)
  228. for _, v := range req.List {
  229. if v.CompanyName == "" {
  230. br.Msg = "请填写公司名称"
  231. return
  232. }
  233. if v.UserName == "" {
  234. br.Msg = "请填写客户名称"
  235. return
  236. }
  237. if v.Position == "" {
  238. br.Msg = "职务不可为空"
  239. return
  240. }
  241. if v.Mobile == "" {
  242. br.Msg = "手机号不可为空"
  243. return
  244. }
  245. //检查是否为禁用客户
  246. item, e := eta_trial.GetETATrialByMobile(v.Mobile)
  247. if e != nil && e.Error() != utils.ErrNoRow() {
  248. err = e
  249. }
  250. if item != nil {
  251. if item.Enabled == 0 {
  252. //放入被禁用客户列表中
  253. respItem := eta_trial.ETATrialAddRespItem{
  254. UserName: v.UserName,
  255. CompanyName: v.CompanyName,
  256. Position: v.Position,
  257. Mobile: v.Mobile,
  258. Seller: item.Seller,
  259. }
  260. resp.BannedList = append(resp.BannedList, &respItem)
  261. continue
  262. } else {
  263. //客户已在正常使用中
  264. //放入已提交申请列表中
  265. respItem := eta_trial.ETATrialAddRespItem{
  266. UserName: v.UserName,
  267. CompanyName: v.CompanyName,
  268. Position: v.Position,
  269. Mobile: v.Mobile,
  270. Seller: item.Seller,
  271. }
  272. resp.RepeatList = append(resp.RepeatList, &respItem)
  273. continue
  274. }
  275. }
  276. seller, e := system.GetSysAdminById(sysUser.AdminId)
  277. if e != nil {
  278. err = e
  279. return
  280. }
  281. //检查是否历史已提交
  282. approval, e := eta_trial.GetETATrialApprovalByMobile(v.Mobile)
  283. if e != nil && e.Error() != utils.ErrNoRow() {
  284. err = e
  285. }
  286. if approval != nil && approval.ApprovalStatus == "待审批" {
  287. //处于待审批状态
  288. //放入已提交申请列表中
  289. respItem := eta_trial.ETATrialAddRespItem{
  290. UserName: v.UserName,
  291. CompanyName: v.CompanyName,
  292. Position: v.Position,
  293. Mobile: v.Mobile,
  294. Seller: approval.Seller,
  295. }
  296. resp.RepeatList = append(resp.RepeatList, &respItem)
  297. continue
  298. }
  299. //检查是否公司内部人员
  300. mobileCount, err := eta_trial.GetSysAdminCountByMobile(v.Mobile, 0)
  301. if err != nil {
  302. br.Msg = "判断手机号是否存在失败"
  303. br.ErrMsg = "判断手机号是否存在失败,Err:" + err.Error()
  304. return
  305. }
  306. if mobileCount > 0 {
  307. //放入内部人员列表中
  308. respItem := eta_trial.ETATrialAddRespItem{
  309. UserName: v.UserName,
  310. CompanyName: v.CompanyName,
  311. Position: v.Position,
  312. Mobile: v.Mobile,
  313. Seller: "",
  314. }
  315. resp.InternalList = append(resp.InternalList, &respItem)
  316. continue
  317. }
  318. var approvalId int64
  319. if approval != nil && (approval.ApprovalStatus == "驳回" || approval.ApprovalStatus == "已撤回") && v.Mobile == approval.Mobile {
  320. //若是被驳回后重新申请且手机号相同的,更新审批记录
  321. e = eta_trial.ResubmitTrialNoReasons(v.UserName, v.CompanyName, v.Position, approval.ApprovalId)
  322. if e != nil {
  323. err = e
  324. return
  325. }
  326. approvalId = int64(approval.ApprovalId)
  327. } else {
  328. //加入审批列表
  329. approvalItem := eta_trial.EtaTrialApproval{
  330. UserName: v.UserName,
  331. CompanyName: v.CompanyName,
  332. Position: v.Position,
  333. Mobile: v.Mobile,
  334. SellerId: seller.AdminId,
  335. Seller: seller.RealName,
  336. CreateTime: time.Now(),
  337. ModifyTime: time.Now(),
  338. ApprovalContent: "申请账号",
  339. ApplyMethod: 1,
  340. ApprovalStatus: "待审批",
  341. }
  342. approvalId, e = eta_trial.AddETATrialApproval(&approvalItem)
  343. if e != nil {
  344. err = e
  345. return
  346. }
  347. }
  348. //放入成功列表中
  349. respItem := eta_trial.ETATrialAddRespItem{
  350. UserName: v.UserName,
  351. CompanyName: v.CompanyName,
  352. Position: v.Position,
  353. Mobile: v.Mobile,
  354. Seller: seller.RealName,
  355. }
  356. resp.SuccessList = append(resp.SuccessList, &respItem)
  357. //新增待办消息
  358. msgItem := new(company.CompanyApprovalMessage)
  359. msgItem.CreateUserId = sysUser.AdminId
  360. msgItem.ReceiveUserId = -1
  361. msgItem.MessageStatus = 1 // 已读, 不再亮红点, 但是消息要有
  362. msgItem.Remark = seller.RealName + "申请试用账号"
  363. msgItem.Content = seller.RealName + "申请试用账号"
  364. msgItem.CompanyName = v.CompanyName
  365. msgItem.CreateTime = time.Now()
  366. msgItem.ModifyTime = time.Now()
  367. msgItem.CompanyApprovalId = int(approvalId)
  368. msgItem.OperationStatus = 1
  369. msgItem.MessageType = 1 //1:申请消息,2:审批结果,3:文字消息
  370. msgItem.SourceType = 9 //消息来源
  371. msgItem.ApprovalStatus = 1 //审批状态,1:待审批,2:已审批,3:已驳回
  372. err = company.AddCompanyApprovalMessage(msgItem)
  373. approvalIds = append(approvalIds, int(approvalId))
  374. }
  375. // 2023-08-01默认审批通过, 不再进行人工审批, 也不发送待办消息
  376. if len(approvalIds) > 0 {
  377. go func() {
  378. for _, v := range approvalIds {
  379. _ = services.ApprovalApply(v)
  380. }
  381. }()
  382. }
  383. br.Ret = 200
  384. br.Success = true
  385. br.Msg = "提交成功"
  386. br.Data = resp
  387. return
  388. }
  389. // @Title 申请启用
  390. // @Description 申请启用 接口
  391. // @Success 200 {object} models.ETATrialAddReq
  392. // @router /apply/enable [post]
  393. func (this *ETATrialController) ApplyEnable() {
  394. br := new(models.BaseResponse).Init()
  395. defer func() {
  396. this.Data["json"] = br
  397. this.ServeJSON()
  398. }()
  399. sysUser := this.SysUser
  400. if sysUser == nil {
  401. br.Msg = "请登录"
  402. br.ErrMsg = "请登录,SysUser Is Empty"
  403. br.Ret = 408
  404. return
  405. }
  406. var req eta_trial.ETAAddApplyReq
  407. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  408. if err != nil {
  409. br.Msg = "参数解析异常!"
  410. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  411. return
  412. }
  413. seller, e := system.GetSysAdminById(sysUser.AdminId)
  414. if e != nil {
  415. err = e
  416. return
  417. }
  418. var condition string
  419. var pars []interface{}
  420. if req.IsCheckAll {
  421. if len(req.MobileList) > 0 {
  422. condition += " and mobile not in (" + utils.GetOrmInReplace(len(req.MobileList)) + ")"
  423. for _, mobile := range req.MobileList {
  424. pars = append(pars, mobile)
  425. }
  426. }
  427. } else {
  428. if len(req.MobileList) > 0 {
  429. condition += " and mobile in (" + utils.GetOrmInReplace(len(req.MobileList)) + ")"
  430. for _, mobile := range req.MobileList {
  431. pars = append(pars, mobile)
  432. }
  433. }
  434. }
  435. trialApprovalList, err := eta_trial.GetETATrialByCondition(condition, pars)
  436. if err != nil {
  437. return
  438. }
  439. for _, trialApproval := range trialApprovalList {
  440. approval, err := eta_trial.GetETATrialApprovalByMobile(trialApproval.Mobile)
  441. if err != nil && err.Error() != utils.ErrNoRow() {
  442. br.Msg = "获取失败!"
  443. br.ErrMsg = "获取失败,Err:" + err.Error()
  444. return
  445. }
  446. var approvalId int64
  447. if approval != nil && (approval.ApprovalStatus == "驳回" || approval.ApprovalStatus == "已撤回") && trialApproval.Mobile == approval.Mobile {
  448. //若是被驳回或撤回后申请且手机号相同的,更新审批记录
  449. err = eta_trial.ResubmitTrial(approval.ApprovalId, req.ApplyReasons)
  450. if err != nil {
  451. br.Msg = "更新失败!"
  452. br.ErrMsg = "更新失败,Err:" + err.Error()
  453. return
  454. }
  455. approvalId = int64(approval.ApprovalId)
  456. } else if approval != nil && approval.ApprovalStatus == "待审批" && approval.ApprovalContent == "申请启用" {
  457. br.Msg = "该客户已在审批中!"
  458. br.ErrMsg = "该客户已在审批中!"
  459. return
  460. } else {
  461. //加入审批列表
  462. approvalItem := eta_trial.EtaTrialApproval{
  463. UserName: trialApproval.UserName,
  464. CompanyName: trialApproval.CompanyName,
  465. Position: trialApproval.Position,
  466. Mobile: trialApproval.Mobile,
  467. SellerId: seller.AdminId,
  468. Seller: seller.RealName,
  469. CreateTime: time.Now(),
  470. ModifyTime: time.Now(),
  471. ApprovalContent: "申请启用",
  472. ApplyMethod: 2,
  473. ApprovalStatus: "待审批",
  474. ApplyReasons: req.ApplyReasons,
  475. }
  476. approvalId, e = eta_trial.AddETATrialApproval(&approvalItem)
  477. if e != nil {
  478. err = e
  479. return
  480. }
  481. }
  482. //新增待办消息
  483. msgItem := new(company.CompanyApprovalMessage)
  484. msgItem.CreateUserId = sysUser.AdminId
  485. msgItem.ReceiveUserId = -1
  486. msgItem.MessageStatus = 1 // 已读, 不再亮红点, 但是消息要有
  487. msgItem.Remark = seller.RealName + "申请账号启用"
  488. msgItem.Content = seller.RealName + "申请账号启用"
  489. msgItem.CompanyName = trialApproval.CompanyName
  490. msgItem.CreateTime = time.Now()
  491. msgItem.ModifyTime = time.Now()
  492. msgItem.CompanyApprovalId = int(approvalId)
  493. msgItem.OperationStatus = 1
  494. msgItem.MessageType = 1 //1:申请消息,2:审批结果,3:文字消息
  495. msgItem.SourceType = 9 //消息来源
  496. msgItem.ApprovalStatus = 1 //审批状态,1:待审批,2:已审批,3:已驳回
  497. err = company.AddCompanyApprovalMessage(msgItem)
  498. // 2023-08-01默认审批通过, 不再进行人工审批
  499. go func() {
  500. _ = services.ApprovalApply(int(approvalId))
  501. }()
  502. }
  503. br.Ret = 200
  504. br.Success = true
  505. br.Msg = "提交成功"
  506. }
  507. // @Title 撤回
  508. // @Description 撤回申请 接口
  509. // @Success 200 {object} models.ETATrialAddReq
  510. // @router /apply/revoke [post]
  511. func (this *ETATrialController) ApplyRevoke() {
  512. br := new(models.BaseResponse).Init()
  513. defer func() {
  514. this.Data["json"] = br
  515. this.ServeJSON()
  516. }()
  517. sysUser := this.SysUser
  518. if sysUser == nil {
  519. br.Msg = "请登录"
  520. br.ErrMsg = "请登录,SysUser Is Empty"
  521. br.Ret = 408
  522. return
  523. }
  524. var req eta_trial.RevokeReq
  525. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  526. if err != nil {
  527. br.Msg = "参数解析异常!"
  528. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  529. return
  530. }
  531. mobile := req.Mobile
  532. mobile = strings.Trim(mobile, " ")
  533. mobile = strings.Replace(mobile, "'", "", -1)
  534. approval, err := eta_trial.GetETATrialApprovalByMobile(mobile)
  535. if err != nil {
  536. if err.Error() == utils.ErrNoRow() {
  537. br.Msg = "待审批信息不存在"
  538. br.ErrMsg = "待审批信息不存在,手机号:" + mobile
  539. return
  540. }
  541. br.Msg = "获取信息失败"
  542. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  543. return
  544. }
  545. if approval == nil {
  546. br.Msg = "待审批信息不存在"
  547. br.ErrMsg = "待审批信息不存在,手机号:" + mobile
  548. return
  549. }
  550. if approval.ApprovalStatus != "待审批" {
  551. br.Msg = "客户状态为:" + approval.ApprovalStatus + ";不可进行撤回操作"
  552. br.ErrMsg = "客户状态为:" + approval.ApprovalStatus + ";不可进行撤回操作"
  553. return
  554. }
  555. //撤回审批单
  556. err = eta_trial.RevokeApproval(mobile)
  557. if err != nil {
  558. br.Msg = "撤回失败"
  559. br.ErrMsg = "撤回失败,Err:" + err.Error()
  560. return
  561. }
  562. // 更新审批消息状态为已读
  563. go func() {
  564. cond := ` AND company_approval_id = ? AND source_type = ? AND message_status = ?`
  565. pars := make([]interface{}, 0)
  566. pars = append(pars, approval.ApprovalId, 9, 0)
  567. if e := company.ModifyCompanyApprovalMessageStatusByCond(cond, pars); e != nil {
  568. br.Msg = "操作失败"
  569. br.ErrMsg = "更新销售ETA试用消息已读状态失败, Err: " + e.Error()
  570. return
  571. }
  572. }()
  573. br.Ret = 200
  574. br.Success = true
  575. br.Msg = "撤回成功"
  576. }
  577. // @Title 删除申请
  578. // @Description 删除申请 接口
  579. // @Success 200 {object} models.ETATrialAddReq
  580. // @router /apply/del [post]
  581. func (this *ETATrialController) ApplyDel() {
  582. br := new(models.BaseResponse).Init()
  583. defer func() {
  584. this.Data["json"] = br
  585. this.ServeJSON()
  586. }()
  587. sysUser := this.SysUser
  588. if sysUser == nil {
  589. br.Msg = "请登录"
  590. br.ErrMsg = "请登录,SysUser Is Empty"
  591. br.Ret = 408
  592. return
  593. }
  594. var req eta_trial.DelReq
  595. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  596. if err != nil {
  597. br.Msg = "参数解析异常!"
  598. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  599. return
  600. }
  601. if req.ApprovalId <= 0 {
  602. br.Msg = "参数有误"
  603. return
  604. }
  605. _, e := eta_trial.GetETATrialApprovalById(req.ApprovalId)
  606. if e != nil {
  607. if e.Error() == utils.ErrNoRow() {
  608. br.Msg = "申请已被删除, 请刷新页面"
  609. return
  610. }
  611. br.Msg = "操作失败"
  612. br.ErrMsg = "获取ETA审批失败, Err: " + e.Error()
  613. return
  614. }
  615. err = eta_trial.DelApproval(req.ApprovalId)
  616. if err != nil {
  617. br.Msg = "删除失败"
  618. br.ErrMsg = "删除失败,Err:" + err.Error()
  619. return
  620. }
  621. // 更新审批消息状态为已读
  622. go func() {
  623. cond := ` AND company_approval_id = ? AND source_type = ? AND message_status = ?`
  624. pars := make([]interface{}, 0)
  625. pars = append(pars, req.ApprovalId, 9, 0)
  626. if e := company.ModifyCompanyApprovalMessageStatusByCond(cond, pars); e != nil {
  627. br.Msg = "操作失败"
  628. br.ErrMsg = "更新销售ETA试用消息已读状态失败, Err: " + e.Error()
  629. return
  630. }
  631. }()
  632. br.Ret = 200
  633. br.Success = true
  634. br.Msg = "删除成功"
  635. }
  636. // @Title 驳回申请
  637. // @Description 驳回申请 接口
  638. // @Param ApprovalId query string true "审批id"
  639. // @Param RejectReason query string true "驳回理由"
  640. // @Success 200 {object} models.ETATrialAddReq
  641. // @router /apply/reject [post]
  642. func (this *ETATrialController) ApplyReject() {
  643. br := new(models.BaseResponse).Init()
  644. defer func() {
  645. this.Data["json"] = br
  646. this.ServeJSON()
  647. }()
  648. sysUser := this.SysUser
  649. if sysUser == nil {
  650. br.Msg = "请登录"
  651. br.ErrMsg = "请登录,SysUser Is Empty"
  652. br.Ret = 408
  653. return
  654. }
  655. var req eta_trial.RejectReq
  656. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  657. if err != nil {
  658. br.Msg = "参数解析异常!"
  659. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  660. return
  661. }
  662. approvalId := req.ApprovalId
  663. reason := req.RejectReason
  664. err = eta_trial.RejectApproval(approvalId, reason)
  665. if err != nil {
  666. br.Msg = "删除失败"
  667. br.ErrMsg = "删除失败,Err:" + err.Error()
  668. return
  669. }
  670. approval, err := eta_trial.GetETATrialApprovalById(approvalId)
  671. if err != nil {
  672. br.Msg = "获取失败"
  673. br.ErrMsg = "获取失败,Err:" + err.Error()
  674. return
  675. }
  676. msgItem := new(company.CompanyApprovalMessage)
  677. msgItem.CreateUserId = sysUser.AdminId
  678. msgItem.ReceiveUserId = approval.SellerId
  679. msgItem.MessageStatus = 0
  680. msgItem.Remark = approval.UserName + approval.ApprovalContent + "驳回"
  681. msgItem.Content = approval.UserName + approval.ApprovalContent + "驳回"
  682. msgItem.CompanyName = approval.CompanyName
  683. msgItem.CreateTime = time.Now()
  684. msgItem.ModifyTime = time.Now()
  685. msgItem.CompanyApprovalId = approvalId
  686. msgItem.OperationStatus = 1
  687. msgItem.MessageType = 2 //1:申请消息,2:审批结果,3:文字消息
  688. msgItem.SourceType = 9 //消息来源
  689. msgItem.ApprovalStatus = 3 //审批状态,1:待审批,2:已审批,3:已驳回
  690. err = company.AddCompanyApprovalMessage(msgItem)
  691. // 更新审批消息(发给所有管理员的)为已读
  692. go func() {
  693. cond := ` AND company_approval_id = ? AND source_type = ? AND message_status = ? AND receive_user_id = -1 `
  694. pars := make([]interface{}, 0)
  695. pars = append(pars, req.ApprovalId, 9, 0)
  696. if e := company.ModifyCompanyApprovalMessageStatusByCond(cond, pars); e != nil {
  697. br.Msg = "操作失败"
  698. br.ErrMsg = "更新销售ETA试用消息已读状态失败, Err: " + e.Error()
  699. return
  700. }
  701. }()
  702. br.Ret = 200
  703. br.Success = true
  704. br.Msg = "驳回成功"
  705. }
  706. // @Title 同意申请
  707. // @Description 同意申请 接口
  708. // @Param ApprovalId query string true "审批id"
  709. // @Success 200 {object} models.ETATrialAddReq
  710. // @router /apply/approval [post]
  711. func (this *ETATrialController) Approval() {
  712. br := new(models.BaseResponse).Init()
  713. defer func() {
  714. this.Data["json"] = br
  715. this.ServeJSON()
  716. }()
  717. sysUser := this.SysUser
  718. if sysUser == nil {
  719. br.Msg = "请登录"
  720. br.ErrMsg = "请登录,SysUser Is Empty"
  721. br.Ret = 408
  722. return
  723. }
  724. var req eta_trial.DelReq
  725. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  726. if err != nil {
  727. br.Msg = "参数解析异常!"
  728. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  729. return
  730. }
  731. approvalId := req.ApprovalId
  732. err = eta_trial.ApprovalTrial(approvalId)
  733. if err != nil {
  734. br.Msg = "删除失败"
  735. br.ErrMsg = "删除失败,Err:" + err.Error()
  736. return
  737. }
  738. approval, err := eta_trial.GetETATrialApprovalById(approvalId)
  739. if err != nil {
  740. br.Msg = "查询失败"
  741. br.ErrMsg = "查询失败,Err:" + err.Error()
  742. return
  743. }
  744. //如果是新客户申请就新增,旧客户更改账号状态即可
  745. if approval.ApplyMethod == 2 {
  746. err := eta_trial.UpdateETATrialEnable(approval.Mobile)
  747. if err != nil {
  748. br.Msg = "启用失败"
  749. br.ErrMsg = "启用失败,Err:" + err.Error()
  750. return
  751. }
  752. err = eta_trial.UpdateAdminEnable(approval.Mobile)
  753. if err != nil {
  754. br.Msg = "启用失败"
  755. br.ErrMsg = "启用失败,Err:" + err.Error()
  756. return
  757. }
  758. } else {
  759. //新增客户
  760. newItem := eta_trial.EtaTrial{
  761. UserName: approval.UserName,
  762. CompanyName: approval.CompanyName,
  763. Position: approval.Position,
  764. Mobile: approval.Mobile,
  765. Enabled: 1,
  766. SellerId: approval.SellerId,
  767. Seller: approval.Seller,
  768. CreateTime: time.Now(),
  769. ModifyTime: time.Now(),
  770. }
  771. strResult := ""
  772. a := pinyin.NewArgs()
  773. rows := pinyin.Pinyin(newItem.UserName, a)
  774. for i := 0; i < len(rows); i++ {
  775. strResult += rows[i][0]
  776. }
  777. //若非中文
  778. if strResult == "" {
  779. strResult = newItem.UserName
  780. }
  781. list, err := eta_trial.GetETATrialByAccount(strResult)
  782. if err != nil && err.Error() != utils.ErrNoRow() {
  783. br.Msg = "查询失败"
  784. br.ErrMsg = "查询失败,GetETATrialByAccount Err:" + err.Error()
  785. return
  786. }
  787. if list != nil && len(list) > 0 {
  788. newItem.Account = strResult + strconv.Itoa(len(list))
  789. } else {
  790. newItem.Account = strResult
  791. }
  792. //newItem.Password = utils.GetRandStringNoSpecialChar(8)
  793. // 初始密码固定
  794. newItem.Password = "123456a"
  795. _, err = eta_trial.AddETATrial(&newItem)
  796. if err != nil {
  797. br.Msg = "新增失败"
  798. br.ErrMsg = "新增失败,AddETATrial Err:" + err.Error()
  799. return
  800. }
  801. //新增至试用平台的Admin
  802. adminItem, err := eta_trial.GetSysUserByRoleAndDepartment("试用", "ETA试用客户")
  803. if err != nil {
  804. br.Msg = "获取用户信息失败"
  805. br.ErrMsg = "获取用户信息失败,Err:" + err.Error()
  806. return
  807. }
  808. admin := new(eta_trial.ETATrialAdmin)
  809. admin.AdminName = newItem.Account
  810. admin.RealName = newItem.UserName
  811. admin.Password = utils.MD5(newItem.Password)
  812. admin.LastUpdatedPasswordTime = time.Now().Format(utils.FormatDateTime)
  813. admin.Enabled = 1
  814. admin.LastLoginTime = time.Now().Format(utils.FormatDateTime)
  815. admin.CreatedTime = time.Now()
  816. admin.LastUpdatedTime = time.Now().Format(utils.FormatDateTime)
  817. admin.Mobile = newItem.Mobile
  818. admin.RoleType = 0
  819. admin.RoleId = adminItem.RoleId
  820. admin.RoleName = "试用"
  821. admin.RoleTypeCode = "管理员"
  822. admin.DepartmentId = adminItem.DepartmentId
  823. admin.DepartmentName = "ETA试用客户"
  824. admin.Role = "admin"
  825. admin.Position = approval.Position
  826. newId, err := eta_trial.AddAdmin(admin)
  827. if err != nil {
  828. br.Msg = "新增失败"
  829. br.ErrMsg = "新增失败,AddAdmin Err:" + err.Error()
  830. return
  831. }
  832. // 新增试用客户手工权限
  833. go func() {
  834. //_ = services.CreateTrialUserManualAuth(newId, admin.RealName)
  835. _ = services.EtaTrialManualUserAddAuth(newId, admin.RealName)
  836. }()
  837. }
  838. msgItem := new(company.CompanyApprovalMessage)
  839. msgItem.CreateUserId = sysUser.AdminId
  840. msgItem.ReceiveUserId = approval.SellerId
  841. msgItem.MessageStatus = 0
  842. msgItem.Remark = approval.UserName + approval.ApprovalContent + "通过"
  843. msgItem.Content = approval.UserName + approval.ApprovalContent + "通过"
  844. msgItem.CompanyName = approval.CompanyName
  845. msgItem.CreateTime = time.Now()
  846. msgItem.ModifyTime = time.Now()
  847. msgItem.CompanyApprovalId = approvalId
  848. msgItem.OperationStatus = 1
  849. msgItem.MessageType = 2 //1:申请消息,2:审批结果,3:文字消息
  850. msgItem.SourceType = 9 //消息来源
  851. msgItem.ApprovalStatus = 2 //审批状态,1:待审批,2:已审批,3:已驳回
  852. err = company.AddCompanyApprovalMessage(msgItem)
  853. // 更新审批消息(发给所有管理员的)为已读
  854. go func() {
  855. cond := ` AND company_approval_id = ? AND source_type = ? AND message_status = ? AND receive_user_id = -1 `
  856. pars := make([]interface{}, 0)
  857. pars = append(pars, req.ApprovalId, 9, 0)
  858. if e := company.ModifyCompanyApprovalMessageStatusByCond(cond, pars); e != nil {
  859. br.Msg = "操作失败"
  860. br.ErrMsg = "更新销售ETA试用消息已读状态失败, Err: " + e.Error()
  861. return
  862. }
  863. }()
  864. br.Ret = 200
  865. br.Success = true
  866. br.Msg = "审批成功"
  867. }
  868. // @Title 我的审批
  869. // @Description 我的审批 接口
  870. // @Param PageSize query int true "每页数据条数"
  871. // @Param CurrentIndex query int true "当前页页码,从1开始"
  872. // @Param KeyWord query string true "搜索关键词"
  873. // @Param SortType query string true "如何排序,是正序还是倒序,枚举值:`asc 正序`,`desc 倒叙`"
  874. // @router /apply/myList [get]
  875. func (this *ETATrialController) MyList() {
  876. br := new(models.BaseResponse).Init()
  877. defer func() {
  878. this.Data["json"] = br
  879. this.ServeJSON()
  880. }()
  881. sysUser := this.SysUser
  882. if sysUser == nil {
  883. br.Msg = "请登录"
  884. br.ErrMsg = "请登录,SysUser Is Empty"
  885. br.Ret = 408
  886. return
  887. }
  888. pageSize, _ := this.GetInt("PageSize")
  889. currentIndex, _ := this.GetInt("CurrentIndex")
  890. keyWord := this.GetString("KeyWord")
  891. keyWord = strings.Trim(keyWord, " ")
  892. keyWord = strings.Replace(keyWord, "'", "", -1)
  893. //排序参数
  894. sortType := this.GetString("SortType")
  895. var total int
  896. page := paging.GetPaging(currentIndex, pageSize, total)
  897. var startSize int
  898. if pageSize <= 0 {
  899. pageSize = utils.PageSize20
  900. }
  901. if currentIndex <= 0 {
  902. currentIndex = 1
  903. }
  904. startSize = paging.StartIndex(currentIndex, pageSize)
  905. var condition string
  906. var pars []interface{}
  907. if keyWord != "" {
  908. condition += ` AND (a.user_name LIKE '%` + keyWord + `%' OR a.company_name LIKE '%` + keyWord + `%' OR a.mobile LIKE '%` + keyWord + `%') `
  909. }
  910. sortStr := ""
  911. if sortType == "asc" {
  912. sortStr = "ORDER BY a.modify_time ASC "
  913. } else {
  914. sortStr = "ORDER BY a.modify_time DESC "
  915. }
  916. pars = append(pars, sysUser.AdminId)
  917. total, err := eta_trial.GetETATrialApprovalCountBySellerId(condition, sortStr, pars)
  918. if err != nil {
  919. br.Msg = "获取失败"
  920. br.ErrMsg = "获取数据总数失败,Err:" + err.Error()
  921. return
  922. }
  923. list, err := eta_trial.GetETATrialApprovalBySellerId(condition, sortStr, pars, startSize, pageSize)
  924. if err != nil {
  925. br.Msg = "查询失败"
  926. br.ErrMsg = "查询失败,Err:" + err.Error()
  927. return
  928. }
  929. page = paging.GetPaging(currentIndex, pageSize, total)
  930. resp := new(eta_trial.ETATrialApprovalListRespList)
  931. resp.List = list
  932. resp.Paging = page
  933. br.Ret = 200
  934. br.Success = true
  935. br.Msg = "获取成功"
  936. br.Data = resp
  937. return
  938. }
  939. // @Title 审批列表
  940. // @Description 审批列表 接口
  941. // @Param SortParam query int false "排序字段参数,用来排序的字段 "
  942. // @Param ListParam query int false "筛选字段参数,用来筛选的字段, 枚举值:1:全部 、 2:待审批 、 3:已审批 "
  943. // @Param PageSize query int true "每页数据条数"
  944. // @Param CurrentIndex query int true "当前页页码,从1开始"
  945. // @Param KeyWord query string true "搜索关键词"
  946. // @Param SortType query string true "如何排序,是正序还是倒序,枚举值:`asc 正序`,`desc 倒叙`"
  947. // @Success 200 {object} models.ETATrialAddReq
  948. // @router /apply/list [get]
  949. func (this *ETATrialController) ApplyList() {
  950. br := new(models.BaseResponse).Init()
  951. defer func() {
  952. this.Data["json"] = br
  953. this.ServeJSON()
  954. }()
  955. sysUser := this.SysUser
  956. if sysUser == nil {
  957. br.Msg = "请登录"
  958. br.ErrMsg = "请登录,SysUser Is Empty"
  959. br.Ret = 408
  960. return
  961. }
  962. pageSize, _ := this.GetInt("PageSize")
  963. currentIndex, _ := this.GetInt("CurrentIndex")
  964. keyWord := this.GetString("KeyWord")
  965. keyWord = strings.Trim(keyWord, " ")
  966. keyWord = strings.Replace(keyWord, "'", "", -1)
  967. //排序参数
  968. sortParam := this.GetString("SortParam")
  969. listParam, _ := this.GetInt("ListParam")
  970. sortType := this.GetString("SortType")
  971. var total int
  972. page := paging.GetPaging(currentIndex, pageSize, total)
  973. var startSize int
  974. if pageSize <= 0 {
  975. pageSize = utils.PageSize20
  976. }
  977. if currentIndex <= 0 {
  978. currentIndex = 1
  979. }
  980. startSize = paging.StartIndex(currentIndex, pageSize)
  981. var condition string
  982. var pars []interface{}
  983. if keyWord != "" {
  984. condition += ` AND (user_name LIKE '%` + keyWord + `%' OR company_name LIKE '%` + keyWord + `%' OR mobile LIKE '%` + keyWord + `%') `
  985. }
  986. sortStr := ""
  987. if listParam == 0 {
  988. condition += ` AND approval_status = '待审批' `
  989. } else if listParam == 2 {
  990. condition += ` AND approval_status = '待审批' `
  991. } else if listParam == 3 {
  992. condition += ` AND approval_status = '已审批' OR approval_status = '驳回' `
  993. }
  994. if sortType == "asc" {
  995. sortStr = "ORDER BY modify_time ASC "
  996. } else {
  997. sortStr = "ORDER BY modify_time DESC "
  998. }
  999. if sortParam == "Expiration" {
  1000. if sortType == "asc" {
  1001. sortStr = "ORDER BY modify_time ASC "
  1002. } else {
  1003. sortStr = "ORDER BY modify_time DESC "
  1004. }
  1005. } else if sortParam == "ModifyTime" {
  1006. if sortType == "asc" {
  1007. sortStr = "ORDER BY modify_time ASC "
  1008. } else {
  1009. sortStr = "ORDER BY modify_time DESC "
  1010. }
  1011. }
  1012. total, err := eta_trial.GetETATrialApprovalListCount(condition, pars)
  1013. if err != nil {
  1014. br.Msg = "获取失败"
  1015. br.ErrMsg = "获取数据总数失败,Err:" + err.Error()
  1016. return
  1017. }
  1018. list, err := eta_trial.GetETATrialApprovalList(condition, sortStr, pars, startSize, pageSize)
  1019. if err != nil {
  1020. br.Msg = "查询失败"
  1021. br.ErrMsg = "查询失败,Err:" + err.Error()
  1022. return
  1023. }
  1024. page = paging.GetPaging(currentIndex, pageSize, total)
  1025. resp := new(eta_trial.ETATrialApprovalListRespList)
  1026. resp.List = list
  1027. resp.Paging = page
  1028. br.Ret = 200
  1029. br.Success = true
  1030. br.Msg = "获取成功"
  1031. br.Data = resp
  1032. return
  1033. }
  1034. // @Title 账号列表
  1035. // @Description 账号列表 接口
  1036. // @Param SortParam query string false "排序字段参数,用来排序的字段, 枚举值:'Expiration':账号到期时长 、 'ModifyTime':账号更新时间 "
  1037. // @Param PageSize query int true "每页数据条数"
  1038. // @Param CurrentIndex query int true "当前页页码,从1开始"
  1039. // @Param KeyWord query string true "搜索关键词"
  1040. // @Param SortType query string true "如何排序,是正序还是倒序,枚举值:`asc 正序`,`desc 倒叙`"
  1041. // @Success 200 {object} models.ETATrialAddReq
  1042. // @router /apply/accountlist [get]
  1043. func (this *ETATrialController) AccountList() {
  1044. br := new(models.BaseResponse).Init()
  1045. defer func() {
  1046. this.Data["json"] = br
  1047. this.ServeJSON()
  1048. }()
  1049. sysUser := this.SysUser
  1050. if sysUser == nil {
  1051. br.Msg = "请登录"
  1052. br.ErrMsg = "请登录,SysUser Is Empty"
  1053. br.Ret = 408
  1054. return
  1055. }
  1056. pageSize, _ := this.GetInt("PageSize")
  1057. currentIndex, _ := this.GetInt("CurrentIndex")
  1058. keyWord := this.GetString("KeyWord")
  1059. keyWord = strings.Trim(keyWord, " ")
  1060. keyWord = strings.Replace(keyWord, "'", "", -1)
  1061. //排序参数
  1062. sortType := this.GetString("SortType")
  1063. var total int
  1064. page := paging.GetPaging(currentIndex, pageSize, total)
  1065. var startSize int
  1066. if pageSize <= 0 {
  1067. pageSize = utils.PageSize20
  1068. }
  1069. if currentIndex <= 0 {
  1070. currentIndex = 1
  1071. }
  1072. startSize = paging.StartIndex(currentIndex, pageSize)
  1073. var condition string
  1074. var pars []interface{}
  1075. if keyWord != "" {
  1076. condition += ` AND (user_name LIKE '%` + keyWord + `%' OR company_name LIKE '%` + keyWord + `%' OR mobile LIKE '%` + keyWord + `%') `
  1077. }
  1078. if sysUser.RoleTypeCode != "admin" && sysUser.RoleTypeCode != "ficc_admin" {
  1079. condition += ` AND seller_id = ? `
  1080. pars = append(pars, sysUser.AdminId)
  1081. }
  1082. total, err := eta_trial.GetETATrialListCount(condition, pars)
  1083. if err != nil {
  1084. br.Msg = "获取失败"
  1085. br.ErrMsg = "获取数据总数失败,Err:" + err.Error()
  1086. return
  1087. }
  1088. sortStr := ""
  1089. if sortType == "asc" {
  1090. sortStr = "ORDER BY modify_time ASC "
  1091. } else {
  1092. sortStr = "ORDER BY modify_time DESC "
  1093. }
  1094. list, err := eta_trial.GetETATrialList(condition, sortStr, pars, startSize, pageSize)
  1095. if err != nil {
  1096. br.Msg = "获取权限列表失败"
  1097. br.ErrMsg = "获取权限列表失败,Err:" + err.Error()
  1098. return
  1099. }
  1100. for _, item := range list {
  1101. activeTime, _ := strconv.Atoi(item.ActiveTime)
  1102. item.ActiveTime = utils.GetDurationFormatBySecond(activeTime)
  1103. //到期时间
  1104. modifyTime, err := time.Parse(utils.FormatDateTime, item.ModifyTime)
  1105. if err != nil {
  1106. br.Msg = "时间转化失败"
  1107. br.ErrMsg = "时间转化失败,Err:" + err.Error()
  1108. return
  1109. }
  1110. var expired int
  1111. expiredTime := modifyTime.AddDate(0, 0, 14).Format(utils.FormatDate)
  1112. expired, err = utils.GetDaysBetween2Date(utils.FormatDate, expiredTime, time.Now().Format(utils.FormatDate))
  1113. if err != nil {
  1114. br.Msg = "时间计算失败"
  1115. br.ErrMsg = "时间计算失败,CalculationDate Err:" + err.Error()
  1116. return
  1117. }
  1118. item.Expiration = expired
  1119. }
  1120. page = paging.GetPaging(currentIndex, pageSize, total)
  1121. resp := new(eta_trial.ETATrialListRespList)
  1122. resp.List = list
  1123. resp.Paging = page
  1124. br.Ret = 200
  1125. br.Success = true
  1126. br.Msg = "获取成功"
  1127. br.Data = resp
  1128. return
  1129. }
  1130. // @Title 问卷配置
  1131. // @Description 问卷配置 接口
  1132. // @Success 200 string "获取成功"
  1133. // @router /questionnaire/list [get]
  1134. func (this *ETATrialController) QuestionnaireList() {
  1135. br := new(models.BaseResponse).Init()
  1136. defer func() {
  1137. this.Data["json"] = br
  1138. this.ServeJSON()
  1139. }()
  1140. sysUser := this.SysUser
  1141. if sysUser == nil {
  1142. br.Msg = "请登录"
  1143. br.ErrMsg = "请登录,SysUser Is Empty"
  1144. br.Ret = 408
  1145. return
  1146. }
  1147. cond := ""
  1148. lists, err := eta_trial.GetETATrialQuestionnaireList(cond)
  1149. if err != nil {
  1150. br.Msg = "获取问卷失败"
  1151. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1152. return
  1153. }
  1154. var resp eta_trial.EtaTrialQuestionnaireResp
  1155. for _, v := range lists {
  1156. item := eta_trial.EtaTrialQuestionnaireRespItem{
  1157. QuestionnaireId: v.QuestionnaireId,
  1158. Question: v.Question,
  1159. Type: v.Type,
  1160. Sort: v.Sort,
  1161. Options: strings.Split(v.Options, "~#"),
  1162. IsMust: v.IsMust,
  1163. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1164. }
  1165. resp.List = append(resp.List, item)
  1166. }
  1167. sort.Sort(resp)
  1168. br.Ret = 200
  1169. br.Success = true
  1170. br.Msg = "获取成功"
  1171. br.Data = resp
  1172. return
  1173. }
  1174. // @Title 问卷保存
  1175. // @Description 问卷保存 接口
  1176. // @Param request body eta_trial.EtaTrialQuestionnaireSaveReq true "type json string"
  1177. // @Success 200 {object} models.ETATrialAddReq
  1178. // @router /questionnaire/save [post]
  1179. func (this *ETATrialController) QuestionnairesSave() {
  1180. br := new(models.BaseResponse).Init()
  1181. defer func() {
  1182. this.Data["json"] = br
  1183. this.ServeJSON()
  1184. }()
  1185. sysUser := this.SysUser
  1186. if sysUser == nil {
  1187. br.Msg = "请登录"
  1188. br.ErrMsg = "请登录,SysUser Is Empty"
  1189. br.Ret = 408
  1190. return
  1191. }
  1192. var req eta_trial.EtaTrialQuestionnaireSaveReq
  1193. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1194. if err != nil {
  1195. br.Msg = "参数解析异常!"
  1196. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1197. return
  1198. }
  1199. questionnaireList := make([]*eta_trial.EtaTrialQuestionnaire, 0)
  1200. for _, v := range req.List {
  1201. if v.QuestionnaireId == 0 {
  1202. //新增
  1203. questionItem := &eta_trial.EtaTrialQuestionnaire{
  1204. Question: v.Question,
  1205. IsMust: v.IsMust,
  1206. Type: v.Type,
  1207. Sort: v.Sort,
  1208. Options: strings.Join(v.Options, "~#"),
  1209. CreateTime: time.Now(),
  1210. }
  1211. questionnaireList = append(questionnaireList, questionItem)
  1212. } else {
  1213. //更新
  1214. questionItem := &eta_trial.EtaTrialQuestionnaire{
  1215. QuestionnaireId: v.QuestionnaireId,
  1216. Question: v.Question,
  1217. Options: strings.Join(v.Options, "~#"),
  1218. Sort: v.Sort,
  1219. IsMust: v.IsMust,
  1220. CreateTime: time.Time{},
  1221. }
  1222. cols := make([]string, 0)
  1223. cols = append(cols, "question", "options", "Sort", "IsMust")
  1224. err = questionItem.Update(cols)
  1225. if err != nil {
  1226. br.Msg = "更新问题失败!"
  1227. br.ErrMsg = "更新问题失败,Err:" + err.Error()
  1228. return
  1229. }
  1230. }
  1231. }
  1232. //批量新增问题和选项
  1233. if len(questionnaireList) > 0 {
  1234. err = eta_trial.AddETATrialQuestionnaire(questionnaireList)
  1235. if err != nil {
  1236. br.Msg = "保存问题失败!"
  1237. br.ErrMsg = "保存问题失败,Err:" + err.Error()
  1238. return
  1239. }
  1240. }
  1241. br.Ret = 200
  1242. br.Success = true
  1243. br.Msg = "保存成功"
  1244. return
  1245. }
  1246. // @Title 问题删除
  1247. // @Description 问题删除 接口
  1248. // @Param request body eta_trial.EtaTrialQuestionnaireSaveReq true "type json string"
  1249. // @Success 200 {object} models.ETATrialAddReq
  1250. // @router /questionnaire/del [post]
  1251. func (this *ETATrialController) QuestionnairesDel() {
  1252. br := new(models.BaseResponse).Init()
  1253. defer func() {
  1254. this.Data["json"] = br
  1255. this.ServeJSON()
  1256. }()
  1257. sysUser := this.SysUser
  1258. if sysUser == nil {
  1259. br.Msg = "请登录"
  1260. br.ErrMsg = "请登录,SysUser Is Empty"
  1261. br.Ret = 408
  1262. return
  1263. }
  1264. var req eta_trial.EtaTrialQuestionnaireDelReq
  1265. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1266. if err != nil {
  1267. br.Msg = "参数解析异常!"
  1268. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1269. return
  1270. }
  1271. if req.QuestionnaireId <= 0 {
  1272. br.Msg = "问题id异常!"
  1273. br.ErrMsg = "问题id异常,Err:" + err.Error()
  1274. return
  1275. }
  1276. count, err := eta_trial.GetETATrialQuestionnaireById(req.QuestionnaireId)
  1277. if err != nil && count > 0 {
  1278. br.Msg = "查询问题异常!"
  1279. br.ErrMsg = "查询问题异常,Err:" + err.Error()
  1280. return
  1281. }
  1282. err = eta_trial.DelETATrialQuestionnaireById(req.QuestionnaireId)
  1283. if err != nil && count > 0 {
  1284. br.Msg = "删除问题异常!"
  1285. br.ErrMsg = "删除问题异常,Err:" + err.Error()
  1286. return
  1287. }
  1288. br.Ret = 200
  1289. br.Success = true
  1290. br.Msg = "删除成功"
  1291. return
  1292. }
  1293. // @Title 问卷统计结果
  1294. // @Description 问卷统计结果 接口
  1295. // @Param ListParam query int false "筛选字段参数,用来筛选的字段, 枚举值:1:全部 、 2:选择题 、 3:简答题 "
  1296. // @Success 200 {object} models.ETATrialAddReq
  1297. // @router /questionnaire/statistical [get]
  1298. func (this *ETATrialController) QuestionnairesStatistical() {
  1299. br := new(models.BaseResponse).Init()
  1300. defer func() {
  1301. this.Data["json"] = br
  1302. this.ServeJSON()
  1303. }()
  1304. sysUser := this.SysUser
  1305. if sysUser == nil {
  1306. br.Msg = "请登录"
  1307. br.ErrMsg = "请登录,SysUser Is Empty"
  1308. br.Ret = 408
  1309. return
  1310. }
  1311. listParam, _ := this.GetInt("ListParam")
  1312. cond := ""
  1313. if listParam == 2 {
  1314. cond = "AND a.type = 1 OR a.type = 2 "
  1315. } else if listParam == 3 {
  1316. cond = "AND a.type = 3 "
  1317. }
  1318. list, err := eta_trial.GetETATrialQuestionnaireStatistic(cond)
  1319. if err != nil {
  1320. br.Msg = "获取问题统计失败!"
  1321. br.ErrMsg = "获取问题统计失败,Err:" + err.Error()
  1322. return
  1323. }
  1324. //获取单选和简答的回答数量,多选计算方式不同在计算后面统计时再计算
  1325. questionCountList, err := eta_trial.GetETATrialQuestionnaireStatisticCount()
  1326. if err != nil {
  1327. br.Msg = "获取问卷记录数量失败"
  1328. br.ErrMsg = "获取问卷记录数量失败,Err:" + err.Error()
  1329. return
  1330. }
  1331. questioncountMap := make(map[int]int, 0)
  1332. for _, v := range questionCountList {
  1333. questioncountMap[v.QuestionnaireId] = v.Count
  1334. }
  1335. chooseMap := make(map[string]int, 0)
  1336. answerCountMap := make(map[int]int, 0)
  1337. answerMap := make(map[int][]string, 0)
  1338. answerNameMap := make(map[int]string, 0)
  1339. for _, v := range list {
  1340. //问卷ID拼选项作为key,防止不同问题选项重复
  1341. if v.Type == 1 {
  1342. key := strconv.Itoa(v.QuestionnaireId) + v.Options
  1343. if _, ok := chooseMap[key]; !ok {
  1344. chooseMap[key] = v.Count
  1345. }
  1346. } else if v.Type == 2 {
  1347. options := strings.Split(v.Options, "~#")
  1348. for _, op := range options {
  1349. key := strconv.Itoa(v.QuestionnaireId) + op
  1350. if _, ok := chooseMap[key]; ok {
  1351. //多选题可能出现多人同样的选择
  1352. chooseMap[key] += v.Count
  1353. } else {
  1354. chooseMap[key] = v.Count
  1355. }
  1356. questioncountMap[v.QuestionnaireId] += v.Count
  1357. }
  1358. } else {
  1359. //简答题,最多十条
  1360. if count, ok := answerCountMap[v.QuestionnaireId]; ok && count < 11 {
  1361. answerMap[v.QuestionnaireId] = append(answerMap[v.QuestionnaireId], v.Options)
  1362. answerNameMap[v.QuestionnaireId] = v.UserName
  1363. answerCountMap[v.QuestionnaireId] += 1
  1364. } else if !ok {
  1365. answerMap[v.QuestionnaireId] = append(answerMap[v.QuestionnaireId], v.Options)
  1366. answerNameMap[v.QuestionnaireId] = v.UserName
  1367. answerCountMap[v.QuestionnaireId] = 1
  1368. }
  1369. }
  1370. }
  1371. lists, err := eta_trial.GetETATrialQuestionnaireList(cond)
  1372. if err != nil {
  1373. br.Msg = "获取问卷失败"
  1374. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1375. return
  1376. }
  1377. var questionList eta_trial.EtaTrialQuestionnaireResp
  1378. for _, v := range lists {
  1379. item := eta_trial.EtaTrialQuestionnaireRespItem{
  1380. QuestionnaireId: v.QuestionnaireId,
  1381. Question: v.Question,
  1382. Options: strings.Split(v.Options, "~#"),
  1383. Type: v.Type,
  1384. Sort: v.Sort,
  1385. IsMust: v.IsMust,
  1386. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1387. }
  1388. questionList.List = append(questionList.List, item)
  1389. }
  1390. sort.Sort(questionList)
  1391. var resp []eta_trial.EtaTrialQuestionnaireRecordStatisticResp
  1392. for _, v := range questionList.List {
  1393. if v.Type != 3 {
  1394. options := make([]*eta_trial.EtaTrialQuestionnaireRecordStatisticOption, 0)
  1395. for _, op := range v.Options {
  1396. key := strconv.Itoa(v.QuestionnaireId) + op
  1397. opItem := eta_trial.EtaTrialQuestionnaireRecordStatisticOption{
  1398. Option: op,
  1399. Count: chooseMap[key],
  1400. }
  1401. options = append(options, &opItem)
  1402. }
  1403. item := eta_trial.EtaTrialQuestionnaireRecordStatisticResp{
  1404. QuestionnaireId: v.QuestionnaireId,
  1405. Question: v.Question,
  1406. Options: options,
  1407. Type: v.Type,
  1408. IsMust: v.IsMust,
  1409. }
  1410. resp = append(resp, item)
  1411. } else {
  1412. item := eta_trial.EtaTrialQuestionnaireRecordStatisticResp{
  1413. QuestionnaireId: v.QuestionnaireId,
  1414. Question: v.Question,
  1415. Type: v.Type,
  1416. IsMust: v.IsMust,
  1417. }
  1418. ansList := make([]eta_trial.EtaTrialQuestionnaireRecordStatisticAnswer, 0)
  1419. for _, val := range answerMap[v.QuestionnaireId] {
  1420. ansItem := eta_trial.EtaTrialQuestionnaireRecordStatisticAnswer{
  1421. Answer: val,
  1422. UserName: answerNameMap[v.QuestionnaireId],
  1423. }
  1424. ansList = append(ansList, ansItem)
  1425. }
  1426. item.Answers = ansList
  1427. resp = append(resp, item)
  1428. }
  1429. }
  1430. for _, v := range resp {
  1431. if v.Type != 3 && v.Type != 4 {
  1432. for i, op := range v.Options {
  1433. key := strconv.Itoa(v.QuestionnaireId) + op.Option
  1434. opCount := float64(chooseMap[key])
  1435. count := float64(questioncountMap[v.QuestionnaireId])
  1436. if count != 0 {
  1437. per, _ := strconv.ParseFloat(fmt.Sprintf("%.4f", opCount/count), 64)
  1438. op.Percentage = per
  1439. }
  1440. op.Index = i
  1441. }
  1442. }
  1443. }
  1444. br.Ret = 200
  1445. br.Success = true
  1446. br.Msg = "保存成功"
  1447. br.Data = resp
  1448. return
  1449. }
  1450. // @Title 简答题列表
  1451. // @Description 简答题列表 接口
  1452. // @Success 200 string "获取成功"
  1453. // @Param PageSize query int true "每页数据条数"
  1454. // @Param CurrentIndex query int true "当前页页码,从1开始"
  1455. // @Param QuestionnaireId query int true "问题id"
  1456. // @router /questionnaire/answerList [get]
  1457. func (this *ETATrialController) QuestionnaireAnswerList() {
  1458. br := new(models.BaseResponse).Init()
  1459. defer func() {
  1460. this.Data["json"] = br
  1461. this.ServeJSON()
  1462. }()
  1463. sysUser := this.SysUser
  1464. if sysUser == nil {
  1465. br.Msg = "请登录"
  1466. br.ErrMsg = "请登录,SysUser Is Empty"
  1467. br.Ret = 408
  1468. return
  1469. }
  1470. var startSize int
  1471. pageSize, _ := this.GetInt("PageSize")
  1472. currentIndex, _ := this.GetInt("CurrentIndex")
  1473. if pageSize <= 0 {
  1474. pageSize = utils.PageSize20
  1475. }
  1476. if currentIndex <= 0 {
  1477. currentIndex = 1
  1478. }
  1479. startSize = paging.StartIndex(currentIndex, pageSize)
  1480. questionnaireId, _ := this.GetInt("QuestionnaireId")
  1481. lists, err := eta_trial.GetETATrialQuestionnaireAnswerListById(questionnaireId, startSize, pageSize)
  1482. if err != nil {
  1483. br.Msg = "获取问卷失败"
  1484. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1485. return
  1486. }
  1487. total, err := eta_trial.GetETATrialQuestionnaireAnswerListByIdCount(questionnaireId)
  1488. if err != nil {
  1489. br.Msg = "获取问卷失败"
  1490. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1491. return
  1492. }
  1493. cond := ""
  1494. qLists, err := eta_trial.GetETATrialQuestionnaireList(cond)
  1495. if err != nil {
  1496. br.Msg = "获取问卷失败"
  1497. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1498. return
  1499. }
  1500. mustMap := make(map[int]int, 0)
  1501. for _, v := range qLists {
  1502. mustMap[v.QuestionnaireId] = v.IsMust
  1503. }
  1504. resp := new(eta_trial.QuestionnaireDetailListResp)
  1505. for _, v := range lists {
  1506. item := eta_trial.EtaTrialQuestionnaireRecordRespItem{
  1507. RecordId: v.RecordId,
  1508. UserName: v.UserName,
  1509. CompanyName: v.CompanyName,
  1510. Position: v.Position,
  1511. Options: v.Options,
  1512. Mobile: v.Mobile,
  1513. Type: v.Type,
  1514. QuestionnaireId: v.QuestionnaireId,
  1515. IsMust: mustMap[v.QuestionnaireId],
  1516. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1517. }
  1518. resp.List = append(resp.List, &item)
  1519. }
  1520. page := paging.GetPaging(currentIndex, pageSize, total)
  1521. resp.Paging = page
  1522. br.Ret = 200
  1523. br.Success = true
  1524. br.Msg = "获取成功"
  1525. br.Data = resp
  1526. return
  1527. }
  1528. // @Title 详细数据列表
  1529. // @Description 详细数据列表 接口
  1530. // @Success 200 string "获取成功"
  1531. // @Param PageSize query int true "每页数据条数"
  1532. // @Param CurrentIndex query int true "当前页页码,从1开始"
  1533. // @router /questionnaire/detailList [get]
  1534. func (this *ETATrialController) QuestionnaireDetailList() {
  1535. br := new(models.BaseResponse).Init()
  1536. defer func() {
  1537. this.Data["json"] = br
  1538. this.ServeJSON()
  1539. }()
  1540. sysUser := this.SysUser
  1541. if sysUser == nil {
  1542. br.Msg = "请登录"
  1543. br.ErrMsg = "请登录,SysUser Is Empty"
  1544. br.Ret = 408
  1545. return
  1546. }
  1547. var startSize int
  1548. pageSize, _ := this.GetInt("PageSize")
  1549. currentIndex, _ := this.GetInt("CurrentIndex")
  1550. if pageSize <= 0 {
  1551. pageSize = utils.PageSize20
  1552. }
  1553. if currentIndex <= 0 {
  1554. currentIndex = 1
  1555. }
  1556. startSize = paging.StartIndex(currentIndex, pageSize)
  1557. total, err := eta_trial.GetETATrialQuestionnaireDetailListCount()
  1558. if err != nil {
  1559. br.Msg = "获取问卷数量失败"
  1560. br.ErrMsg = "获取问卷数量失败,Err:" + err.Error()
  1561. return
  1562. }
  1563. if total == 0 {
  1564. br.Msg = "无问卷调查记录"
  1565. br.Ret = 200
  1566. br.Success = true
  1567. return
  1568. }
  1569. lists, err := eta_trial.GetETATrialQuestionnaireDetailList(startSize, pageSize)
  1570. if err != nil {
  1571. br.Msg = "获取问卷失败"
  1572. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1573. return
  1574. }
  1575. cond := ""
  1576. qLists, err := eta_trial.GetETATrialQuestionnaireList(cond)
  1577. if err != nil {
  1578. br.Msg = "获取问卷失败"
  1579. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1580. return
  1581. }
  1582. mustMap := make(map[int]int, 0)
  1583. for _, v := range qLists {
  1584. mustMap[v.QuestionnaireId] = v.IsMust
  1585. }
  1586. resp := new(eta_trial.QuestionnaireDetailListResp)
  1587. for _, v := range lists {
  1588. item := eta_trial.EtaTrialQuestionnaireRecordRespItem{
  1589. RecordId: v.RecordId,
  1590. UserName: v.UserName,
  1591. CompanyName: v.CompanyName,
  1592. Position: v.Position,
  1593. Options: v.Options,
  1594. Mobile: v.Mobile,
  1595. Type: v.Type,
  1596. QuestionnaireId: v.QuestionnaireId,
  1597. IsMust: mustMap[v.QuestionnaireId],
  1598. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1599. }
  1600. resp.List = append(resp.List, &item)
  1601. }
  1602. page := paging.GetPaging(currentIndex, pageSize, total)
  1603. resp.Paging = page
  1604. br.Ret = 200
  1605. br.Success = true
  1606. br.Msg = "获取成功"
  1607. br.Data = resp
  1608. return
  1609. }
  1610. // @Title 详细数据查看
  1611. // @Description 详细数据查看 接口
  1612. // @Success 200 string "获取成功"
  1613. // @Param Mobile query string true "手机号"
  1614. // @Param CreateTime query string true "手机号"
  1615. // @router /questionnaire/detail [get]
  1616. func (this *ETATrialController) QuestionnaireDetail() {
  1617. br := new(models.BaseResponse).Init()
  1618. defer func() {
  1619. this.Data["json"] = br
  1620. this.ServeJSON()
  1621. }()
  1622. sysUser := this.SysUser
  1623. if sysUser == nil {
  1624. br.Msg = "请登录"
  1625. br.ErrMsg = "请登录,SysUser Is Empty"
  1626. br.Ret = 408
  1627. return
  1628. }
  1629. cond := ""
  1630. lists, err := eta_trial.GetETATrialQuestionnaireList(cond)
  1631. if err != nil {
  1632. br.Msg = "获取问卷失败"
  1633. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1634. return
  1635. }
  1636. var resp eta_trial.EtaTrialQuestionnaireResp
  1637. for _, v := range lists {
  1638. item := eta_trial.EtaTrialQuestionnaireRespItem{
  1639. QuestionnaireId: v.QuestionnaireId,
  1640. Question: v.Question,
  1641. Options: strings.Split(v.Options, "~#"),
  1642. Type: v.Type,
  1643. Sort: v.Sort,
  1644. IsMust: v.IsMust,
  1645. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1646. }
  1647. resp.List = append(resp.List, item)
  1648. }
  1649. sort.Sort(resp)
  1650. mobile := this.GetString("Mobile")
  1651. createTime := this.GetString("CreateTime")
  1652. timeDate, _ := time.Parse(utils.FormatDateTime, createTime)
  1653. startDate := timeDate.AddDate(0, 0, -1).Format(utils.FormatDateTime)
  1654. endDate := timeDate.AddDate(0, 0, 1).Format(utils.FormatDateTime)
  1655. answerList, err := eta_trial.GetETATrialQuestionnaireDetailListByMobile(mobile, startDate, endDate)
  1656. if err != nil {
  1657. br.Msg = "获取问卷失败"
  1658. br.ErrMsg = "获取问卷失败,Err:" + err.Error()
  1659. return
  1660. }
  1661. answerMap := make(map[int]string)
  1662. for _, v := range answerList {
  1663. answerMap[v.QuestionnaireId] = v.Options
  1664. }
  1665. nResp := make([]eta_trial.EtaTrialQuestionnaireDetailItem, 0)
  1666. for _, v := range lists {
  1667. item := eta_trial.EtaTrialQuestionnaireDetailItem{
  1668. QuestionnaireId: v.QuestionnaireId,
  1669. Question: v.Question,
  1670. Type: v.Type,
  1671. Sort: v.Sort,
  1672. IsMust: v.IsMust,
  1673. Options: strings.Split(v.Options, "~#"),
  1674. UserOptions: answerMap[v.QuestionnaireId],
  1675. CreateTime: v.CreateTime.Format(utils.FormatDateTime),
  1676. }
  1677. nResp = append(nResp, item)
  1678. }
  1679. br.Ret = 200
  1680. br.Success = true
  1681. br.Msg = "获取成功"
  1682. br.Data = nResp
  1683. return
  1684. }
  1685. // EnableAccountList
  1686. // @Title 已启用账号列表
  1687. // @Description 已启用账号列表
  1688. // @Success 200
  1689. // @router /enable/account/list [get]
  1690. func (this *ETATrialController) EnableAccountList() {
  1691. br := new(models.BaseResponse).Init()
  1692. defer func() {
  1693. this.Data["json"] = br
  1694. this.ServeJSON()
  1695. }()
  1696. sysUser := this.SysUser
  1697. if sysUser == nil {
  1698. br.Msg = "请登录"
  1699. br.ErrMsg = "请登录,SysUser Is Empty"
  1700. br.Ret = 408
  1701. return
  1702. }
  1703. var condition string
  1704. var pars []interface{}
  1705. condition += ` AND enabled = ? `
  1706. pars = append(pars, 1)
  1707. adminItems, err := system.GetSysUserItems(condition, pars)
  1708. if err != nil {
  1709. return
  1710. }
  1711. br.Ret = 200
  1712. br.Success = true
  1713. br.Msg = "获取成功"
  1714. br.Data = adminItems
  1715. return
  1716. }
  1717. // AccountTransfer
  1718. // @Title 账号转移
  1719. // @Description 账号转移
  1720. // @Success 200
  1721. // @router /account/transfer [post]
  1722. func (this *ETATrialController) AccountTransfer() {
  1723. br := new(models.BaseResponse).Init()
  1724. defer func() {
  1725. this.Data["json"] = br
  1726. this.ServeJSON()
  1727. }()
  1728. sysUser := this.SysUser
  1729. if sysUser == nil {
  1730. br.Msg = "请登录"
  1731. br.ErrMsg = "请登录,SysUser Is Empty"
  1732. br.Ret = 408
  1733. return
  1734. }
  1735. var req eta_trial.TrialAccountTransferReq
  1736. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1737. if err != nil {
  1738. br.Msg = "参数解析异常!"
  1739. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1740. return
  1741. }
  1742. if len(req.EtaTrialIdList) <= 0 {
  1743. br.Msg = "参数有误"
  1744. br.ErrMsg = "参数有误, 至少选中一个试用用户"
  1745. return
  1746. }
  1747. err = eta_trial.TransferETATrial(&req)
  1748. if err != nil {
  1749. br.Msg = "转移失败!"
  1750. br.ErrMsg = "转移失败,Err:" + err.Error()
  1751. return
  1752. }
  1753. br.Ret = 200
  1754. br.Success = true
  1755. br.Msg = "获取成功"
  1756. return
  1757. }