-
Notifications
You must be signed in to change notification settings - Fork 0
/
axis-builder.php
259 lines (225 loc) · 6.09 KB
/
axis-builder.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
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
<?php
/**
* Plugin Name: Axis Builder
* Plugin URI: http://axisthemes.com/axis-builder/
* Description: A drag and drop builder that helps you build modern and unique page layouts smartly. Beautifully.
* Author: AxisThemes
* Author URI: http://axisthemes.com
* Version: 1.0-bleeding
* Requires at least: 4.0
* Tested up to: 4.0
*
* Text Domain: axisbuilder
* Domain Path: /i18n/languages/
*
* @package AxisBuilder
* @category Core
* @author AxisThemes
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly
}
if ( ! class_exists( 'AxisBuilder' ) ) :
/**
* Main AxisBuilder Class
*
* @class AxisBuilder
* @property mixed $shortcodes Get shortcodes class
* @version 1.0.0
*/
final class AxisBuilder {
/**
* @var string
*/
public $version = '1.0.0';
/**
* @var AxisBuilder The single instance of the class
*/
protected static $_instance = null;
/**
* Main AxisBuilder Instance
*
* Ensure only one instance of AxisBuilder is loaded or can be loaded.
*
* @static
* @see AB()
* @return AxisBuilder - Main instance
*/
public static function instance() {
if ( is_null( self::$_instance ) ) {
self::$_instance = new self();
}
return self::$_instance;
}
/**
* Cloning is forbidden.
* @since 1.0
*/
public function __clone() {
_doing_it_wrong( __FUNCTION__, __( 'Cheatin’ huh?', 'axisbuilder' ), '1.0' );
}
/**
* Unserializing instances of this class is forbidden.
* @since 1.0
*/
public function __wakeup() {
_doing_it_wrong( __FUNCTION__, __( 'Cheatin’ huh?', 'axisbuilder' ), '1.0' );
}
/**
* Auto-load in-accessible properties on demand.
* @param mixed $key
* @return mixed
*/
public function __get( $key ) {
if ( in_array( $key, array( 'shortcodes' ) ) ) {
return $this->$key();
}
}
/**
* AxisBuilder Constructor.
* @access public
* @return AxisBuilder
*/
public function __construct() {
$this->define_constants();
$this->includes();
// Hooks
add_action( 'init', array( $this, 'init' ), 0 );
// Loaded action
do_action( 'axisbuilder_loaded' );
}
/**
* Define constant if not already set
* @param string $name
* @param string|bool $value
*/
private function define( $name, $value ) {
if ( ! defined( $name ) ) {
define( $name, $value );
}
}
/**
* What type of request is this?
* @param string $type ajax, frontend or admin
* @return string
*/
private function is_request( $type ) {
switch ( $type ) {
case 'admin' :
return is_admin();
case 'ajax' :
return defined( 'DOING_AJAX' );
case 'frontend' :
return ! is_admin() || defined( 'DOING_AJAX' );
}
}
/**
* Define AB Constants.
*/
private function define_constants() {
$this->define( 'AB_PLUGIN_FILE', __FILE__ );
$this->define( 'AB_PLUGIN_BASENAME', plugin_basename( __FILE__ ) );
$this->define( 'AB_VERSION', $this->version );
$this->define( 'AB_CONFIG_DIR', $this->plugin_path() . '/config/' );
}
/**
* Includes the required core files used in admin and on the frontend.
*/
private function includes() {
include_once( 'includes/builder-core-functions.php' );
include_once( 'includes/builder-helper-functions.php' );
include_once( 'includes/builder-widget-functions.php' );
include_once( 'includes/class-builder-autoloader.php' );
include_once( 'includes/class-builder-install.php' );
if ( $this->is_request( 'admin' ) ) {
include_once( 'includes/admin/class-builder-admin.php' );
}
if ( $this->is_request( 'ajax' ) ) {
$this->ajax_includes();
}
include_once( 'includes/abstracts/abstract-builder-shortcode.php' ); // Shortcodes
include_once( 'includes/class-builder-localization.php' ); // Download/update languages
}
/**
* Include required ajax files.
*/
public function ajax_includes() {
include_once( 'includes/class-builder-ajax.php' ); // Ajax functions for admin and the front-end
}
/**
* Init AxisBuilder when WordPress Initialises.
*/
public function init() {
// Before init action
do_action( 'before_axisbuilder_init' );
// Set up localisation
$this->load_plugin_textdomain();
// Set up shortcodes
$this->shortcodes();
// Init action
do_action( 'axisbuilder_init' );
}
/**
* Load Localisation files.
*
* Note: the first-loaded translation file overrides any following ones if the same translation is present.
*
* Admin Locales are found in:
* - WP_LANG_DIR/axis-builder/axisbuilder-admin-LOCALE.mo
* - WP_LANG_DIR/plugins/axisbuilder-admin-LOCALE.mo
*
* Frontend/global Locales found in:
* - WP_LANG_DIR/axis-builder/axisbuilder-LOCALE.mo
* - axis-builder/i18n/languages/axisbuilder-LOCALE.mo (which if not found falls back to:)
* - WP_LANG_DIR/plugins/axisbuilder-LOCALE.mo
*/
public function load_plugin_textdomain() {
$locale = apply_filters( 'plugin_locale', get_locale(), 'axisbuilder' );
if ( $this->is_request( 'admin' ) ) {
load_textdomain( 'axisbuilder', WP_LANG_DIR . '/axis-builder/axisbuilder-admin-' . $locale . '.mo' );
load_textdomain( 'axisbuilder', WP_LANG_DIR . '/plugins/axisbuilder-admin-' . $locale . '.mo' );
}
load_textdomain( 'axisbuilder', WP_LANG_DIR . '/axis-builder/axisbuilder-' . $locale . '.mo' );
load_plugin_textdomain( 'axisbuilder', false, plugin_basename( dirname( __FILE__ ) ) . "/i18n/languages" );
}
/**
* Get the plugin url.
* @return string
*/
public function plugin_url() {
return untrailingslashit( plugins_url( '/', __FILE__ ) );
}
/**
* Get the plugin path.
* @return string
*/
public function plugin_path() {
return untrailingslashit( plugin_dir_path( __FILE__ ) );
}
/**
* Get Ajax URL.
* @return string
*/
public function ajax_url() {
return admin_url( 'admin-ajax.php', 'relative' );
}
/**
* Get shortcodes class
* @return AB_Shortcodes
*/
public function shortcodes() {
return AB_Shortcodes::instance();
}
}
endif;
/**
* Returns the main instance of AB to prevent the need to use globals.
*
* @since 1.0.0
* @return AxisBuilder
*/
function AB() {
return AxisBuilder::instance();
}
// Global for backwards compatibility.
$GLOBALS['axisbuilder'] = AB();