Plan your next getaway.
- Thuan Tran - Software Engineer
- Travis Tillman - Software Engineer
- David Inoa - Software Engineer
- Henry Neale - Software Engineer
Used for managing trips for individuals. Allows a user to search the events, restaurants, activities around the destination place. Users can also save their trips and collab with other users.
- Node
- Express
- React
- Mongo DB
- mongoose
- Passport
- body-parser
- Axios
- bluebird
- passport-local
- react-dom
- webpack
- babel
- react-router-dom
- bootstrap
Once you have forked the repo from https://github.com/bestpikachu/Voyage, install all the dependencies.
From within the root directory:
npm install npm run react-dev npm run server-dev
Inside /server/config/config.js, create a new file named "config.js". Inside this file you will want to have to following:
'module.exports = { YELP_API_KEY:"", EVENT_BRITE_API_KEY:""
}'
We use google to authenticate, so your app with need google credentials to properly implement authentication. There are links below to get your google credentials.
- Google developers website: https://console.developers.google.com/
Below is the format:
'module.exports = { googleAuth: { clientID: '', clientSecret: '', callbackURL: '' } }'
React, Axios, and React-Router were used heavily in the creation of this project. During the initial stages of this project we had a general idea of the direction of the project but did not know whether to go with an SPA design or not. This led to some back-tracking and re-writing of code, as well as making one of our pre-existing files obsolete. There is an index.jsx file left over from during our re-write process.
The search bar is a simple input field implemented as a stateful component to pass data back to the parent component. It is set to update its value upon any change made inside the field, and its state will update upon pressing the return key or on deselection of the field (onBlur).
The app.jsx file is the new top-level container for the app. Ideally when integrating React-Router, the View would only change upon successful receipt of data back from the server. However, as we were unable to successfully implement this function into the App file, the alternative was to change the state of the view which would then cause the Trip View to render in place. This is done without the use of React-Router inside of the "go" function.
React-Router is more seamlessly integrated into the TripView. The <BrowserRouter>
tag acts as the parent <div>
and maintains the history of the page. This allows <Route>
, <Link>
, and <Switch>
to work as intended as all of the aforementioned tags require the user's browser history. This will also allow future integration of the "back" and "forward" browser features to allow users to backtrack or trace their history.
Upon search the server listens for post requests to the following endpoints:
- /Eat [YELP]
- /Sleep [YELP]
- /Party [Event Brite]
- /Explore [YELP]
The user's search input determines which endpoints are hit. Whenever an endpoint is hit, a GET request is made to the corresponding API, and the data from the API is returned to the client. Helper functions for the API requests are located in server/utils.js
In the future a user will be able to log in and save their trips to a database and then retrieve them later (see database/index.js and also the commented out code in config/passport-setup.js).
See CONTRIBUTING.md for contribution guidelines