UNPKG

22.9 kBJavaScriptView Raw
1var __extends = (this && this.__extends) || (function () {
2 var extendStatics = function (d, b) {
3 extendStatics = Object.setPrototypeOf ||
4 ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
5 function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
6 return extendStatics(d, b);
7 };
8 return function (d, b) {
9 extendStatics(d, b);
10 function __() { this.constructor = d; }
11 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
12 };
13})();
14var __assign = (this && this.__assign) || function () {
15 __assign = Object.assign || function(t) {
16 for (var s, i = 1, n = arguments.length; i < n; i++) {
17 s = arguments[i];
18 for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
19 t[p] = s[p];
20 }
21 return t;
22 };
23 return __assign.apply(this, arguments);
24};
25import React from "react";
26import { View } from "react-native";
27import { G, Rect, Svg, Text } from "react-native-svg";
28import AbstractChart from "./AbstractChart";
29var barWidth = 32;
30var StackedBarChart = /** @class */ (function (_super) {
31 __extends(StackedBarChart, _super);
32 function StackedBarChart() {
33 var _this = _super !== null && _super.apply(this, arguments) || this;
34 _this.getBarPercentage = function () {
35 var _a = _this.props.chartConfig.barPercentage, barPercentage = _a === void 0 ? 1 : _a;
36 return barPercentage;
37 };
38 _this.getBarRadius = function (ret, x) {
39 return _this.props.chartConfig.barRadius && ret.length === x.length - 1
40 ? _this.props.chartConfig.barRadius
41 : 0;
42 };
43 _this.renderBars = function (_a) {
44 var data = _a.data, width = _a.width, height = _a.height, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, border = _a.border, colors = _a.colors, _b = _a.stackedBar, stackedBar = _b === void 0 ? false : _b;
45 return data.map(function (x, i) {
46 var barWidth = 32 * _this.getBarPercentage();
47 var ret = [];
48 var h = 0;
49 var st = paddingTop;
50 var fac = 1;
51 if (stackedBar) {
52 fac = 0.7;
53 }
54 for (var z = 0; z < x.length; z++) {
55 h = (height - 55) * (x[z] / border);
56 var y = (height / 4) * 3 - h + st;
57 var xC = (paddingRight +
58 (i * (width - paddingRight)) / data.length +
59 barWidth / 2) *
60 fac;
61 ret.push(<Rect key={Math.random()} x={xC} y={y} rx={_this.getBarRadius(ret, x)} ry={_this.getBarRadius(ret, x)} width={barWidth} height={h} fill={colors[z]}/>);
62 if (!_this.props.hideLegend) {
63 ret.push(<Text key={Math.random()} x={xC + 7 + barWidth / 2} textAnchor="end" y={h > 15 ? y + 15 : y + 7} {..._this.getPropsForLabels()}>
64 {x[z]}
65 </Text>);
66 }
67 st -= h;
68 }
69 return ret;
70 });
71 };
72 _this.renderLegend = function (_a) {
73 var legend = _a.legend, colors = _a.colors, width = _a.width, height = _a.height;
74 return legend.map(function (x, i) {
75 return (<G key={Math.random()}>
76 <Rect width="16px" height="16px" fill={colors[i]} rx={8} ry={8} x={width * 0.71} y={height * 0.7 - i * 50}/>
77 <Text x={width * 0.78} y={height * 0.76 - i * 50} {..._this.getPropsForLabels()}>
78 {x}
79 </Text>
80 </G>);
81 });
82 };
83 return _this;
84 }
85 StackedBarChart.prototype.render = function () {
86 var paddingTop = 15;
87 var paddingRight = 50;
88 var _a = this.props, width = _a.width, height = _a.height, _b = _a.style, style = _b === void 0 ? {} : _b, data = _a.data, _c = _a.withHorizontalLabels, withHorizontalLabels = _c === void 0 ? true : _c, _d = _a.withVerticalLabels, withVerticalLabels = _d === void 0 ? true : _d, _e = _a.segments, segments = _e === void 0 ? 4 : _e, decimalPlaces = _a.decimalPlaces;
89 var _f = style.borderRadius, borderRadius = _f === void 0 ? 0 : _f;
90 var config = {
91 width: width,
92 height: height
93 };
94 var border = 0;
95 for (var i = 0; i < data.data.length; i++) {
96 var actual = data.data[i].reduce(function (pv, cv) { return pv + cv; }, 0);
97 if (actual > border) {
98 border = actual;
99 }
100 }
101 var stackedBar = data.legend && data.legend.length == 0 ? false : true;
102 return (<View style={style}>
103 <Svg height={height} width={width}>
104 {this.renderDefs(__assign(__assign({}, config), this.props.chartConfig))}
105 <Rect width="100%" height={height} rx={borderRadius} ry={borderRadius} fill="url(#backgroundGradient)"/>
106 <G>
107 {this.renderHorizontalLines(__assign(__assign({}, config), { count: segments, paddingTop: paddingTop }))}
108 </G>
109 <G>
110 {withHorizontalLabels
111 ? this.renderHorizontalLabels(__assign(__assign({}, config), { count: segments, data: [0, border], paddingTop: paddingTop,
112 paddingRight: paddingRight,
113 decimalPlaces: decimalPlaces }))
114 : null}
115 </G>
116 <G>
117 {withVerticalLabels
118 ? this.renderVerticalLabels(__assign(__assign({}, config), { labels: data.labels, paddingRight: paddingRight + 28, stackedBar: stackedBar,
119 paddingTop: paddingTop, horizontalOffset: barWidth }))
120 : null}
121 </G>
122 <G>
123 {this.renderBars(__assign(__assign({}, config), { data: data.data, border: border, colors: this.props.data.barColors, paddingTop: paddingTop, paddingRight: paddingRight + 20, stackedBar: stackedBar }))}
124 </G>
125 {data.legend &&
126 data.legend.length != 0 &&
127 this.renderLegend(__assign(__assign({}, config), { legend: data.legend, colors: this.props.data.barColors }))}
128 </Svg>
129 </View>);
130 };
131 return StackedBarChart;
132}(AbstractChart));
133export default StackedBarChart;
134//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StackedBarChart.js","sourceRoot":"","sources":["../src/StackedBarChart.tsx"],"names":[],"mappings":"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","sourcesContent":["import React from \"react\";\nimport { View, ViewStyle } from \"react-native\";\nimport { G, Rect, Svg, Text } from \"react-native-svg\";\n\nimport AbstractChart, {\n  AbstractChartConfig,\n  AbstractChartProps\n} from \"./AbstractChart\";\n\nconst barWidth = 32;\n\nexport interface StackedBarChartData {\n  labels: string[];\n  legend: string[];\n  data: number[][];\n  barColors: string[];\n}\n\nexport interface StackedBarChartProps extends AbstractChartProps {\n  /**\n   * E.g.\n   * ```javascript\n   * const data = {\n   *   labels: [\"Test1\", \"Test2\"],\n   *   legend: [\"L1\", \"L2\", \"L3\"],\n   *   data: [[60, 60, 60], [30, 30, 60]],\n   *   barColors: [\"#dfe4ea\", \"#ced6e0\", \"#a4b0be\"]\n   * };\n   * ```\n   */\n  data: StackedBarChartData;\n  width: number;\n  height: number;\n  chartConfig: AbstractChartConfig;\n  hideLegend: boolean;\n  style?: Partial<ViewStyle>;\n  barPercentage?: number;\n  decimalPlaces?: number;\n  /**\n   * Show vertical labels - default: True.\n   */\n  withVerticalLabels?: boolean;\n  /**\n   * Show horizontal labels - default: True.\n   */\n  withHorizontalLabels?: boolean;\n  /**\n   * The number of horizontal lines\n   */\n  segments?: number;\n}\n\ntype StackedBarChartState = {};\n\nclass StackedBarChart extends AbstractChart<\n  StackedBarChartProps,\n  StackedBarChartState\n> {\n  getBarPercentage = () => {\n    const { barPercentage = 1 } = this.props.chartConfig;\n    return barPercentage;\n  };\n\n  getBarRadius = (ret: string | any[], x: string | any[]) => {\n    return this.props.chartConfig.barRadius && ret.length === x.length - 1\n      ? this.props.chartConfig.barRadius\n      : 0;\n  };\n\n  renderBars = ({\n    data,\n    width,\n    height,\n    paddingTop,\n    paddingRight,\n    border,\n    colors,\n    stackedBar = false\n  }: Pick<\n    Omit<AbstractChartConfig, \"data\">,\n    \"width\" | \"height\" | \"paddingRight\" | \"paddingTop\" | \"stackedBar\"\n  > & {\n    border: number;\n    colors: string[];\n    data: number[][];\n  }) =>\n    data.map((x, i) => {\n      const barWidth = 32 * this.getBarPercentage();\n      const ret = [];\n      let h = 0;\n      let st = paddingTop;\n\n      let fac = 1;\n      if (stackedBar) {\n        fac = 0.7;\n      }\n\n      for (let z = 0; z < x.length; z++) {\n        h = (height - 55) * (x[z] / border);\n\n        const y = (height / 4) * 3 - h + st;\n        const xC =\n          (paddingRight +\n            (i * (width - paddingRight)) / data.length +\n            barWidth / 2) *\n          fac;\n\n        ret.push(\n          <Rect\n            key={Math.random()}\n            x={xC}\n            y={y}\n            rx={this.getBarRadius(ret, x)}\n            ry={this.getBarRadius(ret, x)}\n            width={barWidth}\n            height={h}\n            fill={colors[z]}\n          />\n        );\n\n        if (!this.props.hideLegend) {\n          ret.push(\n            <Text\n              key={Math.random()}\n              x={xC + 7 + barWidth / 2}\n              textAnchor=\"end\"\n              y={h > 15 ? y + 15 : y + 7}\n              {...this.getPropsForLabels()}\n            >\n              {x[z]}\n            </Text>\n          );\n        }\n\n        st -= h;\n      }\n\n      return ret;\n    });\n\n  renderLegend = ({\n    legend,\n    colors,\n    width,\n    height\n  }: Pick<AbstractChartConfig, \"width\" | \"height\"> & {\n    legend: string[];\n    colors: string[];\n  }) =>\n    legend.map((x, i) => {\n      return (\n        <G key={Math.random()}>\n          <Rect\n            width=\"16px\"\n            height=\"16px\"\n            fill={colors[i]}\n            rx={8}\n            ry={8}\n            x={width * 0.71}\n            y={height * 0.7 - i * 50}\n          />\n          <Text\n            x={width * 0.78}\n            y={height * 0.76 - i * 50}\n            {...this.getPropsForLabels()}\n          >\n            {x}\n          </Text>\n        </G>\n      );\n    });\n\n  render() {\n    const paddingTop = 15;\n    const paddingRight = 50;\n\n    const {\n      width,\n      height,\n      style = {},\n      data,\n      withHorizontalLabels = true,\n      withVerticalLabels = true,\n      segments = 4,\n      decimalPlaces\n    } = this.props;\n\n    const { borderRadius = 0 } = style;\n    const config = {\n      width,\n      height\n    };\n\n    let border = 0;\n    for (let i = 0; i < data.data.length; i++) {\n      const actual = data.data[i].reduce((pv, cv) => pv + cv, 0);\n      if (actual > border) {\n        border = actual;\n      }\n    }\n\n    var stackedBar = data.legend && data.legend.length == 0 ? false : true;\n\n    return (\n      <View style={style}>\n        <Svg height={height} width={width}>\n          {this.renderDefs({\n            ...config,\n            ...this.props.chartConfig\n          })}\n          <Rect\n            width=\"100%\"\n            height={height}\n            rx={borderRadius}\n            ry={borderRadius}\n            fill=\"url(#backgroundGradient)\"\n          />\n          <G>\n            {this.renderHorizontalLines({\n              ...config,\n              count: segments,\n              paddingTop\n            })}\n          </G>\n          <G>\n            {withHorizontalLabels\n              ? this.renderHorizontalLabels({\n                  ...config,\n                  count: segments,\n                  data: [0, border],\n                  paddingTop,\n                  paddingRight,\n                  decimalPlaces\n                })\n              : null}\n          </G>\n          <G>\n            {withVerticalLabels\n              ? this.renderVerticalLabels({\n                  ...config,\n                  labels: data.labels,\n                  paddingRight: paddingRight + 28,\n                  stackedBar,\n                  paddingTop,\n                  horizontalOffset: barWidth\n                })\n              : null}\n          </G>\n          <G>\n            {this.renderBars({\n              ...config,\n              data: data.data,\n              border,\n              colors: this.props.data.barColors,\n              paddingTop,\n              paddingRight: paddingRight + 20,\n              stackedBar\n            })}\n          </G>\n          {data.legend &&\n            data.legend.length != 0 &&\n            this.renderLegend({\n              ...config,\n              legend: data.legend,\n              colors: this.props.data.barColors\n            })}\n        </Svg>\n      </View>\n    );\n  }\n}\n\nexport default StackedBarChart;\n"]}
\No newline at end of file