refactor: clear up Plugin init, add activator/deactivator hooks
This commit is contained in:
parent
12b1eb556e
commit
0d1e0d75bb
4 changed files with 595 additions and 23 deletions
|
@ -1,9 +1,15 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* The footnotes WordPress Plugin.
|
* The plugin bootstrap file.
|
||||||
|
*
|
||||||
|
* This file is read by WordPress to generate the plugin information in the plugin
|
||||||
|
* admin area. This file also includes all of the dependencies used by the plugin,
|
||||||
|
* registers the activation and deactivation functions, and defines a function
|
||||||
|
* that starts the plugin.
|
||||||
*
|
*
|
||||||
* @package footnotes
|
|
||||||
* @author Mark Cheret
|
* @author Mark Cheret
|
||||||
|
* @since 1.0.0
|
||||||
|
* @package footnotes
|
||||||
* @copyright 2021 Mark Cheret (email: mark@cheret.de)
|
* @copyright 2021 Mark Cheret (email: mark@cheret.de)
|
||||||
* @license GPL-3.0-only
|
* @license GPL-3.0-only
|
||||||
*
|
*
|
||||||
|
@ -11,7 +17,7 @@
|
||||||
* Plugin Name: footnotes
|
* Plugin Name: footnotes
|
||||||
* Plugin URI: https://wordpress.org/plugins/footnotes/
|
* Plugin URI: https://wordpress.org/plugins/footnotes/
|
||||||
* Description: footnotes lets you easily add highly-customisable footnotes on your WordPress Pages and Posts.
|
* Description: footnotes lets you easily add highly-customisable footnotes on your WordPress Pages and Posts.
|
||||||
* Version: 2.7.3
|
* Version: 2.8.0d
|
||||||
* Requires at least: 3.9
|
* Requires at least: 3.9
|
||||||
* Requires PHP: 7.0
|
* Requires PHP: 7.0
|
||||||
* Author: Mark Cheret
|
* Author: Mark Cheret
|
||||||
|
@ -24,13 +30,15 @@
|
||||||
|
|
||||||
declare(strict_types=1);
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
// If this file is called directly, abort.
|
||||||
|
if ( ! defined( 'WPINC' ) ) {
|
||||||
|
die;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines the current Plugin version.
|
* Current plugin version.
|
||||||
*
|
|
||||||
* @since 2.1.4
|
|
||||||
* @var string
|
|
||||||
*/
|
*/
|
||||||
const C_STR_FOOTNOTES_VERSION = '2.7.3';
|
define('C_STR_FOOTNOTES_VERSION', '2.8.0d');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines the current environment ('development' or 'production').
|
* Defines the current environment ('development' or 'production').
|
||||||
|
@ -38,25 +46,52 @@ const C_STR_FOOTNOTES_VERSION = '2.7.3';
|
||||||
* This primarily affects whether minified or unminified files are requested.
|
* This primarily affects whether minified or unminified files are requested.
|
||||||
*
|
*
|
||||||
* @since 2.5.5
|
* @since 2.5.5
|
||||||
* @var bool
|
|
||||||
*/
|
*/
|
||||||
const PRODUCTION_ENV = false;
|
define('PRODUCTION_ENV' , false);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines the Plugin entry point (relative to the `wp-content/` dir).
|
* The code that runs during plugin activation.
|
||||||
|
* This action is documented in includes/class-plugin-name-activator.php
|
||||||
|
*/
|
||||||
|
function activate_footnotes() {
|
||||||
|
require_once plugin_dir_path( __FILE__ ) . 'includes/class-footnotes-activator.php';
|
||||||
|
Footnotes_Activator::activate();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The code that runs during plugin deactivation.
|
||||||
|
* This action is documented in includes/class-plugin-name-deactivator.php
|
||||||
|
*/
|
||||||
|
function deactivate_plugin_name() {
|
||||||
|
require_once plugin_dir_path( __FILE__ ) . 'includes/class-footnotes-deactivator.php';
|
||||||
|
Footnotes_Deactivator::deactivate();
|
||||||
|
}
|
||||||
|
|
||||||
|
register_activation_hook( __FILE__, 'activate_footnotes' );
|
||||||
|
register_deactivation_hook( __FILE__, 'deactivate_footnotes' );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The core plugin class that is used to define internationalization,
|
||||||
|
* admin-specific hooks, and public-facing site hooks.
|
||||||
|
*/
|
||||||
|
require plugin_dir_path( __FILE__ ) . 'includes/class-footnotes.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Begins execution of the plugin.
|
||||||
|
*
|
||||||
|
* Since everything within the plugin is registered via hooks,
|
||||||
|
* then kicking off the plugin from this point in the file does
|
||||||
|
* not affect the page life cycle.
|
||||||
*
|
*
|
||||||
* @since 2.8.0
|
* @since 2.8.0
|
||||||
* @var string
|
|
||||||
*/
|
*/
|
||||||
const PLUGIN_ENTRYPOINT = 'footnotes/footnotes.php';
|
function run_footnotes() {
|
||||||
|
global $footnotes;
|
||||||
|
$footnotes = new Footnotes();
|
||||||
|
$footnotes->run();
|
||||||
|
|
||||||
// Requires the core Plugin file.
|
// Add the links to the dashboard plugins page.
|
||||||
require_once dirname( __FILE__ ) . '/class/init.php';
|
// TODO: Move this somewhere more appropriate.
|
||||||
|
add_filter( "plugin_action_links_footnotes/footnotes.php", array( 'Footnotes_Hooks', 'get_plugin_links' ), 10, 2 );
|
||||||
// Add links to the ‘Installed Plugins’ page on the WordPress dashboard.
|
}
|
||||||
add_filter( 'plugin_action_links_' . PLUGIN_ENTRYPOINT, array( 'Footnotes_Hooks', 'get_plugin_links' ), 10, 2 );
|
run_footnotes();
|
||||||
|
|
||||||
// Initialize the Plugin.
|
|
||||||
$g_obj_mci_footnotes = new Footnotes();
|
|
||||||
// Run the Plugin.
|
|
||||||
$g_obj_mci_footnotes->run();
|
|
||||||
|
|
33
src/includes/class-footnotes-activator.php
Normal file
33
src/includes/class-footnotes-activator.php
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Fired during plugin activation
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*
|
||||||
|
* @package footnotes
|
||||||
|
* @subpackage footnotes/includes
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired during plugin activation.
|
||||||
|
*
|
||||||
|
* This class defines all code necessary to run during the plugin's activation.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
* @package footnotes
|
||||||
|
* @subpackage footnotes/includes
|
||||||
|
*/
|
||||||
|
class Footnotes_Activator {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs when the Plugin is deactivated.
|
||||||
|
*
|
||||||
|
* Currently NOP.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*/
|
||||||
|
public static function activate() {
|
||||||
|
// Nothing yet.
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
33
src/includes/class-footnotes-deactivator.php
Normal file
33
src/includes/class-footnotes-deactivator.php
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Fired during plugin deactivation
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*
|
||||||
|
* @package footnotes
|
||||||
|
* @subpackage footnotes/includes
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired during plugin deactivation.
|
||||||
|
*
|
||||||
|
* This class defines all code necessary to run during the plugin's deactivation.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
* @package footnotes
|
||||||
|
* @subpackage footnotes/includes
|
||||||
|
*/
|
||||||
|
class Plugin_Name_Deactivator {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs when the Plugin is deactivated.
|
||||||
|
*
|
||||||
|
* Currently NOP.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*/
|
||||||
|
public static function deactivate() {
|
||||||
|
// Nothing yet.
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
471
src/includes/class-footnotes.php
Normal file
471
src/includes/class-footnotes.php
Normal file
|
@ -0,0 +1,471 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Footnotes class
|
||||||
|
*
|
||||||
|
* @package footnotes
|
||||||
|
* @since 1.5.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once dirname( __FILE__ ) . '/config.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/convert.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/hooks.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/language.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/settings.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/task.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/wysiwyg.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/dashboard/init.php';
|
||||||
|
require_once dirname( __FILE__ ) . '/widgets/reference-container.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provides an entry point to the Plugin.
|
||||||
|
*
|
||||||
|
* Loads the dashboard and executes the task.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*/
|
||||||
|
class Footnotes {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Plugin task.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
* @var Task $task The Plugin task.
|
||||||
|
*/
|
||||||
|
public $a_obj_task = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag for using tooltips.
|
||||||
|
*
|
||||||
|
* @since 2.4.0
|
||||||
|
*
|
||||||
|
* @var bool $tooltips_enabled Whether tooltips are enabled or not.
|
||||||
|
*/
|
||||||
|
public static $a_bool_tooltips_enabled = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allows to determine whether alternative tooltips are enabled.
|
||||||
|
*
|
||||||
|
* - Bugfix: Tooltips: optional alternative JS implementation with CSS transitions to fix configuration-related outage, thanks to @andreasra feedback.
|
||||||
|
*
|
||||||
|
* @since 2.1.1
|
||||||
|
*
|
||||||
|
* @reporter @andreasra
|
||||||
|
* @link https://wordpress.org/support/topic/footnotes-appearing-in-header/page/2/#post-13632566
|
||||||
|
*
|
||||||
|
* @since 2.4.0
|
||||||
|
* @contributor Patrizia Lutz @misfist
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
public static $a_bool_alternative_tooltips_enabled = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allows to determine whether AMP compatibility mode is enabled.
|
||||||
|
*
|
||||||
|
* - Adding: Tooltips: make display work purely by style rules for AMP compatibility, thanks to @milindmore22 code contribution.
|
||||||
|
* - Bugfix: Tooltips: enable accessibility by keyboard navigation, thanks to @westonruter code contribution.
|
||||||
|
* - Adding: Reference container: get expanding and collapsing to work also in AMP compatibility mode, thanks to @westonruter code contribution.
|
||||||
|
*
|
||||||
|
* @since 2.5.11 (draft)
|
||||||
|
* @since 2.6.0 (release)
|
||||||
|
*
|
||||||
|
* @contributor @milindmore22
|
||||||
|
* @link https://github.com/ampproject/amp-wp/issues/5913#issuecomment-785306933
|
||||||
|
*
|
||||||
|
* @contributor @westonruter
|
||||||
|
* @link https://github.com/ampproject/amp-wp/issues/5913#issuecomment-785419655
|
||||||
|
* @link https://github.com/markcheret/footnotes/issues/48#issuecomment-799580854
|
||||||
|
* @link https://github.com/markcheret/footnotes/issues/48#issuecomment-799582394
|
||||||
|
*
|
||||||
|
* @var bool
|
||||||
|
*/
|
||||||
|
public static $a_bool_amp_enabled = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allows to determine the script mode among jQuery or plain JS.
|
||||||
|
*
|
||||||
|
* - Bugfix: Reference container: optional alternative expanding and collapsing without jQuery for use with hard links, thanks to @hopper87it @pkverma99 issue reports.
|
||||||
|
*
|
||||||
|
* @since 2.5.6
|
||||||
|
*
|
||||||
|
* @reporter @hopper87it
|
||||||
|
* @link https://wordpress.org/support/topic/footnotes-wp-rocket/
|
||||||
|
*
|
||||||
|
* @reporter @pkverma99
|
||||||
|
* @link https://wordpress.org/support/topic/footnotes-wp-rocket/#post-14076188
|
||||||
|
*
|
||||||
|
* @var str 'js' Plain JavaScript.
|
||||||
|
* 'jquery' Use jQuery libraries.
|
||||||
|
*/
|
||||||
|
public static $a_str_script_mode = 'js';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Executes the Plugin.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*
|
||||||
|
* - Bugfix: Improve widgets registration, thanks to @felipelavinz code contribution.
|
||||||
|
*
|
||||||
|
* @since 1.6.5
|
||||||
|
*
|
||||||
|
* @contributor @felipelavinz
|
||||||
|
* @link https://github.com/benleyjyc/footnotes/commit/87173d2980c7ff90e12ffee94ca7153e11163793
|
||||||
|
* @link https://github.com/media-competence-institute/footnotes/commit/87173d2980c7ff90e12ffee94ca7153e11163793
|
||||||
|
*
|
||||||
|
* @see self::initialize_widgets()
|
||||||
|
*/
|
||||||
|
public function run() {
|
||||||
|
// Register language.
|
||||||
|
Footnotes_Language::register_hooks();
|
||||||
|
// Register Button hooks.
|
||||||
|
Footnotes_WYSIWYG::register_hooks();
|
||||||
|
// Register general hooks.
|
||||||
|
Footnotes_Hooks::register_hooks();
|
||||||
|
|
||||||
|
// Initialize the Plugin Dashboard.
|
||||||
|
$this->initialize_dashboard();
|
||||||
|
// Initialize the Plugin Task.
|
||||||
|
$this->initialize_task();
|
||||||
|
|
||||||
|
// Register all Public Stylesheets and Scripts.
|
||||||
|
add_action( 'init', array( $this, 'register_public' ) );
|
||||||
|
// Enqueue all Public Stylesheets and Scripts.
|
||||||
|
add_action( 'wp_enqueue_scripts', array( $this, 'register_public' ) );
|
||||||
|
// Register all Widgets of the Plugin..
|
||||||
|
add_action( 'widgets_init', array( $this, 'initialize_widgets' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes all Widgets of the Plugin.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*
|
||||||
|
* - Update: Fix for deprecated PHP function create_function(), thanks to @psykonevro @daliasued bug reports, thanks to @felipelavinz code contribution
|
||||||
|
*
|
||||||
|
* @since 1.6.5
|
||||||
|
*
|
||||||
|
* @contributor @felipelavinz
|
||||||
|
* @link https://github.com/media-competence-institute/footnotes/commit/87173d2980c7ff90e12ffee94ca7153e11163793
|
||||||
|
*
|
||||||
|
* @reporter @psykonevro
|
||||||
|
* @link https://wordpress.org/support/topic/bug-function-create_function-is-deprecated/
|
||||||
|
* @link https://wordpress.org/support/topic/deprecated-function-create_function-14/
|
||||||
|
*
|
||||||
|
* @reporter @daliasued
|
||||||
|
* @link https://wordpress.org/support/topic/deprecated-function-create_function-14/#post-13312853
|
||||||
|
*
|
||||||
|
* create_function() was deprecated in PHP 7.2.0 and removed in PHP 8.0.0.
|
||||||
|
* @link https://www.php.net/manual/en/function.create-function.php
|
||||||
|
*
|
||||||
|
* The fix is to move add_action() above into run(),
|
||||||
|
* and use the bare register_widget() here.
|
||||||
|
* @see self::run()
|
||||||
|
*
|
||||||
|
* Also, the visibility of initialize_widgets() is not private any longer.
|
||||||
|
*/
|
||||||
|
public function initialize_widgets() {
|
||||||
|
register_widget( 'Footnotes_Widget_Reference_Container' );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes the Dashboard of the Plugin and loads them.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*/
|
||||||
|
private function initialize_dashboard() {
|
||||||
|
new Footnotes_Layout_Init();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes the Plugin Task and registers the Task hooks.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*/
|
||||||
|
private function initialize_task() {
|
||||||
|
$this->a_obj_task = new Footnotes_Task();
|
||||||
|
$this->a_obj_task->register_hooks();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers and enqueues scripts and stylesheets to the public pages.
|
||||||
|
*
|
||||||
|
* @since 1.5.0
|
||||||
|
*
|
||||||
|
* @since 2.0.0 Update: Tooltips: fix disabling bug by loading jQuery UI library, thanks to @rajinderverma @ericcorbett2 @honlapdavid @mmallett bug reports, thanks to @vonpiernik code contribution.
|
||||||
|
* @since 2.0.3 add versioning of public.css for cache busting
|
||||||
|
* @since 2.0.4 add jQuery UI from WordPress
|
||||||
|
* @since 2.1.4 automate passing version number for cache busting
|
||||||
|
* @since 2.1.4 optionally enqueue an extra stylesheet
|
||||||
|
*/
|
||||||
|
public function register_public() {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues external scripts.
|
||||||
|
*
|
||||||
|
* - Bugfix: Libraries: optimize processes by loading external and internal scripts only if needed, thanks to @docteurfitness issue report.
|
||||||
|
*
|
||||||
|
* @since 2.5.5
|
||||||
|
* @reporter @docteurfitness
|
||||||
|
* @link https://wordpress.org/support/topic/simply-speed-optimisation/
|
||||||
|
*
|
||||||
|
* The condition about tooltips was missing, only the not-alternative-tooltips part was present.
|
||||||
|
*/
|
||||||
|
// Set conditions re-used for stylesheet enqueuing and in class/task.php.
|
||||||
|
self::$a_bool_amp_enabled = Footnotes_Convert::to_bool( Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_AMP_COMPATIBILITY_ENABLE ) );
|
||||||
|
self::$a_bool_tooltips_enabled = Footnotes_Convert::to_bool( Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_MOUSE_OVER_BOX_ENABLED ) );
|
||||||
|
self::$a_bool_alternative_tooltips_enabled = Footnotes_Convert::to_bool( Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_MOUSE_OVER_BOX_ALTERNATIVE ) );
|
||||||
|
self::$a_str_script_mode = Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_REFERENCE_CONTAINER_SCRIPT_MODE );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues the jQuery library registered by WordPress.
|
||||||
|
*
|
||||||
|
* - Bugfix: Reference container: optional alternative expanding and collapsing without jQuery for use with hard links, thanks to @hopper87it @pkverma99 issue reports.
|
||||||
|
*
|
||||||
|
* @since 2.5.6
|
||||||
|
*
|
||||||
|
* @reporter @hopper87it
|
||||||
|
* @link https://wordpress.org/support/topic/footnotes-wp-rocket/
|
||||||
|
*
|
||||||
|
* jQuery is also used for animated scrolling, so it was loaded by default.
|
||||||
|
* The function wp_enqueue_script() avoids loading the same library multiple times.
|
||||||
|
* After adding the alternative reference container, jQuery has become optional,
|
||||||
|
* but still enabled by default.
|
||||||
|
*/
|
||||||
|
if ( ! self::$a_bool_amp_enabled ) {
|
||||||
|
|
||||||
|
if ( 'jquery' === self::$a_str_script_mode || ( self::$a_bool_tooltips_enabled && ! self::$a_bool_alternative_tooltips_enabled ) ) {
|
||||||
|
|
||||||
|
wp_enqueue_script( 'jquery' );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( self::$a_bool_tooltips_enabled && ! self::$a_bool_alternative_tooltips_enabled ) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues the jQuery Tools library shipped with the plugin.
|
||||||
|
*
|
||||||
|
* Redacted jQuery.browser, completed minification;
|
||||||
|
* see full header in js/jquery.tools.js.
|
||||||
|
*
|
||||||
|
* Add versioning.
|
||||||
|
*
|
||||||
|
* @since 2.1.2
|
||||||
|
*
|
||||||
|
* No '-js' in the handle, is appended automatically.
|
||||||
|
*
|
||||||
|
* Deferring to the footer breaks jQuery tooltip display.
|
||||||
|
*/
|
||||||
|
wp_enqueue_script(
|
||||||
|
'mci-footnotes-jquery-tools',
|
||||||
|
plugins_url( 'footnotes/public/js/jquery.tools.min.js' ),
|
||||||
|
array(),
|
||||||
|
'1.2.7.redacted.2',
|
||||||
|
false
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues some jQuery UI libraries registered by WordPress.
|
||||||
|
*
|
||||||
|
* - Update: Tooltips: fix disabling bug by loading jQuery UI library, thanks to @rajinderverma @ericcorbett2 @honlapdavid @mmallett bug reports, thanks to @vonpiernik code contribution.
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @reporter @rajinderverma
|
||||||
|
* @link https://wordpress.org/support/topic/tooltip-hover-not-showing/
|
||||||
|
*
|
||||||
|
* @reporter @ericcorbett2
|
||||||
|
* @link https://wordpress.org/support/topic/tooltip-hover-not-showing/#post-13324142
|
||||||
|
*
|
||||||
|
* @reporter @honlapdavid
|
||||||
|
* @link https://wordpress.org/support/topic/tooltip-hover-not-showing/#post-13355421
|
||||||
|
*
|
||||||
|
* @reporter @mmallett
|
||||||
|
* @link https://wordpress.org/support/topic/tooltip-hover-not-showing/#post-13445437
|
||||||
|
*
|
||||||
|
* Fetch jQuery UI from cdnjs.cloudflare.com.
|
||||||
|
* @since 2.0.0
|
||||||
|
* @contributor @vonpiernik
|
||||||
|
* @link https://wordpress.org/support/topic/tooltip-hover-not-showing/#post-13456762
|
||||||
|
*
|
||||||
|
* jQueryUI re-enables the tooltip infobox disabled when WPv5.5 was released. * @since 2.1.2
|
||||||
|
*
|
||||||
|
* - Update: Libraries: Load jQuery UI from WordPress, thanks to @check2020de issue report.
|
||||||
|
*
|
||||||
|
* @since 2.0.4
|
||||||
|
* @reporter @check2020de
|
||||||
|
* @link https://wordpress.org/support/topic/gdpr-issue-with-jquery/
|
||||||
|
* @link https://wordpress.stackexchange.com/questions/273986/correct-way-to-enqueue-jquery-ui
|
||||||
|
*
|
||||||
|
* If alternative tooltips are enabled, these libraries are not needed.
|
||||||
|
*/
|
||||||
|
wp_enqueue_script( 'jquery-ui-core' );
|
||||||
|
wp_enqueue_script( 'jquery-ui-widget' );
|
||||||
|
wp_enqueue_script( 'jquery-ui-position' );
|
||||||
|
wp_enqueue_script( 'jquery-ui-tooltip' );
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enables enqueuing a new-scheme stylesheet.
|
||||||
|
*
|
||||||
|
* @since 2.5.5
|
||||||
|
*
|
||||||
|
* Enables enqueuing the formatted individual stylesheets if false.
|
||||||
|
* WARNING: This facility is designed for development and must NOT be used in production.
|
||||||
|
*
|
||||||
|
* The Boolean may be set at the bottom of the plugin’s main PHP file.
|
||||||
|
* @see footnotes.php
|
||||||
|
*/
|
||||||
|
if ( PRODUCTION_ENV ) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues a minified united external stylesheet in production.
|
||||||
|
*
|
||||||
|
* - Update: Stylesheets: increase speed and energy efficiency by tailoring stylesheets to the needs of the instance, thanks to @docteurfitness design contribution.
|
||||||
|
* - Bugfix: Stylesheets: minify to shrink the carbon footprint, increase speed and implement best practice, thanks to @docteurfitness issue report.
|
||||||
|
*
|
||||||
|
* @since 2.5.5
|
||||||
|
*
|
||||||
|
* @contributor @docteurfitness
|
||||||
|
* @link https://wordpress.org/support/topic/simply-speed-optimisation/
|
||||||
|
*
|
||||||
|
* @reporter @docteurfitness
|
||||||
|
* @link https://wordpress.org/support/topic/simply-speed-optimisation/
|
||||||
|
*
|
||||||
|
* The dashboard stylesheet is minified as-is.
|
||||||
|
* @see class/dashboard/layout.php
|
||||||
|
*
|
||||||
|
* @since 2.0.3 add versioning of public.css for cache busting.
|
||||||
|
* Plugin version number is needed for busting browser caches after each plugin update.
|
||||||
|
*
|
||||||
|
* @since 2.1.4 automate passing version number for cache busting.
|
||||||
|
* The constant C_STR_FOOTNOTES_VERSION is defined at start of footnotes.php.
|
||||||
|
*
|
||||||
|
* The media scope argument 'all' is the default.
|
||||||
|
* No need to use '-css' in the handle, as this is appended automatically.
|
||||||
|
*/
|
||||||
|
// Set tooltip mode for use in stylesheet name.
|
||||||
|
if ( self::$a_bool_tooltips_enabled ) {
|
||||||
|
|
||||||
|
if ( self::$a_bool_amp_enabled ) {
|
||||||
|
$l_str_tooltip_mode_short = 'ampt';
|
||||||
|
$l_str_tooltip_mode_long = 'amp-tooltips';
|
||||||
|
|
||||||
|
} elseif ( self::$a_bool_alternative_tooltips_enabled ) {
|
||||||
|
$l_str_tooltip_mode_short = 'altt';
|
||||||
|
$l_str_tooltip_mode_long = 'alternative-tooltips';
|
||||||
|
|
||||||
|
} else {
|
||||||
|
$l_str_tooltip_mode_short = 'jqtt';
|
||||||
|
$l_str_tooltip_mode_long = 'jquery-tooltips';
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$l_str_tooltip_mode_short = 'nott';
|
||||||
|
$l_str_tooltip_mode_long = 'no-tooltips';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set basic responsive page layout mode for use in stylesheet name.
|
||||||
|
$l_str_page_layout_option = Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_PAGE_LAYOUT_SUPPORT );
|
||||||
|
switch ( $l_str_page_layout_option ) {
|
||||||
|
case 'reference-container':
|
||||||
|
$l_str_layout_mode = '1';
|
||||||
|
break;
|
||||||
|
case 'entry-content':
|
||||||
|
$l_str_layout_mode = '2';
|
||||||
|
break;
|
||||||
|
case 'main-content':
|
||||||
|
$l_str_layout_mode = '3';
|
||||||
|
break;
|
||||||
|
case 'none':
|
||||||
|
default:
|
||||||
|
$l_str_layout_mode = '0';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Enqueue the tailored united minified stylesheet.
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-' . $l_str_tooltip_mode_long . '-pagelayout-' . $l_str_page_layout_option,
|
||||||
|
plugins_url(
|
||||||
|
Footnotes_Config::C_STR_PLUGIN_NAME . '/css/footnotes-' . $l_str_tooltip_mode_short . 'brpl' . $l_str_layout_mode . '.min.css'
|
||||||
|
),
|
||||||
|
array(),
|
||||||
|
C_STR_FOOTNOTES_VERSION,
|
||||||
|
'all'
|
||||||
|
);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enqueues external stylesheets, ONLY in development now.
|
||||||
|
*
|
||||||
|
* @since 2.1.4 optionally enqueue an extra stylesheet.
|
||||||
|
*
|
||||||
|
* This optional layout fix is useful by lack of layout support.
|
||||||
|
*/
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-common',
|
||||||
|
plugins_url( Footnotes_Config::C_STR_PLUGIN_NAME . '/css/dev-common.css' ),
|
||||||
|
array(),
|
||||||
|
filemtime(
|
||||||
|
plugin_dir_path(
|
||||||
|
dirname( __FILE__, 1 )
|
||||||
|
) . 'css/dev-common.css'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-tooltips',
|
||||||
|
plugins_url( Footnotes_Config::C_STR_PLUGIN_NAME . '/css/dev-tooltips.css' ),
|
||||||
|
array(),
|
||||||
|
filemtime(
|
||||||
|
plugin_dir_path(
|
||||||
|
dirname( __FILE__, 1 )
|
||||||
|
) . 'css/dev-tooltips.css'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
if ( self::$a_bool_amp_enabled ) {
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-amp',
|
||||||
|
plugins_url( Footnotes_Config::C_STR_PLUGIN_NAME . '/css/dev-amp-tooltips.css' ),
|
||||||
|
array(),
|
||||||
|
filemtime(
|
||||||
|
plugin_dir_path(
|
||||||
|
dirname( __FILE__, 1 )
|
||||||
|
) . 'css/dev-amp-tooltips.css'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( self::$a_bool_alternative_tooltips_enabled ) {
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-alternative',
|
||||||
|
plugins_url( Footnotes_Config::C_STR_PLUGIN_NAME . '/css/dev-tooltips-alternative.css' ),
|
||||||
|
array(),
|
||||||
|
filemtime(
|
||||||
|
plugin_dir_path(
|
||||||
|
dirname( __FILE__, 1 )
|
||||||
|
) . 'css/dev-tooltips-alternative.css'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
$l_str_page_layout_option = Footnotes_Settings::instance()->get( Footnotes_Settings::C_STR_FOOTNOTES_PAGE_LAYOUT_SUPPORT );
|
||||||
|
if ( 'none' !== $l_str_page_layout_option ) {
|
||||||
|
wp_enqueue_style(
|
||||||
|
'mci-footnotes-layout-' . $l_str_page_layout_option,
|
||||||
|
plugins_url(
|
||||||
|
Footnotes_Config::C_STR_PLUGIN_NAME . '/css/dev-layout-' . $l_str_page_layout_option . '.css'
|
||||||
|
),
|
||||||
|
array(),
|
||||||
|
filemtime(
|
||||||
|
plugin_dir_path(
|
||||||
|
dirname( __FILE__, 1 )
|
||||||
|
) . 'css/dev-layout-' . $l_str_page_layout_option . '.css'
|
||||||
|
),
|
||||||
|
'all'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in a new issue