Full Stack Flutter, Firebase and Riverpod – Build a YouTube Clone
In this beginner's course, you will build a fully functional YouTube Clone using Flutter UI kit, Firebase as backend, and Riverpod for managing state. It could be helpful to have some familiarity of basic Flutter and Dart before starting this course.
✏️ Course developed by @codeheadq
💻 Code:
- Starting Project: https://github.com/CoderrHQ/youtube-clone/tree/main
- Final Project: https://github.com/CoderrHQ/youtube-clone/tree/final_project
❤️ Try interactive Frontend courses we love, right in your browser: https://scrimba.com/freeCodeCamp-Frontend (Made possible by a grant from our friends at Scrimba)
⭐️ Contents ⭐️
0:00:00 Introduction
0:02:20 Create Firebase Project
0:08:45 Introduce starting project
0:12:03 Login page UI
0:17:26 Google Sign In
0:21:42 Introduce Flutter Riverpod
0:29:48 Sign in methods
0:34:04 Create Firestore database
0:36:03 collect user data
0:58:22 username validation logic
1:22:20 Channel Feature
1:28:26 Fetch user data
1:35:23 my channel page UI
1:57:14 display my channel data provider
2:00:37 Channel settings UI
2:18:04 customize channel logic
2:30:18 Users Channel page UI
2:42:42 Start Upload Feature
2:57:37 Pick video method
3:26:32 Upload Long Video
3:44:48 Account Page
3:52:40 Create Video's thumbnail page
3:54:30 Display Long Videos
4:21:12 acctual video
4:38:31 play and pause video
5:03:13 Display Suggested videos
5:11:45 Comment Feature
5:23:30 Comment sheet UI
5:42:01 Display Comments
5:52:47 Start Short Video Feature
5:57:26 Edit short Video || video editor package
6:11:33 Export Video
6:28:10 Add short video to Firestore
6:36:05 Display Short Videos
6:50:53 Search Feature
7:08:52 Filter Videos and Channels
7:59:46 First comment in each video
8:08:56 Like Video Logic
8:18:24 View Video
8:19:52 Subscribe Channels
Watch on YouTube ↗
(saves to browser)
Sign in to unlock AI tutor explanation · ⚡30
Playlist
Uploads from freeCodeCamp.org · freeCodeCamp.org · 0 of 60
← Previous
Next →
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
React: Production Server Setup Part 2 - Live Coding with Jesse
freeCodeCamp.org
cookies vs localStorage vs sessionStorage - Beau teaches JavaScript
freeCodeCamp.org
Browser history tutorial - Beau teaches JavaScript
freeCodeCamp.org
Graph Data Structure Intro (inc. adjacency list, adjacency matrix, incidence matrix)
freeCodeCamp.org
React: Parameterized Routing with Next.js - Live Coding with Jesse
freeCodeCamp.org
React: Dealing with jQuery Issues - Live Coding with Jesse
freeCodeCamp.org
setInterval and setTimeout: timing events - Beau teaches JavaScript
freeCodeCamp.org
Browser and Device Testing - Live Coding with Jesse
freeCodeCamp.org
Last Minute Updates - Live Coding with Jesse
freeCodeCamp.org
Post Launch Updates - Live Coding with Jesse
freeCodeCamp.org
React: Setting Up Google Analytics - Live Coding with Jesse
freeCodeCamp.org
React: Masonry Layout - Live Coding with Jesse
freeCodeCamp.org
Load Balancing Digital Ocean Droplets - Live Coding with Jesse
freeCodeCamp.org
try, catch, finally, throw - error handling in JavaScript
freeCodeCamp.org
Load Balancing: SSL Passthrough Setup - Live Coding with Jesse
freeCodeCamp.org
Graphs: breadth-first search - Beau teaches JavaScript
freeCodeCamp.org
React: Masonry Layout Part 2 - Live Coding with Jesse
freeCodeCamp.org
React: WordPress API Live Search - Live Coding with Jesse
freeCodeCamp.org
Creating WordPress Custom Post Types - Live Coding With Jesse
freeCodeCamp.org
Dates - Beau teaches JavaScript
freeCodeCamp.org
Miscellaneous Front End Updates - Live Coding with Jesse
freeCodeCamp.org
Merging a Pull Request from GitHub - Live Coding with Jesse
freeCodeCamp.org
React + Prettier + Standard JS - Live Coding with Jesse
freeCodeCamp.org
React: Sortable Responsive Table - Live Coding with Jesse
freeCodeCamp.org
Geolocation Sorting by Distance - Live Coding with Jesse
freeCodeCamp.org
Tradeoff Matrix - Agile Software Development
freeCodeCamp.org
The Definition of Ready - Agile Software Development
freeCodeCamp.org
Getting first React job without experience - Ask Preethi
freeCodeCamp.org
React: Google Analytics Click Tracking - Live Coding with Jesse
freeCodeCamp.org
Submitting a PR to an Open Source Project - Live Coding with Jesse
freeCodeCamp.org
Should I go back to school to get CS degree? - Ask Preethi
freeCodeCamp.org
Hero Section CSS Changes - Live Coding with Jesse
freeCodeCamp.org
Working Agreement - Agile Software Development
freeCodeCamp.org
A day at Pennybox with Co-Founder Reji Eapen
freeCodeCamp.org
React: Sorting and Filtering Data - Live Coding with Jesse
freeCodeCamp.org
React: Sorting and Filtering Data Part 2 - Live Coding with Jesse
freeCodeCamp.org
React: Building a New UI - Live Coding with Jesse
freeCodeCamp.org
Definition of Done - Agile Software Development
freeCodeCamp.org
Getting started with jQuery (tutorial) - Beau teaches JavaScript
freeCodeCamp.org
Making a React Blog with WordPress Content - Live Coding with Jesse
freeCodeCamp.org
React, NextJS, CSS - Live Coding with Jesse
freeCodeCamp.org
jQuery events - Beau teaches JavaScript
freeCodeCamp.org
React/NextJS Routing and WordPress API Custom Types - Live Coding with Jesse
freeCodeCamp.org
React: Working with API Data - Live Coding with Jesse
freeCodeCamp.org
React: Refactoring Components - Live Streaming with Jesse
freeCodeCamp.org
jQuery effects - Beau teaches JavaScript
freeCodeCamp.org
More React Refactoring - Live Coding with Jesse
freeCodeCamp.org
animate in jQuery - Beau teaches JavaScript
freeCodeCamp.org
"Finishing" My React Site - Live Coding with Jesse
freeCodeCamp.org
Starting a New React Project (P2D1) - Live Coding with Jesse
freeCodeCamp.org
React Project 2 Day 2: Learning Material UI - Live Coding with Jesse
freeCodeCamp.org
The Agile Manifesto - Agile Software Development
freeCodeCamp.org
jQuery: get and set with http, text, val, and attr - Beau teaches JavaScript
freeCodeCamp.org
React Project 2 Day 3 - Live Coding with Jesse
freeCodeCamp.org
The INVEST approach to product backlog items
freeCodeCamp.org
React Project 2 Day 4 - Live Coding with Jesse
freeCodeCamp.org
Chickens and Pigs - Agile Software Development
freeCodeCamp.org
React Project 2 Day 5 - Live Coding with Jesse
freeCodeCamp.org
jQuery: add and remove DOM elements - Beau teaches JavaScript
freeCodeCamp.org
React Project 2 Day 6 - Live Coding with Jesse
freeCodeCamp.org
More on: Tool Use & Function Calling
View skill →Related AI Lessons
⚡
⚡
⚡
⚡
When AI Helped Write a Real Zero-Day, It Wasn’t ChatGPT
Medium · AI
Why Human Imperfections and Cultural Diversity matter? The Humane Values Rule (AI SAFE© 5)
Medium · AI
Deepfake Nearly Indicted an Innocent Person. Courts Have Zero Protocols to Stop the Next One.
Dev.to · CaraComp
Red-Teamer’s Guide to MCP Tool Poisoning Attacks
Medium · LLM
Chapters (40)
Introduction
2:20
Create Firebase Project
8:45
Introduce starting project
12:03
Login page UI
17:26
Google Sign In
21:42
Introduce Flutter Riverpod
29:48
Sign in methods
34:04
Create Firestore database
36:03
collect user data
58:22
username validation logic
1:22:20
Channel Feature
1:28:26
Fetch user data
1:35:23
my channel page UI
1:57:14
display my channel data provider
2:00:37
Channel settings UI
2:18:04
customize channel logic
2:30:18
Users Channel page UI
2:42:42
Start Upload Feature
2:57:37
Pick video method
3:26:32
Upload Long Video
3:44:48
Account Page
3:52:40
Create Video's thumbnail page
3:54:30
Display Long Videos
4:21:12
acctual video
4:38:31
play and pause video
5:03:13
Display Suggested videos
5:11:45
Comment Feature
5:23:30
Comment sheet UI
5:42:01
Display Comments
5:52:47
Start Short Video Feature
5:57:26
Edit short Video || video editor package
6:11:33
Export Video
6:28:10
Add short video to Firestore
6:36:05
Display Short Videos
6:50:53
Search Feature
7:08:52
Filter Videos and Channels
7:59:46
First comment in each video
8:08:56
Like Video Logic
8:18:24
View Video
8:19:52
Subscribe Channels
🎓
Tutor Explanation
DeepCamp AI