import { useSpring, animated } from "@react-spring/web"; import { useEffect, useState } from "react"; import { Pie } from "react-chartjs-2"; import "chart.js/auto"; import { Chart as ChartJS, ArcElement, Tooltip, Legend, ChartData, } from "chart.js"; import ChartDataLabels from "chartjs-plugin-datalabels"; import { Context } from "chartjs-plugin-datalabels"; import tokenomicChart from "../../../assets/images/tokenomic-chart.png"; import "animate.css"; type Props = {}; ChartJS.register(ArcElement, Tooltip, Legend); const tokenomics = [ { name: "Liquidity", title: "Liquidity - 5% 1,000,000 SGPT", precent: "5", description: " ", color: "#86eae9", bgcolor: "bg-[#86eae9]", }, { name: "Private Sale", title: "Private Sale - 17% 3,400,000 SGPT", precent: "17", description: " ", color: "#5dbdd3", bgcolor: "bg-[#5dbdd3]", }, { name: "Stacking & Farming", title: "Stacking & Farming - 15% 3,000,000 SGPT", precent: "15", description: " ", color: "#4591b8", bgcolor: "bg-[#4591b8]", }, { name: "Marketing & Promotion", title: "Marketing & Promotion - 15% 3,000,000 SGPT", precent: "15", description: " ", color: "#3b6696", bgcolor: "bg-[#3b6696]", }, { name: "Public Sale", title: "Public Sale - 14% 2,800,000 SGPT", precent: "14", description: " ", color: "#353c6e", bgcolor: "bg-[#353c6e]", }, { name: "Reward & Q&A", title: "Reward & Q&A - 10% 2,000,000 SGPT", precent: "10", description: " ", color: "#705788", bgcolor: "bg-[#705788]", }, { name: "Advisor", title: "Advisor - 10% 2,000,000 SGPT", precent: "10", description: " ", color: "#a5769e", bgcolor: "bg-[#a5769e]", }, { name: "Treasury", title: "Treasury - 14% 2,800,000 SGPT", precent: "14", description: " ", color: "#d59ab3", bgcolor: "bg-[#d59ab3]", }, ]; const TokenomicsSection = (props: Props) => { const [isVisible, setIsVisible] = useState(false); useEffect(() => { const section = document.getElementById("tokenomics"); const observer = new IntersectionObserver( ([entry]) => { setIsVisible(entry.isIntersecting); }, { threshold: 0.4 } ); if (!section) { return; } observer.observe(section); return () => { observer.unobserve(section); }; }, []); useEffect(() => { console.log("isVisible", isVisible); }, [isVisible]); const styles = useSpring({ opacity: isVisible ? 1 : 0, transform: isVisible ? "scaleX(1)" : "scaleX(0.5)", config: { duration: 300, }, }); const plugins = { id: "textCenter", datalabels: {}, }; const [userData, setUserData] = useState({ labels: tokenomics.map((data) => data.name), datasets: [ { label: "text", data: tokenomics.map((data) => data.precent), backgroundColor: tokenomics.map((data) => data.color), borderWidth: 1, datalabels: { font: { weight: "bold", }, anchor: "center", rotation: function (ctx: any) { const valuesBefore = ctx.dataset.data .slice(0, ctx.dataIndex) .reduce( (a: number, b: number) => Number(a) + Number(b), 1 as number ); const sum = ctx.dataset.data.reduce( (a: number, b: number) => Number(a) + Number(b), 1 as number ); const rotation = ((valuesBefore + ctx.dataset.data[ctx.dataIndex] / 2) / sum) * 360; return rotation < 180 ? rotation - 95 : rotation + 90; }, align: "center", offset: -30, }, }, ], }); const options = { layout: {}, hoverBorderWidth: 4, plugins: { legend: { display: false, }, datalabels: { font: { size: window.innerWidth > 1024 ? 20 : window.innerWidth > 768 ? 16 : 10, }, color: "#fff", formatter: (context: any, agrs: any) => { const index = agrs.dataIndex; return agrs.chart.data.labels[index]; }, }, tooltip: { callbacks: { label: (context: any) => { return ` ${tokenomics[context.dataIndex].title}`; }, }, }, }, }; ChartJS.register(ChartDataLabels); return (

Tokenomics

{/*
    {tokenomics.map((item, index) => { return (

    {item.title}

    {item.description}

    ); })}
*/}
); }; export default TokenomicsSection;