*/ class Anchor_Highlighter_Admin { /** * The ID of this plugin. * * @since 1.0.0 * @access private * @var string $plugin_name The ID of this plugin. */ private $plugin_name; /** * The version of this plugin. * * @since 1.0.0 * @access private * @var string $version The current version of this plugin. */ private $version; /** * Initialize the class and set its properties. * * @since 1.0.0 * @param string $plugin_name The name of this plugin. * @param string $version The version of this plugin. */ public function __construct( $plugin_name, $version ) { $this->plugin_name = $plugin_name; $this->version = $version; } /** * Register the stylesheets for the admin area. * * @since 1.0.0 */ public function enqueue_styles() { /** * This function is provided for demonstration purposes only. * * An instance of this class should be passed to the run() function * defined in Anchor_Highlighter_Loader as all of the hooks are defined * in that particular class. * * The Anchor_Highlighter_Loader will then create the relationship * between the defined hooks and the functions defined in this * class. */ wp_enqueue_style( $this->plugin_name, plugin_dir_url( __FILE__ ) . 'css/anchor-highlighter-admin.css', array(), $this->version, 'all' ); } /** * Register the JavaScript for the admin area. * * @since 1.0.0 */ public function enqueue_scripts() { /** * This function is provided for demonstration purposes only. * * An instance of this class should be passed to the run() function * defined in Anchor_Highlighter_Loader as all of the hooks are defined * in that particular class. * * The Anchor_Highlighter_Loader will then create the relationship * between the defined hooks and the functions defined in this * class. */ wp_enqueue_script( $this->plugin_name, plugin_dir_url( __FILE__ ) . 'js/anchor-highlighter-admin.js', array( 'jquery' ), $this->version, false ); } public function add_plugin_admin_menu() { /* * Add a settings page for this plugin to the Settings menu. * * NOTE: Alternative menu locations are available via WordPress administration menu functions. * * Administration Menus: http://codex.wordpress.org/Administration_Menus * */ add_options_page( 'Anchor Highlighter', 'Anchor Highlighter', 'manage_options', $this->plugin_name, array($this, 'display_plugin_setup_page') ); } /** * Add settings action link to the plugins page. * * @since 1.0.0 */ public function add_action_links( $links ) { /* * Documentation : https://codex.wordpress.org/Plugin_API/Filter_Reference/plugin_action_links_(plugin_file_name) */ $settings_link = array( '' . __('Settings', $this->plugin_name) . '', ); return array_merge( $settings_link, $links ); } /** * Render the settings page for this plugin. * * @since 1.0.0 */ public function display_plugin_setup_page() { include_once( 'partials/anchor-highlighter-admin-display.php' ); } public function validate($input) { // All checkboxes inputs $valid = array(); //class for anchor validator $anchorclass = sanitize_text_field ($input['activated']); if (preg_match('/^[a-z][-a-z0-9]*$/', $anchorclass)) { $valid['activated'] = $anchorclass; return $valid; } $valid['activated'] = "non-valid-class-selected-please-change-it"; return $valid; } public function options_update() { register_setting($this->plugin_name, $this->plugin_name, array($this, 'validate')); } }