Skip to content

Latest commit

 

History

History
113 lines (73 loc) · 3.03 KB

README.md

File metadata and controls

113 lines (73 loc) · 3.03 KB

Sharepin - Image Sharing App

Sharepin is a photo sharing social media application (inspired by pinterest and unsplash).

screenshot

Key Technologies

  • node v14.18.1
  • npm 6.14.15
  • react.js
  • google authentication
  • sanity.io
  • tailwind css
  • netlify

Dev Setup

To get this project running locally, you will need to configure your environment variables in which will require you to create an account with Sanity and Google Cloud.

Getting Started

  1. Fork or clone this repository
  2. cd sharepin-social-media
  3. Follow 'Backend Setup w/Sanity'
  4. Follow 'Frontend Setup w/Google'
  5. cd instashare-frontend
  6. Run npm start

Backend Setup w/Sanity

  1. cd instashare_backend
  2. npm install -g @sanity/cli
  3. sanity install
  4. sanity login
    • Select login type
  5. sanity init
    • Select to create new project
      • Enter (Y) to use the default dataset configuration.

To start the development server for Sanity Studio, run this command: sanity start

Next, you will open the Sanity project management UI where you can add API token and CORS origins.

In your terminal, run sanity manage to get started.

Add API Token

API > Tokens > Add API Token

  • Enter a name and select 'Editor' for permissions then save.
Add CORS origin

API > CORS origins > Add CORS Origin

Frontend Setup w/Google

  1. cd instashare_frontend
  2. npm install
  3. Create google client ID
Create Credentials

APIs & Services > Dashboard > Credentials

  • Click 'Create credentials' > Select 'OAuth client ID' > Click 'Configure consent screen'

    • Select 'external' for user type then create to enter the 'App name' and User support email'.

    • Click 'Add domains' to enter email address then save and continue.

      Go back to the dashboard > OAuth consent screen

      • Click 'Publish App' then confirm.

Using your dashboard, navigate to 'Credentials' page to grab your client ID.

Note: If the OAuth Client ID was not auto-generated, you can manually create it by clicking the 'create credentials' button. For this project, you will select 'application type' as web application and add http://localhost:3000 as the URI. The Client ID will generate once you click the 'create' button.

Configure Environment Variables

To create a new .env file, run touch .env

Copy and paste the following variables then configure your environments:

REACT_APP_SANITY_TOKEN=
REACT_APP_SANITY_PROJECT_ID=
REACT_APP_GOOGLE_API_TOKEN=

In /instashare_frontend, run this command: npm start

http://localhost:3000/login