1 line
33 KiB
JSON
1 line
33 KiB
JSON
{"ast":null,"code":"var _jsxFileName = \"/home/magh/Documents/landing_page_divided/src/MultiCategoryResults.jsx\",\n _s = $RefreshSig$();\n// MultiCategoryResults.jsx\nimport React, { useEffect, useState } from 'react';\nimport { Link } from 'react-router-dom';\nimport './App.css';\nimport { jsxDEV as _jsxDEV, Fragment as _Fragment } from \"react/jsx-dev-runtime\";\nfunction MultiCategoryResults({\n query,\n categories\n}) {\n _s();\n const [results, setResults] = useState([]);\n const [loading, setLoading] = useState(true);\n const [videoResults, setVideoResults] = useState([]);\n const [videoLoading, setVideoLoading] = useState(false);\n const [currentPage, setCurrentPage] = useState(1);\n const [viewMode, setViewMode] = useState(\"web\");\n const [visitedLinks, setVisitedLinks] = useState(() => {\n const stored = localStorage.getItem(\"visitedLinks\");\n return stored ? JSON.parse(stored) : [];\n });\n const resultsPerPage = 10;\n\n // Determine number of categories selected.\n const numCats = categories.length;\n\n // Define pages per category according to the rules:\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 (numCats === 1) {\n pagesPerCat = 9;\n } else if (numCats === 2) {\n pagesPerCat = 4;\n } else if (numCats === 3) {\n pagesPerCat = 3;\n } else {\n pagesPerCat = 2;\n }\n\n // Compute total pages: for multiple categories use (numCats * pagesPerCat)\n // while for a single category, we simply use pagesPerCat since we are aggregating.\n const totalPages = numCats > 1 ? numCats * pagesPerCat : pagesPerCat;\n\n // Determine which category to fetch:\n // For multiple categories, pick the appropriate category and page based on currentPage.\n const categoryIndex = (currentPage - 1) % numCats;\n const pageForCategory = Math.floor((currentPage - 1) / numCats) + 1;\n const fetchCategory = categories[categoryIndex];\n\n // For header and styling, always use the primary category (first in array).\n const primaryCategory = categories[0];\n const headerCategory = primaryCategory;\n\n // Define source and header maps.\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 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 useEffect(() => {\n const fetchResults = async () => {\n setLoading(true);\n // If more than one category, fetch results for the computed category/page.\n if (numCats > 1) {\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 multi-category results:\", error);\n setResults([]);\n }\n } else {\n // For a single category, aggregate results over multiple pages.\n let allResults = [];\n for (let page = 0; page < pagesPerCat; page++) {\n const startRecord = page * resultsPerPage;\n try {\n var _data$channels$2;\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$2 = data.channels[0]) === null || _data$channels$2 === void 0 ? void 0 : _data$channels$2.items) || [])];\n } catch (error) {\n console.error(\"Error fetching results:\", error);\n }\n }\n setResults(allResults);\n }\n setLoading(false);\n };\n if (viewMode === \"web\") {\n fetchResults();\n }\n }, [query, currentPage, viewMode, numCats, pageForCategory, pagesPerCat, fetchCategory, primaryCategory, resultsPerPage]);\n\n // Compute pagination count.\n const computedPages = numCats > 1 ? totalPages : Math.ceil(results.length / resultsPerPage);\n const paginate = page => setCurrentPage(page);\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) throw new Error(\"Video API error\");\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 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(\"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: 173,\n columnNumber: 11\n }, this)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 172,\n columnNumber: 9\n }, this)\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 171,\n columnNumber: 7\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: 178,\n columnNumber: 30\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: 180,\n columnNumber: 13\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: 190,\n columnNumber: 13\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 177,\n columnNumber: 9\n }, this), viewMode === \"web\" ? loading ? /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"Loading results...\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 197,\n columnNumber: 13\n }, this) : results.length > 0 ? /*#__PURE__*/_jsxDEV(_Fragment, {\n children: [/*#__PURE__*/_jsxDEV(\"ul\", {\n className: \"results-list\",\n children: results.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: 203,\n columnNumber: 21\n }, this), /*#__PURE__*/_jsxDEV(\"p\", {\n dangerouslySetInnerHTML: {\n __html: item.description\n }\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 212,\n columnNumber: 21\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: 213,\n columnNumber: 21\n }, this)]\n }, idx, true, {\n fileName: _jsxFileName,\n lineNumber: 202,\n columnNumber: 19\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 200,\n columnNumber: 15\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: 227,\n columnNumber: 21\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 225,\n columnNumber: 17\n }, this)]\n }, void 0, true) : /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"No search results found.\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 239,\n columnNumber: 13\n }, this) : videoLoading ? /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"Loading videos...\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 242,\n columnNumber: 11\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: 247,\n columnNumber: 17\n }, this), /*#__PURE__*/_jsxDEV(\"p\", {\n dangerouslySetInnerHTML: {\n __html: video.description\n }\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 250,\n columnNumber: 17\n }, this)]\n }, idx, true, {\n fileName: _jsxFileName,\n lineNumber: 246,\n columnNumber: 15\n }, this))\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 244,\n columnNumber: 11\n }, this) : /*#__PURE__*/_jsxDEV(\"p\", {\n children: \"No video results found.\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 255,\n columnNumber: 11\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 176,\n columnNumber: 7\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: 259,\n columnNumber: 9\n }, this), \" | \", /*#__PURE__*/_jsxDEV(\"a\", {\n href: \"https://docs.tsugutsugugo.com/\",\n children: \"Docs\"\n }, void 0, false, {\n fileName: _jsxFileName,\n lineNumber: 259,\n columnNumber: 75\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 258,\n columnNumber: 7\n }, this)]\n }, void 0, true, {\n fileName: _jsxFileName,\n lineNumber: 170,\n columnNumber: 5\n }, this);\n}\n_s(MultiCategoryResults, \"Cem8QxvtH48jNsLuOL8v9JN0JbM=\");\n_c = MultiCategoryResults;\nexport default MultiCategoryResults;\nvar _c;\n$RefreshReg$(_c, \"MultiCategoryResults\");","map":{"version":3,"names":["React","useEffect","useState","Link","jsxDEV","_jsxDEV","Fragment","_Fragment","MultiCategoryResults","query","categories","_s","results","setResults","loading","setLoading","videoResults","setVideoResults","videoLoading","setVideoLoading","currentPage","setCurrentPage","viewMode","setViewMode","visitedLinks","setVisitedLinks","stored","localStorage","getItem","JSON","parse","resultsPerPage","numCats","length","pagesPerCat","totalPages","categoryIndex","pageForCategory","Math","floor","fetchCategory","primaryCategory","headerCategory","sourceMap","science","philosophy","tech","discover","headerMap","multi","headerBgMap","appBgMap","fetchResults","startRecord","response","fetch","encodeURIComponent","ok","_data$channels$","data","json","channels","items","error","console","allResults","page","_data$channels$2","computedPages","ceil","paginate","fetchVideoResults","Error","handleLinkClick","url","prev","includes","newVisited","setItem","stringify","className","style","backgroundColor","children","to","src","alt","fileName","_jsxFileName","lineNumber","columnNumber","id","onClick","map","item","idx","href","link","target","rel","title","dangerouslySetInnerHTML","__html","description","window","innerWidth","Array","_","video","name","_c","$RefreshReg$"],"sources":["/home/magh/Documents/landing_page_divided/src/MultiCategoryResults.jsx"],"sourcesContent":["// MultiCategoryResults.jsx\nimport React, { useEffect, useState } from 'react';\nimport { Link } from 'react-router-dom';\nimport './App.css';\n\nfunction MultiCategoryResults({ query, categories }) {\n const [results, setResults] = useState([]);\n const [loading, setLoading] = useState(true);\n const [videoResults, setVideoResults] = useState([]);\n const [videoLoading, setVideoLoading] = useState(false);\n const [currentPage, setCurrentPage] = useState(1);\n const [viewMode, setViewMode] = useState(\"web\");\n const [visitedLinks, setVisitedLinks] = useState(() => {\n const stored = localStorage.getItem(\"visitedLinks\");\n return stored ? JSON.parse(stored) : [];\n });\n const resultsPerPage = 10;\n\n // Determine number of categories selected.\n const numCats = categories.length;\n\n // Define pages per category according to the rules:\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 (numCats === 1) {\n pagesPerCat = 9;\n } else if (numCats === 2) {\n pagesPerCat = 4;\n } else if (numCats === 3) {\n pagesPerCat = 3;\n } else {\n pagesPerCat = 2;\n }\n\n // Compute total pages: for multiple categories use (numCats * pagesPerCat)\n // while for a single category, we simply use pagesPerCat since we are aggregating.\n const totalPages = numCats > 1 ? numCats * pagesPerCat : pagesPerCat;\n\n // Determine which category to fetch:\n // For multiple categories, pick the appropriate category and page based on currentPage.\n const categoryIndex = (currentPage - 1) % numCats;\n const pageForCategory = Math.floor((currentPage - 1) / numCats) + 1;\n const fetchCategory = categories[categoryIndex];\n\n // For header and styling, always use the primary category (first in array).\n const primaryCategory = categories[0];\n const headerCategory = primaryCategory;\n\n // Define source and header maps.\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 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 useEffect(() => {\n const fetchResults = async () => {\n setLoading(true);\n // If more than one category, fetch results for the computed category/page.\n if (numCats > 1) {\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 multi-category results:\", error);\n setResults([]);\n }\n } else {\n // For a single category, aggregate results over multiple pages.\n let allResults = [];\n for (let page = 0; page < pagesPerCat; 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 }\n setLoading(false);\n };\n\n if (viewMode === \"web\") {\n fetchResults();\n }\n }, [\n query,\n currentPage,\n viewMode,\n numCats,\n pageForCategory,\n pagesPerCat,\n fetchCategory,\n primaryCategory,\n resultsPerPage\n ]);\n\n // Compute pagination count.\n const computedPages = numCats > 1 ? totalPages : Math.ceil(results.length / resultsPerPage);\n\n const paginate = (page) => setCurrentPage(page);\n\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) throw new Error(\"Video API error\");\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 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 <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 {viewMode === \"web\" ? (\n loading ? (\n <p>Loading results...</p>\n ) : results.length > 0 ? (\n <>\n <ul className=\"results-list\">\n {results.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 ${visitedLinks.includes(item.link) ? \"visited-link\" : \"\"}`}\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 ${currentPage === idx + 1 ? \"active-page\" : \"\"}`}\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 href={video.url} target=\"_blank\" rel=\"noopener noreferrer\" className=\"result-title\">\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> | <a href=\"https://docs.tsugutsugugo.com/\">Docs</a>\n </footer>\n </div>\n );\n}\n\nexport default MultiCategoryResults;\n"],"mappings":"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","ignoreList":[]},"metadata":{},"sourceType":"module","externalDependencies":[]} |