1 line
36 KiB
JSON
1 line
36 KiB
JSON
{"ast":null,"code":"var _jsxFileName = \"/home/magh/Documents/landing_page_experimental/src/ResultsPage.jsx\",\n _s = $RefreshSig$();\nimport React, { useEffect, useState } from 'react';\nimport { useLocation, Link } from 'react-router-dom';\nimport './App.css';\nimport { jsxDEV as _jsxDEV, Fragment as _Fragment } from \"react/jsx-dev-runtime\";\nfunction ResultsPage() {\n _s();\n const [results, setResults] = useState([]);\n const [videoResults, setVideoResults] = useState([]);\n const [loading, setLoading] = useState(true);\n const [videoLoading, setVideoLoading] = useState(false);\n const [currentPage, setCurrentPage] = useState(1);\n const [viewMode, setViewMode] = useState('web'); // \"web\" for normal results, \"video\" for Peertube results\n const [visitedLinks, setVisitedLinks] = useState(() => {\n const stored = localStorage.getItem('visitedLinks');\n return stored ? JSON.parse(stored) : [];\n });\n const resultsPerPage = 10;\n const location = useLocation();\n const queryParams = new URLSearchParams(location.search);\n const query = queryParams.get('q') || '';\n\n // Get the \"cat\" parameter and split it into an array.\n // If only one category is chosen, this array has length 1.\n const catParam = queryParams.get('cat') || 'science';\n const categories = catParam.split(',').filter(Boolean);\n const primaryCategory = categories[0] || 'science';\n\n // Determine if there is a multi-category search.\n const multiCategorySearch = categories.length > 1;\n\n // For header purposes, we always use the primary category.\n const headerCategory = primaryCategory;\n\n // Maps: these remain as originally configured.\n const sourceMap = {\n science: 'https://science.tsugutsugugo.com/yacysearch.json',\n philosophy: 'https://sophos.tsugutsugugo.com/yacysearch.json',\n tech: 'https://tech.tsugutsugugo.com/yacysearch.json',\n discover: 'https://web.tsugutsugugo.com/yacysearch.json'\n };\n const headerMap = {\n science: '/header.png',\n philosophy: '/header_philosophy.png',\n tech: '/header_tech.png',\n discover: '/header_web.png',\n multi: '/header_multi.png'\n };\n\n // For single category searches, we use these mappings as given.\n const headerBgMap = {\n science: '#f8f8f8',\n philosophy: '#ffffff',\n tech: '#ffffff',\n discover: '#ffffff',\n multi: '#ffffff'\n };\n const appBgMap = {\n science: '#fcfcff',\n philosophy: '#ffffff',\n tech: '#ffffff',\n discover: '#ffffff',\n multi: '#ffffff'\n };\n\n // ---- Paging logic ----\n // When multiple categories are selected, use the round-robin algorithm with limits:\n // 1 category: 9 pages, 2 categories: 4 pages each, 3 categories: 3 pages each, 4+ categories: 2 pages each.\n let pagesPerCat;\n if (multiCategorySearch) {\n if (categories.length === 2) {\n pagesPerCat = 4;\n } else if (categories.length === 3) {\n pagesPerCat = 3;\n } else {\n pagesPerCat = 2;\n }\n }\n\n // For multi-category, total pages is categories.length * pagesPerCat.\n const totalPagesMulti = multiCategorySearch ? categories.length * pagesPerCat : null;\n\n // For multi-category search, determine which category and which page within that category to fetch:\n let fetchCategory, pageForCategory;\n if (multiCategorySearch) {\n const numCats = categories.length;\n const categoryIndex = (currentPage - 1) % numCats;\n pageForCategory = Math.floor((currentPage - 1) / numCats) + 1;\n fetchCategory = categories[categoryIndex];\n }\n useEffect(() => {\n const fetchResults = async () => {\n setLoading(true);\n // If exactly one category is selected, use the original algorithm.\n if (!multiCategorySearch) {\n let allResults = [];\n for (let page = 0; page < 10; page++) {\n const startRecord = page * resultsPerPage;\n try {\n const response = await fetch(`${sourceMap[primaryCategory]}?query=${encodeURIComponent(query)}&resource=global&urlmaskfilter=.*&prefermaskfilter=&nav=all&maximumRecords=${resultsPerPage}&startRecord=${startRecord}`);\n if (!response.ok) continue;\n const data = await response.json();\n allResults = [...allResults, ...(data.channels[0].items || [])];\n } catch (error) {\n console.error(\"Error fetching results:\", error);\n }\n }\n setResults(allResults);\n } else {\n // Multiple categories: use round-robin paging limited by pagesPerCat.\n const startRecord = (pageForCategory - 1) * resultsPerPage;\n try {\n const response = await fetch(`${sourceMap[fetchCategory]}?query=${encodeURIComponent(query)}&resource=global&urlmaskfilter=.*&prefermaskfilter=&nav=all&maximumRecords=${resultsPerPage}&startRecord=${startRecord}`);\n if (response.ok) {\n var _data$channels$;\n const data = await response.json();\n setResults(((_data$channels$ = data.channels[0]) === null || _data$channels$ === void 0 ? void 0 : _data$channels$.items) || []);\n } else {\n setResults([]);\n }\n } catch (error) {\n console.error(\"Error fetching results:\", error);\n setResults([]);\n }\n }\n setLoading(false);\n };\n if (viewMode === \"web\") {\n fetchResults();\n }\n }, [query, primaryCategory, multiCategorySearch, fetchCategory, pageForCategory, viewMode, sourceMap]);\n\n // Video results fetching remains unchanged.\n const fetchVideoResults = async () => {\n setVideoLoading(true);\n try {\n const response = await fetch(`https://stream.tsugutsugugo.com/api/v1/videos?search=${encodeURIComponent(query)}`);\n if (!response.ok) {\n throw new Error(`Video API responded with status ${response.status}`);\n }\n const data = await response.json();\n setVideoResults(data.data || []);\n } catch (error) {\n console.error(\"Error fetching video results:\", error);\n } finally {\n setVideoLoading(false);\n }\n };\n\n // Compute total pages.\n // For multi, use totalPagesMulti; for single, use the computed aggregation.\n const computedPages = multiCategorySearch ? totalPagesMulti : Math.ceil(results.length / resultsPerPage);\n const paginate = page => setCurrentPage(page);\n const handleLinkClick = url => {\n setVisitedLinks(prev => {\n if (!prev.includes(url)) {\n const newVisited = [...prev, url];\n localStorage.setItem(\"visitedLinks\", JSON.stringify(newVisited));\n return newVisited;\n }\n return prev;\n });\n };\n return /*#__PURE__*/_jsxDEV(_Fragment, {\n children: /*#__PURE__*/_jsxDEV(\"div\", {\n className: \"App results-page\",\n style: {\n backgroundColor: appBgMap[headerCategory]\n },\n children: [/*#__PURE__*/_jsxDEV(\"header\", {\n className: \"header-bar\",\n style: {\n backgroundColor: headerBgMap[headerCategory]\n },\n children: /*#__PURE__*/_jsxDEV(Link, {\n to: \"/\",\n children: /*#__PURE__*/_jsxDEV(\"img\", {\n src: headerMap[headerCategory],\n alt: `${headerCategory} Header`\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 187,\n columnNumber: 13\n }, this)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 186,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 185,\n columnNumber: 9\n }, this), /*#__PURE__*/_jsxDEV(\"main\", {\n className: \"main-content\",\n children: [/*#__PURE__*/_jsxDEV(\"div\", {\n id: \"tagline\",\n children: [\"Search Results for \", /*#__PURE__*/_jsxDEV(\"strong\", {\n children: query\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 192,\n columnNumber: 32\n }, this), \",\", \" \", viewMode === \"web\" ? /*#__PURE__*/_jsxDEV(\"span\", {\n className: \"link-switch\",\n onClick: async () => {\n await fetchVideoResults();\n setViewMode(\"video\");\n },\n children: \"browse videos\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 194,\n columnNumber: 15\n }, this) : /*#__PURE__*/_jsxDEV(\"span\", {\n className: \"link-switch\",\n onClick: () => setViewMode(\"web\"),\n children: \"browse web results\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 204,\n columnNumber: 15\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 191,\n columnNumber: 11\n }, this), viewMode === \"web\" ? loading ? /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"Loading results...\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 212,\n columnNumber: 15\n }, this) : results.length > 0 ? /*#__PURE__*/_jsxDEV(_Fragment, {\n children: [/*#__PURE__*/_jsxDEV(\"ul\", {\n className: \"results-list\",\n children: results.slice(window.innerWidth < 600 ? 0 : (currentPage - 1) * resultsPerPage, window.innerWidth < 600 ? results.length : currentPage * resultsPerPage).map((item, idx) => /*#__PURE__*/_jsxDEV(\"li\", {\n className: \"result-item\",\n children: [/*#__PURE__*/_jsxDEV(\"a\", {\n href: item.link,\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n onClick: () => handleLinkClick(item.link),\n className: `result-title ${visitedLinks.includes(item.link) ? \"visited-link\" : \"\"}`,\n children: item.title\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 225,\n columnNumber: 23\n }, this), /*#__PURE__*/_jsxDEV(\"p\", {\n dangerouslySetInnerHTML: {\n __html: item.description\n }\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 236,\n columnNumber: 23\n }, this), /*#__PURE__*/_jsxDEV(\"a\", {\n href: `https://web.archive.org/web/*/${item.link}`,\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n className: \"cache-link\",\n children: \"Cache\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 237,\n columnNumber: 23\n }, this)]\n }, idx, true, {\n fileName: _jsxFileName,\n lineNumber: 224,\n columnNumber: 21\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 215,\n columnNumber: 17\n }, this), window.innerWidth >= 600 && computedPages > 1 && /*#__PURE__*/_jsxDEV(\"div\", {\n className: \"pagination\",\n children: [...Array(computedPages)].map((_, idx) => /*#__PURE__*/_jsxDEV(\"button\", {\n onClick: () => paginate(idx + 1),\n className: `page-btn ${currentPage === idx + 1 ? \"active-page\" : \"\"}`,\n children: idx + 1\n }, idx, false, {\n fileName: _jsxFileName,\n lineNumber: 251,\n columnNumber: 23\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 249,\n columnNumber: 19\n }, this)]\n }, void 0, true) : /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"No search results found.\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 265,\n columnNumber: 15\n }, this) : videoLoading ? /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"Loading videos...\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 268,\n columnNumber: 13\n }, this) : videoResults && videoResults.length > 0 ? /*#__PURE__*/_jsxDEV(\"ul\", {\n className: \"results-list\",\n children: videoResults.map((video, idx) => /*#__PURE__*/_jsxDEV(\"li\", {\n className: \"result-item\",\n children: [/*#__PURE__*/_jsxDEV(\"a\", {\n href: video.url,\n target: \"_blank\",\n rel: \"noopener noreferrer\",\n className: \"result-title\",\n children: video.name\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 273,\n columnNumber: 19\n }, this), /*#__PURE__*/_jsxDEV(\"p\", {\n dangerouslySetInnerHTML: {\n __html: video.description\n }\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 281,\n columnNumber: 19\n }, this)]\n }, idx, true, {\n fileName: _jsxFileName,\n lineNumber: 272,\n columnNumber: 17\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 270,\n columnNumber: 13\n }, this) : /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"No video results found.\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 286,\n columnNumber: 13\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 190,\n columnNumber: 9\n }, this), /*#__PURE__*/_jsxDEV(\"footer\", {\n className: \"footer\",\n children: [/*#__PURE__*/_jsxDEV(\"a\", {\n href: \"https://git.tsugutsugugo.com/explore/repos\",\n children: \"Source\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 290,\n columnNumber: 11\n }, this), \" |\", \" \", /*#__PURE__*/_jsxDEV(\"a\", {\n href: \"https://docs.tsugutsugugo.com/\",\n children: \"Docs\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 291,\n columnNumber: 11\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 289,\n columnNumber: 9\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 184,\n columnNumber: 7\n }, this)\n }, void 0, false);\n}\n_s(ResultsPage, \"uwqTDoSoe1ghclz16pMS19XbwaE=\", false, function () {\n return [useLocation];\n});\n_c = ResultsPage;\nexport default ResultsPage;\nvar _c;\n$RefreshReg$(_c, \"ResultsPage\");","map":{"version":3,"names":["React","useEffect","useState","useLocation","Link","jsxDEV","_jsxDEV","Fragment","_Fragment","ResultsPage","_s","results","setResults","videoResults","setVideoResults","loading","setLoading","videoLoading","setVideoLoading","currentPage","setCurrentPage","viewMode","setViewMode","visitedLinks","setVisitedLinks","stored","localStorage","getItem","JSON","parse","resultsPerPage","location","queryParams","URLSearchParams","search","query","get","catParam","categories","split","filter","Boolean","primaryCategory","multiCategorySearch","length","headerCategory","sourceMap","science","philosophy","tech","discover","headerMap","multi","headerBgMap","appBgMap","pagesPerCat","totalPagesMulti","fetchCategory","pageForCategory","numCats","categoryIndex","Math","floor","fetchResults","allResults","page","startRecord","response","fetch","encodeURIComponent","ok","data","json","channels","items","error","console","_data$channels$","fetchVideoResults","Error","status","computedPages","ceil","paginate","handleLinkClick","url","prev","includes","newVisited","setItem","stringify","children","className","style","backgroundColor","to","src","alt","fileName","_jsxFileName","lineNumber","columnNumber","id","onClick","slice","window","innerWidth","map","item","idx","href","link","target","rel","title","dangerouslySetInnerHTML","__html","description","Array","_","video","name","_c","$RefreshReg$"],"sources":["/home/magh/Documents/landing_page_experimental/src/ResultsPage.jsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { useLocation, Link } from 'react-router-dom';\nimport './App.css';\n\nfunction ResultsPage() {\n const [results, setResults] = useState([]);\n const [videoResults, setVideoResults] = useState([]);\n const [loading, setLoading] = useState(true);\n const [videoLoading, setVideoLoading] = useState(false);\n const [currentPage, setCurrentPage] = useState(1);\n const [viewMode, setViewMode] = useState('web'); // \"web\" for normal results, \"video\" for Peertube results\n const [visitedLinks, setVisitedLinks] = useState(() => {\n const stored = localStorage.getItem('visitedLinks');\n return stored ? JSON.parse(stored) : [];\n });\n const resultsPerPage = 10;\n\n const location = useLocation();\n const queryParams = new URLSearchParams(location.search);\n const query = queryParams.get('q') || '';\n\n // Get the \"cat\" parameter and split it into an array.\n // If only one category is chosen, this array has length 1.\n const catParam = queryParams.get('cat') || 'science';\n const categories = catParam.split(',').filter(Boolean);\n const primaryCategory = categories[0] || 'science';\n\n // Determine if there is a multi-category search.\n const multiCategorySearch = categories.length > 1;\n\n // For header purposes, we always use the primary category.\n const headerCategory = primaryCategory;\n\n // Maps: these remain as originally configured.\n const sourceMap = {\n science: 'https://science.tsugutsugugo.com/yacysearch.json',\n philosophy: 'https://sophos.tsugutsugugo.com/yacysearch.json',\n tech: 'https://tech.tsugutsugugo.com/yacysearch.json',\n discover: 'https://web.tsugutsugugo.com/yacysearch.json',\n };\n\n const headerMap = {\n science: '/header.png',\n philosophy: '/header_philosophy.png',\n tech: '/header_tech.png',\n discover: '/header_web.png',\n multi: '/header_multi.png',\n };\n\n // For single category searches, we use these mappings as given.\n const headerBgMap = {\n science: '#f8f8f8',\n philosophy: '#ffffff',\n tech: '#ffffff',\n discover: '#ffffff',\n multi: '#ffffff'\n };\n\n const appBgMap = {\n science: '#fcfcff',\n philosophy: '#ffffff',\n tech: '#ffffff',\n discover: '#ffffff',\n multi: '#ffffff'\n };\n\n // ---- Paging logic ----\n // When multiple categories are selected, use the round-robin algorithm with limits:\n // 1 category: 9 pages, 2 categories: 4 pages each, 3 categories: 3 pages each, 4+ categories: 2 pages each.\n let pagesPerCat;\n if (multiCategorySearch) {\n if (categories.length === 2) {\n pagesPerCat = 4;\n } else if (categories.length === 3) {\n pagesPerCat = 3;\n } else {\n pagesPerCat = 2;\n }\n }\n\n // For multi-category, total pages is categories.length * pagesPerCat.\n const totalPagesMulti = multiCategorySearch ? categories.length * pagesPerCat : null;\n\n // For multi-category search, determine which category and which page within that category to fetch:\n let fetchCategory, pageForCategory;\n if (multiCategorySearch) {\n const numCats = categories.length;\n const categoryIndex = (currentPage - 1) % numCats;\n pageForCategory = Math.floor((currentPage - 1) / numCats) + 1;\n fetchCategory = categories[categoryIndex];\n }\n\n useEffect(() => {\n const fetchResults = async () => {\n setLoading(true);\n // If exactly one category is selected, use the original algorithm.\n if (!multiCategorySearch) {\n let allResults = [];\n for (let page = 0; page < 10; page++) {\n const startRecord = page * resultsPerPage;\n try {\n const response = await fetch(\n `${sourceMap[primaryCategory]}?query=${encodeURIComponent(query)}&resource=global&urlmaskfilter=.*&prefermaskfilter=&nav=all&maximumRecords=${resultsPerPage}&startRecord=${startRecord}`\n );\n if (!response.ok) continue;\n const data = await response.json();\n allResults = [...allResults, ...(data.channels[0].items || [])];\n } catch (error) {\n console.error(\"Error fetching results:\", error);\n }\n }\n setResults(allResults);\n } else {\n // Multiple categories: use round-robin paging limited by pagesPerCat.\n const startRecord = (pageForCategory - 1) * resultsPerPage;\n try {\n const response = await fetch(\n `${sourceMap[fetchCategory]}?query=${encodeURIComponent(query)}&resource=global&urlmaskfilter=.*&prefermaskfilter=&nav=all&maximumRecords=${resultsPerPage}&startRecord=${startRecord}`\n );\n if (response.ok) {\n const data = await response.json();\n setResults(data.channels[0]?.items || []);\n } else {\n setResults([]);\n }\n } catch (error) {\n console.error(\"Error fetching results:\", error);\n setResults([]);\n }\n }\n setLoading(false);\n };\n\n if (viewMode === \"web\") {\n fetchResults();\n }\n }, [\n query,\n primaryCategory,\n multiCategorySearch,\n fetchCategory,\n pageForCategory,\n viewMode,\n sourceMap\n ]);\n\n // Video results fetching remains unchanged.\n const fetchVideoResults = async () => {\n setVideoLoading(true);\n try {\n const response = await fetch(\n `https://stream.tsugutsugugo.com/api/v1/videos?search=${encodeURIComponent(query)}`\n );\n if (!response.ok) {\n throw new Error(`Video API responded with status ${response.status}`);\n }\n const data = await response.json();\n setVideoResults(data.data || []);\n } catch (error) {\n console.error(\"Error fetching video results:\", error);\n } finally {\n setVideoLoading(false);\n }\n };\n\n // Compute total pages.\n // For multi, use totalPagesMulti; for single, use the computed aggregation.\n const computedPages = multiCategorySearch ? totalPagesMulti : Math.ceil(results.length / resultsPerPage);\n const paginate = (page) => setCurrentPage(page);\n\n const handleLinkClick = (url) => {\n setVisitedLinks((prev) => {\n if (!prev.includes(url)) {\n const newVisited = [...prev, url];\n localStorage.setItem(\"visitedLinks\", JSON.stringify(newVisited));\n return newVisited;\n }\n return prev;\n });\n };\n\n return (\n <>\n <div className=\"App results-page\" style={{ backgroundColor: appBgMap[headerCategory] }}>\n <header className=\"header-bar\" style={{ backgroundColor: headerBgMap[headerCategory] }}>\n <Link to=\"/\">\n <img src={headerMap[headerCategory]} alt={`${headerCategory} Header`} />\n </Link>\n </header>\n <main className=\"main-content\">\n <div id=\"tagline\">\n Search Results for <strong>{query}</strong>,{\" \"}\n {viewMode === \"web\" ? (\n <span\n className=\"link-switch\"\n onClick={async () => {\n await fetchVideoResults();\n setViewMode(\"video\");\n }}\n >\n browse videos\n </span>\n ) : (\n <span className=\"link-switch\" onClick={() => setViewMode(\"web\")}>\n browse web results\n </span>\n )}\n </div>\n\n {viewMode === \"web\" ? (\n loading ? (\n <p>Loading results...</p>\n ) : results.length > 0 ? (\n <>\n <ul className=\"results-list\">\n {results.slice(\n window.innerWidth < 600\n ? 0\n : (currentPage - 1) * resultsPerPage,\n window.innerWidth < 600\n ? results.length\n : currentPage * resultsPerPage\n ).map((item, idx) => (\n <li key={idx} className=\"result-item\">\n <a\n href={item.link}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n onClick={() => handleLinkClick(item.link)}\n className={`result-title ${\n visitedLinks.includes(item.link) ? \"visited-link\" : \"\"\n }`}\n >\n {item.title}\n </a>\n <p dangerouslySetInnerHTML={{ __html: item.description }} />\n <a\n href={`https://web.archive.org/web/*/${item.link}`}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"cache-link\"\n >\n Cache\n </a>\n </li>\n ))}\n </ul>\n {window.innerWidth >= 600 && computedPages > 1 && (\n <div className=\"pagination\">\n {[...Array(computedPages)].map((_, idx) => (\n <button\n key={idx}\n onClick={() => paginate(idx + 1)}\n className={`page-btn ${\n currentPage === idx + 1 ? \"active-page\" : \"\"\n }`}\n >\n {idx + 1}\n </button>\n ))}\n </div>\n )}\n </>\n ) : (\n <p>No search results found.</p>\n )\n ) : videoLoading ? (\n <p>Loading videos...</p>\n ) : videoResults && videoResults.length > 0 ? (\n <ul className=\"results-list\">\n {videoResults.map((video, idx) => (\n <li key={idx} className=\"result-item\">\n <a\n href={video.url}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"result-title\"\n >\n {video.name}\n </a>\n <p dangerouslySetInnerHTML={{ __html: video.description }} />\n </li>\n ))}\n </ul>\n ) : (\n <p>No video results found.</p>\n )}\n </main>\n <footer className=\"footer\">\n <a href=\"https://git.tsugutsugugo.com/explore/repos\">Source</a> |{\" \"}\n <a href=\"https://docs.tsugutsugugo.com/\">Docs</a>\n </footer>\n </div>\n </>\n );\n}\n\nexport default ResultsPage;\n"],"mappings":"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","ignoreList":[]},"metadata":{},"sourceType":"module","externalDependencies":[]} |