Welcome to the documentation for the Emumba Plugin project. This project aims to streamline the creation of React applications by providing a CLI tool that sets up a boilerplate project with selected options.
The Emumba Plugin is a CLI tool designed to simplify the process of creating new React applications by providing a set of prompts to customize the project setup. It allows developers to choose various configurations such as UI libraries, data fetching libraries, state management, and more.
-
Clone the Emumba Plugin repository from Gitlab:
git clone https://github.com/emumba-com/emumba-nx-boilerplate-plugin.git
-
Setup Verdaccio in the project for local publishing
npx nx g setup-verdaccio
-
Install project dependencies:
npm i
For development/testing purposes, comment the line with @emumba-com:registry in the .npmrc files located at project root, /packages/emumbaplugin and /packages/emumba-project-setup.
-
Set up a local registry for testing and run the project locally. In one terminal, run:
npx nx local-registry
-
In a second terminal, publish the package locally using verdaccio (e.g., version 1.0.0):
npx nx run-many -t publish --ver 1.0.0 --tag latest
To create a new React project using the Emumba Plugin, follow these simple steps:
-
Open your terminal.
-
Generate a Personal Access Token from Github.
-
Run the following command to login and use your generated token when asked.
npm login --registry=https://npm.pkg.github.com --scope=@emumba-com
- Run the following command:
npx @emumba-com/nx-project-setup@latest my-app
-
Follow the on-screen prompts to configure your project. You can select options for UI libraries, data fetching libraries, state management, React Router, Storybook, the type of application (standalone or monorepo), and the build tool you want to use.
-
The Emumba Plugin will create the project with your chosen configurations.
-
To start your project, navigate to the project directory. If you've created a standalone app, use the command
npm start
. For a monorepo project, usenx serve your_monorepo_appName
. -
If you've chosen the Storybook option as true, you can run the Storybook by using the following commands. For a standalone project, use
nx storybook
. If you've selected a monorepo, usenx storybook your_monorepo_appName
.
The Emumba Plugin allows you to configure various aspects of your project, including:
-
Type of Application: Choose between Standalone or Monorepo project.
-
Build Tool: Choose between Webpack or Vite.
-
UI Library: Choose between Material UI, Ant Design, or None.
-
Data Fetching Library: Choose between React Query, SWR, or None.
-
Form Library: Choose between React Hook Form, Formik, or None.
-
Default Stylesheet: Choose between CSS, SASS, or Styled-Components.
-
React Router: Configure whether or not to include React Router for handling navigation.
-
State Management Library: Choose between Redux, Jotai, or None.
-
Storybook: Configure whether or not to include Storybook for component development.
You can customize these options during project setup, and the Emumba Plugin will generate a project that adheres to your choices.
Here's an overview of the project's directory structure:
├── packages
│ ├── emumba-plugin
│ │ ├── src
│ │ │ ├── generators
│ │ │ │ ├── preset
│ │ │ │ │ ├── files
│ │ │ │ │ │ ├── formik_components
│ │ │ │ │ │ ├── jotai_components
│ │ │ │ │ │ ├── react_hook_form_components
│ │ │ │ │ │ ├── react_query_components
│ │ │ │ │ │ ├── redux_components
│ │ │ │ │ │ ├── router_components
│ │ │ │ │ │ ├── src
│ │ │ │ │ │ │ ├── app
│ │ │ │ │ │ │ │ ├── App.css.template
│ │ │ │ │ │ │ │ └── App.tsx.template
│ │ │ │ │ │ │ ├── main.tsx.template
│ │ │ │ │ │ │ └── styles.css.template
│ │ │ │ │ │ ├── storybook_components
│ │ │ │ │ │ ├── swr_components
│ │ │ │ │ │ └── ui_library_components
│ │ │ │ │ ├── generator.ts
│ │ │ │ │ ├── schema.d.ts
│ │ │ │ │ └── schema.json
│ └── emumba-project-setup
│ ├── bin
│ │ └── index.ts
├── project.json
├── README.md
└── tsconfig.base.json
This directory contains the core logic for generating boilerplates based on user preferences. It includes the following elements:
bin/index.ts
: This is the entry point of the CLI tool. It utilizes theenquirer
npm package to prompt users and collect their choices regarding project configuration.
This directory encompasses the code responsible for generating project files and adding dependencies. The central file in this directory is:
generator.ts
: This file handles the appropriate file generation and dependency management based on the user's prompt selections.
This directory holds templates for the components that will be generated/added based on the user's selections. It includes subdirectories for various components, such as UI libraries (e.g., Material UI in /ui_library_components/mui
) and other options.