From 81611b991477c57f48107772b3344c0324770b58 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Halit=20=C4=B0nce?= Date: Sat, 21 Oct 2023 02:41:07 +0300 Subject: [PATCH] feat: add new snippet to CodeSnippets paths --- .../react/document-screen-fetch-ts.mdx | 56 +++++++++++++++++++ .../build-pages-with-storybook.md | 1 + 2 files changed, 57 insertions(+) create mode 100644 docs/snippets/react/document-screen-fetch-ts.mdx diff --git a/docs/snippets/react/document-screen-fetch-ts.mdx b/docs/snippets/react/document-screen-fetch-ts.mdx new file mode 100644 index 000000000000..5286bf2003ee --- /dev/null +++ b/docs/snippets/react/document-screen-fetch-ts.mdx @@ -0,0 +1,56 @@ +```ts +// YourPage.tsx + +import React, { useState, useEffect } from 'react'; + +import { PageLayout } from './PageLayout'; +import { DocumentHeader } from './DocumentHeader'; +import { DocumentList } from './DocumentList'; + +// Example hook to retrieve data from an external endpoint +function useFetchData() { + const [status, setStatus] = useState('idle'); + const [data, setData] = useState([]); + useEffect(() => { + setStatus('loading'); + fetch('https://your-restful-endpoint') + .then((res) => { + if (!res.ok) { + throw new Error(res.statusText); + } + return res; + }) + .then((res) => res.json()) + .then((data) => { + setStatus('success'); + setData(data); + }) + .catch(() => { + setStatus('error'); + }); + }, []); + + return { + status, + data, + }; +} + +export function DocumentScreen() { + const { status, data } = useFetchData(); + + const { user, document, subdocuments } = data; + + if (status === 'loading') { + return

Loading...

; + } + if (status === 'error') { + return

There was an error fetching the data!

; + } + return ( + + + + + ); +} \ No newline at end of file diff --git a/docs/writing-stories/build-pages-with-storybook.md b/docs/writing-stories/build-pages-with-storybook.md index 4307a31020f4..bb62b2d26c27 100644 --- a/docs/writing-stories/build-pages-with-storybook.md +++ b/docs/writing-stories/build-pages-with-storybook.md @@ -141,6 +141,7 @@ If you're working with pure presentational screens, adding stories through [args