[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Source view] [Print] [Project Stats]
Blocks API: WP_Block class
File Size: | 658 lines (23 kb) |
Included or required: | 0 times |
Referenced: | 0 times |
Includes or requires: | 0 files |
WP_Block:: (7 methods):
__construct()
refresh_context_dependents()
refresh_parsed_block_dependents()
__get()
process_block_bindings()
replace_html()
render()
__construct( $block, $available_context = array() X-Ref |
Constructor. Populates object properties from the provided block instance argument. The given array of context values will not necessarily be available on the instance itself, but is treated as the full set of values provided by the block's ancestry. This is assigned to the private `available_context` property. Only values which are configured to consumed by the block via its registered type will be assigned to the block's `context` property. param: array $block { param: array $available_context Optional array of ancestry context values. param: WP_Block_Type_Registry $registry Optional block type registry. |
refresh_context_dependents() X-Ref |
Updates the context for the current block and its inner blocks. The method updates the context of inner blocks, if any, by passing down any context values the block provides (`provides_context`). If the block has inner blocks, the method recursively processes them by creating new instances of `WP_Block` for each inner block and updating their context based on the block's `provides_context` property. |
refresh_parsed_block_dependents() X-Ref |
Updates the parsed block content for the current block and its inner blocks. This method sets the `inner_html` and `inner_content` properties of the block based on the parsed block content provided during initialization. It ensures that the block instance reflects the most up-to-date content for both the inner HTML and any string fragments around inner blocks. If the block has inner blocks, this method initializes a new `WP_Block_List` for them, ensuring the correct content and context are updated for each nested block. |
__get( $name ) X-Ref |
Returns a value from an inaccessible property. This is used to lazily initialize the `attributes` property of a block, such that it is only prepared with default attributes at the time that the property is accessed. For all other inaccessible properties, a `null` value is returned. return: array|null Prepared attributes, or null. param: string $name Property name. |
process_block_bindings() X-Ref |
Processes the block bindings and updates the block attributes with the values from the sources. A block might contain bindings in its attributes. Bindings are mappings between an attribute of the block and a source. A "source" is a function registered with `register_block_bindings_source()` that defines how to retrieve a value from outside the block, e.g. from post meta. This function will process those bindings and update the block's attributes with the values coming from the bindings. ### Example The "bindings" property for an Image block might look like this: ```json { "metadata": { "bindings": { "title": { "source": "core/post-meta", "args": { "key": "text_custom_field" } }, "url": { "source": "core/post-meta", "args": { "key": "url_custom_field" } } } } } ``` The above example will replace the `title` and `url` attributes of the Image block with the values of the `text_custom_field` and `url_custom_field` post meta. return: array The computed block attributes for the provided block bindings. |
replace_html( string $block_content, string $attribute_name, $source_value ) X-Ref |
Depending on the block attribute name, replace its value in the HTML based on the value provided. return: string The modified block content. param: string $block_content Block content. param: string $attribute_name The attribute name to replace. param: mixed $source_value The value used to replace in the HTML. |
render( $options = array() X-Ref |
Generates the render output for the block. return: string Rendered block output. param: array $options { |
Generated : Tue Jan 21 08:20:01 2025 | Cross-referenced by PHPXref |