Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ibhavikmakwana/manch

Trying to develop an open source social media app
https://github.com/ibhavikmakwana/manch

dart flutter social-network supabase

Last synced: 3 months ago
JSON representation

Trying to develop an open source social media app

Awesome Lists containing this project

README

        

# Social Media App (नाम में क्या रखा है :P) [![Analyze](https://github.com/ibhavikmakwana/manch/actions/workflows/analyze_actions.yml/badge.svg)](https://github.com/ibhavikmakwana/manch/actions/workflows/analyze_actions.yml)

[![All Contributors](https://img.shields.io/badge/all_contributors-1-orange.svg?style=flat-square)](#contributors-)

## Screenshots

| Login | Login Error | Sign up |
| ------------------ | --------------------------- | ------------------ |
| Screenshot | Screenshot | Screenshot |

| Edit Profile | Filled Edit Profile | Profile |
| ------------------ | --------------------------- | ------------------ |
| Screenshot | Screenshot | Screenshot |

## Getting Started

To run this Project you'll need an account on the [Supbase](https://app.supabase.io/).

1. After creating an account run below query from the Supabase SQL editor to create required table.

```dart
-- Create a table for Profiles
create table if not exists profiles (
id uuid references auth.users on delete cascade not null,
updated_at timestamp with time zone,
created_at timestamp with time zone,
user_name text unique,
email text unique,
name text,
avatar_url text,
website text,
about text,

primary key (id),
unique(user_name),
unique(email)
);

alter table profiles enable row level security;

create policy "Public profiles are viewable by everyone."
on profiles for select
using ( true );

create policy "Users can insert their own profile."
on profiles for insert
with check ( auth.role() = 'anon' );

create policy "Users can update own profile."
on profiles for update
using ( auth.uid() = id );

-- Set up Realtime!
begin;
drop publication if exists supabase_realtime;
create publication supabase_realtime;
commit;
alter publication supabase_realtime add table profiles;

-- Set up Storage!
insert into storage.buckets (id, name)
values ('avatars', 'avatars');

create policy "Avatar images are publicly accessible."
on storage.objects for select
using ( bucket_id = 'avatars' );

create policy "Anyone can upload an avatar."
on storage.objects for insert
with check ( bucket_id = 'avatars' );

create policy "Anyone can update an avatar."
on storage.objects for update
with check ( bucket_id = 'avatars' );
```

2. Go to `Authentication` => `settings` and make sure `Disable email confirmations` is Active or Enabled.
Screenshot 2021-07-31 at 11 05 09 AM

3. After successfully running above query get the Base url and Base key and pass it to the command line args. while running flutter app.

```dart
flutte run --dart-define=BASE_URL=supabase_base_url --dart-define=BASE_KEY=supabase_base_key --dart-define=OAUTH_CLIENT_ID=oauth_client_id
```

That's it! You'll be able to run this app, Ping me if you stuck on any step.

Let's create an open source alternative of the social media apps out there together.

## Generating files
- `flutter pub run build_runner build`
> If code generation fails, consider running it with the flag `--delete-conflicting-outputs`

## Design Credit
https://www.figma.com/proto/pVVxJrrPmgo2OR2D5yEj0o/dianfei-SocialAppUIKit-Updated-(Community)?node-id=25%3A1577&scaling=min-zoom

## Contributors ✨

Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):



Sudhanshu Mittal
Sudhanshu Mittal

💻

This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!