Criando UseCase loadCategoryByPage no CrazyStack Node.js

Dev Doido - Feb 27 '23 - - Dev Community

Este é um material auxiliar do bootcamp CrazyStack Node.js do DevDoido. Ele servirá como uma espécie de documentação de alguns códigos vistos durante as aulas apenas como material complementar, garanta já sua vaga no bootcamp clicando AQUI!.

Nesta aula, vamos criar o use case "loadCategoryByPage". Este use case tem como objetivo carregar as categorias de uma página específica, com base nas opções de consulta fornecidas. Para isso, precisamos criar um contrato "loadCategoryByPageRepository", que define as operações necessárias para carregar as categorias. Em aulas posteriores do curso, implementaremos essas operações em nossa camada de repositório, usando a base de dados que escolhemos. Por fim, criaremos o use case "loadCategoryByPage", que utilizará o contrato para obter as categorias da página solicitada e fornecerá os resultados ao chamador. Este use case é importante porque permite paginação dos dados, o que é importante para melhorar a performance da aplicação quando há muitos dados a serem exibidos.

import { LoadCategoryByPageRepository } from "@/slices/category/repositories";
import { CategoryPaginated } from "@/slices/category/entities";
import { Query } from "@/application/types";

export type LoadCategoryByPage = (query: Query) => Promise<CategoryPaginated | null>;
export type LoadCategoryByPageSignature = (
  loadCategoryByPage: LoadCategoryByPageRepository
) => LoadCategoryByPage;
export const loadCategoryByPage: LoadCategoryByPageSignature =
  (loadCategoryByPageRepository: LoadCategoryByPageRepository) => async (query: Query) => {
    return loadCategoryByPageRepository.loadCategoryByPage(query);
  };
Enter fullscreen mode Exit fullscreen mode

Este código contém três exportações: LoadCategoryByPage, LoadCategoryByPageSignature, e loadCategoryByPage.

  1. LoadCategoryByPage é uma função que recebe um objeto Query como entrada e retorna uma promessa que, quando resolvida, retorna um objeto CategoryPaginated ou null.

  2. LoadCategoryByPageSignature é uma função que recebe um objeto LoadCategoryByPageRepository como entrada e retorna a função LoadCategoryByPage.

  3. loadCategoryByPage é uma constante que é uma instância da função LoadCategoryByPageSignature e foi já passado como entrada um objeto loadCategoryByPageRepository.

A função LoadCategoryByPage é usada para carregar as categorias do sistema por página. Ela recebe um objeto Query como entrada e retorna uma promessa que, quando resolvida, retorna um objeto CategoryPaginated correspondente ou null caso ocorra algum erro.

A função LoadCategoryByPageSignature é usada para criar uma assinatura para a função LoadCategoryByPage, ela espera receber como entrada um objeto do tipo LoadCategoryByPageRepository e retorna a função LoadCategoryByPage.

A constante loadCategoryByPage é uma instância da função LoadCategoryByPageSignature já passando como entrada o objeto loadCategoryByPageRepository. Ele é usado para carregar as categorias do sistema por página, Ele passa o objeto query para o objeto loadCategoryByPageRepository para carregar as categorias correspondentes do banco de dados.

Este código é usado para definir e implementar a funcionalidade de carregar categorias por página. Ele utiliza a interface LoadCategoryByPageRepository para carregar as categorias do banco de dados e retorna uma promessa com o objeto CategoryPaginated correspondente ou null caso ocorra algum erro.

LINK DO REPOSITÓRIO

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .