Skip to content

The Pivot: turn legacy resteraunt code into an multi-tenancy travel website similar to AirBnB

Notifications You must be signed in to change notification settings

DSynergy/The-Pivot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

README

Visit us on Heroku! travel-home-turing.herokuapp.com/

The Pivot: taking the Dinner Dash project and changing the purpose of the site with keeping the legacy code


The Pivot

Your Dinner Dash application was almost great, but it turns out that we need to pivot the business model.

In this project you’ll build upon an existing implementation of Dinner Dash, turning it from a restaurant ordering site to something much bigger. Learning Goals Modeling

Adapt the existing restaurant models to belong to individual businesses
Mind security permissions such that each business does not have any knowledge of other businesses’ data
Push all logic down to the model layer so controllers and views remain simple

Interface & Views

Use and switch between multiple view templates to reduce view-layer logic
Implement a clean, logical order flow that minimizes customer frustration

Process

Practice working with a "legacy" codebase to add substantial functionality
Use outside-in TDD/BDD to drive all layers of Rails development
Use a professional project management tool to pace and track progress

Teams

The project will be completed by teams of three to four developers over the span of eighteen days.

Like all projects, individual team members are expected to:

Seek out features and responsibilities that are uncomfortable. The time to learn is now.
Support your teammates so that everyone can collaborate and contribute.

Project Starting Point

You’ll build upon an existing code base assigned by the instructors. You need to work on adapting and improving this codebase, not building your own thing from scratch. This is sometimes called “brownfield” development, and you’ll soon know why. Exploring the Dinner Dash App

As a group, dig into the code base and pay particular attention to:

Test coverage and quality
Architectural concerns
Components that are particularly strong or weak
General strengths and weaknesses

Restrictions & Outside Code

Your project should evolve, refactor, and clean up the code you inherit. This includes deleting redundant, broken, or obsolete code. However, you should not throw out the previous work wholesale.

Furthermore, there should be no reduction in functionality except when explicitly called for by new requirements. Setup the Project Management Tool

There are many popular project management tools out there. For this project we’ll use a lightweight tool that wraps GitHub issues: Waffle.io

Setup a Waffle project for your new repo. Your team members and instructors should be added to the project so they can create, edit, and comment on issues. Managing Requirements

The stories as written and prioritized in your project management tool will be the authoritative project requirements. They may go against and likely go beyond the general requirements in this project description. Workflow

Generally speaking, work for your project should go through this process:

A story is written in the project management tool
A developer comments on the story that they’re beginning work
They create a feature branch
They develop and test the feature
They push the feature branch to the repository
They submit a pull request asking to merge the branch into master
A teammate reviews the code for quality and functionality
The teammate merges the pull request and closes the story/issue
Later, the customer will review the delivered features by browsing closed pull requests

Pivots

Your group will be assigned one of the following problem domains to pivot Dinner Dash: Keevahh

Micro-lending is a powerful tool for social progress. Let’s rework Dinner Dash into a micro-lending platform.

Users register on the site as either a borrower (the business) or a lender (the customer)
Borrowers automatically have a borrower page (the store)
Within that borrower page, they post one or more loan requests (the products)
A loan request has a title, description, categories, photos, borrowing amount, requested-by date, a repayments-begin date, and a repayment rate
A lender can browse the site and view all open loan requests
They can add multiple loans from multiple borrowers to their cart
They can then checkout and the funds are allocated to the borrowers
The borrowers are notified that funding has come through and their loan request page is updated

Lending like this is more fun together – it’d be great if lenders could band together into lending groups that make loans together on a weekly or monthly basis. EmployMe

Employment is key to quality of life. Let’s rework our Dinner Dash into a platform to help people find great jobs.

Users register on the site as either a job poster (the business) or a job seeker (the customer)
A business has a listings page with all their job listings
The business can create one or more job listing
A listing has a title, description, categories, full-time/part-time indicator, wage/salary range, number of positions open, and a closing date
A job seeker can browse the site and view all open job listings
They can add one or more job listings to their cart
They can upload a PDF resume that’s attached to their user account
During the "checkout" process, they can add a brief introduction note to each job they’re applying for
The job posters are notified that a new application has come in

The job posters will need a great dashboard where they can review the applicants and either send them rejections or schedule interviews. Airlift

Technology has a huge role to play in disaster relief and recovery. Let’s rework Dinner Dash to help get relief supplies to the people and places that need them.

Users register on the site as either suppliers (the business) or service providers (the customer)
A supplier has a listings page with all their available supplies
A listing has a title, description, categories, quantity available, unit size, current location, shippable indicator, unit weight
A service provider can browse the site and view all available supplies
They can add one or more supplies to their cart
During checkout they can choose to (a) pickup the supplies and request a pickup day/time or (b) request delivery and set their current location using GPS coordinates
The suppliers are notifed that a new request has come in

Disaster areas probably don’t have desktops, electricity, and internet access. This project needs to be built targeting mobile web and SMS where appropriate. TravelHome

Experiencing other cultures is one of the strongest ways to build our understanding of humanity. Let’s make it easier for people to open their homes to travelers.

Users register on the site and can be both hosts (the business) and travelers (the customer)
A host has a listings page where they list available accommodations and they have a profile with their photo, name, and description
A listing has a title, description, categories, quantity available, people-per-unit, daily rate, photos, location, shared/private bathroom indicator, and available dates
A traveler can browse the site and view all available listings
They can add one or more listings along with requested dates to their cart
Their profile has their name, photo, and previous bookings
When they checkout, the hosts are notified of the requests
The hosts can either confirm or deny the requests
The traveler is notified when request status changes

A traveler will need a good way to roll up all their bookings into an itinerary that helps them get from place to place with a map and pushes data to their Google Calendar. FreshThreads

Off-the-rack clothes are so blah. Let’s build a marketplace for buying custom clothing.

Users register on the site as either sellers or buyers
Sellers have a "store" page where they can post one or more listings
An listing has a title, photos, a detailed description, and a time-to-produce
Each listing can also have one or more "options" defined by the seller such as: waist size, color, fabric, sleeve length, etc. These must be chosen by the seller when creating/editing the listing and allow them to set specific values (like "S", "M", "L", etc or "Short", "Regular", "Long")
Customers can browse all listingson the platform or browse a specific seller’s store
When a customer adds an listing to their cart they need to specify each of the options
When the order is submitted the customer is emailed a receipt and the seller is notified to begin production.

It’s a pain to enter my options for EVERY purchase. Allow a user to store their options in their account, so when they purchase an listing the right values are pre-selected (but can still be changed). Gallery

People hated our restaurant, but they loved our product photos. Let’s pivot the platform to sell photography, providing our customers a “whitelabel” experience:

A photographer registers on the platform to create a new store
A photographer posts photos for sale
A photo has an image, dimensions, title, description, shooting date, and photographed by attributes.
A customer visits a store at a URL like example.com/stores/store_name
The customer sees only the photos for this store
The customer can browse photos and add them to the cart
There is no aggregated shopping experience across stores, so a customer who visits Store A and adds something to their cart, then visits Store B, will not see the Store A listing in the Store B cart
The customer can checkout and receives an email receipt
A photograph which is purchased is marked as purchased, can still be browsed, but cannot be ordered by other users
The photographer is notified via email about the purchase.

And, one more thing: it takes awhile to save up for these amazing photographs. It’d be awesome if a user could “favorite” photos to come back and easily find/purchase them later. HubStub

Who wants to stand in line for tickets the day they come out? Nobody. Instead you can just pay 50-500% more to buy them from someone else. HubStub helps you do just that!

Users register on the site and can both sell tickets (the business) or buy tickets (the customer)
Sellers automatically have a tickets-for-sale page (the store)
Within that seller page, they post one or more available listings (the products)
An listing has an event title, date, time, section, seat number(s), categories, photos, and a delivery method (download or mail)
A buyer can browse the site and view all available tickets or browse them grouped by event or seller
They can add multiple tickets from multiple sellers to their cart
They can then checkout and the tickets are either downloaded or the seller is notified that they need to mail them

Shows and events are more fun together. Can you create a way to invite my friends and have them RSVP? Base Expectations

You are to extend Dinner Dash so that it can handle multiple, simultaneous businesses. Each business has their own name, unique URL pattern, listings, orders, and administrators.

The requirements reference an example.com, but your URL will differ. Functional Requirements

Individual restaurants can be accessed by specifying their restaurant name as the path prefix.

Given a business named Billy’s BBQ
When I visit http://example.com/billys-bbq
Then I expect to see all listings defined for Billy’s BBQ
And I expect to see branding defined for Billy’s BBQ
When I visit http://example.com/billys-bbq/categories
Then I expect to see all categories defined for Billy’s BBQ

Public Visitor

As a public, unauthenticated visitor to a business I can:

Maintain a shared shopping cart across all businesses I browse
Add listings to a shopping cart
Log in to or create an account before completing checkout
    When I create an account, then I expect to receive a welcome email
    After login or creating an account, I will immediately resume the checkout process
Request that my account become a business owner

Authenticated Customer

As an authenticated customer I can:

Make purchases on any business I am browsing
    Receive an email confirmation of my order with basic order details and a link to the order detail page
Manage my account information shared by all businesses centrally on my account page
    Shipping addresses
    Billing addresses
    Credit cards associated with my account
    Basic account info like name and password, as managed previously in Dinner Dash v1
View and manage my purchase history across all businesses

Creating a Business

An account can request to create a new business that includes a name, URL identifier ("slug"), and description
The platform administrators are notified of the pending request
If approved…
    the requester is notified by email
    the requester automatically becomes a business administrator for the business
If denied…
    the requester is notified by email

Authenticated Business Administrator

As an authenticated business admin, by using a dedicated admin area, I can:

Add listings, edit listings, and retire listings in my business only
Update the details of my business such as the: name, URL identifier, and description
Add or remove other admins for the business
    There can never be fewer than 1 admin for a business
Perform the admin actions available to administrators in Dinner Dash as appropriate

Authenticated Platform Administrator

As an authenticated Platform Administrator, I can:

Approve or decline the creation of new businesses
Take a restaurant "offline" temporarily so that attempting to browse it redirects its root and displays a maintenance message
    Bring an offline restaurant back online
Override/assist restaurant admins in any functionality available to them via the admin portion of their restaurant pages

Validation and Error Messages

Any form in the application must:

validate the submitted data appropriately
reject invalid input
display clear and helpful errors and corrective instructions
allow the user to quickly fix and resubmit

Non-Functional Requirements Background Workers

Use background workers for any job that doesn’t have to be completed before the response is sent to the user (ex: sending email, updating statistics, etc).

Use Resque or a similar library to support this functionality. Security

Your app needs to be secure enough that a malicious user with complete knowledge of the source code cannot exploit the system (ie: change other users’ data, view other users’ data, elevate their own privledge level, etc). Base Data

Before final delivery, and ideally before customer check-ins, you should have the following data pre-loaded in your marketplace:

At least 10 total businesses
At least 20 listings per business
At least 5 listing categories
100 known customers
2 business admins per business
2 platform administrators

It creates a much stronger impression of your site if the data is plausible. We recommend creating a few “template” businesses that have real listings, then replicating those as needed. It’s better to have “Taste of India 26” and “Taste of India 27” than “Lorem Ipsum” and “Tellus Domit”. Extensions

In this project you as developers are expected to take a more active role in shaping the project. Although there are a few potential extensions proposed at the outset, you are encouraged to propose additional extensions, in the form of new features and user stories describing them, to your project manager.

If you have an idea for a killer feature for your application, pitch it to your stakeholders for refinement. If they are convinced of its value, they’ll work with your team to create one or more user stories in your project management software and prioritize those stories in the context of the rest of the requirements. You may be able to convince them to prioritize your feature ahead of current base requirements if it is sufficiently compelling or necessary.

However, your application should not implement features which have not been approved by your customer. Custom CSS per Business

Provide a mechanism so that business administrators may provide custom a CSS sheet to change the appearance of their listing page. This custom styling should not affect any other business’s appearance.

Have four pre-built themes they can select from and the ability to upload their own. Use Sub-Domains To Distinguish Businesses

In order to give greater precedence and more SEO-juice to each individual business, as well as pave the way for businesses to use custom domains, change your application so that, instead of using a path prefix per request to identify individual businesses in the system, use unique sub-domains instead.

So instead of www.example.com/billys-bbq/listings pointing to the listings belonging to the business Billy’s BBQ, allow billys-bbq.example.com/listings to be used instead. Feedback/Evaluation Schedule

Rapid and frequent feedback about the work we produce is a central tenet of agile software development. As such, we’ll have frequent meetings to discuss the state of your project and correct course as necessary.

These meetings are intended to model interactions with a real customer, they are not support sessions. As the stories clearly define the customer’s expectations, your application needs to exactly follow the stories as they’ve been developed with your customer. A 95% implementation is wrong. If you want to deviate from the story as it’s written, you need to discuss that with your customer and get approval to change the story first.

Your project feedback/evaluation process will take place in five parts: Kickoff

On the day you begin the project you’ll meet with an instructor who will act as your client for the project. In this brief session you will:

Lay out a general iteration plan for the entire project
Draft expectations for the features to be delivered by Checkpoint 1
Sketch expectations for the features to be delivered by Checkpoint 2

After your meeting your team will work to translate these expectations into organized, detailed stories in your project tracker and notify your customer when they’re ready. The customer will provide feedback/approval by the end of the following day. Checkpoint 1

The Checkpoint 1 meeting will take place on the first Thursday of the project cycle. The first half of the meeting will be used to assess your progress, the second half will set the expectations for Checkpoint 2. Checkpoint 2

The Checkpoint 2 meeting will take place on the second Thursday of the project cycle. The first half of the meeting will be used to assess your progress, the second half will set the expectations for Checkpoint 3. Checkpoint 3

The last Checkpoint meeting will take place on Tuesday before the project is delivered. It’ll again be split 50/50 between evaluation and next steps. But the project is expected to be in a ready-to-deliver state by this meeting. The next steps set in the meeting should be minor polish, UX improvements, and extension features. Final Evaluations

The final evaluations will use the rubric below on the day the project is due. Evaluation Rubric

The following criteria will be used for each evaluation: Feature Delivery

You’ll be graded on each of the criteria below with a score of (1) well below expectations, (2) below expectations, (3) as expected, (4) better than expected.

Completion: did you deliver what you committed to build?
Organization: did you use your project management tool to keep the project organized?
Progress: are you on track to finish the project on time? Will/does the end product realize the vision of the concept?

Technical Quality

Test-Driven Development: (1) disregard for testing, (2) gaps in test usage/coverage/design, (3) adequate testing, (4) exceptional use of testing
Code Quality: (1) poor factoring and understanding of MVC, (2) some gaps in code quality / application of MVC, (3) solid code quality and pushing logic down the stack, (4) exceptionally well factored code
User Experience: (1) inattention to the user experience, (2) some gaps in the UX, (3) a production-ready user experience, (4) a polished UX

About

The Pivot: turn legacy resteraunt code into an multi-tenancy travel website similar to AirBnB

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •