|
@@ -816,7 +816,7 @@ func (this *TradeCommonController) HisugarExporthisugarList() {
|
|
br.Msg = "success"
|
|
br.Msg = "success"
|
|
}
|
|
}
|
|
|
|
|
|
-// getHisugarClassifyTree 返回卓创红旗的树形结构
|
|
|
|
|
|
+// getHisugarClassifyTree 返回泛糖科技的树形结构
|
|
func getHisugarClassifyTree(items []*data_manage.BaseFromHisugarClassifyItem, parentId int) []*data_manage.BaseFromHisugarClassifyItem {
|
|
func getHisugarClassifyTree(items []*data_manage.BaseFromHisugarClassifyItem, parentId int) []*data_manage.BaseFromHisugarClassifyItem {
|
|
res := make([]*data_manage.BaseFromHisugarClassifyItem, 0)
|
|
res := make([]*data_manage.BaseFromHisugarClassifyItem, 0)
|
|
for _, item := range items {
|
|
for _, item := range items {
|
|
@@ -839,3 +839,134 @@ func getHisugarClassifyTree(items []*data_manage.BaseFromHisugarClassifyItem, pa
|
|
}
|
|
}
|
|
return res
|
|
return res
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+// FenweiIndexData
|
|
|
|
+// @Title 获取数据
|
|
|
|
+// @Description 获取泛糖科技数据接口
|
|
|
|
+// @Param PageSize query int true "每页数据条数"
|
|
|
|
+// @Param CurrentIndex query int true "当前页页码,从1开始"
|
|
|
|
+// @Param ClassifyId query string true "分类id"
|
|
|
|
+// @Param Frequency query string true "频率"
|
|
|
|
+// @Success 200 {object} data_manage.LzFrequency
|
|
|
|
+// @router /data/hisugar/index/data [get]
|
|
|
|
+func (this *TradeCommonController) FenweiIndexData() {
|
|
|
|
+ br := new(models.BaseResponse).Init()
|
|
|
|
+ defer func() {
|
|
|
|
+ if br.ErrMsg == "" {
|
|
|
|
+ br.IsSendEmail = false
|
|
|
|
+ }
|
|
|
|
+ this.Data["json"] = br
|
|
|
|
+ this.ServeJSON()
|
|
|
|
+ }()
|
|
|
|
+ sysUser := this.SysUser
|
|
|
|
+ if sysUser == nil {
|
|
|
|
+ br.Msg = "请登录"
|
|
|
|
+ br.ErrMsg = "请登录,SysUser Is Empty"
|
|
|
|
+ br.Ret = 408
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ pageSize, _ := this.GetInt("PageSize")
|
|
|
|
+ currentIndex, _ := this.GetInt("CurrentIndex")
|
|
|
|
+ var startSize int
|
|
|
|
+
|
|
|
|
+ if pageSize <= 0 {
|
|
|
|
+ pageSize = utils.PageSize20
|
|
|
|
+ }
|
|
|
|
+ if currentIndex <= 0 {
|
|
|
|
+ currentIndex = 1
|
|
|
|
+ }
|
|
|
|
+ startSize = utils.StartIndex(currentIndex, pageSize)
|
|
|
|
+
|
|
|
|
+ classifyId, _ := this.GetInt("ClassifyId")
|
|
|
|
+ if classifyId < 0 {
|
|
|
|
+ br.Msg = "请选择分类"
|
|
|
|
+ br.ErrMsg = "请选择分类"
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ frequency := this.GetString("Frequency")
|
|
|
|
+
|
|
|
|
+ // 获取指标
|
|
|
|
+ var condition string
|
|
|
|
+ var pars []interface{}
|
|
|
|
+ if classifyId >= 0 {
|
|
|
|
+ condition += ` AND classify_id=? `
|
|
|
|
+ pars = append(pars, classifyId)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if frequency != "" {
|
|
|
|
+ condition += ` AND frequency=? `
|
|
|
|
+ pars = append(pars, frequency)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ indexes, err := data_manage.GetHisugarIndex(condition, pars)
|
|
|
|
+ if err != nil {
|
|
|
|
+ br.Msg = "获取数据失败"
|
|
|
|
+ br.ErrMsg = "获取数据失败,Err:" + err.Error()
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ indexCodes := make([]string, 0)
|
|
|
|
+ for _, v := range indexes {
|
|
|
|
+ indexCodes = append(indexCodes, v.IndexCode)
|
|
|
|
+ }
|
|
|
|
+ indexCounts, e := data_manage.GetHisugarIndexDataCountGroup(indexCodes)
|
|
|
|
+ if e != nil {
|
|
|
|
+ br.Msg = "获取失败"
|
|
|
|
+ br.ErrMsg = "获取指标数据总量失败, Err:" + err.Error()
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ countMap := make(map[string]int)
|
|
|
|
+ for _, v := range indexCounts {
|
|
|
|
+ countMap[v.IndexCode] = v.Count
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 判断是否存在于指标库
|
|
|
|
+ edbCodeList, err := data_manage.GetEdbInfoByEdbCodeList(utils.DATA_SOURCE_HISUGAR, indexCodes)
|
|
|
|
+ if err != nil {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ edbCodeMap := make(map[string]*data_manage.EdbInfo)
|
|
|
|
+ for _, v := range edbCodeList {
|
|
|
|
+ edbCodeMap[v.EdbCode] = v
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ resultList := make([]*data_manage.BaseFromHisugarIndexList, 0)
|
|
|
|
+ for _, v := range indexes {
|
|
|
|
+ product := new(data_manage.BaseFromHisugarIndexList)
|
|
|
|
+ product.BaseFromHisugarIndexId = v.BaseFromHisugarIndexId
|
|
|
|
+ product.ClassifyId = v.ClassifyId
|
|
|
|
+ product.Unit = v.Unit
|
|
|
|
+ product.IndexCode = v.IndexCode
|
|
|
|
+ product.IndexName = v.IndexName
|
|
|
|
+ product.Frequency = v.Frequency
|
|
|
|
+ product.CreateTime = v.CreateTime
|
|
|
|
+ product.ModifyTime = v.ModifyTime
|
|
|
|
+
|
|
|
|
+ edbInfo := edbCodeMap[v.IndexCode]
|
|
|
|
+ if edbInfo != nil {
|
|
|
|
+ product.EdbInfoId = edbInfo.EdbInfoId
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ total := countMap[v.IndexCode]
|
|
|
|
+ page := paging.GetPaging(currentIndex, pageSize, total)
|
|
|
|
+ dataList, e := data_manage.GetHisugarIndexDataV2(v.IndexCode, startSize, pageSize)
|
|
|
|
+ if e != nil {
|
|
|
|
+ br.Msg = "获取数据失败"
|
|
|
|
+ br.ErrMsg = "获取指标数据失败,Err:" + e.Error()
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ if dataList == nil {
|
|
|
|
+ dataList = make([]*data_manage.BaseFromHisugarData, 0)
|
|
|
|
+ }
|
|
|
|
+ product.DataList = dataList
|
|
|
|
+ product.Paging = page
|
|
|
|
+ resultList = append(resultList, product)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ br.Ret = 200
|
|
|
|
+ br.Success = true
|
|
|
|
+ br.Msg = "获取成功"
|
|
|
|
+ br.Data = resultList
|
|
|
|
+}
|