UNPKG

angular-sunburst-radar-chart

Version:
60 lines 14.1 kB
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"]}