Passed
Pull Request — master (#862)
by Kiran
06:12
created
vendor/ayecode/wp-ayecode-ui/includes/ayecode-ui-settings.php 3 patches
Braces   +13 added lines, -9 removed lines patch added patch discarded remove patch
@@ -538,7 +538,7 @@  discard block
 block discarded – undo
538 538
 					// custom changes
539 539
 					if ( $load_fse ) {
540 540
 						wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
-					}else{
541
+					} else{
542 542
 						wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
543 543
 					}
544 544
 				}
@@ -558,7 +558,7 @@  discard block
 block discarded – undo
558 558
 			ob_start();
559 559
 			if ( $aui_bs5 ) {
560 560
 				include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
-			}else{
561
+			} else{
562 562
 				include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
563 563
             }
564 564
 
@@ -642,7 +642,7 @@  discard block
 block discarded – undo
642 642
 				// iconpicker
643 643
 				if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644 644
 					wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
-				}else{
645
+				} else{
646 646
 					wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
647 647
 				}
648 648
 
@@ -1371,9 +1371,9 @@  discard block
 block discarded – undo
1371 1371
 
1372 1372
 			if($compatibility===true || $compatibility===1){
1373 1373
 				$compatibility = '.bsui';
1374
-			}elseif(!$compatibility){
1374
+			} elseif(!$compatibility){
1375 1375
 				$compatibility = '';
1376
-			}else{
1376
+			} else{
1377 1377
 				$compatibility = esc_attr($compatibility);
1378 1378
 			}
1379 1379
 
@@ -1659,9 +1659,9 @@  discard block
 block discarded – undo
1659 1659
 
1660 1660
 			if($compatibility===true || $compatibility===1){
1661 1661
 				$compatibility = '.bsui';
1662
-			}elseif(!$compatibility){
1662
+			} elseif(!$compatibility){
1663 1663
 				$compatibility = '';
1664
-			}else{
1664
+			} else{
1665 1665
 				$compatibility = esc_attr($compatibility);
1666 1666
 			}
1667 1667
 
@@ -2531,7 +2531,9 @@  discard block
 block discarded – undo
2531 2531
 		 * @return mixed
2532 2532
 		 */
2533 2533
 		public static function minify_js($input) {
2534
-			if(trim($input) === "") return $input;
2534
+			if(trim($input) === "") {
2535
+			    return $input;
2536
+			}
2535 2537
 			return preg_replace(
2536 2538
 				array(
2537 2539
 					// Remove comment(s)
@@ -2563,7 +2565,9 @@  discard block
 block discarded – undo
2563 2565
 		 * @return mixed
2564 2566
 		 */
2565 2567
 		public static function minify_css($input) {
2566
-			if(trim($input) === "") return $input;
2568
+			if(trim($input) === "") {
2569
+			    return $input;
2570
+			}
2567 2571
 			return preg_replace(
2568 2572
 				array(
2569 2573
 					// Remove comment(s)
Please login to merge, or discard this patch.
Spacing   +799 added lines, -799 removed lines patch added patch discarded remove patch
@@ -12,14 +12,14 @@  discard block
 block discarded – undo
12 12
 /**
13 13
  * Bail if we are not in WP.
14 14
  */
15
-if ( ! defined( 'ABSPATH' ) ) {
15
+if (!defined('ABSPATH')) {
16 16
 	exit;
17 17
 }
18 18
 
19 19
 /**
20 20
  * Only add if the class does not already exist.
21 21
  */
22
-if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
22
+if (!class_exists('AyeCode_UI_Settings')) {
23 23
 
24 24
 	/**
25 25
 	 * A Class to be able to change settings for Font Awesome.
@@ -99,27 +99,27 @@  discard block
 block discarded – undo
99 99
 		 * @return AyeCode_UI_Settings - Main instance.
100 100
 		 */
101 101
 		public static function instance() {
102
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
102
+			if (!isset(self::$instance) && !(self::$instance instanceof AyeCode_UI_Settings)) {
103 103
 
104 104
 				self::$instance = new AyeCode_UI_Settings;
105 105
 
106
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
+				add_action('init', array(self::$instance, 'init')); // set settings
107 107
 
108
-				if ( is_admin() ) {
109
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
110
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
108
+				if (is_admin()) {
109
+					add_action('admin_menu', array(self::$instance, 'menu_item'));
110
+					add_action('admin_init', array(self::$instance, 'register_settings'));
111 111
 
112 112
 					// Maybe show example page
113
-					add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
113
+					add_action('template_redirect', array(self::$instance, 'maybe_show_examples'));
114 114
 
115
-					if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
116
-						add_filter( 'sd_aui_colors', array( self::$instance,'sd_aui_colors' ), 10, 3 );
115
+					if (defined('BLOCKSTRAP_VERSION')) {
116
+						add_filter('sd_aui_colors', array(self::$instance, 'sd_aui_colors'), 10, 3);
117 117
 					}
118 118
 				}
119 119
 
120
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
120
+				add_action('customize_register', array(self::$instance, 'customizer_settings'));
121 121
 
122
-				do_action( 'ayecode_ui_settings_loaded' );
122
+				do_action('ayecode_ui_settings_loaded');
123 123
 			}
124 124
 
125 125
 			return self::$instance;
@@ -134,13 +134,13 @@  discard block
 block discarded – undo
134 134
 		 *
135 135
 		 * @return mixed
136 136
 		 */
137
-		public function sd_aui_colors( $theme_colors, $include_outlines, $include_branding ){
137
+		public function sd_aui_colors($theme_colors, $include_outlines, $include_branding) {
138 138
 
139 139
 
140 140
 			$setting = wp_get_global_settings();
141 141
 
142
-			if(!empty($setting['color']['palette']['custom'])){
143
-				foreach($setting['color']['palette']['custom'] as $color){
142
+			if (!empty($setting['color']['palette']['custom'])) {
143
+				foreach ($setting['color']['palette']['custom'] as $color) {
144 144
 					$theme_colors[$color['slug']] = esc_attr($color['name']);
145 145
 				}
146 146
 			}
@@ -151,81 +151,81 @@  discard block
 block discarded – undo
151 151
 		/**
152 152
 		 * Setup some constants.
153 153
 		 */
154
-		public function constants(){
155
-			define( 'AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be" );
156
-			define( 'AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d' );
157
-			define( 'AUI_INFO_COLOR_ORIGINAL', '#17a2b8' );
158
-			define( 'AUI_WARNING_COLOR_ORIGINAL', '#ffc107' );
159
-			define( 'AUI_DANGER_COLOR_ORIGINAL', '#dc3545' );
160
-			define( 'AUI_SUCCESS_COLOR_ORIGINAL', '#44c553' );
161
-			define( 'AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa' );
162
-			define( 'AUI_DARK_COLOR_ORIGINAL', '#343a40' );
163
-			define( 'AUI_WHITE_COLOR_ORIGINAL', '#fff' );
164
-			define( 'AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd' );
165
-			define( 'AUI_SALMON_COLOR_ORIGINAL', '#ff977a' );
166
-			define( 'AUI_CYAN_COLOR_ORIGINAL', '#35bdff' );
167
-			define( 'AUI_GRAY_COLOR_ORIGINAL', '#ced4da' );
168
-			define( 'AUI_INDIGO_COLOR_ORIGINAL', '#502c6c' );
169
-			define( 'AUI_ORANGE_COLOR_ORIGINAL', '#orange' );
170
-			define( 'AUI_BLACK_COLOR_ORIGINAL', '#000' );
154
+		public function constants() {
155
+			define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be");
156
+			define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d');
157
+			define('AUI_INFO_COLOR_ORIGINAL', '#17a2b8');
158
+			define('AUI_WARNING_COLOR_ORIGINAL', '#ffc107');
159
+			define('AUI_DANGER_COLOR_ORIGINAL', '#dc3545');
160
+			define('AUI_SUCCESS_COLOR_ORIGINAL', '#44c553');
161
+			define('AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa');
162
+			define('AUI_DARK_COLOR_ORIGINAL', '#343a40');
163
+			define('AUI_WHITE_COLOR_ORIGINAL', '#fff');
164
+			define('AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd');
165
+			define('AUI_SALMON_COLOR_ORIGINAL', '#ff977a');
166
+			define('AUI_CYAN_COLOR_ORIGINAL', '#35bdff');
167
+			define('AUI_GRAY_COLOR_ORIGINAL', '#ced4da');
168
+			define('AUI_INDIGO_COLOR_ORIGINAL', '#502c6c');
169
+			define('AUI_ORANGE_COLOR_ORIGINAL', '#orange');
170
+			define('AUI_BLACK_COLOR_ORIGINAL', '#000');
171 171
 
172
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
173
-				define( 'AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL );
172
+			if (!defined('AUI_PRIMARY_COLOR')) {
173
+				define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL);
174 174
 			}
175
-			if ( ! defined( 'AUI_SECONDARY_COLOR' ) ) {
176
-				define( 'AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL );
175
+			if (!defined('AUI_SECONDARY_COLOR')) {
176
+				define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL);
177 177
 			}
178
-			if ( ! defined( 'AUI_INFO_COLOR' ) ) {
179
-				define( 'AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL );
178
+			if (!defined('AUI_INFO_COLOR')) {
179
+				define('AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL);
180 180
 			}
181
-			if ( ! defined( 'AUI_WARNING_COLOR' ) ) {
182
-				define( 'AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL );
181
+			if (!defined('AUI_WARNING_COLOR')) {
182
+				define('AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL);
183 183
 			}
184
-			if ( ! defined( 'AUI_DANGER_COLOR' ) ) {
185
-				define( 'AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL );
184
+			if (!defined('AUI_DANGER_COLOR')) {
185
+				define('AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL);
186 186
 			}
187
-			if ( ! defined( 'AUI_SUCCESS_COLOR' ) ) {
188
-				define( 'AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL );
187
+			if (!defined('AUI_SUCCESS_COLOR')) {
188
+				define('AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL);
189 189
 			}
190
-			if ( ! defined( 'AUI_LIGHT_COLOR' ) ) {
191
-				define( 'AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL );
190
+			if (!defined('AUI_LIGHT_COLOR')) {
191
+				define('AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL);
192 192
 			}
193
-			if ( ! defined( 'AUI_DARK_COLOR' ) ) {
194
-				define( 'AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL );
193
+			if (!defined('AUI_DARK_COLOR')) {
194
+				define('AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL);
195 195
 			}
196
-			if ( ! defined( 'AUI_WHITE_COLOR' ) ) {
197
-				define( 'AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL );
196
+			if (!defined('AUI_WHITE_COLOR')) {
197
+				define('AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL);
198 198
 			}
199
-			if ( ! defined( 'AUI_PURPLE_COLOR' ) ) {
200
-				define( 'AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL );
199
+			if (!defined('AUI_PURPLE_COLOR')) {
200
+				define('AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL);
201 201
 			}
202
-			if ( ! defined( 'AUI_SALMON_COLOR' ) ) {
203
-				define( 'AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL );
202
+			if (!defined('AUI_SALMON_COLOR')) {
203
+				define('AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL);
204 204
 			}
205
-			if ( ! defined( 'AUI_CYAN_COLOR' ) ) {
206
-				define( 'AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL );
205
+			if (!defined('AUI_CYAN_COLOR')) {
206
+				define('AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL);
207 207
 			}
208
-			if ( ! defined( 'AUI_GRAY_COLOR' ) ) {
209
-				define( 'AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL );
208
+			if (!defined('AUI_GRAY_COLOR')) {
209
+				define('AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL);
210 210
 			}
211
-			if ( ! defined( 'AUI_INDIGO_COLOR' ) ) {
212
-				define( 'AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL );
211
+			if (!defined('AUI_INDIGO_COLOR')) {
212
+				define('AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL);
213 213
 			}
214
-			if ( ! defined( 'AUI_ORANGE_COLOR' ) ) {
215
-				define( 'AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL );
214
+			if (!defined('AUI_ORANGE_COLOR')) {
215
+				define('AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL);
216 216
 			}
217
-			if ( ! defined( 'AUI_BLACK_COLOR' ) ) {
218
-				define( 'AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL );
217
+			if (!defined('AUI_BLACK_COLOR')) {
218
+				define('AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL);
219 219
 			}
220 220
 
221 221
 		}
222 222
 
223
-		public static function get_colors( $original = false){
223
+		public static function get_colors($original = false) {
224 224
 
225
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
225
+			if (!defined('AUI_PRIMARY_COLOR')) {
226 226
 				return array();
227 227
 			}
228
-			if ( $original ) {
228
+			if ($original) {
229 229
 				return array(
230 230
 					'primary'   => AUI_PRIMARY_COLOR_ORIGINAL,
231 231
 					'secondary' => AUI_SECONDARY_COLOR_ORIGINAL,
@@ -273,7 +273,7 @@  discard block
 block discarded – undo
273 273
 		 *
274 274
 		 * @return mixed
275 275
 		 */
276
-		public function add_bs5_admin_body_class( $classes = '' ) {
276
+		public function add_bs5_admin_body_class($classes = '') {
277 277
 			$classes .= ' aui_bs5';
278 278
 
279 279
 			return $classes;
@@ -286,7 +286,7 @@  discard block
 block discarded – undo
286 286
 		 *
287 287
 		 * @return mixed
288 288
 		 */
289
-		public function add_bs5_body_class( $classes ) {
289
+		public function add_bs5_body_class($classes) {
290 290
 			$classes[] = 'aui_bs5';
291 291
 
292 292
 			return $classes;
@@ -299,12 +299,12 @@  discard block
 block discarded – undo
299 299
             global $aui_bs5;
300 300
 
301 301
 			// Maybe fix settings
302
-			if ( ! empty( $_REQUEST['aui-fix-admin'] ) && !empty($_REQUEST['nonce']) && wp_verify_nonce( $_REQUEST['nonce'], "aui-fix-admin" ) ) {
303
-				$db_settings = get_option( 'ayecode-ui-settings' );
304
-				if ( ! empty( $db_settings ) ) {
302
+			if (!empty($_REQUEST['aui-fix-admin']) && !empty($_REQUEST['nonce']) && wp_verify_nonce($_REQUEST['nonce'], "aui-fix-admin")) {
303
+				$db_settings = get_option('ayecode-ui-settings');
304
+				if (!empty($db_settings)) {
305 305
 					$db_settings['css_backend'] = 'compatibility';
306 306
 					$db_settings['js_backend'] = 'core-popper';
307
-					update_option( 'ayecode-ui-settings', $db_settings );
307
+					update_option('ayecode-ui-settings', $db_settings);
308 308
 					wp_safe_redirect(admin_url("options-general.php?page=ayecode-ui-settings&updated=true"));
309 309
 				}
310 310
 			}
@@ -316,10 +316,10 @@  discard block
 block discarded – undo
316 316
             // define the version
317 317
 			$aui_bs5 = $this->settings['bs_ver'] === '5';
318 318
 
319
-			if ( $aui_bs5 ) {
320
-				include_once( dirname( __FILE__ ) . '/inc/bs-conversion.php' );
321
-				add_filter( 'admin_body_class', array( $this, 'add_bs5_admin_body_class' ), 99, 1 );
322
-				add_filter( 'body_class', array( $this, 'add_bs5_body_class' ) );
319
+			if ($aui_bs5) {
320
+				include_once(dirname(__FILE__) . '/inc/bs-conversion.php');
321
+				add_filter('admin_body_class', array($this, 'add_bs5_admin_body_class'), 99, 1);
322
+				add_filter('body_class', array($this, 'add_bs5_body_class'));
323 323
 			}
324 324
 
325 325
 			/**
@@ -327,32 +327,32 @@  discard block
 block discarded – undo
327 327
 			 *
328 328
 			 * We load super early in case there is a theme version that might change the colors
329 329
 			 */
330
-			if ( $this->settings['css'] ) {
330
+			if ($this->settings['css']) {
331 331
 				$priority = $this->is_bs3_compat() ? 100 : 1;
332 332
                 $priority = $aui_bs5 ? 10 : $priority;
333
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), $priority );
333
+				add_action('wp_enqueue_scripts', array($this, 'enqueue_style'), $priority);
334 334
 			}
335
-			if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
336
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
335
+			if ($this->settings['css_backend'] && $this->load_admin_scripts()) {
336
+				add_action('admin_enqueue_scripts', array($this, 'enqueue_style'), 1);
337 337
 			}
338 338
 
339 339
 			// maybe load JS
340
-			if ( $this->settings['js'] ) {
340
+			if ($this->settings['js']) {
341 341
 				$priority = $this->is_bs3_compat() ? 100 : 1;
342
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
342
+				add_action('wp_enqueue_scripts', array($this, 'enqueue_scripts'), $priority);
343 343
 			}
344
-			if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
345
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
344
+			if ($this->settings['js_backend'] && $this->load_admin_scripts()) {
345
+				add_action('admin_enqueue_scripts', array($this, 'enqueue_scripts'), 1);
346 346
 			}
347 347
 
348 348
 			// Maybe set the HTML font size
349
-			if ( $this->settings['html_font_size'] ) {
350
-				add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
349
+			if ($this->settings['html_font_size']) {
350
+				add_action('wp_footer', array($this, 'html_font_size'), 10);
351 351
 			}
352 352
 
353 353
 			// Maybe show backend style error
354
-			if( $this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper' ){
355
-				add_action( 'admin_notices', array( $this, 'show_admin_style_notice' ) );
354
+			if ($this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper') {
355
+				add_action('admin_notices', array($this, 'show_admin_style_notice'));
356 356
 			}
357 357
 
358 358
 		}
@@ -360,11 +360,11 @@  discard block
 block discarded – undo
360 360
 		/**
361 361
 		 * Show admin notice if backend scripts not loaded.
362 362
 		 */
363
-		public function show_admin_style_notice(){
364
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=".wp_create_nonce('aui-fix-admin'));
365
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">Fix Now</a>';
366
-			$message = __( '<b>Style Issue:</b> AyeCode UI is disable or set wrong.')." " .$button;
367
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
363
+		public function show_admin_style_notice() {
364
+			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=" . wp_create_nonce('aui-fix-admin'));
365
+			$button = '<a href="' . esc_url($fix_url) . '" class="button-primary">Fix Now</a>';
366
+			$message = __('<b>Style Issue:</b> AyeCode UI is disable or set wrong.') . " " . $button;
367
+			echo '<div class="notice notice-error aui-settings-error-notice"><p>' . wp_kses_post($message) . '</p></div>';
368 368
 		}
369 369
 
370 370
 		/**
@@ -372,14 +372,14 @@  discard block
 block discarded – undo
372 372
 		 *
373 373
 		 * @return bool
374 374
 		 */
375
-		public function load_admin_scripts(){
375
+		public function load_admin_scripts() {
376 376
 			$result = true;
377 377
 
378 378
 			// check if specifically disabled
379
-			if(!empty($this->settings['disable_admin'])){
380
-				$url_parts = explode("\n",$this->settings['disable_admin']);
381
-				foreach($url_parts as $part){
382
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
379
+			if (!empty($this->settings['disable_admin'])) {
380
+				$url_parts = explode("\n", $this->settings['disable_admin']);
381
+				foreach ($url_parts as $part) {
382
+					if (strpos($_SERVER['REQUEST_URI'], trim($part)) !== false) {
383 383
 						return false; // return early, no point checking further
384 384
 					}
385 385
 				}
@@ -391,9 +391,9 @@  discard block
 block discarded – undo
391 391
 		/**
392 392
 		 * Add a html font size to the footer.
393 393
 		 */
394
-		public function html_font_size(){
394
+		public function html_font_size() {
395 395
 			$this->settings = $this->get_settings();
396
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
396
+			echo "<style>html{font-size:" . absint($this->settings['html_font_size']) . "px;}</style>";
397 397
 		}
398 398
 
399 399
 		/**
@@ -401,11 +401,11 @@  discard block
 block discarded – undo
401 401
 		 *
402 402
 		 * @return bool
403 403
 		 */
404
-		public function is_aui_screen(){
404
+		public function is_aui_screen() {
405 405
 //			echo '###';exit;
406 406
 			$load = false;
407 407
 			// check if we should load or not
408
-			if ( is_admin() ) {
408
+			if (is_admin()) {
409 409
 				// Only enable on set pages
410 410
 				$aui_screens = array(
411 411
 					'page',
@@ -417,26 +417,26 @@  discard block
 block discarded – undo
417 417
 					'ayecode-ui-settings',
418 418
 					'site-editor'
419 419
 				);
420
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
420
+				$screen_ids = apply_filters('aui_screen_ids', $aui_screens);
421 421
 
422 422
 				$screen = get_current_screen();
423 423
 
424 424
 //				echo '###'.$screen->id;
425 425
 
426 426
 				// check if we are on a AUI screen
427
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
427
+				if ($screen && in_array($screen->id, $screen_ids)) {
428 428
 					$load = true;
429 429
 				}
430 430
 
431 431
 				//load for widget previews in WP 5.8
432
-				if( !empty($_REQUEST['legacy-widget-preview'])){
432
+				if (!empty($_REQUEST['legacy-widget-preview'])) {
433 433
 					$load = true;
434 434
 				}
435 435
 			}
436 436
 
437 437
 
438 438
 
439
-			return apply_filters( 'aui_load_on_admin' , $load );
439
+			return apply_filters('aui_load_on_admin', $load);
440 440
 		}
441 441
 
442 442
 		/**
@@ -445,7 +445,7 @@  discard block
 block discarded – undo
445 445
 		 * @return bool
446 446
 		 */
447 447
 		public static function is_block_theme() {
448
-			if ( function_exists( 'wp_is_block_theme' && wp_is_block_theme() ) ) {
448
+			if (function_exists('wp_is_block_theme' && wp_is_block_theme())) {
449 449
 				return true;
450 450
 			}
451 451
 
@@ -460,32 +460,32 @@  discard block
 block discarded – undo
460 460
 
461 461
             $load_fse = false;
462 462
 
463
-			if ( is_admin() && ! $this->is_aui_screen() ) {
463
+			if (is_admin() && !$this->is_aui_screen()) {
464 464
 				// Don't add wp-admin scripts if not requested to.
465 465
 			} else {
466 466
 				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
467
-				$rtl = is_rtl() && ! $aui_bs5 ? '-rtl' : '';
467
+				$rtl = is_rtl() && !$aui_bs5 ? '-rtl' : '';
468 468
                 $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
469 469
 
470
-				if ( $this->settings[ $css_setting ] ) {
471
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
472
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets'.$bs_ver.'/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets'.$bs_ver.'/css/ayecode-ui-compatibility'.$rtl.'.css';
470
+				if ($this->settings[$css_setting]) {
471
+					$compatibility = $this->settings[$css_setting] == 'core' ? false : true;
472
+					$url = $this->settings[$css_setting] == 'core' ? $this->url . 'assets' . $bs_ver . '/css/ayecode-ui' . $rtl . '.css' : $this->url . 'assets' . $bs_ver . '/css/ayecode-ui-compatibility' . $rtl . '.css';
473 473
 
474
-					wp_register_style( 'ayecode-ui', $url, array(), $this->version );
475
-					wp_enqueue_style( 'ayecode-ui' );
474
+					wp_register_style('ayecode-ui', $url, array(), $this->version);
475
+					wp_enqueue_style('ayecode-ui');
476 476
 
477
-					if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
478
-						$url = $this->url.'assets'.$bs_ver.'/css/ayecode-ui-fse.css';
479
-						wp_register_style( 'ayecode-ui-fse', $url, array(), $this->version );
480
-						wp_enqueue_style( 'ayecode-ui-fse' );
477
+					if (is_admin() && (!empty($_REQUEST['postType']) || self::is_block_editor()) && (defined('BLOCKSTRAP_VERSION') || defined('AUI_FSE'))) {
478
+						$url = $this->url . 'assets' . $bs_ver . '/css/ayecode-ui-fse.css';
479
+						wp_register_style('ayecode-ui-fse', $url, array(), $this->version);
480
+						wp_enqueue_style('ayecode-ui-fse');
481 481
 						$load_fse = true;
482 482
 					}
483 483
 
484 484
 					// flatpickr
485
-					wp_register_style( 'flatpickr', $this->url.'assets'.$bs_ver.'/css/flatpickr.min.css', array(), $this->version );
485
+					wp_register_style('flatpickr', $this->url . 'assets' . $bs_ver . '/css/flatpickr.min.css', array(), $this->version);
486 486
 
487 487
 					// fix some wp-admin issues
488
-					if(is_admin()){
488
+					if (is_admin()) {
489 489
 						$custom_css = "
490 490
                 body{
491 491
                     background-color: #f1f1f1;
@@ -532,14 +532,14 @@  discard block
 block discarded – undo
532 532
 						    padding: 0;
533 533
 						}
534 534
 					";
535
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
535
+						wp_add_inline_style('ayecode-ui', $custom_css);
536 536
 					}
537 537
 
538 538
 					// custom changes
539
-					if ( $load_fse ) {
540
-						wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
-					}else{
542
-						wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
539
+					if ($load_fse) {
540
+						wp_add_inline_style('ayecode-ui-fse', self::custom_css($compatibility, true));
541
+					} else {
542
+						wp_add_inline_style('ayecode-ui', self::custom_css($compatibility));
543 543
 					}
544 544
 				}
545 545
 			}
@@ -556,10 +556,10 @@  discard block
 block discarded – undo
556 556
 			$flatpickr_locale = self::flatpickr_locale();
557 557
 
558 558
 			ob_start();
559
-			if ( $aui_bs5 ) {
560
-				include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
-			}else{
562
-				include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
559
+			if ($aui_bs5) {
560
+				include_once(dirname(__FILE__) . '/inc/bs5-js.php');
561
+			} else {
562
+				include_once(dirname(__FILE__) . '/inc/bs4-js.php');
563 563
             }
564 564
 
565 565
 			$output = ob_get_clean();
@@ -567,10 +567,10 @@  discard block
 block discarded – undo
567 567
 			/*
568 568
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
569 569
 			 */
570
-			return str_replace( array(
570
+			return str_replace(array(
571 571
 				'<script>',
572 572
 				'</script>'
573
-			), '', self::minify_js($output) );
573
+			), '', self::minify_js($output));
574 574
 		}
575 575
 
576 576
 
@@ -584,13 +584,13 @@  discard block
 block discarded – undo
584 584
 			ob_start();
585 585
 			?>
586 586
             <script>
587
-				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
587
+				<?php if (defined('FUSION_BUILDER_VERSION')) { ?>
588 588
                 /* With Avada builder */
589 589
 
590 590
 				<?php } ?>
591 591
             </script>
592 592
 			<?php
593
-			return str_replace( array(
593
+			return str_replace(array(
594 594
 				'<script>',
595 595
 				'</script>'
596 596
 			), '', ob_get_clean());
@@ -601,7 +601,7 @@  discard block
 block discarded – undo
601 601
 		 *
602 602
 		 * If this remains small then its best to use this than to add another JS file.
603 603
 		 */
604
-		public function inline_script_file_browser(){
604
+		public function inline_script_file_browser() {
605 605
 			ob_start();
606 606
 			?>
607 607
             <script>
@@ -616,17 +616,17 @@  discard block
 block discarded – undo
616 616
 			/*
617 617
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
618 618
 			 */
619
-			return str_replace( array(
619
+			return str_replace(array(
620 620
 				'<script>',
621 621
 				'</script>'
622
-			), '', $output );
622
+			), '', $output);
623 623
 		}
624 624
 
625 625
 		/**
626 626
 		 * Adds the Font Awesome JS.
627 627
 		 */
628 628
 		public function enqueue_scripts() {
629
-			if( is_admin() && !$this->is_aui_screen()){
629
+			if (is_admin() && !$this->is_aui_screen()) {
630 630
 				// Don't add wp-admin scripts if not requested to.
631 631
 			} else {
632 632
 				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
@@ -634,57 +634,57 @@  discard block
 block discarded – undo
634 634
 				$bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
635 635
 
636 636
 				// select2
637
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
637
+				wp_register_script('select2', $this->url . 'assets/js/select2.min.js', array('jquery'), $this->select2_version);
638 638
 
639 639
 				// flatpickr
640
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version );
640
+				wp_register_script('flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version);
641 641
 
642 642
 				// iconpicker
643
-				if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644
-					wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
-				}else{
646
-					wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
643
+				if (defined('FAS_ICONPICKER_JS_URL')) {
644
+					wp_register_script('iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version);
645
+				} else {
646
+					wp_register_script('iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version);
647 647
 				}
648 648
 
649 649
 				// Bootstrap file browser
650
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
651
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
650
+				wp_register_script('aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array('jquery'), $this->select2_version);
651
+				wp_add_inline_script('aui-custom-file-input', $this->inline_script_file_browser());
652 652
 
653 653
 				$load_inline = false;
654 654
 
655 655
 				// Load select2 only when required.
656
-				if ( $this->force_load_select2() ) {
657
-					$dependency = array( 'select2', 'jquery' );
656
+				if ($this->force_load_select2()) {
657
+					$dependency = array('select2', 'jquery');
658 658
 				} else {
659
-					$dependency = array( 'jquery' );
659
+					$dependency = array('jquery');
660 660
 				}
661 661
 
662
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
662
+				if ($this->settings[$js_setting] == 'core-popper') {
663 663
 					// Bootstrap bundle
664 664
 					$url = $this->url . 'assets' . $bs_ver . '/js/bootstrap.bundle.min.js';
665
-					wp_register_script( 'bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat() );
665
+					wp_register_script('bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat());
666 666
 
667 667
 					// If in admin then add to footer for compatibility.
668
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
668
+					is_admin() ? wp_enqueue_script('bootstrap-js-bundle', '', null, null, true) : wp_enqueue_script('bootstrap-js-bundle');
669 669
 
670 670
 					$script = $this->inline_script();
671
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
672
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
671
+					wp_add_inline_script('bootstrap-js-bundle', $script);
672
+				} elseif ($this->settings[$js_setting] == 'popper') {
673 673
 					$url = $this->url . 'assets/js/popper.min.js'; // @todo we need to update this to bs5
674
-					wp_register_script( 'bootstrap-js-popper', $url, $dependency, $this->version );
675
-					wp_enqueue_script( 'bootstrap-js-popper' );
674
+					wp_register_script('bootstrap-js-popper', $url, $dependency, $this->version);
675
+					wp_enqueue_script('bootstrap-js-popper');
676 676
 					$load_inline = true;
677 677
 				} else {
678 678
 					$load_inline = true;
679 679
 				}
680 680
 
681 681
 				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
682
-				if ( $load_inline ) {
683
-					wp_register_script( 'bootstrap-dummy', '', $dependency );
684
-					wp_enqueue_script( 'bootstrap-dummy' );
682
+				if ($load_inline) {
683
+					wp_register_script('bootstrap-dummy', '', $dependency);
684
+					wp_enqueue_script('bootstrap-dummy');
685 685
 
686 686
 					$script = $this->inline_script();
687
-					wp_add_inline_script( 'bootstrap-dummy', $script );
687
+					wp_add_inline_script('bootstrap-dummy', $script);
688 688
 				}
689 689
 			}
690 690
 		}
@@ -697,15 +697,15 @@  discard block
 block discarded – undo
697 697
 		public function force_load_select2() {
698 698
 			global $aui_select2_enqueued;
699 699
 
700
-			$conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
700
+			$conditional_select2 = apply_filters('aui_is_conditional_select2', true);
701 701
 
702
-			if ( $conditional_select2 !== true ) {
702
+			if ($conditional_select2 !== true) {
703 703
 				return true;
704 704
 			}
705 705
 
706
-			$load = is_admin() && ! $aui_select2_enqueued;
706
+			$load = is_admin() && !$aui_select2_enqueued;
707 707
 
708
-			return apply_filters( 'aui_force_load_select2', $load );
708
+			return apply_filters('aui_force_load_select2', $load);
709 709
 		}
710 710
 
711 711
 		/**
@@ -714,23 +714,23 @@  discard block
 block discarded – undo
714 714
 		 * @since 0.2.29
715 715
 		 */
716 716
 		public function enqueue_select2() {
717
-			wp_enqueue_script( 'select2' );
717
+			wp_enqueue_script('select2');
718 718
 		}
719 719
 
720 720
 		/**
721 721
 		 * Enqueue flatpickr if called.
722 722
 		 */
723
-		public function enqueue_flatpickr(){
724
-			wp_enqueue_style( 'flatpickr' );
725
-			wp_enqueue_script( 'flatpickr' );
723
+		public function enqueue_flatpickr() {
724
+			wp_enqueue_style('flatpickr');
725
+			wp_enqueue_script('flatpickr');
726 726
 		}
727 727
 
728 728
 		/**
729 729
 		 * Enqueue iconpicker if called.
730 730
 		 */
731
-		public function enqueue_iconpicker(){
732
-			wp_enqueue_style( 'iconpicker' );
733
-			wp_enqueue_script( 'iconpicker' );
731
+		public function enqueue_iconpicker() {
732
+			wp_enqueue_style('iconpicker');
733
+			wp_enqueue_script('iconpicker');
734 734
 		}
735 735
 
736 736
         /**
@@ -742,17 +742,17 @@  discard block
 block discarded – undo
742 742
          * @return string
743 743
          */
744 744
         public function get_url() {
745
-            $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
746
-            $content_url = untrailingslashit( WP_CONTENT_URL );
745
+            $content_dir = wp_normalize_path(untrailingslashit(WP_CONTENT_DIR));
746
+            $content_url = untrailingslashit(WP_CONTENT_URL);
747 747
 
748 748
             // maybe Replace http:// to https://.
749
-            if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
750
-                $content_url = str_replace( 'http://', 'https://', $content_url );
749
+            if (strpos($content_url, 'http://') === 0 && strpos(plugins_url(), 'https://') === 0) {
750
+                $content_url = str_replace('http://', 'https://', $content_url);
751 751
             }
752 752
 
753 753
             // First find where in the path our content directory starts
754 754
             $content_basename = basename($content_dir);
755
-            $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
755
+            $file_dir = str_replace("/includes", "", wp_normalize_path(dirname(__FILE__)));
756 756
 
757 757
             // Find the relative path by matching from content directory name
758 758
             $after_content = substr($file_dir, strpos($file_dir, '/' . $content_basename . '/') + strlen('/' . $content_basename . '/'));
@@ -761,7 +761,7 @@  discard block
 block discarded – undo
761 761
             $url = trailingslashit($content_url) . $after_content;
762 762
 
763 763
             // some hosts end up with /wp-content/wp-content/
764
-            $url = str_replace( '/wp-content/wp-content/', '/wp-content/', $url );
764
+            $url = str_replace('/wp-content/wp-content/', '/wp-content/', $url);
765 765
 
766 766
             return trailingslashit($url);
767 767
         }
@@ -775,15 +775,15 @@  discard block
 block discarded – undo
775 775
 
776 776
 			$url = '';
777 777
 			// check if we are inside a plugin
778
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
778
+			$file_dir = str_replace("/includes", "", wp_normalize_path(dirname(__FILE__)));
779 779
 
780 780
 			// add check in-case user has changed wp-content dir name.
781 781
 			$wp_content_folder_name = basename(WP_CONTENT_DIR);
782
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
783
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
782
+			$dir_parts = explode("/$wp_content_folder_name/", $file_dir);
783
+			$url_parts = explode("/$wp_content_folder_name/", plugins_url());
784 784
 
785
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
786
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
785
+			if (!empty($url_parts[0]) && !empty($dir_parts[1])) {
786
+				$url = trailingslashit($url_parts[0] . "/$wp_content_folder_name/" . $dir_parts[1]);
787 787
 			}
788 788
 
789 789
 			return $url;
@@ -793,7 +793,7 @@  discard block
 block discarded – undo
793 793
 		 * Register the database settings with WordPress.
794 794
 		 */
795 795
 		public function register_settings() {
796
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
796
+			register_setting('ayecode-ui-settings', 'ayecode-ui-settings');
797 797
 		}
798 798
 
799 799
 		/**
@@ -802,10 +802,10 @@  discard block
 block discarded – undo
802 802
 		 */
803 803
 		public function menu_item() {
804 804
 			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
805
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
805
+			call_user_func($menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
806 806
 				$this,
807 807
 				'settings_page'
808
-			) );
808
+			));
809 809
 		}
810 810
 
811 811
 		/**
@@ -813,7 +813,7 @@  discard block
 block discarded – undo
813 813
 		 *
814 814
 		 * @return array
815 815
 		 */
816
-		public function theme_js_settings(){
816
+		public function theme_js_settings() {
817 817
 			return array(
818 818
 				'ayetheme' => 'popper',
819 819
 				'listimia' => 'required',
@@ -834,7 +834,7 @@  discard block
 block discarded – undo
834 834
 	        $query = "SELECT MIN(user_registered) AS oldest_registration_date FROM {$wpdb->users}";
835 835
 
836 836
 	        // Execute the query
837
-	        $date = $wpdb->get_var( $query ); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
837
+	        $date = $wpdb->get_var($query); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
838 838
 
839 839
 	        return $date ? $date : false;
840 840
         }
@@ -842,11 +842,11 @@  discard block
 block discarded – undo
842 842
 		/**
843 843
 		 * Show admin notice if backend scripts not loaded.
844 844
 		 */
845
-		public function show_admin_version_notice(){
846
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings" );
847
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">View Settings</a>';
848
-			$message = __( '<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)')." " .$button;
849
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
845
+		public function show_admin_version_notice() {
846
+			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings");
847
+			$button = '<a href="' . esc_url($fix_url) . '" class="button-primary">View Settings</a>';
848
+			$message = __('<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)') . " " . $button;
849
+			echo '<div class="notice notice-error aui-settings-error-notice"><p>' . wp_kses_post($message) . '</p></div>';
850 850
 		}
851 851
 
852 852
 		/**
@@ -855,15 +855,15 @@  discard block
 block discarded – undo
855 855
 		 * @return array The array of settings.
856 856
 		 */
857 857
 		public function get_settings() {
858
-			$db_settings = get_option( 'ayecode-ui-settings' );
858
+			$db_settings = get_option('ayecode-ui-settings');
859 859
 
860 860
 			// Maybe show default version notice
861
-			if ( empty( $db_settings ) ) {
862
-				$site_install_date = new DateTime( self::get_site_install_date() );
863
-				$switch_over_date = new DateTime( "2024-02-01" );
861
+			if (empty($db_settings)) {
862
+				$site_install_date = new DateTime(self::get_site_install_date());
863
+				$switch_over_date = new DateTime("2024-02-01");
864 864
 
865
-				if ( $site_install_date < $switch_over_date ) {
866
-					add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
865
+				if ($site_install_date < $switch_over_date) {
866
+					add_action('admin_notices', array($this, 'show_admin_version_notice'));
867 867
 				}
868 868
 			}
869 869
 
@@ -871,19 +871,19 @@  discard block
 block discarded – undo
871 871
 			$js_default_backend = $js_default;
872 872
 
873 873
 			// maybe set defaults (if no settings set)
874
-			if(empty($db_settings)){
875
-				$active_theme = strtolower( get_template() ); // active parent theme.
874
+			if (empty($db_settings)) {
875
+				$active_theme = strtolower(get_template()); // active parent theme.
876 876
 				$theme_js_settings = self::theme_js_settings();
877
-				if(isset($theme_js_settings[$active_theme])){
877
+				if (isset($theme_js_settings[$active_theme])) {
878 878
 					$js_default = $theme_js_settings[$active_theme];
879
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
879
+					$js_default_backend = isset($theme_js_settings[$active_theme . "_backend"]) ? $theme_js_settings[$active_theme . "_backend"] : $js_default;
880 880
 				}
881 881
 			}
882 882
 
883 883
 			/**
884 884
 			 * Filter the default settings.
885 885
 			 */
886
-			$defaults = apply_filters( 'ayecode-ui-default-settings', array(
886
+			$defaults = apply_filters('ayecode-ui-default-settings', array(
887 887
 				'css'            => 'compatibility', // core, compatibility
888 888
 				'js'             => $js_default, // js to load, core-popper, popper
889 889
 				'html_font_size' => '16', // js to load, core-popper, popper
@@ -891,16 +891,16 @@  discard block
 block discarded – undo
891 891
 				'js_backend'     => $js_default_backend, // js to load, core-popper, popper
892 892
 				'disable_admin'  => '', // URL snippets to disable loading on admin
893 893
                 'bs_ver'         => '5', // The default bootstrap version to sue by default
894
-			), $db_settings );
894
+			), $db_settings);
895 895
 
896
-			$settings = wp_parse_args( $db_settings, $defaults );
896
+			$settings = wp_parse_args($db_settings, $defaults);
897 897
 
898 898
 			/**
899 899
 			 * Filter the Bootstrap settings.
900 900
 			 *
901 901
 			 * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
902 902
 			 */
903
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
903
+			return $this->settings = apply_filters('ayecode-ui-settings', $settings, $db_settings, $defaults);
904 904
 		}
905 905
 
906 906
 
@@ -908,109 +908,109 @@  discard block
 block discarded – undo
908 908
 		 * The settings page html output.
909 909
 		 */
910 910
 		public function settings_page() {
911
-			if ( ! current_user_can( 'manage_options' ) ) {
912
-				wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
911
+			if (!current_user_can('manage_options')) {
912
+				wp_die(esc_attr__('You do not have sufficient permissions to access this page.', 'ayecode-connect'));
913 913
 			}
914
-            $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
914
+            $overrides = apply_filters('ayecode-ui-settings', array(), array(), array());
915 915
 
916 916
 			?>
917 917
             <div class="wrap">
918
-                <h1><?php echo esc_attr( $this->name ); ?></h1>
919
-                <p><?php echo esc_html( apply_filters( 'ayecode-ui-settings-message', __("Here you can adjust settings if you are having compatibility issues.", 'ayecode-connect' ) ) );?></p>
918
+                <h1><?php echo esc_attr($this->name); ?></h1>
919
+                <p><?php echo esc_html(apply_filters('ayecode-ui-settings-message', __("Here you can adjust settings if you are having compatibility issues.", 'ayecode-connect'))); ?></p>
920 920
                 <form method="post" action="options.php">
921 921
 					<?php
922
-					settings_fields( 'ayecode-ui-settings' );
923
-					do_settings_sections( 'ayecode-ui-settings' );
922
+					settings_fields('ayecode-ui-settings');
923
+					do_settings_sections('ayecode-ui-settings');
924 924
 					?>
925 925
 
926
-                    <h2><?php esc_html_e( 'BootStrap Version', 'ayecode-connect' ); ?></h2>
927
-                    <p><?php echo esc_html( apply_filters( 'ayecode-ui-version-settings-message', __("V5 is recommended, however if you have another plugin installed using v4, you may need to use v4 also.", 'ayecode-connect' ) ) );?></p>
926
+                    <h2><?php esc_html_e('BootStrap Version', 'ayecode-connect'); ?></h2>
927
+                    <p><?php echo esc_html(apply_filters('ayecode-ui-version-settings-message', __("V5 is recommended, however if you have another plugin installed using v4, you may need to use v4 also.", 'ayecode-connect'))); ?></p>
928 928
 	                <div class="bsui"><?php
929
-	                if ( ! empty( $overrides ) ) {
929
+	                if (!empty($overrides)) {
930 930
 		                echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
931 931
 			                'type'=> 'info',
932
-			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
932
+			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect')
933 933
 		                ));
934 934
 	                }
935 935
 	                ?>
936 936
                     </div>
937 937
                     <table class="form-table wpbs-table-version-settings">
938 938
                         <tr valign="top">
939
-                            <th scope="row"><label for="wpbs-css"><?php esc_html_e( 'Version', 'ayecode-connect' ); ?></label></th>
939
+                            <th scope="row"><label for="wpbs-css"><?php esc_html_e('Version', 'ayecode-connect'); ?></label></th>
940 940
                             <td>
941 941
                                 <select name="ayecode-ui-settings[bs_ver]" id="wpbs-css" <?php echo !empty($overrides['bs_ver']) ? 'disabled' : ''; ?>>
942
-                                    <option	value="5" <?php selected( $this->settings['bs_ver'], '5' ); ?>><?php esc_html_e( 'v5 (recommended)', 'ayecode-connect' ); ?></option>
943
-                                    <option value="4" <?php selected( $this->settings['bs_ver'], '4' ); ?>><?php esc_html_e( 'v4 (legacy)', 'ayecode-connect' ); ?></option>
942
+                                    <option	value="5" <?php selected($this->settings['bs_ver'], '5'); ?>><?php esc_html_e('v5 (recommended)', 'ayecode-connect'); ?></option>
943
+                                    <option value="4" <?php selected($this->settings['bs_ver'], '4'); ?>><?php esc_html_e('v4 (legacy)', 'ayecode-connect'); ?></option>
944 944
                                 </select>
945 945
                             </td>
946 946
                         </tr>
947 947
                     </table>
948 948
 
949
-                    <h2><?php esc_html_e( 'Frontend', 'ayecode-connect' ); ?></h2>
949
+                    <h2><?php esc_html_e('Frontend', 'ayecode-connect'); ?></h2>
950 950
                     <table class="form-table wpbs-table-settings">
951 951
                         <tr valign="top">
952
-                            <th scope="row"><label for="wpbs-css"><?php esc_html_e( 'Load CSS', 'ayecode-connect' ); ?></label></th>
952
+                            <th scope="row"><label for="wpbs-css"><?php esc_html_e('Load CSS', 'ayecode-connect'); ?></label></th>
953 953
                             <td>
954 954
                                 <select name="ayecode-ui-settings[css]" id="wpbs-css" <?php echo !empty($overrides['css']) ? 'disabled' : ''; ?>>
955
-                                    <option	value="compatibility" <?php selected( $this->settings['css'], 'compatibility' ); ?>><?php esc_html_e( 'Compatibility Mode (default)', 'ayecode-connect' ); ?></option>
956
-                                    <option value="core" <?php selected( $this->settings['css'], 'core' ); ?>><?php esc_html_e( 'Full Mode', 'ayecode-connect' ); ?></option>
957
-                                    <option	value="" <?php selected( $this->settings['css'], '' ); ?>><?php esc_html_e( 'Disabled', 'ayecode-connect' ); ?></option>
955
+                                    <option	value="compatibility" <?php selected($this->settings['css'], 'compatibility'); ?>><?php esc_html_e('Compatibility Mode (default)', 'ayecode-connect'); ?></option>
956
+                                    <option value="core" <?php selected($this->settings['css'], 'core'); ?>><?php esc_html_e('Full Mode', 'ayecode-connect'); ?></option>
957
+                                    <option	value="" <?php selected($this->settings['css'], ''); ?>><?php esc_html_e('Disabled', 'ayecode-connect'); ?></option>
958 958
                                 </select>
959 959
                             </td>
960 960
                         </tr>
961 961
 
962 962
                         <tr valign="top">
963
-                            <th scope="row"><label for="wpbs-js"><?php esc_html_e( 'Load JS', 'ayecode-connect' ); ?></label></th>
963
+                            <th scope="row"><label for="wpbs-js"><?php esc_html_e('Load JS', 'ayecode-connect'); ?></label></th>
964 964
                             <td>
965 965
                                 <select name="ayecode-ui-settings[js]" id="wpbs-js" <?php echo !empty($overrides['js']) ? 'disabled' : ''; ?>>
966
-                                    <option	value="core-popper" <?php selected( $this->settings['js'], 'core-popper' ); ?>><?php esc_html_e( 'Core + Popper (default)', 'ayecode-connect' ); ?></option>
967
-                                    <option value="popper" <?php selected( $this->settings['js'], 'popper' ); ?>><?php esc_html_e( 'Popper', 'ayecode-connect' ); ?></option>
968
-                                    <option value="required" <?php selected( $this->settings['js'], 'required' ); ?>><?php esc_html_e( 'Required functions only', 'ayecode-connect' ); ?></option>
969
-                                    <option	value="" <?php selected( $this->settings['js'], '' ); ?>><?php esc_html_e( 'Disabled (not recommended)', 'ayecode-connect' ); ?></option>
966
+                                    <option	value="core-popper" <?php selected($this->settings['js'], 'core-popper'); ?>><?php esc_html_e('Core + Popper (default)', 'ayecode-connect'); ?></option>
967
+                                    <option value="popper" <?php selected($this->settings['js'], 'popper'); ?>><?php esc_html_e('Popper', 'ayecode-connect'); ?></option>
968
+                                    <option value="required" <?php selected($this->settings['js'], 'required'); ?>><?php esc_html_e('Required functions only', 'ayecode-connect'); ?></option>
969
+                                    <option	value="" <?php selected($this->settings['js'], ''); ?>><?php esc_html_e('Disabled (not recommended)', 'ayecode-connect'); ?></option>
970 970
                                 </select>
971 971
                             </td>
972 972
                         </tr>
973 973
 
974 974
                         <tr valign="top">
975
-                            <th scope="row"><label for="wpbs-font_size"><?php esc_html_e( 'HTML Font Size (px)', 'ayecode-connect' ); ?></label></th>
975
+                            <th scope="row"><label for="wpbs-font_size"><?php esc_html_e('HTML Font Size (px)', 'ayecode-connect'); ?></label></th>
976 976
                             <td>
977
-                                <input type="number" name="ayecode-ui-settings[html_font_size]" id="wpbs-font_size" value="<?php echo absint( $this->settings['html_font_size']); ?>" placeholder="16" <?php echo !empty($overrides['html_font_size']) ? 'disabled' : ''; ?> />
978
-                                <p class="description" ><?php esc_html_e("Our font sizing is rem (responsive based) here you can set the html font size in-case your theme is setting it too low.", 'ayecode-connect' );?></p>
977
+                                <input type="number" name="ayecode-ui-settings[html_font_size]" id="wpbs-font_size" value="<?php echo absint($this->settings['html_font_size']); ?>" placeholder="16" <?php echo !empty($overrides['html_font_size']) ? 'disabled' : ''; ?> />
978
+                                <p class="description" ><?php esc_html_e("Our font sizing is rem (responsive based) here you can set the html font size in-case your theme is setting it too low.", 'ayecode-connect'); ?></p>
979 979
                             </td>
980 980
                         </tr>
981 981
 
982 982
                     </table>
983 983
 
984
-                    <h2><?php esc_html_e( 'Backend', 'ayecode-connect' ); ?> (wp-admin)</h2>
984
+                    <h2><?php esc_html_e('Backend', 'ayecode-connect'); ?> (wp-admin)</h2>
985 985
                     <table class="form-table wpbs-table-settings">
986 986
                         <tr valign="top">
987
-                            <th scope="row"><label for="wpbs-css-admin"><?php esc_html_e( 'Load CSS', 'ayecode-connect' ); ?></label></th>
987
+                            <th scope="row"><label for="wpbs-css-admin"><?php esc_html_e('Load CSS', 'ayecode-connect'); ?></label></th>
988 988
                             <td>
989 989
                                 <select name="ayecode-ui-settings[css_backend]" id="wpbs-css-admin" <?php echo !empty($overrides['css_backend']) ? 'disabled' : ''; ?>>
990
-                                    <option	value="compatibility" <?php selected( $this->settings['css_backend'], 'compatibility' ); ?>><?php esc_html_e( 'Compatibility Mode (default)', 'ayecode-connect' ); ?></option>
991
-                                    <option value="core" <?php selected( $this->settings['css_backend'], 'core' ); ?>><?php esc_html_e( 'Full Mode (will cause style issues)', 'ayecode-connect' ); ?></option>
992
-                                    <option	value="" <?php selected( $this->settings['css_backend'], '' ); ?>><?php esc_html_e( 'Disabled', 'ayecode-connect' ); ?></option>
990
+                                    <option	value="compatibility" <?php selected($this->settings['css_backend'], 'compatibility'); ?>><?php esc_html_e('Compatibility Mode (default)', 'ayecode-connect'); ?></option>
991
+                                    <option value="core" <?php selected($this->settings['css_backend'], 'core'); ?>><?php esc_html_e('Full Mode (will cause style issues)', 'ayecode-connect'); ?></option>
992
+                                    <option	value="" <?php selected($this->settings['css_backend'], ''); ?>><?php esc_html_e('Disabled', 'ayecode-connect'); ?></option>
993 993
                                 </select>
994 994
                             </td>
995 995
                         </tr>
996 996
 
997 997
                         <tr valign="top">
998
-                            <th scope="row"><label for="wpbs-js-admin"><?php esc_html_e( 'Load JS', 'ayecode-connect' ); ?></label></th>
998
+                            <th scope="row"><label for="wpbs-js-admin"><?php esc_html_e('Load JS', 'ayecode-connect'); ?></label></th>
999 999
                             <td>
1000 1000
                                 <select name="ayecode-ui-settings[js_backend]" id="wpbs-js-admin" <?php echo !empty($overrides['js_backend']) ? 'disabled' : ''; ?>>
1001
-                                    <option	value="core-popper" <?php selected( $this->settings['js_backend'], 'core-popper' ); ?>><?php esc_html_e( 'Core + Popper (default)', 'ayecode-connect' ); ?></option>
1002
-                                    <option value="popper" <?php selected( $this->settings['js_backend'], 'popper' ); ?>><?php esc_html_e( 'Popper', 'ayecode-connect' ); ?></option>
1003
-                                    <option value="required" <?php selected( $this->settings['js_backend'], 'required' ); ?>><?php esc_html_e( 'Required functions only', 'ayecode-connect' ); ?></option>
1004
-                                    <option	value="" <?php selected( $this->settings['js_backend'], '' ); ?>><?php esc_html_e( 'Disabled (not recommended)', 'ayecode-connect' ); ?></option>
1001
+                                    <option	value="core-popper" <?php selected($this->settings['js_backend'], 'core-popper'); ?>><?php esc_html_e('Core + Popper (default)', 'ayecode-connect'); ?></option>
1002
+                                    <option value="popper" <?php selected($this->settings['js_backend'], 'popper'); ?>><?php esc_html_e('Popper', 'ayecode-connect'); ?></option>
1003
+                                    <option value="required" <?php selected($this->settings['js_backend'], 'required'); ?>><?php esc_html_e('Required functions only', 'ayecode-connect'); ?></option>
1004
+                                    <option	value="" <?php selected($this->settings['js_backend'], ''); ?>><?php esc_html_e('Disabled (not recommended)', 'ayecode-connect'); ?></option>
1005 1005
                                 </select>
1006 1006
                             </td>
1007 1007
                         </tr>
1008 1008
 
1009 1009
                         <tr valign="top">
1010
-                            <th scope="row"><label for="wpbs-disable-admin"><?php esc_html_e( 'Disable load on URL', 'ayecode-connect' ); ?></label></th>
1010
+                            <th scope="row"><label for="wpbs-disable-admin"><?php esc_html_e('Disable load on URL', 'ayecode-connect'); ?></label></th>
1011 1011
                             <td>
1012
-                                <p><?php esc_html_e( 'If you have backend conflict you can enter a partial URL argument that will disable the loading of AUI on those pages. Add each argument on a new line.', 'ayecode-connect' ); ?></p>
1013
-                                <textarea name="ayecode-ui-settings[disable_admin]" rows="10" cols="50" id="wpbs-disable-admin" class="large-text code" spellcheck="false" placeholder="myplugin.php &#10;action=go"><?php echo esc_textarea( $this->settings['disable_admin'] );?></textarea>
1012
+                                <p><?php esc_html_e('If you have backend conflict you can enter a partial URL argument that will disable the loading of AUI on those pages. Add each argument on a new line.', 'ayecode-connect'); ?></p>
1013
+                                <textarea name="ayecode-ui-settings[disable_admin]" rows="10" cols="50" id="wpbs-disable-admin" class="large-text code" spellcheck="false" placeholder="myplugin.php &#10;action=go"><?php echo esc_textarea($this->settings['disable_admin']); ?></textarea>
1014 1014
                             </td>
1015 1015
                         </tr>
1016 1016
                     </table>
@@ -1019,33 +1019,33 @@  discard block
 block discarded – undo
1019 1019
 					submit_button();
1020 1020
 					?>
1021 1021
                 </form>
1022
-                <div id="wpbs-version" data-aui-source="<?php echo esc_attr( $this->get_load_source() ); ?>"><?php echo esc_html( $this->version ); ?></div>
1022
+                <div id="wpbs-version" data-aui-source="<?php echo esc_attr($this->get_load_source()); ?>"><?php echo esc_html($this->version); ?></div>
1023 1023
             </div>
1024 1024
 			<?php
1025 1025
 		}
1026 1026
 
1027
-        public function get_load_source(){
1028
-	        $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1029
-	        $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1027
+        public function get_load_source() {
1028
+	        $file = str_replace(array("/", "\\"), "/", realpath(__FILE__));
1029
+	        $plugins_dir = str_replace(array("/", "\\"), "/", realpath(WP_PLUGIN_DIR));
1030 1030
 
1031 1031
 	        // Find source plugin/theme of SD
1032 1032
 	        $source = array();
1033
-	        if ( strpos( $file, $plugins_dir ) !== false ) {
1034
-		        $source = explode( "/", plugin_basename( $file ) );
1035
-	        } else if ( function_exists( 'get_theme_root' ) ) {
1036
-		        $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1033
+	        if (strpos($file, $plugins_dir) !== false) {
1034
+		        $source = explode("/", plugin_basename($file));
1035
+	        } else if (function_exists('get_theme_root')) {
1036
+		        $themes_dir = str_replace(array("/", "\\"), "/", realpath(get_theme_root()));
1037 1037
 
1038
-		        if ( strpos( $file, $themes_dir ) !== false ) {
1039
-			        $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1038
+		        if (strpos($file, $themes_dir) !== false) {
1039
+			        $source = explode("/", ltrim(str_replace($themes_dir, "", $file), "/"));
1040 1040
 		        }
1041 1041
 	        }
1042 1042
 
1043 1043
             return isset($source[0]) ? esc_attr($source[0]) : '';
1044 1044
         }
1045 1045
 
1046
-		public function customizer_settings($wp_customize){
1046
+		public function customizer_settings($wp_customize) {
1047 1047
 			$wp_customize->add_section('aui_settings', array(
1048
-				'title'    => __('AyeCode UI', 'ayecode-connect' ),
1048
+				'title'    => __('AyeCode UI', 'ayecode-connect'),
1049 1049
 				'priority' => 120,
1050 1050
 			));
1051 1051
 
@@ -1059,8 +1059,8 @@  discard block
 block discarded – undo
1059 1059
 				'type'              => 'option',
1060 1060
 				'transport'         => 'refresh',
1061 1061
 			));
1062
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1063
-				'label'    => __('Primary Color', 'ayecode-connect' ),
1062
+			$wp_customize->add_control(new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1063
+				'label'    => __('Primary Color', 'ayecode-connect'),
1064 1064
 				'section'  => 'aui_settings',
1065 1065
 				'settings' => 'aui_options[color_primary]',
1066 1066
 			)));
@@ -1072,8 +1072,8 @@  discard block
 block discarded – undo
1072 1072
 				'type'              => 'option',
1073 1073
 				'transport'         => 'refresh',
1074 1074
 			));
1075
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1076
-				'label'    => __('Secondary Color', 'ayecode-connect' ),
1075
+			$wp_customize->add_control(new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1076
+				'label'    => __('Secondary Color', 'ayecode-connect'),
1077 1077
 				'section'  => 'aui_settings',
1078 1078
 				'settings' => 'aui_options[color_secondary]',
1079 1079
 			)));
@@ -1099,12 +1099,12 @@  discard block
 block discarded – undo
1099 1099
                 .collapse.show:not(.in){display: inherit;}
1100 1100
                 .fade.show{opacity: 1;}
1101 1101
 
1102
-                <?php if( defined( 'SVQ_THEME_VERSION' ) ){ ?>
1102
+                <?php if (defined('SVQ_THEME_VERSION')) { ?>
1103 1103
                 /* KLEO theme specific */
1104 1104
                 .kleo-main-header .navbar-collapse.collapse.show:not(.in){display: block !important;}
1105 1105
                 <?php } ?>
1106 1106
 
1107
-                <?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1107
+                <?php if (defined('FUSION_BUILDER_VERSION')) { ?>
1108 1108
                 /* With Avada builder */
1109 1109
                 body.modal-open .modal.in  {opacity:1;z-index: 99999}
1110 1110
                 body.modal-open .modal.bsui.in .modal-content  {box-shadow: none;}
@@ -1115,44 +1115,44 @@  discard block
 block discarded – undo
1115 1115
                 <?php } ?>
1116 1116
             </style>
1117 1117
 			<?php
1118
-			return str_replace( array(
1118
+			return str_replace(array(
1119 1119
 				'<style>',
1120 1120
 				'</style>'
1121
-			), '', self::minify_css( ob_get_clean() ) );
1121
+			), '', self::minify_css(ob_get_clean()));
1122 1122
 		}
1123 1123
 
1124
-		public static function custom_css( $compatibility = true, $is_fse = false ) {
1124
+		public static function custom_css($compatibility = true, $is_fse = false) {
1125 1125
 			global $aui_bs5;
1126 1126
 
1127 1127
 			$colors = array();
1128 1128
 
1129
-			if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1129
+			if (defined('BLOCKSTRAP_VERSION')) {
1130 1130
 				$setting = wp_get_global_settings();
1131 1131
 
1132
-				if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1133
-					foreach ( $setting['color']['palette']['theme'] as $color ) {
1134
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1132
+				if (!empty($setting['color']['palette']['theme'])) {
1133
+					foreach ($setting['color']['palette']['theme'] as $color) {
1134
+						$colors[$color['slug']] = esc_attr($color['color']);
1135 1135
 					}
1136 1136
 				}
1137 1137
 
1138
-				if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1139
-					foreach ( $setting['color']['palette']['custom'] as $color ) {
1140
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1138
+				if (!empty($setting['color']['palette']['custom'])) {
1139
+					foreach ($setting['color']['palette']['custom'] as $color) {
1140
+						$colors[$color['slug']] = esc_attr($color['color']);
1141 1141
 					}
1142 1142
 				}
1143 1143
 			} else {
1144
-				$settings = get_option( 'aui_options' );
1144
+				$settings = get_option('aui_options');
1145 1145
 
1146 1146
 				$colors = array(
1147
-					'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1148
-					'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1147
+					'primary'   => !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1148
+					'secondary' => !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1149 1149
 				);
1150 1150
 			}
1151 1151
 
1152 1152
 			ob_start();
1153 1153
 			?><style><?php
1154 1154
 			// BS v3 compat
1155
-			if( self::is_bs3_compat() ){
1155
+			if (self::is_bs3_compat()) {
1156 1156
 				echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1157 1157
 			}
1158 1158
 
@@ -1161,152 +1161,152 @@  discard block
 block discarded – undo
1161 1161
 				//$is_fse = true;
1162 1162
 			//}
1163 1163
 
1164
-			$custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1165
-			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1166
-            $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1164
+			$custom_front = !is_admin() ? true : apply_filters('ayecode_ui_custom_front', false);
1165
+			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false);
1166
+            $bs_custom_css = apply_filters('ayecode_ui_bs_custom_css', $custom_admin || $custom_front);
1167 1167
 			//$bs_custom_css = true; // Force true to fix any color issue.
1168 1168
 
1169 1169
 			$colors_css = '';
1170
-			if ( ! empty( $colors ) && $bs_custom_css ) {
1170
+			if (!empty($colors) && $bs_custom_css) {
1171 1171
 				$d_colors = self::get_colors(true);
1172 1172
 
1173
-				foreach ( $colors as $key => $color ) {
1174
-					if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1173
+				foreach ($colors as $key => $color) {
1174
+					if ((empty($d_colors[$key]) || $d_colors[$key] != $color) || $is_fse) {
1175 1175
 						$var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1176 1176
 						$compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1177 1177
 
1178
-						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1178
+						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5($key, $var, $compat, $color) : self::css_overwrite($key, $var, $compat, $color);
1179 1179
 					}
1180 1180
 				}
1181 1181
 			}
1182 1182
 
1183
-			if ( $colors_css ) {
1183
+			if ($colors_css) {
1184 1184
 				echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1185 1185
 			}
1186 1186
 
1187 1187
 			// Set admin bar z-index lower when modal is open.
1188 1188
 			echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1189 1189
 
1190
-			if ( is_admin() ) {
1190
+			if (is_admin()) {
1191 1191
 				echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1192 1192
 			}
1193 1193
 
1194 1194
 			$custom_css = '';
1195 1195
 
1196
-			if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1196
+			if ($aui_bs5 && defined('BLOCKSTRAP_VERSION') && $bs_custom_css) {
1197 1197
 				$css = '';
1198 1198
 				$theme_settings = wp_get_global_styles();
1199 1199
 
1200 1200
 				// Font face
1201
-				if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1202
-					$t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1201
+				if (!empty($theme_settings['typography']['fontFamily'])) {
1202
+					$t_fontface = str_replace(array('var:preset|', 'font-family|'), array('--wp--preset--', 'font-family--'), $theme_settings['typography']['fontFamily']); //var(--wp--preset--font-family--poppins)
1203 1203
 					$css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1204 1204
 				}
1205 1205
 
1206 1206
 				// font size
1207
-				if( !empty( $theme_settings['typography']['fontSize'] ) ){
1208
-					$css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1207
+				if (!empty($theme_settings['typography']['fontSize'])) {
1208
+					$css .= '--bs-body-font-size: ' . esc_attr($theme_settings['typography']['fontSize']) . ' ;';
1209 1209
 				}
1210 1210
 
1211 1211
 				// line height
1212
-				 if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1213
-					$css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1212
+				 if (!empty($theme_settings['typography']['lineHeight'])) {
1213
+					$css .= '--bs-body-line-height: ' . esc_attr($theme_settings['typography']['lineHeight']) . ';';
1214 1214
 				}
1215 1215
 
1216 1216
 
1217 1217
 				   // font weight
1218
-				 if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1219
-					$css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1218
+				 if (!empty($theme_settings['typography']['fontWeight'])) {
1219
+					$css .= '--bs-body-font-weight: ' . esc_attr($theme_settings['typography']['fontWeight']) . ';';
1220 1220
 				}
1221 1221
 
1222 1222
 				// Background
1223
-				 if( !empty( $theme_settings['color']['background'] ) ){
1224
-					$css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1223
+				 if (!empty($theme_settings['color']['background'])) {
1224
+					$css .= '--bs-body-bg: ' . esc_attr($theme_settings['color']['background']) . ';';
1225 1225
 				}
1226 1226
 
1227 1227
 				 // Background Gradient
1228
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1229
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1228
+				 if (!empty($theme_settings['color']['gradient'])) {
1229
+					$css .= 'background: ' . esc_attr($theme_settings['color']['gradient']) . ';';
1230 1230
 				}
1231 1231
 
1232 1232
 				   // Background Gradient
1233
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1234
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1233
+				 if (!empty($theme_settings['color']['gradient'])) {
1234
+					$css .= 'background: ' . esc_attr($theme_settings['color']['gradient']) . ';';
1235 1235
 				}
1236 1236
 
1237 1237
 				// text color
1238
-				if( !empty( $theme_settings['color']['text'] ) ){
1239
-					$css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1238
+				if (!empty($theme_settings['color']['text'])) {
1239
+					$css .= '--bs-body-color: ' . esc_attr($theme_settings['color']['text']) . ';';
1240 1240
 				}
1241 1241
 
1242 1242
 
1243 1243
 				// link colors
1244
-				if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1245
-					$css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1244
+				if (!empty($theme_settings['elements']['link']['color']['text'])) {
1245
+					$css .= '--bs-link-color: ' . esc_attr($theme_settings['elements']['link']['color']['text']) . ';';
1246 1246
 				}
1247
-				if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1248
-					$css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1247
+				if (!empty($theme_settings['elements']['link'][':hover']['color']['text'])) {
1248
+					$css .= '--bs-link-hover-color: ' . esc_attr($theme_settings['elements']['link'][':hover']['color']['text']) . ';';
1249 1249
 				}
1250 1250
 
1251
-				if($css){
1252
-					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1251
+				if ($css) {
1252
+					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr($css) . '}' : 'body{' . esc_attr($css) . '}';
1253 1253
 				}
1254 1254
 
1255 1255
 				$bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1256 1256
 
1257 1257
 				// Headings
1258 1258
 				$headings_css = '';
1259
-				if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1260
-					$headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1259
+				if (!empty($theme_settings['elements']['heading']['color']['text'])) {
1260
+					$headings_css .= "color: " . esc_attr($theme_settings['elements']['heading']['color']['text']) . ";";
1261 1261
 				}
1262 1262
 
1263 1263
 				// heading background
1264
-				if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1265
-					$headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1264
+				if (!empty($theme_settings['elements']['heading']['color']['background'])) {
1265
+					$headings_css .= 'background: ' . esc_attr($theme_settings['elements']['heading']['color']['background']) . ';';
1266 1266
 				}
1267 1267
 
1268 1268
 				 // heading font family
1269
-				if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1270
-					$headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1269
+				if (!empty($theme_settings['elements']['heading']['typography']['fontFamily'])) {
1270
+					$headings_css .= 'font-family: ' . esc_attr($theme_settings['elements']['heading']['typography']['fontFamily']) . ';';
1271 1271
 				}
1272 1272
 
1273
-				if( $headings_css ){
1274
-					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1273
+				if ($headings_css) {
1274
+					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr($headings_css) . "}";
1275 1275
 				}
1276 1276
 
1277
-				$hs = array('h1','h2','h3','h4','h5','h6');
1277
+				$hs = array('h1', 'h2', 'h3', 'h4', 'h5', 'h6');
1278 1278
 
1279
-				foreach($hs as $hn){
1279
+				foreach ($hs as $hn) {
1280 1280
 					$h_css = '';
1281
-					 if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1282
-						$h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1281
+					 if (!empty($theme_settings['elements'][$hn]['color']['text'])) {
1282
+						$h_css .= 'color: ' . esc_attr($theme_settings['elements'][$hn]['color']['text']) . ';';
1283 1283
 					 }
1284 1284
 
1285
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1286
-						$h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1285
+					  if (!empty($theme_settings['elements'][$hn]['typography']['fontSize'])) {
1286
+						$h_css .= 'font-size: ' . esc_attr($theme_settings['elements'][$hn]['typography']['fontSize']) . ';';
1287 1287
 					 }
1288 1288
 
1289
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1290
-						$h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1289
+					  if (!empty($theme_settings['elements'][$hn]['typography']['fontFamily'])) {
1290
+						$h_css .= 'font-family: ' . esc_attr($theme_settings['elements'][$hn]['typography']['fontFamily']) . ';';
1291 1291
 					 }
1292 1292
 
1293
-					 if($h_css){
1294
-						$custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1293
+					 if ($h_css) {
1294
+						$custom_css .= esc_attr($bep . $hn) . '{' . esc_attr($h_css) . '}';
1295 1295
 					 }
1296 1296
 				}
1297 1297
 			}
1298 1298
 			
1299
-			if ( $custom_css ) {
1299
+			if ($custom_css) {
1300 1300
 				echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1301 1301
 			}
1302 1302
 
1303 1303
 			// Pagination on Hello Elementor theme.
1304
-			if ( function_exists( 'hello_elementor_setup' ) ) {
1304
+			if (function_exists('hello_elementor_setup')) {
1305 1305
 				echo '.aui-nav-links .pagination{justify-content:inherit}';
1306 1306
 			}
1307 1307
 
1308 1308
             // Astra theme - when woocommerce active they add compatibility CSS which breaks select2 in modals
1309
-            if( defined('ASTRA_THEME_VERSION')){
1309
+            if (defined('ASTRA_THEME_VERSION')) {
1310 1310
                 echo '.woocommerce-js.modal-open .select2-container .select2-dropdown, .woocommerce-js.modal-open .select2-container .select2-search__field, .woocommerce-page.modal-open .select2-container .select2-dropdown, .woocommerce-page.modal-open .select2-container .select2-search__field{z-index: 1056;}';
1311 1311
             }
1312 1312
 
@@ -1316,10 +1316,10 @@  discard block
 block discarded – undo
1316 1316
 			/*
1317 1317
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1318 1318
 			 */
1319
-			return str_replace( array(
1319
+			return str_replace(array(
1320 1320
 				'<style>',
1321 1321
 				'</style>'
1322
-			), '', self::minify_css( $custom_css ) );
1322
+			), '', self::minify_css($custom_css));
1323 1323
 		}
1324 1324
 
1325 1325
 		/**
@@ -1327,34 +1327,34 @@  discard block
 block discarded – undo
1327 1327
 		 *
1328 1328
 		 * @return bool
1329 1329
 		 */
1330
-		public static function is_bs3_compat(){
1330
+		public static function is_bs3_compat() {
1331 1331
 			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1332 1332
 		}
1333 1333
 
1334
-		public static function hex_to_rgb( $hex ) {
1334
+		public static function hex_to_rgb($hex) {
1335 1335
 			// Remove '#' if present
1336
-			$hex = str_replace( '#', '', $hex );
1336
+			$hex = str_replace('#', '', $hex);
1337 1337
 
1338 1338
 			// Check if input is RGB
1339
-			if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1340
-				$_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1339
+			if (strpos($hex, 'rgba(') === 0 || strpos($hex, 'rgb(') === 0) {
1340
+				$_rgb = explode(',', str_replace(array('rgba(', 'rgb(', ')'), '', $hex));
1341 1341
 
1342
-				$rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1343
-				$rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1344
-				$rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1342
+				$rgb = (isset($_rgb[0]) ? (int) trim($_rgb[0]) : '0') . ',';
1343
+				$rgb .= (isset($_rgb[1]) ? (int) trim($_rgb[1]) : '0') . ',';
1344
+				$rgb .= (isset($_rgb[2]) ? (int) trim($_rgb[2]) : '0');
1345 1345
 
1346 1346
 				return $rgb;
1347 1347
 			}
1348 1348
 
1349 1349
 			// Convert 3-digit hex to 6-digit hex
1350
-			if ( strlen( $hex ) == 3 ) {
1351
-				$hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1350
+			if (strlen($hex) == 3) {
1351
+				$hex = str_repeat(substr($hex, 0, 1), 2) . str_repeat(substr($hex, 1, 1), 2) . str_repeat(substr($hex, 2, 1), 2);
1352 1352
 			}
1353 1353
 
1354 1354
 			// Convert hex to RGB
1355
-			$r = hexdec( substr( $hex, 0, 2 ) );
1356
-			$g = hexdec( substr( $hex, 2, 2 ) );
1357
-			$b = hexdec( substr( $hex, 4, 2 ) );
1355
+			$r = hexdec(substr($hex, 0, 2));
1356
+			$g = hexdec(substr($hex, 2, 2));
1357
+			$b = hexdec(substr($hex, 4, 2));
1358 1358
 
1359 1359
 			// Return RGB values as an array
1360 1360
 			return $r . ',' . $g . ',' . $b;
@@ -1369,13 +1369,13 @@  discard block
 block discarded – undo
1369 1369
 		 *
1370 1370
 		 * @return string
1371 1371
 		 */
1372
-		public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1372
+		public static function css_overwrite_bs5($type, $color_code, $compatibility, $hex = '') {
1373 1373
 			global $aui_bs5;
1374 1374
 
1375 1375
 			$is_var = false;
1376 1376
 			$is_custom = strpos($type, 'custom-') !== false ? true : false;
1377
-			if(!$color_code){return '';}
1378
-			if(strpos($color_code, 'var') !== false){
1377
+			if (!$color_code) {return ''; }
1378
+			if (strpos($color_code, 'var') !== false) {
1379 1379
 				//if(!sanitize_hex_color($color_code)){
1380 1380
 				$color_code = esc_attr($color_code);
1381 1381
 				$is_var = true;
@@ -1385,15 +1385,15 @@  discard block
 block discarded – undo
1385 1385
 
1386 1386
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1387 1387
 
1388
-			if(!$color_code){return '';}
1388
+			if (!$color_code) {return ''; }
1389 1389
 
1390 1390
 			$rgb = self::hex_to_rgb($hex);
1391 1391
 
1392
-			if($compatibility===true || $compatibility===1){
1392
+			if ($compatibility === true || $compatibility === 1) {
1393 1393
 				$compatibility = '.bsui';
1394
-			}elseif(!$compatibility){
1394
+			}elseif (!$compatibility) {
1395 1395
 				$compatibility = '';
1396
-			}else{
1396
+			} else {
1397 1397
 				$compatibility = esc_attr($compatibility);
1398 1398
 			}
1399 1399
 
@@ -1410,30 +1410,30 @@  discard block
 block discarded – undo
1410 1410
 			 * c = color, b = background color, o = border-color, f = fill
1411 1411
 			 */
1412 1412
 			$selectors = array(
1413
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1414
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1415
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1416
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1417
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1418
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1419
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1420
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1421
-				".badge-{$type}"                                            => array( 'b' ),
1422
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1423
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1424
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1425
-				".text-{$type}"                                     => array( 'c' ),
1413
+				".btn-{$type}"                                              => array('b', 'o'),
1414
+				".btn-{$type}.disabled"                                     => array('b', 'o'),
1415
+				".btn-{$type}:disabled"                                     => array('b', 'o'),
1416
+				".btn-outline-{$type}"                                      => array('c', 'o'),
1417
+				".btn-outline-{$type}:hover"                                => array('b', 'o'),
1418
+				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array('b', 'o'),
1419
+				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array('b', 'o'),
1420
+				".show>.btn-outline-{$type}.dropdown-toggle"                => array('b', 'o'),
1421
+				".badge-{$type}"                                            => array('b'),
1422
+				".alert-{$type}"                                            => array('b', 'o'),
1423
+				".bg-{$type}"                                               => array('b', 'f'),
1424
+				".btn-link.btn-{$type}"                                     => array('c'),
1425
+				".text-{$type}"                                     => array('c'),
1426 1426
 			);
1427 1427
 
1428
-			if ( $aui_bs5 ) {
1429
-				unset($selectors[".alert-{$type}" ]);
1428
+			if ($aui_bs5) {
1429
+				unset($selectors[".alert-{$type}"]);
1430 1430
 			}
1431 1431
 
1432
-			if ( $type == 'primary' ) {
1432
+			if ($type == 'primary') {
1433 1433
 				$selectors = $selectors + array(
1434
-						'a'                                                                                                    => array( 'c' ),
1435
-						'.btn-link'                                                                                            => array( 'c' ),
1436
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1434
+						'a'                                                                                                    => array('c'),
1435
+						'.btn-link'                                                                                            => array('c'),
1436
+						'.dropdown-item.active'                                                                                => array('b'),
1437 1437
 						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1438 1438
 							'b',
1439 1439
 							'o'
@@ -1442,57 +1442,57 @@  discard block
 block discarded – undo
1442 1442
 							'b',
1443 1443
 							'o'
1444 1444
 						),
1445
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1446
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1447
-						'.page-link'                                                                                           => array( 'c' ),
1445
+						'.nav-pills .nav-link.active'                                                                          => array('b'),
1446
+						'.nav-pills .show>.nav-link'                                                                           => array('b'),
1447
+						'.page-link'                                                                                           => array('c'),
1448 1448
 						'.page-item.active .page-link'                                                                         => array(
1449 1449
 							'b',
1450 1450
 							'o'
1451 1451
 						),
1452
-						'.progress-bar'                                                                                        => array( 'b' ),
1452
+						'.progress-bar'                                                                                        => array('b'),
1453 1453
 						'.list-group-item.active'                                                                              => array(
1454 1454
 							'b',
1455 1455
 							'o'
1456 1456
 						),
1457
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1457
+						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1458 1458
 					);
1459 1459
 			}
1460 1460
 
1461 1461
 
1462 1462
 
1463 1463
             // link
1464
-			if ( $type === 'primary' ) {
1465
-				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1466
-				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1467
-				$output .= $prefix . ' .navbar { --bs-nav-link-hover-color: '.esc_attr($color_code).'; --bs-navbar-hover-color: '.esc_attr($color_code).'; --bs-navbar-active-color: '.esc_attr($color_code).'; }';
1464
+			if ($type === 'primary') {
1465
+				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-' . esc_attr($type) . '-rgb), .75); --bs-link-color: var(--bs-' . esc_attr($type) . '); }';
1466
+				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: ' . esc_attr($color_code) . ';  }';
1467
+				$output .= $prefix . ' .navbar { --bs-nav-link-hover-color: ' . esc_attr($color_code) . '; --bs-navbar-hover-color: ' . esc_attr($color_code) . '; --bs-navbar-active-color: ' . esc_attr($color_code) . '; }';
1468 1468
 
1469
-				$output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1470
-				$output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1469
+				$output .= $prefix . ' a{color: var(--bs-' . esc_attr($type) . ');}';
1470
+				$output .= $prefix . ' .text-primary{color: var(--bs-' . esc_attr($type) . ') !important;}';
1471 1471
 
1472 1472
                 // dropdown
1473
-				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1473
+				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-' . esc_attr($type) . '); --bs-dropdown-link-active-color: var(--bs-' . esc_attr($type) . ');}';
1474 1474
 
1475 1475
                 // pagination
1476
-				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1476
+				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-' . esc_attr($type) . '); --bs-pagination-active-bg: var(--bs-' . esc_attr($type) . ');}';
1477 1477
 
1478 1478
 			}
1479 1479
 
1480
-			$output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1481
-			$output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1480
+			$output .= $prefix . ' .link-' . esc_attr($type) . ' {color: var(--bs-' . esc_attr($type) . '-rgb) !important;}';
1481
+			$output .= $prefix . ' .link-' . esc_attr($type) . ':hover {color: rgba(var(--bs-' . esc_attr($type) . '-rgb), .8) !important;}';
1482 1482
 
1483 1483
 			//  buttons
1484
-			$output .= $prefix . ' .btn-'.esc_attr($type).'{';
1484
+			$output .= $prefix . ' .btn-' . esc_attr($type) . '{';
1485 1485
 			$output .= ' 
1486
-            --bs-btn-bg: '.esc_attr($color_code).';
1487
-            --bs-btn-border-color: '.esc_attr($color_code).';
1488
-            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1489
-            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1490
-            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type).'-rgb;
1491
-            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1492
-            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1486
+            --bs-btn-bg: '.esc_attr($color_code) . ';
1487
+            --bs-btn-border-color: '.esc_attr($color_code) . ';
1488
+            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1489
+            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1490
+            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type) . '-rgb;
1491
+            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1492
+            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1493 1493
             --bs-btn-active-shadow: unset;
1494
-            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1495
-            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1494
+            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .5);
1495
+            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .1);
1496 1496
             ';
1497 1497
 //			$output .= '
1498 1498
 //		    --bs-btn-color: #fff;
@@ -1503,18 +1503,18 @@  discard block
 block discarded – undo
1503 1503
 			$output .= '}';
1504 1504
 
1505 1505
 			//  buttons outline
1506
-			$output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1506
+			$output .= $prefix . ' .btn-outline-' . esc_attr($type) . '{';
1507 1507
 			$output .= ' 
1508
-			--bs-btn-color: '.esc_attr($color_code).';
1509
-            --bs-btn-border-color: '.esc_attr($color_code).';
1510
-            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1511
-            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1512
-            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type).'-rgb;
1513
-            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1514
-            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1508
+			--bs-btn-color: '.esc_attr($color_code) . ';
1509
+            --bs-btn-border-color: '.esc_attr($color_code) . ';
1510
+            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1511
+            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1512
+            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type) . '-rgb;
1513
+            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1514
+            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1515 1515
             --bs-btn-active-shadow: unset;
1516
-            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1517
-            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1516
+            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .5);
1517
+            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .1);
1518 1518
             ';
1519 1519
 //			$output .= '
1520 1520
 //		    --bs-btn-color: #fff;
@@ -1526,32 +1526,32 @@  discard block
 block discarded – undo
1526 1526
 
1527 1527
 
1528 1528
             // button hover
1529
-			$output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1529
+			$output .= $prefix . ' .btn-' . esc_attr($type) . ':hover{';
1530 1530
 			$output .= ' 
1531
-            box-shadow: 0 0.25rem 0.25rem 0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb), .1), 0 0.375rem 0.75rem -0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb) , .4);
1531
+            box-shadow: 0 0.25rem 0.25rem 0.125rem rgb(var(--bs-'.esc_attr($type) . '-rgb), .1), 0 0.375rem 0.75rem -0.125rem rgb(var(--bs-' . esc_attr($type) . '-rgb) , .4);
1532 1532
             }
1533 1533
             ';
1534 1534
 
1535 1535
 
1536
-			if ( $aui_bs5 ) {
1536
+			if ($aui_bs5) {
1537 1537
 //				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1538
-				$output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1539
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1538
+				$output .= 'html body {--bs-' . esc_attr($type) . ': ' . esc_attr($color_code) . '; }';
1539
+				$output .= 'html body {--bs-' . esc_attr($type) . '-rgb: ' . $rgb . '; }';
1540 1540
 			}
1541 1541
 
1542 1542
 
1543
-			if ( $is_custom ) {
1543
+			if ($is_custom) {
1544 1544
 
1545 1545
 //				echo '###'.$type;exit;
1546 1546
 
1547 1547
 				// build rules into each type
1548
-				foreach($selectors as $selector => $types){
1549
-					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1550
-					$types = array_combine($types,$types);
1551
-					if(isset($types['c'])){$color[] = $selector;}
1552
-					if(isset($types['b'])){$background[] = $selector;}
1553
-					if(isset($types['o'])){$border[] = $selector;}
1554
-					if(isset($types['f'])){$fill[] = $selector;}
1548
+				foreach ($selectors as $selector => $types) {
1549
+					$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1550
+					$types = array_combine($types, $types);
1551
+					if (isset($types['c'])) {$color[] = $selector; }
1552
+					if (isset($types['b'])) {$background[] = $selector; }
1553
+					if (isset($types['o'])) {$border[] = $selector; }
1554
+					if (isset($types['f'])) {$fill[] = $selector; }
1555 1555
 				}
1556 1556
 
1557 1557
 //				// build rules into each type
@@ -1565,36 +1565,36 @@  discard block
 block discarded – undo
1565 1565
 //				}
1566 1566
 
1567 1567
 				// add any color rules
1568
-				if(!empty($color)){
1569
-					$output .= implode(",",$color) . "{color: $color_code;} ";
1568
+				if (!empty($color)) {
1569
+					$output .= implode(",", $color) . "{color: $color_code;} ";
1570 1570
 				}
1571
-				if(!empty($color_i)){
1572
-					$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1571
+				if (!empty($color_i)) {
1572
+					$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1573 1573
 				}
1574 1574
 
1575 1575
 				// add any background color rules
1576
-				if(!empty($background)){
1577
-					$output .= implode(",",$background) . "{background-color: $color_code;} ";
1576
+				if (!empty($background)) {
1577
+					$output .= implode(",", $background) . "{background-color: $color_code;} ";
1578 1578
 				}
1579
-				if(!empty($background_i)){
1580
-					$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1579
+				if (!empty($background_i)) {
1580
+					$output .= $aui_bs5 ? '' : implode(",", $background_i) . "{background-color: $color_code !important;} ";
1581 1581
 //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1582 1582
 				}
1583 1583
 
1584 1584
 				// add any border color rules
1585
-				if(!empty($border)){
1586
-					$output .= implode(",",$border) . "{border-color: $color_code;} ";
1585
+				if (!empty($border)) {
1586
+					$output .= implode(",", $border) . "{border-color: $color_code;} ";
1587 1587
 				}
1588
-				if(!empty($border_i)){
1589
-					$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1588
+				if (!empty($border_i)) {
1589
+					$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1590 1590
 				}
1591 1591
 
1592 1592
 				// add any fill color rules
1593
-				if(!empty($fill)){
1594
-					$output .= implode(",",$fill) . "{fill: $color_code;} ";
1593
+				if (!empty($fill)) {
1594
+					$output .= implode(",", $fill) . "{fill: $color_code;} ";
1595 1595
 				}
1596
-				if(!empty($fill_i)){
1597
-					$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1596
+				if (!empty($fill_i)) {
1597
+					$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1598 1598
 				}
1599 1599
 
1600 1600
 			}
@@ -1604,26 +1604,26 @@  discard block
 block discarded – undo
1604 1604
 
1605 1605
 			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1606 1606
 			// darken
1607
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1608
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1609
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1610
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1607
+			$darker_075 = $is_var ? $color_code . ';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code, "-0.075");
1608
+			$darker_10 = $is_var ? $color_code . ';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code, "-0.10");
1609
+			$darker_125 = $is_var ? $color_code . ';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code, "-0.125");
1610
+			$darker_40 = $is_var ? $color_code . ';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code, "-0.4");
1611 1611
 
1612 1612
 			// lighten
1613
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1613
+			$lighten_25 = $is_var ? $color_code . ';filter:brightness(1.25)' : self::css_hex_lighten_darken($color_code, "0.25");
1614 1614
 
1615 1615
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1616
-			$op_25 = $color_code."40"; // 25% opacity
1616
+			$op_25 = $color_code . "40"; // 25% opacity
1617 1617
 
1618 1618
 
1619 1619
 			// button states
1620
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1621
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1620
+			$output .= $is_var ? $prefix . " .btn-{$type}{{$transition }} " : '';
1621
+			$output .= $prefix . " .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
1622 1622
 //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1623
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1624
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1625
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1626
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
1623
+			$output .= $prefix . " .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1624
+			$output .= $prefix . " .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: " . $darker_10 . ";    border-color: " . $darker_125 . ";} ";
1625
+            $output .= $prefix . " .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1626
+            $output .= $prefix . " .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
1627 1627
 
1628 1628
 			// text
1629 1629
 //			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
@@ -1641,9 +1641,9 @@  discard block
 block discarded – undo
1641 1641
 //			}
1642 1642
 
1643 1643
 			// alerts
1644
-			if ( $aui_bs5 ) {
1644
+			if ($aui_bs5) {
1645 1645
 //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1646
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1646
+				$output .= $prefix . " .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1647 1647
 			}
1648 1648
 
1649 1649
 			return $output;
@@ -1658,12 +1658,12 @@  discard block
 block discarded – undo
1658 1658
 		 *
1659 1659
 		 * @return string
1660 1660
 		 */
1661
-		public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1661
+		public static function css_overwrite($type, $color_code, $compatibility, $hex = '') {
1662 1662
             global $aui_bs5;
1663 1663
 
1664 1664
 			$is_var = false;
1665
-			if(!$color_code){return '';}
1666
-			if(strpos($color_code, 'var') !== false){
1665
+			if (!$color_code) {return ''; }
1666
+			if (strpos($color_code, 'var') !== false) {
1667 1667
 				//if(!sanitize_hex_color($color_code)){
1668 1668
 				$color_code = esc_attr($color_code);
1669 1669
 				$is_var = true;
@@ -1673,15 +1673,15 @@  discard block
 block discarded – undo
1673 1673
 
1674 1674
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1675 1675
 
1676
-			if(!$color_code){return '';}
1676
+			if (!$color_code) {return ''; }
1677 1677
 
1678 1678
             $rgb = self::hex_to_rgb($hex);
1679 1679
 
1680
-			if($compatibility===true || $compatibility===1){
1680
+			if ($compatibility === true || $compatibility === 1) {
1681 1681
 				$compatibility = '.bsui';
1682
-			}elseif(!$compatibility){
1682
+			}elseif (!$compatibility) {
1683 1683
 				$compatibility = '';
1684
-			}else{
1684
+			} else {
1685 1685
 				$compatibility = esc_attr($compatibility);
1686 1686
 			}
1687 1687
 
@@ -1695,29 +1695,29 @@  discard block
 block discarded – undo
1695 1695
 			 * c = color, b = background color, o = border-color, f = fill
1696 1696
 			 */
1697 1697
 			$selectors = array(
1698
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1699
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1700
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1701
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1702
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1703
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1704
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1705
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1706
-				".badge-{$type}"                                            => array( 'b' ),
1707
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1708
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1709
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1698
+				".btn-{$type}"                                              => array('b', 'o'),
1699
+				".btn-{$type}.disabled"                                     => array('b', 'o'),
1700
+				".btn-{$type}:disabled"                                     => array('b', 'o'),
1701
+				".btn-outline-{$type}"                                      => array('c', 'o'),
1702
+				".btn-outline-{$type}:hover"                                => array('b', 'o'),
1703
+				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array('b', 'o'),
1704
+				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array('b', 'o'),
1705
+				".show>.btn-outline-{$type}.dropdown-toggle"                => array('b', 'o'),
1706
+				".badge-{$type}"                                            => array('b'),
1707
+				".alert-{$type}"                                            => array('b', 'o'),
1708
+				".bg-{$type}"                                               => array('b', 'f'),
1709
+				".btn-link.btn-{$type}"                                     => array('c'),
1710 1710
 			);
1711 1711
 
1712
-			if ( $aui_bs5 ) {
1713
-                unset($selectors[".alert-{$type}" ]);
1712
+			if ($aui_bs5) {
1713
+                unset($selectors[".alert-{$type}"]);
1714 1714
 			}
1715 1715
 
1716
-			if ( $type == 'primary' ) {
1716
+			if ($type == 'primary') {
1717 1717
 				$selectors = $selectors + array(
1718
-						'a'                                                                                                    => array( 'c' ),
1719
-						'.btn-link'                                                                                            => array( 'c' ),
1720
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1718
+						'a'                                                                                                    => array('c'),
1719
+						'.btn-link'                                                                                            => array('c'),
1720
+						'.dropdown-item.active'                                                                                => array('b'),
1721 1721
 						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1722 1722
 							'b',
1723 1723
 							'o'
@@ -1726,19 +1726,19 @@  discard block
 block discarded – undo
1726 1726
 							'b',
1727 1727
 							'o'
1728 1728
 						),
1729
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1730
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1731
-						'.page-link'                                                                                           => array( 'c' ),
1729
+						'.nav-pills .nav-link.active'                                                                          => array('b'),
1730
+						'.nav-pills .show>.nav-link'                                                                           => array('b'),
1731
+						'.page-link'                                                                                           => array('c'),
1732 1732
 						'.page-item.active .page-link'                                                                         => array(
1733 1733
 							'b',
1734 1734
 							'o'
1735 1735
 						),
1736
-						'.progress-bar'                                                                                        => array( 'b' ),
1736
+						'.progress-bar'                                                                                        => array('b'),
1737 1737
 						'.list-group-item.active'                                                                              => array(
1738 1738
 							'b',
1739 1739
 							'o'
1740 1740
 						),
1741
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1741
+						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1742 1742
 //				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1743 1743
 //				    '.custom-range::-moz-range-thumb' => array('b'),
1744 1744
 //				    '.custom-range::-ms-thumb' => array('b'),
@@ -1746,7 +1746,7 @@  discard block
 block discarded – undo
1746 1746
 			}
1747 1747
 
1748 1748
 			$important_selectors = array(
1749
-				".bg-{$type}" => array('b','f'),
1749
+				".bg-{$type}" => array('b', 'f'),
1750 1750
 				".border-{$type}" => array('o'),
1751 1751
 				".text-{$type}" => array('c'),
1752 1752
 			);
@@ -1762,62 +1762,62 @@  discard block
 block discarded – undo
1762 1762
 
1763 1763
 			$output = '';
1764 1764
 
1765
-			if ( $aui_bs5 ) {
1765
+			if ($aui_bs5) {
1766 1766
 //				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1767
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1767
+				$output .= 'html body {--bs-' . esc_attr($type) . '-rgb: ' . $rgb . '; }';
1768 1768
 			}
1769 1769
 
1770 1770
 			// build rules into each type
1771
-			foreach($selectors as $selector => $types){
1772
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1773
-				$types = array_combine($types,$types);
1774
-				if(isset($types['c'])){$color[] = $selector;}
1775
-				if(isset($types['b'])){$background[] = $selector;}
1776
-				if(isset($types['o'])){$border[] = $selector;}
1777
-				if(isset($types['f'])){$fill[] = $selector;}
1771
+			foreach ($selectors as $selector => $types) {
1772
+				$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1773
+				$types = array_combine($types, $types);
1774
+				if (isset($types['c'])) {$color[] = $selector; }
1775
+				if (isset($types['b'])) {$background[] = $selector; }
1776
+				if (isset($types['o'])) {$border[] = $selector; }
1777
+				if (isset($types['f'])) {$fill[] = $selector; }
1778 1778
 			}
1779 1779
 
1780 1780
 			// build rules into each type
1781
-			foreach($important_selectors as $selector => $types){
1782
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1783
-				$types = array_combine($types,$types);
1784
-				if(isset($types['c'])){$color_i[] = $selector;}
1785
-				if(isset($types['b'])){$background_i[] = $selector;}
1786
-				if(isset($types['o'])){$border_i[] = $selector;}
1787
-				if(isset($types['f'])){$fill_i[] = $selector;}
1781
+			foreach ($important_selectors as $selector => $types) {
1782
+				$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1783
+				$types = array_combine($types, $types);
1784
+				if (isset($types['c'])) {$color_i[] = $selector; }
1785
+				if (isset($types['b'])) {$background_i[] = $selector; }
1786
+				if (isset($types['o'])) {$border_i[] = $selector; }
1787
+				if (isset($types['f'])) {$fill_i[] = $selector; }
1788 1788
 			}
1789 1789
 
1790 1790
 			// add any color rules
1791
-			if(!empty($color)){
1792
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1791
+			if (!empty($color)) {
1792
+				$output .= implode(",", $color) . "{color: $color_code;} ";
1793 1793
 			}
1794
-			if(!empty($color_i)){
1795
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1794
+			if (!empty($color_i)) {
1795
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1796 1796
 			}
1797 1797
 
1798 1798
 			// add any background color rules
1799
-			if(!empty($background)){
1800
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1799
+			if (!empty($background)) {
1800
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
1801 1801
 			}
1802
-			if(!empty($background_i)){
1803
-				$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1802
+			if (!empty($background_i)) {
1803
+				$output .= $aui_bs5 ? '' : implode(",", $background_i) . "{background-color: $color_code !important;} ";
1804 1804
 //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1805 1805
 			}
1806 1806
 
1807 1807
 			// add any border color rules
1808
-			if(!empty($border)){
1809
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1808
+			if (!empty($border)) {
1809
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
1810 1810
 			}
1811
-			if(!empty($border_i)){
1812
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1811
+			if (!empty($border_i)) {
1812
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1813 1813
 			}
1814 1814
 
1815 1815
 			// add any fill color rules
1816
-			if(!empty($fill)){
1817
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1816
+			if (!empty($fill)) {
1817
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
1818 1818
 			}
1819
-			if(!empty($fill_i)){
1820
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1819
+			if (!empty($fill_i)) {
1820
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1821 1821
 			}
1822 1822
 
1823 1823
 
@@ -1825,27 +1825,27 @@  discard block
 block discarded – undo
1825 1825
 
1826 1826
 			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1827 1827
 			// darken
1828
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1829
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1830
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1831
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1828
+			$darker_075 = $is_var ? $color_code . ';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code, "-0.075");
1829
+			$darker_10 = $is_var ? $color_code . ';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code, "-0.10");
1830
+			$darker_125 = $is_var ? $color_code . ';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code, "-0.125");
1831
+			$darker_40 = $is_var ? $color_code . ';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code, "-0.4");
1832 1832
 
1833 1833
 			// lighten
1834
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1834
+			$lighten_25 = $is_var ? $color_code . ';filter:brightness(1.25)' : self::css_hex_lighten_darken($color_code, "0.25");
1835 1835
 
1836 1836
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1837
-			$op_25 = $color_code."40"; // 25% opacity
1837
+			$op_25 = $color_code . "40"; // 25% opacity
1838 1838
 
1839 1839
 
1840 1840
 			// button states
1841
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1842
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1841
+			$output .= $is_var ? $prefix . " .btn-{$type}{{$transition }} " : '';
1842
+			$output .= $prefix . " .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
1843 1843
 //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1844
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1845
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1846
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1844
+			$output .= $prefix . " .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1845
+			$output .= $prefix . " .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: " . $darker_10 . ";    border-color: " . $darker_125 . ";} ";
1846
+			$output .= $prefix . " .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1847 1847
 
1848
-			if ( $type == 'primary' ) {
1848
+			if ($type == 'primary') {
1849 1849
 				// dropdown's
1850 1850
 				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1851 1851
 
@@ -1857,9 +1857,9 @@  discard block
 block discarded – undo
1857 1857
 			}
1858 1858
 
1859 1859
             // alerts
1860
-			if ( $aui_bs5 ) {
1860
+			if ($aui_bs5) {
1861 1861
 //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1862
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1862
+				$output .= $prefix . " .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1863 1863
 			}
1864 1864
 
1865 1865
 			return $output;
@@ -1875,11 +1875,11 @@  discard block
 block discarded – undo
1875 1875
 		 *
1876 1876
 		 * @return string
1877 1877
 		 */
1878
-		public static function css_primary($color_code,$compatibility, $use_variable = false){
1878
+		public static function css_primary($color_code, $compatibility, $use_variable = false) {
1879 1879
 
1880
-			if(!$use_variable){
1880
+			if (!$use_variable) {
1881 1881
 				$color_code = sanitize_hex_color($color_code);
1882
-				if(!$color_code){return '';}
1882
+				if (!$color_code) {return ''; }
1883 1883
 			}
1884 1884
 
1885 1885
 			/**
@@ -1887,36 +1887,36 @@  discard block
 block discarded – undo
1887 1887
 			 */
1888 1888
 			$selectors = array(
1889 1889
 				'a' => array('c'),
1890
-				'.btn-primary' => array('b','o'),
1891
-				'.btn-primary.disabled' => array('b','o'),
1892
-				'.btn-primary:disabled' => array('b','o'),
1893
-				'.btn-outline-primary' => array('c','o'),
1894
-				'.btn-outline-primary:hover' => array('b','o'),
1895
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1896
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1897
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1890
+				'.btn-primary' => array('b', 'o'),
1891
+				'.btn-primary.disabled' => array('b', 'o'),
1892
+				'.btn-primary:disabled' => array('b', 'o'),
1893
+				'.btn-outline-primary' => array('c', 'o'),
1894
+				'.btn-outline-primary:hover' => array('b', 'o'),
1895
+				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b', 'o'),
1896
+				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b', 'o'),
1897
+				'.show>.btn-outline-primary.dropdown-toggle' => array('b', 'o'),
1898 1898
 				'.btn-link' => array('c'),
1899 1899
 				'.dropdown-item.active' => array('b'),
1900
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1901
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1900
+				'.custom-control-input:checked~.custom-control-label::before' => array('b', 'o'),
1901
+				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b', 'o'),
1902 1902
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1903 1903
 //				'.custom-range::-moz-range-thumb' => array('b'),
1904 1904
 //				'.custom-range::-ms-thumb' => array('b'),
1905 1905
 				'.nav-pills .nav-link.active' => array('b'),
1906 1906
 				'.nav-pills .show>.nav-link' => array('b'),
1907 1907
 				'.page-link' => array('c'),
1908
-				'.page-item.active .page-link' => array('b','o'),
1908
+				'.page-item.active .page-link' => array('b', 'o'),
1909 1909
 				'.badge-primary' => array('b'),
1910
-				'.alert-primary' => array('b','o'),
1910
+				'.alert-primary' => array('b', 'o'),
1911 1911
 				'.progress-bar' => array('b'),
1912
-				'.list-group-item.active' => array('b','o'),
1913
-				'.bg-primary' => array('b','f'),
1912
+				'.list-group-item.active' => array('b', 'o'),
1913
+				'.bg-primary' => array('b', 'f'),
1914 1914
 				'.btn-link.btn-primary' => array('c'),
1915 1915
 				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1916 1916
 			);
1917 1917
 
1918 1918
 			$important_selectors = array(
1919
-				'.bg-primary' => array('b','f'),
1919
+				'.bg-primary' => array('b', 'f'),
1920 1920
 				'.border-primary' => array('o'),
1921 1921
 				'.text-primary' => array('c'),
1922 1922
 			);
@@ -1933,88 +1933,88 @@  discard block
 block discarded – undo
1933 1933
 			$output = '';
1934 1934
 
1935 1935
 			// build rules into each type
1936
-			foreach($selectors as $selector => $types){
1937
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1938
-				$types = array_combine($types,$types);
1939
-				if(isset($types['c'])){$color[] = $selector;}
1940
-				if(isset($types['b'])){$background[] = $selector;}
1941
-				if(isset($types['o'])){$border[] = $selector;}
1942
-				if(isset($types['f'])){$fill[] = $selector;}
1936
+			foreach ($selectors as $selector => $types) {
1937
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
1938
+				$types = array_combine($types, $types);
1939
+				if (isset($types['c'])) {$color[] = $selector; }
1940
+				if (isset($types['b'])) {$background[] = $selector; }
1941
+				if (isset($types['o'])) {$border[] = $selector; }
1942
+				if (isset($types['f'])) {$fill[] = $selector; }
1943 1943
 			}
1944 1944
 
1945 1945
 			// build rules into each type
1946
-			foreach($important_selectors as $selector => $types){
1947
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1948
-				$types = array_combine($types,$types);
1949
-				if(isset($types['c'])){$color_i[] = $selector;}
1950
-				if(isset($types['b'])){$background_i[] = $selector;}
1951
-				if(isset($types['o'])){$border_i[] = $selector;}
1952
-				if(isset($types['f'])){$fill_i[] = $selector;}
1946
+			foreach ($important_selectors as $selector => $types) {
1947
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
1948
+				$types = array_combine($types, $types);
1949
+				if (isset($types['c'])) {$color_i[] = $selector; }
1950
+				if (isset($types['b'])) {$background_i[] = $selector; }
1951
+				if (isset($types['o'])) {$border_i[] = $selector; }
1952
+				if (isset($types['f'])) {$fill_i[] = $selector; }
1953 1953
 			}
1954 1954
 
1955 1955
 			// add any color rules
1956
-			if(!empty($color)){
1957
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1956
+			if (!empty($color)) {
1957
+				$output .= implode(",", $color) . "{color: $color_code;} ";
1958 1958
 			}
1959
-			if(!empty($color_i)){
1960
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1959
+			if (!empty($color_i)) {
1960
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1961 1961
 			}
1962 1962
 
1963 1963
 			// add any background color rules
1964
-			if(!empty($background)){
1965
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1964
+			if (!empty($background)) {
1965
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
1966 1966
 			}
1967
-			if(!empty($background_i)){
1968
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1967
+			if (!empty($background_i)) {
1968
+				$output .= implode(",", $background_i) . "{background-color: $color_code !important;} ";
1969 1969
 			}
1970 1970
 
1971 1971
 			// add any border color rules
1972
-			if(!empty($border)){
1973
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1972
+			if (!empty($border)) {
1973
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
1974 1974
 			}
1975
-			if(!empty($border_i)){
1976
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1975
+			if (!empty($border_i)) {
1976
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1977 1977
 			}
1978 1978
 
1979 1979
 			// add any fill color rules
1980
-			if(!empty($fill)){
1981
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1980
+			if (!empty($fill)) {
1981
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
1982 1982
 			}
1983
-			if(!empty($fill_i)){
1984
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1983
+			if (!empty($fill_i)) {
1984
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1985 1985
 			}
1986 1986
 
1987 1987
 
1988 1988
 			$prefix = $compatibility ? ".bsui " : "";
1989 1989
 
1990 1990
 			// darken
1991
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1992
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1993
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1991
+			$darker_075 = self::css_hex_lighten_darken($color_code, "-0.075");
1992
+			$darker_10 = self::css_hex_lighten_darken($color_code, "-0.10");
1993
+			$darker_125 = self::css_hex_lighten_darken($color_code, "-0.125");
1994 1994
 
1995 1995
 			// lighten
1996
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1996
+			$lighten_25 = self::css_hex_lighten_darken($color_code, "0.25");
1997 1997
 
1998 1998
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1999
-			$op_25 = $color_code."40"; // 25% opacity
1999
+			$op_25 = $color_code . "40"; // 25% opacity
2000 2000
 
2001 2001
 
2002 2002
 			// button states
2003
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2004
-			$output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2005
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2006
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2003
+			$output .= $prefix . " .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
2004
+			$output .= $prefix . " .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2005
+			$output .= $prefix . " .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: " . $darker_10 . ";    border-color: " . $darker_125 . ";} ";
2006
+			$output .= $prefix . " .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2007 2007
 
2008 2008
 
2009 2009
 			// dropdown's
2010
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2010
+			$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2011 2011
 
2012 2012
 
2013 2013
 			// input states
2014
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2014
+			$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
2015 2015
 
2016 2016
 			// page link
2017
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2017
+			$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2018 2018
 
2019 2019
 			return $output;
2020 2020
 		}
@@ -2028,30 +2028,30 @@  discard block
 block discarded – undo
2028 2028
 		 *
2029 2029
 		 * @return string
2030 2030
 		 */
2031
-		public static function css_secondary($color_code,$compatibility){;
2031
+		public static function css_secondary($color_code, $compatibility) {;
2032 2032
 			$color_code = sanitize_hex_color($color_code);
2033
-			if(!$color_code){return '';}
2033
+			if (!$color_code) {return ''; }
2034 2034
 			/**
2035 2035
 			 * c = color, b = background color, o = border-color, f = fill
2036 2036
 			 */
2037 2037
 			$selectors = array(
2038
-				'.btn-secondary' => array('b','o'),
2039
-				'.btn-secondary.disabled' => array('b','o'),
2040
-				'.btn-secondary:disabled' => array('b','o'),
2041
-				'.btn-outline-secondary' => array('c','o'),
2042
-				'.btn-outline-secondary:hover' => array('b','o'),
2038
+				'.btn-secondary' => array('b', 'o'),
2039
+				'.btn-secondary.disabled' => array('b', 'o'),
2040
+				'.btn-secondary:disabled' => array('b', 'o'),
2041
+				'.btn-outline-secondary' => array('c', 'o'),
2042
+				'.btn-outline-secondary:hover' => array('b', 'o'),
2043 2043
 				'.btn-outline-secondary.disabled' => array('c'),
2044 2044
 				'.btn-outline-secondary:disabled' => array('c'),
2045
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2046
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2047
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2045
+				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b', 'o'),
2046
+				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b', 'o'),
2047
+				'.btn-outline-secondary.dropdown-toggle' => array('b', 'o'),
2048 2048
 				'.badge-secondary' => array('b'),
2049
-				'.alert-secondary' => array('b','o'),
2049
+				'.alert-secondary' => array('b', 'o'),
2050 2050
 				'.btn-link.btn-secondary' => array('c'),
2051 2051
 			);
2052 2052
 
2053 2053
 			$important_selectors = array(
2054
-				'.bg-secondary' => array('b','f'),
2054
+				'.bg-secondary' => array('b', 'f'),
2055 2055
 				'.border-secondary' => array('o'),
2056 2056
 				'.text-secondary' => array('c'),
2057 2057
 			);
@@ -2068,77 +2068,77 @@  discard block
 block discarded – undo
2068 2068
 			$output = '';
2069 2069
 
2070 2070
 			// build rules into each type
2071
-			foreach($selectors as $selector => $types){
2072
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2073
-				$types = array_combine($types,$types);
2074
-				if(isset($types['c'])){$color[] = $selector;}
2075
-				if(isset($types['b'])){$background[] = $selector;}
2076
-				if(isset($types['o'])){$border[] = $selector;}
2077
-				if(isset($types['f'])){$fill[] = $selector;}
2071
+			foreach ($selectors as $selector => $types) {
2072
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
2073
+				$types = array_combine($types, $types);
2074
+				if (isset($types['c'])) {$color[] = $selector; }
2075
+				if (isset($types['b'])) {$background[] = $selector; }
2076
+				if (isset($types['o'])) {$border[] = $selector; }
2077
+				if (isset($types['f'])) {$fill[] = $selector; }
2078 2078
 			}
2079 2079
 
2080 2080
 			// build rules into each type
2081
-			foreach($important_selectors as $selector => $types){
2082
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2083
-				$types = array_combine($types,$types);
2084
-				if(isset($types['c'])){$color_i[] = $selector;}
2085
-				if(isset($types['b'])){$background_i[] = $selector;}
2086
-				if(isset($types['o'])){$border_i[] = $selector;}
2087
-				if(isset($types['f'])){$fill_i[] = $selector;}
2081
+			foreach ($important_selectors as $selector => $types) {
2082
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
2083
+				$types = array_combine($types, $types);
2084
+				if (isset($types['c'])) {$color_i[] = $selector; }
2085
+				if (isset($types['b'])) {$background_i[] = $selector; }
2086
+				if (isset($types['o'])) {$border_i[] = $selector; }
2087
+				if (isset($types['f'])) {$fill_i[] = $selector; }
2088 2088
 			}
2089 2089
 
2090 2090
 			// add any color rules
2091
-			if(!empty($color)){
2092
-				$output .= implode(",",$color) . "{color: $color_code;} ";
2091
+			if (!empty($color)) {
2092
+				$output .= implode(",", $color) . "{color: $color_code;} ";
2093 2093
 			}
2094
-			if(!empty($color_i)){
2095
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2094
+			if (!empty($color_i)) {
2095
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
2096 2096
 			}
2097 2097
 
2098 2098
 			// add any background color rules
2099
-			if(!empty($background)){
2100
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
2099
+			if (!empty($background)) {
2100
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
2101 2101
 			}
2102
-			if(!empty($background_i)){
2103
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2102
+			if (!empty($background_i)) {
2103
+				$output .= implode(",", $background_i) . "{background-color: $color_code !important;} ";
2104 2104
 			}
2105 2105
 
2106 2106
 			// add any border color rules
2107
-			if(!empty($border)){
2108
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
2107
+			if (!empty($border)) {
2108
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
2109 2109
 			}
2110
-			if(!empty($border_i)){
2111
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2110
+			if (!empty($border_i)) {
2111
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
2112 2112
 			}
2113 2113
 
2114 2114
 			// add any fill color rules
2115
-			if(!empty($fill)){
2116
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
2115
+			if (!empty($fill)) {
2116
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
2117 2117
 			}
2118
-			if(!empty($fill_i)){
2119
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2118
+			if (!empty($fill_i)) {
2119
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
2120 2120
 			}
2121 2121
 
2122 2122
 
2123 2123
 			$prefix = $compatibility ? ".bsui " : "";
2124 2124
 
2125 2125
 			// darken
2126
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2127
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2128
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2126
+			$darker_075 = self::css_hex_lighten_darken($color_code, "-0.075");
2127
+			$darker_10 = self::css_hex_lighten_darken($color_code, "-0.10");
2128
+			$darker_125 = self::css_hex_lighten_darken($color_code, "-0.125");
2129 2129
 
2130 2130
 			// lighten
2131
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2131
+			$lighten_25 = self::css_hex_lighten_darken($color_code, "0.25");
2132 2132
 
2133 2133
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
2134
-			$op_25 = $color_code."40"; // 25% opacity
2134
+			$op_25 = $color_code . "40"; // 25% opacity
2135 2135
 
2136 2136
 
2137 2137
 			// button states
2138
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2139
-			$output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2140
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2141
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2138
+			$output .= $prefix . " .btn-secondary:hover{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
2139
+			$output .= $prefix . " .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2140
+			$output .= $prefix . " .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: " . $darker_10 . ";    border-color: " . $darker_125 . ";} ";
2141
+			$output .= $prefix . " .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2142 2142
 
2143 2143
 
2144 2144
 			return $output;
@@ -2155,7 +2155,7 @@  discard block
 block discarded – undo
2155 2155
 		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2156 2156
 			$hexCode = ltrim($hexCode, '#');
2157 2157
 
2158
-			if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2158
+			if (strpos($hexCode, 'rgba(') !== false || strpos($hexCode, 'rgb(') !== false) {
2159 2159
 				return $hexCode;
2160 2160
 			}
2161 2161
 
@@ -2178,8 +2178,8 @@  discard block
 block discarded – undo
2178 2178
 		/**
2179 2179
 		 * Check if we should display examples.
2180 2180
 		 */
2181
-		public function maybe_show_examples(){
2182
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2181
+		public function maybe_show_examples() {
2182
+			if (current_user_can('manage_options') && isset($_REQUEST['preview-aui'])) {
2183 2183
 				echo "<head>";
2184 2184
 				wp_head();
2185 2185
 				echo "</head>";
@@ -2195,7 +2195,7 @@  discard block
 block discarded – undo
2195 2195
 		 *
2196 2196
 		 * @return string
2197 2197
 		 */
2198
-		public function get_examples(){
2198
+		public function get_examples() {
2199 2199
 			$output = '';
2200 2200
 
2201 2201
 
@@ -2301,74 +2301,74 @@  discard block
 block discarded – undo
2301 2301
 		 */
2302 2302
 		public static function calendar_params() {
2303 2303
 			$params = array(
2304
-				'month_long_1' => __( 'January', 'ayecode-connect' ),
2305
-				'month_long_2' => __( 'February', 'ayecode-connect' ),
2306
-				'month_long_3' => __( 'March', 'ayecode-connect' ),
2307
-				'month_long_4' => __( 'April', 'ayecode-connect' ),
2308
-				'month_long_5' => __( 'May', 'ayecode-connect' ),
2309
-				'month_long_6' => __( 'June', 'ayecode-connect' ),
2310
-				'month_long_7' => __( 'July', 'ayecode-connect' ),
2311
-				'month_long_8' => __( 'August', 'ayecode-connect' ),
2312
-				'month_long_9' => __( 'September', 'ayecode-connect' ),
2313
-				'month_long_10' => __( 'October', 'ayecode-connect' ),
2314
-				'month_long_11' => __( 'November', 'ayecode-connect' ),
2315
-				'month_long_12' => __( 'December', 'ayecode-connect' ),
2316
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2317
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2318
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2319
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2320
-				'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2321
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2322
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2323
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2324
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2325
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2326
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2327
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2328
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2329
-				'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2330
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2331
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2332
-				'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2333
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2334
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2335
-				'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2336
-				'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2337
-				'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2338
-				'day_s2_4' => __( 'We', 'ayecode-connect' ),
2339
-				'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2340
-				'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2341
-				'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2342
-				'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2343
-				'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2344
-				'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2345
-				'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2346
-				'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2347
-				'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2348
-				'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2349
-				'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2350
-				'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2351
-				'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2352
-				'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2353
-				'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2354
-				'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2355
-				'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2356
-				'am_lower' => __( 'am', 'ayecode-connect' ),
2357
-				'pm_lower' => __( 'pm', 'ayecode-connect' ),
2358
-				'am_upper' => __( 'AM', 'ayecode-connect' ),
2359
-				'pm_upper' => __( 'PM', 'ayecode-connect' ),
2360
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2304
+				'month_long_1' => __('January', 'ayecode-connect'),
2305
+				'month_long_2' => __('February', 'ayecode-connect'),
2306
+				'month_long_3' => __('March', 'ayecode-connect'),
2307
+				'month_long_4' => __('April', 'ayecode-connect'),
2308
+				'month_long_5' => __('May', 'ayecode-connect'),
2309
+				'month_long_6' => __('June', 'ayecode-connect'),
2310
+				'month_long_7' => __('July', 'ayecode-connect'),
2311
+				'month_long_8' => __('August', 'ayecode-connect'),
2312
+				'month_long_9' => __('September', 'ayecode-connect'),
2313
+				'month_long_10' => __('October', 'ayecode-connect'),
2314
+				'month_long_11' => __('November', 'ayecode-connect'),
2315
+				'month_long_12' => __('December', 'ayecode-connect'),
2316
+				'month_s_1' => _x('Jan', 'January abbreviation', 'ayecode-connect'),
2317
+				'month_s_2' => _x('Feb', 'February abbreviation', 'ayecode-connect'),
2318
+				'month_s_3' => _x('Mar', 'March abbreviation', 'ayecode-connect'),
2319
+				'month_s_4' => _x('Apr', 'April abbreviation', 'ayecode-connect'),
2320
+				'month_s_5' => _x('May', 'May abbreviation', 'ayecode-connect'),
2321
+				'month_s_6' => _x('Jun', 'June abbreviation', 'ayecode-connect'),
2322
+				'month_s_7' => _x('Jul', 'July abbreviation', 'ayecode-connect'),
2323
+				'month_s_8' => _x('Aug', 'August abbreviation', 'ayecode-connect'),
2324
+				'month_s_9' => _x('Sep', 'September abbreviation', 'ayecode-connect'),
2325
+				'month_s_10' => _x('Oct', 'October abbreviation', 'ayecode-connect'),
2326
+				'month_s_11' => _x('Nov', 'November abbreviation', 'ayecode-connect'),
2327
+				'month_s_12' => _x('Dec', 'December abbreviation', 'ayecode-connect'),
2328
+				'day_s1_1' => _x('S', 'Sunday initial', 'ayecode-connect'),
2329
+				'day_s1_2' => _x('M', 'Monday initial', 'ayecode-connect'),
2330
+				'day_s1_3' => _x('T', 'Tuesday initial', 'ayecode-connect'),
2331
+				'day_s1_4' => _x('W', 'Wednesday initial', 'ayecode-connect'),
2332
+				'day_s1_5' => _x('T', 'Friday initial', 'ayecode-connect'),
2333
+				'day_s1_6' => _x('F', 'Thursday initial', 'ayecode-connect'),
2334
+				'day_s1_7' => _x('S', 'Saturday initial', 'ayecode-connect'),
2335
+				'day_s2_1' => __('Su', 'ayecode-connect'),
2336
+				'day_s2_2' => __('Mo', 'ayecode-connect'),
2337
+				'day_s2_3' => __('Tu', 'ayecode-connect'),
2338
+				'day_s2_4' => __('We', 'ayecode-connect'),
2339
+				'day_s2_5' => __('Th', 'ayecode-connect'),
2340
+				'day_s2_6' => __('Fr', 'ayecode-connect'),
2341
+				'day_s2_7' => __('Sa', 'ayecode-connect'),
2342
+				'day_s3_1' => __('Sun', 'ayecode-connect'),
2343
+				'day_s3_2' => __('Mon', 'ayecode-connect'),
2344
+				'day_s3_3' => __('Tue', 'ayecode-connect'),
2345
+				'day_s3_4' => __('Wed', 'ayecode-connect'),
2346
+				'day_s3_5' => __('Thu', 'ayecode-connect'),
2347
+				'day_s3_6' => __('Fri', 'ayecode-connect'),
2348
+				'day_s3_7' => __('Sat', 'ayecode-connect'),
2349
+				'day_s5_1' => __('Sunday', 'ayecode-connect'),
2350
+				'day_s5_2' => __('Monday', 'ayecode-connect'),
2351
+				'day_s5_3' => __('Tuesday', 'ayecode-connect'),
2352
+				'day_s5_4' => __('Wednesday', 'ayecode-connect'),
2353
+				'day_s5_5' => __('Thursday', 'ayecode-connect'),
2354
+				'day_s5_6' => __('Friday', 'ayecode-connect'),
2355
+				'day_s5_7' => __('Saturday', 'ayecode-connect'),
2356
+				'am_lower' => __('am', 'ayecode-connect'),
2357
+				'pm_lower' => __('pm', 'ayecode-connect'),
2358
+				'am_upper' => __('AM', 'ayecode-connect'),
2359
+				'pm_upper' => __('PM', 'ayecode-connect'),
2360
+				'firstDayOfWeek' => (int) get_option('start_of_week'),
2361 2361
 				'time_24hr' => false,
2362
-				'year' => __( 'Year', 'ayecode-connect' ),
2363
-				'hour' => __( 'Hour', 'ayecode-connect' ),
2364
-				'minute' => __( 'Minute', 'ayecode-connect' ),
2365
-				'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2366
-				'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2367
-				'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2368
-				'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2362
+				'year' => __('Year', 'ayecode-connect'),
2363
+				'hour' => __('Hour', 'ayecode-connect'),
2364
+				'minute' => __('Minute', 'ayecode-connect'),
2365
+				'weekAbbreviation' => __('Wk', 'ayecode-connect'),
2366
+				'rangeSeparator' => __(' to ', 'ayecode-connect'),
2367
+				'scrollTitle' => __('Scroll to increment', 'ayecode-connect'),
2368
+				'toggleTitle' => __('Click to toggle', 'ayecode-connect')
2369 2369
 			);
2370 2370
 
2371
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
2371
+			return apply_filters('ayecode_ui_calendar_params', $params);
2372 2372
 		}
2373 2373
 
2374 2374
 		/**
@@ -2381,47 +2381,47 @@  discard block
 block discarded – undo
2381 2381
 		public static function flatpickr_locale() {
2382 2382
 			$params = self::calendar_params();
2383 2383
 
2384
-			if ( is_string( $params ) ) {
2385
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2384
+			if (is_string($params)) {
2385
+				$params = html_entity_decode($params, ENT_QUOTES, 'UTF-8');
2386 2386
 			} else {
2387
-				foreach ( (array) $params as $key => $value ) {
2388
-					if ( ! is_scalar( $value ) ) {
2387
+				foreach ((array) $params as $key => $value) {
2388
+					if (!is_scalar($value)) {
2389 2389
 						continue;
2390 2390
 					}
2391 2391
 
2392
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2392
+					$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2393 2393
 				}
2394 2394
 			}
2395 2395
 
2396 2396
 			$day_s3 = array();
2397 2397
 			$day_s5 = array();
2398 2398
 
2399
-			for ( $i = 1; $i <= 7; $i ++ ) {
2400
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2401
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
+			for ($i = 1; $i <= 7; $i++) {
2400
+				$day_s3[] = addslashes($params['day_s3_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2401
+				$day_s5[] = addslashes($params['day_s3_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2402 2402
 			}
2403 2403
 
2404 2404
 			$month_s = array();
2405 2405
 			$month_long = array();
2406 2406
 
2407
-			for ( $i = 1; $i <= 12; $i ++ ) {
2408
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2409
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2407
+			for ($i = 1; $i <= 12; $i++) {
2408
+				$month_s[] = addslashes($params['month_s_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2409
+				$month_long[] = addslashes($params['month_long_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2410 2410
 			}
2411 2411
 
2412 2412
 			ob_start();
2413
-		if ( 0 ) { ?><script><?php } ?>
2413
+		if (0) { ?><script><?php } ?>
2414 2414
                 {
2415 2415
                     weekdays: {
2416
-                        shorthand: ['<?php echo implode( "','", $day_s3 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2417
-                            longhand: ['<?php echo implode( "','", $day_s5 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2416
+                        shorthand: ['<?php echo implode("','", $day_s3); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2417
+                            longhand: ['<?php echo implode("','", $day_s5); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2418 2418
                     },
2419 2419
                     months: {
2420
-                        shorthand: ['<?php echo implode( "','", $month_s ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2421
-                            longhand: ['<?php echo implode( "','", $month_long ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2420
+                        shorthand: ['<?php echo implode("','", $month_s); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2421
+                            longhand: ['<?php echo implode("','", $month_long); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2422 2422
                     },
2423 2423
                     daysInMonth: [31,28,31,30,31,30,31,31,30,31,30,31],
2424
-                        firstDayOfWeek: <?php echo (int) $params[ 'firstDayOfWeek' ]; ?>,
2424
+                        firstDayOfWeek: <?php echo (int) $params['firstDayOfWeek']; ?>,
2425 2425
                     ordinal: function (nth) {
2426 2426
                         var s = nth % 100;
2427 2427
                         if (s > 3 && s < 21)
@@ -2437,21 +2437,21 @@  discard block
 block discarded – undo
2437 2437
                                 return "th";
2438 2438
                         }
2439 2439
                     },
2440
-                    rangeSeparator: '<?php echo esc_attr( $params[ 'rangeSeparator' ] ); ?>',
2441
-                        weekAbbreviation: '<?php echo esc_attr( $params[ 'weekAbbreviation' ] ); ?>',
2442
-                    scrollTitle: '<?php echo esc_attr( $params[ 'scrollTitle' ] ); ?>',
2443
-                    toggleTitle: '<?php echo esc_attr( $params[ 'toggleTitle' ] ); ?>',
2444
-                    amPM: ['<?php echo esc_attr( $params[ 'am_upper' ] ); ?>','<?php echo esc_attr( $params[ 'pm_upper' ] ); ?>'],
2445
-                    yearAriaLabel: '<?php echo esc_attr( $params[ 'year' ] ); ?>',
2446
-                    hourAriaLabel: '<?php echo esc_attr( $params[ 'hour' ] ); ?>',
2447
-                    minuteAriaLabel: '<?php echo esc_attr( $params[ 'minute' ] ); ?>',
2448
-                    time_24hr: <?php echo ( $params[ 'time_24hr' ] ? 'true' : 'false' ) ; ?>
2440
+                    rangeSeparator: '<?php echo esc_attr($params['rangeSeparator']); ?>',
2441
+                        weekAbbreviation: '<?php echo esc_attr($params['weekAbbreviation']); ?>',
2442
+                    scrollTitle: '<?php echo esc_attr($params['scrollTitle']); ?>',
2443
+                    toggleTitle: '<?php echo esc_attr($params['toggleTitle']); ?>',
2444
+                    amPM: ['<?php echo esc_attr($params['am_upper']); ?>','<?php echo esc_attr($params['pm_upper']); ?>'],
2445
+                    yearAriaLabel: '<?php echo esc_attr($params['year']); ?>',
2446
+                    hourAriaLabel: '<?php echo esc_attr($params['hour']); ?>',
2447
+                    minuteAriaLabel: '<?php echo esc_attr($params['minute']); ?>',
2448
+                    time_24hr: <?php echo ($params['time_24hr'] ? 'true' : 'false'); ?>
2449 2449
                 }
2450
-				<?php if ( 0 ) { ?></script><?php } ?>
2450
+				<?php if (0) { ?></script><?php } ?>
2451 2451
 			<?php
2452 2452
 			$locale = ob_get_clean();
2453 2453
 
2454
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2454
+			return apply_filters('ayecode_ui_flatpickr_locale', trim($locale));
2455 2455
 		}
2456 2456
 
2457 2457
 		/**
@@ -2463,20 +2463,20 @@  discard block
 block discarded – undo
2463 2463
 		 */
2464 2464
 		public static function select2_params() {
2465 2465
 			$params = array(
2466
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2467
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2468
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2469
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2470
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2471
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2472
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2473
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2474
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2475
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2476
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2466
+				'i18n_select_state_text'    => esc_attr__('Select an option&hellip;', 'ayecode-connect'),
2467
+				'i18n_no_matches'           => _x('No matches found', 'enhanced select', 'ayecode-connect'),
2468
+				'i18n_ajax_error'           => _x('Loading failed', 'enhanced select', 'ayecode-connect'),
2469
+				'i18n_input_too_short_1'    => _x('Please enter 1 or more characters', 'enhanced select', 'ayecode-connect'),
2470
+				'i18n_input_too_short_n'    => _x('Please enter %item% or more characters', 'enhanced select', 'ayecode-connect'),
2471
+				'i18n_input_too_long_1'     => _x('Please delete 1 character', 'enhanced select', 'ayecode-connect'),
2472
+				'i18n_input_too_long_n'     => _x('Please delete %item% characters', 'enhanced select', 'ayecode-connect'),
2473
+				'i18n_selection_too_long_1' => _x('You can only select 1 item', 'enhanced select', 'ayecode-connect'),
2474
+				'i18n_selection_too_long_n' => _x('You can only select %item% items', 'enhanced select', 'ayecode-connect'),
2475
+				'i18n_load_more'            => _x('Loading more results&hellip;', 'enhanced select', 'ayecode-connect'),
2476
+				'i18n_searching'            => _x('Searching&hellip;', 'enhanced select', 'ayecode-connect')
2477 2477
 			);
2478 2478
 
2479
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2479
+			return apply_filters('ayecode_ui_select2_params', $params);
2480 2480
 		}
2481 2481
 
2482 2482
 		/**
@@ -2489,17 +2489,17 @@  discard block
 block discarded – undo
2489 2489
 		public static function select2_locale() {
2490 2490
 			$params = self::select2_params();
2491 2491
 
2492
-			foreach ( (array) $params as $key => $value ) {
2493
-				if ( ! is_scalar( $value ) ) {
2492
+			foreach ((array) $params as $key => $value) {
2493
+				if (!is_scalar($value)) {
2494 2494
 					continue;
2495 2495
 				}
2496 2496
 
2497
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2497
+				$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2498 2498
 			}
2499 2499
 
2500
-			$locale = json_encode( $params );
2500
+			$locale = json_encode($params);
2501 2501
 
2502
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2502
+			return apply_filters('ayecode_ui_select2_locale', trim($locale));
2503 2503
 		}
2504 2504
 
2505 2505
 		/**
@@ -2512,35 +2512,35 @@  discard block
 block discarded – undo
2512 2512
 		public static function timeago_locale() {
2513 2513
 			$params = array(
2514 2514
 				'prefix_ago' => '',
2515
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2516
-				'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2515
+				'suffix_ago' => ' ' . _x('ago', 'time ago', 'ayecode-connect'),
2516
+				'prefix_after' => _x('after', 'time ago', 'ayecode-connect') . ' ',
2517 2517
 				'suffix_after' => '',
2518
-				'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2519
-				'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2520
-				'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2521
-				'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2522
-				'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2523
-				'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2524
-				'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2525
-				'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2526
-				'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2527
-				'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2528
-				'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2518
+				'seconds' => _x('less than a minute', 'time ago', 'ayecode-connect'),
2519
+				'minute' => _x('about a minute', 'time ago', 'ayecode-connect'),
2520
+				'minutes' => _x('%d minutes', 'time ago', 'ayecode-connect'),
2521
+				'hour' => _x('about an hour', 'time ago', 'ayecode-connect'),
2522
+				'hours' => _x('about %d hours', 'time ago', 'ayecode-connect'),
2523
+				'day' => _x('a day', 'time ago', 'ayecode-connect'),
2524
+				'days' => _x('%d days', 'time ago', 'ayecode-connect'),
2525
+				'month' => _x('about a month', 'time ago', 'ayecode-connect'),
2526
+				'months' => _x('%d months', 'time ago', 'ayecode-connect'),
2527
+				'year' => _x('about a year', 'time ago', 'ayecode-connect'),
2528
+				'years' => _x('%d years', 'time ago', 'ayecode-connect'),
2529 2529
 			);
2530 2530
 
2531
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2531
+			$params = apply_filters('ayecode_ui_timeago_params', $params);
2532 2532
 
2533
-			foreach ( (array) $params as $key => $value ) {
2534
-				if ( ! is_scalar( $value ) ) {
2533
+			foreach ((array) $params as $key => $value) {
2534
+				if (!is_scalar($value)) {
2535 2535
 					continue;
2536 2536
 				}
2537 2537
 
2538
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2538
+				$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2539 2539
 			}
2540 2540
 
2541
-			$locale = json_encode( $params );
2541
+			$locale = json_encode($params);
2542 2542
 
2543
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2543
+			return apply_filters('ayecode_ui_timeago_locale', trim($locale));
2544 2544
 		}
2545 2545
 
2546 2546
 		/**
@@ -2551,7 +2551,7 @@  discard block
 block discarded – undo
2551 2551
 		 * @return mixed
2552 2552
 		 */
2553 2553
 		public static function minify_js($input) {
2554
-			if(trim($input) === "") return $input;
2554
+			if (trim($input) === "") return $input;
2555 2555
 			return preg_replace(
2556 2556
 				array(
2557 2557
 					// Remove comment(s)
@@ -2583,7 +2583,7 @@  discard block
 block discarded – undo
2583 2583
 		 * @return mixed
2584 2584
 		 */
2585 2585
 		public static function minify_css($input) {
2586
-			if(trim($input) === "") return $input;
2586
+			if (trim($input) === "") return $input;
2587 2587
 			return preg_replace(
2588 2588
 				array(
2589 2589
 					// Remove comment(s)
@@ -3163,12 +3163,12 @@  discard block
 block discarded – undo
3163 3163
                         });
3164 3164
                     }
3165 3165
                 }
3166
-				<?php do_action( 'aui_conditional_fields_js', $this ); ?>
3166
+				<?php do_action('aui_conditional_fields_js', $this); ?>
3167 3167
             </script>
3168 3168
 			<?php
3169 3169
 			$output = ob_get_clean();
3170 3170
 
3171
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3171
+			return str_replace(array('<script>', '</script>'), '', self::minify_js($output));
3172 3172
 		}
3173 3173
 
3174 3174
 		/**
@@ -3179,10 +3179,10 @@  discard block
 block discarded – undo
3179 3179
 		 * @return bool
3180 3180
 		 */
3181 3181
 		public static function is_block_editor() {
3182
-			if ( is_admin() ) {
3183
-				$current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3182
+			if (is_admin()) {
3183
+				$current_screen = function_exists('get_current_screen') ? get_current_screen() : array();
3184 3184
 
3185
-				if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3185
+				if (!empty($current_screen) && $current_screen->is_block_editor()) {
3186 3186
 					return true;
3187 3187
 				}
3188 3188
 			}
@@ -3201,7 +3201,7 @@  discard block
 block discarded – undo
3201 3201
 		 */
3202 3202
 		public static function is_block_content_call() {
3203 3203
 			$result = false;
3204
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3204
+			if (wp_doing_ajax() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'super_duper_output_shortcode') {
3205 3205
 				$result = true;
3206 3206
 			}
3207 3207
 
@@ -3217,7 +3217,7 @@  discard block
 block discarded – undo
3217 3217
 		 */
3218 3218
 		public static function is_divi_preview() {
3219 3219
 			$result = false;
3220
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3220
+			if (isset($_REQUEST['et_fb']) || isset($_REQUEST['et_pb_preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor')) {
3221 3221
 				$result = true;
3222 3222
 			}
3223 3223
 
@@ -3234,7 +3234,7 @@  discard block
 block discarded – undo
3234 3234
 		 */
3235 3235
 		public static function is_elementor_preview() {
3236 3236
 			$result = false;
3237
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3237
+			if (isset($_REQUEST['elementor-preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') || (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor_ajax')) {
3238 3238
 				$result = true;
3239 3239
 			}
3240 3240
 
@@ -3250,7 +3250,7 @@  discard block
 block discarded – undo
3250 3250
 		 */
3251 3251
 		public static function is_beaver_preview() {
3252 3252
 			$result = false;
3253
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3253
+			if (isset($_REQUEST['fl_builder'])) {
3254 3254
 				$result = true;
3255 3255
 			}
3256 3256
 
@@ -3266,7 +3266,7 @@  discard block
 block discarded – undo
3266 3266
 		 */
3267 3267
 		public static function is_siteorigin_preview() {
3268 3268
 			$result = false;
3269
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3269
+			if (!empty($_REQUEST['siteorigin_panels_live_editor'])) {
3270 3270
 				$result = true;
3271 3271
 			}
3272 3272
 
@@ -3282,7 +3282,7 @@  discard block
 block discarded – undo
3282 3282
 		 */
3283 3283
 		public static function is_cornerstone_preview() {
3284 3284
 			$result = false;
3285
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3285
+			if (!empty($_REQUEST['cornerstone_preview']) || basename($_SERVER['REQUEST_URI']) == 'cornerstone-endpoint') {
3286 3286
 				$result = true;
3287 3287
 			}
3288 3288
 
@@ -3297,7 +3297,7 @@  discard block
 block discarded – undo
3297 3297
 		 */
3298 3298
 		public static function is_fusion_preview() {
3299 3299
 			$result = false;
3300
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3300
+			if (!empty($_REQUEST['fb-edit']) || !empty($_REQUEST['fusion_load_nonce'])) {
3301 3301
 				$result = true;
3302 3302
 			}
3303 3303
 
@@ -3312,7 +3312,7 @@  discard block
 block discarded – undo
3312 3312
 		 */
3313 3313
 		public static function is_oxygen_preview() {
3314 3314
 			$result = false;
3315
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3315
+			if (!empty($_REQUEST['ct_builder']) || (!empty($_REQUEST['action']) && (substr($_REQUEST['action'], 0, 11) === "oxy_render_" || substr($_REQUEST['action'], 0, 10) === "ct_render_"))) {
3316 3316
 				$result = true;
3317 3317
 			}
3318 3318
 
@@ -3329,7 +3329,7 @@  discard block
 block discarded – undo
3329 3329
 		public static function is_kallyas_zion_preview() {
3330 3330
 			$result = false;
3331 3331
 
3332
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3332
+			if (function_exists('znhg_kallyas_theme_config') && !empty($_REQUEST['zn_pb_edit'])) {
3333 3333
 				$result = true;
3334 3334
 			}
3335 3335
 
@@ -3346,7 +3346,7 @@  discard block
 block discarded – undo
3346 3346
 		public static function is_bricks_preview() {
3347 3347
 			$result = false;
3348 3348
 
3349
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3349
+			if (function_exists('bricks_is_builder') && (bricks_is_builder() || bricks_is_builder_call())) {
3350 3350
 				$result = true;
3351 3351
 			}
3352 3352
 
@@ -3363,29 +3363,29 @@  discard block
 block discarded – undo
3363 3363
 		public static function is_preview() {
3364 3364
 			$preview = false;
3365 3365
 
3366
-			if ( self::is_block_editor() ) {
3366
+			if (self::is_block_editor()) {
3367 3367
 				return true;
3368 3368
 			}
3369 3369
 
3370
-			if( self::is_block_content_call() ) {
3370
+			if (self::is_block_content_call()) {
3371 3371
 				$preview = true;
3372
-			} elseif ( self::is_divi_preview() ) {
3372
+			} elseif (self::is_divi_preview()) {
3373 3373
 				$preview = true;
3374
-			} elseif ( self::is_elementor_preview() ) {
3374
+			} elseif (self::is_elementor_preview()) {
3375 3375
 				$preview = true;
3376
-			} elseif ( self::is_beaver_preview() ) {
3376
+			} elseif (self::is_beaver_preview()) {
3377 3377
 				$preview = true;
3378
-			} elseif ( self::is_siteorigin_preview() ) {
3378
+			} elseif (self::is_siteorigin_preview()) {
3379 3379
 				$preview = true;
3380
-			} elseif ( self::is_cornerstone_preview() ) {
3380
+			} elseif (self::is_cornerstone_preview()) {
3381 3381
 				$preview = true;
3382
-			} elseif ( self::is_fusion_preview() ) {
3382
+			} elseif (self::is_fusion_preview()) {
3383 3383
 				$preview = true;
3384
-			} elseif ( self::is_oxygen_preview() ) {
3384
+			} elseif (self::is_oxygen_preview()) {
3385 3385
 				$preview = true;
3386
-			} elseif( self::is_kallyas_zion_preview() ) {
3386
+			} elseif (self::is_kallyas_zion_preview()) {
3387 3387
 				$preview = true;
3388
-			} elseif( self::is_bricks_preview() ) {
3388
+			} elseif (self::is_bricks_preview()) {
3389 3389
 				$preview = true;
3390 3390
 			}
3391 3391
 
Please login to merge, or discard this patch.
Indentation   +2339 added lines, -2339 removed lines patch added patch discarded remove patch
@@ -13,7 +13,7 @@  discard block
 block discarded – undo
13 13
  * Bail if we are not in WP.
14 14
  */
15 15
 if ( ! defined( 'ABSPATH' ) ) {
16
-	exit;
16
+    exit;
17 17
 }
18 18
 
19 19
 /**
@@ -21,472 +21,472 @@  discard block
 block discarded – undo
21 21
  */
22 22
 if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
23 23
 
24
-	/**
25
-	 * A Class to be able to change settings for Font Awesome.
26
-	 *
27
-	 * Class AyeCode_UI_Settings
28
-	 * @ver 1.0.0
29
-	 * @todo decide how to implement textdomain
30
-	 */
31
-	class AyeCode_UI_Settings {
32
-
33
-		/**
34
-		 * Class version version.
35
-		 *
36
-		 * @var string
37
-		 */
38
-		public $version = '0.2.40';
39
-
40
-		/**
41
-		 * Class textdomain.
42
-		 *
43
-		 * @var string
44
-		 */
45
-		public $textdomain = 'aui';
46
-
47
-		/**
48
-		 * Latest version of Bootstrap at time of publish published.
49
-		 *
50
-		 * @var string
51
-		 */
52
-		public $latest = "5.2.2";
53
-
54
-		/**
55
-		 * Current version of select2 being used.
56
-		 *
57
-		 * @var string
58
-		 */
59
-		public $select2_version = "4.0.11";
60
-
61
-		/**
62
-		 * The title.
63
-		 *
64
-		 * @var string
65
-		 */
66
-		public $name = 'AyeCode UI';
67
-
68
-		/**
69
-		 * The relative url to the assets.
70
-		 *
71
-		 * @var string
72
-		 */
73
-		public $url = '';
74
-
75
-		/**
76
-		 * Holds the settings values.
77
-		 *
78
-		 * @var array
79
-		 */
80
-		private $settings;
81
-
82
-		/**
83
-		 * AyeCode_UI_Settings instance.
84
-		 *
85
-		 * @access private
86
-		 * @since  1.0.0
87
-		 * @var    AyeCode_UI_Settings There can be only one!
88
-		 */
89
-		private static $instance = null;
90
-
91
-
92
-		/**
93
-		 * Main AyeCode_UI_Settings Instance.
94
-		 *
95
-		 * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
96
-		 *
97
-		 * @since 1.0.0
98
-		 * @static
99
-		 * @return AyeCode_UI_Settings - Main instance.
100
-		 */
101
-		public static function instance() {
102
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
103
-
104
-				self::$instance = new AyeCode_UI_Settings;
105
-
106
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
107
-
108
-				if ( is_admin() ) {
109
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
110
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
111
-
112
-					// Maybe show example page
113
-					add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
114
-
115
-					if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
116
-						add_filter( 'sd_aui_colors', array( self::$instance,'sd_aui_colors' ), 10, 3 );
117
-					}
118
-				}
24
+    /**
25
+     * A Class to be able to change settings for Font Awesome.
26
+     *
27
+     * Class AyeCode_UI_Settings
28
+     * @ver 1.0.0
29
+     * @todo decide how to implement textdomain
30
+     */
31
+    class AyeCode_UI_Settings {
32
+
33
+        /**
34
+         * Class version version.
35
+         *
36
+         * @var string
37
+         */
38
+        public $version = '0.2.40';
39
+
40
+        /**
41
+         * Class textdomain.
42
+         *
43
+         * @var string
44
+         */
45
+        public $textdomain = 'aui';
46
+
47
+        /**
48
+         * Latest version of Bootstrap at time of publish published.
49
+         *
50
+         * @var string
51
+         */
52
+        public $latest = "5.2.2";
53
+
54
+        /**
55
+         * Current version of select2 being used.
56
+         *
57
+         * @var string
58
+         */
59
+        public $select2_version = "4.0.11";
119 60
 
120
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
61
+        /**
62
+         * The title.
63
+         *
64
+         * @var string
65
+         */
66
+        public $name = 'AyeCode UI';
121 67
 
122
-				do_action( 'ayecode_ui_settings_loaded' );
123
-			}
68
+        /**
69
+         * The relative url to the assets.
70
+         *
71
+         * @var string
72
+         */
73
+        public $url = '';
124 74
 
125
-			return self::$instance;
126
-		}
75
+        /**
76
+         * Holds the settings values.
77
+         *
78
+         * @var array
79
+         */
80
+        private $settings;
127 81
 
128
-		/**
129
-		 * Add custom colors to the color selector.
130
-		 *
131
-		 * @param $theme_colors
132
-		 * @param $include_outlines
133
-		 * @param $include_branding
134
-		 *
135
-		 * @return mixed
136
-		 */
137
-		public function sd_aui_colors( $theme_colors, $include_outlines, $include_branding ){
82
+        /**
83
+         * AyeCode_UI_Settings instance.
84
+         *
85
+         * @access private
86
+         * @since  1.0.0
87
+         * @var    AyeCode_UI_Settings There can be only one!
88
+         */
89
+        private static $instance = null;
138 90
 
139 91
 
140
-			$setting = wp_get_global_settings();
92
+        /**
93
+         * Main AyeCode_UI_Settings Instance.
94
+         *
95
+         * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
96
+         *
97
+         * @since 1.0.0
98
+         * @static
99
+         * @return AyeCode_UI_Settings - Main instance.
100
+         */
101
+        public static function instance() {
102
+            if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
141 103
 
142
-			if(!empty($setting['color']['palette']['custom'])){
143
-				foreach($setting['color']['palette']['custom'] as $color){
144
-					$theme_colors[$color['slug']] = esc_attr($color['name']);
145
-				}
146
-			}
147
-
148
-			return $theme_colors;
149
-		}
150
-
151
-		/**
152
-		 * Setup some constants.
153
-		 */
154
-		public function constants(){
155
-			define( 'AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be" );
156
-			define( 'AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d' );
157
-			define( 'AUI_INFO_COLOR_ORIGINAL', '#17a2b8' );
158
-			define( 'AUI_WARNING_COLOR_ORIGINAL', '#ffc107' );
159
-			define( 'AUI_DANGER_COLOR_ORIGINAL', '#dc3545' );
160
-			define( 'AUI_SUCCESS_COLOR_ORIGINAL', '#44c553' );
161
-			define( 'AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa' );
162
-			define( 'AUI_DARK_COLOR_ORIGINAL', '#343a40' );
163
-			define( 'AUI_WHITE_COLOR_ORIGINAL', '#fff' );
164
-			define( 'AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd' );
165
-			define( 'AUI_SALMON_COLOR_ORIGINAL', '#ff977a' );
166
-			define( 'AUI_CYAN_COLOR_ORIGINAL', '#35bdff' );
167
-			define( 'AUI_GRAY_COLOR_ORIGINAL', '#ced4da' );
168
-			define( 'AUI_INDIGO_COLOR_ORIGINAL', '#502c6c' );
169
-			define( 'AUI_ORANGE_COLOR_ORIGINAL', '#orange' );
170
-			define( 'AUI_BLACK_COLOR_ORIGINAL', '#000' );
171
-
172
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
173
-				define( 'AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL );
174
-			}
175
-			if ( ! defined( 'AUI_SECONDARY_COLOR' ) ) {
176
-				define( 'AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL );
177
-			}
178
-			if ( ! defined( 'AUI_INFO_COLOR' ) ) {
179
-				define( 'AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL );
180
-			}
181
-			if ( ! defined( 'AUI_WARNING_COLOR' ) ) {
182
-				define( 'AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL );
183
-			}
184
-			if ( ! defined( 'AUI_DANGER_COLOR' ) ) {
185
-				define( 'AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL );
186
-			}
187
-			if ( ! defined( 'AUI_SUCCESS_COLOR' ) ) {
188
-				define( 'AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL );
189
-			}
190
-			if ( ! defined( 'AUI_LIGHT_COLOR' ) ) {
191
-				define( 'AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL );
192
-			}
193
-			if ( ! defined( 'AUI_DARK_COLOR' ) ) {
194
-				define( 'AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL );
195
-			}
196
-			if ( ! defined( 'AUI_WHITE_COLOR' ) ) {
197
-				define( 'AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL );
198
-			}
199
-			if ( ! defined( 'AUI_PURPLE_COLOR' ) ) {
200
-				define( 'AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL );
201
-			}
202
-			if ( ! defined( 'AUI_SALMON_COLOR' ) ) {
203
-				define( 'AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL );
204
-			}
205
-			if ( ! defined( 'AUI_CYAN_COLOR' ) ) {
206
-				define( 'AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL );
207
-			}
208
-			if ( ! defined( 'AUI_GRAY_COLOR' ) ) {
209
-				define( 'AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL );
210
-			}
211
-			if ( ! defined( 'AUI_INDIGO_COLOR' ) ) {
212
-				define( 'AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL );
213
-			}
214
-			if ( ! defined( 'AUI_ORANGE_COLOR' ) ) {
215
-				define( 'AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL );
216
-			}
217
-			if ( ! defined( 'AUI_BLACK_COLOR' ) ) {
218
-				define( 'AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL );
219
-			}
220
-
221
-		}
222
-
223
-		public static function get_colors( $original = false){
224
-
225
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
226
-				return array();
227
-			}
228
-			if ( $original ) {
229
-				return array(
230
-					'primary'   => AUI_PRIMARY_COLOR_ORIGINAL,
231
-					'secondary' => AUI_SECONDARY_COLOR_ORIGINAL,
232
-					'info'      => AUI_INFO_COLOR_ORIGINAL,
233
-					'warning'   => AUI_WARNING_COLOR_ORIGINAL,
234
-					'danger'    => AUI_DANGER_COLOR_ORIGINAL,
235
-					'success'   => AUI_SUCCESS_COLOR_ORIGINAL,
236
-					'light'     => AUI_LIGHT_COLOR_ORIGINAL,
237
-					'dark'      => AUI_DARK_COLOR_ORIGINAL,
238
-					'white'     => AUI_WHITE_COLOR_ORIGINAL,
239
-					'purple'    => AUI_PURPLE_COLOR_ORIGINAL,
240
-					'salmon'    => AUI_SALMON_COLOR_ORIGINAL,
241
-					'cyan'      => AUI_CYAN_COLOR_ORIGINAL,
242
-					'gray'      => AUI_GRAY_COLOR_ORIGINAL,
243
-					'indigo'    => AUI_INDIGO_COLOR_ORIGINAL,
244
-					'orange'    => AUI_ORANGE_COLOR_ORIGINAL,
245
-					'black'     => AUI_BLACK_COLOR_ORIGINAL,
246
-				);
247
-			}
248
-
249
-			return array(
250
-				'primary'   => AUI_PRIMARY_COLOR,
251
-				'secondary' => AUI_SECONDARY_COLOR,
252
-				'info'      => AUI_INFO_COLOR,
253
-				'warning'   => AUI_WARNING_COLOR,
254
-				'danger'    => AUI_DANGER_COLOR,
255
-				'success'   => AUI_SUCCESS_COLOR,
256
-				'light'     => AUI_LIGHT_COLOR,
257
-				'dark'      => AUI_DARK_COLOR,
258
-				'white'     => AUI_WHITE_COLOR,
259
-				'purple'    => AUI_PURPLE_COLOR,
260
-				'salmon'    => AUI_SALMON_COLOR,
261
-				'cyan'      => AUI_CYAN_COLOR,
262
-				'gray'      => AUI_GRAY_COLOR,
263
-				'indigo'    => AUI_INDIGO_COLOR,
264
-				'orange'    => AUI_ORANGE_COLOR,
265
-				'black'     => AUI_BLACK_COLOR,
266
-			);
267
-		}
268
-
269
-		/**
270
-		 * Add admin body class to show when BS5 is active.
271
-		 *
272
-		 * @param $classes
273
-		 *
274
-		 * @return mixed
275
-		 */
276
-		public function add_bs5_admin_body_class( $classes = '' ) {
277
-			$classes .= ' aui_bs5';
278
-
279
-			return $classes;
280
-		}
281
-
282
-		/**
283
-		 * Add a body class to show when BS5 is active.
284
-		 *
285
-		 * @param $classes
286
-		 *
287
-		 * @return mixed
288
-		 */
289
-		public function add_bs5_body_class( $classes ) {
290
-			$classes[] = 'aui_bs5';
291
-
292
-			return $classes;
293
-		}
294
-
295
-		/**
296
-		 * Initiate the settings and add the required action hooks.
297
-		 */
298
-		public function init() {
104
+                self::$instance = new AyeCode_UI_Settings;
105
+
106
+                add_action( 'init', array( self::$instance, 'init' ) ); // set settings
107
+
108
+                if ( is_admin() ) {
109
+                    add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
110
+                    add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
111
+
112
+                    // Maybe show example page
113
+                    add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
114
+
115
+                    if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
116
+                        add_filter( 'sd_aui_colors', array( self::$instance,'sd_aui_colors' ), 10, 3 );
117
+                    }
118
+                }
119
+
120
+                add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
121
+
122
+                do_action( 'ayecode_ui_settings_loaded' );
123
+            }
124
+
125
+            return self::$instance;
126
+        }
127
+
128
+        /**
129
+         * Add custom colors to the color selector.
130
+         *
131
+         * @param $theme_colors
132
+         * @param $include_outlines
133
+         * @param $include_branding
134
+         *
135
+         * @return mixed
136
+         */
137
+        public function sd_aui_colors( $theme_colors, $include_outlines, $include_branding ){
138
+
139
+
140
+            $setting = wp_get_global_settings();
141
+
142
+            if(!empty($setting['color']['palette']['custom'])){
143
+                foreach($setting['color']['palette']['custom'] as $color){
144
+                    $theme_colors[$color['slug']] = esc_attr($color['name']);
145
+                }
146
+            }
147
+
148
+            return $theme_colors;
149
+        }
150
+
151
+        /**
152
+         * Setup some constants.
153
+         */
154
+        public function constants(){
155
+            define( 'AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be" );
156
+            define( 'AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d' );
157
+            define( 'AUI_INFO_COLOR_ORIGINAL', '#17a2b8' );
158
+            define( 'AUI_WARNING_COLOR_ORIGINAL', '#ffc107' );
159
+            define( 'AUI_DANGER_COLOR_ORIGINAL', '#dc3545' );
160
+            define( 'AUI_SUCCESS_COLOR_ORIGINAL', '#44c553' );
161
+            define( 'AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa' );
162
+            define( 'AUI_DARK_COLOR_ORIGINAL', '#343a40' );
163
+            define( 'AUI_WHITE_COLOR_ORIGINAL', '#fff' );
164
+            define( 'AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd' );
165
+            define( 'AUI_SALMON_COLOR_ORIGINAL', '#ff977a' );
166
+            define( 'AUI_CYAN_COLOR_ORIGINAL', '#35bdff' );
167
+            define( 'AUI_GRAY_COLOR_ORIGINAL', '#ced4da' );
168
+            define( 'AUI_INDIGO_COLOR_ORIGINAL', '#502c6c' );
169
+            define( 'AUI_ORANGE_COLOR_ORIGINAL', '#orange' );
170
+            define( 'AUI_BLACK_COLOR_ORIGINAL', '#000' );
171
+
172
+            if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
173
+                define( 'AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL );
174
+            }
175
+            if ( ! defined( 'AUI_SECONDARY_COLOR' ) ) {
176
+                define( 'AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL );
177
+            }
178
+            if ( ! defined( 'AUI_INFO_COLOR' ) ) {
179
+                define( 'AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL );
180
+            }
181
+            if ( ! defined( 'AUI_WARNING_COLOR' ) ) {
182
+                define( 'AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL );
183
+            }
184
+            if ( ! defined( 'AUI_DANGER_COLOR' ) ) {
185
+                define( 'AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL );
186
+            }
187
+            if ( ! defined( 'AUI_SUCCESS_COLOR' ) ) {
188
+                define( 'AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL );
189
+            }
190
+            if ( ! defined( 'AUI_LIGHT_COLOR' ) ) {
191
+                define( 'AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL );
192
+            }
193
+            if ( ! defined( 'AUI_DARK_COLOR' ) ) {
194
+                define( 'AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL );
195
+            }
196
+            if ( ! defined( 'AUI_WHITE_COLOR' ) ) {
197
+                define( 'AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL );
198
+            }
199
+            if ( ! defined( 'AUI_PURPLE_COLOR' ) ) {
200
+                define( 'AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL );
201
+            }
202
+            if ( ! defined( 'AUI_SALMON_COLOR' ) ) {
203
+                define( 'AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL );
204
+            }
205
+            if ( ! defined( 'AUI_CYAN_COLOR' ) ) {
206
+                define( 'AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL );
207
+            }
208
+            if ( ! defined( 'AUI_GRAY_COLOR' ) ) {
209
+                define( 'AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL );
210
+            }
211
+            if ( ! defined( 'AUI_INDIGO_COLOR' ) ) {
212
+                define( 'AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL );
213
+            }
214
+            if ( ! defined( 'AUI_ORANGE_COLOR' ) ) {
215
+                define( 'AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL );
216
+            }
217
+            if ( ! defined( 'AUI_BLACK_COLOR' ) ) {
218
+                define( 'AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL );
219
+            }
220
+
221
+        }
222
+
223
+        public static function get_colors( $original = false){
224
+
225
+            if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
226
+                return array();
227
+            }
228
+            if ( $original ) {
229
+                return array(
230
+                    'primary'   => AUI_PRIMARY_COLOR_ORIGINAL,
231
+                    'secondary' => AUI_SECONDARY_COLOR_ORIGINAL,
232
+                    'info'      => AUI_INFO_COLOR_ORIGINAL,
233
+                    'warning'   => AUI_WARNING_COLOR_ORIGINAL,
234
+                    'danger'    => AUI_DANGER_COLOR_ORIGINAL,
235
+                    'success'   => AUI_SUCCESS_COLOR_ORIGINAL,
236
+                    'light'     => AUI_LIGHT_COLOR_ORIGINAL,
237
+                    'dark'      => AUI_DARK_COLOR_ORIGINAL,
238
+                    'white'     => AUI_WHITE_COLOR_ORIGINAL,
239
+                    'purple'    => AUI_PURPLE_COLOR_ORIGINAL,
240
+                    'salmon'    => AUI_SALMON_COLOR_ORIGINAL,
241
+                    'cyan'      => AUI_CYAN_COLOR_ORIGINAL,
242
+                    'gray'      => AUI_GRAY_COLOR_ORIGINAL,
243
+                    'indigo'    => AUI_INDIGO_COLOR_ORIGINAL,
244
+                    'orange'    => AUI_ORANGE_COLOR_ORIGINAL,
245
+                    'black'     => AUI_BLACK_COLOR_ORIGINAL,
246
+                );
247
+            }
248
+
249
+            return array(
250
+                'primary'   => AUI_PRIMARY_COLOR,
251
+                'secondary' => AUI_SECONDARY_COLOR,
252
+                'info'      => AUI_INFO_COLOR,
253
+                'warning'   => AUI_WARNING_COLOR,
254
+                'danger'    => AUI_DANGER_COLOR,
255
+                'success'   => AUI_SUCCESS_COLOR,
256
+                'light'     => AUI_LIGHT_COLOR,
257
+                'dark'      => AUI_DARK_COLOR,
258
+                'white'     => AUI_WHITE_COLOR,
259
+                'purple'    => AUI_PURPLE_COLOR,
260
+                'salmon'    => AUI_SALMON_COLOR,
261
+                'cyan'      => AUI_CYAN_COLOR,
262
+                'gray'      => AUI_GRAY_COLOR,
263
+                'indigo'    => AUI_INDIGO_COLOR,
264
+                'orange'    => AUI_ORANGE_COLOR,
265
+                'black'     => AUI_BLACK_COLOR,
266
+            );
267
+        }
268
+
269
+        /**
270
+         * Add admin body class to show when BS5 is active.
271
+         *
272
+         * @param $classes
273
+         *
274
+         * @return mixed
275
+         */
276
+        public function add_bs5_admin_body_class( $classes = '' ) {
277
+            $classes .= ' aui_bs5';
278
+
279
+            return $classes;
280
+        }
281
+
282
+        /**
283
+         * Add a body class to show when BS5 is active.
284
+         *
285
+         * @param $classes
286
+         *
287
+         * @return mixed
288
+         */
289
+        public function add_bs5_body_class( $classes ) {
290
+            $classes[] = 'aui_bs5';
291
+
292
+            return $classes;
293
+        }
294
+
295
+        /**
296
+         * Initiate the settings and add the required action hooks.
297
+         */
298
+        public function init() {
299 299
             global $aui_bs5;
300 300
 
301
-			// Maybe fix settings
302
-			if ( ! empty( $_REQUEST['aui-fix-admin'] ) && !empty($_REQUEST['nonce']) && wp_verify_nonce( $_REQUEST['nonce'], "aui-fix-admin" ) ) {
303
-				$db_settings = get_option( 'ayecode-ui-settings' );
304
-				if ( ! empty( $db_settings ) ) {
305
-					$db_settings['css_backend'] = 'compatibility';
306
-					$db_settings['js_backend'] = 'core-popper';
307
-					update_option( 'ayecode-ui-settings', $db_settings );
308
-					wp_safe_redirect(admin_url("options-general.php?page=ayecode-ui-settings&updated=true"));
309
-				}
310
-			}
301
+            // Maybe fix settings
302
+            if ( ! empty( $_REQUEST['aui-fix-admin'] ) && !empty($_REQUEST['nonce']) && wp_verify_nonce( $_REQUEST['nonce'], "aui-fix-admin" ) ) {
303
+                $db_settings = get_option( 'ayecode-ui-settings' );
304
+                if ( ! empty( $db_settings ) ) {
305
+                    $db_settings['css_backend'] = 'compatibility';
306
+                    $db_settings['js_backend'] = 'core-popper';
307
+                    update_option( 'ayecode-ui-settings', $db_settings );
308
+                    wp_safe_redirect(admin_url("options-general.php?page=ayecode-ui-settings&updated=true"));
309
+                }
310
+            }
311 311
 
312
-			$this->constants();
313
-			$this->settings = $this->get_settings();
314
-			$this->url = $this->get_url();
312
+            $this->constants();
313
+            $this->settings = $this->get_settings();
314
+            $this->url = $this->get_url();
315 315
 
316 316
             // define the version
317
-			$aui_bs5 = $this->settings['bs_ver'] === '5';
318
-
319
-			if ( $aui_bs5 ) {
320
-				include_once( dirname( __FILE__ ) . '/inc/bs-conversion.php' );
321
-				add_filter( 'admin_body_class', array( $this, 'add_bs5_admin_body_class' ), 99, 1 );
322
-				add_filter( 'body_class', array( $this, 'add_bs5_body_class' ) );
323
-			}
324
-
325
-			/**
326
-			 * Maybe load CSS
327
-			 *
328
-			 * We load super early in case there is a theme version that might change the colors
329
-			 */
330
-			if ( $this->settings['css'] ) {
331
-				$priority = $this->is_bs3_compat() ? 100 : 1;
317
+            $aui_bs5 = $this->settings['bs_ver'] === '5';
318
+
319
+            if ( $aui_bs5 ) {
320
+                include_once( dirname( __FILE__ ) . '/inc/bs-conversion.php' );
321
+                add_filter( 'admin_body_class', array( $this, 'add_bs5_admin_body_class' ), 99, 1 );
322
+                add_filter( 'body_class', array( $this, 'add_bs5_body_class' ) );
323
+            }
324
+
325
+            /**
326
+             * Maybe load CSS
327
+             *
328
+             * We load super early in case there is a theme version that might change the colors
329
+             */
330
+            if ( $this->settings['css'] ) {
331
+                $priority = $this->is_bs3_compat() ? 100 : 1;
332 332
                 $priority = $aui_bs5 ? 10 : $priority;
333
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), $priority );
334
-			}
335
-			if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
336
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
337
-			}
338
-
339
-			// maybe load JS
340
-			if ( $this->settings['js'] ) {
341
-				$priority = $this->is_bs3_compat() ? 100 : 1;
342
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
343
-			}
344
-			if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
345
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
346
-			}
347
-
348
-			// Maybe set the HTML font size
349
-			if ( $this->settings['html_font_size'] ) {
350
-				add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
351
-			}
352
-
353
-			// Maybe show backend style error
354
-			if( $this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper' ){
355
-				add_action( 'admin_notices', array( $this, 'show_admin_style_notice' ) );
356
-			}
357
-
358
-		}
359
-
360
-		/**
361
-		 * Show admin notice if backend scripts not loaded.
362
-		 */
363
-		public function show_admin_style_notice(){
364
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=".wp_create_nonce('aui-fix-admin'));
365
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">Fix Now</a>';
366
-			$message = __( '<b>Style Issue:</b> AyeCode UI is disable or set wrong.')." " .$button;
367
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
368
-		}
369
-
370
-		/**
371
-		 * Check if we should load the admin scripts or not.
372
-		 *
373
-		 * @return bool
374
-		 */
375
-		public function load_admin_scripts(){
376
-			$result = true;
377
-
378
-			// check if specifically disabled
379
-			if(!empty($this->settings['disable_admin'])){
380
-				$url_parts = explode("\n",$this->settings['disable_admin']);
381
-				foreach($url_parts as $part){
382
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
383
-						return false; // return early, no point checking further
384
-					}
385
-				}
386
-			}
387
-
388
-			return $result;
389
-		}
390
-
391
-		/**
392
-		 * Add a html font size to the footer.
393
-		 */
394
-		public function html_font_size(){
395
-			$this->settings = $this->get_settings();
396
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
397
-		}
398
-
399
-		/**
400
-		 * Check if the current admin screen should load scripts.
401
-		 *
402
-		 * @return bool
403
-		 */
404
-		public function is_aui_screen(){
333
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), $priority );
334
+            }
335
+            if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
336
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
337
+            }
338
+
339
+            // maybe load JS
340
+            if ( $this->settings['js'] ) {
341
+                $priority = $this->is_bs3_compat() ? 100 : 1;
342
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
343
+            }
344
+            if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
345
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
346
+            }
347
+
348
+            // Maybe set the HTML font size
349
+            if ( $this->settings['html_font_size'] ) {
350
+                add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
351
+            }
352
+
353
+            // Maybe show backend style error
354
+            if( $this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper' ){
355
+                add_action( 'admin_notices', array( $this, 'show_admin_style_notice' ) );
356
+            }
357
+
358
+        }
359
+
360
+        /**
361
+         * Show admin notice if backend scripts not loaded.
362
+         */
363
+        public function show_admin_style_notice(){
364
+            $fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=".wp_create_nonce('aui-fix-admin'));
365
+            $button = '<a href="'.esc_url($fix_url).'" class="button-primary">Fix Now</a>';
366
+            $message = __( '<b>Style Issue:</b> AyeCode UI is disable or set wrong.')." " .$button;
367
+            echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
368
+        }
369
+
370
+        /**
371
+         * Check if we should load the admin scripts or not.
372
+         *
373
+         * @return bool
374
+         */
375
+        public function load_admin_scripts(){
376
+            $result = true;
377
+
378
+            // check if specifically disabled
379
+            if(!empty($this->settings['disable_admin'])){
380
+                $url_parts = explode("\n",$this->settings['disable_admin']);
381
+                foreach($url_parts as $part){
382
+                    if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
383
+                        return false; // return early, no point checking further
384
+                    }
385
+                }
386
+            }
387
+
388
+            return $result;
389
+        }
390
+
391
+        /**
392
+         * Add a html font size to the footer.
393
+         */
394
+        public function html_font_size(){
395
+            $this->settings = $this->get_settings();
396
+            echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
397
+        }
398
+
399
+        /**
400
+         * Check if the current admin screen should load scripts.
401
+         *
402
+         * @return bool
403
+         */
404
+        public function is_aui_screen(){
405 405
 //			echo '###';exit;
406
-			$load = false;
407
-			// check if we should load or not
408
-			if ( is_admin() ) {
409
-				// Only enable on set pages
410
-				$aui_screens = array(
411
-					'page',
406
+            $load = false;
407
+            // check if we should load or not
408
+            if ( is_admin() ) {
409
+                // Only enable on set pages
410
+                $aui_screens = array(
411
+                    'page',
412 412
                     //'docs',
413
-					'post',
414
-					'settings_page_ayecode-ui-settings',
415
-					'appearance_page_gutenberg-widgets',
416
-					'widgets',
417
-					'ayecode-ui-settings',
418
-					'site-editor'
419
-				);
420
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
413
+                    'post',
414
+                    'settings_page_ayecode-ui-settings',
415
+                    'appearance_page_gutenberg-widgets',
416
+                    'widgets',
417
+                    'ayecode-ui-settings',
418
+                    'site-editor'
419
+                );
420
+                $screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
421 421
 
422
-				$screen = get_current_screen();
422
+                $screen = get_current_screen();
423 423
 
424 424
 //				echo '###'.$screen->id;
425 425
 
426
-				// check if we are on a AUI screen
427
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
428
-					$load = true;
429
-				}
426
+                // check if we are on a AUI screen
427
+                if ( $screen && in_array( $screen->id, $screen_ids ) ) {
428
+                    $load = true;
429
+                }
430 430
 
431
-				//load for widget previews in WP 5.8
432
-				if( !empty($_REQUEST['legacy-widget-preview'])){
433
-					$load = true;
434
-				}
435
-			}
431
+                //load for widget previews in WP 5.8
432
+                if( !empty($_REQUEST['legacy-widget-preview'])){
433
+                    $load = true;
434
+                }
435
+            }
436 436
 
437 437
 
438 438
 
439
-			return apply_filters( 'aui_load_on_admin' , $load );
440
-		}
439
+            return apply_filters( 'aui_load_on_admin' , $load );
440
+        }
441 441
 
442
-		/**
443
-		 * Check if the current theme is a block theme.
444
-		 *
445
-		 * @return bool
446
-		 */
447
-		public static function is_block_theme() {
448
-			if ( function_exists( 'wp_is_block_theme' && wp_is_block_theme() ) ) {
449
-				return true;
450
-			}
442
+        /**
443
+         * Check if the current theme is a block theme.
444
+         *
445
+         * @return bool
446
+         */
447
+        public static function is_block_theme() {
448
+            if ( function_exists( 'wp_is_block_theme' && wp_is_block_theme() ) ) {
449
+                return true;
450
+            }
451 451
 
452
-			return false;
453
-		}
452
+            return false;
453
+        }
454 454
 
455
-		/**
456
-		 * Adds the styles.
457
-		 */
458
-		public function enqueue_style() {
455
+        /**
456
+         * Adds the styles.
457
+         */
458
+        public function enqueue_style() {
459 459
             global $aui_bs5;
460 460
 
461 461
             $load_fse = false;
462 462
 
463
-			if ( is_admin() && ! $this->is_aui_screen() ) {
464
-				// Don't add wp-admin scripts if not requested to.
465
-			} else {
466
-				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
467
-				$rtl = is_rtl() && ! $aui_bs5 ? '-rtl' : '';
463
+            if ( is_admin() && ! $this->is_aui_screen() ) {
464
+                // Don't add wp-admin scripts if not requested to.
465
+            } else {
466
+                $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
467
+                $rtl = is_rtl() && ! $aui_bs5 ? '-rtl' : '';
468 468
                 $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
469 469
 
470
-				if ( $this->settings[ $css_setting ] ) {
471
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
472
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets'.$bs_ver.'/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets'.$bs_ver.'/css/ayecode-ui-compatibility'.$rtl.'.css';
470
+                if ( $this->settings[ $css_setting ] ) {
471
+                    $compatibility = $this->settings[$css_setting]=='core' ? false : true;
472
+                    $url = $this->settings[$css_setting]=='core' ? $this->url.'assets'.$bs_ver.'/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets'.$bs_ver.'/css/ayecode-ui-compatibility'.$rtl.'.css';
473 473
 
474
-					wp_register_style( 'ayecode-ui', $url, array(), $this->version );
475
-					wp_enqueue_style( 'ayecode-ui' );
474
+                    wp_register_style( 'ayecode-ui', $url, array(), $this->version );
475
+                    wp_enqueue_style( 'ayecode-ui' );
476 476
 
477
-					if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
478
-						$url = $this->url.'assets'.$bs_ver.'/css/ayecode-ui-fse.css';
479
-						wp_register_style( 'ayecode-ui-fse', $url, array(), $this->version );
480
-						wp_enqueue_style( 'ayecode-ui-fse' );
481
-						$load_fse = true;
482
-					}
477
+                    if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
478
+                        $url = $this->url.'assets'.$bs_ver.'/css/ayecode-ui-fse.css';
479
+                        wp_register_style( 'ayecode-ui-fse', $url, array(), $this->version );
480
+                        wp_enqueue_style( 'ayecode-ui-fse' );
481
+                        $load_fse = true;
482
+                    }
483 483
 
484
-					// flatpickr
485
-					wp_register_style( 'flatpickr', $this->url.'assets'.$bs_ver.'/css/flatpickr.min.css', array(), $this->version );
484
+                    // flatpickr
485
+                    wp_register_style( 'flatpickr', $this->url.'assets'.$bs_ver.'/css/flatpickr.min.css', array(), $this->version );
486 486
 
487
-					// fix some wp-admin issues
488
-					if(is_admin()){
489
-						$custom_css = "
487
+                    // fix some wp-admin issues
488
+                    if(is_admin()){
489
+                        $custom_css = "
490 490
                 body{
491 491
                     background-color: #f1f1f1;
492 492
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -526,63 +526,63 @@  discard block
 block discarded – undo
526 526
 				}
527 527
                 ";
528 528
 
529
-						// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
530
-						$custom_css .= "
529
+                        // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
530
+                        $custom_css .= "
531 531
 						.edit-post-sidebar input[type=color].components-text-control__input{
532 532
 						    padding: 0;
533 533
 						}
534 534
 					";
535
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
536
-					}
537
-
538
-					// custom changes
539
-					if ( $load_fse ) {
540
-						wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
-					}else{
542
-						wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
543
-					}
544
-				}
545
-			}
546
-		}
547
-
548
-		/**
549
-		 * Get inline script used if bootstrap enqueued
550
-		 *
551
-		 * If this remains small then its best to use this than to add another JS file.
552
-		 */
553
-		public function inline_script() {
554
-            global $aui_bs5;
555
-			// Flatpickr calendar locale
556
-			$flatpickr_locale = self::flatpickr_locale();
535
+                        wp_add_inline_style( 'ayecode-ui', $custom_css );
536
+                    }
557 537
 
558
-			ob_start();
559
-			if ( $aui_bs5 ) {
560
-				include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
-			}else{
562
-				include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
538
+                    // custom changes
539
+                    if ( $load_fse ) {
540
+                        wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
+                    }else{
542
+                        wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
543
+                    }
544
+                }
545
+            }
546
+        }
547
+
548
+        /**
549
+         * Get inline script used if bootstrap enqueued
550
+         *
551
+         * If this remains small then its best to use this than to add another JS file.
552
+         */
553
+        public function inline_script() {
554
+            global $aui_bs5;
555
+            // Flatpickr calendar locale
556
+            $flatpickr_locale = self::flatpickr_locale();
557
+
558
+            ob_start();
559
+            if ( $aui_bs5 ) {
560
+                include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
+            }else{
562
+                include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
563 563
             }
564 564
 
565
-			$output = ob_get_clean();
565
+            $output = ob_get_clean();
566 566
 
567
-			/*
567
+            /*
568 568
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
569 569
 			 */
570
-			return str_replace( array(
571
-				'<script>',
572
-				'</script>'
573
-			), '', self::minify_js($output) );
574
-		}
575
-
576
-
577
-		/**
578
-		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
579
-		 *
580
-		 * @TODO we may need this when other conflicts arrise.
581
-		 * @return mixed
582
-		 */
583
-		public static function bs3_compat_js() {
584
-			ob_start();
585
-			?>
570
+            return str_replace( array(
571
+                '<script>',
572
+                '</script>'
573
+            ), '', self::minify_js($output) );
574
+        }
575
+
576
+
577
+        /**
578
+         * JS to help with conflict issues with other plugins and themes using bootstrap v3.
579
+         *
580
+         * @TODO we may need this when other conflicts arrise.
581
+         * @return mixed
582
+         */
583
+        public static function bs3_compat_js() {
584
+            ob_start();
585
+            ?>
586 586
             <script>
587 587
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
588 588
                 /* With Avada builder */
@@ -590,20 +590,20 @@  discard block
 block discarded – undo
590 590
 				<?php } ?>
591 591
             </script>
592 592
 			<?php
593
-			return str_replace( array(
594
-				'<script>',
595
-				'</script>'
596
-			), '', ob_get_clean());
597
-		}
598
-
599
-		/**
600
-		 * Get inline script used if bootstrap file browser enqueued.
601
-		 *
602
-		 * If this remains small then its best to use this than to add another JS file.
603
-		 */
604
-		public function inline_script_file_browser(){
605
-			ob_start();
606
-			?>
593
+            return str_replace( array(
594
+                '<script>',
595
+                '</script>'
596
+            ), '', ob_get_clean());
597
+        }
598
+
599
+        /**
600
+         * Get inline script used if bootstrap file browser enqueued.
601
+         *
602
+         * If this remains small then its best to use this than to add another JS file.
603
+         */
604
+        public function inline_script_file_browser(){
605
+            ob_start();
606
+            ?>
607 607
             <script>
608 608
                 // run on doc ready
609 609
                 jQuery(document).ready(function () {
@@ -611,127 +611,127 @@  discard block
 block discarded – undo
611 611
                 });
612 612
             </script>
613 613
 			<?php
614
-			$output = ob_get_clean();
614
+            $output = ob_get_clean();
615 615
 
616
-			/*
616
+            /*
617 617
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
618 618
 			 */
619
-			return str_replace( array(
620
-				'<script>',
621
-				'</script>'
622
-			), '', $output );
623
-		}
624
-
625
-		/**
626
-		 * Adds the Font Awesome JS.
627
-		 */
628
-		public function enqueue_scripts() {
629
-			if( is_admin() && !$this->is_aui_screen()){
630
-				// Don't add wp-admin scripts if not requested to.
631
-			} else {
632
-				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
633
-
634
-				$bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
635
-
636
-				// select2
637
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
638
-
639
-				// flatpickr
640
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version );
641
-
642
-				// iconpicker
643
-				if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644
-					wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
-				}else{
646
-					wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
647
-				}
619
+            return str_replace( array(
620
+                '<script>',
621
+                '</script>'
622
+            ), '', $output );
623
+        }
648 624
 
649
-				// Bootstrap file browser
650
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
651
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
625
+        /**
626
+         * Adds the Font Awesome JS.
627
+         */
628
+        public function enqueue_scripts() {
629
+            if( is_admin() && !$this->is_aui_screen()){
630
+                // Don't add wp-admin scripts if not requested to.
631
+            } else {
632
+                $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
652 633
 
653
-				$load_inline = false;
634
+                $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
654 635
 
655
-				// Load select2 only when required.
656
-				if ( $this->force_load_select2() ) {
657
-					$dependency = array( 'select2', 'jquery' );
658
-				} else {
659
-					$dependency = array( 'jquery' );
660
-				}
636
+                // select2
637
+                wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
661 638
 
662
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
663
-					// Bootstrap bundle
664
-					$url = $this->url . 'assets' . $bs_ver . '/js/bootstrap.bundle.min.js';
665
-					wp_register_script( 'bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat() );
666
-
667
-					// If in admin then add to footer for compatibility.
668
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
669
-
670
-					$script = $this->inline_script();
671
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
672
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
673
-					$url = $this->url . 'assets/js/popper.min.js'; // @todo we need to update this to bs5
674
-					wp_register_script( 'bootstrap-js-popper', $url, $dependency, $this->version );
675
-					wp_enqueue_script( 'bootstrap-js-popper' );
676
-					$load_inline = true;
677
-				} else {
678
-					$load_inline = true;
679
-				}
639
+                // flatpickr
640
+                wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version );
680 641
 
681
-				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
682
-				if ( $load_inline ) {
683
-					wp_register_script( 'bootstrap-dummy', '', $dependency );
684
-					wp_enqueue_script( 'bootstrap-dummy' );
642
+                // iconpicker
643
+                if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644
+                    wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
+                }else{
646
+                    wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
647
+                }
685 648
 
686
-					$script = $this->inline_script();
687
-					wp_add_inline_script( 'bootstrap-dummy', $script );
688
-				}
689
-			}
690
-		}
691
-
692
-		/**
693
-		 * Enqueue select2 if called.
694
-		 *
695
-		 * @since 0.2.29
696
-		 */
697
-		public function force_load_select2() {
698
-			global $aui_select2_enqueued;
699
-
700
-			$conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
701
-
702
-			if ( $conditional_select2 !== true ) {
703
-				return true;
704
-			}
705
-
706
-			$load = is_admin() && ! $aui_select2_enqueued;
707
-
708
-			return apply_filters( 'aui_force_load_select2', $load );
709
-		}
710
-
711
-		/**
712
-		 * Enqueue select2 if called.
713
-		 *
714
-		 * @since 0.2.29
715
-		 */
716
-		public function enqueue_select2() {
717
-			wp_enqueue_script( 'select2' );
718
-		}
719
-
720
-		/**
721
-		 * Enqueue flatpickr if called.
722
-		 */
723
-		public function enqueue_flatpickr(){
724
-			wp_enqueue_style( 'flatpickr' );
725
-			wp_enqueue_script( 'flatpickr' );
726
-		}
727
-
728
-		/**
729
-		 * Enqueue iconpicker if called.
730
-		 */
731
-		public function enqueue_iconpicker(){
732
-			wp_enqueue_style( 'iconpicker' );
733
-			wp_enqueue_script( 'iconpicker' );
734
-		}
649
+                // Bootstrap file browser
650
+                wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
651
+                wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
652
+
653
+                $load_inline = false;
654
+
655
+                // Load select2 only when required.
656
+                if ( $this->force_load_select2() ) {
657
+                    $dependency = array( 'select2', 'jquery' );
658
+                } else {
659
+                    $dependency = array( 'jquery' );
660
+                }
661
+
662
+                if ( $this->settings[ $js_setting ] == 'core-popper' ) {
663
+                    // Bootstrap bundle
664
+                    $url = $this->url . 'assets' . $bs_ver . '/js/bootstrap.bundle.min.js';
665
+                    wp_register_script( 'bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat() );
666
+
667
+                    // If in admin then add to footer for compatibility.
668
+                    is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
669
+
670
+                    $script = $this->inline_script();
671
+                    wp_add_inline_script( 'bootstrap-js-bundle', $script );
672
+                } elseif ( $this->settings[ $js_setting ] == 'popper' ) {
673
+                    $url = $this->url . 'assets/js/popper.min.js'; // @todo we need to update this to bs5
674
+                    wp_register_script( 'bootstrap-js-popper', $url, $dependency, $this->version );
675
+                    wp_enqueue_script( 'bootstrap-js-popper' );
676
+                    $load_inline = true;
677
+                } else {
678
+                    $load_inline = true;
679
+                }
680
+
681
+                // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
682
+                if ( $load_inline ) {
683
+                    wp_register_script( 'bootstrap-dummy', '', $dependency );
684
+                    wp_enqueue_script( 'bootstrap-dummy' );
685
+
686
+                    $script = $this->inline_script();
687
+                    wp_add_inline_script( 'bootstrap-dummy', $script );
688
+                }
689
+            }
690
+        }
691
+
692
+        /**
693
+         * Enqueue select2 if called.
694
+         *
695
+         * @since 0.2.29
696
+         */
697
+        public function force_load_select2() {
698
+            global $aui_select2_enqueued;
699
+
700
+            $conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
701
+
702
+            if ( $conditional_select2 !== true ) {
703
+                return true;
704
+            }
705
+
706
+            $load = is_admin() && ! $aui_select2_enqueued;
707
+
708
+            return apply_filters( 'aui_force_load_select2', $load );
709
+        }
710
+
711
+        /**
712
+         * Enqueue select2 if called.
713
+         *
714
+         * @since 0.2.29
715
+         */
716
+        public function enqueue_select2() {
717
+            wp_enqueue_script( 'select2' );
718
+        }
719
+
720
+        /**
721
+         * Enqueue flatpickr if called.
722
+         */
723
+        public function enqueue_flatpickr(){
724
+            wp_enqueue_style( 'flatpickr' );
725
+            wp_enqueue_script( 'flatpickr' );
726
+        }
727
+
728
+        /**
729
+         * Enqueue iconpicker if called.
730
+         */
731
+        public function enqueue_iconpicker(){
732
+            wp_enqueue_style( 'iconpicker' );
733
+            wp_enqueue_script( 'iconpicker' );
734
+        }
735 735
 
736 736
         /**
737 737
          * Get the url path to the current folder.
@@ -766,173 +766,173 @@  discard block
 block discarded – undo
766 766
             return trailingslashit($url);
767 767
         }
768 768
 
769
-		/**
770
-		 * Get the url path to the current folder.
771
-		 * @todo remove
772
-		 * @return string
773
-		 */
774
-		public function get_url_old() {
775
-
776
-			$url = '';
777
-			// check if we are inside a plugin
778
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
779
-
780
-			// add check in-case user has changed wp-content dir name.
781
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
782
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
783
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
784
-
785
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
786
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
787
-			}
788
-
789
-			return $url;
790
-		}
791
-
792
-		/**
793
-		 * Register the database settings with WordPress.
794
-		 */
795
-		public function register_settings() {
796
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
797
-		}
798
-
799
-		/**
800
-		 * Add the WordPress settings menu item.
801
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
802
-		 */
803
-		public function menu_item() {
804
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
805
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
806
-				$this,
807
-				'settings_page'
808
-			) );
809
-		}
810
-
811
-		/**
812
-		 * Get a list of themes and their default JS settings.
813
-		 *
814
-		 * @return array
815
-		 */
816
-		public function theme_js_settings(){
817
-			return array(
818
-				'ayetheme' => 'popper',
819
-				'listimia' => 'required',
820
-				'listimia_backend' => 'core-popper',
821
-				//'avada'    => 'required', // removed as we now add compatibility
822
-			);
823
-		}
824
-
825
-		/**
769
+        /**
770
+         * Get the url path to the current folder.
771
+         * @todo remove
772
+         * @return string
773
+         */
774
+        public function get_url_old() {
775
+
776
+            $url = '';
777
+            // check if we are inside a plugin
778
+            $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
779
+
780
+            // add check in-case user has changed wp-content dir name.
781
+            $wp_content_folder_name = basename(WP_CONTENT_DIR);
782
+            $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
783
+            $url_parts = explode("/$wp_content_folder_name/",plugins_url());
784
+
785
+            if(!empty($url_parts[0]) && !empty($dir_parts[1])){
786
+                $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
787
+            }
788
+
789
+            return $url;
790
+        }
791
+
792
+        /**
793
+         * Register the database settings with WordPress.
794
+         */
795
+        public function register_settings() {
796
+            register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
797
+        }
798
+
799
+        /**
800
+         * Add the WordPress settings menu item.
801
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
802
+         */
803
+        public function menu_item() {
804
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
805
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
806
+                $this,
807
+                'settings_page'
808
+            ) );
809
+        }
810
+
811
+        /**
812
+         * Get a list of themes and their default JS settings.
813
+         *
814
+         * @return array
815
+         */
816
+        public function theme_js_settings(){
817
+            return array(
818
+                'ayetheme' => 'popper',
819
+                'listimia' => 'required',
820
+                'listimia_backend' => 'core-popper',
821
+                //'avada'    => 'required', // removed as we now add compatibility
822
+            );
823
+        }
824
+
825
+        /**
826 826
          * Get the date the site was installed.
827 827
          *
828
-		 * @return false|string
829
-		 */
828
+         * @return false|string
829
+         */
830 830
         public function get_site_install_date() {
831
-	        global $wpdb; // This gives you access to the WordPress database object
831
+            global $wpdb; // This gives you access to the WordPress database object
832 832
 
833
-	        // Prepare the SQL query to get the oldest registration date
834
-	        $query = "SELECT MIN(user_registered) AS oldest_registration_date FROM {$wpdb->users}";
833
+            // Prepare the SQL query to get the oldest registration date
834
+            $query = "SELECT MIN(user_registered) AS oldest_registration_date FROM {$wpdb->users}";
835 835
 
836
-	        // Execute the query
837
-	        $date = $wpdb->get_var( $query ); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
836
+            // Execute the query
837
+            $date = $wpdb->get_var( $query ); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
838 838
 
839
-	        return $date ? $date : false;
839
+            return $date ? $date : false;
840 840
         }
841 841
 
842
-		/**
843
-		 * Show admin notice if backend scripts not loaded.
844
-		 */
845
-		public function show_admin_version_notice(){
846
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings" );
847
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">View Settings</a>';
848
-			$message = __( '<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)')." " .$button;
849
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
850
-		}
851
-
852
-		/**
853
-		 * Get the current Font Awesome output settings.
854
-		 *
855
-		 * @return array The array of settings.
856
-		 */
857
-		public function get_settings() {
858
-			$db_settings = get_option( 'ayecode-ui-settings' );
859
-
860
-			// Maybe show default version notice
861
-			if ( empty( $db_settings ) ) {
862
-				$site_install_date = new DateTime( self::get_site_install_date() );
863
-				$switch_over_date = new DateTime( "2024-02-01" );
864
-
865
-				if ( $site_install_date < $switch_over_date ) {
866
-					add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
867
-				}
868
-			}
869
-
870
-			$js_default = 'core-popper';
871
-			$js_default_backend = $js_default;
872
-
873
-			// maybe set defaults (if no settings set)
874
-			if(empty($db_settings)){
875
-				$active_theme = strtolower( get_template() ); // active parent theme.
876
-				$theme_js_settings = self::theme_js_settings();
877
-				if(isset($theme_js_settings[$active_theme])){
878
-					$js_default = $theme_js_settings[$active_theme];
879
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
880
-				}
881
-			}
842
+        /**
843
+         * Show admin notice if backend scripts not loaded.
844
+         */
845
+        public function show_admin_version_notice(){
846
+            $fix_url = admin_url("options-general.php?page=ayecode-ui-settings" );
847
+            $button = '<a href="'.esc_url($fix_url).'" class="button-primary">View Settings</a>';
848
+            $message = __( '<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)')." " .$button;
849
+            echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
850
+        }
882 851
 
883
-			/**
884
-			 * Filter the default settings.
885
-			 */
886
-			$defaults = apply_filters( 'ayecode-ui-default-settings', array(
887
-				'css'            => 'compatibility', // core, compatibility
888
-				'js'             => $js_default, // js to load, core-popper, popper
889
-				'html_font_size' => '16', // js to load, core-popper, popper
890
-				'css_backend'    => 'compatibility', // core, compatibility
891
-				'js_backend'     => $js_default_backend, // js to load, core-popper, popper
892
-				'disable_admin'  => '', // URL snippets to disable loading on admin
852
+        /**
853
+         * Get the current Font Awesome output settings.
854
+         *
855
+         * @return array The array of settings.
856
+         */
857
+        public function get_settings() {
858
+            $db_settings = get_option( 'ayecode-ui-settings' );
859
+
860
+            // Maybe show default version notice
861
+            if ( empty( $db_settings ) ) {
862
+                $site_install_date = new DateTime( self::get_site_install_date() );
863
+                $switch_over_date = new DateTime( "2024-02-01" );
864
+
865
+                if ( $site_install_date < $switch_over_date ) {
866
+                    add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
867
+                }
868
+            }
869
+
870
+            $js_default = 'core-popper';
871
+            $js_default_backend = $js_default;
872
+
873
+            // maybe set defaults (if no settings set)
874
+            if(empty($db_settings)){
875
+                $active_theme = strtolower( get_template() ); // active parent theme.
876
+                $theme_js_settings = self::theme_js_settings();
877
+                if(isset($theme_js_settings[$active_theme])){
878
+                    $js_default = $theme_js_settings[$active_theme];
879
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
880
+                }
881
+            }
882
+
883
+            /**
884
+             * Filter the default settings.
885
+             */
886
+            $defaults = apply_filters( 'ayecode-ui-default-settings', array(
887
+                'css'            => 'compatibility', // core, compatibility
888
+                'js'             => $js_default, // js to load, core-popper, popper
889
+                'html_font_size' => '16', // js to load, core-popper, popper
890
+                'css_backend'    => 'compatibility', // core, compatibility
891
+                'js_backend'     => $js_default_backend, // js to load, core-popper, popper
892
+                'disable_admin'  => '', // URL snippets to disable loading on admin
893 893
                 'bs_ver'         => '5', // The default bootstrap version to sue by default
894
-			), $db_settings );
894
+            ), $db_settings );
895 895
 
896
-			$settings = wp_parse_args( $db_settings, $defaults );
896
+            $settings = wp_parse_args( $db_settings, $defaults );
897 897
 
898
-			/**
899
-			 * Filter the Bootstrap settings.
900
-			 *
901
-			 * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
902
-			 */
903
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
904
-		}
898
+            /**
899
+             * Filter the Bootstrap settings.
900
+             *
901
+             * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
902
+             */
903
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
904
+        }
905 905
 
906 906
 
907
-		/**
908
-		 * The settings page html output.
909
-		 */
910
-		public function settings_page() {
911
-			if ( ! current_user_can( 'manage_options' ) ) {
912
-				wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
913
-			}
907
+        /**
908
+         * The settings page html output.
909
+         */
910
+        public function settings_page() {
911
+            if ( ! current_user_can( 'manage_options' ) ) {
912
+                wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
913
+            }
914 914
             $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
915 915
 
916
-			?>
916
+            ?>
917 917
             <div class="wrap">
918 918
                 <h1><?php echo esc_attr( $this->name ); ?></h1>
919 919
                 <p><?php echo esc_html( apply_filters( 'ayecode-ui-settings-message', __("Here you can adjust settings if you are having compatibility issues.", 'ayecode-connect' ) ) );?></p>
920 920
                 <form method="post" action="options.php">
921 921
 					<?php
922
-					settings_fields( 'ayecode-ui-settings' );
923
-					do_settings_sections( 'ayecode-ui-settings' );
924
-					?>
922
+                    settings_fields( 'ayecode-ui-settings' );
923
+                    do_settings_sections( 'ayecode-ui-settings' );
924
+                    ?>
925 925
 
926 926
                     <h2><?php esc_html_e( 'BootStrap Version', 'ayecode-connect' ); ?></h2>
927 927
                     <p><?php echo esc_html( apply_filters( 'ayecode-ui-version-settings-message', __("V5 is recommended, however if you have another plugin installed using v4, you may need to use v4 also.", 'ayecode-connect' ) ) );?></p>
928 928
 	                <div class="bsui"><?php
929
-	                if ( ! empty( $overrides ) ) {
930
-		                echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
931
-			                'type'=> 'info',
932
-			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
933
-		                ));
934
-	                }
935
-	                ?>
929
+                    if ( ! empty( $overrides ) ) {
930
+                        echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
931
+                            'type'=> 'info',
932
+                            'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
933
+                        ));
934
+                    }
935
+                    ?>
936 936
                     </div>
937 937
                     <table class="form-table wpbs-table-version-settings">
938 938
                         <tr valign="top">
@@ -1016,77 +1016,77 @@  discard block
 block discarded – undo
1016 1016
                     </table>
1017 1017
 
1018 1018
 					<?php
1019
-					submit_button();
1020
-					?>
1019
+                    submit_button();
1020
+                    ?>
1021 1021
                 </form>
1022 1022
                 <div id="wpbs-version" data-aui-source="<?php echo esc_attr( $this->get_load_source() ); ?>"><?php echo esc_html( $this->version ); ?></div>
1023 1023
             </div>
1024 1024
 			<?php
1025
-		}
1025
+        }
1026 1026
 
1027 1027
         public function get_load_source(){
1028
-	        $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1029
-	        $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1030
-
1031
-	        // Find source plugin/theme of SD
1032
-	        $source = array();
1033
-	        if ( strpos( $file, $plugins_dir ) !== false ) {
1034
-		        $source = explode( "/", plugin_basename( $file ) );
1035
-	        } else if ( function_exists( 'get_theme_root' ) ) {
1036
-		        $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1037
-
1038
-		        if ( strpos( $file, $themes_dir ) !== false ) {
1039
-			        $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1040
-		        }
1041
-	        }
1028
+            $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1029
+            $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1030
+
1031
+            // Find source plugin/theme of SD
1032
+            $source = array();
1033
+            if ( strpos( $file, $plugins_dir ) !== false ) {
1034
+                $source = explode( "/", plugin_basename( $file ) );
1035
+            } else if ( function_exists( 'get_theme_root' ) ) {
1036
+                $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1037
+
1038
+                if ( strpos( $file, $themes_dir ) !== false ) {
1039
+                    $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1040
+                }
1041
+            }
1042 1042
 
1043 1043
             return isset($source[0]) ? esc_attr($source[0]) : '';
1044 1044
         }
1045 1045
 
1046
-		public function customizer_settings($wp_customize){
1047
-			$wp_customize->add_section('aui_settings', array(
1048
-				'title'    => __('AyeCode UI', 'ayecode-connect' ),
1049
-				'priority' => 120,
1050
-			));
1051
-
1052
-			//  =============================
1053
-			//  = Color Picker              =
1054
-			//  =============================
1055
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1056
-				'default'           => AUI_PRIMARY_COLOR,
1057
-				'sanitize_callback' => 'sanitize_hex_color',
1058
-				'capability'        => 'edit_theme_options',
1059
-				'type'              => 'option',
1060
-				'transport'         => 'refresh',
1061
-			));
1062
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1063
-				'label'    => __('Primary Color', 'ayecode-connect' ),
1064
-				'section'  => 'aui_settings',
1065
-				'settings' => 'aui_options[color_primary]',
1066
-			)));
1067
-
1068
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1069
-				'default'           => '#6c757d',
1070
-				'sanitize_callback' => 'sanitize_hex_color',
1071
-				'capability'        => 'edit_theme_options',
1072
-				'type'              => 'option',
1073
-				'transport'         => 'refresh',
1074
-			));
1075
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1076
-				'label'    => __('Secondary Color', 'ayecode-connect' ),
1077
-				'section'  => 'aui_settings',
1078
-				'settings' => 'aui_options[color_secondary]',
1079
-			)));
1080
-		}
1081
-
1082
-		/**
1083
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1084
-		 *
1085
-		 * @return mixed
1086
-		 */
1087
-		public static function bs3_compat_css() {
1088
-			ob_start();
1089
-			?>
1046
+        public function customizer_settings($wp_customize){
1047
+            $wp_customize->add_section('aui_settings', array(
1048
+                'title'    => __('AyeCode UI', 'ayecode-connect' ),
1049
+                'priority' => 120,
1050
+            ));
1051
+
1052
+            //  =============================
1053
+            //  = Color Picker              =
1054
+            //  =============================
1055
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1056
+                'default'           => AUI_PRIMARY_COLOR,
1057
+                'sanitize_callback' => 'sanitize_hex_color',
1058
+                'capability'        => 'edit_theme_options',
1059
+                'type'              => 'option',
1060
+                'transport'         => 'refresh',
1061
+            ));
1062
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1063
+                'label'    => __('Primary Color', 'ayecode-connect' ),
1064
+                'section'  => 'aui_settings',
1065
+                'settings' => 'aui_options[color_primary]',
1066
+            )));
1067
+
1068
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1069
+                'default'           => '#6c757d',
1070
+                'sanitize_callback' => 'sanitize_hex_color',
1071
+                'capability'        => 'edit_theme_options',
1072
+                'type'              => 'option',
1073
+                'transport'         => 'refresh',
1074
+            ));
1075
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1076
+                'label'    => __('Secondary Color', 'ayecode-connect' ),
1077
+                'section'  => 'aui_settings',
1078
+                'settings' => 'aui_options[color_secondary]',
1079
+            )));
1080
+        }
1081
+
1082
+        /**
1083
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1084
+         *
1085
+         * @return mixed
1086
+         */
1087
+        public static function bs3_compat_css() {
1088
+            ob_start();
1089
+            ?>
1090 1090
             <style>
1091 1091
                 /* Bootstrap 3 compatibility */
1092 1092
                 body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1115,374 +1115,374 @@  discard block
 block discarded – undo
1115 1115
                 <?php } ?>
1116 1116
             </style>
1117 1117
 			<?php
1118
-			return str_replace( array(
1119
-				'<style>',
1120
-				'</style>'
1121
-			), '', self::minify_css( ob_get_clean() ) );
1122
-		}
1118
+            return str_replace( array(
1119
+                '<style>',
1120
+                '</style>'
1121
+            ), '', self::minify_css( ob_get_clean() ) );
1122
+        }
1123 1123
 
1124
-		public static function custom_css( $compatibility = true, $is_fse = false ) {
1125
-			global $aui_bs5;
1124
+        public static function custom_css( $compatibility = true, $is_fse = false ) {
1125
+            global $aui_bs5;
1126 1126
 
1127
-			$colors = array();
1127
+            $colors = array();
1128 1128
 
1129
-			if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1130
-				$setting = wp_get_global_settings();
1129
+            if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1130
+                $setting = wp_get_global_settings();
1131 1131
 
1132
-				if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1133
-					foreach ( $setting['color']['palette']['theme'] as $color ) {
1134
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1135
-					}
1136
-				}
1132
+                if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1133
+                    foreach ( $setting['color']['palette']['theme'] as $color ) {
1134
+                        $colors[$color['slug']] = esc_attr( $color['color'] );
1135
+                    }
1136
+                }
1137 1137
 
1138
-				if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1139
-					foreach ( $setting['color']['palette']['custom'] as $color ) {
1140
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1141
-					}
1142
-				}
1143
-			} else {
1144
-				$settings = get_option( 'aui_options' );
1145
-
1146
-				$colors = array(
1147
-					'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1148
-					'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1149
-				);
1150
-			}
1151
-
1152
-			ob_start();
1153
-			?><style><?php
1154
-			// BS v3 compat
1155
-			if( self::is_bs3_compat() ){
1156
-				echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1157
-			}
1158
-
1159
-			//$is_fse = false;
1160
-			//if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1161
-				//$is_fse = true;
1162
-			//}
1163
-
1164
-			$custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1165
-			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1138
+                if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1139
+                    foreach ( $setting['color']['palette']['custom'] as $color ) {
1140
+                        $colors[$color['slug']] = esc_attr( $color['color'] );
1141
+                    }
1142
+                }
1143
+            } else {
1144
+                $settings = get_option( 'aui_options' );
1145
+
1146
+                $colors = array(
1147
+                    'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1148
+                    'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1149
+                );
1150
+            }
1151
+
1152
+            ob_start();
1153
+            ?><style><?php
1154
+            // BS v3 compat
1155
+            if( self::is_bs3_compat() ){
1156
+                echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1157
+            }
1158
+
1159
+            //$is_fse = false;
1160
+            //if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1161
+                //$is_fse = true;
1162
+            //}
1163
+
1164
+            $custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1165
+            $custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1166 1166
             $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1167
-			//$bs_custom_css = true; // Force true to fix any color issue.
1167
+            //$bs_custom_css = true; // Force true to fix any color issue.
1168 1168
 
1169
-			$colors_css = '';
1170
-			if ( ! empty( $colors ) && $bs_custom_css ) {
1171
-				$d_colors = self::get_colors(true);
1169
+            $colors_css = '';
1170
+            if ( ! empty( $colors ) && $bs_custom_css ) {
1171
+                $d_colors = self::get_colors(true);
1172 1172
 
1173
-				foreach ( $colors as $key => $color ) {
1174
-					if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1175
-						$var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1176
-						$compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1173
+                foreach ( $colors as $key => $color ) {
1174
+                    if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1175
+                        $var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1176
+                        $compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1177 1177
 
1178
-						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1179
-					}
1180
-				}
1181
-			}
1178
+                        $colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1179
+                    }
1180
+                }
1181
+            }
1182 1182
 
1183
-			if ( $colors_css ) {
1184
-				echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1185
-			}
1183
+            if ( $colors_css ) {
1184
+                echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1185
+            }
1186 1186
 
1187
-			// Set admin bar z-index lower when modal is open.
1188
-			echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1187
+            // Set admin bar z-index lower when modal is open.
1188
+            echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1189 1189
 
1190
-			if ( is_admin() ) {
1191
-				echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1192
-			}
1190
+            if ( is_admin() ) {
1191
+                echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1192
+            }
1193 1193
 
1194
-			$custom_css = '';
1194
+            $custom_css = '';
1195 1195
 
1196
-			if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1197
-				$css = '';
1198
-				$theme_settings = wp_get_global_styles();
1196
+            if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1197
+                $css = '';
1198
+                $theme_settings = wp_get_global_styles();
1199 1199
 
1200
-				// Font face
1201
-				if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1202
-					$t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1203
-					$css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1204
-				}
1200
+                // Font face
1201
+                if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1202
+                    $t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1203
+                    $css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1204
+                }
1205 1205
 
1206
-				// font size
1207
-				if( !empty( $theme_settings['typography']['fontSize'] ) ){
1208
-					$css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1209
-				}
1206
+                // font size
1207
+                if( !empty( $theme_settings['typography']['fontSize'] ) ){
1208
+                    $css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1209
+                }
1210 1210
 
1211
-				// line height
1212
-				 if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1213
-					$css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1214
-				}
1211
+                // line height
1212
+                    if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1213
+                    $css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1214
+                }
1215 1215
 
1216 1216
 
1217
-				   // font weight
1218
-				 if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1219
-					$css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1220
-				}
1217
+                    // font weight
1218
+                    if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1219
+                    $css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1220
+                }
1221 1221
 
1222
-				// Background
1223
-				 if( !empty( $theme_settings['color']['background'] ) ){
1224
-					$css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1225
-				}
1222
+                // Background
1223
+                    if( !empty( $theme_settings['color']['background'] ) ){
1224
+                    $css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1225
+                }
1226 1226
 
1227
-				 // Background Gradient
1228
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1229
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1230
-				}
1227
+                    // Background Gradient
1228
+                    if( !empty( $theme_settings['color']['gradient'] ) ){
1229
+                    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1230
+                }
1231 1231
 
1232
-				   // Background Gradient
1233
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1234
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1235
-				}
1232
+                    // Background Gradient
1233
+                    if( !empty( $theme_settings['color']['gradient'] ) ){
1234
+                    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1235
+                }
1236 1236
 
1237
-				// text color
1238
-				if( !empty( $theme_settings['color']['text'] ) ){
1239
-					$css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1240
-				}
1237
+                // text color
1238
+                if( !empty( $theme_settings['color']['text'] ) ){
1239
+                    $css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1240
+                }
1241 1241
 
1242 1242
 
1243
-				// link colors
1244
-				if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1245
-					$css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1246
-				}
1247
-				if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1248
-					$css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1249
-				}
1243
+                // link colors
1244
+                if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1245
+                    $css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1246
+                }
1247
+                if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1248
+                    $css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1249
+                }
1250 1250
 
1251
-				if($css){
1252
-					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1253
-				}
1251
+                if($css){
1252
+                    $custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1253
+                }
1254 1254
 
1255
-				$bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1255
+                $bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1256 1256
 
1257
-				// Headings
1258
-				$headings_css = '';
1259
-				if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1260
-					$headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1261
-				}
1257
+                // Headings
1258
+                $headings_css = '';
1259
+                if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1260
+                    $headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1261
+                }
1262 1262
 
1263
-				// heading background
1264
-				if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1265
-					$headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1266
-				}
1263
+                // heading background
1264
+                if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1265
+                    $headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1266
+                }
1267 1267
 
1268
-				 // heading font family
1269
-				if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1270
-					$headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1271
-				}
1268
+                    // heading font family
1269
+                if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1270
+                    $headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1271
+                }
1272 1272
 
1273
-				if( $headings_css ){
1274
-					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1275
-				}
1273
+                if( $headings_css ){
1274
+                    $custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1275
+                }
1276 1276
 
1277
-				$hs = array('h1','h2','h3','h4','h5','h6');
1277
+                $hs = array('h1','h2','h3','h4','h5','h6');
1278 1278
 
1279
-				foreach($hs as $hn){
1280
-					$h_css = '';
1281
-					 if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1282
-						$h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1283
-					 }
1279
+                foreach($hs as $hn){
1280
+                    $h_css = '';
1281
+                        if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1282
+                        $h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1283
+                        }
1284 1284
 
1285
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1286
-						$h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1287
-					 }
1285
+                        if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1286
+                        $h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1287
+                        }
1288 1288
 
1289
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1290
-						$h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1291
-					 }
1289
+                        if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1290
+                        $h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1291
+                        }
1292 1292
 
1293
-					 if($h_css){
1294
-						$custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1295
-					 }
1296
-				}
1297
-			}
1293
+                        if($h_css){
1294
+                        $custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1295
+                        }
1296
+                }
1297
+            }
1298 1298
 			
1299
-			if ( $custom_css ) {
1300
-				echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1301
-			}
1299
+            if ( $custom_css ) {
1300
+                echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1301
+            }
1302 1302
 
1303
-			// Pagination on Hello Elementor theme.
1304
-			if ( function_exists( 'hello_elementor_setup' ) ) {
1305
-				echo '.aui-nav-links .pagination{justify-content:inherit}';
1306
-			}
1303
+            // Pagination on Hello Elementor theme.
1304
+            if ( function_exists( 'hello_elementor_setup' ) ) {
1305
+                echo '.aui-nav-links .pagination{justify-content:inherit}';
1306
+            }
1307 1307
 
1308 1308
             // Astra theme - when woocommerce active they add compatibility CSS which breaks select2 in modals
1309 1309
             if( defined('ASTRA_THEME_VERSION')){
1310 1310
                 echo '.woocommerce-js.modal-open .select2-container .select2-dropdown, .woocommerce-js.modal-open .select2-container .select2-search__field, .woocommerce-page.modal-open .select2-container .select2-dropdown, .woocommerce-page.modal-open .select2-container .select2-search__field{z-index: 1056;}';
1311 1311
             }
1312 1312
 
1313
-			?></style><?php
1314
-			$custom_css = ob_get_clean();
1313
+            ?></style><?php
1314
+            $custom_css = ob_get_clean();
1315 1315
 
1316
-			/*
1316
+            /*
1317 1317
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1318 1318
 			 */
1319
-			return str_replace( array(
1320
-				'<style>',
1321
-				'</style>'
1322
-			), '', self::minify_css( $custom_css ) );
1323
-		}
1324
-
1325
-		/**
1326
-		 * Check if we should add booststrap 3 compatibility changes.
1327
-		 *
1328
-		 * @return bool
1329
-		 */
1330
-		public static function is_bs3_compat(){
1331
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1332
-		}
1333
-
1334
-		public static function hex_to_rgb( $hex ) {
1335
-			// Remove '#' if present
1336
-			$hex = str_replace( '#', '', $hex );
1337
-
1338
-			// Check if input is RGB
1339
-			if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1340
-				$_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1341
-
1342
-				$rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1343
-				$rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1344
-				$rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1345
-
1346
-				return $rgb;
1347
-			}
1348
-
1349
-			// Convert 3-digit hex to 6-digit hex
1350
-			if ( strlen( $hex ) == 3 ) {
1351
-				$hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1352
-			}
1353
-
1354
-			// Convert hex to RGB
1355
-			$r = hexdec( substr( $hex, 0, 2 ) );
1356
-			$g = hexdec( substr( $hex, 2, 2 ) );
1357
-			$b = hexdec( substr( $hex, 4, 2 ) );
1358
-
1359
-			// Return RGB values as an array
1360
-			return $r . ',' . $g . ',' . $b;
1361
-		}
1362
-
1363
-		/**
1364
-		 * Build the CSS to overwrite a bootstrap color variable.
1365
-		 *
1366
-		 * @param $type
1367
-		 * @param $color_code
1368
-		 * @param $compatibility
1369
-		 *
1370
-		 * @return string
1371
-		 */
1372
-		public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1373
-			global $aui_bs5;
1374
-
1375
-			$is_var = false;
1376
-			$is_custom = strpos($type, 'custom-') !== false ? true : false;
1377
-			if(!$color_code){return '';}
1378
-			if(strpos($color_code, 'var') !== false){
1379
-				//if(!sanitize_hex_color($color_code)){
1380
-				$color_code = esc_attr($color_code);
1381
-				$is_var = true;
1319
+            return str_replace( array(
1320
+                '<style>',
1321
+                '</style>'
1322
+            ), '', self::minify_css( $custom_css ) );
1323
+        }
1324
+
1325
+        /**
1326
+         * Check if we should add booststrap 3 compatibility changes.
1327
+         *
1328
+         * @return bool
1329
+         */
1330
+        public static function is_bs3_compat(){
1331
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1332
+        }
1333
+
1334
+        public static function hex_to_rgb( $hex ) {
1335
+            // Remove '#' if present
1336
+            $hex = str_replace( '#', '', $hex );
1337
+
1338
+            // Check if input is RGB
1339
+            if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1340
+                $_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1341
+
1342
+                $rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1343
+                $rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1344
+                $rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1345
+
1346
+                return $rgb;
1347
+            }
1348
+
1349
+            // Convert 3-digit hex to 6-digit hex
1350
+            if ( strlen( $hex ) == 3 ) {
1351
+                $hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1352
+            }
1353
+
1354
+            // Convert hex to RGB
1355
+            $r = hexdec( substr( $hex, 0, 2 ) );
1356
+            $g = hexdec( substr( $hex, 2, 2 ) );
1357
+            $b = hexdec( substr( $hex, 4, 2 ) );
1358
+
1359
+            // Return RGB values as an array
1360
+            return $r . ',' . $g . ',' . $b;
1361
+        }
1362
+
1363
+        /**
1364
+         * Build the CSS to overwrite a bootstrap color variable.
1365
+         *
1366
+         * @param $type
1367
+         * @param $color_code
1368
+         * @param $compatibility
1369
+         *
1370
+         * @return string
1371
+         */
1372
+        public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1373
+            global $aui_bs5;
1374
+
1375
+            $is_var = false;
1376
+            $is_custom = strpos($type, 'custom-') !== false ? true : false;
1377
+            if(!$color_code){return '';}
1378
+            if(strpos($color_code, 'var') !== false){
1379
+                //if(!sanitize_hex_color($color_code)){
1380
+                $color_code = esc_attr($color_code);
1381
+                $is_var = true;
1382 1382
 //				$color_code = "rgba($color_code, 0.5)";
1383 1383
 //                echo '###1'.$color_code.'###';//exit;
1384
-			}
1384
+            }
1385 1385
 
1386 1386
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1387 1387
 
1388
-			if(!$color_code){return '';}
1388
+            if(!$color_code){return '';}
1389 1389
 
1390
-			$rgb = self::hex_to_rgb($hex);
1390
+            $rgb = self::hex_to_rgb($hex);
1391 1391
 
1392
-			if($compatibility===true || $compatibility===1){
1393
-				$compatibility = '.bsui';
1394
-			}elseif(!$compatibility){
1395
-				$compatibility = '';
1396
-			}else{
1397
-				$compatibility = esc_attr($compatibility);
1398
-			}
1392
+            if($compatibility===true || $compatibility===1){
1393
+                $compatibility = '.bsui';
1394
+            }elseif(!$compatibility){
1395
+                $compatibility = '';
1396
+            }else{
1397
+                $compatibility = esc_attr($compatibility);
1398
+            }
1399 1399
 
1400
-			$prefix = $compatibility ? $compatibility . " " : "";
1400
+            $prefix = $compatibility ? $compatibility . " " : "";
1401 1401
 
1402 1402
 
1403 1403
             $output = '';
1404 1404
 
1405 1405
 //            echo '####'.$color_code;exit;
1406 1406
 
1407
-			$type = sanitize_html_class($type);
1407
+            $type = sanitize_html_class($type);
1408
+
1409
+            /**
1410
+             * c = color, b = background color, o = border-color, f = fill
1411
+             */
1412
+            $selectors = array(
1413
+                ".btn-{$type}"                                              => array( 'b', 'o' ),
1414
+                ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1415
+                ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1416
+                ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1417
+                ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1418
+                ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1419
+                ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1420
+                ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1421
+                ".badge-{$type}"                                            => array( 'b' ),
1422
+                ".alert-{$type}"                                            => array( 'b', 'o' ),
1423
+                ".bg-{$type}"                                               => array( 'b', 'f' ),
1424
+                ".btn-link.btn-{$type}"                                     => array( 'c' ),
1425
+                ".text-{$type}"                                     => array( 'c' ),
1426
+            );
1427
+
1428
+            if ( $aui_bs5 ) {
1429
+                unset($selectors[".alert-{$type}" ]);
1430
+            }
1408 1431
 
1409
-			/**
1410
-			 * c = color, b = background color, o = border-color, f = fill
1411
-			 */
1412
-			$selectors = array(
1413
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1414
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1415
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1416
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1417
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1418
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1419
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1420
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1421
-				".badge-{$type}"                                            => array( 'b' ),
1422
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1423
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1424
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1425
-				".text-{$type}"                                     => array( 'c' ),
1426
-			);
1427
-
1428
-			if ( $aui_bs5 ) {
1429
-				unset($selectors[".alert-{$type}" ]);
1430
-			}
1431
-
1432
-			if ( $type == 'primary' ) {
1433
-				$selectors = $selectors + array(
1434
-						'a'                                                                                                    => array( 'c' ),
1435
-						'.btn-link'                                                                                            => array( 'c' ),
1436
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1437
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1438
-							'b',
1439
-							'o'
1440
-						),
1441
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1442
-							'b',
1443
-							'o'
1444
-						),
1445
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1446
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1447
-						'.page-link'                                                                                           => array( 'c' ),
1448
-						'.page-item.active .page-link'                                                                         => array(
1449
-							'b',
1450
-							'o'
1451
-						),
1452
-						'.progress-bar'                                                                                        => array( 'b' ),
1453
-						'.list-group-item.active'                                                                              => array(
1454
-							'b',
1455
-							'o'
1456
-						),
1457
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1458
-					);
1459
-			}
1432
+            if ( $type == 'primary' ) {
1433
+                $selectors = $selectors + array(
1434
+                        'a'                                                                                                    => array( 'c' ),
1435
+                        '.btn-link'                                                                                            => array( 'c' ),
1436
+                        '.dropdown-item.active'                                                                                => array( 'b' ),
1437
+                        '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1438
+                            'b',
1439
+                            'o'
1440
+                        ),
1441
+                        '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1442
+                            'b',
1443
+                            'o'
1444
+                        ),
1445
+                        '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1446
+                        '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1447
+                        '.page-link'                                                                                           => array( 'c' ),
1448
+                        '.page-item.active .page-link'                                                                         => array(
1449
+                            'b',
1450
+                            'o'
1451
+                        ),
1452
+                        '.progress-bar'                                                                                        => array( 'b' ),
1453
+                        '.list-group-item.active'                                                                              => array(
1454
+                            'b',
1455
+                            'o'
1456
+                        ),
1457
+                        '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1458
+                    );
1459
+            }
1460 1460
 
1461 1461
 
1462 1462
 
1463 1463
             // link
1464
-			if ( $type === 'primary' ) {
1465
-				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1466
-				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1467
-				$output .= $prefix . ' .navbar { --bs-nav-link-hover-color: '.esc_attr($color_code).'; --bs-navbar-hover-color: '.esc_attr($color_code).'; --bs-navbar-active-color: '.esc_attr($color_code).'; }';
1464
+            if ( $type === 'primary' ) {
1465
+                $output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1466
+                $output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1467
+                $output .= $prefix . ' .navbar { --bs-nav-link-hover-color: '.esc_attr($color_code).'; --bs-navbar-hover-color: '.esc_attr($color_code).'; --bs-navbar-active-color: '.esc_attr($color_code).'; }';
1468 1468
 
1469
-				$output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1470
-				$output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1469
+                $output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1470
+                $output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1471 1471
 
1472 1472
                 // dropdown
1473
-				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1473
+                $output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1474 1474
 
1475 1475
                 // pagination
1476
-				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1476
+                $output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1477 1477
 
1478
-			}
1478
+            }
1479 1479
 
1480
-			$output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1481
-			$output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1480
+            $output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1481
+            $output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1482 1482
 
1483
-			//  buttons
1484
-			$output .= $prefix . ' .btn-'.esc_attr($type).'{';
1485
-			$output .= ' 
1483
+            //  buttons
1484
+            $output .= $prefix . ' .btn-'.esc_attr($type).'{';
1485
+            $output .= ' 
1486 1486
             --bs-btn-bg: '.esc_attr($color_code).';
1487 1487
             --bs-btn-border-color: '.esc_attr($color_code).';
1488 1488
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1500,11 +1500,11 @@  discard block
 block discarded – undo
1500 1500
 //			--bs-btn-active-color: #fff;
1501 1501
 //			--bs-btn-disabled-color: #fff;
1502 1502
 //            ';
1503
-			$output .= '}';
1503
+            $output .= '}';
1504 1504
 
1505
-			//  buttons outline
1506
-			$output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1507
-			$output .= ' 
1505
+            //  buttons outline
1506
+            $output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1507
+            $output .= ' 
1508 1508
 			--bs-btn-color: '.esc_attr($color_code).';
1509 1509
             --bs-btn-border-color: '.esc_attr($color_code).';
1510 1510
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1522,37 +1522,37 @@  discard block
 block discarded – undo
1522 1522
 //			--bs-btn-active-color: #fff;
1523 1523
 //			--bs-btn-disabled-color: #fff;
1524 1524
 //            ';
1525
-			$output .= '}';
1525
+            $output .= '}';
1526 1526
 
1527 1527
 
1528 1528
             // button hover
1529
-			$output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1530
-			$output .= ' 
1529
+            $output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1530
+            $output .= ' 
1531 1531
             box-shadow: 0 0.25rem 0.25rem 0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb), .1), 0 0.375rem 0.75rem -0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb) , .4);
1532 1532
             }
1533 1533
             ';
1534 1534
 
1535 1535
 
1536
-			if ( $aui_bs5 ) {
1536
+            if ( $aui_bs5 ) {
1537 1537
 //				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1538
-				$output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1539
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1540
-			}
1538
+                $output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1539
+                $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1540
+            }
1541 1541
 
1542 1542
 
1543
-			if ( $is_custom ) {
1543
+            if ( $is_custom ) {
1544 1544
 
1545 1545
 //				echo '###'.$type;exit;
1546 1546
 
1547
-				// build rules into each type
1548
-				foreach($selectors as $selector => $types){
1549
-					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1550
-					$types = array_combine($types,$types);
1551
-					if(isset($types['c'])){$color[] = $selector;}
1552
-					if(isset($types['b'])){$background[] = $selector;}
1553
-					if(isset($types['o'])){$border[] = $selector;}
1554
-					if(isset($types['f'])){$fill[] = $selector;}
1555
-				}
1547
+                // build rules into each type
1548
+                foreach($selectors as $selector => $types){
1549
+                    $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1550
+                    $types = array_combine($types,$types);
1551
+                    if(isset($types['c'])){$color[] = $selector;}
1552
+                    if(isset($types['b'])){$background[] = $selector;}
1553
+                    if(isset($types['o'])){$border[] = $selector;}
1554
+                    if(isset($types['f'])){$fill[] = $selector;}
1555
+                }
1556 1556
 
1557 1557
 //				// build rules into each type
1558 1558
 //				foreach($important_selectors as $selector => $types){
@@ -1564,853 +1564,853 @@  discard block
 block discarded – undo
1564 1564
 //					if(isset($types['f'])){$fill_i[] = $selector;}
1565 1565
 //				}
1566 1566
 
1567
-				// add any color rules
1568
-				if(!empty($color)){
1569
-					$output .= implode(",",$color) . "{color: $color_code;} ";
1570
-				}
1571
-				if(!empty($color_i)){
1572
-					$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1573
-				}
1567
+                // add any color rules
1568
+                if(!empty($color)){
1569
+                    $output .= implode(",",$color) . "{color: $color_code;} ";
1570
+                }
1571
+                if(!empty($color_i)){
1572
+                    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1573
+                }
1574
+
1575
+                // add any background color rules
1576
+                if(!empty($background)){
1577
+                    $output .= implode(",",$background) . "{background-color: $color_code;} ";
1578
+                }
1579
+                if(!empty($background_i)){
1580
+                    $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1581
+//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1582
+                }
1583
+
1584
+                // add any border color rules
1585
+                if(!empty($border)){
1586
+                    $output .= implode(",",$border) . "{border-color: $color_code;} ";
1587
+                }
1588
+                if(!empty($border_i)){
1589
+                    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1590
+                }
1591
+
1592
+                // add any fill color rules
1593
+                if(!empty($fill)){
1594
+                    $output .= implode(",",$fill) . "{fill: $color_code;} ";
1595
+                }
1596
+                if(!empty($fill_i)){
1597
+                    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1598
+                }
1599
+
1600
+            }
1601
+
1602
+
1603
+
1604
+
1605
+            $transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1606
+            // darken
1607
+            $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1608
+            $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1609
+            $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1610
+            $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1611
+
1612
+            // lighten
1613
+            $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1614
+
1615
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1616
+            $op_25 = $color_code."40"; // 25% opacity
1617
+
1618
+
1619
+            // button states
1620
+            $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1621
+            $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1622
+//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1623
+            $output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1624
+            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1625
+            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1626
+            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
1627
+
1628
+            // text
1629
+//			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
1630
+
1631
+
1632
+//			if ( $type == 'primary' ) {
1633
+//				// dropdown's
1634
+//				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1635
+//
1636
+//				// input states
1637
+//				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1638
+//
1639
+//				// page link
1640
+//				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1641
+//			}
1642
+
1643
+            // alerts
1644
+            if ( $aui_bs5 ) {
1645
+//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1646
+                $output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1647
+            }
1648
+
1649
+            return $output;
1650
+        }
1651
+
1652
+        /**
1653
+         * Build the CSS to overwrite a bootstrap color variable.
1654
+         *
1655
+         * @param $type
1656
+         * @param $color_code
1657
+         * @param $compatibility
1658
+         *
1659
+         * @return string
1660
+         */
1661
+        public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1662
+            global $aui_bs5;
1663
+
1664
+            $is_var = false;
1665
+            if(!$color_code){return '';}
1666
+            if(strpos($color_code, 'var') !== false){
1667
+                //if(!sanitize_hex_color($color_code)){
1668
+                $color_code = esc_attr($color_code);
1669
+                $is_var = true;
1670
+//				$color_code = "rgba($color_code, 0.5)";
1671
+//                echo '###1'.$color_code.'###';//exit;
1672
+            }
1673
+
1674
+//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1675
+
1676
+            if(!$color_code){return '';}
1677
+
1678
+            $rgb = self::hex_to_rgb($hex);
1679
+
1680
+            if($compatibility===true || $compatibility===1){
1681
+                $compatibility = '.bsui';
1682
+            }elseif(!$compatibility){
1683
+                $compatibility = '';
1684
+            }else{
1685
+                $compatibility = esc_attr($compatibility);
1686
+            }
1687
+
1688
+
1689
+
1690
+//            echo '####'.$color_code;exit;
1691
+
1692
+            $type = sanitize_html_class($type);
1693
+
1694
+            /**
1695
+             * c = color, b = background color, o = border-color, f = fill
1696
+             */
1697
+            $selectors = array(
1698
+                ".btn-{$type}"                                              => array( 'b', 'o' ),
1699
+                ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1700
+                ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1701
+                ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1702
+                ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1703
+                ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1704
+                ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1705
+                ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1706
+                ".badge-{$type}"                                            => array( 'b' ),
1707
+                ".alert-{$type}"                                            => array( 'b', 'o' ),
1708
+                ".bg-{$type}"                                               => array( 'b', 'f' ),
1709
+                ".btn-link.btn-{$type}"                                     => array( 'c' ),
1710
+            );
1711
+
1712
+            if ( $aui_bs5 ) {
1713
+                unset($selectors[".alert-{$type}" ]);
1714
+            }
1715
+
1716
+            if ( $type == 'primary' ) {
1717
+                $selectors = $selectors + array(
1718
+                        'a'                                                                                                    => array( 'c' ),
1719
+                        '.btn-link'                                                                                            => array( 'c' ),
1720
+                        '.dropdown-item.active'                                                                                => array( 'b' ),
1721
+                        '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1722
+                            'b',
1723
+                            'o'
1724
+                        ),
1725
+                        '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1726
+                            'b',
1727
+                            'o'
1728
+                        ),
1729
+                        '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1730
+                        '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1731
+                        '.page-link'                                                                                           => array( 'c' ),
1732
+                        '.page-item.active .page-link'                                                                         => array(
1733
+                            'b',
1734
+                            'o'
1735
+                        ),
1736
+                        '.progress-bar'                                                                                        => array( 'b' ),
1737
+                        '.list-group-item.active'                                                                              => array(
1738
+                            'b',
1739
+                            'o'
1740
+                        ),
1741
+                        '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1742
+//				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1743
+//				    '.custom-range::-moz-range-thumb' => array('b'),
1744
+//				    '.custom-range::-ms-thumb' => array('b'),
1745
+                    );
1746
+            }
1747
+
1748
+            $important_selectors = array(
1749
+                ".bg-{$type}" => array('b','f'),
1750
+                ".border-{$type}" => array('o'),
1751
+                ".text-{$type}" => array('c'),
1752
+            );
1753
+
1754
+            $color = array();
1755
+            $color_i = array();
1756
+            $background = array();
1757
+            $background_i = array();
1758
+            $border = array();
1759
+            $border_i = array();
1760
+            $fill = array();
1761
+            $fill_i = array();
1762
+
1763
+            $output = '';
1764
+
1765
+            if ( $aui_bs5 ) {
1766
+//				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1767
+                $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1768
+            }
1769
+
1770
+            // build rules into each type
1771
+            foreach($selectors as $selector => $types){
1772
+                $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1773
+                $types = array_combine($types,$types);
1774
+                if(isset($types['c'])){$color[] = $selector;}
1775
+                if(isset($types['b'])){$background[] = $selector;}
1776
+                if(isset($types['o'])){$border[] = $selector;}
1777
+                if(isset($types['f'])){$fill[] = $selector;}
1778
+            }
1779
+
1780
+            // build rules into each type
1781
+            foreach($important_selectors as $selector => $types){
1782
+                $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1783
+                $types = array_combine($types,$types);
1784
+                if(isset($types['c'])){$color_i[] = $selector;}
1785
+                if(isset($types['b'])){$background_i[] = $selector;}
1786
+                if(isset($types['o'])){$border_i[] = $selector;}
1787
+                if(isset($types['f'])){$fill_i[] = $selector;}
1788
+            }
1789
+
1790
+            // add any color rules
1791
+            if(!empty($color)){
1792
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1793
+            }
1794
+            if(!empty($color_i)){
1795
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1796
+            }
1797
+
1798
+            // add any background color rules
1799
+            if(!empty($background)){
1800
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1801
+            }
1802
+            if(!empty($background_i)){
1803
+                $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1804
+//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1805
+            }
1806
+
1807
+            // add any border color rules
1808
+            if(!empty($border)){
1809
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1810
+            }
1811
+            if(!empty($border_i)){
1812
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1813
+            }
1814
+
1815
+            // add any fill color rules
1816
+            if(!empty($fill)){
1817
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1818
+            }
1819
+            if(!empty($fill_i)){
1820
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1821
+            }
1822
+
1823
+
1824
+            $prefix = $compatibility ? $compatibility . " " : "";
1825
+
1826
+            $transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1827
+            // darken
1828
+            $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1829
+            $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1830
+            $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1831
+            $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1832
+
1833
+            // lighten
1834
+            $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1835
+
1836
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1837
+            $op_25 = $color_code."40"; // 25% opacity
1838
+
1839
+
1840
+            // button states
1841
+            $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1842
+            $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1843
+//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1844
+            $output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1845
+            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1846
+            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1847
+
1848
+            if ( $type == 'primary' ) {
1849
+                // dropdown's
1850
+                $output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1851
+
1852
+                // input states
1853
+                $output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1854
+
1855
+                // page link
1856
+                $output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1857
+            }
1858
+
1859
+            // alerts
1860
+            if ( $aui_bs5 ) {
1861
+//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1862
+                $output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1863
+            }
1864
+
1865
+            return $output;
1866
+        }
1867
+
1868
+        /**
1869
+         *
1870
+         * @deprecated 0.1.76 Use css_overwrite()
1871
+         *
1872
+         * @param $color_code
1873
+         * @param $compatibility
1874
+         * @param $use_variable
1875
+         *
1876
+         * @return string
1877
+         */
1878
+        public static function css_primary($color_code,$compatibility, $use_variable = false){
1879
+
1880
+            if(!$use_variable){
1881
+                $color_code = sanitize_hex_color($color_code);
1882
+                if(!$color_code){return '';}
1883
+            }
1884
+
1885
+            /**
1886
+             * c = color, b = background color, o = border-color, f = fill
1887
+             */
1888
+            $selectors = array(
1889
+                'a' => array('c'),
1890
+                '.btn-primary' => array('b','o'),
1891
+                '.btn-primary.disabled' => array('b','o'),
1892
+                '.btn-primary:disabled' => array('b','o'),
1893
+                '.btn-outline-primary' => array('c','o'),
1894
+                '.btn-outline-primary:hover' => array('b','o'),
1895
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1896
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1897
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1898
+                '.btn-link' => array('c'),
1899
+                '.dropdown-item.active' => array('b'),
1900
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1901
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1902
+//				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1903
+//				'.custom-range::-moz-range-thumb' => array('b'),
1904
+//				'.custom-range::-ms-thumb' => array('b'),
1905
+                '.nav-pills .nav-link.active' => array('b'),
1906
+                '.nav-pills .show>.nav-link' => array('b'),
1907
+                '.page-link' => array('c'),
1908
+                '.page-item.active .page-link' => array('b','o'),
1909
+                '.badge-primary' => array('b'),
1910
+                '.alert-primary' => array('b','o'),
1911
+                '.progress-bar' => array('b'),
1912
+                '.list-group-item.active' => array('b','o'),
1913
+                '.bg-primary' => array('b','f'),
1914
+                '.btn-link.btn-primary' => array('c'),
1915
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1916
+            );
1917
+
1918
+            $important_selectors = array(
1919
+                '.bg-primary' => array('b','f'),
1920
+                '.border-primary' => array('o'),
1921
+                '.text-primary' => array('c'),
1922
+            );
1923
+
1924
+            $color = array();
1925
+            $color_i = array();
1926
+            $background = array();
1927
+            $background_i = array();
1928
+            $border = array();
1929
+            $border_i = array();
1930
+            $fill = array();
1931
+            $fill_i = array();
1932
+
1933
+            $output = '';
1934
+
1935
+            // build rules into each type
1936
+            foreach($selectors as $selector => $types){
1937
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1938
+                $types = array_combine($types,$types);
1939
+                if(isset($types['c'])){$color[] = $selector;}
1940
+                if(isset($types['b'])){$background[] = $selector;}
1941
+                if(isset($types['o'])){$border[] = $selector;}
1942
+                if(isset($types['f'])){$fill[] = $selector;}
1943
+            }
1944
+
1945
+            // build rules into each type
1946
+            foreach($important_selectors as $selector => $types){
1947
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1948
+                $types = array_combine($types,$types);
1949
+                if(isset($types['c'])){$color_i[] = $selector;}
1950
+                if(isset($types['b'])){$background_i[] = $selector;}
1951
+                if(isset($types['o'])){$border_i[] = $selector;}
1952
+                if(isset($types['f'])){$fill_i[] = $selector;}
1953
+            }
1954
+
1955
+            // add any color rules
1956
+            if(!empty($color)){
1957
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1958
+            }
1959
+            if(!empty($color_i)){
1960
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1961
+            }
1962
+
1963
+            // add any background color rules
1964
+            if(!empty($background)){
1965
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1966
+            }
1967
+            if(!empty($background_i)){
1968
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1969
+            }
1970
+
1971
+            // add any border color rules
1972
+            if(!empty($border)){
1973
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1974
+            }
1975
+            if(!empty($border_i)){
1976
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1977
+            }
1978
+
1979
+            // add any fill color rules
1980
+            if(!empty($fill)){
1981
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1982
+            }
1983
+            if(!empty($fill_i)){
1984
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1985
+            }
1986
+
1574 1987
 
1575
-				// add any background color rules
1576
-				if(!empty($background)){
1577
-					$output .= implode(",",$background) . "{background-color: $color_code;} ";
1578
-				}
1579
-				if(!empty($background_i)){
1580
-					$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1581
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1582
-				}
1988
+            $prefix = $compatibility ? ".bsui " : "";
1583 1989
 
1584
-				// add any border color rules
1585
-				if(!empty($border)){
1586
-					$output .= implode(",",$border) . "{border-color: $color_code;} ";
1587
-				}
1588
-				if(!empty($border_i)){
1589
-					$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1590
-				}
1990
+            // darken
1991
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1992
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1993
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1591 1994
 
1592
-				// add any fill color rules
1593
-				if(!empty($fill)){
1594
-					$output .= implode(",",$fill) . "{fill: $color_code;} ";
1595
-				}
1596
-				if(!empty($fill_i)){
1597
-					$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1598
-				}
1995
+            // lighten
1996
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1599 1997
 
1600
-			}
1998
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1999
+            $op_25 = $color_code."40"; // 25% opacity
1601 2000
 
1602 2001
 
2002
+            // button states
2003
+            $output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2004
+            $output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2005
+            $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2006
+            $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1603 2007
 
1604 2008
 
1605
-			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1606
-			// darken
1607
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1608
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1609
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1610
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
2009
+            // dropdown's
2010
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1611 2011
 
1612
-			// lighten
1613
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1614 2012
 
1615
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1616
-			$op_25 = $color_code."40"; // 25% opacity
2013
+            // input states
2014
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1617 2015
 
2016
+            // page link
2017
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1618 2018
 
1619
-			// button states
1620
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1621
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1622
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1623
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1624
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1625
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1626
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
2019
+            return $output;
2020
+        }
1627 2021
 
1628
-			// text
1629
-//			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
2022
+        /**
2023
+         *
2024
+         * @deprecated 0.1.76 Use css_overwrite()
2025
+         *
2026
+         * @param $color_code
2027
+         * @param $compatibility
2028
+         *
2029
+         * @return string
2030
+         */
2031
+        public static function css_secondary($color_code,$compatibility){;
2032
+            $color_code = sanitize_hex_color($color_code);
2033
+            if(!$color_code){return '';}
2034
+            /**
2035
+             * c = color, b = background color, o = border-color, f = fill
2036
+             */
2037
+            $selectors = array(
2038
+                '.btn-secondary' => array('b','o'),
2039
+                '.btn-secondary.disabled' => array('b','o'),
2040
+                '.btn-secondary:disabled' => array('b','o'),
2041
+                '.btn-outline-secondary' => array('c','o'),
2042
+                '.btn-outline-secondary:hover' => array('b','o'),
2043
+                '.btn-outline-secondary.disabled' => array('c'),
2044
+                '.btn-outline-secondary:disabled' => array('c'),
2045
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2046
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2047
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2048
+                '.badge-secondary' => array('b'),
2049
+                '.alert-secondary' => array('b','o'),
2050
+                '.btn-link.btn-secondary' => array('c'),
2051
+            );
2052
+
2053
+            $important_selectors = array(
2054
+                '.bg-secondary' => array('b','f'),
2055
+                '.border-secondary' => array('o'),
2056
+                '.text-secondary' => array('c'),
2057
+            );
2058
+
2059
+            $color = array();
2060
+            $color_i = array();
2061
+            $background = array();
2062
+            $background_i = array();
2063
+            $border = array();
2064
+            $border_i = array();
2065
+            $fill = array();
2066
+            $fill_i = array();
1630 2067
 
2068
+            $output = '';
1631 2069
 
1632
-//			if ( $type == 'primary' ) {
1633
-//				// dropdown's
1634
-//				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1635
-//
1636
-//				// input states
1637
-//				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1638
-//
1639
-//				// page link
1640
-//				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1641
-//			}
2070
+            // build rules into each type
2071
+            foreach($selectors as $selector => $types){
2072
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
2073
+                $types = array_combine($types,$types);
2074
+                if(isset($types['c'])){$color[] = $selector;}
2075
+                if(isset($types['b'])){$background[] = $selector;}
2076
+                if(isset($types['o'])){$border[] = $selector;}
2077
+                if(isset($types['f'])){$fill[] = $selector;}
2078
+            }
1642 2079
 
1643
-			// alerts
1644
-			if ( $aui_bs5 ) {
1645
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1646
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1647
-			}
1648
-
1649
-			return $output;
1650
-		}
1651
-
1652
-		/**
1653
-		 * Build the CSS to overwrite a bootstrap color variable.
1654
-		 *
1655
-		 * @param $type
1656
-		 * @param $color_code
1657
-		 * @param $compatibility
1658
-		 *
1659
-		 * @return string
1660
-		 */
1661
-		public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1662
-            global $aui_bs5;
2080
+            // build rules into each type
2081
+            foreach($important_selectors as $selector => $types){
2082
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
2083
+                $types = array_combine($types,$types);
2084
+                if(isset($types['c'])){$color_i[] = $selector;}
2085
+                if(isset($types['b'])){$background_i[] = $selector;}
2086
+                if(isset($types['o'])){$border_i[] = $selector;}
2087
+                if(isset($types['f'])){$fill_i[] = $selector;}
2088
+            }
1663 2089
 
1664
-			$is_var = false;
1665
-			if(!$color_code){return '';}
1666
-			if(strpos($color_code, 'var') !== false){
1667
-				//if(!sanitize_hex_color($color_code)){
1668
-				$color_code = esc_attr($color_code);
1669
-				$is_var = true;
1670
-//				$color_code = "rgba($color_code, 0.5)";
1671
-//                echo '###1'.$color_code.'###';//exit;
1672
-			}
2090
+            // add any color rules
2091
+            if(!empty($color)){
2092
+                $output .= implode(",",$color) . "{color: $color_code;} ";
2093
+            }
2094
+            if(!empty($color_i)){
2095
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2096
+            }
1673 2097
 
1674
-//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
2098
+            // add any background color rules
2099
+            if(!empty($background)){
2100
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
2101
+            }
2102
+            if(!empty($background_i)){
2103
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2104
+            }
1675 2105
 
1676
-			if(!$color_code){return '';}
2106
+            // add any border color rules
2107
+            if(!empty($border)){
2108
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
2109
+            }
2110
+            if(!empty($border_i)){
2111
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2112
+            }
1677 2113
 
1678
-            $rgb = self::hex_to_rgb($hex);
2114
+            // add any fill color rules
2115
+            if(!empty($fill)){
2116
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
2117
+            }
2118
+            if(!empty($fill_i)){
2119
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2120
+            }
1679 2121
 
1680
-			if($compatibility===true || $compatibility===1){
1681
-				$compatibility = '.bsui';
1682
-			}elseif(!$compatibility){
1683
-				$compatibility = '';
1684
-			}else{
1685
-				$compatibility = esc_attr($compatibility);
1686
-			}
1687 2122
 
2123
+            $prefix = $compatibility ? ".bsui " : "";
1688 2124
 
2125
+            // darken
2126
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2127
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2128
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1689 2129
 
1690
-//            echo '####'.$color_code;exit;
2130
+            // lighten
2131
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1691 2132
 
1692
-			$type = sanitize_html_class($type);
2133
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
2134
+            $op_25 = $color_code."40"; // 25% opacity
1693 2135
 
1694
-			/**
1695
-			 * c = color, b = background color, o = border-color, f = fill
1696
-			 */
1697
-			$selectors = array(
1698
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1699
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1700
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1701
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1702
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1703
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1704
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1705
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1706
-				".badge-{$type}"                                            => array( 'b' ),
1707
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1708
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1709
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1710
-			);
1711
-
1712
-			if ( $aui_bs5 ) {
1713
-                unset($selectors[".alert-{$type}" ]);
1714
-			}
1715
-
1716
-			if ( $type == 'primary' ) {
1717
-				$selectors = $selectors + array(
1718
-						'a'                                                                                                    => array( 'c' ),
1719
-						'.btn-link'                                                                                            => array( 'c' ),
1720
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1721
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1722
-							'b',
1723
-							'o'
1724
-						),
1725
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1726
-							'b',
1727
-							'o'
1728
-						),
1729
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1730
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1731
-						'.page-link'                                                                                           => array( 'c' ),
1732
-						'.page-item.active .page-link'                                                                         => array(
1733
-							'b',
1734
-							'o'
1735
-						),
1736
-						'.progress-bar'                                                                                        => array( 'b' ),
1737
-						'.list-group-item.active'                                                                              => array(
1738
-							'b',
1739
-							'o'
1740
-						),
1741
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1742
-//				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1743
-//				    '.custom-range::-moz-range-thumb' => array('b'),
1744
-//				    '.custom-range::-ms-thumb' => array('b'),
1745
-					);
1746
-			}
1747
-
1748
-			$important_selectors = array(
1749
-				".bg-{$type}" => array('b','f'),
1750
-				".border-{$type}" => array('o'),
1751
-				".text-{$type}" => array('c'),
1752
-			);
1753
-
1754
-			$color = array();
1755
-			$color_i = array();
1756
-			$background = array();
1757
-			$background_i = array();
1758
-			$border = array();
1759
-			$border_i = array();
1760
-			$fill = array();
1761
-			$fill_i = array();
1762
-
1763
-			$output = '';
1764
-
1765
-			if ( $aui_bs5 ) {
1766
-//				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1767
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1768
-			}
1769
-
1770
-			// build rules into each type
1771
-			foreach($selectors as $selector => $types){
1772
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1773
-				$types = array_combine($types,$types);
1774
-				if(isset($types['c'])){$color[] = $selector;}
1775
-				if(isset($types['b'])){$background[] = $selector;}
1776
-				if(isset($types['o'])){$border[] = $selector;}
1777
-				if(isset($types['f'])){$fill[] = $selector;}
1778
-			}
1779
-
1780
-			// build rules into each type
1781
-			foreach($important_selectors as $selector => $types){
1782
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1783
-				$types = array_combine($types,$types);
1784
-				if(isset($types['c'])){$color_i[] = $selector;}
1785
-				if(isset($types['b'])){$background_i[] = $selector;}
1786
-				if(isset($types['o'])){$border_i[] = $selector;}
1787
-				if(isset($types['f'])){$fill_i[] = $selector;}
1788
-			}
1789
-
1790
-			// add any color rules
1791
-			if(!empty($color)){
1792
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1793
-			}
1794
-			if(!empty($color_i)){
1795
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1796
-			}
1797
-
1798
-			// add any background color rules
1799
-			if(!empty($background)){
1800
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1801
-			}
1802
-			if(!empty($background_i)){
1803
-				$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1804
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1805
-			}
1806 2136
 
1807
-			// add any border color rules
1808
-			if(!empty($border)){
1809
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1810
-			}
1811
-			if(!empty($border_i)){
1812
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1813
-			}
2137
+            // button states
2138
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2139
+            $output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2140
+            $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2141
+            $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1814 2142
 
1815
-			// add any fill color rules
1816
-			if(!empty($fill)){
1817
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1818
-			}
1819
-			if(!empty($fill_i)){
1820
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1821
-			}
1822 2143
 
2144
+            return $output;
2145
+        }
1823 2146
 
1824
-			$prefix = $compatibility ? $compatibility . " " : "";
2147
+        /**
2148
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
2149
+         *
2150
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
2151
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
2152
+         *
2153
+         * @return  string
2154
+         */
2155
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2156
+            $hexCode = ltrim($hexCode, '#');
1825 2157
 
1826
-			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1827
-			// darken
1828
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1829
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1830
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1831
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
2158
+            if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2159
+                return $hexCode;
2160
+            }
1832 2161
 
1833
-			// lighten
1834
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
2162
+            if (strlen($hexCode) == 3) {
2163
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2164
+            }
1835 2165
 
1836
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1837
-			$op_25 = $color_code."40"; // 25% opacity
2166
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1838 2167
 
2168
+            foreach ($hexCode as & $color) {
2169
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2170
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1839 2171
 
1840
-			// button states
1841
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1842
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1843
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1844
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1845
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1846
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2172
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2173
+            }
1847 2174
 
1848
-			if ( $type == 'primary' ) {
1849
-				// dropdown's
1850
-				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2175
+            return '#' . implode($hexCode);
2176
+        }
1851 2177
 
1852
-				// input states
1853
-				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
2178
+        /**
2179
+         * Check if we should display examples.
2180
+         */
2181
+        public function maybe_show_examples(){
2182
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2183
+                echo "<head>";
2184
+                wp_head();
2185
+                echo "</head>";
2186
+                echo "<body>";
2187
+                echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2188
+                echo "</body>";
2189
+                exit;
2190
+            }
2191
+        }
1854 2192
 
1855
-				// page link
1856
-				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1857
-			}
2193
+        /**
2194
+         * Get developer examples.
2195
+         *
2196
+         * @return string
2197
+         */
2198
+        public function get_examples(){
2199
+            $output = '';
1858 2200
 
1859
-            // alerts
1860
-			if ( $aui_bs5 ) {
1861
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1862
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1863
-			}
1864
-
1865
-			return $output;
1866
-		}
1867
-
1868
-		/**
1869
-		 *
1870
-		 * @deprecated 0.1.76 Use css_overwrite()
1871
-		 *
1872
-		 * @param $color_code
1873
-		 * @param $compatibility
1874
-		 * @param $use_variable
1875
-		 *
1876
-		 * @return string
1877
-		 */
1878
-		public static function css_primary($color_code,$compatibility, $use_variable = false){
1879
-
1880
-			if(!$use_variable){
1881
-				$color_code = sanitize_hex_color($color_code);
1882
-				if(!$color_code){return '';}
1883
-			}
1884
-
1885
-			/**
1886
-			 * c = color, b = background color, o = border-color, f = fill
1887
-			 */
1888
-			$selectors = array(
1889
-				'a' => array('c'),
1890
-				'.btn-primary' => array('b','o'),
1891
-				'.btn-primary.disabled' => array('b','o'),
1892
-				'.btn-primary:disabled' => array('b','o'),
1893
-				'.btn-outline-primary' => array('c','o'),
1894
-				'.btn-outline-primary:hover' => array('b','o'),
1895
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1896
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1897
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1898
-				'.btn-link' => array('c'),
1899
-				'.dropdown-item.active' => array('b'),
1900
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1901
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1902
-//				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1903
-//				'.custom-range::-moz-range-thumb' => array('b'),
1904
-//				'.custom-range::-ms-thumb' => array('b'),
1905
-				'.nav-pills .nav-link.active' => array('b'),
1906
-				'.nav-pills .show>.nav-link' => array('b'),
1907
-				'.page-link' => array('c'),
1908
-				'.page-item.active .page-link' => array('b','o'),
1909
-				'.badge-primary' => array('b'),
1910
-				'.alert-primary' => array('b','o'),
1911
-				'.progress-bar' => array('b'),
1912
-				'.list-group-item.active' => array('b','o'),
1913
-				'.bg-primary' => array('b','f'),
1914
-				'.btn-link.btn-primary' => array('c'),
1915
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1916
-			);
1917
-
1918
-			$important_selectors = array(
1919
-				'.bg-primary' => array('b','f'),
1920
-				'.border-primary' => array('o'),
1921
-				'.text-primary' => array('c'),
1922
-			);
1923
-
1924
-			$color = array();
1925
-			$color_i = array();
1926
-			$background = array();
1927
-			$background_i = array();
1928
-			$border = array();
1929
-			$border_i = array();
1930
-			$fill = array();
1931
-			$fill_i = array();
1932
-
1933
-			$output = '';
1934
-
1935
-			// build rules into each type
1936
-			foreach($selectors as $selector => $types){
1937
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1938
-				$types = array_combine($types,$types);
1939
-				if(isset($types['c'])){$color[] = $selector;}
1940
-				if(isset($types['b'])){$background[] = $selector;}
1941
-				if(isset($types['o'])){$border[] = $selector;}
1942
-				if(isset($types['f'])){$fill[] = $selector;}
1943
-			}
1944
-
1945
-			// build rules into each type
1946
-			foreach($important_selectors as $selector => $types){
1947
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1948
-				$types = array_combine($types,$types);
1949
-				if(isset($types['c'])){$color_i[] = $selector;}
1950
-				if(isset($types['b'])){$background_i[] = $selector;}
1951
-				if(isset($types['o'])){$border_i[] = $selector;}
1952
-				if(isset($types['f'])){$fill_i[] = $selector;}
1953
-			}
1954
-
1955
-			// add any color rules
1956
-			if(!empty($color)){
1957
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1958
-			}
1959
-			if(!empty($color_i)){
1960
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1961
-			}
1962
-
1963
-			// add any background color rules
1964
-			if(!empty($background)){
1965
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1966
-			}
1967
-			if(!empty($background_i)){
1968
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1969
-			}
1970
-
1971
-			// add any border color rules
1972
-			if(!empty($border)){
1973
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1974
-			}
1975
-			if(!empty($border_i)){
1976
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1977
-			}
1978
-
1979
-			// add any fill color rules
1980
-			if(!empty($fill)){
1981
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1982
-			}
1983
-			if(!empty($fill_i)){
1984
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1985
-			}
1986
-
1987
-
1988
-			$prefix = $compatibility ? ".bsui " : "";
1989
-
1990
-			// darken
1991
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1992
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1993
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1994
-
1995
-			// lighten
1996
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1997
-
1998
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1999
-			$op_25 = $color_code."40"; // 25% opacity
2000
-
2001
-
2002
-			// button states
2003
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2004
-			$output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2005
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2006
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2007
-
2008
-
2009
-			// dropdown's
2010
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2011
-
2012
-
2013
-			// input states
2014
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2015
-
2016
-			// page link
2017
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2018
-
2019
-			return $output;
2020
-		}
2021
-
2022
-		/**
2023
-		 *
2024
-		 * @deprecated 0.1.76 Use css_overwrite()
2025
-		 *
2026
-		 * @param $color_code
2027
-		 * @param $compatibility
2028
-		 *
2029
-		 * @return string
2030
-		 */
2031
-		public static function css_secondary($color_code,$compatibility){;
2032
-			$color_code = sanitize_hex_color($color_code);
2033
-			if(!$color_code){return '';}
2034
-			/**
2035
-			 * c = color, b = background color, o = border-color, f = fill
2036
-			 */
2037
-			$selectors = array(
2038
-				'.btn-secondary' => array('b','o'),
2039
-				'.btn-secondary.disabled' => array('b','o'),
2040
-				'.btn-secondary:disabled' => array('b','o'),
2041
-				'.btn-outline-secondary' => array('c','o'),
2042
-				'.btn-outline-secondary:hover' => array('b','o'),
2043
-				'.btn-outline-secondary.disabled' => array('c'),
2044
-				'.btn-outline-secondary:disabled' => array('c'),
2045
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2046
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2047
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2048
-				'.badge-secondary' => array('b'),
2049
-				'.alert-secondary' => array('b','o'),
2050
-				'.btn-link.btn-secondary' => array('c'),
2051
-			);
2052
-
2053
-			$important_selectors = array(
2054
-				'.bg-secondary' => array('b','f'),
2055
-				'.border-secondary' => array('o'),
2056
-				'.text-secondary' => array('c'),
2057
-			);
2058
-
2059
-			$color = array();
2060
-			$color_i = array();
2061
-			$background = array();
2062
-			$background_i = array();
2063
-			$border = array();
2064
-			$border_i = array();
2065
-			$fill = array();
2066
-			$fill_i = array();
2067
-
2068
-			$output = '';
2069
-
2070
-			// build rules into each type
2071
-			foreach($selectors as $selector => $types){
2072
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2073
-				$types = array_combine($types,$types);
2074
-				if(isset($types['c'])){$color[] = $selector;}
2075
-				if(isset($types['b'])){$background[] = $selector;}
2076
-				if(isset($types['o'])){$border[] = $selector;}
2077
-				if(isset($types['f'])){$fill[] = $selector;}
2078
-			}
2079
-
2080
-			// build rules into each type
2081
-			foreach($important_selectors as $selector => $types){
2082
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2083
-				$types = array_combine($types,$types);
2084
-				if(isset($types['c'])){$color_i[] = $selector;}
2085
-				if(isset($types['b'])){$background_i[] = $selector;}
2086
-				if(isset($types['o'])){$border_i[] = $selector;}
2087
-				if(isset($types['f'])){$fill_i[] = $selector;}
2088
-			}
2089
-
2090
-			// add any color rules
2091
-			if(!empty($color)){
2092
-				$output .= implode(",",$color) . "{color: $color_code;} ";
2093
-			}
2094
-			if(!empty($color_i)){
2095
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2096
-			}
2097
-
2098
-			// add any background color rules
2099
-			if(!empty($background)){
2100
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
2101
-			}
2102
-			if(!empty($background_i)){
2103
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2104
-			}
2105
-
2106
-			// add any border color rules
2107
-			if(!empty($border)){
2108
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
2109
-			}
2110
-			if(!empty($border_i)){
2111
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2112
-			}
2113
-
2114
-			// add any fill color rules
2115
-			if(!empty($fill)){
2116
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
2117
-			}
2118
-			if(!empty($fill_i)){
2119
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2120
-			}
2121
-
2122
-
2123
-			$prefix = $compatibility ? ".bsui " : "";
2124
-
2125
-			// darken
2126
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2127
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2128
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2129
-
2130
-			// lighten
2131
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2132
-
2133
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
2134
-			$op_25 = $color_code."40"; // 25% opacity
2135
-
2136
-
2137
-			// button states
2138
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2139
-			$output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2140
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2141
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2142
-
2143
-
2144
-			return $output;
2145
-		}
2146
-
2147
-		/**
2148
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
2149
-		 *
2150
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
2151
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
2152
-		 *
2153
-		 * @return  string
2154
-		 */
2155
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2156
-			$hexCode = ltrim($hexCode, '#');
2157
-
2158
-			if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2159
-				return $hexCode;
2160
-			}
2161
-
2162
-			if (strlen($hexCode) == 3) {
2163
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2164
-			}
2165
-
2166
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
2167
-
2168
-			foreach ($hexCode as & $color) {
2169
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2170
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
2171
-
2172
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2173
-			}
2174
-
2175
-			return '#' . implode($hexCode);
2176
-		}
2177
-
2178
-		/**
2179
-		 * Check if we should display examples.
2180
-		 */
2181
-		public function maybe_show_examples(){
2182
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2183
-				echo "<head>";
2184
-				wp_head();
2185
-				echo "</head>";
2186
-				echo "<body>";
2187
-				echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2188
-				echo "</body>";
2189
-				exit;
2190
-			}
2191
-		}
2192
-
2193
-		/**
2194
-		 * Get developer examples.
2195
-		 *
2196
-		 * @return string
2197
-		 */
2198
-		public function get_examples(){
2199
-			$output = '';
2200
-
2201
-
2202
-			// open form
2203
-			$output .= "<form class='p-5 m-5 border rounded'>";
2204
-
2205
-			// input example
2206
-			$output .= aui()->input(array(
2207
-				'type'  =>  'text',
2208
-				'id'    =>  'text-example',
2209
-				'name'    =>  'text-example',
2210
-				'placeholder'   => 'text placeholder',
2211
-				'title'   => 'Text input example',
2212
-				'value' =>  '',
2213
-				'required'  => false,
2214
-				'help_text' => 'help text',
2215
-				'label' => 'Text input example label'
2216
-			));
2217
-
2218
-			// input example
2219
-			$output .= aui()->input(array(
2220
-				'type'  =>  'url',
2221
-				'id'    =>  'text-example2',
2222
-				'name'    =>  'text-example',
2223
-				'placeholder'   => 'url placeholder',
2224
-				'title'   => 'Text input example',
2225
-				'value' =>  '',
2226
-				'required'  => false,
2227
-				'help_text' => 'help text',
2228
-				'label' => 'Text input example label'
2229
-			));
2230
-
2231
-			// checkbox example
2232
-			$output .= aui()->input(array(
2233
-				'type'  =>  'checkbox',
2234
-				'id'    =>  'checkbox-example',
2235
-				'name'    =>  'checkbox-example',
2236
-				'placeholder'   => 'checkbox-example',
2237
-				'title'   => 'Checkbox example',
2238
-				'value' =>  '1',
2239
-				'checked'   => true,
2240
-				'required'  => false,
2241
-				'help_text' => 'help text',
2242
-				'label' => 'Checkbox checked'
2243
-			));
2244
-
2245
-			// checkbox example
2246
-			$output .= aui()->input(array(
2247
-				'type'  =>  'checkbox',
2248
-				'id'    =>  'checkbox-example2',
2249
-				'name'    =>  'checkbox-example2',
2250
-				'placeholder'   => 'checkbox-example',
2251
-				'title'   => 'Checkbox example',
2252
-				'value' =>  '1',
2253
-				'checked'   => false,
2254
-				'required'  => false,
2255
-				'help_text' => 'help text',
2256
-				'label' => 'Checkbox un-checked'
2257
-			));
2258
-
2259
-			// switch example
2260
-			$output .= aui()->input(array(
2261
-				'type'  =>  'checkbox',
2262
-				'id'    =>  'switch-example',
2263
-				'name'    =>  'switch-example',
2264
-				'placeholder'   => 'checkbox-example',
2265
-				'title'   => 'Switch example',
2266
-				'value' =>  '1',
2267
-				'checked'   => true,
2268
-				'switch'    => true,
2269
-				'required'  => false,
2270
-				'help_text' => 'help text',
2271
-				'label' => 'Switch on'
2272
-			));
2273
-
2274
-			// switch example
2275
-			$output .= aui()->input(array(
2276
-				'type'  =>  'checkbox',
2277
-				'id'    =>  'switch-example2',
2278
-				'name'    =>  'switch-example2',
2279
-				'placeholder'   => 'checkbox-example',
2280
-				'title'   => 'Switch example',
2281
-				'value' =>  '1',
2282
-				'checked'   => false,
2283
-				'switch'    => true,
2284
-				'required'  => false,
2285
-				'help_text' => 'help text',
2286
-				'label' => 'Switch off'
2287
-			));
2288
-
2289
-			// close form
2290
-			$output .= "</form>";
2291
-
2292
-			return $output;
2293
-		}
2294
-
2295
-		/**
2296
-		 * Calendar params.
2297
-		 *
2298
-		 * @since 0.1.44
2299
-		 *
2300
-		 * @return array Calendar params.
2301
-		 */
2302
-		public static function calendar_params() {
2303
-			$params = array(
2304
-				'month_long_1' => __( 'January', 'ayecode-connect' ),
2305
-				'month_long_2' => __( 'February', 'ayecode-connect' ),
2306
-				'month_long_3' => __( 'March', 'ayecode-connect' ),
2307
-				'month_long_4' => __( 'April', 'ayecode-connect' ),
2308
-				'month_long_5' => __( 'May', 'ayecode-connect' ),
2309
-				'month_long_6' => __( 'June', 'ayecode-connect' ),
2310
-				'month_long_7' => __( 'July', 'ayecode-connect' ),
2311
-				'month_long_8' => __( 'August', 'ayecode-connect' ),
2312
-				'month_long_9' => __( 'September', 'ayecode-connect' ),
2313
-				'month_long_10' => __( 'October', 'ayecode-connect' ),
2314
-				'month_long_11' => __( 'November', 'ayecode-connect' ),
2315
-				'month_long_12' => __( 'December', 'ayecode-connect' ),
2316
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2317
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2318
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2319
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2320
-				'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2321
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2322
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2323
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2324
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2325
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2326
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2327
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2328
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2329
-				'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2330
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2331
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2332
-				'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2333
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2334
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2335
-				'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2336
-				'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2337
-				'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2338
-				'day_s2_4' => __( 'We', 'ayecode-connect' ),
2339
-				'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2340
-				'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2341
-				'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2342
-				'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2343
-				'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2344
-				'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2345
-				'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2346
-				'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2347
-				'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2348
-				'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2349
-				'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2350
-				'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2351
-				'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2352
-				'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2353
-				'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2354
-				'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2355
-				'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2356
-				'am_lower' => __( 'am', 'ayecode-connect' ),
2357
-				'pm_lower' => __( 'pm', 'ayecode-connect' ),
2358
-				'am_upper' => __( 'AM', 'ayecode-connect' ),
2359
-				'pm_upper' => __( 'PM', 'ayecode-connect' ),
2360
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2361
-				'time_24hr' => false,
2362
-				'year' => __( 'Year', 'ayecode-connect' ),
2363
-				'hour' => __( 'Hour', 'ayecode-connect' ),
2364
-				'minute' => __( 'Minute', 'ayecode-connect' ),
2365
-				'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2366
-				'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2367
-				'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2368
-				'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2369
-			);
2370
-
2371
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
2372
-		}
2373
-
2374
-		/**
2375
-		 * Flatpickr calendar localize.
2376
-		 *
2377
-		 * @since 0.1.44
2378
-		 *
2379
-		 * @return string Calendar locale.
2380
-		 */
2381
-		public static function flatpickr_locale() {
2382
-			$params = self::calendar_params();
2383
-
2384
-			if ( is_string( $params ) ) {
2385
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2386
-			} else {
2387
-				foreach ( (array) $params as $key => $value ) {
2388
-					if ( ! is_scalar( $value ) ) {
2389
-						continue;
2390
-					}
2391
-
2392
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2393
-				}
2394
-			}
2395 2201
 
2396
-			$day_s3 = array();
2397
-			$day_s5 = array();
2202
+            // open form
2203
+            $output .= "<form class='p-5 m-5 border rounded'>";
2204
+
2205
+            // input example
2206
+            $output .= aui()->input(array(
2207
+                'type'  =>  'text',
2208
+                'id'    =>  'text-example',
2209
+                'name'    =>  'text-example',
2210
+                'placeholder'   => 'text placeholder',
2211
+                'title'   => 'Text input example',
2212
+                'value' =>  '',
2213
+                'required'  => false,
2214
+                'help_text' => 'help text',
2215
+                'label' => 'Text input example label'
2216
+            ));
2217
+
2218
+            // input example
2219
+            $output .= aui()->input(array(
2220
+                'type'  =>  'url',
2221
+                'id'    =>  'text-example2',
2222
+                'name'    =>  'text-example',
2223
+                'placeholder'   => 'url placeholder',
2224
+                'title'   => 'Text input example',
2225
+                'value' =>  '',
2226
+                'required'  => false,
2227
+                'help_text' => 'help text',
2228
+                'label' => 'Text input example label'
2229
+            ));
2230
+
2231
+            // checkbox example
2232
+            $output .= aui()->input(array(
2233
+                'type'  =>  'checkbox',
2234
+                'id'    =>  'checkbox-example',
2235
+                'name'    =>  'checkbox-example',
2236
+                'placeholder'   => 'checkbox-example',
2237
+                'title'   => 'Checkbox example',
2238
+                'value' =>  '1',
2239
+                'checked'   => true,
2240
+                'required'  => false,
2241
+                'help_text' => 'help text',
2242
+                'label' => 'Checkbox checked'
2243
+            ));
2244
+
2245
+            // checkbox example
2246
+            $output .= aui()->input(array(
2247
+                'type'  =>  'checkbox',
2248
+                'id'    =>  'checkbox-example2',
2249
+                'name'    =>  'checkbox-example2',
2250
+                'placeholder'   => 'checkbox-example',
2251
+                'title'   => 'Checkbox example',
2252
+                'value' =>  '1',
2253
+                'checked'   => false,
2254
+                'required'  => false,
2255
+                'help_text' => 'help text',
2256
+                'label' => 'Checkbox un-checked'
2257
+            ));
2258
+
2259
+            // switch example
2260
+            $output .= aui()->input(array(
2261
+                'type'  =>  'checkbox',
2262
+                'id'    =>  'switch-example',
2263
+                'name'    =>  'switch-example',
2264
+                'placeholder'   => 'checkbox-example',
2265
+                'title'   => 'Switch example',
2266
+                'value' =>  '1',
2267
+                'checked'   => true,
2268
+                'switch'    => true,
2269
+                'required'  => false,
2270
+                'help_text' => 'help text',
2271
+                'label' => 'Switch on'
2272
+            ));
2273
+
2274
+            // switch example
2275
+            $output .= aui()->input(array(
2276
+                'type'  =>  'checkbox',
2277
+                'id'    =>  'switch-example2',
2278
+                'name'    =>  'switch-example2',
2279
+                'placeholder'   => 'checkbox-example',
2280
+                'title'   => 'Switch example',
2281
+                'value' =>  '1',
2282
+                'checked'   => false,
2283
+                'switch'    => true,
2284
+                'required'  => false,
2285
+                'help_text' => 'help text',
2286
+                'label' => 'Switch off'
2287
+            ));
2288
+
2289
+            // close form
2290
+            $output .= "</form>";
2291
+
2292
+            return $output;
2293
+        }
2294
+
2295
+        /**
2296
+         * Calendar params.
2297
+         *
2298
+         * @since 0.1.44
2299
+         *
2300
+         * @return array Calendar params.
2301
+         */
2302
+        public static function calendar_params() {
2303
+            $params = array(
2304
+                'month_long_1' => __( 'January', 'ayecode-connect' ),
2305
+                'month_long_2' => __( 'February', 'ayecode-connect' ),
2306
+                'month_long_3' => __( 'March', 'ayecode-connect' ),
2307
+                'month_long_4' => __( 'April', 'ayecode-connect' ),
2308
+                'month_long_5' => __( 'May', 'ayecode-connect' ),
2309
+                'month_long_6' => __( 'June', 'ayecode-connect' ),
2310
+                'month_long_7' => __( 'July', 'ayecode-connect' ),
2311
+                'month_long_8' => __( 'August', 'ayecode-connect' ),
2312
+                'month_long_9' => __( 'September', 'ayecode-connect' ),
2313
+                'month_long_10' => __( 'October', 'ayecode-connect' ),
2314
+                'month_long_11' => __( 'November', 'ayecode-connect' ),
2315
+                'month_long_12' => __( 'December', 'ayecode-connect' ),
2316
+                'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2317
+                'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2318
+                'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2319
+                'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2320
+                'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2321
+                'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2322
+                'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2323
+                'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2324
+                'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2325
+                'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2326
+                'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2327
+                'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2328
+                'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2329
+                'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2330
+                'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2331
+                'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2332
+                'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2333
+                'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2334
+                'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2335
+                'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2336
+                'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2337
+                'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2338
+                'day_s2_4' => __( 'We', 'ayecode-connect' ),
2339
+                'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2340
+                'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2341
+                'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2342
+                'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2343
+                'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2344
+                'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2345
+                'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2346
+                'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2347
+                'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2348
+                'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2349
+                'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2350
+                'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2351
+                'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2352
+                'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2353
+                'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2354
+                'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2355
+                'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2356
+                'am_lower' => __( 'am', 'ayecode-connect' ),
2357
+                'pm_lower' => __( 'pm', 'ayecode-connect' ),
2358
+                'am_upper' => __( 'AM', 'ayecode-connect' ),
2359
+                'pm_upper' => __( 'PM', 'ayecode-connect' ),
2360
+                'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2361
+                'time_24hr' => false,
2362
+                'year' => __( 'Year', 'ayecode-connect' ),
2363
+                'hour' => __( 'Hour', 'ayecode-connect' ),
2364
+                'minute' => __( 'Minute', 'ayecode-connect' ),
2365
+                'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2366
+                'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2367
+                'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2368
+                'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2369
+            );
2370
+
2371
+            return apply_filters( 'ayecode_ui_calendar_params', $params );
2372
+        }
2373
+
2374
+        /**
2375
+         * Flatpickr calendar localize.
2376
+         *
2377
+         * @since 0.1.44
2378
+         *
2379
+         * @return string Calendar locale.
2380
+         */
2381
+        public static function flatpickr_locale() {
2382
+            $params = self::calendar_params();
2383
+
2384
+            if ( is_string( $params ) ) {
2385
+                $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2386
+            } else {
2387
+                foreach ( (array) $params as $key => $value ) {
2388
+                    if ( ! is_scalar( $value ) ) {
2389
+                        continue;
2390
+                    }
2391
+
2392
+                    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2393
+                }
2394
+            }
2398 2395
 
2399
-			for ( $i = 1; $i <= 7; $i ++ ) {
2400
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2401
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2402
-			}
2396
+            $day_s3 = array();
2397
+            $day_s5 = array();
2398
+
2399
+            for ( $i = 1; $i <= 7; $i ++ ) {
2400
+                $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2401
+                $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2402
+            }
2403 2403
 
2404
-			$month_s = array();
2405
-			$month_long = array();
2404
+            $month_s = array();
2405
+            $month_long = array();
2406 2406
 
2407
-			for ( $i = 1; $i <= 12; $i ++ ) {
2408
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2409
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2410
-			}
2407
+            for ( $i = 1; $i <= 12; $i ++ ) {
2408
+                $month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2409
+                $month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2410
+            }
2411 2411
 
2412
-			ob_start();
2413
-		if ( 0 ) { ?><script><?php } ?>
2412
+            ob_start();
2413
+        if ( 0 ) { ?><script><?php } ?>
2414 2414
                 {
2415 2415
                     weekdays: {
2416 2416
                         shorthand: ['<?php echo implode( "','", $day_s3 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
@@ -2449,189 +2449,189 @@  discard block
 block discarded – undo
2449 2449
                 }
2450 2450
 				<?php if ( 0 ) { ?></script><?php } ?>
2451 2451
 			<?php
2452
-			$locale = ob_get_clean();
2453
-
2454
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2455
-		}
2456
-
2457
-		/**
2458
-		 * Select2 JS params.
2459
-		 *
2460
-		 * @since 0.1.44
2461
-		 *
2462
-		 * @return array Select2 JS params.
2463
-		 */
2464
-		public static function select2_params() {
2465
-			$params = array(
2466
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2467
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2468
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2469
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2470
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2471
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2472
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2473
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2474
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2475
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2476
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2477
-			);
2478
-
2479
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2480
-		}
2481
-
2482
-		/**
2483
-		 * Select2 JS localize.
2484
-		 *
2485
-		 * @since 0.1.44
2486
-		 *
2487
-		 * @return string Select2 JS locale.
2488
-		 */
2489
-		public static function select2_locale() {
2490
-			$params = self::select2_params();
2491
-
2492
-			foreach ( (array) $params as $key => $value ) {
2493
-				if ( ! is_scalar( $value ) ) {
2494
-					continue;
2495
-				}
2452
+            $locale = ob_get_clean();
2496 2453
 
2497
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2498
-			}
2499
-
2500
-			$locale = json_encode( $params );
2501
-
2502
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2503
-		}
2504
-
2505
-		/**
2506
-		 * Time ago JS localize.
2507
-		 *
2508
-		 * @since 0.1.47
2509
-		 *
2510
-		 * @return string Time ago JS locale.
2511
-		 */
2512
-		public static function timeago_locale() {
2513
-			$params = array(
2514
-				'prefix_ago' => '',
2515
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2516
-				'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2517
-				'suffix_after' => '',
2518
-				'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2519
-				'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2520
-				'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2521
-				'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2522
-				'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2523
-				'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2524
-				'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2525
-				'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2526
-				'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2527
-				'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2528
-				'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2529
-			);
2530
-
2531
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2532
-
2533
-			foreach ( (array) $params as $key => $value ) {
2534
-				if ( ! is_scalar( $value ) ) {
2535
-					continue;
2536
-				}
2454
+            return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2455
+        }
2456
+
2457
+        /**
2458
+         * Select2 JS params.
2459
+         *
2460
+         * @since 0.1.44
2461
+         *
2462
+         * @return array Select2 JS params.
2463
+         */
2464
+        public static function select2_params() {
2465
+            $params = array(
2466
+                'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2467
+                'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2468
+                'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2469
+                'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2470
+                'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2471
+                'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2472
+                'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2473
+                'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2474
+                'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2475
+                'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2476
+                'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2477
+            );
2478
+
2479
+            return apply_filters( 'ayecode_ui_select2_params', $params );
2480
+        }
2481
+
2482
+        /**
2483
+         * Select2 JS localize.
2484
+         *
2485
+         * @since 0.1.44
2486
+         *
2487
+         * @return string Select2 JS locale.
2488
+         */
2489
+        public static function select2_locale() {
2490
+            $params = self::select2_params();
2491
+
2492
+            foreach ( (array) $params as $key => $value ) {
2493
+                if ( ! is_scalar( $value ) ) {
2494
+                    continue;
2495
+                }
2496
+
2497
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2498
+            }
2499
+
2500
+            $locale = json_encode( $params );
2501
+
2502
+            return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2503
+        }
2504
+
2505
+        /**
2506
+         * Time ago JS localize.
2507
+         *
2508
+         * @since 0.1.47
2509
+         *
2510
+         * @return string Time ago JS locale.
2511
+         */
2512
+        public static function timeago_locale() {
2513
+            $params = array(
2514
+                'prefix_ago' => '',
2515
+                'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2516
+                'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2517
+                'suffix_after' => '',
2518
+                'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2519
+                'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2520
+                'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2521
+                'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2522
+                'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2523
+                'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2524
+                'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2525
+                'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2526
+                'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2527
+                'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2528
+                'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2529
+            );
2530
+
2531
+            $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2532
+
2533
+            foreach ( (array) $params as $key => $value ) {
2534
+                if ( ! is_scalar( $value ) ) {
2535
+                    continue;
2536
+                }
2537 2537
 
2538
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2539
-			}
2540
-
2541
-			$locale = json_encode( $params );
2542
-
2543
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2544
-		}
2545
-
2546
-		/**
2547
-		 * JavaScript Minifier
2548
-		 *
2549
-		 * @param $input
2550
-		 *
2551
-		 * @return mixed
2552
-		 */
2553
-		public static function minify_js($input) {
2554
-			if(trim($input) === "") return $input;
2555
-			return preg_replace(
2556
-				array(
2557
-					// Remove comment(s)
2558
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2559
-					// Remove white-space(s) outside the string and regex
2560
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2561
-					// Remove the last semicolon
2562
-					'#;+\}#',
2563
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2564
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2565
-					// --ibid. From `foo['bar']` to `foo.bar`
2566
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2567
-				),
2568
-				array(
2569
-					'$1',
2570
-					'$1$2',
2571
-					'}',
2572
-					'$1$3',
2573
-					'$1.$3'
2574
-				),
2575
-				$input);
2576
-		}
2577
-
2578
-		/**
2579
-		 * Minify CSS
2580
-		 *
2581
-		 * @param $input
2582
-		 *
2583
-		 * @return mixed
2584
-		 */
2585
-		public static function minify_css($input) {
2586
-			if(trim($input) === "") return $input;
2587
-			return preg_replace(
2588
-				array(
2589
-					// Remove comment(s)
2590
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2591
-					// Remove unused white-space(s)
2592
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2593
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2594
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2595
-					// Replace `:0 0 0 0` with `:0`
2596
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2597
-					// Replace `background-position:0` with `background-position:0 0`
2598
-					'#(background-position):0(?=[;\}])#si',
2599
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2600
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2601
-					// Minify string value
2602
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2603
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2604
-					// Minify HEX color code
2605
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2606
-					// Replace `(border|outline):none` with `(border|outline):0`
2607
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2608
-					// Remove empty selector(s)
2609
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2610
-				),
2611
-				array(
2612
-					'$1',
2613
-					'$1$2$3$4$5$6$7',
2614
-					'$1',
2615
-					':0',
2616
-					'$1:0 0',
2617
-					'.$1',
2618
-					'$1$3',
2619
-					'$1$2$4$5',
2620
-					'$1$2$3',
2621
-					'$1:0',
2622
-					'$1$2'
2623
-				),
2624
-				$input);
2625
-		}
2626
-
2627
-		/**
2628
-		 * Get the conditional fields JavaScript.
2629
-		 *
2630
-		 * @return mixed
2631
-		 */
2632
-		public function conditional_fields_js() {
2633
-			ob_start();
2634
-			?>
2538
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2539
+            }
2540
+
2541
+            $locale = json_encode( $params );
2542
+
2543
+            return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2544
+        }
2545
+
2546
+        /**
2547
+         * JavaScript Minifier
2548
+         *
2549
+         * @param $input
2550
+         *
2551
+         * @return mixed
2552
+         */
2553
+        public static function minify_js($input) {
2554
+            if(trim($input) === "") return $input;
2555
+            return preg_replace(
2556
+                array(
2557
+                    // Remove comment(s)
2558
+                    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2559
+                    // Remove white-space(s) outside the string and regex
2560
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2561
+                    // Remove the last semicolon
2562
+                    '#;+\}#',
2563
+                    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2564
+                    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2565
+                    // --ibid. From `foo['bar']` to `foo.bar`
2566
+                    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2567
+                ),
2568
+                array(
2569
+                    '$1',
2570
+                    '$1$2',
2571
+                    '}',
2572
+                    '$1$3',
2573
+                    '$1.$3'
2574
+                ),
2575
+                $input);
2576
+        }
2577
+
2578
+        /**
2579
+         * Minify CSS
2580
+         *
2581
+         * @param $input
2582
+         *
2583
+         * @return mixed
2584
+         */
2585
+        public static function minify_css($input) {
2586
+            if(trim($input) === "") return $input;
2587
+            return preg_replace(
2588
+                array(
2589
+                    // Remove comment(s)
2590
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2591
+                    // Remove unused white-space(s)
2592
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2593
+                    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2594
+                    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2595
+                    // Replace `:0 0 0 0` with `:0`
2596
+                    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2597
+                    // Replace `background-position:0` with `background-position:0 0`
2598
+                    '#(background-position):0(?=[;\}])#si',
2599
+                    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2600
+                    '#(?<=[\s:,\-])0+\.(\d+)#s',
2601
+                    // Minify string value
2602
+                    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2603
+                    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2604
+                    // Minify HEX color code
2605
+                    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2606
+                    // Replace `(border|outline):none` with `(border|outline):0`
2607
+                    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2608
+                    // Remove empty selector(s)
2609
+                    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2610
+                ),
2611
+                array(
2612
+                    '$1',
2613
+                    '$1$2$3$4$5$6$7',
2614
+                    '$1',
2615
+                    ':0',
2616
+                    '$1:0 0',
2617
+                    '.$1',
2618
+                    '$1$3',
2619
+                    '$1$2$4$5',
2620
+                    '$1$2$3',
2621
+                    '$1:0',
2622
+                    '$1$2'
2623
+                ),
2624
+                $input);
2625
+        }
2626
+
2627
+        /**
2628
+         * Get the conditional fields JavaScript.
2629
+         *
2630
+         * @return mixed
2631
+         */
2632
+        public function conditional_fields_js() {
2633
+            ob_start();
2634
+            ?>
2635 2635
             <script>
2636 2636
                 /**
2637 2637
                  * Conditional Fields
@@ -3166,237 +3166,237 @@  discard block
 block discarded – undo
3166 3166
 				<?php do_action( 'aui_conditional_fields_js', $this ); ?>
3167 3167
             </script>
3168 3168
 			<?php
3169
-			$output = ob_get_clean();
3170
-
3171
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3172
-		}
3173
-
3174
-		/**
3175
-		 * Check if block editor page.
3176
-		 *
3177
-		 * @since 0.2.27
3178
-		 *
3179
-		 * @return bool
3180
-		 */
3181
-		public static function is_block_editor() {
3182
-			if ( is_admin() ) {
3183
-				$current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3184
-
3185
-				if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3186
-					return true;
3187
-				}
3188
-			}
3189
-
3190
-			return false;
3191
-		}
3192
-
3193
-		/**
3194
-		 * Checks if the current call is a ajax call to get the block content.
3195
-		 *
3196
-		 * This can be used in your widget to return different content as the block content.
3197
-		 *
3198
-		 * @since 0.2.27
3199
-		 *
3200
-		 * @return bool
3201
-		 */
3202
-		public static function is_block_content_call() {
3203
-			$result = false;
3204
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3205
-				$result = true;
3206
-			}
3207
-
3208
-			return $result;
3209
-		}
3210
-
3211
-		/**
3212
-		 * Tests if the current output is inside a Divi preview.
3213
-		 *
3214
-		 * @since 0.2.27
3215
-		 *
3216
-		 * @return bool
3217
-		 */
3218
-		public static function is_divi_preview() {
3219
-			$result = false;
3220
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3221
-				$result = true;
3222
-			}
3223
-
3224
-			return $result;
3225
-		}
3226
-
3227
-		/**
3228
-		 * Tests if the current output is inside a elementor preview.
3229
-		 *
3230
-		 *
3231
-		 * @since 0.2.27
3232
-		 *
3233
-		 * @return bool
3234
-		 */
3235
-		public static function is_elementor_preview() {
3236
-			$result = false;
3237
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3238
-				$result = true;
3239
-			}
3240
-
3241
-			return $result;
3242
-		}
3243
-
3244
-		/**
3245
-		 * Tests if the current output is inside a Beaver builder preview.
3246
-		 *
3247
-		 * @since 0.2.27
3248
-		 *
3249
-		 * @return bool
3250
-		 */
3251
-		public static function is_beaver_preview() {
3252
-			$result = false;
3253
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3254
-				$result = true;
3255
-			}
3256
-
3257
-			return $result;
3258
-		}
3259
-
3260
-		/**
3261
-		 * Tests if the current output is inside a siteorigin builder preview.
3262
-		 *
3263
-		 * @since 0.2.27
3264
-		 *
3265
-		 * @return bool
3266
-		 */
3267
-		public static function is_siteorigin_preview() {
3268
-			$result = false;
3269
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3270
-				$result = true;
3271
-			}
3272
-
3273
-			return $result;
3274
-		}
3275
-
3276
-		/**
3277
-		 * Tests if the current output is inside a cornerstone builder preview.
3278
-		 *
3279
-		 * @since 0.2.27
3280
-		 *
3281
-		 * @return bool
3282
-		 */
3283
-		public static function is_cornerstone_preview() {
3284
-			$result = false;
3285
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3286
-				$result = true;
3287
-			}
3288
-
3289
-			return $result;
3290
-		}
3291
-
3292
-		/**
3293
-		 * Tests if the current output is inside a fusion builder preview.
3294
-		 *
3295
-		 * @return bool
3296
-		 *@since 1.1.0
3297
-		 */
3298
-		public static function is_fusion_preview() {
3299
-			$result = false;
3300
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3301
-				$result = true;
3302
-			}
3303
-
3304
-			return $result;
3305
-		}
3306
-
3307
-		/**
3308
-		 * Tests if the current output is inside a Oxygen builder preview.
3309
-		 *
3310
-		 * @return bool
3311
-		 *@since 1.0.18
3312
-		 */
3313
-		public static function is_oxygen_preview() {
3314
-			$result = false;
3315
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3316
-				$result = true;
3317
-			}
3318
-
3319
-			return $result;
3320
-		}
3321
-
3322
-		/**
3323
-		 * Check for Kallyas theme Zion builder preview.
3324
-		 *
3325
-		 * @since 0.2.27
3326
-		 *
3327
-		 * @return bool
3328
-		 */
3329
-		public static function is_kallyas_zion_preview() {
3330
-			$result = false;
3331
-
3332
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3333
-				$result = true;
3334
-			}
3335
-
3336
-			return $result;
3337
-		}
3338
-
3339
-		/**
3340
-		 * Check for Bricks theme builder preview.
3341
-		 *
3342
-		 * @since 0.2.27
3343
-		 *
3344
-		 * @return bool
3345
-		 */
3346
-		public static function is_bricks_preview() {
3347
-			$result = false;
3348
-
3349
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3350
-				$result = true;
3351
-			}
3352
-
3353
-			return $result;
3354
-		}
3355
-
3356
-		/**
3357
-		 * General function to check if we are in a preview situation.
3358
-		 *
3359
-		 * @since 0.2.27
3360
-		 *
3361
-		 * @return bool
3362
-		 */
3363
-		public static function is_preview() {
3364
-			$preview = false;
3365
-
3366
-			if ( self::is_block_editor() ) {
3367
-				return true;
3368
-			}
3369
-
3370
-			if( self::is_block_content_call() ) {
3371
-				$preview = true;
3372
-			} elseif ( self::is_divi_preview() ) {
3373
-				$preview = true;
3374
-			} elseif ( self::is_elementor_preview() ) {
3375
-				$preview = true;
3376
-			} elseif ( self::is_beaver_preview() ) {
3377
-				$preview = true;
3378
-			} elseif ( self::is_siteorigin_preview() ) {
3379
-				$preview = true;
3380
-			} elseif ( self::is_cornerstone_preview() ) {
3381
-				$preview = true;
3382
-			} elseif ( self::is_fusion_preview() ) {
3383
-				$preview = true;
3384
-			} elseif ( self::is_oxygen_preview() ) {
3385
-				$preview = true;
3386
-			} elseif( self::is_kallyas_zion_preview() ) {
3387
-				$preview = true;
3388
-			} elseif( self::is_bricks_preview() ) {
3389
-				$preview = true;
3390
-			}
3391
-
3392
-			return $preview;
3393
-		}
3394
-	}
3395
-
3396
-	global $ayecode_ui_settings;
3397
-
3398
-	/**
3399
-	 * Run the class if found.
3400
-	 */
3401
-	$ayecode_ui_settings = AyeCode_UI_Settings::instance();
3169
+            $output = ob_get_clean();
3170
+
3171
+            return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3172
+        }
3173
+
3174
+        /**
3175
+         * Check if block editor page.
3176
+         *
3177
+         * @since 0.2.27
3178
+         *
3179
+         * @return bool
3180
+         */
3181
+        public static function is_block_editor() {
3182
+            if ( is_admin() ) {
3183
+                $current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3184
+
3185
+                if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3186
+                    return true;
3187
+                }
3188
+            }
3189
+
3190
+            return false;
3191
+        }
3192
+
3193
+        /**
3194
+         * Checks if the current call is a ajax call to get the block content.
3195
+         *
3196
+         * This can be used in your widget to return different content as the block content.
3197
+         *
3198
+         * @since 0.2.27
3199
+         *
3200
+         * @return bool
3201
+         */
3202
+        public static function is_block_content_call() {
3203
+            $result = false;
3204
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3205
+                $result = true;
3206
+            }
3207
+
3208
+            return $result;
3209
+        }
3210
+
3211
+        /**
3212
+         * Tests if the current output is inside a Divi preview.
3213
+         *
3214
+         * @since 0.2.27
3215
+         *
3216
+         * @return bool
3217
+         */
3218
+        public static function is_divi_preview() {
3219
+            $result = false;
3220
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3221
+                $result = true;
3222
+            }
3223
+
3224
+            return $result;
3225
+        }
3226
+
3227
+        /**
3228
+         * Tests if the current output is inside a elementor preview.
3229
+         *
3230
+         *
3231
+         * @since 0.2.27
3232
+         *
3233
+         * @return bool
3234
+         */
3235
+        public static function is_elementor_preview() {
3236
+            $result = false;
3237
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3238
+                $result = true;
3239
+            }
3240
+
3241
+            return $result;
3242
+        }
3243
+
3244
+        /**
3245
+         * Tests if the current output is inside a Beaver builder preview.
3246
+         *
3247
+         * @since 0.2.27
3248
+         *
3249
+         * @return bool
3250
+         */
3251
+        public static function is_beaver_preview() {
3252
+            $result = false;
3253
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
3254
+                $result = true;
3255
+            }
3256
+
3257
+            return $result;
3258
+        }
3259
+
3260
+        /**
3261
+         * Tests if the current output is inside a siteorigin builder preview.
3262
+         *
3263
+         * @since 0.2.27
3264
+         *
3265
+         * @return bool
3266
+         */
3267
+        public static function is_siteorigin_preview() {
3268
+            $result = false;
3269
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3270
+                $result = true;
3271
+            }
3272
+
3273
+            return $result;
3274
+        }
3275
+
3276
+        /**
3277
+         * Tests if the current output is inside a cornerstone builder preview.
3278
+         *
3279
+         * @since 0.2.27
3280
+         *
3281
+         * @return bool
3282
+         */
3283
+        public static function is_cornerstone_preview() {
3284
+            $result = false;
3285
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3286
+                $result = true;
3287
+            }
3288
+
3289
+            return $result;
3290
+        }
3291
+
3292
+        /**
3293
+         * Tests if the current output is inside a fusion builder preview.
3294
+         *
3295
+         * @return bool
3296
+         *@since 1.1.0
3297
+         */
3298
+        public static function is_fusion_preview() {
3299
+            $result = false;
3300
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3301
+                $result = true;
3302
+            }
3303
+
3304
+            return $result;
3305
+        }
3306
+
3307
+        /**
3308
+         * Tests if the current output is inside a Oxygen builder preview.
3309
+         *
3310
+         * @return bool
3311
+         *@since 1.0.18
3312
+         */
3313
+        public static function is_oxygen_preview() {
3314
+            $result = false;
3315
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3316
+                $result = true;
3317
+            }
3318
+
3319
+            return $result;
3320
+        }
3321
+
3322
+        /**
3323
+         * Check for Kallyas theme Zion builder preview.
3324
+         *
3325
+         * @since 0.2.27
3326
+         *
3327
+         * @return bool
3328
+         */
3329
+        public static function is_kallyas_zion_preview() {
3330
+            $result = false;
3331
+
3332
+            if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3333
+                $result = true;
3334
+            }
3335
+
3336
+            return $result;
3337
+        }
3338
+
3339
+        /**
3340
+         * Check for Bricks theme builder preview.
3341
+         *
3342
+         * @since 0.2.27
3343
+         *
3344
+         * @return bool
3345
+         */
3346
+        public static function is_bricks_preview() {
3347
+            $result = false;
3348
+
3349
+            if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3350
+                $result = true;
3351
+            }
3352
+
3353
+            return $result;
3354
+        }
3355
+
3356
+        /**
3357
+         * General function to check if we are in a preview situation.
3358
+         *
3359
+         * @since 0.2.27
3360
+         *
3361
+         * @return bool
3362
+         */
3363
+        public static function is_preview() {
3364
+            $preview = false;
3365
+
3366
+            if ( self::is_block_editor() ) {
3367
+                return true;
3368
+            }
3369
+
3370
+            if( self::is_block_content_call() ) {
3371
+                $preview = true;
3372
+            } elseif ( self::is_divi_preview() ) {
3373
+                $preview = true;
3374
+            } elseif ( self::is_elementor_preview() ) {
3375
+                $preview = true;
3376
+            } elseif ( self::is_beaver_preview() ) {
3377
+                $preview = true;
3378
+            } elseif ( self::is_siteorigin_preview() ) {
3379
+                $preview = true;
3380
+            } elseif ( self::is_cornerstone_preview() ) {
3381
+                $preview = true;
3382
+            } elseif ( self::is_fusion_preview() ) {
3383
+                $preview = true;
3384
+            } elseif ( self::is_oxygen_preview() ) {
3385
+                $preview = true;
3386
+            } elseif( self::is_kallyas_zion_preview() ) {
3387
+                $preview = true;
3388
+            } elseif( self::is_bricks_preview() ) {
3389
+                $preview = true;
3390
+            }
3391
+
3392
+            return $preview;
3393
+        }
3394
+    }
3395
+
3396
+    global $ayecode_ui_settings;
3397
+
3398
+    /**
3399
+     * Run the class if found.
3400
+     */
3401
+    $ayecode_ui_settings = AyeCode_UI_Settings::instance();
3402 3402
 }
3403 3403
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/includes/class-super-duper-bricks-element.php 3 patches
Braces   +4 added lines, -1 removed lines patch added patch discarded remove patch
@@ -1,7 +1,10 @@
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 
4
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
4
+if ( ! defined( 'ABSPATH' ) ) {
5
+    exit;
6
+}
7
+// Exit if accessed directly
5 8
 
6 9
 
7 10
 class Super_Duper_Bricks_Element extends \Bricks\Element {
Please login to merge, or discard this patch.
Indentation   +259 added lines, -259 removed lines patch added patch discarded remove patch
@@ -6,259 +6,259 @@  discard block
 block discarded – undo
6 6
 
7 7
 class Super_Duper_Bricks_Element extends \Bricks\Element {
8 8
 
9
-	public $widget;
10
-
11
-	public function __construct( $element = null ) {
12
-
13
-
14
-		$block_icon = !empty($this->widget->options['block-icon']) ? $this->widget->options['block-icon'] : '';
9
+    public $widget;
15 10
 
11
+    public function __construct( $element = null ) {
12
+
13
+
14
+        $block_icon = !empty($this->widget->options['block-icon']) ? $this->widget->options['block-icon'] : '';
15
+
16
+
17
+        $this->category = !empty($this->widget->options['textdomain']) ? esc_attr( $this->widget->options['textdomain'] ) : 'Super Duper';
18
+        $this->name     = $this->widget->id_base;
19
+        $this->icon     = (strpos($block_icon, 'fa') === 0) ? esc_attr($this->widget->options['block-icon']) : 'fas fa-globe-americas';
20
+
21
+        parent::__construct($element);
22
+    }
23
+
24
+    /**
25
+     * Set the element name.
26
+     *
27
+     * @return array|string|string[]|null
28
+     */
29
+    public function get_label() {
30
+        $escaped_text = esc_attr( $this->widget->name );
31
+        return str_replace( ' &gt; ', ' > ', $escaped_text ); // keep our > but have it safe
32
+    }
33
+
34
+    /**
35
+     * Bricks function to set the controls
36
+     *
37
+     * @return void
38
+     */
39
+    public function set_controls() {
40
+        $args = $this->sd_convert_arguments($this->widget);
41
+
42
+        if (!empty($args)) {
43
+            $this->controls = $this->controls + $args;
44
+        }
45
+
46
+    }
47
+
48
+    /**
49
+     * Set the bricks control groups from the GD ones.
50
+     *
51
+     * @return void
52
+     */
53
+    public function set_control_groups() {
54
+        $args = $this->sd_get_arguments();
55
+
56
+        $groups = array();
57
+        if(!empty($args)) {
58
+            foreach ($args as $k => $v) {
59
+                $g_slug = !empty($v['group']) ? sanitize_title( $v['group'] ) : '';
60
+                if($g_slug && empty($groups[$g_slug])) {
61
+                    $groups[$g_slug] = array(
62
+                        'title' => esc_html( $v['group'] ),
63
+                        'tab' => 'content',
64
+                    );
65
+                }
66
+            }
67
+        }
68
+
69
+        if(!empty($groups)) {
70
+            $this->control_groups = $this->control_groups + $groups;
71
+        }
72
+
73
+    }
74
+
75
+    /**
76
+     * Get the setting input arguments.
77
+     *
78
+     * @return mixed
79
+     */
80
+    public function sd_get_arguments() {
81
+        $args = $this->widget->set_arguments();
82
+
83
+        $widget_options = ! empty( $this->widget->options ) ? $this->widget->options : array();
84
+        $widget_instance = ! empty( $this->widget->instance ) ? $this->widget->instance : array();
85
+
86
+        $args = apply_filters( 'wp_super_duper_arguments', $args, $widget_options, $widget_instance );
87
+
88
+        $arg_keys_subtract = $this->sd_remove_arguments();
89
+
90
+        if ( ! empty( $arg_keys_subtract ) ) {
91
+            foreach($arg_keys_subtract as $key ){
92
+                unset($args[$key]);
93
+            }
94
+        }
95
+
96
+        return $args;
97
+    }
98
+
99
+
100
+    /**
101
+     * Simply use our own render function for the output.
102
+     *
103
+     * @return void
104
+     */
105
+    public function render() {
106
+        $settings = $this->sd_maybe_convert_values( $this->settings );
107
+
108
+        // Set the AyeCode UI calss on the wrapper
109
+        $this->set_attribute( '_root', 'class', 'bsui' );
110
+
111
+        // We might need to add a placeholder here for previews.
112
+
113
+        do_action( 'super_duper_before_render_bricks_element', $settings, $this->widget, $this );
114
+
115
+        // Add the bricks attributes to wrapper
116
+        echo "<div {$this->render_attributes( '_root' )}>";
117
+        echo $this->widget->output( $settings );
118
+        echo '</div>';
119
+    }
120
+
121
+    /**
122
+     * Values can never be arrays so convert if bricks setting make it an array.
123
+     *
124
+     * @param $settings
125
+     * @return mixed
126
+     */
127
+    public function sd_maybe_convert_values( $settings ) {
128
+
129
+
130
+        if (!empty($settings)) {
131
+            foreach( $settings as $k => $v ) {
132
+                if(is_array($v)) {
133
+                    $value = '';
134
+                    // is color
135
+                    if (isset($v['hex'])) {
136
+                        $value = $v['hex'];
137
+                    } elseif (isset($v['icon'])) {
138
+                        $value = $v['icon'];
139
+                    }
140
+
141
+
142
+                    // set the value
143
+                    $settings[$k] = $value;
144
+                }
145
+
146
+            }
147
+        }
148
+
149
+        return $settings;
150
+    }
151
+
152
+    /**
153
+     * Convert SD arguments to Bricks arguments.
154
+     *
155
+     * @param $widget
156
+     *
157
+     * @return array
158
+     */
159
+    public function sd_convert_arguments() {
160
+        $bricks_args = array();
161
+
162
+        $args = $this->sd_get_arguments();
163
+
164
+        if ( ! empty( $args ) ) {
165
+            foreach ( $args as $key => $arg ) {
166
+                // convert title
167
+                if ( ! empty( $arg['title'] ) ) {
168
+                    $arg['label'] = $arg['title'];
169
+                    unset( $arg['title'] );
170
+                }
171
+
172
+                // set fields not to use dynamic data
173
+                $arg['hasDynamicData'] = false;
174
+
175
+                if ( ! empty( $arg['group'] ) ) {
176
+                    $arg['group'] =  sanitize_title( $arg['group'] );
177
+                }
178
+
179
+                $arg['rerender'] = true;
180
+
181
+                // required
182
+                if( ! empty( $arg['element_require'] ) ) {
183
+                    $arg['required'] = $this->sd_convert_required( $arg['element_require'] );
184
+                    unset( $arg['element_require'] );
185
+                }
186
+
187
+                // icons
188
+                if ( 'icon' === $key ) {
189
+                    $arg['type'] = 'icon';
190
+                }
191
+
192
+                // Bricks don't render dropdown when first option key is 0.
193
+                if ( in_array( $key, array( 'zoom', 'mapzoom' ) ) && ! empty( $arg['options'] ) && is_array( $arg['options'] ) && ( $option_keys = array_keys( $arg['options'] ) ) ) {
194
+                    // Move first element to last.
195
+                    if ( $option_keys[0] === 0 || $option_keys[0] === '0' ) {
196
+                        $options = $arg['options'];
197
+                        unset( $arg['options'][0] );
198
+                        $arg['options'][0] = $options[0];
199
+                    }
200
+                }
201
+
202
+                $bricks_args[$key] = $arg;
203
+            }
204
+        }
205
+
206
+        return $bricks_args;
207
+    }
208
+
209
+    /**
210
+     * Convert the SD element_required to the Bricks required syntax.
211
+     *
212
+     * @param $element_require
213
+     * @return array
214
+     */
215
+    public function sd_convert_required($element_require) {
216
+        $bricks_required = [];
217
+
218
+        // Handle logical OR (||) for multiple values
219
+        if (strpos($element_require, '||') !== false) {
220
+            preg_match('/\[%(.+?)%\] *== *"(.*?)"/', $element_require, $matches);
221
+            if ($matches) {
222
+                $control_id = $matches[1];
223
+                preg_match_all('/\[%.*?%\] *== *"(.*?)"/', $element_require, $value_matches);
224
+                $values = $value_matches[1];
225
+                $bricks_required[] = [$control_id, '=', $values];
226
+            }
227
+            return $bricks_required;
228
+        }
229
+
230
+        // Match individual conditions
231
+        preg_match_all('/(!)?\[%(.*?)%\](?:\s*([!=<>]=?)\s*(".*?"|\'.*?\'|\d+))?/', $element_require, $matches, PREG_SET_ORDER);
232
+
233
+        foreach ($matches as $match) {
234
+            $is_negation = isset($match[1]) && $match[1] === '!';
235
+            $control_id = $match[2];
236
+            $operator = isset($match[3]) ? str_replace('==', '=', $match[3]) : ($is_negation ? '=' : '!=');
237
+            $value = isset($match[4]) ? trim($match[4], '"\'') : ($is_negation ? '' : '');
238
+
239
+            // Adjust for negation without explicit operator
240
+            if ($is_negation && !isset($match[3])) {
241
+                $operator = '=';
242
+                $value = '';
243
+            }
244
+
245
+            $bricks_required[] = [$control_id, $operator, $value];
246
+        }
247
+
248
+        return $bricks_required;
249
+    }
250
+
251
+
252
+    /**
253
+     * A way to remove some settings by keys.
254
+     *
255
+     * @return array
256
+     */
257
+    public function sd_remove_arguments()
258
+    {
259
+        return array();
260
+    }
16 261
 
17
-		$this->category = !empty($this->widget->options['textdomain']) ? esc_attr( $this->widget->options['textdomain'] ) : 'Super Duper';
18
-		$this->name     = $this->widget->id_base;
19
-		$this->icon     = (strpos($block_icon, 'fa') === 0) ? esc_attr($this->widget->options['block-icon']) : 'fas fa-globe-americas';
20
-
21
-		parent::__construct($element);
22
-	}
23
-
24
-	/**
25
-	 * Set the element name.
26
-	 *
27
-	 * @return array|string|string[]|null
28
-	 */
29
-	public function get_label() {
30
-		$escaped_text = esc_attr( $this->widget->name );
31
-		return str_replace( ' &gt; ', ' > ', $escaped_text ); // keep our > but have it safe
32
-	}
33
-
34
-	/**
35
-	 * Bricks function to set the controls
36
-	 *
37
-	 * @return void
38
-	 */
39
-	public function set_controls() {
40
-		$args = $this->sd_convert_arguments($this->widget);
41
-
42
-		if (!empty($args)) {
43
-			$this->controls = $this->controls + $args;
44
-		}
45
-
46
-	}
47
-
48
-	/**
49
-	 * Set the bricks control groups from the GD ones.
50
-	 *
51
-	 * @return void
52
-	 */
53
-	public function set_control_groups() {
54
-		$args = $this->sd_get_arguments();
55
-
56
-		$groups = array();
57
-		if(!empty($args)) {
58
-			foreach ($args as $k => $v) {
59
-				$g_slug = !empty($v['group']) ? sanitize_title( $v['group'] ) : '';
60
-				if($g_slug && empty($groups[$g_slug])) {
61
-					$groups[$g_slug] = array(
62
-						'title' => esc_html( $v['group'] ),
63
-						'tab' => 'content',
64
-					);
65
-				}
66
-			}
67
-		}
68
-
69
-		if(!empty($groups)) {
70
-			$this->control_groups = $this->control_groups + $groups;
71
-		}
72
-
73
-	}
74
-
75
-	/**
76
-	 * Get the setting input arguments.
77
-	 *
78
-	 * @return mixed
79
-	 */
80
-	public function sd_get_arguments() {
81
-		$args = $this->widget->set_arguments();
82
-
83
-		$widget_options = ! empty( $this->widget->options ) ? $this->widget->options : array();
84
-		$widget_instance = ! empty( $this->widget->instance ) ? $this->widget->instance : array();
85
-
86
-		$args = apply_filters( 'wp_super_duper_arguments', $args, $widget_options, $widget_instance );
87
-
88
-		$arg_keys_subtract = $this->sd_remove_arguments();
89
-
90
-		if ( ! empty( $arg_keys_subtract ) ) {
91
-			foreach($arg_keys_subtract as $key ){
92
-				unset($args[$key]);
93
-			}
94
-		}
95
-
96
-		return $args;
97
-	}
98
-
99
-
100
-	/**
101
-	 * Simply use our own render function for the output.
102
-	 *
103
-	 * @return void
104
-	 */
105
-	public function render() {
106
-		$settings = $this->sd_maybe_convert_values( $this->settings );
107
-
108
-		// Set the AyeCode UI calss on the wrapper
109
-		$this->set_attribute( '_root', 'class', 'bsui' );
110
-
111
-		// We might need to add a placeholder here for previews.
112
-
113
-		do_action( 'super_duper_before_render_bricks_element', $settings, $this->widget, $this );
114
-
115
-		// Add the bricks attributes to wrapper
116
-		echo "<div {$this->render_attributes( '_root' )}>";
117
-		echo $this->widget->output( $settings );
118
-		echo '</div>';
119
-	}
120
-
121
-	/**
122
-	 * Values can never be arrays so convert if bricks setting make it an array.
123
-	 *
124
-	 * @param $settings
125
-	 * @return mixed
126
-	 */
127
-	public function sd_maybe_convert_values( $settings ) {
128
-
129
-
130
-		if (!empty($settings)) {
131
-			foreach( $settings as $k => $v ) {
132
-				if(is_array($v)) {
133
-					$value = '';
134
-					// is color
135
-					if (isset($v['hex'])) {
136
-						$value = $v['hex'];
137
-					} elseif (isset($v['icon'])) {
138
-						$value = $v['icon'];
139
-					}
140
-
141
-
142
-					// set the value
143
-					$settings[$k] = $value;
144
-				}
145
-
146
-			}
147
-		}
148
-
149
-		return $settings;
150
-	}
151
-
152
-	/**
153
-	 * Convert SD arguments to Bricks arguments.
154
-	 *
155
-	 * @param $widget
156
-	 *
157
-	 * @return array
158
-	 */
159
-	public function sd_convert_arguments() {
160
-		$bricks_args = array();
161
-
162
-		$args = $this->sd_get_arguments();
163
-
164
-		if ( ! empty( $args ) ) {
165
-			foreach ( $args as $key => $arg ) {
166
-				// convert title
167
-				if ( ! empty( $arg['title'] ) ) {
168
-					$arg['label'] = $arg['title'];
169
-					unset( $arg['title'] );
170
-				}
171
-
172
-				// set fields not to use dynamic data
173
-				$arg['hasDynamicData'] = false;
174
-
175
-				if ( ! empty( $arg['group'] ) ) {
176
-					$arg['group'] =  sanitize_title( $arg['group'] );
177
-				}
178
-
179
-				$arg['rerender'] = true;
180
-
181
-				// required
182
-				if( ! empty( $arg['element_require'] ) ) {
183
-					$arg['required'] = $this->sd_convert_required( $arg['element_require'] );
184
-					unset( $arg['element_require'] );
185
-				}
186
-
187
-				// icons
188
-				if ( 'icon' === $key ) {
189
-					$arg['type'] = 'icon';
190
-				}
191
-
192
-				// Bricks don't render dropdown when first option key is 0.
193
-				if ( in_array( $key, array( 'zoom', 'mapzoom' ) ) && ! empty( $arg['options'] ) && is_array( $arg['options'] ) && ( $option_keys = array_keys( $arg['options'] ) ) ) {
194
-					// Move first element to last.
195
-					if ( $option_keys[0] === 0 || $option_keys[0] === '0' ) {
196
-						$options = $arg['options'];
197
-						unset( $arg['options'][0] );
198
-						$arg['options'][0] = $options[0];
199
-					}
200
-				}
201
-
202
-				$bricks_args[$key] = $arg;
203
-			}
204
-		}
205
-
206
-		return $bricks_args;
207
-	}
208
-
209
-	/**
210
-	 * Convert the SD element_required to the Bricks required syntax.
211
-	 *
212
-	 * @param $element_require
213
-	 * @return array
214
-	 */
215
-	public function sd_convert_required($element_require) {
216
-		$bricks_required = [];
217
-
218
-		// Handle logical OR (||) for multiple values
219
-		if (strpos($element_require, '||') !== false) {
220
-			preg_match('/\[%(.+?)%\] *== *"(.*?)"/', $element_require, $matches);
221
-			if ($matches) {
222
-				$control_id = $matches[1];
223
-				preg_match_all('/\[%.*?%\] *== *"(.*?)"/', $element_require, $value_matches);
224
-				$values = $value_matches[1];
225
-				$bricks_required[] = [$control_id, '=', $values];
226
-			}
227
-			return $bricks_required;
228
-		}
229
-
230
-		// Match individual conditions
231
-		preg_match_all('/(!)?\[%(.*?)%\](?:\s*([!=<>]=?)\s*(".*?"|\'.*?\'|\d+))?/', $element_require, $matches, PREG_SET_ORDER);
232
-
233
-		foreach ($matches as $match) {
234
-			$is_negation = isset($match[1]) && $match[1] === '!';
235
-			$control_id = $match[2];
236
-			$operator = isset($match[3]) ? str_replace('==', '=', $match[3]) : ($is_negation ? '=' : '!=');
237
-			$value = isset($match[4]) ? trim($match[4], '"\'') : ($is_negation ? '' : '');
238
-
239
-			// Adjust for negation without explicit operator
240
-			if ($is_negation && !isset($match[3])) {
241
-				$operator = '=';
242
-				$value = '';
243
-			}
244
-
245
-			$bricks_required[] = [$control_id, $operator, $value];
246
-		}
247
-
248
-		return $bricks_required;
249
-	}
250
-
251
-
252
-	/**
253
-	 * A way to remove some settings by keys.
254
-	 *
255
-	 * @return array
256
-	 */
257
-	public function sd_remove_arguments()
258
-	{
259
-		return array();
260
-	}
261
-
262 262
 }
263 263
 
264 264
 
@@ -267,12 +267,12 @@  discard block
 block discarded – undo
267 267
  */
268 268
 add_action( 'wp_enqueue_scripts', function() {
269 269
 
270
-	// Check if we're in the Bricks Editor
271
-	if ( isset( $_GET['bricks'] ) && $_GET['bricks'] && bricks_is_builder_main() ) {
272
-		// Add inline script to the 'bricks-builder' script
273
-		wp_add_inline_script(
274
-			'bricks-builder',
275
-			"
270
+    // Check if we're in the Bricks Editor
271
+    if ( isset( $_GET['bricks'] ) && $_GET['bricks'] && bricks_is_builder_main() ) {
272
+        // Add inline script to the 'bricks-builder' script
273
+        wp_add_inline_script(
274
+            'bricks-builder',
275
+            "
276 276
 
277 277
 (function () {
278 278
     // Function to get the current breakpoint from the #bricks-preview class
@@ -479,6 +479,6 @@  discard block
 block discarded – undo
479 479
     addIconsToLabels();
480 480
 })();
481 481
 "
482
-		);
483
-	}
482
+        );
483
+    }
484 484
 });
Please login to merge, or discard this patch.
Spacing   +38 added lines, -38 removed lines patch added patch discarded remove patch
@@ -1,20 +1,20 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 
4
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
4
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
5 5
 
6 6
 
7 7
 class Super_Duper_Bricks_Element extends \Bricks\Element {
8 8
 
9 9
 	public $widget;
10 10
 
11
-	public function __construct( $element = null ) {
11
+	public function __construct($element = null) {
12 12
 
13 13
 
14 14
 		$block_icon = !empty($this->widget->options['block-icon']) ? $this->widget->options['block-icon'] : '';
15 15
 
16 16
 
17
-		$this->category = !empty($this->widget->options['textdomain']) ? esc_attr( $this->widget->options['textdomain'] ) : 'Super Duper';
17
+		$this->category = !empty($this->widget->options['textdomain']) ? esc_attr($this->widget->options['textdomain']) : 'Super Duper';
18 18
 		$this->name     = $this->widget->id_base;
19 19
 		$this->icon     = (strpos($block_icon, 'fa') === 0) ? esc_attr($this->widget->options['block-icon']) : 'fas fa-globe-americas';
20 20
 
@@ -27,8 +27,8 @@  discard block
 block discarded – undo
27 27
 	 * @return array|string|string[]|null
28 28
 	 */
29 29
 	public function get_label() {
30
-		$escaped_text = esc_attr( $this->widget->name );
31
-		return str_replace( ' &gt; ', ' > ', $escaped_text ); // keep our > but have it safe
30
+		$escaped_text = esc_attr($this->widget->name);
31
+		return str_replace(' &gt; ', ' > ', $escaped_text); // keep our > but have it safe
32 32
 	}
33 33
 
34 34
 	/**
@@ -54,19 +54,19 @@  discard block
 block discarded – undo
54 54
 		$args = $this->sd_get_arguments();
55 55
 
56 56
 		$groups = array();
57
-		if(!empty($args)) {
57
+		if (!empty($args)) {
58 58
 			foreach ($args as $k => $v) {
59
-				$g_slug = !empty($v['group']) ? sanitize_title( $v['group'] ) : '';
60
-				if($g_slug && empty($groups[$g_slug])) {
59
+				$g_slug = !empty($v['group']) ? sanitize_title($v['group']) : '';
60
+				if ($g_slug && empty($groups[$g_slug])) {
61 61
 					$groups[$g_slug] = array(
62
-						'title' => esc_html( $v['group'] ),
62
+						'title' => esc_html($v['group']),
63 63
 						'tab' => 'content',
64 64
 					);
65 65
 				}
66 66
 			}
67 67
 		}
68 68
 
69
-		if(!empty($groups)) {
69
+		if (!empty($groups)) {
70 70
 			$this->control_groups = $this->control_groups + $groups;
71 71
 		}
72 72
 
@@ -80,15 +80,15 @@  discard block
 block discarded – undo
80 80
 	public function sd_get_arguments() {
81 81
 		$args = $this->widget->set_arguments();
82 82
 
83
-		$widget_options = ! empty( $this->widget->options ) ? $this->widget->options : array();
84
-		$widget_instance = ! empty( $this->widget->instance ) ? $this->widget->instance : array();
83
+		$widget_options = !empty($this->widget->options) ? $this->widget->options : array();
84
+		$widget_instance = !empty($this->widget->instance) ? $this->widget->instance : array();
85 85
 
86
-		$args = apply_filters( 'wp_super_duper_arguments', $args, $widget_options, $widget_instance );
86
+		$args = apply_filters('wp_super_duper_arguments', $args, $widget_options, $widget_instance);
87 87
 
88 88
 		$arg_keys_subtract = $this->sd_remove_arguments();
89 89
 
90
-		if ( ! empty( $arg_keys_subtract ) ) {
91
-			foreach($arg_keys_subtract as $key ){
90
+		if (!empty($arg_keys_subtract)) {
91
+			foreach ($arg_keys_subtract as $key) {
92 92
 				unset($args[$key]);
93 93
 			}
94 94
 		}
@@ -103,18 +103,18 @@  discard block
 block discarded – undo
103 103
 	 * @return void
104 104
 	 */
105 105
 	public function render() {
106
-		$settings = $this->sd_maybe_convert_values( $this->settings );
106
+		$settings = $this->sd_maybe_convert_values($this->settings);
107 107
 
108 108
 		// Set the AyeCode UI calss on the wrapper
109
-		$this->set_attribute( '_root', 'class', 'bsui' );
109
+		$this->set_attribute('_root', 'class', 'bsui');
110 110
 
111 111
 		// We might need to add a placeholder here for previews.
112 112
 
113
-		do_action( 'super_duper_before_render_bricks_element', $settings, $this->widget, $this );
113
+		do_action('super_duper_before_render_bricks_element', $settings, $this->widget, $this);
114 114
 
115 115
 		// Add the bricks attributes to wrapper
116
-		echo "<div {$this->render_attributes( '_root' )}>";
117
-		echo $this->widget->output( $settings );
116
+		echo "<div {$this->render_attributes('_root')}>";
117
+		echo $this->widget->output($settings);
118 118
 		echo '</div>';
119 119
 	}
120 120
 
@@ -124,12 +124,12 @@  discard block
 block discarded – undo
124 124
 	 * @param $settings
125 125
 	 * @return mixed
126 126
 	 */
127
-	public function sd_maybe_convert_values( $settings ) {
127
+	public function sd_maybe_convert_values($settings) {
128 128
 
129 129
 
130 130
 		if (!empty($settings)) {
131
-			foreach( $settings as $k => $v ) {
132
-				if(is_array($v)) {
131
+			foreach ($settings as $k => $v) {
132
+				if (is_array($v)) {
133 133
 					$value = '';
134 134
 					// is color
135 135
 					if (isset($v['hex'])) {
@@ -161,40 +161,40 @@  discard block
 block discarded – undo
161 161
 
162 162
 		$args = $this->sd_get_arguments();
163 163
 
164
-		if ( ! empty( $args ) ) {
165
-			foreach ( $args as $key => $arg ) {
164
+		if (!empty($args)) {
165
+			foreach ($args as $key => $arg) {
166 166
 				// convert title
167
-				if ( ! empty( $arg['title'] ) ) {
167
+				if (!empty($arg['title'])) {
168 168
 					$arg['label'] = $arg['title'];
169
-					unset( $arg['title'] );
169
+					unset($arg['title']);
170 170
 				}
171 171
 
172 172
 				// set fields not to use dynamic data
173 173
 				$arg['hasDynamicData'] = false;
174 174
 
175
-				if ( ! empty( $arg['group'] ) ) {
176
-					$arg['group'] =  sanitize_title( $arg['group'] );
175
+				if (!empty($arg['group'])) {
176
+					$arg['group'] = sanitize_title($arg['group']);
177 177
 				}
178 178
 
179 179
 				$arg['rerender'] = true;
180 180
 
181 181
 				// required
182
-				if( ! empty( $arg['element_require'] ) ) {
183
-					$arg['required'] = $this->sd_convert_required( $arg['element_require'] );
184
-					unset( $arg['element_require'] );
182
+				if (!empty($arg['element_require'])) {
183
+					$arg['required'] = $this->sd_convert_required($arg['element_require']);
184
+					unset($arg['element_require']);
185 185
 				}
186 186
 
187 187
 				// icons
188
-				if ( 'icon' === $key ) {
188
+				if ('icon' === $key) {
189 189
 					$arg['type'] = 'icon';
190 190
 				}
191 191
 
192 192
 				// Bricks don't render dropdown when first option key is 0.
193
-				if ( in_array( $key, array( 'zoom', 'mapzoom' ) ) && ! empty( $arg['options'] ) && is_array( $arg['options'] ) && ( $option_keys = array_keys( $arg['options'] ) ) ) {
193
+				if (in_array($key, array('zoom', 'mapzoom')) && !empty($arg['options']) && is_array($arg['options']) && ($option_keys = array_keys($arg['options']))) {
194 194
 					// Move first element to last.
195
-					if ( $option_keys[0] === 0 || $option_keys[0] === '0' ) {
195
+					if ($option_keys[0] === 0 || $option_keys[0] === '0') {
196 196
 						$options = $arg['options'];
197
-						unset( $arg['options'][0] );
197
+						unset($arg['options'][0]);
198 198
 						$arg['options'][0] = $options[0];
199 199
 					}
200 200
 				}
@@ -265,10 +265,10 @@  discard block
 block discarded – undo
265 265
 /**
266 266
  * This implements the desktop, tablet and mobile breakpoints views with our fields that are hidden on these types and adda the icon after the label to show which it applies to.
267 267
  */
268
-add_action( 'wp_enqueue_scripts', function() {
268
+add_action('wp_enqueue_scripts', function() {
269 269
 
270 270
 	// Check if we're in the Bricks Editor
271
-	if ( isset( $_GET['bricks'] ) && $_GET['bricks'] && bricks_is_builder_main() ) {
271
+	if (isset($_GET['bricks']) && $_GET['bricks'] && bricks_is_builder_main()) {
272 272
 		// Add inline script to the 'bricks-builder' script
273 273
 		wp_add_inline_script(
274 274
 			'bricks-builder',
Please login to merge, or discard this patch.
includes/class-wpinv-privacy-exporters.php 1 patch
Spacing   +61 added lines, -61 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Personal data exporters.
4 4
  */
5 5
 
6
-defined( 'ABSPATH' ) || exit;
6
+defined('ABSPATH') || exit;
7 7
 
8 8
 /**
9 9
  * WPInv_Privacy_Exporters Class.
@@ -17,39 +17,39 @@  discard block
 block discarded – undo
17 17
      * @param int    $page  Page.
18 18
      * @return array An array of invoice data in name value pairs
19 19
      */
20
-    public static function customer_invoice_data_exporter( $email_address, $page ) {
20
+    public static function customer_invoice_data_exporter($email_address, $page) {
21 21
         $done           = false;
22 22
         $page           = (int) $page;
23 23
         $data_to_export = array();
24 24
 
25
-        $user           = get_user_by( 'email', $email_address );
26
-        if ( ! $user instanceof WP_User ) {
25
+        $user           = get_user_by('email', $email_address);
26
+        if (!$user instanceof WP_User) {
27 27
             return array(
28 28
                 'data' => $data_to_export,
29 29
                 'done' => true,
30 30
             );
31 31
         }
32 32
 
33
-        $args    = array(
34
-            'limit'    => get_option( 'posts_per_page' ),
33
+        $args = array(
34
+            'limit'    => get_option('posts_per_page'),
35 35
             'page'     => $page,
36 36
             'user'     => $user->ID,
37 37
             'paginate' => false,
38 38
         );
39 39
 
40
-        $invoices = wpinv_get_invoices( $args );
40
+        $invoices = wpinv_get_invoices($args);
41 41
 
42
-        if ( 0 < count( $invoices ) ) {
43
-            foreach ( $invoices as $invoice ) {
42
+        if (0 < count($invoices)) {
43
+            foreach ($invoices as $invoice) {
44 44
                 $data_to_export[] = array(
45 45
                     'group_id'          => 'customer_invoices',
46
-                    'group_label'       => __( 'GetPaid: Invoices', 'invoicing' ),
47
-                    'group_description' => __( 'Customer invoices.', 'invoicing' ),
46
+                    'group_label'       => __('GetPaid: Invoices', 'invoicing'),
47
+                    'group_description' => __('Customer invoices.', 'invoicing'),
48 48
                     'item_id'           => "wpinv-{$invoice->get_id()}",
49
-                    'data'              => self::get_customer_invoice_data( $invoice ),
49
+                    'data'              => self::get_customer_invoice_data($invoice),
50 50
                 );
51 51
             }
52
-            $done = get_option( 'posts_per_page' ) > count( $invoices );
52
+            $done = get_option('posts_per_page') > count($invoices);
53 53
         } else {
54 54
             $done = true;
55 55
         }
@@ -67,122 +67,122 @@  discard block
 block discarded – undo
67 67
      * @param WPInv_Invoice $invoice invoice object.
68 68
      * @return array
69 69
      */
70
-    public static function get_customer_invoice_data( $invoice ) {
70
+    public static function get_customer_invoice_data($invoice) {
71 71
 
72 72
         // Prepare basic properties.
73 73
         $props_to_export = array(
74 74
             'number'       => array(
75
-                'name'  => __( 'Invoice Number', 'invoicing' ),
75
+                'name'  => __('Invoice Number', 'invoicing'),
76 76
                 'value' => $invoice->get_number(),
77 77
             ),
78 78
             'created_date' => array(
79
-                'name'  => __( 'Created Date', 'invoicing' ),
79
+                'name'  => __('Created Date', 'invoicing'),
80 80
                 'value' => $invoice->get_date_created(),
81 81
             ),
82 82
             'due_date'     => array(
83
-                'name'  => __( 'Due Date', 'invoicing' ),
83
+                'name'  => __('Due Date', 'invoicing'),
84 84
                 'value' => $invoice->get_due_date(),
85 85
             ),
86 86
             'items'        => array(
87
-                'name'  => __( 'Invoice Items', 'invoicing' ),
88
-                'value' => self::process_invoice_items( $invoice ),
87
+                'name'  => __('Invoice Items', 'invoicing'),
88
+                'value' => self::process_invoice_items($invoice),
89 89
             ),
90 90
             'discount'     => array(
91
-                'name'  => __( 'Invoice Discount', 'invoicing' ),
92
-                'value' => wpinv_price( $invoice->get_total_discount(), $invoice->get_currency() ),
91
+                'name'  => __('Invoice Discount', 'invoicing'),
92
+                'value' => wpinv_price($invoice->get_total_discount(), $invoice->get_currency()),
93 93
             ),
94 94
             'total'        => array(
95
-                'name'  => __( 'Invoice Total', 'invoicing' ),
96
-                'value' => wpinv_price( $invoice->get_total(), $invoice->get_currency() ),
95
+                'name'  => __('Invoice Total', 'invoicing'),
96
+                'value' => wpinv_price($invoice->get_total(), $invoice->get_currency()),
97 97
             ),
98 98
             'status'       => array(
99
-                'name'  => __( 'Invoice Status', 'invoicing' ),
99
+                'name'  => __('Invoice Status', 'invoicing'),
100 100
                 'value' => $invoice->get_status_nicename(),
101 101
             ),
102 102
             'first_name'   => array(
103
-                'name'  => __( 'First Name', 'invoicing' ),
103
+                'name'  => __('First Name', 'invoicing'),
104 104
                 'value' => $invoice->get_first_name(),
105 105
             ),
106 106
             'last_name'    => array(
107
-                'name'  => __( 'Last Name', 'invoicing' ),
107
+                'name'  => __('Last Name', 'invoicing'),
108 108
                 'value' => $invoice->get_last_name(),
109 109
             ),
110 110
             'email'        => array(
111
-                'name'  => __( 'Email Address', 'invoicing' ),
111
+                'name'  => __('Email Address', 'invoicing'),
112 112
                 'value' => $invoice->get_email(),
113 113
             ),
114 114
             'company'      => array(
115
-                'name'  => __( 'Company', 'invoicing' ),
115
+                'name'  => __('Company', 'invoicing'),
116 116
                 'value' => $invoice->get_company(),
117 117
             ),
118 118
             'phone'        => array(
119
-                'name'  => __( 'Phone Number', 'invoicing' ),
119
+                'name'  => __('Phone Number', 'invoicing'),
120 120
                 'value' => $invoice->get_phone(),
121 121
             ),
122 122
             'address'      => array(
123
-                'name'  => __( 'Address', 'invoicing' ),
123
+                'name'  => __('Address', 'invoicing'),
124 124
                 'value' => $invoice->get_address(),
125 125
             ),
126 126
             'city'         => array(
127
-                'name'  => __( 'City', 'invoicing' ),
127
+                'name'  => __('City', 'invoicing'),
128 128
                 'value' => $invoice->get_city(),
129 129
             ),
130 130
             'state'        => array(
131
-                'name'  => __( 'State', 'invoicing' ),
131
+                'name'  => __('State', 'invoicing'),
132 132
                 'value' => $invoice->get_state(),
133 133
             ),
134 134
             'zip'          => array(
135
-                'name'  => __( 'Zip', 'invoicing' ),
135
+                'name'  => __('Zip', 'invoicing'),
136 136
                 'value' => $invoice->get_zip(),
137 137
             ),
138 138
             'vat_number'   => array(
139
-                'name'  => __( 'VAT Number', 'invoicing' ),
139
+                'name'  => __('VAT Number', 'invoicing'),
140 140
                 'value' => $invoice->get_vat_number(),
141 141
             ),
142 142
             'description'  => array(
143
-                'name'  => __( 'Description', 'invoicing' ),
143
+                'name'  => __('Description', 'invoicing'),
144 144
                 'value' => $invoice->get_description(),
145 145
             ),
146 146
         );
147 147
 
148 148
         // In case the invoice is paid, add the payment date and gateway.
149
-        if ( $invoice->is_paid() ) {
149
+        if ($invoice->is_paid()) {
150 150
 
151 151
             $props_to_export['completed_date'] = array(
152
-                'name'  => __( 'Completed Date', 'invoicing' ),
152
+                'name'  => __('Completed Date', 'invoicing'),
153 153
                 'value' => $invoice->get_completed_date(),
154 154
             );
155 155
 
156 156
             $props_to_export['gateway'] = array(
157
-                'name'  => __( 'Paid Via', 'invoicing' ),
157
+                'name'  => __('Paid Via', 'invoicing'),
158 158
                 'value' => $invoice->get_gateway(),
159 159
             );
160 160
 
161 161
         }
162 162
 
163 163
         // Maybe add subscription details.
164
-        $props_to_export = self::process_subscription( $invoice, $props_to_export );
164
+        $props_to_export = self::process_subscription($invoice, $props_to_export);
165 165
 
166 166
         // Add the ip address.
167 167
         $props_to_export['ip'] = array(
168
-            'name'  => __( 'IP Address', 'invoicing' ),
168
+            'name'  => __('IP Address', 'invoicing'),
169 169
             'value' => $invoice->get_ip(),
170 170
         );
171 171
 
172 172
         // Add the invoice url.
173 173
         $props_to_export['view_url'] = array(
174
-            'name'  => __( 'Invoice URL', 'invoicing' ),
174
+            'name'  => __('Invoice URL', 'invoicing'),
175 175
             'value' => $invoice->get_view_url(),
176 176
         );
177 177
 
178 178
         // Return the values.
179
-        $items = apply_filters( 'getpaid_privacy_export_invoice_personal_data', array_values( $props_to_export ), $invoice );
179
+        $items = apply_filters('getpaid_privacy_export_invoice_personal_data', array_values($props_to_export), $invoice);
180 180
 
181 181
         $data = array();
182 182
 
183 183
         // Unset null values to prevent PHP deprecated notice.
184
-        foreach ( $items as $item ) {
185
-            if ( isset( $item['value'] ) && ! is_null( $item['value'] ) ) {
184
+        foreach ($items as $item) {
185
+            if (isset($item['value']) && !is_null($item['value'])) {
186 186
                 $data[] = $item;
187 187
             }
188 188
         }
@@ -198,40 +198,40 @@  discard block
 block discarded – undo
198 198
      * @param array $props invoice props.
199 199
      * @return array
200 200
      */
201
-    public static function process_subscription( $invoice, $props ) {
201
+    public static function process_subscription($invoice, $props) {
202 202
 
203
-        $subscription = wpinv_get_subscription( $invoice );
204
-        if ( ! empty( $subscription ) ) {
203
+        $subscription = wpinv_get_subscription($invoice);
204
+        if (!empty($subscription)) {
205 205
 
206
-            $frequency    = getpaid_get_subscription_period_label( $subscription->get_period(), $subscription->get_frequency() );
207
-            $period       = wpinv_price( $subscription->get_recurring_amount(), $subscription->get_parent_payment()->get_currency() ) . ' / ' . $frequency;
208
-            $initial_amt  = wpinv_price( $subscription->get_initial_amount(), $subscription->get_parent_payment()->get_currency() );
209
-            $bill_times   = $subscription->get_times_billed() . ' / ' . ( ( $subscription->get_bill_times() == 0 ) ? __( 'Until Cancelled', 'invoicing' ) : $subscription->get_bill_times() );
210
-            $renewal_date = getpaid_format_date_value( $subscription->get_expiration() );
206
+            $frequency    = getpaid_get_subscription_period_label($subscription->get_period(), $subscription->get_frequency());
207
+            $period       = wpinv_price($subscription->get_recurring_amount(), $subscription->get_parent_payment()->get_currency()) . ' / ' . $frequency;
208
+            $initial_amt  = wpinv_price($subscription->get_initial_amount(), $subscription->get_parent_payment()->get_currency());
209
+            $bill_times   = $subscription->get_times_billed() . ' / ' . (($subscription->get_bill_times() == 0) ? __('Until Cancelled', 'invoicing') : $subscription->get_bill_times());
210
+            $renewal_date = getpaid_format_date_value($subscription->get_expiration());
211 211
 
212 212
             // Billing cycle.
213 213
             $props['period'] = array(
214
-                'name'  => __( 'Billing Cycle', 'invoicing' ),
214
+                'name'  => __('Billing Cycle', 'invoicing'),
215 215
                 'value' => $period,
216 216
             );
217 217
 
218 218
             // Initial amount.
219 219
             $props['initial_amount'] = array(
220
-                'name'  => __( 'Initial Amount', 'invoicing' ),
220
+                'name'  => __('Initial Amount', 'invoicing'),
221 221
                 'value' => $initial_amt,
222 222
             );
223 223
 
224 224
             // Bill times.
225 225
             $props['bill_times'] = array(
226
-                'name'  => __( 'Times Billed', 'invoicing' ),
226
+                'name'  => __('Times Billed', 'invoicing'),
227 227
                 'value' => $bill_times,
228 228
             );
229 229
 
230 230
             // Add expiry date.
231
-            if ( $subscription->is_active() ) {
231
+            if ($subscription->is_active()) {
232 232
 
233 233
                 $props['renewal_date'] = array(
234
-                    'name'  => __( 'Expires', 'invoicing' ),
234
+                    'name'  => __('Expires', 'invoicing'),
235 235
                     'value' => $renewal_date,
236 236
                 );
237 237
 
@@ -249,19 +249,19 @@  discard block
 block discarded – undo
249 249
      * @param WPInv_Invoice $invoice invoice object.
250 250
      * @return array
251 251
      */
252
-    public static function process_invoice_items( $invoice ) {
252
+    public static function process_invoice_items($invoice) {
253 253
 
254 254
         $item_names = array();
255
-        foreach ( $invoice->get_items() as $cart_item ) {
255
+        foreach ($invoice->get_items() as $cart_item) {
256 256
             $item_names[] = sprintf(
257 257
                 '%s x %s - %s',
258 258
                 $cart_item->get_name(),
259 259
                 $cart_item->get_quantity(),
260
-                wpinv_price( $invoice->is_renewal() ? $cart_item->get_recurring_sub_total() : $cart_item->get_sub_total(), $invoice->get_currency() )
260
+                wpinv_price($invoice->is_renewal() ? $cart_item->get_recurring_sub_total() : $cart_item->get_sub_total(), $invoice->get_currency())
261 261
             );
262 262
         }
263 263
 
264
-        return implode( ', ', $item_names );
264
+        return implode(', ', $item_names);
265 265
 
266 266
     }
267 267
 
Please login to merge, or discard this patch.
includes/class-wpinv-privacy.php 2 patches
Indentation   +20 added lines, -20 removed lines patch added patch discarded remove patch
@@ -29,7 +29,7 @@  discard block
 block discarded – undo
29 29
         add_action( 'init', array( $this, 'register_erasers_exporters' ) );
30 30
     }
31 31
 
32
-   /**
32
+    /**
33 33
      * Initial registration of privacy erasers and exporters.
34 34
      *
35 35
      * Due to the use of translation functions, this should run only after plugins loaded.
@@ -49,25 +49,25 @@  discard block
 block discarded – undo
49 49
     public function get_privacy_message() {
50 50
 
51 51
         $content = '<div class="wp-suggested-text">' .
52
-                   '<h2>' . __( 'Invoices and checkout', 'invoicing' ) . '</h2>' .
53
-                   '<p class="privacy-policy-tutorial">' . __( 'Example privacy texts.', 'invoicing' ) . '</p>' .
54
-                   '<p>' . __( 'We collect information about you during the checkout process on our site. This information may include, but is not limited to, your name, email address, phone number, address, IP and any other details that might be requested from you for the purpose of processing your payment and retaining your invoice details for legal reasons.', 'invoicing' ) . '</p>' .
55
-                   '<p>' . __( 'Handling this data also allows us to:', 'invoicing' ) . '</p>' .
56
-                   '<ul>' .
57
-                   '<li>' . __( '- Send you important account/invoice/service information.', 'invoicing' ) . '</li>' .
58
-                   '<li>' . __( '- Estimate taxes based on your location.', 'invoicing' ) . '</li>' .
59
-                   '<li>' . __( '- Respond to your queries or complaints.', 'invoicing' ) . '</li>' .
60
-                   '<li>' . __( '- Process payments and to prevent fraudulent transactions. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
61
-                   '<li>' . __( '- Retain historical payment and invoice history. We do this on the basis of legal obligations.', 'invoicing' ) . '</li>' .
62
-                   '<li>' . __( '- Set up and administer your account, provide technical and/or customer support, and to verify your identity. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
63
-                   '</ul>' .
64
-                   '<p>' . __( 'In addition to collecting information at checkout we may also use and store your contact details when manually creating invoices for require payments relating to prior contractual agreements or agreed terms.', 'invoicing' ) . '</p>' .
65
-                   '<h2>' . __( 'What we share with others', 'invoicing' ) . '</h2>' .
66
-                   '<p>' . __( 'We share information with third parties who help us provide our payment and invoicing services to you; for example --', 'invoicing' ) . '</p>' .
67
-                   '<p class="privacy-policy-tutorial">' . __( 'In this subsection you should list which third party payment processors you’re using to take payments since these may handle customer data. We’ve included PayPal as an example, but you should remove this if you’re not using PayPal.', 'invoicing' ) . '</p>' .
68
-                   '<p>' . __( 'We accept payments through PayPal. When processing payments, some of your data will be passed to PayPal, including information required to process or support the payment, such as the purchase total and billing information.', 'invoicing' ) . '</p>' .
69
-                   '<p>' . __( 'Please see the <a href="https://www.paypal.com/us/webapps/mpp/ua/privacy-full">PayPal Privacy Policy</a> for more details.', 'invoicing' ) . '</p>' .
70
-                   '</div>';
52
+                    '<h2>' . __( 'Invoices and checkout', 'invoicing' ) . '</h2>' .
53
+                    '<p class="privacy-policy-tutorial">' . __( 'Example privacy texts.', 'invoicing' ) . '</p>' .
54
+                    '<p>' . __( 'We collect information about you during the checkout process on our site. This information may include, but is not limited to, your name, email address, phone number, address, IP and any other details that might be requested from you for the purpose of processing your payment and retaining your invoice details for legal reasons.', 'invoicing' ) . '</p>' .
55
+                    '<p>' . __( 'Handling this data also allows us to:', 'invoicing' ) . '</p>' .
56
+                    '<ul>' .
57
+                    '<li>' . __( '- Send you important account/invoice/service information.', 'invoicing' ) . '</li>' .
58
+                    '<li>' . __( '- Estimate taxes based on your location.', 'invoicing' ) . '</li>' .
59
+                    '<li>' . __( '- Respond to your queries or complaints.', 'invoicing' ) . '</li>' .
60
+                    '<li>' . __( '- Process payments and to prevent fraudulent transactions. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
61
+                    '<li>' . __( '- Retain historical payment and invoice history. We do this on the basis of legal obligations.', 'invoicing' ) . '</li>' .
62
+                    '<li>' . __( '- Set up and administer your account, provide technical and/or customer support, and to verify your identity. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
63
+                    '</ul>' .
64
+                    '<p>' . __( 'In addition to collecting information at checkout we may also use and store your contact details when manually creating invoices for require payments relating to prior contractual agreements or agreed terms.', 'invoicing' ) . '</p>' .
65
+                    '<h2>' . __( 'What we share with others', 'invoicing' ) . '</h2>' .
66
+                    '<p>' . __( 'We share information with third parties who help us provide our payment and invoicing services to you; for example --', 'invoicing' ) . '</p>' .
67
+                    '<p class="privacy-policy-tutorial">' . __( 'In this subsection you should list which third party payment processors you’re using to take payments since these may handle customer data. We’ve included PayPal as an example, but you should remove this if you’re not using PayPal.', 'invoicing' ) . '</p>' .
68
+                    '<p>' . __( 'We accept payments through PayPal. When processing payments, some of your data will be passed to PayPal, including information required to process or support the payment, such as the purchase total and billing information.', 'invoicing' ) . '</p>' .
69
+                    '<p>' . __( 'Please see the <a href="https://www.paypal.com/us/webapps/mpp/ua/privacy-full">PayPal Privacy Policy</a> for more details.', 'invoicing' ) . '</p>' .
70
+                    '</div>';
71 71
 
72 72
         return apply_filters( 'wpinv_privacy_policy_content', $content );
73 73
     }
Please login to merge, or discard this patch.
Spacing   +21 added lines, -21 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Privacy/GDPR related functionality which ties into WordPress functionality.
4 4
  */
5 5
 
6
-defined( 'ABSPATH' ) || exit;
6
+defined('ABSPATH') || exit;
7 7
 
8 8
 /**
9 9
  * WPInv_Privacy Class.
@@ -26,7 +26,7 @@  discard block
 block discarded – undo
26 26
         $this->init();
27 27
 
28 28
         // Initialize data exporters and erasers.
29
-        add_action( 'init', array( $this, 'register_erasers_exporters' ) );
29
+        add_action('init', array($this, 'register_erasers_exporters'));
30 30
     }
31 31
 
32 32
    /**
@@ -35,10 +35,10 @@  discard block
 block discarded – undo
35 35
      * Due to the use of translation functions, this should run only after plugins loaded.
36 36
      */
37 37
     public function register_erasers_exporters() {
38
-        $this->name = __( 'GetPaid', 'invoicing' );
38
+        $this->name = __('GetPaid', 'invoicing');
39 39
 
40 40
         // This hook registers Invoicing data exporters.
41
-        $this->add_exporter( 'wpinv-customer-invoices', __( 'Customer Invoices', 'invoicing' ), array( 'WPInv_Privacy_Exporters', 'customer_invoice_data_exporter' ) );
41
+        $this->add_exporter('wpinv-customer-invoices', __('Customer Invoices', 'invoicing'), array('WPInv_Privacy_Exporters', 'customer_invoice_data_exporter'));
42 42
     }
43 43
 
44 44
     /**
@@ -49,27 +49,27 @@  discard block
 block discarded – undo
49 49
     public function get_privacy_message() {
50 50
 
51 51
         $content = '<div class="wp-suggested-text">' .
52
-                   '<h2>' . __( 'Invoices and checkout', 'invoicing' ) . '</h2>' .
53
-                   '<p class="privacy-policy-tutorial">' . __( 'Example privacy texts.', 'invoicing' ) . '</p>' .
54
-                   '<p>' . __( 'We collect information about you during the checkout process on our site. This information may include, but is not limited to, your name, email address, phone number, address, IP and any other details that might be requested from you for the purpose of processing your payment and retaining your invoice details for legal reasons.', 'invoicing' ) . '</p>' .
55
-                   '<p>' . __( 'Handling this data also allows us to:', 'invoicing' ) . '</p>' .
52
+                   '<h2>' . __('Invoices and checkout', 'invoicing') . '</h2>' .
53
+                   '<p class="privacy-policy-tutorial">' . __('Example privacy texts.', 'invoicing') . '</p>' .
54
+                   '<p>' . __('We collect information about you during the checkout process on our site. This information may include, but is not limited to, your name, email address, phone number, address, IP and any other details that might be requested from you for the purpose of processing your payment and retaining your invoice details for legal reasons.', 'invoicing') . '</p>' .
55
+                   '<p>' . __('Handling this data also allows us to:', 'invoicing') . '</p>' .
56 56
                    '<ul>' .
57
-                   '<li>' . __( '- Send you important account/invoice/service information.', 'invoicing' ) . '</li>' .
58
-                   '<li>' . __( '- Estimate taxes based on your location.', 'invoicing' ) . '</li>' .
59
-                   '<li>' . __( '- Respond to your queries or complaints.', 'invoicing' ) . '</li>' .
60
-                   '<li>' . __( '- Process payments and to prevent fraudulent transactions. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
61
-                   '<li>' . __( '- Retain historical payment and invoice history. We do this on the basis of legal obligations.', 'invoicing' ) . '</li>' .
62
-                   '<li>' . __( '- Set up and administer your account, provide technical and/or customer support, and to verify your identity. We do this on the basis of our legitimate business interests.', 'invoicing' ) . '</li>' .
57
+                   '<li>' . __('- Send you important account/invoice/service information.', 'invoicing') . '</li>' .
58
+                   '<li>' . __('- Estimate taxes based on your location.', 'invoicing') . '</li>' .
59
+                   '<li>' . __('- Respond to your queries or complaints.', 'invoicing') . '</li>' .
60
+                   '<li>' . __('- Process payments and to prevent fraudulent transactions. We do this on the basis of our legitimate business interests.', 'invoicing') . '</li>' .
61
+                   '<li>' . __('- Retain historical payment and invoice history. We do this on the basis of legal obligations.', 'invoicing') . '</li>' .
62
+                   '<li>' . __('- Set up and administer your account, provide technical and/or customer support, and to verify your identity. We do this on the basis of our legitimate business interests.', 'invoicing') . '</li>' .
63 63
                    '</ul>' .
64
-                   '<p>' . __( 'In addition to collecting information at checkout we may also use and store your contact details when manually creating invoices for require payments relating to prior contractual agreements or agreed terms.', 'invoicing' ) . '</p>' .
65
-                   '<h2>' . __( 'What we share with others', 'invoicing' ) . '</h2>' .
66
-                   '<p>' . __( 'We share information with third parties who help us provide our payment and invoicing services to you; for example --', 'invoicing' ) . '</p>' .
67
-                   '<p class="privacy-policy-tutorial">' . __( 'In this subsection you should list which third party payment processors you’re using to take payments since these may handle customer data. We’ve included PayPal as an example, but you should remove this if you’re not using PayPal.', 'invoicing' ) . '</p>' .
68
-                   '<p>' . __( 'We accept payments through PayPal. When processing payments, some of your data will be passed to PayPal, including information required to process or support the payment, such as the purchase total and billing information.', 'invoicing' ) . '</p>' .
69
-                   '<p>' . __( 'Please see the <a href="https://www.paypal.com/us/webapps/mpp/ua/privacy-full">PayPal Privacy Policy</a> for more details.', 'invoicing' ) . '</p>' .
64
+                   '<p>' . __('In addition to collecting information at checkout we may also use and store your contact details when manually creating invoices for require payments relating to prior contractual agreements or agreed terms.', 'invoicing') . '</p>' .
65
+                   '<h2>' . __('What we share with others', 'invoicing') . '</h2>' .
66
+                   '<p>' . __('We share information with third parties who help us provide our payment and invoicing services to you; for example --', 'invoicing') . '</p>' .
67
+                   '<p class="privacy-policy-tutorial">' . __('In this subsection you should list which third party payment processors you’re using to take payments since these may handle customer data. We’ve included PayPal as an example, but you should remove this if you’re not using PayPal.', 'invoicing') . '</p>' .
68
+                   '<p>' . __('We accept payments through PayPal. When processing payments, some of your data will be passed to PayPal, including information required to process or support the payment, such as the purchase total and billing information.', 'invoicing') . '</p>' .
69
+                   '<p>' . __('Please see the <a href="https://www.paypal.com/us/webapps/mpp/ua/privacy-full">PayPal Privacy Policy</a> for more details.', 'invoicing') . '</p>' .
70 70
                    '</div>';
71 71
 
72
-        return apply_filters( 'wpinv_privacy_policy_content', $content );
72
+        return apply_filters('wpinv_privacy_policy_content', $content);
73 73
     }
74 74
 
75 75
 }
Please login to merge, or discard this patch.
includes/abstracts/abstract-wpinv-privacy.php 1 patch
Spacing   +20 added lines, -20 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Abstract privacy class.
4 4
  */
5 5
 
6
-defined( 'ABSPATH' ) || exit;
6
+defined('ABSPATH') || exit;
7 7
 
8 8
 /**
9 9
  * Abstract class that is intended to be extended by
@@ -38,7 +38,7 @@  discard block
 block discarded – undo
38 38
      *
39 39
      * @param string $name Plugin identifier.
40 40
      */
41
-    public function __construct( $name = '' ) {
41
+    public function __construct($name = '') {
42 42
         $this->name = $name;
43 43
         $this->init();
44 44
     }
@@ -47,26 +47,26 @@  discard block
 block discarded – undo
47 47
      * Hook in events.
48 48
      */
49 49
     protected function init() {
50
-        add_action( 'admin_init', array( $this, 'add_privacy_message' ) );
50
+        add_action('admin_init', array($this, 'add_privacy_message'));
51 51
         // Register data exporters
52
-        add_filter( 'wp_privacy_personal_data_exporters', array( $this, 'register_exporters' ), 10 );
52
+        add_filter('wp_privacy_personal_data_exporters', array($this, 'register_exporters'), 10);
53 53
         // Register data erasers
54
-        add_filter( 'wp_privacy_personal_data_erasers', array( $this, 'register_erasers' ) );
54
+        add_filter('wp_privacy_personal_data_erasers', array($this, 'register_erasers'));
55 55
     }
56 56
 
57 57
     /**
58 58
      * Adds the privacy message on invoicing privacy page.
59 59
      */
60 60
     public function add_privacy_message() {
61
-        if ( function_exists( 'wp_add_privacy_policy_content' ) ) {
61
+        if (function_exists('wp_add_privacy_policy_content')) {
62 62
             $content = $this->get_privacy_message();
63 63
 
64
-            if ( $content ) {
65
-                if ( empty( $this->name ) ) {
66
-                    $this->name = __( 'GetPaid', 'invoicing' );
64
+            if ($content) {
65
+                if (empty($this->name)) {
66
+                    $this->name = __('GetPaid', 'invoicing');
67 67
                 }
68 68
 
69
-                wp_add_privacy_policy_content( $this->name, $this->get_privacy_message() );
69
+                wp_add_privacy_policy_content($this->name, $this->get_privacy_message());
70 70
             }
71 71
         }
72 72
     }
@@ -87,9 +87,9 @@  discard block
 block discarded – undo
87 87
      * @param array $exporters List of exporter callbacks.
88 88
      * @return array
89 89
      */
90
-    public function register_exporters( $exporters = array() ) {
91
-        foreach ( $this->exporters as $id => $exporter ) {
92
-            $exporters[ $id ] = $exporter;
90
+    public function register_exporters($exporters = array()) {
91
+        foreach ($this->exporters as $id => $exporter) {
92
+            $exporters[$id] = $exporter;
93 93
         }
94 94
         return $exporters;
95 95
     }
@@ -100,9 +100,9 @@  discard block
 block discarded – undo
100 100
      * @param array $erasers List of eraser callbacks.
101 101
      * @return array
102 102
      */
103
-    public function register_erasers( $erasers = array() ) {
104
-        foreach ( $this->erasers as $id => $eraser ) {
105
-            $erasers[ $id ] = $eraser;
103
+    public function register_erasers($erasers = array()) {
104
+        foreach ($this->erasers as $id => $eraser) {
105
+            $erasers[$id] = $eraser;
106 106
         }
107 107
         return $erasers;
108 108
     }
@@ -116,8 +116,8 @@  discard block
 block discarded – undo
116 116
      *
117 117
      * @return array
118 118
      */
119
-    public function add_exporter( $id, $name, $callback ) {
120
-        $this->exporters[ $id ] = array(
119
+    public function add_exporter($id, $name, $callback) {
120
+        $this->exporters[$id] = array(
121 121
             'exporter_friendly_name' => $name,
122 122
             'callback'               => $callback,
123 123
         );
@@ -133,8 +133,8 @@  discard block
 block discarded – undo
133 133
      *
134 134
      * @return array
135 135
      */
136
-    public function add_eraser( $id, $name, $callback ) {
137
-        $this->erasers[ $id ] = array(
136
+    public function add_eraser($id, $name, $callback) {
137
+        $this->erasers[$id] = array(
138 138
             'eraser_friendly_name' => $name,
139 139
             'callback'             => $callback,
140 140
         );
Please login to merge, or discard this patch.
includes/class-getpaid-invoice-notification-emails.php 2 patches
Indentation   +469 added lines, -469 removed lines patch added patch discarded remove patch
@@ -12,492 +12,492 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Invoice_Notification_Emails {
14 14
 
15
-	/**
16
-	 * The array of invoice email actions.
17
-	 *
18
-	 * @param array
19
-	 */
20
-	public $invoice_actions;
21
-
22
-	/**
23
-	 * Class constructor
24
-	 *
25
-	 */
26
-	public function __construct() {
27
-
28
-		$this->invoice_actions = apply_filters(
29
-			'getpaid_notification_email_invoice_triggers',
30
-			array(
31
-				'getpaid_new_invoice'                   => array( 'new_invoice', 'user_invoice' ),
32
-				'getpaid_invoice_status_wpi-cancelled'  => 'cancelled_invoice',
33
-				'getpaid_invoice_status_wpi-failed'     => 'failed_invoice',
34
-				'getpaid_invoice_status_wpi-onhold'     => 'onhold_invoice',
35
-				'getpaid_invoice_status_wpi-processing' => 'processing_invoice',
36
-				'getpaid_invoice_status_publish'        => 'completed_invoice',
37
-				'getpaid_invoice_status_wpi-renewal'    => 'completed_invoice',
38
-				'getpaid_invoice_status_wpi-refunded'   => 'refunded_invoice',
39
-				'getpaid_new_customer_note'             => 'user_note',
40
-				'getpaid_daily_maintenance'             => 'overdue',
41
-			)
42
-		);
43
-
44
-		add_action( 'init', array( $this, 'init_hooks' ) );
45
-	}
46
-
47
-	/**
48
-	 * Registers email hooks.
49
-	 */
50
-	public function init_hooks() {
51
-
52
-		add_filter( 'getpaid_get_email_merge_tags', array( $this, 'invoice_merge_tags' ), 10, 2 );
53
-		add_filter( 'getpaid_invoice_email_recipients', array( $this, 'filter_email_recipients' ), 10, 2 );
54
-
55
-		foreach ( $this->invoice_actions as $hook => $email_type ) {
56
-			$this->init_email_type_hook( $hook, $email_type );
57
-		}
58
-	}
59
-
60
-	/**
61
-	 * Registers an email hook for an invoice action.
62
-	 *
63
-	 * @param string $hook
64
-	 * @param string|array $email_type
65
-	 */
66
-	public function init_email_type_hook( $hook, $email_type ) {
67
-
68
-		$email_type = wpinv_parse_list( $email_type );
69
-
70
-		foreach ( $email_type as $type ) {
71
-
72
-			$email = new GetPaid_Notification_Email( $type );
73
-
74
-			// Abort if it is not active.
75
-			if ( ! $email->is_active() ) {
76
-				continue;
77
-			}
78
-
79
-			if ( method_exists( $this, $type ) ) {
80
-				add_action( $hook, array( $this, $type ), 100, 2 );
81
-				continue;
82
-			}
83
-
84
-			do_action( 'getpaid_invoice_init_email_type_hook', $type, $hook );
85
-		}
86
-
87
-	}
88
-
89
-	/**
90
-	 * Filters invoice merge tags.
91
-	 *
92
-	 * @param array $merge_tags
93
-	 * @param mixed|WPInv_Invoice|WPInv_Subscription $object
94
-	 */
95
-	public function invoice_merge_tags( $merge_tags, $object ) {
96
-
97
-		if ( is_a( $object, 'WPInv_Invoice' ) ) {
98
-			return array_merge(
99
-				$merge_tags,
100
-				$this->get_invoice_merge_tags( $object )
101
-			);
102
-		}
103
-
104
-		if ( is_a( $object, 'WPInv_Subscription' ) ) {
105
-			return array_merge(
106
-				$merge_tags,
107
-				$this->get_invoice_merge_tags( $object->get_parent_payment() )
108
-			);
109
-		}
110
-
111
-		return $merge_tags;
112
-
113
-	}
114
-
115
-	/**
116
-	 * Generates invoice merge tags.
117
-	 *
118
-	 * @param WPInv_Invoice $invoice
119
-	 * @return array
120
-	 */
121
-	public function get_invoice_merge_tags( $invoice ) {
122
-
123
-		// Abort if it does not exist.
124
-		if ( ! $invoice->get_id() ) {
125
-			return array();
126
-		}
127
-
128
-		$due_date   = $invoice->get_due_date();
129
-		$due_date   = empty( $due_date ) ? time() + MINUTE_IN_SECONDS : strtotime( $due_date ) + ( (int) get_option( 'gmt_offset' ) * HOUR_IN_SECONDS );
130
-		$merge_tags = array(
131
-			'{name}'                 => sanitize_text_field( $invoice->get_user_full_name() ),
132
-			'{full_name}'            => sanitize_text_field( $invoice->get_user_full_name() ),
133
-			'{first_name}'           => sanitize_text_field( $invoice->get_first_name() ),
134
-			'{last_name}'            => sanitize_text_field( $invoice->get_last_name() ),
135
-			'{email}'                => sanitize_email( $invoice->get_email() ),
136
-			'{invoice_number}'       => sanitize_text_field( $invoice->get_number() ),
137
-			'{invoice_currency}'     => sanitize_text_field( $invoice->get_currency() ),
138
-			'{invoice_total}'        => sanitize_text_field( wpinv_price( $invoice->get_total(), $invoice->get_currency() ) ),
139
-			'{invoice_link}'         => esc_url( $invoice->get_view_url() ),
140
-			'{invoice_pay_link}'     => esc_url( $invoice->get_checkout_payment_url() ),
141
-			'{invoice_receipt_link}' => esc_url( $invoice->get_receipt_url() ),
142
-			'{invoice_date}'         => getpaid_format_date_value( $invoice->get_date_created() ),
143
-			'{invoice_due_date}'     => getpaid_format_date_value( $invoice->get_due_date(), __( 'on receipt', 'invoicing' ) ),
144
-			'{invoice_quote}'        => sanitize_text_field( strtolower( $invoice->get_label() ) ),
145
-			'{invoice_label}'        => sanitize_text_field( ucfirst( $invoice->get_label() ) ),
146
-			'{invoice_description}'  => wp_kses_post( $invoice->get_description() ),
147
-			'{subscription_name}'    => wp_kses_post( $invoice->get_subscription_name() ),
148
-			'{is_was}'               => $due_date < time() ? __( 'was', 'invoicing' ) : __( 'is', 'invoicing' ),
149
-		);
150
-
151
-		$payment_form_data = $invoice->get_meta( 'payment_form_data', true );
152
-
153
-		if ( is_array( $payment_form_data ) ) {
154
-
155
-			foreach ( $payment_form_data as $label => $value ) {
156
-
157
-				$label = preg_replace( '/[^a-z0-9]+/', '_', strtolower( $label ) );
158
-				$value = is_array( $value ) ? implode( ', ', $value ) : $value;
159
-
160
-				if ( is_scalar( $value ) ) {
161
-					$merge_tags[ "{{$label}}" ] = wp_kses_post( $value );
162
-				}
163
-			}
164
-		}
165
-
166
-		return apply_filters( 'getpaid_invoice_email_merge_tags', $merge_tags, $invoice );
167
-	}
168
-
169
-	/**
170
-	 * Helper function to send an email.
171
-	 *
172
-	 * @param WPInv_Invoice $invoice
173
-	 * @param GetPaid_Notification_Email $email
174
-	 * @param string $type
175
-	 * @param string|array $recipients
176
-	 * @param array $extra_args Extra template args.
177
-	 */
178
-	public function send_email( $invoice, $email, $type, $recipients, $extra_args = array() ) {
179
-
180
-		do_action( 'getpaid_before_send_invoice_notification', $type, $invoice, $email );
181
-
182
-		$skip = $invoice->is_free() && wpinv_get_option( 'skip_email_free_invoice' );
183
-		if ( apply_filters( 'getpaid_skip_invoice_email', $skip, $type, $invoice ) ) {
184
-			return;
185
-		}
186
-
187
-		$mailer     = new GetPaid_Notification_Email_Sender();
188
-		$merge_tags = $email->get_merge_tags();
189
-
190
-		$result = $mailer->send(
191
-			apply_filters( 'getpaid_invoice_email_recipients', wpinv_parse_list( $recipients ), $email ),
192
-			$email->add_merge_tags( $email->get_subject(), $merge_tags ),
193
-			$email->get_content( $merge_tags, $extra_args ),
194
-			$email->get_attachments()
195
-		);
196
-
197
-		// Maybe send a copy to the admin.
198
-		if ( $email->include_admin_bcc() ) {
199
-			$mailer->send(
200
-				wpinv_get_admin_email(),
201
-				$email->add_merge_tags( $email->get_subject() . __( ' - ADMIN BCC COPY', 'invoicing' ), $merge_tags ),
202
-				$email->get_content( $merge_tags ),
203
-				$email->get_attachments()
204
-			);
205
-		}
206
-
207
-		if ( $result ) {
208
-			$invoice->add_system_note(
209
-				sprintf(
210
-					// translators: %1 is the email type, %2 is the invoice recipient.
211
-					__( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
212
-					sanitize_key( $type ),
213
-					$email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
214
-				)
215
-			);
216
-		} else {
217
-			$invoice->add_system_note(
218
-				sprintf(
219
-					// translators: %1 is the email type, %2 is the invoice recipient.
220
-					__( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
221
-					sanitize_key( $type ),
222
-					$email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
223
-				)
224
-			);
225
-		}
226
-
227
-		do_action( 'getpaid_after_send_invoice_notification', $type, $invoice, $email );
228
-
229
-		return $result;
230
-	}
231
-
232
-	/**
233
-	 * Also send emails to any cc users.
234
-	 *
235
-	 * @param array $recipients
236
-	 * @param GetPaid_Notification_Email $email
237
-	 */
238
-	public function filter_email_recipients( $recipients, $email ) {
239
-
240
-		if ( ! $email->is_admin_email() ) {
241
-			$cc   = $email->object->get_email_cc();
242
-			$cc_2 = get_user_meta( $email->object->get_user_id(), '_wpinv_email_cc', true );
243
-
244
-			if ( ! empty( $cc ) ) {
245
-				$cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
246
-				$recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
247
-			}
248
-
249
-			if ( ! empty( $cc_2 ) ) {
250
-				$cc_2 = array_map( 'sanitize_email', wpinv_parse_list( $cc_2 ) );
251
-				$recipients = array_filter( array_unique( array_merge( $recipients, $cc_2 ) ) );
252
-			}
253
-		}
254
-
255
-		return $recipients;
256
-
257
-	}
258
-
259
-	/**
260
-	 * Sends a new invoice notification.
261
-	 *
262
-	 * @param WPInv_Invoice $invoice
263
-	 */
264
-	public function new_invoice( $invoice ) {
265
-
266
-		// Only send this email for invoices created via the admin page.
267
-		if ( ! $invoice->is_type( 'invoice' ) || $invoice->is_paid() || $this->is_payment_form_invoice( $invoice->get_id() ) ) {
268
-			return;
269
-		}
270
-
271
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
272
-		$recipient = wpinv_get_admin_email();
273
-
274
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
275
-
276
-	}
277
-
278
-	/**
279
-	 * Sends a cancelled invoice notification.
280
-	 *
281
-	 * @param WPInv_Invoice $invoice
282
-	 */
283
-	public function cancelled_invoice( $invoice ) {
284
-
285
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
286
-		$recipient = $invoice->get_email();
287
-
288
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
289
-	}
290
-
291
-	/**
292
-	 * Sends a failed invoice notification.
293
-	 *
294
-	 * @param WPInv_Invoice $invoice
295
-	 */
296
-	public function failed_invoice( $invoice ) {
297
-
298
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
299
-		$recipient = wpinv_get_admin_email();
300
-
301
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
302
-
303
-	}
304
-
305
-	/**
306
-	 * Sends a notification whenever an invoice is put on hold.
307
-	 *
308
-	 * @param WPInv_Invoice $invoice
309
-	 */
310
-	public function onhold_invoice( $invoice ) {
311
-
312
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
313
-		$recipient = $invoice->get_email();
314
-
315
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
316
-
317
-	}
318
-
319
-	/**
320
-	 * Sends a notification whenever an invoice is marked as processing payment.
321
-	 *
322
-	 * @param WPInv_Invoice $invoice
323
-	 */
324
-	public function processing_invoice( $invoice ) {
325
-
326
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
327
-		$recipient = $invoice->get_email();
328
-
329
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
330
-
331
-	}
332
-
333
-	/**
334
-	 * Sends a notification whenever an invoice is paid.
335
-	 *
336
-	 * @param WPInv_Invoice $invoice
337
-	 */
338
-	public function completed_invoice( $invoice ) {
339
-
340
-		// (Maybe) abort if it is a renewal invoice.
341
-		if ( $invoice->is_renewal() && ! wpinv_get_option( 'email_completed_invoice_renewal_active', false ) ) {
342
-			return;
343
-		}
344
-
345
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
346
-		$recipient = $invoice->get_email();
347
-
348
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
349
-
350
-	}
15
+    /**
16
+     * The array of invoice email actions.
17
+     *
18
+     * @param array
19
+     */
20
+    public $invoice_actions;
21
+
22
+    /**
23
+     * Class constructor
24
+     *
25
+     */
26
+    public function __construct() {
27
+
28
+        $this->invoice_actions = apply_filters(
29
+            'getpaid_notification_email_invoice_triggers',
30
+            array(
31
+                'getpaid_new_invoice'                   => array( 'new_invoice', 'user_invoice' ),
32
+                'getpaid_invoice_status_wpi-cancelled'  => 'cancelled_invoice',
33
+                'getpaid_invoice_status_wpi-failed'     => 'failed_invoice',
34
+                'getpaid_invoice_status_wpi-onhold'     => 'onhold_invoice',
35
+                'getpaid_invoice_status_wpi-processing' => 'processing_invoice',
36
+                'getpaid_invoice_status_publish'        => 'completed_invoice',
37
+                'getpaid_invoice_status_wpi-renewal'    => 'completed_invoice',
38
+                'getpaid_invoice_status_wpi-refunded'   => 'refunded_invoice',
39
+                'getpaid_new_customer_note'             => 'user_note',
40
+                'getpaid_daily_maintenance'             => 'overdue',
41
+            )
42
+        );
43
+
44
+        add_action( 'init', array( $this, 'init_hooks' ) );
45
+    }
46
+
47
+    /**
48
+     * Registers email hooks.
49
+     */
50
+    public function init_hooks() {
51
+
52
+        add_filter( 'getpaid_get_email_merge_tags', array( $this, 'invoice_merge_tags' ), 10, 2 );
53
+        add_filter( 'getpaid_invoice_email_recipients', array( $this, 'filter_email_recipients' ), 10, 2 );
54
+
55
+        foreach ( $this->invoice_actions as $hook => $email_type ) {
56
+            $this->init_email_type_hook( $hook, $email_type );
57
+        }
58
+    }
59
+
60
+    /**
61
+     * Registers an email hook for an invoice action.
62
+     *
63
+     * @param string $hook
64
+     * @param string|array $email_type
65
+     */
66
+    public function init_email_type_hook( $hook, $email_type ) {
67
+
68
+        $email_type = wpinv_parse_list( $email_type );
69
+
70
+        foreach ( $email_type as $type ) {
71
+
72
+            $email = new GetPaid_Notification_Email( $type );
73
+
74
+            // Abort if it is not active.
75
+            if ( ! $email->is_active() ) {
76
+                continue;
77
+            }
78
+
79
+            if ( method_exists( $this, $type ) ) {
80
+                add_action( $hook, array( $this, $type ), 100, 2 );
81
+                continue;
82
+            }
83
+
84
+            do_action( 'getpaid_invoice_init_email_type_hook', $type, $hook );
85
+        }
86
+
87
+    }
88
+
89
+    /**
90
+     * Filters invoice merge tags.
91
+     *
92
+     * @param array $merge_tags
93
+     * @param mixed|WPInv_Invoice|WPInv_Subscription $object
94
+     */
95
+    public function invoice_merge_tags( $merge_tags, $object ) {
96
+
97
+        if ( is_a( $object, 'WPInv_Invoice' ) ) {
98
+            return array_merge(
99
+                $merge_tags,
100
+                $this->get_invoice_merge_tags( $object )
101
+            );
102
+        }
103
+
104
+        if ( is_a( $object, 'WPInv_Subscription' ) ) {
105
+            return array_merge(
106
+                $merge_tags,
107
+                $this->get_invoice_merge_tags( $object->get_parent_payment() )
108
+            );
109
+        }
110
+
111
+        return $merge_tags;
112
+
113
+    }
114
+
115
+    /**
116
+     * Generates invoice merge tags.
117
+     *
118
+     * @param WPInv_Invoice $invoice
119
+     * @return array
120
+     */
121
+    public function get_invoice_merge_tags( $invoice ) {
122
+
123
+        // Abort if it does not exist.
124
+        if ( ! $invoice->get_id() ) {
125
+            return array();
126
+        }
127
+
128
+        $due_date   = $invoice->get_due_date();
129
+        $due_date   = empty( $due_date ) ? time() + MINUTE_IN_SECONDS : strtotime( $due_date ) + ( (int) get_option( 'gmt_offset' ) * HOUR_IN_SECONDS );
130
+        $merge_tags = array(
131
+            '{name}'                 => sanitize_text_field( $invoice->get_user_full_name() ),
132
+            '{full_name}'            => sanitize_text_field( $invoice->get_user_full_name() ),
133
+            '{first_name}'           => sanitize_text_field( $invoice->get_first_name() ),
134
+            '{last_name}'            => sanitize_text_field( $invoice->get_last_name() ),
135
+            '{email}'                => sanitize_email( $invoice->get_email() ),
136
+            '{invoice_number}'       => sanitize_text_field( $invoice->get_number() ),
137
+            '{invoice_currency}'     => sanitize_text_field( $invoice->get_currency() ),
138
+            '{invoice_total}'        => sanitize_text_field( wpinv_price( $invoice->get_total(), $invoice->get_currency() ) ),
139
+            '{invoice_link}'         => esc_url( $invoice->get_view_url() ),
140
+            '{invoice_pay_link}'     => esc_url( $invoice->get_checkout_payment_url() ),
141
+            '{invoice_receipt_link}' => esc_url( $invoice->get_receipt_url() ),
142
+            '{invoice_date}'         => getpaid_format_date_value( $invoice->get_date_created() ),
143
+            '{invoice_due_date}'     => getpaid_format_date_value( $invoice->get_due_date(), __( 'on receipt', 'invoicing' ) ),
144
+            '{invoice_quote}'        => sanitize_text_field( strtolower( $invoice->get_label() ) ),
145
+            '{invoice_label}'        => sanitize_text_field( ucfirst( $invoice->get_label() ) ),
146
+            '{invoice_description}'  => wp_kses_post( $invoice->get_description() ),
147
+            '{subscription_name}'    => wp_kses_post( $invoice->get_subscription_name() ),
148
+            '{is_was}'               => $due_date < time() ? __( 'was', 'invoicing' ) : __( 'is', 'invoicing' ),
149
+        );
150
+
151
+        $payment_form_data = $invoice->get_meta( 'payment_form_data', true );
152
+
153
+        if ( is_array( $payment_form_data ) ) {
154
+
155
+            foreach ( $payment_form_data as $label => $value ) {
156
+
157
+                $label = preg_replace( '/[^a-z0-9]+/', '_', strtolower( $label ) );
158
+                $value = is_array( $value ) ? implode( ', ', $value ) : $value;
159
+
160
+                if ( is_scalar( $value ) ) {
161
+                    $merge_tags[ "{{$label}}" ] = wp_kses_post( $value );
162
+                }
163
+            }
164
+        }
165
+
166
+        return apply_filters( 'getpaid_invoice_email_merge_tags', $merge_tags, $invoice );
167
+    }
351 168
 
352
-	/**
353
-	 * Sends a notification whenever an invoice is refunded.
354
-	 *
355
-	 * @param WPInv_Invoice $invoice
356
-	 */
357
-	public function refunded_invoice( $invoice ) {
358
-
359
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
360
-		$recipient = $invoice->get_email();
361
-
362
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
363
-
364
-	}
169
+    /**
170
+     * Helper function to send an email.
171
+     *
172
+     * @param WPInv_Invoice $invoice
173
+     * @param GetPaid_Notification_Email $email
174
+     * @param string $type
175
+     * @param string|array $recipients
176
+     * @param array $extra_args Extra template args.
177
+     */
178
+    public function send_email( $invoice, $email, $type, $recipients, $extra_args = array() ) {
365 179
 
366
-	/**
367
-	 * Notifies a user about new invoices
368
-	 *
369
-	 * @param WPInv_Invoice $invoice
370
-	 * @param bool $force
371
-	 */
372
-	public function user_invoice( $invoice, $force = false ) {
180
+        do_action( 'getpaid_before_send_invoice_notification', $type, $invoice, $email );
373 181
 
374
-		if ( ! $force && ! empty( $GLOBALS['wpinv_skip_invoice_notification'] ) ) {
375
-			return;
376
-		}
377
-
378
-		// Only send this email for invoices created via the admin page.
379
-		if ( ! $invoice->is_type( 'invoice' ) || ( empty( $force ) && $invoice->is_paid() ) || ( empty( $force ) && $this->is_payment_form_invoice( $invoice->get_id() ) ) ) {
380
-			return;
381
-		}
382
-
383
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
384
-		$recipient = $invoice->get_email();
385
-
386
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
387
-
388
-	}
389
-
390
-	/**
391
-	 * Checks if an invoice is a payment form invoice.
392
-	 *
393
-	 * @param int $invoice
394
-	 * @return bool
395
-	 */
396
-	public function is_payment_form_invoice( $invoice ) {
397
-		$created_via             = get_post_meta( $invoice, 'wpinv_created_via', true );
398
-		$is_payment_form_invoice = 'payment_form' === $created_via || 'geodirectory' === $created_via;
399
-		$is_payment_form_invoice = apply_filters( 'getpaid_invoice_notifications_is_payment_form_invoice', $is_payment_form_invoice, $invoice );
400
-		return empty( $_GET['getpaid-admin-action'] ) && $is_payment_form_invoice;
401
-	}
402
-
403
-	/**
404
-	 * Notifies admin about new invoice notes
405
-	 *
406
-	 * @param WPInv_Invoice $invoice
407
-	 * @param string $note
408
-	 */
409
-	public function user_note( $invoice, $note ) {
410
-
411
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
412
-		$recipient = $invoice->get_email();
413
-
414
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient, array( 'customer_note' => $note ) );
415
-
416
-	}
417
-
418
-	/**
419
-	 * (Force) Sends overdue notices.
420
-	 *
421
-	 * @param WPInv_Invoice $invoice
422
-	 */
423
-	public function force_send_overdue_notice( $invoice ) {
424
-		$email = new GetPaid_Notification_Email( 'overdue', $invoice );
425
-		return $this->send_email( $invoice, $email, 'overdue', $invoice->get_email() );
426
-	}
427
-
428
-	/**
429
-	 * Sends overdue notices.
430
-	 *
431
-	 * @TODO: Create an invoices query class.
432
-	 */
433
-	public function overdue() {
434
-		global $wpdb;
435
-
436
-		$email = new GetPaid_Notification_Email( __FUNCTION__ );
437
-
438
-		// Fetch reminder days.
439
-		$reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
440
-
441
-		// Abort if non is set.
442
-		if ( empty( $reminder_days ) ) {
443
-			return;
444
-		}
445
-
446
-		// Retrieve date query.
447
-		$date_query = $this->get_date_query( $reminder_days );
448
-
449
-		// Invoices table.
450
-		$table = $wpdb->prefix . 'getpaid_invoices';
451
-
452
-		// Fetch invoices.
453
-		$invoices  = $wpdb->get_col(
454
-			"SELECT posts.ID FROM $wpdb->posts as posts
182
+        $skip = $invoice->is_free() && wpinv_get_option( 'skip_email_free_invoice' );
183
+        if ( apply_filters( 'getpaid_skip_invoice_email', $skip, $type, $invoice ) ) {
184
+            return;
185
+        }
186
+
187
+        $mailer     = new GetPaid_Notification_Email_Sender();
188
+        $merge_tags = $email->get_merge_tags();
189
+
190
+        $result = $mailer->send(
191
+            apply_filters( 'getpaid_invoice_email_recipients', wpinv_parse_list( $recipients ), $email ),
192
+            $email->add_merge_tags( $email->get_subject(), $merge_tags ),
193
+            $email->get_content( $merge_tags, $extra_args ),
194
+            $email->get_attachments()
195
+        );
196
+
197
+        // Maybe send a copy to the admin.
198
+        if ( $email->include_admin_bcc() ) {
199
+            $mailer->send(
200
+                wpinv_get_admin_email(),
201
+                $email->add_merge_tags( $email->get_subject() . __( ' - ADMIN BCC COPY', 'invoicing' ), $merge_tags ),
202
+                $email->get_content( $merge_tags ),
203
+                $email->get_attachments()
204
+            );
205
+        }
206
+
207
+        if ( $result ) {
208
+            $invoice->add_system_note(
209
+                sprintf(
210
+                    // translators: %1 is the email type, %2 is the invoice recipient.
211
+                    __( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
212
+                    sanitize_key( $type ),
213
+                    $email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
214
+                )
215
+            );
216
+        } else {
217
+            $invoice->add_system_note(
218
+                sprintf(
219
+                    // translators: %1 is the email type, %2 is the invoice recipient.
220
+                    __( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
221
+                    sanitize_key( $type ),
222
+                    $email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
223
+                )
224
+            );
225
+        }
226
+
227
+        do_action( 'getpaid_after_send_invoice_notification', $type, $invoice, $email );
228
+
229
+        return $result;
230
+    }
231
+
232
+    /**
233
+     * Also send emails to any cc users.
234
+     *
235
+     * @param array $recipients
236
+     * @param GetPaid_Notification_Email $email
237
+     */
238
+    public function filter_email_recipients( $recipients, $email ) {
239
+
240
+        if ( ! $email->is_admin_email() ) {
241
+            $cc   = $email->object->get_email_cc();
242
+            $cc_2 = get_user_meta( $email->object->get_user_id(), '_wpinv_email_cc', true );
243
+
244
+            if ( ! empty( $cc ) ) {
245
+                $cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
246
+                $recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
247
+            }
248
+
249
+            if ( ! empty( $cc_2 ) ) {
250
+                $cc_2 = array_map( 'sanitize_email', wpinv_parse_list( $cc_2 ) );
251
+                $recipients = array_filter( array_unique( array_merge( $recipients, $cc_2 ) ) );
252
+            }
253
+        }
254
+
255
+        return $recipients;
256
+
257
+    }
258
+
259
+    /**
260
+     * Sends a new invoice notification.
261
+     *
262
+     * @param WPInv_Invoice $invoice
263
+     */
264
+    public function new_invoice( $invoice ) {
265
+
266
+        // Only send this email for invoices created via the admin page.
267
+        if ( ! $invoice->is_type( 'invoice' ) || $invoice->is_paid() || $this->is_payment_form_invoice( $invoice->get_id() ) ) {
268
+            return;
269
+        }
270
+
271
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
272
+        $recipient = wpinv_get_admin_email();
273
+
274
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
275
+
276
+    }
277
+
278
+    /**
279
+     * Sends a cancelled invoice notification.
280
+     *
281
+     * @param WPInv_Invoice $invoice
282
+     */
283
+    public function cancelled_invoice( $invoice ) {
284
+
285
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
286
+        $recipient = $invoice->get_email();
287
+
288
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
289
+    }
290
+
291
+    /**
292
+     * Sends a failed invoice notification.
293
+     *
294
+     * @param WPInv_Invoice $invoice
295
+     */
296
+    public function failed_invoice( $invoice ) {
297
+
298
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
299
+        $recipient = wpinv_get_admin_email();
300
+
301
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
302
+
303
+    }
304
+
305
+    /**
306
+     * Sends a notification whenever an invoice is put on hold.
307
+     *
308
+     * @param WPInv_Invoice $invoice
309
+     */
310
+    public function onhold_invoice( $invoice ) {
311
+
312
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
313
+        $recipient = $invoice->get_email();
314
+
315
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
316
+
317
+    }
318
+
319
+    /**
320
+     * Sends a notification whenever an invoice is marked as processing payment.
321
+     *
322
+     * @param WPInv_Invoice $invoice
323
+     */
324
+    public function processing_invoice( $invoice ) {
325
+
326
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
327
+        $recipient = $invoice->get_email();
328
+
329
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
330
+
331
+    }
332
+
333
+    /**
334
+     * Sends a notification whenever an invoice is paid.
335
+     *
336
+     * @param WPInv_Invoice $invoice
337
+     */
338
+    public function completed_invoice( $invoice ) {
339
+
340
+        // (Maybe) abort if it is a renewal invoice.
341
+        if ( $invoice->is_renewal() && ! wpinv_get_option( 'email_completed_invoice_renewal_active', false ) ) {
342
+            return;
343
+        }
344
+
345
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
346
+        $recipient = $invoice->get_email();
347
+
348
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
349
+
350
+    }
351
+
352
+    /**
353
+     * Sends a notification whenever an invoice is refunded.
354
+     *
355
+     * @param WPInv_Invoice $invoice
356
+     */
357
+    public function refunded_invoice( $invoice ) {
358
+
359
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
360
+        $recipient = $invoice->get_email();
361
+
362
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
363
+
364
+    }
365
+
366
+    /**
367
+     * Notifies a user about new invoices
368
+     *
369
+     * @param WPInv_Invoice $invoice
370
+     * @param bool $force
371
+     */
372
+    public function user_invoice( $invoice, $force = false ) {
373
+
374
+        if ( ! $force && ! empty( $GLOBALS['wpinv_skip_invoice_notification'] ) ) {
375
+            return;
376
+        }
377
+
378
+        // Only send this email for invoices created via the admin page.
379
+        if ( ! $invoice->is_type( 'invoice' ) || ( empty( $force ) && $invoice->is_paid() ) || ( empty( $force ) && $this->is_payment_form_invoice( $invoice->get_id() ) ) ) {
380
+            return;
381
+        }
382
+
383
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
384
+        $recipient = $invoice->get_email();
385
+
386
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
387
+
388
+    }
389
+
390
+    /**
391
+     * Checks if an invoice is a payment form invoice.
392
+     *
393
+     * @param int $invoice
394
+     * @return bool
395
+     */
396
+    public function is_payment_form_invoice( $invoice ) {
397
+        $created_via             = get_post_meta( $invoice, 'wpinv_created_via', true );
398
+        $is_payment_form_invoice = 'payment_form' === $created_via || 'geodirectory' === $created_via;
399
+        $is_payment_form_invoice = apply_filters( 'getpaid_invoice_notifications_is_payment_form_invoice', $is_payment_form_invoice, $invoice );
400
+        return empty( $_GET['getpaid-admin-action'] ) && $is_payment_form_invoice;
401
+    }
402
+
403
+    /**
404
+     * Notifies admin about new invoice notes
405
+     *
406
+     * @param WPInv_Invoice $invoice
407
+     * @param string $note
408
+     */
409
+    public function user_note( $invoice, $note ) {
410
+
411
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
412
+        $recipient = $invoice->get_email();
413
+
414
+        return $this->send_email( $invoice, $email, __FUNCTION__, $recipient, array( 'customer_note' => $note ) );
415
+
416
+    }
417
+
418
+    /**
419
+     * (Force) Sends overdue notices.
420
+     *
421
+     * @param WPInv_Invoice $invoice
422
+     */
423
+    public function force_send_overdue_notice( $invoice ) {
424
+        $email = new GetPaid_Notification_Email( 'overdue', $invoice );
425
+        return $this->send_email( $invoice, $email, 'overdue', $invoice->get_email() );
426
+    }
427
+
428
+    /**
429
+     * Sends overdue notices.
430
+     *
431
+     * @TODO: Create an invoices query class.
432
+     */
433
+    public function overdue() {
434
+        global $wpdb;
435
+
436
+        $email = new GetPaid_Notification_Email( __FUNCTION__ );
437
+
438
+        // Fetch reminder days.
439
+        $reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
440
+
441
+        // Abort if non is set.
442
+        if ( empty( $reminder_days ) ) {
443
+            return;
444
+        }
445
+
446
+        // Retrieve date query.
447
+        $date_query = $this->get_date_query( $reminder_days );
448
+
449
+        // Invoices table.
450
+        $table = $wpdb->prefix . 'getpaid_invoices';
451
+
452
+        // Fetch invoices.
453
+        $invoices  = $wpdb->get_col(
454
+            "SELECT posts.ID FROM $wpdb->posts as posts
455 455
 			LEFT JOIN $table as invoices ON invoices.post_id = posts.ID
456 456
 			WHERE posts.post_type = 'wpi_invoice' AND posts.post_status = 'wpi-pending' $date_query"
457 457
         );
458 458
 
459
-		foreach ( $invoices as $invoice ) {
459
+        foreach ( $invoices as $invoice ) {
460 460
 
461
-			// Only send this email for invoices created via the admin page.
462
-			if ( ! $this->is_payment_form_invoice( $invoice ) ) {
463
-				$invoice       = new WPInv_Invoice( $invoice );
464
-				$email->object = $invoice;
461
+            // Only send this email for invoices created via the admin page.
462
+            if ( ! $this->is_payment_form_invoice( $invoice ) ) {
463
+                $invoice       = new WPInv_Invoice( $invoice );
464
+                $email->object = $invoice;
465 465
 
466
-				if ( $invoice->needs_payment() && ! $invoice->is_renewal() ) {
467
-					$this->send_email( $invoice, $email, __FUNCTION__, $invoice->get_email() );
468
-				}
469
-			}
470
-		}
466
+                if ( $invoice->needs_payment() && ! $invoice->is_renewal() ) {
467
+                    $this->send_email( $invoice, $email, __FUNCTION__, $invoice->get_email() );
468
+                }
469
+            }
470
+        }
471 471
 
472
-	}
472
+    }
473 473
 
474
-	/**
475
-	 * Calculates the date query for an invoices query
476
-	 *
477
-	 * @param array $reminder_days
478
-	 * @return string
479
-	 */
480
-	public function get_date_query( $reminder_days ) {
474
+    /**
475
+     * Calculates the date query for an invoices query
476
+     *
477
+     * @param array $reminder_days
478
+     * @return string
479
+     */
480
+    public function get_date_query( $reminder_days ) {
481 481
 
482
-		$date_query = array(
483
-			'relation' => 'OR',
484
-		);
482
+        $date_query = array(
483
+            'relation' => 'OR',
484
+        );
485 485
 
486
-		foreach ( $reminder_days as $days ) {
487
-			$date = date_parse( date( 'Y-m-d', strtotime( "-$days days", current_time( 'timestamp' ) ) ) );
486
+        foreach ( $reminder_days as $days ) {
487
+            $date = date_parse( date( 'Y-m-d', strtotime( "-$days days", current_time( 'timestamp' ) ) ) );
488 488
 
489
-			$date_query[] = array(
490
-				'year'  => $date['year'],
491
-				'month' => $date['month'],
492
-				'day'   => $date['day'],
493
-			);
489
+            $date_query[] = array(
490
+                'year'  => $date['year'],
491
+                'month' => $date['month'],
492
+                'day'   => $date['day'],
493
+            );
494 494
 
495
-		}
495
+        }
496 496
 
497
-		$date_query = new WP_Date_Query( $date_query, 'invoices.due_date' );
497
+        $date_query = new WP_Date_Query( $date_query, 'invoices.due_date' );
498 498
 
499
-		return $date_query->get_sql();
499
+        return $date_query->get_sql();
500 500
 
501
-	}
501
+    }
502 502
 
503 503
 }
Please login to merge, or discard this patch.
Spacing   +128 added lines, -128 removed lines patch added patch discarded remove patch
@@ -4,7 +4,7 @@  discard block
 block discarded – undo
4 4
  *
5 5
  */
6 6
 
7
-defined( 'ABSPATH' ) || exit;
7
+defined('ABSPATH') || exit;
8 8
 
9 9
 /**
10 10
  * This class handles invoice notificaiton emails.
@@ -28,7 +28,7 @@  discard block
 block discarded – undo
28 28
 		$this->invoice_actions = apply_filters(
29 29
 			'getpaid_notification_email_invoice_triggers',
30 30
 			array(
31
-				'getpaid_new_invoice'                   => array( 'new_invoice', 'user_invoice' ),
31
+				'getpaid_new_invoice'                   => array('new_invoice', 'user_invoice'),
32 32
 				'getpaid_invoice_status_wpi-cancelled'  => 'cancelled_invoice',
33 33
 				'getpaid_invoice_status_wpi-failed'     => 'failed_invoice',
34 34
 				'getpaid_invoice_status_wpi-onhold'     => 'onhold_invoice',
@@ -41,7 +41,7 @@  discard block
 block discarded – undo
41 41
 			)
42 42
 		);
43 43
 
44
-		add_action( 'init', array( $this, 'init_hooks' ) );
44
+		add_action('init', array($this, 'init_hooks'));
45 45
 	}
46 46
 
47 47
 	/**
@@ -49,11 +49,11 @@  discard block
 block discarded – undo
49 49
 	 */
50 50
 	public function init_hooks() {
51 51
 
52
-		add_filter( 'getpaid_get_email_merge_tags', array( $this, 'invoice_merge_tags' ), 10, 2 );
53
-		add_filter( 'getpaid_invoice_email_recipients', array( $this, 'filter_email_recipients' ), 10, 2 );
52
+		add_filter('getpaid_get_email_merge_tags', array($this, 'invoice_merge_tags'), 10, 2);
53
+		add_filter('getpaid_invoice_email_recipients', array($this, 'filter_email_recipients'), 10, 2);
54 54
 
55
-		foreach ( $this->invoice_actions as $hook => $email_type ) {
56
-			$this->init_email_type_hook( $hook, $email_type );
55
+		foreach ($this->invoice_actions as $hook => $email_type) {
56
+			$this->init_email_type_hook($hook, $email_type);
57 57
 		}
58 58
 	}
59 59
 
@@ -63,25 +63,25 @@  discard block
 block discarded – undo
63 63
 	 * @param string $hook
64 64
 	 * @param string|array $email_type
65 65
 	 */
66
-	public function init_email_type_hook( $hook, $email_type ) {
66
+	public function init_email_type_hook($hook, $email_type) {
67 67
 
68
-		$email_type = wpinv_parse_list( $email_type );
68
+		$email_type = wpinv_parse_list($email_type);
69 69
 
70
-		foreach ( $email_type as $type ) {
70
+		foreach ($email_type as $type) {
71 71
 
72
-			$email = new GetPaid_Notification_Email( $type );
72
+			$email = new GetPaid_Notification_Email($type);
73 73
 
74 74
 			// Abort if it is not active.
75
-			if ( ! $email->is_active() ) {
75
+			if (!$email->is_active()) {
76 76
 				continue;
77 77
 			}
78 78
 
79
-			if ( method_exists( $this, $type ) ) {
80
-				add_action( $hook, array( $this, $type ), 100, 2 );
79
+			if (method_exists($this, $type)) {
80
+				add_action($hook, array($this, $type), 100, 2);
81 81
 				continue;
82 82
 			}
83 83
 
84
-			do_action( 'getpaid_invoice_init_email_type_hook', $type, $hook );
84
+			do_action('getpaid_invoice_init_email_type_hook', $type, $hook);
85 85
 		}
86 86
 
87 87
 	}
@@ -92,19 +92,19 @@  discard block
 block discarded – undo
92 92
 	 * @param array $merge_tags
93 93
 	 * @param mixed|WPInv_Invoice|WPInv_Subscription $object
94 94
 	 */
95
-	public function invoice_merge_tags( $merge_tags, $object ) {
95
+	public function invoice_merge_tags($merge_tags, $object) {
96 96
 
97
-		if ( is_a( $object, 'WPInv_Invoice' ) ) {
97
+		if (is_a($object, 'WPInv_Invoice')) {
98 98
 			return array_merge(
99 99
 				$merge_tags,
100
-				$this->get_invoice_merge_tags( $object )
100
+				$this->get_invoice_merge_tags($object)
101 101
 			);
102 102
 		}
103 103
 
104
-		if ( is_a( $object, 'WPInv_Subscription' ) ) {
104
+		if (is_a($object, 'WPInv_Subscription')) {
105 105
 			return array_merge(
106 106
 				$merge_tags,
107
-				$this->get_invoice_merge_tags( $object->get_parent_payment() )
107
+				$this->get_invoice_merge_tags($object->get_parent_payment())
108 108
 			);
109 109
 		}
110 110
 
@@ -118,52 +118,52 @@  discard block
 block discarded – undo
118 118
 	 * @param WPInv_Invoice $invoice
119 119
 	 * @return array
120 120
 	 */
121
-	public function get_invoice_merge_tags( $invoice ) {
121
+	public function get_invoice_merge_tags($invoice) {
122 122
 
123 123
 		// Abort if it does not exist.
124
-		if ( ! $invoice->get_id() ) {
124
+		if (!$invoice->get_id()) {
125 125
 			return array();
126 126
 		}
127 127
 
128 128
 		$due_date   = $invoice->get_due_date();
129
-		$due_date   = empty( $due_date ) ? time() + MINUTE_IN_SECONDS : strtotime( $due_date ) + ( (int) get_option( 'gmt_offset' ) * HOUR_IN_SECONDS );
129
+		$due_date   = empty($due_date) ? time() + MINUTE_IN_SECONDS : strtotime($due_date) + ((int) get_option('gmt_offset') * HOUR_IN_SECONDS);
130 130
 		$merge_tags = array(
131
-			'{name}'                 => sanitize_text_field( $invoice->get_user_full_name() ),
132
-			'{full_name}'            => sanitize_text_field( $invoice->get_user_full_name() ),
133
-			'{first_name}'           => sanitize_text_field( $invoice->get_first_name() ),
134
-			'{last_name}'            => sanitize_text_field( $invoice->get_last_name() ),
135
-			'{email}'                => sanitize_email( $invoice->get_email() ),
136
-			'{invoice_number}'       => sanitize_text_field( $invoice->get_number() ),
137
-			'{invoice_currency}'     => sanitize_text_field( $invoice->get_currency() ),
138
-			'{invoice_total}'        => sanitize_text_field( wpinv_price( $invoice->get_total(), $invoice->get_currency() ) ),
139
-			'{invoice_link}'         => esc_url( $invoice->get_view_url() ),
140
-			'{invoice_pay_link}'     => esc_url( $invoice->get_checkout_payment_url() ),
141
-			'{invoice_receipt_link}' => esc_url( $invoice->get_receipt_url() ),
142
-			'{invoice_date}'         => getpaid_format_date_value( $invoice->get_date_created() ),
143
-			'{invoice_due_date}'     => getpaid_format_date_value( $invoice->get_due_date(), __( 'on receipt', 'invoicing' ) ),
144
-			'{invoice_quote}'        => sanitize_text_field( strtolower( $invoice->get_label() ) ),
145
-			'{invoice_label}'        => sanitize_text_field( ucfirst( $invoice->get_label() ) ),
146
-			'{invoice_description}'  => wp_kses_post( $invoice->get_description() ),
147
-			'{subscription_name}'    => wp_kses_post( $invoice->get_subscription_name() ),
148
-			'{is_was}'               => $due_date < time() ? __( 'was', 'invoicing' ) : __( 'is', 'invoicing' ),
131
+			'{name}'                 => sanitize_text_field($invoice->get_user_full_name()),
132
+			'{full_name}'            => sanitize_text_field($invoice->get_user_full_name()),
133
+			'{first_name}'           => sanitize_text_field($invoice->get_first_name()),
134
+			'{last_name}'            => sanitize_text_field($invoice->get_last_name()),
135
+			'{email}'                => sanitize_email($invoice->get_email()),
136
+			'{invoice_number}'       => sanitize_text_field($invoice->get_number()),
137
+			'{invoice_currency}'     => sanitize_text_field($invoice->get_currency()),
138
+			'{invoice_total}'        => sanitize_text_field(wpinv_price($invoice->get_total(), $invoice->get_currency())),
139
+			'{invoice_link}'         => esc_url($invoice->get_view_url()),
140
+			'{invoice_pay_link}'     => esc_url($invoice->get_checkout_payment_url()),
141
+			'{invoice_receipt_link}' => esc_url($invoice->get_receipt_url()),
142
+			'{invoice_date}'         => getpaid_format_date_value($invoice->get_date_created()),
143
+			'{invoice_due_date}'     => getpaid_format_date_value($invoice->get_due_date(), __('on receipt', 'invoicing')),
144
+			'{invoice_quote}'        => sanitize_text_field(strtolower($invoice->get_label())),
145
+			'{invoice_label}'        => sanitize_text_field(ucfirst($invoice->get_label())),
146
+			'{invoice_description}'  => wp_kses_post($invoice->get_description()),
147
+			'{subscription_name}'    => wp_kses_post($invoice->get_subscription_name()),
148
+			'{is_was}'               => $due_date < time() ? __('was', 'invoicing') : __('is', 'invoicing'),
149 149
 		);
150 150
 
151
-		$payment_form_data = $invoice->get_meta( 'payment_form_data', true );
151
+		$payment_form_data = $invoice->get_meta('payment_form_data', true);
152 152
 
153
-		if ( is_array( $payment_form_data ) ) {
153
+		if (is_array($payment_form_data)) {
154 154
 
155
-			foreach ( $payment_form_data as $label => $value ) {
155
+			foreach ($payment_form_data as $label => $value) {
156 156
 
157
-				$label = preg_replace( '/[^a-z0-9]+/', '_', strtolower( $label ) );
158
-				$value = is_array( $value ) ? implode( ', ', $value ) : $value;
157
+				$label = preg_replace('/[^a-z0-9]+/', '_', strtolower($label));
158
+				$value = is_array($value) ? implode(', ', $value) : $value;
159 159
 
160
-				if ( is_scalar( $value ) ) {
161
-					$merge_tags[ "{{$label}}" ] = wp_kses_post( $value );
160
+				if (is_scalar($value)) {
161
+					$merge_tags["{{$label}}"] = wp_kses_post($value);
162 162
 				}
163 163
 			}
164 164
 		}
165 165
 
166
-		return apply_filters( 'getpaid_invoice_email_merge_tags', $merge_tags, $invoice );
166
+		return apply_filters('getpaid_invoice_email_merge_tags', $merge_tags, $invoice);
167 167
 	}
168 168
 
169 169
 	/**
@@ -175,12 +175,12 @@  discard block
 block discarded – undo
175 175
 	 * @param string|array $recipients
176 176
 	 * @param array $extra_args Extra template args.
177 177
 	 */
178
-	public function send_email( $invoice, $email, $type, $recipients, $extra_args = array() ) {
178
+	public function send_email($invoice, $email, $type, $recipients, $extra_args = array()) {
179 179
 
180
-		do_action( 'getpaid_before_send_invoice_notification', $type, $invoice, $email );
180
+		do_action('getpaid_before_send_invoice_notification', $type, $invoice, $email);
181 181
 
182
-		$skip = $invoice->is_free() && wpinv_get_option( 'skip_email_free_invoice' );
183
-		if ( apply_filters( 'getpaid_skip_invoice_email', $skip, $type, $invoice ) ) {
182
+		$skip = $invoice->is_free() && wpinv_get_option('skip_email_free_invoice');
183
+		if (apply_filters('getpaid_skip_invoice_email', $skip, $type, $invoice)) {
184 184
 			return;
185 185
 		}
186 186
 
@@ -188,43 +188,43 @@  discard block
 block discarded – undo
188 188
 		$merge_tags = $email->get_merge_tags();
189 189
 
190 190
 		$result = $mailer->send(
191
-			apply_filters( 'getpaid_invoice_email_recipients', wpinv_parse_list( $recipients ), $email ),
192
-			$email->add_merge_tags( $email->get_subject(), $merge_tags ),
193
-			$email->get_content( $merge_tags, $extra_args ),
191
+			apply_filters('getpaid_invoice_email_recipients', wpinv_parse_list($recipients), $email),
192
+			$email->add_merge_tags($email->get_subject(), $merge_tags),
193
+			$email->get_content($merge_tags, $extra_args),
194 194
 			$email->get_attachments()
195 195
 		);
196 196
 
197 197
 		// Maybe send a copy to the admin.
198
-		if ( $email->include_admin_bcc() ) {
198
+		if ($email->include_admin_bcc()) {
199 199
 			$mailer->send(
200 200
 				wpinv_get_admin_email(),
201
-				$email->add_merge_tags( $email->get_subject() . __( ' - ADMIN BCC COPY', 'invoicing' ), $merge_tags ),
202
-				$email->get_content( $merge_tags ),
201
+				$email->add_merge_tags($email->get_subject() . __(' - ADMIN BCC COPY', 'invoicing'), $merge_tags),
202
+				$email->get_content($merge_tags),
203 203
 				$email->get_attachments()
204 204
 			);
205 205
 		}
206 206
 
207
-		if ( $result ) {
207
+		if ($result) {
208 208
 			$invoice->add_system_note(
209 209
 				sprintf(
210 210
 					// translators: %1 is the email type, %2 is the invoice recipient.
211
-					__( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
212
-					sanitize_key( $type ),
213
-					$email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
211
+					__('Successfully sent %1$s notification email to %2$s.', 'invoicing'),
212
+					sanitize_key($type),
213
+					$email->is_admin_email() ? __('admin', 'invoicing') : __('the customer', 'invoicing')
214 214
 				)
215 215
 			);
216 216
 		} else {
217 217
 			$invoice->add_system_note(
218 218
 				sprintf(
219 219
 					// translators: %1 is the email type, %2 is the invoice recipient.
220
-					__( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
221
-					sanitize_key( $type ),
222
-					$email->is_admin_email() ? __( 'admin', 'invoicing' ) : __( 'the customer', 'invoicing' )
220
+					__('Failed sending %1$s notification email to %2$s.', 'invoicing'),
221
+					sanitize_key($type),
222
+					$email->is_admin_email() ? __('admin', 'invoicing') : __('the customer', 'invoicing')
223 223
 				)
224 224
 			);
225 225
 		}
226 226
 
227
-		do_action( 'getpaid_after_send_invoice_notification', $type, $invoice, $email );
227
+		do_action('getpaid_after_send_invoice_notification', $type, $invoice, $email);
228 228
 
229 229
 		return $result;
230 230
 	}
@@ -235,20 +235,20 @@  discard block
 block discarded – undo
235 235
 	 * @param array $recipients
236 236
 	 * @param GetPaid_Notification_Email $email
237 237
 	 */
238
-	public function filter_email_recipients( $recipients, $email ) {
238
+	public function filter_email_recipients($recipients, $email) {
239 239
 
240
-		if ( ! $email->is_admin_email() ) {
240
+		if (!$email->is_admin_email()) {
241 241
 			$cc   = $email->object->get_email_cc();
242
-			$cc_2 = get_user_meta( $email->object->get_user_id(), '_wpinv_email_cc', true );
242
+			$cc_2 = get_user_meta($email->object->get_user_id(), '_wpinv_email_cc', true);
243 243
 
244
-			if ( ! empty( $cc ) ) {
245
-				$cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
246
-				$recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
244
+			if (!empty($cc)) {
245
+				$cc = array_map('sanitize_email', wpinv_parse_list($cc));
246
+				$recipients = array_filter(array_unique(array_merge($recipients, $cc)));
247 247
 			}
248 248
 
249
-			if ( ! empty( $cc_2 ) ) {
250
-				$cc_2 = array_map( 'sanitize_email', wpinv_parse_list( $cc_2 ) );
251
-				$recipients = array_filter( array_unique( array_merge( $recipients, $cc_2 ) ) );
249
+			if (!empty($cc_2)) {
250
+				$cc_2 = array_map('sanitize_email', wpinv_parse_list($cc_2));
251
+				$recipients = array_filter(array_unique(array_merge($recipients, $cc_2)));
252 252
 			}
253 253
 		}
254 254
 
@@ -261,17 +261,17 @@  discard block
 block discarded – undo
261 261
 	 *
262 262
 	 * @param WPInv_Invoice $invoice
263 263
 	 */
264
-	public function new_invoice( $invoice ) {
264
+	public function new_invoice($invoice) {
265 265
 
266 266
 		// Only send this email for invoices created via the admin page.
267
-		if ( ! $invoice->is_type( 'invoice' ) || $invoice->is_paid() || $this->is_payment_form_invoice( $invoice->get_id() ) ) {
267
+		if (!$invoice->is_type('invoice') || $invoice->is_paid() || $this->is_payment_form_invoice($invoice->get_id())) {
268 268
 			return;
269 269
 		}
270 270
 
271
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
271
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
272 272
 		$recipient = wpinv_get_admin_email();
273 273
 
274
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
274
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
275 275
 
276 276
 	}
277 277
 
@@ -280,12 +280,12 @@  discard block
 block discarded – undo
280 280
 	 *
281 281
 	 * @param WPInv_Invoice $invoice
282 282
 	 */
283
-	public function cancelled_invoice( $invoice ) {
283
+	public function cancelled_invoice($invoice) {
284 284
 
285
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
285
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
286 286
 		$recipient = $invoice->get_email();
287 287
 
288
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
288
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
289 289
 	}
290 290
 
291 291
 	/**
@@ -293,12 +293,12 @@  discard block
 block discarded – undo
293 293
 	 *
294 294
 	 * @param WPInv_Invoice $invoice
295 295
 	 */
296
-	public function failed_invoice( $invoice ) {
296
+	public function failed_invoice($invoice) {
297 297
 
298
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
298
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
299 299
 		$recipient = wpinv_get_admin_email();
300 300
 
301
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
301
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
302 302
 
303 303
 	}
304 304
 
@@ -307,12 +307,12 @@  discard block
 block discarded – undo
307 307
 	 *
308 308
 	 * @param WPInv_Invoice $invoice
309 309
 	 */
310
-	public function onhold_invoice( $invoice ) {
310
+	public function onhold_invoice($invoice) {
311 311
 
312
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
312
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
313 313
 		$recipient = $invoice->get_email();
314 314
 
315
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
315
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
316 316
 
317 317
 	}
318 318
 
@@ -321,12 +321,12 @@  discard block
 block discarded – undo
321 321
 	 *
322 322
 	 * @param WPInv_Invoice $invoice
323 323
 	 */
324
-	public function processing_invoice( $invoice ) {
324
+	public function processing_invoice($invoice) {
325 325
 
326
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
326
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
327 327
 		$recipient = $invoice->get_email();
328 328
 
329
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
329
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
330 330
 
331 331
 	}
332 332
 
@@ -335,17 +335,17 @@  discard block
 block discarded – undo
335 335
 	 *
336 336
 	 * @param WPInv_Invoice $invoice
337 337
 	 */
338
-	public function completed_invoice( $invoice ) {
338
+	public function completed_invoice($invoice) {
339 339
 
340 340
 		// (Maybe) abort if it is a renewal invoice.
341
-		if ( $invoice->is_renewal() && ! wpinv_get_option( 'email_completed_invoice_renewal_active', false ) ) {
341
+		if ($invoice->is_renewal() && !wpinv_get_option('email_completed_invoice_renewal_active', false)) {
342 342
 			return;
343 343
 		}
344 344
 
345
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
345
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
346 346
 		$recipient = $invoice->get_email();
347 347
 
348
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
348
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
349 349
 
350 350
 	}
351 351
 
@@ -354,12 +354,12 @@  discard block
 block discarded – undo
354 354
 	 *
355 355
 	 * @param WPInv_Invoice $invoice
356 356
 	 */
357
-	public function refunded_invoice( $invoice ) {
357
+	public function refunded_invoice($invoice) {
358 358
 
359
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
359
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
360 360
 		$recipient = $invoice->get_email();
361 361
 
362
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
362
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
363 363
 
364 364
 	}
365 365
 
@@ -369,21 +369,21 @@  discard block
 block discarded – undo
369 369
 	 * @param WPInv_Invoice $invoice
370 370
 	 * @param bool $force
371 371
 	 */
372
-	public function user_invoice( $invoice, $force = false ) {
372
+	public function user_invoice($invoice, $force = false) {
373 373
 
374
-		if ( ! $force && ! empty( $GLOBALS['wpinv_skip_invoice_notification'] ) ) {
374
+		if (!$force && !empty($GLOBALS['wpinv_skip_invoice_notification'])) {
375 375
 			return;
376 376
 		}
377 377
 
378 378
 		// Only send this email for invoices created via the admin page.
379
-		if ( ! $invoice->is_type( 'invoice' ) || ( empty( $force ) && $invoice->is_paid() ) || ( empty( $force ) && $this->is_payment_form_invoice( $invoice->get_id() ) ) ) {
379
+		if (!$invoice->is_type('invoice') || (empty($force) && $invoice->is_paid()) || (empty($force) && $this->is_payment_form_invoice($invoice->get_id()))) {
380 380
 			return;
381 381
 		}
382 382
 
383
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
383
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
384 384
 		$recipient = $invoice->get_email();
385 385
 
386
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient );
386
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient);
387 387
 
388 388
 	}
389 389
 
@@ -393,11 +393,11 @@  discard block
 block discarded – undo
393 393
 	 * @param int $invoice
394 394
 	 * @return bool
395 395
 	 */
396
-	public function is_payment_form_invoice( $invoice ) {
397
-		$created_via             = get_post_meta( $invoice, 'wpinv_created_via', true );
396
+	public function is_payment_form_invoice($invoice) {
397
+		$created_via             = get_post_meta($invoice, 'wpinv_created_via', true);
398 398
 		$is_payment_form_invoice = 'payment_form' === $created_via || 'geodirectory' === $created_via;
399
-		$is_payment_form_invoice = apply_filters( 'getpaid_invoice_notifications_is_payment_form_invoice', $is_payment_form_invoice, $invoice );
400
-		return empty( $_GET['getpaid-admin-action'] ) && $is_payment_form_invoice;
399
+		$is_payment_form_invoice = apply_filters('getpaid_invoice_notifications_is_payment_form_invoice', $is_payment_form_invoice, $invoice);
400
+		return empty($_GET['getpaid-admin-action']) && $is_payment_form_invoice;
401 401
 	}
402 402
 
403 403
 	/**
@@ -406,12 +406,12 @@  discard block
 block discarded – undo
406 406
 	 * @param WPInv_Invoice $invoice
407 407
 	 * @param string $note
408 408
 	 */
409
-	public function user_note( $invoice, $note ) {
409
+	public function user_note($invoice, $note) {
410 410
 
411
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $invoice );
411
+		$email     = new GetPaid_Notification_Email(__FUNCTION__, $invoice);
412 412
 		$recipient = $invoice->get_email();
413 413
 
414
-		return $this->send_email( $invoice, $email, __FUNCTION__, $recipient, array( 'customer_note' => $note ) );
414
+		return $this->send_email($invoice, $email, __FUNCTION__, $recipient, array('customer_note' => $note));
415 415
 
416 416
 	}
417 417
 
@@ -420,9 +420,9 @@  discard block
 block discarded – undo
420 420
 	 *
421 421
 	 * @param WPInv_Invoice $invoice
422 422
 	 */
423
-	public function force_send_overdue_notice( $invoice ) {
424
-		$email = new GetPaid_Notification_Email( 'overdue', $invoice );
425
-		return $this->send_email( $invoice, $email, 'overdue', $invoice->get_email() );
423
+	public function force_send_overdue_notice($invoice) {
424
+		$email = new GetPaid_Notification_Email('overdue', $invoice);
425
+		return $this->send_email($invoice, $email, 'overdue', $invoice->get_email());
426 426
 	}
427 427
 
428 428
 	/**
@@ -433,38 +433,38 @@  discard block
 block discarded – undo
433 433
 	public function overdue() {
434 434
 		global $wpdb;
435 435
 
436
-		$email = new GetPaid_Notification_Email( __FUNCTION__ );
436
+		$email = new GetPaid_Notification_Email(__FUNCTION__);
437 437
 
438 438
 		// Fetch reminder days.
439
-		$reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
439
+		$reminder_days = array_unique(wp_parse_id_list($email->get_option('days')));
440 440
 
441 441
 		// Abort if non is set.
442
-		if ( empty( $reminder_days ) ) {
442
+		if (empty($reminder_days)) {
443 443
 			return;
444 444
 		}
445 445
 
446 446
 		// Retrieve date query.
447
-		$date_query = $this->get_date_query( $reminder_days );
447
+		$date_query = $this->get_date_query($reminder_days);
448 448
 
449 449
 		// Invoices table.
450 450
 		$table = $wpdb->prefix . 'getpaid_invoices';
451 451
 
452 452
 		// Fetch invoices.
453
-		$invoices  = $wpdb->get_col(
453
+		$invoices = $wpdb->get_col(
454 454
 			"SELECT posts.ID FROM $wpdb->posts as posts
455 455
 			LEFT JOIN $table as invoices ON invoices.post_id = posts.ID
456 456
 			WHERE posts.post_type = 'wpi_invoice' AND posts.post_status = 'wpi-pending' $date_query"
457 457
         );
458 458
 
459
-		foreach ( $invoices as $invoice ) {
459
+		foreach ($invoices as $invoice) {
460 460
 
461 461
 			// Only send this email for invoices created via the admin page.
462
-			if ( ! $this->is_payment_form_invoice( $invoice ) ) {
463
-				$invoice       = new WPInv_Invoice( $invoice );
462
+			if (!$this->is_payment_form_invoice($invoice)) {
463
+				$invoice       = new WPInv_Invoice($invoice);
464 464
 				$email->object = $invoice;
465 465
 
466
-				if ( $invoice->needs_payment() && ! $invoice->is_renewal() ) {
467
-					$this->send_email( $invoice, $email, __FUNCTION__, $invoice->get_email() );
466
+				if ($invoice->needs_payment() && !$invoice->is_renewal()) {
467
+					$this->send_email($invoice, $email, __FUNCTION__, $invoice->get_email());
468 468
 				}
469 469
 			}
470 470
 		}
@@ -477,14 +477,14 @@  discard block
 block discarded – undo
477 477
 	 * @param array $reminder_days
478 478
 	 * @return string
479 479
 	 */
480
-	public function get_date_query( $reminder_days ) {
480
+	public function get_date_query($reminder_days) {
481 481
 
482 482
 		$date_query = array(
483 483
 			'relation' => 'OR',
484 484
 		);
485 485
 
486
-		foreach ( $reminder_days as $days ) {
487
-			$date = date_parse( date( 'Y-m-d', strtotime( "-$days days", current_time( 'timestamp' ) ) ) );
486
+		foreach ($reminder_days as $days) {
487
+			$date = date_parse(date('Y-m-d', strtotime("-$days days", current_time('timestamp'))));
488 488
 
489 489
 			$date_query[] = array(
490 490
 				'year'  => $date['year'],
@@ -494,7 +494,7 @@  discard block
 block discarded – undo
494 494
 
495 495
 		}
496 496
 
497
-		$date_query = new WP_Date_Query( $date_query, 'invoices.due_date' );
497
+		$date_query = new WP_Date_Query($date_query, 'invoices.due_date');
498 498
 
499 499
 		return $date_query->get_sql();
500 500
 
Please login to merge, or discard this patch.
includes/class-getpaid-subscription-notification-emails.php 2 patches
Indentation   +284 added lines, -284 removed lines patch added patch discarded remove patch
@@ -13,324 +13,324 @@
 block discarded – undo
13 13
 class GetPaid_Subscription_Notification_Emails {
14 14
 
15 15
     /**
16
-	 * The array of subscription email actions.
17
-	 *
18
-	 * @param array
19
-	 */
20
-	public $subscription_actions;
16
+     * The array of subscription email actions.
17
+     *
18
+     * @param array
19
+     */
20
+    public $subscription_actions;
21 21
 
22 22
     /**
23
-	 * Class constructor
23
+     * Class constructor
24 24
      *
25
-	 */
26
-	public function __construct() {
27
-
28
-		$this->subscription_actions = apply_filters(
29
-			'getpaid_notification_email_subscription_triggers',
30
-			array(
31
-				'getpaid_subscription_active'    => 'subscription_active',
32
-				'getpaid_subscription_trialling' => 'subscription_trial',
33
-				'getpaid_subscription_cancelled' => 'subscription_cancelled',
34
-				'getpaid_subscription_expired'   => 'subscription_expired',
35
-				'getpaid_subscription_completed' => 'subscription_complete',
36
-				'getpaid_daily_maintenance'      => 'renewal_reminder'
37
-			)
38
-		);
39
-
40
-		add_action( 'init', array( $this, 'init_hooks' ) );
41
-	}
25
+     */
26
+    public function __construct() {
27
+
28
+        $this->subscription_actions = apply_filters(
29
+            'getpaid_notification_email_subscription_triggers',
30
+            array(
31
+                'getpaid_subscription_active'    => 'subscription_active',
32
+                'getpaid_subscription_trialling' => 'subscription_trial',
33
+                'getpaid_subscription_cancelled' => 'subscription_cancelled',
34
+                'getpaid_subscription_expired'   => 'subscription_expired',
35
+                'getpaid_subscription_completed' => 'subscription_complete',
36
+                'getpaid_daily_maintenance'      => 'renewal_reminder'
37
+            )
38
+        );
39
+
40
+        add_action( 'init', array( $this, 'init_hooks' ) );
41
+    }
42 42
 
43 43
     /**
44
-	 * Registers email hooks.
45
-	 */
46
-	public function init_hooks() {
47
-
48
-		add_filter( 'getpaid_get_email_merge_tags', array( $this, 'subscription_merge_tags' ), 10, 2 );
49
-		foreach ( $this->subscription_actions as $hook => $email_type ) {
50
-
51
-			$email = new GetPaid_Notification_Email( $email_type );
52
-
53
-			if ( ! $email->is_active() ) {
54
-				continue;
55
-			}
56
-
57
-			if ( method_exists( $this, $email_type ) ) {
58
-				add_action( $hook, array( $this, $email_type ), 100, 2 );
59
-				continue;
60
-			}
61
-
62
-			do_action( 'getpaid_subscription_notification_email_register_hook', $email_type, $hook );
63
-
64
-		}
65
-
66
-	}
67
-
68
-	/**
69
-	 * Filters subscription merge tags.
70
-	 *
71
-	 * @param array $merge_tags
72
-	 * @param mixed|WPInv_Invoice|WPInv_Subscription $object
73
-	 */
74
-	public function subscription_merge_tags( $merge_tags, $object ) {
75
-
76
-		if ( is_a( $object, 'WPInv_Subscription' ) ) {
77
-			$merge_tags = array_merge(
78
-				$merge_tags,
79
-				$this->get_subscription_merge_tags( $object )
80
-			);
81
-		}
82
-
83
-		return $merge_tags;
84
-
85
-	}
86
-
87
-	/**
88
-	 * Generates subscription merge tags.
89
-	 *
90
-	 * @param WPInv_Subscription $subscription
91
-	 * @return array
92
-	 */
93
-	public function get_subscription_merge_tags( $subscription ) {
94
-
95
-		// Abort if it does not exist.
96
-		if ( ! $subscription->get_id() ) {
97
-			return array();
98
-		}
99
-
100
-		$invoice    = $subscription->get_parent_invoice();
101
-		return array(
102
-			'{subscription_renewal_date}'     => getpaid_format_date_value( $subscription->get_next_renewal_date(), __( 'Never', 'invoicing' ) ),
103
-			'{subscription_created}'          => getpaid_format_date_value( $subscription->get_date_created() ),
104
-			'{subscription_status}'           => sanitize_text_field( $subscription->get_status_label() ),
105
-			'{subscription_profile_id}'       => sanitize_text_field( $subscription->get_profile_id() ),
106
-			'{subscription_id}'               => absint( $subscription->get_id() ),
107
-			'{subscription_recurring_amount}' => sanitize_text_field( wpinv_price( $subscription->get_recurring_amount(), $invoice->get_currency() ) ),
108
-			'{subscription_initial_amount}'   => sanitize_text_field( wpinv_price( $subscription->get_initial_amount(), $invoice->get_currency() ) ),
109
-			'{subscription_recurring_period}' => getpaid_get_subscription_period_label( $subscription->get_period(), $subscription->get_frequency(), '' ),
110
-			'{subscription_bill_times}'       => $subscription->get_bill_times(),
111
-			'{subscription_url}'              => esc_url( $subscription->get_view_url() ),
112
-		);
113
-
114
-	}
115
-
116
-	/**
117
-	 * Checks if we should send a notification for a subscription.
118
-	 *
119
-	 * @param WPInv_Invoice $invoice
120
-	 * @return bool
121
-	 */
122
-	public function should_send_notification( $invoice ) {
123
-		return 0 != $invoice->get_id();
124
-	}
125
-
126
-	/**
127
-	 * Returns notification recipients.
128
-	 *
129
-	 * @param WPInv_Invoice $invoice
130
-	 * @return array
131
-	 */
132
-	public function get_recipients( $invoice ) {
133
-		$recipients = array( $invoice->get_email() );
134
-
135
-		$cc = $invoice->get_email_cc();
136
-
137
-		if ( ! empty( $cc ) ) {
138
-			$cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
139
-			$recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
140
-		}
141
-
142
-		return $recipients;
143
-	}
144
-
145
-	/**
146
-	 * Helper function to send an email.
147
-	 *
148
-	 * @param WPInv_Subscription $subscription
149
-	 * @param GetPaid_Notification_Email $email
150
-	 * @param string $type
151
-	 * @param array $extra_args Extra template args.
152
-	 */
153
-	public function send_email( $subscription, $email, $type, $extra_args = array() ) {
154
-
155
-		if ( empty( $subscription ) ) {
156
-			return;
157
-		}
158
-
159
-		if ( is_array( $subscription ) ) {
160
-			$subscription = current( $subscription );
161
-		}
162
-
163
-		if ( ! $subscription instanceof WPInv_Subscription ) {
164
-			return;
165
-		}
166
-
167
-		// Abort in case the parent invoice does not exist.
168
-		$invoice = $subscription->get_parent_invoice();
169
-		if ( ! $this->should_send_notification( $invoice ) ) {
170
-			return;
171
-		}
172
-
173
-		if ( apply_filters( 'getpaid_skip_subscription_email', false, $type, $subscription ) ) {
174
-			return;
175
-		}
176
-
177
-		do_action( 'getpaid_before_send_subscription_notification', $type, $subscription, $email );
178
-
179
-		$recipients  = $this->get_recipients( $invoice );
180
-		$mailer      = new GetPaid_Notification_Email_Sender();
181
-		$merge_tags  = $email->get_merge_tags();
182
-		$content     = $email->get_content( $merge_tags, $extra_args );
183
-		$subject     = $email->add_merge_tags( $email->get_subject(), $merge_tags );
184
-		$attachments = $email->get_attachments();
185
-
186
-		$result = $mailer->send(
187
-			apply_filters( 'getpaid_subscription_email_recipients', wpinv_parse_list( $recipients ), $email ),
188
-			$subject,
189
-			$content,
190
-			$attachments
191
-		);
192
-
193
-		// Maybe send a copy to the admin.
194
-		if ( $email->include_admin_bcc() ) {
195
-			$mailer->send(
196
-				wpinv_get_admin_email(),
197
-				$subject . __( ' - ADMIN BCC COPY', 'invoicing' ),
198
-				$content,
199
-				$attachments
200
-			);
201
-		}
202
-
203
-		if ( $result ) {
204
-			$invoice->add_system_note(
205
-				sprintf(
206
-					__( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
207
-					sanitize_key( $type ),
208
-					$email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
209
-				)
210
-			);
211
-		} else {
212
-			$invoice->add_system_note(
213
-				sprintf(
214
-					__( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
215
-					sanitize_key( $type ),
216
-					$email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
217
-				)
218
-			);
219
-		}
220
-
221
-		do_action( 'getpaid_after_send_subscription_notification', $type, $subscription, $email );
222
-
223
-	}
224
-
225
-	/**
226
-	 * Sends a subscription active.
227
-	 *
228
-	 * @since 2.8.4
229
-	 *
230
-	 * @param WPInv_Subscription $subscription
231
-	 */
232
-	public function subscription_active( $subscription ) {
233
-		$email = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
234
-
235
-		$this->send_email( $subscription, $email, __FUNCTION__ );
236
-	}
44
+     * Registers email hooks.
45
+     */
46
+    public function init_hooks() {
47
+
48
+        add_filter( 'getpaid_get_email_merge_tags', array( $this, 'subscription_merge_tags' ), 10, 2 );
49
+        foreach ( $this->subscription_actions as $hook => $email_type ) {
50
+
51
+            $email = new GetPaid_Notification_Email( $email_type );
52
+
53
+            if ( ! $email->is_active() ) {
54
+                continue;
55
+            }
56
+
57
+            if ( method_exists( $this, $email_type ) ) {
58
+                add_action( $hook, array( $this, $email_type ), 100, 2 );
59
+                continue;
60
+            }
61
+
62
+            do_action( 'getpaid_subscription_notification_email_register_hook', $email_type, $hook );
63
+
64
+        }
65
+
66
+    }
237 67
 
238 68
     /**
239
-	 * Sends a new trial notification.
240
-	 *
241
-	 * @param WPInv_Subscription $subscription
242
-	 */
243
-	public function subscription_trial( $subscription ) {
69
+     * Filters subscription merge tags.
70
+     *
71
+     * @param array $merge_tags
72
+     * @param mixed|WPInv_Invoice|WPInv_Subscription $object
73
+     */
74
+    public function subscription_merge_tags( $merge_tags, $object ) {
244 75
 
245
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
246
-		$this->send_email( $subscription, $email, __FUNCTION__ );
76
+        if ( is_a( $object, 'WPInv_Subscription' ) ) {
77
+            $merge_tags = array_merge(
78
+                $merge_tags,
79
+                $this->get_subscription_merge_tags( $object )
80
+            );
81
+        }
247 82
 
248
-	}
83
+        return $merge_tags;
249 84
 
250
-	/**
251
-	 * Sends a cancelled subscription notification.
252
-	 *
253
-	 * @param WPInv_Subscription $subscription
254
-	 */
255
-	public function subscription_cancelled( $subscription ) {
85
+    }
86
+
87
+    /**
88
+     * Generates subscription merge tags.
89
+     *
90
+     * @param WPInv_Subscription $subscription
91
+     * @return array
92
+     */
93
+    public function get_subscription_merge_tags( $subscription ) {
94
+
95
+        // Abort if it does not exist.
96
+        if ( ! $subscription->get_id() ) {
97
+            return array();
98
+        }
99
+
100
+        $invoice    = $subscription->get_parent_invoice();
101
+        return array(
102
+            '{subscription_renewal_date}'     => getpaid_format_date_value( $subscription->get_next_renewal_date(), __( 'Never', 'invoicing' ) ),
103
+            '{subscription_created}'          => getpaid_format_date_value( $subscription->get_date_created() ),
104
+            '{subscription_status}'           => sanitize_text_field( $subscription->get_status_label() ),
105
+            '{subscription_profile_id}'       => sanitize_text_field( $subscription->get_profile_id() ),
106
+            '{subscription_id}'               => absint( $subscription->get_id() ),
107
+            '{subscription_recurring_amount}' => sanitize_text_field( wpinv_price( $subscription->get_recurring_amount(), $invoice->get_currency() ) ),
108
+            '{subscription_initial_amount}'   => sanitize_text_field( wpinv_price( $subscription->get_initial_amount(), $invoice->get_currency() ) ),
109
+            '{subscription_recurring_period}' => getpaid_get_subscription_period_label( $subscription->get_period(), $subscription->get_frequency(), '' ),
110
+            '{subscription_bill_times}'       => $subscription->get_bill_times(),
111
+            '{subscription_url}'              => esc_url( $subscription->get_view_url() ),
112
+        );
113
+
114
+    }
256 115
 
257
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
258
-		$this->send_email( $subscription, $email, __FUNCTION__ );
116
+    /**
117
+     * Checks if we should send a notification for a subscription.
118
+     *
119
+     * @param WPInv_Invoice $invoice
120
+     * @return bool
121
+     */
122
+    public function should_send_notification( $invoice ) {
123
+        return 0 != $invoice->get_id();
124
+    }
259 125
 
260
-	}
126
+    /**
127
+     * Returns notification recipients.
128
+     *
129
+     * @param WPInv_Invoice $invoice
130
+     * @return array
131
+     */
132
+    public function get_recipients( $invoice ) {
133
+        $recipients = array( $invoice->get_email() );
261 134
 
262
-	/**
263
-	 * Sends a subscription expired notification.
264
-	 *
265
-	 * @param WPInv_Subscription $subscription
266
-	 */
267
-	public function subscription_expired( $subscription ) {
135
+        $cc = $invoice->get_email_cc();
268 136
 
269
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
270
-		$this->send_email( $subscription, $email, __FUNCTION__ );
137
+        if ( ! empty( $cc ) ) {
138
+            $cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
139
+            $recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
140
+        }
271 141
 
272
-	}
142
+        return $recipients;
143
+    }
273 144
 
274
-	/**
275
-	 * Sends a completed subscription notification.
276
-	 *
277
-	 * @param WPInv_Subscription $subscription
278
-	 */
279
-	public function subscription_complete( $subscription ) {
145
+    /**
146
+     * Helper function to send an email.
147
+     *
148
+     * @param WPInv_Subscription $subscription
149
+     * @param GetPaid_Notification_Email $email
150
+     * @param string $type
151
+     * @param array $extra_args Extra template args.
152
+     */
153
+    public function send_email( $subscription, $email, $type, $extra_args = array() ) {
154
+
155
+        if ( empty( $subscription ) ) {
156
+            return;
157
+        }
158
+
159
+        if ( is_array( $subscription ) ) {
160
+            $subscription = current( $subscription );
161
+        }
162
+
163
+        if ( ! $subscription instanceof WPInv_Subscription ) {
164
+            return;
165
+        }
166
+
167
+        // Abort in case the parent invoice does not exist.
168
+        $invoice = $subscription->get_parent_invoice();
169
+        if ( ! $this->should_send_notification( $invoice ) ) {
170
+            return;
171
+        }
172
+
173
+        if ( apply_filters( 'getpaid_skip_subscription_email', false, $type, $subscription ) ) {
174
+            return;
175
+        }
176
+
177
+        do_action( 'getpaid_before_send_subscription_notification', $type, $subscription, $email );
178
+
179
+        $recipients  = $this->get_recipients( $invoice );
180
+        $mailer      = new GetPaid_Notification_Email_Sender();
181
+        $merge_tags  = $email->get_merge_tags();
182
+        $content     = $email->get_content( $merge_tags, $extra_args );
183
+        $subject     = $email->add_merge_tags( $email->get_subject(), $merge_tags );
184
+        $attachments = $email->get_attachments();
185
+
186
+        $result = $mailer->send(
187
+            apply_filters( 'getpaid_subscription_email_recipients', wpinv_parse_list( $recipients ), $email ),
188
+            $subject,
189
+            $content,
190
+            $attachments
191
+        );
192
+
193
+        // Maybe send a copy to the admin.
194
+        if ( $email->include_admin_bcc() ) {
195
+            $mailer->send(
196
+                wpinv_get_admin_email(),
197
+                $subject . __( ' - ADMIN BCC COPY', 'invoicing' ),
198
+                $content,
199
+                $attachments
200
+            );
201
+        }
202
+
203
+        if ( $result ) {
204
+            $invoice->add_system_note(
205
+                sprintf(
206
+                    __( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
207
+                    sanitize_key( $type ),
208
+                    $email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
209
+                )
210
+            );
211
+        } else {
212
+            $invoice->add_system_note(
213
+                sprintf(
214
+                    __( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
215
+                    sanitize_key( $type ),
216
+                    $email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
217
+                )
218
+            );
219
+        }
220
+
221
+        do_action( 'getpaid_after_send_subscription_notification', $type, $subscription, $email );
222
+
223
+    }
280 224
 
281
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
282
-		$this->send_email( $subscription, $email, __FUNCTION__ );
225
+    /**
226
+     * Sends a subscription active.
227
+     *
228
+     * @since 2.8.4
229
+     *
230
+     * @param WPInv_Subscription $subscription
231
+     */
232
+    public function subscription_active( $subscription ) {
233
+        $email = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
283 234
 
284
-	}
235
+        $this->send_email( $subscription, $email, __FUNCTION__ );
236
+    }
285 237
 
286
-	/**
287
-	 * Sends a subscription renewal reminder notification.
288
-	 *
289
-	 */
290
-	public function renewal_reminder() {
238
+    /**
239
+     * Sends a new trial notification.
240
+     *
241
+     * @param WPInv_Subscription $subscription
242
+     */
243
+    public function subscription_trial( $subscription ) {
244
+
245
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
246
+        $this->send_email( $subscription, $email, __FUNCTION__ );
247
+
248
+    }
249
+
250
+    /**
251
+     * Sends a cancelled subscription notification.
252
+     *
253
+     * @param WPInv_Subscription $subscription
254
+     */
255
+    public function subscription_cancelled( $subscription ) {
256
+
257
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
258
+        $this->send_email( $subscription, $email, __FUNCTION__ );
259
+
260
+    }
261
+
262
+    /**
263
+     * Sends a subscription expired notification.
264
+     *
265
+     * @param WPInv_Subscription $subscription
266
+     */
267
+    public function subscription_expired( $subscription ) {
268
+
269
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
270
+        $this->send_email( $subscription, $email, __FUNCTION__ );
271
+
272
+    }
273
+
274
+    /**
275
+     * Sends a completed subscription notification.
276
+     *
277
+     * @param WPInv_Subscription $subscription
278
+     */
279
+    public function subscription_complete( $subscription ) {
280
+
281
+        $email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
282
+        $this->send_email( $subscription, $email, __FUNCTION__ );
283
+
284
+    }
285
+
286
+    /**
287
+     * Sends a subscription renewal reminder notification.
288
+     *
289
+     */
290
+    public function renewal_reminder() {
291 291
 
292
-		$email = new GetPaid_Notification_Email( __FUNCTION__ );
292
+        $email = new GetPaid_Notification_Email( __FUNCTION__ );
293 293
 
294
-		// Fetch reminder days.
295
-		$reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
294
+        // Fetch reminder days.
295
+        $reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
296 296
 
297
-		// Abort if non is set.
298
-		if ( empty( $reminder_days ) ) {
299
-			return;
300
-		}
297
+        // Abort if non is set.
298
+        if ( empty( $reminder_days ) ) {
299
+            return;
300
+        }
301 301
 
302
-		// Fetch matching subscriptions.
302
+        // Fetch matching subscriptions.
303 303
         $args  = array(
304 304
             'number'             => -1,
305
-			'count_total'        => false,
306
-			'status'             => 'trialling active',
305
+            'count_total'        => false,
306
+            'status'             => 'trialling active',
307 307
             'date_expires_query' => array(
308
-				'relation' => 'OR',
308
+                'relation' => 'OR',
309 309
             ),
310
-		);
310
+        );
311 311
 
312
-		foreach ( $reminder_days as $days ) {
313
-			$date = date_parse( date( 'Y-m-d', strtotime( "+$days days", current_time( 'timestamp' ) ) ) );
312
+        foreach ( $reminder_days as $days ) {
313
+            $date = date_parse( date( 'Y-m-d', strtotime( "+$days days", current_time( 'timestamp' ) ) ) );
314 314
 
315
-			$args['date_expires_query'][] = array(
316
-				'year'  => $date['year'],
317
-				'month' => $date['month'],
318
-				'day'   => $date['day'],
319
-			);
315
+            $args['date_expires_query'][] = array(
316
+                'year'  => $date['year'],
317
+                'month' => $date['month'],
318
+                'day'   => $date['day'],
319
+            );
320 320
 
321
-		}
321
+        }
322 322
 
323
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
323
+        $subscriptions = new GetPaid_Subscriptions_Query( $args );
324 324
 
325 325
         foreach ( $subscriptions->get_results() as $subscription ) {
326 326
 
327
-			// Skip packages.
328
-			if ( apply_filters( 'getpaid_send_subscription_renewal_reminder_email', true ) ) {
329
-				$email->object = $subscription;
330
-            	$this->send_email( $subscription, $email, __FUNCTION__ );
331
-			}
332
-		}
327
+            // Skip packages.
328
+            if ( apply_filters( 'getpaid_send_subscription_renewal_reminder_email', true ) ) {
329
+                $email->object = $subscription;
330
+                $this->send_email( $subscription, $email, __FUNCTION__ );
331
+            }
332
+        }
333 333
 
334
-	}
334
+    }
335 335
 
336 336
 }
Please login to merge, or discard this patch.
Spacing   +77 added lines, -77 removed lines patch added patch discarded remove patch
@@ -4,7 +4,7 @@  discard block
 block discarded – undo
4 4
  *
5 5
  */
6 6
 
7
-defined( 'ABSPATH' ) || exit;
7
+defined('ABSPATH') || exit;
8 8
 
9 9
 /**
10 10
  * This class handles subscription notificaiton emails.
@@ -37,7 +37,7 @@  discard block
 block discarded – undo
37 37
 			)
38 38
 		);
39 39
 
40
-		add_action( 'init', array( $this, 'init_hooks' ) );
40
+		add_action('init', array($this, 'init_hooks'));
41 41
 	}
42 42
 
43 43
     /**
@@ -45,21 +45,21 @@  discard block
 block discarded – undo
45 45
 	 */
46 46
 	public function init_hooks() {
47 47
 
48
-		add_filter( 'getpaid_get_email_merge_tags', array( $this, 'subscription_merge_tags' ), 10, 2 );
49
-		foreach ( $this->subscription_actions as $hook => $email_type ) {
48
+		add_filter('getpaid_get_email_merge_tags', array($this, 'subscription_merge_tags'), 10, 2);
49
+		foreach ($this->subscription_actions as $hook => $email_type) {
50 50
 
51
-			$email = new GetPaid_Notification_Email( $email_type );
51
+			$email = new GetPaid_Notification_Email($email_type);
52 52
 
53
-			if ( ! $email->is_active() ) {
53
+			if (!$email->is_active()) {
54 54
 				continue;
55 55
 			}
56 56
 
57
-			if ( method_exists( $this, $email_type ) ) {
58
-				add_action( $hook, array( $this, $email_type ), 100, 2 );
57
+			if (method_exists($this, $email_type)) {
58
+				add_action($hook, array($this, $email_type), 100, 2);
59 59
 				continue;
60 60
 			}
61 61
 
62
-			do_action( 'getpaid_subscription_notification_email_register_hook', $email_type, $hook );
62
+			do_action('getpaid_subscription_notification_email_register_hook', $email_type, $hook);
63 63
 
64 64
 		}
65 65
 
@@ -71,12 +71,12 @@  discard block
 block discarded – undo
71 71
 	 * @param array $merge_tags
72 72
 	 * @param mixed|WPInv_Invoice|WPInv_Subscription $object
73 73
 	 */
74
-	public function subscription_merge_tags( $merge_tags, $object ) {
74
+	public function subscription_merge_tags($merge_tags, $object) {
75 75
 
76
-		if ( is_a( $object, 'WPInv_Subscription' ) ) {
76
+		if (is_a($object, 'WPInv_Subscription')) {
77 77
 			$merge_tags = array_merge(
78 78
 				$merge_tags,
79
-				$this->get_subscription_merge_tags( $object )
79
+				$this->get_subscription_merge_tags($object)
80 80
 			);
81 81
 		}
82 82
 
@@ -90,25 +90,25 @@  discard block
 block discarded – undo
90 90
 	 * @param WPInv_Subscription $subscription
91 91
 	 * @return array
92 92
 	 */
93
-	public function get_subscription_merge_tags( $subscription ) {
93
+	public function get_subscription_merge_tags($subscription) {
94 94
 
95 95
 		// Abort if it does not exist.
96
-		if ( ! $subscription->get_id() ) {
96
+		if (!$subscription->get_id()) {
97 97
 			return array();
98 98
 		}
99 99
 
100
-		$invoice    = $subscription->get_parent_invoice();
100
+		$invoice = $subscription->get_parent_invoice();
101 101
 		return array(
102
-			'{subscription_renewal_date}'     => getpaid_format_date_value( $subscription->get_next_renewal_date(), __( 'Never', 'invoicing' ) ),
103
-			'{subscription_created}'          => getpaid_format_date_value( $subscription->get_date_created() ),
104
-			'{subscription_status}'           => sanitize_text_field( $subscription->get_status_label() ),
105
-			'{subscription_profile_id}'       => sanitize_text_field( $subscription->get_profile_id() ),
106
-			'{subscription_id}'               => absint( $subscription->get_id() ),
107
-			'{subscription_recurring_amount}' => sanitize_text_field( wpinv_price( $subscription->get_recurring_amount(), $invoice->get_currency() ) ),
108
-			'{subscription_initial_amount}'   => sanitize_text_field( wpinv_price( $subscription->get_initial_amount(), $invoice->get_currency() ) ),
109
-			'{subscription_recurring_period}' => getpaid_get_subscription_period_label( $subscription->get_period(), $subscription->get_frequency(), '' ),
102
+			'{subscription_renewal_date}'     => getpaid_format_date_value($subscription->get_next_renewal_date(), __('Never', 'invoicing')),
103
+			'{subscription_created}'          => getpaid_format_date_value($subscription->get_date_created()),
104
+			'{subscription_status}'           => sanitize_text_field($subscription->get_status_label()),
105
+			'{subscription_profile_id}'       => sanitize_text_field($subscription->get_profile_id()),
106
+			'{subscription_id}'               => absint($subscription->get_id()),
107
+			'{subscription_recurring_amount}' => sanitize_text_field(wpinv_price($subscription->get_recurring_amount(), $invoice->get_currency())),
108
+			'{subscription_initial_amount}'   => sanitize_text_field(wpinv_price($subscription->get_initial_amount(), $invoice->get_currency())),
109
+			'{subscription_recurring_period}' => getpaid_get_subscription_period_label($subscription->get_period(), $subscription->get_frequency(), ''),
110 110
 			'{subscription_bill_times}'       => $subscription->get_bill_times(),
111
-			'{subscription_url}'              => esc_url( $subscription->get_view_url() ),
111
+			'{subscription_url}'              => esc_url($subscription->get_view_url()),
112 112
 		);
113 113
 
114 114
 	}
@@ -119,7 +119,7 @@  discard block
 block discarded – undo
119 119
 	 * @param WPInv_Invoice $invoice
120 120
 	 * @return bool
121 121
 	 */
122
-	public function should_send_notification( $invoice ) {
122
+	public function should_send_notification($invoice) {
123 123
 		return 0 != $invoice->get_id();
124 124
 	}
125 125
 
@@ -129,14 +129,14 @@  discard block
 block discarded – undo
129 129
 	 * @param WPInv_Invoice $invoice
130 130
 	 * @return array
131 131
 	 */
132
-	public function get_recipients( $invoice ) {
133
-		$recipients = array( $invoice->get_email() );
132
+	public function get_recipients($invoice) {
133
+		$recipients = array($invoice->get_email());
134 134
 
135 135
 		$cc = $invoice->get_email_cc();
136 136
 
137
-		if ( ! empty( $cc ) ) {
138
-			$cc = array_map( 'sanitize_email', wpinv_parse_list( $cc ) );
139
-			$recipients = array_filter( array_unique( array_merge( $recipients, $cc ) ) );
137
+		if (!empty($cc)) {
138
+			$cc = array_map('sanitize_email', wpinv_parse_list($cc));
139
+			$recipients = array_filter(array_unique(array_merge($recipients, $cc)));
140 140
 		}
141 141
 
142 142
 		return $recipients;
@@ -150,75 +150,75 @@  discard block
 block discarded – undo
150 150
 	 * @param string $type
151 151
 	 * @param array $extra_args Extra template args.
152 152
 	 */
153
-	public function send_email( $subscription, $email, $type, $extra_args = array() ) {
153
+	public function send_email($subscription, $email, $type, $extra_args = array()) {
154 154
 
155
-		if ( empty( $subscription ) ) {
155
+		if (empty($subscription)) {
156 156
 			return;
157 157
 		}
158 158
 
159
-		if ( is_array( $subscription ) ) {
160
-			$subscription = current( $subscription );
159
+		if (is_array($subscription)) {
160
+			$subscription = current($subscription);
161 161
 		}
162 162
 
163
-		if ( ! $subscription instanceof WPInv_Subscription ) {
163
+		if (!$subscription instanceof WPInv_Subscription) {
164 164
 			return;
165 165
 		}
166 166
 
167 167
 		// Abort in case the parent invoice does not exist.
168 168
 		$invoice = $subscription->get_parent_invoice();
169
-		if ( ! $this->should_send_notification( $invoice ) ) {
169
+		if (!$this->should_send_notification($invoice)) {
170 170
 			return;
171 171
 		}
172 172
 
173
-		if ( apply_filters( 'getpaid_skip_subscription_email', false, $type, $subscription ) ) {
173
+		if (apply_filters('getpaid_skip_subscription_email', false, $type, $subscription)) {
174 174
 			return;
175 175
 		}
176 176
 
177
-		do_action( 'getpaid_before_send_subscription_notification', $type, $subscription, $email );
177
+		do_action('getpaid_before_send_subscription_notification', $type, $subscription, $email);
178 178
 
179
-		$recipients  = $this->get_recipients( $invoice );
179
+		$recipients  = $this->get_recipients($invoice);
180 180
 		$mailer      = new GetPaid_Notification_Email_Sender();
181 181
 		$merge_tags  = $email->get_merge_tags();
182
-		$content     = $email->get_content( $merge_tags, $extra_args );
183
-		$subject     = $email->add_merge_tags( $email->get_subject(), $merge_tags );
182
+		$content     = $email->get_content($merge_tags, $extra_args);
183
+		$subject     = $email->add_merge_tags($email->get_subject(), $merge_tags);
184 184
 		$attachments = $email->get_attachments();
185 185
 
186 186
 		$result = $mailer->send(
187
-			apply_filters( 'getpaid_subscription_email_recipients', wpinv_parse_list( $recipients ), $email ),
187
+			apply_filters('getpaid_subscription_email_recipients', wpinv_parse_list($recipients), $email),
188 188
 			$subject,
189 189
 			$content,
190 190
 			$attachments
191 191
 		);
192 192
 
193 193
 		// Maybe send a copy to the admin.
194
-		if ( $email->include_admin_bcc() ) {
194
+		if ($email->include_admin_bcc()) {
195 195
 			$mailer->send(
196 196
 				wpinv_get_admin_email(),
197
-				$subject . __( ' - ADMIN BCC COPY', 'invoicing' ),
197
+				$subject . __(' - ADMIN BCC COPY', 'invoicing'),
198 198
 				$content,
199 199
 				$attachments
200 200
 			);
201 201
 		}
202 202
 
203
-		if ( $result ) {
203
+		if ($result) {
204 204
 			$invoice->add_system_note(
205 205
 				sprintf(
206
-					__( 'Successfully sent %1$s notification email to %2$s.', 'invoicing' ),
207
-					sanitize_key( $type ),
208
-					$email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
206
+					__('Successfully sent %1$s notification email to %2$s.', 'invoicing'),
207
+					sanitize_key($type),
208
+					$email->is_admin_email() ? __('admin') : __('the customer')
209 209
 				)
210 210
 			);
211 211
 		} else {
212 212
 			$invoice->add_system_note(
213 213
 				sprintf(
214
-					__( 'Failed sending %1$s notification email to %2$s.', 'invoicing' ),
215
-					sanitize_key( $type ),
216
-					$email->is_admin_email() ? __( 'admin' ) : __( 'the customer' )
214
+					__('Failed sending %1$s notification email to %2$s.', 'invoicing'),
215
+					sanitize_key($type),
216
+					$email->is_admin_email() ? __('admin') : __('the customer')
217 217
 				)
218 218
 			);
219 219
 		}
220 220
 
221
-		do_action( 'getpaid_after_send_subscription_notification', $type, $subscription, $email );
221
+		do_action('getpaid_after_send_subscription_notification', $type, $subscription, $email);
222 222
 
223 223
 	}
224 224
 
@@ -229,10 +229,10 @@  discard block
 block discarded – undo
229 229
 	 *
230 230
 	 * @param WPInv_Subscription $subscription
231 231
 	 */
232
-	public function subscription_active( $subscription ) {
233
-		$email = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
232
+	public function subscription_active($subscription) {
233
+		$email = new GetPaid_Notification_Email(__FUNCTION__, $subscription);
234 234
 
235
-		$this->send_email( $subscription, $email, __FUNCTION__ );
235
+		$this->send_email($subscription, $email, __FUNCTION__);
236 236
 	}
237 237
 
238 238
     /**
@@ -240,10 +240,10 @@  discard block
 block discarded – undo
240 240
 	 *
241 241
 	 * @param WPInv_Subscription $subscription
242 242
 	 */
243
-	public function subscription_trial( $subscription ) {
243
+	public function subscription_trial($subscription) {
244 244
 
245
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
246
-		$this->send_email( $subscription, $email, __FUNCTION__ );
245
+		$email = new GetPaid_Notification_Email(__FUNCTION__, $subscription);
246
+		$this->send_email($subscription, $email, __FUNCTION__);
247 247
 
248 248
 	}
249 249
 
@@ -252,10 +252,10 @@  discard block
 block discarded – undo
252 252
 	 *
253 253
 	 * @param WPInv_Subscription $subscription
254 254
 	 */
255
-	public function subscription_cancelled( $subscription ) {
255
+	public function subscription_cancelled($subscription) {
256 256
 
257
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
258
-		$this->send_email( $subscription, $email, __FUNCTION__ );
257
+		$email = new GetPaid_Notification_Email(__FUNCTION__, $subscription);
258
+		$this->send_email($subscription, $email, __FUNCTION__);
259 259
 
260 260
 	}
261 261
 
@@ -264,10 +264,10 @@  discard block
 block discarded – undo
264 264
 	 *
265 265
 	 * @param WPInv_Subscription $subscription
266 266
 	 */
267
-	public function subscription_expired( $subscription ) {
267
+	public function subscription_expired($subscription) {
268 268
 
269
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
270
-		$this->send_email( $subscription, $email, __FUNCTION__ );
269
+		$email = new GetPaid_Notification_Email(__FUNCTION__, $subscription);
270
+		$this->send_email($subscription, $email, __FUNCTION__);
271 271
 
272 272
 	}
273 273
 
@@ -276,10 +276,10 @@  discard block
 block discarded – undo
276 276
 	 *
277 277
 	 * @param WPInv_Subscription $subscription
278 278
 	 */
279
-	public function subscription_complete( $subscription ) {
279
+	public function subscription_complete($subscription) {
280 280
 
281
-		$email     = new GetPaid_Notification_Email( __FUNCTION__, $subscription );
282
-		$this->send_email( $subscription, $email, __FUNCTION__ );
281
+		$email = new GetPaid_Notification_Email(__FUNCTION__, $subscription);
282
+		$this->send_email($subscription, $email, __FUNCTION__);
283 283
 
284 284
 	}
285 285
 
@@ -289,18 +289,18 @@  discard block
 block discarded – undo
289 289
 	 */
290 290
 	public function renewal_reminder() {
291 291
 
292
-		$email = new GetPaid_Notification_Email( __FUNCTION__ );
292
+		$email = new GetPaid_Notification_Email(__FUNCTION__);
293 293
 
294 294
 		// Fetch reminder days.
295
-		$reminder_days = array_unique( wp_parse_id_list( $email->get_option( 'days' ) ) );
295
+		$reminder_days = array_unique(wp_parse_id_list($email->get_option('days')));
296 296
 
297 297
 		// Abort if non is set.
298
-		if ( empty( $reminder_days ) ) {
298
+		if (empty($reminder_days)) {
299 299
 			return;
300 300
 		}
301 301
 
302 302
 		// Fetch matching subscriptions.
303
-        $args  = array(
303
+        $args = array(
304 304
             'number'             => -1,
305 305
 			'count_total'        => false,
306 306
 			'status'             => 'trialling active',
@@ -309,8 +309,8 @@  discard block
 block discarded – undo
309 309
             ),
310 310
 		);
311 311
 
312
-		foreach ( $reminder_days as $days ) {
313
-			$date = date_parse( date( 'Y-m-d', strtotime( "+$days days", current_time( 'timestamp' ) ) ) );
312
+		foreach ($reminder_days as $days) {
313
+			$date = date_parse(date('Y-m-d', strtotime("+$days days", current_time('timestamp'))));
314 314
 
315 315
 			$args['date_expires_query'][] = array(
316 316
 				'year'  => $date['year'],
@@ -320,14 +320,14 @@  discard block
 block discarded – undo
320 320
 
321 321
 		}
322 322
 
323
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
323
+		$subscriptions = new GetPaid_Subscriptions_Query($args);
324 324
 
325
-        foreach ( $subscriptions->get_results() as $subscription ) {
325
+        foreach ($subscriptions->get_results() as $subscription) {
326 326
 
327 327
 			// Skip packages.
328
-			if ( apply_filters( 'getpaid_send_subscription_renewal_reminder_email', true ) ) {
328
+			if (apply_filters('getpaid_send_subscription_renewal_reminder_email', true)) {
329 329
 				$email->object = $subscription;
330
-            	$this->send_email( $subscription, $email, __FUNCTION__ );
330
+            	$this->send_email($subscription, $email, __FUNCTION__);
331 331
 			}
332 332
 		}
333 333
 
Please login to merge, or discard this patch.
includes/admin/class-getpaid-anonymization-logs.php 3 patches
Indentation   +6 added lines, -6 removed lines patch added patch discarded remove patch
@@ -34,12 +34,12 @@
 block discarded – undo
34 34
         // Prepare pagination
35 35
         $pagination = paginate_links(
36 36
             array(
37
-				'base'      => add_query_arg( 'paged', '%#%' ),
38
-				'format'    => '',
39
-				'prev_text' => __( '&laquo;', 'invoicing' ),
40
-				'next_text' => __( '&raquo;', 'invoicing' ),
41
-				'total'     => ceil( $total_logs / $per_page ),
42
-				'current'   => $page,
37
+                'base'      => add_query_arg( 'paged', '%#%' ),
38
+                'format'    => '',
39
+                'prev_text' => __( '&laquo;', 'invoicing' ),
40
+                'next_text' => __( '&raquo;', 'invoicing' ),
41
+                'total'     => ceil( $total_logs / $per_page ),
42
+                'current'   => $page,
43 43
             )
44 44
         );
45 45
 
Please login to merge, or discard this patch.
Spacing   +44 added lines, -44 removed lines patch added patch discarded remove patch
@@ -7,7 +7,7 @@  discard block
 block discarded – undo
7 7
  * @since 2.8.22
8 8
  */
9 9
 
10
-defined( 'ABSPATH' ) || exit;
10
+defined('ABSPATH') || exit;
11 11
 
12 12
 /**
13 13
  * GetPaid_Anonymization_Logs Class
@@ -19,89 +19,89 @@  discard block
 block discarded – undo
19 19
      */
20 20
     public function display_logs() {
21 21
         // Check user capabilities
22
-        if ( ! current_user_can( 'manage_options' ) ) {
22
+        if (!current_user_can('manage_options')) {
23 23
             return;
24 24
         }
25 25
 
26 26
         // Get current page number
27
-        $page = isset( $_GET['paged'] ) ? absint( $_GET['paged'] ) : 1;
27
+        $page = isset($_GET['paged']) ? absint($_GET['paged']) : 1;
28 28
         $per_page = 20;
29 29
 
30 30
         // Fetch logs
31
-        $logs = $this->get_logs( $page, $per_page );
31
+        $logs = $this->get_logs($page, $per_page);
32 32
         $total_logs = $this->get_total_logs();
33 33
 
34 34
         // Prepare pagination
35 35
         $pagination = paginate_links(
36 36
             array(
37
-				'base'      => add_query_arg( 'paged', '%#%' ),
37
+				'base'      => add_query_arg('paged', '%#%'),
38 38
 				'format'    => '',
39
-				'prev_text' => __( '&laquo;', 'invoicing' ),
40
-				'next_text' => __( '&raquo;', 'invoicing' ),
41
-				'total'     => ceil( $total_logs / $per_page ),
39
+				'prev_text' => __('&laquo;', 'invoicing'),
40
+				'next_text' => __('&raquo;', 'invoicing'),
41
+				'total'     => ceil($total_logs / $per_page),
42 42
 				'current'   => $page,
43 43
             )
44 44
         );
45 45
 
46 46
         ?>
47 47
         <div class="wrap getpaid-anonymization-logs">
48
-            <h1><?php echo esc_html( get_admin_page_title() ); ?></h1>
48
+            <h1><?php echo esc_html(get_admin_page_title()); ?></h1>
49 49
             <div class="tablenav top">
50 50
                 <div class="alignleft actions">
51 51
                     <form method="get">
52 52
                         <input type="hidden" name="page" value="wpinv-anonymization-logs">
53
-                        <label for="filter-by-date" class="screen-reader-text"><?php _e( 'Filter by date', 'invoicing' ); ?></label>
53
+                        <label for="filter-by-date" class="screen-reader-text"><?php _e('Filter by date', 'invoicing'); ?></label>
54 54
                         <select name="m" id="filter-by-date">
55
-                            <option value="0"><?php _e( 'All dates', 'invoicing' ); ?></option>
55
+                            <option value="0"><?php _e('All dates', 'invoicing'); ?></option>
56 56
                             <?php
57 57
                             $months = $this->get_log_months();
58
-                            foreach ( $months as $month ) {
59
-                                $selected = ( isset( $_GET['m'] ) && $_GET['m'] == $month->month ) ? ' selected="selected"' : '';
60
-                                echo '<option value="' . esc_attr( $month->month ) . '"' . $selected . '>' . esc_html( $month->month_name . ' ' . $month->year ) . '</option>';
58
+                            foreach ($months as $month) {
59
+                                $selected = (isset($_GET['m']) && $_GET['m'] == $month->month) ? ' selected="selected"' : '';
60
+                                echo '<option value="' . esc_attr($month->month) . '"' . $selected . '>' . esc_html($month->month_name . ' ' . $month->year) . '</option>';
61 61
                             }
62 62
                             ?>
63 63
                         </select>
64
-                        <?php submit_button( __( 'Filter', 'invoicing' ), '', 'filter_action', false ); ?>
64
+                        <?php submit_button(__('Filter', 'invoicing'), '', 'filter_action', false); ?>
65 65
                     </form>
66 66
                 </div>
67 67
             </div>
68 68
             <table class="wp-list-table widefat fixed striped">
69 69
                 <thead>
70 70
                     <tr>
71
-                        <th><?php _e( 'Log ID', 'invoicing' ); ?></th>
72
-                        <th><?php _e( 'User', 'invoicing' ); ?></th>
73
-                        <th><?php _e( 'Action', 'invoicing' ); ?></th>
74
-                        <th><?php _e( 'Date', 'invoicing' ); ?></th>
75
-                        <th><?php _e( 'Details', 'invoicing' ); ?></th>
71
+                        <th><?php _e('Log ID', 'invoicing'); ?></th>
72
+                        <th><?php _e('User', 'invoicing'); ?></th>
73
+                        <th><?php _e('Action', 'invoicing'); ?></th>
74
+                        <th><?php _e('Date', 'invoicing'); ?></th>
75
+                        <th><?php _e('Details', 'invoicing'); ?></th>
76 76
                     </tr>
77 77
                 </thead>
78 78
                 <tbody>
79
-                    <?php if ( empty( $logs ) ) : ?>
79
+                    <?php if (empty($logs)) : ?>
80 80
                         <tr>
81
-                            <td colspan="5"><?php _e( 'No anonymization logs found.', 'invoicing' ); ?></td>
81
+                            <td colspan="5"><?php _e('No anonymization logs found.', 'invoicing'); ?></td>
82 82
                         </tr>
83 83
                     <?php else : ?>
84 84
                         <?php
85
-                        foreach ( $logs as $log ) :
86
-                            $additional_info = json_decode( $log->additional_info, true );
85
+                        foreach ($logs as $log) :
86
+                            $additional_info = json_decode($log->additional_info, true);
87 87
                         ?>
88 88
                             <tr>
89
-                                <td><?php echo esc_html( $log->log_id ); ?></td>
89
+                                <td><?php echo esc_html($log->log_id); ?></td>
90 90
                                 <td>
91 91
                                     <?php
92
-                                    $user_edit_link = get_edit_user_link( $log->user_id );
93
-                                    if ( $user_edit_link ) {
94
-                                        echo '<a href="' . esc_url( $user_edit_link ) . '">' . esc_html( $log->user_id ) . '</a>';
92
+                                    $user_edit_link = get_edit_user_link($log->user_id);
93
+                                    if ($user_edit_link) {
94
+                                        echo '<a href="' . esc_url($user_edit_link) . '">' . esc_html($log->user_id) . '</a>';
95 95
                                     } else {
96
-                                        echo esc_html( $log->user_id );
96
+                                        echo esc_html($log->user_id);
97 97
                                     }
98 98
                                     ?>
99 99
                                 </td>
100
-                                <td><?php echo esc_html( ucfirst( $log->action ) ); ?></td>
101
-                                <td><?php echo esc_html( get_date_from_gmt( $log->timestamp, 'F j, Y g:i a' ) ); ?></td>
100
+                                <td><?php echo esc_html(ucfirst($log->action)); ?></td>
101
+                                <td><?php echo esc_html(get_date_from_gmt($log->timestamp, 'F j, Y g:i a')); ?></td>
102 102
                                 <td>
103 103
                                     <button class="button-link toggle-details" type="button" aria-expanded="false">
104
-                                        <span class="screen-reader-text"><?php _e( 'Show more details', 'invoicing' ); ?></span>
104
+                                        <span class="screen-reader-text"><?php _e('Show more details', 'invoicing'); ?></span>
105 105
                                         <span class="dashicons dashicons-arrow-down-alt2"></span>
106 106
                                     </button>
107 107
                                 </td>
@@ -112,19 +112,19 @@  discard block
 block discarded – undo
112 112
                                         <table class="widefat fixed">
113 113
                                             <tbody>
114 114
                                                 <tr>
115
-                                                    <th><?php _e( 'Data Type', 'invoicing' ); ?></th>
116
-                                                    <td><?php echo esc_html( $log->data_type ); ?></td>
115
+                                                    <th><?php _e('Data Type', 'invoicing'); ?></th>
116
+                                                    <td><?php echo esc_html($log->data_type); ?></td>
117 117
                                                 </tr>
118
-                                                <?php if ( is_array( $additional_info ) ) : ?>
118
+                                                <?php if (is_array($additional_info)) : ?>
119 119
                                                     <tr>
120
-                                                        <th><?php _e( 'Additional Information', 'invoicing' ); ?></th>
120
+                                                        <th><?php _e('Additional Information', 'invoicing'); ?></th>
121 121
                                                         <td>
122 122
                                                             <table class="widefat fixed">
123 123
                                                                 <tbody>
124
-                                                                    <?php foreach ( $additional_info as $key => $value ) : ?>
124
+                                                                    <?php foreach ($additional_info as $key => $value) : ?>
125 125
                                                                         <tr>
126
-                                                                            <th><?php echo esc_html( $key ); ?></th>
127
-                                                                            <td><?php echo esc_html( $value ); ?></td>
126
+                                                                            <th><?php echo esc_html($key); ?></th>
127
+                                                                            <td><?php echo esc_html($value); ?></td>
128 128
                                                                         </tr>
129 129
                                                                     <?php endforeach; ?>
130 130
                                                                 </tbody>
@@ -141,7 +141,7 @@  discard block
 block discarded – undo
141 141
                     <?php endif; ?>
142 142
                 </tbody>
143 143
             </table>
144
-            <?php if ( $pagination ) : ?>
144
+            <?php if ($pagination) : ?>
145 145
                 <div class="tablenav bottom">
146 146
                     <div class="tablenav-pages">
147 147
                         <?php echo $pagination; ?>
@@ -159,10 +159,10 @@  discard block
 block discarded – undo
159 159
      * @param int $per_page Number of logs per page
160 160
      * @return array
161 161
      */
162
-    private function get_logs( $page, $per_page ) {
162
+    private function get_logs($page, $per_page) {
163 163
         global $wpdb;
164 164
         $table_name = $wpdb->prefix . 'getpaid_anonymization_logs';
165
-        $offset = ( $page - 1 ) * $per_page;
165
+        $offset = ($page - 1) * $per_page;
166 166
 
167 167
         $query = $wpdb->prepare(
168 168
             "SELECT * FROM $table_name ORDER BY timestamp DESC LIMIT %d OFFSET %d",
@@ -170,7 +170,7 @@  discard block
 block discarded – undo
170 170
             $offset
171 171
         );
172 172
 
173
-        return $wpdb->get_results( $query );
173
+        return $wpdb->get_results($query);
174 174
     }
175 175
 
176 176
     /**
@@ -181,7 +181,7 @@  discard block
 block discarded – undo
181 181
     private function get_total_logs() {
182 182
         global $wpdb;
183 183
         $table_name = $wpdb->prefix . 'getpaid_anonymization_logs';
184
-        return $wpdb->get_var( "SELECT COUNT(*) FROM $table_name" );
184
+        return $wpdb->get_var("SELECT COUNT(*) FROM $table_name");
185 185
     }
186 186
 
187 187
     /**
Please login to merge, or discard this patch.
Braces   +3 added lines, -1 removed lines patch added patch discarded remove patch
@@ -80,10 +80,12 @@
 block discarded – undo
80 80
                         <tr>
81 81
                             <td colspan="5"><?php _e( 'No anonymization logs found.', 'invoicing' ); ?></td>
82 82
                         </tr>
83
-                    <?php else : ?>
83
+                    <?php else {
84
+    : ?>
84 85
                         <?php
85 86
                         foreach ( $logs as $log ) :
86 87
                             $additional_info = json_decode( $log->additional_info, true );
88
+}
87 89
                         ?>
88 90
                             <tr>
89 91
                                 <td><?php echo esc_html( $log->log_id ); ?></td>
Please login to merge, or discard this patch.
includes/class-wpinv-data-retention.php 2 patches
Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -291,18 +291,18 @@
 block discarded – undo
291 291
 
292 292
         $user_meta_data = array(
293 293
             'nickname',
294
-			'description',
295
-			'rich_editing',
296
-			'syntax_highlighting',
297
-			'comment_shortcuts',
294
+            'description',
295
+            'rich_editing',
296
+            'syntax_highlighting',
297
+            'comment_shortcuts',
298 298
             'admin_color',
299
-			'use_ssl',
300
-			'show_admin_bar_front',
301
-			'locale',
302
-			'wp_capabilities',
299
+            'use_ssl',
300
+            'show_admin_bar_front',
301
+            'locale',
302
+            'wp_capabilities',
303 303
             'wp_user_level',
304
-			'dismissed_wp_pointers',
305
-			'show_welcome_panel',
304
+            'dismissed_wp_pointers',
305
+            'show_welcome_panel',
306 306
         );
307 307
 
308 308
         /**
Please login to merge, or discard this patch.
Spacing   +148 added lines, -148 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
  * @since   2.8.22
7 7
  */
8 8
 
9
-defined( 'ABSPATH' ) || exit;
9
+defined('ABSPATH') || exit;
10 10
 
11 11
 /**
12 12
  * WPInv_Data_Retention Class.
@@ -35,13 +35,13 @@  discard block
 block discarded – undo
35 35
      * Class constructor.
36 36
      */
37 37
     public function __construct() {
38
-        add_filter( 'wpinv_settings_misc', array( $this, 'add_data_retention_settings' ) );
38
+        add_filter('wpinv_settings_misc', array($this, 'add_data_retention_settings'));
39 39
 
40
-        add_action( 'wpmu_delete_user', array( $this, 'maybe_handle_user_deletion' ), 1 );
41
-        add_action( 'delete_user', array( $this, 'maybe_handle_user_deletion' ), 1 );
42
-        add_filter( 'wp_privacy_personal_data_erasure_request', array( $this, 'handle_erasure_request' ), 10, 2 );
40
+        add_action('wpmu_delete_user', array($this, 'maybe_handle_user_deletion'), 1);
41
+        add_action('delete_user', array($this, 'maybe_handle_user_deletion'), 1);
42
+        add_filter('wp_privacy_personal_data_erasure_request', array($this, 'handle_erasure_request'), 10, 2);
43 43
 
44
-        add_action( 'getpaid_daily_maintenance', array( $this, 'perform_data_retention_cleanup' ) );
44
+        add_action('getpaid_daily_maintenance', array($this, 'perform_data_retention_cleanup'));
45 45
     }
46 46
 
47 47
     /**
@@ -50,43 +50,43 @@  discard block
 block discarded – undo
50 50
      * @param array $misc_settings Existing misc settings.
51 51
      * @return array Updated misc settings.
52 52
      */
53
-    public function add_data_retention_settings( $misc_settings ) {
53
+    public function add_data_retention_settings($misc_settings) {
54 54
         $misc_settings['data_retention'] = array(
55 55
             'id'   => 'data_retention',
56
-            'name' => '<h3>' . __( 'Data Retention', 'invoicing' ) . '</h3>',
56
+            'name' => '<h3>' . __('Data Retention', 'invoicing') . '</h3>',
57 57
             'type' => 'header',
58 58
         );
59 59
 
60 60
         $misc_settings['data_retention_method'] = array(
61 61
             'id'      => 'data_retention_method',
62
-            'name'    => __( 'Data Handling', 'invoicing' ),
63
-            'desc'    => __( 'Choose how to handle user data when deletion is required.', 'invoicing' ),
62
+            'name'    => __('Data Handling', 'invoicing'),
63
+            'desc'    => __('Choose how to handle user data when deletion is required.', 'invoicing'),
64 64
             'type'    => 'select',
65 65
             'options' => array(
66
-                'anonymize' => __( 'Anonymize data', 'invoicing' ),
67
-                'delete'    => __( 'Delete data without anonymization', 'invoicing' ),
66
+                'anonymize' => __('Anonymize data', 'invoicing'),
67
+                'delete'    => __('Delete data without anonymization', 'invoicing'),
68 68
             ),
69 69
             'std'     => 'anonymize',
70
-            'tooltip' => __( 'Anonymization replaces personal data with non-identifiable information. Direct deletion removes all data permanently.', 'invoicing' ),
70
+            'tooltip' => __('Anonymization replaces personal data with non-identifiable information. Direct deletion removes all data permanently.', 'invoicing'),
71 71
         );
72 72
 
73 73
         $misc_settings['data_retention_period'] = array(
74 74
             'id'      => 'data_retention_period',
75
-            'name'    => __( 'Retention Period', 'invoicing' ),
76
-            'desc'    => __( 'Specify how long to retain customer data after processing.', 'invoicing' ),
75
+            'name'    => __('Retention Period', 'invoicing'),
76
+            'desc'    => __('Specify how long to retain customer data after processing.', 'invoicing'),
77 77
             'type'    => 'select',
78 78
             'options' => array(
79
-                'never' => __( 'Never delete (retain indefinitely)', 'invoicing' ),
80
-                '30'    => __( '30 days', 'invoicing' ),
81
-                '90'    => __( '90 days', 'invoicing' ),
82
-                '180'   => __( '6 months', 'invoicing' ),
83
-                '365'   => __( '1 year', 'invoicing' ),
84
-                '730'   => __( '2 years', 'invoicing' ),
85
-                '1825'  => __( '5 years', 'invoicing' ),
86
-                '3650'  => __( '10 years', 'invoicing' ),
79
+                'never' => __('Never delete (retain indefinitely)', 'invoicing'),
80
+                '30'    => __('30 days', 'invoicing'),
81
+                '90'    => __('90 days', 'invoicing'),
82
+                '180'   => __('6 months', 'invoicing'),
83
+                '365'   => __('1 year', 'invoicing'),
84
+                '730'   => __('2 years', 'invoicing'),
85
+                '1825'  => __('5 years', 'invoicing'),
86
+                '3650'  => __('10 years', 'invoicing'),
87 87
             ),
88 88
             'std'     => '3650',
89
-            'tooltip' => __( 'Choose how long to keep processed customer data before final action. This helps balance data minimization with business needs.', 'invoicing' ),
89
+            'tooltip' => __('Choose how long to keep processed customer data before final action. This helps balance data minimization with business needs.', 'invoicing'),
90 90
         );
91 91
 
92 92
         return $misc_settings;
@@ -97,15 +97,15 @@  discard block
 block discarded – undo
97 97
      *
98 98
      * @param int $user_id The ID of the user being deleted.
99 99
      */
100
-    public function maybe_handle_user_deletion( $user_id ) {
101
-        if ( ! $this->handle_user_deletion ) {
100
+    public function maybe_handle_user_deletion($user_id) {
101
+        if (!$this->handle_user_deletion) {
102 102
             return;
103 103
         }
104 104
 
105
-        if ( current_user_can( 'manage_options' ) ) {
106
-            $this->handle_admin_user_deletion( $user_id );
105
+        if (current_user_can('manage_options')) {
106
+            $this->handle_admin_user_deletion($user_id);
107 107
         } else {
108
-            $this->handle_self_account_deletion( $user_id );
108
+            $this->handle_self_account_deletion($user_id);
109 109
         }
110 110
     }
111 111
 
@@ -115,19 +115,19 @@  discard block
 block discarded – undo
115 115
      * @since 2.8.22
116 116
      * @param int $user_id The ID of the user being deleted.
117 117
      */
118
-    public function handle_admin_user_deletion( $user_id ) {
119
-        if ( $this->has_active_subscriptions( $user_id ) ) {
120
-            $this->prevent_user_deletion( $user_id, 'active_subscriptions' );
118
+    public function handle_admin_user_deletion($user_id) {
119
+        if ($this->has_active_subscriptions($user_id)) {
120
+            $this->prevent_user_deletion($user_id, 'active_subscriptions');
121 121
             return;
122 122
         }
123 123
 
124
-        if ( $this->has_paid_invoices( $user_id ) ) {
125
-            $retention_method = wpinv_get_option( 'data_retention_method', 'anonymize' );
126
-            if ( 'anonymize' === $retention_method ) {
127
-                $this->anonymize_user_data( $user_id );
128
-                $this->prevent_user_deletion( $user_id, 'paid_invoices' );
124
+        if ($this->has_paid_invoices($user_id)) {
125
+            $retention_method = wpinv_get_option('data_retention_method', 'anonymize');
126
+            if ('anonymize' === $retention_method) {
127
+                $this->anonymize_user_data($user_id);
128
+                $this->prevent_user_deletion($user_id, 'paid_invoices');
129 129
             } else {
130
-                $this->delete_user_data( $user_id );
130
+                $this->delete_user_data($user_id);
131 131
             }
132 132
         }
133 133
     }
@@ -138,19 +138,19 @@  discard block
 block discarded – undo
138 138
      * @since 2.8.22
139 139
      * @param int $user_id The ID of the user being deleted.
140 140
      */
141
-    public function handle_self_account_deletion( $user_id ) {
142
-        $this->cancel_active_subscriptions( $user_id );
141
+    public function handle_self_account_deletion($user_id) {
142
+        $this->cancel_active_subscriptions($user_id);
143 143
 
144
-        if ( $this->has_paid_invoices( $user_id ) ) {
145
-            $retention_method = wpinv_get_option( 'data_retention_method', 'anonymize' );
144
+        if ($this->has_paid_invoices($user_id)) {
145
+            $retention_method = wpinv_get_option('data_retention_method', 'anonymize');
146 146
 
147
-            if ( 'anonymize' === $retention_method ) {
148
-                $user = get_userdata( $user_id );
147
+            if ('anonymize' === $retention_method) {
148
+                $user = get_userdata($user_id);
149 149
 
150
-                $this->anonymize_user_data( $user_id );
150
+                $this->anonymize_user_data($user_id);
151 151
 
152
-                $message = apply_filters( 'uwp_get_account_deletion_message', '', $user );
153
-                do_action( 'uwp_send_account_deletion_emails', $user, $message );
152
+                $message = apply_filters('uwp_get_account_deletion_message', '', $user);
153
+                do_action('uwp_send_account_deletion_emails', $user, $message);
154 154
 
155 155
                 $this->end_user_session();
156 156
             }
@@ -164,15 +164,15 @@  discard block
 block discarded – undo
164 164
      * @param int $user_id The ID of the user being checked.
165 165
      * @return bool True if user has active subscriptions, false otherwise.
166 166
      */
167
-    private function has_active_subscriptions( $user_id ) {
167
+    private function has_active_subscriptions($user_id) {
168 168
         $subscriptions = getpaid_get_subscriptions(
169 169
             array(
170
-                'customer_in' => array( (int) $user_id ),
170
+                'customer_in' => array((int) $user_id),
171 171
                 'status'      => 'active',
172 172
             )
173 173
         );
174 174
 
175
-        return ! empty( $subscriptions );
175
+        return !empty($subscriptions);
176 176
     }
177 177
 
178 178
     /**
@@ -181,15 +181,15 @@  discard block
 block discarded – undo
181 181
      * @since 2.8.22
182 182
      * @param int $user_id The ID of the user.
183 183
      */
184
-    private function cancel_active_subscriptions( $user_id ) {
184
+    private function cancel_active_subscriptions($user_id) {
185 185
         $subscriptions = getpaid_get_subscriptions(
186 186
             array(
187
-                'customer_in' => array( (int) $user_id ),
187
+                'customer_in' => array((int) $user_id),
188 188
                 'status'      => 'active',
189 189
             )
190 190
         );
191 191
 
192
-        foreach ( $subscriptions as $subscription ) {
192
+        foreach ($subscriptions as $subscription) {
193 193
             $subscription->cancel();
194 194
         }
195 195
     }
@@ -201,7 +201,7 @@  discard block
 block discarded – undo
201 201
      * @param int $user_id The ID of the user being checked.
202 202
      * @return bool True if user has paid invoices, false otherwise.
203 203
      */
204
-    private function has_paid_invoices( $user_id ) {
204
+    private function has_paid_invoices($user_id) {
205 205
         $invoices = wpinv_get_invoices(
206 206
             array(
207 207
                 'user'   => (int) $user_id,
@@ -209,7 +209,7 @@  discard block
 block discarded – undo
209 209
             )
210 210
         );
211 211
 
212
-        return ! empty( $invoices->total );
212
+        return !empty($invoices->total);
213 213
     }
214 214
 
215 215
     /**
@@ -219,24 +219,24 @@  discard block
 block discarded – undo
219 219
      * @param int    $user_id The ID of the user being deleted.
220 220
      * @param string $reason  The reason for preventing deletion.
221 221
      */
222
-    private function prevent_user_deletion( $user_id, $reason ) {
223
-        $user = get_userdata( $user_id );
222
+    private function prevent_user_deletion($user_id, $reason) {
223
+        $user = get_userdata($user_id);
224 224
 
225
-        if ( 'active_subscriptions' === $reason ) {
225
+        if ('active_subscriptions' === $reason) {
226 226
             $this->error_message = sprintf(
227 227
                 /* translators: %s: user login */
228
-                esc_html__( 'User deletion for %s has been halted. All active subscriptions should be cancelled first.', 'invoicing' ),
228
+                esc_html__('User deletion for %s has been halted. All active subscriptions should be cancelled first.', 'invoicing'),
229 229
                 $user->user_login
230 230
             );
231 231
         } else {
232 232
             $this->error_message = sprintf(
233 233
                 /* translators: %s: user login */
234
-                esc_html__( 'User deletion for %s has been halted due to paid invoices. Data will be anonymized instead.', 'invoicing' ),
234
+                esc_html__('User deletion for %s has been halted due to paid invoices. Data will be anonymized instead.', 'invoicing'),
235 235
                 $user->user_login
236 236
             );
237 237
         }
238 238
 
239
-        wp_die( $this->error_message, esc_html__( 'User Deletion Halted', 'invoicing' ), array( 'response' => 403 ) );
239
+        wp_die($this->error_message, esc_html__('User Deletion Halted', 'invoicing'), array('response' => 403));
240 240
     }
241 241
 
242 242
     /**
@@ -246,17 +246,17 @@  discard block
 block discarded – undo
246 246
      * @param int $user_id The ID of the user to anonymize.
247 247
      * @return bool True on success, false on failure.
248 248
      */
249
-    private function anonymize_user_data( $user_id ) {
249
+    private function anonymize_user_data($user_id) {
250 250
         global $wpdb;
251 251
 
252
-        $user = get_userdata( $user_id );
253
-        if ( ! $user ) {
252
+        $user = get_userdata($user_id);
253
+        if (!$user) {
254 254
             return false;
255 255
         }
256 256
 
257 257
         $table_name    = $wpdb->prefix . 'getpaid_customers';
258
-        $deletion_date = gmdate( 'Y-m-d', strtotime( '+10 years' ) );
259
-        $hashed_email  = $this->hash_email( $user->user_email );
258
+        $deletion_date = gmdate('Y-m-d', strtotime('+10 years'));
259
+        $hashed_email  = $this->hash_email($user->user_email);
260 260
 
261 261
         $updated = $wpdb->update(
262 262
             $table_name,
@@ -267,10 +267,10 @@  discard block
 block discarded – undo
267 267
                 'email_cc'      => $hashed_email,
268 268
                 'phone'         => '',
269 269
             ),
270
-            array( 'user_id' => (int) $user->ID )
270
+            array('user_id' => (int) $user->ID)
271 271
         );
272 272
 
273
-        if ( false === $updated ) {
273
+        if (false === $updated) {
274 274
             return false;
275 275
         }
276 276
 
@@ -287,7 +287,7 @@  discard block
 block discarded – undo
287 287
          * @since 2.8.22
288 288
          * @param int $user_id The ID of the user being anonymized.
289 289
          */
290
-        do_action( 'wpinv_anonymize_user_meta_data', $user->ID );
290
+        do_action('wpinv_anonymize_user_meta_data', $user->ID);
291 291
 
292 292
         $user_meta_data = array(
293 293
             'nickname',
@@ -312,13 +312,13 @@  discard block
 block discarded – undo
312 312
          * @param array $user_meta_data The meta fields to be anonymized.
313 313
          * @param int   $user_id          The ID of the user being anonymized.
314 314
          */
315
-        $user_meta_data = apply_filters( 'wpinv_user_meta_data_to_anonymize', $user_meta_data, $user->ID );
315
+        $user_meta_data = apply_filters('wpinv_user_meta_data_to_anonymize', $user_meta_data, $user->ID);
316 316
 
317
-        foreach ( $user_meta_data as $meta_key ) {
318
-            delete_user_meta( $user->ID, $meta_key );
317
+        foreach ($user_meta_data as $meta_key) {
318
+            delete_user_meta($user->ID, $meta_key);
319 319
         }
320 320
 
321
-        return $this->ensure_invoice_anonymization( $user->ID, 'anonymize' );
321
+        return $this->ensure_invoice_anonymization($user->ID, 'anonymize');
322 322
     }
323 323
 
324 324
     /**
@@ -327,15 +327,15 @@  discard block
 block discarded – undo
327 327
      * @param int $user_id The ID of the user to delete.
328 328
      * @return bool True on success, false on failure.
329 329
      */
330
-    private function delete_user_data( $user_id ) {
330
+    private function delete_user_data($user_id) {
331 331
         // Delete associated invoices.
332
-        $this->ensure_invoice_anonymization( $user_id, 'delete' );
332
+        $this->ensure_invoice_anonymization($user_id, 'delete');
333 333
 
334 334
         // Delete the user.
335
-        if ( is_multisite() ) {
336
-            wpmu_delete_user( $user_id );
335
+        if (is_multisite()) {
336
+            wpmu_delete_user($user_id);
337 337
         } else {
338
-            wp_delete_user( $user_id );
338
+            wp_delete_user($user_id);
339 339
         }
340 340
 
341 341
         /**
@@ -344,7 +344,7 @@  discard block
 block discarded – undo
344 344
          * @since 2.8.22
345 345
          * @param int $user_id The ID of the user being deleted.
346 346
          */
347
-        do_action( 'wpinv_delete_user_data', $user_id );
347
+        do_action('wpinv_delete_user_data', $user_id);
348 348
 
349 349
         return true;
350 350
     }
@@ -357,8 +357,8 @@  discard block
 block discarded – undo
357 357
      * @param string $action  The action to perform (anonymize or delete).
358 358
      * @return bool True on success, false on failure.
359 359
      */
360
-    public function ensure_invoice_anonymization( $user_id, $action = 'anonymize' ) {
361
-        $invoices = wpinv_get_invoices( array( 'user' => $user_id ) );
360
+    public function ensure_invoice_anonymization($user_id, $action = 'anonymize') {
361
+        $invoices = wpinv_get_invoices(array('user' => $user_id));
362 362
 
363 363
         /**
364 364
          * Filters the invoice meta fields to be anonymized.
@@ -367,22 +367,22 @@  discard block
 block discarded – undo
367 367
          * @param array $inv_meta_data The meta fields to be anonymized.
368 368
          * @param int   $user_id         The ID of the user being processed.
369 369
          */
370
-        $inv_meta_data = apply_filters( 'wpinv_invoice_meta_data_to_anonymize', array(), $user_id );
370
+        $inv_meta_data = apply_filters('wpinv_invoice_meta_data_to_anonymize', array(), $user_id);
371 371
 
372
-        foreach ( $invoices->invoices as $invoice ) {
373
-            foreach ( $inv_meta_data as $meta_key ) {
374
-                delete_post_meta( $invoice->get_id(), $meta_key );
372
+        foreach ($invoices->invoices as $invoice) {
373
+            foreach ($inv_meta_data as $meta_key) {
374
+                delete_post_meta($invoice->get_id(), $meta_key);
375 375
             }
376 376
 
377
-            if ( 'anonymize' === $action ) {
378
-                $hashed_inv_email    = $this->hash_email( $invoice->get_email() );
379
-                $hashed_inv_email_cc = $this->hash_email( $invoice->get_email_cc() );
377
+            if ('anonymize' === $action) {
378
+                $hashed_inv_email    = $this->hash_email($invoice->get_email());
379
+                $hashed_inv_email_cc = $this->hash_email($invoice->get_email_cc());
380 380
 
381
-                $invoice->set_email( $hashed_inv_email );
382
-                $invoice->set_email_cc( $hashed_inv_email_cc );
383
-                $invoice->set_phone( '' );
384
-                $invoice->set_ip( $this->anonymize_data( $invoice->get_ip() ) );
385
-                $invoice->set_is_anonymized( 1 );
381
+                $invoice->set_email($hashed_inv_email);
382
+                $invoice->set_email_cc($hashed_inv_email_cc);
383
+                $invoice->set_phone('');
384
+                $invoice->set_ip($this->anonymize_data($invoice->get_ip()));
385
+                $invoice->set_is_anonymized(1);
386 386
 
387 387
                 /**
388 388
                  * Fires when anonymizing additional invoice data.
@@ -391,7 +391,7 @@  discard block
 block discarded – undo
391 391
                  * @param WPInv_Invoice $invoice The invoice being anonymized.
392 392
                  * @param string        $action  The action being performed (anonymize or delete).
393 393
                  */
394
-                do_action( 'wpinv_anonymize_invoice_data', $invoice, $action );
394
+                do_action('wpinv_anonymize_invoice_data', $invoice, $action);
395 395
 
396 396
                 $invoice->save();
397 397
             } else {
@@ -399,7 +399,7 @@  discard block
 block discarded – undo
399 399
             }
400 400
         }
401 401
 
402
-        return $this->log_deletion_action( $user_id, $invoices->invoices, $action );
402
+        return $this->log_deletion_action($user_id, $invoices->invoices, $action);
403 403
     }
404 404
 
405 405
     /**
@@ -411,11 +411,11 @@  discard block
 block discarded – undo
411 411
      * @param string $action   The action being performed (anonymize or delete).
412 412
      * @return bool True on success, false on failure.
413 413
      */
414
-    private function log_deletion_action( $user_id, $invoices, $action ) {
414
+    private function log_deletion_action($user_id, $invoices, $action) {
415 415
         global $wpdb;
416 416
 
417 417
         $table_name = $wpdb->prefix . 'getpaid_anonymization_logs';
418
-        $user_data  = get_userdata( $user_id );
418
+        $user_data  = get_userdata($user_id);
419 419
 
420 420
         $additional_info = array(
421 421
             'Username'      => $user_data ? $user_data->user_login : 'N/A',
@@ -424,7 +424,7 @@  discard block
 block discarded – undo
424 424
             'First Name'    => $user_data ? $user_data->first_name : 'N/A',
425 425
             'Last Name'     => $user_data ? $user_data->last_name : 'N/A',
426 426
             'Registered'    => $user_data ? $user_data->user_registered : 'N/A',
427
-            'invoice_count' => count( $invoices ),
427
+            'invoice_count' => count($invoices),
428 428
         );
429 429
 
430 430
 
@@ -437,43 +437,43 @@  discard block
 block discarded – undo
437 437
          * @param array  $invoices        The invoices being processed.
438 438
          * @param string $action          The action being performed (anonymize or delete).
439 439
          */
440
-        $additional_info = apply_filters( 'wpinv_anonymization_log_additional_info', $additional_info, $user_id, $invoices, $action );
440
+        $additional_info = apply_filters('wpinv_anonymization_log_additional_info', $additional_info, $user_id, $invoices, $action);
441 441
 
442 442
         $data = array(
443 443
             'user_id'         => $user_id,
444
-            'action'          => sanitize_text_field( $action ),
444
+            'action'          => sanitize_text_field($action),
445 445
             'data_type'       => 'User Invoices',
446
-            'timestamp'       => current_time( 'mysql' ),
447
-            'additional_info' => wp_json_encode( $additional_info ),
446
+            'timestamp'       => current_time('mysql'),
447
+            'additional_info' => wp_json_encode($additional_info),
448 448
         );
449 449
 
450 450
         $format = array(
451
-            '%d',  // user_id
452
-            '%s',  // action
453
-            '%s',  // data_type
454
-            '%s',  // timestamp
455
-            '%s',  // additional_info
451
+            '%d', // user_id
452
+            '%s', // action
453
+            '%s', // data_type
454
+            '%s', // timestamp
455
+            '%s', // additional_info
456 456
         );
457 457
 
458
-        if ( ! empty( $user_id ) && ! empty( $action ) ) {
458
+        if (!empty($user_id) && !empty($action)) {
459 459
             $result = $wpdb->update(
460 460
                 $table_name,
461 461
                 $data,
462 462
                 array(
463 463
                     'user_id' => (int) $user_id,
464
-                    'action'  => sanitize_text_field( $action ),
464
+                    'action'  => sanitize_text_field($action),
465 465
                 ),
466 466
                 $format,
467
-                array( '%d', '%s' )
467
+                array('%d', '%s')
468 468
             );
469 469
 
470
-            if ( false === $result ) {
470
+            if (false === $result) {
471 471
                 // If update fails, try to insert.
472
-                $result = $wpdb->insert( $table_name, $data, $format );
472
+                $result = $wpdb->insert($table_name, $data, $format);
473 473
             }
474 474
 
475
-            if ( false === $result ) {
476
-                wpinv_error_log( sprintf( 'Failed to log anonymization action for user ID: %d. Error: %s', $user_id, $wpdb->last_error ) );
475
+            if (false === $result) {
476
+                wpinv_error_log(sprintf('Failed to log anonymization action for user ID: %d. Error: %s', $user_id, $wpdb->last_error));
477 477
                 return false;
478 478
             }
479 479
         }
@@ -487,7 +487,7 @@  discard block
 block discarded – undo
487 487
          * @param string $action   The action being performed (anonymize or delete).
488 488
          * @param array  $data     The data that was inserted into the log.
489 489
          */
490
-        do_action( 'wpinv_after_log_deletion_action', $user_id, $invoices, $action, $data );
490
+        do_action('wpinv_after_log_deletion_action', $user_id, $invoices, $action, $data);
491 491
 
492 492
         return true;
493 493
     }
@@ -500,20 +500,20 @@  discard block
 block discarded – undo
500 500
      * @param int   $user_id  The ID of the user being erased.
501 501
      * @return array The modified response.
502 502
      */
503
-    public function handle_erasure_request( $response, $user_id ) {
504
-        if ( $this->has_active_subscriptions( $user_id ) ) {
505
-            $response['messages'][]    = esc_html__( 'User has active subscriptions. Data cannot be erased at this time.', 'invoicing' );
503
+    public function handle_erasure_request($response, $user_id) {
504
+        if ($this->has_active_subscriptions($user_id)) {
505
+            $response['messages'][]    = esc_html__('User has active subscriptions. Data cannot be erased at this time.', 'invoicing');
506 506
             $response['items_removed'] = false;
507
-        } elseif ( $this->has_paid_invoices( $user_id ) ) {
508
-            $retention_method = wpinv_get_option( 'data_retention_method', 'anonymize' );
509
-            if ( 'anonymize' === $retention_method ) {
510
-                $this->anonymize_user_data( $user_id );
511
-                $response['messages'][]     = esc_html__( 'User data has been anonymized due to existing paid invoices.', 'invoicing' );
507
+        } elseif ($this->has_paid_invoices($user_id)) {
508
+            $retention_method = wpinv_get_option('data_retention_method', 'anonymize');
509
+            if ('anonymize' === $retention_method) {
510
+                $this->anonymize_user_data($user_id);
511
+                $response['messages'][]     = esc_html__('User data has been anonymized due to existing paid invoices.', 'invoicing');
512 512
                 $response['items_removed']  = false;
513 513
                 $response['items_retained'] = true;
514 514
             } else {
515
-                $this->delete_user_data( $user_id );
516
-                $response['messages'][]     = esc_html__( 'User data has been deleted.', 'invoicing' );
515
+                $this->delete_user_data($user_id);
516
+                $response['messages'][]     = esc_html__('User data has been deleted.', 'invoicing');
517 517
                 $response['items_removed']  = true;
518 518
                 $response['items_retained'] = false;
519 519
             }
@@ -529,18 +529,18 @@  discard block
 block discarded – undo
529 529
      * @param string $email The email to hash.
530 530
      * @return string The hashed email.
531 531
      */
532
-    private function hash_email( $email ) {
532
+    private function hash_email($email) {
533 533
         $site_url = get_site_url();
534
-        $domain   = wp_parse_url( $site_url, PHP_URL_HOST );
534
+        $domain   = wp_parse_url($site_url, PHP_URL_HOST);
535 535
 
536
-        if ( empty( $domain ) ) {
536
+        if (empty($domain)) {
537 537
             return $email;
538 538
         }
539 539
 
540
-        $clean_email     = sanitize_email( strtolower( trim( $email ) ) );
541
-        $hash            = wp_hash( $clean_email );
542
-        $hash            = substr( $hash, 0, 20 );
543
-        $anonymized_email = sprintf( '%s@%s', $hash, $domain );
540
+        $clean_email     = sanitize_email(strtolower(trim($email)));
541
+        $hash            = wp_hash($clean_email);
542
+        $hash            = substr($hash, 0, 20);
543
+        $anonymized_email = sprintf('%s@%s', $hash, $domain);
544 544
 
545 545
         /**
546 546
          * Filters the anonymized email before returning.
@@ -549,7 +549,7 @@  discard block
 block discarded – undo
549 549
          * @param string $anonymized_email The anonymized email address.
550 550
          * @param string $email            The original email address.
551 551
          */
552
-        return apply_filters( 'wpinv_anonymized_email', $anonymized_email, $email );
552
+        return apply_filters('wpinv_anonymized_email', $anonymized_email, $email);
553 553
     }
554 554
 
555 555
     /**
@@ -559,12 +559,12 @@  discard block
 block discarded – undo
559 559
      * @param string $data The data to anonymize.
560 560
      * @return string The anonymized data.
561 561
      */
562
-    private function anonymize_data( $data ) {
563
-        if ( empty( $data ) ) {
562
+    private function anonymize_data($data) {
563
+        if (empty($data)) {
564 564
             return '';
565 565
         }
566 566
 
567
-        return wp_privacy_anonymize_data( 'text', $data );
567
+        return wp_privacy_anonymize_data('text', $data);
568 568
     }
569 569
 
570 570
     /**
@@ -578,17 +578,17 @@  discard block
 block discarded – undo
578 578
     public function perform_data_retention_cleanup() {
579 579
         global $wpdb;
580 580
 
581
-        $retention_period = wpinv_get_option( 'data_retention_period', '3650' );
581
+        $retention_period = wpinv_get_option('data_retention_period', '3650');
582 582
 
583 583
         // If retention period is set to 'never', exit the function.
584
-        if ( 'never' === $retention_period ) {
584
+        if ('never' === $retention_period) {
585 585
             return;
586 586
         }
587 587
 
588 588
         $customers_table = $wpdb->prefix . 'getpaid_customers';
589 589
 
590 590
         // Calculate the cutoff date for data retention.
591
-        $cutoff_date = gmdate( 'Y-m-d', strtotime( "-$retention_period days" ) );
591
+        $cutoff_date = gmdate('Y-m-d', strtotime("-$retention_period days"));
592 592
 
593 593
         $expired_records = $wpdb->get_results(
594 594
             $wpdb->prepare(
@@ -603,18 +603,18 @@  discard block
 block discarded – undo
603 603
          * @since 2.8.22
604 604
          * @param array $expired_records Array of customer records to be processed.
605 605
          */
606
-        do_action( 'getpaid_data_retention_before_cleanup', $expired_records );
606
+        do_action('getpaid_data_retention_before_cleanup', $expired_records);
607 607
 
608
-        if ( ! empty( $expired_records ) ) {
608
+        if (!empty($expired_records)) {
609 609
             // Disable our custom user deletion handling.
610 610
             $this->handle_user_deletion = false;
611 611
 
612
-            foreach ( $expired_records as $record ) {
612
+            foreach ($expired_records as $record) {
613 613
                 // Delete associated invoices.
614
-                $this->ensure_invoice_anonymization( (int) $record->user_id, 'delete' );
614
+                $this->ensure_invoice_anonymization((int) $record->user_id, 'delete');
615 615
 
616 616
                 // Delete the user.
617
-                wp_delete_user( (int) $record->user_id );
617
+                wp_delete_user((int) $record->user_id);
618 618
 
619 619
                 /**
620 620
                  * Fires after processing each expired record during cleanup.
@@ -622,7 +622,7 @@  discard block
 block discarded – undo
622 622
                  * @since 2.8.22
623 623
                  * @param object $record The customer record being processed.
624 624
                  */
625
-                do_action( 'getpaid_data_retention_process_record', $record );
625
+                do_action('getpaid_data_retention_process_record', $record);
626 626
             }
627 627
 
628 628
             // Re-enable our custom user deletion handling.
@@ -634,7 +634,7 @@  discard block
 block discarded – undo
634 634
              * @since 2.8.22
635 635
              * @param array $expired_records Array of customer records that were processed.
636 636
              */
637
-            do_action( 'getpaid_data_retention_after_cleanup', $expired_records );
637
+            do_action('getpaid_data_retention_after_cleanup', $expired_records);
638 638
         }
639 639
 
640 640
         /**
@@ -644,7 +644,7 @@  discard block
 block discarded – undo
644 644
          * @param int $retention_period The current retention period in years.
645 645
          * @param string $cutoff_date The cutoff date used for identifying expired records.
646 646
          */
647
-        do_action( 'getpaid_data_retention_cleanup_complete', $retention_period, $cutoff_date );
647
+        do_action('getpaid_data_retention_cleanup_complete', $retention_period, $cutoff_date);
648 648
     }
649 649
 
650 650
     /**
@@ -657,7 +657,7 @@  discard block
 block discarded – undo
657 657
 
658 658
         // Redirect after deletion.
659 659
         $redirect_page = home_url();
660
-        wp_safe_redirect( $redirect_page );
660
+        wp_safe_redirect($redirect_page);
661 661
         exit();
662 662
     }
663 663
 }
664 664
\ No newline at end of file
Please login to merge, or discard this patch.