O Design
Last updated
Was this helpful?
Last updated
Was this helpful?
No Skeleton Quasar foi adotado um design que fornece modelos de abstrações que podem ser usadas para desacoplar seu código da apresentação (frameworks CSS e Javascript) que será utilizada para a apresentação. O projeto como um todo possui opções de uso para roteadores, organização de componentes e modularização na base de código deste projeto, mas elas farão sentido com o contexto que será apresentado.
Buscando ter uma maturidade na implementação o modelo utilizado está sendo batizado de Agnostic Presentation Design (APD) e veremos mais detalhes sobre ele à seguir.
Agnostic Presentation Design (Design de Apresentação Agnóstica) é o nome da abordagem que visa criar estruturas de dados para criar as apresentações independente das ferramentas utilizadas para apresentação. Abaixo você pode ver um modelo de como esse padrão funciona.
O modelo acima mostra como são separadas as responsabilidades dentro do ciclo de vida da apresentação. A lógica de negócio e os serviços são criados fora da camada de apresentação e são mapeados por componentes e rotinas capazes de interpretar e lidar com a notação apresentada.
O Agnostic Presentation Design irá guiá-lo para não usar a lógica de negócios dentro de seus componentes. O mantra é manter a estratégia de apresentação apenas como uma camada de visualização e não permitir que lógicas de negócio sejam aplicadas nessa camada.
Ao tentar fazer isso é comum ter problemas com a relação entre o local onde eventos e outras rotinas são declaradas e onde são realizadas de fato. O APD busca minimizar a lacuna criada por essa estratégia com o gerenciamento do escopo. Assim, você declara imperativamente suas propriedades e seus comportamentos em uma estrutura que representa o esboço do componente em questão e essa estrutura será associada ao componente que será renderizado da maneira mais conveniente.
Você pode reusar sua rotina em variados cenários diferentes. Você pode mudar sua camada de apresentação inteira tendo como única premissa manter os contratos e comportamentos da anterior. Pode usar outro framework diferente do Quasar e pode usar outras ferramentas de renderização como React e outras com um impacto reduzido sobre o projeto.
O esboço (Schema) é um recurso que agrupa as propriedades do domínio da entidade e especifica seu comportamento. O esboço principal (classe, módulo ou qualquer outra estrutura de dados escolhida) será capaz de fornecer um conjunto mínimo de recursos para construir o objetivo principal de sua natureza. Deve ser extensível e fornecer gateways para ser especializado em contextos específicos.
Os comportamentos da estrutura do esboço são projetados para serem executados em outros escopos. Portanto, a base do projeto deve ser capaz de manter os recursos fornecidos pelo esboço disponíveis nos comportamentos criados para ele.
Como você pode ver na imagem acima, para dizer o que um projeto implementa Agnostic Presentation Design irá requerer a existência de uma camada dedicada para fornecer os recursos definidos no esboço para a camada de renderização da tela. Essa camada intermediária pode variar de framework de componentes ou de framework de renderização. Um projeto APD pode ter sua lógica de negócio sendo usada em Vue ou React sem muitos problemas, já que haverá uma gateway e uma cadeia de componentes preparados para isso.
O primeiro passo para exemplificar a estratégia de APD será criar um arquivo para representar o Service. Vamos consumir a API pública da saga Star Wars em nosso exemplo.
Note que é apenas uma função que consulta o endpoint usando fetch e extrai da resposta um os resultados.
O próximo exemplo será uma estrutura para representar a estrutura que a API responde.
Esta é uma função bem simples para criar um objeto para mapear as propriedades do nosso serviço e corresponde à Business Logic apresentada na Figura 1 no início da página
Para representar um Controller Component teremos o seguinte trecho.
A principal característica desse componente é que provavelmente será mapeado à uma rota da aplicação e não terá nada além de um template que carregará um único componente (Container Component) e alguma relação com o Service e/ou Business Logic.
Um Container Component é um componente agnóstico. Ele provavelmente será registrado globalmente e terá uma estrutura altamente flexível.
Os exemplos passados são, por razões óbvias, o mais simples possível, porém esse componente poderia ter vários desdobramentos, interagir com o service do controller através de eventos e muitas outras coisas.
Para ver tudo isso funcionando podemos fazer isso e montar nosso componente controlador. O exemplo funcional está disponível nesse link aqui.