From aa805b2b16b2a2b3a101aa52c033e78f322b2b58 Mon Sep 17 00:00:00 2001 From: Anmol Singh Bhatia Date: Fri, 3 Feb 2023 02:35:25 +0530 Subject: [PATCH] feat: custom progress bar added --- apps/app/components/ui/progress-bar/index.tsx | 70 +++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 apps/app/components/ui/progress-bar/index.tsx diff --git a/apps/app/components/ui/progress-bar/index.tsx b/apps/app/components/ui/progress-bar/index.tsx new file mode 100644 index 000000000..0bebcb93c --- /dev/null +++ b/apps/app/components/ui/progress-bar/index.tsx @@ -0,0 +1,70 @@ +import React from "react"; + +type Props = { + maxValue?: number; + value?: number; + radius?: number; + strokeWidth?: number; + activeStrokeColor?: string; + inactiveStrokeColor?: string; +}; + +const ProgressBar: React.FC = ({ + maxValue = 0, + value = 0, + radius = 8, + strokeWidth = 2, + activeStrokeColor = "#3e98c7", + inactiveStrokeColor = "#ddd", +}) => { + // PIE Calc Fn + const generatePie = (value: any) => { + const x = radius - Math.cos((2 * Math.PI) / (100 / value)) * radius; + const y = radius + Math.sin((2 * Math.PI) / (100 / value)) * radius; + const long = value <= 50 ? 0 : 1; + const d = `M${radius} ${radius} L${radius} ${0} A${radius} ${radius} 0 ${long} 1 ${y} ${x} Z`; + + return d; + }; + + // ---- PIE Area Calc -------- + const calculatePieValue = (numberOfBars: any) => { + const angle = 360 / numberOfBars; + const pieValue = Math.floor(angle / 4); + return pieValue < 1 ? 1 : Math.floor(angle / 4); + }; + + // ---- PIE Render Fn -------- + const renderPie = (i: any) => { + const DIRECTION = -1; + // Rotation Calc + const primaryRotationAngle = (maxValue - 1) * (360 / maxValue); + const rotationAngle = + -1 * DIRECTION * primaryRotationAngle + i * DIRECTION * primaryRotationAngle; + const rotationTransformation = `rotate(${rotationAngle}, ${radius}, ${radius})`; + const pieValue = calculatePieValue(maxValue); + const dValue = generatePie(pieValue); + const fillColor = value > 0 && i <= value ? activeStrokeColor : inactiveStrokeColor; + + return ( + + ); + }; + + // combining the Pies + const renderOuterCircle = () => [...Array(maxValue + 1)].map((e, i) => renderPie(i)); + + return ( + + {renderOuterCircle()} + + + ); +}; +export default ProgressBar;