设计 Token
设计 Token 是主题机制的实现,可以通过一些原子化的 Token 配置集合便捷的配置样式。
例如,实现一套包含背景色和色板配置的主题:
render(dom, {
// ...
token: {
backgroundColor: '#fff',
color: ['red', 'green', 'blue']
}
});
设计 Token 兼容 ECharts 主题,可参考主题编辑器的导出格式。
token
由于 UED Token 规范不能完全覆盖可视化组件的所有配置,所以 token 参数实际上可以包含两部分内容,即 UED Token 变量和配置项,且配置项优先级高于 UED Token 变量。
UED Token 变量
设计师负责人为 @钱宇楠(qianyunan@myhexin.com),可找其参考设计规范中的 Token 集合和映射规则进行配置。
type UEDToken = {
/** 色板 */
'--color-visualization': string[];
/** 背景色 */
'--color-background-weak': string;
/** 分割线颜色 */
'--color-visualization-divider': string;
/** tooltip 背景色 / 光标线 */
'--color-visualization-tooltip': string;
/** 文本颜色 */
'--color-text-primary': string;
'--color-text-secondary': string;
'--color-text-tertiary': string;
'--color-text-quaternary': string;
'--color-text-inverse': string;
'--color-text-link': string;
'--color-text-inverse-primary': string;
'--color-text-inverse-secondary': string;
'--color-text-inverse-tertiary': string;
'--color-text-inverse-quaternary': string;
/** 基础灰阶 */
'--color-grey-01': string;
'--color-grey-02': string;
'--color-grey-03': string;
'--color-grey-04': string;
'--color-grey-05': string;
/** 字重 */
'--font-weight-regular': number;
'--font-weight-medium': number;
'--font-weight-bold': number;
/** 字体大小 */
'--font-size-super-large': number;
'--font-size-extra-large': number;
'--font-size-large': number;
'--font-size-base': number;
'--font-size-small': number;
'--font-size-extra-small': number;
'--font-size-super-small': number;
'--font-size-xxs': number;
'--font-size-xxxs': number;
/** 行高 */
'--line-height-super-large': number;
'--line-height-extra-large': number;
'--line-height-large': number;
'--line-height-base': number;
'--line-height-medium': number;
'--line-height-small': number;
'--line-height-extra-small': number;
'--line-height-super-small': number;
'--line-height-xxs': number;
};
配置项
type Token = {
/** 背景色 */
backgroundColor: string;
/** 字体 */
textStyle?: {
color?: string;
fontFamily?: string;
fontWeight?: number | string;
fontSize?: number;
lineHeight?: number;
};
/** 色板 */
color: string[];
/** 范式组件 */
dvStandardChart?: {
/** 主题 @see https://datav.iwencai.com/components/paradigm-chart/docs/apis/theme */
theme?: string;
/** 基础配置 @see https://echarts.apache.org/zh/option.html#title */
baseOption?: StandardChartOption;
};
/** 时间轴组件 */
dvTimeline?: {
theme?: (typeof TIMELINE_THEME)[keyof typeof TIMELINE_THEME];
/** 容器 dom 的 css 样式 */
domCSSText?: string;
/** 时间轴配置 @see https://datav.iwencai.com/components/paradigm-chart/docs/more/paradigm-timeline-docs/apis/option#config */
config?: TimelineOption;
};
};
Legend 组件主题配置项说明
legend 的主题配置应放在 token.dvStandardChart.baseOption.legend 下,支持如下字段:
一级字段
| 字段 | 类型 | 说明 | 可选值/示例 |
|---|---|---|---|
| dvLayout | string | 图例布局方式 | 'all' | 'scroll' | 'pagination' |
| backgroundColor | string | 图例背景色 | '#fff'、'transparent'等 |
| textStyle | object | 文本样式配置(见下表) | 见下表 |
| dvPagination | object | 分页器样式配置(见下表) | 见下表 |
| dvIcon | object | 图例 icon 样式配置(见下表) | 见下表 |
| dvLegendGap | number | 图例项之间的间距(像素) | 12、20等 |
textStyle 字段
| 字段 | 类型 | 说明 | 示例 |
|---|---|---|---|
| fontSize | number | 文本字号(px) | 14 |
| lineHeight | number | 文本行高(px) | 14 |
| fontFamily | string | 字体族 | 'PingFangSC' |
| fontWeight | string/number | 字重 | 'bold' |
| color | string | 文本颜色 | '#A1A1B3' |
| dvDisabledTextColor | string | 未激活项文本颜色 | '#4F4F5E' |
dvPagination 字段
| 字段 | 类型 | 说明 | 示例(可为 base64/svg url) |
|---|---|---|---|
| color | string | 分页器文本颜色 | '#A1A1B3' |
| fontSize | number | 分页器文本字号(px) | 12 |
| lineHeight | number | 分页器文本行高(px) | 16 |
| fontFamily | string | 分页器字体 | 'PingFangSC' |
| fontWeight | string/number | 分页器字重 | 'bold' |
| image | string | 下一页/上一页按钮图标 | 'url(...)' |
| imageHover | string | 按钮悬浮图标 | 'url(...)' |
| imageDisabled | string | 按钮禁用图标 | 'url(...)' |
dvIcon 字段
| 字段 | 类型 | 说明 | 示例 |
|---|---|---|---|
| gap | number | icon 与文本间距(px) | 6 |
| line | object | 线型 icon 尺寸 | {width:12,height:3} |
| rect | object | 矩形 icon 尺寸 | {width:12} |
| round | object | 圆形 icon 半径 | {r:12} |
完整配置示例
legend: {
dvLayout: 'pagination',
backgroundColor: 'transparent',
textStyle: {
fontSize: 14,
lineHeight: 14,
fontFamily: 'PingFangSC',
fontWeight: 'bold',
color: '#A1A1B3',
dvDisabledTextColor: '#4F4F5E'
},
dvPagination: {
color: '#A1A1B3',
fontSize: 12,
lineHeight: 16,
fontFamily: 'PingFangSC',
fontWeight: 400,
image: 'url(...)',
imageHover: 'url(...)',
imageDisabled: 'url(...)'
},
dvIcon: {
gap: 6,
line: { width: 12, height: 3 },
rect: { width: 12 },
round: { r: 12 }
},
dvLegendGap: 20
}
注意: 只需配置上述字段,其他字段不会生效。legend 配置应放在
token.dvStandardChart.baseOption.legend路径下。
dvInsight 主题配置
在 token 中,dvStandardChart.baseOption.dvInsight 路径专门用于定义数据洞察(Insight)所有可视化元素的默认样式。这使得所有图表的洞察效果在视觉上保持统一,并方便地进行全局主题切换。
其核心思想是样式与逻辑分离:
- 图表
spec.dvInsight: 定义应用何种洞察以及其关联的具体数据。 - 主题
token.dvInsight: 定义这些洞察的视觉呈现,如颜色、线条、透明度等。
配置结构
token 中的 dvInsight 是一个对象数组,采用分层样式结构:
-
通用样式 (Common Style) 数组的第一个对象用于定义全局通用样式,它没有
type字段。所有类型的洞察都会默认继承此对象中定义的样式。 -
特定类型覆盖 (Type-Specific Override) 从数组的第二个对象开始,每个对象通过指定
type字段(如"type": "Trend")来为特定类型的洞察定义专属样式。这些样式会覆盖通用样式。
样式优先级: 特定类型样式 > 通用样式。
可配置的样式模块
| 模块名 | 说明 | 适用洞察类型 |
|---|---|---|
blurSeries | 定义其他系列被“弱化”时的样式,通常是设置一个较低的 opacity。 | 所有(用于高亮或对比场景) |
line | 定义由洞察生成的标记线 (markLine) 的基础样式。 | Line, Trend, CompareLine, ComparePoint |
referenceLine | 定义用于连接两个数据点的参考线样式,通常带有箭头。 | ComparePoint, CompareLine |
axisReferenceLine | 定义用于连接数据点和坐标轴的参考线样式,通常是虚线。 | Point |
area | 定义由洞察生成的标记区域 (markArea) 的样式。 | Interval, IntervalX |
textSummary | 一个复合对象,用于定义通过 dvMarker 渲染的富文本标注的复杂样式(如背景、引线)。 | Point, Trend 等需要显示复杂文本信息的洞察 |
textStyle | 定义由洞察生成的简单文本 (markPoint.label) 的样式。 | Text |
完整示例
// 位于 token.dvStandardChart.baseOption.dvInsight
dvInsight: [
// =======================================================
// 1. 通用配置 (无 type 字段)
// 所有洞察类型都会继承这里的样式
// =======================================================
{
// 文本标注的默认样式
textSummary: {
rectStyle: { style: { fill: '#FFFFFF', opacity: 0.8 } },
textStyle: { style: { fill: '#000' } }
},
// 标记线的默认样式
line: {
lineStyle: { width: 1, color: '#F2920D' },
label: { color: '#F2920D' }
},
// 参考线的默认样式 (如对比线)
referenceLine: {
symbol: 'image://...', // 默认使用 SVG 箭头
lineStyle: { color: '#FFF' }
},
// 弱化效果的默认样式
blurSeries: {
itemStyle: { opacity: 0.2 },
lineStyle: { opacity: 0.2 }
}
},
// =======================================================
// 2. 特定类型覆盖 (有 type 字段)
// 这里的样式会覆盖通用配置
// =======================================================
{
"type": "Trend",
// 将 "Trend" 洞察的标记线颜色覆盖为 #fff
"line": {
"lineStyle": { "color": "#fff" },
"label": { "color": "#fff" }
}
},
{
"type": "Text",
// 将 "Text" 洞察的文本颜色覆盖为 #FFF
"textStyle": {
"color": "#FFF"
}
}
]
Series 主题配置
与 dvInsight 类似,token 中的 dvStandardChart.baseOption.series 路径允许您为**不同类型的系列(series)**定义全局的默认样式。这使得在主题层面统一特定图表类型(如所有柱状图、所有折线图)的视觉表现成为可能,而无需在每个图表实例中重复配置。
配置结构与原理
series 的配置是一个对象数组。数组中的每个对象都通过 type 字段来指定其应用的目标系列类型。当 VISALL 渲染图表时,它会:
- 检查图表中每个
series的type。 - 在
token的series数组中查找具有相同type的配置对象。 - 将
token中定义的样式深度合并到图表实例的series配置中。
这提供了一种强大的、基于类型的样式模板机制。
自定义配置项
除了支持所有 ECharts 原生的 series 配置外,VISALL 还扩展了一些自定义的 dv* 属性,以提供更强的功能:
-
dvTextColors:- 适用类型:
wordCloud - 作用: 为词云图提供一组特定的文本颜色,渲染器会从这个数组中为词语循环取色。
- 适用类型:
-
dvReferenceLine:- 适用类型:
bar - 作用: 一个对象,用于控制在柱状图上绘制参考线。
{ show: true, color: '#...' }。
- 适用类型:
-
dvData:- 适用类型:
通用 - 作用: 一个数据处理函数
(data) => void。该函数在图表渲染前执行,允许您在主题层面直接修改系列图的数据,例如动态调整标签颜色或节点样式。这是一个强大的主题级数据转换钩子。
- 适用类型:
完整示例
以下示例展示了如何为 line, bar, pie, wordCloud, sankey 等多种图表类型设置默认样式和自定义行为。
// 位于 token.dvStandardChart.baseOption.series
series: [
// 为所有折线图(line)设置默认样式
{
type: 'line',
symbolSize: 8, // 标记点大小
lineStyle: {
width: 1.5 // 线条宽度
},
itemStyle: {
opacity: 0 // 默认隐藏标记点,悬浮时再显示
}
},
// 为所有柱状图(bar)设置默认样式
{
type: 'bar',
barMaxWidth: 14, // 柱子最大宽度
label: {
color: '#FFF' // 标签文字颜色
},
// 自定义属性:显示参考线
dvReferenceLine: {
show: true,
color: '#828FA1'
}
},
// 为词云图提供专用的文本颜色列表
{
type: 'wordCloud',
dvTextColors: [
'#FAFBFC',
'#E9EDF6',
'#E0E4EA',
'#828FA1'
]
},
// 为桑基图(sankey)提供一个数据后处理钩子
{
type: 'sankey',
// 在渲染前修改每个数据项的标签颜色
dvData: data => {
data.forEach(item => {
item.label.rich.a.color = '#dadada';
item.label.rich.b.color = '#dadada';
});
}
},
// 为饼图(pie)设置默认样式
{
type: 'pie',
label: {
color: '#FFF'
},
labelLine: {
length: 5 // 标签引导线长度
}
}
]
dvHXKLine 主题配置
dvHXKLine 是 token 中一个高度集成的配置模块,专门用于深度定制行情 K 线图及其衍生组件。由于行情图的复杂性,它的配置项非常丰富,并且拥有自己独立的命名空间和配置结构。
配置结构
dvHXKLine 模块内部包含多个对象,分别对应不同类型的 K 线图以及它们的共享模块:
-
特定 K 线图配置:
hxKLine: 标准 K 线图hxKLineAndBar: K 线图与成交量图(柱状图)hxKLineAndDynamicLine: K 线图与动态指标线hxKLineAndMultiIndicatorLine: K 线图与多条动态指标线hxKLineAndTag: K 线图与标签
这些对象内部都有一个
option字段,其结构遵循底层行情图组件库的私有 schema,用于定义该类型 K 线图的核心行为和样式(如yAxis,candle,indicator等),详细可以参考HXKLine 文档。 -
共享模块配置:
tooltip: 配置所有 K 线图的提示框样式。dataZoom: 配置所有 K 线图的数据漫游组件(缩放条)样式。constants: 一个非常重要的常量集合,它为整个dvHXKLine组件家族定义了一套独立的“微型设计 Token”,包括各种涨跌颜色、字体、线条颜色等(详情可以参考HXKLine 常量配置,或者咨询@穆泓宋)。
重点配置项说明
-
[kLineType].option: 这是针对特定 K 线图类型的核心配置,其内容会直接传递给底层的行情图渲染引擎。您可以在这里配置坐标轴 (xAxis,yAxis)、K 线实体 (candle)、技术指标 (indicator) 等。hxKLine: {
option: {
yAxis: { inside: false, tickText: { family: 'Microsoft YaHei' } },
candle: { priceMark: { show: false } }
}
} -
[kLineType].rect:- 适用类型:
hxKLineAndTag - 作用: 当 K 线图附带标签时,此对象用于定义标签矩形的边框、背景色,以及在不同交互状态(
hover,active)下的样式。
hxKLineAndTag: {
rect: {
borderColor: '#545E71',
backgroundColor: 'rgba(84, 94, 113, 0.16)',
hoverBackgroundColor: 'rgba(99, 111, 255, 0.08)',
activeBorderColor: '#636FFF',
}
} - 适用类型:
-
dataZoom: 配置 K 线图底部的数据缩放滚动条。可以自定义背景色、填充色、手柄图标等(参考ECharts配置文档)。dataZoom: {
backgroundColor: '#60656C',
fillerColor: 'rgba(15,98,254,0.2)',
handleIcon: 'image://...'
} -
constants: 这是dvHXKLine的基础调色板和尺寸规范。它定义了一系列以DEFAULT_开头的常量,如DEFAULT_COLOR_UP(上涨红)、DEFAULT_COLOR_DOWN(下跌绿)、DEFAULT_GRID_LINE_COLOR(网格线颜色)、DEFAULT_FONT_FAMILY(默认字体) 等。K 线图组件内部会优先使用这些常量作为默认值。通过修改constants,可以实现对 K 线图整体视觉风格的快速、全局性调整。constants: {
DEFAULT_COLOR_UP: '#FF2436',
DEFAULT_COLOR_DOWN: '#07AB4B',
DEFAULT_GRID_LINE_COLOR: 'rgba(255, 255, 255, 0.06)',
DEFAULT_FONT_FAMILY: '-apple-system,BlinkMacSystemFont,sans-serif'
}
UI 组件主题配置
除了 ECharts 相关的图表,VISALL 还包含一系列基于原生 DOM 构建的、独立的 UI 组件,如文本卡片(dvText)、时间轴(dvTimeLine)和多维表格(dvTable)。这些组件的主题同样可以通过 token 进行配置。
配置原理
这些组件的主题机制基于 CSS 自定义属性 (CSS Custom Properties)。
- 在
token中,为相应的组件模块(如dvTable)提供一个对象。 - 该对象的所有
key都应为以--theme-开头的字符串,这对应一个 CSS 变量名。 - 组件在初始化时,会遍历这些
key-value对,并通过domElement.style.setProperty(key, value)将它们注入到组件的根元素的style属性上。 - 组件自身的样式表(SCSS)通过
var(--theme-some-property)的方式来使用这些变量,从而实现动态的主题切换。
dvText
用于配置 @visall/text 组件。
| Token Key | 说明 |
|---|---|
--theme-background | 组件的整体背景色 |
--theme-text-color | 主要文本颜色 |
--theme-title-color | 标题文本颜色 |
--theme-text-background-normal | 文本块在普通状态下的背景色 |
--theme-text-background-hover | 文本块在悬浮状态下的背景色 |
--theme-text-background-select | 文本块在选中状态下的背景色 |
dvTimeLine
用于配置 @visall/timeline 组件。
| Token Key | 说明 |
|---|---|
--theme-background | 组件的整体背景色 |
--theme-border | 边框颜色 |
--theme-line-border | 时间轴线的颜色 |
--theme-label | 标签文本颜色 |
--theme-label-background | 标签背景色 |
--theme-time | 时间节点的文本颜色 |
--theme-text | 事件内容的文本颜色 |
--theme-link | 事件内容中的链接颜色 |
--theme-text-hover | 事件内容在悬浮状态下的背景色 |
--theme-text-select | 事件内容在选中状态下的背景色 |
--theme-button-color | 控制按钮的颜色 |
dvTable
用于配置 @visall/table 组件。这是一个复杂的组件,因此 token 数量较多。
| Token Key | 说明 |
|---|---|
--theme-border | 表格单元格的常规边框色 |
--theme-border-select | 选中状态下的边框色 |
--theme-header-background | 表头的背景色 |
--theme-header-text | 表头的文本颜色 |
--theme-normal-background | 内容单元格的背景色 |
--theme-normal-text | 内容单元格的文本颜色 |
--theme-header-hover | 表头在悬浮状态下的背景色 |
--theme-normal-hover | 内容单元格在悬浮状态下的背景色 |
--theme-header-select | 表头在选中状态下的背景色 |
--theme-icon-container | 图标容器的背景(可为渐变色) |
--theme-icon-container-hover | 悬浮时图标容器的背景 |
--theme-icon-container-selected | 选中时图标容器的背景 |
--theme-expand-icon-background | 展开/收起图标的背景 |
--theme-sort-icon-container-hover | 排序图标在悬浮时的背景 |
--theme-tree-icon-hover | 树形表格图标在悬浮时的背景 |
--theme-icon-up | “升序”图标的 url() |
--theme-icon-up-enable | “升序”图标在激活状态下的 url() |
--theme-icon-down | “降序”图标的 url() |
--theme-icon-down-enable | “降序”图标在激活状态下的 url() |
--theme-expand-icon-text | 展开/收起图标旁的文本颜色 |
--theme-expand-icon-down | “展开”图标的 url() |
dvDropdown
用于配置位于 src/ui/dropdown 的下拉菜单组件。
| Token Key | 说明 |
|---|---|
--theme-text | 文本颜色 |
--theme-text-hover | 悬浮状态的文本颜色 |
--theme-background | 背景色 |
--theme-background-hover | 悬浮状态的背景色 |
--theme-background-select | 选中状态的背景色 |
--theme-border | 边框颜色 |
--theme-kline-text | K线图场景下的文本颜色 |
--theme-kline-text-hover | K线图场景下悬浮的文本颜色 |
--theme-dropdown | 下拉箭头图标的 url() |
--theme-default-dropdown | 默认下拉箭头图标的 url() |
dvPagination
用于配置位于 src/ui/pagination 的分页器组件。
| Token Key | 说明 |
|---|---|
--theme-button | “上一页/下一页”按钮的图标 url() |
--theme-more | “更多”按钮的图标 url() |
--theme-fast | “快速跳转”按钮的图标 url() |
--theme-button-disabled | 禁用状态按钮的图标 url() |
--theme-background-color-disabled | 禁用状态的背景色 |
--theme-background-color | 默认背景色 |
--theme-border-color | 边框颜色 |
--theme-background-color-selected | 选中页码的背景色 |
--theme-font-color-selected | 选中页码的文本颜色 |
--theme-border-color-selected | 选中页码的边框颜色 |
--theme-background-color-hover | 悬浮状态的背景色 |
--theme-font-color-hover | 悬浮状态的文本颜色 |
--theme-font-color | 默认文本颜色 |
dvButtonGroup
用于配置位于 src/ui/buttonGroup 的按钮组组件。
| Token Key | 说明 |
|---|---|
--theme-container-background-color | 按钮组容器的背景色 |
--theme-color | 按钮文本/图标的颜色 |
--theme-color-hover | 悬浮时按钮的颜色 |
--theme-background-color-selected | 选中时按钮的背景色 |
--theme-color-selected | 选中时按钮的颜色 |
--theme-background-color | 单个按钮的默认背景色 |
dvScrollButtonGroup
用于配置位于 src/ui/scrollButtonGroup 的可滚动按钮组组件。
| Token Key | 说明 |
|---|---|
--theme-background-color | 按钮背景色 |
--theme-color | 按钮文本颜色 |
--theme-background-color-hover | 悬浮时按钮的背景色 |
--theme-color-hover | 悬浮时按钮的文本颜色 |
--theme-color-selected | 选中时按钮的文本颜色 |
--theme-background-color-selected | 选中时按钮的背景色 |
示例
{
// ... 其他 token 配置
dvText: {
'--theme-background': '#10182E',
'--theme-text-color': '#FFD993',
'--theme-title-color': '#C4CAD5'
},
dvPagination: {
'--theme-background-color': '#181E25',
'--theme-border-color': '#60656C',
'--theme-font-color': '#FFFFFF',
'--theme-background-color-selected': '#2C375D',
'--theme-font-color-selected': '#7E8DFF'
},
dvButtonGroup: {
'--theme-color': '#C8CBD0',
'--theme-background-color-selected': '#24282E',
'--theme-color-selected': '#7E8DFF',
},
dvDropdown: {
'--theme-text': '#FAFBFC',
'--theme-background': '#181E25',
'--theme-background-select': '#272E50',
'--theme-border': '#60656C',
}
// ...
}
图表特定主题配置
除了上述通用配置外,token 中还包含一些直接与特定图表类型或渲染器绑定的配置项。
dvTreemapLevelStyle
用于深度定制可下钻矩形树图 (drillableTreeMap) 的层级样式。
| Token Key | 说明 |
|---|---|
labelOpenIcon | “上卷”图标的 url() |
labelCloseIcon | “下钻”图标的 url() |
labelColor | 层级标签的全局文字颜色 |
level_2, level_3, ... | 特定层级的样式配置对象。key 必须为 level_ + 层级数。 |
[level_n].itemStyleBorderColor | 第 n 层矩形块的边框颜色 |
[level_n].upperLabelBackgroundColor | 第 n 层“面包屑”标签的背景色 |
[level_n].upperLabelBackgroundColorE | 第 n 层“面包屑”标签在悬浮或高亮 (Emphasis) 状态下的背景色 |
dvMarkerLine
用于配置由 markerLine 图层渲染的自定义标记线的样式。
| Token Key | 说明 |
|---|---|
titleColor | 标记点上标题文本的颜色 |
descColor | 标记点上描述文本的颜色 |
scatterBorderColor | 标记点(散点)的边框颜色 |
markerBackground | 标记点的背景色(通常带有透明度) |
markerCircleColor | 标记点内部小圆点的颜色 |
dvRadar
用于配置雷达图 (radar) 的坐标系样式。其内部结构与 ECharts 的 radar 配置项完全一致。
| Token Key | 说明 |
|---|---|
axisLine | 坐标轴轴线相关设置 |
splitLine | 坐标轴在 grid 区域中的分隔线。 |
axisName | 坐标轴名称的文字样式 |
splitArea | 坐标轴在 grid 区域中的分隔区域,默认是关闭的。 |
示例
{
// ... 其他 token 配置
dvTreemapLevelStyle: {
labelOpenIcon: 'data:image/svg+xml;...',
labelCloseIcon: 'data:image/svg+xml;...',
labelColor: '#fff',
level_2: {
itemStyleBorderColor: 'rgba(42, 53, 78, 1)',
upperLabelBackgroundColor: 'rgba(42, 53, 78, 1)'
},
level_3: {
upperLabelBackgroundColor: 'rgba(84, 94, 113, 1)'
}
},
dvMarkerLine: {
titleColor: '#fff',
descColor: '#C4CAD5',
markerBackground: 'rgba(0, 0, 0, 0.5)'
},
dvRadar: {
axisLine: {
lineStyle: { color: '#2A354E' }
},
splitLine: {
lineStyle: { color: '#2A354E' }
},
axisName: { color: '#F2F5FA' }
}
// ...
}