You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
163 lines
2.6 KiB
PHTML
163 lines
2.6 KiB
PHTML
8 months ago
|
<?php
|
||
|
/**
|
||
|
* The Module Base Class
|
||
|
*
|
||
|
* ALl the classes inherit from this class
|
||
|
*
|
||
|
* @since 0.9.0
|
||
|
* @package RankMath
|
||
|
* @subpackage RankMath\Module
|
||
|
* @author Rank Math <support@rankmath.com>
|
||
|
*/
|
||
|
|
||
|
namespace RankMath\Module;
|
||
|
|
||
|
use RankMath\Traits\Hooker;
|
||
|
|
||
|
defined( 'ABSPATH' ) || exit;
|
||
|
|
||
|
/**
|
||
|
* Base class.
|
||
|
*/
|
||
|
class Base {
|
||
|
|
||
|
use Hooker;
|
||
|
|
||
|
/**
|
||
|
* Module ID.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $id = '';
|
||
|
|
||
|
/**
|
||
|
* Module directory.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $directory = '';
|
||
|
|
||
|
/**
|
||
|
* Module help.
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
public $help = [];
|
||
|
|
||
|
/**
|
||
|
* Page object.
|
||
|
*
|
||
|
* @var object
|
||
|
*/
|
||
|
public $page;
|
||
|
|
||
|
/**
|
||
|
* List table object.
|
||
|
*
|
||
|
* @var object
|
||
|
*/
|
||
|
public $table;
|
||
|
|
||
|
/**
|
||
|
* Screen.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public static $screen = '';
|
||
|
|
||
|
/**
|
||
|
* Screen options.
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
public $screen_options = [];
|
||
|
|
||
|
/**
|
||
|
* Admin object.
|
||
|
*
|
||
|
* @var Admin
|
||
|
*/
|
||
|
public $admin;
|
||
|
|
||
|
/**
|
||
|
* The Constructor.
|
||
|
*/
|
||
|
public function __construct() {
|
||
|
$this->register_admin_page();
|
||
|
|
||
|
if ( ! empty( $this->page ) && $this->page->is_current_page() ) {
|
||
|
|
||
|
// Store the current screen ID.
|
||
|
self::$screen = $this->page->parent . '_page_' . $this->page->id;
|
||
|
|
||
|
// Register screen options.
|
||
|
$this->register_screen_options();
|
||
|
|
||
|
// Register the table if it exists.
|
||
|
if ( isset( $this->table ) ) {
|
||
|
$this->action( 'admin_init', 'admin_init' );
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the current screen.
|
||
|
*/
|
||
|
public static function get_screen() {
|
||
|
return self::$screen;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Register admin page.
|
||
|
*/
|
||
|
public function register_admin_page() {}
|
||
|
|
||
|
/**
|
||
|
* Admin initialize.
|
||
|
*/
|
||
|
public function admin_init() {
|
||
|
$this->table = new $this->table();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Register screen options.
|
||
|
*/
|
||
|
private function register_screen_options() {
|
||
|
if ( ! isset( $this->screen_options ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->action( 'current_screen', 'add_screen_options' );
|
||
|
$this->filter( 'set-screen-option', 'set_screen_options', 10, 3 );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add screen options.
|
||
|
*/
|
||
|
public function add_screen_options() {
|
||
|
if ( ! isset( $this->screen_options['id'] ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
add_screen_option(
|
||
|
'per_page',
|
||
|
[
|
||
|
'option' => $this->screen_options['id'],
|
||
|
'default' => $this->screen_options['default'],
|
||
|
'label' => esc_html__( 'Items per page', 'rank-math' ),
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set screen options.
|
||
|
*
|
||
|
* @param bool|int $status Screen option value. Default false to skip.
|
||
|
* @param string $option The option name.
|
||
|
* @param int $value The number of rows to use.
|
||
|
*/
|
||
|
public function set_screen_options( $status, $option, $value ) {
|
||
|
return $this->screen_options['id'] === $option ? min( $value, 999 ) : $status;
|
||
|
}
|
||
|
}
|