> Read the accompanying readme.txt file for instructions and documentation. * =>> Also, visit the plugin's homepage for additional information and updates. * =>> Or visit: https://wordpress.org/plugins/admin-expert-mode/ * * @package Admin_Expert_Mode * @author Scott Reilly * @version 2.5 */ /* * TODO: * - Add inline documentation for class variables * - Define custom caps for being able to edit setting for another user * - Add unit tests * */ /* Copyright (c) 2009-2019 by Scott Reilly (aka coffee2code) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ defined( 'ABSPATH' ) or die(); if ( is_admin() && ! class_exists( 'c2c_AdminExpertMode' ) ) : class c2c_AdminExpertMode { private static $admin_options_name = 'c2c_admin_expert_mode'; private static $field_name = 'admin_expert_mode'; private static $prompt = ''; private static $help_text = ''; private static $config = array(); private static $options = array(); private static $is_active = false; // Has admin expert mode been determined to be active? /** * Name of the query key used for disabling expert mode for current page. * * @since 2.4 * @var string */ private static $disable_query_key = 'disable-admin-expert-mode'; /** * Returns version of the plugin. * * @access public * @since 1.8 */ public static function version() { return '2.5'; } /** * Initializer. * * @access public * @since 1.0.0 */ public static function init() { // Fire off a function when the plugin gets activated. register_activation_hook( __FILE__, array( __CLASS__, 'plugin_activated' ) ); // Load textdomain. load_plugin_textdomain( 'admin-expert-mode' ); // Set translatable strings. self::$prompt = __( 'Expert mode', 'admin-expert-mode' ); self::$help_text = __( 'Enable expert mode (disables most of the onscreen documentation in the admin)', 'admin-expert-mode' ); // Register and enqueue styles for admin page. add_action( 'init', array( __CLASS__, 'register_styles' ) ); // Display admin notice on same page load as plugin activation. add_action( 'admin_notices', array( __CLASS__, 'display_activation_notice' ) ); // Add the checkbox to user profiles. add_action( 'personal_options', array( __CLASS__, 'show_option' ) ); // Save the user preference. add_action( 'personal_options_update', array( __CLASS__, 'maybe_save_options' ) ); add_action( 'edit_user_profile_update', array( __CLASS__, 'maybe_save_options' ) ); // Enqueue admin scripts and styles. add_action( 'admin_enqueue_scripts', array( __CLASS__, 'enqueue_admin_css' ) ); } /** * Set a temporary flag (transient) to indicate the plugin was just activated. * * @access public * @since 1.5.0 */ public static function plugin_activated() { set_transient( 'aem_activated', 'show', 10 ); } /** * Outputs activation notice. * * @access public * @since 1.0.0 */ public static function display_activation_notice() { if ( get_transient( 'aem_activated' ) ) { if ( self::is_admin_expert_mode_active() ) { $msg = __( 'Expert mode is now enabled for you since you had it previously enabled. You can disable it in your profile. Reminder: other admins must separately enable expert mode for themselves via their own profiles. (See the readme.txt for more advanced controls.)', 'admin-expert-mode' ); } else { $msg = __( 'NOTE: You must enable expert mode for yourself (in your profile) for it to take effect. Other admin users must do the same for themselves as well. (See the readme.txt for more advanced controls.)', 'admin-expert-mode' ); } $msg = sprintf( $msg, esc_url( admin_url( 'profile.php' ) ) ); echo "
$msg