✅Practical Task Assessment
Create a Personal Portfolio Tracker Web Application
🛠 Tech Stack:
● Front-End: React.js / Next.js
● Back-End: Node.js (Express.js)
● Database: MongoDB or PostgreSQL (choose one)
🛠 Task Requirements
1. User Authentication
🛠 Signup Page:
Create a form with the following fields and validation:
Field Validation Rules
First Name Only alphabets
Last Name Only alphabets
Email ID Valid email format
Password Minimum 6 characters, use a custom pattern (e.g. 1 capital, 1 special
char)
Mobile Only digits, 10 digits preferred
Number
Profile Image Upload image file (PNG/JPEG, file extension validation)
Date of Birth User should be 18+ years old
🛠 Login Page:
Form fields:
● Email
● Password
Implement JWT-based authentication. On successful login, send a JWT token from the
backend and store it in the frontend (e.g. localStorage or HTTP-only cookies). Use this token
for accessing protected routes.
2. Dashboard (Protected Page)
Authentication required to access this page. After login:
🛠 Header (Reusable Component):
● Profile Picture
● User initials (e.g., John Doe → JD)
● Logout button
🛠 Main Section:
● Show user details in a Card View (profile image, name, email, DOB, phone, etc.)
● Include a “View Portfolio” button.
🛠 Portfolio Popup:
On clicking the View Portfolio button:
● Open a Modal.
● Display a Kendo UI Graph using dummy data from a given endpoint.
🛠 Portfolio Graph
Endpoint Structure for Graph Data
1. Daily - https://your-data-domain/endpoint?tenure=Daily
2. Weekly - https://your-data-domain/endpoint?tenure=Weekly
3. Monthly - https://your-data-domain/endpoint?tenure=Monthly
4. Quarterly - https://your-data-domain/endpoint?tenure=Quarterly
5. Yearly - https://your-data-domain/endpoint?tenure=Yearly
● The data is open to all users (authentication not required).
● Format is based on provided JSON.
● Use Kendo UI React Charts to build the graph.
● Implement a custom tooltip on hover based on provided screenshots.
🛠 Project Structure & Guidelines
🛠 Frontend (React/Next.js)
● Use modular component structure (Header, Card, Modal, Graph etc.)
● Reusable hooks and services
● Responsive UI (use Tailwind CSS, Material UI, or Chakra UI)
● API service layer using Axios or Fetch
● Routing (Next.js routing or React Router)
● For State management use Zustand / Redux
🛠 Backend (Node.js + Express)
● Follow MVC Architecture
○ Models: MongoDB or PostgreSQL (via Mongoose or Sequelize/Prisma)
○ Controllers: Business logic
○ Routes: Clean endpoint structure
● JWT Auth Middleware
● Multer (for image uploads)
● Validate fields with Joi or Express Validator
🛠 Database
Use either:
● MongoDB (with Mongoose)
● PostgreSQL (with Sequelize or Prisma)
🛠 Security
● Password hashing with bcrypt
● Validate JWTs using jsonwebtoken
● Limit file upload types
● Handle edge cases (invalid user, duplicate email, expired token, etc.)
🛠 Hosting
● You may host using any nginx-compatible free provider such as:
○ Render
○ Vercel (for frontend)
○ Netlify
● Ensure frontend and backend are deployed, and provide access credentials (if
required)
🛠 Deliverables
1. GitHub Repository with:
○ Clear folder structure
○ .env.example
○ README with:
■ Setup steps for frontend & backend
■ Tech stack
■ Postman collection or API testing instructions
■ Example credentials (if seeding is done)
2. Live URL(s) for frontend and backend (if deployed)
🛠 Guidelines
● Break down the app into meaningful modules and components
● Focus on reusability and scalability
● Keep code clean and readable
● Do NOT use ChatGPT or AI tools to build the app – this task is a test of your own
creativity and technical flexibility
● Ensure the application is production-ready