{"version":3,"file":"static/chunks/90-50416c29c7118cd0.js","mappings":"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","sources":["webpack://_N_E/./src/assets/logo.png","webpack://_N_E/./src/components/base/seo.tsx","webpack://_N_E/./src/components/connect-wallet/view.tsx","webpack://_N_E/./src/components/connect-wallet/container.tsx","webpack://_N_E/./src/components/connect-wallet/index.ts","webpack://_N_E/./src/constants/index.ts","webpack://_N_E/./src/hooks/use-distributor-data.ts","webpack://_N_E/./src/hooks/use-mobile-detection.ts","webpack://_N_E/./src/locales/en.ts","webpack://_N_E/./src/hooks/use-trans.ts","webpack://_N_E/./src/layouts/components/solcat-carouse.tsx","webpack://_N_E/./src/layouts/main-layout/footer.tsx","webpack://_N_E/./src/assets/launchpad-logo.png","webpack://_N_E/./src/layouts/main-layout/header.tsx","webpack://_N_E/./src/layouts/main-layout/index.tsx","webpack://_N_E/./src/utils/apis/merkle-tree.ts","webpack://_N_E/./src/utils/apis/project-details.ts","webpack://_N_E/./src/utils/helpers.ts","webpack://_N_E/./src/assets/svgs/telegram.svg","webpack://_N_E/./src/assets/svgs/telegram-black.svg","webpack://_N_E/./src/assets/svgs/x.svg","webpack://_N_E/./src/assets/svgs/x-black.svg","webpack://_N_E/./src/assets/svgs/youtube.svg","webpack://_N_E/./src/assets/svgs/youtube-black.svg","webpack://_N_E/./src/assets/svgs/web.svg","webpack://_N_E/./src/assets/svgs/medium-black.svg","webpack://_N_E/./src/assets/svgs/tiktok-black.svg","webpack://_N_E/./src/assets/svgs/discord-black.svg","webpack://_N_E/./src/utils/static-import-icon.tsx","webpack://_N_E/<anon>"],"sourcesContent":["export default {\"src\":\"/_next/static/media/logo.f500d8a5.png\",\"height\":60,\"width\":60,\"blurDataURL\":\"\",\"blurWidth\":8,\"blurHeight\":8};","import React from 'react'\n\nimport Head from 'next/head'\n\ninterface SeoData {\n title: string;\n description: string;\n url?: string;\n thumbnailUrl?: string;\n}\n\ninterface SeoProps {\n data: SeoData;\n}\n\nconst Seo = ({ data }: SeoProps) => {\n const { title, description, url, thumbnailUrl } = data\n const ahrefMetaContent = process.env.NEXT_PUBLIC_AHREF_META\n\n return (\n <Head>\n {/* <!-- Primary Meta Tags --> */}\n <title>{title}</title>\n <meta name=\"title\" content={title} />\n <meta name=\"description\" content={description} />\n\n {/* <!-- Open Graph / Facebook --> */}\n <meta property=\"og:type\" content=\"website\" />\n <meta property=\"og:url\" content={url} />\n <meta property=\"og:title\" content={title} />\n <meta property=\"og:description\" content={description} />\n <meta property=\"og:image\" content={thumbnailUrl} />\n\n {/* <!-- Twitter --> */}\n <meta property=\"twitter:card\" content=\"summary_large_image\" />\n <meta property=\"twitter:url\" content={url} />\n <meta property=\"twitter:title\" content={title} />\n <meta property=\"twitter:description\" content={description} />\n <meta property=\"twitter:image\" content={thumbnailUrl} />\n {/* <!-- Ahref --> */}\n <meta name=\"ahrefs-site-verification\" content={ahrefMetaContent} />\n </Head>\n )\n}\n\nexport default Seo\n","import { memo } from 'react';\n\nimport useMobileDetection from '@/root/src/hooks/use-mobile-detection';\nimport {\n Button,\n Divider,\n Menu,\n MenuItem,\n Stack,\n Typography,\n} from '@mui/material';\nimport { useWallet } from '@solana/wallet-adapter-react';\n\nimport { WalletMultiButtonViewProps } from './types';\nimport { isSolcatToken } from '../../utils/helpers';\n\nconst View = ({\n walletInfo,\n balance,\n onClick,\n menuAnchorEl,\n menuItems,\n onMenuClose,\n}: WalletMultiButtonViewProps) => {\n const { connected } = useWallet();\n const font = connected ? 'font-dm_mono normal-case' : 'font-cc';\n const isMobile = useMobileDetection();\n const fontSize = isMobile ? '' : 'text-xl';\n const tokenSymbol = process.env.NEXT_PUBLIC_TOKEN_SYMBOL;\n const isSolcat = isSolcatToken(tokenSymbol);\n\n return (\n <Stack>\n <Button\n className=\"px-6 py-3 bg-white bg-opacity-10 rounded-full justify-center items-center gap-2.5 inline-flex mx-auto hover:bg-opacity-20\"\n onClick={onClick}\n >\n {connected ? (\n <Stack direction={'row'}>\n <Typography className={`text-white ${fontSize} ${font}`}>\n {balance} {isSolcat ? 'SOLCAT' : tokenSymbol}\n </Typography>\n <Divider\n sx={{ bgcolor: '#343434', width: '1px', height: '27px', mx: 1 }}\n />\n <Typography className={`text-white ${fontSize} ${font}`}>\n {walletInfo}\n </Typography>\n </Stack>\n ) : (\n <Typography className={`text-white ${fontSize} ${font}`}>\n {walletInfo}\n </Typography>\n )}\n </Button>\n\n {Boolean(menuItems.length) && (\n <Menu\n open={Boolean(menuAnchorEl)}\n onClose={onMenuClose}\n anchorEl={menuAnchorEl}\n anchorOrigin={{ horizontal: 'right', vertical: 'bottom' }}\n transformOrigin={{ horizontal: 'right', vertical: 'top' }}\n MenuListProps={{\n className: 'bg-[#2c2d30] rounded-xl p-2 text-sm',\n }}\n classes={{ paper: 'bg-[#2c2d30] mt-1 rounded-md' }}\n >\n {menuItems.map(\n ({ disabled, keepMenuOpenAfterClick, onClick, testId, text }) => (\n <MenuItem\n key={text}\n data-testid={`header-wallet-${testId}`}\n disabled={disabled}\n className=\"bg-[#2c2d30] rounded-md text-sm px-4 py-3 text-white font-dm_mono hover:bg-[#3c3d40]\"\n onClick={() => {\n onClick?.();\n !keepMenuOpenAfterClick && onMenuClose?.();\n }}\n >\n {text}\n </MenuItem>\n ),\n )}\n </Menu>\n )}\n </Stack>\n );\n};\n\nconst memoView = memo(View);\nmemoView.displayName = 'ConnectWallet';\nexport default memoView;\n","import { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { useWallet } from '@solana/wallet-adapter-react';\nimport { useWalletModal } from '@solana/wallet-adapter-react-ui';\n\nimport { WalletMultiButtonViewProps } from './types';\nimport View from './view';\nimport { Connection, PublicKey } from '@solana/web3.js';\nimport {\n Token,\n TOKEN_PROGRAM_ID,\n ASSOCIATED_TOKEN_PROGRAM_ID,\n} from '@solana/spl-token';\nimport { useSolana } from '../../providers/solana';\n\nconst Container = () => {\n const {\n connected,\n connecting,\n disconnect,\n disconnecting,\n publicKey,\n wallet,\n } = useWallet();\n const { connection, mintPublicKey } = useSolana();\n const { setVisible } = useWalletModal();\n\n const [menuAnchorEl, setMenuAnchorEl] = useState<HTMLElement>();\n const [showCopiedMenuItem, setShowCopiedMenuItem] = useState(false);\n\n const isWalletConnected = connected && publicKey && wallet;\n const [solCatBalance, setSolCatBalance] = useState(0);\n\n useEffect(() => {\n if (!publicKey || !connection) return;\n const fetchTokenBalance = async () => {\n try {\n const ata = await Token.getAssociatedTokenAddress(\n ASSOCIATED_TOKEN_PROGRAM_ID,\n TOKEN_PROGRAM_ID,\n mintPublicKey,\n publicKey,\n );\n const ataInfo = await connection.getParsedAccountInfo(ata);\n let balance = 0;\n if (ataInfo && ataInfo.value && ataInfo.value.data) {\n balance =\n (ataInfo.value.data as any).parsed?.info?.tokenAmount?.uiAmount ||\n 0;\n }\n setSolCatBalance(balance);\n } catch (error) {\n console.error('Error fetching token balance:', error);\n }\n };\n\n fetchTokenBalance();\n }, [publicKey]);\n\n const minifyAddress = (address: string, length = 4) => {\n if (address.length <= length * 2) {\n return address;\n }\n\n const firstPart = address.slice(0, length);\n const lastPart = address.slice(-length);\n return `${firstPart}...${lastPart}`;\n };\n\n const handleCopyAddress = useCallback(async () => {\n if (publicKey) {\n await navigator?.clipboard?.writeText(publicKey.toBase58());\n setShowCopiedMenuItem(true);\n setTimeout(() => setShowCopiedMenuItem(false), 600);\n }\n }, [publicKey]);\n\n useEffect(() => {\n setMenuAnchorEl(undefined);\n }, [isWalletConnected]);\n\n const menuItems = useMemo(\n () =>\n isWalletConnected\n ? [\n {\n disabled: showCopiedMenuItem,\n keepMenuOpenAfterClick: true,\n onClick: showCopiedMenuItem ? undefined : handleCopyAddress,\n testId: 'btn-copy-wallet-address',\n text: showCopiedMenuItem ? 'Copied' : 'Copy Address',\n },\n {\n onClick: () => setVisible(true),\n testId: 'btn-change-wallet',\n text: 'Change Wallet',\n },\n {\n onClick: disconnect,\n testId: 'btn-disconnect-wallet',\n text: 'Disconnect',\n },\n ]\n : [],\n [\n disconnect,\n handleCopyAddress,\n isWalletConnected,\n showCopiedMenuItem,\n setVisible,\n 'Copied',\n 'Copy Address',\n 'Disconnect',\n ],\n );\n\n const buttonLabel = isWalletConnected\n ? minifyAddress(publicKey.toBase58())\n : connecting\n ? 'Connecting...'\n : disconnecting\n ? 'Disconnecting...'\n : 'Connect Wallet';\n\n const viewProps = useMemo<WalletMultiButtonViewProps>(\n () => ({\n icon: wallet?.adapter.icon,\n loading: connecting || disconnecting,\n onClick: (e) =>\n isWalletConnected ? setMenuAnchorEl(e.currentTarget) : setVisible(true),\n walletInfo: buttonLabel,\n balance: solCatBalance,\n menuAnchorEl,\n menuItems,\n onMenuClose: () => setMenuAnchorEl(undefined),\n }),\n [\n buttonLabel,\n connecting,\n disconnecting,\n isWalletConnected,\n menuAnchorEl,\n menuItems,\n setVisible,\n wallet?.adapter.icon,\n solCatBalance,\n ],\n );\n\n return <View {...viewProps} />;\n};\n\nexport default Container;\n","export { default } from './container'\n","export const MICRO_TOKEN = 1_000_000; // TODO: based on mint address\n","import { useQuery } from 'react-query';\n\nimport { PublicKey } from '@solana/web3.js';\n\nimport { useSolana } from '../providers/solana';\n\ninterface DistributorData {\n version: number;\n root: Uint8Array;\n mint: PublicKey;\n tokenVault: PublicKey;\n maxTotalClaim: number;\n maxNumNodes: number;\n totalAmountClaimed: number;\n numNodesClaimed: number;\n startTs: number;\n endTs: number;\n clawbackReceiver: PublicKey;\n admin: PublicKey;\n}\n\nexport const useDistributorData = () => {\n const { distributorClient, distributor } = useSolana();\n\n const fetchDistributorData = async (): Promise<DistributorData | null> => {\n if (!distributorClient || !distributor) return null;\n const fetchedData =\n await distributorClient.ctx.program.account.merkleDistributor.fetchNullable(\n distributor.key,\n );\n if (!fetchedData) return null;\n return fetchedData as unknown as DistributorData;\n };\n\n return useQuery(['distributorData', distributor?.key], fetchDistributorData, {\n enabled: !!distributor?.key,\n staleTime: 1 * 60 * 1000,\n })\n};\n","import { useMediaQuery, useTheme } from '@mui/material'\n\nconst useMobileDetection = () => {\n const theme = useTheme()\n const isMobile = useMediaQuery(theme.breakpoints.down('sm'))\n\n return isMobile\n}\n\nexport default useMobileDetection\n","// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst locale: { [key: string]: any } = {\n BODO: {\n website_url: 'https://boopdoge.com/',\n telegram_url: 'https://t.me/BoopDoge_Token',\n x_url: 'https://x.com/BoopDoge_Token',\n guide_url:\n 'https://catsolhat.medium.com/introducing-the-first-catsolhat-launchpad-project-boopdoge-4e136347e53f',\n description:\n '<p>BoopDoge is a community-driven meme coin inspired by the urge to boop a dog on the nose. \\\n Our mission is to help passionate dog lovers and crypto enthusiasts achieve financial freedom.</p> \\\n <p>BoopDoge will be a flagship for emerging DeFi and meme culture on Solana. \\\n This is part of a larger plan to strengthen the creator culture on Solana as BoopDoge continues to integrate into the broader ecosystem.</p>',\n eligibility: (eligibleAmount: number) =>\n `<p>Average holding of at <span style=\"color:#6dfcd1\">least ${eligibleAmount} SOLCAT</span> (based on two snapshots). \\\n The first snapshot was taken on 1st July. The second snapshot will be taken at a random moment between 6th and 8th July.</p>`,\n token_name: 'BoopDoge',\n blockchain: 'Solana',\n },\n SOFAC: {\n website_url: 'https://sofacat.click/',\n telegram_url: 'https://t.me/SofaCatSPL',\n x_url: 'https://x.com/SofaCatSPL',\n guide_url:\n 'https://catsolhat.medium.com/introducing-the-next-launchpad-project-sofacat-9a498f0865a7',\n description:\n '<p>Every cat loves a good sofa, and so does the SofaCat! With $SOFAC, \\\n comfort and profit go hand in hand - relax, enjoy, and watch your crypto grow.</p>',\n eligibility: (eligibleAmount: number) =>\n `<p>Hold at <span style=\"color:#6dfcd1\">least ${eligibleAmount} $SOLCAT</span> at the snapshot on September 27th.</p>`,\n token_name: 'SofaCat',\n blockchain: 'Solana',\n },\n OIIA: {\n website_url: 'https://oiiaoiiasol.com/',\n telegram_url: 'https://t.me/oiia_oiia_community',\n x_url: 'https://x.com/oiia_oiia_onSol',\n guide_url: 'https://x.com/catsolhat/status/1854521247759208769',\n description:\n '<p>OiiaOiia is a dynamic memecoin, featuring a quirky cat caught in endless spin excitement!</p>',\n eligibility: (eligibleAmount: number) =>\n `<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">at least ${eligibleAmount} Launchpad Credits (LC)</span> by the snapshot on November 18.`,\n token_name: 'OiiaOiia',\n blockchain: 'Solana',\n },\n CATIVA: {\n website_url: 'https://cativa.lol/',\n telegram_url: 'https://t.me/cativasolana',\n x_url: 'https://x.com/cativasolana',\n guide_url: 'https://x.com/catsolhat/status/1863952080312176786',\n description:\n '<p>Cats on Sativa are a bunch of chill cats enjoying life, purring, and vibing with the universe. Pure feline zen energy!</p>',\n eligibility: (eligibleAmount: number) =>\n `<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">${eligibleAmount}+ Launchpad Credits (LC)</span> at the snapshot on December 9`,\n token_name: 'Cats on Savita',\n blockchain: 'Solana',\n },\n SHINO: {\n website_url: 'https://dinoshiba.me/',\n telegram_url: 'https://t.me/dinoshiba_me',\n x_url: 'https://x.com/dinoshiba_x',\n guide_url: 'https://x.com/catsolhat/status/1878807792653631537',\n description:\n \"<p>Half Dino, Half Shiba, 100% Adorable! Experience the joy of DinoShiba's daily adventures! Watch as our adorable friend combines the charm of a Shiba Inu with the playful spirit of a tiny dinosaur.</p>\",\n eligibility: (eligibleAmount: number) =>\n `<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">${eligibleAmount}+ Launchpad Credits (LC)</span> at the snapshot on Jan 22, 2025</p>`,\n token_name: 'DinoShiba',\n blockchain: 'Solana',\n },\n meta: {\n title: 'CatSolHat Super Airdrop',\n description:\n 'Claim your SOLCAT airdrop: Early Contributors, Active Wallets on Solana DEXs, Saga Phone Buyers, Top NFT Collections Holders,...',\n thumbnail_url: '/thumbnail.png',\n },\n};\n\nexport default locale;\n","import { useRouter } from 'next/router'\n\nimport en from '@/locales/en'\n\nconst useTrans = () => {\n const { locale } = useRouter()\n\n switch (locale) {\n default:\n return en\n }\n}\n\nexport default useTrans\n","import React from 'react';\nimport { Box, keyframes, Typography } from '@mui/material';\nimport useMobileDetection from '../../hooks/use-mobile-detection';\n\nconst slide = keyframes`\n 0% {\n transform: translateX(100%);\n }\n 100% {\n transform: translateX(-100%);\n }\n`;\n\nconst CarouselText: React.FC = () => {\n const isMobile = useMobileDetection();\n\n return (\n <Box className=\"relative\">\n <Box\n sx={{\n display: 'flex',\n position: 'relative',\n justifyContent: 'center',\n alignItems: 'center',\n animation: `${slide} 100s linear infinite`,\n }}\n className=\"p-1\"\n >\n {Array.from({ length: 24 }).map((_, index) => (\n <Typography\n key={index}\n className={`${\n isMobile ? 'text-[24px]' : 'text-[56px] leading-[72px]'\n } text-black font-cc`}\n >\n {index % 2 === 0 ? '$SOLCAT' : <span> · </span>}\n </Typography>\n ))}\n </Box>\n </Box>\n );\n};\n\nexport default CarouselText;\n","import Image from 'next/image';\n\nimport useTrans from '@/root/src/hooks/use-trans';\nimport { Fade, Link, Stack, Tooltip, Typography } from '@mui/material';\n\nimport useMobileDetection from '../../hooks/use-mobile-detection';\nimport { IconName, staticImportIcon } from '../../utils/static-import-icon';\nimport CarouselText from '../components/solcat-carouse';\n\nconst SocialButton = () => {\n const isMobile = useMobileDetection();\n\n return (\n <Stack\n direction=\"row\"\n gap={isMobile ? 2 : 3}\n className={`${isMobile ? 'px-6 py-8' : 'px-12 py-12'}`}\n justifyContent=\"center\"\n alignItems=\"center\"\n spacing=\"2px\"\n >\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"Youtube\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-youtube\"\n href=\"https://www.youtube.com/@catsolhat\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.YOUTUBE_BLACK)}\n alt={IconName.YOUTUBE_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"TikTok\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-tiktok\"\n href=\"https://www.tiktok.com/@catsolhat\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.TIKTOK_BLACK)}\n alt={IconName.TIKTOK_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"Medium\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-medium\"\n href=\"https://catsolhat.medium.com/\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.MEDIUM_BLACK)}\n alt={IconName.MEDIUM_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"Telegram\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-telegram\"\n href=\"https://t.me/catsolhat1\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.TELEGRAM_BLACK)}\n alt={IconName.TELEGRAM_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"X\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-x\"\n href=\"https://x.com/catsolhat\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.X_BLACK)}\n alt={IconName.X_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n <Stack className=\"social-button-stack\">\n <Tooltip title=\"Discord\" placement=\"top\" TransitionComponent={Fade}>\n <Link\n data-testid=\"social-link-discord\"\n href=\"https://discord.gg/dVytU8NJsf\"\n target=\"_blank\"\n rel=\"noreferrer\"\n height={40}\n >\n <Image\n src={staticImportIcon(IconName.DISCORD_BLACK)}\n alt={IconName.DISCORD_BLACK}\n width={40}\n height={40}\n />\n </Link>\n </Tooltip>\n </Stack>\n </Stack>\n );\n};\n\nconst Footer = () => {\n const trans = useTrans();\n const isMobile = useMobileDetection();\n\n return (\n <>\n <Stack\n className={`${\n isMobile ? 'mx-3 py-4 rounded-[20px]' : 'mx-6 py-8 rounded-[40px]'\n } w-auto bg-gradient-footer mt-2 `}\n gap={isMobile ? 2 : 3}\n >\n <CarouselText />\n <SocialButton />\n <Stack\n direction=\"row\"\n justifyContent=\"center\"\n spacing={4}\n alignItems=\"center\"\n className={`${isMobile ? 'px-8 py-6' : 'px-12 py-8'}`}\n >\n <Typography className=\"text-[14px] leading-5\">\n © 2024 CATSOLHAT\n </Typography>\n </Stack>\n </Stack>\n </>\n );\n};\n\nexport default Footer;\n","export default {\"src\":\"/_next/static/media/launchpad-logo.dce70e87.png\",\"height\":125,\"width\":564,\"blurDataURL\":\"\",\"blurWidth\":8,\"blurHeight\":2};","import React, { useEffect, useState } from 'react';\n\nimport Image from 'next/image';\nimport Link from 'next/link';\n\nimport Logo from '@/assets/logo.png';\nimport LaunchpadLogo from '@/assets/launchpad-logo.png';\nimport ConnectWallet from '@/components/connect-wallet';\nimport useMobileDetection from '@/root/src/hooks/use-mobile-detection';\nimport { Box, Stack, Typography } from '@mui/material';\n\nconst DesktopHeader = () => {\n const [isClient, setIsClient] = useState(false);\n const tokenSymbol = process.env.NEXT_PUBLIC_TOKEN_SYMBOL;\n const isSolCatToken = tokenSymbol == 'SOLCAT' || !tokenSymbol;\n\n useEffect(() => {\n setIsClient(true);\n }, []);\n\n return (\n <Stack\n direction=\"row\"\n className={`flex justify-between items-center ${\n isSolCatToken ? 'px-10 py-6' : 'pt-6 px-9 pb-3'\n } `}\n >\n <Stack direction=\"row\" spacing={2}>\n <Link href=\"https://catsolhat.com/\">\n <Image src={LaunchpadLogo} alt=\"launchpad-logo\" height={60} />\n </Link>\n </Stack>\n {/* <Stack direction=\"row\" spacing={2}>\n <Link href=\"/admin\">Admin</Link>\n </Stack> */}\n {isClient && <ConnectWallet />}\n </Stack>\n );\n};\n\nconst MobileHeader = () => {\n const [isClient, setIsClient] = useState(false);\n\n useEffect(() => {\n setIsClient(true);\n }, []);\n\n return (\n <Stack\n direction=\"row\"\n className=\"flex justify-between items-center px-5 py-5\"\n >\n <Image src={Logo} alt=\"logo\" width={35} height={35} />\n {isClient && <ConnectWallet />}\n </Stack>\n );\n};\n\nconst Header = () => {\n const isMobile = useMobileDetection();\n return (\n <Box className=\"fixed top-0 md:py-0 bg-black w-full z-[100]\">\n {isMobile ? <MobileHeader /> : <DesktopHeader />}\n </Box>\n );\n};\n\nexport default Header;\n","import useMobileDetection from '@/root/src/hooks/use-mobile-detection';\nimport { Box, Stack } from '@mui/material';\n\nimport Footer from './footer';\nimport Header from './header';\n\ninterface MainLayoutProps extends HocProps {\n showFooter?: boolean;\n}\nexport const MainLayout = ({\n children,\n showFooter = true,\n}: MainLayoutProps) => {\n const tokenSymbol = process.env.NEXT_PUBLIC_TOKEN_SYMBOL;\n const isSolCatToken = tokenSymbol == 'SOLCAT' || !tokenSymbol;\n const isMobile = useMobileDetection();\n const paddingStyle = isMobile ? 'px-3 pt-24' : 'px-6 pt-28';\n return (\n <Stack className=\"h-full\" justifyContent=\"space-between\">\n <Header />\n <Box\n className={`w-full ${paddingStyle} bg-black min-h-dvh overflow-x-clip`}\n >\n {children}\n </Box>\n {showFooter && !isSolCatToken && <Footer />}\n </Stack>\n );\n};\n","import axios from 'axios';\n\nimport { PublicKey } from '@solana/web3.js';\n\nexport async function fetchMerkleRoot(): Promise<{\n merkleRoot: string;\n totalAmount: number;\n totalUsers: number;\n}> {\n const response = await axios.get(\n `${process.env.NEXT_PUBLIC_API_BASE_URL}/merkle_distributor/merkle_root`,\n );\n return {\n merkleRoot: response.data.root,\n totalAmount: response.data.total_amount,\n totalUsers: response.data.total_users,\n };\n}\n\nexport async function fetchMerkleProof(publicKey: PublicKey | null): Promise<{\n proof: string[];\n index: number;\n amount: number;\n}> {\n if (!publicKey) {\n throw new Error('Public key is null');\n }\n\n const response = await axios.get(\n `${process.env.NEXT_PUBLIC_API_BASE_URL}/merkle_distributor/merkle_proof`,\n {\n params: {\n wallet_address: publicKey.toBase58(),\n token_symbol: process.env.NEXT_PUBLIC_TOKEN_SYMBOL,\n },\n },\n );\n\n if (response.status !== 200) {\n console.warn('Failed to fetch proof data, status:', response.status);\n return {\n proof: [],\n index: 0,\n amount: 0,\n };\n }\n\n return {\n proof: response.data.proof,\n index: response.data.index,\n amount: response.data.amount,\n };\n}\n","import axios from 'axios';\n\nexport async function fetchProjectDetails(): Promise<{\n tge: string | null;\n totalSupply: number;\n airdropAllocation: number;\n eligibleAmount: number;\n merkleRoot: string | undefined;\n totalAmount: number | undefined;\n totalUsers: number | undefined;\n startDate: string;\n endDate: string;\n tokenDecimals: number;\n}> {\n const response = await axios.get(\n `${process.env.NEXT_PUBLIC_API_BASE_URL}/projects`,\n {\n params: {\n token_symbol: `${process.env.NEXT_PUBLIC_TOKEN_SYMBOL}`,\n },\n },\n );\n\n return {\n tge: response.data.tge,\n totalSupply: response.data.total_supply,\n airdropAllocation: response.data.airdrop_allocation,\n eligibleAmount: response.data.eligible_amount,\n merkleRoot: response.data.merkle_root?.root,\n totalAmount: response.data.merkle_root?.total_amount,\n totalUsers: response.data.merkle_root?.total_users,\n startDate: response.data.start_date,\n endDate: response.data.end_date,\n tokenDecimals: response.data.token_decimals,\n };\n}\n","export const isSolcatToken = (tokenSymbol?: string): boolean => !tokenSymbol;\n","export default {\"src\":\"/_next/static/media/telegram.6f59cff6.svg\",\"height\":24,\"width\":25};","export default {\"src\":\"/_next/static/media/telegram-black.25759ae0.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/x.dd439bc4.svg\",\"height\":41,\"width\":40};","export default {\"src\":\"/_next/static/media/x-black.81527124.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/youtube.0d1bea12.svg\",\"height\":18,\"width\":19};","export default {\"src\":\"/_next/static/media/youtube-black.8423c462.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/web.399717c3.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/medium-black.ed865739.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/tiktok-black.7afda82d.svg\",\"height\":41,\"width\":41};","export default {\"src\":\"/_next/static/media/discord-black.745242a8.svg\",\"height\":41,\"width\":40};","import Logo from '@/assets/logo.png';\nimport Telegram from '@/assets/svgs/telegram.svg';\nimport TelegramBlack from '@/assets/svgs/telegram-black.svg';\nimport X from '@/assets/svgs/x.svg';\nimport XBlack from '@/assets/svgs/x-black.svg';\nimport Youtube from '@/assets/svgs/youtube.svg';\nimport YoutubeBlack from '@/assets/svgs/youtube-black.svg';\nimport Web from '@/assets/svgs/web.svg';\nimport MediumBlack from '@/assets/svgs/medium-black.svg';\nimport TikTokBlack from '@/assets/svgs/tiktok-black.svg';\nimport DiscordBlack from '@/assets/svgs/discord-black.svg';\n\nexport const IconName = {\n WEB: 'web',\n MEDIUM_BLACK: 'medium-black',\n TIKTOK_BLACK: 'tiktok-black',\n TELEGRAM: 'telegram',\n TELEGRAM_BLACK: 'telegram-black',\n X: 'x',\n X_BLACK: 'x-black',\n YOUTUBE: 'youtube',\n YOUTUBE_BLACK: 'youtube-black',\n LOGO: 'logo',\n DISCORD_BLACK: 'discord-black',\n};\n\nexport const staticImportIcon = (iconName: string) => {\n switch (iconName) {\n case IconName.WEB:\n return Web;\n case IconName.MEDIUM_BLACK:\n return MediumBlack;\n case IconName.TIKTOK_BLACK:\n return TikTokBlack;\n case IconName.TELEGRAM:\n return Telegram;\n case IconName.TELEGRAM_BLACK:\n return TelegramBlack;\n case IconName.X:\n return X;\n case IconName.X_BLACK:\n return XBlack;\n case IconName.YOUTUBE:\n return Youtube;\n case IconName.YOUTUBE_BLACK:\n return YoutubeBlack;\n case IconName.DISCORD_BLACK:\n return DiscordBlack;\n default:\n return Logo;\n }\n};\n","\"use strict\";\n(self[\"webpackChunk_N_E\"] = self[\"webpackChunk_N_E\"] || []).push([[90],{\n\n/***/ 8630:\n/***/ (function(__unused_webpack_module, __webpack_exports__) {\n\n/* harmony default export */ __webpack_exports__[\"Z\"] = ({\"src\":\"/_next/static/media/logo.f500d8a5.png\",\"height\":60,\"width\":60,\"blurDataURL\":\"\",\"blurWidth\":8,\"blurHeight\":8});\n\n/***/ }),\n\n/***/ 2857:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5893);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7294);\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9008);\n/* harmony import */ var next_head__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(next_head__WEBPACK_IMPORTED_MODULE_2__);\n/* provided dependency */ var process = __webpack_require__(4155);\n\n\n\nconst Seo = (param)=>{\n let { data } = param;\n const { title , description , url , thumbnailUrl } = data;\n const ahrefMetaContent = process.env.NEXT_PUBLIC_AHREF_META;\n return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsxs)((next_head__WEBPACK_IMPORTED_MODULE_2___default()), {\n children: [\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"title\", {\n children: title\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n name: \"title\",\n content: title\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n name: \"description\",\n content: description\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"og:type\",\n content: \"website\"\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"og:url\",\n content: url\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"og:title\",\n content: title\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"og:description\",\n content: description\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"og:image\",\n content: thumbnailUrl\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"twitter:card\",\n content: \"summary_large_image\"\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"twitter:url\",\n content: url\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"twitter:title\",\n content: title\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"twitter:description\",\n content: description\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n property: \"twitter:image\",\n content: thumbnailUrl\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__.jsx)(\"meta\", {\n name: \"ahrefs-site-verification\",\n content: ahrefMetaContent\n })\n ]\n });\n};\n/* harmony default export */ __webpack_exports__[\"Z\"] = (Seo);\n\n\n/***/ }),\n\n/***/ 7131:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"Z\": function() { return /* reexport */ container; }\n});\n\n// EXTERNAL MODULE: ./node_modules/react/jsx-runtime.js\nvar jsx_runtime = __webpack_require__(5893);\n// EXTERNAL MODULE: ./node_modules/react/index.js\nvar react = __webpack_require__(7294);\n// EXTERNAL MODULE: ./node_modules/@solana/wallet-adapter-react/lib/esm/useWallet.js\nvar useWallet = __webpack_require__(4306);\n// EXTERNAL MODULE: ./node_modules/@solana/wallet-adapter-react-ui/lib/esm/useWalletModal.js\nvar useWalletModal = __webpack_require__(3495);\n// EXTERNAL MODULE: ./src/hooks/use-mobile-detection.ts\nvar use_mobile_detection = __webpack_require__(3634);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Stack/Stack.js + 4 modules\nvar Stack = __webpack_require__(7668);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Button/Button.js + 3 modules\nvar Button = __webpack_require__(9417);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Typography/Typography.js + 1 modules\nvar Typography = __webpack_require__(5861);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Divider/Divider.js\nvar Divider = __webpack_require__(5551);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Menu/Menu.js + 18 modules\nvar Menu = __webpack_require__(8832);\n// EXTERNAL MODULE: ./node_modules/@mui/material/MenuItem/MenuItem.js + 3 modules\nvar MenuItem = __webpack_require__(3599);\n// EXTERNAL MODULE: ./src/utils/helpers.ts\nvar helpers = __webpack_require__(3680);\n;// CONCATENATED MODULE: ./src/components/connect-wallet/view.tsx\n\n\n\n\n\n\nconst View = (param)=>{\n let { walletInfo , balance , onClick , menuAnchorEl , menuItems , onMenuClose } = param;\n const { connected } = (0,useWallet/* useWallet */.O)();\n const font = connected ? \"font-dm_mono normal-case\" : \"font-cc\";\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n const fontSize = isMobile ? \"\" : \"text-xl\";\n const tokenSymbol = \"SOFAC\";\n const isSolcat = (0,helpers/* isSolcatToken */.k)(tokenSymbol);\n return /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Button/* default */.Z, {\n className: \"px-6 py-3 bg-white bg-opacity-10 rounded-full justify-center items-center gap-2.5 inline-flex mx-auto hover:bg-opacity-20\",\n onClick: onClick,\n children: connected ? /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n direction: \"row\",\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsxs)(Typography/* default */.Z, {\n className: \"text-white \".concat(fontSize, \" \").concat(font),\n children: [\n balance,\n \" \",\n isSolcat ? \"SOLCAT\" : tokenSymbol\n ]\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Divider/* default */.Z, {\n sx: {\n bgcolor: \"#343434\",\n width: \"1px\",\n height: \"27px\",\n mx: 1\n }\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Typography/* default */.Z, {\n className: \"text-white \".concat(fontSize, \" \").concat(font),\n children: walletInfo\n })\n ]\n }) : /*#__PURE__*/ (0,jsx_runtime.jsx)(Typography/* default */.Z, {\n className: \"text-white \".concat(fontSize, \" \").concat(font),\n children: walletInfo\n })\n }),\n Boolean(menuItems.length) && /*#__PURE__*/ (0,jsx_runtime.jsx)(Menu/* default */.Z, {\n open: Boolean(menuAnchorEl),\n onClose: onMenuClose,\n anchorEl: menuAnchorEl,\n anchorOrigin: {\n horizontal: \"right\",\n vertical: \"bottom\"\n },\n transformOrigin: {\n horizontal: \"right\",\n vertical: \"top\"\n },\n MenuListProps: {\n className: \"bg-[#2c2d30] rounded-xl p-2 text-sm\"\n },\n classes: {\n paper: \"bg-[#2c2d30] mt-1 rounded-md\"\n },\n children: menuItems.map((param)=>{\n let { disabled , keepMenuOpenAfterClick , onClick , testId , text } = param;\n /*#__PURE__*/ return (0,jsx_runtime.jsx)(MenuItem/* default */.Z, {\n \"data-testid\": \"header-wallet-\".concat(testId),\n disabled: disabled,\n className: \"bg-[#2c2d30] rounded-md text-sm px-4 py-3 text-white font-dm_mono hover:bg-[#3c3d40]\",\n onClick: ()=>{\n onClick === null || onClick === void 0 ? void 0 : onClick();\n !keepMenuOpenAfterClick && (onMenuClose === null || onMenuClose === void 0 ? void 0 : onMenuClose());\n },\n children: text\n }, text);\n })\n })\n ]\n });\n};\nconst memoView = /*#__PURE__*/ (0,react.memo)(View);\nmemoView.displayName = \"ConnectWallet\";\n/* harmony default export */ var view = (memoView);\n\n// EXTERNAL MODULE: ./node_modules/@solana/spl-token/lib/index.browser.esm.js + 4 modules\nvar index_browser_esm = __webpack_require__(4945);\n// EXTERNAL MODULE: ./src/providers/solana/index.tsx + 1 modules\nvar solana = __webpack_require__(3671);\n;// CONCATENATED MODULE: ./src/components/connect-wallet/container.tsx\n\n\n\n\n\n\n\nconst Container = ()=>{\n const { connected , connecting , disconnect , disconnecting , publicKey , wallet } = (0,useWallet/* useWallet */.O)();\n const { connection , mintPublicKey } = (0,solana/* useSolana */.X)();\n const { setVisible } = (0,useWalletModal/* useWalletModal */.h)();\n const [menuAnchorEl, setMenuAnchorEl] = (0,react.useState)();\n const [showCopiedMenuItem, setShowCopiedMenuItem] = (0,react.useState)(false);\n const isWalletConnected = connected && publicKey && wallet;\n const [solCatBalance, setSolCatBalance] = (0,react.useState)(0);\n (0,react.useEffect)(()=>{\n if (!publicKey || !connection) return;\n const fetchTokenBalance = async ()=>{\n try {\n const ata = await index_browser_esm.Token.getAssociatedTokenAddress(index_browser_esm.ASSOCIATED_TOKEN_PROGRAM_ID, index_browser_esm.TOKEN_PROGRAM_ID, mintPublicKey, publicKey);\n const ataInfo = await connection.getParsedAccountInfo(ata);\n let balance = 0;\n if (ataInfo && ataInfo.value && ataInfo.value.data) {\n var _ataInfo_value_data_parsed, _ataInfo_value_data_parsed_info, _ataInfo_value_data_parsed_info_tokenAmount;\n balance = ((_ataInfo_value_data_parsed = ataInfo.value.data.parsed) === null || _ataInfo_value_data_parsed === void 0 ? void 0 : (_ataInfo_value_data_parsed_info = _ataInfo_value_data_parsed.info) === null || _ataInfo_value_data_parsed_info === void 0 ? void 0 : (_ataInfo_value_data_parsed_info_tokenAmount = _ataInfo_value_data_parsed_info.tokenAmount) === null || _ataInfo_value_data_parsed_info_tokenAmount === void 0 ? void 0 : _ataInfo_value_data_parsed_info_tokenAmount.uiAmount) || 0;\n }\n setSolCatBalance(balance);\n } catch (error) {\n console.error(\"Error fetching token balance:\", error);\n }\n };\n fetchTokenBalance();\n }, [\n publicKey\n ]);\n const minifyAddress = function(address) {\n let length = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 4;\n if (address.length <= length * 2) {\n return address;\n }\n const firstPart = address.slice(0, length);\n const lastPart = address.slice(-length);\n return \"\".concat(firstPart, \"...\").concat(lastPart);\n };\n const handleCopyAddress = (0,react.useCallback)(async ()=>{\n if (publicKey) {\n var _navigator_clipboard;\n await (navigator === null || navigator === void 0 ? void 0 : (_navigator_clipboard = navigator.clipboard) === null || _navigator_clipboard === void 0 ? void 0 : _navigator_clipboard.writeText(publicKey.toBase58()));\n setShowCopiedMenuItem(true);\n setTimeout(()=>setShowCopiedMenuItem(false), 600);\n }\n }, [\n publicKey\n ]);\n (0,react.useEffect)(()=>{\n setMenuAnchorEl(undefined);\n }, [\n isWalletConnected\n ]);\n const menuItems = (0,react.useMemo)(()=>isWalletConnected ? [\n {\n disabled: showCopiedMenuItem,\n keepMenuOpenAfterClick: true,\n onClick: showCopiedMenuItem ? undefined : handleCopyAddress,\n testId: \"btn-copy-wallet-address\",\n text: showCopiedMenuItem ? \"Copied\" : \"Copy Address\"\n },\n {\n onClick: ()=>setVisible(true),\n testId: \"btn-change-wallet\",\n text: \"Change Wallet\"\n },\n {\n onClick: disconnect,\n testId: \"btn-disconnect-wallet\",\n text: \"Disconnect\"\n }\n ] : [], [\n disconnect,\n handleCopyAddress,\n isWalletConnected,\n showCopiedMenuItem,\n setVisible,\n \"Copied\",\n \"Copy Address\",\n \"Disconnect\"\n ]);\n const buttonLabel = isWalletConnected ? minifyAddress(publicKey.toBase58()) : connecting ? \"Connecting...\" : disconnecting ? \"Disconnecting...\" : \"Connect Wallet\";\n const viewProps = (0,react.useMemo)(()=>{\n return {\n icon: wallet === null || wallet === void 0 ? void 0 : wallet.adapter.icon,\n loading: connecting || disconnecting,\n onClick: (e)=>isWalletConnected ? setMenuAnchorEl(e.currentTarget) : setVisible(true),\n walletInfo: buttonLabel,\n balance: solCatBalance,\n menuAnchorEl,\n menuItems,\n onMenuClose: ()=>setMenuAnchorEl(undefined)\n };\n }, [\n buttonLabel,\n connecting,\n disconnecting,\n isWalletConnected,\n menuAnchorEl,\n menuItems,\n setVisible,\n wallet === null || wallet === void 0 ? void 0 : wallet.adapter.icon,\n solCatBalance\n ]);\n return /*#__PURE__*/ (0,jsx_runtime.jsx)(view, {\n ...viewProps\n });\n};\n/* harmony default export */ var container = (Container);\n\n;// CONCATENATED MODULE: ./src/components/connect-wallet/index.ts\n\n\n\n/***/ }),\n\n/***/ 1880:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"j\": function() { return /* binding */ MICRO_TOKEN; }\n/* harmony export */ });\nconst MICRO_TOKEN = 1000000; // TODO: based on mint address\n\n\n/***/ }),\n\n/***/ 9419:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"X\": function() { return /* binding */ useDistributorData; }\n/* harmony export */ });\n/* harmony import */ var react_query__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8767);\n/* harmony import */ var _providers_solana__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3671);\n\n\nconst useDistributorData = ()=>{\n const { distributorClient , distributor } = (0,_providers_solana__WEBPACK_IMPORTED_MODULE_1__/* .useSolana */ .X)();\n const fetchDistributorData = async ()=>{\n if (!distributorClient || !distributor) return null;\n const fetchedData = await distributorClient.ctx.program.account.merkleDistributor.fetchNullable(distributor.key);\n if (!fetchedData) return null;\n return fetchedData;\n };\n return (0,react_query__WEBPACK_IMPORTED_MODULE_0__.useQuery)([\n \"distributorData\",\n distributor === null || distributor === void 0 ? void 0 : distributor.key\n ], fetchDistributorData, {\n enabled: !!(distributor === null || distributor === void 0 ? void 0 : distributor.key),\n staleTime: 1 * 60 * 1000\n });\n};\n\n\n/***/ }),\n\n/***/ 3634:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony import */ var _mui_material__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2734);\n/* harmony import */ var _mui_material__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(1730);\n\nconst useMobileDetection = ()=>{\n const theme = (0,_mui_material__WEBPACK_IMPORTED_MODULE_0__/* [\"default\"] */ .Z)();\n const isMobile = (0,_mui_material__WEBPACK_IMPORTED_MODULE_1__/* [\"default\"] */ .Z)(theme.breakpoints.down(\"sm\"));\n return isMobile;\n};\n/* harmony default export */ __webpack_exports__[\"Z\"] = (useMobileDetection);\n\n\n/***/ }),\n\n/***/ 942:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"Z\": function() { return /* binding */ use_trans; }\n});\n\n// EXTERNAL MODULE: ./node_modules/next/router.js\nvar router = __webpack_require__(1163);\n;// CONCATENATED MODULE: ./src/locales/en.ts\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst locale = {\n BODO: {\n website_url: \"https://boopdoge.com/\",\n telegram_url: \"https://t.me/BoopDoge_Token\",\n x_url: \"https://x.com/BoopDoge_Token\",\n guide_url: \"https://catsolhat.medium.com/introducing-the-first-catsolhat-launchpad-project-boopdoge-4e136347e53f\",\n description: \"<p>BoopDoge is a community-driven meme coin inspired by the urge to boop a dog on the nose. Our mission is to help passionate dog lovers and crypto enthusiasts achieve financial freedom.</p> <p>BoopDoge will be a flagship for emerging DeFi and meme culture on Solana. This is part of a larger plan to strengthen the creator culture on Solana as BoopDoge continues to integrate into the broader ecosystem.</p>\",\n eligibility: (eligibleAmount)=>'<p>Average holding of at <span style=\"color:#6dfcd1\">least '.concat(eligibleAmount, \" SOLCAT</span> (based on two snapshots). The first snapshot was taken on 1st July. The second snapshot will be taken at a random moment between 6th and 8th July.</p>\"),\n token_name: \"BoopDoge\",\n blockchain: \"Solana\"\n },\n SOFAC: {\n website_url: \"https://sofacat.click/\",\n telegram_url: \"https://t.me/SofaCatSPL\",\n x_url: \"https://x.com/SofaCatSPL\",\n guide_url: \"https://catsolhat.medium.com/introducing-the-next-launchpad-project-sofacat-9a498f0865a7\",\n description: \"<p>Every cat loves a good sofa, and so does the SofaCat! With $SOFAC, comfort and profit go hand in hand - relax, enjoy, and watch your crypto grow.</p>\",\n eligibility: (eligibleAmount)=>'<p>Hold at <span style=\"color:#6dfcd1\">least '.concat(eligibleAmount, \" $SOLCAT</span> at the snapshot on September 27th.</p>\"),\n token_name: \"SofaCat\",\n blockchain: \"Solana\"\n },\n OIIA: {\n website_url: \"https://oiiaoiiasol.com/\",\n telegram_url: \"https://t.me/oiia_oiia_community\",\n x_url: \"https://x.com/oiia_oiia_onSol\",\n guide_url: \"https://x.com/catsolhat/status/1854521247759208769\",\n description: \"<p>OiiaOiia is a dynamic memecoin, featuring a quirky cat caught in endless spin excitement!</p>\",\n eligibility: (eligibleAmount)=>'<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">at least '.concat(eligibleAmount, \" Launchpad Credits (LC)</span> by the snapshot on November 18.\"),\n token_name: \"OiiaOiia\",\n blockchain: \"Solana\"\n },\n CATIVA: {\n website_url: \"https://cativa.lol/\",\n telegram_url: \"https://t.me/cativasolana\",\n x_url: \"https://x.com/cativasolana\",\n guide_url: \"https://x.com/catsolhat/status/1863952080312176786\",\n description: \"<p>Cats on Sativa are a bunch of chill cats enjoying life, purring, and vibing with the universe. Pure feline zen energy!</p>\",\n eligibility: (eligibleAmount)=>'<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">'.concat(eligibleAmount, \"+ Launchpad Credits (LC)</span> at the snapshot on December 9\"),\n token_name: \"Cats on Savita\",\n blockchain: \"Solana\"\n },\n SHINO: {\n website_url: \"https://dinoshiba.me/\",\n telegram_url: \"https://t.me/dinoshiba_me\",\n x_url: \"https://x.com/dinoshiba_x\",\n guide_url: \"https://x.com/catsolhat/status/1878807792653631537\",\n description: \"<p>Half Dino, Half Shiba, 100% Adorable! Experience the joy of DinoShiba's daily adventures! Watch as our adorable friend combines the charm of a Shiba Inu with the playful spirit of a tiny dinosaur.</p>\",\n eligibility: (eligibleAmount)=>'<p>Stake $SOLCAT to accumulate <span style=\"color:#6dfcd1\">'.concat(eligibleAmount, \"+ Launchpad Credits (LC)</span> at the snapshot on Jan 22, 2025</p>\"),\n token_name: \"DinoShiba\",\n blockchain: \"Solana\"\n },\n meta: {\n title: \"CatSolHat Super Airdrop\",\n description: \"Claim your SOLCAT airdrop: Early Contributors, Active Wallets on Solana DEXs, Saga Phone Buyers, Top NFT Collections Holders,...\",\n thumbnail_url: \"/thumbnail.png\"\n }\n};\n/* harmony default export */ var en = (locale);\n\n;// CONCATENATED MODULE: ./src/hooks/use-trans.ts\n\n\nconst useTrans = ()=>{\n const { locale } = (0,router.useRouter)();\n switch(locale){\n default:\n return en;\n }\n};\n/* harmony default export */ var use_trans = (useTrans);\n\n\n/***/ }),\n\n/***/ 9408:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"Z\": function() { return /* binding */ MainLayout; }\n});\n\n// EXTERNAL MODULE: ./node_modules/react/jsx-runtime.js\nvar jsx_runtime = __webpack_require__(5893);\n// EXTERNAL MODULE: ./src/hooks/use-mobile-detection.ts\nvar use_mobile_detection = __webpack_require__(3634);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Stack/Stack.js + 4 modules\nvar Stack = __webpack_require__(7668);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Box/Box.js + 2 modules\nvar Box = __webpack_require__(5616);\n// EXTERNAL MODULE: ./node_modules/next/image.js\nvar next_image = __webpack_require__(5675);\nvar image_default = /*#__PURE__*/__webpack_require__.n(next_image);\n// EXTERNAL MODULE: ./src/hooks/use-trans.ts + 1 modules\nvar use_trans = __webpack_require__(942);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Tooltip/Tooltip.js + 62 modules\nvar Tooltip = __webpack_require__(5203);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Fade/Fade.js\nvar Fade = __webpack_require__(6227);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Link/Link.js + 2 modules\nvar Link = __webpack_require__(3795);\n// EXTERNAL MODULE: ./node_modules/@mui/material/Typography/Typography.js + 1 modules\nvar Typography = __webpack_require__(5861);\n// EXTERNAL MODULE: ./src/utils/static-import-icon.tsx + 10 modules\nvar static_import_icon = __webpack_require__(3353);\n// EXTERNAL MODULE: ./node_modules/@swc/helpers/src/_tagged_template_literal.mjs\nvar _tagged_template_literal = __webpack_require__(7297);\n// EXTERNAL MODULE: ./node_modules/react/index.js\nvar react = __webpack_require__(7294);\n// EXTERNAL MODULE: ./node_modules/@emotion/react/dist/emotion-react.browser.esm.js\nvar emotion_react_browser_esm = __webpack_require__(917);\n;// CONCATENATED MODULE: ./src/layouts/components/solcat-carouse.tsx\n\nfunction _templateObject() {\n const data = (0,_tagged_template_literal/* default */.Z)([\n \"\\n 0% {\\n transform: translateX(100%);\\n }\\n 100% {\\n transform: translateX(-100%);\\n }\\n\"\n ]);\n _templateObject = function() {\n return data;\n };\n return data;\n}\n\n\n\n\nconst slide = (0,emotion_react_browser_esm/* keyframes */.F4)(_templateObject());\nconst CarouselText = ()=>{\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n return /*#__PURE__*/ (0,jsx_runtime.jsx)(Box/* default */.Z, {\n className: \"relative\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Box/* default */.Z, {\n sx: {\n display: \"flex\",\n position: \"relative\",\n justifyContent: \"center\",\n alignItems: \"center\",\n animation: \"\".concat(slide, \" 100s linear infinite\")\n },\n className: \"p-1\",\n children: Array.from({\n length: 24\n }).map((_, index)=>/*#__PURE__*/ (0,jsx_runtime.jsx)(Typography/* default */.Z, {\n className: \"\".concat(isMobile ? \"text-[24px]\" : \"text-[56px] leading-[72px]\", \" text-black font-cc\"),\n children: index % 2 === 0 ? \"$SOLCAT\" : /*#__PURE__*/ (0,jsx_runtime.jsx)(\"span\", {\n children: \"\\xa0\\xb7\\xa0\"\n })\n }, index))\n })\n });\n};\n/* harmony default export */ var solcat_carouse = (CarouselText);\n\n;// CONCATENATED MODULE: ./src/layouts/main-layout/footer.tsx\n\n\n\n\n\n\n\nconst SocialButton = ()=>{\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n return /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n direction: \"row\",\n gap: isMobile ? 2 : 3,\n className: \"\".concat(isMobile ? \"px-6 py-8\" : \"px-12 py-12\"),\n justifyContent: \"center\",\n alignItems: \"center\",\n spacing: \"2px\",\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"Youtube\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-youtube\",\n href: \"https://www.youtube.com/@catsolhat\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.YOUTUBE_BLACK */.u.YOUTUBE_BLACK),\n alt: static_import_icon/* IconName.YOUTUBE_BLACK */.u.YOUTUBE_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"TikTok\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-tiktok\",\n href: \"https://www.tiktok.com/@catsolhat\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.TIKTOK_BLACK */.u.TIKTOK_BLACK),\n alt: static_import_icon/* IconName.TIKTOK_BLACK */.u.TIKTOK_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"Medium\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-medium\",\n href: \"https://catsolhat.medium.com/\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.MEDIUM_BLACK */.u.MEDIUM_BLACK),\n alt: static_import_icon/* IconName.MEDIUM_BLACK */.u.MEDIUM_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"Telegram\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-telegram\",\n href: \"https://t.me/catsolhat1\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.TELEGRAM_BLACK */.u.TELEGRAM_BLACK),\n alt: static_import_icon/* IconName.TELEGRAM_BLACK */.u.TELEGRAM_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"X\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-x\",\n href: \"https://x.com/catsolhat\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.X_BLACK */.u.X_BLACK),\n alt: static_import_icon/* IconName.X_BLACK */.u.X_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n }),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n className: \"social-button-stack\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Tooltip/* default */.Z, {\n title: \"Discord\",\n placement: \"top\",\n TransitionComponent: Fade/* default */.Z,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Link/* default */.Z, {\n \"data-testid\": \"social-link-discord\",\n href: \"https://discord.gg/dVytU8NJsf\",\n target: \"_blank\",\n rel: \"noreferrer\",\n height: 40,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: (0,static_import_icon/* staticImportIcon */.N)(static_import_icon/* IconName.DISCORD_BLACK */.u.DISCORD_BLACK),\n alt: static_import_icon/* IconName.DISCORD_BLACK */.u.DISCORD_BLACK,\n width: 40,\n height: 40\n })\n })\n })\n })\n ]\n });\n};\nconst Footer = ()=>{\n const trans = (0,use_trans/* default */.Z)();\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n return /*#__PURE__*/ (0,jsx_runtime.jsx)(jsx_runtime.Fragment, {\n children: /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n className: \"\".concat(isMobile ? \"mx-3 py-4 rounded-[20px]\" : \"mx-6 py-8 rounded-[40px]\", \" w-auto bg-gradient-footer mt-2 \"),\n gap: isMobile ? 2 : 3,\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)(solcat_carouse, {}),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(SocialButton, {}),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n direction: \"row\",\n justifyContent: \"center\",\n spacing: 4,\n alignItems: \"center\",\n className: \"\".concat(isMobile ? \"px-8 py-6\" : \"px-12 py-8\"),\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)(Typography/* default */.Z, {\n className: \"text-[14px] leading-5\",\n children: \"\\xa9 2024 CATSOLHAT\"\n })\n })\n ]\n })\n });\n};\n/* harmony default export */ var footer = (Footer);\n\n// EXTERNAL MODULE: ./node_modules/next/link.js\nvar next_link = __webpack_require__(1664);\nvar link_default = /*#__PURE__*/__webpack_require__.n(next_link);\n// EXTERNAL MODULE: ./src/assets/logo.png\nvar logo = __webpack_require__(8630);\n;// CONCATENATED MODULE: ./src/assets/launchpad-logo.png\n/* harmony default export */ var launchpad_logo = ({\"src\":\"/_next/static/media/launchpad-logo.dce70e87.png\",\"height\":125,\"width\":564,\"blurDataURL\":\"\",\"blurWidth\":8,\"blurHeight\":2});\n// EXTERNAL MODULE: ./src/components/connect-wallet/index.ts + 2 modules\nvar connect_wallet = __webpack_require__(7131);\n;// CONCATENATED MODULE: ./src/layouts/main-layout/header.tsx\n\n\n\n\n\n\n\n\n\nconst DesktopHeader = ()=>{\n const [isClient, setIsClient] = (0,react.useState)(false);\n const tokenSymbol = \"SOFAC\";\n const isSolCatToken = tokenSymbol == \"SOLCAT\" || !tokenSymbol;\n (0,react.useEffect)(()=>{\n setIsClient(true);\n }, []);\n return /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n direction: \"row\",\n className: \"flex justify-between items-center \".concat(isSolCatToken ? \"px-10 py-6\" : \"pt-6 px-9 pb-3\", \" \"),\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Stack/* default */.Z, {\n direction: \"row\",\n spacing: 2,\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((link_default()), {\n href: \"https://catsolhat.com/\",\n children: /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: launchpad_logo,\n alt: \"launchpad-logo\",\n height: 60\n })\n })\n }),\n isClient && /*#__PURE__*/ (0,jsx_runtime.jsx)(connect_wallet/* default */.Z, {})\n ]\n });\n};\nconst MobileHeader = ()=>{\n const [isClient, setIsClient] = (0,react.useState)(false);\n (0,react.useEffect)(()=>{\n setIsClient(true);\n }, []);\n return /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n direction: \"row\",\n className: \"flex justify-between items-center px-5 py-5\",\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)((image_default()), {\n src: logo/* default */.Z,\n alt: \"logo\",\n width: 35,\n height: 35\n }),\n isClient && /*#__PURE__*/ (0,jsx_runtime.jsx)(connect_wallet/* default */.Z, {})\n ]\n });\n};\nconst Header = ()=>{\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n return /*#__PURE__*/ (0,jsx_runtime.jsx)(Box/* default */.Z, {\n className: \"fixed top-0 md:py-0 bg-black w-full z-[100]\",\n children: isMobile ? /*#__PURE__*/ (0,jsx_runtime.jsx)(MobileHeader, {}) : /*#__PURE__*/ (0,jsx_runtime.jsx)(DesktopHeader, {})\n });\n};\n/* harmony default export */ var header = (Header);\n\n;// CONCATENATED MODULE: ./src/layouts/main-layout/index.tsx\n\n\n\n\n\nconst MainLayout = (param)=>{\n let { children , showFooter =true } = param;\n const tokenSymbol = \"SOFAC\";\n const isSolCatToken = tokenSymbol == \"SOLCAT\" || !tokenSymbol;\n const isMobile = (0,use_mobile_detection/* default */.Z)();\n const paddingStyle = isMobile ? \"px-3 pt-24\" : \"px-6 pt-28\";\n return /*#__PURE__*/ (0,jsx_runtime.jsxs)(Stack/* default */.Z, {\n className: \"h-full\",\n justifyContent: \"space-between\",\n children: [\n /*#__PURE__*/ (0,jsx_runtime.jsx)(header, {}),\n /*#__PURE__*/ (0,jsx_runtime.jsx)(Box/* default */.Z, {\n className: \"w-full \".concat(paddingStyle, \" bg-black min-h-dvh overflow-x-clip\"),\n children: children\n }),\n showFooter && !isSolCatToken && /*#__PURE__*/ (0,jsx_runtime.jsx)(footer, {})\n ]\n });\n};\n\n\n/***/ }),\n\n/***/ 4725:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"G\": function() { return /* binding */ fetchMerkleProof; },\n/* harmony export */ \"o\": function() { return /* binding */ fetchMerkleRoot; }\n/* harmony export */ });\n/* harmony import */ var axios__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7066);\n\nasync function fetchMerkleRoot() {\n const response = await axios__WEBPACK_IMPORTED_MODULE_0__/* [\"default\"].get */ .Z.get(\"\".concat(\"https://api.catsolhat.com/api/v1\", \"/merkle_distributor/merkle_root\"));\n return {\n merkleRoot: response.data.root,\n totalAmount: response.data.total_amount,\n totalUsers: response.data.total_users\n };\n}\nasync function fetchMerkleProof(publicKey) {\n if (!publicKey) {\n throw new Error(\"Public key is null\");\n }\n const response = await axios__WEBPACK_IMPORTED_MODULE_0__/* [\"default\"].get */ .Z.get(\"\".concat(\"https://api.catsolhat.com/api/v1\", \"/merkle_distributor/merkle_proof\"), {\n params: {\n wallet_address: publicKey.toBase58(),\n token_symbol: \"SOFAC\"\n }\n });\n if (response.status !== 200) {\n console.warn(\"Failed to fetch proof data, status:\", response.status);\n return {\n proof: [],\n index: 0,\n amount: 0\n };\n }\n return {\n proof: response.data.proof,\n index: response.data.index,\n amount: response.data.amount\n };\n}\n\n\n/***/ }),\n\n/***/ 7127:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"G\": function() { return /* binding */ fetchProjectDetails; }\n/* harmony export */ });\n/* harmony import */ var axios__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7066);\n\nasync function fetchProjectDetails() {\n var _response_data_merkle_root, _response_data_merkle_root1, _response_data_merkle_root2;\n const response = await axios__WEBPACK_IMPORTED_MODULE_0__/* [\"default\"].get */ .Z.get(\"\".concat(\"https://api.catsolhat.com/api/v1\", \"/projects\"), {\n params: {\n token_symbol: \"\".concat(\"SOFAC\")\n }\n });\n return {\n tge: response.data.tge,\n totalSupply: response.data.total_supply,\n airdropAllocation: response.data.airdrop_allocation,\n eligibleAmount: response.data.eligible_amount,\n merkleRoot: (_response_data_merkle_root = response.data.merkle_root) === null || _response_data_merkle_root === void 0 ? void 0 : _response_data_merkle_root.root,\n totalAmount: (_response_data_merkle_root1 = response.data.merkle_root) === null || _response_data_merkle_root1 === void 0 ? void 0 : _response_data_merkle_root1.total_amount,\n totalUsers: (_response_data_merkle_root2 = response.data.merkle_root) === null || _response_data_merkle_root2 === void 0 ? void 0 : _response_data_merkle_root2.total_users,\n startDate: response.data.start_date,\n endDate: response.data.end_date,\n tokenDecimals: response.data.token_decimals\n };\n}\n\n\n/***/ }),\n\n/***/ 3680:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"k\": function() { return /* binding */ isSolcatToken; }\n/* harmony export */ });\nconst isSolcatToken = (tokenSymbol)=>!tokenSymbol;\n\n\n/***/ }),\n\n/***/ 3353:\n/***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {\n\n\n// EXPORTS\n__webpack_require__.d(__webpack_exports__, {\n \"u\": function() { return /* binding */ IconName; },\n \"N\": function() { return /* binding */ staticImportIcon; }\n});\n\n// EXTERNAL MODULE: ./src/assets/logo.png\nvar logo = __webpack_require__(8630);\n;// CONCATENATED MODULE: ./src/assets/svgs/telegram.svg\n/* harmony default export */ var telegram = ({\"src\":\"/_next/static/media/telegram.6f59cff6.svg\",\"height\":24,\"width\":25});\n;// CONCATENATED MODULE: ./src/assets/svgs/telegram-black.svg\n/* harmony default export */ var telegram_black = ({\"src\":\"/_next/static/media/telegram-black.25759ae0.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/x.svg\n/* harmony default export */ var x = ({\"src\":\"/_next/static/media/x.dd439bc4.svg\",\"height\":41,\"width\":40});\n;// CONCATENATED MODULE: ./src/assets/svgs/x-black.svg\n/* harmony default export */ var x_black = ({\"src\":\"/_next/static/media/x-black.81527124.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/youtube.svg\n/* harmony default export */ var youtube = ({\"src\":\"/_next/static/media/youtube.0d1bea12.svg\",\"height\":18,\"width\":19});\n;// CONCATENATED MODULE: ./src/assets/svgs/youtube-black.svg\n/* harmony default export */ var youtube_black = ({\"src\":\"/_next/static/media/youtube-black.8423c462.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/web.svg\n/* harmony default export */ var web = ({\"src\":\"/_next/static/media/web.399717c3.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/medium-black.svg\n/* harmony default export */ var medium_black = ({\"src\":\"/_next/static/media/medium-black.ed865739.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/tiktok-black.svg\n/* harmony default export */ var tiktok_black = ({\"src\":\"/_next/static/media/tiktok-black.7afda82d.svg\",\"height\":41,\"width\":41});\n;// CONCATENATED MODULE: ./src/assets/svgs/discord-black.svg\n/* harmony default export */ var discord_black = ({\"src\":\"/_next/static/media/discord-black.745242a8.svg\",\"height\":41,\"width\":40});\n;// CONCATENATED MODULE: ./src/utils/static-import-icon.tsx\n\n\n\n\n\n\n\n\n\n\n\nconst IconName = {\n WEB: \"web\",\n MEDIUM_BLACK: \"medium-black\",\n TIKTOK_BLACK: \"tiktok-black\",\n TELEGRAM: \"telegram\",\n TELEGRAM_BLACK: \"telegram-black\",\n X: \"x\",\n X_BLACK: \"x-black\",\n YOUTUBE: \"youtube\",\n YOUTUBE_BLACK: \"youtube-black\",\n LOGO: \"logo\",\n DISCORD_BLACK: \"discord-black\"\n};\nconst staticImportIcon = (iconName)=>{\n switch(iconName){\n case IconName.WEB:\n return web;\n case IconName.MEDIUM_BLACK:\n return medium_black;\n case IconName.TIKTOK_BLACK:\n return tiktok_black;\n case IconName.TELEGRAM:\n return telegram;\n case IconName.TELEGRAM_BLACK:\n return telegram_black;\n case IconName.X:\n return x;\n case IconName.X_BLACK:\n return x_black;\n case IconName.YOUTUBE:\n return youtube;\n case IconName.YOUTUBE_BLACK:\n return youtube_black;\n case IconName.DISCORD_BLACK:\n return discord_black;\n default:\n return logo/* default */.Z;\n }\n};\n\n\n/***/ })\n\n}]);"],"names":["self","push","__unused_webpack_module","__webpack_exports__","__webpack_require__","react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__","next_head__WEBPACK_IMPORTED_MODULE_2__","next_head__WEBPACK_IMPORTED_MODULE_2___default","n","process","Seo","data","param","title","description","url","thumbnailUrl","ahrefMetaContent","env","NEXT_PUBLIC_AHREF_META","jsxs","children","jsx","name","content","property","d","container","jsx_runtime","react","useWallet","useWalletModal","use_mobile_detection","Stack","Button","Typography","Divider","Menu","MenuItem","helpers","View","walletInfo","balance","onClick","menuAnchorEl","menuItems","onMenuClose","connected","O","font","isMobile","Z","fontSize","tokenSymbol","isSolcat","k","className","direction","concat","sx","bgcolor","width","height","mx","Boolean","length","open","onClose","anchorEl","anchorOrigin","horizontal","vertical","transformOrigin","MenuListProps","classes","paper","map","disabled","keepMenuOpenAfterClick","testId","text","memoView","memo","displayName","index_browser_esm","solana","Container","connecting","disconnect","disconnecting","publicKey","wallet","connection","mintPublicKey","X","setVisible","h","setMenuAnchorEl","useState","showCopiedMenuItem","setShowCopiedMenuItem","isWalletConnected","solCatBalance","setSolCatBalance","useEffect","fetchTokenBalance","ata","Token","getAssociatedTokenAddress","ASSOCIATED_TOKEN_PROGRAM_ID","TOKEN_PROGRAM_ID","ataInfo","getParsedAccountInfo","value","_ataInfo_value_data_parsed","_ataInfo_value_data_parsed_info","_ataInfo_value_data_parsed_info_tokenAmount","parsed","info","tokenAmount","uiAmount","error","console","handleCopyAddress","useCallback","_navigator_clipboard","navigator","clipboard","writeText","toBase58","setTimeout","undefined","useMemo","buttonLabel","minifyAddress","address","arguments","firstPart","slice","lastPart","viewProps","icon","adapter","loading","e","currentTarget","MICRO_TOKEN","useDistributorData","react_query__WEBPACK_IMPORTED_MODULE_0__","_providers_solana__WEBPACK_IMPORTED_MODULE_1__","distributorClient","distributor","fetchDistributorData","fetchedData","ctx","program","account","merkleDistributor","fetchNullable","key","useQuery","enabled","staleTime","_mui_material__WEBPACK_IMPORTED_MODULE_0__","_mui_material__WEBPACK_IMPORTED_MODULE_1__","useMobileDetection","theme","breakpoints","down","use_trans","router","en","BODO","website_url","telegram_url","x_url","guide_url","eligibility","eligibleAmount","token_name","blockchain","SOFAC","OIIA","CATIVA","SHINO","meta","thumbnail_url","useTrans","locale","useRouter","MainLayout","Box","next_image","image_default","Tooltip","Fade","Link","static_import_icon","_tagged_template_literal","emotion_react_browser_esm","_templateObject","slide","F4","CarouselText","display","position","justifyContent","alignItems","animation","Array","from","_","index","SocialButton","gap","spacing","placement","TransitionComponent","href","target","rel","src","N","u","YOUTUBE_BLACK","alt","TIKTOK_BLACK","MEDIUM_BLACK","TELEGRAM_BLACK","X_BLACK","DISCORD_BLACK","Footer","Fragment","next_link","link_default","logo","launchpad_logo","connect_wallet","DesktopHeader","isClient","setIsClient","MobileHeader","Header","showFooter","fetchMerkleProof","fetchMerkleRoot","axios__WEBPACK_IMPORTED_MODULE_0__","response","get","merkleRoot","root","totalAmount","total_amount","totalUsers","total_users","params","wallet_address","token_symbol","status","warn","proof","amount","fetchProjectDetails","_response_data_merkle_root","_response_data_merkle_root1","_response_data_merkle_root2","tge","totalSupply","total_supply","airdropAllocation","airdrop_allocation","eligible_amount","merkle_root","startDate","start_date","endDate","end_date","tokenDecimals","token_decimals","isSolcatToken","IconName","staticImportIcon","telegram","telegram_black","x","x_black","youtube","youtube_black","web","medium_black","tiktok_black","discord_black","WEB","TELEGRAM","YOUTUBE","LOGO","iconName"],"sourceRoot":""}