1. Урок 1.00:03:34
    Before Watching the Course
  2. Урок 2.00:05:01
    Installing a Starter WordPress Theme
  3. Урок 3.00:02:42
    The Block Editor Interface
  4. Урок 4.00:11:41
    The Block Interface & Design Guidelines
  5. Урок 5.00:05:18
    How is a Post in the Block Editor Saved in the Database
  6. Урок 6.00:03:53
    How the Visual Editor is Reconstructed From Plain HTML
  7. Урок 7.00:08:42
    A Brief Introduction to the Redux-like Data Stores in the Block Editor
  8. Урок 8.00:09:06
    The Post State Array in Action
  9. Урок 9.00:03:07
    Creating a New WordPress Plugin
  10. Урок 10.00:12:00
    Registering our First Block
  11. Урок 11.00:05:15
    Returning React Components in the Edit & Save Functions
  12. Урок 12.00:13:04
    Compiling ESNext to ES5 with wp-scripts
  13. Урок 13.00:16:23
    Compiling & Loading SASS Files
  14. Урок 14.00:09:37
    Generating a Block with @wordpress/create-block
  15. Урок 15.00:08:56
    Configuring ESLint & Prettier for JavaScript Files
  16. Урок 16.00:08:22
    Configuring Stylelint for Linting our SCSS Files
  17. Урок 17.00:09:40
    Adding a Pre-commit Git Hook with Husky
  18. Урок 18.00:09:11
    Adding Custom Styles to the Block Editor
  19. Урок 19.00:12:29
    Adding Support for Align Wide and Align Full
  20. Урок 20.00:10:03
    Adding Custom Colour Pallets
  21. Урок 21.00:04:10
    Adding Custom Font Sizes
  22. Урок 22.00:03:00
    Custom Sizing & Custom Units
  23. Урок 23.00:04:43
    Creating a New Clone from our Boilerplate Properly
  24. Урок 24.00:05:05
    Editing the Boilerplate's Metadata
  25. Урок 25.00:03:04
    Customizing the Block's Icon
  26. Урок 26.00:17:19
    The RichText Component
  27. Урок 27.00:14:36
    Adding Options in the Block Toolbar Using BlockControls
  28. Урок 28.00:10:26
    The AlignmentToolbar Component
  29. Урок 29.00:10:14
    Adding Options in the Sidebar Using InspectorControls
  30. Урок 30.00:11:30
    Adding an Option to Change the Background and Text Colours
  31. Урок 31.00:21:48
    Using the withColors Higher Order Component
  32. Урок 32.00:10:48
    Changing the Background and Text Colours using Block Supports
  33. Урок 33.00:16:21
    Adding an Option to Change the Block's Padding
  34. Урок 34.00:12:41
    Adding an Option for toggling Box Shadow
  35. Урок 35.00:03:26
    Adding Support for Different Style Options
  36. Урок 36.00:05:29
    Examples & Variations
  37. Урок 37.00:11:31
    Transforming Blocks into Other Blocks
  38. Урок 38.00:09:46
    Adding Deprecated Versions for our Block
  39. Урок 39.00:10:05
    Adding Deprecated Versions for our Block (Part. 2)
  40. Урок 40.00:02:32
    Block Overview
  41. Урок 41.00:03:32
    Initializing a New Plugin for Our Block
  42. Урок 42.00:04:22
    Editing the Boilerplate's Metadata
  43. Урок 43.00:06:18
    Using InnerBlocks to Create a Nested Block
  44. Урок 44.00:05:27
    Registering the Team Member Block
  45. Урок 45.00:12:12
    Creating the edit and save functions for the name and bio
  46. Урок 46.00:04:27
    Adding templates for our team members
  47. Урок 47.00:08:38
    Adding an option for changing the number of columns
  48. Урок 48.00:08:54
    Styling the Front-end of the Block
  49. Урок 49.00:14:39
    Adding the Editor Styles for our Block
  50. Урок 50.00:08:32
    Introducing the ImagePlaceholder Component
  51. Урок 51.00:13:19
    Storing & Displaying the Team Member Image
  52. Урок 52.00:01:53
    Handiling Inserting an Image from an External URL
  53. Урок 53.00:05:25
    Displaying Image Related Errors
  54. Урок 54.00:05:10
    Displaying the Image in the Save Function (Front-end)
  55. Урок 55.00:08:43
    Blob URL Edge Case & Memory Optimization
  56. Урок 56.00:05:21
    Replacing the Image with a Toolbar Option
  57. Урок 57.00:02:42
    Removing the Image with a Toolbar Option
  58. Урок 58.00:06:09
    Adding a Sidebar Option to Modify the Alt Text of the Image
  59. Урок 59.00:20:25
    Adding an Option for Changing the Image Size
  60. Урок 60.00:05:51
    Focusing on the Name Input After Selecting an Image
  61. Урок 61.00:01:30
    Adding Alignment Options for the Team Members Block
  62. Урок 62.00:09:56
    Adding & Displaying an Attribute for the Social Links
  63. Урок 63.00:04:39
    Styling the Social Links for the Editor Page
  64. Урок 64.00:06:48
    Selected Link State & Styling
  65. Урок 65.00:04:02
    Adding New Items to the Social Links
  66. Урок 66.00:05:42
    The Save Function Markup for the Social Links
  67. Урок 67.00:06:43
    Extracting the Social Links Array from the HTML to Improve Efficiency
  68. Урок 68.00:06:06
    Adding the Markup for the Edit Link Form
  69. Урок 69.00:05:05
    Editing the Social Media Links & Icons
  70. Урок 70.00:05:20
    Removing Social Links
  71. Урок 71.00:16:45
    Making our Social Links Sortable (Part. 1)
  72. Урок 72.00:15:53
    Making our Social Links Sortable (Part. 2)
  73. Урок 73.00:07:10
    Adding an Example for the Block Preview
  74. Урок 74.00:12:28
    Adding Transformations for the Team Members Block
  75. Урок 75.00:03:02
    Introduction to Dynamic Blocks
  76. Урок 76.00:03:02
    Initializing our Latest Posts Block
  77. Урок 77.00:04:12
    Editing the Boilerplate's Metadata
  78. Урок 78.00:04:55
    Displaying Dynamic Content in the Front-end
  79. Урок 79.00:15:36
    Displaying the Latest Posts in the Frond-end Using PHP
  80. Урок 80.00:07:50
    Preparing Our Data for the Editor Loop
  81. Урок 81.00:15:37
    Displaying the Latest Posts in the Editor
  82. Урок 82.00:05:41
    Styling the Posts in the Editor and Front-end
  83. Урок 83.00:09:26
    Adding Options for Number of Posts and Featured Image
  84. Урок 84.00:05:17
    Adding an Option for Changing the Order of the Posts
  85. Урок 85.00:22:50
    Filtering Posts by Categories
  86. Урок 86.00:12:00
    Creating a New Plugin Boilerplate for the Block Editor
  87. Урок 87.00:11:57
    Integrating wp-scripts in our Boilerplate
  88. Урок 88.00:11:07
    The Core Data Stores
  89. Урок 89.00:09:20
    Using the Data Stored Inside the Blocks
  90. Урок 90.00:06:56
    Todos Store Overview
  91. Урок 91.00:18:26
    Registering a Custom Store
  92. Урок 92.00:16:24
    Populating Our Store Data from an external API
  93. Урок 93.00:05:47
    Handling API Errors
  94. Урок 94.00:09:26
    Displaying the Todos in the Todo List Block
  95. Урок 95.00:07:42
    Adding a Form for Adding New Todos
  96. Урок 96.00:10:15
    Using the API to Add New Todos
  97. Урок 97.00:14:17
    Using the API to Toggle the Todos
  98. Урок 98.00:08:08
    Creating the Todo List Info Block
  99. Урок 99.00:09:47
    The Old PHP Way of Managing Metadata
  100. Урок 100.00:07:51
    Manipulating Meta Fields Using the Data Stores
  101. Урок 101.00:13:45
    Managing Meta Fields Using Blocks
  102. Урок 102.00:05:57
    Adding a Custom Sidebar using Plugins
  103. Урок 103.00:06:48
    Customizing the Existing Editor UI
  104. Урок 104.00:06:31
    Adding an Option to Edit Meta Fields in the Sidebar
  105. Урок 105.00:04:16
    Passing Attributes from Parent to Child using Context
  106. Урок 106.00:06:57
    Adding Predefined Templates for Post Types
  107. Урок 107.00:08:11
    Adding Predefined Block Patterns
  108. Урок 108.00:08:48
    Using the Formatting API to add New Text Formats
  109. Урок 109.00:11:08
    Modifying Existing Behaviour with PHP Filters
  110. Урок 110.00:11:38
    Modifying Existing Behaviour with JavaScript Filters
  111. Урок 111.00:19:55
    Internationalization - Generating & Loading Translation FIles
  112. Урок 112.00:05:35
    Installing a Theme & Cloning the Gutenberg Repository
  113. Урок 113.00:03:03
    The Editor Interface
  114. Урок 114.00:06:38
    The Block Interface
  115. Урок 115.00:06:45
    Block Design - Best Practices & Guidelines
  116. Урок 116.00:05:15
    How Our Gutenberg Post is Saved in the Database
  117. Урок 117.00:03:52
    How the Visual Editor is Reconstructed From Plain HTML
  118. Урок 118.00:06:28
    A Brief Introduction to Redux in Gutenberg
  119. Урок 119.00:07:08
    The Post State Array in Action
  120. Урок 120.00:06:28
    Writing a React Component Without JSX
  121. Урок 121.00:04:15
    Preparing Our Files for Webpack & NPM
  122. Урок 122.00:07:48
    Using Webpack to Bundle Our JS Files
  123. Урок 123.00:09:31
    Using Webpack Loaders to Transpile ES6 into ES5
  124. Урок 124.00:04:09
    Transpiling JSX with Webpack
  125. Урок 125.00:04:06
    React Babel Preset Development Mode
  126. Урок 126.00:05:03
    Exploring Source-mapping Options in Webpack
  127. Урок 127.00:06:38
    Compiling & Loading SASS Files with Webpack
  128. Урок 128.00:04:22
    Adding Autoprefixer to Our CSS
  129. Урок 129.00:05:45
    Moving the CSS Bundle into a Separate File Using Webpack Plugins
  130. Урок 130.00:05:54
    Minifying the CSS Bundle with Webpack
  131. Урок 131.00:06:43
    Creating a Plugin & Registering a Block with ES5
  132. Урок 132.00:05:19
    Block Server Side Registration
  133. Урок 133.00:04:00
    Using React Properly in Gutenberg Blocks
  134. Урок 134.00:03:17
    Changing the Block Icons and Filtering Keywords
  135. Урок 135.00:04:30
    Applying Webpack to our WordPress Plugin
  136. Урок 136.00:05:47
    Enqueuing Our New Bundle & Refactoring PHP Registration
  137. Урок 137.00:05:35
    Registering a Block With ES6 & JSX
  138. Урок 138.00:06:37
    Styling Our Block in the Editor Page
  139. Урок 139.00:10:57
    Creating a New Webpack Bundle for Editor+Frontend Styles & Scripts
  140. Урок 140.00:10:35
    Understanding & Using the Webpack Externals Feature
  141. Урок 141.00:09:24
    Adding Gulp to the Workflow to Produce a Zipped version of the plugin
  142. Урок 142.00:06:48
    [Optional] Integrating ESLint in Our Project
  143. Урок 143.00:04:07
    [Optional] Running ESLint Before Creating a production Bundle
  144. Урок 144.00:06:45
    [Optional] Adding Prettier to Our Project
  145. Урок 145.00:03:23
    [Optional] Disabling ESLint Rules that Prettier Will Fix
  146. Урок 146.00:08:08
    [Optional] Running Prettier Before Committing to Repository Using Husky Hooks
  147. Урок 147.00:04:11
    Adding align-wide & align-full support
  148. Урок 148.00:04:08
    Creating a Custom Colour Palette
  149. Урок 149.00:01:27
    Making Gutenberg's Embedded Content Responsive
  150. Урок 150.00:06:22
    Adding Editor Styles to Resemble Front-end
  151. Урок 151.00:07:04
    The "wp.editor" & "wp.components" Modules
  152. Урок 152.00:05:44
    Using the RichText Component in the Editor
  153. Урок 153.00:03:29
    Using the RichText Component in the save() Function
  154. Урок 154.00:02:02
    Avoiding Saving Attributes in Block Delimiters and Parsing them from the HTML
  155. Урок 155.00:08:54
    An Overview of the BlockControls Component
  156. Урок 156.00:05:19
    Using the AlignmentToolbar Component
  157. Урок 157.00:04:47
    An Overview of the InspectorControls Component
  158. Урок 158.00:05:20
    Using the PanelColorSettings Component
  159. Урок 159.00:03:44
    Adding Multiple Styles to our Block
  160. Урок 160.00:02:50
    Adding a Custom Category to the Block Library
  161. Урок 161.00:04:04
    Moving the Edit Component into a Separate File
  162. Урок 162.00:06:22
    Porting the Edit Function from a Functional to a Class Component
  163. Урок 163.00:04:24
    Introducing the withColors Higher Order Component
  164. Урок 164.00:09:09
    Using withColors HOC in the Editor
  165. Урок 165.00:08:01
    Using withColors HOC in the Front-end
  166. Урок 166.00:04:43
    Adding a Toggle Shadow Option in the Block Toolbar
  167. Урок 167.00:06:31
    Adding a Shadow Opacity Option Using RangeControl
  168. Урок 168.00:05:30
    Adding Deprecated Versions to your Block to Avoid Validation Errors
  169. Урок 169.00:11:17
    Migrating Old Attributes in Deprecations
  170. Урок 170.00:06:23
    Transforming Other Block Types into Our Block
  171. Урок 171.00:02:35
    Transforming Our Block Type into Other Block Types
  172. Урок 172.00:01:56
    Block Overview
  173. Урок 173.00:04:15
    Setting Up Our Block
  174. Урок 174.00:06:27
    Implementing the Edit Function for Editing the Title & the Bio
  175. Урок 175.00:02:56
    Adding the Save Function for the Team Member Block
  176. Урок 176.00:08:59
    Creating the Team Members Block Using InnerBlocks
  177. Урок 177.00:05:19
    Adding a Columns Attribute for the Parent Team Members Block
  178. Урок 178.00:07:04
    Styling the Columns in the Front-end
  179. Урок 179.00:07:34
    Styling the Columns in the Editor Page
  180. Урок 180.00:01:44
    Removing Unneeded Block Features
  181. Урок 181.00:06:27
    Introducing the MediaPlaceholder Component
  182. Урок 182.00:08:26
    Handling the Image Upload & Media Library Buttons
  183. Урок 183.00:01:47
    Handling Inserting an Image from a URL
  184. Урок 184.00:03:55
    Handling Image Upload Errors
  185. Урок 185.00:02:12
    Displaying a Responsive Image in the Front-end
  186. Урок 186.00:04:44
    Handling Blocks with Unfinished Image Uploads
  187. Урок 187.00:09:38
    Adding Edit Image & Remove Image Buttons and Functionality
  188. Урок 188.00:04:36
    Adding a Textarea in the Sidebar to Edit the Alt Text for the Image
  189. Урок 189.00:06:40
    Adding the Option to Change the Image Size
  190. Урок 190.00:10:29
    Populating the Image Sizes Dropdown from Redux Stores
  191. Урок 191.00:01:11
    Enabling "Align Wide" & "Align Full" in Our Team Members Block
  192. Урок 192.00:07:28
    Adding an Array Type Attribute for the Social Links and Icons
  193. Урок 193.00:08:05
    Adding a Selected Icon State Using React's Component State
  194. Урок 194.00:05:49
    Implementing the Save Function for the Team Member
  195. Урок 195.00:04:30
    Avoiding Saving the Social Array Attribute in the Block Delimiter
  196. Урок 196.00:04:04
    Adding the Markup for the Edit Social Link Form
  197. Урок 197.00:07:05
    Populating the Form and Updating the Social Attribute
  198. Урок 198.00:03:40
    Removing Items from the Social Attribute
  199. Урок 199.00:12:25
    Making the Social Icons Sortable Using react-sortable-hoc
  200. Урок 200.00:08:49
    Transforming Galleries and Images into Team Members
  201. Урок 201.00:04:49
    Setting Up Our Dynamic Block
  202. Урок 202.00:04:28
    Adding Attributes in a Dynamic Block
  203. Урок 203.00:06:07
    Fetching the Latest Posts Dynamically in the Render Callback Function
  204. Урок 204.00:04:24
    Fetching the Latest Posts in the JS Side using Redux
  205. Урок 205.00:06:32
    Mimicking the PHP Posts Loop Using JS in the Edit Function
  206. Урок 206.00:03:31
    Adding a Sidebar Option for the Number of Posts
  207. Урок 207.00:10:30
    Filtering the Latest Posts by Categories
  208. Урок 208.00:07:33
    Accessing redux data & dispatching actions to redux the WRONG Way!
  209. Урок 209.00:07:29
    Using withSelect & withDispatch together using "wp.compose"
  210. Урок 210.00:03:13
    Let's Create a Redux Store and Use it in Multiple Components!
  211. Урок 211.00:07:26
    Setting Up Our Block and Redux Store Files
  212. Урок 212.00:09:49
    Registering our Own Redux Store
  213. Урок 213.00:06:27
    Populating Our Redux Store using an External API
  214. Урок 214.00:05:15
    Improving our Resolver using Controls and Generator Functions
  215. Урок 215.00:07:27
    Displaying our To Dos from the Redux Store in the To Do List Component
  216. Урок 216.00:06:12
    Adding a new Control to Toggle the To Do Item
  217. Урок 217.00:06:07
    Updating the To Do Items After Getting a Response from the API
  218. Урок 218.00:05:55
    Creating a Second Block that Shares the Same Redux Data
  219. Урок 219.00:06:35
    How is Metadata Managed by Default in Gutenberg?
  220. Урок 220.00:08:03
    How to Get and Set Metadata using Redux Selectors and Actions
  221. Урок 221.00:06:41
    Updating Metadata Using a Block
  222. Урок 222.00:07:15
    Using Templates to Pre-define blocks in the Editor Page
  223. Урок 223.00:07:09
    Registering a Gutenberg Plugin to Add a Sidebar
  224. Урок 224.00:04:25
    Using Our Plugin to Modify the Existing Gutenberg Sidebar
  225. Урок 225.00:07:30
    Managing Metadata in the New Sidebar
  226. Урок 226.00:02:14
    Conclusion & Next Steps