Patilerce
Patilerce is a website created for cat and dog adoptions. It has many features. After signing up and confirming their email, users can:
- Create new pet adoption listings.
- Save listings to their favorites.
- Ask and answer questions in the Q&A section.
- Chat privately with other users.
- Edit their profiles.
- Learn about different cat and dog breeds, complete with pictures and details.
All new adoption listings and Q&A posts must be approved by an admin before they appear on the site.
STACK
- javascript
- next.js
- css modules
- mongoDB
- next-auth
- aws s3
- jest
- react testing library
data:image/s3,"s3://crabby-images/efaa0/efaa037a3819a6b96494ac840d3540ac3a0c0c4a" alt="Patilerce Homepage"
Project Purpose
Patilerce was built to make pet adoption easier and more accessible. The main goal was to provide a platform where users can share and find adoption listings with ease. I also wanted to include features like a Q&A section and private messaging to create a sense of community. Admin approval ensures only high-quality and safe listings are published.
data:image/s3,"s3://crabby-images/83949/83949264031fc800e29d9049b476ba20f8f11ec2" alt="Patilerce Adopt Listings"
Stack
I chose Next.js because it has full-stack capabilities. For styling, I decided not to use any libraries or pre-made UI. Instead, I designed everything with pure CSS and used CSS modules to easily create unique class names.
Since the database for Patilerce is not very complex, I decided to use MongoDB, as it doesn't need relationships between data entries.
For authentication, I used the Next-Auth package and set up JWT for authentication, using bcryptjs to handle password security.
Since the website handles a lot of images, I integrated AWS S3 as an image container. With Next.js's built-in image optimization, the images load more efficiently.
data:image/s3,"s3://crabby-images/eeaeb/eeaeb09239dd561b7402e34e5665616c90a965af" alt="Patilerce Profile Page"
data:image/s3,"s3://crabby-images/55c9f/55c9f6411f1aed692676bdc3fc95dd30a1d793b0" alt="Patilerce Breed Info Section"
data:image/s3,"s3://crabby-images/e0017/e001737e58fb01eca3144ee73e457645a5bd2a42" alt="Patilerce Community Section"
data:image/s3,"s3://crabby-images/4bb52/4bb522bf9ce367b81b5cc2fe3e88caf9b727a82c" alt="Patilerce Login Page"
Challenges
Since Patilerce was my first big project, I faced many challenges. One of the biggest was making sure the authentication was secure. Using Next-Auth with JWT and bcryptjs was easy, but I had to be careful with user data and passwords. I learned how to manage tokens and keep passwords safe.
Another challenge was building the site without using pre-made UI components or libraries. I had to make everything from scratch, which took more time, but I had full control over the design and learned a lot about CSS.
Lastly, I had some trouble making the database structure work well, especially since I chose MongoDB. It’s flexible, but I had to plan the database carefully to make sure it could grow as the site did.
data:image/s3,"s3://crabby-images/5a062/5a06221a851793624eba7542bedad66f2e4e3946" alt="Patilerce Cat Breeds Page"
Lessons Learned
Working on Patilerce taught me several valuable lessons. I learned the importance of good planning, especially when building a design from scratch. It made me appreciate the time and effort that goes into creating a custom design and how crucial it is to understand CSS thoroughly.
I also learned how to handle authentication and passwords securely. It's important to manage user data carefully and use the right methods to ensure security.
Lastly, I learned the importance of planning the database structure from the beginning. Even with a flexible system like MongoDB, a well-designed schema is key to making sure the project can grow without issues.