preview->is_preview_mode() ) { return; } // Setup global post for Elementor\frontend so `_has_elementor_in_page = true`. $GLOBALS['post'] = get_post( self::get( 'template_id' ) ); add_filter( 'template_include', [ $this, 'template_include' ], 1 ); } /** * Template include. * * Update the path of the current template before including it. Used to * change the "Maintenance Mode" path and the HTTP header data. * * Fired by `template_include` filter. * * @since 1.4.0 * @access public * * @param string $template The path of the template to include. * * @return string Updated path of the template to include. */ public function template_include( $template ) { // Set the template as `$wp_query->current_object` for `wp_title` and etc. query_posts( [ 'p' => self::get( 'template_id' ), 'post_type' => Source_Local::CPT, ] ); if ( 'maintenance' === self::get( 'mode' ) ) { $protocol = wp_get_server_protocol(); header( "$protocol 503 Service Unavailable", true, 503 ); header( 'Content-Type: text/html; charset=utf-8' ); header( 'Retry-After: 600' ); } return $template; } /** * Register settings fields. * * Adds new "Maintenance Mode" settings fields to Elementor admin page. * * Fired by `elementor/admin/after_create_settings/{$page_id}` action. * * @since 1.4.0 * @access public */ public function register_settings_fields( Tools $tools ) { $templates = Plugin::$instance->templates_manager->get_source( 'local' )->get_items( [ 'type' => 'page' ] ); $templates_options = []; foreach ( $templates as $template ) { $templates_options[ $template['template_id'] ] = $template['title']; } $template_description = sprintf( ' ', Utils::get_edit_link( self::get( 'template_id' ) ), __( 'Edit Template', 'elementor' ) ); $template_description .= ''; $tools->add_tab( 'maintenance_mode', [ 'label' => __( 'Maintenance Mode', 'elementor' ), 'sections' => [ 'maintenance_mode' => [ 'callback' => function() { echo '
' . __( 'Set your entire website as MAINTENANCE MODE, meaning the site is offline temporarily for maintenance, or set it as COMING SOON mode, meaning the site is offline until it is ready to be launched.', 'elementor' ) . '
'; }, 'fields' => [ 'maintenance_mode_mode' => [ 'label' => __( 'Choose Mode', 'elementor' ), 'field_args' => [ 'type' => 'select', 'options' => [ '' => __( 'Disabled', 'elementor' ), self::MODE_COMING_SOON => __( 'Coming Soon', 'elementor' ), self::MODE_MAINTENANCE => __( 'Maintenance', 'elementor' ), ], 'desc' => '' . '' . '', ], ], 'maintenance_mode_exclude_mode' => [ 'label' => __( 'Who Can Access', 'elementor' ), 'field_args' => [ 'class' => 'elementor-default-hide', 'type' => 'select', 'std' => 'logged_in', 'options' => [ 'logged_in' => __( 'Logged In', 'elementor' ), 'custom' => __( 'Custom', 'elementor' ), ], ], ], 'maintenance_mode_exclude_roles' => [ 'label' => __( 'Roles', 'elementor' ), 'field_args' => [ 'class' => 'elementor-default-hide', 'type' => 'checkbox_list_roles', ], 'setting_args' => [ __NAMESPACE__ . '\Settings_Validations', 'checkbox_list' ], ], 'maintenance_mode_template_id' => [ 'label' => __( 'Choose Template', 'elementor' ), 'field_args' => [ 'class' => 'elementor-default-hide', 'type' => 'select', 'show_select' => true, 'options' => $templates_options, 'desc' => $template_description, ], ], ], ], ], ] ); } /** * Add menu in admin bar. * * Adds "Maintenance Mode" items to the WordPress admin bar. * * Fired by `admin_bar_menu` filter. * * @since 1.4.0 * @access public * * @param \WP_Admin_Bar $wp_admin_bar WP_Admin_Bar instance, passed by reference. */ public function add_menu_in_admin_bar( \WP_Admin_Bar $wp_admin_bar ) { $wp_admin_bar->add_node( [ 'id' => 'elementor-maintenance-on', 'title' => __( 'Maintenance Mode ON', 'elementor' ), 'href' => Tools::get_url() . '#tab-maintenance_mode', ] ); $wp_admin_bar->add_node( [ 'id' => 'elementor-maintenance-edit', 'parent' => 'elementor-maintenance-on', 'title' => __( 'Edit Template', 'elementor' ), 'href' => Utils::get_edit_link( self::get( 'template_id' ) ), ] ); } /** * Print style. * * Adds custom CSS to the HEAD html tag. The CSS that emphasise the maintenance * mode with red colors. * * Fired by `admin_head` and `wp_head` filters. * * @since 1.4.0 * @access public */ public function print_style() { ?> roles, $exclude_roles ); if ( ! empty( $compare_roles ) ) { return; } } add_filter( 'body_class', [ $this, 'body_class' ] ); add_action( 'template_redirect', [ $this, 'template_redirect' ], 1 ); } }