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