Skip to content

JasonStieber/TrekTracker

 
 

Repository files navigation

Trek Tracker

Welcome to Trek Tracker! Here you can search for trails near you, upload photos, and see others! Pictures can be viewed in lists which are either associated with a user or trail. Any picture can be viewed, but to submit a new photo, you need to login with a Google account.

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 OAuth credentials. Once you have those: in config.json: fill in your 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 loggin in, users can see trails in the Home component and display the associated posts after clicking view posts.
  • After loggin 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 profile

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

Deployment

Add additional notes about how to deploy this on a live system

Built With

Authors

See also the list of contributors who participated in this project. The commits here are inaccurate and do not reflect the amount of work each member put in.

Acknowledgments

  • Hat tip to anyone who's code was used
  • Inspiration
  • etc

About

Find local hikes with cool features!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 96.9%
  • CSS 3.1%