Setup
Clone the project:
git clone https://github.com/Pjiwm/circle-project/
Docker Setup
If you do not have Docker installed yet, but want to use the Docker setup:
If you Are on windows 10/11 Home:
- Install WSL: WSL installation guide
- Restart your computer, and run in powershell:
WSL -l
- If you receive any errors troubleshoot.
- If Windows did not install a default distro (Ubuntu) Install one from the MS store: Ubuntu from MS store
- For a more comfortable working environment get Windows Terminal and set Ubuntu as your default CLI: Windows Terminal from MS store
- Install Docker: Docker
- Restart computer
- Open Docker-Desktop open settings and got to:
Resources > WSL Integration
Enable Ubuntu and press refresh
- Open Windows Terminal or Ubuntu and see if the docker command is working.
If you are on Linux, Mac or Windows 10/11 Pro:
- Install Docker
- Run Docker in a CLI to see if it works
When Docker is installed:
- navigate to the repo in a terminal or inside your IDE’s CLI
- Copy and paste
sample.env
(to keep it on the repo) and rename it to .env
- run
docker-compose build
- run
docker-compose up
Using remote containers with VSCode
For an optimal dev environment use the Remote containers extensions.
- Open VSCode in this project
- Install Remote - Containers from Microsoft (ms-vscode-remote.remote-containers)
- Copy and paste
sample.env
(to keep it on the repo) and rename it to .env
- Open the command pallet
ctrl
+ shift
+ p
and run > Remote Containers: Open Folder in container..
- You should now be inside the container within VSCode.
Regular Setup
- Install Node 16: guide
- Install NX globally with
npm install -g nx
- Copy and paste
sample.env
(to keep it on the repo) and rename it to .env
- Setup a local MariaDB server or any other MySQL server.
- Use a tool like Xamp or phpMyAdmin to manage your local databases.
- Install OpenSSL on Windows.
Useful NX commands
Remember, you can always use the NX console!
Angular Commands
Generating a component: npx nx g @nrwl/angular:component <name> --project frontend
Generating a service: npx nx g @nrwl/angular:service <name> --project frontend
Linting
To lint your code: npx nx lint --fix express-backend
Working environment
Managing the project in your editor/IDE
Open the project in your editor/IDE preferably VSCode due to extensions used for linting and the NX gui extension.
- If you do not use VSCode make sure you can use ESLint linting and optionally an extension for NX. Otherwise you have to use the NX CLI.
(If you use og Vim, Nano or Ed have fun 💀)
- If you use Docker with remote containers all extensions should be installed already.
- If you are not using Docker but are using VSCode make sure to install the recommended extensions.
Set prettier as your formatter, this will make sure you’re not making any linting errors.
Project structure
This repository is an NX monorepo. This means different projects backend, frontend etc. are all in the same workspace area.
in the apps
directory the different projects can be found. The libs
directory can be used to put resources in that will be reused over different apps.
Running tests, building, serving, generating new components, linting etc. can all be done using NX commands.
In VSCode simply navigate to the left. There should be a logo with the letters NX. Using this extension running any NX command will become fairly easy.
For more information: NX setup
Contribution rules
Code conventions
- Strict convention rules are not applied in any frontend Projects. Most components and boilerplate will be generated already.
- No unused variables
- Always make use of semicolons (😉 at the end of a statement.
- Use double quotes.
- All functions must have a JSDoc comment.
/**
* I am a JSDoc, I describe the function below me.
* This function calls someone SUS!
* @param person - The person who's gonna be sus.
*/
function amongUs(person: any): void {
console.log(`${person} is sus`);
}
- No unused functions
- When you use an ESLint Ignore statement add an explanation.
What happens when code is committed that does not follow the code conventions?
When code is committed that contains linting errors it will fail whilst running in the pipeline.
Your pull request will fail and can therefor not be pr’d back to dev or main.
Git and Github rules
- Do not push directly to Dev or Main.
- Use Milestones for user stories.
- Use an issue per problem you’ll tackle.
- Add corresponding Milestones (user stories) to your issue.
- Add fitting labels to your issue (bugfix, new feature, documentation etc.)
- For every new problem you’ll solve you work on a different feature or bug-fix branch. (feature/stream-window, bug-fix/centered-div)
- When done with a branch create a pull request with your pushed branch.
- in the description write: Closes #Issue number of issue you’ve solved. This way Issues will automatically be closed after the pull request has been submitted.
- Every pull request needs at least one code review.
- Only use
feature
and bug-fix
branches.
- Do your code reviews seriously.
- Do not review/submit pull requests that are still running CI tests.
- Assign yourself and other people if necessary to the assignee’s tab in a pull request.
- Feel free to request reviewers in a pull request.
- Make sure not to commit big chunks of changes, commit in small steps.
Working Lean
- Make use of the github projects kanban board.
- The boards can be found in this repo’s projects tab > Projects (classic)
- Always assign yourself first before working on any tasks.
- Make sure to update the tasks status. (in progress, testing done)
- WIP-Limits:
- Kanban-backlog 10
- under development 6
- under test 4
- done (waiting for acceptance by PO) 3
- accepted by PO ∞