Skip to content

COVID19 Global Hackathon /// To support local businesses, we’re creating a map layer for crowdfunding campaigns so ppl can see the businesses near them raising survival money online -- giving businesses access to and helping them maintain a loyal consumer base.

Notifications You must be signed in to change notification settings

SidhaantAnand/support-local-businesses-app

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SaveSmall.org

Struggling to survive, small businesses are turning to crowdfunding. S.O.S. pulls together local campaigns into a single view so neighbors can easily support the businesses they love.

Live Demo

intro

Small businesses (restaurants, bars, cleaners, etc.) are suffering. Many will go broke during quarantines and all will struggle to get business back afterwards. This not only affects the owners, but the employees of those businesses and ultimately the patrons. Our over-arching goal is to help small businesses weather the storm in the short term and be positioned to recover and thrive in the long term by (a) helping the businesses know who their most supportive patrons are, and (b) providing a method for consumers to see their local businesses in need and link out to funding/support mechanisms (e.g. TipJar, GoFundMe, etc.). You can read more about the project here

todo

core features:

  • Would be really cool if, after you submit your email address, that button turns green and from "Support" to "Supporter"
  • Map: Hovers on top of businesses and click scrolls you to that business and pops open the Support section
  • Integrate map
  • Clam your business/Add campaign - link to Airtable form
  • Integrate airtable with support the business form
  • Filters
  • Zooming in on map changes search
  • Change screen update so that results are added onto the bottom of the array
  • Add to instructions, especially related to .env and keys and Airtable accounts, etc.

bugs

  • Search by keyword, reset after first search
  • Map update
  • Display images

improvements

  • Map: auto-scale the map to match the actual results of the search so the used area is as big as possible
  • Need to add a captcha for the email submission
  • Find/scrape campaign info binded with a place and put it to the Airtable as a starting point
  • Update "Supported" logos on page with results of the ones you have supported already (for return visitors)
  • Deal with paging of results so user can get more by scrolling down page
  • Put a button underneath the map. “Redo Search for Visible Map Area”
  • Styling, styling, styling
  • Figure out if we can bring up GoFundMe embed without leaving page
  • Move some logic to the back end eg. Airtable search
  • Add props validation
  • Lint all the components/views
  • Delete node_modules folder and run just to make sure all the required files are in package.json

tech stack

  • react v16.3
  • react-router v5.1.2
  • react-mapbox-gl v5.2.3
  • axios v0.19.2
  • airtable v0.8.1
  • node-sass v.4.13.1
  • react-select v.3.1.0
  • d3-ease v1.0.6
  • react-places
  • react-places-autocomplete
  • turf-point
  • ...a lot of React

development

  1. Start with cloning the git repo git clone https://github.com/Ilnicki010/support-local-businesses-app.git &&support-local-businesses-app
  2. You need to install all dependencies using npm install --save
  3. Create .env file as follows
REACT_APP_AIRTABLE_KEY= airtable api key
REACT_APP_AIRTABLE_BASE= id of your airtable base
REACT_APP_AIRTABLE_CLAIM_BUSINESS_TABLE= table name for businesses(*1)
REACT_APP_AIRTABLE_WAITING_LIST_TABLE= table name for emails(*2)
REACT_APP_GOOGLE_API_KEY= google api key
REACT_APP_MAPBOX_KEY= mapbox api key

(*1) The table must have columns named exactly like that: “google_places_id”, “gofundme_url”, “place_name”, “is_verified”, “phone_number” and “email”. (*2) The table must have columns named exactly like that: "placeName", "placeId ", "email".

  1. Run development server using npm run start

npm scripts

  • npm run start run app in development mode (default port: 3000)
  • npm run build build for production
  • npm run lint lint all js/jsx files

About

COVID19 Global Hackathon /// To support local businesses, we’re creating a map layer for crowdfunding campaigns so ppl can see the businesses near them raising survival money online -- giving businesses access to and helping them maintain a loyal consumer base.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 84.1%
  • CSS 12.3%
  • HTML 3.6%