进度条.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. // 配置版本号
  2. const version = '0.0.1'
  3. // 分类
  4. const category = 'Progress'
  5. // 标题
  6. const title = '进度条'
  7. // 类别, new Gauge()
  8. const chartType = 'Progress'
  9. // 用于标识,唯一,和文件夹名称一致
  10. const name = 'JinDuTiao'
  11. // 右侧配置项
  12. const setting = [
  13. {
  14. label: '指标',
  15. // 设置组件类型
  16. type: 'select',
  17. // 字段
  18. field: 'percent',
  19. // 对应options中的字段
  20. optionField: 'percent',
  21. // 是否多选
  22. multiple: false,
  23. value: '',
  24. tabName: 'data'
  25. },
  26. /** 样式配置 **/
  27. // 图表 graph
  28. {
  29. label: '进度条背景色',
  30. // 设置组件类型
  31. type: 'colorPicker',
  32. // 字段
  33. field: 'backColor',
  34. // 对应options中的字段
  35. optionField: 'backColor',
  36. value: '#fff',
  37. tabName: 'custom',
  38. groupName: 'graph'
  39. },
  40. {
  41. label: '进度条颜色',
  42. // 设置组件类型
  43. type: 'colorPicker',
  44. // 字段
  45. field: 'frontColor',
  46. // 对应options中的字段
  47. optionField: 'frontColor',
  48. value: '#4a7af4',
  49. tabName: 'custom',
  50. groupName: 'graph'
  51. },
  52. {
  53. label: '不透明度',
  54. // 设置组件类型
  55. type: 'slider',
  56. // 字段
  57. field: 'progressStyle_fillOpacity',
  58. // 对应options中的字段
  59. optionField: 'progressStyle.fillOpacity',
  60. value: 1,
  61. tabName: 'custom',
  62. groupName: 'graph'
  63. },
  64. // 边距 padding
  65. {
  66. label: '图表边距',
  67. type: 'padding', // 设置组件类型
  68. field: 'appendPadding', // 字段
  69. optionField: 'appendPadding', // 对应options中的字段
  70. value: [0, 0, 0, 0],
  71. tabName: 'custom',
  72. groupName: 'padding'
  73. }
  74. ]
  75. const data = [
  76. {
  77. percent: 0.536
  78. }
  79. ]
  80. // 配置处理脚本
  81. const optionHandler = 'option.color = [option.frontColor, option.backColor]'
  82. // 数据处理脚本
  83. const dataHandler = '// 取返回数据列表的第一项指标值\noption.percent = data[0][setting.filter(settingItem=>settingItem.field === \'percent\')[0].value]'
  84. // 图表配置 new Gauge('domName', option)
  85. const option = {
  86. // 数据将要放入到哪个字段中
  87. dataKey: 'percent',
  88. data,
  89. appendPadding: [0, 0, 0, 0], // 设置图标的边距
  90. height: 50,
  91. width: 400,
  92. autoFit: true,
  93. percent: 0.8,
  94. barWidthRatio: 0.3,
  95. backColor: '#EEEEEE',
  96. frontColor: '#4391F4',
  97. color: ['#4a7af4', '#fff'],
  98. progressStyle: {
  99. current: {
  100. style: {
  101. fillOpacity: 1,
  102. lineWidth: 0,
  103. shadowColor: 'black'
  104. }
  105. }
  106. }
  107. }
  108. export default {
  109. category,
  110. version,
  111. title,
  112. chartType,
  113. name,
  114. option,
  115. setting,
  116. dataHandler,
  117. optionHandler
  118. }