data:image/s3,"s3://crabby-images/05a16/05a16f0fcee193a42888dac33f7fc42cbfd4c7b0" alt="How to create a YouTube live streaming app with Bubble – Part 3"
Do not index
Do not index
Welcome to the final installment of building a live-streaming app with Bubble and the free Daily Video Conferencing & Chat plugin! If you haven’t completed Part 1 and Part 2, start there first.
In this part, you’ll design the backstage page where users can join and start their YouTube stream, and set up workflows for broadcasting live.
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. Design the backstage page
Let’s start by setting up the backstage page, where users will join the stream. In the backstage page settings, change the layout to Column.
data:image/s3,"s3://crabby-images/c8951/c8951b819af5a8201736d5fa72b4d795719e0559" alt="notion image"
Add a Marketing Component to the page. Remove any images and buttons, and modify the text fields as follows:
- Main Text: Backstage for [insert dynamic data: Current stream’s name]
- Subtext: Step into the spotlight! 🌟 You’re on camera, and your conversation will stream live to YouTube. Here’s how to get started:
data:image/s3,"s3://crabby-images/d4ecb/d4ecb51e02ffa77cb405eba958cdcb2224539442" alt="notion image"
Update the text of the three cards within the component.
- Card 1: 🎬 Join the Room Your conversation will be broadcast on YouTube. Invite viewers to tune in live.
- Card 2: 🔗 Share the Link Share this link with anyone you want to invite. Link: [insert dynamic data: Current page URL]
- Card 3: 📺 Watch on YouTube Your conversation is live on YouTube. Invite viewers to tune in!
data:image/s3,"s3://crabby-images/3372d/3372d6c1f87b4b91e9bb9080eb971c689ecddcdc" alt="notion image"
Go to Settings, select Expose HTML Element ID, and check this option. Enabling this option will later enable you to place the video call in a custom element anywhere on the page.
data:image/s3,"s3://crabby-images/97838/978380f806e5b310f3e74d15e1a87d720c8d9983" alt="notion image"
Back in the Design tab, add a Group to your page. Name it Group Video and set the ID Attribute to “video.”
data:image/s3,"s3://crabby-images/eaf2c/eaf2ca650627439e74e59c681e633d552ea3f16c" alt="notion image"
In the Layout tab, adjust the settings:
- Check Collapse when hidden.
- Uncheck Make this element fixed-width.
- Set Min Width to 274px and Max Width to 960px.
- Uncheck Fit width to content and Fit height to content.
- Set Min Height to 750px and leave Max Height blank.
data:image/s3,"s3://crabby-images/ca240/ca2400fac4d42655f311fd20f430d302ca534a96" alt="notion image"
Add the Events Element to the page to listen for events when the user joins the room.
data:image/s3,"s3://crabby-images/14592/145927f1486415ce9ce0e547861b115759833e5b" alt="notion image"
Add the header to the top of the page
data:image/s3,"s3://crabby-images/b3ba9/b3ba90c502a72f2526e1ad6f299726fc1b5e0d1b" alt="notion image"
2. Set Up Backstage Workflows
Page Load Workflow: Add a workflow to join the room upon page load.
- Use Daily - join room action.
- Set URL to
Current page’s stream’s room URL
.
- For Room Style, use Custom Position.
- Set Meeting Token to
Current page’s stream’s owner token
.
- Enter “video” as the Element ID.
- Add an action to start listening to events.
data:image/s3,"s3://crabby-images/1fa47/1fa47c01737f627016a44ad574b1abf3c877a9e0" alt="notion image"
Add an event A Daily events joined-meeting
data:image/s3,"s3://crabby-images/02f8c/02f8ccb8970699b0c23471efcaf03d03f3573638" alt="notion image"
Add a condition so that the event triggers when “Curren user is Current page’s stream’s user”
data:image/s3,"s3://crabby-images/5cc8c/5cc8cd746122182f3b8e9680099fd45f416a0b3c" alt="notion image"
When the condition is met, add the action Daily - Start Live Stream to begin streaming.
- Set the RTMP URL to the stream URL, followed by a /, and enter the stream key.
data:image/s3,"s3://crabby-images/b8c92/b8c92074e1c2251699013446caa8eefb92cadf99" alt="notion image"
Add a final workflow that will redirect to the index page when the page is loaded and the current page’s stream is empty. This will prevent the page from loading when there isn’t a stream
data:image/s3,"s3://crabby-images/21af8/21af892c08ac5d31fda6b64c04d25eac64a078e7" alt="notion image"
Try it out
Click Preview to test the app.
data:image/s3,"s3://crabby-images/aee71/aee717d098bd1e1dbc8668a03a5bfcc45838bac2" alt="notion image"
In YouTube, go to Go Live and open the Live Streaming Dashboard.
data:image/s3,"s3://crabby-images/3f00d/3f00d843abf856082a049015c24280138b891d0f" alt="notion image"
Copy your Stream URL and Stream Key.
data:image/s3,"s3://crabby-images/3c92c/3c92cac15039ad3bac00ecbb2f24c705ca3063c7" alt="notion image"
Paste the Stream URL and Stream Key into the form.
data:image/s3,"s3://crabby-images/60e24/60e24c319eb31fecb57db3fd69909a18cedc933e" alt="notion image"
Join the app, and you’re live! Share the backstage link for other people to join you as well
data:image/s3,"s3://crabby-images/224e0/224e02413351486f6e428f6c56fa45ed00698ccc" alt="notion image"
Wrap-Up
Fantastic work! 🎉 You’ve completed the final steps to building a YouTube live-streaming app in Bubble. Your app is now set to let hosts and guests join, manage, and broadcast live events directly to their audience.
That’s a wrap—your live-streaming app is ready to go live!