namespace Elementor\Core\Responsive;
use Elementor\Core\Breakpoints\Manager as Breakpoints_Manager;
use Elementor\Modules\DevTools\Deprecation;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
* Elementor responsive handler class is responsible for setting up Elementor
* responsive breakpoints.
* The Elementor breakpoint prefix.
const BREAKPOINT_OPTION_PREFIX = 'viewport_';
* Holds the default responsive breakpoints.
* @var array Default breakpoints.
private static $default_breakpoints = [
* Editable breakpoint keys.
* Holds the editable breakpoint keys.
* @var array Editable breakpoint keys.
private static $editable_breakpoints_keys = [
* Get default breakpoints.
* Retrieve the default responsive breakpoints.
* @deprecated 3.2.0 Use `Elementor\Core\Breakpoints\Manager::get_default_config()` instead.
* @return array Default breakpoints.
public static function get_default_breakpoints() {
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.2.0', 'Elementor\Core\Breakpoints\Manager::get_default_config()' );
return self::$default_breakpoints;
* Get editable breakpoints.
* Retrieve the editable breakpoints.
* @return array Editable breakpoints.
public static function get_editable_breakpoints() {
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.2.0' );
return array_intersect_key( self::get_breakpoints(), array_flip( self::$editable_breakpoints_keys ) );
* Retrieve the responsive breakpoints.
* @return array Responsive breakpoints.
public static function get_breakpoints() {
array_keys( self::$default_breakpoints ), function( $new_array, $breakpoint_key ) {
if ( ! in_array( $breakpoint_key, self::$editable_breakpoints_keys, true ) ) {
$new_array[ $breakpoint_key ] = self::$default_breakpoints[ $breakpoint_key ];
$saved_option = Plugin::$instance->kits_manager->get_current_settings( self::BREAKPOINT_OPTION_PREFIX . $breakpoint_key );
$new_array[ $breakpoint_key ] = $saved_option ? (int) $saved_option : self::$default_breakpoints[ $breakpoint_key ];
* @deprecated 3.2.0 Use `Plugin::$instance->breakpoints->has_custom_breakpoints()` instead.
public static function has_custom_breakpoints() {
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.2.0', 'Plugin::$instance->breakpoints->has_custom_breakpoints()' );
return (bool) array_diff( self::$default_breakpoints, self::get_breakpoints() );
* @deprecated 3.2.0 Use `Elementor\Core\Breakpoints\Manager::get_stylesheet_templates_path()` instead.
public static function get_stylesheet_templates_path() {
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.2.0', 'Elementor\Core\Breakpoints\Manager::get_stylesheet_templates_path()' );
return Breakpoints_Manager::get_stylesheet_templates_path();
* @deprecated 3.2.0 Use `Elementor\Core\Breakpoints\Manager::compile_stylesheet_templates()` instead.
public static function compile_stylesheet_templates() {
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.2.0', 'Elementor\Core\Breakpoints\Manager::compile_stylesheet_templates()' );
Breakpoints_Manager::compile_stylesheet_templates();