https://github.com/harshmangalam/supabook
  
  
    Social media web app build with nextjs and supabase 
    https://github.com/harshmangalam/supabook
  
chakra-ui nextjs react-hook-form react-icons reactjs social-media supabase-js swr typescript yup
        Last synced: 9 months ago 
        JSON representation
    
Social media web app build with nextjs and supabase
- Host: GitHub
- URL: https://github.com/harshmangalam/supabook
- Owner: harshmangalam
- Created: 2022-08-13T01:20:39.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-08-20T05:18:31.000Z (about 3 years ago)
- Last Synced: 2025-02-06T11:16:46.552Z (9 months ago)
- Topics: chakra-ui, nextjs, react-hook-form, react-icons, reactjs, social-media, supabase-js, swr, typescript, yup
- Language: JavaScript
- Homepage: supabook-navy.vercel.app
- Size: 298 KB
- Stars: 10
- Watchers: 1
- Forks: 7
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
 
Awesome Lists containing this project
README
          # Supabook - Nextjs Supabase Social Media Web App
[Deployed on vercel](https://supabook-dev.vercel.app/)
## Tech Stack
- Nextjs
- Supabase
- SWR
- Chakra UI
- Typescript
- React icons
- Yup
- React hook form
## Features
- Authentication
  - [x] Signup
  - Login
    - [x] Login with email and password
    - [x] Login with magic link
    - Oauth login
      - [ ] Login with Google
      - [ ] Login with Facebook
      - [ ] Login with Github
      - [ ] Login with Linkedin
      - [ ] Login with Spotify
      - [ ] Login with Apple
  - [ ] Password reset
  - [x] Protected routes
- Post
  - [x] Create post
  - [x] Delete post
  - [ ] Like post
  - [ ] Like count
  - [ ] Comment count
  - [ ] Comment post
  - [ ] Share post
  - [ ] Share count
  - [ ] Tag friends
  - [ ] Share live location
  - [ ] Bookmark post
  - [x] Show author profile from post
- Friends
  - [x] Show friends list
  - [x] Show friends request sent list
  - [x] Show friends request received list
  - [x] Send friend request
  - [x] Accept friend request
  - [x] Ignore friend request
  - [x] Cancel sent friend request
  - [x] Unfriend friend
  - [ ] Show friends of friends
- Profile
  - [x] Profile information
  - [x] Friends information
  - [x] Posts information
  - [ ] Edit information
  - [x] Update profile pic
  - [x] Authorize user can update profile pic and profile info
  - [x] Friends count
  - [x] Posts count
- [x] Dark theme
- [ ] Settings
- [ ] Realtime Chat
- [ ] Post details
- [ ] Video calling using webrtc and simple-peer
- [ ] Screen sharing
- [ ] Show all users around coordinate
- [ ] show all friends around there on map coordinates
- [ ] show posts on map coordinate
## Supabase
In this project i have used supabase for
- Database
- Storage
- Authentication
When someone create their account it internally use supabase authentication and also create new row in profile table that extend the user details like profile pic, name , etc...
When authenticated user create new post the data go into supabase post table and if it contain image then first it store to supabase storage and then their path and signed url get stored in post table.
Any authenticated user can visit their profile and change their profile avatar that get stored in supabase storage in avatar folder.
## Supabase Authentication
- Signup using email and password also provide name to be displayed in post and profile
- Login using email and password
- Login using magic link. Magic link will sent to email address and get authenticated when user click on that link
- Upcomming Oauth authentication using google,github,linkedin , etc...
- Supabase authentication is easy to use and utilize.