adaptor.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. exports.adaptor = void 0;
  4. var tslib_1 = require("tslib");
  5. var common_1 = require("../../adaptor/common");
  6. var geometries_1 = require("../../adaptor/geometries");
  7. var utils_1 = require("../../utils");
  8. /**
  9. * geometry 配置处理
  10. * @param params
  11. */
  12. function geometry(params) {
  13. var chart = params.chart, options = params.options;
  14. var data = options.data, lineStyle = options.lineStyle, color = options.color, pointOptions = options.point, areaOptions = options.area;
  15. chart.data(data);
  16. // 雷达图 主 geometry
  17. var primary = (0, utils_1.deepAssign)({}, params, {
  18. options: {
  19. line: {
  20. style: lineStyle,
  21. color: color,
  22. },
  23. point: pointOptions
  24. ? tslib_1.__assign({ color: color }, pointOptions) : pointOptions,
  25. area: areaOptions
  26. ? tslib_1.__assign({ color: color }, areaOptions) : areaOptions,
  27. // label 不传递给各个 geometry adaptor,由 label adaptor 处理
  28. label: undefined,
  29. },
  30. });
  31. // 副 Geometry
  32. var second = (0, utils_1.deepAssign)({}, primary, {
  33. options: {
  34. tooltip: false,
  35. },
  36. });
  37. // 优先使用 point.state, 其次取主元素的 state 状态样式配置
  38. var pointState = (pointOptions === null || pointOptions === void 0 ? void 0 : pointOptions.state) || options.state;
  39. var pointParams = (0, utils_1.deepAssign)({}, primary, { options: { tooltip: false, state: pointState } });
  40. (0, geometries_1.line)(primary);
  41. (0, geometries_1.point)(pointParams);
  42. (0, geometries_1.area)(second);
  43. return params;
  44. }
  45. /**
  46. * meta 配置
  47. * @param params
  48. */
  49. function meta(params) {
  50. var _a;
  51. var options = params.options;
  52. var xAxis = options.xAxis, yAxis = options.yAxis, xField = options.xField, yField = options.yField;
  53. return (0, utils_1.flow)((0, common_1.scale)((_a = {},
  54. _a[xField] = xAxis,
  55. _a[yField] = yAxis,
  56. _a)))(params);
  57. }
  58. /**
  59. * coord 配置
  60. * @param params
  61. */
  62. function coord(params) {
  63. var chart = params.chart, options = params.options;
  64. var radius = options.radius, startAngle = options.startAngle, endAngle = options.endAngle;
  65. chart.coordinate('polar', {
  66. radius: radius,
  67. startAngle: startAngle,
  68. endAngle: endAngle,
  69. });
  70. return params;
  71. }
  72. /**
  73. * axis 配置
  74. * @param params
  75. */
  76. function axis(params) {
  77. var chart = params.chart, options = params.options;
  78. var xField = options.xField, xAxis = options.xAxis, yField = options.yField, yAxis = options.yAxis;
  79. chart.axis(xField, xAxis);
  80. chart.axis(yField, yAxis);
  81. return params;
  82. }
  83. /**
  84. * label 配置
  85. * @param params
  86. */
  87. function label(params) {
  88. var chart = params.chart, options = params.options;
  89. var label = options.label, yField = options.yField;
  90. var geometry = (0, utils_1.findGeometry)(chart, 'line');
  91. if (!label) {
  92. geometry.label(false);
  93. }
  94. else {
  95. var callback = label.callback, cfg = tslib_1.__rest(label, ["callback"]);
  96. geometry.label({
  97. fields: [yField],
  98. callback: callback,
  99. cfg: (0, utils_1.transformLabel)(cfg),
  100. });
  101. }
  102. return params;
  103. }
  104. /**
  105. * 雷达图适配器
  106. * @param chart
  107. * @param options
  108. */
  109. function adaptor(params) {
  110. // flow 的方式处理所有的配置到 G2 API
  111. return (0, utils_1.flow)(geometry, meta, common_1.theme, coord, axis, common_1.legend, common_1.tooltip, label, common_1.interaction, common_1.animation, (0, common_1.annotation)())(params);
  112. }
  113. exports.adaptor = adaptor;
  114. //# sourceMappingURL=adaptor.js.map