angular-sunburst-radar-chart
Version:
A Sunburst Radar chart with SVG,No Dependencies
60 lines • 14.1 kB
JavaScript
import { getLargeArcFlag, polarToCartesian } from './trignometry';
import { convertToPercentage } from './math';
import { createPathForBar } from './elements';
import { getItemTitle } from './utils';
export function createOuterChartBarWithInArc({ item, startAngle, endAngle, middleAngle, color, middleRadius, maxScore, innerRadiusBorder, center }) {
const [centerX, centerY] = [center.x, center.y];
const currentVal = item.value;
const totalRadiusInside = middleRadius - innerRadiusBorder;
const innerRadius = convertToPercentage({ plotMax: totalRadiusInside, actualScore: currentVal, maxScore });
const radiusFromCenter = innerRadius + innerRadiusBorder;
const firstPoint = polarToCartesian(centerX, centerY, radiusFromCenter, startAngle);
const secondPoint = polarToCartesian(centerX, centerY, radiusFromCenter, endAngle);
const startPoint = polarToCartesian(centerX, centerY, innerRadiusBorder, startAngle);
const endPoint = polarToCartesian(centerX, centerY, innerRadiusBorder, endAngle);
const startMiddlePoint = polarToCartesian(centerX, centerY, innerRadiusBorder, middleAngle);
const distFromStartToFirst = Math.sqrt(Math.pow((startPoint.x - firstPoint.x), 2) + Math.pow((startPoint.y - firstPoint.y), 2));
const distFromStartToSecond = Math.sqrt(Math.pow((startPoint.x - secondPoint.x), 2) + Math.pow((startPoint.y - secondPoint.y), 2));
const { updatedFirstPoint, updatedSecondPoint } = getUpdatedPoints(firstPoint, secondPoint, distFromStartToFirst, distFromStartToSecond);
const d = getDrawPositions(updatedFirstPoint, middleRadius, updatedSecondPoint, endPoint, startMiddlePoint, startPoint);
const title = getItemTitle(item);
return createPathForBar({ d: d.join(' '), stroke: 'none', fill: color, "fill-opacity": '0.5', title });
}
function getDrawPositions(firstPoint, middleRadius, secondPoint, endPoint, startMiddlePoint, startPoint) {
const d = [
'M', firstPoint.x, firstPoint.y,
'A', middleRadius, middleRadius, 0, 0, 1, secondPoint.x, secondPoint.y,
'L', endPoint.x, endPoint.y,
'C', endPoint.x, endPoint.y, startMiddlePoint.x, startMiddlePoint.y, startPoint.x, startPoint.y,
'L', firstPoint.x, firstPoint.y,
'Z'
];
return d;
}
export function getUpdatedPoints(firstPoint, secondPoint, distFromStartToFirst, distFromStartToSecond) {
let [updatedFirstPoint, updatedSecondPoint] = [firstPoint, secondPoint];
if (distFromStartToSecond < distFromStartToFirst) {
updatedSecondPoint = firstPoint;
updatedFirstPoint = secondPoint;
}
return { updatedSecondPoint, updatedFirstPoint };
}
export function createInnerChartBarWithInArc({ startPoint, item, radius, startAngle, endAngle, maxScore }) {
const [centerX, centerY] = [startPoint.x, startPoint.y];
const currentVal = item.value;
const color = item.color;
const arcRadius = convertToPercentage({ plotMax: radius, actualScore: currentVal, maxScore });
const start = polarToCartesian(centerX, centerY, arcRadius, endAngle);
const end = polarToCartesian(centerX, centerY, arcRadius, startAngle);
const largeArcFlag = getLargeArcFlag(startAngle, endAngle);
//const largeArcFlag = endAngle - startAngle <= 180 ? '0' : '1';
const d = [
'M', centerX, centerY,
'L', start.x, start.y,
'A', arcRadius, arcRadius, 0, largeArcFlag, 0, end.x, end.y
].join(' ');
const title = getItemTitle(item);
const arcForInnerChart = createPathForBar({ d, fill: color, title });
return arcForInnerChart;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arc-bar-charts.js","sourceRoot":"ng://angular-sunburst-radar-chart/","sources":["lib/utils/arc-bar-charts.ts"],"names":[],"mappings":"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","sourcesContent":["import {getLargeArcFlag, polarToCartesian} from './trignometry';\r\nimport {convertToPercentage} from './math';\r\nimport {createPath, createPathForBar} from './elements';\r\nimport {getItemTitle} from './utils';\r\nimport {Point} from './positions';\r\n\r\nexport function createOuterChartBarWithInArc({item, startAngle, endAngle, middleAngle, color, middleRadius,maxScore, innerRadiusBorder, center}) {\r\n\r\n\r\n  const [centerX, centerY] = [center.x, center.y];\r\n\r\n\r\n  const currentVal = item.value;\r\n\r\n\r\n  const totalRadiusInside = middleRadius - innerRadiusBorder;\r\n\r\n  const innerRadius = convertToPercentage({plotMax: totalRadiusInside, actualScore: currentVal, maxScore});\r\n  const radiusFromCenter = innerRadius + innerRadiusBorder;\r\n\r\n\r\n  const firstPoint = polarToCartesian(centerX, centerY, radiusFromCenter, startAngle);\r\n  const secondPoint = polarToCartesian(centerX, centerY, radiusFromCenter, endAngle);\r\n\r\n\r\n  const startPoint = polarToCartesian(centerX, centerY, innerRadiusBorder, startAngle);\r\n  const endPoint = polarToCartesian(centerX, centerY, innerRadiusBorder, endAngle);\r\n\r\n\r\n  const startMiddlePoint = polarToCartesian(centerX, centerY, innerRadiusBorder, middleAngle);\r\n\r\n  const distFromStartToFirst = Math.sqrt(Math.pow((startPoint.x - firstPoint.x), 2) + Math.pow((startPoint.y - firstPoint.y), 2));\r\n  const distFromStartToSecond = Math.sqrt(Math.pow((startPoint.x - secondPoint.x), 2) + Math.pow((startPoint.y - secondPoint.y), 2));\r\n\r\n\r\n  const {updatedFirstPoint, updatedSecondPoint} = getUpdatedPoints(firstPoint, secondPoint, distFromStartToFirst, distFromStartToSecond);\r\n\r\n\r\n  const d = getDrawPositions(updatedFirstPoint, middleRadius, updatedSecondPoint, endPoint, startMiddlePoint, startPoint);\r\n\r\n\r\n  const title = getItemTitle(item);\r\n\r\n  return createPathForBar({d: d.join(' '), stroke: 'none', fill: color,\"fill-opacity\":'0.5', title});\r\n\r\n}\r\nfunction getDrawPositions(firstPoint: { x: any; y: any }, middleRadius, secondPoint: { x: any; y: any }, endPoint: { x: any; y: any }, startMiddlePoint: { x: any; y: any }, startPoint: { x: any; y: any }) {\r\n  const d = [\r\n\r\n    'M', firstPoint.x, firstPoint.y,\r\n    'A', middleRadius, middleRadius, 0, 0, 1, secondPoint.x, secondPoint.y,\r\n    'L', endPoint.x, endPoint.y,\r\n    'C', endPoint.x, endPoint.y, startMiddlePoint.x, startMiddlePoint.y, startPoint.x, startPoint.y,\r\n    'L', firstPoint.x, firstPoint.y,\r\n    'Z'\r\n\r\n\r\n  ];\r\n  return d;\r\n}\r\n\r\n\r\nexport function getUpdatedPoints(firstPoint: Point, secondPoint: Point, distFromStartToFirst, distFromStartToSecond) {\r\n\r\n  let [updatedFirstPoint, updatedSecondPoint] = [firstPoint, secondPoint];\r\n\r\n  if (distFromStartToSecond < distFromStartToFirst) {\r\n    updatedSecondPoint = firstPoint;\r\n    updatedFirstPoint = secondPoint;\r\n\r\n\r\n  }\r\n  return {updatedSecondPoint, updatedFirstPoint};\r\n}\r\n\r\nexport function createInnerChartBarWithInArc({startPoint, item, radius, startAngle, endAngle,maxScore}) {\r\n\r\n  const [centerX, centerY] = [startPoint.x, startPoint.y];\r\n\r\n  const currentVal = item.value;\r\n  const color = item.color;\r\n  const arcRadius = convertToPercentage({plotMax: radius, actualScore: currentVal,maxScore});\r\n\r\n\r\n  const start = polarToCartesian(centerX, centerY, arcRadius, endAngle);\r\n  const end = polarToCartesian(centerX, centerY, arcRadius, startAngle);\r\n\r\n  const largeArcFlag = getLargeArcFlag(startAngle,endAngle)\r\n  //const largeArcFlag = endAngle - startAngle <= 180 ? '0' : '1';\r\n\r\n  const d = [\r\n    'M', centerX, centerY,\r\n    'L', start.x, start.y,\r\n    'A', arcRadius, arcRadius, 0, largeArcFlag, 0, end.x, end.y\r\n  ].join(' ');\r\n\r\n\r\n  const title = getItemTitle(item);\r\n\r\n\r\n  const arcForInnerChart = createPathForBar({d, fill: color, title});\r\n\r\n  return arcForInnerChart;\r\n}\r\n"]}