chart_info.go 53 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694
  1. package chart
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. "github.com/shopspring/decimal"
  7. "hongze/hongze_yb/global"
  8. "hongze/hongze_yb/models/request"
  9. "hongze/hongze_yb/models/response/chart_info"
  10. chartEdbMappingModel "hongze/hongze_yb/models/tables/chart_edb_mapping"
  11. chartInfoModel "hongze/hongze_yb/models/tables/chart_info"
  12. company2 "hongze/hongze_yb/models/tables/company"
  13. edbDataModel "hongze/hongze_yb/models/tables/edb_data"
  14. edbInfoModel "hongze/hongze_yb/models/tables/edb_info"
  15. "hongze/hongze_yb/models/tables/my_chart_classify"
  16. "hongze/hongze_yb/models/tables/yb_chart_daily_visit_log"
  17. "hongze/hongze_yb/models/tables/yb_chart_visit_log"
  18. "hongze/hongze_yb/services/alarm_msg"
  19. edbDataService "hongze/hongze_yb/services/edb_data"
  20. "hongze/hongze_yb/services/user"
  21. "hongze/hongze_yb/utils"
  22. "math"
  23. "sort"
  24. "strconv"
  25. "strings"
  26. "time"
  27. )
  28. // ModifyChartInfoAndMapping 修改图表信息
  29. func ModifyChartInfoAndMapping(edbInfoIdStr string, req *chartInfoModel.SaveChartInfoReq, chartType int, chartEdbInfoList []*chartInfoModel.ChartSaveItem) (err error) {
  30. // 开启事务
  31. tx := global.MYSQL["data"].Begin()
  32. defer func() {
  33. if err != nil {
  34. tx.Rollback()
  35. } else {
  36. tx.Commit()
  37. }
  38. }()
  39. // 更新图表信息
  40. if chartType == 1 {
  41. sql := ` UPDATE chart_info
  42. SET
  43. edb_info_ids = ?,
  44. modify_time = NOW(),
  45. date_type = ?,
  46. start_date = ?,
  47. end_date = ?,
  48. left_min = ?,
  49. left_max = ?,
  50. right_min = ?,
  51. right_max = ?,extra_config = ?
  52. WHERE chart_info_id = ?`
  53. err = tx.Exec(sql, edbInfoIdStr, req.DateType, req.StartDate, req.EndDate, req.LeftMin, req.LeftMax, req.RightMin, req.RightMax, req.ExtraConfig, req.ChartInfoId).Error
  54. } else {
  55. sql := ` UPDATE chart_info
  56. SET
  57. edb_info_ids = ?,
  58. modify_time = NOW(),
  59. date_type = ?,
  60. calendar = ?,
  61. start_date = ?,
  62. end_date = ?,
  63. season_start_date = ?,
  64. season_end_date = ?,
  65. left_min = ?,
  66. left_max = ?,
  67. right_min = ?,
  68. right_max = ?,extra_config = ?
  69. WHERE chart_info_id = ?`
  70. err = tx.Exec(sql, edbInfoIdStr, req.DateType, req.Calendar, req.StartDate, req.EndDate, req.StartDate, req.EndDate, req.LeftMin, req.LeftMax, req.RightMin, req.RightMax, req.ExtraConfig, req.ChartInfoId).Error
  71. }
  72. if err != nil {
  73. fmt.Println("UPDATE chart_info Err:", err.Error())
  74. return
  75. }
  76. // 修改图表关联指标
  77. chartEdbMappingIdList := make([]string, 0)
  78. for _, v := range chartEdbInfoList {
  79. var tmpChartEdbMapping *chartEdbMappingModel.ChartEdbMapping
  80. csql := `SELECT * FROM chart_edb_mapping WHERE chart_info_id=? AND edb_info_id=? AND source = ? `
  81. err = tx.Raw(csql, req.ChartInfoId, v.EdbInfoId, utils.CHART_SOURCE_DEFAULT).First(&tmpChartEdbMapping).Error
  82. if err != nil && err != utils.ErrNoRow {
  83. fmt.Println("QueryRow Err:", err.Error())
  84. return err
  85. }
  86. if tmpChartEdbMapping == nil || tmpChartEdbMapping.ChartEdbMappingId == 0 {
  87. mapItem := new(chartEdbMappingModel.ChartEdbMapping)
  88. mapItem.ChartInfoId = req.ChartInfoId
  89. mapItem.EdbInfoId = v.EdbInfoId
  90. mapItem.CreateTime = time.Now()
  91. mapItem.ModifyTime = time.Now()
  92. timestamp := strconv.FormatInt(time.Now().UnixNano(), 10)
  93. mapItem.UniqueCode = utils.MD5(utils.CHART_PREFIX + "_" + timestamp)
  94. mapItem.MaxData = v.MaxData
  95. mapItem.MinData = v.MinData
  96. mapItem.IsOrder = 0
  97. if v.IsOrder {
  98. mapItem.IsOrder = 1
  99. }
  100. mapItem.IsAxis = v.IsAxis
  101. mapItem.EdbInfoType = v.EdbInfoType
  102. mapItem.LeadValue = v.LeadValue
  103. mapItem.LeadUnit = v.LeadUnit
  104. mapItem.ChartStyle = v.ChartStyle
  105. mapItem.ChartColor = v.ChartColor
  106. mapItem.ChartWidth = v.ChartWidth
  107. mapItem.Source = utils.CHART_SOURCE_DEFAULT
  108. err = tx.Create(mapItem).Error
  109. if err != nil {
  110. return
  111. }
  112. chartEdbMappingIdList = append(chartEdbMappingIdList, strconv.Itoa(mapItem.ChartEdbMappingId))
  113. } else {
  114. chartEdbMappingIdList = append(chartEdbMappingIdList, strconv.Itoa(tmpChartEdbMapping.ChartEdbMappingId))
  115. tmpChartEdbMapping.ModifyTime = time.Now()
  116. tmpChartEdbMapping.MaxData = v.MaxData
  117. tmpChartEdbMapping.MinData = v.MinData
  118. tmpChartEdbMapping.IsOrder = 0
  119. if v.IsOrder {
  120. tmpChartEdbMapping.IsOrder = 1
  121. }
  122. tmpChartEdbMapping.IsAxis = v.IsAxis
  123. tmpChartEdbMapping.EdbInfoType = v.EdbInfoType
  124. tmpChartEdbMapping.LeadValue = v.LeadValue
  125. tmpChartEdbMapping.LeadUnit = v.LeadUnit
  126. tmpChartEdbMapping.ChartStyle = v.ChartStyle
  127. tmpChartEdbMapping.ChartColor = v.ChartColor
  128. //tmpChartEdbMapping.PredictChartColor = v.PredictChartColor
  129. tmpChartEdbMapping.ChartWidth = v.ChartWidth
  130. err = tx.Model(tmpChartEdbMapping).Select([]string{"ModifyTime", "MaxData", "MinData", "IsOrder", "IsAxis", "EdbInfoType", "LeadValue", "LeadUnit", "ChartStyle", "ChartColor", "PredictChartColor", "ChartWidth"}).Updates(*tmpChartEdbMapping).Error
  131. if err != nil {
  132. fmt.Println("chart_edb_mapping Err:" + err.Error())
  133. return err
  134. }
  135. }
  136. }
  137. // 清除原图表指标
  138. if len(chartEdbMappingIdList) > 0 {
  139. chartEdbMappingIdStr := strings.Join(chartEdbMappingIdList, ",")
  140. dsql := `DELETE FROM chart_edb_mapping WHERE chart_info_id=? AND chart_edb_mapping_id NOT IN(` + chartEdbMappingIdStr + `)`
  141. err = tx.Exec(dsql, req.ChartInfoId).Error
  142. if err != nil {
  143. fmt.Println("delete err:" + err.Error())
  144. return err
  145. }
  146. }
  147. return
  148. }
  149. // GetChartInfoRefreshData 获取需要刷新的指标
  150. func GetChartInfoRefreshData(chartInfoId int) (baseEdbInfoArr, calculateInfoArr []*edbInfoModel.EdbInfo, err error) {
  151. sql := ` SELECT b.* FROM chart_edb_mapping AS a
  152. INNER JOIN edb_info AS b ON a.edb_info_id=b.edb_info_id
  153. WHERE a.chart_info_id=? `
  154. edbInfoList := make([]*edbInfoModel.EdbInfo, 0)
  155. err = global.MYSQL["data"].Raw(sql, chartInfoId).Scan(&edbInfoList).Error
  156. if err != nil {
  157. return
  158. }
  159. for _, v := range edbInfoList {
  160. fmt.Println(v.EdbInfoId, v.EdbType)
  161. if v.EdbType == 1 {
  162. baseEdbInfoArr = append(baseEdbInfoArr, v)
  163. } else {
  164. calculateInfoArr = append(calculateInfoArr, v)
  165. newBaseEdbInfoArr, newCalculateInfoArr, err := GetChartRefreshEdbInfo(v.EdbInfoId, v.Source, 0)
  166. if err != nil {
  167. return baseEdbInfoArr, calculateInfoArr, err
  168. }
  169. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  170. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  171. }
  172. }
  173. return
  174. }
  175. // GetChartRefreshEdbInfo
  176. func GetChartRefreshEdbInfo(edbInfoId, source, n int) (baseEdbInfoArr, calculateInfoArr []*edbInfoModel.EdbInfo, err error) {
  177. calculateList, err := GetEdbInfoCalculateMap(edbInfoId, source)
  178. if err != nil && err != utils.ErrNoRow {
  179. return
  180. }
  181. n++
  182. for _, item := range calculateList {
  183. fmt.Println(item.EdbInfoId)
  184. if item.EdbType == 1 {
  185. baseEdbInfoArr = append(baseEdbInfoArr, item)
  186. } else {
  187. calculateInfoArr = append(calculateInfoArr, item)
  188. if n > 10 {
  189. return
  190. }
  191. newBaseEdbInfoArr, newCalculateInfoArr, _ := GetChartRefreshEdbInfo(item.EdbInfoId, item.Source, n)
  192. baseEdbInfoArr = append(baseEdbInfoArr, newBaseEdbInfoArr...)
  193. calculateInfoArr = append(calculateInfoArr, newCalculateInfoArr...)
  194. }
  195. }
  196. return
  197. }
  198. func GetEdbInfoCalculateMap(edbInfoId, source int) (list []*edbInfoModel.EdbInfo, err error) {
  199. sql := ` SELECT b.* FROM edb_info_calculate_mapping AS a
  200. INNER JOIN edb_info AS b ON a.from_edb_info_id=b.edb_info_id
  201. WHERE a.edb_info_id=? ORDER BY sort ASC `
  202. err = global.MYSQL["data"].Exec(sql, edbInfoId).Error
  203. return
  204. }
  205. // SaveChartVisitLog 保存图表访问记录
  206. func SaveChartVisitLog(userInfo user.UserInfo, chartInfo *chartInfoModel.ChartInfoView, myChartClassifyId int) (err error) {
  207. userId := int(userInfo.UserID)
  208. companyId := int(userInfo.CompanyID)
  209. chartInfoId := chartInfo.ChartInfoId
  210. // 访问记录
  211. visitLog := new(yb_chart_visit_log.YbChartVisitLog)
  212. visitLog.CompanyId = companyId
  213. companyInfo, err := company2.GetByCompanyId(userInfo.CompanyID)
  214. if err == nil {
  215. visitLog.CompanyName = companyInfo.CompanyName
  216. }
  217. visitLog.UserId = userId
  218. visitLog.RealName = userInfo.RealName
  219. visitLog.Mobile = userInfo.Mobile
  220. visitLog.Email = userInfo.Email
  221. visitLog.ChartInfoId = chartInfoId
  222. visitLog.ChartName = chartInfo.ChartName
  223. visitLog.CreateTime = time.Now().Local()
  224. visitLog.Create()
  225. // 每日访问记录,用户/天/图仅记录一次
  226. if myChartClassifyId > 0 {
  227. // 今日是否已访问
  228. nowTime := time.Now().Local()
  229. startTime := time.Date(nowTime.Year(), nowTime.Month(), nowTime.Day(), 0, 0, 0, 0, time.Local)
  230. endTime := time.Date(nowTime.Year(), nowTime.Month(), nowTime.Day(), 23, 59, 59, 0, time.Local)
  231. _, tmpErr := yb_chart_daily_visit_log.GetTodayVisitLog(userId, chartInfoId, myChartClassifyId, startTime, endTime)
  232. if tmpErr == nil {
  233. return
  234. }
  235. myChartClassify, tmpErr := my_chart_classify.GetClassifyById(myChartClassifyId)
  236. if tmpErr != nil {
  237. return
  238. }
  239. dailyLog := new(yb_chart_daily_visit_log.YbChartDailyVisitLog)
  240. dailyLog.CompanyId = companyId
  241. if companyInfo != nil {
  242. dailyLog.CompanyName = companyInfo.CompanyName
  243. }
  244. dailyLog.UserId = userId
  245. dailyLog.RealName = userInfo.RealName
  246. dailyLog.Mobile = userInfo.Mobile
  247. dailyLog.Email = userInfo.Email
  248. dailyLog.ChartInfoId = chartInfoId
  249. dailyLog.ChartName = chartInfo.ChartName
  250. dailyLog.MyChartClassifyId = myChartClassifyId
  251. dailyLog.MyChartClassifyName = myChartClassify.MyChartClassifyName
  252. dailyLog.CreateTime = time.Now().Local()
  253. dailyLog.Create()
  254. }
  255. return
  256. }
  257. // RefreshChart 图表刷新
  258. func RefreshChart(chartInfoId int) (err error) {
  259. var errMsg string
  260. defer func() {
  261. if err != nil {
  262. if global.CONFIG.Serve.RunMode == "release" {
  263. //go services.SendEmail(utils.APPNAME+"【"+global.CONFIG.Serve.RunMode+"】"+"失败提醒", "RefreshChart:"+errMsg, utils.EmailSendToUsers)
  264. go alarm_msg.SendAlarmMsg("RefreshChart Err:"+errMsg, 3)
  265. }
  266. fmt.Println("RefreshChart Err:" + errMsg)
  267. }
  268. }()
  269. // 获取需要刷新的指标
  270. baseEdbInfoArr, calculateInfoArr, err := GetChartInfoRefreshData(chartInfoId)
  271. if err != nil {
  272. errMsg = "获取需要刷新的指标失败:Err:" + err.Error()
  273. return
  274. }
  275. newBaseEdbInfoArr := make([]*edbInfoModel.EdbInfo, 0)
  276. baseMap := make(map[int]*edbInfoModel.EdbInfo)
  277. for _, bv := range baseEdbInfoArr {
  278. // 如果不是普通指标,那么过滤
  279. if bv.EdbInfoType != 0 {
  280. continue
  281. }
  282. if _, ok := baseMap[bv.EdbInfoId]; !ok {
  283. newBaseEdbInfoArr = append(newBaseEdbInfoArr, bv)
  284. }
  285. baseMap[bv.EdbInfoId] = bv
  286. }
  287. newCalculateInfoArr := make([]*edbInfoModel.EdbInfo, 0)
  288. calculateMap := make(map[int]*edbInfoModel.EdbInfo)
  289. var calculateArr []int
  290. for _, bv := range calculateInfoArr {
  291. if _, ok := calculateMap[bv.EdbInfoId]; !ok {
  292. newCalculateInfoArr = append(newCalculateInfoArr, bv)
  293. calculateArr = append(calculateArr, bv.EdbInfoId)
  294. }
  295. calculateMap[bv.EdbInfoId] = bv
  296. }
  297. sort.Ints(calculateArr)
  298. // 刷新指标
  299. var startDate string
  300. for _, bv := range newBaseEdbInfoArr {
  301. source := bv.Source
  302. subSource := bv.SubSource
  303. edbInfoId := bv.EdbInfoId
  304. edbCode := bv.EdbCode
  305. startDate = bv.StartDate.Format(utils.FormatDate)
  306. frequency := bv.Frequency
  307. if startDate == "0000-00-00" {
  308. continue
  309. }
  310. sTime := bv.EndDate
  311. var limitDay int
  312. startDate := ""
  313. switch frequency {
  314. case "日度":
  315. limitDay = utils.DATA_START_REFRESH_LIMIT
  316. case "周度":
  317. limitDay = utils.DATA_START_REFRESH_LIMIT * 7
  318. case "月度":
  319. limitDay = utils.DATA_START_REFRESH_LIMIT * 30
  320. case "季度":
  321. limitDay = utils.DATA_START_REFRESH_LIMIT * 90
  322. case "年度":
  323. limitDay = utils.DATA_START_REFRESH_LIMIT * 365
  324. default:
  325. limitDay = utils.DATA_START_REFRESH_LIMIT
  326. }
  327. startDate = sTime.AddDate(0, 0, -limitDay).Format(utils.FormatDate)
  328. fmt.Println("source:", source)
  329. respItem, err := RefreshEdbData(edbInfoId, source, subSource, edbCode, startDate)
  330. if err != nil {
  331. errMsg = errors.New("RefreshEdbData Err:" + err.Error()).Error()
  332. return err
  333. }
  334. if respItem.Ret != 200 {
  335. errMsg = errors.New(respItem.ErrMsg + ";EdbCode:" + edbCode).Error()
  336. return err
  337. }
  338. //maxAndMinItem, err := edbDataModel.GetEdbInfoMaxAndMinInfo(source, edbCode)
  339. //if err != nil {
  340. // return err
  341. //}
  342. //if maxAndMinItem != nil {
  343. // err = edbDataModel.ModifyEdbInfoMaxAndMinInfo(edbInfoId, maxAndMinItem)
  344. // if err != nil {
  345. // return err
  346. // }
  347. //}
  348. }
  349. // 刷新计算指标
  350. for _, v := range calculateArr {
  351. edbInfo := calculateMap[v]
  352. if edbInfo == nil {
  353. return err
  354. }
  355. startDate = edbInfo.StartDate.Format(utils.FormatDate)
  356. source := edbInfo.Source
  357. if source == utils.DATA_SOURCE_CALCULATE {
  358. sTime := edbInfo.EndDate
  359. startDate = sTime.Format(utils.FormatDate)
  360. }
  361. result, err := RefreshEdbCalculateData(edbInfo.EdbInfoId, edbInfo.EdbCode, startDate)
  362. if err != nil {
  363. fmt.Println(v, "RefreshEdbCalculateData err", time.Now())
  364. errMsg = "RefreshEdbCalculateData Err:" + err.Error()
  365. return err
  366. }
  367. if result.Ret != 200 {
  368. fmt.Println(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
  369. errMsg = fmt.Sprint(v, "RefreshEdbCalculateData err;msg:", result.Msg, ";errMsg:", result.ErrMsg)
  370. return fmt.Errorf("刷新失败")
  371. }
  372. }
  373. return
  374. }
  375. // GetChartEdbData 获取图表的指标数据
  376. func GetChartEdbData(chartInfoId, chartType int, calendar, startDate, endDate string, mappingList []*chartEdbMappingModel.ChartEdbInfoMapping, extraConfigStr string, seasonExtraConfig string) (edbList []*chartEdbMappingModel.ChartEdbInfoMappingList, xEdbIdValue []int, yDataList []chart_info.YData, sourceArr []string, dataResp interface{}, err error, errMsg string) {
  377. edbList = make([]*chartEdbMappingModel.ChartEdbInfoMappingList, 0)
  378. xEdbIdValue = make([]int, 0)
  379. yDataList = make([]chart_info.YData, 0)
  380. var extraConfig interface{}
  381. switch chartType {
  382. case 7: // 柱形图
  383. var barConfig request.BarChartInfoReq
  384. if extraConfigStr == `` {
  385. errMsg = "柱方图未配置"
  386. err = errors.New(errMsg)
  387. return
  388. }
  389. err = json.Unmarshal([]byte(extraConfigStr), &barConfig)
  390. if err != nil {
  391. errMsg = "柱方图配置异常"
  392. err = errors.New(errMsg)
  393. return
  394. }
  395. extraConfig = barConfig
  396. case 10: // 截面散点图
  397. var tmpExtraConfig request.SectionScatterReq
  398. if extraConfigStr == `` {
  399. errMsg = "截面散点图未配置"
  400. err = errors.New(errMsg)
  401. return
  402. }
  403. err = json.Unmarshal([]byte(extraConfigStr), &tmpExtraConfig)
  404. if err != nil {
  405. errMsg = "截面散点配置异常"
  406. err = errors.New(errMsg)
  407. return
  408. }
  409. extraConfig = tmpExtraConfig
  410. }
  411. // 指标对应的所有数据
  412. edbDataListMap, edbList, sourceArr, err := getEdbDataMapList(chartInfoId, chartType, calendar, startDate, endDate, mappingList, seasonExtraConfig)
  413. if err != nil {
  414. return
  415. }
  416. // 特殊图形数据处理
  417. switch chartType {
  418. case 7: // 柱形图
  419. barChartConf := extraConfig.(request.BarChartInfoReq)
  420. xEdbIdValue, yDataList, err = BarChartData(mappingList, edbDataListMap, barChartConf.DateList, barChartConf.Sort)
  421. for _, v := range edbList {
  422. // 指标别名
  423. if barChartConf.EdbInfoIdList != nil && len(barChartConf.EdbInfoIdList) > 0 {
  424. for _, reqEdb := range barChartConf.EdbInfoIdList {
  425. if v.EdbInfoId == reqEdb.EdbInfoId {
  426. v.EdbAliasName = reqEdb.Name
  427. }
  428. }
  429. }
  430. }
  431. case 10: // 截面散点图
  432. sectionScatterConf := extraConfig.(request.SectionScatterReq)
  433. xEdbIdValue, dataResp, err = GetSectionScatterChartData(mappingList, edbDataListMap, sectionScatterConf)
  434. // 这个数据没有必要返回给前端
  435. for _, v := range edbList {
  436. v.DataList = nil
  437. }
  438. }
  439. return
  440. }
  441. // GetEdbDataMapList 获取指标最后的基础数据
  442. func GetEdbDataMapList(chartInfoId, chartType int, calendar, startDate, endDate string, mappingList []*chartEdbMappingModel.ChartEdbInfoMapping, seasonExtraConfig string) (edbDataListMap map[int][]*edbDataModel.EdbDataList, edbList []*chartEdbMappingModel.ChartEdbInfoMappingList, sourceArr []string, err error) {
  443. edbDataListMap, edbList, sourceArr, err = getEdbDataMapList(chartInfoId, chartType, calendar, startDate, endDate, mappingList, seasonExtraConfig)
  444. return
  445. }
  446. // getEdbDataMapList 获取指标最后的基础数据
  447. func getEdbDataMapList(chartInfoId, chartType int, calendar, startDate, endDate string, mappingList []*chartEdbMappingModel.ChartEdbInfoMapping, seasonExtraConfig string) (edbDataListMap map[int][]*edbDataModel.EdbDataList, edbList []*chartEdbMappingModel.ChartEdbInfoMappingList, sourceArr []string, err error) {
  448. // 关联指标来源
  449. sourceArr = make([]string, 0)
  450. // 指标对应的所有数据
  451. edbDataListMap = make(map[int][]*edbDataModel.EdbDataList)
  452. for _, v := range mappingList {
  453. //fmt.Println("v:", v.EdbInfoId)
  454. item := new(chartEdbMappingModel.ChartEdbInfoMappingList)
  455. item.EdbInfoId = v.EdbInfoId
  456. item.SourceName = v.SourceName
  457. item.Source = v.Source
  458. item.EdbCode = v.EdbCode
  459. item.EdbName = v.EdbName
  460. item.EdbNameEn = v.EdbNameEn
  461. item.Frequency = v.Frequency
  462. item.FrequencyEn = GetFrequencyEn(v.Frequency)
  463. if v.Unit != `无` {
  464. item.Unit = v.Unit
  465. }
  466. item.UnitEn = v.UnitEn
  467. item.StartDate = v.StartDate
  468. item.EndDate = v.EndDate
  469. item.ModifyTime = v.ModifyTime
  470. item.EdbInfoCategoryType = v.EdbInfoCategoryType
  471. item.PredictChartColor = v.PredictChartColor
  472. item.EdbAliasName = v.EdbAliasName
  473. if !utils.InArray(v.Source, utils.SystemSourceList) { //来源于系统的指标,都展示为弘则研究
  474. if !utils.InArray(v.SourceName, sourceArr) {
  475. sourceArr = append(sourceArr, v.SourceName)
  476. }
  477. }
  478. if chartInfoId <= 0 {
  479. item.IsAxis = 1
  480. item.LeadValue = 0
  481. item.LeadUnit = ""
  482. item.ChartEdbMappingId = 0
  483. item.ChartInfoId = 0
  484. item.IsOrder = false
  485. item.EdbInfoType = 1
  486. item.ChartStyle = ""
  487. item.ChartColor = ""
  488. item.ChartWidth = 0
  489. item.MaxData = v.MaxValue
  490. item.MinData = v.MinValue
  491. } else {
  492. item.IsAxis = v.IsAxis
  493. item.EdbInfoType = v.EdbInfoType
  494. item.LeadValue = v.LeadValue
  495. item.LeadUnit = v.LeadUnit
  496. item.LeadUnitEn = GetLeadUnitEn(v.LeadUnit)
  497. item.ChartEdbMappingId = v.ChartEdbMappingId
  498. item.ChartInfoId = v.ChartInfoId
  499. item.ChartStyle = v.ChartStyle
  500. item.ChartColor = v.ChartColor
  501. item.ChartWidth = v.ChartWidth
  502. item.IsOrder = v.IsOrder
  503. item.MaxData = v.MaxData
  504. item.MinData = v.MinData
  505. }
  506. item.LatestValue = v.LatestValue
  507. item.LatestDate = v.LatestDate
  508. item.UniqueCode = v.UniqueCode
  509. item.MoveLatestDate = item.LatestDate
  510. var startDateReal string
  511. var diffSeconds int64
  512. if chartType == 2 { //季节性图
  513. startDateReal = startDate
  514. } else {
  515. if v.EdbInfoType == 0 && v.LeadUnit != "" && v.LeadValue > 0 { //领先指标
  516. var startTimeRealTemp time.Time
  517. startDateParse, _ := time.Parse(utils.FormatDate, startDate)
  518. switch v.LeadUnit {
  519. case "天":
  520. startTimeRealTemp = startDateParse.AddDate(0, 0, -v.LeadValue)
  521. case "月":
  522. startTimeRealTemp = startDateParse.AddDate(0, -v.LeadValue, 0)
  523. case "季":
  524. startTimeRealTemp = startDateParse.AddDate(0, -3*v.LeadValue, 0)
  525. case "周":
  526. startTimeRealTemp = startDateParse.AddDate(0, 0, -7*v.LeadValue)
  527. case "年":
  528. startTimeRealTemp = startDateParse.AddDate(-v.LeadValue, 0, 0)
  529. }
  530. if startTimeRealTemp.Before(startDateParse) {
  531. startDateReal = startTimeRealTemp.Format(utils.FormatDate)
  532. diffSeconds = (int64(startTimeRealTemp.UnixNano()) - int64(startDateParse.UnixNano())) / 1e6
  533. } else {
  534. startDateReal = startDate
  535. diffSeconds = 0
  536. }
  537. // 预测指标的开始日期也要偏移
  538. {
  539. day, tmpErr := utils.GetDaysBetween2Date(utils.FormatDate, startDate, startDateReal)
  540. if tmpErr != nil {
  541. err = tmpErr
  542. return
  543. }
  544. item.MoveLatestDate = item.MoveLatestDate.AddDate(0, 0, day)
  545. }
  546. } else {
  547. startDateReal = startDate
  548. }
  549. }
  550. //fmt.Println("line 1011 chart:", v.Source, v.EdbInfoId, startDateReal, endDate)
  551. calendarPreYear := 0
  552. if calendar == "农历" {
  553. newStartDateReal, err := time.Parse(utils.FormatDate, startDateReal)
  554. if err != nil {
  555. fmt.Println("time.Parse:" + err.Error())
  556. }
  557. calendarPreYear = newStartDateReal.Year() - 1
  558. newStartDateReal = newStartDateReal.AddDate(-1, 0, 0)
  559. startDateReal = newStartDateReal.Format(utils.FormatDate)
  560. }
  561. dataList := make([]*edbDataModel.EdbDataList, 0)
  562. //fmt.Println("chart:", v.Source, v.EdbInfoId, startDateReal, endDate, ";EdbInfoCategoryType:", v.EdbInfoCategoryType)
  563. //var newEdbInfo *edbInfoModel.EdbInfo
  564. switch v.EdbInfoCategoryType {
  565. case 0:
  566. dataList, err = edbDataModel.GetEdbDataList(v.Source, v.SubSource, v.EdbInfoId, startDateReal, endDate)
  567. case 1:
  568. _, dataList, _, _, err, _ = GetPredictDataListByPredictEdbInfoId(v.EdbInfoId, startDateReal, endDate, false)
  569. //if item.MaxValue < newEdbInfo.MaxValue {
  570. // item.MaxData = newEdbInfo.MaxValue
  571. //}
  572. //if item.MinData > newEdbInfo.MinValue {
  573. // item.MinData = newEdbInfo.MinValue
  574. //}
  575. default:
  576. err = errors.New(fmt.Sprint("获取失败,指标类型异常", v.EdbInfoCategoryType))
  577. }
  578. if err != nil {
  579. return
  580. }
  581. edbDataListMap[v.EdbInfoId] = dataList
  582. if diffSeconds != 0 && v.EdbInfoType == 0 {
  583. dataListLen := len(dataList)
  584. for i := 0; i < dataListLen; i++ {
  585. dataList[i].DataTimestamp = dataList[i].DataTimestamp - diffSeconds
  586. }
  587. }
  588. if chartType == 2 {
  589. //latestDateStr := v.LatestDate.Format(utils.FormatDate) //实际数据的截止日期
  590. latestDate := v.LatestDate
  591. if calendar == "农历" {
  592. if len(dataList) <= 0 {
  593. result := new(edbDataModel.EdbDataResult)
  594. item.DataList = result
  595. } else {
  596. result, tmpErr := edbDataService.AddCalculateQuarterV6(dataList)
  597. if tmpErr != nil {
  598. err = errors.New("获取农历数据失败,Err:" + tmpErr.Error())
  599. return
  600. }
  601. quarterDataList, tErr := GetSeasonEdbInfoDataListByXDateNong(result, latestDate, seasonExtraConfig, calendarPreYear)
  602. if tErr != nil {
  603. err = errors.New("获取季节性图表数据失败,Err:" + tErr.Error())
  604. return
  605. }
  606. item.DataList = quarterDataList
  607. }
  608. } else {
  609. quarterDataList, tErr := GetSeasonEdbInfoDataListByXDate(dataList, latestDate, seasonExtraConfig)
  610. if tErr != nil {
  611. err = errors.New("获取季节性图表数据失败,Err:" + tErr.Error())
  612. return
  613. }
  614. item.DataList = quarterDataList
  615. }
  616. } else if chartType == 7 { //柱方图
  617. //item.DataList = dataList
  618. } else {
  619. item.DataList = dataList
  620. }
  621. edbList = append(edbList, item)
  622. }
  623. return
  624. }
  625. // GetSeasonEdbInfoDataListByXDate 季节性图的指标数据根据横轴展示
  626. func GetSeasonEdbInfoDataListByXDate(dataList []*edbDataModel.EdbDataList, latestDate time.Time, seasonExtraConfig string) (quarterDataListSort edbDataModel.QuarterDataList, err error) {
  627. xStartDate := "01-01"
  628. xEndDate := "12-31"
  629. jumpYear := 0
  630. legends := make([]edbDataModel.SeasonChartLegend, 0)
  631. var seasonExtra edbDataModel.SeasonExtraItem
  632. if seasonExtraConfig != "" {
  633. err = json.Unmarshal([]byte(seasonExtraConfig), &seasonExtra)
  634. if err != nil {
  635. return
  636. }
  637. }
  638. if seasonExtra.XStartDate != "" {
  639. xStartDate = seasonExtra.XStartDate
  640. xEndDate = seasonExtra.XEndDate
  641. jumpYear = seasonExtra.JumpYear
  642. legends = seasonExtra.ChartLegend
  643. }
  644. length := len(dataList)
  645. if length == 0 {
  646. return
  647. }
  648. legendMap := make(map[string]string, 0)
  649. if len(legends) > 0 {
  650. for _, v := range legends {
  651. legendMap[v.Name] = v.Value
  652. }
  653. }
  654. latestDateStr := latestDate.Format(utils.FormatDate)
  655. //判断横轴的两个时间之间是不是跨年了,如果跨年了,则横轴截止年份比起始年份+1,如果不跨年,截止年份等于起始年份
  656. //根据数据确定最早的年份,和最近年份
  657. //根据横轴的日期,汇总所有的年份
  658. startDate := dataList[0].DataTime
  659. startDateT, tmpErr := time.Parse(utils.FormatDate, startDate)
  660. if tmpErr != nil {
  661. err = tmpErr
  662. return
  663. }
  664. startYear := startDateT.Year()
  665. //获取数据的最新日期
  666. lastDate := dataList[length-1].DataTime
  667. lastDateT, tmpErr := time.Parse(utils.FormatDate, lastDate)
  668. if tmpErr != nil {
  669. err = tmpErr
  670. return
  671. }
  672. endYear := lastDateT.Year()
  673. nowYear := time.Now().Year()
  674. dataMap := make(map[string]edbDataModel.QuarterXDateItem, 0)
  675. quarterDataList := make([]*edbDataModel.QuarterData, 0)
  676. quarterMap := make(map[string][]*edbDataModel.EdbDataList, 0)
  677. //整理出日期
  678. idx := 1
  679. chartLegendMap := make(map[string]int, 0)
  680. for currentStartYear := startYear; currentStartYear <= endYear; currentStartYear++ {
  681. startStr := fmt.Sprintf("%d-%s", currentStartYear, xStartDate)
  682. currentEndYear := currentStartYear
  683. if jumpYear == 1 {
  684. currentEndYear = currentStartYear + 1
  685. }
  686. endStr := fmt.Sprintf("%d-%s", currentEndYear, xEndDate)
  687. name := fmt.Sprintf("%s_%s", startStr, endStr)
  688. showName := fmt.Sprintf("%d_%d", currentStartYear, currentEndYear)
  689. startT, tEr := time.Parse(utils.FormatDate, startStr)
  690. if tEr != nil {
  691. err = tEr
  692. return
  693. }
  694. endT, tEr := time.Parse(utils.FormatDate, endStr)
  695. if tEr != nil {
  696. err = tEr
  697. return
  698. }
  699. if lastDateT.Before(startT) {
  700. //如果最新的日期在起始日之前,则跳出循环
  701. break
  702. }
  703. if endT.Year() > nowYear {
  704. //如果最新的日期比真实年份要大,则数据全部按照最大的年份补齐
  705. nowYear = endT.Year()
  706. }
  707. item := edbDataModel.QuarterXDateItem{
  708. StartDate: startT,
  709. EndDate: endT,
  710. ShowName: showName,
  711. }
  712. dataMap[name] = item
  713. chartLegendMap[name] = idx
  714. idx++
  715. if lastDateT.Before(endT) {
  716. //如果最新的日期在起始日之前,则跳出循环
  717. break
  718. }
  719. }
  720. lenYear := len(dataMap)
  721. for k, v := range dataMap {
  722. if i, ok := chartLegendMap[k]; ok {
  723. v.ChartLegend = strconv.Itoa(endYear - lenYear + i)
  724. }
  725. dataMap[k] = v
  726. }
  727. for _, v := range dataList {
  728. dataTimeT, _ := time.Parse(utils.FormatDate, v.DataTime)
  729. year := dataTimeT.Year()
  730. newItemDate := dataTimeT.AddDate(nowYear-year, 0, 0)
  731. for k, dateItem := range dataMap {
  732. tmpVal := edbDataModel.EdbDataList{
  733. EdbDataId: v.EdbDataId,
  734. EdbInfoId: v.EdbInfoId,
  735. DataTime: v.DataTime,
  736. DataTimestamp: v.DataTimestamp,
  737. Value: v.Value,
  738. }
  739. if (dateItem.StartDate.Before(dataTimeT) && dateItem.EndDate.After(dataTimeT)) || dateItem.StartDate == dataTimeT || dateItem.EndDate == dataTimeT {
  740. if jumpYear == 1 {
  741. //计算前一年最大的日期, 只补齐数据到去年
  742. beforeYearMaxDate := fmt.Sprintf("%d-12-31", dateItem.StartDate.Year())
  743. beforeYearMaxDateT, _ := time.Parse(utils.FormatDate, beforeYearMaxDate)
  744. if dataTimeT.Before(beforeYearMaxDateT) || dataTimeT == beforeYearMaxDateT {
  745. newItemDate = dataTimeT.AddDate(nowYear-year-1, 0, 0)
  746. } else {
  747. newItemDate = dataTimeT.AddDate(nowYear-year, 0, 0)
  748. }
  749. } else {
  750. newItemDate = dataTimeT.AddDate(nowYear-year, 0, 0)
  751. }
  752. timestamp := newItemDate.UnixNano() / 1e6
  753. tmpVal.DataTimestamp = timestamp
  754. tmpV := &tmpVal
  755. if findVal, ok := quarterMap[k]; !ok {
  756. findVal = append(findVal, tmpV)
  757. quarterMap[k] = findVal
  758. } else {
  759. findVal = append(findVal, tmpV)
  760. quarterMap[k] = findVal
  761. }
  762. if v.DataTime == latestDateStr {
  763. dateItem.CuttingDataTimestamp = timestamp
  764. dataMap[k] = dateItem
  765. }
  766. //break
  767. }
  768. }
  769. }
  770. for k, v := range dataMap {
  771. itemList := quarterMap[k]
  772. quarterItem := new(edbDataModel.QuarterData)
  773. quarterItem.Years = v.ShowName
  774. quarterItem.Year = v.ChartLegend
  775. quarterItem.ChartLegend = v.ChartLegend
  776. if le, ok := legendMap[v.ShowName]; ok {
  777. if le != strconv.Itoa(v.StartDate.Year()) && le != strconv.Itoa(v.EndDate.Year()) {
  778. quarterItem.ChartLegend = le
  779. }
  780. }
  781. quarterItem.DataList = itemList
  782. quarterItem.CuttingDataTimestamp = v.CuttingDataTimestamp
  783. //如果等于最后的实际日期,那么将切割时间戳记录
  784. if quarterItem.CuttingDataTimestamp == 0 {
  785. //如果大于最后的实际日期,那么第一个点就是切割的时间戳
  786. if latestDate.Before(v.StartDate) && len(itemList) > 0 {
  787. quarterItem.CuttingDataTimestamp = itemList[0].DataTimestamp - 100
  788. }
  789. }
  790. quarterDataList = append(quarterDataList, quarterItem)
  791. }
  792. if len(quarterDataList) > 0 {
  793. quarterDataListSort = quarterDataList
  794. sort.Sort(quarterDataListSort)
  795. }
  796. return
  797. }
  798. // GetSeasonEdbInfoDataListByXDateNong 季节性图的指标数据根据横轴选择农历时展示
  799. func GetSeasonEdbInfoDataListByXDateNong(result *edbDataModel.EdbDataResult, latestDate time.Time, seasonExtraConfig string, calendarPreYear int) (quarterDataListSort edbDataModel.QuarterDataList, err error) {
  800. xStartDate := "01-01"
  801. xEndDate := "12-31"
  802. jumpYear := 0
  803. legends := make([]edbDataModel.SeasonChartLegend, 0)
  804. var seasonExtra edbDataModel.SeasonExtraItem
  805. if seasonExtraConfig != "" {
  806. err = json.Unmarshal([]byte(seasonExtraConfig), &seasonExtra)
  807. if err != nil {
  808. return
  809. }
  810. }
  811. if seasonExtra.XStartDate != "" {
  812. xStartDate = seasonExtra.XStartDate
  813. xEndDate = seasonExtra.XEndDate
  814. jumpYear = seasonExtra.JumpYear
  815. legends = seasonExtra.ChartLegend
  816. }
  817. length := len(result.List)
  818. if length == 0 {
  819. return
  820. }
  821. legendMap := make(map[string]string, 0)
  822. if len(legends) > 0 {
  823. for _, v := range legends {
  824. legendMap[v.Name] = v.Value
  825. }
  826. }
  827. latestDateYear := latestDate.Year()
  828. //判断横轴的两个时间之间是不是跨年了,如果跨年了,则横轴截止年份比起始年份+1,如果不跨年,截止年份等于起始年份
  829. //根据数据确定最早的年份,和最近年份
  830. //根据横轴的日期,汇总所有的年份
  831. startYear := result.List[0].Year
  832. /*if jumpYear == 1 {
  833. if startYear != calendarPreYear {
  834. startYear = startYear - 1
  835. }
  836. }*/
  837. itemLength := len(result.List[length-1].Items)
  838. //获取数据的最新日期
  839. lastDate := result.List[length-1].Items[itemLength-1].DataTime
  840. maxY := result.List[length-1].Year
  841. lastDateT, tmpErr := time.Parse(utils.FormatDate, lastDate)
  842. if tmpErr != nil {
  843. err = tmpErr
  844. return
  845. }
  846. endYear := lastDateT.Year()
  847. nowYear := time.Now().Year()
  848. dataMap := make(map[string]edbDataModel.QuarterXDateItem, 0)
  849. quarterDataList := make([]*edbDataModel.QuarterData, 0)
  850. resultData := make([]*edbDataModel.QuarterData, 0)
  851. quarterMap := make(map[string][]*edbDataModel.EdbDataList, 0)
  852. //整理出日期
  853. var startTmpT, endTmpT time.Time
  854. idx := 1
  855. chartLegendMap := make(map[string]int, 0)
  856. for currentStartYear := startYear; currentStartYear <= endYear; currentStartYear++ {
  857. startStr := fmt.Sprintf("%d-%s", currentStartYear, xStartDate)
  858. currentEndYear := currentStartYear
  859. if jumpYear == 1 {
  860. currentEndYear = currentStartYear + 1
  861. }
  862. endStr := fmt.Sprintf("%d-%s", currentEndYear, xEndDate)
  863. showName := fmt.Sprintf("%d_%d", currentStartYear, currentEndYear)
  864. startT, tEr := time.Parse(utils.FormatDate, startStr)
  865. if tEr != nil {
  866. err = tEr
  867. return
  868. }
  869. endT, tEr := time.Parse(utils.FormatDate, endStr)
  870. if tEr != nil {
  871. err = tEr
  872. return
  873. }
  874. if lastDateT.Before(startT) {
  875. //如果最新的日期在起始日之前,则跳出循环
  876. break
  877. }
  878. if endT.Year() > nowYear {
  879. //如果最新的日期比真实年份要大,则数据全部按照最大的年份补齐
  880. nowYear = endT.Year()
  881. }
  882. item := edbDataModel.QuarterXDateItem{
  883. StartDate: startT,
  884. EndDate: endT,
  885. ShowName: showName,
  886. }
  887. dataMap[showName] = item
  888. fmt.Println("年份" + showName + "日期" + startStr + " " + endStr)
  889. startTmpT = startT
  890. endTmpT = endT
  891. chartLegendMap[showName] = idx
  892. idx++
  893. if lastDateT.Before(endT) {
  894. //如果最新的日期在起始日之前,则跳出循环
  895. break
  896. }
  897. }
  898. lenYear := len(dataMap)
  899. for k, v := range dataMap {
  900. if i, ok := chartLegendMap[k]; ok {
  901. v.ChartLegend = strconv.Itoa(endYear - lenYear + i)
  902. }
  903. dataMap[k] = v
  904. }
  905. yearDataListMap := make(map[int]*edbDataModel.EdbDataItems, 0)
  906. for _, lv := range result.List {
  907. yearDataListMap[lv.Year] = lv
  908. }
  909. fmt.Println("横轴截取日" + startTmpT.Format(utils.FormatDate) + " " + endTmpT.Format(utils.FormatDate))
  910. fmt.Printf("lastDateT.Year() 为%d \n", lastDateT.Year())
  911. fmt.Printf("maxY 为%d \n", maxY)
  912. for name, dateItem := range dataMap {
  913. tY := dateItem.EndDate.Year()
  914. if lastDateT.Month() >= 11 {
  915. if maxY > endTmpT.Year() {
  916. tY = tY + 1
  917. }
  918. }
  919. lv, ok1 := yearDataListMap[tY]
  920. fmt.Printf("name %s yearDataListMap[%d]\n", name, tY)
  921. if !ok1 {
  922. continue
  923. }
  924. for _, item := range lv.Items {
  925. tmpVal := edbDataModel.EdbDataList{
  926. EdbDataId: item.EdbDataId,
  927. EdbInfoId: item.EdbInfoId,
  928. DataTime: item.DataTime,
  929. DataTimestamp: item.DataTimestamp,
  930. Value: item.Value,
  931. }
  932. dataTimeT, _ := time.Parse(utils.FormatDate, item.DataTime)
  933. if (startTmpT.Before(dataTimeT) && endTmpT.After(dataTimeT)) || startTmpT == dataTimeT || endTmpT == dataTimeT {
  934. tmpV := &tmpVal
  935. if findVal, ok := quarterMap[name]; !ok {
  936. findVal = append(findVal, tmpV)
  937. quarterMap[name] = findVal
  938. } else {
  939. findVal = append(findVal, tmpV)
  940. quarterMap[name] = findVal
  941. }
  942. if lv.Year >= latestDateYear {
  943. // 切割的日期时间字符串
  944. cuttingDataTimeStr := latestDate.AddDate(0, 0, lv.BetweenDay).Format(utils.FormatDate)
  945. if item.DataTime == cuttingDataTimeStr {
  946. dateItem.CuttingDataTimestamp = tmpVal.DataTimestamp
  947. dataMap[name] = dateItem
  948. }
  949. }
  950. }
  951. }
  952. }
  953. for k, v := range dataMap {
  954. itemList := quarterMap[k]
  955. quarterItem := new(edbDataModel.QuarterData)
  956. quarterItem.Years = v.ShowName
  957. quarterItem.Year = v.ChartLegend
  958. quarterItem.ChartLegend = v.ChartLegend
  959. if le, ok := legendMap[v.ShowName]; ok {
  960. if le != strconv.Itoa(v.StartDate.Year()) && le != strconv.Itoa(v.EndDate.Year()) {
  961. quarterItem.ChartLegend = le
  962. }
  963. }
  964. quarterItem.DataList = itemList
  965. quarterItem.CuttingDataTimestamp = v.CuttingDataTimestamp
  966. //如果等于最后的实际日期,那么将切割时间戳记录
  967. if quarterItem.CuttingDataTimestamp == 0 {
  968. //如果大于最后的实际日期,那么第一个点就是切割的时间戳
  969. if latestDate.Before(v.StartDate) && len(itemList) > 0 {
  970. quarterItem.CuttingDataTimestamp = itemList[0].DataTimestamp - 100
  971. }
  972. }
  973. quarterDataList = append(quarterDataList, quarterItem)
  974. }
  975. if result.List[0].Year != calendarPreYear {
  976. itemList := make([]*edbDataModel.EdbDataList, 0)
  977. items := new(edbDataModel.QuarterData)
  978. //items.Year = calendarPreYear
  979. items.DataList = itemList
  980. newResult := make([]*edbDataModel.QuarterData, 0)
  981. newResult = append(newResult, items)
  982. newResult = append(newResult, quarterDataList...)
  983. resultData = newResult
  984. } else {
  985. resultData = quarterDataList
  986. }
  987. if len(quarterDataList) > 0 {
  988. quarterDataListSort = resultData
  989. sort.Sort(quarterDataListSort)
  990. }
  991. return
  992. }
  993. // BarChartData 柱方图的数据处理
  994. func BarChartData(mappingList []*chartEdbMappingModel.ChartEdbInfoMapping, edbDataListMap map[int][]*edbDataModel.EdbDataList, barChartInfoDateList []request.BarChartInfoDateReq, barChartInfoSort request.BarChartInfoSortReq) (edbIdList []int, yDataList []chart_info.YData, err error) {
  995. // 指标数据数组(10086:{"2022-12-02":100.01,"2022-12-01":102.3})
  996. edbDataMap := make(map[int]map[string]float64)
  997. for edbInfoId, edbDataList := range edbDataListMap {
  998. edbDateData := make(map[string]float64)
  999. for _, edbData := range edbDataList {
  1000. edbDateData[edbData.DataTime] = edbData.Value
  1001. }
  1002. edbDataMap[edbInfoId] = edbDateData
  1003. }
  1004. // edbIdList 指标展示顺序;x轴的指标顺序
  1005. edbIdList = make([]int, 0)
  1006. //Sort int `description:"排序类型,0:默认,1:升序,2:降序"`
  1007. dateData := make(map[int]float64)
  1008. if barChartInfoSort.Sort == 0 {
  1009. for _, v := range mappingList {
  1010. edbIdList = append(edbIdList, v.EdbInfoId)
  1011. }
  1012. } else {
  1013. lenBarChartInfoDateList := len(barChartInfoDateList)
  1014. if barChartInfoSort.DateIndex >= lenBarChartInfoDateList {
  1015. err = errors.New("排序日期异常")
  1016. return
  1017. }
  1018. notDataEdbIdList := make([]int, 0) //没有数据的指标id
  1019. // 日期配置
  1020. barChartInfoDate := barChartInfoDateList[barChartInfoSort.DateIndex]
  1021. for edbInfoId, dataList := range edbDataListMap {
  1022. if len(dataList) <= 0 {
  1023. // 没有数据的指标id
  1024. notDataEdbIdList = append(notDataEdbIdList, edbInfoId)
  1025. continue
  1026. }
  1027. findDate := barChartInfoDate.Date
  1028. switch barChartInfoDate.Type {
  1029. case 1: //最新值
  1030. findDate = dataList[len(dataList)-1].DataTime
  1031. case 2: //近期几天
  1032. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[len(dataList)-1].DataTime, time.Local)
  1033. if tmpErr != nil {
  1034. err = tmpErr
  1035. return
  1036. }
  1037. findDateTime = findDateTime.AddDate(0, 0, -barChartInfoDate.Value)
  1038. lenData := len(dataList) - 1
  1039. for i := lenData; i >= 0; i-- {
  1040. currDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[i].DataTime, time.Local)
  1041. if tmpErr != nil {
  1042. err = tmpErr
  1043. return
  1044. }
  1045. if currDateTime.Equal(findDateTime) || currDateTime.Before(findDateTime) {
  1046. findDate = dataList[i].DataTime
  1047. break
  1048. }
  1049. }
  1050. case 3: // 固定日期
  1051. //最早的日期
  1052. minDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[0].DataTime, time.Local)
  1053. if tmpErr != nil {
  1054. err = tmpErr
  1055. return
  1056. }
  1057. //寻找固定日期的数据
  1058. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, barChartInfoDate.Date, time.Local)
  1059. if tmpErr != nil {
  1060. err = tmpErr
  1061. return
  1062. }
  1063. for tmpDateTime := findDateTime; tmpDateTime.After(minDateTime) || tmpDateTime.Equal(minDateTime); tmpDateTime = tmpDateTime.AddDate(0, 0, -1) {
  1064. tmpDate := tmpDateTime.Format(utils.FormatDate)
  1065. if _, ok := edbDataMap[edbInfoId][tmpDate]; ok { //如果能找到数据,那么就返回
  1066. findDate = tmpDate
  1067. break
  1068. }
  1069. }
  1070. default:
  1071. err = errors.New(fmt.Sprint("日期类型异常,Type:", barChartInfoDate.Type))
  1072. return
  1073. }
  1074. if tmpValue, ok := edbDataMap[edbInfoId][findDate]; ok {
  1075. dateData[edbInfoId] = tmpValue
  1076. } else {
  1077. // 没有数据的指标id
  1078. notDataEdbIdList = append(notDataEdbIdList, edbInfoId)
  1079. }
  1080. }
  1081. //Sort int `description:"排序类型,0:默认,1:升序,2:降序"`
  1082. // 排序
  1083. dateDataSort := utils.NewMapSorter(dateData)
  1084. sort.Sort(dateDataSort)
  1085. if barChartInfoSort.Sort == 1 {
  1086. // 先将没有数据的指标id放在最前面
  1087. if len(notDataEdbIdList) > 0 {
  1088. edbIdList = append(edbIdList, notDataEdbIdList...)
  1089. }
  1090. for _, v := range dateDataSort {
  1091. edbIdList = append(edbIdList, v.Key)
  1092. }
  1093. } else {
  1094. for i := len(dateDataSort) - 1; i >= 0; i-- {
  1095. edbIdList = append(edbIdList, dateDataSort[i].Key)
  1096. }
  1097. // 再将没有数据的指标id放在最后面
  1098. if len(notDataEdbIdList) > 0 {
  1099. edbIdList = append(edbIdList, notDataEdbIdList...)
  1100. }
  1101. }
  1102. }
  1103. yDataList = make([]chart_info.YData, 0) //y轴的数据列表
  1104. for _, barChartInfoDate := range barChartInfoDateList {
  1105. var maxDate time.Time
  1106. findDataList := make([]float64, 0) // 当前日期的数据值
  1107. for _, edbInfoId := range edbIdList {
  1108. findDate := barChartInfoDate.Date //需要的日期值
  1109. dataList := edbDataListMap[edbInfoId] //指标的所有数据值
  1110. if len(dataList) <= 0 {
  1111. // 没有数据的指标id
  1112. findDataList = append(findDataList, 0)
  1113. continue
  1114. }
  1115. switch barChartInfoDate.Type {
  1116. case 1: //最新值
  1117. dataList := edbDataListMap[edbInfoId]
  1118. findDate = dataList[len(dataList)-1].DataTime
  1119. case 2: //近期几天
  1120. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[len(dataList)-1].DataTime, time.Local)
  1121. if tmpErr != nil {
  1122. err = tmpErr
  1123. return
  1124. }
  1125. findDateTime = findDateTime.AddDate(0, 0, -barChartInfoDate.Value)
  1126. lenData := len(dataList) - 1
  1127. for i := lenData; i >= 0; i-- {
  1128. currDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[i].DataTime, time.Local)
  1129. if tmpErr != nil {
  1130. err = tmpErr
  1131. return
  1132. }
  1133. if currDateTime.Equal(findDateTime) || currDateTime.Before(findDateTime) {
  1134. findDate = dataList[i].DataTime
  1135. break
  1136. }
  1137. }
  1138. case 3: // 固定日期
  1139. //最早的日期
  1140. minDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[0].DataTime, time.Local)
  1141. if tmpErr != nil {
  1142. err = tmpErr
  1143. return
  1144. }
  1145. //寻找固定日期的数据
  1146. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, barChartInfoDate.Date, time.Local)
  1147. if tmpErr != nil {
  1148. err = tmpErr
  1149. return
  1150. }
  1151. for tmpDateTime := findDateTime; tmpDateTime.After(minDateTime) || tmpDateTime.Equal(minDateTime); tmpDateTime = tmpDateTime.AddDate(0, 0, -1) {
  1152. tmpDate := tmpDateTime.Format(utils.FormatDate)
  1153. if _, ok := edbDataMap[edbInfoId][tmpDate]; ok { //如果能找到数据,那么就返回
  1154. findDate = tmpDate
  1155. break
  1156. }
  1157. }
  1158. default:
  1159. err = errors.New(fmt.Sprint("日期类型异常,Type:", barChartInfoDate.Type))
  1160. return
  1161. }
  1162. findDateTime, _ := time.ParseInLocation(utils.FormatDate, findDate, time.Local)
  1163. if maxDate.IsZero() {
  1164. maxDate = findDateTime
  1165. } else {
  1166. if findDateTime.After(maxDate) {
  1167. maxDate = findDateTime
  1168. }
  1169. }
  1170. if tmpValue, ok := edbDataMap[edbInfoId][findDate]; ok {
  1171. findDataList = append(findDataList, tmpValue)
  1172. } else {
  1173. findDataList = append(findDataList, 0)
  1174. }
  1175. }
  1176. yDate := "0000-00-00"
  1177. if !maxDate.IsZero() {
  1178. yDate = maxDate.Format(utils.FormatDate)
  1179. }
  1180. yDataList = append(yDataList, chart_info.YData{
  1181. Date: yDate,
  1182. Value: findDataList,
  1183. Color: barChartInfoDate.Color,
  1184. Name: barChartInfoDate.Name,
  1185. })
  1186. }
  1187. return
  1188. }
  1189. // 获取频度的英文版
  1190. func GetFrequencyEn(frequency string) (frequencyEn string) {
  1191. switch frequency {
  1192. case "日度":
  1193. frequencyEn = "day"
  1194. return
  1195. case "周度":
  1196. frequencyEn = "week"
  1197. return
  1198. case "旬度":
  1199. frequencyEn = "ten days"
  1200. return
  1201. case "月度":
  1202. frequencyEn = "month"
  1203. return
  1204. case "季度":
  1205. frequencyEn = "quarter"
  1206. return
  1207. case "年度":
  1208. frequencyEn = "year"
  1209. return
  1210. }
  1211. return
  1212. }
  1213. func GetLeadUnitEn(unit string) (unitEn string) {
  1214. switch unit {
  1215. case "天":
  1216. unitEn = "day"
  1217. return
  1218. case "周":
  1219. unitEn = "week"
  1220. return
  1221. case "月":
  1222. unitEn = "month"
  1223. return
  1224. case "季":
  1225. unitEn = "quarter"
  1226. return
  1227. case "年":
  1228. unitEn = "year"
  1229. return
  1230. }
  1231. return
  1232. }
  1233. // ChartInfoRefreshV2 图表刷新
  1234. // @author Roc
  1235. // @datetime 2022-09-16 10:15:38
  1236. // @description 将原来自己写的一套获取所有关联指标,然后刷新指标逻辑 改成 只获取使用的指标id,然后遍历去调用“指标刷新服务”
  1237. func ChartInfoRefreshV2(chartInfoId int) (err error) {
  1238. var errmsg string
  1239. defer func() {
  1240. if err != nil {
  1241. go alarm_msg.SendAlarmMsg("ChartInfoRefresh:"+errmsg, 3)
  1242. //go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ChartInfoRefresh:"+errmsg, utils.EmailSendToUsers)
  1243. fmt.Println("ChartInfoRefresh Err:" + errmsg)
  1244. }
  1245. }()
  1246. edbMappingList, err := chartEdbMappingModel.GetMappingListByChartInfoId(chartInfoId)
  1247. if err != nil {
  1248. errmsg = "获取需要刷新的指标失败:Err:" + err.Error()
  1249. return
  1250. }
  1251. edbIdList := make([]int, 0)
  1252. for _, v := range edbMappingList {
  1253. edbIdList = append(edbIdList, v.EdbInfoId)
  1254. }
  1255. // 批量刷新
  1256. err, errmsg = EdbInfoRefreshAllFromBase(edbIdList, false)
  1257. if err != nil {
  1258. return
  1259. }
  1260. return
  1261. }
  1262. // CheckChartExtraConfig 校验图表额外配置的信息,并且获取相关联的指标id
  1263. func CheckChartExtraConfig(chartType int, extraConfigStr string) (edbIdList []int, err error, errMsg string) {
  1264. switch chartType {
  1265. case 10: //截面散点
  1266. var extraConfig request.SectionScatterReq
  1267. err = json.Unmarshal([]byte(extraConfigStr), &extraConfig)
  1268. if err != nil {
  1269. return
  1270. }
  1271. // 判断是否有配置日期序列
  1272. if len(extraConfig.SeriesList) <= 0 {
  1273. errMsg = `请配置序列`
  1274. err = errors.New(errMsg)
  1275. return
  1276. }
  1277. // 判断是否有填写指标
  1278. if len(extraConfig.SeriesList[0].EdbInfoList) <= 0 {
  1279. errMsg = `请选择指标`
  1280. err = errors.New(errMsg)
  1281. return
  1282. }
  1283. // 遍历指标列表获取指标id
  1284. edbIdMap := make(map[int]int)
  1285. for _, v := range extraConfig.SeriesList[0].EdbInfoList {
  1286. // X 轴的指标id
  1287. if _, ok := edbIdMap[v.XEdbInfoId]; !ok {
  1288. edbIdMap[v.XEdbInfoId] = v.XEdbInfoId
  1289. edbIdList = append(edbIdList, v.XEdbInfoId)
  1290. }
  1291. // Y 轴的指标id
  1292. if _, ok := edbIdMap[v.YEdbInfoId]; !ok {
  1293. edbIdMap[v.YEdbInfoId] = v.YEdbInfoId
  1294. edbIdList = append(edbIdList, v.YEdbInfoId)
  1295. }
  1296. }
  1297. }
  1298. return
  1299. }
  1300. // GetSectionScatterChartData 柱方图的数据处理
  1301. func GetSectionScatterChartData(mappingList []*chartEdbMappingModel.ChartEdbInfoMapping, edbDataListMap map[int][]*edbDataModel.EdbDataList, extraConfig request.SectionScatterReq) (edbIdList []int, chartDataResp request.SectionScatterInfoResp, err error) {
  1302. // 指标数据数组(10086:{"2022-12-02":100.01,"2022-12-01":102.3})
  1303. edbDataMap := make(map[int]map[string]float64)
  1304. for edbInfoId, edbDataList := range edbDataListMap {
  1305. edbDateData := make(map[string]float64)
  1306. for _, edbData := range edbDataList {
  1307. edbDateData[edbData.DataTime] = edbData.Value
  1308. }
  1309. edbDataMap[edbInfoId] = edbDateData
  1310. }
  1311. // edbIdList 指标展示顺序;x轴的指标顺序
  1312. edbIdList = make([]int, 0)
  1313. edbMappingMap := make(map[int]*chartEdbMappingModel.ChartEdbInfoMapping)
  1314. for _, v := range mappingList {
  1315. edbIdList = append(edbIdList, v.EdbInfoId)
  1316. edbMappingMap[v.EdbInfoId] = v
  1317. }
  1318. //SectionScatterSeriesInfoResp
  1319. dataListResp := make([]request.SectionScatterSeriesItemResp, 0) //y轴的数据列表
  1320. for _, seriesItem := range extraConfig.SeriesList {
  1321. var maxDate time.Time
  1322. // 系列中的指标数据
  1323. tmpSeriesEdbInfoList := make([]request.SectionScatterEdbItemResp, 0)
  1324. var minXVal, maxXVal, minYVal, maxYVal float64
  1325. for _, edbConf := range seriesItem.EdbInfoList {
  1326. tmpItem := request.SectionScatterEdbItemResp{
  1327. IsShow: edbConf.IsShow,
  1328. Name: edbConf.Name,
  1329. NameEn: edbConf.NameEn,
  1330. } //单个坐标点的数据
  1331. //X轴的数据
  1332. {
  1333. edbInfoId := edbConf.XEdbInfoId //X轴的指标
  1334. edbMappingInfo, ok := edbMappingMap[edbInfoId]
  1335. if !ok {
  1336. continue
  1337. }
  1338. findDate := edbConf.XDate //需要的日期值
  1339. dataList := edbDataListMap[edbInfoId] //指标的所有数据值
  1340. if len(dataList) <= 0 {
  1341. // 没有数据的指标id
  1342. //findDataList = append(findDataList, 0)
  1343. continue
  1344. }
  1345. tmpItem.XEdbInfoId = edbInfoId
  1346. tmpItem.XName = edbMappingInfo.EdbName
  1347. tmpItem.XNameEn = edbMappingInfo.EdbNameEn
  1348. switch edbConf.XDateType {
  1349. case 1: //最新值
  1350. dataList := edbDataListMap[edbInfoId]
  1351. findDate = dataList[len(dataList)-1].DataTime
  1352. case 2: //近期几天
  1353. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[len(dataList)-1].DataTime, time.Local)
  1354. if tmpErr != nil {
  1355. err = tmpErr
  1356. return
  1357. }
  1358. findDateTime = findDateTime.AddDate(0, 0, -edbConf.XDateValue)
  1359. lenData := len(dataList) - 1
  1360. for i := lenData; i >= 0; i-- {
  1361. currDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[i].DataTime, time.Local)
  1362. if tmpErr != nil {
  1363. err = tmpErr
  1364. return
  1365. }
  1366. if currDateTime.Equal(findDateTime) || currDateTime.Before(findDateTime) {
  1367. findDate = dataList[i].DataTime
  1368. break
  1369. }
  1370. }
  1371. case 3: // 固定日期
  1372. //最早的日期
  1373. minDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[0].DataTime, time.Local)
  1374. if tmpErr != nil {
  1375. err = tmpErr
  1376. return
  1377. }
  1378. //寻找固定日期的数据
  1379. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, edbConf.XDate, time.Local)
  1380. if tmpErr != nil {
  1381. err = tmpErr
  1382. return
  1383. }
  1384. for tmpDateTime := findDateTime; tmpDateTime.After(minDateTime) || tmpDateTime.Equal(minDateTime); tmpDateTime = tmpDateTime.AddDate(0, 0, -1) {
  1385. tmpDate := tmpDateTime.Format(utils.FormatDate)
  1386. if _, ok := edbDataMap[edbInfoId][tmpDate]; ok { //如果能找到数据,那么就返回
  1387. findDate = tmpDate
  1388. break
  1389. }
  1390. }
  1391. default:
  1392. err = errors.New(fmt.Sprint("日期类型异常,Type:", edbConf.XDate))
  1393. return
  1394. }
  1395. findDateTime, _ := time.ParseInLocation(utils.FormatDate, findDate, time.Local)
  1396. if maxDate.IsZero() {
  1397. maxDate = findDateTime
  1398. } else {
  1399. if findDateTime.After(maxDate) {
  1400. maxDate = findDateTime
  1401. }
  1402. }
  1403. if tmpValue, ok := edbDataMap[edbInfoId][findDate]; ok {
  1404. tmpItem.XDate = findDate
  1405. tmpItem.XValue = tmpValue
  1406. } else {
  1407. continue
  1408. }
  1409. }
  1410. //Y轴的数据
  1411. {
  1412. edbInfoId := edbConf.YEdbInfoId //Y轴的指标
  1413. edbMappingInfo, ok := edbMappingMap[edbInfoId]
  1414. if !ok {
  1415. continue
  1416. }
  1417. findDate := edbConf.YDate //需要的日期值
  1418. dataList := edbDataListMap[edbInfoId] //指标的所有数据值
  1419. if len(dataList) <= 0 {
  1420. // 没有数据的指标id
  1421. //findDataList = append(findDataList, 0)
  1422. continue
  1423. }
  1424. tmpItem.YEdbInfoId = edbInfoId
  1425. tmpItem.YName = edbMappingInfo.EdbName
  1426. tmpItem.YNameEn = edbMappingInfo.EdbNameEn
  1427. switch edbConf.YDateType {
  1428. case 1: //最新值
  1429. dataList := edbDataListMap[edbInfoId]
  1430. findDate = dataList[len(dataList)-1].DataTime
  1431. case 2: //近期几天
  1432. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[len(dataList)-1].DataTime, time.Local)
  1433. if tmpErr != nil {
  1434. err = tmpErr
  1435. return
  1436. }
  1437. findDateTime = findDateTime.AddDate(0, 0, -edbConf.YDateValue)
  1438. lenData := len(dataList) - 1
  1439. for i := lenData; i >= 0; i-- {
  1440. currDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[i].DataTime, time.Local)
  1441. if tmpErr != nil {
  1442. err = tmpErr
  1443. return
  1444. }
  1445. if currDateTime.Equal(findDateTime) || currDateTime.Before(findDateTime) {
  1446. findDate = dataList[i].DataTime
  1447. break
  1448. }
  1449. }
  1450. case 3: // 固定日期
  1451. //最早的日期
  1452. minDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, dataList[0].DataTime, time.Local)
  1453. if tmpErr != nil {
  1454. err = tmpErr
  1455. return
  1456. }
  1457. //寻找固定日期的数据
  1458. findDateTime, tmpErr := time.ParseInLocation(utils.FormatDate, edbConf.YDate, time.Local)
  1459. if tmpErr != nil {
  1460. err = tmpErr
  1461. return
  1462. }
  1463. for tmpDateTime := findDateTime; tmpDateTime.After(minDateTime) || tmpDateTime.Equal(minDateTime); tmpDateTime = tmpDateTime.AddDate(0, 0, -1) {
  1464. tmpDate := tmpDateTime.Format(utils.FormatDate)
  1465. if _, ok := edbDataMap[edbInfoId][tmpDate]; ok { //如果能找到数据,那么就返回
  1466. findDate = tmpDate
  1467. break
  1468. }
  1469. }
  1470. default:
  1471. err = errors.New(fmt.Sprint("日期类型异常,Type:", edbConf.YDate))
  1472. return
  1473. }
  1474. findDateTime, _ := time.ParseInLocation(utils.FormatDate, findDate, time.Local)
  1475. if maxDate.IsZero() {
  1476. maxDate = findDateTime
  1477. } else {
  1478. if findDateTime.After(maxDate) {
  1479. maxDate = findDateTime
  1480. }
  1481. }
  1482. if tmpValue, ok := edbDataMap[edbInfoId][findDate]; ok {
  1483. tmpItem.YDate = findDate
  1484. tmpItem.YValue = tmpValue
  1485. } else {
  1486. continue
  1487. }
  1488. }
  1489. // 获取当前系列的X轴的最大最小值
  1490. {
  1491. if tmpItem.XValue < minXVal {
  1492. minXVal = tmpItem.XValue
  1493. }
  1494. if tmpItem.XValue > maxXVal {
  1495. maxXVal = tmpItem.XValue
  1496. }
  1497. if tmpItem.YValue < minYVal {
  1498. minYVal = tmpItem.YValue
  1499. }
  1500. if tmpItem.YValue > maxYVal {
  1501. maxYVal = tmpItem.YValue
  1502. }
  1503. }
  1504. tmpSeriesEdbInfoList = append(tmpSeriesEdbInfoList, tmpItem)
  1505. }
  1506. trendLimitData := make([]request.CoordinatePoint, 0) //趋势线的前后坐标点
  1507. var trendLine, rSquare string
  1508. // 生成线性方程式
  1509. var a, b float64
  1510. {
  1511. coordinateData := make([]utils.Coordinate, 0)
  1512. for _, tmpSeriesEdbInfo := range tmpSeriesEdbInfoList {
  1513. tmpCoordinate1 := utils.Coordinate{
  1514. X: tmpSeriesEdbInfo.XValue,
  1515. Y: tmpSeriesEdbInfo.YValue,
  1516. }
  1517. coordinateData = append(coordinateData, tmpCoordinate1)
  1518. }
  1519. // 只有存在两个坐标点的时候,才能去计算线性方程和R平方
  1520. if len(coordinateData) >= 2 {
  1521. a, b = utils.GetLinearResult(coordinateData)
  1522. if !math.IsNaN(a) && !math.IsNaN(b) {
  1523. if b > 0 {
  1524. trendLine = fmt.Sprintf("y=%sx+%s", utils.SubFloatToString(a, 4), utils.SubFloatToString(b, 4))
  1525. } else {
  1526. trendLine = fmt.Sprintf("y=%sx%s", utils.SubFloatToString(a, 4), utils.SubFloatToString(b, 4))
  1527. }
  1528. minYVal, _ = decimal.NewFromFloat(a).Mul(decimal.NewFromFloat(minXVal)).Add(decimal.NewFromFloat(b)).Round(4).Float64()
  1529. maxYVal, _ = decimal.NewFromFloat(a).Mul(decimal.NewFromFloat(maxXVal)).Add(decimal.NewFromFloat(b)).Round(4).Float64()
  1530. }
  1531. // 计算R平方
  1532. rSquare = fmt.Sprint(utils.CalculationDecisive(coordinateData))
  1533. }
  1534. trendLimitData = append(trendLimitData, request.CoordinatePoint{
  1535. X: minXVal,
  1536. Y: minYVal,
  1537. }, request.CoordinatePoint{
  1538. X: maxXVal,
  1539. Y: maxYVal,
  1540. })
  1541. }
  1542. dataListResp = append(dataListResp, request.SectionScatterSeriesItemResp{
  1543. Name: seriesItem.Name,
  1544. NameEn: seriesItem.NameEn,
  1545. Color: seriesItem.Color,
  1546. EdbInfoList: tmpSeriesEdbInfoList,
  1547. ShowTrendLine: seriesItem.ShowTrendLine,
  1548. ShowFitEquation: seriesItem.ShowFitEquation,
  1549. ShowRSquare: seriesItem.ShowRSquare,
  1550. TrendLine: trendLine,
  1551. RSquare: rSquare,
  1552. TrendLimitData: trendLimitData,
  1553. })
  1554. }
  1555. chartDataResp = request.SectionScatterInfoResp{
  1556. XName: extraConfig.XName,
  1557. XNameEn: extraConfig.XNameEn,
  1558. XUnitName: extraConfig.XUnitName,
  1559. XUnitNameEn: extraConfig.XUnitNameEn,
  1560. YName: extraConfig.YName,
  1561. YNameEn: extraConfig.YNameEn,
  1562. YUnitName: extraConfig.YUnitName,
  1563. YUnitNameEn: extraConfig.YUnitNameEn,
  1564. XMinValue: extraConfig.XMinValue,
  1565. XMaxValue: extraConfig.XMaxValue,
  1566. YMinValue: extraConfig.YMinValue,
  1567. YMaxValue: extraConfig.YMaxValue,
  1568. DataList: dataListResp,
  1569. }
  1570. return
  1571. }