-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathshortcode-button.php
156 lines (140 loc) · 4.4 KB
/
shortcode-button.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
<?php
/**
* Shortcode_Button loader
* Handles checking for and smartly loading the newest version of this library.
*
* Shortcode_Button - Tinymce and Quicktag buttons for outputting shortcodes.
*
* @category WordPressLibrary
* @package Shortcode_Button
* @author Justin Sternberg <justin@dsgnwrks.pro>
* @copyright 2015-2016 Justin Sternberg <justin@dsgnwrks.pro>
* @license GPL-2.0+
* @version 1.0.7
* @link https://github.com/jtsternberg/Shortcode_Button
* @since 1.0.0
*/
/**
* Copyright (c) 2015-2016 Justin Sternberg (email : justin@dsgnwrks.pro)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License, version 2 or, at
* your discretion, any later version, as published by the Free
* Software Foundation.
*
* 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 St, Fifth Floor, Boston, MA 02110-1301 USA
*/
/**
* Loader versioning: http://jtsternberg.github.io/wp-lib-loader/
*/
if ( ! class_exists( 'Shortcode_Button_107', false ) ) {
/**
* Versioned loader class-name
*
* This ensures each version is loaded/checked.
*
* @category WordPressLibrary
* @package Shortcode_Button
* @author Justin Sternberg <justin@dsgnwrks.pro>
* @license GPL-2.0+
* @version 1.0.7
* @link https://github.com/jtsternberg/Shortcode_Button
* @since 1.0.0
*/
class Shortcode_Button_107 {
/**
* Shortcode_Button version number
* @var string
* @since 1.0.0
*/
const VERSION = '1.0.7';
/**
* Current version hook priority.
* Will decrement with each release
*
* @var int
* @since 1.0.0
*/
const PRIORITY = 9992;
/**
* Starts the version checking process.
* Creates SHORTCODE_BUTTONS_LOADED definition for early detection by
* other scripts.
*
* Hooks Shortcode_Button inclusion to the shortcode_button_load hook
* on a high priority which decrements (increasing the priority) with
* each version release.
*
* @since 1.0.0
*/
public function __construct() {
if ( ! defined( 'SHORTCODE_BUTTONS_LOADED' ) ) {
/**
* A constant you can use to check if Shortcode_Button is loaded
* for your plugins/themes with Shortcode_Button dependency.
*
* Can also be used to determine the priority of the hook
* in use for the currently loaded version.
*/
define( 'SHORTCODE_BUTTONS_LOADED', self::PRIORITY );
}
// Use the hook system to ensure only the newest version is loaded.
add_action( 'shortcode_button_load', array( $this, 'include_lib' ), self::PRIORITY );
/*
* Hook in to the first hook we have available and
* fire our `shortcode_button_load' hook.
*/
add_action( 'muplugins_loaded', array( __CLASS__, 'fire_hook' ), 9 );
add_action( 'plugins_loaded', array( __CLASS__, 'fire_hook' ), 9 );
add_action( 'after_setup_theme', array( __CLASS__, 'fire_hook' ), 9 );
}
/**
* Fires the shortcode_button_load action hook.
*
* @since 1.0.0
*/
public static function fire_hook() {
if ( ! did_action( 'shortcode_button_load' ) ) {
// Then fire our hook.
do_action( 'shortcode_button_load' );
}
}
/**
* A final check if Shortcode_Button exists before kicking off
* our Shortcode_Button loading.
*
* SHORTCODE_BUTTONS_VERSION and SHORTCODE_BUTTONS_DIR constants are
* set at this point.
*
* @since 1.0.0
*/
public function include_lib() {
if ( class_exists( 'Shortcode_Button', false ) ) {
return;
}
if ( ! defined( 'SHORTCODE_BUTTONS_VERSION' ) ) {
/**
* Defines the currently loaded version of Shortcode_Button.
*/
define( 'SHORTCODE_BUTTONS_VERSION', self::VERSION );
}
if ( ! defined( 'SHORTCODE_BUTTONS_DIR' ) ) {
/**
* Defines the directory of the currently loaded version of Shortcode_Button.
*/
define( 'SHORTCODE_BUTTONS_DIR', dirname( __FILE__ ) . '/' );
}
// Include and initiate Shortcode_Button.
require_once SHORTCODE_BUTTONS_DIR . 'lib/class-shortcode-button.php';
}
}
// Kick it off.
new Shortcode_Button_107;
}