598 lines
16 KiB
JavaScript
598 lines
16 KiB
JavaScript
/*
|
|
* @Descripttion: 柱状图json
|
|
* @version:
|
|
* @Author: qianlishi
|
|
* @Date: 2021-08-29 07:21:45
|
|
* @LastEditors: qianlishi
|
|
* @LastEditTime: 2022-03-11 11:40:29
|
|
*/
|
|
export const widgetBarchart = {
|
|
code: 'widget-barchart',
|
|
type: 'barChart',
|
|
tabName: '柱状图',
|
|
label: '柱状图',
|
|
icon: 'iconzhuzhuangtu',
|
|
options: {
|
|
// 配置
|
|
setup: [
|
|
{
|
|
type: 'el-input-text',
|
|
label: '图层名称',
|
|
name: 'layerName',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '柱状图',
|
|
},
|
|
{
|
|
type: 'el-switch',
|
|
label: '竖展示',
|
|
name: 'verticalShow',
|
|
required: false,
|
|
placeholder: '',
|
|
value: false,
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '背景颜色',
|
|
name: 'background',
|
|
required: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
[
|
|
{
|
|
name: '柱体设置',
|
|
list: [
|
|
{
|
|
type: 'el-slider',
|
|
label: '最大宽度',
|
|
name: 'maxWidth',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 10,
|
|
},
|
|
{
|
|
type: 'el-slider',
|
|
label: '圆角',
|
|
name: 'radius',
|
|
require: false,
|
|
placeholder: '',
|
|
value: 5,
|
|
},
|
|
{
|
|
type: 'el-slider',
|
|
label: '最小高度',
|
|
name: 'minHeight',
|
|
require: false,
|
|
placeholder: '',
|
|
value: 0,
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: '标题设置',
|
|
list: [
|
|
{
|
|
type: 'el-switch',
|
|
label: '标题',
|
|
name: 'isNoTitle',
|
|
required: false,
|
|
placeholder: '',
|
|
value: true,
|
|
},
|
|
{
|
|
type: 'el-input-text',
|
|
label: '标题',
|
|
name: 'titleText',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '',
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '字体颜色',
|
|
name: 'textColor',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#FFD700'
|
|
},
|
|
{
|
|
type: 'el-select',
|
|
label: '字体粗细',
|
|
name: 'textFontWeight',
|
|
required: false,
|
|
placeholder: '',
|
|
selectOptions: [
|
|
{code: 'normal', name: '正常'},
|
|
{code: 'bold', name: '粗体'},
|
|
{code: 'bolder', name: '特粗体'},
|
|
{code: 'lighter', name: '细体'}
|
|
],
|
|
value: 'normal'
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '字体字号',
|
|
name: 'textFontSize',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 20
|
|
},
|
|
{
|
|
type: 'el-select',
|
|
label: '字体位置',
|
|
name: 'textAlign',
|
|
required: false,
|
|
placeholder: '',
|
|
selectOptions: [
|
|
{code: 'center', name: '居中'},
|
|
{code: 'left', name: '左对齐'},
|
|
{code: 'right', name: '右对齐'},
|
|
],
|
|
value: 'center'
|
|
},
|
|
{
|
|
type: 'el-input-text',
|
|
label: '副标题',
|
|
name: 'subText',
|
|
required: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '字体颜色',
|
|
name: 'subTextColor',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 'rgba(30, 144, 255, 1)'
|
|
},
|
|
{
|
|
type: 'el-select',
|
|
label: '字体粗细',
|
|
name: 'subTextFontWeight',
|
|
required: false,
|
|
placeholder: '',
|
|
selectOptions: [
|
|
{code: 'normal', name: '正常'},
|
|
{code: 'bold', name: '粗体'},
|
|
{code: 'bolder', name: '特粗体'},
|
|
{code: 'lighter', name: '细体'}
|
|
],
|
|
value: 'normal'
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '字体字号',
|
|
name: 'subTextFontSize',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 20
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: 'X轴设置',
|
|
list: [
|
|
{
|
|
type: 'el-switch',
|
|
label: '显示',
|
|
name: 'hideX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: true,
|
|
},
|
|
{
|
|
type: 'el-input-text',
|
|
label: '坐标名',
|
|
name: 'xName',
|
|
required: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '坐标名颜色',
|
|
name: 'nameColorX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff'
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '坐标字号',
|
|
name: 'nameFontSizeX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 14
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '数值颜色',
|
|
name: 'Xcolor',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '数值字号',
|
|
name: 'fontSizeX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 14,
|
|
},
|
|
{
|
|
type: 'el-slider',
|
|
label: '数值角度',
|
|
name: 'textAngle',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 0
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '数值间隔',
|
|
name: 'textInterval',
|
|
required: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
{
|
|
type: 'el-switch',
|
|
label: '轴反转',
|
|
name: 'reversalX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: false
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '轴颜色',
|
|
name: 'lineColorX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
},
|
|
{
|
|
type: 'el-switch',
|
|
label: '分割线显示',
|
|
name: 'isShowSplitLineX',
|
|
require: false,
|
|
placeholder: '',
|
|
value: false,
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '分割线颜色',
|
|
name: 'splitLineColorX',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
|
|
}
|
|
],
|
|
},
|
|
{
|
|
name: 'Y轴设置',
|
|
list: [
|
|
{
|
|
type: 'el-switch',
|
|
label: '显示',
|
|
name: 'isShowY',
|
|
require: false,
|
|
placeholder: '',
|
|
value: true,
|
|
},
|
|
{
|
|
type: 'el-input-text',
|
|
label: '坐标名',
|
|
name: 'textNameY',
|
|
require: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '坐标名颜色',
|
|
name: 'nameColorY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '坐标字号',
|
|
name: 'nameFontSizeY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 14,
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '数值颜色',
|
|
name: 'colorY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '数值字号',
|
|
name: 'fontSizeY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 14,
|
|
},
|
|
{
|
|
type: 'el-slider',
|
|
label: '数值角度',
|
|
name: 'ytextAngle',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 0
|
|
},
|
|
{
|
|
type: 'el-switch',
|
|
label: '缩放',
|
|
name: 'scale',
|
|
require: false,
|
|
placeholder: '',
|
|
value: false,
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '均分',
|
|
name: 'splitNumber',
|
|
required: false,
|
|
placeholder: '',
|
|
value: ''
|
|
},
|
|
{
|
|
type: 'el-switch',
|
|
label: '轴反转',
|
|
name: 'reversalY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: false
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '轴颜色',
|
|
name: 'lineColorY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
}, {
|
|
type: 'el-switch',
|
|
label: '分割线显示',
|
|
name: 'isShowSplitLineY',
|
|
require: false,
|
|
placeholder: '',
|
|
value: false,
|
|
}, {
|
|
type: 'vue-color',
|
|
label: '分割线颜色',
|
|
name: 'splitLineColorY',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff',
|
|
|
|
}
|
|
],
|
|
},
|
|
{
|
|
name: '数值设定',
|
|
list: [
|
|
{
|
|
type: 'el-switch',
|
|
label: '显示',
|
|
name: 'isShow',
|
|
required: false,
|
|
placeholder: '',
|
|
value: true
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '距离',
|
|
name: 'distance',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 5
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '字体字号',
|
|
name: 'fontSize',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 14
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '字体颜色',
|
|
name: 'subTextColor',
|
|
required: false,
|
|
placeholder: '',
|
|
value: '#fff'
|
|
},
|
|
{
|
|
type: 'el-select',
|
|
label: '字体粗细',
|
|
name: 'fontWeight',
|
|
required: false,
|
|
placeholder: '',
|
|
selectOptions: [
|
|
{code: 'normal', name: '正常'},
|
|
{code: 'bold', name: '粗体'},
|
|
{code: 'bolder', name: '特粗体'},
|
|
{code: 'lighter', name: '细体'}
|
|
],
|
|
value: 'normal'
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: '提示语设置',
|
|
list: [
|
|
{
|
|
type: 'el-input-number',
|
|
label: '字体字号',
|
|
name: 'tipsFontSize',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 16
|
|
},
|
|
{
|
|
type: 'vue-color',
|
|
label: '字体颜色',
|
|
name: 'lineColor',
|
|
required: false,
|
|
placeholder: '',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: '坐标轴边距设置',
|
|
list: [
|
|
{
|
|
type: 'el-slider',
|
|
label: '左边距(像素)',
|
|
name: 'marginLeft',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 10,
|
|
}, {
|
|
type: 'el-slider',
|
|
label: '顶边距(像素)',
|
|
name: 'marginTop',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 50,
|
|
}, {
|
|
type: 'el-slider',
|
|
label: '右边距(像素)',
|
|
name: 'marginRight',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 40,
|
|
}, {
|
|
type: 'el-slider',
|
|
label: '底边距(像素)',
|
|
name: 'marginBottom',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 10,
|
|
},
|
|
],
|
|
},
|
|
{
|
|
name: '自定义配色',
|
|
list: [
|
|
{
|
|
type: 'customColor',
|
|
label: '',
|
|
name: 'customColor',
|
|
required: false,
|
|
value: [{color: '#ff7f50'}, {color: '#87cefa'}, {color: '#da70d6'}, {color: '#32cd32'}, {color: '#6495ed'}],
|
|
},
|
|
],
|
|
},
|
|
],
|
|
],
|
|
// 数据
|
|
data: [
|
|
{
|
|
type: 'el-radio-group',
|
|
label: '数据类型',
|
|
name: 'dataType',
|
|
require: false,
|
|
placeholder: '',
|
|
selectValue: true,
|
|
selectOptions: [
|
|
{
|
|
code: 'staticData',
|
|
name: '静态数据',
|
|
},
|
|
{
|
|
code: 'dynamicData',
|
|
name: '动态数据',
|
|
},
|
|
],
|
|
value: 'staticData',
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '刷新时间(毫秒)',
|
|
name: 'refreshTime',
|
|
relactiveDom: 'dataType',
|
|
relactiveDomValue: 'dynamicData',
|
|
value: 5000
|
|
},
|
|
{
|
|
type: 'el-button',
|
|
label: '静态数据',
|
|
name: 'staticData',
|
|
required: false,
|
|
placeholder: '',
|
|
relactiveDom: 'dataType',
|
|
relactiveDomValue: 'staticData',
|
|
value: [
|
|
{"axis": "苹果", "data": 1000},
|
|
{"axis": "三星", "data": 2229},
|
|
{"axis": "小米", "data": 3879},
|
|
{"axis": "oppo", "data": 2379},
|
|
{"axis": "vivo", "data": 4079},
|
|
],
|
|
},
|
|
{
|
|
type: 'dycustComponents',
|
|
label: '',
|
|
name: 'dynamicData',
|
|
required: false,
|
|
placeholder: '',
|
|
relactiveDom: 'dataType',
|
|
relactiveDomValue: 'dynamicData',
|
|
chartType: 'widget-barchart',
|
|
dictKey: 'BAR_PROPERTIES',
|
|
value: '',
|
|
},
|
|
],
|
|
// 坐标
|
|
position: [
|
|
{
|
|
type: 'el-input-number',
|
|
label: '左边距',
|
|
name: 'left',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 0,
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '上边距',
|
|
name: 'top',
|
|
required: false,
|
|
placeholder: '',
|
|
value: 0,
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '宽度',
|
|
name: 'width',
|
|
required: false,
|
|
placeholder: '该容器在1920px大屏中的宽度',
|
|
value: 400,
|
|
},
|
|
{
|
|
type: 'el-input-number',
|
|
label: '高度',
|
|
name: 'height',
|
|
required: false,
|
|
placeholder: '该容器在1080px大屏中的高度',
|
|
value: 200,
|
|
},
|
|
],
|
|
}
|
|
}
|