data:image/s3,"s3://crabby-images/3f715/3f715ef9563b3eb3fef9b337e140be3973f4f40b" alt="How to create a YouTube live streaming app with Bubble – Part 2"
Do not index
Do not index
Welcome to Part 2 of building a live-streaming app with Bubble! If you haven’t completed Part 1, start there before continuing.
This section covers designing the app’s header, creating sign-up and login workflows, and setting up the basic stream creation form. If you’re mainly interested in the plugin-related steps, jump to the sections on creating the stream form and stream workflow.
While the guide walks you through each step, you can also explore a finished version in the sample editor. Please note that, for security, sign-ups are disabled and API keys have been removed.
1. Create the app header
First, create a simple home page where users can sign up and log in. You’ll use the default index page and Bubble’s built-in components.
Go to the Design tab for the index page. Click on the page and set the layout to Column.
data:image/s3,"s3://crabby-images/4b79e/4b79ee3abb4a8ae2ad0aafc30bf378f650a3cb8a" alt="notion image"
Under Components, install any plugins needed for this setup.
data:image/s3,"s3://crabby-images/e80b0/e80b02b1dc27aa50768ab8f7fbf8d64b00ea60e3" alt="notion image"
Drag a Header component onto the page.
data:image/s3,"s3://crabby-images/23214/232147a19ea63d3ca219f3218bff5e83afe15811" alt="notion image"
Rename it to YouStreamly, and remove other header elements as needed.
data:image/s3,"s3://crabby-images/b6765/b676590c4c3c84bc538faf6498ca3c056356ec11" alt="notion image"
Since this header will appear across multiple pages in your app, converting it to a reusable element will save time and ensure consistency. Right-click on the header, select Convert to a reusable element, and name it header. Now, you can easily add this header to any page without rebuilding it each time
data:image/s3,"s3://crabby-images/ecdaa/ecdaab11faa5dbe664e191812cd58e5b2c68c00c" alt="notion image"
Set the default width for the reusable header to 1200 in Layout.
data:image/s3,"s3://crabby-images/0a392/0a3922529dda5f28e16ee12c37ed44f259a75cf4" alt="notion image"
Create a conditional for the Sign Up button to change to Log Out when a user is logged in.
data:image/s3,"s3://crabby-images/28fe7/28fe771ac53d52d22518baf070cc580547fcf9b5" alt="notion image"
In the appearance tab select Edit workflow.
data:image/s3,"s3://crabby-images/86b4b/86b4b8ec4e97cd78fc7610c559250c76fad87503" alt="notion image"
Create a workflow that redirects the user to home when a user is logged out
data:image/s3,"s3://crabby-images/da2b5/da2b5e75c2eeb20b083e4b3260384567457e8f3f" alt="notion image"
Duplicate the workflow and log the user out if the user is logged in
data:image/s3,"s3://crabby-images/b66d7/b66d7ea69b7ae3b07593c97cbe150ec29ea15463" alt="notion image"
Add a final workflow to go home when Group logo is clicked
data:image/s3,"s3://crabby-images/9a931/9a9314cf995379b33aeca4e3058e4f88498e618c" alt="notion image"
Back in the index page remove the
Group header
and replace it with the reusable element header
.data:image/s3,"s3://crabby-images/c7b48/c7b4890614cbee0de9bc093638d9d50c80d53c9e" alt="notion image"
2. Design the home page
Now, set up the home page for users to create accounts, log in, and create streams.
Sign up form
Drag the sign-up component onto the page.
data:image/s3,"s3://crabby-images/f4f42/f4f42fcde39e3964a6776112ecad92d343bfd786" alt="notion image"
Customize the sign up page as follows:
- Title: Start streaming with YouStreamly
- Description: Create an account and start live streaming to YouTube. Perfect for creators who want a lightweight way to share live sessions, Q&As, and interviews with viewers.
data:image/s3,"s3://crabby-images/823cb/823cb25822db4535cd62597c2cbccae5fd5824b7" alt="notion image"
In the layout tab select collapse when hidden
data:image/s3,"s3://crabby-images/1b63f/1b63f93f46920413954712a3cfd9ba42d77ffc1c" alt="notion image"
In the Conditional tab, make the sign-up form hidden when a user is logged in.
data:image/s3,"s3://crabby-images/57ed8/57ed89a679433a0f49904380f6ade5ffa1289b27" alt="notion image"
Log in Form
Add a Log In component below the sign-up form and customize as follows:
- Title: Start streaming with YouStreamly
- Description: Log into your account to start live streaming to YouTube.
data:image/s3,"s3://crabby-images/f08fb/f08fb51cf20a5c6a955a7306c5d7436fd60da67b" alt="notion image"
In the Layout tab for
Group log in
check collapse when hidden and uncheck this element is visible on page load. data:image/s3,"s3://crabby-images/a9888/a988895f05eb0a884da72758c597e12f02ef468c" alt="notion image"
In the conditional tab add a condition that when the current user is logged in the element isn’t visible
data:image/s3,"s3://crabby-images/b97c5/b97c58ac226681195022fd1db818caff8fdfeac7" alt="notion image"
Stream creation form
To add a form for stream details, duplicate the Sign-Up form and make the following adjustments:
- Rename the duplicated group to Group Stream.
- Update the title to Create Stream and add a subtitle: Enter your stream details.
- Modify the input fields as follows:
- Change the Email input to Stream Name. Set the placeholder to Stream Name and format to
text
. - Change Password to RTMP URL, with a placeholder of YouTube RTMP URL. Set the format to
text
. - Update the Confirm Password field to Stream Key and keep it formatted as a password field.
- Update the button text to Create and remove any “Already have an account?” text.
data:image/s3,"s3://crabby-images/1675a/1675a63f58e5274cbc0c9e4b90f68b976c87b616" alt="notion image"
In the Layout tab, uncheck This element is visible on page load so it stays hidden initially.
data:image/s3,"s3://crabby-images/6f81b/6f81bf67e8dad0c21821f0e24fef31c69e5c3d4c" alt="notion image"
In the Conditional tab, set the form to become visible when the current user is logged in
data:image/s3,"s3://crabby-images/00008/00008d0917cdb13f752b122d8f00087b6627128b" alt="notion image"
3. Workflows for signing up, logging in and creating the stream
Sign up Workflow
Select the Sign Up button, go to Edit Workflow, and create a workflow to register a user when clicked.
data:image/s3,"s3://crabby-images/e2843/e2843e1987ffc57ddf6caf6cf0906c0b99de1018" alt="notion image"
Replace the “Already have an account?” link with text
data:image/s3,"s3://crabby-images/9f21f/9f21faaaf598dcf1dbb03333b4cd21f569c81b32" alt="notion image"
Add a workflow to hide the sign-up group and display the login group when this text is clicked
data:image/s3,"s3://crabby-images/bb6ff/bb6ffb854be1e87ba9ee9de1fe1937426c8a0f05" alt="notion image"
Log in
Select the Log In button, edit the workflow to log in a user, and add a step to reset relevant inputs
data:image/s3,"s3://crabby-images/c0cac/c0cacd26058f497fecc87fdfcdb46231e243593b" alt="notion image"
For Forgot Password?, set up a workflow to send a password reset email when clicked.
data:image/s3,"s3://crabby-images/d8549/d8549993796b7d250b1c2a0467d3bcf0bafde0c9" alt="notion image"
Round out the workflow by setting up Reset relevant input to ensure clean data entry.
data:image/s3,"s3://crabby-images/c3ce5/c3ce52669909ebf7e0db4e6d6d5b3d8019ea332e" alt="notion image"
Create stream workflow
This is where the Daily Video Conferencing Plugin comes into play!
Select the Create Stream button and create a workflow to set up a streaming session. In the workflow, use Daily - create a room followed by Daily - create a meeting token. Ensure the owner token is set to “Yes” to allow room owners to stream.
data:image/s3,"s3://crabby-images/8f583/8f5836088f5b45fee4dfb44ec6f0fee2d4bde41e" alt="notion image"
Save the stream information to your database:
- Name = Input stream name’s value
- Owner Token = Result of Step 2’s token
- Room ID = Result of Step 1’s ID
- Room Name = Result of Step 1’s room name
- Room URL = Result of Step 1’s URL
- RTMP URL = Input RTMP URL’s value
- Stream Key = Input stream key’s value
- User = Current user
data:image/s3,"s3://crabby-images/744f1/744f1478f7a739a38695b16df4c8e72ca30f0b4d" alt="notion image"
Add an action to navigate users to a backstage page where they can join and view the stream. Create a new page called backstage, leaving the clone form field blank.
data:image/s3,"s3://crabby-images/0a90d/0a90dcadd7cb519195d639cbd49705953f4b036e" alt="notion image"
Send the stream data to the backstage page and set the content type to stream.
data:image/s3,"s3://crabby-images/fa126/fa126954c8d0052ded2c99c71e1c0eca40fe54d9" alt="notion image"
Wrap-Up
Nice job! 🎉 You’ve created the home page and stream workflows to bring your app to life. Now let’s move to Part 3: Building the Backstage to create a seamless experience for going live.