Try it out | Download from App Store
A beautiful, modern productivity app that combines task management with Pomodoro timer functionality, habit tracking, and real-time collaboration. Built with Next.js, React, and Framer Motion for smooth animations and premium user experience.
- Create, edit, and manage tasks and habits
- Subtasks support - Break down complex tasks into manageable subtasks
- Organize tasks with custom color-coded categories
- Mark tasks as complete with smooth animations
- Hold-to-complete gesture for mobile-friendly interaction
- Separate sections for regular tasks and habits
- WebRTC-powered task sharing
- Peer-to-peer connection for instant synchronization
- Share tasks and progress with team members in real-time
- No server dependency for peer connections after initial handshake
- Customizable timer presets (5, 10, 25, 50 minutes)
- Real-time countdown with animated display
- Overtime tracking for extended work sessions
- Break timer with automatic transitions
- Focus time tracking for productivity insights
- Music player-style controls (play/pause/stop)
- GitHub-style contribution graph for 30-day habit history
- Monthly view with visual intensity indicators
- Individual habit tracking with daily completion
- Interactive grid for marking habit completion
- Comprehensive habit analytics and progress visualization
- Modern bottom-sheet modal design
- 4 stunning themes with seamless theme selection
- Smooth spring animations with Framer Motion
- Responsive design optimized for mobile and desktop
- Dark/Light mode support with enhanced theme system
- Primary color theming throughout the app
- Intuitive touch gestures and micro-interactions
- Export/Import functionality for data backup
- Local storage persistence
- Enhanced settings panel with theme controls
- Motivational intro screen with random quotes
- Node.js 18+
- npm or yarn package manager
- 
Clone the repository git clone https://github.com/anoyrc/priospace.git cd priospace
- 
Install dependencies npm install # or yarn install
- 
Set up WebRTC Server (for collaboration features) cd webrtc-server npm install npm run startThe WebRTC signaling server will start on the default port. Make sure this is running before using collaboration features. 
- 
Run the development server # Navigate back to root directory cd .. npm run dev # or yarn dev 
- 
Open your browser Navigate to http://localhost:3000 
- Next.js 15 - React framework with App Router
- React 19 - UI library with hooks and modern patterns
- TypeScript - Type-safe JavaScript development
- Tailwind CSS - Utility-first CSS framework
- Framer Motion - Animation library for smooth interactions
- WebRTC - Peer-to-peer real-time communication
- WebSocket - Signaling server for WebRTC handshake
- Node.js - Backend server for WebRTC signaling
- shadcn/ui - High-quality, accessible UI components
- Lucide React - Beautiful, customizable icons
- Custom Components - CountdownTimer, CircleProgress, and modal systems
- React Hooks - useState, useEffect, useRef for state management
- Local Storage - Data persistence in browser
- Context API - Theme and global state management
priospace/
โโโ app/                    # Next.js App Router
โ   โโโ globals.css        # Global styles and Tailwind imports
โ   โโโ layout.tsx         # Root layout with providers
โ   โโโ page.tsx           # Main application page
โโโ components/            # Reusable components
โโโ lib/                   # Utility functions
โ   โโโ utils.ts          # Helper functions and utilities
โโโ webrtc-server/         # WebRTC signaling server
โ   โโโ server.js         # Express server with WebSocket support
โ   โโโ package.json      # Server dependencies
โ   โโโ ...
โโโ public/               # Static assets
โโโ package.json          # Dependencies and scripts
- Click the "Add Task" button
- Enter your task title in the borderless input
- Optionally select or create a category with custom colors
- Add subtasks by clicking the subtask option
- Break down complex tasks into manageable chunks
- Click "Add Task" to save
- Select a task from your list
- Choose a timer preset (5, 10, 25, or 50 minutes)
- Use the music player-style controls:
- Play/Pause - Start or pause the timer
- Stop - Reset the timer to original time
- Break - Take a 5-minute break
 
- Complete your task when finished
- Open the Habit Tracker from the bottom navigation
- Add new habits with categories
- Click on grid squares to mark daily completions
- View your 30-day progress with GitHub-style visualization
- Navigate between habit overview and individual habit views
- Access Settings to browse 8 beautiful themes
- Choose from enhanced color schemes
- Experience seamless theme transitions
- Themes persist across sessions
- Access Settings to:
- Select from 8 stunning themes
- Toggle between light and dark modes
- Auto Start Feature for Windows & Mac
- P2P Task Sync Feature
- Export your data as JSON backup
- Import previously exported data
- Support the developer with "Buy Me a Coffee"
 
The WebRTC server handles signaling for peer connections:
# Default server configuration
cd webrtc-server
npm install
npm run startFor production deployment, configure your server settings in webrtc-server/server.js.
- 
Navigate to the WebRTC server directory cd webrtc-server
- 
Install server dependencies npm install 
- 
Start the signaling server npm run start 
The server will handle WebRTC signaling for real-time collaboration features. Make sure it's running before using collaborative workspaces.
For production deployment of the WebRTC server:
- Configure your production environment variables
- Set up proper CORS policies
- Use process managers like PM2 for server stability
- Consider using HTTPS for secure WebRTC connections
- Responsive design for mobile and desktop
- Touch gestures and mobile-optimized interactions
- Offline-ready with local storage persistence
- Fast loading with Next.js optimization
- Real-time collaboration that works across devices
- Fork the repository
- Create a feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add some amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
- Follow the existing code style and component patterns
- Add appropriate animations with Framer Motion
- Ensure responsive design works on all screen sizes
- Test all 8 themes for consistency
- Test WebRTC functionality with multiple peers
- Maintain accessibility standards
- Test subtask functionality thoroughly
Please use the GitHub Issues page to:
- Report bugs with detailed reproduction steps
- Request new features with clear use cases
- Discuss improvements and suggestions
- Report WebRTC connection issues
This project is licensed under the MIT License - see the LICENSE file for details.
- shadcn/ui for the beautiful component library
- Framer Motion for smooth animations
- Lucide for the icon set
- Tailwind CSS for the utility-first styling approach
- Next.js team for the amazing React framework
- WebRTC community for real-time communication standards
If you find this project helpful, consider:
- โญ Starring the repository
- ๐ Reporting bugs or requesting features
- โ Buying me a coffee
- ๐ฆ Following @Anoyroyc on Twitter
Coded with โค๏ธ by Anoy Roy Chowdhury
Focus โข Track โข Achieve โข Share