Nối tiếp phần 6 của series, trong phần này, chúng ta sẽ bắt tay vào code Sign Up page, config lại phần router để đáp ứng được vấn đề Authentication kèm theo tạo custom hook để listening for Authentication. Không dài dòng nữa, Chúng ta bắt đầu thôi 😁.
I. Tạo sign up page.
Thì Sign up page của Netflix thì sẽ trông như thế nào? Thì hiện tại cái flow của việc Sign Up tài khoản mới của Netflix thì nó nhiều step hơn rồi. Chúng ta không nhất thiết phải làm y hệt như nó, do đó chúng ta sẽ code Sign Up page như Sign In page, ta chỉ thêm bớt một số thứ thôi.
Chúng ta làm như sau:
Trong file /pages/signup.jsx
, chúng ta sẽ sử dụng lại những gì mà chúng ta đã built-in là component form và headercontainer.
- Sau khi code xong và run thử thì ta sẽ được như hình.
Giải thích một chút về function handleSignUp()
nhé:
- Sau khi send request gồm
email
vàpassword
, nếu đăng ký thành công thì sẽ sang bước tiếp theo. - Sau khi đăng ký thành công sẽ tiến hành update profile gồm
displayName
vàphotoURL
(Avatar) của user. - Phần
photoURL
mình chỉ cho random 1 trong tổng số 5 image mà mình có cho user khi đăng ký thôi 😁.
Nếu chưa có ảnh để làm avatar thì các bạn có thể tải tại đây.
Chúng ta cùng test thử nó có thể Sign Up một user mới được không nhé 😉.
- Nhập thông tin đầy đủ.
- Nếu Sign Up thành công thì nó sẽ tự động redirect sang Browse page.
- Để chắc chắn hơn, chúng ta có thể kiểm tra trên firebase, như hình là đã Sign Up thành công .
II. Cấu hình Router auth.
Tại sao lại config lại phần router? Thì như các bạn biết, việc chia các loại router khác nhau để phân loại các role của user, tức là ta sẽ phân loại ra thành 2 loại user là: user chưa login và user đã login.
Tùy thuộc vào từng case mà user sẽ vào được những page khác nhau, đó là những gì mà chúng ta sẽ config ngay dưới đây. Trong folder src ta tạo thêm folder helpers và file routes.js
như sau:
Trong file routes.js
ta thêm các đoạn code sau:
Giải thích một chút về 2 function trên nhé:
isUser()
: function này có nhiệm vụ là check xem user đã login hay chưa, nếu chưa thì sẽ load page tương ứng là SignIn hoặc SignUp page ngược lại sẽ Redirect đến Browser page.ProtectedRoute()
: function này có nhiệm vụ là chặn những user có những action cố truy cập Browser page hoặc những page khác mà bắt buộc user phải login tài khoản mới có thể truy cập được. Nếu user vẫn cố tình truy cập các page này bằng cách gõ các path tương ứng trên thanh url của browser thì nó sẽ tự động Redirect đến SignIn page theopathname
vàlocation
tương ứng.
Okie! Vậy sử dụng nó ra sao? Thì để sử dụng, chúng ta sẽ import và dùng nó trong file App.js
như sau:
III. Tạo custom hook (auth listener).
Chúng ta sẽ tạo một custom hook để handle việc listen user SignIn hoặc SignOut từ đó có thể lấy được data của user đó để sử dụng cho những việc cần thiết sau này.
Trong folder src ta tạo một folder hooks, dùng để chứa các custom hook. Tiếp theo trong folder hooks vừa tạo, ta tạo thêm file useAuthListener.jsx
và sẽ code như sau:
Giải thích:
onAuthStateChanged()
: function này listen khi user trigger việc SignIn hoặc SignOut.- Nếu user SignIn thì lưu user data vào localStorage ngược lại thì remove khỏi localStorage.
Vì trong tương lai, chúng ta sẽ có thêm nhiều custom hook khác, do đó ta sẽ tạo thêm file index.jsx
trong folder hooks và config như sau:
Tiếp theo là sử dụng custom hook vừa built xong nè 😁, trong file App.js
chúng ta sẽ sử dụng như sau:
Sau khi reload thì có thể các bạn sẽ thắc mắc là tại sao current page là Browser page (như hình dưới), mặc dù chúng ta đã thực hiện việc SignIn đâu?
Trong bài trước chúng ta đã test việc SigIn và SignUp, do đó account mà chúng ta đã SignUp và sử dụng để SignIn ở bài trước nó vẫn còn lưu lại trên firebase.
Tuy nhiên trên firebase nó chưa ghi nhận việc chúng ta đã gọi function signOut()
của nó để SignOut cái account này ra khỏi app, do đó ta mới có trường hợp trên.
Okie current page là Browser page do đó ta có thể thấy custom hook của chúng ta đã hoạt động. Chúng ta check thêm nó có lưu được vào localStorage không nhé 😉.
Perfect!!! 😁
IV. Tổng kết.
Okie phần thứ 7 của series này cũng đã xong, cảm ơn các bạn đã đọc. Hẹn gặp lại các bạn trong phần tiếp theo nhé 😉. See u again~
TỪ QUỐC HƯNG
Đam mêm lập trình Frontend, Yêu thích việc setup workspace theo phong cách tối giản
follow me :
Bài viết liên quan
NodeJS là gì? Tại sao NodeJS lại phổ biến
Jul 09, 2024 • 8 min read
Event Loop là gì? Cơ chế hoạt động của Event Loop trong JavaScript
Jun 18, 2024 • 7 min read
So sánh Golang và NodeJS chi tiết
Oct 14, 2023 • 22 min read
Home Feed UI Instagram with TailwindCSS: Giới thiệu về series
Nov 28, 2022 • 2 min read
ReactJS Tutorial for Beginners Phần 2
Dec 12, 2021 • 3 min read
ReactJS vs React Native - Gà cùng một mẹ liệu có giống nhau?
Dec 12, 2021 • 14 min read