Projeto Gráficos com shadcn/charts e Next.js

Muitas vezes gráficos são a melhor forma de "enxergarmos" os dados. Neste mini projeto, vamos criar gráficos dinâmicos com shadcn, Next.js e Recharts.

Project preview

Muitas vezes, a melhor forma de exibir dados é através de gráficos. E para grande parte dos casos, não é necessário que sejamos especialistas em data science - basta apenas que conheçamos as ferramentas certas para essa tarefa. E é exatamente isso que se tornaram algumas bibliotecas de gráficos para React - uma forma simples e rápida de construirmos gráficos dinâmicos e bonitos.

Neste Mini Projeto, vamos criar uma visualização com gráficos sobre os gastos dos senadores brasileiros.

🤓 Antes de começar

Este Mini Projeto não possui um template pronto. Isso significa que você deverá começar, do zero, seu projeto Next.js. Entretanto, os dados que alimentarão os gráficos deverão vir da API de Gastos de Senadores, que nós do Codante criamos e preparamos.

Também vale a pena contextualizar o que são os dados com os quais estamos trabalhando: trata-se das despesas com Cotas para Exercício da Atividade Parlamentar dos Senadores (CEAPS), que basicamente são reembolsos de despesas gerais com gabinete e atividade parlamentar. Alguns exemplos incluem assessoria parlamentar (contratação de pessoal para auxiliar em atividades como elaboração de projetos de lei e atendimento à população), material de expediente (compra de materiais de escritório, como papel e computadores), locação de imóveis (aluguel de espaços para escritórios), serviços de comunicação (contratação de internet e telefone), viagens e diárias (despesas com viagens para eventos relacionados ao mandato) e outras despesas (como eventos e divulgação de atividades parlamentares).

A API utilizada

A documentação da API está neste link.

Nós iremos utilizar, para este Mini Projeto, dois endpoints da API:

🔨 Requisitos

  • Crie o Gráfico de Gastos por UF

    • Crie uma visualização de gráfico de barras horizontal.
    • Cada barra do gráfico deverá corresponder a um estado brasileiro (UF).
    • Adicione no gráfico a média de gastos de todas as UFs.
      • Você deverá calcular esses valores e adicioná-los aos dados originais da API.
      • A barra que representa a média deverá estar destacada com outra cor no gráfico.
    • Transforme os dados conforme o necessário - a transformação e saneamento dos dados também fazem parte do Mini Projeto!
    • Adicione tooltips e labels para deixar o gráfico mais legível.
  • Crie o Gráfico de Gastos por Partido

    • Crie uma visualização de gráfico de barras horizontal.
    • Cada barra do gráfico deverá corresponder a um partido.
    • Adicione no gráfico a média de gastos de todos os partidos.
      • Você deverá calcular esses valores e adicioná-los aos dados originais da API.
      • A barra que representa a média deverá estar destacada com outra cor no gráfico.
    • Transforme os dados conforme o necessário - a transformação e saneamento dos dados também fazem parte do Mini Projeto!
    • Adicione tooltips e labels para deixar o gráfico mais legível.
  • Crie botões dinâmicos que irão trocar as visualizações entre os dois gráficos (UF e Partido).
  • Crie um seletor que irá trocar o ano dos dados - desde 2020 até 2024.
  • Você deverá utilizar a biblioteca shadcn/charts para construir seus gráficos.

🔨 Desafio extra para quem quer ir além

Se você quiser mergulhar ainda mais nos dados, dê uma olhada na documentação da nossa API. Uma possível - e interessante - implementação de gráficos com estes dados é a criação de um gráfico de pizza que demonstra a divisão das categorias/tipos de despesas.

🎨 Design Sugerido

Temos uma sugestão de design no Figma. Entretanto, sinta-se à vontade para montar a aplicação conforme a sua criatividade.

Figma

🔗 Link do design

👉🏽 O que você irá praticar:

Next.js

  • Criação de um novo projeto
  • Fetch de dados de API externa usando server components

shadcn/charts

  • Criação de gráficos com a biblioteca

Pré-requisitos

  • Conhecimento básico de Next.js e server components
  • Conhecimento de React

Junte-se a outras 23 pessoas que estão fazendo esse mini projeto.

Avatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuário