<?php /** * Manages the initial state of the Interactivity API store in the server and * its serialization so it can be restored in the browser upon hydration. * * It's a private class, exposed by other functions, like `wc_initial_state`. * * @access private */ class WC_Interactivity_Initial_State { /** * Map of initial state by namespace. * * @var array */ private static $initial_state = array(); /** * Get state from a given namespace. * * @param string $namespace Namespace. * * @return array The requested state. */ public static function get_state( $namespace ) { return self::$initial_state[ $namespace ] ?? array(); } /** * Merge data into the state with the given namespace. * * @param string $namespace Namespace. * @param array $data State to merge. * * @return void */ public static function merge_state( $namespace, $data ) { self::$initial_state[ $namespace ] = array_replace_recursive( self::get_state( $namespace ), $data ); } /** * Reset the initial state. */ public static function reset() { self::$initial_state = array(); } /** * Render the initial state. */ public static function render() { if ( empty( self::$initial_state ) ) { return; } echo sprintf( '<script id="wc-interactivity-initial-state" type="application/json">%s</script>', wp_json_encode( self::$initial_state, JSON_HEX_TAG | JSON_HEX_AMP ) ); } }