Helpers
General helpers for development.
Array
data_get
The data_get helper retrieves a value from an array or object using "dot"
notation. If the specified key does not exist, it will return null or a
default value if provided.
use function Mantle\Support\Helpers\data_get;
$data = [
	'user' => [
		'name' => 'John Doe',
		'email' => 'example@example.com'
	]
];
$email = data_get( $data, 'user.email' ); // returns 'example@example.com
data_set
The data_set helper sets a value in an array or object using "dot" notation.
If the specified key does not exist, it will be created.
use function Mantle\Support\Helpers\data_set;
$data = [
	'user' => [
		'name' => 'John Doe',
	],
];
data_set( $data, 'user.email', 'example@example.com' );
data_fill
The data_fill helper is used to set a value in an array or object using "dot"
notation. If the specified key does not exist, it not be created.
use function Mantle\Support\Helpers\data_fill;
$data = [
	'user' => [
		'name' => 'John Doe',
	],
];
data_fill( $data, 'user.email', 'example@example.com' );
head
The head helper retrieves the first element of an array. If the array is
empty, it will return null.
use function Mantle\Support\Helpers\head;
$array = [ 'apple', 'banana', 'cherry' ];
$first = head( $array ); // returns 'apple'
last
The last helper retrieves the last element of an array. If the array is
empty, it will return null.
use function Mantle\Support\Helpers\last;
$array = [ 'apple', 'banana', 'cherry' ];
$last = last( $array ); // returns 'cherry'
value
The value helper retrieves the value of a variable or calls a callback if
the variable is a closure. This is useful for lazy evaluation.
use function Mantle\Support\Helpers\value;
$value = value( 'Hello, World!' ); // returns 'Hello, World!'
$value = value( fn () => { return 'Hello, World!'; } ); // returns 'Hello, World!'
Core Objects
get_comment_object
Nullable wrapper for get_comment().
use function Mantle\Support\Helpers\get_comment_object;
$comment = get_comment_object( 1 ); // returns a comment object or null if not found
get_post_object
Nullable wrapper for get_post().
use function Mantle\Support\Helpers\get_post_object;
$post = get_post_object( 1 ); // returns a post object or null if not found
get_site_object
Nullable wrapper for get_site().
use function Mantle\Support\Helpers\get_site_object;
$site = get_site_object( 1 ); // returns a site object or null if not found
get_term_object
Nullable wrapper for get_term().
use function Mantle\Support\Helpers\get_term_object;
$term = get_term_object( 1 ); // returns a term object or null if not found
get_term_object_by
Nullable wrapper for get_term_by().
use function Mantle\Support\Helpers\get_term_object_by;
$term = get_term_object_by( 'slug', 'example-slug', 'category' ); // returns a term object or null if not found
get_user_object
Nullable wrapper for get_user().
use function Mantle\Support\Helpers\get_user_object;
$user = get_user_object( 1 ); // returns a user object or null if not found
get_user_object_by
Nullable wrapper for get_user_by().
use function Mantle\Support\Helpers\get_user_object_by;
$user = get_user_object_by( 'login', 'exampleuser' ); // returns a user object or null if not found
Environment
is_hosted_env
The is_hosted_env helper checks if the application is running in a hosted
environment. Checks if the site is a production environment.
use function Mantle\Support\Helpers\is_hosted_env;
if ( is_hosted_env() ) {
	// The application is running in a hosted environment
}
is_local_env
The is_local_env helper checks if the application is running in a local
environment. Checks if the site is a local environment.
use function Mantle\Support\Helpers\is_local_env;
if ( is_local_env() ) {
	// The application is running in a local environment
}
is_wp_cli
The is_wp_cli helper checks if the application is running in the WP-CLI
context. This is useful for determining if the code is being executed
through the command line interface.
use function Mantle\Support\Helpers\is_wp_cli;
if ( is_wp_cli() ) {
  // The application is running in the WP-CLI context
}
is_unit_testing
The is_unit_testing helper checks if the application is running in a unit
testing environment via the testing framework.
use function Mantle\Support\Helpers\is_unit_testing;
if ( is_unit_testing() ) {
  // The application is running in a unit testing environment
  dump( 'Unit testing is enabled!' );
}
General
backtickit
The backtickit helper is a simple utility to wrap a string in backticks (```).
use function Mantle\Support\Helpers\backtickit;
$wrapped = backtickit( 'example' ); // returns '`example`'
blank
The blank helper checks if a value is "blank". A value is considered blank
if it is null, an empty string, or an empty array.
use function Mantle\Support\Helpers\blank;
blank( null ); // returns true
blank( '' ); // returns true
blank( [] ); // returns true
blank( 'example' ); // returns false
class_basename
The class_basename helper retrieves the class name of a given object or
class name without the namespace.
use function Mantle\Support\Helpers\class_basename;
class_basename( \Mantle\Support\Helpers\ExampleClass::class ); // returns 'ExampleClass'
class_uses_recursive
The class_uses_recursive helper returns all traits used by a class, its parent
classes and trait of their traits.
use function Mantle\Support\Helpers\class_uses_recursive;
class_uses_recursive( \Mantle\Support\Helpers\ExampleClass::class ); // returns an array of trait names
classname
See Classname;
collect
Returns a Collection instance containing the given value.
use function Mantle\Support\Helpers\collect;
$collection = collect( [ 1, 2, 3 ] ); // returns a Collection instance
defer
The defer() helper function can be used to defer the execution of a function
until the end of the request lifecycle. This can be useful for deferring
functions that should be executed after the response has been sent to the user.
use function Mantle\Support\Helpers\defer;
defer( function() {
  // Your deferred function code here.
} );
filled
The filled helper checks if a value is "filled". A value is considered
filled if it is not null, an empty string, or an empty array.
use function Mantle\Support\Helpers\filled;
filled( null ); // returns false
filled( '' ); // returns false
filled( [] ); // returns false
filled( 'example' ); // returns true
get_callable_fqn
The get_callable_fqn helper retrieves the fully qualified name of a callable
or a closure. This is useful for debugging or logging purposes.
html_string
Returns a HTML instance containing the given value.
use function Mantle\Support\Helpers\html_string;
$html = html_string( '<div id="test">Hello World</div>' );
object_get
The object_get helper retrieves a value from an object using "dot" notation.
If the specified key does not exist, it will return null or a default value if
provided.
use function Mantle\Support\Helpers\object_get;
$object = (object) [
  'user' => (object) [
	  'name' => 'John Doe',
  ]
];
$name = object_get( $object, 'user.name' ); // returns 'John Doe'
retry
The retry helper attempts to execute a given callback a specified number of
times until it succeeds or the maximum number of attempts is reached. If the
callback fails, it will wait for a specified delay before retrying.
use function Mantle\Support\Helpers\retry;
retry(
  times: 5
  callback: function() {
    // Your code that may fail
  },
  sleep: 100 // milliseconds
stringable
Returns an instance of Mantle\Support\Str which contains all the Laravel
string helper methods you might be familiar with. You can reference those
here.
use function Mantle\Support\Helpers\stringable;
stringable( 'example string' )->title(); // Example String
tap
The tap helper allows you to pass a value to a callback and then return the
original value. This is useful for performing side effects on a value without
modifying it.
use function Mantle\Support\Helpers\tap;
$value = tap(
  new Example(),
  function ( Example $example ) {
    $example->doSomething();
  },
);
throw_if
The throw_if helper throws an exception if the given condition passes. This
is useful for validating conditions before executing code.
use function Mantle\Support\Helpers\throw_if;
throw_if( $value_to_check, \Exception::class, 'Invalid value!' );
throw_unless
The throw_unless helper throws an exception if the given condition fails.
This is useful for validating conditions before executing code.
use function Mantle\Support\Helpers\throw_unless;
throw_unless( $value_to_check, \Exception::class, 'Invalid value!' );
trait_uses_recursive
The trait_uses_recursive helper returns all traits used by a trait and its traits.
use function Mantle\Support\Helpers\trait_uses_recursive;
trait_uses_recursive( \Mantle\Support\Helpers\ExampleTrait::class ); // returns an array of trait names
with
The with helper returns the given value, optionally passed through the given callback.
use function Mantle\Support\Helpers\with;
$value = with( 'example', function( $value ) {
    return strtoupper( $value );
} ); // returns 'EXAMPLE'
memo
The memo helper memoizes the result of a callback function, caching it to
avoid repeated execution. It works similar to Spatie's once helper but with
the added ability to specify dependencies that determine when the cached value
should be invalidated (think React's useMemo).
use function Mantle\Support\Helpers\memo;
// Basic usage - function will only run once, subsequent calls return the cached value.
$result = memo( function() {
	// Expensive operation that will only execute once
	return expensive_calculation();
} );
// With dependencies - function result is cached based on the dependency values.
$post_content = memo(
	function() use ( $post ) {
		// This will be recalculated only when $post->ID changes
		return apply_filters( 'the_content', $post->post_content );
	},
	[ $post->ID ] // Dependencies array
);
// Multiple dependencies can be specified
$user_posts = memo(
	function() use ( $user_id, $post_status ) {
		return get_posts([
			'author' => $user_id,
			'post_status' => $post_status,
		]);
	},
	[ $user_id, $post_status ]
);
Use memo() for expensive operations that are called multiple times but don't need to be recalculated unless dependencies change. This can significantly improve performance in your application.
Meta
Helpers for registering meta fields on objects in WordPress.
register_meta_helper
Register meta for a specific object type with some common defaults. By default, the meta will have the following settings:
- show_in_restis set to- true
- singleis set to- true
- typeis set to- string
Example:
use function Mantle\Support\Helpers\register_meta_helper;
register_meta_helper( 'post', 'example_meta_key', [
	'type'         => 'string',
	'single'       => true,
	'show_in_rest' => true,
	'default'      => '',
] );
register_meta_from_file
Register meta fields from a JSON file. The JSON file should contain an array of meta field definitions. Let's say you have a JSON file with meta definitions like this:
{
  "$schema": "https://raw.githubusercontent.com/alleyinteractive/mantle-framework/HEAD/src/mantle/support/schema/meta.json",
  "example_meta_key": {
    "post_types": "article",
    "type": "string"
  },
  "another_meta_key": {
    "post_types": [ "article", "page" ],
    "type": "number",
    "single": false,
    "default": 0
  }
}
You can register the meta fields defined in this file using the
register_meta_from_file helper:
use function Mantle\Support\Helpers\register_meta_from_file;
register_meta_from_file( __DIR__ . '/post-meta.json', 'post' );
Testing
capture
The capture() helper is a simple wrapper around ob_start() and ob_get_clean(). It captures the output of a callable and returns it as a string. This can be useful when you want to test the output of a function or method that echoes content. Example:
use function Mantle\Support\Helpers\capture;
$output = capture( fn () => the_title() );
block_factory
The block_factory() helper creates a new instance of a block factory. This can be useful for testing or creating blocks dynamically.
For more information see the documentation.
use function Mantle\Testing\block_factory;
$block = block_factory()->block(
  name: 'example/block-name',
  attributes: [ 'example' => 'value' ],
);
$heading   = block_factory()->heading( 'Example Heading' );
$paragraph = block_factory()->paragraph( 'Example Paragraph' );
Requests
terminate_request
The terminate_request() helper function is used to terminate the current HTTP
request and send a response to the client. This is useful in scenarios where you
want to stop further processing and immediately return a response. This helper
also supports unit testing by not exiting the script when running a unit test.
It will allow the response to be properly captured and asserted against.
use function Mantle\Support\Helpers\terminate_request;
if ( some_condition() ) {
	echo 'Terminating request early.';
	terminate_request( exit_status: 0, response_code: 200 );
}
send_json_response
The send_json_response() helper function is used to send a JSON response to
the client and terminate the current HTTP request. This is useful for API endpoints
or AJAX requests where you want to return data in JSON format. This helper also
supports unit testing by not exiting the script when running a unit test. It will
allow the response to be properly captured and asserted against.
use function Mantle\Support\Helpers\send_json_response;
$data = [
	'success' => true,
	'message' => 'Data processed successfully.',
];
send_json_response( data: $data, status_code: 200 );