Skip to content

Latest commit

 

History

History
91 lines (72 loc) · 4.35 KB

README.md

File metadata and controls

91 lines (72 loc) · 4.35 KB

Trek Tracker

Welcome to Trek Tracker! Here you can search for trails near you, upload photos, and see others! Trail pages feature crowd-sourced photos, Google maps location, trail description, and local weather report. Any picture can be viewed in association with a user or trail, but you need to login with a Google or Facebook account in order to submit photos.

Getting Started

  • First and foremost, in the root of the repo npm install.

Steps:

  • I. Initialize the database:
    • -make sure mysql and mysql2 is install locally
    • -run mysql.server start
    • -run mysql -u student
      • -If there is no student profile, create one with the password 'student', otherwise the database/config.json development object can be changed to a username and password currently existing. For the default mysql profile, change username to 'root', and password to an empty string.
      • -If there is no server profile, create one with the password 'serverpass'
    • -create a database for this app by running the following command in the mysql shell opened from the previous step: CREATE DATABASE TrekTracker
    • -the tables and are automatically built with the correct columns if they do not already exist
    • -Database is good to go!
  • II. Input credentials for passport:
    • -In the passport folder, open example.config.json and make a copy of it: rename it to config.json
    • -Obtain Google and Facebook OAuth credentials. Once you have those: in config.json: fill in the respective client ID, secret and callback URL (for the callback URL you most likely will use localhost:3000 in the "FILL_ME_IN" part).
  • III. Enable the Google+ API in your Google API library for this project only if you obtained the Google OAuth credentials.
  • IV. Transpile the code:
    • -in a new terminal tab, run npm run react-dev
  • V. Start the server
    • -in a new terminal tab, run npm run server-dev
  • VI. Open in browser
    • -open a new web browser window and navigate to localhost:3000

Program Architecture

Client

  • In the index.jsx, the flow of the program is controlled with react router dependent rendering.
  • Without logging in, users can see trails in the Home component and display the associated posts after clicking view posts.
  • After logging in, the upload component becomes available in Trail.jsx

Server

  • api-router
    • /currentUser
    • /posts/[users || trails]
      • posts to, or gets from, the database Posts table. They can be queried to return wither a list of posts by a particular user, or from a specific trail.
    • /trails
      • posts to, or gets from, the database Trails table. They can be queried to get all trails currently stored, or a specific trail by id.
  • auth-router
    • for redirect to authenticate via users' Google or Facebook profiles

Database

APIs

  • Imgur
    • stores images, a URL is returned, which is then stored in the database along with additional metadata
  • Google maps
    • to displays a google map on the page to be populated by nearby trails
  • Trails
    • gets all nearby trails, to then be placed in the rendered map

Built With

Authors

Clarissa.js Team:

SisterMother Team:

Acknowledgments

  • Hat tip to SisterMother whose legacy code was used
  • TrailAPI.com