{"version":3,"sources":["assets/images/kcc-logo.svg","assets/images/kucoin-logo.svg","assets/images/foundation/f1.png","pages/home/components/Slider.tsx","assets/images/Icons/app/twitter-logo@2x.png","assets/images/Icons/app/telegram-logo@2x.png","assets/images/Icons/app/github-logo@2x.png","assets/images/Icons/app/discord-logo@2x.png","assets/images/Icons/twitter-logo@2x.png","assets/images/Icons/twitter-logo-hover@2x.png","assets/images/Icons/telegram-logo@2x.png","assets/images/Icons/telegram-logo-hover@2x.png","assets/images/Icons/medium-logo@2x.png","assets/images/Icons/medium-logo-hover@2x.png","assets/images/Icons/discord-logo@2x.png","assets/images/Icons/discord-logo-hover@2x.png","assets/images/kcs-logo.svg","utils/responsive.ts","assets/images/home/4.svg","assets/images/home/1.svg","assets/images/home/2.svg","assets/images/home/green-bg.png","assets/images/home/mojito.svg","assets/images/home/kucoin.svg","assets/images/home/gray-bg.png","assets/images/home/cross.png","assets/images/home/left-arrow.png","assets/images/home/right-arrow.png","assets/images/home/spotbg.png","assets/images/home/spotbg2.png","assets/images/home/spotbg1.png","assets/images/home/icon1.png","assets/images/home/icon2.png","assets/images/home/icon3.png","assets/images/home/icon4.png","assets/images/home/icon5.png","assets/images/home/icon6.png","assets/images/home/icon7.png","assets/images/home/rainbow.png","constants/theme.ts","assets/images/home/focus-bg.png","assets/images/home/m-banner-bg.png","assets/images/404/404.png","assets/images/404/left-bg.png","assets/images/404/right-bg.png","components/FullLoading/index.tsx","constants/menuList.ts","components/Row/index.tsx","components/Column/index.tsx","components/Common/index.tsx","state/application/actions.ts","components/AppMenu/index.tsx","state/application/hooks.ts","components/AppHeader/index.tsx","components/Footer/index.tsx","layouts/AppLayout.tsx","components/SloganPicture/index.tsx","pages/home/components/Advantage.tsx","pages/home/components/Card.tsx","pages/home/components/Benefits.tsx","pages/home/components/Synergy.tsx","pages/home/components/Focus.tsx","pages/home/index.tsx","pages/404/404.tsx","App.tsx","reportWebVitals.ts","utils/theme.ts","state/application/reducer.ts","state/index.ts","Providers.tsx","index.tsx","utils/getThemeValue.ts","components/Text/index.tsx","components/Box.tsx","components/index.tsx","constants/index.ts","utils/animation.tsx"],"names":["SliderWrap","styled","div","SliderContent","ButtonGroup","Button","ControlBar","ArrorIcon","img","StyledCarousel","Carousel","CarouselOne","P","P1","DotGroup","Dot","active","CrossLineWrap","CrossIccon","CrossBorder","Line","CrossLine","styles","style","src","require","default","SliderTitle","h2","Slider","sliderRef","React","useState","nth","setNth","setSliding0","setSliding1","setSliding2","ref","useRef","isMobile","useResponsive","onClick","setTimeout","hidePreTitle","current","prev","hideNextTitle","next","position","initialSlide","dots","autoplay","afterChange","height","Box","marginTop","marginLeft","width","setIsModile","isTablet","setIsTablet","calc","document","body","clientWidth","documentElement","useEffect","window","addEventListener","removeEventListener","isPC","theme","colors","primary","second","logo","bridgePrimay","text","Wrap","FullLoading","MENU_LIST","name","route","hasChildren","Row","RowBetween","AutoRow","gap","justify","Column","MobileView","BrowserView","ParagraphText","span","updateBlockNumber","createAction","changeLanguage","changeTheme","changeMobileMenuShow","updateBridgeLoading","MenuWrap","SubMenu","Menu","NavTitle","NavSubTitle","NavItemWrap","NavIcon","TitleWrap","NavItem","props","useTranslation","t","i18n","dispatch","useDispatch","router","useHistory","startsWith","push","route1","KCC","EXPLORER","language","getNavRoute","open","show","bind","icon","title","whiteSpace","subTitle","AppMenu","openKeys","setOpenKeys","showSubMenu","navItem","length","MenuListDom","map","item","Item","href","target","color","top","to","activeClassName","hasGroup","subMenuList","childrens","lists","lineHeight","className","alignItems","DownOutlined","fontSize","paddingTop","groupList","groupDom","group","index","groupItemDom","groupMember","groupChild","ItemGroup","groupName","genNavList","M_MENU_CSS","zIndex","background","selectedKeys","mode","border","useMobileMenuShow","useSelector","state","application","mobileMenuShow","AppHeaderWrap","menuOpen","HeaderLeftWrap","AppHeaderContent","KCSLogoWrap","withRouter","useMemo","location","pathname","CloseOutlined","MenuOutlined","KCSLogo","Container","FooterWrap","Footer","a","KuCoin","Logo","Image","transparent","flexFlow","Text","Date","getFullYear","AppContentWrap","StartBg","AppBaseLayout","children","settings","autoResize","autoResizeMinWidth","autoResizeMaxWidth","autoResizeMinHeight","autoResizeMaxHeight","addMouseControls","addTouchControls","hideContextMenu","starCount","starBgCount","starBgColor","r","g","b","starBgColorRangeMin","starBgColorRangeMax","starColor","starColorRangeMin","starColorRangeMax","starfieldBackgroundColor","starDirection","starSpeed","starSpeedMax","starSpeedAnimationDuration","starFov","starFovMin","starFovAnimationDuration","starRotationPermission","starRotationDirection","starRotationSpeed","starRotationSpeedMax","starRotationAnimationDuration","starWarpLineLength","starWarpTunnelDiameter","starFollowMouseSensitivity","starFollowMouseXAxis","starFollowMouseYAxis","WarpDrive","clientHeight","getElementById","id","AppLayout","localStorage","getItem","PictureAWrap","PictureWrap","direction","TextWrap","Title","Description","SloganPicture","url","description","AdvantageWrap","AdvantageContent","Characteristics","image","Advantage","CharacteristicsComponent","dir","CardWrap","CardContent","StyledCard","bg","LogoIcon","Card","BuyKCSWithMojitoSwap","BuyKCSWithKuCoin","protocol","host","BenifitList","desc","BenefitWrap","Img","ListWrap","ListItem","Benefits","SynergyBg","SynergyWrap","SynergyContent","Synergy","FocusWrap","CarouselWrap","BackgroundImg","BackgroundImg1","CarouselPanel","CTitle","CDescription","CarouselList","Focus","undefined","HomePageWrap","mBannerBg","video","BannerWrap","BannerContent","KCSTitle","h1","SubTitle","StartButton","HomePage","videoLoaded","setVideoLoaded","start","console","log","offsetTop","requestAnimationFrame","callback","element","scrollTop","step","distance","Math","abs","scrollTo","scrollSmoothTo","Helmet","rel","content","property","display","justifyContent","LoadingOutlined","fontWeight","muted","controls","autoPlay","loop","playing","onReady","config","file","forceVideo","delay","P404","LeftBg","RightBg","ContentWrap","MainPic","NotFound","history","Ecosystem","lazy","Lock","KCS","App","bodyDom","getElementsByTagName","overflowY","overflowX","fallback","path","exact","component","Home","reportWebVitals","onPerfEntry","Function","then","getCLS","getFID","getFCP","getLCP","getTTFB","CACHE_KEY","createReducer","blockNumber","darkMode","bridgeLoadingVisible","bridgeLoadingStatus","builder","addCase","action","payload","chainId","max","isDark","lng","visible","status","PERSISTED_KEYS","loadedState","load","states","cache","rawCache","JSON","parse","error","getThemeCache","store","configureStore","reducer","middleware","getDefaultMiddleware","thunk","save","debounce","preloadedState","Providers","ReactDOM","render","StrictMode","getThemeValue","get","small","bold","textTransform","ellipsis","space","typography","layout","defaultProps","FULLNAME","ABBR","TEST_EXPLORER","FAUCET","DOCS_URL","GITHUB_URL","DAPP_URL","DISCORD_URL","MEDIA_URL","MEDIA_API","MAIL_SUBSCRIBE_PROXY","TWITTER","TELEGRAM","RISK_STATMENT","DISCLAIMER","FAQ","GRANTS","DISCOVER","DAO","SAFE_GNOSIS","CONTACT_LIST","app","FadeInUp","playScale","replay","always","animation","opacity","y","pointerEvents","transform"],"mappings":"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","file":"static/js/main.df765d53.chunk.js","sourcesContent":["export default __webpack_public_path__ + \"static/media/kcc-logo.d9909f20.svg\";","export default __webpack_public_path__ + \"static/media/kucoin-logo.225ca47c.svg\";","export default __webpack_public_path__ + \"static/media/f1.cad4a14d.png\";","import { Carousel } from 'antd'\nimport React, { CSSProperties } from 'react'\nimport styled from 'styled-components'\nimport { Box } from '../../../components/Box'\nimport Text from '../../../components/Text/index'\nimport { theme } from '../../../constants/theme'\nimport { Image } from '../../../components/index'\nimport { FunctionComponent } from 'react'\nimport CountUp from '../../../components/CuntUp'\nimport { useResponsive } from '../../../utils/responsive'\n\ninterface Props {}\n\nconst SliderWrap = styled.div`\n width: 100%;\n @media (max-width: 768px) {\n padding: 0 20px;\n }\n`\nconst SliderContent = styled.div`\n width: 100%;\n max-width: 1200px;\n margin: 0 auto;\n position: relative;\n`\n\nconst ButtonGroup = styled.div`\n display: flex;\n flex-flow: row nowrap;\n justify-content: center;\n align-items: center;\n width: 120px;\n height: 54px;\n background: #0c1013;\n user-select: none;\n margin-top: -20px;\n @media (max-width: 768px) {\n margin-top: -20px;\n }\n`\n\nconst Button = styled.div`\n background: transparent;\n color: #fff;\n border-radius: 0px;\n width: 60px;\n height: 54px;\n display: flex;\n flex-flow: row nowrap;\n justify-content: center;\n align-items: center;\n border: 1px solid #5b5b5b;\n cursor: pointer;\n & + & {\n border-left: none;\n }\n`\nconst ControlBar = styled.div`\n display: flex;\n flex-flow: row nowrap;\n justify-content: space-between;\n align-items: center;\n position: relative;\n right: 0px;\n top: 16px;\n z-index: 99;\n padding: 20px;\n @media (max-width: 768px) {\n left: 0;\n padding: 0px;\n top: 0px;\n }\n`\nconst ArrorIcon = styled.img`\n width: 24px;\n height: 24px;\n transition: all 0.3s ease-in-out;\n &:hover {\n transform: scale(1.1);\n }\n`\n\nconst StyledCarousel = styled(Carousel)`\n padding-bottom: 96px;\n padding-top: 0px;\n position: relative;\n @media (max-width: 768px) {\n padding-top: 0px;\n padding-bottom: 0px;\n height: auto;\n }\n`\n\nconst CarouselOne = styled.div`\n display: flex;\n width: 100%;\n flex-flow: row nowrap;\n justify-content: flex-start;\n align-items: flex-start;\n margin-top: 57px;\n @media (max-width: 768px) {\n flex-flow: column nowrap;\n margin-top: 0px;\n justify-content: flex-start;\n align-items: center;\n padding-bottom: 0px;\n }\n`\nconst P = styled.div`\n font-family: 'Barlow Light';\n font-style: normal;\n font-weight: 300;\n font-size: 16px;\n line-height: 40px;\n color: #ffffff;\n width: 100%;\n max-width: 630px;\n @media (max-width: 768px) {\n font-size: 14px;\n line-height: 32px;\n }\n`\n\nconst P1 = styled.div`\n font-family: 'Barlow Light';\n font-style: normal;\n font-weight: 300;\n font-size: 16px;\n line-height: 40px;\n color: #ffffff;\n max-width: 630px;\n @media (max-width: 768px) {\n font-size: 14px;\n line-height: 26px;\n }\n`\n\nconst DotGroup = styled.div`\n display: flex;\n width: auto;\n flex-flow: row nowrap;\n justify-content: flex-start;\n align-items: center;\n position: absolute;\n z-index: 1;\n bottom: 80px;\n left: 0;\n user-select: none;\n @media (max-width: 768px) {\n left: 100%;\n transform: translateX(-100%);\n top: 140px;\n height: 54px;\n width: 50px;\n z-index: 9999;\n }\n`\n\nconst Dot = styled.div<{ active: boolean }>`\n & + & {\n margin-left: 8px;\n }\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: ${({ active }) => {\n if (active) {\n return '#c4c4c4'\n }\n return 'transparent'\n }};\n border: ${({ active }) => {\n if (active) {\n return 'none'\n }\n return '1px solid #c4c4c4'\n }};\n`\n\nconst CrossLineWrap = styled.div`\n height: 5px;\n height: 5px;\n display: flex;\n flex-flow: row nowrap;\n width: 100%;\n justify-content: flex-start;\n align-items: center;\n`\n\nconst CrossIccon = styled.img`\n width: 5px;\n height: 5px;\n`\nconst CrossBorder = styled.div`\n background: #5b5b5b;\n height: 1px;\n flex: 1;\n`\n\nconst Line = styled.div`\n background: #ffffff;\n width: 553px;\n opacity: 0.5;\n height: 1px;\n @media (max-width: 768px) {\n display: none;\n }\n`\n\nexport const CrossLine: FunctionComponent<{ styles?: CSSProperties }> = ({ styles }) => {\n return (\n \n \n \n \n )\n}\n\nconst TitleWithNumberWrap = styled.div`\n width: 350px;\n @media (max-width: 768px) {\n width: 100%;\n }\n`\n\nconst SliderTitle = styled.h2`\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: 700;\n line-height: 64px;\n font-size: 64px;\n /* or 246% */\n display: flex;\n color: #ffffff;\n transition: all 0.1s ease-out;\n opacity: 1;\n @media (max-width: 768px) {\n font-size: 36px;\n line-height: 120px;\n }\n`\n\nconst TitleWithNumber: FunctionComponent<{ styles?: CSSProperties; title: string; amount: number }> = ({\n title,\n amount,\n styles,\n}) => {\n const { isMobile } = useResponsive()\n return (\n \n \n {title}\n \n \n \n {/* {amount} */}\n \n \n \n \n )\n}\n\nexport const Slider = ({ sliderRef }: { sliderRef: any }) => {\n const [nth, setNth] = React.useState(0)\n\n const [sliding0, setSliding0] = React.useState(false)\n const [sliding1, setSliding1] = React.useState(false)\n const [sliding2, setSliding2] = React.useState(false)\n\n const onChange = (current: number) => {\n setNth(() => current)\n }\n\n const goTo = (index: number) => {\n ref.current.goTo(index)\n }\n\n const hidePreTitle = (nth: number) => {\n if (nth === 0) {\n setSliding0(() => true)\n setTimeout(() => {\n setSliding0(() => false)\n }, 1000)\n }\n if (nth === 1) {\n setSliding1(() => true)\n setTimeout(() => {\n setSliding1(() => false)\n }, 1000)\n }\n if (nth === 2) {\n setSliding2(() => true)\n setTimeout(() => {\n setSliding2(() => false)\n }, 1000)\n }\n }\n\n const hideNextTitle = (nth: number) => {\n if (nth === 0) {\n setSliding1(() => true)\n setTimeout(() => {\n setSliding1(() => false)\n }, 200)\n }\n if (nth === 1) {\n setSliding2(() => true)\n setTimeout(() => {\n setSliding2(() => false)\n }, 200)\n }\n if (nth === 2) {\n setSliding0(() => true)\n setTimeout(() => {\n setSliding0(() => false)\n }, 200)\n }\n }\n\n const goPrev = () => {\n hidePreTitle(nth)\n ref.current.prev()\n }\n\n const goNext = () => {\n hideNextTitle(nth)\n ref.current.next()\n }\n\n const ref = React.useRef()\n\n const { isMobile } = useResponsive()\n\n return (\n \n \n \n Motivation\n \n \n \n \n \n\n {isMobile && (\n \n \n \n \n \n )}\n
\n {!isMobile && (\n \n \n \n \n \n )}\n\n \n
\n \n \n \n

\n Since the birth of Bitcoin in 2009, the crypto world has experienced a revolution that saw\n blockchain 1.0 to blockchain 2.0, and blockchain N.0. Cryptocurrency has expanded beyond the\n characteristics of a currency to include the capabilities of an application with the smart contract\n as its basis, with an endless supply of new application types. Decentralized finance, decentralized\n computing, decentralized storage, Web3.0 etc.\n

\n \n Each new bold attempt at innovation brings not only new technological improvement in this area, but\n also changes to the world. Decentralized finance advances financial inclusion, decentralized\n computing and decentralized storage allows every byte of information to be executed and recorded\n while Web3.0 redefines the relationship between productivity and production.\n \n
\n \n \n \n
\n
\n
\n \n \n \n

\n We believe that in the future, blockchain technology and its related applications will be applied on\n a large scale and profoundly change our lives, akin to the Internet today.\n

\n \n The ecosystem and the applications derived from blockchain technology will continue to benefit\n mankind. However, while blockchain technology continues to move towards mass application, there are\n still urgent problems that need to be solved. For example, more than 90% of the world's population\n has never been exposed to cryptocurrencies or the associated technology. The rapid development of\n the crypto world (such as the emergence of new technologies, new concepts and new applications) will\n also increase the threshold for new users to enter the crypto world (such as NFT transactions, Layer\n 2s and cross-chain transactions, etc.). Moreover, there remains a huge \"disconnection\" between the\n crypto world and the traditional world.\n \n
\n \n \n \n
\n
\n
\n \n \n \n \n Since its establishment in 2017, KCS ecosystem has been an observer, a participant, and a\n beneficiary within the crypto industry. For the next phase of the industry’s development, KCS team\n would like to further capitalize on the key advantages, such as our influence, platform, technology,\n talents etc., to build a self-circulating ecosystem based on KCS, thereby lowering the barriers for\n ordinary users to enter the world of the blockchain, thus allowing blockchain technology and its\n related applications to truly move from the geeks to the masses while allowing more individuals and\n organizations to make better use of blockchain technology and advance it.\n \n \n \n \n \n \n
\n
\n
\n
\n
\n )\n}\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/kcs-logo.092f6509.svg\";","import React from 'react'\nimport { useEffect } from 'react'\nexport function useResponsive() {\n const MobileWidth = 768\n const TabletWidth = 1200\n const [isMobile, setIsModile] = React.useState(false)\n const [isTablet, setIsTablet] = React.useState(false)\n const calc = () => {\n const width = document.body.clientWidth ?? document.documentElement.clientWidth\n if (width <= MobileWidth) {\n setIsModile(true)\n } else {\n setIsModile(false)\n }\n if (width > MobileWidth && width <= TabletWidth) {\n setIsTablet(true)\n } else {\n setIsTablet(false)\n }\n }\n useEffect(() => {\n calc()\n window.addEventListener('resize', calc)\n return () => {\n window.removeEventListener('resize', calc)\n }\n }, [])\n\n const m = isMobile\n const t = isTablet\n const p = !(m || t)\n\n return { isMobile: m, isTablet: t, isPC: p }\n}\n","export default __webpack_public_path__ + \"static/media/4.1d2f4f09.svg\";","export default __webpack_public_path__ + \"static/media/1.7555ab0a.svg\";","export default __webpack_public_path__ + \"static/media/2.0e7a6659.svg\";","export default __webpack_public_path__ + \"static/media/green-bg.72341137.png\";","export default __webpack_public_path__ + \"static/media/mojito.7c1950ed.svg\";","export default __webpack_public_path__ + \"static/media/kucoin.17096774.svg\";","export default __webpack_public_path__ + \"static/media/gray-bg.32876552.png\";","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/spotbg.f2d8692e.png\";","export default __webpack_public_path__ + \"static/media/spotbg2.5fccfb7a.png\";","export default __webpack_public_path__ + \"static/media/spotbg1.dab4750b.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/rainbow.8c443963.png\";","export const theme = {\n colors: {\n // primary: '#31D7A0',\n primary: '#00ce87',\n second: '#76E2B3',\n logo: '#39E2A5',\n bridgePrimay: '#31D7A0',\n text: '#fff',\n },\n}\n","export default __webpack_public_path__ + \"static/media/focus-bg.c568881e.png\";","export default __webpack_public_path__ + \"static/media/m-banner-bg.5f932016.png\";","export default __webpack_public_path__ + \"static/media/404.96442307.png\";","export default __webpack_public_path__ + \"static/media/left-bg.bab946f1.png\";","export default __webpack_public_path__ + \"static/media/right-bg.801c38d8.png\";","import { Spin } from 'antd'\nimport React from 'react'\nimport styled from 'styled-components'\nexport interface FullLoadingProps {}\n\nconst Wrap = styled.div`\n width: 100%;\n height: 100vh;\n display: flex;\n justify-content: center;\n align-items: center;\n`\n\nconst FullLoading: React.FunctionComponent = () => {\n return (\n \n \n \n )\n}\n\nexport default FullLoading\n","import { KCC } from './index'\n\nexport interface NavItemType {\n name: string\n hasChildren?: boolean\n hasGroup?: boolean\n route?: string\n childrens?: NavItemChildrenType[] | NavItemGroupType[]\n}\n\nexport interface NavItemChildrenType {\n title: string\n subTitle: string\n route: string\n icon: string\n setOpenKeys?: any\n}\n\nexport interface NavItemGroupType {\n groupName: string\n groupMember: NavItemChildrenType[]\n}\n\nexport const MENU_LIST = [\n {\n name: 'Home',\n route: '/',\n hasChildren: false,\n },\n {\n name: 'KCS Ecosystem',\n route: '/kcs-ecosystem',\n hasChildren: false,\n },\n {\n name: 'GoDAO',\n route: 'https://godao.community',\n hasChildren: false,\n },\n {\n name: 'Token Distribution',\n route: 'token-distribution',\n hasChildren: false,\n },\n\n {\n name: 'KCS Status',\n route: '/kcs',\n hasChildren: false,\n },\n]\n","import styled from 'styled-components'\n\nconst Row = styled.div`\n width: 100%;\n display: flex;\n padding: 0;\n`\n\nexport const RowBetween = styled(Row)`\n justify-content: space-between;\n`\n\nexport const RowFlat = styled.div`\n display: flex;\n align-items: flex-end;\n`\n\nexport const AutoRow = styled(Row)<{ gap?: string; justify?: string }>`\n flex-wrap: wrap;\n margin: ${({ gap }) => gap && `-${gap}`};\n justify-content: ${({ justify }) => justify && justify};\n\n & > * {\n margin: ${({ gap }) => gap} !important;\n }\n`\n\nexport const CenterRow = styled(AutoRow)`\n flex-flow: row nowrap;\n align-items: center;\n`\n\nexport const RowFixed = styled(Row)<{ gap?: string; justify?: string }>`\n width: fit-content;\n margin: ${({ gap }) => gap && `-${gap}`};\n`\n\nexport default Row\n","import styled from 'styled-components'\n\nconst Column = styled.div`\n display: flex;\n flex-direction: column;\n justify-content: flex-start;\n`\nexport const ColumnCenter = styled(Column)`\n width: 100%;\n align-items: center;\n`\n\nexport const AutoColumn = styled.div<{\n gap?: 'sm' | 'md' | 'lg' | string\n justify?: 'stretch' | 'center' | 'start' | 'end' | 'flex-start' | 'flex-end' | 'space-between'\n}>`\n display: grid;\n grid-auto-rows: auto;\n grid-row-gap: ${({ gap }) => (gap === 'sm' && '8px') || (gap === 'md' && '12px') || (gap === 'lg' && '24px') || gap};\n justify-items: ${({ justify }) => justify && justify};\n`\n\nexport default Column\n","import styled from 'styled-components'\nimport { theme } from '../../constants/theme'\n\nexport const MDivider = styled.div`\n width: calc(100% - 48px);\n height: 1px;\n margin: 0 auto;\n border-bottom: 1px solid rgba(255, 255, 255, 0.16);\n`\n\nexport const MobileView = styled.div`\n @media (max-width: 768px) {\n display: block;\n }\n @media (min-width: 769px) {\n display: none;\n }\n`\n\nexport const BrowserView = styled.div`\n @media (max-width: 768px) {\n display: none;\n }\n @media (min-width: 769px) {\n display: block;\n }\n`\n\nexport const TitleText = styled.span`\n font-family: Barlow-Demi;\n font-size: 48px;\n color: ${theme.colors.primary};\n text-align: center;\n @media (max-width: 768px) {\n width: 100%;\n font-size: 24px;\n font-weight: 500;\n line-height: 36px;\n text-align: left;\n }\n`\nexport const ParagraphText = styled.div`\n font-family: Barlow-Regular, PingFangSC-Regular, PingFang SC;\n // font-family: ftb;\n font-size: 20px;\n color: #ffffff;\n line-height: 32px;\n font-weight: 400;\n @media (max-width: 768px) {\n width: 100%;\n font-size: 12px;\n line-height: 20px;\n }\n`\n\nexport const DivideLine = styled.div`\n width: 100%;\n height: 1px;\n background: ${theme.colors.primary};\n @media (max-width: 768px) {\n width: calc(100% - 48px);\n margin: 0 24px;\n }\n`\n\nexport const ModalTitle = styled.div`\n height: 36px;\n font-size: 20px;\n font-family: Barlow;\n font-weight: 500;\n color: #000621;\n line-height: 36px;\n`\n","import { createAction } from '@reduxjs/toolkit'\n\nexport const updateBlockNumber =\n createAction<{\n chainId: number\n blockNumber: number\n }>('app/updateBlockNumber')\n\nexport const changeLanguage =\n createAction<{\n lng: string\n }>('app/changeLanguage')\n\nexport const changeTheme =\n createAction<{\n isDark: boolean\n }>('app/changeTheme')\n\nexport const changeMobileMenuShow =\n createAction<{\n show: boolean\n }>('app/changeMobileMenuShow')\n\nexport const updateBridgeLoading =\n createAction<{\n visible: boolean\n status: number\n }>('app/updateBridgeLoading')\n","import React, { CSSProperties } from 'react'\nimport styled from 'styled-components'\nimport { NavItemType, NavItemChildrenType, NavItemGroupType, MENU_LIST } from '../../constants/menuList'\nimport { NavLink, useHistory } from 'react-router-dom'\nimport { DownOutlined } from '@ant-design/icons'\nimport { useTranslation } from 'react-i18next'\n\nimport Row from '../Row/index'\nimport Column from '../Column'\nimport { RowBetween } from '../Row/index'\nimport { Menu } from 'antd'\n\nimport { theme } from '../../constants/theme'\nimport { useResponsive } from '../../utils/responsive'\nimport { BrowserView, MobileView } from '../Common'\nimport { useDispatch } from 'react-redux'\nimport { changeMobileMenuShow } from '../../state/application/actions'\nimport { KCC } from '../../constants/index'\n\nimport './index.less'\n\nexport interface AppMenuProps {\n style?: CSSProperties\n}\n\nconst MenuWrap = styled.div`\n margin-left: 40px;\n position: relative;\n z-index: 2;\n @media (max-width: 768px) {\n margin-left: 0px;\n position: absolute;\n top: 70px;\n left: 0px;\n width: 100%;\n background: rgba(0, 0, 0, 0.7);\n height: 100vh;\n }\n`\n\nconst { SubMenu } = Menu\n\nconst NavTitle = styled.span`\n font-family: Barlow;\n font-size: 16px;\n color: #fff;\n letter-spacing: 0;\n text-align: center;\n padding: 0;\n margin: 0;\n`\n\nconst NavSubTitle = styled.div`\n opacity: 0.6;\n font-family: Barlow;\n font-size: 12px;\n color: #fff;\n letter-spacing: 0;\n text-align: center;\n padding: 0;\n margin: 0;\n width: auto;\n max-width: 245px;\n word-wrap: wrap;\n white-space: wrap !important;\n text-align: left;\n`\n\nconst NavItemWrap = styled.div`\n display: flex;\n flex-flow: row nowrap;\n justify-content: flex-start;\n align-items: flex-start;\n`\n\nconst NavIcon = styled.img`\n width: 32px;\n height: auto;\n`\n\nconst TitleWrap = styled(Column)`\n justify-content: flex-start;\n align-items: flex-start;\n margin-left: 16px;\n`\n\nconst NavItem: React.FunctionComponent = (props) => {\n const { t, i18n } = useTranslation()\n const { isMobile } = useResponsive()\n\n const getNavRoute = (route: string) => {\n if (route === KCC.EXPLORER) {\n if (i18n.language === 'zh-CN') {\n return `${route}/cn`\n }\n return `${route}/en`\n }\n return route\n }\n\n const dispatch = useDispatch()\n\n const router = useHistory()\n\n const nav2Target = (route: string | undefined) => {\n if (route) {\n if (route.startsWith('/')) {\n router.push(route)\n }\n if (route.startsWith('http')) {\n const route1 = getNavRoute(route)\n window.open(route1, '_blank')\n }\n if (isMobile) {\n dispatch(changeMobileMenuShow({ show: false }))\n }\n }\n }\n\n return (\n \n \n \n {t(`${props.title}`)}\n {t(`${props.subTitle}`)}\n \n \n )\n}\n\nconst AppMenu: React.FunctionComponent = ({ style }) => {\n const { t, i18n } = useTranslation()\n\n const { isMobile } = useResponsive()\n\n const dispatch = useDispatch()\n\n const [openKeys, setOpenKeys] = React.useState([])\n\n const showSubMenu = (navItem: any) => {\n if (openKeys.length && openKeys[0] === navItem.name) {\n setOpenKeys(() => [])\n } else {\n setOpenKeys(() => [navItem.name])\n }\n }\n\n const getNavRoute = (route: string) => {\n if (route === KCC.EXPLORER) {\n if (i18n.language === 'zh-CN') {\n return `${route}/cn`\n }\n return `${route}/en`\n }\n return route\n }\n\n const genNavList = (navItem: NavItemType) => {\n const history = useHistory()\n // no children\n if (!navItem.hasChildren && navItem?.route) {\n const isHttp = navItem.route.startsWith('http')\n\n if (isHttp) {\n return (\n \n {\n dispatch(changeMobileMenuShow({ show: false }))\n }}\n // activeClassName=\"selected\"\n style={{ color: theme.colors.primary }}\n >\n {t(`${navItem.name}`)}\n \n \n )\n }\n\n return (\n \n {\n dispatch(changeMobileMenuShow({ show: false }))\n }}\n activeClassName=\"selected\"\n style={{ color: theme.colors.primary }}\n >\n {t(`${navItem.name}`)}\n \n \n )\n }\n\n // has children & not group menu\n if (navItem?.hasChildren && !navItem?.hasGroup) {\n const subMenuList = navItem.childrens as NavItemChildrenType[]\n\n const lists = subMenuList?.map((item) => {\n return (\n \n \n \n )\n })\n\n return (\n \n \n {t(`${navItem.name}`)}\n \n \n \n }\n >\n {lists}\n \n )\n }\n\n // gourp menu & has children\n if (navItem?.hasGroup) {\n const groupList = navItem.childrens as NavItemGroupType[]\n const groupDom = groupList?.map((group, index) => {\n const groupMember = group.groupMember\n\n const groupItemDom = groupMember.map((groupChild) => {\n return (\n \n \n \n )\n })\n\n return (\n {t(`${group.groupName}`)}}>\n {groupItemDom}\n {groupList.length - 1 !== index ? (\n {/* */}\n ) : null}\n \n )\n })\n return (\n \n \n {t(`${navItem.name}`)}{' '}\n \n \n \n }\n >\n {groupDom}\n \n )\n }\n\n return null\n }\n\n const MenuListDom = MENU_LIST.map((item) => {\n return genNavList(item)\n })\n\n const M_MENU_CSS: CSSProperties = isMobile\n ? {\n // border: `1px solid #fff`,\n zIndex: 999999,\n background: 'rgba(0,0,0,0.2)',\n position: 'relative',\n }\n : {}\n\n return (\n \n \n \n {MenuListDom}\n \n \n \n \n {MenuListDom}\n \n \n \n )\n}\n\nexport default AppMenu\n","import { useSelector } from 'react-redux'\n\n// import { addPopup, PopupContent, removePopup, toggleWalletModal, toggleSettingsMenu } from './actions'\nimport { AppState } from '../index'\n\nexport function useBlockNumber(): number | undefined {\n return useSelector((state: AppState) => 0)\n}\n\nexport function useDark(): boolean {\n return useSelector((state: AppState) => state.application.darkMode === true)\n}\n\nexport function useLanguage(): string {\n return useSelector((state: AppState) => state.application.language)\n}\n\nexport function useMobileMenuShow(): boolean {\n return useSelector((state: AppState) => state.application.mobileMenuShow)\n}\n\nexport function useBridgeLoading(): { visible: boolean; status: number } {\n return useSelector((state: AppState) => {\n return { visible: state.application.bridgeLoadingVisible, status: state.application.bridgeLoadingStatus }\n })\n}\n\nexport function useBridgeLoadingVisible(): boolean {\n return useSelector((state: AppState) => {\n return state.application.bridgeLoadingVisible\n })\n}\n\n// get the list of active popups\n/* export function useActivePopups(): AppState['application']['popupList'] {\n const list = useSelector((state: AppState) => state.application.popupList)\n return useMemo(() => list.filter(item => item.show), [list])\n} */\n","import React from 'react'\nimport styled from 'styled-components'\nimport AppMenu from '../AppMenu'\nimport { MobileView, BrowserView } from '../Common'\nimport { MenuOutlined, CloseOutlined } from '@ant-design/icons'\nimport { useMobileMenuShow } from '../../state/application/hooks'\nimport { useDispatch } from 'react-redux'\nimport { changeMobileMenuShow } from '../../state/application/actions'\nimport { useResponsive } from '../../utils/responsive'\nimport { withRouter, useHistory } from 'react-router-dom'\nimport { KCSLogo } from '../../constants'\nimport { Link } from 'react-router-dom'\n\nconst AppHeaderWrap = styled.div<{ menuOpen: boolean }>`\n display: flex;\n flex-flow: row nowrap;\n justify-content: center;\n align-items: center;\n height: 80px;\n width: 100%;\n max-width: 1200px;\n padding: 0;\n position: absolute;\n top: 0;\n left: 50%;\n transform: translateX(-50%);\n background: transparent;\n z-index: 99;\n @media (max-width: 768px) {\n padding: 0 24px;\n background: ${({ menuOpen }) => {\n if (menuOpen) {\n return '#000708'\n }\n return 'transparent'\n }};\n position: absolute;\n z-index: 9999;\n left: 0;\n width: 100%;\n transform: translateX(0);\n }\n`\n\nconst Box = styled.div`\n display: flex;\n align-items: center;\n`\n\nconst HeaderLeftWrap = styled.div`\n display: flex;\n flex-flow: row nowrap;\n justify-content: space-between;\n align-items: center;\n @media (min-width: 1200px) {\n padding-left: 0px;\n }\n`\n\nconst AppHeaderContent = styled(HeaderLeftWrap)<{ isMobile: boolean }>`\n justify-content: flex-start;\n width: 100%;\n`\n\nconst ButtonGroup = styled.div`\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n`\n\nconst KCSLogoWrap = styled.img`\n width: 40px;\n height: 40px;\n cursor: pointer;\n @media (max-width: 768px) {\n margin-left: 28px;\n }\n`\n\nconst AppHeader: React.FunctionComponent = (props: any) => {\n // const [mobileMenuShow, setMobileMenuShow] = React.useState(false)\n const show = useMobileMenuShow()\n const { isMobile } = useResponsive()\n\n const history = useHistory()\n\n const dispatch = useDispatch()\n\n const walletButtonShow = React.useMemo(() => {\n return props.location.pathname.startsWith('/bridge')\n }, [props.location.pathname])\n\n return (\n \n \n \n \n {!show ? (\n {\n dispatch(changeMobileMenuShow({ show: true }))\n }}\n />\n ) : (\n {\n dispatch(changeMobileMenuShow({ show: false }))\n }}\n />\n )}\n\n {show ? : null}\n \n \n \n \n {\n dispatch(changeMobileMenuShow({ show: false }))\n }}\n />\n \n \n \n \n \n \n \n )\n}\n\nexport default withRouter(AppHeader)\n","import React, { FunctionComponent, useEffect } from 'react'\nimport styled from 'styled-components'\nimport Row, { RowBetween } from '../../components/Row'\nimport { media } from '../../constants'\nimport { useResponsive } from '../../utils/responsive'\nimport Text from '../Text'\nimport { Image } from '../../components'\nimport { open } from '../../utils'\n\nexport const Container = styled.div<{ width?: string }>`\n width: ${({ width }) => width ?? '1200px'};\n margin-top: 80px;\n margin: 0 auto;\n padding:0 24px;\n @media (max-width: 768px) {\n margin-top: 0px;\n }\n`\n\nconst FooterWrap = styled.div<{ transparent?: boolean }>`\n width: 100%;\n background: #1e1e1e;\n\n display: flex;\n align-items: center;\n position: relative;\n z-index: 1;\n\n height: 80px;\n margin-top: 0px;\n @media (max-width: 768px) {\n margin-top: 0px;\n height: 140px;\n }\n`\nconst MediaItem = styled.a`\n height: 42px;\n width: 42px;\n border-radius: 20px;\n background: #ffffff33;\n display: flex;\n justify-content: center;\n align-items: center;\n margin-left: 24px;\n :hover {\n background: #b8c6d8;\n // opacity: .75;\n }\n`\n\ninterface FooterProps {\n transparent?: boolean\n}\n\nconst Footer: React.FunctionComponent = (props) => {\n const { isMobile } = useResponsive()\n\n const renderMedia = (data: any, index: any) => {\n return (\n \n {data?.app}\n \n )\n }\n\n const KCC = require('../../assets/images/kcc-logo.svg').default\n const KuCoin = require('../../assets/images/kucoin-logo.svg').default\n\n const Logo = styled(Image)`\n height: 27px;\n width: auto;\n cursor: pointer;\n `\n\n const Line = styled.div`\n height: 17px;\n width: 1px;\n background: #5b5b5b;\n margin: 0 18px;\n `\n\n return (\n \n \n \n © {new Date().getFullYear()} KCS All rights reserved\n \n \n \n \n \n \n \n \n \n \n \n \n )\n}\n\nexport default Footer\n","import { relative } from 'path'\nimport React from 'react'\nimport { FunctionComponent } from 'react'\nimport styled from 'styled-components'\nimport AppFooter from '../components/AppFooter'\nimport AppHeader from '../components/AppHeader/index'\nimport Footer from '../components/Footer'\nimport { isMobile } from 'react-device-detect'\nimport { useResponsive } from '../utils/responsive'\n\nconst AppContentWrap = styled.div`\n height: auto;\n min-height: calc(100vh - 400px);\n`\n\nconst StartBg = styled.div`\n width: 100vw;\n height: 100vh;\n position: fixed;\n top: 0;\n left: 0;\n z-index: 0;\n`\n\n// Not fullscreen mode\nconst AppBaseLayout: FunctionComponent = ({ children }) => {\n const { isMobile } = useResponsive()\n\n const settings = (width:number, height:number) => {\n return {\n width: width,\n height: height,\n autoResize: true /*enable/disable autoResize*/,\n autoResizeMinWidth: null /*set autoResize min width*/,\n autoResizeMaxWidth: null /*set autoResize max width*/,\n autoResizeMinHeight: null /*set autoResize min height*/,\n autoResizeMaxHeight: null /*set autoResize max height*/,\n addMouseControls: false /*enable/disable mouse controls*/,\n addTouchControls: true /*enable/disable touch controls*/,\n hideContextMenu: true /*enable/disable canvas context menu*/,\n starCount: 666 /*count of active/moving stars*/,\n starBgCount: 0 /*count of inactive/background stars*/,\n starBgColor: { r: 255, g: 255, b: 255 } /*background stars color*/,\n starBgColorRangeMin: 10 /*background stars color range min of starBgColor*/,\n starBgColorRangeMax: 60 /*background stars color range max of starBgColor*/,\n starColor: { r: 255, g: 255, b: 255 } /*stars color*/,\n starColorRangeMin: 10 /*stars color range min of starBgColor*/,\n starColorRangeMax: 100 /*stars color range max of starBgColor*/,\n starfieldBackgroundColor: { r: 11, g: 16, b: 19 } /*background color*/,\n starDirection: 1 /*stars moving in which direction*/,\n starSpeed: 20 /*stars moving speed*/,\n starSpeedMax: 200 /*stars moving speed max*/,\n starSpeedAnimationDuration: 6 /*time in seconds from starSpeed to starSpeedMax*/,\n starFov: 300 /*field of view*/,\n starFovMin: 200 /*field of view min*/,\n starFovAnimationDuration: 2 /*time in seconds from starFov to starFovMin*/,\n starRotationPermission: true /*enable/disable rotation*/,\n starRotationDirection: 1 /*rotation direction*/,\n starRotationSpeed: 0.0 /*rotation speed*/,\n starRotationSpeedMax: 2.0 /*rotation speed max*/,\n starRotationAnimationDuration: 2 /*time in seconds from starRotationSpeed to starRotationSpeedMax*/,\n starWarpLineLength: 7.0 /*line length*/,\n starWarpTunnelDiameter: 100 /*tunnel diameter*/,\n starFollowMouseSensitivity: 0.025 /*mouse follow sensitivity*/,\n starFollowMouseXAxis: true /*enable/disable mouse follow x axis*/,\n starFollowMouseYAxis: true /*enable/disable mouse follow y axis*/,\n }\n }\n\n React.useEffect(() => {\n // @ts-ignore\n if (WarpDrive && !isMobile && process.env.NODE_ENV==='production') {\n const width = document.body.clientWidth\n const height = document.body.clientHeight\n // @ts-ignore\n const warpdrive = new WarpDrive(document.getElementById('start-bg'), settings(width,height))\n }\n }, [settings])\n\n return (\n
\n \n
\n
\n \n {children}\n
\n
\n )\n}\n\n// App layout\nconst AppLayout: FunctionComponent = ({ children }) => {\n const isFullScreen = localStorage.getItem('FULLSCREEN_MODE')\n\n if (isFullScreen) return
{children}
\n return {children}\n}\n\nexport default AppLayout\n","import React from 'react'\nimport styled from 'styled-components'\nimport Row from '../Row'\nimport { ParagraphText } from '../Common/index'\nimport { useTranslation } from 'react-i18next'\nimport Text from '../Text/index'\nimport { FadeInUp } from '../../utils/animation'\n\nexport interface PictureProps {\n url: string\n width?: string\n title: string\n description: any\n direction: string\n}\n\nconst PictureAWrap = styled.div`\n & + & {\n margin-top: 150px;\n }\n @media (max-width: 768px) {\n & + & {\n margin-top: 60px;\n }\n }\n`\n\nconst PictureWrap = styled(Row)<{ direction: string }>`\n align-items: center;\n justify-content: ${({ direction }) => (direction === 'left' ? 'space-between' : 'space-between')};\n @media (max-width: 768px) {\n margin-bottom: 60px;\n flex-flow: column nowrap;\n }\n`\nconst ImageDescription = styled(ParagraphText)<{ direction: string }>`\n order: ${({ direction }) => (direction === 'left' ? 1 : 2)};\n width: auto;\n max-width: 480px;\n text-align: left;\n font-size: 20px;\n padding-left: ${({ direction }) => (direction === 'left' ? '0px' : '80px')};\n @media (max-width: 768px) {\n font-size: 16px;\n padding-left: ${({ direction }) => (direction === 'left' ? '0px' : '16px')};\n padding-right: ${({ direction }) => (direction === 'right' ? '0px' : '16px')};\n }\n`\n\nconst Image = styled.img<{ width: string; direction: string }>`\n width: ${({ width }) => width};\n order: ${({ direction }) => (direction === 'left' ? 2 : 1)};\n transition: 0.3s all ease-in-out;\n &:hover {\n transform: scale(1.1);\n }\n @media (max-width: 768px) {\n margin-top: 64px;\n width: 70%;\n height: auto;\n }\n`\n\nconst TextWrap = styled.div<{ direction: string }>`\n order: ${({ direction }) => (direction === 'left' ? 1 : 2)};\n`\n\nconst Title = styled.h2`\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: bold;\n font-size: 54px;\n line-height: 54px;\n /* identical to box height, or 148% */\n color: #ffffff;\n @media (max-width: 768px) {\n font-size: 32px;\n line-height: 80px;\n /* identical to box height, or 250% */\n }\n`\n\nconst Description = styled(Text)`\n font-family: 'Barlow Light';\n font-style: normal;\n font-weight: 300;\n font-size: 16px;\n line-height: 32px;\n /* or 200% */\n color: #ffffff;\n max-width: 534px;\n @media (max-width: 768px) {\n font-size: 14px;\n margin-top: 24px;\n }\n`\n\nconst Line = styled.div`\n width: 35px;\n height: 7px;\n background: #00ce87;\n margin: 24px 0;\n @media (max-width: 768px) {\n margin: 0;\n }\n`\n\nconst SloganPicture: React.FunctionComponent = (props) => {\n const { t } = useTranslation()\n return (\n \n \n \n \n {props.title}\n \n {props.description}\n \n \n \n )\n}\n\nexport default SloganPicture\n","import React from 'react'\nimport styled from 'styled-components'\nimport SloganPicture from '../../../components/SloganPicture'\nimport { useResponsive } from '../../../utils/responsive'\nimport { FadeInUp } from '../../../utils/animation'\nimport { marginTop } from 'styled-system'\n\ninterface Props {}\n\nconst AdvantageWrap = styled.div`\n width: 100%;\n padding: 0 20px;\n z-index: 1;\n position: relative;\n`\n\nconst AdvantageContent = styled.div`\n width: 100%;\n max-width: 1200px;\n margin: 0 auto;\n padding-top: 120px;\n padding-bottom: 120px;\n @media (max-width: 768px) {\n padding-top: 40px;\n padding-bottom: 0px;\n }\n`\n\nconst Characteristics = [\n {\n title: 'Deflationary Mechanism',\n description: (\n
\n KCS Deflationary Mechanism: On the one hand, the KuCoin trading platform will regularly repurchase KCS from the\n secondary market with part of the platform’s revenue and burn this part of KCS. This means that there will be\n less and less KCS supply in the market. In the past 4 years, KuCoin has burned tens of millions of KCS, worth\n hundreds of millions of dollars.
\n
\n On the other hand, in order to better support the development of the KCS ecosystem, we plan to introduce\n EIP1559, the KCC fee mechanism of base fee + priority fee. Among them, the basic fuel fee will be dynamically\n adjusted according to the congestion of the KCC network and will lead to the continuous destruction and\n deflation of KCS. The priority gas fee will go to the corresponding miner node. In this way, both developers\n and KCS holders will benefit from this.\n
\n
\n ),\n image: require('../../../assets/images/home/4.svg').default,\n },\n {\n title: 'Reward Mechanism',\n description:\n \"KCS Incentive Model: The KuCoin platform will repurchase KCS with part of its fees and distribute it to users according to the user's KCS position on a daily basis. In the past 4 years, the KuCoin trading platform has cumulatively distributed tens of millions of KCS incentives, which is worth hundreds of millions of dollars.\",\n image: require('../../../assets/images/home/1.svg').default,\n },\n {\n title: 'Fee Discounts',\n description:\n 'KuCoin uses the size of a user’s KCS holdings as the criterion for determining users’ VIP level. The more KCS held, the higher the VIP level, the more benefits and the greater the fee discounts. In addition, users can also use KCS to pay for transaction fees on the KuCoin platform and enjoy discounts.',\n image: require('../../../assets/images/home/2.svg').default,\n },\n // {\n // title: 'KCS Burning',\n // description:\n // 'KuCoin regularly performs KCS buyback and burns from the secondary market with a portion of platform revenues to gradually reduce the supply of KCS on the market. Over the past four years, KuCoin has burned tens of millions of KCS, worth hundreds of millions of dollars. ',\n // image: require('../../../assets/images/home/3.svg').default,\n // },\n]\n\nexport const Advantage = (props: Props) => {\n const { isMobile } = useResponsive()\n const CharacteristicsComponent = Characteristics.map((item, index) => {\n let dir = ''\n if (isMobile) {\n dir = index % 2 === 1 ? 'left' : 'left'\n } else {\n dir = index % 2 === 0 ? 'left' : 'right'\n }\n return (\n \n )\n })\n\n return (\n \n {CharacteristicsComponent}\n \n )\n}\n","import React from 'react'\nimport styled from 'styled-components'\nimport Text from '../../../components/Text/index'\nimport { open } from '../../../utils'\nimport { FadeInUp } from '../../../utils/animation'\nimport { BuyKCSWithMojitoSwap, BuyKCSWithKuCoin } from '../../../constants/index'\nimport { useResponsive } from '../../../utils/responsive'\n\ninterface Props {}\n\nconst CardWrap = styled.div`\n width: 100%;\n position: relative;\n z-index: 1;\n @media (max-width: 768px) {\n padding: 0 20px;\n }\n`\n\nconst CardContent = styled.div`\n width: 100%;\n max-width: 1200px;\n margin: 0 auto;\n padding-top: 120px;\n padding-bottom: 120px;\n display: flex;\n flex-flow: row nowrap;\n justify-content: space-between;\n align-items: center;\n @media (max-width: 768px) {\n flex-flow: column nowrap;\n padding-top: 120px;\n padding-bottom: 80px;\n }\n`\n\nconst StyledCard = styled.div<{ bg: string }>`\n width: 584px;\n height: 240px;\n border-radius: 12px;\n padding: 40px;\n background: url(${({ bg }) => bg}) bottom right no-repeat, #293238;\n background-size: 34% 100%;\n transition: all 0.3s ease-in-out;\n &:hover {\n background-size: 50% 120%;\n }\n @media (max-width: 768px) {\n width: 100%;\n height: 400px;\n background-size: 50% 50%;\n & + & {\n margin-top: 20px;\n }\n &:hover {\n background-size: 60% 60%;\n }\n }\n`\n\nconst Button = styled.a`\n height: 54px;\n margin-top: 26px;\n display: flex;\n flex-flow: row nowrap;\n justify-content: center;\n align-items: center;\n width: 180px;\n font-family: Barlow;\n font-style: normal;\n font-weight: 500;\n font-size: 20px;\n /* identical to box height, or 160% */\n /* 亮色主题文字/标题 l 正文 */\n color: #00142a;\n background: linear-gradient(90deg, #ffffff -2.45%, #ffffff 101.4%);\n cursor: pointer;\n font-weight: bold;\n &:hover {\n color: #00142a;\n }\n @media (max-width: 768px) {\n width: 100%;\n }\n`\n\nconst Title = styled(Text)`\n font-family: Barlow;\n font-style: normal;\n font-weight: 500;\n font-size: 28px;\n line-height: 40px;\n max-width: 382px;\n /* or 143% */\n color: #ffffff;\n @media (max-width: 768px) {\n max-width: 280px;\n }\n`\n\nconst Row = styled.div`\n display: flex;\n flex-flow: row nowrap;\n justify-content: flex-start;\n align-items: center;\n @media (max-width: 768px) {\n flex-flow: column nowrap;\n }\n`\n\nconst LogoIcon = styled.img`\n width: 30px;\n height: 30px;\n`\n\nexport const Card = (props: Props) => {\n const { isMobile } = useResponsive()\n return (\n \n \n \n \n Get the Cryptocurrency That Powers the KCC Ecosystem\n \n {\n // window.$KcSensors.trackClick(['KcsHomeDex', '1'])\n // }}\n >\n \n \n Buy with Dex\n \n \n {\n // window.$KcSensors.trackClick(['KcsHomeCex', '1'])\n // }}\n >\n \n \n Buy with Cex\n \n \n \n \n\n \n Get Our White Paper\n {\n // window.$KcSensors.trackClick(['KcsHomeDownload', '1'])\n // }}\n >\n Download Now\n \n \n \n \n \n )\n}\n","import React from 'react'\nimport { isMobile } from 'react-device-detect'\nimport styled from 'styled-components'\n\nexport const TitleText = styled.span`\n font-family: Barlow;\n font-size: 48px;\n color: #fff;\n text-align: center;\n @media (max-width: 768px) {\n width: 100%;\n font-size: 24px;\n font-weight: 500;\n line-height: 36px;\n text-align: left;\n }\n`\n\ninterface Props {}\n\nconst BenifitList = [\n {\n icon: require('../../../assets/images/home/icon1.png').default,\n desc: 'Pledge KCS to obtain rights to new projects and other benefits in the ecosystem',\n },\n {\n icon: require('../../../assets/images/home/icon2.png').default,\n desc: 'Part of on-chain transaction fees (gas fee)',\n },\n {\n icon: require('../../../assets/images/home/icon3.png').default,\n desc: 'Loan products',\n },\n {\n icon: require('../../../assets/images/home/icon4.png').default,\n desc: 'Game, NFT service and transaction fees',\n },\n {\n icon: require('../../../assets/images/home/icon5.png').default,\n desc: 'Resource consumption fees such as storage and bandwidth',\n },\n {\n icon: require('../../../assets/images/home/icon6.png').default,\n desc: 'Investment income of ecological projects',\n },\n {\n icon: require('../../../assets/images/home/icon7.png').default,\n desc: 'Liquidity gains',\n },\n]\n\nconst BenefitWrap = styled.div`\n max-width: 1200px;\n margin: 0 auto;\n display: flex;\n flex-flow: column nowrap;\n justify-content: flex-start;\n position: relative;\n z-index: 1;\n align-items: center;\n @media (max-width: 768px) {\n padding: 0 20px;\n }\n`\n\nconst Img = styled.img`\n width: 86px;\n height: 86px;\n`\nconst Line = styled.div`\n width: 360px;\n background: #fff;\n height: 1px;\n margin: 32px 0;\n opacity: 0.7;\n @media (max-width: 768px) {\n width: 100%;\n margin: 32px 0 16px 0;\n }\n`\nconst Text = styled.div`\n font-family: 'URWDIN-Regular';\n font-style: normal;\n font-weight: normal;\n font-size: 16px;\n line-height: 28px;\n /* or 175% */\n color: #ffffff;\n max-width: 360px;\n`\n\nconst ListWrap = styled.div`\n max-width: 880px;\n margin-top: 120px;\n display: flex;\n flex-flow: row wrap;\n justify-content: space-between;\n align-items: flex-start;\n @media (max-width: 768px) {\n margin-top: 60px;\n }\n`\n\nconst ListItem = styled.div`\n display: flex;\n flex-flow: column nowrap;\n justify-content: flex-start;\n align-items: flex-start;\n margin-bottom: 80px;\n &:nth-child(even) {\n margin-left: 160px;\n }\n @media (max-width: 768px) {\n &:nth-child(even) {\n margin-left: 0px;\n }\n margin-bottom: 50px;\n padding: 0 20px;\n justify-content: center;\n align-items: flex-start;\n width: 100%;\n }\n`\n\nexport default function Benefits() {\n return (\n \n \n {BenifitList.map((item, index) => {\n return (\n \n \n \n {item.desc}\n \n )\n })}\n \n \n )\n}\n","import React from 'react'\nimport styled from 'styled-components'\nimport Benefits from './Benefits'\nimport { FadeInUp } from '../../../utils/animation'\n\ninterface Props {}\n\nconst SynergyBg = require('../../../assets/images/home/rainbow.png').default\n\nconst SynergyWrap = styled.div`\n width: 100%;\n position: relative;\n z-index: 1;\n background: url(${SynergyBg}) top center no-repeat;\n @media (max-width: 768px) {\n height: auto;\n /* background-size: 250% 100%; */\n }\n`\n\nconst SynergyContent = styled.div`\n width: 100%;\n max-width: 1200px;\n margin: 0 auto;\n`\n\nconst Title = styled.h2`\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: 700;\n font-size: 64px;\n line-height: 80px;\n /* identical to box height, or 246% */\n text-align: center;\n color: #ffffff;\n padding-top: 170px;\n @media (max-width: 768px) {\n font-size: 40px;\n line-height: 80px;\n padding: 0 20px;\n padding-top: 150px;\n line-height: 1.5;\n }\n`\n\nconst Description = styled.div`\n font-family: Barlow;\n font-style: normal;\n font-weight: 300;\n font-size: 16px;\n line-height: 32px;\n /* or 200% */\n text-align: center;\n color: #ffffff;\n max-width: 1116px;\n margin: 40px auto;\n @media (max-width: 768px) {\n padding: 0 20px;\n margin-top: 40px;\n }\n`\n\nexport const Synergy = (props: Props) => {\n return (\n \n \n \n KCS Value Capture and Deflationary Mechanism \n \n The KCC ecosystem will aggregate various types of projects and platforms, including DeFi, NFT+, games, Web\n 3.0-related application projects, etc. KCS will support and integrate with the entire ecosystem and continue\n to capture value from the following aspects, including the right to participate in the services of related\n products and the repurchase of KCS for the benefit of projects in the ecosystem.\n \n \n \n \n \n )\n}\n","import { Carousel } from 'antd'\nimport React from 'react'\nimport styled from 'styled-components'\nimport { Image } from '../../../components'\nimport Text from '../../../components/Text/index'\n\ninterface Props {}\n\nconst FocusWrap = styled.div`\n width: 100%;\n background: #0c1013;\n padding-bottom: 0px;\n`\n\nconst FocusContent = styled.div`\n width: 100%;\n max-width: 1200px;\n margin: 0 auto;\n padding-top: 0px;\n padding-bottom: 0px;\n @media (max-width: 768px) {\n padding-bottom: 32px;\n }\n`\n\nconst Title = styled.div`\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: bold;\n font-size: 36px;\n line-height: 158px;\n /* identical to box height, or 111% */\n color: #ffffff;\n @media (max-width: 768px) {\n font-size: 28px;\n line-height: 40px;\n text-align: center;\n padding: 0 20px;\n }\n`\n\nconst CarouselWrap = styled.div`\n width: 100%;\n background: #000;\n position: relative;\n @media (max-width: 768px) {\n margin-bottom: 0px;\n }\n`\n\nconst BackgroundImg = require('../../../assets/images/foundation/f1.png').default\nconst BackgroundImg1 = require('../../../assets/images/home/focus-bg.png').default\n\nconst StyledCarousel = styled.div`\n width: 100%;\n max-width: 1250px;\n position: relative;\n margin: 0 auto;\n background: url(${BackgroundImg}) 0px 0px no-repeat;\n background-size: auto 120%;\n @media (max-width: 768px) {\n background: url(${BackgroundImg1}) right 400px no-repeat;\n }\n`\n\nconst CarouselPanel = styled.div`\n position: relative;\n display: flex;\n flex-flow: row nowrap;\n width: 100%;\n flex-flow: row nowrap;\n justify-content: flex-end;\n align-items: center;\n height: 690px;\n @media (max-width: 768px) {\n height: auto;\n left: 0px;\n top: 0px;\n padding: 24px;\n padding-bottom: 50px;\n justify-content: flex-start;\n align-items: flex-start;\n }\n`\n\nconst TextWrap = styled.div`\n display: flex;\n flex-flow: column nowrap;\n margin-right: 100px;\n max-width: 460px;\n position: relatIve;\n z-index: 1;\n @media (max-width: 768px) {\n width: 100%;\n margin-right: 0px;\n }\n`\nconst CTitle = styled.h2`\n width: auto;\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: bold;\n font-size: 54px;\n line-height: 36px;\n /* identical to box height, or 100% */\n color: #ffffff;\n padding-right: 40px;\n @media (max-width: 768px) {\n width: 100%;\n font-size: 32px;\n padding-right: 0px;\n word-break: keep-all;\n white-space: nowrap;\n margin-bottom:0px ;\n }\n`\n\nconst Line = styled.div<{ width?: string }>`\n width: ${({ width }) => {\n if (width) {\n return width\n }\n return '269px'\n }};\n height: 1px;\n background: #5b5b5b;\n margin-top: 24px;\n @media (max-width: 768px) {\n width: 269px;\n }\n`\n\nconst CDescription = styled.div`\n font-family: Barlow;\n font-style: normal;\n font-weight: 300;\n font-size: 16px;\n line-height: 30px;\n /* or 200% */\n color: #ffffff;\n margin-top: 24px;\n @media (max-width: 768px) {\n width: 100%;\n }\n`\n\nconst RowLineWrap = styled.div`\n position: absolute;\n display: flex;\n flex-flow: column nowrap;\n justify-content: space-between;\n align-items: center;\n right: calc((100vw - 1200px) / 2 + 10px);\n top: 40px;\n height: 516px;\n width: 1px;\n @media (max-width: 768px) {\n right: 36px;\n }\n`\n\nconst RowLine = styled.div`\n width: 1px;\n height: 180px;\n background: #5b5b5b;\n @media (max-width: 768px) {\n position: relative;\n z-index: 9999;\n }\n`\n\nconst DotGroup = styled.div`\n display: flex;\n width: auto;\n flex-flow: column nowrap;\n justify-content: flex-start;\n align-items: center;\n position: relative;\n z-index: 9999;\n`\n\nconst Dot = styled.div<{ active: boolean }>`\n margin: 4px;\n width: 8px;\n height: 8px;\n border-radius: 50%;\n cursor: pointer;\n background: ${({ active }) => {\n if (active) {\n return '#c4c4c4'\n }\n return 'transparent'\n }};\n border: ${({ active }) => {\n if (active) {\n return 'none'\n }\n return '1px solid #c4c4c4'\n }};\n`\n\nconst CarouselList = [\n {\n title: 'Outlook',\n description:\n 'With further development of the KuCoin exchange ecosystem and the gradual improvement of the KCC ecosystem, we have built an ecosystem based on blockchain technology around KCS with self-circulating value. Not only has it provided a payment system that can serve hundreds of millions of users around the world, but it has also accelerated the arrival of the Web 3.0 era. Moreover, the spectrum of diversified application scenarios based on the KCS ecosystem also improves the ease of use of blockchain technology and its related applications, lowers the threshold for ordinary users to enter the crypto world, and truly pushes blockchain technology from the geeks to the masses. In the process of promoting the fusion of the crypto world and the traditional world, it will also open the door to the future of the digital world for us.',\n icon: require('../../../assets/images/foundation/f1.png').default,\n },\n]\n\nexport const Focus = (props: Props) => {\n const ref = React.useRef()\n\n const [nth, setNth] = React.useState(1)\n\n const onChange = (current: number) => {\n setNth(() => current)\n }\n const goTo = (index: number) => {\n ref.current.goTo(index)\n }\n\n return (\n \n \n {/* \n \n \n */}\n \n {CarouselList.map((item, index) => {\n return (\n
\n \n {/* \n \n */}\n \n {item.title}\n \n {item.description}\n \n \n
\n )\n })}\n
\n
\n
\n )\n}\n","import React from 'react'\nimport styled from 'styled-components'\nimport { theme } from '../../constants/theme'\nimport { Advantage } from './components/Advantage'\nimport { Card } from './components/Card'\nimport { Slider } from './components/Slider'\nimport { Synergy } from './components/Synergy'\nimport { FadeInUp } from '../../utils/animation'\nimport { LoadingOutlined } from '@ant-design/icons'\nimport { Box } from '../../components/Box'\nimport ReactPlayer from 'react-player'\nimport Helmet from 'react-helmet'\nimport { useResponsive } from '../../utils/responsive'\nimport { Focus } from './components/Focus'\n\ninterface Props {}\n\nconst HomePageWrap = styled.div`\n width: 100%;\n height: 100%;\n min-height: 100vh;\n background: #0c1013;\n`\n\nconst BannerImage = styled.video`\n width: 100%;\n height: auto;\n position: relative;\n top: 0;\n left: 0;\n z-index: 0;\n`\n\nconst mBannerBg = require('../../assets/images/home/m-banner-bg.png').default\n\nconst BannerWrap = styled.div`\n height: auto;\n position: relative;\n min-height: 600px;\n z-index: 3;\n @media (max-width: 768px) {\n background: url(${mBannerBg}) top center no-repeat;\n background-size: 100% 100%;\n }\n`\n\nconst BannerContent = styled.div`\n width: 100%;\n max-width: 1200px;\n position: absolute;\n z-index: 999;\n top: 26%;\n left: calc((100vw - 1200px) / 2);\n @media (max-width: 1200px) {\n left: 10px;\n }\n @media (max-width: 768px) {\n top: 84px;\n position: relative;\n display: flex;\n flex-flow: column nowrap;\n justify-content: center;\n align-items: center;\n left: 0px;\n padding-top: 80px;\n }\n`\n\nconst KCSTitle = styled.h1`\n font-family: 'Barlow Bold';\n font-style: normal;\n font-weight: 700;\n font-size: 90px;\n line-height: 60px;\n /* identical to box height, or 111% */\n color: ${theme.colors.primary};\n @media (max-width: 768px) {\n text-align: center;\n }\n`\nconst SubTitle = styled.div`\n font-family: Barlow;\n font-style: normal;\n font-weight: 400;\n font-size: 36px;\n line-height: 60px;\n /* identical to box height, or 167% */\n color: #ffffff;\n @media (max-width: 768px) {\n font-size: 24px;\n text-align: center;\n }\n`\n\nconst StartButton = styled.div`\n width: 200px;\n height: 64px;\n border: 1px solid #ffffff;\n box-sizing: border-box;\n display: flex;\n justify-content: center;\n align-items: center;\n font-size: 24px;\n font-family: Barlow;\n font-style: normal;\n font-weight: normal;\n color: #fff;\n margin-top: 32px;\n cursor: pointer;\n transition: all ease-in-out 0.2s;\n &:hover {\n font-size: 25px;\n }\n @media (max-width: 768px) {\n margin: 32px auto;\n }\n`\n\nconst scrollSmoothTo = function (position: any) {\n if (!window.requestAnimationFrame) {\n ;(window as any).requestAnimationFrame = function (callback: any, element: any): any {\n return setTimeout(callback, 17)\n }\n }\n\n let scrollTop = document.documentElement.scrollTop || document.body.scrollTop\n\n const step = function () {\n const distance = position - scrollTop\n scrollTop = scrollTop + distance / 5\n if (Math.abs(distance) < 1) {\n window.scrollTo(0, position)\n } else {\n window.scrollTo(0, scrollTop)\n requestAnimationFrame(step)\n }\n }\n step()\n}\n\nexport const HomePage = () => {\n const { isMobile } = useResponsive()\n\n const ref = React.useRef(null)\n\n const sliderRef = React.useRef(null)\n\n const [videoLoaded, setVideoLoaded] = React.useState(false)\n\n const loadedHandle = () => {\n console.log('console.log')\n setVideoLoaded(() => true)\n }\n\n const videoUrl = '/banner.mp4'\n\n const start = () => {\n console.log(sliderRef.current.offsetTop)\n scrollSmoothTo(sliderRef.current.offsetTop)\n }\n\n return (\n \n \n KCS Token | KCS Value | KCS Foundation\n \n \n \n \n \n \n\n \n \n \n \n \n {/* Banner */}\n \n {!videoLoaded && !isMobile && (\n \n \n \n )}\n\n {!isMobile && (\n \n )}\n \n \n KCS\n A blockchain-based value\n self-circulation ecosystem\n start()}>Start Now\n \n \n \n \n \n \n \n \n \n )\n}\n\nexport default HomePage\n","import React from 'react'\nimport { useHistory } from 'react-router-dom'\nimport styled from 'styled-components'\nimport { Image } from '../../components'\n\nconst P404 = require('../../assets/images/404/404.png').default\nconst LeftBg = require('../../assets/images/404/left-bg.png').default\nconst RightBg = require('../../assets/images/404/right-bg.png').default\n\nconst Wrap = styled.div`\n display: flex;\n flex-flow: column nowrap;\n justify-content: center;\n align-items: center;\n width: 100%;\n height: calc(100vh - 80px);\n background: #0e1114;\n position:relative;\n z-index:3 ;\n @media (max-width: 768px) {\n height: calc(100vh - 140px);\n padding:0 24px;\n }\n`\nconst ContentWrap = styled.div`\n display: flex;\n flex-flow: column nowrap;\n justify-content: center;\n align-items: center;\n width: 100%;\n max-width: 1300px;\n height: 700px;\n margin: 0 auto;\n background: url(${LeftBg}) 0px 500px no-repeat, url(${RightBg}) right 0px no-repeat;\n @media (max-width: 768px) {\n height: 500px;\n background: url(${LeftBg}) 0px 300px no-repeat, url(${RightBg}) right 0px no-repeat;\n }\n`\nconst MainPic = styled.div`\n display: flex;\n flex-flow: column nowrap;\n justify-content: center;\n align-items: center;\n width: 480px;\n height: auto;\n @media (max-width: 768px) {\n width: 80%;\n height: auto;\n }\n`\n\nconst Button = styled.div`\n width: 140px;\n height: 48px;\n border: 1px solid #00ce87;\n box-sizing: border-box;\n font-family: 'Barlow';\n font-style: normal;\n font-weight: 500;\n font-size: 16px;\n line-height: 32px;\n /* identical to box height, or 200% */\n display: flex;\n align-items: center;\n justify-content: center;\n color: #00ce87;\n margin-top: 80px;\n cursor: pointer;\n position:relative ;\n z-index:2 ;\n transition:all 0.3s ease-in-out ;\n &:hover {\n background: #00ce87;\n color:#fff;\n }\n`\n\nconst NotFound: React.FunctionComponent = () => {\n\n const history = useHistory()\n\n return (\n \n \n \n \n \n \n \n \n )\n}\n\nexport default NotFound\n","import React, { lazy, Suspense } from 'react'\nimport { Redirect, Route, Switch } from 'react-router-dom'\nimport FullLoading from './components/FullLoading'\nimport AppLayout from './layouts/AppLayout'\nimport Home from './pages/home/'\nimport NotFound from './pages/404/404'\n\n// const Foundation = lazy(() => import(/* webpackChunkName:'Foundation' */ './pages/foundation/index'))\nconst Ecosystem = lazy(() => import(/* webpackChunkName:'Ecosystem' */ './pages/ecosystem/index'))\nconst Lock = lazy(() => import(/* webpackChunkName:'Lock' */ './pages/lock/index'))\nconst KCS = lazy(() => import(/* webpackChunkName:'KCS' */ './pages/kcs/index'))\n\nimport './App.less'\nimport { useMobileMenuShow } from './state/application/hooks'\nimport { useResponsive } from './utils/responsive'\nimport styled from 'styled-components'\n\nexport default function App() {\n const show = useMobileMenuShow()\n const { isMobile } = useResponsive()\n\n // initSensor()\n\n // React.useEffect(() => {\n // registerPage()\n // }, [])\n\n React.useEffect(() => {\n const bodyDom = document.getElementsByTagName('body')[0]\n if (show && isMobile) {\n bodyDom.style.overflowY = 'hidden'\n bodyDom.style.overflowX = 'hidden'\n } else {\n bodyDom.style.overflowY = 'auto'\n bodyDom.style.overflowX = 'auto'\n }\n }, [show, isMobile])\n\n return (\n }>\n \n \n \n \n \n \n \n \n \n \n \n \n \n )\n}\n","import { ReportHandler } from 'web-vitals'\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry)\n getFID(onPerfEntry)\n getFCP(onPerfEntry)\n getLCP(onPerfEntry)\n getTTFB(onPerfEntry)\n })\n }\n}\n\nexport default reportWebVitals\n","const CACHE_KEY = 'IS_DARK'\n\nexport function getThemeCache(): boolean | null {\n let cache = null\n try {\n const rawCache = localStorage.getItem(CACHE_KEY)\n if (rawCache) {\n cache = JSON.parse(rawCache)\n }\n } catch (error) {\n console.error(error)\n }\n\n return cache\n}\n\nexport function setThemeCache(isDark: boolean) {\n try {\n localStorage.setItem(CACHE_KEY, JSON.stringify(isDark))\n } catch (error) {\n console.error(error)\n }\n}\n","import { createReducer } from '@reduxjs/toolkit'\nimport { updateBlockNumber, changeLanguage, changeTheme, changeMobileMenuShow, updateBridgeLoading } from './actions'\n\nexport interface ApplicationState {\n blockNumber: { [chainId: number]: number }\n darkMode: boolean\n language: string\n mobileMenuShow: boolean\n bridgeLoadingVisible: boolean\n bridgeLoadingStatus: number\n}\n\nconst initialState: ApplicationState = {\n blockNumber: {},\n darkMode: false,\n language: 'en',\n mobileMenuShow: false,\n bridgeLoadingVisible: false,\n bridgeLoadingStatus: 0,\n}\n\nexport default createReducer(initialState, (builder) =>\n builder\n .addCase(updateBlockNumber, (state, action) => {\n const { chainId, blockNumber } = action.payload\n if (typeof state.blockNumber[chainId] !== 'number') {\n state.blockNumber[chainId] = blockNumber\n } else {\n state.blockNumber[chainId] = Math.max(blockNumber, state.blockNumber[chainId])\n }\n })\n .addCase(changeTheme, (state, action) => {\n const { isDark } = action.payload\n if (isDark) {\n state.darkMode = true\n } else {\n state.darkMode = false\n }\n })\n .addCase(changeLanguage, (state, action) => {\n const { lng } = action.payload\n if (lng) {\n state.language = lng\n } else {\n state.language = 'en'\n }\n })\n .addCase(changeMobileMenuShow, (state, action) => {\n const { show } = action.payload\n state.mobileMenuShow = show\n })\n .addCase(updateBridgeLoading, (state, action) => {\n const { visible, status } = action.payload\n state.bridgeLoadingStatus = status\n state.bridgeLoadingVisible = visible\n })\n)\n","import { configureStore, getDefaultMiddleware } from '@reduxjs/toolkit'\nimport { load, save } from 'redux-localstorage-simple'\nimport { getThemeCache } from '../utils/theme'\n\nimport application from './application/reducer'\n\ntype ModuleTypes = 'application' | 'wallet' | 'bridge'\n\ntype MergedState = {\n [key in ModuleTypes]: {\n [key: string]: any\n }\n}\nconst PERSISTED_KEYS: string[] = ['application']\nconst loadedState = load({ states: PERSISTED_KEYS }) as any\n\nif (loadedState.application) {\n loadedState.application = { ...loadedState.application, darkMode: getThemeCache() }\n}\n\nconst store = configureStore({\n reducer: {\n application,\n },\n middleware: [...getDefaultMiddleware({ thunk: false }), save({ states: PERSISTED_KEYS, debounce: 500 })],\n preloadedState: loadedState,\n})\n\nexport default store\n\nexport type AppState = ReturnType\nexport type AppDispatch = typeof store.dispatch\n","import React, { FunctionComponent } from 'react'\nimport { ConfigProvider } from 'antd'\nimport { Provider } from 'react-redux'\nimport store from './state'\nimport { HashRouter, BrowserRouter } from 'react-router-dom'\n\n\nconst Providers: FunctionComponent = ({ children }) => {\n return (\n \n \n {children}\n \n \n )\n}\n\nexport default Providers\n","import React from 'react'\nimport ReactDOM from 'react-dom'\nimport App from './App'\nimport reportWebVitals from './reportWebVitals'\n\nimport Providers from './Providers'\n\nimport 'normalize.css'\nimport './index.less'\n\nReactDOM.render(\n \n \n \n \n ,\n document.getElementById('root')\n)\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals()\n","import get from 'lodash/get'\nimport { DefaultTheme } from 'styled-components'\n\nconst getThemeValue =\n (path: string, fallback?: string | number) =>\n (theme: DefaultTheme): string =>\n get(theme, path, fallback)\n\nexport default getThemeValue\n","import styled, { DefaultTheme } from 'styled-components'\nimport getThemeValue from '../../utils/getThemeValue'\nimport { space, typography, layout } from 'styled-system'\nimport { TextProps } from './types'\n\ninterface ThemedProps extends TextProps {\n theme: DefaultTheme\n}\n\nconst getColor = ({ color, theme }: ThemedProps) => {\n return getThemeValue(`colors.${color}`, color)(theme)\n}\n\nconst getFontSize = ({ fontSize, small }: TextProps) => {\n return small ? '14px' : fontSize || '16px'\n}\n\nconst Text = styled.div`\n color: ${getColor};\n font-size: ${getFontSize};\n font-weight: ${({ bold }) => (bold ? 600 : 400)};\n line-height: 1.5;\n ${({ textTransform }) => textTransform && `text-transform: ${textTransform};`}\n ${({ ellipsis }) =>\n ellipsis &&\n `white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;`}\n\n ${space}\n ${typography}\n ${layout}\n font-family:Barlow;\n`\n\nText.defaultProps = {\n color: 'text',\n small: false,\n ellipsis: false,\n}\n\nexport default Text\n","import React, { FunctionComponent } from 'react'\nimport styled from 'styled-components'\nexport const Box = styled.div``\n","import React, { FunctionComponent } from 'react'\nimport styled from 'styled-components'\nexport const Image = styled.img``\n","export const KCC = {\n FULLNAME: 'KuCoin Community Chain',\n ABBR: 'KCC',\n EXPLORER: 'https://explorer.kcc.io',\n TEST_EXPLORER: 'https://scan-testnet.kcc.network',\n FAUCET: 'https://faucet-testnet.kcc.network/',\n DOCS_URL: 'https://docs.kcc.io/#/',\n GITHUB_URL: 'https://github.com/kcc-community',\n DAPP_URL: 'https://github.com/kcc-community/awesome-dApps',\n DISCORD_URL: 'https://discord.com/invite/H5ucJydSyd',\n MEDIA_URL: 'https://kccofficial.medium.com',\n MEDIA_API: 'https://api.rss2json.com/v1/api.json?rss_url=https://medium.com/feed/@kccofficial',\n MAIL_SUBSCRIBE_PROXY: 'https://mailsubscribe.kcc.io/mailchimp-subscribe',\n TWITTER: 'https://twitter.com/KCCOfficialTW',\n TELEGRAM: 'https://t.me/KCCOfficialEnglishCommunity',\n RISK_STATMENT: 'id=risk-statement',\n DISCLAIMER: 'id=disclaimers',\n FAQ: 'id=faq',\n GRANTS: 'https://github.com/kcc-community/kcc-grants',\n DISCOVER: 'https://discover.kcc.io',\n DAO: 'https://godao.community',\n SAFE_GNOSIS: 'https://safe.kcc.io',\n CONTACT_LIST: [\n {\n app: 'Twitter',\n icon: require('../assets/images/Icons/app/twitter-logo@2x.png').default,\n route: 'https://twitter.com/KCCOfficialTW',\n },\n {\n app: 'Telegram',\n icon: require('../assets/images/Icons/app/telegram-logo@2x.png').default,\n route: 'https://t.me/KCCOfficialEnglishCommunity',\n },\n {\n app: 'Github',\n icon: require('../assets/images/Icons/app/github-logo@2x.png').default,\n route: 'https://github.com/kcc-community',\n },\n {\n app: 'Discord',\n icon: require('../assets/images/Icons/app/discord-logo@2x.png').default,\n route: 'https://discord.com/invite/H5ucJydSyd',\n },\n ],\n}\n\nexport const media = [\n {\n app: 'Twitter',\n icon: require('../assets/images/Icons/twitter-logo@2x.png').default,\n hover: require('../assets/images/Icons/twitter-logo-hover@2x.png').default,\n route: 'https://twitter.com/KCCOfficialTW',\n },\n {\n app: 'Telegram',\n icon: require('../assets/images/Icons/telegram-logo@2x.png').default,\n hover: require('../assets/images/Icons/telegram-logo-hover@2x.png').default,\n route: 'https://t.me/KCCOfficialEnglishCommunity',\n },\n {\n app: 'Medium',\n icon: require('../assets/images/Icons/medium-logo@2x.png').default,\n hover: require('../assets/images/Icons/medium-logo-hover@2x.png').default,\n route: 'https://kccofficial.medium.com/',\n },\n {\n app: 'Discord',\n icon: require('../assets/images/Icons/discord-logo@2x.png').default,\n hover: require('../assets/images/Icons/discord-logo-hover@2x.png').default,\n route: 'https://discord.com/invite/H5ucJydSyd',\n },\n]\n\nexport const APP = {\n TOKEN_INFO_CDN: 'https://cdn.jsdelivr.net/gh/kucoin-community-chain/tokens-info@main/icons/',\n}\n\nexport const KCSLogo = require('../assets/images/kcs-logo.svg').default\nexport const KCCLogoWithText = require('../assets/images/kcc-logo.svg').default\nexport const KucoinLogoWithText = require('../assets/images/kucoin-logo.svg').default\n\nexport const BuyKCSWithMojitoSwap = 'https://app.mojitoswap.finance/swap'\nexport const BuyKCSWithKuCoin = 'https://trade.kucoin.com/trade/KCS-USDT'\n","import React, { ReactNode } from 'react'\nimport { OverPack } from 'rc-scroll-anim'\nimport TweenOne from 'rc-tween-one'\n\ninterface FadeUpProps {\n children?: ReactNode\n delay?: number\n onClick?: () => void\n playScale?: number\n}\n\nexport function FadeInUp({ children, playScale = 0.1, delay = 100, onClick }: FadeUpProps) {\n return (\n // @ts-ignore\n \n \n
\n {children}\n
\n
\n
\n )\n}\n\nexport function FadeInLeft({ children, playScale = 0.5 }: { children: any; playScale: number }) {\n return (\n \n \n {children}\n \n \n )\n}\n\nexport function FadeInRight({ children, playScale = 0.2 }: { children: any; playScale: number }) {\n return (\n \n \n {children}\n \n \n )\n}\n"],"sourceRoot":""}