This is a T3 Stack project bootstrapped with create-t3-app
.
We try to keep this project as simple as possible, so you can start with just the scaffolding we set up for you, and add additional things later when they become necessary.
If you are not familiar with the different technologies used in this project, please refer to the respective docs. If you still are in the wind, please join our Discord and ask for help.
To learn more about the T3 Stack, take a look at the following resources:
- Documentation
- Learn the T3 Stack — Check out these awesome tutorials
You can check out the create-t3-app GitHub repository — your feedback and contributions are welcome!
Follow our deployment guides for Vercel, Netlify and Docker for more information.
https://api.pokemontcg.io/v2/cards?q=(id:"swsh10-46" OR id:"swsh11-79")
[x] Display list of sets [x] Display list of cards in a set [x] Migrate data to PG [x] Fix pagination (https://github.com/hqasmei/youtube-tutorials/blob/main/shadcn-pagination/src/components/client-pagination.tsx) [x] Add search [x] Clean up Suspense and search bar [x] Attach user creation to webhook and save to local db [x] Clean DB of cards with null data [x] Display list of all cards [x] Let a user create a collection [x] make user create username upon creation (redirect until done) [x] Fix set list and card to accommodate api fxn argument update [x] Add table indexes (Vercel Postgres has it on id by default?) [x] Create dashboard [x] Let user create a trade list [x] Add top progress bar [x] Seperate types to seperate file [x] Find trade [x] Send trade request [x] Show UI notification [x] Have new trade list show up when creating new trade list [x] Update Trade page when a trade request is made [x] Update buttons on Trade list once status is changed [x] Add confirmation toast after user requests trade [x] Sub Lists show up in normal Sets/Cards popups. Probably don't want that [x] Redo pagination [x] tooltip doesn't overflow modal [x] View options for cards (sort, list/pics) [x] View Collection/Wish List [x] Dashboard list pagination not hooked up to db [x] Correct +/- on card list tables [x] make mobile friendly (responsive tables) [x] Finish trade flow (paginate lists, +- on table) [x] Add sort by price [x] autogenerate public tradelist after user enters username [x] Lock trade on Complete and +1 trade to each user [x] Add trade stats [x] Let users share trade lists [x] Build out Notifications page [x] move to Auth.js [x] in trade list, make a separate list for completed trades [x] completed trades still show up in potential trade lists (for now don't update users wish lists and make note of it in UI) [x] trades should have a last updated field to show last time trade was updated [x] Convert queries to prepared statements, Get away from raw queries [x] Dockerized DB [x] Containerize app [x] Add spinners [x] user shouldn't be able to select a list unless it has at least 1 card (update: decided that even if we did that, user can still empty out the list) [x] pretty up modal [x] verify prod build [x] hearts on card list view [x] deploy to AWS [x] loading bar for search [x] users should be able to message each other during a trade [] tests [] price sorting not hooked up to In Collection and Wish List [] Proper error handling on the database side with respective messages on the UI [] handle when adding variations of same card. Currently doesn't differentiate between holo/normal/reverse/etc [] Limit # of public lists for non-premium users [] Optimize trade search [] Realtime updates on trade page [] find a way for next build to ignore one file instead of ignoring all typescript errors (might not matter as not deploying in Vercel) [] Go through all sets to make sure cards are in order and all show up [] drizzle.config.ts to better handle url? [x] Consider how to deal with deletions when there's foreign keys (ie trade table relies on trade lists which user may want to delete (update: don't let them delete but hide trades after a certain time))
Shortcomings -only main variants. Basically, official checklist so won't have variations like cosmos -the prices are by TCGPlayer market but sometimes those fields are null so have to go by another field which sometimes results in some weird results when sorting. Tried to go by low but there are some entries that are obviously off so sticking to market. If price is null, check eBay last solds for comps. If it already hasn't happeed yet, there will be an ability to manually change the price during a trade -English only
https://tocalai.medium.com/pagination-on-tanstack-table-under-next-js-787ed03198a3 https://medium.com/@ctrlaltmonique/how-to-use-usecontext-and-usereducer-with-typescript-in-react-735f6c5f27ba https://www.youtube.com/watch?v=TLGFTH4s_0Y