adaptor.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. import { __assign, __rest } from "tslib";
  2. import { animation, annotation, interaction, legend, scale, theme, tooltip } from '../../adaptor/common';
  3. import { interval, point } from '../../adaptor/geometries';
  4. import { pattern } from '../../adaptor/pattern';
  5. import { deepAssign, findGeometry, flow, processIllegalData, transformLabel } from '../../utils';
  6. import { getScaleMax, getStackedData } from './utils';
  7. /**
  8. * geometry 处理
  9. * @param params
  10. */
  11. function geometry(params) {
  12. var chart = params.chart, options = params.options;
  13. var style = options.barStyle, color = options.color, tooltip = options.tooltip, colorField = options.colorField, type = options.type, xField = options.xField, yField = options.yField, data = options.data, shape = options.shape;
  14. // 处理不合法的数据
  15. var processData = processIllegalData(data, yField);
  16. chart.data(processData);
  17. var p = deepAssign({}, params, {
  18. options: {
  19. tooltip: tooltip,
  20. seriesField: colorField,
  21. interval: {
  22. style: style,
  23. color: color,
  24. shape: shape || (type === 'line' ? 'line' : 'intervel'),
  25. },
  26. // 柱子的一些样式设置:柱子最小宽度、柱子最大宽度、柱子背景
  27. minColumnWidth: options.minBarWidth,
  28. maxColumnWidth: options.maxBarWidth,
  29. columnBackground: options.barBackground,
  30. },
  31. });
  32. interval(p);
  33. if (type === 'line') {
  34. point({
  35. chart: chart,
  36. options: { xField: xField, yField: yField, seriesField: colorField, point: { shape: 'circle', color: color } },
  37. });
  38. }
  39. return params;
  40. }
  41. /**
  42. * meta 配置
  43. * @param params
  44. */
  45. export function meta(params) {
  46. var _a;
  47. var options = params.options;
  48. var yField = options.yField, xField = options.xField, data = options.data, isStack = options.isStack, isGroup = options.isGroup, colorField = options.colorField, maxAngle = options.maxAngle;
  49. var actualData = isStack && !isGroup && colorField ? getStackedData(data, xField, yField) : data;
  50. var processData = processIllegalData(actualData, yField);
  51. return flow(scale((_a = {},
  52. _a[yField] = {
  53. min: 0,
  54. max: getScaleMax(maxAngle, yField, processData),
  55. },
  56. _a)))(params);
  57. }
  58. /**
  59. * coordinate 配置
  60. * @param params
  61. */
  62. function coordinate(params) {
  63. var chart = params.chart, options = params.options;
  64. var radius = options.radius, innerRadius = options.innerRadius, startAngle = options.startAngle, endAngle = options.endAngle;
  65. chart
  66. .coordinate({
  67. type: 'polar',
  68. cfg: {
  69. radius: radius,
  70. innerRadius: innerRadius,
  71. startAngle: startAngle,
  72. endAngle: endAngle,
  73. },
  74. })
  75. .transpose();
  76. return params;
  77. }
  78. /**
  79. * axis 配置
  80. * @param params
  81. */
  82. export function axis(params) {
  83. var chart = params.chart, options = params.options;
  84. var xField = options.xField, xAxis = options.xAxis;
  85. chart.axis(xField, xAxis);
  86. return params;
  87. }
  88. /**
  89. * 数据标签
  90. * @param params
  91. */
  92. function label(params) {
  93. var chart = params.chart, options = params.options;
  94. var label = options.label, yField = options.yField;
  95. var intervalGeometry = findGeometry(chart, 'interval');
  96. // label 为 false, 空 则不显示 label
  97. if (!label) {
  98. intervalGeometry.label(false);
  99. }
  100. else {
  101. var callback = label.callback, cfg = __rest(label, ["callback"]);
  102. intervalGeometry.label({
  103. fields: [yField],
  104. callback: callback,
  105. cfg: __assign(__assign({}, transformLabel(cfg)), { type: 'polar' }),
  106. });
  107. }
  108. return params;
  109. }
  110. /**
  111. * 图适配器
  112. * @param chart
  113. * @param options
  114. */
  115. export function adaptor(params) {
  116. return flow(pattern('barStyle'), geometry, meta, axis, coordinate, interaction, animation, theme, tooltip, legend, annotation(), label)(params);
  117. }
  118. //# sourceMappingURL=adaptor.js.map