Skip to content

Commit

Permalink
Try Request/Response 탭으로 분리
Browse files Browse the repository at this point in the history
  • Loading branch information
CirnoV committed Apr 18, 2024
1 parent 2ea458b commit 7033507
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 31 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import JsonViewer from "../../../editor/JsonViewer";
import Card from "../Card";

export interface ResExampleProps {
example: { [key: string]: unknown };
example: { [key: string]: unknown } | undefined;
}

export default function ResExample({ example }: ResExampleProps) {
Expand Down
9 changes: 6 additions & 3 deletions src/layouts/rest-api/endpoint/playground/try/Tabs.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useSignal } from "@preact/signals";
import { Signal, useSignal } from "@preact/signals";
import type React from "preact/compat";

export interface Tab<Id extends string> {
Expand All @@ -8,10 +8,13 @@ export interface Tab<Id extends string> {
}
export interface TabsProps<Id extends string> {
tabs: (Tab<Id> | false | 0)[];
tabIdSignal?: Signal<string | Id>;
}
export function Tabs<Id extends string>({ tabs }: TabsProps<Id>) {
export function Tabs<Id extends string>({ tabs, tabIdSignal }: TabsProps<Id>) {
const _tabs = tabs.filter(Boolean);
const currTabIdSignal = useSignal(_tabs[0]?.id || "");
const currTabIdSignal = tabIdSignal
? tabIdSignal
: useSignal(_tabs[0]?.id || "");
const currTabId = currTabIdSignal.value;
const currTab = _tabs.find((tab) => tab.id === currTabId);
return (
Expand Down
76 changes: 49 additions & 27 deletions src/layouts/rest-api/endpoint/playground/try/Try.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import Req from "./Req";
import ReqSample from "./ReqSample";
import ResComponent, { type Res } from "./Res";
import ResExample from "./ResExample";
import { Tabs } from "./Tabs";

export interface TryProps {
apiHost: string;
Expand All @@ -24,36 +25,57 @@ export default function Try(props: TryProps) {
const harRequestSignal = useSignal<HarRequest | undefined>(undefined);
const example =
props.operation.responses?.["200"]?.content?.["application/json"]?.example;
const tabIdSignal = useSignal<"request" | "response">("request");
return (
<div
class={`grid flex-1 grid-rows-4 gap-3 ${
waiting ? "pointer-events-none opacity-50" : ""
}`}
class={`grid grid-rows-[auto_1fr] flex-1 gap-3 ${waiting ? "pointer-events-none opacity-50" : ""}`}
>
<Req
{...props}
harRequestSignal={harRequestSignal}
execute={(fn) =>
void (async () => {
try {
waitingSignal.value = true;
resSignal.value = await fn();
errSignal.value = "";
} catch (err) {
errSignal.value = (err as Error).message;
} finally {
waitingSignal.value = false;
}
})()
}
/>
{err ? (
<Err>{err}</Err>
) : (
resSignal.value && <ResComponent resSignal={resSignal} />
)}
<ReqSample harRequestSignal={harRequestSignal} />
{example && <ResExample example={example} />}
<Tabs
tabIdSignal={tabIdSignal}
tabs={[
{
id: "request",
label: "request",
render: (key) => (
<div key={key} class="grid grid-rows-2 h-full gap-3">
<Req
{...props}
harRequestSignal={harRequestSignal}
execute={(fn) =>
void (async () => {
try {
waitingSignal.value = true;
resSignal.value = await fn();
errSignal.value = "";
} catch (err) {
errSignal.value = (err as Error).message;
} finally {
waitingSignal.value = false;
tabIdSignal.value = "response";
}
})()
}
/>
<ReqSample harRequestSignal={harRequestSignal} />
</div>
),
},
{
id: "response",
label: "response",
render: (key) => (
<div key={key} class="grid grid-rows-2 h-full gap-3">
{err ? (
<Err>{err}</Err>
) : (
<ResComponent resSignal={resSignal} />
)}
<ResExample example={example} />
</div>
),
},
]}
></Tabs>
</div>
);
}

0 comments on commit 7033507

Please sign in to comment.