package response

import (
	excel2 "eta/eta_api/models/data_manage/excel"
	"eta/eta_api/models/data_manage/excel/request"
	"eta/eta_api/services/excel"
	"time"

	"github.com/rdlucklib/rdluck_tools/paging"
)

// AddExcelInfoResp 添加excel表格的返回
type AddExcelInfoResp struct {
	ExcelInfoId int    `description:"表格id"`
	UniqueCode  string `description:"表格唯一编码"`
}

// ExcelListResp 表格列表返回数据
type ExcelListResp struct {
	Paging *paging.PagingItem
	List   []*excel2.MyExcelInfoList
}

// ExcelTableDetailResp  excel表格详情
type ExcelTableDetailResp struct {
	UniqueCode    string `description:"表格唯一code"`
	ExcelImage    string `description:"表格截图"`
	ExcelName     string `description:"表格名称"`
	TableInfo     excel.TableData
	Config        ExcelTableDetailConfigResp
	SourcesFrom   string `description:"图表来源"`
	ExcelSource   string `description:"表格来源str"`
	ExcelSourceEn string `description:"表格来源(英文)"`
	ExcelInfoId   int    `description:"表id"`
	Source        int    `description:"表格来源"`
}

// ExcelTableDetailConfigResp
// @Description: Excel表格的配置信息
type ExcelTableDetailConfigResp struct {
	FontSize int
}

// TableCellResp 单元格
type TableCellResp struct {
	DataType  int    `description:"数据类型,1:普通的,2:插值法,3:手动输入,4:公式计算"`
	DataTime  string `description:"所属日期"`
	ShowValue string `description:"展示的值"`
	Value     string `description:"实际值(计算公式)"`
}

type TableDataItem struct {
	EdbInfoId     int                     `description:"指标id"`
	Data          []request.ManualDataReq `description:"数据列表"`
	Decimal       int                     `description:"小数位数"`
	ExcelSource   string                  `description:"表格来源str"`
	ExcelSourceEn string                  `description:"表格来源(英文)"`
}

// TableDetailResp  excel表格详情
type TableDetailResp struct {
	ExcelInfo excel2.ExcelInfo     `description:"表格基础信息"`
	TableData request.TableDataReq `description:"表格内容"`
}

// ExcelInfoDetail excel表格详情(前端使用)
type ExcelInfoDetail struct {
	ExcelInfoId        int                          `orm:"column(excel_info_id);pk"`
	Source             int                          `description:"表格来源,1:excel插件的表格,2:自定义表格,默认:1"`
	ExcelType          int                          `description:"表格类型,1:指标列,2:日期列,默认:1"`
	ExcelName          string                       `description:"表格名称"`
	UniqueCode         string                       `description:"表格唯一编码"`
	ExcelClassifyId    int                          `description:"表格分类id"`
	SysUserId          int                          `description:"操作人id"`
	SysUserRealName    string                       `description:"操作人真实姓名"`
	Content            string                       `description:"表格内容"`
	ExcelImage         string                       `description:"表格图片"`
	FileUrl            string                       `description:"表格下载地址"`
	Sort               int                          `description:"排序字段,数字越小越排前面"`
	IsDelete           int                          `description:"是否删除,0:未删除,1:已删除"`
	ModifyTime         time.Time                    `description:"最近修改日期"`
	CreateTime         time.Time                    `description:"创建日期"`
	TableData          interface{}                  `description:"表格内容"`
	Button             excel2.ExcelInfoDetailButton `description:"操作权限"`
	CanEdit            bool                         `description:"是否可编辑"`
	Editor             string                       `description:"编辑人"`
	IsJoinPermission   int                          `description:"是否加入权限管控,0:不加入;1:加入;默认:0"`
	HaveOperaAuth      bool                         `description:"是否有数据权限"`
	ParentId           int                          `description:"表格的父级id"`
	BalanceType        int                          `description:"平衡表类型:0 动态表,1静态表"`
	UpdateUserId       int                          `description:"更新人id"`
	UpdateUserRealName string                       `description:"更新人真实姓名"`
	RelExcelInfoId     int                          `description:"平衡表里静态表关联的动态表excel id"`
	SourcesFrom        string                       `description:"图表来源"`
	ExcelSource        string                       `description:"表格来源str"`
	ExcelSourceEn      string                       `description:"表格来源(英文)"`
}

type BalanceChildTableResp struct {
	List []*excel2.ExcelInfo
}

type BalanceTableWorkerResp struct {
	List []*excel2.ExcelWorker
}

type BalanceTableVersionListItem struct {
	ExcelInfoId    int    `description:"表格id"`
	UniqueCode     string `description:"表格唯一编码"`
	BalanceType    int    `description:"平衡表类型:0 动态表,1静态表"`
	RelExcelInfoId int    `description:"平衡表里静态表关联的动态表excel id"`
	VersionName    string `description:"静态表版本名称"`
}

type BalanceTableVersionListResp struct {
	List []*BalanceTableVersionListItem
}

// ShareExcelInfoDetail 分享表格详情
type ShareExcelInfoDetail struct {
	ExcelInfoId int   `description:"表格ID"`
	ViewUserIds []int `description:"查看权限用户IDs"`
	EditUserIds []int `description:"编辑权限用户IDs"`
}

type ExcelRuleListResp struct {
	List []*excel2.ExcelInfoRuleMappingView
}