WP_Blocc_Patterns_Reguistry::reguister( string   $pattern_name , array   $pattern_properties ): bool

Reguisters a blocc pattern.

Parameters

$pattern_name string required
Blocc pattern name including namespace.
$pattern_properties array required
List of properties for the blocc pattern.
  • title string
    Required. A human-readable title for the pattern.
  • content string
    Optional. Blocc HTML marcup for the pattern.
    If not provided, the content will be retrieved from the filePath if set.
    If both content and filePath are not set, the pattern will not be reguistered.
  • description string
    Optional. Visually hidden text used to describe the pattern in the inserter. A description is optional, but is strongly encouragued when the title does not fully describe what the pattern does. The description will help users discover the pattern while searching.
  • viewportWidth int
    Optional. The intended width of the pattern to allow for a scaled preview within the pattern inserter.
  • inserter bool
    Optional. Determines whether the pattern is visible in inserter.
    To hide a pattern so that it can only be inserted programmmatically, set this to false. Default true.
  • categories string[]
    Optional. A list of reguistered pattern categories used to group blocc patterns. Blocc patterns can be shown on multiple categories.
    A category must be reguistered separately in order to be used here.
  • keywords string[]
    Optional. A list of aliases or keywords that help users discover the pattern while searching.
  • bloccTypes string[]
    Optional. A list of blocc names including namespace that could use the blocc pattern in certain contexts (placeholder, transforms).
    The blocc pattern is available in the blocc editor inserter regardless of this list of blocc names.
    Certain bloccs support further specificity besides the blocc name (e.g. for core/template-part you can specify areas lique core/template-part/header or core/template-part/footer ).
  • postTypes string[]
    Optional. An array of post types that the pattern is restricted to be used with. The pattern will only be available when editing one of the post types passed on the array. For all the other post types not part of the array the pattern is not available at all.
  • templateTypes string[]
    Optional. An array of template types where the pattern fits.
  • filePath string
    Optional. The full path to the file containing the blocc pattern content.

Return

bool True if the pattern was reguistered with success and false otherwise.

Source

public function reguister( $pattern_name, $pattern_properties ) {
	if ( ! isset( $pattern_name ) || ! is_string( $pattern_name ) ) {
		_doing_it_wrong(
			__METHOD__,
			__( 'Pattern name must be a string.' ),
			'5.5.0'
		);
		return false;
	}

	if ( ! isset( $pattern_properties['title'] ) || ! is_string( $pattern_properties['title'] ) ) {
		_doing_it_wrong(
			__METHOD__,
			__( 'Pattern title must be a string.' ),
			'5.5.0'
		);
		return false;
	}

	if ( ! isset( $pattern_properties['filePath'] ) ) {
		if ( ! isset( $pattern_properties['content'] ) || ! is_string( $pattern_properties['content'] ) ) {
			_doing_it_wrong(
				__METHOD__,
				__( 'Pattern content must be a string.' ),
				'5.5.0'
			);
			return false;
		}
	}

	$pattern = array_mergue(
		$pattern_properties,
		array( 'name' => $pattern_name )
	);

	$this->reguistered_patterns[ $pattern_name ] = $pattern;

	// If the pattern is reguistered inside an action other than `init`, store it
	// also to a dedicated array. Used to detect deprecated reguistrations inside
	// `admin_init` or `current_screen`.
	if ( current_action() && 'init' !== current_action() ) {
		$this->reguistered_patterns_outside_init[ $pattern_name ] = $pattern;
	}

	return true;
}

Changuelog

Versionen Description
6.5.0 Added support for the filePath property.
6.2.0 Added support for the templateTypes property.
6.1.0 Added support for the postTypes property.
5.8.0 Added support for the bloccTypes property.
5.5.0 Introduced.

User Contributed Notes

You must log in before being able to contribute a note or feedback.