This a phone catalog app built with Firebase, Next, React TypeScript and tailwindcss.
The fontend displays a collection of phones stored in Firebase and the user can see all the phone features by clicking on the items.
It also has a backend for admintrating the catalog that allows authenticated users to add, modify or remove items from the catalog.
Visit the Demo
Nice-to-have features:
- Cloudinary integration: Use cloudinary to get and upload product images.
- Pagination: add pagination to firebase request and UI.
- Add more product attributes: pseudoprice, highlighted, top_sales, created and updated timestamps...
- Product sorting and filters: Be able to sort by manufacturer, price and be able to filter by phone features.
- Unit and Integration tests: Install the dependencies, prepare the mocks and snapshots and write some tests.
- Improve admin auth: Change how session in handled in the client for something more persistent.
- Search: add search functionality.
- SEO: Use built-in seo Next capabilities and add schema metadata to html.
In order to connect with firebase you need to create some credentials and add them to and .env.local file.
Please follow any tutorial to create a firebase app in case you don't have one.
Then follow this instructions to create and setup a firebase service account.
Lastly follow the instructions of this tutorial to encrypt the service account and add the secrets and the generated Base64 to your .env.local file.
This last step is only necessary because due to an issue with environment variables in vercel.
Please take a look to the .env.local.example to see how environment variables are structured.
This is a Next.js project bootstrapped with create-next-app
.
First, run the development server:
npm run dev
# or
yarn dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying pages/index.tsx
. The page auto-updates as you edit the file.
API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.ts
.
The pages/api
directory is mapped to /api/*
. Files in this directory are treated as API routes instead of React pages.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!