โจ In this workshop we'll be building a store for a fictional board game company called The Board Game Hoard โจ
We're going to be using Nx and some its plugins to accelerate the development of this app.
Some of the things you'll learn:
- Generating Nx workspace applications and libraries
- Integrate an existing CRA application to the monorepo
- Generating project configurations
- Creating shared libs for re-using code
- How to organize code in a monorepo
- Easily move libs around your folder structure
- Write unit test for packages
- Creating Storybook stories and E2E Cypress tests for your components
- How to set boundaries between the different scopes in your project
- Set-up Gitlab CI workflows for the code
To help you understand how to apply some of these lessons in your own projects, we'll try to integrate a "real-world" example. However, because of the time constrains and to make sure we get to cover as much material as possible, we'll provide you with all the code for any "non-Nx" work you need to do (like styling and configuring routes) - so you can focus on learning to use Nx to its full potential.
This is what we'll build:
Can be found here
Nx has support for a lot of platforms, but in this workshop we'll be using mainly React. While all the code for any React specific work will be provided, it will help if you have some experience with the React ecosystem.
Make sure you have the following installed:
Bun
version 1.0+ orNode.js
version 16+git-filter-repo
you can install with your favorite package manager for example$ PACKAGE_TOOL install git-filter-repo
Each task will have the following sections:
- โฐ Estimated time
- How much time we expect is needed to finish this task
- ๐ Learning outcomes
- A summary of the most important things you'll learn in that task
- ๐ฒ After this workshop, your app should look similar to this
- This will contain a screenshot of any changes to the app visuals after the task
- ๐๏ธโโ๏ธ Steps
- All the task steps you need to follow
- ๐ Solution
- If you get stuck running any Nx command, there is a
SOLUTION.md
file in each task's folder.
- If you get stuck running any Nx command, there is a
The task might also have this helpful sections:
- ๐ณ Hints and solutions feat. Ron the whale
- While the mighty narwhal is away on secret missions, you will occasionally see his assistant, Ron The Whale offering helpful hints to the different exercises. Please use these if you get stuck.
โ ๏ธ Important information- Sometimes there are hidden gotchas or common mistakes. Read this before running the step
- Source files
- As mentioned, for anything React/styling or HTML template work we will provide the code you need as direct links to the files. Please use these as much as possible.
Each task will contain a link to the next one. Start from "Task 1" and move through them as required:
- ๐ฌ Task 1 - Generate an empty workspace
- โ๏ธ Task 2 - Import a CRA based app
- ๐งช Task 3 - Executors
- ๐ญ Task 4 - Generate a component lib
- ๐งฌ Task 5 - Move the utility lib
- ๐งฎ Task 6 - Generate a route lib
- ๐ค Task 7 - Add an Express API
- ๐ Task 8 - Displaying a full game in the routed game-detail component
- ๐ป Task 9 - Generate a type lib that the API and frontend can share
- ๐ฉโ๐ป Task 10 - Generate Storybook stories for the shared ui component
- โจ๏ธ Task 11 - E2E test the shared component
- ๐ก Task 12 - Module boundaries
- ๐ Task 13 - Setting up CI
- ๐ Task 14 - Run-Commands and deploying the frontend