gandarfh / server-driven-ui

Teste de implementacao de server driven ui com next.js. (Em desenvolvimento...)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Server Driven UI

Neste artigo vamos desenvolver uma simples aplicação que vai consumir um pequeno JSON e renderizar um tela com esses dados.

Nada muito fora da realizada de muitos desenvolvedores frontend correto? Ai que esta o diferencial, nesse JSON teremos também quais componentes deveram ser utilizados para compor a nossa tela final. Basicamente tirando a responsabilidade de construção da interface do front.

O que é Server Driven Ui

Sendo bem breve, SDU (Server Driven Ui) é uma das alternativas de se montar a interface da sua aplicação, onde através de uma API será retornado tudo, tanto os dados de usuário para montar um simples avatar quanto os componentes que iriam compor essa pedaço da interface.

Uma estrutura muito conhecida é a de simplesmente enviar os dados através de uma API e no frontend iriamos pegar esses dados e compor a tela da forma em que foi acordado.

Como implementar

Sera necessário desenvolver as seguintes implementações:

  • Backend (BFF) -> Ele ira disponibilizar o nosso schema.
    • Uma estrutura simples com pelo menos uma rota por tela.
  • Frontend -> Para renderizar os componentes informados pela api.
    • No caso do react (Next.js) um provider para controlar as configurações básicas.
    • Uma função simples para criar as configurações.
    • Uma função que vai ler o json e gerar a arvore de componentes.
    • Um hook para realizar a requisição e retornar a arvore de componentes.
    • Implementar internacionalização com next-18next com os arquivos de tradução em uma ambiente externo.
  • Criar um modelo do schema que será cria pela api e lido pelo frontend

Estrutura

Nossa aplicação seguirão com as estruturas definidas abaixo.

Um ponto interessante de se avisar é que não irei desenvolver um backend bem estruturado ou com todos as firulas que conhecemos hoje em dia, a ideia aqui é exemplificar como pode ser feita essa conversa utilizando de SDU.

Caso desejem estarei disponibilizando um monorepo contendo um exemplo do backend e do frontend desenvolvidos nesse artigo.

Link para o repositório.

Backend

Nosso backend terá a seguinte estrutura:

├── src
│   ├── api
│   │   ├── Home
│   │   │   ├── controller.ts
│   │   │   └── routes.ts
│   │   └── Search
│   │       ├── controller.ts
│   │       └── routes.ts
│   ├── app.ts
│   ├── routes.ts
│   └── server.ts
├── package.json
└── tsconfig.json

Frontend

Nosso frontend terá a seguinte estrutura:

├── pages
│   ├── _app.tsx
│   ├── _document.tsx
│   ├── index.tsx
│   └── search.tsx
├── public
│   ├── favicon.ico
├── src
│   ├── components
│   │   ├── Layout.tsx
│   │   ├── Navbar.tsx
│   │   └── Search.tsx
│   ├── screens
│   │   ├── Home
│   │   │   └── index.tsx
│   │   └── Search
│   │       └── index.tsx
│   └── sdu
│       ├── config.tsx
│       ├── Context.tsx
│       └── createElement.tsx
├── retriever.d.ts
├── next.config.js
├── next-env.d.ts
├── next-i18next.config.js
├── README.md
├── package.json
└── tsconfig.json

Schema

Um possível exemplo de interface

type Children = | string | number | Record<string, unknown> | string[] | number[] |  Record<string, unknown>[]

interface Schema {
  component: string
  children: Schema[] | Children
  [props: string]?: any
}

Como pode notar, nossa estrutura é muito baseada em recursividade, um component tem um children que pode ter N components ou alguma outra coisa. Sempre bom lembrar de nunca esquecer esse tipo de estrutura deve sempre ter um break, para que ela não "quebre" e rode infinitamente.

Representação do schema com um json

[
  {
    "component": "retriever:div",
    "bg": "primary.400",
    "height": "300px",
    "children": [
      {
        "component": "retriever:p",
        "children": [
          {
            "component": "retriever:span",
            "children": "Primeiro texto ",
          }
          {
            "component": "retriever:span",
            "color": "green.400",
            "children": "Primeiro texto."
          }
        ]
      }
    ]
  }
  // {...} e a estrutura se repete quantas vezes for necessário.
]

Com essas estruturas decididas, não falta mais nada para começarmos a desenvolver nossas funcionalidades.

About

Teste de implementacao de server driven ui com next.js. (Em desenvolvimento...)


Languages

Language:TypeScript 86.1%Language:CSS 10.6%Language:JavaScript 3.3%