manual_edb.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  1. package controllers
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/models/data_manage"
  5. "eta/eta_api/models/system"
  6. "eta/eta_api/utils"
  7. "github.com/rdlucklib/rdluck_tools/paging"
  8. )
  9. // EdbDetail
  10. // @Title 指标列表
  11. // @Description 指标列表
  12. // @Param TradeCode query string true "指标编码"
  13. // @Success 200 {object} models.TargetDetailResp
  14. // @router /target/edb/detail [get]
  15. func (this *TargetController) EdbDetail() {
  16. br := new(models.BaseResponse).Init()
  17. defer func() {
  18. this.Data["json"] = br
  19. this.ServeJSON()
  20. }()
  21. sysUser := this.SysUser
  22. if sysUser == nil {
  23. br.Msg = "请重新登录"
  24. return
  25. }
  26. // 指标编码
  27. tradeCode := this.GetString("TradeCode")
  28. if tradeCode == `` {
  29. br.Msg = "请输入指标编码"
  30. br.IsSendEmail = false
  31. return
  32. }
  33. manualEdbInfo, err := models.GetTargetByTradeCode(tradeCode)
  34. if err != nil {
  35. br.Msg = "获取指标失败"
  36. br.ErrMsg = "获取指标失败,err:" + err.Error()
  37. return
  38. }
  39. // 如果不是超管账号,那么得校验下当前用户是否有该指标的权限
  40. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  41. //获取账户所拥有权限的分类id集合
  42. count, err := models.GetCountManualUserClassify(sysUser.AdminId, manualEdbInfo.ClassifyId)
  43. if err != nil {
  44. br.Msg = "获取分类数据失败"
  45. br.ErrMsg = "获取分类数据失败,err:" + err.Error()
  46. return
  47. }
  48. if count <= 0 {
  49. br.Msg = "无权访问"
  50. br.ErrMsg = "无权访问"
  51. br.IsSendEmail = false
  52. return
  53. }
  54. }
  55. classifyList := make([]*models.EdbdataClassify, 0)
  56. {
  57. classify, err := models.GetManualClassifyByClassifyId(manualEdbInfo.ClassifyId)
  58. if err != nil {
  59. br.Msg = "获取分类信息失败"
  60. br.ErrMsg = "获取分类信息失败,err:" + err.Error()
  61. return
  62. }
  63. parentClassify, err := models.GetManualClassifyByClassifyId(classify.ParentId)
  64. if err != nil {
  65. br.Msg = "获取分类信息失败"
  66. br.ErrMsg = "获取父级分类信息失败,err:" + err.Error()
  67. return
  68. }
  69. classifyList = []*models.EdbdataClassify{
  70. parentClassify, classify,
  71. }
  72. }
  73. // 录入的用户名称
  74. adminInfo, err := system.GetSysAdminById(manualEdbInfo.UserId)
  75. if err == nil {
  76. manualEdbInfo.UserName = adminInfo.RealName
  77. }
  78. dataList, err := models.GetEdbDataListByCode(manualEdbInfo.TradeCode)
  79. if err != nil {
  80. br.Msg = "获取明细数据失败"
  81. br.ErrMsg = "获取明细数据失败,err:" + err.Error()
  82. return
  83. }
  84. manualEdbInfo.DataList = dataList
  85. resp := models.TargetDetailResp{
  86. Detail: manualEdbInfo,
  87. ClassifyList: classifyList,
  88. }
  89. br.Ret = 200
  90. br.Success = true
  91. br.Msg = "获取成功"
  92. //br.Data = resp
  93. br.Data = resp
  94. }
  95. // ClassifyEdbList
  96. // @Title 分类指标列表
  97. // @Description 指标列表
  98. // @Param ClassifyId query string true "分类id"
  99. // @Success 200 {object} models.TargetDetailResp
  100. // @router /target/classify/edb/list [get]
  101. func (this *TargetController) ClassifyEdbList() {
  102. br := new(models.BaseResponse).Init()
  103. defer func() {
  104. this.Data["json"] = br
  105. this.ServeJSON()
  106. }()
  107. sysUser := this.SysUser
  108. if sysUser == nil {
  109. br.Msg = "请登录"
  110. br.Ret = 408
  111. return
  112. }
  113. resp := new(models.EdbdataClassifyResp)
  114. classifyId, _ := this.GetInt("ClassifyId") //分类
  115. if classifyId <= 0 {
  116. br.Msg = "请传入分类"
  117. br.ErrMsg = "请传入分类"
  118. br.IsSendEmail = false
  119. }
  120. var condition string
  121. var pars []interface{}
  122. // 如果不是超管账号,那么得校验下当前用户是否有该指标的权限
  123. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  124. //获取账户所拥有权限的分类id集合
  125. count, err := models.GetCountManualUserClassify(sysUser.AdminId, classifyId)
  126. if err != nil {
  127. br.Msg = "获取分类数据失败"
  128. br.ErrMsg = "获取分类数据失败,err:" + err.Error()
  129. return
  130. }
  131. if count <= 0 {
  132. br.Msg = "无权访问"
  133. br.ErrMsg = "无权访问"
  134. br.IsSendEmail = false
  135. return
  136. }
  137. }
  138. list := make([]*models.EdbdataClassifyList, 0)
  139. condition += ` AND a.classify_id = ? `
  140. pars = append(pars, classifyId)
  141. tmpList, err := models.GetEdbInfoList(condition, pars, 0, 0)
  142. if err != nil {
  143. br.Msg = "获取失败"
  144. br.ErrMsg = "获取失败,Err:" + err.Error()
  145. return
  146. }
  147. for _, v := range tmpList {
  148. list = append(list, &models.EdbdataClassifyList{
  149. ClassifyId: 0,
  150. ClassifyName: v.SecName,
  151. ParentId: v.ClassifyId,
  152. Child: nil,
  153. TradeCode: v.TradeCode,
  154. UniqueCode: utils.MD5(v.TradeCode),
  155. })
  156. }
  157. resp.List = list
  158. br.Ret = 200
  159. br.Success = true
  160. br.Msg = "获取成功"
  161. br.Data = resp
  162. }
  163. // EdbSearch
  164. // @Title 指标搜索
  165. // @Description 指标搜索
  166. // @Param Keyword query string false "关键字搜索"
  167. // @Success 200 {object} models.TargetItemListResp
  168. // @router /target/edb/search [get]
  169. func (this *TargetController) EdbSearch() {
  170. br := new(models.BaseResponse).Init()
  171. defer func() {
  172. this.Data["json"] = br
  173. this.ServeJSON()
  174. }()
  175. sysUser := this.SysUser
  176. if sysUser == nil {
  177. br.Msg = "请重新登录"
  178. return
  179. }
  180. pageSize, _ := this.GetInt("PageSize")
  181. currentIndex, _ := this.GetInt("CurrentIndex")
  182. var startSize int
  183. if pageSize <= 0 {
  184. pageSize = utils.PageSize20
  185. }
  186. if currentIndex <= 0 {
  187. currentIndex = 1
  188. }
  189. startSize = utils.StartIndex(currentIndex, pageSize)
  190. //关键字
  191. keyword := this.GetString("Keyword")
  192. var condition string
  193. var pars []interface{}
  194. userId := sysUser.AdminId
  195. //超管账号可以查看分类下的所有频度数据
  196. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  197. classifyList, err := models.GetEdbdataClassify(int64(userId))
  198. if err != nil {
  199. br.Msg = "获取分类数据失败"
  200. br.Msg = "获取拥有的分类数据失败,Err:" + err.Error()
  201. return
  202. }
  203. num := len(classifyList)
  204. if num > 0 {
  205. classifyIdList := make([]int, 0)
  206. for _, v := range classifyList {
  207. classifyIdList = append(classifyIdList, v.ClassifyId)
  208. }
  209. condition += ` AND a.classify_id in (` + utils.GetOrmInReplace(num) + `) `
  210. pars = append(pars, classifyIdList)
  211. }
  212. }
  213. if keyword != "" {
  214. condition += ` AND (a.SEC_NAME like ? or a.TRADE_CODE like ? )`
  215. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  216. }
  217. total, err := models.GetCountEdbInfoList(condition, pars)
  218. if err != nil {
  219. br.Msg = "获取失败"
  220. br.ErrMsg = "获取失败,Err:" + err.Error()
  221. return
  222. }
  223. list, err := models.GetEdbInfoList(condition, pars, startSize, pageSize)
  224. if err != nil {
  225. br.Msg = "获取失败"
  226. br.ErrMsg = "获取失败,Err:" + err.Error()
  227. return
  228. }
  229. for _, v := range list {
  230. v.UniqueCode = utils.MD5(v.TradeCode)
  231. }
  232. resp := models.EdbListResp{
  233. List: list,
  234. Paging: paging.GetPaging(currentIndex, pageSize, total),
  235. }
  236. br.Ret = 200
  237. br.Success = true
  238. br.Msg = "获取成功"
  239. br.Data = resp
  240. }
  241. // EdbList
  242. // @Title 获取研究员指标
  243. // @Description 获取研究员指标
  244. // @Param Frequency query string false "频度;枚举值:日度、周度、月度、季度、半年度、年度"
  245. // @Param Keyword query string false "关键字搜索"
  246. // @Param TradeCode query string false "指标唯一编码"
  247. // @Param ClassifyId query int false "分类id"
  248. // @Param EdbShowType query string true "指标展示类型:0,1,2; 0:不管有没有数据,指标都展示出来, 1:只展示有数据的指标, 2:只展示没有数据的指标"
  249. // @Success 200 {object} models.TargetItemListResp
  250. // @router /target/edb/list [get]
  251. func (this *TargetController) EdbList() {
  252. br := new(models.BaseResponse).Init()
  253. defer func() {
  254. this.Data["json"] = br
  255. this.ServeJSON()
  256. }()
  257. sysUser := this.SysUser
  258. if sysUser == nil {
  259. br.Msg = "请重新登录"
  260. return
  261. }
  262. pageSize, _ := this.GetInt("PageSize")
  263. currentIndex, _ := this.GetInt("CurrentIndex")
  264. var startSize int
  265. if pageSize <= 0 {
  266. pageSize = utils.PageSize20
  267. }
  268. if currentIndex <= 0 {
  269. currentIndex = 1
  270. }
  271. startSize = utils.StartIndex(currentIndex, pageSize)
  272. //关键字
  273. keyword := this.GetString("Keyword")
  274. //关键字
  275. classifyId, _ := this.GetInt("ClassifyId", 0)
  276. var condition string
  277. var pars []interface{}
  278. userId := sysUser.AdminId
  279. //超管账号可以查看分类下的所有频度数据
  280. if sysUser.RoleTypeCode != utils.ROLE_TYPE_CODE_ADMIN {
  281. classifyList, err := models.GetEdbdataClassify(int64(userId))
  282. if err != nil {
  283. br.Msg = "获取分类数据失败"
  284. br.Msg = "获取拥有的分类数据失败,Err:" + err.Error()
  285. return
  286. }
  287. num := len(classifyList)
  288. if num > 0 {
  289. classifyIdList := make([]int, 0)
  290. for _, v := range classifyList {
  291. classifyIdList = append(classifyIdList, v.ClassifyId)
  292. }
  293. condition += ` AND a.classify_id in (` + utils.GetOrmInReplace(num) + `) `
  294. pars = append(pars, classifyIdList)
  295. }
  296. }
  297. // 关键词
  298. if keyword != "" {
  299. condition += ` AND (a.SEC_NAME like ? or a.TRADE_CODE like ? )`
  300. pars = utils.GetLikeKeywordPars(pars, keyword, 2)
  301. }
  302. // 所属分类
  303. if classifyId > 0 {
  304. condition += ` AND a.classify_id = ? `
  305. pars = append(pars, classifyId)
  306. }
  307. total, err := models.GetCountEdbInfoList(condition, pars)
  308. if err != nil {
  309. br.Msg = "获取失败"
  310. br.ErrMsg = "获取失败,Err:" + err.Error()
  311. return
  312. }
  313. list, err := models.GetEdbInfoList(condition, pars, startSize, pageSize)
  314. if err != nil {
  315. br.Msg = "获取失败"
  316. br.ErrMsg = "获取失败,Err:" + err.Error()
  317. return
  318. }
  319. edbCodeMap := make(map[string]bool)
  320. listNum := len(list)
  321. if listNum > 0 {
  322. tradeCodeList := make([]string, 0)
  323. for _, v := range list {
  324. v.UniqueCode = utils.MD5(v.TradeCode)
  325. tradeCodeList = append(tradeCodeList, v.TradeCode)
  326. }
  327. // 查找是否加入到指标库
  328. {
  329. var edbCondition string
  330. var edbPars []interface{}
  331. edbCondition = ` AND source = ? AND edb_code in (` + utils.GetOrmInReplace(listNum) + `) `
  332. edbPars = append(edbPars, utils.DATA_SOURCE_MANUAL, tradeCodeList)
  333. edbInfoList, err := data_manage.GetEdbInfoListByCond(edbCondition, edbPars)
  334. if err != nil {
  335. br.Msg = "获取失败"
  336. br.ErrMsg = "获取失败,Err:" + err.Error()
  337. return
  338. }
  339. for _, v := range edbInfoList {
  340. edbCodeMap[v.EdbCode] = true
  341. }
  342. }
  343. for _, v := range list {
  344. // 如果能通过指标编码下标找到,那么说明是加到指标库中
  345. if _, ok := edbCodeMap[v.TradeCode]; ok {
  346. v.EdbExist = 1
  347. }
  348. }
  349. }
  350. resp := models.EdbListResp{
  351. List: list,
  352. Paging: paging.GetPaging(currentIndex, pageSize, total),
  353. }
  354. br.Ret = 200
  355. br.Success = true
  356. br.Msg = "获取成功"
  357. br.Data = resp
  358. }