Current Path : /var/www/ooareogundevinitiative/wp-content/plugins/forminator/admin/abstracts/ |
Current File : /var/www/ooareogundevinitiative/wp-content/plugins/forminator/admin/abstracts/class-admin-page.php |
<?php if ( ! defined( 'ABSPATH' ) ) { die(); } /** * Class Forminator_Admin_Page * * @since 1.0 */ abstract class Forminator_Admin_Page { /** * Current page ID * * @var number */ public $page_id = null; /** * Current page slug * * @var string */ protected $page_slug = ''; /** * Path to view folder * * @var string */ protected $folder = ''; /** * All registered content boxes * * @var array */ protected $content_boxes = array(); /** * @since 1.0 * * @param string $page_slug Page slug. * @param string $folder * @param string $page_title Page title. * @param string $menu_title Menu title. * @param bool $parent Parent or not. * @param bool $render Render the page. */ public function __construct( $page_slug, $folder, $page_title, $menu_title, $parent = false, $render = true ) { $this->page_slug = $page_slug; $this->folder = $folder; if ( ! $parent ) { $this->page_id = add_menu_page( $page_title, $menu_title, forminator_get_admin_cap(), $page_slug, $render ? array( $this, 'render' ) : null, '' //'' ); } else { $this->page_id = add_submenu_page( $parent, $page_title, $menu_title, forminator_get_admin_cap(), $page_slug, $render ? array( $this, 'render' ) : null ); } if ( $render ) { $this->render_page_hooks(); } $this->init(); } /** * Use that method instead of __construct * * @todo : deperecate this, since its not correct way to execute action on page, * instead this function will executed everywhere on all pages, * unless you are really wanna do that?! * * @since 1.0 */ public function init() { } /** * Hooks before content render * * @since 1.0 */ public function render_page_hooks() { add_action( 'load-' . $this->page_id, array( $this, 'register_content_boxes' ) ); add_action( 'load-' . $this->page_id, array( $this, 'before_render' ) ); add_action( 'load-' . $this->page_id, array( $this, 'trigger_before_render_action' ) ); add_filter( 'load-' . $this->page_id, array( $this, 'add_page_hooks' ) ); } /** * Return page slug * * @since 1.0 * @return string */ public function get_the_slug() { return $this->page_slug; } /** * Used to register content boxes for the page * * @since 1.0 */ public function register_content_boxes() { } /** * Called when page is loaded and content not rendered yet * * @since 1.0 */ public function before_render() { } /** * Trigger an action before this screen is rendered * * @since 1.0 */ public function trigger_before_render_action() { do_action( 'forminator_loaded_admin_page_' . $this->get_the_slug() ); } /** * Add page screen hooks * * @since 1.0 */ public function add_page_hooks() { add_filter( 'user_can_richedit', '__return_true' ); //Confirms wp editor script is loaded on Forminator admin pages. add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ) ); add_filter( 'admin_body_class', array( $this, 'admin_body_classes' ) ); add_action( 'init', array( $this, 'init_scripts' ) ); } /** * Add page screen hooks * * @since 1.0 * * @param $hook */ public function enqueue_scripts( $hook ) { // Load jquery ui forminator_admin_jquery_ui(); // Load shared-ui scripts forminator_sui_scripts(); // Load admin fonts forminator_admin_enqueue_fonts( FORMINATOR_VERSION ); // Load admin styles forminator_admin_enqueue_styles( FORMINATOR_VERSION ); $forminator_data = new Forminator_Admin_Data(); $forminator_l10n = new Forminator_Admin_L10n(); // Load admin scripts forminator_admin_enqueue_scripts( FORMINATOR_VERSION, $forminator_data->get_options_data(), $forminator_l10n->get_l10n_strings() ); } /** * Init Admin scripts * * @since 1.0 * * @param $hook */ public function init_scripts( $hook ) { // Init jquery ui forminator_admin_jquery_ui_init(); } /** * Render page header * * @since 1.0 */ protected function render_header() { ?> <header class="sui-header"> <?php if ( $this->template_exists( $this->folder . '/header' ) ) { $this->template( $this->folder . '/header' ); } else { ?> <h1 class="sui-header-title"><?php echo esc_html( get_admin_page_title() ); ?></h1> <?php } ?> </header> <?php } /** * Render page footer * * @since 1.0 */ protected function render_footer() { $hide_footer = false; $footer_text = sprintf(/* translators: ... */ __( 'Made with %s by WPMU DEV', 'wpmudev' ), ' <i class="sui-icon-heart"></i>' ); if ( Forminator::is_wpmudev_member() ) { $hide_footer = apply_filters( 'wpmudev_branding_change_footer', $hide_footer ); $footer_text = apply_filters( 'wpmudev_branding_footer_text', $footer_text ); } if ( $this->template_exists( $this->folder . '/footer' ) ) { $this->template( $this->folder . '/footer' ); } ?> <div class="sui-footer"><?php echo $footer_text; // phpcs:ignore ?></div> <?php if ( FORMINATOR_PRO ) { ?> <?php if ( ! $hide_footer ) : ?> <ul class="sui-footer-nav"> <li><a href="https://premium.wpmudev.org/hub/" target="_blank"><?php esc_html_e( 'The Hub', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/projects/category/plugins/" target="_blank"><?php esc_html_e( 'Plugins', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/roadmap/" target="_blank"><?php esc_html_e( 'Roadmap', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/hub/support/" target="_blank"><?php esc_html_e( 'Support', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/docs/" target="_blank"><?php esc_html_e( 'Docs', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/hub/community/" target="_blank"><?php esc_html_e( 'Community', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/academy/" target="_blank"><?php esc_html_e( 'Academy', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/terms-of-service/" target="_blank"><?php esc_html_e( 'Terms of Service', Forminator::DOMAIN ); ?></a></li> <li><a href="https://incsub.com/privacy-policy/" target="_blank"><?php esc_html_e( 'Privacy Policy', Forminator::DOMAIN ); ?></a></li> </ul> <?php endif; ?> <?php } else { ?> <ul class="sui-footer-nav"> <li><a href="https://profiles.wordpress.org/wpmudev#content-plugins" target="_blank"><?php esc_html_e( 'Free Plugins', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/features/" target="_blank"><?php esc_html_e( 'Membership', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/roadmap/" target="_blank"><?php esc_html_e( 'Roadmap', Forminator::DOMAIN ); ?></a></li> <li><a href="https://wordpress.org/support/plugin/forminator" target="_blank"><?php esc_html_e( 'Support', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/docs/" target="_blank"><?php esc_html_e( 'Docs', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/hub-welcome/" target="_blank"><?php esc_html_e( 'The Hub', Forminator::DOMAIN ); ?></a></li> <li><a href="https://premium.wpmudev.org/terms-of-service/" target="_blank"><?php esc_html_e( 'Terms of Service', Forminator::DOMAIN ); ?></a></li> <li><a href="https://incsub.com/privacy-policy/" target="_blank"><?php esc_html_e( 'Privacy Policy', Forminator::DOMAIN ); ?></a></li> </ul> <?php } ?> <?php if ( ! $hide_footer ) : ?> <ul class="sui-footer-social"> <li><a href="https://www.facebook.com/wpmudev" target="_blank"> <i class="sui-icon-social-facebook" aria-hidden="true"></i> <span class="sui-screen-reader-text"><?php esc_html_e( 'Facebook', Forminator::DOMAIN ); ?></span> </a></li> <li><a href="https://twitter.com/wpmudev" target="_blank"> <i class="sui-icon-social-twitter" aria-hidden="true"></i> <span class="sui-screen-reader-text"><?php esc_html_e( 'Twitter', Forminator::DOMAIN ); ?></span> </a></li> <li><a href="https://www.instagram.com/wpmu_dev/" target="_blank"> <i class="sui-icon-instagram" aria-hidden="true"></i> <span class="sui-screen-reader-text"><?php esc_html_e( 'Instagram', Forminator::DOMAIN ); ?></span> </a></li> </ul> <?php endif; ?> <?php } /** * Render page container * * @since 1.0 */ public function render() { $accessibility_enabled = get_option( 'forminator_enable_accessibility', false ); ?> <main class="sui-wrap <?php echo $accessibility_enabled ? 'sui-color-accessible' : ''; ?> <?php echo esc_attr( 'wpmudev-forminator-' . $this->page_slug ); ?>"> <?php $this->render_header(); $this->render_page_content(); $this->render_footer(); ?> </main> <?php } /** * Render actual page template * * @since 1.0 */ protected function render_page_content() { $this->template( $this->folder . '/content' ); } /** * Load an admin template * * @since 1.0 * * @param $path * @param array $args * @param bool $echo * * @return string */ public function template( $path, $args = array(), $echo = true ) { $file = forminator_plugin_dir() . "admin/views/$path.php"; $content = ''; if ( is_file( $file ) ) { ob_start(); if ( isset( $args['id'] ) ) { $template_class = $args['class']; $template_id = $args['id']; $title = $args['title']; $header_callback = $args['header_callback']; $main_callback = $args['main_callback']; $footer_callback = $args['footer_callback']; } include $file; $content = ob_get_clean(); } if ( $echo ) { echo $content;// phpcs:ignore } return $content; } /** * Check if template exist * * @since 1.0 * * @param $path * * @return bool */ protected function template_exists( $path ) { $file = forminator_plugin_dir() . "admin/views/$path.php"; return is_file( $file ); } /** * Add a box to the page * * @since 1.0 * * @param $box_id * @param $title * @param $class * @param string $header_callback * @param string $main_callback * @param string $footer_callback * @param array $args */ public function add_box( $box_id, $title, $class, $header_callback = '', $main_callback = '', $footer_callback = '', $args = array() ) { $args = wp_parse_args( $args, array() ); if ( ! isset( $this->content_boxes[ $this->page_slug ] ) ) { $this->content_boxes[ $this->page_slug ] = array(); } $box = array( 'id' => $box_id, 'title' => $title, 'class' => $class, 'header_callback' => $header_callback, 'main_callback' => $main_callback, 'footer_callback' => $footer_callback, 'args' => $args, ); $box = apply_filters( 'forminator_add_box', $box, $this->page_slug, $this->page_id ); $box = apply_filters( 'forminator_add_box_' . $box_id, $box, $this->page_slug, $this->page_id ); if ( $box ) { $this->content_boxes[ $this->page_slug ][ $box_id ] = $box; } } /** * Check if content box exist * * @since 1.0 * * @param $box_id * * @return bool */ protected function box_exist( $box_id ) { return ! empty( $this->content_boxes[ $this->page_slug ][ $box_id ] ); } /** * Print content box * * @since 1.0 * * @param $box_id */ protected function do_content_box( $box_id ) { if ( ! isset( $this->content_boxes[ $this->page_slug ][ $box_id ] ) ) { return; } do_action_ref_array( 'forminator_admin_print_content_box' . $this->page_slug, array( &$this ) ); $box_data = $this->content_boxes[ $this->page_slug ][ $box_id ]; $args = array( 'title' => $box_data['title'], 'id' => $box_id, 'class' => $box_data['class'], 'header_callback' => $box_data['header_callback'], 'main_callback' => $box_data['main_callback'], 'footer_callback' => $box_data['footer_callback'], 'args' => $box_data['args'], ); $this->template( 'boxes/content-box', $args ); } /** * Print popup box * * @since 1.0 * * @param $box_id */ protected function do_popup_box( $box_id ) { if ( ! isset( $this->content_boxes[ $this->page_slug ][ $box_id ] ) ) { return; } do_action_ref_array( 'forminator_admin_print_popup_box' . $this->page_slug, array( &$this ) ); $box_data = $this->content_boxes[ $this->page_slug ][ $box_id ]; $args = array( 'title' => $box_data['title'], 'id' => $box_id, 'class' => $box_data['class'], 'header_callback' => $box_data['header_callback'], 'main_callback' => $box_data['main_callback'], 'footer_callback' => $box_data['footer_callback'], 'args' => $box_data['args'], ); $this->template( 'boxes/popup-box', $args ); } /** * Generates the admin body class required for WPMU DEV Shared UI * * @since 1.0.2 * @return string $sui_body_class */ public function get_sui_body_class() { $sanitize_version = str_replace( '.', '-', FORMINATOR_SUI_VERSION ); $sui_body_class = "sui-$sanitize_version"; return $sui_body_class; } /** * Add admin body classes * * @since 1.0.2 * * @param string $classes * * @return string $classes */ public function admin_body_classes( $classes ) { $screen = get_current_screen(); $classes = ''; // Do nothing if not a forminator page if ( strpos( $screen->base, '_page_forminator' ) === false ) { return $classes; } $classes .= $this->get_sui_body_class(); return $classes; } /** * Get admin page param * * @since 1.5.4 * @return string */ protected function get_admin_page() { return ( isset( $_GET['page'] ) ? sanitize_text_field( $_GET['page'] ) : '' ); } /** * Redirect to referer if available * * @since 1.6 * * @param string $fallback_redirect url if referer not found */ protected function maybe_redirect_to_referer( $fallback_redirect = '', $to_referer = true ) { $referer = wp_get_referer(); $referer = ! empty( $referer ) ? $referer : wp_get_raw_referer(); $referer = remove_query_arg( array( 'export', 'delete' ), $referer ); if ( $referer && $to_referer ) { wp_safe_redirect( $referer ); } elseif ( $fallback_redirect ) { wp_safe_redirect( $fallback_redirect ); } else { $admin_url = admin_url( 'admin.php' ); $admin_url = add_query_arg( array( 'page' => $this->get_admin_page(), ), $admin_url ); wp_safe_redirect( $admin_url ); } exit(); } /** * Get css class used for box summary on admin page * * @since 1.6 * @return string */ public function get_box_summary_classes() { $classes = ''; if ( Forminator::is_wpmudev_member() ) { $hide_branding = false; $hide_branding = apply_filters( 'wpmudev_branding_hide_branding', $hide_branding ); $custom_branding_image = ''; $custom_branding_image = apply_filters( 'wpmudev_branding_hero_image', $custom_branding_image ); if ( $hide_branding && ! empty( $custom_branding_image ) ) { $classes .= ' sui-rebranded'; } elseif ( $hide_branding && empty( $custom_branding_image ) ) { $classes .= ' sui-unbranded'; } } return $classes; } /** * Get image url for summary box * * @since 1.6 * @return string */ public function get_box_summary_image_url() { $image_url = ''; if ( Forminator::is_wpmudev_member() ) { $image_url = apply_filters( 'wpmudev_branding_hero_image', $image_url ); } return $image_url; } /** * Get inline style for box summary-image div * * @since 1.6 * @return string */ public function get_box_summary_image_style() { $image_url = $this->get_box_summary_image_url(); if ( ! empty( $image_url ) ) { return 'background-image:url(' . esc_url( $image_url ) . ')'; } return ''; } }