From 3683c11b2d4ca07a187341a307c14b52d6fb68a7 Mon Sep 17 00:00:00 2001 From: Joaquim Verges Date: Thu, 19 Dec 2024 13:59:28 +1300 Subject: [PATCH] docs: Simplify React Native sidebar navigation (#5800) --- .../src/app/react-native/v5/sidebar.tsx | 257 +----------------- 1 file changed, 13 insertions(+), 244 deletions(-) diff --git a/apps/portal/src/app/react-native/v5/sidebar.tsx b/apps/portal/src/app/react-native/v5/sidebar.tsx index d601b9aa1b6..451101c218c 100644 --- a/apps/portal/src/app/react-native/v5/sidebar.tsx +++ b/apps/portal/src/app/react-native/v5/sidebar.tsx @@ -1,11 +1,8 @@ -import { Book, BugIcon, CodeIcon, ZapIcon } from "lucide-react"; +import { BookIcon, BugIcon, CodeIcon, ZapIcon } from "lucide-react"; import type { SideBar } from "../../../components/Layouts/DocLayout"; import { ReactIcon, TypeScriptIcon } from "../../../icons"; -import { fetchTypeScriptDoc } from "../../references/components/TDoc/fetchDocs/fetchTypeScriptDoc"; -import { getCustomTag } from "../../references/components/TDoc/utils/getSidebarLinkgroups"; const slug = "/react-native/v5"; -const docs = await fetchTypeScriptDoc("v5"); export const sidebar: SideBar = { name: "Connect React Native SDK", @@ -27,253 +24,25 @@ export const sidebar: SideBar = { href: `${slug}/troubleshooting`, icon: , }, - { separator: true }, { - name: "Core", - isCollapsible: false, - links: [ - { - name: "Client", - href: `${slug}/createThirdwebClient`, - }, - { - name: "ThirdwebProvider", - href: `${slug}/ThirdwebProvider`, - }, - { - name: "Themes", - links: [ - { - name: "Theme Props", - href: `${slug}/Theme`, - icon: , - }, - ...(docs.functions - ?.filter((f) => { - const [tag] = getCustomTag(f) || []; - return tag === "@theme"; - }) - ?.map((f) => ({ - name: f.name, - href: `${slug}/${f.name}`, - icon: , - })) || []), - ], - }, - { - name: "TS reference", - href: "/typescript/v5", - icon: , - }, - { - name: "React reference", - href: "/react/v5", - icon: , - }, - ], - }, - { separator: true }, - { - name: "Wallets", - isCollapsible: false, - links: [ - { - name: "UI Components", - links: ["ConnectButton", "ConnectEmbed", "AutoConnect"].map( - (name) => ({ - name, - href: `${slug}/${name}`, - icon: , - }), - ), - }, - { - name: "Connection Hooks", - href: `${slug}/connecting-wallets/hooks`, - links: - docs.hooks - ?.filter((hook) => { - const [tag] = getCustomTag(hook) || []; - return tag === "@walletConnection"; - }) - ?.map((hook) => ({ - name: hook.name, - href: `${slug}/${hook.name}`, - icon: , - })) || [], - }, - { - name: "Wallet Hooks", - links: - docs.hooks - ?.filter((hook) => { - const [tag] = getCustomTag(hook) || []; - return tag === "@wallet"; - }) - ?.map((hook) => ({ - name: hook.name, - href: `${slug}/${hook.name}`, - icon: , - })) || [], - }, - { - name: "In-App Wallets", - links: [ - { - name: "React API", - href: "/react/v5/in-app-wallet/get-started", - icon: , - }, - ], - }, - { - name: "Ecosystem Wallets", - links: [ - { - name: "React API", - href: "/react/v5/ecosystem-wallet/get-started", - icon: , - }, - ], - }, - { - name: "Account Abstraction", - links: [ - { - name: "React API", - href: "/react/v5/account-abstraction/get-started", - icon: , - }, - ], - }, - { - name: "Supported Wallets", - href: "/typescript/v5/supported-wallets", - icon: , - }, - ], - }, - { separator: true }, - { - name: "Social API", - isCollapsible: false, - links: ["useSocialProfiles"].map((name) => ({ - name, - href: `${slug}/${name}`, - icon: , - })), - }, - { separator: true }, - { - name: "Pay", - isCollapsible: false, - links: [ - { - name: "Buy with Fiat", - links: - docs.hooks - ?.filter((f) => { - const [tag] = getCustomTag(f) || []; - return tag === "@buyCrypto" && f.name.includes("Fiat"); - }) - ?.map((f) => ({ - name: f.name, - href: `${slug}/${f.name}`, - icon: , - })) || [], - }, - { - name: "Buy with Crypto", - links: - docs.hooks - ?.filter((f) => { - const [tag] = getCustomTag(f) || []; - return tag === "@buyCrypto" && f.name.includes("Crypto"); - }) - ?.map((f) => ({ - name: f.name, - href: `${slug}/${f.name}`, - icon: , - })) || [], - }, - ], - }, - { separator: true }, - { - name: "Blockchain API", - isCollapsible: false, - links: [ - { - name: "UI Components", - links: ["TransactionButton"].map((name) => ({ - name, - href: `${slug}/${name}`, - icon: , - })), - }, - { - name: "Reading State", - href: `${slug}/reading-state`, - links: - docs.hooks - ?.filter((hook) => { - const [tag] = getCustomTag(hook) || []; - return tag === "@contract"; - }) - ?.map((hook) => ({ - name: hook.name, - href: `${slug}/${hook.name}`, - icon: , - })) || [], - }, - { - name: "Transactions", - href: `${slug}/transactions`, - links: - docs.hooks - ?.filter((hook) => { - const [tag] = getCustomTag(hook) || []; - return tag === "@transaction"; - }) - ?.map((hook) => ({ - name: hook.name, - href: `${slug}/${hook.name}`, - icon: , - })) || [], - }, - { - name: "Extensions", - links: [ - { - name: "Using Extensions", - href: "/react/v5/extensions", - icon: , - }, - { - name: "Available Extensions", - href: "/typescript/v5/extensions/built-in", - icon: , - }, - ], - }, - { - name: "Core API", - href: "/typescript/typescript/v5/chain", - icon: , - }, - ], + name: "Differences from React", + href: `${slug}/differences`, + icon: , }, { - separator: true, + name: "TypeScript docs", + href: "/typescript/v5", + icon: , }, { - name: "Differences from React", - href: `${slug}/differences`, + name: "React docs", + href: "/react/v5", + icon: , }, { - name: "Full Reference", - href: "/references/typescript/v5/hooks", - isCollapsible: false, + name: "API Reference", + href: "/references/typescript/v5", + icon: , }, ], };