Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mateusznakodach/coderscamp2020.project.fullstack-node-react.tablesoccertournaments
Final project for CodersCamp 2021 programming course. Team leaded by Mateusz Nowak. Backend finished, frontend in progress.
https://github.com/mateusznakodach/coderscamp2020.project.fullstack-node-react.tablesoccertournaments
coderscamp coderscamp2020 coderscamp2020-dzial-4 coderscamp2020-dzial-5
Last synced: 4 months ago
JSON representation
Final project for CodersCamp 2021 programming course. Team leaded by Mateusz Nowak. Backend finished, frontend in progress.
- Host: GitHub
- URL: https://github.com/mateusznakodach/coderscamp2020.project.fullstack-node-react.tablesoccertournaments
- Owner: MateuszNaKodach
- Created: 2021-02-15T20:16:09.000Z (about 4 years ago)
- Default Branch: develop
- Last Pushed: 2021-08-11T13:21:31.000Z (over 3 years ago)
- Last Synced: 2023-04-27T04:07:14.469Z (almost 2 years ago)
- Topics: coderscamp, coderscamp2020, coderscamp2020-dzial-4, coderscamp2020-dzial-5
- Language: TypeScript
- Homepage: https://wkps.netlify.app/
- Size: 8.37 MB
- Stars: 5
- Watchers: 0
- Forks: 6
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# TourDeFoos - CodersCamp final project
### Frontend
#### Netlify Deployment
URL: https://wkps.netlify.app/
[data:image/s3,"s3://crabby-images/0d381/0d381a01e6805d7c06d1640291b9f1e7c57f109d" alt="Netlify Status"](https://app.netlify.com/sites/wkps/deploys)
### Backend
[Swagger REST API Docs](https://coderscamp2020-tablesoccer.herokuapp.com/rest-api-docs/)
#### Test Coverage
[data:image/s3,"s3://crabby-images/3b6d7/3b6d796ab1b3442ad45bbde3bacad43f5b4f25e8" alt="codecov"](https://codecov.io/gh/nowakprojects/CodersCamp2020.Project.FullStack-Node-React.TableSoccerTournaments)#### Mutation Test Coverage
[data:image/s3,"s3://crabby-images/ad6dd/ad6dde15df752a75fc903d54d60ad4b9a9480697" alt="Mutation testing badge"](https://dashboard.stryker-mutator.io/reports/github.com/nowakprojects/CodersCamp2020.Project.FullStack-Node-React.TableSoccerTournaments/develop)## Overview
**TourDeFoos is an application to organize and manage tournaments - in this case it's dedicated especially for foosball tournaments.**
**It was created as a final project of CodersCamp course.**
## Our Crew
Mentor **[Mateusz Nowak](https://github.com/nowakprojects)**
- [Anna Lamperska](https://github.com/lamparina)
- [Piotr Rynio](https://github.com/PiotrWR)
- [Paweł Szambelan](https://github.com/Szambelan)
- [Tomasz Dworniczak](https://github.com/tomdworniczak)## Main functionalities
1. Tournament organisation
2. Creating players profiles (regardless of tournaments) and sending them confirmation emails via NodeMailer.
3. Tournament registration
4. Tournament tables module responsible for enable/disable tables during tournament
5. Division into teams and assignment to teams
6. Division of matches between teams - making tournament tree
7. Matches module responsible for starting and finishing matches## Dependencies
The following technologies were used:
#### Backend:
- Node.js
- Express
- Database: MongoDB / in memory save
- TypeScript
- Docker
- Nodemailer
- Jest
- MailHog
- Stryker
- Heroku
- Swagger
- DockerOur backend application follows the **TDD approach** and is almost **fully covered** by tests. The architecture has been designed according to the **DDD (Domain-driven design)**.
#### Frontend:
- React
- React-DOM
- Router
- Hooks (useState, useEffect, useContext,useHistory)
- Material-UI
- AxiosThe architecture has been designed according to the **Atomic Design approach**. Application follows th **Mobile First Design.**
#### Other:
- Code Review in every Pull Request (and 2 Approve to merge)
- Event Storming & Event Modeling
- Domain-Driven Design (DDD)
- Git
- GitHub
- IntelliJ
- Miro
- Figma
- Swagger
- Docker
- EasyRetro
- We used to daily every day and remote-meeting every week!## Event Modeling
During this project used EventStorming, followed by Event Modeling to model our application flow and for task division.
We used for it miro web app.
[Link to Miro Board](https://miro.com/app/board/o9J_lOEebqI=/?moveToWidget=3074457356075616433&cot=14).data:image/s3,"s3://crabby-images/08c52/08c52e5e53450ce218458a36e13b06ed52461442" alt="image"
## Running the project
Running this project locally
###### From the repo:
1. Clone this project locally
2. Run `npm install` in your bash/command line
3. Go to `/backend` in your bash/command line and Run `npm run start:dev` in your bash/command line
4. Go to `/frontend` in your bash/command line and Run `npm run start` in your bash/command line## Development
1. Execute `docker-compose -f docker-compose.dev.yaml up` in main project catalog - this will run the application in watch mode and all required dependencies.
2. Now following urls should be available:
- REST API SWAGGER | http://localhost:5000/rest-api-docs/
- FRONTEND (REACT) | https://localhost:3000