goview_vue/src/store/modules/chartEditStore/chartEditStore.d.ts

213 lines
6.1 KiB
TypeScript
Raw Normal View History

import { CreateComponentType, CreateComponentGroupType, FilterEnum } from '@/packages/index.d'
2022-02-04 12:17:50 +08:00
import { HistoryActionTypeEnum } from '@/store/modules/chartHistoryStore/chartHistoryStore.d'
2022-07-11 09:01:19 +08:00
import {
RequestHttpEnum,
RequestContentTypeEnum,
RequestDataTypeEnum,
RequestHttpIntervalEnum,
2022-07-15 00:11:42 +08:00
RequestParams,
RequestBodyEnum,
RequestParamsObjType
2022-07-11 09:01:19 +08:00
} from '@/enums/httpEnum'
2022-07-15 00:11:42 +08:00
import { PreviewScaleEnum } from '@/enums/styleEnum'
2022-07-11 09:01:19 +08:00
import type { ChartColorsNameType, GlobalThemeJsonType } from '@/settings/chartThemes/index'
2022-02-01 20:57:54 +08:00
2022-01-30 00:43:37 +08:00
// 编辑画布属性
2022-01-20 21:25:35 +08:00
export enum EditCanvasTypeEnum {
2022-01-24 21:12:18 +08:00
EDIT_LAYOUT_DOM = 'editLayoutDom',
EDIT_CONTENT_DOM = 'editContentDom',
2022-01-20 21:25:35 +08:00
OFFSET = 'offset',
SCALE = 'scale',
2022-01-24 21:12:18 +08:00
USER_SCALE = 'userScale',
LOCK_SCALE = 'lockScale',
2022-04-11 18:17:09 +08:00
IS_CREATE = 'isCreate',
2022-08-18 20:30:02 +08:00
IS_DRAG = 'isDrag',
IS_SELECT = 'isSelect'
2022-01-20 21:25:35 +08:00
}
2022-01-30 00:43:37 +08:00
2022-02-04 12:17:50 +08:00
// 编辑区域
2022-01-20 21:25:35 +08:00
export type EditCanvasType = {
// 编辑区域 DOM
2022-01-24 21:12:18 +08:00
[EditCanvasTypeEnum.EDIT_LAYOUT_DOM]: HTMLElement | null
[EditCanvasTypeEnum.EDIT_CONTENT_DOM]: HTMLElement | null
2022-01-20 21:25:35 +08:00
// 偏移大小
[EditCanvasTypeEnum.OFFSET]: number
// 缩放
[EditCanvasTypeEnum.SCALE]: number
2022-01-20 22:13:51 +08:00
// 缩放
2022-01-24 21:12:18 +08:00
[EditCanvasTypeEnum.USER_SCALE]: number
2022-01-20 21:25:35 +08:00
// 锁定缩放
2022-01-24 21:12:18 +08:00
[EditCanvasTypeEnum.LOCK_SCALE]: boolean
2022-04-11 18:17:09 +08:00
// 初始化创建
[EditCanvasTypeEnum.IS_CREATE]: boolean
// 拖拽中
2022-03-04 20:57:36 +08:00
[EditCanvasTypeEnum.IS_DRAG]: boolean
2022-08-18 20:30:02 +08:00
// 框选中
[EditCanvasTypeEnum.IS_SELECT]: boolean
2022-02-06 01:04:05 +08:00
}
2022-03-17 20:18:46 +08:00
// 滤镜/背景色/宽高主题等
2022-02-06 21:35:38 +08:00
export enum EditCanvasConfigEnum {
PROJECT_NAME = 'projectName',
2022-02-06 21:35:38 +08:00
WIDTH = 'width',
HEIGHT = 'height',
2022-02-21 19:45:11 +08:00
CHART_THEME_COLOR = 'chartThemeColor',
CHART_THEME_SETTING = 'chartThemeSetting',
2022-02-06 21:35:38 +08:00
BACKGROUND = 'background',
2022-06-21 10:54:05 +08:00
BACKGROUND_IMAGE = 'backgroundImage',
SELECT_COLOR = 'selectColor',
2022-07-11 09:01:19 +08:00
PREVIEW_SCALE_TYPE = 'previewScaleType'
2022-02-06 01:04:05 +08:00
}
2022-02-06 21:35:38 +08:00
2022-02-06 01:04:05 +08:00
export interface EditCanvasConfigType {
// 滤镜-启用
[FilterEnum.FILTERS_SHOW]: boolean
2022-04-19 22:07:54 +08:00
// 滤镜-色相
2022-04-25 16:17:22 +08:00
[FilterEnum.HUE_ROTATE]: number
2022-04-19 22:07:54 +08:00
// 滤镜-饱和度
2022-04-25 16:17:22 +08:00
[FilterEnum.SATURATE]: number
2022-04-19 22:07:54 +08:00
// 滤镜-亮度
2022-04-25 16:17:22 +08:00
[FilterEnum.BRIGHTNESS]: number
2022-04-19 22:07:54 +08:00
// 滤镜-对比度
2022-04-25 16:17:22 +08:00
[FilterEnum.CONTRAST]: number
2022-04-19 22:07:54 +08:00
// 滤镜-不透明度
2022-04-25 16:17:22 +08:00
[FilterEnum.OPACITY]: number
// 变换(暂不使用)
[FilterEnum.ROTATE_Z]: number
[FilterEnum.ROTATE_X]: number
[FilterEnum.ROTATE_Y]: number
[FilterEnum.SKEW_X]: number
[FilterEnum.SKEW_Y]: number
2022-10-08 11:43:38 +08:00
[FilterEnum.BLEND_MODE]: string
// 大屏名称
[EditCanvasConfigEnum.PROJECT_NAME]?: string
2022-04-19 22:07:54 +08:00
// 大屏宽度
[EditCanvasConfigEnum.WIDTH]: number
// 大屏高度
[EditCanvasConfigEnum.HEIGHT]: number
2022-01-20 21:25:35 +08:00
// 背景色
2022-02-06 21:35:38 +08:00
[EditCanvasConfigEnum.BACKGROUND]?: string
2022-06-21 10:54:05 +08:00
[EditCanvasConfigEnum.BACKGROUND_IMAGE]?: string | null
2022-02-06 21:35:38 +08:00
// 图表主题颜色
2022-02-21 19:45:11 +08:00
[EditCanvasConfigEnum.CHART_THEME_COLOR]: ChartColorsNameType
// 图表全局配置
[EditCanvasConfigEnum.CHART_THEME_SETTING]: GlobalThemeJsonType
2022-02-06 01:04:05 +08:00
// 图表主题颜色
2022-02-06 21:35:38 +08:00
[EditCanvasConfigEnum.SELECT_COLOR]: boolean
2022-05-04 01:46:56 +08:00
// 预览展示方式
[EditCanvasConfigEnum.PREVIEW_SCALE_TYPE]: PreviewScaleEnum
2022-01-20 21:25:35 +08:00
}
// 坐标轴信息
// eslint-disable-next-line no-redeclare
2022-01-20 21:25:35 +08:00
export enum EditCanvasTypeEnum {
2022-03-04 20:57:36 +08:00
START_X = 'startX',
START_Y = 'startY',
2022-01-20 21:25:35 +08:00
X = 'x',
2022-07-11 09:01:19 +08:00
Y = 'y'
2022-01-20 21:25:35 +08:00
}
2022-01-30 00:43:37 +08:00
// 鼠标位置
2022-01-20 21:25:35 +08:00
export type MousePositionType = {
2022-03-04 20:57:36 +08:00
// 开始 X
[EditCanvasTypeEnum.START_X]: number
// 开始 Y
[EditCanvasTypeEnum.START_Y]: number
// X
2022-01-20 21:25:35 +08:00
[EditCanvasTypeEnum.X]: number
2022-03-04 20:57:36 +08:00
// y
2022-01-20 21:25:35 +08:00
[EditCanvasTypeEnum.Y]: number
}
2022-01-29 11:44:51 +08:00
// 操作目标
export type TargetChartType = {
2022-02-01 01:20:00 +08:00
hoverId?: string
selectId: string[]
2022-01-29 11:44:51 +08:00
}
2022-02-04 12:17:50 +08:00
// 数据记录
export type RecordChartType = {
charts: CreateComponentType | CreateComponentGroupType | Array<CreateComponentType | CreateComponentGroupType>
2022-02-04 12:17:50 +08:00
type: HistoryActionTypeEnum.CUT | HistoryActionTypeEnum.COPY
}
2022-01-30 00:43:37 +08:00
// Store 枚举
2022-01-29 21:44:22 +08:00
export enum ChartEditStoreEnum {
2022-01-30 00:43:37 +08:00
EDIT_RANGE = 'editRange',
EDIT_CANVAS = 'editCanvas',
RIGHT_MENU_SHOW = 'rightMenuShow',
2022-01-30 00:43:37 +08:00
MOUSE_POSITION = 'mousePosition',
TARGET_CHART = 'targetChart',
2022-02-04 12:17:50 +08:00
RECORD_CHART = 'recordChart',
2022-03-17 20:18:46 +08:00
// 以下需要存储
EDIT_CANVAS_CONFIG = 'editCanvasConfig',
REQUEST_GLOBAL_CONFIG = 'requestGlobalConfig',
2022-07-11 09:01:19 +08:00
COMPONENT_LIST = 'componentList'
}
// 请求公共类型
type RequestPublicConfigType = {
// 时间单位(时分秒)
requestIntervalUnit: RequestHttpIntervalEnum
// 请求内容
requestParams: RequestParams
2022-01-20 21:25:35 +08:00
}
2022-01-24 21:12:18 +08:00
2022-11-15 21:25:35 +08:00
// 数据池项类型
export type RequestDataPondItemType = {
dataPondId: string,
dataPondName: string,
dataPondRequestConfig: RequestConfigType
}
// 全局的图表请求配置
2022-07-11 09:01:19 +08:00
export interface RequestGlobalConfigType extends RequestPublicConfigType {
2022-07-16 19:01:05 +08:00
// 组件定制轮询时间
requestInterval: number
// 请求源地址
requestOriginUrl?: string
2022-11-15 21:25:35 +08:00
// 公共数据池
requestDataPond: RequestDataPondItemType[]
}
// 单个图表请求配置
2022-07-11 09:01:19 +08:00
export interface RequestConfigType extends RequestPublicConfigType {
2022-11-15 21:25:35 +08:00
// 所选全局数据池的对应 id
requestDataPondId?: string
2022-07-16 19:01:05 +08:00
// 组件定制轮询时间
requestInterval?: number
2022-03-17 20:18:46 +08:00
// 获取数据的方式
requestDataType: RequestDataTypeEnum
2022-03-21 20:56:42 +08:00
// 请求方式 get/post/del/put/patch
requestHttpType: RequestHttpEnum
2022-04-30 21:20:51 +08:00
// 源后续的 url
requestUrl?: string
2022-07-11 09:01:19 +08:00
// 请求内容主体方式 普通/sql
requestContentType: RequestContentTypeEnum
2022-07-16 19:01:05 +08:00
// 请求体类型
requestParamsBodyType: RequestBodyEnum
2022-07-15 00:11:42 +08:00
// SQL 请求对象
requestSQLContent: {
sql: string
}
2022-03-17 20:18:46 +08:00
}
2022-01-30 00:43:37 +08:00
// Store 类型
2022-03-06 02:08:14 +08:00
export interface ChartEditStoreType {
2022-01-30 00:43:37 +08:00
[ChartEditStoreEnum.EDIT_CANVAS]: EditCanvasType
2022-02-06 01:04:05 +08:00
[ChartEditStoreEnum.EDIT_CANVAS_CONFIG]: EditCanvasConfigType
[ChartEditStoreEnum.RIGHT_MENU_SHOW]: boolean
2022-01-30 00:43:37 +08:00
[ChartEditStoreEnum.MOUSE_POSITION]: MousePositionType
2022-01-29 21:44:22 +08:00
[ChartEditStoreEnum.TARGET_CHART]: TargetChartType
2022-02-04 12:17:50 +08:00
[ChartEditStoreEnum.RECORD_CHART]?: RecordChartType
[ChartEditStoreEnum.REQUEST_GLOBAL_CONFIG]: RequestGlobalConfigType
[ChartEditStoreEnum.COMPONENT_LIST]: Array<CreateComponentType | CreateComponentGroupType>
2022-01-20 21:25:35 +08:00
}
2022-03-06 02:08:14 +08:00
// 存储数据类型
2022-03-06 02:08:14 +08:00
export interface ChartEditStorage {
2022-03-17 20:18:46 +08:00
[ChartEditStoreEnum.EDIT_CANVAS_CONFIG]: EditCanvasConfigType
[ChartEditStoreEnum.REQUEST_GLOBAL_CONFIG]: RequestGlobalConfigType
[ChartEditStoreEnum.COMPONENT_LIST]: Array<CreateComponentType | CreateComponentGroupType>
}