Logo

dev-resources.site

for different kinds of informations.

Documentando seus componentes no Storybook

Published at
3/26/2024
Categories
programming
tutorial
typescript
storybook
Author
aledluzm
Author
8 person written this
aledluzm
open
Documentando seus componentes no Storybook

Vamos abordar os conceitos que envolvem doc blocks, parameters e argTypes com exemplos de suas utilizações.

Image description

Recentemente me deparei com a necessidade de documentar uma biblioteca de componentes pela primeira vez. Resolvi aproveitar um pouco do conhecimento adquirido nessa jornada para compartilhar aqui com vocês.

Por que documentar seus componentes?
Ao documentar os seus componentes, você além de facilitar o entendimento da utilização deles para o coleguinha que for pegar pela primeira vez. Também facilita para o seu eu do futuro que desenvolveu aquele componente já tem alguns meses. Além disso, podemos adicionar as alterações dinâmicas para quem gostaria de por exemplo ver outro tema do seu componente de botão apenas clicando no nome do tema.

Como documentar o seu componente
A documentação ocorre dentro do arquivo stories.jsx do seu componente. É lá que a magia acontece e você determina como será a apresentação dele para quem estiver acessando a página do seu storybook. Para isso precisamos entender o conceito de alguns aliados que o storybook nos disponibiliza:

Parameters — é esse carinha que vai nos permitir codificar e controlar tudo que envolve o ambiente do nosso componente. É dentro dele que vamos trabalhar hoje. Vamos passar o doc blocks para trazer as informações do nosso componente de uma forma mais bonita para todos que acessam o storybook.

Essa é a estrutura padrão que fica dentro do arquivo stories.tsx do seu componente.

doc blocks — é utilizado para documentar e compartilhar componentes UI através de uma interface bonitinha. Possui features que nos permitem interagir diretamente com o componente através dessa interface, e adicionar blocos de código para copiar e colar.

Exemplo da estrutura mostrada anteriormente, mas agora com seus blocos de documentação adicionadas:

Vamos dar uma olhadinha tag por tag para maior compreensão.

<Title /> Renderiza uma tag de estilo H1
<Subtitle /> Renderiza uma tag de estilo H2
<Description /> Renderiza uma tag de estilo P
<Stories /> Quando não recebe uma prop indicando qual renderizar, ele pode renderizar todos os exemplos de componentes que existe dentro do arquivo
<Source /> É aqui que adicionamos um trecho de código com a funcionalidade de copiar e colar junto. Note também que no meu exemplo eu adicionei a tag dark para que o bloco de código fique escuro.
<Primary /> Mostra o primeiro componente do arquivo stories. Geralmente é utilizado após o título e descrição do componente.
<Controls /> É a interface dinâmica que além de documentar o componente, também permite uma interação com ele. O que alimenta esse carinha é o argTypes que vamos ver a seguir.

Exemplo de como isso irá renderizar no Storybook (sem a chamada do <Controls /> junto):

Image description

argTypes — Especifica e documenta o comportamento dos argumentos esperados pelo componente, e também os tipos de valores que são aceitos por cada um deles. Quando utilizado sem ser em conjunto do Controls(doc blocks, citado anteriormente), mostra essa lista estática em uma tabela:

Image description

Quando utilizado em conjunto do Controls mostra esses argTypes um por um em cada linha da tabela. A diferença é que agora mostra de forma dinâmica para que possa haver interações diretas com o componente.

Image description

No exemplo utilizando o Controls, nós temos uma coluna a mais que permite essa interação direta com o componente.

Exemplo completo de como ficaria um arquivo stories com tudo que aprendemos:

Espero que esse artigo tenha ajudado você a desmistificar um pouco a parte da documentação dos componentes, ou pelo menos tenha despertado a curiosidade de tentar por aí também.

Para entender mais sobre argTypes e seu funcionamento acesse a documentação do Storybook

Até a próxima!

storybook Article's
30 articles in total
Favicon
Integrate Storybook with VueJS
Favicon
Run Storybook with NX Expo and React Native Paper
Favicon
Storybook for UI Components: Build, Test, and Document Your React Components in Isolation
Favicon
Integrating Storybook into an existing next.js project
Favicon
How to customize storybook (custom theme and layout option)?
Favicon
How to add custom fonts and viewports in storybook?
Favicon
Made AI-Powered Interactive Storybook Generator with Next.js, Gemini and Elevenlabs ️‍🔥
Favicon
Storybook: The Workshop for Modern Frontends
Favicon
SanS-UI v0.0.1 Quick Start!
Favicon
SanS-UI Released v0.0.1
Favicon
Using Storybook with Angular and Vite 🎨
Favicon
Documentation of components in React with TypeScript using Storybook
Favicon
Documentação de componentes em React com Typescript usando Storybook
Favicon
Tutorial de utilização Storybook
Favicon
Component Driven Development with Storybook React Native
Favicon
Storybook: Stories for Smart Components
Favicon
Tutorial de instalação do Storybook com Tailwind
Favicon
📚 How to Handle Multiple MSW Handlers in Storybook Stories
Favicon
Beginner Guide to React Storybook
Favicon
Comparing Vue Component Documentation tools
Favicon
How to stop Storybook opening a new webpage on start (automatically with zsh)
Favicon
Manual setup for a minimal Storybook
Favicon
Setup Your Universal App with React Native, Expo Router, Tamagui, and Storybook
Favicon
Configuring Storybook in Your Nuxt Project
Favicon
Documentando seus componentes no Storybook
Favicon
Build component library using Storybook
Favicon
Integrating Storybook with PrimeNG and TailwindCSS in an Nx Workspace
Favicon
Storybook setup: Virtual Screen Reader with Web Components
Favicon
Simple setup: Virtual Screen Reader in Storybook
Favicon
Using fonts in Storybook for Next.JS and Tailwind Projects

Featured ones: