Projeto Busca, filtro, ordenação e paginação com Next.js

Em uma listagem de pedidos, implemente busca textual, filtro, ordenação e paginação usando server components e estado na URL.

Project preview

Quando um dev front-end pensa em busca, filtro, ordenação e paginação, provavelmente pensa em usar métodos como Array.filter() ou Array.sort() diretamente no front. Mas e se tivermos 100, 500, 1000 itens paginados de 10 em 10? Gerenciar isso pelo front é uma tarefa hercúlea - e pior, não muito eficiente.

Neste Mini Projeto, vamos implementar uma API que retorna uma listagem de pedidos. Por mais simples que pareça, essa é uma API poderosa: ela nos permite passar, como query parameters, busca textual, filtro, ordenação e paginação. E o melhor de tudo: todas essas informações ficarão na URL para fácil compartilhamento!

Tudo isso no front usando Next.js e Server Components!

🤓 Antes de começar

O design e UI do front já estão implementados! O objetivo aqui é conseguir conectar a API e fazer as funcionalidades de busca, filtro, ordenação e paginação funcionarem.

Para isso, basta fazer um fork, clonar o código para a sua máquina, instalar as dependências e rodar pnpm run dev ou npm run dev!

A API

A API que será utilizada foi desenvolvida por nós, do Codante. O endpoint principal (de listagem de pedidos) está em https://apis.codante.io/api/orders-api/orders. A API é capaz de filtrar, ordenar, paginar e fazer uma busca textual.

A documentação da API está em https://apis-docs.codante.io/orders-api. Será necessário consultá-la para fazer este Mini Projeto.

InformaçãoInformação

Nenhum dos dados da API são reais e a base de dados é redefinida a cada hora.

🔨 Requisitos

Conectar dados da API à tabela

  • Popule a tabela com os dados que vêm da API.
  • Você deverá usar os campos
    • Nome do Cliente
    • Email do Cliente
    • Status
    • Data do Pedido
    • Valor do Pedido
DicaDica

O valor do pedido está em centavos. Faça as conversões e transforme para o formato brasileiro de número.

Busca Textual

  • Faça uma busca textual pelo nome do cliente.
  • A busca deverá ser totalmente server-side (ou seja, pela API e não pelo front-end).
  • A busca deverá ser refletida na URL. Quando não há uma busca, a URL não deverá mais possuir a query de busca.

Filtro de Status

  • Faça um filtro de status (pending, completed) usando o botão de filtro.
  • O filtro deverá ser totalmente server-side.
  • O filtro deverá ser refletido na URL. Quando não há filtros ativos, a URL não deverá mais possuir a query de filtro.

Ordenação de Campos

  • Crie ordenação para, pelo menos, os campos de data do pedido e valor.
  • A ordenação deverá ser ativada com um clique no nome da coluna respectiva (por exemplo, valor).
  • Troque o ícone ao lado do nome da coluna para que reflita corretamente o tipo da ordenação.
  • A ordenação deverá ser refletida na URL. Quando não há nenhuma ordenação, a URL não deverá mais possuir a query de ordenação.

Paginação

  • Implemente a paginação conforme os dados recebidos da API - a API já traz os links de páginas prontos para serem implementados.
  • Ative e desative os botões de próximo e anterior quando estiver na primeira e na última página.
  • A paginação também deverá ser refletida na URL.

Server e Client Components

  • Decida quais componentes deverão ser servidor e quais deverão ser de cliente.

🔨 Desafio extra para quem quer ir além

  • Utilize o hook useDebounce para atrasar a execução da função de busca textual e evitar muitos requests.

🎨 Design Sugerido

Neste mini projeto não será preciso implementar nenhum design - já fizemos isso por você.

👉🏽 Sobre este mini-projeto

O que você irá praticar:

Next.js

  • Router
  • Search Params
  • Estado na URL
  • Server Components no Next.js
  • 'use client'
  • Paginação e Ordenação.

Pré-requisitos

  • React
  • Next.js básico
  • Entender as diferenças entre server e client components é recomendável

Junte-se a outras 127 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árioAvatar do usuárioAvatar do usuárioAvatar do usuárioAvatar do usuário