data:image/s3,"s3://crabby-images/c7ef9/c7ef92356cf2adb3fdf8fc9d4e9777edaff60f1b" alt="profile"
Hello 👋, My name is Rajat Bhatt
I am a full stack web developer. Welcome To my portfolio.
Explore myExperience
Senior Software Engineer
Bacancy Technogy
- Worked as a full stack developer in a SaaS product JulesAI
- Developed UI components using React, Material UI, TypeScript, and Apollo Client.
- Implemented GraphQL endpoints with Apollo Server, used Knex.js for SQL queries, and PostgreSQL for data storage.
- Worked on a feature where we implemented an email composer like Gmail to send emails to customers from the app.
- Fixed a critical bug related to file upload in Google Cloud which improved file upload time by around 2 seconds.
Systems Engineer
Tata Consultancy Services
- Worked on a complete revamp of a marketing site for a US based banking company, resulting in a 30% increase in user engagement.
- Worked as a web developer using React & NextJS to build content driven sites using headless CMS like WordPress, Contentful, Strapi CMS
- Focused on improving accessibility and core web vitals using Google's lighthouse tool
Skills
- React
- Typescript
- NextJS
- NodeJS
- Tailwind
- Postgres
- Git
- GraphQL
- REST
Browse my Personal Projects
data:image/s3,"s3://crabby-images/0e653/0e65385308cacaf0d088322a513cdcbfdaa71a6e" alt="Short It"
Short It
- It is a url shortener application like bitly & dub.sh.
- Created using Next.js 14, React Server components and Server actions.
- Uses Redis (Vercel KV) to store the urls. Since It is an in memory database it queries data much faster than Disk based databases.
- Uses Next auth & github Oauth to implement authentication. It has also implemented protected routes so anonymous user can't access it.
- It also uses Next.js dynamic routes & route handlers to implement the redirect logic
data:image/s3,"s3://crabby-images/08e54/08e54bc99ca2d088f1704349029ab62687ae45d5" alt="The chocolate shop"
The chocolate shop
- An e-commerce application created using Next.js 13, PostgreSQL, Tailwind CSS and Stripe checkout.
- Used React server components for better SEO and performance
- Added Persistent shopping cart using localStorage
- Added Stripe checkout for payment and shipping info
- Used Supabase for storing product data in Postgres db and image storage using supabase buckets
data:image/s3,"s3://crabby-images/2e732/2e732c958f4d2fea141ae66e75408db487fa49e8" alt="Type Challenges Progress Tracker"
Type Challenges Progress Tracker
- This is a companion app for the popular Type challenges repository. Since the original repo does not provide a good way to track the progress, I made this to keep track of my progress while solving typescript challenges.
- It uses local storage to store the progress.
- Implemented filters using query parameters in the URL as a best practice
- Created with Next.js 14 & Tailwind CSS. Also added dark mode
data:image/s3,"s3://crabby-images/a3652/a3652aa9c0a9b630c0ec4e13f9f26324681ca24b" alt="Next.js Starter kit for production apps"
Next.js Starter kit for production apps
- Created personalized Next.js starter kit for setting up common quality of life improvements on top of standard create-next-app installation.
- Added Prettier tailwind plugin for automatic class sorting
- Extended eslint with eslint:recommended, typescript-eslint, react, react-hooks & typescript-sort-keys
- Add automatic import sorting plugin in prettier to sort all the imports alphabetically
- Updated project specific settings.json for vscode to enable more settings (Mentioned in readme)
data:image/s3,"s3://crabby-images/d488e/d488ee5b3603ebfeb5ba87599acc0c982d310d2e" alt="Country Finder"
Country Finder
- A Web app which shows countries data using Rest Countries API to fetch data of all the countries in the world.
- Implemented skeleton loader using suspense and next routing
- Added dark mode
- Since the third party Rest countries API does not provide pagination, it uses Intersection Observer to add client-side infinite scrolling