This is the final capstone project for the Full Stack Developer Program at Microverse
Report Bug
·
Request Feature
- About the Project
- Frontend repository
- Project requirements
- Entity Relation Diagram
- Built With
- Live Demo
- API Documentation
- Usage
- Testing
- Kanban Board
- Authors
- Show your support
- Acknowledgements
- License
This is the final capstone project for the Full Stack Developer Program at Microverse.
The Home Sharing App is a fully responsive app that provides the service for connecting homeowners wanting to rent their properties and potential clients, enabling the creation of reservations for periods of time on selected properties.
The property owners can customize the terms of the rental for each property, which lets the app be used for short-term rental (like short vacations at the beach) or for long-term, enabling the app to point to different market segments.
The app was built with a Ruby on Rails backend and a React/Redux frontend, located on separate repositories.
This is the backend repository. Below you will find the link to visit the frontend repo.
To visit the frontend repository, please click on this link.
The basic project requirements are defined by Microverse and can be seen in this link.
User stories: In addition to the basic project requirements, a set of specific requirements was developed from a list of user stories, as shown below:
A) When I go to the home page:
- I can see a selection of the latest properties to rent on the home page, with 1 photo, property title, country, city, and rate.
- If I click on a photo or property title, I can see:
- The property title,
- The whole address,
- The category or categories assigned by the owner (beach, family, honeymoon, mountain, etc.),
- A big photo and several photo miniatures that can show bigger in a popup if clicked,
- A description,
- The guest_capacity, the number of bedrooms, beds, baths,
- The kind of property (house, apartment, villa, etc.),
- The size (must indicate what measurement unit is the size, mts2 or ft2, etc),
- The rate per night, week, month,
- The minimum period of time that the property rents for,
- The cleaning fee,
- A button or link to go to the reservation page for this property,
- A button or link to go back to the home page
- I can also see a select button to select a country to show properties for that country only.
- After selecting a country, I can see a title indicating the chosen country, and the list of properties for that country with 1 photo, property title, country, city, and the rate per night, week, etc. Also, inside a parenthesis, must be the minimum time for rent.
- After clicking on one photo or property title, I can see all the same information shown in A.2. But the button or link to go back must take me to the country list page.
- When I click the reservation button, I can see the fields to enter check_in and check-out dates (or a calendar to select dates), and also a field to enter the number of guests that will stay in the property (the entered number of guests must be greater than 0, and smaller or equal to the guest capacity of the property).
- I can see a “Check dates” button to check if the requested reservation period is available.
- After clicking on this button, I can see the messages: “The property is available for your requested dates” or “Sorry, the property is not available for your requested dates. Please try a different time period”.
- If there isn’t availability, I can enter different dates to start a new check with the Check dates button.
- I can also see a button to go back to the properties list (home page or country list page).
- If there is availability, the page also shows the total amount to pay for the reservation.
- The page shows a “Reserve” button if there is availability.
- If I click the “Reserve” button, that takes the user to a page for signing up (with name, email, and password) or logging in (with email and password).
- After successfully sing up or logging in, the page opens again the reservation page with the reservation information (user name, property title, check-in and check-out dates, total amount to pay). It shows also a confirmation message with the reservation ID and tells the user that an email will be sent to her/his email address with instructions for paying the reservation.
- If the user was already logged in, the signup or log-in is skipped.
B) In the navbar I can see a button or link to “Become a Host”. If I click this button I will see:
- The page for signing up (with name, email, and password) or logging in (with email and password).
- After successfully sing up or logging in, I can see a form to upload all information and photos for a new property (see A.2).
- If the user was already logged in, the “Become a Host” button takes the user directly to the form, without requesting sign up or log in.
- After entering the new property info, the page shows the homepage and a message with: “Thank you for uploading your property”.
- There must be an option for the property owner to block periods of time to avoid users to make reservations on those periods.
C) In the navbar I can see also buttons or links to sign up, log in, and log out.
D) In the navbar I can see a button to show the list of all uploaded properties for the logged-in user. After clicking this button, the page shows the list of property names uploaded by the logged-in user. Each name is a link to the show page of the property. If a name is clicked, the page will show:
- The name of the property,
- A button for updating general information,
- A button for deleting the property from the list,
- And a "Block periods" button for creating blocked periods.
- If the "Block periods" button is clicked, the page shows a form with two input fields (or a calendar) to enter start and end dates for the block period, and a button to save the new blocked period. After saving the blocked period, the page shows again the list of uploaded properties for this user, which contains a button to navigate to the homepage.
E) In the navbar I can see a button to show the list of all the reservations created by the logged-in user, with the name of the property, reservation Id, and a button to delete it.
This project was built using these technologies:
- Ruby
- Ruby on Rails
- React
- Redux
- HTML
- CSS
- JavaScript
- PostgreSQL, pgAdmin 4
- JSON Web Token (JWT)
- API integration
- Adobe Illustrator
- Adobe After Effect
- Rubocop
- Capybara
- Rspec
- OpenApi(Swagger)
- GitHub, Gitflow
- Visual Studio
To visit the live API site, please Click here.
To see the API documentation, please Click here.
Notice: to be able to interact with the documentation sections you need to create a user with name, email and password. After it you will need to log-in and pick the sent token and enter it in the Authorize section (bearerAuth (http, Bearer)).
To have this app on your pc, you need to:
- Clone with SSH:
git@github.com:Home-Sharing-Team/final-capstone-Project-Back-End.git
- Clone with HTTPS
https://github.com/Home-Sharing-Team/final-capstone-Project-Back-End.git
-
In the project directory, you can run:
-
bundle install
- installs all the dependencies required by the project -
rails db:create
- create a database in your local machine -
rails db:migrate
- run migrations -
rake db:seed
- insert the seed data in the new database -
rails s
- to run the Ruby on Rails server and launch your browser to see the project
-
Before running the test command, please make sure you have run rake db:seed
To run the test in your terminal, please type: rspec spec/capybara
Link to the project Kanban board: Click here.
Link to the screenshot of the initial state of the Kanban board: Click here.
The final number of team members for this project is: 4
👤 Ulises Largaespada
-
GitHub: @ulisesedu7
-
Twitter: @LongswordMusic
-
LinkedIn: Ulises Largaespada
👤 Gabriel Santo
-
GitHub: @gvgesanto2
-
Twitter: @GabrielSanto997
-
LinkedIn: Gabriel Santo
👤 David Verde Alvarez
👤 Dario Alessio
-
This is My Slack: https://microverse-students.slack.com/team/U039GCFRK9B
-
This is My LinkedIn: https://www.linkedin.com/in/dario-alessio-3a3b7911b
Give a ⭐ if you like this project!
- Based on the design by Murat Korkmaz on Behance.
- Hat tip to anyone whose code was used
- Microverse
- Our supportive families 😊
This project is MIT licensed.