/zillow-clone

A Zillow clone that help search thousands of for-sale homes and connect with local professional real estate agents.

Primary LanguagePython

🏠 Yillow

The leading real estate marketplace. Search thousands of for-sale homes and connect with local professional real estate agents.

Yillow Live Demo

Splash Page

Screen Shot 2022-06-15 at 7 57 20 AM

Google Map Search and filter

Screen Shot 2022-06-15 at 7 58 25 AM

Browse Properties and Schedule Appointments

Screen Shot 2022-06-15 at 7 59 13 AM

Manage Appointments

Screen Shot 2022-06-15 at 8 00 27 AM

Search and Review Agents

Screen Shot 2022-06-15 at 8 01 03 AM

Screen Shot 2022-06-15 at 8 01 15 AM

Yillow at a Glance

Yillow is a full stack application that allows users to search and filter for properties. A user does not need to log in to use the search property and agent feature, but if they choose to setup an account with Yillow, they can also schedule appointment to tour the properties, and review their experience with the agent.

Getting Started

  1. Clone the repository
git clone git@github.com:frances-y-h/yillow.git

  1. Install dependencies
  • In root folder, install Python server.
pipenv install
  • Navigate to React-app folder, install React
cd React-app
npm install
  1. Setup your PostgreSQL user, password and database
psql
CREATE USER yillow_app WITH PASSWORD 'password';
CREATE DATABASE yillow_app WITH OWNER yillow_app;

  1. create a .env file in root folder, based on the .env.example with proper settings for your development environment

  2. Migrate and seed your database in root folder

pipenv run flask db upgrade
pipenv run flask seed all

  1. Start the server
  • In root folder
pipenv run flask run
  • Navigate to React-app folder
npm start
  1. Have fun!

Application Architecture

Yillow is built on React and Redux frontend with Python Flask backend, using PostgresSQL as a database.

Technologies Used

Conclusion and Next Steps

Yillow is not only a communication platform for regular users, also for agents. The next step for Yillow is to implement the agent interface, porfolio page, manage appointments, and communicate with client users through chat channels(web socket).

Conatact