{"version":3,"sources":["utils/check.ts","utils/setting.ts","components/CardV2/index.tsx","components/SearchBar/index.tsx","components/Loading/index.tsx","utils/api.tsx","components/TagSelector/index.tsx","components/GithubLink/index.tsx","utils/theme.ts","components/DarkSwitch/index.tsx","utils/serachEngine.ts","components/Content/index.tsx","utils/tools.ts","App.tsx","serviceWorker.ts","index.tsx"],"names":["getLogoUrl","url","startsWith","setJumpTarget","target","window","localStorage","setItem","getJumpTarget","getItem","Card","title","des","logo","catelog","onClick","index","isSearching","el","useMemo","src","alt","split","pop","includes","type","showNumIndex","href","undefined","rel","className","SearchBar","props","onKeyDown","ev","code","test","key","document","getElementById","focus","useEffect","addEventListener","removeEventListener","id","placeholder","value","searchString","onChange","v","trim","setSearchText","Loading","FetchList","a","axios","get","raw","data","catelogs","push","forEach","item","name","tools","setting","hideAdmin","desc","jumpTarget","TagSelector","tags","onTagChange","currTag","renderTags","useCallback","map","each","GithubLink","viewBox","version","xmlns","width","height","d","decodeTheme","t","Date","getHours","night","matchMedia","matches","decodeAuto","applyTheme","source","disableLog","querySelector","classList","toggle","console","log","initTheme","theme","DarkSwitch","showGithub","useState","setTheme","current","useRef","hasInit","currentTimer","timer","clearInterval","realTheme","setInterval","useLayoutEffect","iTheme","lightIcon","fill","darkIcon","autoIcon","generateSearchEngineCard","searchBaidu","hide","searchBing","searchGoogle","q","mutiSearch","s","toLowerCase","rawInclude","pinYinInlcude","Boolean","pinyin","match","Content","setData","loading","setLoading","setCurrTag","setSearchString","val","setVal","filteredDataRef","hideGithub","loadData","r","tagInLocalStorage","resetSearch","notSetTag","handleSetSearch","fn","delay","time","args","clearTimeout","setTimeout","apply","useDebounce","filteredData","localResult","filter","onKeyEnter","renderCardsV2","thisTarget","toggleJumpTarget","cards","length","open","ctrlKey","metaKey","num","Number","isNaN","preventDefault","Helmet","charSet","favicon","tag","App","isLocalhost","location","hostname","registerValidSW","swUrl","config","navigator","serviceWorker","register","then","registration","onupdatefound","installingWorker","installing","onstatechange","state","controller","onUpdate","onSuccess","catch","error","ReactDOM","render","URL","process","origin","fetch","response","contentType","headers","status","indexOf","ready","unregister","reload","checkValidServiceWorker"],"mappings":"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","file":"static/js/main.460fa0ed.chunk.js","sourcesContent":["export const isLogin = () => {\n return localStorage.getItem('_token') ? true : false\n}\n\nexport const getLogoUrl = (url: string) => {\n if (url.startsWith('http')) {\n return `/api/img?url=${url}`\n } else {\n return url;\n }\n} ","type JumpTarget = 'blank' | 'self';\n\nexport const toggleJumpTarget = () => {\n const thisTarget = getJumpTarget();\n if (!thisTarget) {\n setJumpTarget('blank');\n }\n if (thisTarget === 'blank') {\n setJumpTarget('self');\n } else {\n setJumpTarget('blank');\n }\n\n}\n\nconst setJumpTarget = (target: JumpTarget) => {\n window.localStorage.setItem('jumpTarget', target);\n}\n\nexport const getJumpTarget = () => {\n return window.localStorage.getItem('jumpTarget') as JumpTarget;\n}","import { useMemo } from \"react\";\r\nimport \"./index.css\";\r\nimport { getLogoUrl } from \"../../utils/check\";\r\nimport { getJumpTarget } from \"../../utils/setting\";\r\nconst Card = ({ title, url, des, logo, catelog, onClick, index, isSearching }) => {\r\n const el = useMemo(() => {\r\n if (url === \"admin\") {\r\n return {title}\r\n } else {\r\n if (logo.split(\".\").pop().includes(\"svg\")) {\r\n return \r\n } else {\r\n return {title}\r\n }\r\n }\r\n }, [logo, title, url])\r\n const showNumIndex = index < 10 && isSearching;\r\n return (\r\n {\r\n onClick();\r\n }}\r\n target={getJumpTarget() === \"blank\" ? \"_blank\" : \"_self\"}\r\n rel=\"noreferrer\"\r\n className=\"card-box\"\r\n >\r\n {showNumIndex && {index + 1}}\r\n
\r\n
\r\n {el}\r\n {/* {url === \"admin\" ? (\r\n {title}\r\n ) : (\r\n {title}\r\n )} */}\r\n
\r\n
\r\n
\r\n {title}\r\n {catelog}\r\n
\r\n
{des}
\r\n
\r\n
\r\n \r\n );\r\n};\r\n\r\nexport default Card;\r\n","import { useEffect } from \"react\";\r\nimport \"./index.css\";\r\n// import { useState } from 'react';\r\n\r\ninterface SearchBarProps {\r\n setSearchText: (t: string) => void;\r\n searchString: string;\r\n}\r\nconst SearchBar = (props: SearchBarProps) => {\r\n const onKeyDown = (ev) => {\r\n const reg = /[a-zA-Z0-9]|[\\u4e00-\\u9fa5]/g;\r\n if (ev.code === \"Enter\" || reg.test(ev.key)) {\r\n const el = document.getElementById(\"search-bar\");\r\n if (el) {\r\n el.focus();\r\n }\r\n }\r\n }\r\n useEffect(() => {\r\n document.addEventListener(\"keydown\", onKeyDown);\r\n return () => {\r\n document.removeEventListener(\"keydown\", onKeyDown)\r\n }\r\n })\r\n return (\r\n
\r\n
\r\n {\r\n const v = ev.target.value.trim();\r\n props.setSearchText(v);\r\n }}\r\n >\r\n
\r\n
\r\n );\r\n};\r\n\r\nexport default SearchBar;\r\n","import \"./index.css\";\nexport const Loading = (props: any) => {\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n );\n};\n","import axios from \"axios\";\r\nimport { getJumpTarget } from \"./setting\";\r\nconst baseUrl = \"/api/\";\r\n// const baseUrl = \"https://tools.mereith.com/api/\";\r\n\r\nconst selfJumpIcon = ``\r\nconst blankJumpIcon = ``\r\nexport const FetchList = async () => {\r\n const { data: raw } = await axios.get(baseUrl);\r\n const { data } = raw;\r\n // 获取分类\r\n const catelogs = [];\r\n catelogs.push(\"全部工具\")\r\n data.catelogs.forEach(item => {\r\n catelogs.push(item.name)\r\n })\r\n data.tools.forEach(item => {\r\n if (!catelogs.includes(item.catelog)) {\r\n catelogs.push(item.catelog);\r\n }\r\n });\r\n if (!data.setting?.hideAdmin) {\r\n data.tools.push({\r\n id: 999999999999,\r\n catelog: \"管理后台\",\r\n name: \"本站管理后台\",\r\n desc: \"本导航站的管理后台哦\",\r\n url: \"admin\",\r\n logo: ``,\r\n })\r\n }\r\n\r\n const jumpTarget = getJumpTarget();\r\n\r\n data.tools.push({\r\n id: 999099999978,\r\n catelogs: \"偏好设置\",\r\n name: jumpTarget === \"blank\" ? \"新建窗口\" : \"原地跳转\",\r\n desc: `点击切换跳转方式`,\r\n url: \"toggleJumpTarget\",\r\n logo: jumpTarget === \"blank\" ? blankJumpIcon : selfJumpIcon\r\n })\r\n\r\n data.catelogs = catelogs;\r\n return data;\r\n};\r\nexport default FetchList;\r\n\r\n\r\n","import \"./index.css\";\nimport { useCallback } from \"react\";\ninterface TagSelectorProps {\n tags: any;\n onTagChange: (newTag: string) => void;\n currTag: string;\n}\nconst TagSelector = (props: TagSelectorProps) => {\n const { tags = [\"all\"], onTagChange, currTag } = props;\n const renderTags = useCallback(() => {\n const originTags = tags.map((each) => {\n return (\n {\n onTagChange(each);\n }}\n >\n {each}\n \n );\n });\n return originTags;\n }, [tags, onTagChange, currTag]);\n return (\n
\n
\n {renderTags()}\n
\n
\n );\n};\n\nexport default TagSelector;\n","import \"./index.css\";\n\nconst GithubLink = () => {\n return (\n
\n \n \n \n
\n );\n};\nexport default GithubLink;\n","export function decodeAuto() {\n const d = new Date().getHours();\n const night = d > 18 || d < 8;\n if (typeof window == \"undefined\") {\n if (night) {\n return \"auto-dark\";\n } else {\n return \"auto-light\";\n }\n }\n if (night || window.matchMedia(\"(prefers-color-scheme: dark)\").matches) {\n return \"auto-dark\";\n } else {\n return \"auto-light\";\n }\n}\nexport const decodeTheme = (t: \"auto\" | \"light\" | \"dark\") => {\n if (t === \"auto\") {\n return decodeAuto();\n } else {\n return t;\n }\n};\nexport const applyTheme = (t: string, source: string, disableLog: boolean) => {\n if (t.includes(\"light\")) {\n const bodyEl = document.querySelector(\"body\")!;\n bodyEl.classList.toggle(\"dark-mode\", false);\n if (!disableLog) {\n console.log(`[Apply Theme][${source}] ${t}`);\n }\n } else {\n const bodyEl = document.querySelector(\"body\")!;\n bodyEl.classList.toggle(\"dark-mode\", true);\n if (!disableLog) {\n console.log(`[Apply Theme][${source}] ${t}`);\n }\n }\n};\nexport const initTheme = () => {\n if (typeof localStorage == \"undefined\") {\n return \"auto\";\n }\n // 2种情况: 1. 自动。 2.手动\n if (!(\"theme\" in localStorage) || localStorage.theme === \"auto\") {\n return \"auto\";\n } else {\n if (localStorage.theme === \"dark\") {\n return \"dark\";\n } else {\n return \"light\";\n }\n }\n};\n","import { useEffect, useLayoutEffect, useRef, useState } from \"react\";\nimport { applyTheme, decodeTheme, initTheme } from \"../../utils/theme\";\nimport \"./index.css\";\n\nconst DarkSwitch = ({ showGithub }: { showGithub: boolean }) => {\n const [theme, setTheme] = useState(initTheme());\n const { current } = useRef({ hasInit: false });\n const { current: currentTimer } = useRef({ timer: null });\n\n useEffect(() => {\n if (currentTimer.timer) {\n clearInterval(currentTimer.timer);\n currentTimer.timer = null;\n }\n localStorage.setItem(\"theme\", theme)\n const realTheme = decodeTheme(theme as any);\n applyTheme(realTheme, 'setTheme', true);\n if (realTheme.includes(\"auto\")) {\n currentTimer.timer = setInterval(() => {\n const realTheme = decodeTheme(\"auto\");\n applyTheme(realTheme, \"autoThemeTimer\", true);\n }, 10000);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [theme])\n\n\n useLayoutEffect(() => {\n if (!current.hasInit) {\n current.hasInit = true;\n if (!!!localStorage.getItem(\"theme\")) {\n // 第一次用默认的\n setTheme(\"auto\");\n } else {\n const iTheme = initTheme();\n setTheme(iTheme);\n }\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const lightIcon = (\n \n );\n const darkIcon = (\n \n )\n const autoIcon = (\n \n )\n const handleSwitch = () => {\n if (theme === \"light\") {\n setTheme(\"dark\");\n } else if (theme === \"dark\") {\n setTheme(\"auto\");\n } else {\n setTheme(\"light\");\n }\n };\n return (\n
\n {theme === \"light\" ? lightIcon : theme === \"dark\" ? darkIcon : autoIcon}\n
\n );\n};\nexport default DarkSwitch;\n","export const generateSearchEngineCard = (searchString: string) => {\n if (!searchString.trim()) return [];\n const result = [\n {\n name: \"使用百度搜索\",\n url: searchBaidu(searchString),\n desc: `在百度中搜索 「${searchString}」`,\n id: 8800880001,\n logo: \"baidu.ico\",\n hide: false\n },\n {\n name: \"使用 Bing 搜索\",\n url: searchBing(searchString),\n desc: `在 Bing 中搜索 「${searchString}」`,\n id: 8800880002,\n logo: \"bing.ico\",\n hide: false\n },\n {\n name: \"使用 Google 搜索\",\n url: searchGoogle(searchString),\n desc: `在 Google 中搜索 「${searchString}」`,\n id: 8800880003,\n logo: \"google.ico\",\n hide: false\n }\n ]\n return result;\n}\n\n\n\nconst searchBaidu = (q: string) => {\n return `https://www.baidu.com/s?wd=${q}`\n}\n\nconst searchGoogle = (q: string) => {\n return `https://www.google.com/search?q=${q}`\n}\n\nconst searchBing = (q: string) => {\n return `https://cn.bing.com/search?q=${q}`\n}","import \"./index.css\";\r\nimport CardV2 from \"../CardV2\";\r\nimport SearchBar from \"../SearchBar\";\r\nimport { Loading } from \"../Loading\";\r\nimport { Helmet } from \"react-helmet\";\r\nimport { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\r\nimport FetchList from \"../../utils/api\";\r\nimport TagSelector from \"../TagSelector\";\r\nimport { useDebounce } from \"../../utils/tools\";\r\nimport pinyin from \"pinyin-match\";\r\nimport GithubLink from \"../GithubLink\";\r\nimport DarkSwitch from \"../DarkSwitch\";\r\nimport { isLogin } from \"../../utils/check\";\r\nimport { generateSearchEngineCard } from \"../../utils/serachEngine\";\r\nimport { toggleJumpTarget } from \"../../utils/setting\";\r\n\r\nconst mutiSearch = (s, t) => {\r\n const source = (s as string).toLowerCase();\r\n const target = t.toLowerCase();\r\n const rawInclude = source.includes(target);\r\n const pinYinInlcude = Boolean(pinyin.match(source, target));\r\n return rawInclude || pinYinInlcude;\r\n};\r\n\r\nconst Content = (props: any) => {\r\n const [data, setData] = useState({});\r\n const [loading, setLoading] = useState(true);\r\n const [currTag, setCurrTag] = useState(\"全部工具\");\r\n const [searchString, setSearchString] = useState(\"\");\r\n const [val, setVal] = useState(\"\");\r\n\r\n const filteredDataRef = useRef([]);\r\n\r\n const showGithub = useMemo(() => {\r\n const hide = data?.setting?.hideGithub === true\r\n return !hide;\r\n }, [data])\r\n const loadData = useCallback(async () => {\r\n try {\r\n setLoading(true);\r\n const r = await FetchList();\r\n setData(r);\r\n const tagInLocalStorage = window.localStorage.getItem(\"tag\");\r\n if (tagInLocalStorage && tagInLocalStorage !== \"\") {\r\n if (r?.catelogs && r?.catelogs.includes(tagInLocalStorage)) {\r\n setCurrTag(tagInLocalStorage);\r\n }\r\n }\r\n } catch (e) {\r\n console.log(e);\r\n } finally {\r\n setLoading(false);\r\n }\r\n }, [setData, setLoading, setCurrTag]);\r\n useEffect(() => {\r\n loadData();\r\n }, [loadData]);\r\n\r\n const handleSetCurrTag = (tag: string) => {\r\n setCurrTag(tag);\r\n // 管理后台不记录了\r\n if (tag !== \"管理后台\") {\r\n window.localStorage.setItem(\"tag\", tag);\r\n }\r\n resetSearch(true);\r\n };\r\n\r\n const resetSearch = (notSetTag?: boolean) => {\r\n setVal(\"\");\r\n setSearchString(\"\");\r\n const tagInLocalStorage = window.localStorage.getItem(\"tag\");\r\n if (!notSetTag && tagInLocalStorage && tagInLocalStorage !== \"\" && tagInLocalStorage !== \"管理后台\") {\r\n setCurrTag(tagInLocalStorage);\r\n }\r\n };\r\n\r\n const handleSetSearch = useDebounce((val: string) => {\r\n if (val !== \"\" && val) {\r\n setCurrTag(\"全部工具\");\r\n setSearchString(val);\r\n } else {\r\n resetSearch();\r\n }\r\n }, 500);\r\n\r\n\r\n\r\n const filteredData = useMemo(() => {\r\n if (data.tools) {\r\n const localResult = data.tools\r\n .filter((item: any) => {\r\n const hide = item.hide;\r\n if (!hide) return true;\r\n if (hide && isLogin()) return false;\r\n return false;\r\n })\r\n .filter((item: any) => {\r\n if (currTag === \"全部工具\") {\r\n return true;\r\n }\r\n return item.catelog === currTag;\r\n })\r\n .filter((item: any) => {\r\n if (searchString === \"\") {\r\n return true;\r\n }\r\n return (\r\n mutiSearch(item.name, searchString) ||\r\n mutiSearch(item.desc, searchString) ||\r\n mutiSearch(item.url, searchString)\r\n );\r\n });\r\n return [...localResult, ...generateSearchEngineCard(searchString)]\r\n } else {\r\n return [...generateSearchEngineCard(searchString)];\r\n }\r\n }, [data, currTag, searchString]);\r\n\r\n useEffect(() => {\r\n filteredDataRef.current = filteredData\r\n }, [filteredData])\r\n\r\n useEffect(() => {\r\n if (searchString.trim() === \"\") {\r\n document.removeEventListener(\"keydown\", onKeyEnter);\r\n } else {\r\n document.addEventListener(\"keydown\", onKeyEnter);\r\n }\r\n return () => {\r\n document.removeEventListener(\"keydown\", onKeyEnter);\r\n }\r\n // eslint-disable-next-line\r\n }, [searchString])\r\n\r\n const renderCardsV2 = useCallback(() => {\r\n return filteredData.map((item, index) => {\r\n return (\r\n {\r\n resetSearch();\r\n if (item.url === \"toggleJumpTarget\") {\r\n toggleJumpTarget();\r\n loadData();\r\n }\r\n }}\r\n />\r\n );\r\n });\r\n // eslint-disable-next-line\r\n }, [filteredData, searchString]);\r\n\r\n const onKeyEnter = (ev: KeyboardEvent) => {\r\n const cards = filteredDataRef.current;\r\n if (ev.code === \"Enter\") {\r\n if (cards && cards.length) {\r\n window.open(cards[0]?.url, \"_blank\");\r\n resetSearch();\r\n }\r\n }\r\n // 如果按了数字键 + ctrl/meta,打开对应的卡片\r\n if (ev.ctrlKey || ev.metaKey) {\r\n const num = Number(ev.key);\r\n if (isNaN(num)) return;\r\n ev.preventDefault()\r\n const index = Number(ev.key) - 1;\r\n if (index >= 0 && index < cards.length) {\r\n window.open(cards[index]?.url, \"_blank\");\r\n resetSearch();\r\n }\r\n }\r\n\r\n };\r\n\r\n return (\r\n <>\r\n \r\n \r\n \r\n {data?.setting?.title ?? \"Van Nav\"}\r\n \r\n
\r\n
\r\n {\r\n setVal(t);\r\n handleSetSearch(t);\r\n }}\r\n />\r\n \r\n
\r\n
\r\n
\r\n
\r\n {loading ? : renderCardsV2()}\r\n
\r\n
\r\n {showGithub && }\r\n \r\n \r\n );\r\n};\r\n\r\nexport default Content;\r\n","import { useRef, useCallback } from \"react\";\n\nexport const useDebounce = (fn: any, delay: number) => {\n const { current } = useRef<{ time: any }>({ time: null });\n return useCallback(\n (...args: any[]) => {\n if (current.time) {\n clearTimeout(current.time);\n current.time = null;\n }\n current.time = setTimeout(() => {\n fn.apply(this, args);\n clearTimeout(current.time);\n current.time = null;\n }, delay);\n },\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [current, delay]\n );\n};","import \"./App.css\";\r\nimport Content from \"./components/Content\";\r\nfunction App() {\r\n return (\r\n
\r\n
\r\n \r\n
\r\n
\r\n );\r\n}\r\n\r\nexport default App;\r\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.1/8 is considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl)\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister();\n });\n }\n}\n","import React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport './index.css';\r\nimport App from './App';\r\nimport * as serviceWorker from \"./serviceWorker\"\r\n// import reportWebVitals from './reportWebVitals';\r\n\r\nconsole.log(\"欢迎使用 Van Nav 项目\")\r\nconsole.log(\"项目地址: https://github.com/mereithhh/van-nav\")\r\n\r\n\r\nReactDOM.render(\r\n \r\n,\r\n document.getElementById('root')\r\n);\r\n\r\nserviceWorker.register(null);"],"sourceRoot":""}