DEV Community

Cover image for Crie seu próprio template customizado para seus apps Reactjs
Vinicius Savegnago
Vinicius Savegnago

Posted on

5 3

Crie seu próprio template customizado para seus apps Reactjs

Nestes últimos tempos, tenho utilizado bastante o framework Reactjs, e iniciando meus projetos com o pacote Create React App. Porém sempre que faço essa inicialização, há uma estrutura pronta que sempre acabo removendo por completo, então resolvi criar um template personalizado para me ajudar com o setup inicial de meus projetos.

Eu só não achava que seria tão simples...

Segue aqui uma breve explicação de como fazer isso:

 

Para isso você vai precisar de uma conta npm. É lá que vamos publicar o nosso template para utilizar com o Create React App.

Primeiro de tudo, vamos criar uma pasta e iniciar um projeto com o pacote CRA. Assim vamos ter a base do projeto para deixar do nosso jeito antes de publicar.

yarn create react-app meu-template
Enter fullscreen mode Exit fullscreen mode

Após a instalação, podemos remover ou adicionar os pacotes e bibliotecas que desejarmos.

Assim que tudo estiver do jeito que você gosta, podemos preparar o nosso template. (O seu projeto será iniciado do mesmo jeito em que você deixou os arquivos)

Para isso vamos criar uma pasta com o nome template. É nela que vamos deixar todos os nossos arquivos do template.

Dentro dela, podemos colocar a nossa pasta /public e /src. Além de nosso arquivo .gitignore (Só devemos remover o ponto no começo do nome do arquivo, ficando assim: gitignore)

Não vamos precisar da pasta /node_modules. Então podemos excluí-la.

Além disso também podemos adicionar um README.md, tsconfig, .prettierrc, e entre outros arquivos que você desejar.

Segue a estrutura até agora:

meu-template/
  README.md (Para o npm)
  package.json
    /template
        README.md (Para os projetos criados com este template)
        gitignore (sem o ponto no começo do arquivo)
        public/
          index.html
                /...outros arquivos que desejar
        src/
          index.js (or index.tsx)
                /...outros arquivos que desejar
Enter fullscreen mode Exit fullscreen mode

Agora vamos adicionar um arquivo com o nome de template.json

Nele vai estar todas as nossas dependências e configurações do template, inclusive scripts, se desejarmos.

Vou utilizar o template base oficial do Create React App como exemplo:

facebook/create-react-app

template.json

{
  "package": {
    "dependencies": {
      "@testing-library/jest-dom": "^5.11.4",
      "@testing-library/react": "^11.1.0",
      "@testing-library/user-event": "^12.1.10",
      "web-vitals": "^1.0.1"
    },
    "eslintConfig": {
      "extends": ["react-app", "react-app/jest"]
    }
  }
}
Enter fullscreen mode Exit fullscreen mode

E em em nosso package.json, podemos adicionar algumas informações, além do nome do nosso template, que precisa ter o prefixo: cra-template-[nome-do-template].

Também é importante adicionar o arquivo principal em main e a opção files, com os itens: template e template.json

Segue o exemplo:

{
  "name": "cra-template-meu-template",
  "main": "template.json",
  "version": "1.0.0",
  "keywords": [
    "react",
    "create-react-app",
    "template"
  ],
  "description": "Meu template personalizado",
  "engines": {
    "node": ">=10"
  },
  "files": [
    "template",
    "template.json"
  ]
}
Enter fullscreen mode Exit fullscreen mode

E nossa estrutura está assim:


meu-template/
  README.md (Para o npm)
  template.json
  package.json
  template/
    README.md (Para os projetos criados com este template)
    gitignore
    public/
      index.html
            /...outros arquivos que desejar
    src/
      index.js (or index.tsx)
            /...outros arquivos que desejar
Enter fullscreen mode Exit fullscreen mode

Agora podemos fazer login no NPM pelo terminal e publicar o nosso template 😎

Vamos abrir o terminal e rodar:

npm login
Enter fullscreen mode Exit fullscreen mode

Insira suas credenciais para fazer o login e em seguida podemos publicar:

npm publish --access public
Enter fullscreen mode Exit fullscreen mode

Agora em sua conta NPM você pode ver o seu novo pacote 👍🏼

Vamos testar!!

yarn create react-app --template meu-template
Enter fullscreen mode Exit fullscreen mode

 

Irado!! 🔥

Agora podemos utilizar o nosso novo template para projetos futuros.

Você também pode fazer outros tipos de templates, ou adicionar scripts, para deixar o seu setup inicial de projetos turbinado 🤘🏼

 

Então é isso. Se esse post foi útil de alguma maneira, deixe um comentário ou uma reação 😉

Valeu!

Segue o repositório do meu template:

vinisaveg/cra-template-vinisaveg

Links úteis:

Custom Templates | Create React App

Creating and publishing scoped public packages | npm Docs

 

Happy Coding! 🙂

Image of Timescale

🚀 pgai Vectorizer: SQLAlchemy and LiteLLM Make Vector Search Simple

We built pgai Vectorizer to simplify embedding management for AI applications—without needing a separate database or complex infrastructure. Since launch, developers have created over 3,000 vectorizers on Timescale Cloud, with many more self-hosted.

Read more →

Top comments (0)

Billboard image

The Next Generation Developer Platform

Coherence is the first Platform-as-a-Service you can control. Unlike "black-box" platforms that are opinionated about the infra you can deploy, Coherence is powered by CNC, the open-source IaC framework, which offers limitless customization.

Learn more

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay