import { forwardRef } from "react";

interface BrandCommitmentSVGProps {
  className?: string;
  svgRef?: React.RefObject<SVGSVGElement | null>;
}

const BrandCommitmentSVG = forwardRef<SVGPathElement, BrandCommitmentSVGProps>(
  ({ className, svgRef }, outerPathRef) => {
    return (
      <svg
        ref={svgRef}
        viewBox="0 0 386 853"
        fill="none"
        xmlns="http://www.w3.org/2000/svg"
        className={`w-full h-full ${className}`}
      >
        {/* Outer path to animate */}
        <path
          ref={outerPathRef}
          d="M79.1528 126.621L149.76 1.23315L385.13 155.524V852.132H120.818H0.887695L1.21837 818.991L88.0462 820.676L88.4813 798.982L40.4466 797.089L39.6635 706.074L42.2044 705.727L41.9956 703.191L79.5357 694.228L79.031 548.831L57.9723 542.491L57.5546 540.511L54.857 539.66L55.1877 376.216L58.0071 374.879L57.9375 373.819L79.3617 363.936L79.1528 126.621Z"
          stroke="black"
          strokeMiterlimit="10"
        />
        {/* outer path but with less opacity and this path not animated */}
        <path
          d="M79.1528 126.621L149.76 1.23315L385.13 155.524V852.132H120.818H0.887695L1.21837 818.991L88.0462 820.676L88.4813 798.982L40.4466 797.089L39.6635 706.074L42.2044 705.727L41.9956 703.191L79.5357 694.228L79.031 548.831L57.9723 542.491L57.5546 540.511L54.857 539.66L55.1877 376.216L58.0071 374.879L57.9375 373.819L79.3617 363.936L79.1528 126.621Z"
          stroke="black"
          strokeMiterlimit="10"
          className="opacity-15"
        />
        {/* Rest of the SVG */}
        <path
          d="M355.247 351.83L150.282 256.838L79.3442 343.614"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.248 310.04L149.43 209.437L79.3096 304.742"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.248 269.969L149.865 162.037L79.2747 263.195"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.247 229.325L150.282 115.053L79.2224 222.742"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.247 190.401L150.282 66.8018L79.4834 183.193"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.248 393.637L178.738 320.93L150.961 310.04L117.146 348.339L58.6338 375.608"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M55.3792 415.245L178.79 363.832L355.247 430.495"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.247 470.496L178.79 410.173L55.3792 456.653"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M55.4836 498.321L179.329 457.156L355.248 510.271"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.248 551.332L150.491 497.783L109.557 528.057L57.9724 542.491"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M79.7793 549.022L110.01 528.387"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.248 590.604L150.3 543.829L79.4487 587.113"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M79.3096 627.704L150.248 591.264L355.248 630.518"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.247 670.415L149.76 638.977L79.7793 668.001"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M354.812 709.687L125.447 682.73L79.5356 694.228"
          stroke="black"
          strokeMiterlimit="10"
        />
        {/* --- bottom brick starts---- */}
        <path
          d="M123.672 790.818V687.819L84.7917 696.208V794.049L153.502 796.463V792.503L125.83 791.513L123.568 791.548L123.672 790.818Z"
          stroke="black"
          strokeMiterlimit="10"
          className="brick"
        />
        <path
          d="M123.672 790.818V687.819L84.7917 696.208V794.049L153.502 796.463V792.503L125.83 791.513L123.568 791.548L123.672 790.818Z"
          fill="#E2E2E2"
          className="brick"
        />
        {/* --- bottom brick ends ---- */}
        <path
          d="M356.692 799.034L125.83 791.513L125.447 682.73L356.361 710.139L356.692 799.034Z"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M132.008 791.721V683.511"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M139.022 684.328V684.345V791.721"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M146.018 685.162V685.179V792.138"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M153.502 686.03V686.065V792.277"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M161.003 686.916V686.951V792.607"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M168.487 687.802V687.854V792.885"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M175.988 688.67V688.74V793.146V793.198"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M183.471 689.556V689.626V793.337"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M190.973 690.442V690.511V793.632V793.667"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M198.456 691.31V691.397V793.858"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M205.957 692.196V692.3V794.118"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M213.441 693.082V693.186V794.292"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M220.942 693.95V694.072V794.518"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M228.426 694.836V694.958V794.848V795.004"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M235.927 695.722V695.844V795.004"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M243.41 696.591V696.747V795.265"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M250.911 697.476V697.633V795.595V795.734"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M258.395 698.362V698.519V795.734"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M265.896 699.231V699.404V796.064"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M273.38 700.116V700.29V796.324V796.515"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M280.881 701.002V701.193V796.515"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M288.347 701.871V702.079V796.811V796.828"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M295.865 702.757V702.965V797.054V797.123"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M303.332 703.642V703.851V797.297V797.401"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M310.85 704.528V704.737V797.401"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M318.351 705.397V705.623V797.783V797.818"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M325.835 706.283V706.526V798.027V798.061"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M333.301 707.168V707.412V798.061"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M340.82 708.037V708.297V798.061"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M348.321 708.923V709.183V798.756V799.034"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M84.7916 739.162L40.0115 745.936"
          stroke="black"
          strokeMiterlimit="10"
        />
        <path
          d="M355.178 135.914L356.744 852.131"
          stroke="black"
          strokeMiterlimit="10"
        />{" "}
      </svg>
    );
  }
);

BrandCommitmentSVG.displayName = "BrandCommitmentSVG";
export default BrandCommitmentSVG;
