Welcome to this Planning Poker Application repository ! This project showcases a full-stack application designed to facilatate planning poker sessions for agile teams. The application is built using modern web technologies and follows best practices for both client-side and server-side development.
- Project Overview
- Features
- Technologies Used
- Getting Started
- Installation
- Directory Structure
- Configuration
- Running the application
- Contributing
The Planning Poker Application is a tool for agile teams to estimate the effort required for various tasks. It allows users to create sessions, invite team memebers and vote on issues using planning poker approach. The application consists of a React-based client and Node/Express-based server with real-time communication facilitated through Socket.IO.
- User authentication and authorization
- Session mangement (create, join and leave session aswell as real-time updates)
- CRUD management of voted issues
- Real-time voting on issues
- Customizable voting systems
- Comprehensive validation and error handling
- Responsive design
- React
- TypeScript
- TailwindCSS
- React-Router
- Shadcn/UI component library
- React Hook Form
- Zod
- ESLint
- Prettier
- Husky
- Express
- MongoDB (Mongoose ODM)
- Passport.js (JWT Startegy)
- Socket.IO
- Express-validator
- Docker
- Node.js (14.x or above)
- MongoDB
- Docker (optional, for containerized deployment)
- Clone the repository :
git clone https://github.com/aymankahya/poker-planning.git
cd poker-planning
- Install dependencies for both client and server :
cd client
npm install
cd ../server
npm install
/client
: Contains the client-side code./public
: Static assets served to the client./src
: Source code for the client application./assets
: Static assets like images and fonts./components
: Reusable React components./context
: React context providers./hooks
: Custom React hooks./layouts
: Layout components./pages
: Page components./routes
: Route definitions./styles
: CSS and PostCSS files./types
: TypeScript type definitions./utils
: Utility functions.
/server
: Contains the server-side code./config
: Configuration files for database and authentication./controllers
: Handles user authentication, session management, and requests./event
: Functions for managing planning poker sessions an real-time updates./models
: Mongoose models and schemas./routes
: Express router objects for handling HTTP requests./sockets
: Socket.IO setup for real-time communication./utils
: Utility functions for session data, JWTs, and RSA key pairs generation./validation
: Middleware functions for user input validation and sanitization.
- Create a
.env
file in the/server
directory with the following variables:
PORT= server_running_port
CLIENT = client_side_url
ENV = "prod" or "dev"
DB_PROD = production_database_name
DB_DEV = development_database_name
DB_USERNAME = mongodb_database_username
DB_PASSWORD = mongodb_database_password
- Create a
.env
file in the/client
directory with the following variables:
VITE_SERVER_URL= server_side_url
VITE_CLIENT= client_side_url
- Start the client :
cd client
npm run dev
- Start the server :
cd ../server
npm run dev
- Build the client :
cd client
npm run build
- Build and Start the server :
cd ../server
npm run tsc
npm start
Contributions are welcome! Please follow these steps:
- Fork the repository
- Create a new branch
git checkout -b feature/your-feature
- Commit your changes
git commit -m "your-commit-message"
- Push to the branch
git push origin feature/your-feature
- Open a pull request