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.
- 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.
- -Go to: https://console.developers.google.com/apis/library
- -Select the appropriate project (in this case, TrekTracker)
- -Click on Library --> Google+ API --> then click on ENABLE
- IV. Transpile the code:
- -in a new terminal tab, run
npm run react-dev
- -in a new terminal tab, run
- V. Start the server
- -in a new terminal tab, run
npm run server-dev
- -in a new terminal tab, run
- VI. Open in browser
- -open a new web browser window and navigate to
localhost:3000
- -open a new web browser window and navigate to
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
Add additional notes about how to deploy this on a live system
- React - The web framework used
- NPM - Dependency package management
- AXIOS - Handle server calls
- BABEL - code transpiler
- CHAI - testing
- MYSQL - database
- PASSPORT - authentication
- SEQUELIZE
- Jacob Penney - OneCent01
- Thomas Volk - tvolk131
- Brendan Bansavage - brendanusa
- Samuel Davis - Sam0064
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.
- Hat tip to anyone who's code was used
- Inspiration
- etc