// Package data
// @Author gmy 2024/8/22 9:44:00
package data

import (
	"eta/eta_api/models/data_manage"
	"eta/eta_api/utils"
	"fmt"
)

// RzdIndexAddValidate 指标添加校验
func RzdIndexAddValidate(indexCodes []string) (*[]data_manage.RzdIndexCheckData, error) {
	// 根据指标编码获取指标库 指标信息
	edbInfos, err := data_manage.GetEdbInfoByEdbCodeList(utils.DATA_SOURCE_RZD, indexCodes)
	if err != nil {
		return nil, err
	}
	var respList []data_manage.RzdIndexCheckData
	if len(edbInfos) > 0 {
		for _, ebdInfo := range edbInfos {
			respList = append(respList, data_manage.RzdIndexCheckData{
				IndexCode:  ebdInfo.EdbCode,
				IndexName:  ebdInfo.EdbName,
				Unit:       ebdInfo.Unit,
				Frequency:  ebdInfo.Frequency,
				EdbInfoId:  ebdInfo.EdbInfoId,
				ClassifyId: ebdInfo.ClassifyId,
				UniqueCode: ebdInfo.UniqueCode,
			})
		}
	}
	return &respList, nil
}

// RzdIndexNameCheck 指标名称校验
func RzdIndexNameCheck(indexNames []string, resp []*data_manage.RzdNameCheckResult) ([]*data_manage.RzdNameCheckResult, error) {
	// 重名校验
	edbList, e := data_manage.GetEdbInfoByNameArr(indexNames, utils.EDB_INFO_TYPE)
	if e != nil {
		return nil, e
	}
	nameExists := make(map[string]bool)
	for _, edbInfo := range edbList {
		nameExists[edbInfo.EdbName] = true
	}
	if len(nameExists) > 0 {
		for _, v := range resp {
			v.Exist = nameExists[v.IndexName]
		}
	}
	return resp, nil
}

// RzdIndexAdd 批量添加指标
func RzdIndexAdd(req data_manage.RzdIndexAddReq, lang string) (edb *data_manage.EdbInfo, err error, errMsg string, skip bool) {
	if req.EdbCode == "" {
		err = fmt.Errorf("指标ID为空")
		return
	}
	defer func() {
		if err != nil {
			tips := fmt.Sprintf("ruizide指标数据新增失败, Err: %s", err.Error())
			utils.FileLog.Info(tips)
		}
	}()
	source := utils.DATA_SOURCE_RZD

	// 是否已有指标数据
	dataList, e := data_manage.GetEdbDataAllByEdbCode(req.EdbCode, source, utils.DATA_SUB_SOURCE_EDB, utils.EDB_DATA_LIMIT)
	if e != nil {
		err = fmt.Errorf("获取指标数据失败, Err: %s", e.Error())
		return
	}

	// 新增指标数据
	if len(dataList) == 0 {
		res, e := AddEdbData(source, req.EdbCode, req.Frequency)
		if e != nil {
			err = fmt.Errorf("index_lib: 新增指标数据失败, Err: %s", e.Error())
			return
		}
		if res == nil {
			err = fmt.Errorf("index_lib: 新增指标数据失败, res nil")
			return
		}
		if res.Ret != 200 {
			err = fmt.Errorf("index_lib: 新增指标数据失败, Ret: %d", res.Ret)
			return
		}
	}

	// 是否新增过指标
	exist, e := data_manage.GetEdbInfoByEdbCode(source, req.EdbCode)
	if e != nil && e.Error() != utils.ErrNoRow() {
		err = fmt.Errorf("获取指标是否存在失败, err: %s", e.Error())
		return
	}
	if exist != nil {
		skip = true
		return
	}

	// 开始结束时间
	var startDate, endDate string
	minMax, e := data_manage.GetEdbInfoMaxAndMinInfo(source, utils.DATA_SUB_SOURCE_EDB, req.EdbCode)
	if e != nil && e.Error() != utils.ErrNoRow() {
		err = fmt.Errorf("MinMax: 获取指标极值失败, err: %s", e.Error())
		return
	}
	if minMax != nil {
		startDate = minMax.MinDate
		endDate = minMax.MaxDate
	}

	// 新增指标到指标库
	edbInfo, e, msg, _ := EdbInfoAdd(source, utils.DATA_SUB_SOURCE_EDB, req.ClassifyId, req.EdbCode, req.EdbName, req.Frequency, req.Unit, startDate, endDate, req.AdminId, req.AdminRealName, lang)
	if e != nil {
		errMsg = msg
		err = fmt.Errorf("EdbInfo: 新增指标失败, err: %s", e.Error())
		return
	}
	edb = edbInfo

	// EdbInfoAdd方法已经新增es,这里不需要再新增???
	// 新增es
	// go AddOrEditEdbInfoToEs(edbInfo.EdbInfoId)
	return
}

// GetRzdIndexInfo 获取指标信息-分页
func GetRzdIndexInfo(keyWord string, classifyIdList []string, frequencyList []string) (rzdIndexInfoList []*data_manage.BaseFromRzdIndex, err error) {

	// 获取指标
	var condition string
	var pars []interface{}
	if keyWord != "" {
		condition += ` AND CONCAT(index_name,index_code) LIKE '%` + keyWord + `%'`
	}
	if len(classifyIdList) > 0 {
		condition += ` AND classify_id IN (`
		for _, v := range classifyIdList {
			condition += `?,`
			pars = append(pars, v)
		}
		condition = condition[:len(condition)-1] + `)`
	}
	if len(frequencyList) > 0 {
		condition += ` AND frequency IN (`
		for _, v := range frequencyList {
			condition += `?,`
			pars = append(pars, v)
		}
		condition = condition[:len(condition)-1] + `)`
	}

	rzdIndexInfoList, err = data_manage.GetRzdIndexInfoPage(condition, pars)
	if err != nil {
		return
	}

	return
}

// GetRzdIndexDetail 获取指标详情
func GetRzdIndexDetail(indexCode string) (rzdIndexInfoList *data_manage.BaseFromRzdIndexList, err error) {

	// 获取指标
	var condition string
	var pars []interface{}
	if indexCode != "" {
		condition += ` and index_code = ?`
		pars = append(pars, indexCode)
	}
	rzdIndexList, err := data_manage.GetRzdIndex(condition, pars)
	if err != nil {
		return nil, err
	}

	var rzdIndex *data_manage.BaseFromRzdIndexList
	if len(rzdIndexList) > 0 {
		rzdIndex = rzdIndexList[0]
		// 查询指标数据
		dataList, err := data_manage.GetBaseFormRzdDataByIndexCode(indexCode)
		if err != nil {
			return nil, err
		}
		rzdIndex.DataList = dataList

		// 查询是否在指标库
		edbInfo, err := data_manage.GetEdbInfoByEdbCode(utils.DATA_SOURCE_RZD, indexCode)
		if err != nil && err.Error() != utils.ErrNoRow() {
			return nil, err
		}

		if edbInfo != nil {
			rzdIndex.EdbInfoId = edbInfo.EdbInfoId
		}
	}

	return rzdIndex, nil
}

// GetRzdIndexList 获取指标列表
func GetRzdIndexList(searchParams string) (rzdIndexInfoList []*data_manage.BaseFromRzdIndexList, err error) {

	// 获取指标
	var condition string
	var pars []interface{}
	if searchParams != "" {
		condition += ` and index_code like ? or index_name like ?`
		pars = append(pars, "%"+searchParams+"%", "%"+searchParams+"%")
	}
	rzdIndexList, err := data_manage.GetRzdIndex(condition, pars)
	if err != nil {
		return nil, err
	}

	return rzdIndexList, nil
}