In this tutorial, Dave walks through how to build an Uber clone using Bubble
Set your page settings for /index
data:image/s3,"s3://crabby-images/d2a52/d2a52fb0f4bc475a1574c074fd6638f5d79e007e" alt=""
Grab the icons from uber.com
data:image/s3,"s3://crabby-images/487a3/487a3c8fd57e9a7a9999f67d5d0827f8323f6073" alt=""
Get a photo from Unsplash and recreate the top part with the icons
data:image/s3,"s3://crabby-images/aabd4/aabd4535b46904e514bdcbe219ebca24ab3e3317" alt=""
First create one so you can later copy this one 8 times total
When you click the ‘earn’ group set a state /index show top = earn
data:image/s3,"s3://crabby-images/5ff00/5ff00377fe0940242a7179f2e1d88503169cc71b" alt=""
Add this rule to the black group under Earn. Use a hide rule instead of a show because then you always see what things you have on your page when you edit.
data:image/s3,"s3://crabby-images/05bee/05bee57b33bf8c6d21c21de57a5f3ba3ab19885f" alt=""
Copy this (with workflows) for the 7 others
When page is loaded set one of the ‘show top’ to show first Should look something like this now:
data:image/s3,"s3://crabby-images/323fd/323fdfc1c30a2ebe9883840aad7f1e40b30114d8" alt=""
Now you can add the groups bellow the icons that will show based on the selection made
You can stack them op top of each other and use the
data:image/s3,"s3://crabby-images/cad79/cad79c9e97bc872d8438b7924ac8dde17214ca92" alt=""
data:image/s3,"s3://crabby-images/eda0b/eda0baf3f3f7a24f9844561363a092b4ab06b4ee" alt=""
And add this as default value to the search input
data:image/s3,"s3://crabby-images/a53ad/a53ad43e6ec435a46291e8326978fcc951d35d04" alt=""
This will ask the user to agree to give their location when they visit the site
data:image/s3,"s3://crabby-images/4502c/4502ca40a804596ec3517ce5e6ec0c01df00259f" alt=""
Add for both search boxes when input changes: first empty the list of locations
data:image/s3,"s3://crabby-images/ef61f/ef61f8eaed914217b1706d53ea63629043f0f013" alt=""
Then
data:image/s3,"s3://crabby-images/b3d56/b3d5647579024acee04bc95c89c9c8ecb8b0333c" alt=""
Do this for both searchboxes When pick up search box changes
data:image/s3,"s3://crabby-images/24fd4/24fd42c7e5d03b571649fc8f6d8aafa6e43b35af" alt=""
data:image/s3,"s3://crabby-images/c7e6e/c7e6e09aaf21f846e41c6bf71e6bc0414674e495" alt=""
Add this bellow later we can use this to calculate the price.. x km x $
Since the other groups like eat, freight have all the same text, button fields we can use the index show top states to show different data in those groups.
data:image/s3,"s3://crabby-images/940a7/940a79ac6eca012c9156935d538f2593b506c30d" alt=""
You can do this for all except ‘ride’
Add this rule to the first group since it only won’t show with ‘ride’ selected
data:image/s3,"s3://crabby-images/2f16c/2f16c6dfb416de96d764f31b1dc5015b4995d9ca" alt=""
You can also change the image based on the ‘show top’ state
data:image/s3,"s3://crabby-images/17774/177741d45e783a3201a77cc70c0cbd5500938f13" alt=""
You can now design the rest of the homepage or move on to the booking & sign up process
data:image/s3,"s3://crabby-images/2a16e/2a16e9583f263fbf03dcc133cf9c8ac7c7466e3f" alt=""
We’re going to add pop up that looks like this to handle the sign up Download the plugin ionic icons
data:image/s3,"s3://crabby-images/15e5c/15e5c5522deadcfb6dca1e21408775dfead86424" alt=""
data:image/s3,"s3://crabby-images/9ba33/9ba33b9855df3e59f3dfa95fe8b144617d22e66f" alt=""
data:image/s3,"s3://crabby-images/74531/74531a2cb6f3437d8f01a72d88c05b1b73f6abe1" alt=""
Later we can add the work flows to the 2 button. First we’re adding a top menu bar with the link to open the pop up.
data:image/s3,"s3://crabby-images/3cdea/3cdeae4e06adf70ff57644d0dc239cfe1f31053c" alt=""
Do the same for ‘login’
Create a new blanco page ‘signup-ride’ And design it like this:
data:image/s3,"s3://crabby-images/2fcc5/2fcc5ae0ce475585a7440c6d714d6ac19845eb43" alt=""
Add this workflow to the sign up button
data:image/s3,"s3://crabby-images/f76fa/f76fab0e3951709c3a07e4ae50ac9eb1dfdd9771" alt=""
And make sure to add this to the user
data:image/s3,"s3://crabby-images/f76fa/f76fab0e3951709c3a07e4ae50ac9eb1dfdd9771" alt=""
Type of account is ‘ride’
After signing up send to home and give this data:
data:image/s3,"s3://crabby-images/5ac46/5ac46f5a015a6e5ca541b3b9152bfb325acf844f" alt=""
On loading the /index create a flow for when ‘show’ is not empty
data:image/s3,"s3://crabby-images/c8ff2/c8ff29fea789dd6362ccd70b44cbe944504da5ae" alt=""
add this to the pick up location
data:image/s3,"s3://crabby-images/f32ce/f32ce2072970d103800633798bd3dca28952ecaf" alt=""
Now we can clone the sign up page for ride and create the same but different page for drivers ‘signup-drive’
data:image/s3,"s3://crabby-images/db6cc/db6ccc7fe9c4aa41a47412e98cf2113f7b2e1d88" alt=""
Bellow the sign up you can add some extra info to show it’s a driver & change the colors a bit
data:image/s3,"s3://crabby-images/3a9e2/3a9e25b4637cfcd282d54e670498c3bf665d24be" alt=""
data:image/s3,"s3://crabby-images/f63ea/f63eaafd6b2195fb268a06add3213faf0d0ff540" alt=""
Change the type of account:
data:image/s3,"s3://crabby-images/556f5/556f539b3b257fcf95ae38a2e2c14810675917b1" alt=""
On the /index you can now connect the sign up pop up buttons to the right pages
You can add the workflow if a user isn’t signed op to open de signup-ride page
data:image/s3,"s3://crabby-images/d2969/d29690fb3186b7743d6d95e9d7a58d53d3a0005d" alt=""
data:image/s3,"s3://crabby-images/560ba/560ba15b10e22b4c42e1a90b091e024687f8ca96" alt=""
The custom workflow event opens the page
Create a new page called /looking Set the page background to ‘none’
Add a floating group
data:image/s3,"s3://crabby-images/f26b4/f26b4cdf77aa56489c85ef5eebdc8d6d68eca6c0" alt=""
I this group we’re going to add a map like on the homepage Page should look like this:
data:image/s3,"s3://crabby-images/5f793/5f793d454e63176330a6fdd455971f67d1a8bcec" alt=""
Add a floating group with 2 search boxes like the homepage with a pick up & a destination and design it like this:
In the blue you can add from? And to? when the inputs are filled in change to the location street
Add this calculation to the button
data:image/s3,"s3://crabby-images/ae2ac/ae2ac4da629b20cf8b80571b570fbaf5837e0ee7" alt=""
Add this as the data source to the map:
data:image/s3,"s3://crabby-images/9ac68/9ac68539f9885f7a8a1975a917a5b7451e9f2b7b" alt=""
Upload a custom car ;)
data:image/s3,"s3://crabby-images/e0c5d/e0c5dc904ace3438e79394488d89433ffbf38e4a" alt=""
add this rule to the map and copy paste the app
data:image/s3,"s3://crabby-images/87e0b/87e0b285de6850f52c2cfd4bdfd6ae7bc3945d7e" alt=""
Make the copy visible when this rule is true Change the icon of map B
data:image/s3,"s3://crabby-images/818ed/818ed177f761088566a52c661040121e977704bb" alt=""
Add the same workflow as you did on the /index for the search boxes
data:image/s3,"s3://crabby-images/24b42/24b42ec0121dbd45b1369f2f2a72b83376a4d642" alt=""
Data for map B
data:image/s3,"s3://crabby-images/37aeb/37aeb925168f06bbf420e9d04d26d31eaada232f" alt=""
Download the Stripe plugin to handle the payments Add a workflow to the order button and create a order
data:image/s3,"s3://crabby-images/e980a/e980a039d0e1fa1ba33788b33788e86873b4b140" alt=""
Add the orders to the driver and rider
Cancel the order if there is no driver available
data:image/s3,"s3://crabby-images/cccfd/cccfde0d025d4effe5e6ab54ee9a07a37d3670b8" alt=""
If not cancelled charge the user
data:image/s3,"s3://crabby-images/98df3/98df3b562fa7dd44764a581008d7f77b40f6e837" alt=""
Change the order to paid if the user was charged
data:image/s3,"s3://crabby-images/14ae6/14ae63821f692d0bc8aab63d1c0333af771923ff" alt=""
Create a blanco page called; /status we we’ll later use that
data:image/s3,"s3://crabby-images/4926e/4926e95249923f50d1b8dc76af8e018a160ae096" alt=""
We’re now going to build a simple satus page
When page is loaded
data:image/s3,"s3://crabby-images/123fb/123fb2230add0211ae4ac8965445f6996476787c" alt=""
Create a page with info about the driver that is coming
data:image/s3,"s3://crabby-images/4d913/4d913c0571e9321bd5feb602edeb8b6c4ce5fb18" alt=""
You can add different rules to the page to show if the order is cancelled because there is no drive or which driver is coming.
data:image/s3,"s3://crabby-images/e47fe/e47fe0b5539b6e94ee86bd5214554d734f0e3d50" alt=""
Page could look something like this when we found a driver
data:image/s3,"s3://crabby-images/9d7cc/9d7cce17098a7641bb32e162f1edfc930bd42aef" alt=""
Or something like this when no driver was found
data:image/s3,"s3://crabby-images/b97db/b97db4489131faa8ec917d1fa5658379d4f9fa55" alt=""
The basics are working now. We can send the filled in locations from the homepage to the /looking page
When you go to the page use these parameters
data:image/s3,"s3://crabby-images/68471/68471f45e1d227ebf439d7b361e2046fd3e20970" alt=""
On the /looking page create a workflow that will fire when the page is loading setting the state of /looking for from & to
data:image/s3,"s3://crabby-images/5556a/5556ac824de182660f7f489a32f11a14a78e393d" alt=""
data:image/s3,"s3://crabby-images/6f054/6f0543b3e9256dce4246627ac00a8794d06cf286" alt=""
And add them as a condition to the search location fields
data:image/s3,"s3://crabby-images/12778/12778fd60c0e9d8fa0ebb5383142d594434e3d1b" alt=""
We can start building the dashboard so we can see the trips we’ve booked :) Create a new page /dashboard
Add these 3 groups to the page and add the same settings (also check in the responsive tab)
data:image/s3,"s3://crabby-images/ef085/ef085b7dc47e1d9009468ff865adb5d34f3887de" alt=""
Add a repeating group to the middle group
data:image/s3,"s3://crabby-images/45176/4517645c82aa6c3a06d3e23fa21f43d886cba13e" alt=""
Add to groups to a cell. One with only the date and price And the other one with more info about the trip
data:image/s3,"s3://crabby-images/36d0c/36d0c864433ddaa2503dfaddd08de1730abe1c80" alt=""
data:image/s3,"s3://crabby-images/489ca/489ca5a992a99c9e78f57ce0df6d1e40fabebf37" alt=""
When you click on the top one set state of the /dashboard
data:image/s3,"s3://crabby-images/ab615/ab6159f5ab15da253dcd830709c2f85902db4d10" alt=""
Then make this rule for the group with the more info
data:image/s3,"s3://crabby-images/227f3/227f33f5e09843a528db9090a3eb49a5f368cd60" alt=""
Add this rule to the repeating group so a driver sees their past rides.. also add rules to the text inside the repeating group
data:image/s3,"s3://crabby-images/9d19e/9d19ed4578adaeaf5af1386106de10bedb4e9ee3" alt=""
data:image/s3,"s3://crabby-images/3af4f/3af4f5ba107a1cd18d1cde5e025d3a7173379b20" alt=""
*to needs to be destination
Create a pop up that will show when you click the ‘profile’ button where the user can change their profile settings
Create these fields and enable auto-binding
data:image/s3,"s3://crabby-images/f8f35/f8f35b04eafd1539d9ddaffb14288682793224cd" alt=""
data:image/s3,"s3://crabby-images/0053c/0053cf318212ed8abb39114ecf7876c2aead8231" alt=""
Add a pop up to open when the user clicks ‘free ride?’
data:image/s3,"s3://crabby-images/8ddd9/8ddd94ef61f5171cde67423b3652bb142732a4f2" alt=""
data:image/s3,"s3://crabby-images/8b1be/8b1bef3e0a2b330eefff58cef0bb0735ca5e88dc" alt=""
Add this to the /index page
data:image/s3,"s3://crabby-images/f77e0/f77e051745f55ec5334d6c7a2fe1f27e5caf543f" alt=""
And this one
data:image/s3,"s3://crabby-images/54207/54207c38250f30350501aed9d4a3782b920b2560" alt=""
Add this line to the sign up flow
data:image/s3,"s3://crabby-images/e7f1d/e7f1dcc0b863d422cee90442b6520c56c789001e" alt=""
And this action to the sign up work flow
data:image/s3,"s3://crabby-images/2d217/2d217102ec4c0db5c56485fdf1f0ba214b08d64b" alt=""