|
@@ -1551,3 +1551,181 @@ func refreshBalanceTable(excelDetail response.ExcelInfoDetail, lang string) (err
|
|
|
}
|
|
|
return
|
|
|
}
|
|
|
+
|
|
|
+// BalanceChartInfoBaseEdit
|
|
|
+// @Title 编辑图表基础信息接口
|
|
|
+// @Description 编辑图表基础信息接口
|
|
|
+// @Param request body data_manage.EditChartEnInfoBaseReq true "type json string"
|
|
|
+// @Success Ret=200 编辑成功
|
|
|
+// @router /excel_info/balance/chart_base_edit [post]
|
|
|
+func (this *ExcelInfoController) BalanceChartInfoBaseEdit() {
|
|
|
+ br := new(models.BaseResponse).Init()
|
|
|
+ defer func() {
|
|
|
+ this.Data["json"] = br
|
|
|
+ this.ServeJSON()
|
|
|
+ }()
|
|
|
+
|
|
|
+ sysUser := this.SysUser
|
|
|
+ if sysUser == nil {
|
|
|
+ br.Msg = "请登录"
|
|
|
+ br.ErrMsg = "请登录,SysUser Is Empty"
|
|
|
+ br.Ret = 408
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ var req data_manage.EditChartInfoBaseReq
|
|
|
+ err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
|
|
|
+ if err != nil {
|
|
|
+ br.Msg = "参数解析异常!"
|
|
|
+ br.ErrMsg = "参数解析失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ req.ChartName = strings.Trim(req.ChartName, " ")
|
|
|
+ if req.ChartInfoId <= 0 {
|
|
|
+ br.Msg = "请选择图表"
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //判断指标名称是否存在
|
|
|
+ chartItem, err := data_manage.GetChartInfoById(req.ChartInfoId)
|
|
|
+ if err != nil {
|
|
|
+ if err.Error() == utils.ErrNoRow() {
|
|
|
+ br.Msg = "图表已被删除,请刷新页面"
|
|
|
+ br.ErrMsg = "图表已被删除,请刷新页面"
|
|
|
+ return
|
|
|
+ }
|
|
|
+ br.Msg = "获取图表信息失败"
|
|
|
+ br.ErrMsg = "获取图表信息失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ // 判断是否有传入对应的指标配置
|
|
|
+ noEdbInfoType := []int{10}
|
|
|
+ if len(req.ChartEdbInfoList) <= 0 && !utils.InArrayByInt(noEdbInfoType, chartItem.ChartType) {
|
|
|
+ br.Msg = "请选择指标!"
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ var edbCondition string
|
|
|
+ var edbPars []interface{}
|
|
|
+ for _, v := range req.ChartEdbInfoList {
|
|
|
+ edbInfoId := v.EdbInfoId
|
|
|
+ edbInfo, err := excel.GetExcelChartEdbById(edbInfoId)
|
|
|
+ if err != nil {
|
|
|
+ if err.Error() == utils.ErrNoRow() {
|
|
|
+ br.Msg = "图表不存在!"
|
|
|
+ br.ErrMsg = "图表指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId)
|
|
|
+ return
|
|
|
+ } else {
|
|
|
+ br.Msg = "获取图表信息失败!"
|
|
|
+ br.ErrMsg = "获取图表的指标信息失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if edbInfo == nil {
|
|
|
+ br.Msg = "指标不存在!"
|
|
|
+ br.ErrMsg = "指标不存在,ChartInfoId:" + strconv.Itoa(edbInfoId)
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+ //判断指标名称是否重复
|
|
|
+ if v.EdbName != "" {
|
|
|
+ edbCondition = ""
|
|
|
+ edbPars = make([]interface{}, 0)
|
|
|
+
|
|
|
+ edbCondition += " AND excel_chart_edb_id<>? AND chart_info_id=?"
|
|
|
+ edbPars = append(edbPars, edbInfo.ExcelChartEdbId, chartItem.ChartInfoId)
|
|
|
+
|
|
|
+ switch this.Lang {
|
|
|
+ case utils.EnLangVersion:
|
|
|
+ edbCondition += " AND edb_name_en =? "
|
|
|
+ default:
|
|
|
+ edbCondition += " AND edb_name =? "
|
|
|
+ }
|
|
|
+
|
|
|
+ edbPars = append(edbPars, v.EdbName)
|
|
|
+
|
|
|
+ edbExist, err := excel.GetBalanceChartEdbByCondition(edbCondition, edbPars)
|
|
|
+ if err != nil {
|
|
|
+ if err.Error() != utils.ErrNoRow() {
|
|
|
+ br.Msg = "判断英文指标名称是否存在失败"
|
|
|
+ br.ErrMsg = "判断英文指标名称是否存在失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if err == nil && edbExist.ExcelChartEdbId > 0 {
|
|
|
+ br.Msg = edbExist.EdbName + ":" + v.EdbName + "指标名称已存在"
|
|
|
+ br.ErrMsg = "指标名称已存在,请重新填写"
|
|
|
+ br.IsSendEmail = false
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if req.ChartName != "" || req.ExtraConfig != `` {
|
|
|
+ var condition string
|
|
|
+ var pars []interface{}
|
|
|
+ condition += " AND chart_info_id<>? "
|
|
|
+ pars = append(pars, req.ChartInfoId)
|
|
|
+
|
|
|
+ switch this.Lang {
|
|
|
+ case utils.EnLangVersion:
|
|
|
+ condition += " AND chart_name_en = ? "
|
|
|
+ default:
|
|
|
+ condition += " AND chart_name = ? "
|
|
|
+ }
|
|
|
+
|
|
|
+ pars = append(pars, req.ChartName)
|
|
|
+
|
|
|
+ existItem, err := data_manage.GetChartInfoByCondition(condition, pars)
|
|
|
+ if err != nil {
|
|
|
+ if err.Error() != utils.ErrNoRow() {
|
|
|
+ br.Msg = "判断英文图表名称是否存在失败"
|
|
|
+ br.ErrMsg = "判断英文图表名称是否存在失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if err == nil && existItem.ChartInfoId > 0 {
|
|
|
+ br.Msg = existItem.ChartName + ":" + req.ChartName + "图表名称已存在"
|
|
|
+ return
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ err = excel.EditBalanceChartBaseInfoAndEdbEnInfo(&req, chartItem, this.Lang)
|
|
|
+ if err != nil {
|
|
|
+ br.Msg = "保存失败"
|
|
|
+ br.ErrMsg = "保存失败,Err:" + err.Error()
|
|
|
+ return
|
|
|
+ }
|
|
|
+ //添加es数据
|
|
|
+ go data.EsAddOrEditChartInfo(chartItem.ChartInfoId)
|
|
|
+ //修改my eta es数据
|
|
|
+ go data.EsAddOrEditMyChartInfoByChartInfoId(chartItem.ChartInfoId)
|
|
|
+
|
|
|
+ //新增操作日志
|
|
|
+ {
|
|
|
+ chartLog := new(data_manage.ChartInfoLog)
|
|
|
+ chartLog.ChartName = chartItem.ChartName
|
|
|
+ chartLog.ChartInfoId = req.ChartInfoId
|
|
|
+ chartLog.ChartClassifyId = chartItem.ChartClassifyId
|
|
|
+ chartLog.SysUserId = sysUser.AdminId
|
|
|
+ chartLog.SysUserRealName = sysUser.RealName
|
|
|
+ chartLog.UniqueCode = chartItem.UniqueCode
|
|
|
+ chartLog.CreateTime = time.Now()
|
|
|
+ chartLog.Content = string(this.Ctx.Input.RequestBody)
|
|
|
+ chartLog.Status = "编辑图表英文信息"
|
|
|
+ chartLog.Method = this.Ctx.Input.URL()
|
|
|
+ go data_manage.AddChartInfoLog(chartLog)
|
|
|
+ }
|
|
|
+ //清除缓存
|
|
|
+ if utils.Re == nil && utils.Rc != nil {
|
|
|
+ utils.Rc.Delete(utils.HZ_CHART_LIB_DETAIL + chartItem.UniqueCode) //图表分享链接缓存
|
|
|
+ utils.Rc.Delete(data.GetChartInfoDataKey(req.ChartInfoId))
|
|
|
+ }
|
|
|
+
|
|
|
+ br.Ret = 200
|
|
|
+ br.Success = true
|
|
|
+ br.Msg = "编辑成功"
|
|
|
+ br.IsAddLog = true
|
|
|
+}
|