From 7bc22ee3787447d5a4b8d47542470cd672fec676 Mon Sep 17 00:00:00 2001 From: Andrew Jiang Date: Fri, 20 Dec 2024 18:36:42 -0500 Subject: [PATCH] use case switch statements --- .../fern-docs/ui/src/docs/DocsMainContent.tsx | 40 ++++++++++++------- 1 file changed, 25 insertions(+), 15 deletions(-) diff --git a/packages/fern-docs/ui/src/docs/DocsMainContent.tsx b/packages/fern-docs/ui/src/docs/DocsMainContent.tsx index e2bc490a05..a4fb62b04c 100644 --- a/packages/fern-docs/ui/src/docs/DocsMainContent.tsx +++ b/packages/fern-docs/ui/src/docs/DocsMainContent.tsx @@ -1,8 +1,8 @@ -import { visitDiscriminatedUnion } from "@fern-api/ui-core-utils"; import dynamic from "next/dynamic"; import { useSearchParams } from "next/navigation"; import { Fragment, ReactElement, memo } from "react"; -import { useFeatureFlags, useIsReady } from "../atoms"; +import { UnreachableCaseError } from "ts-essentials"; +import { useFeatureFlag, useIsReady } from "../atoms"; import { FernErrorBoundary } from "../components/FernErrorBoundary"; import type { DocsContent } from "../resolver/DocsContent"; @@ -31,19 +31,27 @@ const FeedbackPopover = dynamic(() => import("../feedback/FeedbackPopover"), { ssr: true, }); -const DocsMainContentRenderer = memo( - ({ content }: { content: DocsContent }) => { - return visitDiscriminatedUnion(content)._visit({ - "markdown-page": (content) => , - "api-reference-page": (content) => , - "api-endpoint-page": (content) => , - changelog: (content) => , - "changelog-entry": (content) => , - _other: () => null, - }); +const DocsMainContentRenderer = memo(function DocsMainContentRenderer({ + content, +}: { + content: DocsContent; +}): ReactElement | null { + switch (content.type) { + case "markdown-page": + return ; + case "api-reference-page": + return ; + case "api-endpoint-page": + return ; + case "changelog": + return ; + case "changelog-entry": + return ; + default: + console.error(new UnreachableCaseError(content)); + return null; } -); -DocsMainContentRenderer.displayName = "DocsMainContentRenderer"; +}); function LazyDocsMainContentRenderer({ content, @@ -59,11 +67,13 @@ export const DocsMainContent = memo(function DocsMainContent({ }: { content: DocsContent; }): ReactElement { - const { isInlineFeedbackEnabled } = useFeatureFlags(); + const isInlineFeedbackEnabled = useFeatureFlag("isInlineFeedbackEnabled"); const searchParams = useSearchParams(); + const FeedbackPopoverProvider = isInlineFeedbackEnabled ? FeedbackPopover : Fragment; + const ContentRenderer = searchParams.get("error") === "true" ? LazyDocsMainContentRenderer