123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- package controllers
- import (
- "encoding/json"
- "eta/eta_chart_lib/models"
- "eta/eta_chart_lib/models/request"
- "eta/eta_chart_lib/models/response"
- excel2 "eta/eta_chart_lib/services/data/excel"
- "eta/eta_chart_lib/services/excel"
- "eta/eta_chart_lib/utils"
- "github.com/shopspring/decimal"
- "time"
- )
- type ExcelInfoController struct {
- BaseAuthController
- }
- func (this *ExcelInfoController) GetTableDetail() {
- br := new(models.BaseResponse).Init()
- defer func() {
- this.Data["json"] = br
- this.ServeJSON()
- }()
- uniqueCode := this.GetString("UniqueCode")
- if uniqueCode == "" {
- br.Msg = "参数错误"
- br.ErrMsg = "参数错误,uniqueCode is empty"
- return
- }
- fromScene, _ := this.GetInt("FromScene", 0)
- key := utils.HZ_CHART_LIB_EXCEL_TABLE_DETAIL + ":" + uniqueCode
- resp := new(response.ExcelTableDetailResp)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- excelInfo, err := models.GetExcelInfoByUniqueCode(uniqueCode)
- if err != nil {
- if err.Error() == utils.ErrNoRow() {
- br.Msg = "该表格已被删除,请刷新页面"
- br.ErrMsg = "该表格已被删除,请刷新页面,Err:" + err.Error()
- return
- }
- br.Msg = "获取失败"
- br.ErrMsg = "获取表格表信息失败,Err:" + err.Error()
- return
- }
- var tableData excel.TableData
- switch excelInfo.Source {
- case utils.EXCEL_DEFAULT:
- luckySheetData, err := excel.GetLuckySheetData(excelInfo.Content)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取excel数据失败,Err:" + err.Error()
- return
- }
- tableData, err = luckySheetData.GetTableDataByLuckySheetDataStr()
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "转换成table失败,Err:" + err.Error()
- return
- }
- case utils.TIME_TABLE:
- var tableDataConfig excel2.TableDataConfig
- err = json.Unmarshal([]byte(excelInfo.Content), &tableDataConfig)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
- return
- }
- result, err := excel2.GetDataByTableDataConfig(tableDataConfig)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "获取最新的表格数据失败,Err:" + err.Error()
- return
- }
- tableData, err = excel.GetTableDataByCustomData(excelInfo.ExcelType, result, this.Lang)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "转换成table失败,Err:" + err.Error()
- return
- }
- case utils.MIXED_TABLE:
- var result request.MixedTableReq
- err = json.Unmarshal([]byte(excelInfo.Content), &result)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "表格json转结构体失败,Err:" + err.Error()
- return
- }
- newResult, tmpErr, tmpErrMsg := excel2.GetMixedTableCellData(result)
- if tmpErr != nil {
- br.Msg = "获取失败"
- if tmpErrMsg != `` {
- br.Msg = tmpErrMsg
- }
- br.ErrMsg = "获取最新的数据失败,Err:" + tmpErr.Error()
- return
- }
- tableData, err = excel.GetTableDataByMixedTableData(newResult)
- if err != nil {
- br.Msg = "获取失败"
- br.ErrMsg = "转换成table失败,Err:" + err.Error()
- return
- }
- }
- tableData = excel.HandleTableCell(tableData)
- config := response.ExcelTableDetailConfigResp{
- FontSize: 9,
- }
-
- confName := models.FromSceneMap[fromScene]
- if confName != `` {
- busConf, err := models.GetBusinessConfByKey(confName)
- if err == nil {
- sizeDeci, err := decimal.NewFromString(busConf.ConfVal)
- if err == nil {
- config.FontSize = int(sizeDeci.IntPart())
- }
- }
- }
- resp.TableInfo = tableData
- resp.Source = excelInfo.Source
- resp.ExcelType = excelInfo.ExcelType
- resp.ExcelName = excelInfo.ExcelName
- resp.ExcelImage = excelInfo.ExcelImage
- resp.UniqueCode = excelInfo.UniqueCode
- resp.Config = config
- if utils.Re == nil {
- data, _ := json.Marshal(resp)
- utils.Rc.Put(key, data, 5*time.Minute)
- }
- br.Ret = 200
- br.Success = true
- br.Msg = "获取成功"
- br.Data = resp
- }
|