Это пробный урок. Оформите подписку, чтобы получить доступ ко всем материалам курса. Премиум

  1. Урок 1. 00:02:17
    Welcome to Modern Full Stack Next.js Course
  2. Урок 2. 00:02:04
    Next.js- A Blueprint for Successful Web Development
  3. Урок 3. 00:02:44
    what is Next.js
  4. Урок 4. 00:01:02
    what is framework
  5. Урок 5. 00:05:49
    Getting Started with Next.js App Router
  6. Урок 6. 00:01:42
    ai code editor
  7. Урок 7. 00:01:46
    shell cmd
  8. Урок 8. 00:02:47
    hello-nextjs
  9. Урок 9. 00:01:09
    SEO
  10. Урок 10. 00:02:44
    metadata and fonts
  11. Урок 11. 00:01:39
    other files
  12. Урок 12. 00:02:05
    random files
  13. Урок 13. 00:04:21
    Basics of Routing in Next.js
  14. Урок 14. 00:07:56
    server comp
  15. Урок 15. 00:05:34
    What are Server and Client Components
  16. Урок 16. 00:05:32
    Understanding Server and Client Components
  17. Урок 17. 00:01:57
    Demo
  18. Урок 18. 00:01:57
    Demo_2
  19. Урок 19. 00:02:04
    Untitled Lesson 2.1
  20. Урок 20. 00:02:32
    page architecture
  21. Урок 21. 00:05:23
    Home Page Structure
  22. Урок 22. 00:01:32
    Untitled Lesson 3.1
  23. Урок 23. 00:01:29
    Untitled Lesson 3.2
  24. Урок 24. 00:06:20
    Untitled Lesson 3.3
  25. Урок 25. 00:05:32
    Untitled Lesson 3.4
  26. Урок 26. 00:03:20
    Untitled Lesson 3.5
  27. Урок 27. 00:04:28
    Untitled Lesson 3.6
  28. Урок 28. 00:00:47
    Untitled Lesson 3.7
  29. Урок 29. 00:03:40
    Untitled Lesson 4.1
  30. Урок 30. 00:04:15
    Untitled Lesson 4.2
  31. Урок 31. 00:03:02
    Untitled Lesson 4.3
  32. Урок 32. 00:03:35
    Untitled Lesson 4.4
  33. Урок 33. 00:02:56
    Untitled Lesson 4.5
  34. Урок 34. 00:03:53
    Untitled Lesson 4.6
  35. Урок 35. 00:00:42
    Untitled Lesson 4.7
  36. Урок 36. 00:03:58
    Untitled Lesson 4.8
  37. Урок 37. 00:02:39
    Untitled Lesson 4.9
  38. Урок 38. 00:05:00
    How Next.js Works
  39. Урок 39. 00:02:45
    Profile our app - Instant Page Interactivity
  40. Урок 40. 00:04:00
    makes nextjs special
  41. Урок 41. 00:05:08
    adoption
  42. Урок 42. 00:03:18
    DE
  43. Урок 43. 00:01:25
    hydration
  44. Урок 44. 00:02:14
    Server Rendering vs. Client-Side Rendering
  45. Урок 45. 00:00:52
    Client vs Server Rendering - Breaking Down the Terms
  46. Урок 46. 00:02:31
    Intro to Image
  47. Урок 47. 00:04:19
    Image Component Aspect ratio
  48. Урок 48. 00:00:55
    Correct Aspect Ratio is imp
  49. Урок 49. 00:02:36
    Local Image - Static Import
  50. Урок 50. 00:03:51
    Image comp blur
  51. Урок 51. 00:04:01
    remote image
  52. Урок 52. 00:06:17
    Mastering Next.js Image Component -- rmeote
  53. Урок 53. 00:00:41
    Image Optimization
  54. Урок 54. 00:07:41
    Styling Next.js Apps
  55. Урок 55. 00:01:43
    Intro to App vs Pages Router
  56. Урок 56. 00:12:00
    App Router
  57. Урок 57. 00:07:32
    Pages Router
  58. Урок 58. 00:00:30
    mixtape player
  59. Урок 59. 00:02:57
    nav types
  60. Урок 60. 00:02:10
    Link comp
  61. Урок 61. 00:05:07
    Implement Linkl
  62. Урок 62. 00:02:35
    Link pre-fetching
  63. Урок 63. 00:06:55
    useRouter
  64. Урок 64. 00:04:21
    redirect func
  65. Урок 65. 00:05:43
    window.history
  66. Урок 66. 00:00:55
    Summary for 4 types of nav
  67. Урок 67. 00:06:18
    Demo - Building a Next.js Authentication System
  68. Урок 68. 00:04:17
    Tech Stack Building a Production-Ready Authentication System
  69. Урок 69. 00:01:55
    Creating our Next.js App for Authy
  70. Урок 70. 00:06:13
    Setting up Shadcn component library
  71. Урок 71. 00:04:15
    Integrating Auth.js with Auth Secret
  72. Урок 72. 00:03:48
    Creating our Auth Library
  73. Урок 73. 00:02:04
    Creating a Credentials Provider with Next Auth
  74. Урок 74. 00:02:49
    Signing In with Next.js
  75. Урок 75. 00:06:10
    sign in form server vs client component
  76. Урок 76. 00:03:47
    Fix the Error
  77. Урок 77. 00:10:36
    Building a Responsive UI
  78. Урок 78. 00:03:55
    usepathname and redirect
  79. Урок 79. 00:04:21
    authenticated status
  80. Урок 80. 00:02:43
    Adding Links to Header component
  81. Урок 81. 00:04:54
    Adding a NavLink Component
  82. Урок 82. 00:04:45
    Creating a Dashboard route
  83. Урок 83. 00:05:09
    Creating a Dashboard children routes
  84. Урок 84. 00:02:06
    Log out functionality
  85. Урок 85. 00:07:10
    middleware
  86. Урок 86. 00:02:05
    route groups
  87. Урок 87. 00:01:57
    final demo
  88. Урок 88. 00:05:18
    The Three Data Fetching Methods in Next.js
  89. Урок 89. 00:02:13
    SSR
  90. Урок 90. 00:04:51
    Pros and Cons
  91. Урок 91. 00:04:03
    Caching Deep Dive
  92. Урок 92. 00:06:04
    static
  93. Урок 93. 00:03:24
    isr
  94. Урок 94. 00:02:26
    ssr
  95. Урок 95. 00:02:35
    server action
  96. Урок 96. 00:02:50
    intro to OSS
  97. Урок 97. 00:03:16
    Create Next app
  98. Урок 98. 00:01:12
    Shadcn variables in Globals.css
  99. Урок 99. 00:01:07
    Apply the Theme for our App
  100. Урок 100. 00:00:45
    commit
  101. Урок 101. 00:05:25
    Build the Home Page
  102. Урок 102. 00:05:32
    Build a Navigation Bar
  103. Урок 103. 00:05:32
    Choosing the Right Data Fetching Strategy
  104. Урок 104. 00:03:20
    Setup Github Rest API
  105. Урок 105. 00:05:40
    Invoke Github API
  106. Урок 106. 00:01:15
    Render Potions on the Page
  107. Урок 107. 00:08:51
    Transform Github data
  108. Урок 108. 00:03:01
    Display github info in Cards
  109. Урок 109. 00:03:35
    cntd display gh
  110. Урок 110. 00:02:37
    Cache hit-miss
  111. Урок 111. 00:04:35
    Dynamic fn revalidate
  112. Урок 112. 00:00:13
    git commit
  113. Урок 113. 00:01:09
    Server vs Client Logs
  114. Урок 114. 00:03:03
    Responsive Spirit Shop Cards
  115. Урок 115. 00:07:03
    card styling
  116. Урок 116. 00:03:04
    card styling
  117. Урок 117. 00:02:34
    card- effect+stars
  118. Урок 118. 00:03:29
    forks and badges
  119. Урок 119. 00:02:22
    Fix Spacing
  120. Урок 120. 00:02:19
    Format Number
  121. Урок 121. 00:00:22
    git commit
  122. Урок 122. 00:01:21
    dynamic potion slug
  123. Урок 123. 00:01:47
    dynamic potion slug page + Linking
  124. Урок 124. 00:02:38
    Potion Details Page Architecture
  125. Урок 125. 00:02:57
    Github API for Potion Details
  126. Урок 126. 00:01:33
    Not Found Page
  127. Урок 127. 00:02:07
    ISR data fetch visual
  128. Урок 128. 00:00:37
    impl isr
  129. Урок 129. 00:04:40
    ISR in Potion Details Page
  130. Урок 130. 00:04:19
    Prod Build
  131. Урок 131. 00:01:46
    Dynamic Paramas
  132. Урок 132. 00:01:34
    Prefetch +ISR
  133. Урок 133. 00:05:54
    Potion Details Page - Incremental Static Regeneration
  134. Урок 134. 00:03:13
    Potion Details Page - Left and Right Columns
  135. Урок 135. 00:04:41
    Atomic Components
  136. Урок 136. 00:08:41
    Atomic Comp on Page
  137. Урок 137. 00:08:07
    Github Commit
  138. Урок 138. 00:04:56
    Leverage Atoms
  139. Урок 139. 00:05:58
    Forks + Stars
  140. Урок 140. 00:02:16
    Adjust Container Height
  141. Урок 141. 00:02:35
    Mystery Potion Page - Choosing the Right Fetching Strategy
  142. Урок 142. 00:02:56
    Create MP Page
  143. Урок 143. 00:05:18
    Fetch call
  144. Урок 144. 00:01:08
    Prod Build
  145. Урок 145. 00:00:13
    Commit
  146. Урок 146. 00:06:33
    Dynamic Server Usage
  147. Урок 147. 00:00:41
    Git commit
  148. Урок 148. 00:05:39
    Implementing Seamless Filters
  149. Урок 149. 00:01:21
    Search Params
  150. Урок 150. 00:01:03
    Filtering Potions
  151. Урок 151. 00:04:30
    Summary
  152. Урок 152. 00:06:20
    SEO
  153. Урок 153. 00:03:27
    Genmetadata
  154. Урок 154. 00:00:11
    Git Commit
  155. Урок 155. 00:03:51
    Deploy
  156. Урок 156. 00:02:15
    Review Final App
  157. Урок 157. 00:05:34
    What are Server and Client Components
  158. Урок 158. 00:05:00
    Exposing Server aPI keys
  159. Урок 159. 00:00:13
    Using Suspense in Next.js
  160. Урок 160. 00:01:53
    Intro to Analytics Dashboard
  161. Урок 161. 00:02:59
    Intro to Analytics Dashboard (1)
  162. Урок 162. 00:02:59
    App Demo Pulse Analytics Dashboard
  163. Урок 163. 00:03:39
    Tech Stack
  164. Урок 164. 00:06:28
    Pulse Tour_ How This Next.js App Is Structure
  165. Урок 165. 00:03:27
    Fixing Slow Navigation in Next.js
  166. Урок 166. 00:00:55
    Fixing Slow Navigation in Next.js (1)
  167. Урок 167. 00:05:58
    Progressive Rendering in Next.js_ Making Layouts Feel Instant
  168. Урок 168. 00:02:39
    Fixing Layout Shift in Next.js_ Why CLS Hurts Your UX (and SEO)
  169. Урок 169. 00:05:53
    Highlighting the Active Insight_ Making Navigation State Visual in Next.js
  170. Урок 170. 00:03:37
    Highlight the Active Insight_ Solving the Client vs Server Challenge in Next.js
  171. Урок 171. 00:02:46
    Rendering Without Blocking
  172. Урок 172. 00:03:47
    Modern Search with Next.js Form
  173. Урок 173. 00:00:46
    Modern Search with Next.js Form (1)
  174. Урок 174. 00:00:26
    Modern Search with Next.js Form (2)
  175. Урок 175. 00:04:00
    Add Visual Feedback to Search
  176. Урок 176. 00:05:57
    Updating URL in Real Time
  177. Урок 177. 00:02:13
    Build Context-Aware Search
  178. Урок 178. 00:01:09
    Prevent Scroll Jumps During Live Search
  179. Урок 179. 00:03:16
    Use Transition to Show Loading Feedback
  180. Урок 180. 00:06:55
    Build Dynamic Filters with URL State Suspense and Optimistic UI
  181. Урок 181. 00:06:00
    Build Dynamic Filter Options from Prisma
  182. Урок 182. 00:03:32
    Apply Filters Dynamically to Visitor Journeys
  183. Урок 183. 00:04:41
    Show Loading Feedback Instantly
  184. Урок 184. 00:03:58
    Make Visitor Filters Feel Instant
  185. Урок 185. 00:03:57
    Avoid Refetching with Staletimes
  186. Урок 186. 00:03:19
    Build Analytics Info Query with Prisma
  187. Урок 187. 00:03:59
    Build Analytics Info Query with Prisma (1)
  188. Урок 188. 00:03:29
    Partial Pre-rendering in Pulse
  189. Урок 189. 00:03:21
    PPR in Action_ Analytics Dashboard
  190. Урок 190. 00:08:53
    Deploying Prisma and Pulse to Production
  191. Урок 191. 00:02:36
    Summary_ Pulse Analytics Dashboard
  192. Урок 192. 00:02:07
    Introduction to Stockorama App
  193. Урок 193. 00:01:49
    Tech Stack for Stockorama App
  194. Урок 194. 00:01:24
    Create Stockorama App
  195. Урок 195. 00:11:24
    Stockorama App Styling
  196. Урок 196. 00:03:31
    Introducing Server Actions
  197. Урок 197. 00:01:31
    Where would we need Server Actions_
  198. Урок 198. 00:05:29
    Server Actions vs API Routes in Practice
  199. Урок 199. 00:01:04
    Server Actions vs API Routes in Practice (1)
  200. Урок 200. 00:02:06
    Redirects with Server Actions
  201. Урок 201. 00:02:20
    Introducing MongoDB and Prisma
  202. Урок 202. 00:03:46
    Setup MongoDB and Prisma
  203. Урок 203. 00:05:04
    App Architecture Stockorama App
  204. Урок 204. 00:02:30
    Creating a new Product with Server Actions
  205. Урок 205. 00:02:00
    Refactoring into a new Server file
  206. Урок 206. 00:05:31
    Using useActionState for form handling
  207. Урок 207. 00:00:36
    Form data validation in Create Product
  208. Урок 208. 00:02:22
    What is Zod_
  209. Урок 209. 00:04:18
    Validating form fields with Zod
  210. Урок 210. 00:04:48
    Validating form fields with Zod (1)
  211. Урок 211. 00:02:56
    Store Products temporarily and Redirects
  212. Урок 212. 00:01:17
    Store Products temporarily and Redirects (1)
  213. Урок 213. 00:01:36
    Setting up Mongodb in Stockorama App
  214. Урок 214. 00:03:29
    Setting up Mongodb in Stockorama App (1)
  215. Урок 215. 00:04:46
    Setting up Mongodb in Stockorama App (2)
  216. Урок 216. 00:05:52
    Setting up Mongodb in Stockorama App (3)
  217. Урок 217. 00:00:43
    Setting up Mongodb in Stockorama App (4)
  218. Урок 218. 00:05:57
    Products Page Structure
  219. Урок 219. 00:03:07
    Fetching and Displaying Products with Prisma
  220. Урок 220. 00:03:48
    Like Component in Stockorama App
  221. Урок 221. 00:04:30
    Like Component in Stockorama App (1)
  222. Урок 222. 00:01:49
    Why do we need useOptimistic_
  223. Урок 223. 00:04:43
    Using useOptimistic for Instant UI Feedback
  224. Урок 224. 00:02:57
    Loading States with Like Button
  225. Урок 225. 00:06:09
    Building Products Page with Next.js
  226. Урок 226. 00:02:39
    How Server Actions get Exposed_
  227. Урок 227. 00:03:08
    Final Project Demo - Stockorama App
  228. Урок 228. 00:01:59
    How I Architected My Course Platform
  229. Урок 229. 00:05:41
    How I Architected My Course Platform (1)
  230. Урок 230. 00:04:18
    How I Architected My Course Platform (2)
  231. Урок 231. 00:05:03
    How I Architected My Course Platform (3)
  232. Урок 232. 00:01:18
    How I Architected My Course Platform (4)
  233. Урок 233. 00:02:21
    Creating a Merito Next.js App
  234. Урок 234. 00:03:45
    Building the Landing Page
  235. Урок 235. 00:03:24
    Building the Landing Page (1)
  236. Урок 236. 00:07:19
    Creating a Resusable Header
  237. Урок 237. 00:03:51
    Set Up shadcn_ui in Next.js
  238. Урок 238. 00:06:13
    Building the Banner Section
  239. Урок 239. 00:05:37
    Building the Banner Section (1)
  240. Урок 240. 00:00:41
    Building the Banner Section (2)
  241. Урок 241. 00:11:25
    Why Testimonials Matter
  242. Урок 242. 00:03:51
    Building the Pricing UI Section
  243. Урок 243. 00:08:07
    Building the Pricing UI Section (1)
  244. Урок 244. 00:04:04
    Build a CTA Section in Next.js
  245. Урок 245. 00:01:39
    Adding a Footer
  246. Урок 246. 00:04:28
    Introduction to Auth in Merito
  247. Урок 247. 00:05:15
    Set Up Clerk Authentication in Next.js
  248. Урок 248. 00:00:45
    Set Up Clerk Authentication in Next.js (1)
  249. Урок 249. 00:02:48
    Create Custom Sign In and Sign Up Pages with Clerk in Next.js
  250. Урок 250. 00:01:30
    Protect Routes with Clerk Middleware in Next.js
  251. Урок 251. 00:04:34
    Build an Auth Layout for Sign In_Up in Next.js
  252. Урок 252. 00:02:54
    Verify Users in the Clerk Dashboard
  253. Урок 253. 00:01:47
    Introduction to Dashboard in Merito
  254. Урок 254. 00:05:52
    Creating a Separate Dashboard Layout with Route Groups
  255. Урок 255. 00:05:28
    Building the Dashboard Cards
  256. Урок 256. 00:04:34
    Building the Dashboard Cards (1)
  257. Урок 257. 00:01:47
    Merito App Data Layer_ Neon Postgres and Prisma ORM
  258. Урок 258. 00:03:22
    Setting Up Neon Postgres for the Merito App
  259. Урок 259. 00:03:31
    Set Up Prisma with Neon in Next.js
  260. Урок 260. 00:04:07
    Designing the Merito Database Schema
  261. Урок 261. 00:03:33
    Create Prisma Schema for Merito App
  262. Урок 262. 00:02:37
    Seed Neon Postgres and Replace Mock Data in the Dashboard
  263. Урок 263. 00:06:30
    Replace Dashboard Mock Data with Real Prisma Data
  264. Урок 264. 00:01:50
    Refactor Forms Query into a Server-Only Lib
  265. Урок 265. 00:03:33
    Server-Only vs “use server”_ Keep Backend Code Off the Client
  266. Урок 266. 00:02:26
    Delete Testimonial Forms with Server Actions (Secure + Revalidation)
  267. Урок 267. 00:03:19
    Delete Form from Dashboard with Server Action
  268. Урок 268. 00:02:40
    Delete Form from Dashboard with Server Action (1)
  269. Урок 269. 00:03:59
    Dashboard Delete Form Action
  270. Урок 270. 00:04:11
    Dashboard Delete Form Action (1)
  271. Урок 271. 00:04:11
    User Feedback with Toasts (Sonner + shadcn_ui)
  272. Урок 272. 00:02:30
    User Feedback with Toasts (Sonner + shadcn_ui) (1)
  273. Урок 273. 00:04:29
    Make Delete Non-Blocking with useTransition
  274. Урок 274. 00:02:40
    Secure Form Deletion_ Validate Authorize Revalidate
  275. Урок 275. 00:03:59
    Secure Form Deletion_ Validate Authorize Revalidate (1)
  276. Урок 276. 00:04:11
    Secure Form Deletion_ Validate Authorize Revalidate (2)
  277. Урок 277. 00:01:46
    Recap_ Building Production-Ready Form Deletion
  278. Урок 278. 00:02:12
    Create a Form (Modal + Validation + Server Action)
  279. Урок 279. 00:05:34
    Why Use React Hook Form for the Create Form
  280. Урок 280. 00:02:41
    Validate the Create Form with Zod + React Hook Form
  281. Урок 281. 00:00:58
    Validate the Create Form with Zod + React Hook Form (1)
  282. Урок 282. 00:11:05
    Building the Create Form with React Hook Form Zod and shadcn_ui
  283. Урок 283. 00:03:37
    Create Form Dialog (shadcn_ui) with Controlled Open State
  284. Урок 284. 00:01:57
    Execute Create Form with FormData and a Typed Server Action
  285. Урок 285. 00:03:23
    Hooking Up the Create Form with useActionState in Next.js
  286. Урок 286. 00:03:16
    Persist Form with Prisma and Consistent Error Handling
  287. Урок 287. 00:05:30
    Short IDs with nanoid + Success UI for the Create Form
  288. Урок 288. 00:02:09
    Build the Reviews Page with Dynamic Data Embeds and Wall of Love
  289. Урок 289. 00:02:40
    Create a Dynamic Reviews Route by Form ID in Next.js
  290. Урок 290. 00:06:40
    Build Reviews Page Header_ Params Layout and Actions in Next.js
  291. Урок 291. 00:01:14
    Server vs Client Components on the Reviews Page
  292. Урок 292. 00:00:54
    Fetch Form Details and Testimonials by formId in Next.js
  293. Урок 293. 00:07:08
    Fetch Form Details and Testimonials by formId in Next.js (1)
  294. Урок 294. 00:03:56
    Fetch Testimonials by Form ID in Next.js with Prisma
  295. Урок 295. 00:03:41
    Create a Responsive Testimonials Grid with Cards in Next.js
  296. Урок 296. 00:06:28
    Add Ratings Dates and Status Badges to Testimonial Cards in Next.js
  297. Урок 297. 00:02:14
    Build a “Wall of Love” with a Testimonials List in Next.js
  298. Урок 298. 00:04:43
    Build a Copy Code Button with Toast Feedback in Next.js
  299. Урок 299. 00:01:24
    Build a Copy Code Button with Toast Feedback in Next.js (1)
  300. Урок 300. 00:02:43
    Build a Copy Code Button with Toast Feedback in Next.js (2)
  301. Урок 301. 00:06:54
    Embed Section Component for the Reviews Page
  302. Урок 302. 00:04:17
    Custom Not Found Page for Missing Review Forms in Next.js
  303. Урок 303. 00:05:34
    Adding Approve and Reject Buttons for Testimonials in Next.js
  304. Урок 304. 00:09:28
    Building the Update Testimonial Status Action
  305. Урок 305. 00:04:09
    Test Approve_Reject Workflow & Sort Testimonials in Next.js (Prisma)
  306. Урок 306. 00:04:18
    Test Approve_Reject Workflow & Sort Testimonials in Next.js (Prisma) (1)
  307. Урок 307. 00:00:53
    Roadmap_ Build Responses Embed and Feedback Preview Pages in Next.js
  308. Урок 308. 00:01:25
    Architecture Overview_ Responses & Embed Pages for Testimonials in Next.js
  309. Урок 309. 00:06:27
    Build a Public Embed “Wall of Love” Page in Next.js
  310. Урок 310. 00:01:30
    Build a Public Embed “Wall of Love” Page in Next.js (1)
  311. Урок 311. 00:02:17
    Public Embed Route for Testimonials
  312. Урок 312. 00:01:56
    Add Footer to Landing & Split Layouts for a Clean Public Embed (Next.js)
  313. Урок 313. 00:02:07
    Copy & Test the Wall of Love Embed Code in Next.js (Iframe)
  314. Урок 314. 00:03:27
    Fix Next.js Hydration Errors_ Invalid HTML Browser Parsing & Mismatched DOM
  315. Урок 315. 00:02:50
    Next.js Hydration Errors_ Common Examples & How to Fix Them
  316. Урок 316. 00:04:25
    Fix Hydration Errors in Create Form Dialog & Dashboard Cards (asChild + No Nested Links)
  317. Урок 317. 00:01:43
    Build an AI Feedback Form with React Hook Form and Server Actions
  318. Урок 318. 00:03:42
    Create a Public Feedback Form Page in Next.js
  319. Урок 319. 00:02:48
    Architecting a Public AI Feedback Form in Next.js
  320. Урок 320. 00:03:44
    Build a Centered Public Feedback Wrapper & Extract the AI Feedback Form Component
  321. Урок 321. 00:02:34
    Build the AI Feedback Form_ RHF + Zod Loading States and Accept_Keep Original
  322. Урок 322. 00:06:14
    Define a Zod Feedback Schema & Wire Up React Hook Form (Next.js + shadcn_ui)
  323. Урок 323. 00:04:03
    Create a Typed FormField Wrapper for the AI Feedback Form
  324. Урок 324. 00:02:33
    Add a Reusable Star Rating Field to the AI Feedback Form (RHF + shadcn_ui)
  325. Урок 325. 00:00:40
    Add a Reusable Star Rating Field to the AI Feedback Form (RHF + shadcn_ui) (1)
  326. Урок 326. 00:06:59
    Building an Interactive Star Rating with Optimal Client_Server Splits
  327. Урок 327. 00:01:19
    Submit Testimonial with a Server Action (Prisma + Zod)
  328. Урок 328. 00:06:47
    Create a Testimonial in Prisma with a Next.js Server Action
  329. Урок 329. 00:03:03
    Redirect to a Thank You Page After Testimonial Submission
  330. Урок 330. 00:03:03
    Add Loading and Success States to Testimonial Submission with useActionState
  331. Урок 331. 00:04:25
    Server vs Client Redirects After Testimonial Submission
  332. Урок 332. 00:02:03
    Build a Thank You Page for Testimonial Submissions
  333. Урок 333. 00:08:51
    Design a Polished Thank You Page for Testimonial Submissions