Passed
Pull Request — master (#847)
by Kiran
05:48
created
includes/wpinv-subscription.php 3 patches
Braces   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -963,7 +963,7 @@
 block discarded – undo
963 963
 
964 964
 		if ( $discount->exists() && $discount->is_recurring() ) {
965 965
 			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
966
-		}  else {
966
+		} else {
967 967
 			// Unset discount code.
968 968
 			$invoice->set_discount_code( '' );
969 969
 
Please login to merge, or discard this patch.
Indentation   +1036 added lines, -1036 removed lines patch added patch discarded remove patch
@@ -15,125 +15,125 @@  discard block
 block discarded – undo
15 15
  */
16 16
 class WPInv_Subscription extends GetPaid_Data {
17 17
 
18
-	/**
19
-	 * Which data store to load.
20
-	 *
21
-	 * @var string
22
-	 */
23
-	protected $data_store_name = 'subscription';
24
-
25
-	/**
26
-	 * This is the name of this object type.
27
-	 *
28
-	 * @var string
29
-	 */
30
-	protected $object_type = 'subscription';
31
-
32
-	/**
33
-	 * Item Data array. This is the core item data exposed in APIs.
34
-	 *
35
-	 * @since 1.0.19
36
-	 * @var array
37
-	 */
38
-	protected $data = array(
39
-		'customer_id'       => 0,
40
-		'frequency'         => 1,
41
-		'period'            => 'D',
42
-		'initial_amount'    => null,
43
-		'recurring_amount'  => null,
44
-		'bill_times'        => 0,
45
-		'transaction_id'    => '',
46
-		'parent_payment_id' => null,
47
-		'product_id'        => 0,
48
-		'created'           => '0000-00-00 00:00:00',
49
-		'expiration'        => '0000-00-00 00:00:00',
50
-		'trial_period'      => '',
51
-		'status'            => 'pending',
52
-		'profile_id'        => '',
53
-		'gateway'           => '',
54
-		'customer'          => '',
55
-	);
56
-
57
-	/**
58
-	 * Stores the status transition information.
59
-	 *
60
-	 * @since 1.0.19
61
-	 * @var bool
62
-	 */
63
-	protected $status_transition = false;
64
-
65
-	/**
66
-	 * Get the subscription if ID is passed, otherwise the subscription is new and empty.
67
-	 *
68
-	 * @param  int|string|object|WPInv_Subscription $subscription Subscription id, profile_id, or object to read.
69
-	 * @param  bool $deprecated
70
-	 */
71
-	function __construct( $subscription = 0, $deprecated = false ) {
72
-
73
-		parent::__construct( $subscription );
74
-
75
-		if ( ! $deprecated && ! empty( $subscription ) && is_numeric( $subscription ) ) {
76
-			$this->set_id( $subscription );
77
-		} elseif ( $subscription instanceof self ) {
78
-			$this->set_id( $subscription->get_id() );
79
-		} elseif ( $deprecated && $subscription_id = self::get_subscription_id_by_field( $subscription, 'profile_id' ) ) {
80
-			$this->set_id( $subscription_id );
81
-		} elseif ( ! empty( $subscription->id ) ) {
82
-			$this->set_id( $subscription->id );
83
-		} else {
84
-			$this->set_object_read( true );
85
-		}
86
-
87
-		// Load the datastore.
88
-		$this->data_store = GetPaid_Data_Store::load( $this->data_store_name );
89
-
90
-		if ( $this->get_id() > 0 ) {
91
-			$this->data_store->read( $this );
92
-		}
93
-
94
-	}
95
-
96
-	/**
97
-	 * Given an invoice id, profile id, transaction id, it returns the subscription's id.
98
-	 *
99
-	 *
100
-	 * @static
101
-	 * @param string $value
102
-	 * @param string $field Either invoice_id, transaction_id or profile_id.
103
-	 * @since 1.0.19
104
-	 * @return int
105
-	 */
106
-	public static function get_subscription_id_by_field( $value, $field = 'profile_id' ) {
18
+    /**
19
+     * Which data store to load.
20
+     *
21
+     * @var string
22
+     */
23
+    protected $data_store_name = 'subscription';
24
+
25
+    /**
26
+     * This is the name of this object type.
27
+     *
28
+     * @var string
29
+     */
30
+    protected $object_type = 'subscription';
31
+
32
+    /**
33
+     * Item Data array. This is the core item data exposed in APIs.
34
+     *
35
+     * @since 1.0.19
36
+     * @var array
37
+     */
38
+    protected $data = array(
39
+        'customer_id'       => 0,
40
+        'frequency'         => 1,
41
+        'period'            => 'D',
42
+        'initial_amount'    => null,
43
+        'recurring_amount'  => null,
44
+        'bill_times'        => 0,
45
+        'transaction_id'    => '',
46
+        'parent_payment_id' => null,
47
+        'product_id'        => 0,
48
+        'created'           => '0000-00-00 00:00:00',
49
+        'expiration'        => '0000-00-00 00:00:00',
50
+        'trial_period'      => '',
51
+        'status'            => 'pending',
52
+        'profile_id'        => '',
53
+        'gateway'           => '',
54
+        'customer'          => '',
55
+    );
56
+
57
+    /**
58
+     * Stores the status transition information.
59
+     *
60
+     * @since 1.0.19
61
+     * @var bool
62
+     */
63
+    protected $status_transition = false;
64
+
65
+    /**
66
+     * Get the subscription if ID is passed, otherwise the subscription is new and empty.
67
+     *
68
+     * @param  int|string|object|WPInv_Subscription $subscription Subscription id, profile_id, or object to read.
69
+     * @param  bool $deprecated
70
+     */
71
+    function __construct( $subscription = 0, $deprecated = false ) {
72
+
73
+        parent::__construct( $subscription );
74
+
75
+        if ( ! $deprecated && ! empty( $subscription ) && is_numeric( $subscription ) ) {
76
+            $this->set_id( $subscription );
77
+        } elseif ( $subscription instanceof self ) {
78
+            $this->set_id( $subscription->get_id() );
79
+        } elseif ( $deprecated && $subscription_id = self::get_subscription_id_by_field( $subscription, 'profile_id' ) ) {
80
+            $this->set_id( $subscription_id );
81
+        } elseif ( ! empty( $subscription->id ) ) {
82
+            $this->set_id( $subscription->id );
83
+        } else {
84
+            $this->set_object_read( true );
85
+        }
86
+
87
+        // Load the datastore.
88
+        $this->data_store = GetPaid_Data_Store::load( $this->data_store_name );
89
+
90
+        if ( $this->get_id() > 0 ) {
91
+            $this->data_store->read( $this );
92
+        }
93
+
94
+    }
95
+
96
+    /**
97
+     * Given an invoice id, profile id, transaction id, it returns the subscription's id.
98
+     *
99
+     *
100
+     * @static
101
+     * @param string $value
102
+     * @param string $field Either invoice_id, transaction_id or profile_id.
103
+     * @since 1.0.19
104
+     * @return int
105
+     */
106
+    public static function get_subscription_id_by_field( $value, $field = 'profile_id' ) {
107 107
         global $wpdb;
108 108
 
109
-		// Trim the value.
110
-		$value = trim( $value );
109
+        // Trim the value.
110
+        $value = trim( $value );
111 111
 
112
-		if ( empty( $value ) ) {
113
-			return 0;
114
-		}
112
+        if ( empty( $value ) ) {
113
+            return 0;
114
+        }
115 115
 
116
-		if ( 'invoice_id' == $field ) {
117
-			$field = 'parent_payment_id';
118
-		}
116
+        if ( 'invoice_id' == $field ) {
117
+            $field = 'parent_payment_id';
118
+        }
119 119
 
120 120
         // Valid fields.
121 121
         $fields = array(
122
-			'parent_payment_id',
123
-			'transaction_id',
124
-			'profile_id',
125
-		);
126
-
127
-		// Ensure a field has been passed.
128
-		if ( empty( $field ) || ! in_array( $field, $fields ) ) {
129
-			return 0;
130
-		}
131
-
132
-		// Maybe retrieve from the cache.
133
-		$subscription_id   = wp_cache_get( $value, "getpaid_subscription_{$field}s_to_subscription_ids" );
134
-		if ( ! empty( $subscription_id ) ) {
135
-			return $subscription_id;
136
-		}
122
+            'parent_payment_id',
123
+            'transaction_id',
124
+            'profile_id',
125
+        );
126
+
127
+        // Ensure a field has been passed.
128
+        if ( empty( $field ) || ! in_array( $field, $fields ) ) {
129
+            return 0;
130
+        }
131
+
132
+        // Maybe retrieve from the cache.
133
+        $subscription_id   = wp_cache_get( $value, "getpaid_subscription_{$field}s_to_subscription_ids" );
134
+        if ( ! empty( $subscription_id ) ) {
135
+            return $subscription_id;
136
+        }
137 137
 
138 138
         // Fetch from the db.
139 139
         $table            = $wpdb->prefix . 'wpinv_subscriptions';
@@ -141,42 +141,42 @@  discard block
 block discarded – undo
141 141
             $wpdb->prepare( "SELECT `id` FROM $table WHERE `$field`=%s LIMIT 1", $value )
142 142
         );
143 143
 
144
-		if ( empty( $subscription_id ) ) {
145
-			return 0;
146
-		}
144
+        if ( empty( $subscription_id ) ) {
145
+            return 0;
146
+        }
147 147
 
148
-		// Update the cache with our data.
149
-		wp_cache_set( $value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids" );
148
+        // Update the cache with our data.
149
+        wp_cache_set( $value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids" );
150 150
 
151
-		return $subscription_id;
152
-	}
151
+        return $subscription_id;
152
+    }
153 153
 
154
-	/**
154
+    /**
155 155
      * Clears the subscription's cache.
156 156
      */
157 157
     public function clear_cache() {
158
-		$caches = array(
159
-			'getpaid_subscription_parent_payment_ids_to_subscription_ids' => $this->get_parent_payment_id(),
160
-			'getpaid_subscription_transaction_ids_to_subscription_ids'    => $this->get_transaction_id(),
161
-			'getpaid_subscription_profile_ids_to_subscription_ids'        => $this->get_profile_id(),
162
-			'getpaid_subscriptions'                                       => $this->get_id(),
163
-		);
164
-
165
-		foreach ( $caches as $cache => $value ) {
166
-			if ( '' !== $value && false !== $value ) {
167
-				wp_cache_delete( $value, $cache );
168
-			}
169
-		}
170
-	}
171
-
172
-	/**
158
+        $caches = array(
159
+            'getpaid_subscription_parent_payment_ids_to_subscription_ids' => $this->get_parent_payment_id(),
160
+            'getpaid_subscription_transaction_ids_to_subscription_ids'    => $this->get_transaction_id(),
161
+            'getpaid_subscription_profile_ids_to_subscription_ids'        => $this->get_profile_id(),
162
+            'getpaid_subscriptions'                                       => $this->get_id(),
163
+        );
164
+
165
+        foreach ( $caches as $cache => $value ) {
166
+            if ( '' !== $value && false !== $value ) {
167
+                wp_cache_delete( $value, $cache );
168
+            }
169
+        }
170
+    }
171
+
172
+    /**
173 173
      * Checks if a subscription key is set.
174 174
      */
175 175
     public function _isset( $key ) {
176 176
         return isset( $this->data[ $key ] ) || method_exists( $this, "get_$key" );
177
-	}
177
+    }
178 178
 
179
-	/*
179
+    /*
180 180
 	|--------------------------------------------------------------------------
181 181
 	| CRUD methods
182 182
 	|--------------------------------------------------------------------------
@@ -185,57 +185,57 @@  discard block
 block discarded – undo
185 185
 	|
186 186
     */
187 187
 
188
-	/*
188
+    /*
189 189
 	|--------------------------------------------------------------------------
190 190
 	| Getters
191 191
 	|--------------------------------------------------------------------------
192 192
 	*/
193 193
 
194
-	/**
195
-	 * Get customer id.
196
-	 *
197
-	 * @since 1.0.19
198
-	 * @param  string $context View or edit context.
199
-	 * @return int
200
-	 */
201
-	public function get_customer_id( $context = 'view' ) {
202
-		return (int) $this->get_prop( 'customer_id', $context );
203
-	}
204
-
205
-	/**
206
-	 * Get customer information.
207
-	 *
208
-	 * @since 1.0.19
209
-	 * @param  string $context View or edit context.
210
-	 * @return WP_User|false WP_User object on success, false on failure.
211
-	 */
212
-	public function get_customer( $context = 'view' ) {
213
-		return get_userdata( $this->get_customer_id( $context ) );
214
-	}
215
-
216
-	/**
217
-	 * Get parent invoice id.
218
-	 *
219
-	 * @since 1.0.19
220
-	 * @param  string $context View or edit context.
221
-	 * @return int
222
-	 */
223
-	public function get_parent_invoice_id( $context = 'view' ) {
224
-		return (int) $this->get_prop( 'parent_payment_id', $context );
225
-	}
226
-
227
-	/**
228
-	 * Alias for self::get_parent_invoice_id().
229
-	 *
230
-	 * @since 1.0.19
231
-	 * @param  string $context View or edit context.
232
-	 * @return int
233
-	 */
194
+    /**
195
+     * Get customer id.
196
+     *
197
+     * @since 1.0.19
198
+     * @param  string $context View or edit context.
199
+     * @return int
200
+     */
201
+    public function get_customer_id( $context = 'view' ) {
202
+        return (int) $this->get_prop( 'customer_id', $context );
203
+    }
204
+
205
+    /**
206
+     * Get customer information.
207
+     *
208
+     * @since 1.0.19
209
+     * @param  string $context View or edit context.
210
+     * @return WP_User|false WP_User object on success, false on failure.
211
+     */
212
+    public function get_customer( $context = 'view' ) {
213
+        return get_userdata( $this->get_customer_id( $context ) );
214
+    }
215
+
216
+    /**
217
+     * Get parent invoice id.
218
+     *
219
+     * @since 1.0.19
220
+     * @param  string $context View or edit context.
221
+     * @return int
222
+     */
223
+    public function get_parent_invoice_id( $context = 'view' ) {
224
+        return (int) $this->get_prop( 'parent_payment_id', $context );
225
+    }
226
+
227
+    /**
228
+     * Alias for self::get_parent_invoice_id().
229
+     *
230
+     * @since 1.0.19
231
+     * @param  string $context View or edit context.
232
+     * @return int
233
+     */
234 234
     public function get_parent_payment_id( $context = 'view' ) {
235 235
         return $this->get_parent_invoice_id( $context );
236
-	}
236
+    }
237 237
 
238
-	/**
238
+    /**
239 239
      * Alias for self::get_parent_invoice_id().
240 240
      *
241 241
      * @since  1.0.0
@@ -245,390 +245,390 @@  discard block
 block discarded – undo
245 245
         return $this->get_parent_invoice_id( $context );
246 246
     }
247 247
 
248
-	/**
249
-	 * Get parent invoice.
250
-	 *
251
-	 * @since 1.0.19
252
-	 * @param  string $context View or edit context.
253
-	 * @return WPInv_Invoice
254
-	 */
255
-	public function get_parent_invoice( $context = 'view' ) {
256
-		return new WPInv_Invoice( $this->get_parent_invoice_id( $context ) );
257
-	}
258
-
259
-	/**
260
-	 * Alias for self::get_parent_invoice().
261
-	 *
262
-	 * @since 1.0.19
263
-	 * @param  string $context View or edit context.
264
-	 * @return WPInv_Invoice
265
-	 */
248
+    /**
249
+     * Get parent invoice.
250
+     *
251
+     * @since 1.0.19
252
+     * @param  string $context View or edit context.
253
+     * @return WPInv_Invoice
254
+     */
255
+    public function get_parent_invoice( $context = 'view' ) {
256
+        return new WPInv_Invoice( $this->get_parent_invoice_id( $context ) );
257
+    }
258
+
259
+    /**
260
+     * Alias for self::get_parent_invoice().
261
+     *
262
+     * @since 1.0.19
263
+     * @param  string $context View or edit context.
264
+     * @return WPInv_Invoice
265
+     */
266 266
     public function get_parent_payment( $context = 'view' ) {
267 267
         return $this->get_parent_invoice( $context );
268
-	}
269
-
270
-	/**
271
-	 * Get subscription's product id.
272
-	 *
273
-	 * @since 1.0.19
274
-	 * @param  string $context View or edit context.
275
-	 * @return int
276
-	 */
277
-	public function get_product_id( $context = 'view' ) {
278
-		return (int) $this->get_prop( 'product_id', $context );
279
-	}
280
-
281
-	/**
282
-	 * Get the subscription product.
283
-	 *
284
-	 * @since 1.0.19
285
-	 * @param  string $context View or edit context.
286
-	 * @return WPInv_Item
287
-	 */
288
-	public function get_product( $context = 'view' ) {
289
-		return new WPInv_Item( $this->get_product_id( $context ) );
290
-	}
291
-
292
-	/**
293
-	 * Get parent invoice's gateway.
294
-	 *
295
-	 * Here for backwards compatibility.
296
-	 *
297
-	 * @since 1.0.19
298
-	 * @param  string $context View or edit context.
299
-	 * @return string
300
-	 */
301
-	public function get_gateway( $context = 'view' ) {
302
-		return $this->get_parent_invoice( $context )->get_gateway();
303
-	}
304
-
305
-	/**
306
-	 * Get the period of a renewal.
307
-	 *
308
-	 * @since 1.0.19
309
-	 * @param  string $context View or edit context.
310
-	 * @return string
311
-	 */
312
-	public function get_period( $context = 'view' ) {
313
-		return $this->get_prop( 'period', $context );
314
-	}
315
-
316
-	/**
317
-	 * Get number of periods each renewal is valid for.
318
-	 *
319
-	 * @since 1.0.19
320
-	 * @param  string $context View or edit context.
321
-	 * @return int
322
-	 */
323
-	public function get_frequency( $context = 'view' ) {
324
-		return (int) $this->get_prop( 'frequency', $context );
325
-	}
326
-
327
-	/**
328
-	 * Get the initial amount for the subscription.
329
-	 *
330
-	 * @since 1.0.19
331
-	 * @param  string $context View or edit context.
332
-	 * @return float
333
-	 */
334
-	public function get_initial_amount( $context = 'view' ) {
335
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'initial_amount', $context ) );
336
-	}
337
-
338
-	/**
339
-	 * Get the recurring amount for the subscription.
340
-	 *
341
-	 * @since 1.0.19
342
-	 * @param  string $context View or edit context.
343
-	 * @return float
344
-	 */
345
-	public function get_recurring_amount( $context = 'view' ) {
346
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'recurring_amount', $context ) );
347
-	}
348
-
349
-	/**
350
-	 * Get number of times that this subscription can be renewed.
351
-	 *
352
-	 * @since 1.0.19
353
-	 * @param  string $context View or edit context.
354
-	 * @return int
355
-	 */
356
-	public function get_bill_times( $context = 'view' ) {
357
-		return (int) $this->get_prop( 'bill_times', $context );
358
-	}
359
-
360
-	/**
361
-	 * Get transaction id of this subscription's parent invoice.
362
-	 *
363
-	 * @since 1.0.19
364
-	 * @param  string $context View or edit context.
365
-	 * @return string
366
-	 */
367
-	public function get_transaction_id( $context = 'view' ) {
368
-		return $this->get_prop( 'transaction_id', $context );
369
-	}
370
-
371
-	/**
372
-	 * Get the date that the subscription was created.
373
-	 *
374
-	 * @since 1.0.19
375
-	 * @param  string $context View or edit context.
376
-	 * @return string
377
-	 */
378
-	public function get_created( $context = 'view' ) {
379
-		return $this->get_prop( 'created', $context );
380
-	}
381
-
382
-	/**
383
-	 * Alias for self::get_created().
384
-	 *
385
-	 * @since 1.0.19
386
-	 * @param  string $context View or edit context.
387
-	 * @return string
388
-	 */
389
-	public function get_date_created( $context = 'view' ) {
390
-		return $this->get_created( $context );
391
-	}
392
-
393
-	/**
394
-	 * Retrieves the creation date in a timestamp
395
-	 *
396
-	 * @since  1.0.0
397
-	 * @return int
398
-	 */
399
-	public function get_time_created() {
400
-		$created = $this->get_date_created();
401
-		return empty( $created ) ? current_time( 'timestamp' ) : strtotime( $created, current_time( 'timestamp' ) );
402
-	}
403
-
404
-	/**
405
-	 * Get GMT date when the subscription was created.
406
-	 *
407
-	 * @since 1.0.19
408
-	 * @param  string $context View or edit context.
409
-	 * @return string
410
-	 */
411
-	public function get_date_created_gmt( $context = 'view' ) {
268
+    }
269
+
270
+    /**
271
+     * Get subscription's product id.
272
+     *
273
+     * @since 1.0.19
274
+     * @param  string $context View or edit context.
275
+     * @return int
276
+     */
277
+    public function get_product_id( $context = 'view' ) {
278
+        return (int) $this->get_prop( 'product_id', $context );
279
+    }
280
+
281
+    /**
282
+     * Get the subscription product.
283
+     *
284
+     * @since 1.0.19
285
+     * @param  string $context View or edit context.
286
+     * @return WPInv_Item
287
+     */
288
+    public function get_product( $context = 'view' ) {
289
+        return new WPInv_Item( $this->get_product_id( $context ) );
290
+    }
291
+
292
+    /**
293
+     * Get parent invoice's gateway.
294
+     *
295
+     * Here for backwards compatibility.
296
+     *
297
+     * @since 1.0.19
298
+     * @param  string $context View or edit context.
299
+     * @return string
300
+     */
301
+    public function get_gateway( $context = 'view' ) {
302
+        return $this->get_parent_invoice( $context )->get_gateway();
303
+    }
304
+
305
+    /**
306
+     * Get the period of a renewal.
307
+     *
308
+     * @since 1.0.19
309
+     * @param  string $context View or edit context.
310
+     * @return string
311
+     */
312
+    public function get_period( $context = 'view' ) {
313
+        return $this->get_prop( 'period', $context );
314
+    }
315
+
316
+    /**
317
+     * Get number of periods each renewal is valid for.
318
+     *
319
+     * @since 1.0.19
320
+     * @param  string $context View or edit context.
321
+     * @return int
322
+     */
323
+    public function get_frequency( $context = 'view' ) {
324
+        return (int) $this->get_prop( 'frequency', $context );
325
+    }
326
+
327
+    /**
328
+     * Get the initial amount for the subscription.
329
+     *
330
+     * @since 1.0.19
331
+     * @param  string $context View or edit context.
332
+     * @return float
333
+     */
334
+    public function get_initial_amount( $context = 'view' ) {
335
+        return (float) wpinv_sanitize_amount( $this->get_prop( 'initial_amount', $context ) );
336
+    }
337
+
338
+    /**
339
+     * Get the recurring amount for the subscription.
340
+     *
341
+     * @since 1.0.19
342
+     * @param  string $context View or edit context.
343
+     * @return float
344
+     */
345
+    public function get_recurring_amount( $context = 'view' ) {
346
+        return (float) wpinv_sanitize_amount( $this->get_prop( 'recurring_amount', $context ) );
347
+    }
348
+
349
+    /**
350
+     * Get number of times that this subscription can be renewed.
351
+     *
352
+     * @since 1.0.19
353
+     * @param  string $context View or edit context.
354
+     * @return int
355
+     */
356
+    public function get_bill_times( $context = 'view' ) {
357
+        return (int) $this->get_prop( 'bill_times', $context );
358
+    }
359
+
360
+    /**
361
+     * Get transaction id of this subscription's parent invoice.
362
+     *
363
+     * @since 1.0.19
364
+     * @param  string $context View or edit context.
365
+     * @return string
366
+     */
367
+    public function get_transaction_id( $context = 'view' ) {
368
+        return $this->get_prop( 'transaction_id', $context );
369
+    }
370
+
371
+    /**
372
+     * Get the date that the subscription was created.
373
+     *
374
+     * @since 1.0.19
375
+     * @param  string $context View or edit context.
376
+     * @return string
377
+     */
378
+    public function get_created( $context = 'view' ) {
379
+        return $this->get_prop( 'created', $context );
380
+    }
381
+
382
+    /**
383
+     * Alias for self::get_created().
384
+     *
385
+     * @since 1.0.19
386
+     * @param  string $context View or edit context.
387
+     * @return string
388
+     */
389
+    public function get_date_created( $context = 'view' ) {
390
+        return $this->get_created( $context );
391
+    }
392
+
393
+    /**
394
+     * Retrieves the creation date in a timestamp
395
+     *
396
+     * @since  1.0.0
397
+     * @return int
398
+     */
399
+    public function get_time_created() {
400
+        $created = $this->get_date_created();
401
+        return empty( $created ) ? current_time( 'timestamp' ) : strtotime( $created, current_time( 'timestamp' ) );
402
+    }
403
+
404
+    /**
405
+     * Get GMT date when the subscription was created.
406
+     *
407
+     * @since 1.0.19
408
+     * @param  string $context View or edit context.
409
+     * @return string
410
+     */
411
+    public function get_date_created_gmt( $context = 'view' ) {
412 412
         $date = $this->get_date_created( $context );
413 413
 
414 414
         if ( $date ) {
415 415
             $date = get_gmt_from_date( $date );
416 416
         }
417
-		return $date;
418
-	}
419
-
420
-	/**
421
-	 * Get the date that the subscription will renew.
422
-	 *
423
-	 * @since 1.0.19
424
-	 * @param  string $context View or edit context.
425
-	 * @return string
426
-	 */
427
-	public function get_next_renewal_date( $context = 'view' ) {
428
-		return $this->get_prop( 'expiration', $context );
429
-	}
430
-
431
-	/**
432
-	 * Alias for self::get_next_renewal_date().
433
-	 *
434
-	 * @since 1.0.19
435
-	 * @param  string $context View or edit context.
436
-	 * @return string
437
-	 */
438
-	public function get_expiration( $context = 'view' ) {
439
-		return $this->get_next_renewal_date( $context );
440
-	}
441
-
442
-	/**
443
-	 * Retrieves the expiration date in a timestamp
444
-	 *
445
-	 * @since  1.0.0
446
-	 * @return int
447
-	 */
448
-	public function get_expiration_time() {
449
-		$expiration = $this->get_expiration();
450
-
451
-		if ( empty( $expiration ) || '0000-00-00 00:00:00' == $expiration ) {
452
-			return current_time( 'timestamp' );
453
-		}
454
-
455
-		$expiration = strtotime( $expiration, current_time( 'timestamp' ) );
456
-		return $expiration < current_time( 'timestamp' ) ? current_time( 'timestamp' ) : $expiration;
457
-	}
458
-
459
-	/**
460
-	 * Get GMT date when the subscription will renew.
461
-	 *
462
-	 * @since 1.0.19
463
-	 * @param  string $context View or edit context.
464
-	 * @return string
465
-	 */
466
-	public function get_next_renewal_date_gmt( $context = 'view' ) {
417
+        return $date;
418
+    }
419
+
420
+    /**
421
+     * Get the date that the subscription will renew.
422
+     *
423
+     * @since 1.0.19
424
+     * @param  string $context View or edit context.
425
+     * @return string
426
+     */
427
+    public function get_next_renewal_date( $context = 'view' ) {
428
+        return $this->get_prop( 'expiration', $context );
429
+    }
430
+
431
+    /**
432
+     * Alias for self::get_next_renewal_date().
433
+     *
434
+     * @since 1.0.19
435
+     * @param  string $context View or edit context.
436
+     * @return string
437
+     */
438
+    public function get_expiration( $context = 'view' ) {
439
+        return $this->get_next_renewal_date( $context );
440
+    }
441
+
442
+    /**
443
+     * Retrieves the expiration date in a timestamp
444
+     *
445
+     * @since  1.0.0
446
+     * @return int
447
+     */
448
+    public function get_expiration_time() {
449
+        $expiration = $this->get_expiration();
450
+
451
+        if ( empty( $expiration ) || '0000-00-00 00:00:00' == $expiration ) {
452
+            return current_time( 'timestamp' );
453
+        }
454
+
455
+        $expiration = strtotime( $expiration, current_time( 'timestamp' ) );
456
+        return $expiration < current_time( 'timestamp' ) ? current_time( 'timestamp' ) : $expiration;
457
+    }
458
+
459
+    /**
460
+     * Get GMT date when the subscription will renew.
461
+     *
462
+     * @since 1.0.19
463
+     * @param  string $context View or edit context.
464
+     * @return string
465
+     */
466
+    public function get_next_renewal_date_gmt( $context = 'view' ) {
467 467
         $date = $this->get_next_renewal_date( $context );
468 468
 
469 469
         if ( $date ) {
470 470
             $date = get_gmt_from_date( $date );
471 471
         }
472
-		return $date;
473
-	}
474
-
475
-	/**
476
-	 * Get the subscription's trial period.
477
-	 *
478
-	 * @since 1.0.19
479
-	 * @param  string $context View or edit context.
480
-	 * @return string
481
-	 */
482
-	public function get_trial_period( $context = 'view' ) {
483
-		return $this->get_prop( 'trial_period', $context );
484
-	}
485
-
486
-	/**
487
-	 * Get the subscription's status.
488
-	 *
489
-	 * @since 1.0.19
490
-	 * @param  string $context View or edit context.
491
-	 * @return string
492
-	 */
493
-	public function get_status( $context = 'view' ) {
494
-		return $this->get_prop( 'status', $context );
495
-	}
496
-
497
-	/**
498
-	 * Get the subscription's profile id.
499
-	 *
500
-	 * @since 1.0.19
501
-	 * @param  string $context View or edit context.
502
-	 * @return string
503
-	 */
504
-	public function get_profile_id( $context = 'view' ) {
505
-		return $this->get_prop( 'profile_id', $context );
506
-	}
507
-
508
-	/*
472
+        return $date;
473
+    }
474
+
475
+    /**
476
+     * Get the subscription's trial period.
477
+     *
478
+     * @since 1.0.19
479
+     * @param  string $context View or edit context.
480
+     * @return string
481
+     */
482
+    public function get_trial_period( $context = 'view' ) {
483
+        return $this->get_prop( 'trial_period', $context );
484
+    }
485
+
486
+    /**
487
+     * Get the subscription's status.
488
+     *
489
+     * @since 1.0.19
490
+     * @param  string $context View or edit context.
491
+     * @return string
492
+     */
493
+    public function get_status( $context = 'view' ) {
494
+        return $this->get_prop( 'status', $context );
495
+    }
496
+
497
+    /**
498
+     * Get the subscription's profile id.
499
+     *
500
+     * @since 1.0.19
501
+     * @param  string $context View or edit context.
502
+     * @return string
503
+     */
504
+    public function get_profile_id( $context = 'view' ) {
505
+        return $this->get_prop( 'profile_id', $context );
506
+    }
507
+
508
+    /*
509 509
 	|--------------------------------------------------------------------------
510 510
 	| Setters
511 511
 	|--------------------------------------------------------------------------
512 512
 	*/
513 513
 
514
-	/**
515
-	 * Set customer id.
516
-	 *
517
-	 * @since 1.0.19
518
-	 * @param  int $value The customer's id.
519
-	 */
520
-	public function set_customer_id( $value ) {
521
-		$this->set_prop( 'customer_id', (int) $value );
522
-	}
523
-
524
-	/**
525
-	 * Set parent invoice id.
526
-	 *
527
-	 * @since 1.0.19
528
-	 * @param  int $value The parent invoice id.
529
-	 */
530
-	public function set_parent_invoice_id( $value ) {
531
-		$this->set_prop( 'parent_payment_id', (int) $value );
532
-	}
533
-
534
-	/**
535
-	 * Alias for self::set_parent_invoice_id().
536
-	 *
537
-	 * @since 1.0.19
538
-	 * @param  int $value The parent invoice id.
539
-	 */
540
-    public function set_parent_payment_id( $value ) {
541
-        $this->set_parent_invoice_id( $value );
542
-	}
514
+    /**
515
+     * Set customer id.
516
+     *
517
+     * @since 1.0.19
518
+     * @param  int $value The customer's id.
519
+     */
520
+    public function set_customer_id( $value ) {
521
+        $this->set_prop( 'customer_id', (int) $value );
522
+    }
523
+
524
+    /**
525
+     * Set parent invoice id.
526
+     *
527
+     * @since 1.0.19
528
+     * @param  int $value The parent invoice id.
529
+     */
530
+    public function set_parent_invoice_id( $value ) {
531
+        $this->set_prop( 'parent_payment_id', (int) $value );
532
+    }
533
+
534
+    /**
535
+     * Alias for self::set_parent_invoice_id().
536
+     *
537
+     * @since 1.0.19
538
+     * @param  int $value The parent invoice id.
539
+     */
540
+    public function set_parent_payment_id( $value ) {
541
+        $this->set_parent_invoice_id( $value );
542
+    }
543
+
544
+    /**
545
+     * Alias for self::set_parent_invoice_id().
546
+     *
547
+     * @since 1.0.19
548
+     * @param  int $value The parent invoice id.
549
+     */
550
+    public function set_original_payment_id( $value ) {
551
+        $this->set_parent_invoice_id( $value );
552
+    }
553
+
554
+    /**
555
+     * Set subscription's product id.
556
+     *
557
+     * @since 1.0.19
558
+     * @param  int $value The subscription product id.
559
+     */
560
+    public function set_product_id( $value ) {
561
+        $this->set_prop( 'product_id', (int) $value );
562
+    }
563
+
564
+    /**
565
+     * Set the period of a renewal.
566
+     *
567
+     * @since 1.0.19
568
+     * @param  string $value The renewal period.
569
+     */
570
+    public function set_period( $value ) {
571
+        $this->set_prop( 'period', $value );
572
+    }
573
+
574
+    /**
575
+     * Set number of periods each renewal is valid for.
576
+     *
577
+     * @since 1.0.19
578
+     * @param  int $value The subscription frequency.
579
+     */
580
+    public function set_frequency( $value ) {
581
+        $value = empty( $value ) ? 1 : (int) $value;
582
+        $this->set_prop( 'frequency', absint( $value ) );
583
+    }
584
+
585
+    /**
586
+     * Set the initial amount for the subscription.
587
+     *
588
+     * @since 1.0.19
589
+     * @param  float $value The initial subcription amount.
590
+     */
591
+    public function set_initial_amount( $value ) {
592
+        $this->set_prop( 'initial_amount', wpinv_sanitize_amount( $value ) );
593
+    }
594
+
595
+    /**
596
+     * Set the recurring amount for the subscription.
597
+     *
598
+     * @since 1.0.19
599
+     * @param  float $value The recurring subcription amount.
600
+     */
601
+    public function set_recurring_amount( $value ) {
602
+        $this->set_prop( 'recurring_amount', wpinv_sanitize_amount( $value ) );
603
+    }
604
+
605
+    /**
606
+     * Set number of times that this subscription can be renewed.
607
+     *
608
+     * @since 1.0.19
609
+     * @param  int $value Bill times.
610
+     */
611
+    public function set_bill_times( $value ) {
612
+        $this->set_prop( 'bill_times', (int) $value );
613
+    }
614
+
615
+    /**
616
+     * Get transaction id of this subscription's parent invoice.
617
+     *
618
+     * @since 1.0.19
619
+     * @param string $value Bill times.
620
+     */
621
+    public function set_transaction_id( $value ) {
622
+        $this->set_prop( 'transaction_id', sanitize_text_field( $value ) );
623
+    }
543 624
 
544
-	/**
545
-     * Alias for self::set_parent_invoice_id().
625
+    /**
626
+     * Set date when this subscription started.
546 627
      *
547 628
      * @since 1.0.19
548
-	 * @param  int $value The parent invoice id.
629
+     * @param string $value strtotime compliant date.
549 630
      */
550
-    public function set_original_payment_id( $value ) {
551
-        $this->set_parent_invoice_id( $value );
552
-	}
553
-
554
-	/**
555
-	 * Set subscription's product id.
556
-	 *
557
-	 * @since 1.0.19
558
-	 * @param  int $value The subscription product id.
559
-	 */
560
-	public function set_product_id( $value ) {
561
-		$this->set_prop( 'product_id', (int) $value );
562
-	}
563
-
564
-	/**
565
-	 * Set the period of a renewal.
566
-	 *
567
-	 * @since 1.0.19
568
-	 * @param  string $value The renewal period.
569
-	 */
570
-	public function set_period( $value ) {
571
-		$this->set_prop( 'period', $value );
572
-	}
573
-
574
-	/**
575
-	 * Set number of periods each renewal is valid for.
576
-	 *
577
-	 * @since 1.0.19
578
-	 * @param  int $value The subscription frequency.
579
-	 */
580
-	public function set_frequency( $value ) {
581
-		$value = empty( $value ) ? 1 : (int) $value;
582
-		$this->set_prop( 'frequency', absint( $value ) );
583
-	}
584
-
585
-	/**
586
-	 * Set the initial amount for the subscription.
587
-	 *
588
-	 * @since 1.0.19
589
-	 * @param  float $value The initial subcription amount.
590
-	 */
591
-	public function set_initial_amount( $value ) {
592
-		$this->set_prop( 'initial_amount', wpinv_sanitize_amount( $value ) );
593
-	}
594
-
595
-	/**
596
-	 * Set the recurring amount for the subscription.
597
-	 *
598
-	 * @since 1.0.19
599
-	 * @param  float $value The recurring subcription amount.
600
-	 */
601
-	public function set_recurring_amount( $value ) {
602
-		$this->set_prop( 'recurring_amount', wpinv_sanitize_amount( $value ) );
603
-	}
604
-
605
-	/**
606
-	 * Set number of times that this subscription can be renewed.
607
-	 *
608
-	 * @since 1.0.19
609
-	 * @param  int $value Bill times.
610
-	 */
611
-	public function set_bill_times( $value ) {
612
-		$this->set_prop( 'bill_times', (int) $value );
613
-	}
614
-
615
-	/**
616
-	 * Get transaction id of this subscription's parent invoice.
617
-	 *
618
-	 * @since 1.0.19
619
-	 * @param string $value Bill times.
620
-	 */
621
-	public function set_transaction_id( $value ) {
622
-		$this->set_prop( 'transaction_id', sanitize_text_field( $value ) );
623
-	}
624
-
625
-	/**
626
-	 * Set date when this subscription started.
627
-	 *
628
-	 * @since 1.0.19
629
-	 * @param string $value strtotime compliant date.
630
-	 */
631
-	public function set_created( $value ) {
631
+    public function set_created( $value ) {
632 632
         $date = strtotime( $value );
633 633
 
634 634
         if ( $date && $value !== '0000-00-00 00:00:00' ) {
@@ -636,93 +636,93 @@  discard block
 block discarded – undo
636 636
             return;
637 637
         }
638 638
 
639
-		$this->set_prop( 'created', '' );
639
+        $this->set_prop( 'created', '' );
640 640
 
641
-	}
641
+    }
642 642
 
643
-	/**
644
-	 * Alias for self::set_created().
645
-	 *
646
-	 * @since 1.0.19
647
-	 * @param string $value strtotime compliant date.
648
-	 */
649
-	public function set_date_created( $value ) {
650
-		$this->set_created( $value );
643
+    /**
644
+     * Alias for self::set_created().
645
+     *
646
+     * @since 1.0.19
647
+     * @param string $value strtotime compliant date.
648
+     */
649
+    public function set_date_created( $value ) {
650
+        $this->set_created( $value );
651 651
     }
652 652
 
653
-	/**
654
-	 * Set the date that the subscription will renew.
655
-	 *
656
-	 * @since 1.0.19
657
-	 * @param string $value strtotime compliant date.
658
-	 */
659
-	public function set_next_renewal_date( $value ) {
660
-		$date = strtotime( $value );
653
+    /**
654
+     * Set the date that the subscription will renew.
655
+     *
656
+     * @since 1.0.19
657
+     * @param string $value strtotime compliant date.
658
+     */
659
+    public function set_next_renewal_date( $value ) {
660
+        $date = strtotime( $value );
661 661
 
662 662
         if ( $date && $value !== '0000-00-00 00:00:00' ) {
663 663
             $this->set_prop( 'expiration', gmdate( 'Y-m-d H:i:s', $date ) );
664 664
             return;
665
-		}
666
-
667
-		$this->set_prop( 'expiration', '' );
668
-
669
-	}
670
-
671
-	/**
672
-	 * Alias for self::set_next_renewal_date().
673
-	 *
674
-	 * @since 1.0.19
675
-	 * @param string $value strtotime compliant date.
676
-	 */
677
-	public function set_expiration( $value ) {
678
-		$this->set_next_renewal_date( $value );
679
-    }
680
-
681
-	/**
682
-	 * Set the subscription's trial period.
683
-	 *
684
-	 * @since 1.0.19
685
-	 * @param string $value trial period e.g 1 year.
686
-	 */
687
-	public function set_trial_period( $value ) {
688
-		$this->set_prop( 'trial_period', $value );
689
-	}
690
-
691
-	/**
692
-	 * Set the subscription's status.
693
-	 *
694
-	 * @since 1.0.19
695
-	 * @param string $new_status    New subscription status.
696
-	 */
697
-	public function set_status( $new_status ) {
698
-
699
-		// Abort if this is not a valid status;
700
-		if ( ! array_key_exists( $new_status, getpaid_get_subscription_statuses() ) ) {
701
-			return;
702
-		}
703
-
704
-		$old_status = ! empty( $this->status_transition['from'] ) ? $this->status_transition['from'] : $this->get_status();
705
-		if ( true === $this->object_read && $old_status !== $new_status ) {
706
-			$this->status_transition = array(
707
-				'from' => $old_status,
708
-				'to'   => $new_status,
709
-			);
710
-		}
711
-
712
-		$this->set_prop( 'status', $new_status );
713
-	}
714
-
715
-	/**
716
-	 * Set the subscription's (remote) profile id.
717
-	 *
718
-	 * @since 1.0.19
719
-	 * @param  string $value the remote profile id.
720
-	 */
721
-	public function set_profile_id( $value ) {
722
-		$this->set_prop( 'profile_id', sanitize_text_field( $value ) );
723
-	}
724
-
725
-	/*
665
+        }
666
+
667
+        $this->set_prop( 'expiration', '' );
668
+
669
+    }
670
+
671
+    /**
672
+     * Alias for self::set_next_renewal_date().
673
+     *
674
+     * @since 1.0.19
675
+     * @param string $value strtotime compliant date.
676
+     */
677
+    public function set_expiration( $value ) {
678
+        $this->set_next_renewal_date( $value );
679
+    }
680
+
681
+    /**
682
+     * Set the subscription's trial period.
683
+     *
684
+     * @since 1.0.19
685
+     * @param string $value trial period e.g 1 year.
686
+     */
687
+    public function set_trial_period( $value ) {
688
+        $this->set_prop( 'trial_period', $value );
689
+    }
690
+
691
+    /**
692
+     * Set the subscription's status.
693
+     *
694
+     * @since 1.0.19
695
+     * @param string $new_status    New subscription status.
696
+     */
697
+    public function set_status( $new_status ) {
698
+
699
+        // Abort if this is not a valid status;
700
+        if ( ! array_key_exists( $new_status, getpaid_get_subscription_statuses() ) ) {
701
+            return;
702
+        }
703
+
704
+        $old_status = ! empty( $this->status_transition['from'] ) ? $this->status_transition['from'] : $this->get_status();
705
+        if ( true === $this->object_read && $old_status !== $new_status ) {
706
+            $this->status_transition = array(
707
+                'from' => $old_status,
708
+                'to'   => $new_status,
709
+            );
710
+        }
711
+
712
+        $this->set_prop( 'status', $new_status );
713
+    }
714
+
715
+    /**
716
+     * Set the subscription's (remote) profile id.
717
+     *
718
+     * @since 1.0.19
719
+     * @param  string $value the remote profile id.
720
+     */
721
+    public function set_profile_id( $value ) {
722
+        $this->set_prop( 'profile_id', sanitize_text_field( $value ) );
723
+    }
724
+
725
+    /*
726 726
 	|--------------------------------------------------------------------------
727 727
 	| Boolean methods
728 728
 	|--------------------------------------------------------------------------
@@ -731,55 +731,55 @@  discard block
 block discarded – undo
731 731
 	|
732 732
 	*/
733 733
 
734
-	/**
734
+    /**
735 735
      * Checks if the subscription has a given status.
736
-	 *
737
-	 * @param string|array String or array of strings to check for.
738
-	 * @return bool
736
+     *
737
+     * @param string|array String or array of strings to check for.
738
+     * @return bool
739 739
      */
740 740
     public function has_status( $status ) {
741 741
         return in_array( $this->get_status(), wpinv_clean( wpinv_parse_list( $status ) ) );
742
-	}
742
+    }
743 743
 
744
-	/**
744
+    /**
745 745
      * Checks if the subscription has a trial period.
746
-	 *
747
-	 * @return bool
746
+     *
747
+     * @return bool
748 748
      */
749 749
     public function has_trial_period() {
750
-		$period = $this->get_trial_period();
750
+        $period = $this->get_trial_period();
751 751
         return ! empty( $period );
752
-	}
753
-
754
-	/**
755
-	 * Is the subscription active?
756
-	 *
757
-	 * @return bool
758
-	 */
759
-	public function is_active() {
760
-		return $this->has_status( 'active trialling' ) && ! $this->is_expired();
761
-	}
762
-
763
-	/**
764
-	 * Is the subscription expired?
765
-	 *
766
-	 * @return bool
767
-	 */
768
-	public function is_expired() {
769
-		return $this->has_status( 'expired' ) || ( $this->has_status( 'active cancelled trialling' ) && $this->get_expiration_time() < current_time( 'timestamp' ) );
770
-	}
771
-
772
-	/**
773
-	 * Is this the last renewals?
774
-	 *
775
-	 * @return bool
776
-	 */
777
-	public function is_last_renewal() {
778
-		$max_bills = $this->get_bill_times();
779
-		return ! empty( $max_bills ) && $max_bills <= $this->get_times_billed();
780
-	}
781
-
782
-	/*
752
+    }
753
+
754
+    /**
755
+     * Is the subscription active?
756
+     *
757
+     * @return bool
758
+     */
759
+    public function is_active() {
760
+        return $this->has_status( 'active trialling' ) && ! $this->is_expired();
761
+    }
762
+
763
+    /**
764
+     * Is the subscription expired?
765
+     *
766
+     * @return bool
767
+     */
768
+    public function is_expired() {
769
+        return $this->has_status( 'expired' ) || ( $this->has_status( 'active cancelled trialling' ) && $this->get_expiration_time() < current_time( 'timestamp' ) );
770
+    }
771
+
772
+    /**
773
+     * Is this the last renewals?
774
+     *
775
+     * @return bool
776
+     */
777
+    public function is_last_renewal() {
778
+        $max_bills = $this->get_bill_times();
779
+        return ! empty( $max_bills ) && $max_bills <= $this->get_times_billed();
780
+    }
781
+
782
+    /*
783 783
 	|--------------------------------------------------------------------------
784 784
 	| Additional methods
785 785
 	|--------------------------------------------------------------------------
@@ -788,27 +788,27 @@  discard block
 block discarded – undo
788 788
 	|
789 789
 	*/
790 790
 
791
-	/**
792
-	 * Backwards compatibilty.
793
-	 */
794
-	public function create( $data = array() ) {
791
+    /**
792
+     * Backwards compatibilty.
793
+     */
794
+    public function create( $data = array() ) {
795 795
 
796
-		// Set the properties.
797
-		if ( is_array( $data ) ) {
798
-			$this->set_props( $data );
799
-		}
796
+        // Set the properties.
797
+        if ( is_array( $data ) ) {
798
+            $this->set_props( $data );
799
+        }
800 800
 
801
-		// Save the item.
802
-		return $this->save();
801
+        // Save the item.
802
+        return $this->save();
803 803
 
804
-	}
804
+    }
805 805
 
806
-	/**
807
-	 * Backwards compatibilty.
808
-	 */
809
-	public function update( $args = array() ) {
810
-		return $this->create( $args );
811
-	}
806
+    /**
807
+     * Backwards compatibilty.
808
+     */
809
+    public function update( $args = array() ) {
810
+        return $this->create( $args );
811
+    }
812 812
 
813 813
     /**
814 814
      * Retrieve renewal payments for a subscription
@@ -818,22 +818,22 @@  discard block
 block discarded – undo
818 818
      */
819 819
     public function get_child_payments( $hide_pending = true ) {
820 820
 
821
-		$statuses = array( 'publish', 'wpi-processing', 'wpi-renewal' );
821
+        $statuses = array( 'publish', 'wpi-processing', 'wpi-renewal' );
822 822
 
823
-		if ( ! $hide_pending ) {
824
-			$statuses = array_keys( wpinv_get_invoice_statuses() );
825
-		}
823
+        if ( ! $hide_pending ) {
824
+            $statuses = array_keys( wpinv_get_invoice_statuses() );
825
+        }
826 826
 
827 827
         return get_posts(
828
-			array(
829
-            	'post_parent' => $this->get_parent_payment_id(),
830
-            	'numberposts' => -1,
831
-            	'post_status' => $statuses,
832
-            	'orderby'     => 'ID',
833
-            	'order'       => 'ASC',
834
-            	'post_type'   => 'wpi_invoice',
835
-			)
836
-		);
828
+            array(
829
+                'post_parent' => $this->get_parent_payment_id(),
830
+                'numberposts' => -1,
831
+                'post_status' => $statuses,
832
+                'orderby'     => 'ID',
833
+                'order'       => 'ASC',
834
+                'post_type'   => 'wpi_invoice',
835
+            )
836
+        );
837 837
     }
838 838
 
839 839
     /**
@@ -843,7 +843,7 @@  discard block
 block discarded – undo
843 843
      * @return int
844 844
      */
845 845
     public function get_total_payments() {
846
-		return getpaid_count_subscription_invoices( $this->get_parent_invoice_id(), $this->get_id() );
846
+        return getpaid_count_subscription_invoices( $this->get_parent_invoice_id(), $this->get_id() );
847 847
     }
848 848
 
849 849
     /**
@@ -867,202 +867,202 @@  discard block
 block discarded – undo
867 867
      *
868 868
      * @since  2.4
869 869
      * @param  array $args Array of values for the payment, including amount and transaction ID
870
-	 * @param  WPInv_Invoice $invoice If adding an existing invoice.
870
+     * @param  WPInv_Invoice $invoice If adding an existing invoice.
871 871
      * @return bool
872 872
      */
873 873
     public function add_payment( $args = array(), $invoice = false ) {
874 874
 
875
-		// Process each payment once.
875
+        // Process each payment once.
876 876
         if ( ! empty( $args['transaction_id'] ) && $this->payment_exists( $args['transaction_id'] ) ) {
877 877
             return false;
878 878
         }
879 879
 
880
-		// Are we creating a new invoice?
881
-		if ( empty( $invoice ) ) {
882
-			$invoice = $this->create_payment( false );
880
+        // Are we creating a new invoice?
881
+        if ( empty( $invoice ) ) {
882
+            $invoice = $this->create_payment( false );
883 883
 
884
-			if ( empty( $invoice ) ) {
885
-				return false;
886
-			}
887
-		}
884
+            if ( empty( $invoice ) ) {
885
+                return false;
886
+            }
887
+        }
888 888
 
889
-		// Maybe set a transaction id.
890
-		if ( ! empty( $args['transaction_id'] ) ) {
891
-			$invoice->set_transaction_id( $args['transaction_id'] );
892
-		}
889
+        // Maybe set a transaction id.
890
+        if ( ! empty( $args['transaction_id'] ) ) {
891
+            $invoice->set_transaction_id( $args['transaction_id'] );
892
+        }
893 893
 
894
-		// Set the completed date.
895
-		$invoice->set_completed_date( current_time( 'mysql' ) );
894
+        // Set the completed date.
895
+        $invoice->set_completed_date( current_time( 'mysql' ) );
896 896
 
897
-		// And the gateway.
898
-		if ( ! empty( $args['gateway'] ) ) {
899
-			$invoice->set_gateway( $args['gateway'] );
900
-		}
897
+        // And the gateway.
898
+        if ( ! empty( $args['gateway'] ) ) {
899
+            $invoice->set_gateway( $args['gateway'] );
900
+        }
901 901
 
902
-		$invoice->set_status( 'wpi-renewal' );
903
-		$invoice->save();
902
+        $invoice->set_status( 'wpi-renewal' );
903
+        $invoice->save();
904 904
 
905
-		if ( ! $invoice->exists() ) {
906
-			return false;
907
-		}
905
+        if ( ! $invoice->exists() ) {
906
+            return false;
907
+        }
908 908
 
909
-		return $this->after_add_payment( $invoice );
910
-	}
909
+        return $this->after_add_payment( $invoice );
910
+    }
911 911
 
912 912
     public function after_add_payment( $invoice ) {
913 913
 
914
-		do_action( 'getpaid_after_create_subscription_renewal_invoice', $invoice, $this );
915
-		do_action( 'wpinv_recurring_add_subscription_payment', $invoice, $this );
914
+        do_action( 'getpaid_after_create_subscription_renewal_invoice', $invoice, $this );
915
+        do_action( 'wpinv_recurring_add_subscription_payment', $invoice, $this );
916 916
         do_action( 'wpinv_recurring_record_payment', $invoice->get_id(), $this->get_parent_invoice_id(), $invoice->get_recurring_total(), $invoice->get_transaction_id() );
917 917
 
918 918
         update_post_meta( $invoice->get_id(), '_wpinv_subscription_id', $this->id );
919 919
 
920 920
         return $invoice->get_id();
921
-	}
921
+    }
922 922
 
923
-	/**
923
+    /**
924 924
      * Creates a new invoice and returns it.
925 925
      *
926 926
      * @since  1.0.19
927
-	 * @param bool $save Whether we should save the invoice.
927
+     * @param bool $save Whether we should save the invoice.
928 928
      * @return WPInv_Invoice|bool
929 929
      */
930 930
     public function create_payment( $save = true ) {
931 931
 
932
-		$parent_invoice = $this->get_parent_payment();
933
-
934
-		if ( ! $parent_invoice->exists() ) {
935
-			return false;
936
-		}
937
-
938
-		// Duplicate the parent invoice.
939
-		$invoice = getpaid_duplicate_invoice( $parent_invoice );
940
-		$invoice->set_parent_id( $parent_invoice->get_id() );
941
-		$invoice->set_subscription_id( $this->get_id() );
942
-		$invoice->set_remote_subscription_id( $this->get_profile_id() );
943
-
944
-		// Set invoice items.
945
-		$subscription_group = getpaid_get_invoice_subscription_group( $parent_invoice->get_id(), $this->get_id() );
946
-		$allowed_items      = empty( $subscription_group ) ? array( $this->get_product_id() ) : array_keys( $subscription_group['items'] );
947
-		$invoice_items      = array();
948
-
949
-		foreach ( $invoice->get_items() as $item ) {
950
-			if ( in_array( $item->get_id(), $allowed_items ) ) {
951
-				$invoice_items[] = $item;
952
-			}
953
-		}
954
-
955
-		$invoice->set_items( $invoice_items );
956
-
957
-		if ( ! empty( $subscription_group['fees'] ) ) {
958
-			$invoice->set_fees( $subscription_group['fees'] );
959
-		}
960
-
961
-		// Maybe recalculate discount (Pre-GetPaid Fix).
962
-		$discount = new WPInv_Discount( $invoice->get_discount_code() );
963
-
964
-		if ( $discount->exists() && $discount->is_recurring() ) {
965
-			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
966
-		}  else {
967
-			// Unset discount code.
968
-			$invoice->set_discount_code( '' );
969
-
970
-			$invoice->remove_discount( 'discount_code' );
971
-		}
972
-
973
-		$invoice->recalculate_total();
974
-		$invoice->set_status( 'wpi-pending' );
975
-
976
-		if ( ! $save ) {
977
-			return $invoice;
978
-		}
979
-
980
-		$invoice->save();
981
-
982
-		return $invoice->exists() ? $invoice : false;
983
-    }
984
-
985
-	/**
986
-	 * Renews or completes a subscription
987
-	 *
988
-	 * @since  1.0.0
989
-	 * @return int The subscription's id
990
-	 */
991
-	public function renew( $calculate_from = null, $_new_expiration = null ) {
992
-		// Complete subscription if applicable
993
-		if ( $this->is_last_renewal() ) {
994
-			return $this->complete();
995
-		}
996
-
997
-		if ( ! empty( $_new_expiration ) ) {
998
-			$new_expiration = $_new_expiration;
999
-		} else {
1000
-			// Calculate new expiration
1001
-			$frequency      = $this->get_frequency();
1002
-			$period         = $this->get_period();
1003
-			$calculate_from = empty( $calculate_from ) ? $this->get_expiration_time() : $calculate_from;
1004
-			$new_expiration = strtotime( "+ $frequency $period", $calculate_from );
1005
-			$new_expiration = date( 'Y-m-d H:i:s', $new_expiration );
1006
-		}
1007
-
1008
-		$this->set_expiration( $new_expiration );
1009
-		$this->set_status( 'active' );
1010
-		$this->save();
1011
-
1012
-		do_action( 'getpaid_subscription_renewed', $this );
1013
-
1014
-		return $this->get_id();
1015
-	}
1016
-
1017
-	/**
1018
-	 * Marks a subscription as completed
1019
-	 *
1020
-	 * Subscription is completed when the number of payments matches the billing_times field
1021
-	 *
1022
-	 * @since  1.0.0
1023
-	 * @return int|bool Subscription id or false if the subscription is cancelled.
1024
-	 */
1025
-	public function complete() {
1026
-
1027
-		// Only mark a subscription as complete if it's not already cancelled.
1028
-		if ( $this->has_status( 'cancelled' ) ) {
1029
-			return false;
1030
-		}
1031
-
1032
-		$this->set_status( 'completed' );
1033
-		return $this->save();
1034
-
1035
-	}
1036
-
1037
-	/**
1038
-	 * Marks a subscription as expired
1039
-	 *
1040
-	 * @since  1.0.0
1041
-	 * @param  bool $check_expiration
1042
-	 * @return int|bool Subscription id or false if $check_expiration is true and expiration date is in the future.
1043
-	 */
1044
-	public function expire( $check_expiration = false ) {
1045
-
1046
-		if ( $check_expiration && $this->get_expiration_time() > current_time( 'timestamp' ) ) {
1047
-			// Do not mark as expired since real expiration date is in the future
1048
-			return false;
1049
-		}
1050
-
1051
-		$this->set_status( 'expired' );
1052
-		return $this->save();
1053
-
1054
-	}
1055
-
1056
-	/**
1057
-	 * Marks a subscription as failing
1058
-	 *
1059
-	 * @since  2.4.2
1060
-	 * @return int Subscription id.
1061
-	 */
1062
-	public function failing() {
1063
-		$this->set_status( 'failing' );
1064
-		return $this->save();
1065
-	}
932
+        $parent_invoice = $this->get_parent_payment();
933
+
934
+        if ( ! $parent_invoice->exists() ) {
935
+            return false;
936
+        }
937
+
938
+        // Duplicate the parent invoice.
939
+        $invoice = getpaid_duplicate_invoice( $parent_invoice );
940
+        $invoice->set_parent_id( $parent_invoice->get_id() );
941
+        $invoice->set_subscription_id( $this->get_id() );
942
+        $invoice->set_remote_subscription_id( $this->get_profile_id() );
943
+
944
+        // Set invoice items.
945
+        $subscription_group = getpaid_get_invoice_subscription_group( $parent_invoice->get_id(), $this->get_id() );
946
+        $allowed_items      = empty( $subscription_group ) ? array( $this->get_product_id() ) : array_keys( $subscription_group['items'] );
947
+        $invoice_items      = array();
948
+
949
+        foreach ( $invoice->get_items() as $item ) {
950
+            if ( in_array( $item->get_id(), $allowed_items ) ) {
951
+                $invoice_items[] = $item;
952
+            }
953
+        }
954
+
955
+        $invoice->set_items( $invoice_items );
956
+
957
+        if ( ! empty( $subscription_group['fees'] ) ) {
958
+            $invoice->set_fees( $subscription_group['fees'] );
959
+        }
960
+
961
+        // Maybe recalculate discount (Pre-GetPaid Fix).
962
+        $discount = new WPInv_Discount( $invoice->get_discount_code() );
963
+
964
+        if ( $discount->exists() && $discount->is_recurring() ) {
965
+            $invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
966
+        }  else {
967
+            // Unset discount code.
968
+            $invoice->set_discount_code( '' );
969
+
970
+            $invoice->remove_discount( 'discount_code' );
971
+        }
972
+
973
+        $invoice->recalculate_total();
974
+        $invoice->set_status( 'wpi-pending' );
975
+
976
+        if ( ! $save ) {
977
+            return $invoice;
978
+        }
979
+
980
+        $invoice->save();
981
+
982
+        return $invoice->exists() ? $invoice : false;
983
+    }
984
+
985
+    /**
986
+     * Renews or completes a subscription
987
+     *
988
+     * @since  1.0.0
989
+     * @return int The subscription's id
990
+     */
991
+    public function renew( $calculate_from = null, $_new_expiration = null ) {
992
+        // Complete subscription if applicable
993
+        if ( $this->is_last_renewal() ) {
994
+            return $this->complete();
995
+        }
996
+
997
+        if ( ! empty( $_new_expiration ) ) {
998
+            $new_expiration = $_new_expiration;
999
+        } else {
1000
+            // Calculate new expiration
1001
+            $frequency      = $this->get_frequency();
1002
+            $period         = $this->get_period();
1003
+            $calculate_from = empty( $calculate_from ) ? $this->get_expiration_time() : $calculate_from;
1004
+            $new_expiration = strtotime( "+ $frequency $period", $calculate_from );
1005
+            $new_expiration = date( 'Y-m-d H:i:s', $new_expiration );
1006
+        }
1007
+
1008
+        $this->set_expiration( $new_expiration );
1009
+        $this->set_status( 'active' );
1010
+        $this->save();
1011
+
1012
+        do_action( 'getpaid_subscription_renewed', $this );
1013
+
1014
+        return $this->get_id();
1015
+    }
1016
+
1017
+    /**
1018
+     * Marks a subscription as completed
1019
+     *
1020
+     * Subscription is completed when the number of payments matches the billing_times field
1021
+     *
1022
+     * @since  1.0.0
1023
+     * @return int|bool Subscription id or false if the subscription is cancelled.
1024
+     */
1025
+    public function complete() {
1026
+
1027
+        // Only mark a subscription as complete if it's not already cancelled.
1028
+        if ( $this->has_status( 'cancelled' ) ) {
1029
+            return false;
1030
+        }
1031
+
1032
+        $this->set_status( 'completed' );
1033
+        return $this->save();
1034
+
1035
+    }
1036
+
1037
+    /**
1038
+     * Marks a subscription as expired
1039
+     *
1040
+     * @since  1.0.0
1041
+     * @param  bool $check_expiration
1042
+     * @return int|bool Subscription id or false if $check_expiration is true and expiration date is in the future.
1043
+     */
1044
+    public function expire( $check_expiration = false ) {
1045
+
1046
+        if ( $check_expiration && $this->get_expiration_time() > current_time( 'timestamp' ) ) {
1047
+            // Do not mark as expired since real expiration date is in the future
1048
+            return false;
1049
+        }
1050
+
1051
+        $this->set_status( 'expired' );
1052
+        return $this->save();
1053
+
1054
+    }
1055
+
1056
+    /**
1057
+     * Marks a subscription as failing
1058
+     *
1059
+     * @since  2.4.2
1060
+     * @return int Subscription id.
1061
+     */
1062
+    public function failing() {
1063
+        $this->set_status( 'failing' );
1064
+        return $this->save();
1065
+    }
1066 1066
 
1067 1067
     /**
1068 1068
      * Marks a subscription as cancelled
@@ -1071,19 +1071,19 @@  discard block
 block discarded – undo
1071 1071
      * @return int Subscription id.
1072 1072
      */
1073 1073
     public function cancel() {
1074
-		$this->set_status( 'cancelled' );
1075
-		return $this->save();
1074
+        $this->set_status( 'cancelled' );
1075
+        return $this->save();
1076 1076
     }
1077 1077
 
1078
-	/**
1079
-	 * Determines if a subscription can be cancelled both locally and with a payment processor.
1080
-	 *
1081
-	 * @since  1.0.0
1082
-	 * @return bool
1083
-	 */
1084
-	public function can_cancel() {
1085
-		return apply_filters( 'wpinv_subscription_can_cancel', $this->has_status( $this->get_cancellable_statuses() ), $this );
1086
-	}
1078
+    /**
1079
+     * Determines if a subscription can be cancelled both locally and with a payment processor.
1080
+     *
1081
+     * @since  1.0.0
1082
+     * @return bool
1083
+     */
1084
+    public function can_cancel() {
1085
+        return apply_filters( 'wpinv_subscription_can_cancel', $this->has_status( $this->get_cancellable_statuses() ), $this );
1086
+    }
1087 1087
 
1088 1088
     /**
1089 1089
      * Returns an array of subscription statuses that can be cancelled
@@ -1096,109 +1096,109 @@  discard block
 block discarded – undo
1096 1096
         return apply_filters( 'wpinv_recurring_cancellable_statuses', array( 'active', 'trialling', 'failing' ) );
1097 1097
     }
1098 1098
 
1099
-	/**
1100
-	 * Retrieves the URL to cancel subscription
1101
-	 *
1102
-	 * @since  1.0.0
1103
-	 * @return string
1104
-	 */
1105
-	public function get_cancel_url() {
1106
-		$url = getpaid_get_authenticated_action_url( 'subscription_cancel', $this->get_view_url() );
1107
-		return apply_filters( 'wpinv_subscription_cancel_url', $url, $this );
1108
-	}
1109
-
1110
-	/**
1111
-	 * Retrieves the URL to view a subscription
1112
-	 *
1113
-	 * @since  1.0.19
1114
-	 * @return string
1115
-	 */
1116
-	public function get_view_url() {
1117
-
1118
-		$url = getpaid_get_tab_url( 'gp-subscriptions', get_permalink( (int) wpinv_get_option( 'invoice_subscription_page' ) ) );
1119
-		$url = add_query_arg( 'subscription', $this->get_id(), $url );
1120
-
1121
-		return apply_filters( 'getpaid_get_subscription_view_url', $url, $this );
1122
-	}
1123
-
1124
-	/**
1125
-	 * Determines if subscription can be manually renewed
1126
-	 *
1127
-	 * This method is filtered by payment gateways in order to return true on subscriptions
1128
-	 * that can be renewed manually
1129
-	 *
1130
-	 * @since  2.5
1131
-	 * @return bool
1132
-	 */
1133
-	public function can_renew() {
1134
-		return apply_filters( 'wpinv_subscription_can_renew', true, $this );
1135
-	}
1136
-
1137
-	/**
1138
-	 * Retrieves the URL to renew a subscription
1139
-	 *
1140
-	 * @since  2.5
1141
-	 * @return string
1142
-	 */
1143
-	public function get_renew_url() {
1144
-		$url = wp_nonce_url(
1099
+    /**
1100
+     * Retrieves the URL to cancel subscription
1101
+     *
1102
+     * @since  1.0.0
1103
+     * @return string
1104
+     */
1105
+    public function get_cancel_url() {
1106
+        $url = getpaid_get_authenticated_action_url( 'subscription_cancel', $this->get_view_url() );
1107
+        return apply_filters( 'wpinv_subscription_cancel_url', $url, $this );
1108
+    }
1109
+
1110
+    /**
1111
+     * Retrieves the URL to view a subscription
1112
+     *
1113
+     * @since  1.0.19
1114
+     * @return string
1115
+     */
1116
+    public function get_view_url() {
1117
+
1118
+        $url = getpaid_get_tab_url( 'gp-subscriptions', get_permalink( (int) wpinv_get_option( 'invoice_subscription_page' ) ) );
1119
+        $url = add_query_arg( 'subscription', $this->get_id(), $url );
1120
+
1121
+        return apply_filters( 'getpaid_get_subscription_view_url', $url, $this );
1122
+    }
1123
+
1124
+    /**
1125
+     * Determines if subscription can be manually renewed
1126
+     *
1127
+     * This method is filtered by payment gateways in order to return true on subscriptions
1128
+     * that can be renewed manually
1129
+     *
1130
+     * @since  2.5
1131
+     * @return bool
1132
+     */
1133
+    public function can_renew() {
1134
+        return apply_filters( 'wpinv_subscription_can_renew', true, $this );
1135
+    }
1136
+
1137
+    /**
1138
+     * Retrieves the URL to renew a subscription
1139
+     *
1140
+     * @since  2.5
1141
+     * @return string
1142
+     */
1143
+    public function get_renew_url() {
1144
+        $url = wp_nonce_url(
1145 1145
             add_query_arg(
1146 1146
                 array(
1147
-					'getpaid-action' => 'renew_subscription',
1148
-					'sub_id'         => $this->get_id,
1147
+                    'getpaid-action' => 'renew_subscription',
1148
+                    'sub_id'         => $this->get_id,
1149 1149
                 )
1150 1150
             ),
1151 1151
             'getpaid-nonce'
1152 1152
         );
1153
-		return apply_filters( 'wpinv_subscription_renew_url', $url, $this );
1154
-	}
1155
-
1156
-	/**
1157
-	 * Determines if subscription can have their payment method updated
1158
-	 *
1159
-	 * @since  1.0.0
1160
-	 * @return bool
1161
-	 */
1162
-	public function can_update() {
1163
-		return apply_filters( 'wpinv_subscription_can_update', false, $this );
1164
-	}
1165
-
1166
-	/**
1167
-	 * Retrieves the URL to update subscription
1168
-	 *
1169
-	 * @since  1.0.0
1170
-	 * @return string
1171
-	 */
1172
-	public function get_update_url() {
1173
-		$url = add_query_arg(
1153
+        return apply_filters( 'wpinv_subscription_renew_url', $url, $this );
1154
+    }
1155
+
1156
+    /**
1157
+     * Determines if subscription can have their payment method updated
1158
+     *
1159
+     * @since  1.0.0
1160
+     * @return bool
1161
+     */
1162
+    public function can_update() {
1163
+        return apply_filters( 'wpinv_subscription_can_update', false, $this );
1164
+    }
1165
+
1166
+    /**
1167
+     * Retrieves the URL to update subscription
1168
+     *
1169
+     * @since  1.0.0
1170
+     * @return string
1171
+     */
1172
+    public function get_update_url() {
1173
+        $url = add_query_arg(
1174 1174
             array(
1175
-				'action'          => 'update',
1176
-				'subscription_id' => $this->get_id(),
1175
+                'action'          => 'update',
1176
+                'subscription_id' => $this->get_id(),
1177 1177
             )
1178 1178
         );
1179
-		return apply_filters( 'wpinv_subscription_update_url', $url, $this );
1180
-	}
1181
-
1182
-	/**
1183
-	 * Retrieves the subscription status label
1184
-	 *
1185
-	 * @since  1.0.0
1186
-	 * @return string
1187
-	 */
1188
-	public function get_status_label() {
1189
-		return getpaid_get_subscription_status_label( $this->get_status() );
1190
-	}
1191
-
1192
-	/**
1193
-	 * Retrieves the subscription status class
1194
-	 *
1195
-	 * @since  1.0.19
1196
-	 * @return string
1197
-	 */
1198
-	public function get_status_class() {
1199
-		$statuses = getpaid_get_subscription_status_classes();
1200
-		return isset( $statuses[ $this->get_status() ] ) ? $statuses[ $this->get_status() ] : 'bg-dark';
1201
-	}
1179
+        return apply_filters( 'wpinv_subscription_update_url', $url, $this );
1180
+    }
1181
+
1182
+    /**
1183
+     * Retrieves the subscription status label
1184
+     *
1185
+     * @since  1.0.0
1186
+     * @return string
1187
+     */
1188
+    public function get_status_label() {
1189
+        return getpaid_get_subscription_status_label( $this->get_status() );
1190
+    }
1191
+
1192
+    /**
1193
+     * Retrieves the subscription status class
1194
+     *
1195
+     * @since  1.0.19
1196
+     * @return string
1197
+     */
1198
+    public function get_status_class() {
1199
+        $statuses = getpaid_get_subscription_status_classes();
1200
+        return isset( $statuses[ $this->get_status() ] ) ? $statuses[ $this->get_status() ] : 'bg-dark';
1201
+    }
1202 1202
 
1203 1203
     /**
1204 1204
      * Retrieves the subscription status label
@@ -1208,11 +1208,11 @@  discard block
 block discarded – undo
1208 1208
      */
1209 1209
     public function get_status_label_html() {
1210 1210
 
1211
-		$status_label = sanitize_text_field( $this->get_status_label() );
1212
-		$class        = esc_attr( $this->get_status_class() );
1213
-		$status       = sanitize_html_class( $this->get_status() );
1211
+        $status_label = sanitize_text_field( $this->get_status_label() );
1212
+        $class        = esc_attr( $this->get_status_class() );
1213
+        $status       = sanitize_html_class( $this->get_status() );
1214 1214
 
1215
-		return "<span class='bsui'><span class='badge $class $status'>$status_label</span></span>";
1215
+        return "<span class='bsui'><span class='badge $class $status'>$status_label</span></span>";
1216 1216
     }
1217 1217
 
1218 1218
     /**
@@ -1223,75 +1223,75 @@  discard block
 block discarded – undo
1223 1223
      * @return bool
1224 1224
      */
1225 1225
     public function payment_exists( $txn_id = '' ) {
1226
-		$invoice_id = WPInv_Invoice::get_invoice_id_by_field( $txn_id, 'transaction_id' );
1226
+        $invoice_id = WPInv_Invoice::get_invoice_id_by_field( $txn_id, 'transaction_id' );
1227 1227
         return ! empty( $invoice_id );
1228
-	}
1229
-
1230
-	/**
1231
-	 * Handle the status transition.
1232
-	 */
1233
-	protected function status_transition() {
1234
-		$status_transition = $this->status_transition;
1235
-
1236
-		// Reset status transition variable.
1237
-		$this->status_transition = false;
1238
-
1239
-		if ( $status_transition ) {
1240
-			try {
1241
-
1242
-				// Fire a hook for the status change.
1243
-				do_action( 'wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition );
1244
-				do_action( 'getpaid_subscription_' . $status_transition['to'], $this, $status_transition );
1245
-
1246
-				if ( ! empty( $status_transition['from'] ) ) {
1247
-
1248
-					/* translators: 1: old subscription status 2: new subscription status */
1249
-					$transition_note = sprintf( __( 'Subscription status changed from %1$s to %2$s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['from'] ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1250
-
1251
-					// Note the transition occurred.
1252
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1253
-
1254
-					// Fire another hook.
1255
-					do_action( 'getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this );
1256
-					do_action( 'getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to'] );
1257
-
1258
-				} else {
1259
-					/* translators: %s: new invoice status */
1260
-					$transition_note = sprintf( __( 'Subscription status set to %s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1261
-
1262
-					// Note the transition occurred.
1263
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1264
-
1265
-				}
1266
-			} catch ( Exception $e ) {
1267
-				$this->get_parent_payment()->add_note( __( 'Error during subscription status transition.', 'invoicing' ) . ' ' . $e->getMessage() );
1268
-			}
1269
-		}
1270
-
1271
-	}
1272
-
1273
-	/**
1274
-	 * Save data to the database.
1275
-	 *
1276
-	 * @since 1.0.19
1277
-	 * @return int subscription ID
1278
-	 */
1279
-	public function save() {
1280
-		parent::save();
1281
-		$this->status_transition();
1282
-		return $this->get_id();
1283
-	}
1284
-
1285
-	/**
1286
-	 * Activates a subscription.
1287
-	 *
1288
-	 * @since 1.0.19
1289
-	 * @return int subscription ID
1290
-	 */
1291
-	public function activate() {
1292
-		$status = $this->has_trial_period() && 'trialling' === $this->get_status() ? 'trialling' : 'active';
1293
-		$this->set_status( $status );
1294
-		return $this->save();
1295
-	}
1228
+    }
1229
+
1230
+    /**
1231
+     * Handle the status transition.
1232
+     */
1233
+    protected function status_transition() {
1234
+        $status_transition = $this->status_transition;
1235
+
1236
+        // Reset status transition variable.
1237
+        $this->status_transition = false;
1238
+
1239
+        if ( $status_transition ) {
1240
+            try {
1241
+
1242
+                // Fire a hook for the status change.
1243
+                do_action( 'wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition );
1244
+                do_action( 'getpaid_subscription_' . $status_transition['to'], $this, $status_transition );
1245
+
1246
+                if ( ! empty( $status_transition['from'] ) ) {
1247
+
1248
+                    /* translators: 1: old subscription status 2: new subscription status */
1249
+                    $transition_note = sprintf( __( 'Subscription status changed from %1$s to %2$s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['from'] ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1250
+
1251
+                    // Note the transition occurred.
1252
+                    $this->get_parent_payment()->add_note( $transition_note, false, false, true );
1253
+
1254
+                    // Fire another hook.
1255
+                    do_action( 'getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this );
1256
+                    do_action( 'getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to'] );
1257
+
1258
+                } else {
1259
+                    /* translators: %s: new invoice status */
1260
+                    $transition_note = sprintf( __( 'Subscription status set to %s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1261
+
1262
+                    // Note the transition occurred.
1263
+                    $this->get_parent_payment()->add_note( $transition_note, false, false, true );
1264
+
1265
+                }
1266
+            } catch ( Exception $e ) {
1267
+                $this->get_parent_payment()->add_note( __( 'Error during subscription status transition.', 'invoicing' ) . ' ' . $e->getMessage() );
1268
+            }
1269
+        }
1270
+
1271
+    }
1272
+
1273
+    /**
1274
+     * Save data to the database.
1275
+     *
1276
+     * @since 1.0.19
1277
+     * @return int subscription ID
1278
+     */
1279
+    public function save() {
1280
+        parent::save();
1281
+        $this->status_transition();
1282
+        return $this->get_id();
1283
+    }
1284
+
1285
+    /**
1286
+     * Activates a subscription.
1287
+     *
1288
+     * @since 1.0.19
1289
+     * @return int subscription ID
1290
+     */
1291
+    public function activate() {
1292
+        $status = $this->has_trial_period() && 'trialling' === $this->get_status() ? 'trialling' : 'active';
1293
+        $this->set_status( $status );
1294
+        return $this->save();
1295
+    }
1296 1296
 
1297 1297
 }
Please login to merge, or discard this patch.
Spacing   +239 added lines, -239 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
  * @package Invoicing
7 7
  */
8 8
 
9
-defined( 'ABSPATH' ) || exit;
9
+defined('ABSPATH') || exit;
10 10
 
11 11
 /**
12 12
  * The Subscription Class
@@ -68,27 +68,27 @@  discard block
 block discarded – undo
68 68
 	 * @param  int|string|object|WPInv_Subscription $subscription Subscription id, profile_id, or object to read.
69 69
 	 * @param  bool $deprecated
70 70
 	 */
71
-	function __construct( $subscription = 0, $deprecated = false ) {
71
+	function __construct($subscription = 0, $deprecated = false) {
72 72
 
73
-		parent::__construct( $subscription );
73
+		parent::__construct($subscription);
74 74
 
75
-		if ( ! $deprecated && ! empty( $subscription ) && is_numeric( $subscription ) ) {
76
-			$this->set_id( $subscription );
77
-		} elseif ( $subscription instanceof self ) {
78
-			$this->set_id( $subscription->get_id() );
79
-		} elseif ( $deprecated && $subscription_id = self::get_subscription_id_by_field( $subscription, 'profile_id' ) ) {
80
-			$this->set_id( $subscription_id );
81
-		} elseif ( ! empty( $subscription->id ) ) {
82
-			$this->set_id( $subscription->id );
75
+		if (!$deprecated && !empty($subscription) && is_numeric($subscription)) {
76
+			$this->set_id($subscription);
77
+		} elseif ($subscription instanceof self) {
78
+			$this->set_id($subscription->get_id());
79
+		} elseif ($deprecated && $subscription_id = self::get_subscription_id_by_field($subscription, 'profile_id')) {
80
+			$this->set_id($subscription_id);
81
+		} elseif (!empty($subscription->id)) {
82
+			$this->set_id($subscription->id);
83 83
 		} else {
84
-			$this->set_object_read( true );
84
+			$this->set_object_read(true);
85 85
 		}
86 86
 
87 87
 		// Load the datastore.
88
-		$this->data_store = GetPaid_Data_Store::load( $this->data_store_name );
88
+		$this->data_store = GetPaid_Data_Store::load($this->data_store_name);
89 89
 
90
-		if ( $this->get_id() > 0 ) {
91
-			$this->data_store->read( $this );
90
+		if ($this->get_id() > 0) {
91
+			$this->data_store->read($this);
92 92
 		}
93 93
 
94 94
 	}
@@ -103,17 +103,17 @@  discard block
 block discarded – undo
103 103
 	 * @since 1.0.19
104 104
 	 * @return int
105 105
 	 */
106
-	public static function get_subscription_id_by_field( $value, $field = 'profile_id' ) {
106
+	public static function get_subscription_id_by_field($value, $field = 'profile_id') {
107 107
         global $wpdb;
108 108
 
109 109
 		// Trim the value.
110
-		$value = trim( $value );
110
+		$value = trim($value);
111 111
 
112
-		if ( empty( $value ) ) {
112
+		if (empty($value)) {
113 113
 			return 0;
114 114
 		}
115 115
 
116
-		if ( 'invoice_id' == $field ) {
116
+		if ('invoice_id' == $field) {
117 117
 			$field = 'parent_payment_id';
118 118
 		}
119 119
 
@@ -125,28 +125,28 @@  discard block
 block discarded – undo
125 125
 		);
126 126
 
127 127
 		// Ensure a field has been passed.
128
-		if ( empty( $field ) || ! in_array( $field, $fields ) ) {
128
+		if (empty($field) || !in_array($field, $fields)) {
129 129
 			return 0;
130 130
 		}
131 131
 
132 132
 		// Maybe retrieve from the cache.
133
-		$subscription_id   = wp_cache_get( $value, "getpaid_subscription_{$field}s_to_subscription_ids" );
134
-		if ( ! empty( $subscription_id ) ) {
133
+		$subscription_id = wp_cache_get($value, "getpaid_subscription_{$field}s_to_subscription_ids");
134
+		if (!empty($subscription_id)) {
135 135
 			return $subscription_id;
136 136
 		}
137 137
 
138 138
         // Fetch from the db.
139 139
         $table            = $wpdb->prefix . 'wpinv_subscriptions';
140 140
         $subscription_id  = (int) $wpdb->get_var(
141
-            $wpdb->prepare( "SELECT `id` FROM $table WHERE `$field`=%s LIMIT 1", $value )
141
+            $wpdb->prepare("SELECT `id` FROM $table WHERE `$field`=%s LIMIT 1", $value)
142 142
         );
143 143
 
144
-		if ( empty( $subscription_id ) ) {
144
+		if (empty($subscription_id)) {
145 145
 			return 0;
146 146
 		}
147 147
 
148 148
 		// Update the cache with our data.
149
-		wp_cache_set( $value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids" );
149
+		wp_cache_set($value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids");
150 150
 
151 151
 		return $subscription_id;
152 152
 	}
@@ -162,9 +162,9 @@  discard block
 block discarded – undo
162 162
 			'getpaid_subscriptions'                                       => $this->get_id(),
163 163
 		);
164 164
 
165
-		foreach ( $caches as $cache => $value ) {
166
-			if ( '' !== $value && false !== $value ) {
167
-				wp_cache_delete( $value, $cache );
165
+		foreach ($caches as $cache => $value) {
166
+			if ('' !== $value && false !== $value) {
167
+				wp_cache_delete($value, $cache);
168 168
 			}
169 169
 		}
170 170
 	}
@@ -172,8 +172,8 @@  discard block
 block discarded – undo
172 172
 	/**
173 173
      * Checks if a subscription key is set.
174 174
      */
175
-    public function _isset( $key ) {
176
-        return isset( $this->data[ $key ] ) || method_exists( $this, "get_$key" );
175
+    public function _isset($key) {
176
+        return isset($this->data[$key]) || method_exists($this, "get_$key");
177 177
 	}
178 178
 
179 179
 	/*
@@ -198,8 +198,8 @@  discard block
 block discarded – undo
198 198
 	 * @param  string $context View or edit context.
199 199
 	 * @return int
200 200
 	 */
201
-	public function get_customer_id( $context = 'view' ) {
202
-		return (int) $this->get_prop( 'customer_id', $context );
201
+	public function get_customer_id($context = 'view') {
202
+		return (int) $this->get_prop('customer_id', $context);
203 203
 	}
204 204
 
205 205
 	/**
@@ -209,8 +209,8 @@  discard block
 block discarded – undo
209 209
 	 * @param  string $context View or edit context.
210 210
 	 * @return WP_User|false WP_User object on success, false on failure.
211 211
 	 */
212
-	public function get_customer( $context = 'view' ) {
213
-		return get_userdata( $this->get_customer_id( $context ) );
212
+	public function get_customer($context = 'view') {
213
+		return get_userdata($this->get_customer_id($context));
214 214
 	}
215 215
 
216 216
 	/**
@@ -220,8 +220,8 @@  discard block
 block discarded – undo
220 220
 	 * @param  string $context View or edit context.
221 221
 	 * @return int
222 222
 	 */
223
-	public function get_parent_invoice_id( $context = 'view' ) {
224
-		return (int) $this->get_prop( 'parent_payment_id', $context );
223
+	public function get_parent_invoice_id($context = 'view') {
224
+		return (int) $this->get_prop('parent_payment_id', $context);
225 225
 	}
226 226
 
227 227
 	/**
@@ -231,8 +231,8 @@  discard block
 block discarded – undo
231 231
 	 * @param  string $context View or edit context.
232 232
 	 * @return int
233 233
 	 */
234
-    public function get_parent_payment_id( $context = 'view' ) {
235
-        return $this->get_parent_invoice_id( $context );
234
+    public function get_parent_payment_id($context = 'view') {
235
+        return $this->get_parent_invoice_id($context);
236 236
 	}
237 237
 
238 238
 	/**
@@ -241,8 +241,8 @@  discard block
 block discarded – undo
241 241
      * @since  1.0.0
242 242
      * @return int
243 243
      */
244
-    public function get_original_payment_id( $context = 'view' ) {
245
-        return $this->get_parent_invoice_id( $context );
244
+    public function get_original_payment_id($context = 'view') {
245
+        return $this->get_parent_invoice_id($context);
246 246
     }
247 247
 
248 248
 	/**
@@ -252,8 +252,8 @@  discard block
 block discarded – undo
252 252
 	 * @param  string $context View or edit context.
253 253
 	 * @return WPInv_Invoice
254 254
 	 */
255
-	public function get_parent_invoice( $context = 'view' ) {
256
-		return new WPInv_Invoice( $this->get_parent_invoice_id( $context ) );
255
+	public function get_parent_invoice($context = 'view') {
256
+		return new WPInv_Invoice($this->get_parent_invoice_id($context));
257 257
 	}
258 258
 
259 259
 	/**
@@ -263,8 +263,8 @@  discard block
 block discarded – undo
263 263
 	 * @param  string $context View or edit context.
264 264
 	 * @return WPInv_Invoice
265 265
 	 */
266
-    public function get_parent_payment( $context = 'view' ) {
267
-        return $this->get_parent_invoice( $context );
266
+    public function get_parent_payment($context = 'view') {
267
+        return $this->get_parent_invoice($context);
268 268
 	}
269 269
 
270 270
 	/**
@@ -274,8 +274,8 @@  discard block
 block discarded – undo
274 274
 	 * @param  string $context View or edit context.
275 275
 	 * @return int
276 276
 	 */
277
-	public function get_product_id( $context = 'view' ) {
278
-		return (int) $this->get_prop( 'product_id', $context );
277
+	public function get_product_id($context = 'view') {
278
+		return (int) $this->get_prop('product_id', $context);
279 279
 	}
280 280
 
281 281
 	/**
@@ -285,8 +285,8 @@  discard block
 block discarded – undo
285 285
 	 * @param  string $context View or edit context.
286 286
 	 * @return WPInv_Item
287 287
 	 */
288
-	public function get_product( $context = 'view' ) {
289
-		return new WPInv_Item( $this->get_product_id( $context ) );
288
+	public function get_product($context = 'view') {
289
+		return new WPInv_Item($this->get_product_id($context));
290 290
 	}
291 291
 
292 292
 	/**
@@ -298,8 +298,8 @@  discard block
 block discarded – undo
298 298
 	 * @param  string $context View or edit context.
299 299
 	 * @return string
300 300
 	 */
301
-	public function get_gateway( $context = 'view' ) {
302
-		return $this->get_parent_invoice( $context )->get_gateway();
301
+	public function get_gateway($context = 'view') {
302
+		return $this->get_parent_invoice($context)->get_gateway();
303 303
 	}
304 304
 
305 305
 	/**
@@ -309,8 +309,8 @@  discard block
 block discarded – undo
309 309
 	 * @param  string $context View or edit context.
310 310
 	 * @return string
311 311
 	 */
312
-	public function get_period( $context = 'view' ) {
313
-		return $this->get_prop( 'period', $context );
312
+	public function get_period($context = 'view') {
313
+		return $this->get_prop('period', $context);
314 314
 	}
315 315
 
316 316
 	/**
@@ -320,8 +320,8 @@  discard block
 block discarded – undo
320 320
 	 * @param  string $context View or edit context.
321 321
 	 * @return int
322 322
 	 */
323
-	public function get_frequency( $context = 'view' ) {
324
-		return (int) $this->get_prop( 'frequency', $context );
323
+	public function get_frequency($context = 'view') {
324
+		return (int) $this->get_prop('frequency', $context);
325 325
 	}
326 326
 
327 327
 	/**
@@ -331,8 +331,8 @@  discard block
 block discarded – undo
331 331
 	 * @param  string $context View or edit context.
332 332
 	 * @return float
333 333
 	 */
334
-	public function get_initial_amount( $context = 'view' ) {
335
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'initial_amount', $context ) );
334
+	public function get_initial_amount($context = 'view') {
335
+		return (float) wpinv_sanitize_amount($this->get_prop('initial_amount', $context));
336 336
 	}
337 337
 
338 338
 	/**
@@ -342,8 +342,8 @@  discard block
 block discarded – undo
342 342
 	 * @param  string $context View or edit context.
343 343
 	 * @return float
344 344
 	 */
345
-	public function get_recurring_amount( $context = 'view' ) {
346
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'recurring_amount', $context ) );
345
+	public function get_recurring_amount($context = 'view') {
346
+		return (float) wpinv_sanitize_amount($this->get_prop('recurring_amount', $context));
347 347
 	}
348 348
 
349 349
 	/**
@@ -353,8 +353,8 @@  discard block
 block discarded – undo
353 353
 	 * @param  string $context View or edit context.
354 354
 	 * @return int
355 355
 	 */
356
-	public function get_bill_times( $context = 'view' ) {
357
-		return (int) $this->get_prop( 'bill_times', $context );
356
+	public function get_bill_times($context = 'view') {
357
+		return (int) $this->get_prop('bill_times', $context);
358 358
 	}
359 359
 
360 360
 	/**
@@ -364,8 +364,8 @@  discard block
 block discarded – undo
364 364
 	 * @param  string $context View or edit context.
365 365
 	 * @return string
366 366
 	 */
367
-	public function get_transaction_id( $context = 'view' ) {
368
-		return $this->get_prop( 'transaction_id', $context );
367
+	public function get_transaction_id($context = 'view') {
368
+		return $this->get_prop('transaction_id', $context);
369 369
 	}
370 370
 
371 371
 	/**
@@ -375,8 +375,8 @@  discard block
 block discarded – undo
375 375
 	 * @param  string $context View or edit context.
376 376
 	 * @return string
377 377
 	 */
378
-	public function get_created( $context = 'view' ) {
379
-		return $this->get_prop( 'created', $context );
378
+	public function get_created($context = 'view') {
379
+		return $this->get_prop('created', $context);
380 380
 	}
381 381
 
382 382
 	/**
@@ -386,8 +386,8 @@  discard block
 block discarded – undo
386 386
 	 * @param  string $context View or edit context.
387 387
 	 * @return string
388 388
 	 */
389
-	public function get_date_created( $context = 'view' ) {
390
-		return $this->get_created( $context );
389
+	public function get_date_created($context = 'view') {
390
+		return $this->get_created($context);
391 391
 	}
392 392
 
393 393
 	/**
@@ -398,7 +398,7 @@  discard block
 block discarded – undo
398 398
 	 */
399 399
 	public function get_time_created() {
400 400
 		$created = $this->get_date_created();
401
-		return empty( $created ) ? current_time( 'timestamp' ) : strtotime( $created, current_time( 'timestamp' ) );
401
+		return empty($created) ? current_time('timestamp') : strtotime($created, current_time('timestamp'));
402 402
 	}
403 403
 
404 404
 	/**
@@ -408,11 +408,11 @@  discard block
 block discarded – undo
408 408
 	 * @param  string $context View or edit context.
409 409
 	 * @return string
410 410
 	 */
411
-	public function get_date_created_gmt( $context = 'view' ) {
412
-        $date = $this->get_date_created( $context );
411
+	public function get_date_created_gmt($context = 'view') {
412
+        $date = $this->get_date_created($context);
413 413
 
414
-        if ( $date ) {
415
-            $date = get_gmt_from_date( $date );
414
+        if ($date) {
415
+            $date = get_gmt_from_date($date);
416 416
         }
417 417
 		return $date;
418 418
 	}
@@ -424,8 +424,8 @@  discard block
 block discarded – undo
424 424
 	 * @param  string $context View or edit context.
425 425
 	 * @return string
426 426
 	 */
427
-	public function get_next_renewal_date( $context = 'view' ) {
428
-		return $this->get_prop( 'expiration', $context );
427
+	public function get_next_renewal_date($context = 'view') {
428
+		return $this->get_prop('expiration', $context);
429 429
 	}
430 430
 
431 431
 	/**
@@ -435,8 +435,8 @@  discard block
 block discarded – undo
435 435
 	 * @param  string $context View or edit context.
436 436
 	 * @return string
437 437
 	 */
438
-	public function get_expiration( $context = 'view' ) {
439
-		return $this->get_next_renewal_date( $context );
438
+	public function get_expiration($context = 'view') {
439
+		return $this->get_next_renewal_date($context);
440 440
 	}
441 441
 
442 442
 	/**
@@ -448,12 +448,12 @@  discard block
 block discarded – undo
448 448
 	public function get_expiration_time() {
449 449
 		$expiration = $this->get_expiration();
450 450
 
451
-		if ( empty( $expiration ) || '0000-00-00 00:00:00' == $expiration ) {
452
-			return current_time( 'timestamp' );
451
+		if (empty($expiration) || '0000-00-00 00:00:00' == $expiration) {
452
+			return current_time('timestamp');
453 453
 		}
454 454
 
455
-		$expiration = strtotime( $expiration, current_time( 'timestamp' ) );
456
-		return $expiration < current_time( 'timestamp' ) ? current_time( 'timestamp' ) : $expiration;
455
+		$expiration = strtotime($expiration, current_time('timestamp'));
456
+		return $expiration < current_time('timestamp') ? current_time('timestamp') : $expiration;
457 457
 	}
458 458
 
459 459
 	/**
@@ -463,11 +463,11 @@  discard block
 block discarded – undo
463 463
 	 * @param  string $context View or edit context.
464 464
 	 * @return string
465 465
 	 */
466
-	public function get_next_renewal_date_gmt( $context = 'view' ) {
467
-        $date = $this->get_next_renewal_date( $context );
466
+	public function get_next_renewal_date_gmt($context = 'view') {
467
+        $date = $this->get_next_renewal_date($context);
468 468
 
469
-        if ( $date ) {
470
-            $date = get_gmt_from_date( $date );
469
+        if ($date) {
470
+            $date = get_gmt_from_date($date);
471 471
         }
472 472
 		return $date;
473 473
 	}
@@ -479,8 +479,8 @@  discard block
 block discarded – undo
479 479
 	 * @param  string $context View or edit context.
480 480
 	 * @return string
481 481
 	 */
482
-	public function get_trial_period( $context = 'view' ) {
483
-		return $this->get_prop( 'trial_period', $context );
482
+	public function get_trial_period($context = 'view') {
483
+		return $this->get_prop('trial_period', $context);
484 484
 	}
485 485
 
486 486
 	/**
@@ -490,8 +490,8 @@  discard block
 block discarded – undo
490 490
 	 * @param  string $context View or edit context.
491 491
 	 * @return string
492 492
 	 */
493
-	public function get_status( $context = 'view' ) {
494
-		return $this->get_prop( 'status', $context );
493
+	public function get_status($context = 'view') {
494
+		return $this->get_prop('status', $context);
495 495
 	}
496 496
 
497 497
 	/**
@@ -501,8 +501,8 @@  discard block
 block discarded – undo
501 501
 	 * @param  string $context View or edit context.
502 502
 	 * @return string
503 503
 	 */
504
-	public function get_profile_id( $context = 'view' ) {
505
-		return $this->get_prop( 'profile_id', $context );
504
+	public function get_profile_id($context = 'view') {
505
+		return $this->get_prop('profile_id', $context);
506 506
 	}
507 507
 
508 508
 	/*
@@ -517,8 +517,8 @@  discard block
 block discarded – undo
517 517
 	 * @since 1.0.19
518 518
 	 * @param  int $value The customer's id.
519 519
 	 */
520
-	public function set_customer_id( $value ) {
521
-		$this->set_prop( 'customer_id', (int) $value );
520
+	public function set_customer_id($value) {
521
+		$this->set_prop('customer_id', (int) $value);
522 522
 	}
523 523
 
524 524
 	/**
@@ -527,8 +527,8 @@  discard block
 block discarded – undo
527 527
 	 * @since 1.0.19
528 528
 	 * @param  int $value The parent invoice id.
529 529
 	 */
530
-	public function set_parent_invoice_id( $value ) {
531
-		$this->set_prop( 'parent_payment_id', (int) $value );
530
+	public function set_parent_invoice_id($value) {
531
+		$this->set_prop('parent_payment_id', (int) $value);
532 532
 	}
533 533
 
534 534
 	/**
@@ -537,8 +537,8 @@  discard block
 block discarded – undo
537 537
 	 * @since 1.0.19
538 538
 	 * @param  int $value The parent invoice id.
539 539
 	 */
540
-    public function set_parent_payment_id( $value ) {
541
-        $this->set_parent_invoice_id( $value );
540
+    public function set_parent_payment_id($value) {
541
+        $this->set_parent_invoice_id($value);
542 542
 	}
543 543
 
544 544
 	/**
@@ -547,8 +547,8 @@  discard block
 block discarded – undo
547 547
      * @since 1.0.19
548 548
 	 * @param  int $value The parent invoice id.
549 549
      */
550
-    public function set_original_payment_id( $value ) {
551
-        $this->set_parent_invoice_id( $value );
550
+    public function set_original_payment_id($value) {
551
+        $this->set_parent_invoice_id($value);
552 552
 	}
553 553
 
554 554
 	/**
@@ -557,8 +557,8 @@  discard block
 block discarded – undo
557 557
 	 * @since 1.0.19
558 558
 	 * @param  int $value The subscription product id.
559 559
 	 */
560
-	public function set_product_id( $value ) {
561
-		$this->set_prop( 'product_id', (int) $value );
560
+	public function set_product_id($value) {
561
+		$this->set_prop('product_id', (int) $value);
562 562
 	}
563 563
 
564 564
 	/**
@@ -567,8 +567,8 @@  discard block
 block discarded – undo
567 567
 	 * @since 1.0.19
568 568
 	 * @param  string $value The renewal period.
569 569
 	 */
570
-	public function set_period( $value ) {
571
-		$this->set_prop( 'period', $value );
570
+	public function set_period($value) {
571
+		$this->set_prop('period', $value);
572 572
 	}
573 573
 
574 574
 	/**
@@ -577,9 +577,9 @@  discard block
 block discarded – undo
577 577
 	 * @since 1.0.19
578 578
 	 * @param  int $value The subscription frequency.
579 579
 	 */
580
-	public function set_frequency( $value ) {
581
-		$value = empty( $value ) ? 1 : (int) $value;
582
-		$this->set_prop( 'frequency', absint( $value ) );
580
+	public function set_frequency($value) {
581
+		$value = empty($value) ? 1 : (int) $value;
582
+		$this->set_prop('frequency', absint($value));
583 583
 	}
584 584
 
585 585
 	/**
@@ -588,8 +588,8 @@  discard block
 block discarded – undo
588 588
 	 * @since 1.0.19
589 589
 	 * @param  float $value The initial subcription amount.
590 590
 	 */
591
-	public function set_initial_amount( $value ) {
592
-		$this->set_prop( 'initial_amount', wpinv_sanitize_amount( $value ) );
591
+	public function set_initial_amount($value) {
592
+		$this->set_prop('initial_amount', wpinv_sanitize_amount($value));
593 593
 	}
594 594
 
595 595
 	/**
@@ -598,8 +598,8 @@  discard block
 block discarded – undo
598 598
 	 * @since 1.0.19
599 599
 	 * @param  float $value The recurring subcription amount.
600 600
 	 */
601
-	public function set_recurring_amount( $value ) {
602
-		$this->set_prop( 'recurring_amount', wpinv_sanitize_amount( $value ) );
601
+	public function set_recurring_amount($value) {
602
+		$this->set_prop('recurring_amount', wpinv_sanitize_amount($value));
603 603
 	}
604 604
 
605 605
 	/**
@@ -608,8 +608,8 @@  discard block
 block discarded – undo
608 608
 	 * @since 1.0.19
609 609
 	 * @param  int $value Bill times.
610 610
 	 */
611
-	public function set_bill_times( $value ) {
612
-		$this->set_prop( 'bill_times', (int) $value );
611
+	public function set_bill_times($value) {
612
+		$this->set_prop('bill_times', (int) $value);
613 613
 	}
614 614
 
615 615
 	/**
@@ -618,8 +618,8 @@  discard block
 block discarded – undo
618 618
 	 * @since 1.0.19
619 619
 	 * @param string $value Bill times.
620 620
 	 */
621
-	public function set_transaction_id( $value ) {
622
-		$this->set_prop( 'transaction_id', sanitize_text_field( $value ) );
621
+	public function set_transaction_id($value) {
622
+		$this->set_prop('transaction_id', sanitize_text_field($value));
623 623
 	}
624 624
 
625 625
 	/**
@@ -628,15 +628,15 @@  discard block
 block discarded – undo
628 628
 	 * @since 1.0.19
629 629
 	 * @param string $value strtotime compliant date.
630 630
 	 */
631
-	public function set_created( $value ) {
632
-        $date = strtotime( $value );
631
+	public function set_created($value) {
632
+        $date = strtotime($value);
633 633
 
634
-        if ( $date && $value !== '0000-00-00 00:00:00' ) {
635
-            $this->set_prop( 'created', gmdate( 'Y-m-d H:i:s', $date ) );
634
+        if ($date && $value !== '0000-00-00 00:00:00') {
635
+            $this->set_prop('created', gmdate('Y-m-d H:i:s', $date));
636 636
             return;
637 637
         }
638 638
 
639
-		$this->set_prop( 'created', '' );
639
+		$this->set_prop('created', '');
640 640
 
641 641
 	}
642 642
 
@@ -646,8 +646,8 @@  discard block
 block discarded – undo
646 646
 	 * @since 1.0.19
647 647
 	 * @param string $value strtotime compliant date.
648 648
 	 */
649
-	public function set_date_created( $value ) {
650
-		$this->set_created( $value );
649
+	public function set_date_created($value) {
650
+		$this->set_created($value);
651 651
     }
652 652
 
653 653
 	/**
@@ -656,15 +656,15 @@  discard block
 block discarded – undo
656 656
 	 * @since 1.0.19
657 657
 	 * @param string $value strtotime compliant date.
658 658
 	 */
659
-	public function set_next_renewal_date( $value ) {
660
-		$date = strtotime( $value );
659
+	public function set_next_renewal_date($value) {
660
+		$date = strtotime($value);
661 661
 
662
-        if ( $date && $value !== '0000-00-00 00:00:00' ) {
663
-            $this->set_prop( 'expiration', gmdate( 'Y-m-d H:i:s', $date ) );
662
+        if ($date && $value !== '0000-00-00 00:00:00') {
663
+            $this->set_prop('expiration', gmdate('Y-m-d H:i:s', $date));
664 664
             return;
665 665
 		}
666 666
 
667
-		$this->set_prop( 'expiration', '' );
667
+		$this->set_prop('expiration', '');
668 668
 
669 669
 	}
670 670
 
@@ -674,8 +674,8 @@  discard block
 block discarded – undo
674 674
 	 * @since 1.0.19
675 675
 	 * @param string $value strtotime compliant date.
676 676
 	 */
677
-	public function set_expiration( $value ) {
678
-		$this->set_next_renewal_date( $value );
677
+	public function set_expiration($value) {
678
+		$this->set_next_renewal_date($value);
679 679
     }
680 680
 
681 681
 	/**
@@ -684,8 +684,8 @@  discard block
 block discarded – undo
684 684
 	 * @since 1.0.19
685 685
 	 * @param string $value trial period e.g 1 year.
686 686
 	 */
687
-	public function set_trial_period( $value ) {
688
-		$this->set_prop( 'trial_period', $value );
687
+	public function set_trial_period($value) {
688
+		$this->set_prop('trial_period', $value);
689 689
 	}
690 690
 
691 691
 	/**
@@ -694,22 +694,22 @@  discard block
 block discarded – undo
694 694
 	 * @since 1.0.19
695 695
 	 * @param string $new_status    New subscription status.
696 696
 	 */
697
-	public function set_status( $new_status ) {
697
+	public function set_status($new_status) {
698 698
 
699 699
 		// Abort if this is not a valid status;
700
-		if ( ! array_key_exists( $new_status, getpaid_get_subscription_statuses() ) ) {
700
+		if (!array_key_exists($new_status, getpaid_get_subscription_statuses())) {
701 701
 			return;
702 702
 		}
703 703
 
704
-		$old_status = ! empty( $this->status_transition['from'] ) ? $this->status_transition['from'] : $this->get_status();
705
-		if ( true === $this->object_read && $old_status !== $new_status ) {
704
+		$old_status = !empty($this->status_transition['from']) ? $this->status_transition['from'] : $this->get_status();
705
+		if (true === $this->object_read && $old_status !== $new_status) {
706 706
 			$this->status_transition = array(
707 707
 				'from' => $old_status,
708 708
 				'to'   => $new_status,
709 709
 			);
710 710
 		}
711 711
 
712
-		$this->set_prop( 'status', $new_status );
712
+		$this->set_prop('status', $new_status);
713 713
 	}
714 714
 
715 715
 	/**
@@ -718,8 +718,8 @@  discard block
 block discarded – undo
718 718
 	 * @since 1.0.19
719 719
 	 * @param  string $value the remote profile id.
720 720
 	 */
721
-	public function set_profile_id( $value ) {
722
-		$this->set_prop( 'profile_id', sanitize_text_field( $value ) );
721
+	public function set_profile_id($value) {
722
+		$this->set_prop('profile_id', sanitize_text_field($value));
723 723
 	}
724 724
 
725 725
 	/*
@@ -737,8 +737,8 @@  discard block
 block discarded – undo
737 737
 	 * @param string|array String or array of strings to check for.
738 738
 	 * @return bool
739 739
      */
740
-    public function has_status( $status ) {
741
-        return in_array( $this->get_status(), wpinv_clean( wpinv_parse_list( $status ) ) );
740
+    public function has_status($status) {
741
+        return in_array($this->get_status(), wpinv_clean(wpinv_parse_list($status)));
742 742
 	}
743 743
 
744 744
 	/**
@@ -748,7 +748,7 @@  discard block
 block discarded – undo
748 748
      */
749 749
     public function has_trial_period() {
750 750
 		$period = $this->get_trial_period();
751
-        return ! empty( $period );
751
+        return !empty($period);
752 752
 	}
753 753
 
754 754
 	/**
@@ -757,7 +757,7 @@  discard block
 block discarded – undo
757 757
 	 * @return bool
758 758
 	 */
759 759
 	public function is_active() {
760
-		return $this->has_status( 'active trialling' ) && ! $this->is_expired();
760
+		return $this->has_status('active trialling') && !$this->is_expired();
761 761
 	}
762 762
 
763 763
 	/**
@@ -766,7 +766,7 @@  discard block
 block discarded – undo
766 766
 	 * @return bool
767 767
 	 */
768 768
 	public function is_expired() {
769
-		return $this->has_status( 'expired' ) || ( $this->has_status( 'active cancelled trialling' ) && $this->get_expiration_time() < current_time( 'timestamp' ) );
769
+		return $this->has_status('expired') || ($this->has_status('active cancelled trialling') && $this->get_expiration_time() < current_time('timestamp'));
770 770
 	}
771 771
 
772 772
 	/**
@@ -776,7 +776,7 @@  discard block
 block discarded – undo
776 776
 	 */
777 777
 	public function is_last_renewal() {
778 778
 		$max_bills = $this->get_bill_times();
779
-		return ! empty( $max_bills ) && $max_bills <= $this->get_times_billed();
779
+		return !empty($max_bills) && $max_bills <= $this->get_times_billed();
780 780
 	}
781 781
 
782 782
 	/*
@@ -791,11 +791,11 @@  discard block
 block discarded – undo
791 791
 	/**
792 792
 	 * Backwards compatibilty.
793 793
 	 */
794
-	public function create( $data = array() ) {
794
+	public function create($data = array()) {
795 795
 
796 796
 		// Set the properties.
797
-		if ( is_array( $data ) ) {
798
-			$this->set_props( $data );
797
+		if (is_array($data)) {
798
+			$this->set_props($data);
799 799
 		}
800 800
 
801 801
 		// Save the item.
@@ -806,8 +806,8 @@  discard block
 block discarded – undo
806 806
 	/**
807 807
 	 * Backwards compatibilty.
808 808
 	 */
809
-	public function update( $args = array() ) {
810
-		return $this->create( $args );
809
+	public function update($args = array()) {
810
+		return $this->create($args);
811 811
 	}
812 812
 
813 813
     /**
@@ -816,12 +816,12 @@  discard block
 block discarded – undo
816 816
      * @since  1.0.0
817 817
      * @return WP_Post[]
818 818
      */
819
-    public function get_child_payments( $hide_pending = true ) {
819
+    public function get_child_payments($hide_pending = true) {
820 820
 
821
-		$statuses = array( 'publish', 'wpi-processing', 'wpi-renewal' );
821
+		$statuses = array('publish', 'wpi-processing', 'wpi-renewal');
822 822
 
823
-		if ( ! $hide_pending ) {
824
-			$statuses = array_keys( wpinv_get_invoice_statuses() );
823
+		if (!$hide_pending) {
824
+			$statuses = array_keys(wpinv_get_invoice_statuses());
825 825
 		}
826 826
 
827 827
         return get_posts(
@@ -843,7 +843,7 @@  discard block
 block discarded – undo
843 843
      * @return int
844 844
      */
845 845
     public function get_total_payments() {
846
-		return getpaid_count_subscription_invoices( $this->get_parent_invoice_id(), $this->get_id() );
846
+		return getpaid_count_subscription_invoices($this->get_parent_invoice_id(), $this->get_id());
847 847
     }
848 848
 
849 849
     /**
@@ -855,7 +855,7 @@  discard block
 block discarded – undo
855 855
     public function get_times_billed() {
856 856
         $times_billed = $this->get_total_payments();
857 857
 
858
-        if ( (float) $this->get_initial_amount() == 0 && $times_billed > 0 ) {
858
+        if ((float) $this->get_initial_amount() == 0 && $times_billed > 0) {
859 859
             $times_billed--;
860 860
         }
861 861
 
@@ -870,52 +870,52 @@  discard block
 block discarded – undo
870 870
 	 * @param  WPInv_Invoice $invoice If adding an existing invoice.
871 871
      * @return bool
872 872
      */
873
-    public function add_payment( $args = array(), $invoice = false ) {
873
+    public function add_payment($args = array(), $invoice = false) {
874 874
 
875 875
 		// Process each payment once.
876
-        if ( ! empty( $args['transaction_id'] ) && $this->payment_exists( $args['transaction_id'] ) ) {
876
+        if (!empty($args['transaction_id']) && $this->payment_exists($args['transaction_id'])) {
877 877
             return false;
878 878
         }
879 879
 
880 880
 		// Are we creating a new invoice?
881
-		if ( empty( $invoice ) ) {
882
-			$invoice = $this->create_payment( false );
881
+		if (empty($invoice)) {
882
+			$invoice = $this->create_payment(false);
883 883
 
884
-			if ( empty( $invoice ) ) {
884
+			if (empty($invoice)) {
885 885
 				return false;
886 886
 			}
887 887
 		}
888 888
 
889 889
 		// Maybe set a transaction id.
890
-		if ( ! empty( $args['transaction_id'] ) ) {
891
-			$invoice->set_transaction_id( $args['transaction_id'] );
890
+		if (!empty($args['transaction_id'])) {
891
+			$invoice->set_transaction_id($args['transaction_id']);
892 892
 		}
893 893
 
894 894
 		// Set the completed date.
895
-		$invoice->set_completed_date( current_time( 'mysql' ) );
895
+		$invoice->set_completed_date(current_time('mysql'));
896 896
 
897 897
 		// And the gateway.
898
-		if ( ! empty( $args['gateway'] ) ) {
899
-			$invoice->set_gateway( $args['gateway'] );
898
+		if (!empty($args['gateway'])) {
899
+			$invoice->set_gateway($args['gateway']);
900 900
 		}
901 901
 
902
-		$invoice->set_status( 'wpi-renewal' );
902
+		$invoice->set_status('wpi-renewal');
903 903
 		$invoice->save();
904 904
 
905
-		if ( ! $invoice->exists() ) {
905
+		if (!$invoice->exists()) {
906 906
 			return false;
907 907
 		}
908 908
 
909
-		return $this->after_add_payment( $invoice );
909
+		return $this->after_add_payment($invoice);
910 910
 	}
911 911
 
912
-    public function after_add_payment( $invoice ) {
912
+    public function after_add_payment($invoice) {
913 913
 
914
-		do_action( 'getpaid_after_create_subscription_renewal_invoice', $invoice, $this );
915
-		do_action( 'wpinv_recurring_add_subscription_payment', $invoice, $this );
916
-        do_action( 'wpinv_recurring_record_payment', $invoice->get_id(), $this->get_parent_invoice_id(), $invoice->get_recurring_total(), $invoice->get_transaction_id() );
914
+		do_action('getpaid_after_create_subscription_renewal_invoice', $invoice, $this);
915
+		do_action('wpinv_recurring_add_subscription_payment', $invoice, $this);
916
+        do_action('wpinv_recurring_record_payment', $invoice->get_id(), $this->get_parent_invoice_id(), $invoice->get_recurring_total(), $invoice->get_transaction_id());
917 917
 
918
-        update_post_meta( $invoice->get_id(), '_wpinv_subscription_id', $this->id );
918
+        update_post_meta($invoice->get_id(), '_wpinv_subscription_id', $this->id);
919 919
 
920 920
         return $invoice->get_id();
921 921
 	}
@@ -927,53 +927,53 @@  discard block
 block discarded – undo
927 927
 	 * @param bool $save Whether we should save the invoice.
928 928
      * @return WPInv_Invoice|bool
929 929
      */
930
-    public function create_payment( $save = true ) {
930
+    public function create_payment($save = true) {
931 931
 
932 932
 		$parent_invoice = $this->get_parent_payment();
933 933
 
934
-		if ( ! $parent_invoice->exists() ) {
934
+		if (!$parent_invoice->exists()) {
935 935
 			return false;
936 936
 		}
937 937
 
938 938
 		// Duplicate the parent invoice.
939
-		$invoice = getpaid_duplicate_invoice( $parent_invoice );
940
-		$invoice->set_parent_id( $parent_invoice->get_id() );
941
-		$invoice->set_subscription_id( $this->get_id() );
942
-		$invoice->set_remote_subscription_id( $this->get_profile_id() );
939
+		$invoice = getpaid_duplicate_invoice($parent_invoice);
940
+		$invoice->set_parent_id($parent_invoice->get_id());
941
+		$invoice->set_subscription_id($this->get_id());
942
+		$invoice->set_remote_subscription_id($this->get_profile_id());
943 943
 
944 944
 		// Set invoice items.
945
-		$subscription_group = getpaid_get_invoice_subscription_group( $parent_invoice->get_id(), $this->get_id() );
946
-		$allowed_items      = empty( $subscription_group ) ? array( $this->get_product_id() ) : array_keys( $subscription_group['items'] );
945
+		$subscription_group = getpaid_get_invoice_subscription_group($parent_invoice->get_id(), $this->get_id());
946
+		$allowed_items      = empty($subscription_group) ? array($this->get_product_id()) : array_keys($subscription_group['items']);
947 947
 		$invoice_items      = array();
948 948
 
949
-		foreach ( $invoice->get_items() as $item ) {
950
-			if ( in_array( $item->get_id(), $allowed_items ) ) {
949
+		foreach ($invoice->get_items() as $item) {
950
+			if (in_array($item->get_id(), $allowed_items)) {
951 951
 				$invoice_items[] = $item;
952 952
 			}
953 953
 		}
954 954
 
955
-		$invoice->set_items( $invoice_items );
955
+		$invoice->set_items($invoice_items);
956 956
 
957
-		if ( ! empty( $subscription_group['fees'] ) ) {
958
-			$invoice->set_fees( $subscription_group['fees'] );
957
+		if (!empty($subscription_group['fees'])) {
958
+			$invoice->set_fees($subscription_group['fees']);
959 959
 		}
960 960
 
961 961
 		// Maybe recalculate discount (Pre-GetPaid Fix).
962
-		$discount = new WPInv_Discount( $invoice->get_discount_code() );
962
+		$discount = new WPInv_Discount($invoice->get_discount_code());
963 963
 
964
-		if ( $discount->exists() && $discount->is_recurring() ) {
965
-			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
966
-		}  else {
964
+		if ($discount->exists() && $discount->is_recurring()) {
965
+			$invoice->add_discount(getpaid_calculate_invoice_discount($invoice, $discount));
966
+		} else {
967 967
 			// Unset discount code.
968
-			$invoice->set_discount_code( '' );
968
+			$invoice->set_discount_code('');
969 969
 
970
-			$invoice->remove_discount( 'discount_code' );
970
+			$invoice->remove_discount('discount_code');
971 971
 		}
972 972
 
973 973
 		$invoice->recalculate_total();
974
-		$invoice->set_status( 'wpi-pending' );
974
+		$invoice->set_status('wpi-pending');
975 975
 
976
-		if ( ! $save ) {
976
+		if (!$save) {
977 977
 			return $invoice;
978 978
 		}
979 979
 
@@ -988,28 +988,28 @@  discard block
 block discarded – undo
988 988
 	 * @since  1.0.0
989 989
 	 * @return int The subscription's id
990 990
 	 */
991
-	public function renew( $calculate_from = null, $_new_expiration = null ) {
991
+	public function renew($calculate_from = null, $_new_expiration = null) {
992 992
 		// Complete subscription if applicable
993
-		if ( $this->is_last_renewal() ) {
993
+		if ($this->is_last_renewal()) {
994 994
 			return $this->complete();
995 995
 		}
996 996
 
997
-		if ( ! empty( $_new_expiration ) ) {
997
+		if (!empty($_new_expiration)) {
998 998
 			$new_expiration = $_new_expiration;
999 999
 		} else {
1000 1000
 			// Calculate new expiration
1001 1001
 			$frequency      = $this->get_frequency();
1002 1002
 			$period         = $this->get_period();
1003
-			$calculate_from = empty( $calculate_from ) ? $this->get_expiration_time() : $calculate_from;
1004
-			$new_expiration = strtotime( "+ $frequency $period", $calculate_from );
1005
-			$new_expiration = date( 'Y-m-d H:i:s', $new_expiration );
1003
+			$calculate_from = empty($calculate_from) ? $this->get_expiration_time() : $calculate_from;
1004
+			$new_expiration = strtotime("+ $frequency $period", $calculate_from);
1005
+			$new_expiration = date('Y-m-d H:i:s', $new_expiration);
1006 1006
 		}
1007 1007
 
1008
-		$this->set_expiration( $new_expiration );
1009
-		$this->set_status( 'active' );
1008
+		$this->set_expiration($new_expiration);
1009
+		$this->set_status('active');
1010 1010
 		$this->save();
1011 1011
 
1012
-		do_action( 'getpaid_subscription_renewed', $this );
1012
+		do_action('getpaid_subscription_renewed', $this);
1013 1013
 
1014 1014
 		return $this->get_id();
1015 1015
 	}
@@ -1025,11 +1025,11 @@  discard block
 block discarded – undo
1025 1025
 	public function complete() {
1026 1026
 
1027 1027
 		// Only mark a subscription as complete if it's not already cancelled.
1028
-		if ( $this->has_status( 'cancelled' ) ) {
1028
+		if ($this->has_status('cancelled')) {
1029 1029
 			return false;
1030 1030
 		}
1031 1031
 
1032
-		$this->set_status( 'completed' );
1032
+		$this->set_status('completed');
1033 1033
 		return $this->save();
1034 1034
 
1035 1035
 	}
@@ -1041,14 +1041,14 @@  discard block
 block discarded – undo
1041 1041
 	 * @param  bool $check_expiration
1042 1042
 	 * @return int|bool Subscription id or false if $check_expiration is true and expiration date is in the future.
1043 1043
 	 */
1044
-	public function expire( $check_expiration = false ) {
1044
+	public function expire($check_expiration = false) {
1045 1045
 
1046
-		if ( $check_expiration && $this->get_expiration_time() > current_time( 'timestamp' ) ) {
1046
+		if ($check_expiration && $this->get_expiration_time() > current_time('timestamp')) {
1047 1047
 			// Do not mark as expired since real expiration date is in the future
1048 1048
 			return false;
1049 1049
 		}
1050 1050
 
1051
-		$this->set_status( 'expired' );
1051
+		$this->set_status('expired');
1052 1052
 		return $this->save();
1053 1053
 
1054 1054
 	}
@@ -1060,7 +1060,7 @@  discard block
 block discarded – undo
1060 1060
 	 * @return int Subscription id.
1061 1061
 	 */
1062 1062
 	public function failing() {
1063
-		$this->set_status( 'failing' );
1063
+		$this->set_status('failing');
1064 1064
 		return $this->save();
1065 1065
 	}
1066 1066
 
@@ -1071,7 +1071,7 @@  discard block
 block discarded – undo
1071 1071
      * @return int Subscription id.
1072 1072
      */
1073 1073
     public function cancel() {
1074
-		$this->set_status( 'cancelled' );
1074
+		$this->set_status('cancelled');
1075 1075
 		return $this->save();
1076 1076
     }
1077 1077
 
@@ -1082,7 +1082,7 @@  discard block
 block discarded – undo
1082 1082
 	 * @return bool
1083 1083
 	 */
1084 1084
 	public function can_cancel() {
1085
-		return apply_filters( 'wpinv_subscription_can_cancel', $this->has_status( $this->get_cancellable_statuses() ), $this );
1085
+		return apply_filters('wpinv_subscription_can_cancel', $this->has_status($this->get_cancellable_statuses()), $this);
1086 1086
 	}
1087 1087
 
1088 1088
     /**
@@ -1093,7 +1093,7 @@  discard block
 block discarded – undo
1093 1093
      * @return      array
1094 1094
      */
1095 1095
     public function get_cancellable_statuses() {
1096
-        return apply_filters( 'wpinv_recurring_cancellable_statuses', array( 'active', 'trialling', 'failing' ) );
1096
+        return apply_filters('wpinv_recurring_cancellable_statuses', array('active', 'trialling', 'failing'));
1097 1097
     }
1098 1098
 
1099 1099
 	/**
@@ -1103,8 +1103,8 @@  discard block
 block discarded – undo
1103 1103
 	 * @return string
1104 1104
 	 */
1105 1105
 	public function get_cancel_url() {
1106
-		$url = getpaid_get_authenticated_action_url( 'subscription_cancel', $this->get_view_url() );
1107
-		return apply_filters( 'wpinv_subscription_cancel_url', $url, $this );
1106
+		$url = getpaid_get_authenticated_action_url('subscription_cancel', $this->get_view_url());
1107
+		return apply_filters('wpinv_subscription_cancel_url', $url, $this);
1108 1108
 	}
1109 1109
 
1110 1110
 	/**
@@ -1115,10 +1115,10 @@  discard block
 block discarded – undo
1115 1115
 	 */
1116 1116
 	public function get_view_url() {
1117 1117
 
1118
-		$url = getpaid_get_tab_url( 'gp-subscriptions', get_permalink( (int) wpinv_get_option( 'invoice_subscription_page' ) ) );
1119
-		$url = add_query_arg( 'subscription', $this->get_id(), $url );
1118
+		$url = getpaid_get_tab_url('gp-subscriptions', get_permalink((int) wpinv_get_option('invoice_subscription_page')));
1119
+		$url = add_query_arg('subscription', $this->get_id(), $url);
1120 1120
 
1121
-		return apply_filters( 'getpaid_get_subscription_view_url', $url, $this );
1121
+		return apply_filters('getpaid_get_subscription_view_url', $url, $this);
1122 1122
 	}
1123 1123
 
1124 1124
 	/**
@@ -1131,7 +1131,7 @@  discard block
 block discarded – undo
1131 1131
 	 * @return bool
1132 1132
 	 */
1133 1133
 	public function can_renew() {
1134
-		return apply_filters( 'wpinv_subscription_can_renew', true, $this );
1134
+		return apply_filters('wpinv_subscription_can_renew', true, $this);
1135 1135
 	}
1136 1136
 
1137 1137
 	/**
@@ -1150,7 +1150,7 @@  discard block
 block discarded – undo
1150 1150
             ),
1151 1151
             'getpaid-nonce'
1152 1152
         );
1153
-		return apply_filters( 'wpinv_subscription_renew_url', $url, $this );
1153
+		return apply_filters('wpinv_subscription_renew_url', $url, $this);
1154 1154
 	}
1155 1155
 
1156 1156
 	/**
@@ -1160,7 +1160,7 @@  discard block
 block discarded – undo
1160 1160
 	 * @return bool
1161 1161
 	 */
1162 1162
 	public function can_update() {
1163
-		return apply_filters( 'wpinv_subscription_can_update', false, $this );
1163
+		return apply_filters('wpinv_subscription_can_update', false, $this);
1164 1164
 	}
1165 1165
 
1166 1166
 	/**
@@ -1176,7 +1176,7 @@  discard block
 block discarded – undo
1176 1176
 				'subscription_id' => $this->get_id(),
1177 1177
             )
1178 1178
         );
1179
-		return apply_filters( 'wpinv_subscription_update_url', $url, $this );
1179
+		return apply_filters('wpinv_subscription_update_url', $url, $this);
1180 1180
 	}
1181 1181
 
1182 1182
 	/**
@@ -1186,7 +1186,7 @@  discard block
 block discarded – undo
1186 1186
 	 * @return string
1187 1187
 	 */
1188 1188
 	public function get_status_label() {
1189
-		return getpaid_get_subscription_status_label( $this->get_status() );
1189
+		return getpaid_get_subscription_status_label($this->get_status());
1190 1190
 	}
1191 1191
 
1192 1192
 	/**
@@ -1197,7 +1197,7 @@  discard block
 block discarded – undo
1197 1197
 	 */
1198 1198
 	public function get_status_class() {
1199 1199
 		$statuses = getpaid_get_subscription_status_classes();
1200
-		return isset( $statuses[ $this->get_status() ] ) ? $statuses[ $this->get_status() ] : 'bg-dark';
1200
+		return isset($statuses[$this->get_status()]) ? $statuses[$this->get_status()] : 'bg-dark';
1201 1201
 	}
1202 1202
 
1203 1203
     /**
@@ -1208,9 +1208,9 @@  discard block
 block discarded – undo
1208 1208
      */
1209 1209
     public function get_status_label_html() {
1210 1210
 
1211
-		$status_label = sanitize_text_field( $this->get_status_label() );
1212
-		$class        = esc_attr( $this->get_status_class() );
1213
-		$status       = sanitize_html_class( $this->get_status() );
1211
+		$status_label = sanitize_text_field($this->get_status_label());
1212
+		$class        = esc_attr($this->get_status_class());
1213
+		$status       = sanitize_html_class($this->get_status());
1214 1214
 
1215 1215
 		return "<span class='bsui'><span class='badge $class $status'>$status_label</span></span>";
1216 1216
     }
@@ -1222,9 +1222,9 @@  discard block
 block discarded – undo
1222 1222
      * @param  string $txn_id The transaction ID from the merchant processor
1223 1223
      * @return bool
1224 1224
      */
1225
-    public function payment_exists( $txn_id = '' ) {
1226
-		$invoice_id = WPInv_Invoice::get_invoice_id_by_field( $txn_id, 'transaction_id' );
1227
-        return ! empty( $invoice_id );
1225
+    public function payment_exists($txn_id = '') {
1226
+		$invoice_id = WPInv_Invoice::get_invoice_id_by_field($txn_id, 'transaction_id');
1227
+        return !empty($invoice_id);
1228 1228
 	}
1229 1229
 
1230 1230
 	/**
@@ -1236,35 +1236,35 @@  discard block
 block discarded – undo
1236 1236
 		// Reset status transition variable.
1237 1237
 		$this->status_transition = false;
1238 1238
 
1239
-		if ( $status_transition ) {
1239
+		if ($status_transition) {
1240 1240
 			try {
1241 1241
 
1242 1242
 				// Fire a hook for the status change.
1243
-				do_action( 'wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition );
1244
-				do_action( 'getpaid_subscription_' . $status_transition['to'], $this, $status_transition );
1243
+				do_action('wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition);
1244
+				do_action('getpaid_subscription_' . $status_transition['to'], $this, $status_transition);
1245 1245
 
1246
-				if ( ! empty( $status_transition['from'] ) ) {
1246
+				if (!empty($status_transition['from'])) {
1247 1247
 
1248 1248
 					/* translators: 1: old subscription status 2: new subscription status */
1249
-					$transition_note = sprintf( __( 'Subscription status changed from %1$s to %2$s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['from'] ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1249
+					$transition_note = sprintf(__('Subscription status changed from %1$s to %2$s.', 'invoicing'), getpaid_get_subscription_status_label($status_transition['from']), getpaid_get_subscription_status_label($status_transition['to']));
1250 1250
 
1251 1251
 					// Note the transition occurred.
1252
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1252
+					$this->get_parent_payment()->add_note($transition_note, false, false, true);
1253 1253
 
1254 1254
 					// Fire another hook.
1255
-					do_action( 'getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this );
1256
-					do_action( 'getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to'] );
1255
+					do_action('getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this);
1256
+					do_action('getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to']);
1257 1257
 
1258 1258
 				} else {
1259 1259
 					/* translators: %s: new invoice status */
1260
-					$transition_note = sprintf( __( 'Subscription status set to %s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1260
+					$transition_note = sprintf(__('Subscription status set to %s.', 'invoicing'), getpaid_get_subscription_status_label($status_transition['to']));
1261 1261
 
1262 1262
 					// Note the transition occurred.
1263
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1263
+					$this->get_parent_payment()->add_note($transition_note, false, false, true);
1264 1264
 
1265 1265
 				}
1266
-			} catch ( Exception $e ) {
1267
-				$this->get_parent_payment()->add_note( __( 'Error during subscription status transition.', 'invoicing' ) . ' ' . $e->getMessage() );
1266
+			} catch (Exception $e) {
1267
+				$this->get_parent_payment()->add_note(__('Error during subscription status transition.', 'invoicing') . ' ' . $e->getMessage());
1268 1268
 			}
1269 1269
 		}
1270 1270
 
@@ -1290,7 +1290,7 @@  discard block
 block discarded – undo
1290 1290
 	 */
1291 1291
 	public function activate() {
1292 1292
 		$status = $this->has_trial_period() && 'trialling' === $this->get_status() ? 'trialling' : 'active';
1293
-		$this->set_status( $status );
1293
+		$this->set_status($status);
1294 1294
 		return $this->save();
1295 1295
 	}
1296 1296
 
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 3 patches
Braces   +42 added lines, -44 removed lines patch added patch discarded remove patch
@@ -60,7 +60,7 @@  discard block
 block discarded – undo
60 60
 			if(!empty($this->options['nested-block'])){
61 61
 				if(empty($this->options['output_types'])){
62 62
 					$this->options['output_types'] = array('shortcode','block');
63
-				}elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
63
+				} elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64 64
 					unset($this->options['output_types'][$key]);
65 65
 				}
66 66
 			}
@@ -716,7 +716,7 @@  discard block
 block discarded – undo
716 716
 				<?php
717 717
 				if(! empty( $insert_shortcode_function )){
718 718
 					echo $insert_shortcode_function;
719
-				}else{
719
+				} else{
720 720
 
721 721
 				/**
722 722
 				 * Function for super duper insert shortcode.
@@ -2240,7 +2240,7 @@  discard block
 block discarded – undo
2240 2240
 				$p_pl = 'ps-';
2241 2241
 				$p_pr = 'pe-';
2242 2242
 					<?php
2243
-				}else{
2243
+				} else{
2244 2244
 						?>
2245 2245
 				$aui_bs5 = false;
2246 2246
 				$p_ml = 'ml-';
@@ -2468,7 +2468,7 @@  discard block
 block discarded – undo
2468 2468
 					var InnerBlocks = blockEditor.InnerBlocks;
2469 2469
 
2470 2470
 					var term_query_type = '';
2471
-					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";}else{echo "[]";} ?>;
2471
+					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";} else{echo "[]";} ?>;
2472 2472
 					const taxonomies_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2473 2473
 					const sort_by_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2474 2474
 					const MediaUpload = wp.blockEditor.MediaUpload;
@@ -2525,9 +2525,9 @@  discard block
 block discarded – undo
2525 2525
 						$example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2526 2526
 						if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2527 2527
 							// no preview if set to false
2528
-						}elseif( !empty( $example_args ) ){
2528
+						} elseif( !empty( $example_args ) ){
2529 2529
 							echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2530
-						}elseif( !empty( $this->options['example'] ) ){
2530
+						} elseif( !empty( $this->options['example'] ) ){
2531 2531
 							unset($this->options['example']['viewportWidth']);
2532 2532
 							unset($this->options['example']['innerBlocks']);
2533 2533
 							$example_atts = $this->array_to_attributes( $this->options['example'] );
@@ -2544,7 +2544,7 @@  discard block
 block discarded – undo
2544 2544
 							if(!empty($example_parts)){
2545 2545
 								echo "example : {".implode(',', $example_parts)."},";
2546 2546
 							}
2547
-						}else{
2547
+						} else{
2548 2548
 							echo 'example : {viewportWidth: 500},';
2549 2549
 						}
2550 2550
 
@@ -2615,8 +2615,7 @@  discard block
 block discarded – undo
2615 2615
 
2616 2616
 									if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2617 2617
 										continue;
2618
-									}
2619
-									elseif ( $args['type'] == 'checkbox' ) {
2618
+									} elseif ( $args['type'] == 'checkbox' ) {
2620 2619
 										$type    = 'boolean';
2621 2620
 										$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2622 2621
 									} elseif ( $args['type'] == 'number' ) {
@@ -2752,7 +2751,7 @@  discard block
 block discarded – undo
2752 2751
 							<?php
2753 2752
 							if(!empty($this->options['block-edit-raw'])) {
2754 2753
 								echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2755
-							}else{
2754
+							} else{
2756 2755
 							?>
2757 2756
 
2758 2757
 function hasSelectedInnerBlock(props) {
@@ -2887,7 +2886,7 @@  discard block
 block discarded – undo
2887 2886
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2888 2887
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2889 2888
 	echo 'const { deviceType } = "";';
2890
-}else{
2889
+} else{
2891 2890
 ?>
2892 2891
 /** Get device type const. */
2893 2892
 const wpVersion = '<?php global $wp_version; echo esc_attr($wp_version); ?>';
@@ -2951,7 +2950,7 @@  discard block
 block discarded – undo
2951 2950
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2952 2951
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2953 2952
 										echo $post->ID;
2954
-									}else{echo '0';}?>,
2953
+									} else{echo '0';}?>,
2955 2954
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2956 2955
 									};
2957 2956
 
@@ -2971,7 +2970,7 @@  discard block
 block discarded – undo
2971 2970
 										is_fetching = false;
2972 2971
 										prev_attributes[props.clientId] = props.attributes;
2973 2972
 											 <?php
2974
-										}else{
2973
+										} else{
2975 2974
 										?>
2976 2975
 										props.setAttributes({content: env});
2977 2976
 										is_fetching = false;
@@ -3182,7 +3181,7 @@  discard block
 block discarded – undo
3182 3181
 //
3183 3182
 
3184 3183
 									}
3185
-									}else {
3184
+									} else {
3186 3185
 									?>
3187 3186
 									el(wp.components.PanelBody, {
3188 3187
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
@@ -3208,9 +3207,9 @@  discard block
 block discarded – undo
3208 3207
 								// If the user sets block-output array then build it
3209 3208
 								if ( ! empty( $this->options['block-output'] ) ) {
3210 3209
 								$this->block_element( $this->options['block-output'] );
3211
-							}elseif(!empty($this->options['block-edit-return'])){
3210
+							} elseif(!empty($this->options['block-edit-return'])){
3212 3211
 								   echo $this->options['block-edit-return'];
3213
-							}else{
3212
+							} else{
3214 3213
 								// if no block-output is set then we try and get the shortcode html output via ajax.
3215 3214
 								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3216 3215
 								?>
@@ -3322,9 +3321,9 @@  discard block
 block discarded – undo
3322 3321
 							   );
3323 3322
 								<?php
3324 3323
 
3325
-							}elseif(!empty($this->options['block-save-return'])){
3324
+							} elseif(!empty($this->options['block-save-return'])){
3326 3325
 								   echo 'return ' . $this->options['block-save-return'];
3327
-							}elseif(!empty($this->options['nested-block'])){
3326
+							} elseif(!empty($this->options['nested-block'])){
3328 3327
 								?>
3329 3328
 							  return el(
3330 3329
 								   '',
@@ -3334,13 +3333,13 @@  discard block
 block discarded – undo
3334 3333
 								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3335 3334
 							   );
3336 3335
 								<?php
3337
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3336
+							} elseif(!empty( $this->options['block-save-return'] ) ){
3338 3337
 								echo "return ". $this->options['block-edit-return'].";";
3339
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3338
+							} elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3340 3339
 							?>
3341 3340
 							return content;
3342 3341
 							<?php
3343
-							}else{
3342
+							} else{
3344 3343
 							?>
3345 3344
 							var block_wrap = 'div';
3346 3345
 							if (attr.hasOwnProperty("block_wrap")) {
@@ -3391,9 +3390,9 @@  discard block
 block discarded – undo
3391 3390
 				$device_type_icon = '';
3392 3391
 				if($device_type=='Desktop'){
3393 3392
 					$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3394
-				}elseif($device_type=='Tablet'){
3393
+				} elseif($device_type=='Tablet'){
3395 3394
 					$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3396
-				}elseif($device_type=='Mobile'){
3395
+				} elseif($device_type=='Mobile'){
3397 3396
 					$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3398 3397
 				}
3399 3398
 				echo $element_require;
@@ -3438,7 +3437,7 @@  discard block
 block discarded – undo
3438 3437
 
3439 3438
 					<?php
3440 3439
 					if(false){?></script><?php }
3441
-				}elseif(!empty($args['row']['close'])){
3440
+				} elseif(!empty($args['row']['close'])){
3442 3441
 					if(false){?><script><?php }?>
3443 3442
 						el(
3444 3443
 							'div',
@@ -3447,7 +3446,7 @@  discard block
 block discarded – undo
3447 3446
 							},
3448 3447
 					<?php
3449 3448
 					if(false){?></script><?php }
3450
-				}else{
3449
+				} else{
3451 3450
 					if(false){?><script><?php }?>
3452 3451
 						el(
3453 3452
 							'div',
@@ -3552,9 +3551,9 @@  discard block
 block discarded – undo
3552 3551
 			$device_type_icon = '';
3553 3552
 			if($device_type=='Desktop'){
3554 3553
 				$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3555
-			}elseif($device_type=='Tablet'){
3554
+			} elseif($device_type=='Tablet'){
3556 3555
 				$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3557
-			}elseif($device_type=='Mobile'){
3556
+			} elseif($device_type=='Mobile'){
3558 3557
 				$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3559 3558
 			}
3560 3559
 
@@ -3617,7 +3616,7 @@  discard block
 block discarded – undo
3617 3616
 				$args['type'] == 'text';
3618 3617
 				// Save numbers as numbers and not strings
3619 3618
 				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3620
-			}else if ( $args['type'] == 'notice' ) {
3619
+			} else if ( $args['type'] == 'notice' ) {
3621 3620
 
3622 3621
 				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3623 3622
 				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
@@ -3692,7 +3691,7 @@  discard block
 block discarded – undo
3692 3691
 							$key: value
3693 3692
 						});
3694 3693
 					},";
3695
-			}elseif ( $args['type'] == 'gradient' ) {
3694
+			} elseif ( $args['type'] == 'gradient' ) {
3696 3695
 				$type = 'GradientPicker';
3697 3696
 				$extra .= "gradients: [{
3698 3697
 			name: 'Vivid cyan blue to vivid purple',
@@ -3731,7 +3730,7 @@  discard block
 block discarded – undo
3731 3730
 			slug: 'cool-to-warm-spectrum',
3732 3731
 		}],";
3733 3732
 
3734
-			}elseif ( $args['type'] == 'image' ) {
3733
+			} elseif ( $args['type'] == 'image' ) {
3735 3734
 //                print_r($args);
3736 3735
 
3737 3736
 				$img_preview = isset($args['focalpoint']) && !$args['focalpoint'] ? " props.attributes.$key && el('img', { src: props.attributes.$key,style: {maxWidth:'100%',background: '#ccc'}})," : " ( props.attributes.$key ||  props.attributes.{$key}_use_featured ) && el(wp.components.FocalPointPicker,{
@@ -3868,8 +3867,7 @@  discard block
 block discarded – undo
3868 3867
 				$onchange = "";
3869 3868
 
3870 3869
 				//$inside_elements = ",el('div',{},'file upload')";
3871
-			}
3872
-			elseif ( $args['type'] == 'checkbox' ) {
3870
+			} elseif ( $args['type'] == 'checkbox' ) {
3873 3871
 				$type = 'CheckboxControl';
3874 3872
 				$extra .= "checked: props.attributes.$key,";
3875 3873
 				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
@@ -3881,9 +3879,9 @@  discard block
 block discarded – undo
3881 3879
 
3882 3880
 				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3883 3881
 					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3884
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3882
+				} elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3885 3883
 					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3886
-				}else {
3884
+				} else {
3887 3885
 
3888 3886
 					if ( ! empty( $args['options'] ) ) {
3889 3887
 						$options .= "options: [";
@@ -4047,7 +4045,7 @@  discard block
 block discarded – undo
4047 4045
 				foreach ( $custom_attributes as $key => $val ) {
4048 4046
 					if(is_array($val)){
4049 4047
 						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4050
-					}else{
4048
+					} else{
4051 4049
 						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4052 4050
 					}
4053 4051
 				}
@@ -4088,7 +4086,7 @@  discard block
 block discarded – undo
4088 4086
 
4089 4087
 							if($new_args['element']=='InnerBlocks'){
4090 4088
 								echo "\n el( InnerBlocks, {";
4091
-							}elseif($new_args['element']=='innerBlocksProps'){
4089
+							} elseif($new_args['element']=='innerBlocksProps'){
4092 4090
 								$element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4093 4091
 							  //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4094 4092
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
@@ -4101,11 +4099,11 @@  discard block
 block discarded – undo
4101 4099
 							//    echo '###';
4102 4100
 
4103 4101
 							  //  echo '###';
4104
-							}elseif($new_args['element']=='BlocksProps'){
4102
+							} elseif($new_args['element']=='BlocksProps'){
4105 4103
 
4106 4104
 								if ( isset($new_args['if_inner_element']) ) {
4107 4105
 									$element = $new_args['if_inner_element'];
4108
-								}else {
4106
+								} else {
4109 4107
 									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4110 4108
 								}
4111 4109
 
@@ -4116,7 +4114,7 @@  discard block
 block discarded – undo
4116 4114
 
4117 4115
 							   // echo "} ),";
4118 4116
 
4119
-							}else{
4117
+							} else{
4120 4118
 								echo "\n el( '" . $new_args['element'] . "', {";
4121 4119
 							}
4122 4120
 
@@ -4141,7 +4139,7 @@  discard block
 block discarded – undo
4141 4139
 
4142 4140
 									if ( $new_key === 'content' ) {
4143 4141
 										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4144
-									}else if ( $new_key === 'if_content' ) {
4142
+									} else if ( $new_key === 'if_content' ) {
4145 4143
 										echo  $this->block_props_replace(  $new_value  );
4146 4144
 									}
4147 4145
 
@@ -4171,7 +4169,7 @@  discard block
 block discarded – undo
4171 4169
 
4172 4170
 							if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4173 4171
 								echo "))";// end content
4174
-							}else{
4172
+							} else{
4175 4173
 								echo ")";// end content
4176 4174
 							}
4177 4175
 
@@ -4795,11 +4793,11 @@  discard block
 block discarded – undo
4795 4793
 		public function get_widget_icon($icon = 'box-top', $title = ''){
4796 4794
 			if($icon=='box-top'){
4797 4795
 				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
4798
-			}elseif($icon=='box-right'){
4796
+			} elseif($icon=='box-right'){
4799 4797
 				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
4800
-			}elseif($icon=='box-bottom'){
4798
+			} elseif($icon=='box-bottom'){
4801 4799
 				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
4802
-			}elseif($icon=='box-left'){
4800
+			} elseif($icon=='box-left'){
4803 4801
 				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
4804 4802
 			}
4805 4803
 		}
Please login to merge, or discard this patch.
Indentation   +2687 added lines, -2687 removed lines patch added patch discarded remove patch
@@ -1,147 +1,147 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 if ( ! class_exists( 'WP_Super_Duper' ) ) {
7 7
 
8
-	define( 'SUPER_DUPER_VER', '1.2.22' );
9
-
10
-	/**
11
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
-	 *
13
-	 * Should not be called direct but extended instead.
14
-	 *
15
-	 * Class WP_Super_Duper
16
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
-	 * @ver 1.1.1
18
-	 */
19
-	class WP_Super_Duper extends WP_Widget {
20
-
21
-		public $version = SUPER_DUPER_VER;
22
-		public $font_awesome_icon_version = "5.11.2";
23
-		public $block_code;
24
-		public $options;
25
-		public $base_id;
26
-		public $settings_hash;
27
-		public $arguments = array();
28
-		public $instance = array();
29
-		private $class_name;
30
-
31
-		/**
32
-		 * The relative url to the current folder.
33
-		 *
34
-		 * @var string
35
-		 */
36
-		public $url = '';
37
-
38
-		/**
39
-		 * Take the array options and use them to build.
40
-		 */
41
-		public function __construct( $options ) {
42
-			global $sd_widgets;
43
-
44
-			$sd_widgets[ $options['base_id'] ] = array(
45
-				'name'       => $options['name'],
46
-				'class_name' => $options['class_name'],
47
-				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
-			);
49
-			$this->base_id                     = $options['base_id'];
50
-			// lets filter the options before we do anything
51
-			$options       = apply_filters( "wp_super_duper_options", $options );
52
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
-			$options       = $this->add_name_from_key( $options );
54
-			$this->options = $options;
55
-
56
-			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58
-
59
-			// nested blocks can't work as a widget
60
-			if(!empty($this->options['nested-block'])){
61
-				if(empty($this->options['output_types'])){
62
-					$this->options['output_types'] = array('shortcode','block');
63
-				}elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
-					unset($this->options['output_types'][$key]);
65
-				}
66
-			}
8
+    define( 'SUPER_DUPER_VER', '1.2.22' );
9
+
10
+    /**
11
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
+     *
13
+     * Should not be called direct but extended instead.
14
+     *
15
+     * Class WP_Super_Duper
16
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
+     * @ver 1.1.1
18
+     */
19
+    class WP_Super_Duper extends WP_Widget {
20
+
21
+        public $version = SUPER_DUPER_VER;
22
+        public $font_awesome_icon_version = "5.11.2";
23
+        public $block_code;
24
+        public $options;
25
+        public $base_id;
26
+        public $settings_hash;
27
+        public $arguments = array();
28
+        public $instance = array();
29
+        private $class_name;
67 30
 
68
-			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
-				parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
-			}
31
+        /**
32
+         * The relative url to the current folder.
33
+         *
34
+         * @var string
35
+         */
36
+        public $url = '';
37
+
38
+        /**
39
+         * Take the array options and use them to build.
40
+         */
41
+        public function __construct( $options ) {
42
+            global $sd_widgets;
43
+
44
+            $sd_widgets[ $options['base_id'] ] = array(
45
+                'name'       => $options['name'],
46
+                'class_name' => $options['class_name'],
47
+                'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
+            );
49
+            $this->base_id                     = $options['base_id'];
50
+            // lets filter the options before we do anything
51
+            $options       = apply_filters( "wp_super_duper_options", $options );
52
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
+            $options       = $this->add_name_from_key( $options );
54
+            $this->options = $options;
55
+
56
+            $this->base_id   = $options['base_id'];
57
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58
+
59
+            // nested blocks can't work as a widget
60
+            if(!empty($this->options['nested-block'])){
61
+                if(empty($this->options['output_types'])){
62
+                    $this->options['output_types'] = array('shortcode','block');
63
+                }elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
+                    unset($this->options['output_types'][$key]);
65
+                }
66
+            }
72 67
 
68
+            // init parent
69
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
+                parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
+            }
73 72
 
74
-			if ( isset( $options['class_name'] ) ) {
75
-				// register widget
76
-				$this->class_name = $options['class_name'];
77 73
 
78
-				// register shortcode, this needs to be done even for blocks and widgets
79
-				$this->register_shortcode();
74
+            if ( isset( $options['class_name'] ) ) {
75
+                // register widget
76
+                $this->class_name = $options['class_name'];
80 77
 
78
+                // register shortcode, this needs to be done even for blocks and widgets
79
+                $this->register_shortcode();
81 80
 
82
-				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
85
-				}
81
+
82
+                // Fusion Builder (avada) support
83
+                if ( function_exists( 'fusion_builder_map' ) ) {
84
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
85
+                }
86 86
 
87 87
                 // maybe load the Bricks transformer class
88 88
                 if( class_exists('\Bricks\Elements', false) ){
89
-					add_action( 'init', array( $this, 'load_bricks_element_class' ) );
89
+                    add_action( 'init', array( $this, 'load_bricks_element_class' ) );
90 90
                 }
91 91
 
92
-				// register block
93
-				if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
94
-					add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
95
-				}
96
-			}
92
+                // register block
93
+                if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
94
+                    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
95
+                }
96
+            }
97 97
 
98
-			// add the CSS and JS we need ONCE
99
-			global $sd_widget_scripts;
98
+            // add the CSS and JS we need ONCE
99
+            global $sd_widget_scripts;
100 100
 
101
-			if ( ! $sd_widget_scripts ) {
102
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
103
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
104
-				wp_add_inline_style( 'widgets', $this->widget_css() );
101
+            if ( ! $sd_widget_scripts ) {
102
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
103
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
104
+                wp_add_inline_style( 'widgets', $this->widget_css() );
105 105
 
106
-				// maybe add elementor editor styles
107
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
106
+                // maybe add elementor editor styles
107
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
108 108
 
109
-				$sd_widget_scripts = true;
109
+                $sd_widget_scripts = true;
110 110
 
111
-				// add shortcode insert button once
112
-				add_action( 'media_buttons', array( $this, 'wp_media_buttons' ), 1 );
113
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
114
-				// generatepress theme sections compatibility
115
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
116
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
117
-				}
118
-				/* Load script on Divi theme builder page */
119
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
120
-					add_thickbox();
121
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
122
-				}
111
+                // add shortcode insert button once
112
+                add_action( 'media_buttons', array( $this, 'wp_media_buttons' ), 1 );
113
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
114
+                // generatepress theme sections compatibility
115
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
116
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
117
+                }
118
+                /* Load script on Divi theme builder page */
119
+                if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
120
+                    add_thickbox();
121
+                    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
122
+                }
123 123
 
124
-				if ( $this->is_preview() ) {
125
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
126
-					// this makes the insert button work for elementor
127
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
128
-						$this,
129
-						'shortcode_insert_button_script'
130
-					) ); // for elementor
131
-				}
132
-				// this makes the insert button work for cornerstone
133
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
124
+                if ( $this->is_preview() ) {
125
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
126
+                    // this makes the insert button work for elementor
127
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
128
+                        $this,
129
+                        'shortcode_insert_button_script'
130
+                    ) ); // for elementor
131
+                }
132
+                // this makes the insert button work for cornerstone
133
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
134 134
 
135
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
136
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
135
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
136
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
137 137
 
138
-				// add generator text to head
139
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
140
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
141
-			}
138
+                // add generator text to head
139
+                add_action( 'admin_head', array( $this, 'generator' ), 99 );
140
+                add_action( 'wp_head', array( $this, 'generator' ), 99 );
141
+            }
142 142
 
143
-			do_action( 'wp_super_duper_widget_init', $options, $this );
144
-		}
143
+            do_action( 'wp_super_duper_widget_init', $options, $this );
144
+        }
145 145
 
146 146
         /**
147 147
          * Load the Bricks conversion class if we are running Bricks.
@@ -151,163 +151,163 @@  discard block
 block discarded – undo
151 151
                     include_once __DIR__ . '/includes/class-super-duper-bricks-element.php';
152 152
         }
153 153
 
154
-		/**
155
-		 * The register widget function
156
-		 * @return void
157
-		 */
158
-		public function _register() {
159
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
160
-				parent::_register();
161
-			}
162
-		}
163
-
164
-		/**
165
-		 * Add our widget CSS to elementor editor.
166
-		 */
167
-		public function elementor_editor_styles() {
168
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
169
-		}
170
-
171
-		public function register_fusion_element() {
172
-
173
-			$options = $this->options;
174
-
175
-			if ( $this->base_id ) {
176
-
177
-				$params = $this->get_fusion_params();
178
-
179
-				$args = array(
180
-					'name'            => $options['name'],
181
-					'shortcode'       => $this->base_id,
182
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
183
-					'allow_generator' => true,
184
-				);
185
-
186
-				if ( ! empty( $params ) ) {
187
-					$args['params'] = $params;
188
-				}
189
-
190
-				fusion_builder_map( $args );
191
-			}
154
+        /**
155
+         * The register widget function
156
+         * @return void
157
+         */
158
+        public function _register() {
159
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
160
+                parent::_register();
161
+            }
162
+        }
192 163
 
193
-		}
164
+        /**
165
+         * Add our widget CSS to elementor editor.
166
+         */
167
+        public function elementor_editor_styles() {
168
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
169
+        }
194 170
 
195
-		public function get_fusion_params() {
196
-			$params    = array();
197
-			$arguments = $this->get_arguments();
198
-
199
-			if ( ! empty( $arguments ) ) {
200
-				foreach ( $arguments as $key => $val ) {
201
-					$param = array();
202
-					// type
203
-					$param['type'] = str_replace(
204
-						array(
205
-							"text",
206
-							"number",
207
-							"email",
208
-							"color",
209
-							"checkbox"
210
-						),
211
-						array(
212
-							"textfield",
213
-							"textfield",
214
-							"textfield",
215
-							"colorpicker",
216
-							"select",
171
+        public function register_fusion_element() {
217 172
 
218
-						),
219
-						$val['type'] );
173
+            $options = $this->options;
220 174
 
221
-					// multiselect
222
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
223
-						$param['type']     = 'multiple_select';
224
-						$param['multiple'] = true;
225
-					}
175
+            if ( $this->base_id ) {
226 176
 
227
-					// heading
228
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
177
+                $params = $this->get_fusion_params();
229 178
 
230
-					// description
231
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
179
+                $args = array(
180
+                    'name'            => $options['name'],
181
+                    'shortcode'       => $this->base_id,
182
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
183
+                    'allow_generator' => true,
184
+                );
232 185
 
233
-					// param_name
234
-					$param['param_name'] = $key;
186
+                if ( ! empty( $params ) ) {
187
+                    $args['params'] = $params;
188
+                }
235 189
 
236
-					// Default
237
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
190
+                fusion_builder_map( $args );
191
+            }
238 192
 
239
-					// Group
240
-					if ( isset( $val['group'] ) ) {
241
-						$param['group'] = $val['group'];
242
-					}
193
+        }
243 194
 
244
-					// value
245
-					if ( $val['type'] == 'checkbox' ) {
246
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
247
-							unset( $param['default'] );
248
-						}
249
-						$param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
250
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
251
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
252
-					} else {
253
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
254
-					}
195
+        public function get_fusion_params() {
196
+            $params    = array();
197
+            $arguments = $this->get_arguments();
198
+
199
+            if ( ! empty( $arguments ) ) {
200
+                foreach ( $arguments as $key => $val ) {
201
+                    $param = array();
202
+                    // type
203
+                    $param['type'] = str_replace(
204
+                        array(
205
+                            "text",
206
+                            "number",
207
+                            "email",
208
+                            "color",
209
+                            "checkbox"
210
+                        ),
211
+                        array(
212
+                            "textfield",
213
+                            "textfield",
214
+                            "textfield",
215
+                            "colorpicker",
216
+                            "select",
217
+
218
+                        ),
219
+                        $val['type'] );
220
+
221
+                    // multiselect
222
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
223
+                        $param['type']     = 'multiple_select';
224
+                        $param['multiple'] = true;
225
+                    }
226
+
227
+                    // heading
228
+                    $param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
229
+
230
+                    // description
231
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
232
+
233
+                    // param_name
234
+                    $param['param_name'] = $key;
235
+
236
+                    // Default
237
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
238
+
239
+                    // Group
240
+                    if ( isset( $val['group'] ) ) {
241
+                        $param['group'] = $val['group'];
242
+                    }
243
+
244
+                    // value
245
+                    if ( $val['type'] == 'checkbox' ) {
246
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
247
+                            unset( $param['default'] );
248
+                        }
249
+                        $param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
250
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
251
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
252
+                    } else {
253
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
254
+                    }
255
+
256
+                    // setup the param
257
+                    $params[] = $param;
255 258
 
256
-					// setup the param
257
-					$params[] = $param;
259
+                }
260
+            }
258 261
 
259
-				}
260
-			}
261 262
 
263
+            return $params;
264
+        }
262 265
 
263
-			return $params;
264
-		}
266
+        /**
267
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
268
+         */
269
+        public static function maybe_cornerstone_builder() {
270
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
271
+                self::shortcode_insert_button_script();
272
+            }
273
+        }
265 274
 
266
-		/**
267
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
268
-		 */
269
-		public static function maybe_cornerstone_builder() {
270
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
271
-				self::shortcode_insert_button_script();
272
-			}
273
-		}
275
+        /**
276
+         * A function to ge the shortcode builder picker html.
277
+         *
278
+         * @param string $editor_id
279
+         *
280
+         * @return string
281
+         */
282
+        public static function get_picker( $editor_id = '' ) {
274 283
 
275
-		/**
276
-		 * A function to ge the shortcode builder picker html.
277
-		 *
278
-		 * @param string $editor_id
279
-		 *
280
-		 * @return string
281
-		 */
282
-		public static function get_picker( $editor_id = '' ) {
283
-
284
-			ob_start();
285
-			if ( isset( $_POST['editor_id'] ) ) {
286
-				$editor_id = esc_attr( $_POST['editor_id'] );
287
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
288
-				$editor_id = 'main_content_content_vb_tiny_mce';
289
-			}
284
+            ob_start();
285
+            if ( isset( $_POST['editor_id'] ) ) {
286
+                $editor_id = esc_attr( $_POST['editor_id'] );
287
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
288
+                $editor_id = 'main_content_content_vb_tiny_mce';
289
+            }
290 290
 
291
-			global $sd_widgets;
291
+            global $sd_widgets;
292 292
 
293 293
 //			print_r($sd_widgets);exit;
294
-			?>
294
+            ?>
295 295
 
296 296
 			<div class="sd-shortcode-left-wrap">
297 297
 				<?php
298
-				ksort( $sd_widgets );
299
-				//				print_r($sd_widgets);exit;
300
-				if ( ! empty( $sd_widgets ) ) {
301
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
302
-					echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
303
-					foreach ( $sd_widgets as $shortcode => $class ) {
304
-						if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
305
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
306
-					}
307
-					echo "</select>";
298
+                ksort( $sd_widgets );
299
+                //				print_r($sd_widgets);exit;
300
+                if ( ! empty( $sd_widgets ) ) {
301
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
302
+                    echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
303
+                    foreach ( $sd_widgets as $shortcode => $class ) {
304
+                        if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
305
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
306
+                    }
307
+                    echo "</select>";
308 308
 
309
-				}
310
-				?>
309
+                }
310
+                ?>
311 311
 				<div class="sd-shortcode-settings"></div>
312 312
 
313 313
 			</div>
@@ -318,8 +318,8 @@  discard block
 block discarded – undo
318 318
 					<?php if ( $editor_id != '' ) { ?>
319 319
 						<button class="button sd-insert-shortcode-button"
320 320
 								onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
321
-									echo "'" . $editor_id . "'";
322
-								} ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
321
+                                    echo "'" . $editor_id . "'";
322
+                                } ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
323 323
 					<?php } ?>
324 324
 					<button class="button"
325 325
 							onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -327,150 +327,150 @@  discard block
 block discarded – undo
327 327
 			</div>
328 328
 			<?php
329 329
 
330
-			$html = ob_get_clean();
330
+            $html = ob_get_clean();
331 331
 
332
-			if ( wp_doing_ajax() ) {
333
-				echo $html;
334
-				$should_die = true;
332
+            if ( wp_doing_ajax() ) {
333
+                echo $html;
334
+                $should_die = true;
335 335
 
336
-				// some builder get the editor via ajax so we should not die on those occasions
337
-				$dont_die = array(
338
-					'parent_tag',// WP Bakery
339
-					'avia_request' // enfold
340
-				);
336
+                // some builder get the editor via ajax so we should not die on those occasions
337
+                $dont_die = array(
338
+                    'parent_tag',// WP Bakery
339
+                    'avia_request' // enfold
340
+                );
341 341
 
342
-				foreach ( $dont_die as $request ) {
343
-					if ( isset( $_REQUEST[ $request ] ) ) {
344
-						$should_die = false;
345
-					}
346
-				}
342
+                foreach ( $dont_die as $request ) {
343
+                    if ( isset( $_REQUEST[ $request ] ) ) {
344
+                        $should_die = false;
345
+                    }
346
+                }
347 347
 
348
-				if ( $should_die ) {
349
-					wp_die();
350
-				}
348
+                if ( $should_die ) {
349
+                    wp_die();
350
+                }
351 351
 
352
-			} else {
353
-				return $html;
354
-			}
352
+            } else {
353
+                return $html;
354
+            }
355 355
 
356
-			return '';
356
+            return '';
357 357
 
358
-		}
358
+        }
359 359
 
360
-		/**
361
-		 * Output the version in the header.
362
-		 */
363
-		public function generator() {
364
-			$file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
365
-			$plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
366
-
367
-			// Find source plugin/theme of SD
368
-			$source = array();
369
-			if ( strpos( $file, $plugins_dir ) !== false ) {
370
-				$source = explode( "/", plugin_basename( $file ) );
371
-			} else if ( function_exists( 'get_theme_root' ) ) {
372
-				$themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
373
-
374
-				if ( strpos( $file, $themes_dir ) !== false ) {
375
-					$source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
376
-				}
377
-			}
360
+        /**
361
+         * Output the version in the header.
362
+         */
363
+        public function generator() {
364
+            $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
365
+            $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
366
+
367
+            // Find source plugin/theme of SD
368
+            $source = array();
369
+            if ( strpos( $file, $plugins_dir ) !== false ) {
370
+                $source = explode( "/", plugin_basename( $file ) );
371
+            } else if ( function_exists( 'get_theme_root' ) ) {
372
+                $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
373
+
374
+                if ( strpos( $file, $themes_dir ) !== false ) {
375
+                    $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
376
+                }
377
+            }
378 378
 
379
-			echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
380
-		}
379
+            echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
380
+        }
381 381
 
382
-		/**
383
-		 * Get widget settings.
384
-		 *
385
-		 * @since 1.0.0
386
-		 */
387
-		public static function get_widget_settings() {
388
-			global $sd_widgets;
389
-
390
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
391
-			if ( ! $shortcode ) {
392
-				wp_die();
393
-			}
394
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
395
-			if ( ! $widget_args ) {
396
-				wp_die();
397
-			}
398
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
-			if ( ! $class_name ) {
400
-				wp_die();
401
-			}
382
+        /**
383
+         * Get widget settings.
384
+         *
385
+         * @since 1.0.0
386
+         */
387
+        public static function get_widget_settings() {
388
+            global $sd_widgets;
402 389
 
403
-			// invoke an instance method
404
-			$widget = new $class_name;
390
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
391
+            if ( ! $shortcode ) {
392
+                wp_die();
393
+            }
394
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
395
+            if ( ! $widget_args ) {
396
+                wp_die();
397
+            }
398
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
+            if ( ! $class_name ) {
400
+                wp_die();
401
+            }
402
+
403
+            // invoke an instance method
404
+            $widget = new $class_name;
405 405
 
406
-			ob_start();
407
-			$widget->form( array() );
408
-			$form = ob_get_clean();
409
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
410
-			echo "<style>" . $widget->widget_css() . "</style>";
411
-			echo "<script>" . $widget->widget_js() . "</script>";
412
-			?>
406
+            ob_start();
407
+            $widget->form( array() );
408
+            $form = ob_get_clean();
409
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
410
+            echo "<style>" . $widget->widget_css() . "</style>";
411
+            echo "<script>" . $widget->widget_js() . "</script>";
412
+            ?>
413 413
 			<?php
414
-			wp_die();
415
-		}
414
+            wp_die();
415
+        }
416 416
 
417
-		/**
418
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
419
-		 *
420
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
421
-		 * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
422
-		 *
423
-		 *@since 1.0.0
424
-		 *
425
-		 */
426
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
427
-			global $sd_widgets, $shortcode_insert_button_once;
428
-			if ( $shortcode_insert_button_once ) {
429
-				return;
430
-			}
431
-			add_thickbox();
417
+        /**
418
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
419
+         *
420
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
421
+         * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
422
+         *
423
+         *@since 1.0.0
424
+         *
425
+         */
426
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
427
+            global $sd_widgets, $shortcode_insert_button_once;
428
+            if ( $shortcode_insert_button_once ) {
429
+                return;
430
+            }
431
+            add_thickbox();
432 432
 
433 433
 
434
-			/**
435
-			 * Cornerstone makes us play dirty tricks :/
436
-			 * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
437
-			 */
438
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
439
-				echo '<span id="insert-media-button">';
440
-			}
434
+            /**
435
+             * Cornerstone makes us play dirty tricks :/
436
+             * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
437
+             */
438
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
439
+                echo '<span id="insert-media-button">';
440
+            }
441 441
 
442
-			echo self::shortcode_button( 'this', 'true' );
442
+            echo self::shortcode_button( 'this', 'true' );
443 443
 
444
-			// see opening note
445
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
446
-				echo '</span>'; // end #insert-media-button
447
-			}
444
+            // see opening note
445
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
446
+                echo '</span>'; // end #insert-media-button
447
+            }
448 448
 
449
-			// Add separate script for generatepress theme sections
450
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
451
-			} else {
452
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
453
-			}
449
+            // Add separate script for generatepress theme sections
450
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
451
+            } else {
452
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
453
+            }
454 454
 
455
-			$shortcode_insert_button_once = true;
456
-		}
455
+            $shortcode_insert_button_once = true;
456
+        }
457 457
 
458
-		/**
459
-		 * Gets the shortcode insert button html.
460
-		 *
461
-		 * @param string $id
462
-		 * @param string $search_for_id
463
-		 *
464
-		 * @return mixed
465
-		 */
466
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
467
-			ob_start();
468
-			?>
458
+        /**
459
+         * Gets the shortcode insert button html.
460
+         *
461
+         * @param string $id
462
+         * @param string $search_for_id
463
+         *
464
+         * @return mixed
465
+         */
466
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
467
+            ob_start();
468
+            ?>
469 469
 			<span class="sd-lable-shortcode-inserter">
470 470
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
471
-				if ( $search_for_id ) {
472
-					echo "," . $search_for_id;
473
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
471
+                if ( $search_for_id ) {
472
+                    echo "," . $search_for_id;
473
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
474 474
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
475 475
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
476 476
 						  class="dashicons dashicons-screenoptions"></span>
@@ -481,21 +481,21 @@  discard block
 block discarded – undo
481 481
 			</span>
482 482
 
483 483
 			<?php
484
-			$html = ob_get_clean();
484
+            $html = ob_get_clean();
485 485
 
486
-			// remove line breaks so we can use it in js
487
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
488
-		}
486
+            // remove line breaks so we can use it in js
487
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
488
+        }
489 489
 
490
-		/**
491
-		 * Makes SD work with the siteOrigin page builder.
492
-		 *
493
-		 * @return mixed
494
-		 *@since 1.0.6
495
-		 */
496
-		public static function siteorigin_js() {
497
-			ob_start();
498
-			?>
490
+        /**
491
+         * Makes SD work with the siteOrigin page builder.
492
+         *
493
+         * @return mixed
494
+         *@since 1.0.6
495
+         */
496
+        public static function siteorigin_js() {
497
+            ob_start();
498
+            ?>
499 499
 			<script>
500 500
 				/**
501 501
 				 * Check a form to see what items should be shown or hidden.
@@ -571,29 +571,29 @@  discard block
 block discarded – undo
571 571
 				});
572 572
 			</script>
573 573
 			<?php
574
-			$output = ob_get_clean();
574
+            $output = ob_get_clean();
575 575
 
576
-			/*
576
+            /*
577 577
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
578 578
 			 */
579 579
 
580
-			return str_replace( array(
581
-				'<script>',
582
-				'</script>'
583
-			), '', $output );
584
-		}
580
+            return str_replace( array(
581
+                '<script>',
582
+                '</script>'
583
+            ), '', $output );
584
+        }
585 585
 
586
-		/**
587
-		 * Output the JS and CSS for the shortcode insert button.
588
-		 *
589
-		 * @param string $editor_id
590
-		 * @param string $insert_shortcode_function
591
-		 *
592
-		 *@since 1.0.6
593
-		 *
594
-		 */
595
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
596
-			?>
586
+        /**
587
+         * Output the JS and CSS for the shortcode insert button.
588
+         *
589
+         * @param string $editor_id
590
+         * @param string $insert_shortcode_function
591
+         *
592
+         *@since 1.0.6
593
+         *
594
+         */
595
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
596
+            ?>
597 597
 			<style>
598 598
 				.sd-shortcode-left-wrap {
599 599
 					float: left;
@@ -721,35 +721,35 @@  discard block
 block discarded – undo
721 721
 				<?php } ?>
722 722
 			</style>
723 723
 			<?php
724
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
725
-				echo "<script>" . self::siteorigin_js() . "</script>";
726
-			}
727
-			?>
724
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
725
+                echo "<script>" . self::siteorigin_js() . "</script>";
726
+            }
727
+            ?>
728 728
 			<script>
729 729
 				<?php
730
-				if(! empty( $insert_shortcode_function )){
731
-					echo $insert_shortcode_function;
732
-				}else{
733
-
734
-				/**
735
-				 * Function for super duper insert shortcode.
736
-				 *
737
-				 * @since 1.0.0
738
-				 */
739
-				?>
730
+                if(! empty( $insert_shortcode_function )){
731
+                    echo $insert_shortcode_function;
732
+                }else{
733
+
734
+                /**
735
+                 * Function for super duper insert shortcode.
736
+                 *
737
+                 * @since 1.0.0
738
+                 */
739
+                ?>
740 740
 				function sd_insert_shortcode($editor_id) {
741 741
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
742 742
 					if ($shortcode) {
743 743
 						if (!$editor_id) {
744 744
 							<?php
745
-							if ( isset( $_REQUEST['et_fb'] ) ) {
746
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
747
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
748
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
749
-							} else {
750
-								echo '$editor_id = "#wp-content-editor-container textarea";';
751
-							}
752
-							?>
745
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
746
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
747
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
748
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
749
+                            } else {
750
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
751
+                            }
752
+                            ?>
753 753
 						} else {
754 754
 							$editor_id = '#' + $editor_id;
755 755
 						}
@@ -1063,18 +1063,18 @@  discard block
 block discarded – undo
1063 1063
 				}
1064 1064
 			</script>
1065 1065
 			<?php
1066
-		}
1066
+        }
1067 1067
 
1068
-		/**
1069
-		 * Gets some CSS for the widgets screen.
1070
-		 *
1071
-		 * @param bool $advanced If we should include advanced CSS.
1072
-		 *
1073
-		 * @return mixed
1074
-		 */
1075
-		public function widget_css( $advanced = true ) {
1076
-			ob_start();
1077
-			?>
1068
+        /**
1069
+         * Gets some CSS for the widgets screen.
1070
+         *
1071
+         * @param bool $advanced If we should include advanced CSS.
1072
+         *
1073
+         * @return mixed
1074
+         */
1075
+        public function widget_css( $advanced = true ) {
1076
+            ob_start();
1077
+            ?>
1078 1078
 			<style>
1079 1079
 				<?php if( $advanced ){ ?>
1080 1080
 				.sd-advanced-setting {
@@ -1114,26 +1114,26 @@  discard block
 block discarded – undo
1114 1114
 				.elementor-control .sd-argument select[multiple] option{padding:3px}
1115 1115
 			</style>
1116 1116
 			<?php
1117
-			$output = ob_get_clean();
1117
+            $output = ob_get_clean();
1118 1118
 
1119
-			/*
1119
+            /*
1120 1120
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1121 1121
 			 */
1122 1122
 
1123
-			return str_replace( array(
1124
-				'<style>',
1125
-				'</style>'
1126
-			), '', $output );
1127
-		}
1123
+            return str_replace( array(
1124
+                '<style>',
1125
+                '</style>'
1126
+            ), '', $output );
1127
+        }
1128 1128
 
1129
-		/**
1130
-		 * Gets some JS for the widgets screen.
1131
-		 *
1132
-		 * @return mixed
1133
-		 */
1134
-		public function widget_js() {
1135
-			ob_start();
1136
-			?>
1129
+        /**
1130
+         * Gets some JS for the widgets screen.
1131
+         *
1132
+         * @return mixed
1133
+         */
1134
+        public function widget_js() {
1135
+            ob_start();
1136
+            ?>
1137 1137
 			<script>
1138 1138
 
1139 1139
 				/**
@@ -1284,517 +1284,517 @@  discard block
 block discarded – undo
1284 1284
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1285 1285
 			</script>
1286 1286
 			<?php
1287
-			$output = ob_get_clean();
1287
+            $output = ob_get_clean();
1288 1288
 
1289
-			/*
1289
+            /*
1290 1290
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1291 1291
 			 */
1292 1292
 
1293
-			return str_replace( array(
1294
-				'<script>',
1295
-				'</script>'
1296
-			), '', $output );
1297
-		}
1293
+            return str_replace( array(
1294
+                '<script>',
1295
+                '</script>'
1296
+            ), '', $output );
1297
+        }
1298 1298
 
1299 1299
 
1300
-		/**
1301
-		 * Set the name from the argument key.
1302
-		 *
1303
-		 * @param $options
1304
-		 *
1305
-		 * @return mixed
1306
-		 */
1307
-		private function add_name_from_key( $options, $arguments = false ) {
1308
-			if ( ! empty( $options['arguments'] ) ) {
1309
-				foreach ( $options['arguments'] as $key => $val ) {
1310
-					$options['arguments'][ $key ]['name'] = $key;
1311
-				}
1312
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1313
-				foreach ( $options as $key => $val ) {
1314
-					$options[ $key ]['name'] = $key;
1315
-				}
1316
-			}
1300
+        /**
1301
+         * Set the name from the argument key.
1302
+         *
1303
+         * @param $options
1304
+         *
1305
+         * @return mixed
1306
+         */
1307
+        private function add_name_from_key( $options, $arguments = false ) {
1308
+            if ( ! empty( $options['arguments'] ) ) {
1309
+                foreach ( $options['arguments'] as $key => $val ) {
1310
+                    $options['arguments'][ $key ]['name'] = $key;
1311
+                }
1312
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1313
+                foreach ( $options as $key => $val ) {
1314
+                    $options[ $key ]['name'] = $key;
1315
+                }
1316
+            }
1317 1317
 
1318
-			return $options;
1319
-		}
1318
+            return $options;
1319
+        }
1320 1320
 
1321
-		/**
1322
-		 * Register the parent shortcode.
1323
-		 *
1324
-		 * @since 1.0.0
1325
-		 */
1326
-		public function register_shortcode() {
1327
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1328
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1329
-		}
1321
+        /**
1322
+         * Register the parent shortcode.
1323
+         *
1324
+         * @since 1.0.0
1325
+         */
1326
+        public function register_shortcode() {
1327
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1328
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1329
+        }
1330 1330
 
1331
-		/**
1332
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1333
-		 *
1334
-		 * @since 1.0.0
1335
-		 */
1336
-		public function render_shortcode() {
1337
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1338
-			if ( ! current_user_can( 'manage_options' ) ) {
1339
-				wp_die();
1340
-			}
1331
+        /**
1332
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1333
+         *
1334
+         * @since 1.0.0
1335
+         */
1336
+        public function render_shortcode() {
1337
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1338
+            if ( ! current_user_can( 'manage_options' ) ) {
1339
+                wp_die();
1340
+            }
1341 1341
 
1342
-			// we might need the $post value here so lets set it.
1343
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1344
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1345
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1346
-					global $post;
1347
-					$post = $post_obj;
1348
-				}
1349
-			}
1342
+            // we might need the $post value here so lets set it.
1343
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1344
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1345
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1346
+                    global $post;
1347
+                    $post = $post_obj;
1348
+                }
1349
+            }
1350 1350
 
1351
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1352
-				$is_preview = $this->is_preview();
1353
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1354
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1355
-				$attributes       = '';
1356
-				if ( ! empty( $attributes_array ) ) {
1357
-					foreach ( $attributes_array as $key => $value ) {
1358
-						if ( is_array( $value ) ) {
1359
-							$value = implode( ",", $value );
1360
-						}
1351
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1352
+                $is_preview = $this->is_preview();
1353
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1354
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1355
+                $attributes       = '';
1356
+                if ( ! empty( $attributes_array ) ) {
1357
+                    foreach ( $attributes_array as $key => $value ) {
1358
+                        if ( is_array( $value ) ) {
1359
+                            $value = implode( ",", $value );
1360
+                        }
1361
+
1362
+                        if ( ! empty( $value ) ) {
1363
+                            $value = wp_unslash( $value );
1364
+
1365
+                            // Encode [ and ].
1366
+                            if ( $is_preview ) {
1367
+                                $value = $this->encode_shortcodes( $value );
1368
+                            }
1369
+                        }
1370
+                        $attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1371
+                    }
1372
+                }
1361 1373
 
1362
-						if ( ! empty( $value ) ) {
1363
-							$value = wp_unslash( $value );
1374
+                $shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1364 1375
 
1365
-							// Encode [ and ].
1366
-							if ( $is_preview ) {
1367
-								$value = $this->encode_shortcodes( $value );
1368
-							}
1369
-						}
1370
-						$attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1371
-					}
1372
-				}
1376
+                $content = do_shortcode( $shortcode );
1373 1377
 
1374
-				$shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1378
+                // Decode [ and ].
1379
+                if ( ! empty( $content ) && $is_preview ) {
1380
+                    $content = $this->decode_shortcodes( $content );
1381
+                }
1375 1382
 
1376
-				$content = do_shortcode( $shortcode );
1383
+                echo $content;
1384
+            }
1385
+            wp_die();
1386
+        }
1377 1387
 
1378
-				// Decode [ and ].
1379
-				if ( ! empty( $content ) && $is_preview ) {
1380
-					$content = $this->decode_shortcodes( $content );
1381
-				}
1388
+        /**
1389
+         * Output the shortcode.
1390
+         *
1391
+         * @param array $args
1392
+         * @param string $content
1393
+         *
1394
+         * @return string
1395
+         */
1396
+        public function shortcode_output( $args = array(), $content = '' ) {
1397
+            $_instance = $args;
1382 1398
 
1383
-				echo $content;
1384
-			}
1385
-			wp_die();
1386
-		}
1399
+            $args = $this->argument_values( $args );
1387 1400
 
1388
-		/**
1389
-		 * Output the shortcode.
1390
-		 *
1391
-		 * @param array $args
1392
-		 * @param string $content
1393
-		 *
1394
-		 * @return string
1395
-		 */
1396
-		public function shortcode_output( $args = array(), $content = '' ) {
1397
-			$_instance = $args;
1398
-
1399
-			$args = $this->argument_values( $args );
1400
-
1401
-			// add extra argument so we know its a output to gutenberg
1402
-			//$args
1403
-			$args = $this->string_to_bool( $args );
1404
-
1405
-			// if we have a enclosed shortcode we add it to the special `html` argument
1406
-			if ( ! empty( $content ) ) {
1407
-				$args['html'] = $content;
1408
-			}
1401
+            // add extra argument so we know its a output to gutenberg
1402
+            //$args
1403
+            $args = $this->string_to_bool( $args );
1409 1404
 
1410
-			if ( ! $this->is_preview() ) {
1411
-				/**
1412
-				 * Filters the settings for a particular widget args.
1413
-				 *
1414
-				 * @param array          $args      The current widget instance's settings.
1415
-				 * @param WP_Super_Duper $widget    The current widget settings.
1416
-				 * @param array          $_instance An array of default widget arguments.
1417
-				 *
1418
-				 *@since 1.0.28
1419
-				 *
1420
-				 */
1421
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1405
+            // if we have a enclosed shortcode we add it to the special `html` argument
1406
+            if ( ! empty( $content ) ) {
1407
+                $args['html'] = $content;
1408
+            }
1422 1409
 
1423
-				if ( ! is_array( $args ) ) {
1424
-					return $args;
1425
-				}
1426
-			}
1410
+            if ( ! $this->is_preview() ) {
1411
+                /**
1412
+                 * Filters the settings for a particular widget args.
1413
+                 *
1414
+                 * @param array          $args      The current widget instance's settings.
1415
+                 * @param WP_Super_Duper $widget    The current widget settings.
1416
+                 * @param array          $_instance An array of default widget arguments.
1417
+                 *
1418
+                 *@since 1.0.28
1419
+                 *
1420
+                 */
1421
+                $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1422
+
1423
+                if ( ! is_array( $args ) ) {
1424
+                    return $args;
1425
+                }
1426
+            }
1427 1427
 
1428
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1429
-			$class .= " sdel-".$this->get_instance_hash();
1428
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1429
+            $class .= " sdel-".$this->get_instance_hash();
1430 1430
 
1431
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1432
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1431
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1432
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1433 1433
 
1434
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1435
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1434
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1435
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1436 1436
 
1437
-			$shortcode_args = array();
1438
-			$output         = '';
1439
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1440
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1441
-				$no_wrap = true;
1442
-			}
1443
-			$main_content = $this->output( $args, $shortcode_args, $content );
1444
-			if ( $main_content && ! $no_wrap ) {
1445
-				// wrap the shortcode in a div with the same class as the widget
1446
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1447
-				if ( ! empty( $args['title'] ) ) {
1448
-					// if its a shortcode and there is a title try to grab the title wrappers
1449
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1450
-					if ( empty( $instance ) ) {
1451
-						global $wp_registered_sidebars;
1452
-						if ( ! empty( $wp_registered_sidebars ) ) {
1453
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1454
-								if ( ! empty( $sidebar['before_title'] ) ) {
1455
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1456
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1457
-									break;
1458
-								}
1459
-							}
1460
-						}
1461
-					}
1462
-					$output .= $this->output_title( $shortcode_args, $args );
1463
-				}
1464
-				$output .= $main_content;
1465
-				$output .= '</div>';
1466
-			} elseif ( $main_content && $no_wrap ) {
1467
-				$output .= $main_content;
1468
-			}
1437
+            $shortcode_args = array();
1438
+            $output         = '';
1439
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1440
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1441
+                $no_wrap = true;
1442
+            }
1443
+            $main_content = $this->output( $args, $shortcode_args, $content );
1444
+            if ( $main_content && ! $no_wrap ) {
1445
+                // wrap the shortcode in a div with the same class as the widget
1446
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1447
+                if ( ! empty( $args['title'] ) ) {
1448
+                    // if its a shortcode and there is a title try to grab the title wrappers
1449
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1450
+                    if ( empty( $instance ) ) {
1451
+                        global $wp_registered_sidebars;
1452
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1453
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1454
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1455
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1456
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1457
+                                    break;
1458
+                                }
1459
+                            }
1460
+                        }
1461
+                    }
1462
+                    $output .= $this->output_title( $shortcode_args, $args );
1463
+                }
1464
+                $output .= $main_content;
1465
+                $output .= '</div>';
1466
+            } elseif ( $main_content && $no_wrap ) {
1467
+                $output .= $main_content;
1468
+            }
1469 1469
 
1470
-			// if preview show a placeholder if empty
1471
-			if ( $this->is_preview() && $output == '' ) {
1472
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1473
-			}
1470
+            // if preview show a placeholder if empty
1471
+            if ( $this->is_preview() && $output == '' ) {
1472
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1473
+            }
1474 1474
 
1475
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1476
-		}
1475
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1476
+        }
1477 1477
 
1478
-		/**
1479
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1480
-		 *
1481
-		 * @param string $name
1482
-		 *
1483
-		 * @return string
1484
-		 */
1485
-		public function preview_placeholder_text( $name = '' ) {
1486
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1487
-		}
1478
+        /**
1479
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1480
+         *
1481
+         * @param string $name
1482
+         *
1483
+         * @return string
1484
+         */
1485
+        public function preview_placeholder_text( $name = '' ) {
1486
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1487
+        }
1488 1488
 
1489
-		/**
1490
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1491
-		 *
1492
-		 * @param $options
1493
-		 *
1494
-		 * @return mixed
1495
-		 */
1496
-		public function string_to_bool( $options ) {
1497
-			// convert bool strings to booleans
1498
-			foreach ( $options as $key => $val ) {
1499
-				if ( $val == 'false' ) {
1500
-					$options[ $key ] = false;
1501
-				} elseif ( $val == 'true' ) {
1502
-					$options[ $key ] = true;
1503
-				}
1504
-			}
1489
+        /**
1490
+         * Sometimes booleans values can be turned to strings, so we fix that.
1491
+         *
1492
+         * @param $options
1493
+         *
1494
+         * @return mixed
1495
+         */
1496
+        public function string_to_bool( $options ) {
1497
+            // convert bool strings to booleans
1498
+            foreach ( $options as $key => $val ) {
1499
+                if ( $val == 'false' ) {
1500
+                    $options[ $key ] = false;
1501
+                } elseif ( $val == 'true' ) {
1502
+                    $options[ $key ] = true;
1503
+                }
1504
+            }
1505 1505
 
1506
-			return $options;
1507
-		}
1506
+            return $options;
1507
+        }
1508 1508
 
1509
-		/**
1510
-		 * Get the argument values that are also filterable.
1511
-		 *
1512
-		 * @param $instance
1513
-		 *
1514
-		 * @return array
1515
-		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1516
-		 *
1517
-		 */
1518
-		public function argument_values( $instance ) {
1519
-			$argument_values = array();
1520
-
1521
-			// set widget instance
1522
-			$this->instance = $instance;
1523
-
1524
-			if ( empty( $this->arguments ) ) {
1525
-				$this->arguments = $this->get_arguments();
1526
-			}
1509
+        /**
1510
+         * Get the argument values that are also filterable.
1511
+         *
1512
+         * @param $instance
1513
+         *
1514
+         * @return array
1515
+         *@since 1.0.12 Don't set checkbox default value if the value is empty.
1516
+         *
1517
+         */
1518
+        public function argument_values( $instance ) {
1519
+            $argument_values = array();
1527 1520
 
1528
-			if ( ! empty( $this->arguments ) ) {
1529
-				foreach ( $this->arguments as $key => $args ) {
1530
-					// set the input name from the key
1531
-					$args['name'] = $key;
1532
-					//
1533
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1534
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1535
-						// don't set default for an empty checkbox
1536
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1537
-						$argument_values[ $key ] = $args['default'];
1538
-					}
1539
-				}
1540
-			}
1521
+            // set widget instance
1522
+            $this->instance = $instance;
1541 1523
 
1542
-			return $argument_values;
1543
-		}
1524
+            if ( empty( $this->arguments ) ) {
1525
+                $this->arguments = $this->get_arguments();
1526
+            }
1544 1527
 
1545
-		/**
1546
-		 * Set arguments in super duper.
1547
-		 *
1548
-		 * @return array Set arguments.
1549
-		 *@since 1.0.0
1550
-		 *
1551
-		 */
1552
-		public function set_arguments() {
1553
-			return $this->arguments;
1554
-		}
1528
+            if ( ! empty( $this->arguments ) ) {
1529
+                foreach ( $this->arguments as $key => $args ) {
1530
+                    // set the input name from the key
1531
+                    $args['name'] = $key;
1532
+                    //
1533
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1534
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1535
+                        // don't set default for an empty checkbox
1536
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1537
+                        $argument_values[ $key ] = $args['default'];
1538
+                    }
1539
+                }
1540
+            }
1555 1541
 
1556
-		/**
1557
-		 * Get arguments in super duper.
1558
-		 *
1559
-		 * @return array Get arguments.
1560
-		 *@since 1.0.0
1561
-		 *
1562
-		 */
1563
-		public function get_arguments() {
1564
-			if ( empty( $this->arguments ) ) {
1565
-				$this->arguments = $this->set_arguments();
1566
-			}
1542
+            return $argument_values;
1543
+        }
1544
+
1545
+        /**
1546
+         * Set arguments in super duper.
1547
+         *
1548
+         * @return array Set arguments.
1549
+         *@since 1.0.0
1550
+         *
1551
+         */
1552
+        public function set_arguments() {
1553
+            return $this->arguments;
1554
+        }
1555
+
1556
+        /**
1557
+         * Get arguments in super duper.
1558
+         *
1559
+         * @return array Get arguments.
1560
+         *@since 1.0.0
1561
+         *
1562
+         */
1563
+        public function get_arguments() {
1564
+            if ( empty( $this->arguments ) ) {
1565
+                $this->arguments = $this->set_arguments();
1566
+            }
1567 1567
 
1568
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1569
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1568
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1569
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1570 1570
 
1571 1571
             if( !empty( $this->arguments['title']['value'] ) ){
1572 1572
                 $this->arguments['title']['value'] = wp_kses_post( $this->arguments['title']['value'] );
1573 1573
             }
1574 1574
 
1575
-			return $this->arguments;
1576
-		}
1575
+            return $this->arguments;
1576
+        }
1577 1577
 
1578
-		/**
1579
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1580
-		 *
1581
-		 * @param array $args
1582
-		 * @param array $widget_args
1583
-		 * @param string $content
1584
-		 */
1585
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1578
+        /**
1579
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1580
+         *
1581
+         * @param array $args
1582
+         * @param array $widget_args
1583
+         * @param string $content
1584
+         */
1585
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1586 1586
 
1587
-		}
1587
+        }
1588 1588
 
1589
-		/**
1590
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1591
-		 */
1592
-		public function register_block() {
1593
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1594
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1595
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1596
-			}
1597
-		}
1589
+        /**
1590
+         * Add the dynamic block code inline when the wp-block in enqueued.
1591
+         */
1592
+        public function register_block() {
1593
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1594
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1595
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1596
+            }
1597
+        }
1598 1598
 
1599
-		/**
1600
-		 * Check if we need to show advanced options.
1601
-		 *
1602
-		 * @return bool
1603
-		 */
1604
-		public function block_show_advanced() {
1605
-
1606
-			$show      = false;
1607
-			$arguments = $this->get_arguments();
1608
-
1609
-			if ( ! empty( $arguments ) ) {
1610
-				foreach ( $arguments as $argument ) {
1611
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1612
-						$show = true;
1613
-						break; // no need to continue if we know we have it
1614
-					}
1615
-				}
1616
-			}
1599
+        /**
1600
+         * Check if we need to show advanced options.
1601
+         *
1602
+         * @return bool
1603
+         */
1604
+        public function block_show_advanced() {
1617 1605
 
1618
-			return $show;
1619
-		}
1606
+            $show      = false;
1607
+            $arguments = $this->get_arguments();
1620 1608
 
1621
-		/**
1622
-		 * Get the url path to the current folder.
1623
-		 *
1624
-		 * @return string
1625
-		 */
1626
-		public function get_url() {
1627
-			$url = $this->url;
1628
-
1629
-			if ( ! $url ) {
1630
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1631
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1632
-
1633
-				// Replace http:// to https://.
1634
-				if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1635
-					$content_url = str_replace( 'http://', 'https://', $content_url );
1636
-				}
1609
+            if ( ! empty( $arguments ) ) {
1610
+                foreach ( $arguments as $argument ) {
1611
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1612
+                        $show = true;
1613
+                        break; // no need to continue if we know we have it
1614
+                    }
1615
+                }
1616
+            }
1637 1617
 
1638
-				// Check if we are inside a plugin
1639
-				$file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1640
-				$url = str_replace( $content_dir, $content_url, $file_dir );
1641
-				$url = trailingslashit( $url );
1642
-				$this->url = $url;
1643
-			}
1618
+            return $show;
1619
+        }
1644 1620
 
1645
-			return $url;
1646
-		}
1621
+        /**
1622
+         * Get the url path to the current folder.
1623
+         *
1624
+         * @return string
1625
+         */
1626
+        public function get_url() {
1627
+            $url = $this->url;
1647 1628
 
1648
-		/**
1649
-		 * Get the url path to the current folder.
1650
-		 *
1651
-		 * @return string
1652
-		 */
1653
-		public function get_url_old() {
1629
+            if ( ! $url ) {
1630
+                $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1631
+                $content_url = untrailingslashit( WP_CONTENT_URL );
1654 1632
 
1655
-			$url = $this->url;
1633
+                // Replace http:// to https://.
1634
+                if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1635
+                    $content_url = str_replace( 'http://', 'https://', $content_url );
1636
+                }
1656 1637
 
1657
-			if ( ! $url ) {
1658
-				// check if we are inside a plugin
1659
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1638
+                // Check if we are inside a plugin
1639
+                $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1640
+                $url = str_replace( $content_dir, $content_url, $file_dir );
1641
+                $url = trailingslashit( $url );
1642
+                $this->url = $url;
1643
+            }
1660 1644
 
1661
-				$dir_parts = explode( "/wp-content/", $file_dir );
1662
-				$url_parts = explode( "/wp-content/", plugins_url() );
1645
+            return $url;
1646
+        }
1663 1647
 
1664
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1665
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1666
-					$this->url = $url;
1667
-				}
1668
-			}
1648
+        /**
1649
+         * Get the url path to the current folder.
1650
+         *
1651
+         * @return string
1652
+         */
1653
+        public function get_url_old() {
1669 1654
 
1655
+            $url = $this->url;
1670 1656
 
1671
-			return $url;
1672
-		}
1657
+            if ( ! $url ) {
1658
+                // check if we are inside a plugin
1659
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1673 1660
 
1674
-		/**
1675
-		 * Generate the block icon.
1676
-		 *
1677
-		 * Enables the use of Font Awesome icons.
1678
-		 *
1679
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1680
-		 *
1681
-		 * @param $icon
1682
-		 *
1683
-		 * @return string
1684
-		 *@since 1.1.0
1685
-		 */
1686
-		public function get_block_icon( $icon ) {
1687
-
1688
-			// check if we have a Font Awesome icon
1689
-			$fa_type = '';
1690
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1691
-				$fa_type = 'solid';
1692
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1693
-				$fa_type = 'regular';
1694
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1695
-				$fa_type = 'brands';
1696
-			} else {
1697
-				$icon = "'" . $icon . "'";
1698
-			}
1661
+                $dir_parts = explode( "/wp-content/", $file_dir );
1662
+                $url_parts = explode( "/wp-content/", plugins_url() );
1699 1663
 
1700
-			// set the icon if we found one
1701
-			if ( $fa_type ) {
1702
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1703
-				$icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1704
-			}
1664
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1665
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1666
+                    $this->url = $url;
1667
+                }
1668
+            }
1705 1669
 
1706
-			return $icon;
1707
-		}
1708 1670
 
1709
-		public function group_arguments( $arguments ) {
1710
-			if ( ! empty( $arguments ) ) {
1711
-				$temp_arguments = array();
1712
-				$general        = __( "General", 'ayecode-connect' );
1713
-				$add_sections   = false;
1714
-				foreach ( $arguments as $key => $args ) {
1715
-					if ( isset( $args['group'] ) ) {
1716
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1717
-						$add_sections                             = true;
1718
-					} else {
1719
-						$temp_arguments[ $general ][ $key ] = $args;
1720
-					}
1721
-				}
1671
+            return $url;
1672
+        }
1722 1673
 
1723
-				// only add sections if more than one
1724
-				if ( $add_sections ) {
1725
-					$arguments = $temp_arguments;
1726
-				}
1727
-			}
1674
+        /**
1675
+         * Generate the block icon.
1676
+         *
1677
+         * Enables the use of Font Awesome icons.
1678
+         *
1679
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1680
+         *
1681
+         * @param $icon
1682
+         *
1683
+         * @return string
1684
+         *@since 1.1.0
1685
+         */
1686
+        public function get_block_icon( $icon ) {
1687
+
1688
+            // check if we have a Font Awesome icon
1689
+            $fa_type = '';
1690
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1691
+                $fa_type = 'solid';
1692
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1693
+                $fa_type = 'regular';
1694
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1695
+                $fa_type = 'brands';
1696
+            } else {
1697
+                $icon = "'" . $icon . "'";
1698
+            }
1728 1699
 
1729
-			return $arguments;
1730
-		}
1700
+            // set the icon if we found one
1701
+            if ( $fa_type ) {
1702
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1703
+                $icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1704
+            }
1731 1705
 
1732
-		/**
1733
-		 * Parse used group tabs.
1734
-		 *
1735
-		 * @since 1.1.17
1736
-		 */
1737
-		public function group_block_tabs( $tabs, $arguments ) {
1738
-			if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1739
-				$has_sections = false;
1740
-
1741
-				foreach ( $this->arguments as $key => $args ) {
1742
-					if ( isset( $args['group'] ) ) {
1743
-						$has_sections = true;
1744
-						break;
1745
-					}
1746
-				}
1706
+            return $icon;
1707
+        }
1747 1708
 
1748
-				if ( ! $has_sections ) {
1749
-					return $tabs;
1750
-				}
1709
+        public function group_arguments( $arguments ) {
1710
+            if ( ! empty( $arguments ) ) {
1711
+                $temp_arguments = array();
1712
+                $general        = __( "General", 'ayecode-connect' );
1713
+                $add_sections   = false;
1714
+                foreach ( $arguments as $key => $args ) {
1715
+                    if ( isset( $args['group'] ) ) {
1716
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1717
+                        $add_sections                             = true;
1718
+                    } else {
1719
+                        $temp_arguments[ $general ][ $key ] = $args;
1720
+                    }
1721
+                }
1751 1722
 
1752
-				$new_tabs = array();
1723
+                // only add sections if more than one
1724
+                if ( $add_sections ) {
1725
+                    $arguments = $temp_arguments;
1726
+                }
1727
+            }
1753 1728
 
1754
-				foreach ( $tabs as $tab_key => $tab ) {
1755
-					$new_groups = array();
1729
+            return $arguments;
1730
+        }
1756 1731
 
1757
-					if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1758
-						foreach ( $tab['groups'] as $group ) {
1759
-							if ( isset( $arguments[ $group ] ) ) {
1760
-								$new_groups[] = $group;
1761
-							}
1762
-						}
1763
-					}
1732
+        /**
1733
+         * Parse used group tabs.
1734
+         *
1735
+         * @since 1.1.17
1736
+         */
1737
+        public function group_block_tabs( $tabs, $arguments ) {
1738
+            if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1739
+                $has_sections = false;
1740
+
1741
+                foreach ( $this->arguments as $key => $args ) {
1742
+                    if ( isset( $args['group'] ) ) {
1743
+                        $has_sections = true;
1744
+                        break;
1745
+                    }
1746
+                }
1764 1747
 
1765
-					if ( ! empty( $new_groups ) ) {
1766
-						$tab['groups'] = $new_groups;
1748
+                if ( ! $has_sections ) {
1749
+                    return $tabs;
1750
+                }
1767 1751
 
1768
-						$new_tabs[ $tab_key ] = $tab;
1769
-					}
1770
-				}
1752
+                $new_tabs = array();
1771 1753
 
1772
-				$tabs = $new_tabs;
1773
-			}
1754
+                foreach ( $tabs as $tab_key => $tab ) {
1755
+                    $new_groups = array();
1774 1756
 
1775
-			return $tabs;
1776
-		}
1757
+                    if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1758
+                        foreach ( $tab['groups'] as $group ) {
1759
+                            if ( isset( $arguments[ $group ] ) ) {
1760
+                                $new_groups[] = $group;
1761
+                            }
1762
+                        }
1763
+                    }
1764
+
1765
+                    if ( ! empty( $new_groups ) ) {
1766
+                        $tab['groups'] = $new_groups;
1777 1767
 
1778
-		/**
1779
-		 * Output the JS for building the dynamic Guntenberg block.
1780
-		 *
1781
-		 * @return mixed
1782
-		 *@since 1.0.9 Save numbers as numbers and not strings.
1783
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1784
-		 * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1785
-		 */
1786
-		public function block() {
1787
-			global $sd_is_js_functions_loaded, $aui_bs5;
1788
-
1789
-			$show_advanced = $this->block_show_advanced();
1790
-
1791
-			ob_start();
1792
-			?>
1768
+                        $new_tabs[ $tab_key ] = $tab;
1769
+                    }
1770
+                }
1771
+
1772
+                $tabs = $new_tabs;
1773
+            }
1774
+
1775
+            return $tabs;
1776
+        }
1777
+
1778
+        /**
1779
+         * Output the JS for building the dynamic Guntenberg block.
1780
+         *
1781
+         * @return mixed
1782
+         *@since 1.0.9 Save numbers as numbers and not strings.
1783
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1784
+         * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1785
+         */
1786
+        public function block() {
1787
+            global $sd_is_js_functions_loaded, $aui_bs5;
1788
+
1789
+            $show_advanced = $this->block_show_advanced();
1790
+
1791
+            ob_start();
1792
+            ?>
1793 1793
 			<script>
1794 1794
 			<?php
1795
-			if ( ! $sd_is_js_functions_loaded ) {
1796
-				$sd_is_js_functions_loaded = true;
1797
-			?>
1795
+            if ( ! $sd_is_js_functions_loaded ) {
1796
+                $sd_is_js_functions_loaded = true;
1797
+            ?>
1798 1798
 function sd_show_view_options($this){
1799 1799
 	if(jQuery($this).html().length){
1800 1800
 		jQuery($this).html('');
@@ -2294,8 +2294,8 @@  discard block
 block discarded – undo
2294 2294
 				$classes = [];
2295 2295
 
2296 2296
 				<?php
2297
-				if($aui_bs5){
2298
-					?>
2297
+                if($aui_bs5){
2298
+                    ?>
2299 2299
 				$aui_bs5 = true;
2300 2300
 				$p_ml = 'ms-';
2301 2301
 				$p_mr = 'me-';
@@ -2303,8 +2303,8 @@  discard block
 block discarded – undo
2303 2303
 				$p_pl = 'ps-';
2304 2304
 				$p_pr = 'pe-';
2305 2305
 					<?php
2306
-				}else{
2307
-						?>
2306
+                }else{
2307
+                        ?>
2308 2308
 				$aui_bs5 = false;
2309 2309
 				$p_ml = 'ml-';
2310 2310
 				$p_mr = 'mr-';
@@ -2312,8 +2312,8 @@  discard block
 block discarded – undo
2312 2312
 				$p_pl = 'pl-';
2313 2313
 				$p_pr = 'pr-';
2314 2314
 					<?php
2315
-				}
2316
-				?>
2315
+                }
2316
+                ?>
2317 2317
 
2318 2318
 				// margins
2319 2319
 				if ( $args['mt'] !== undefined && $args['mt'] !== '' ) { $classes.push( "mt-" + $args['mt'] );  $mt = $args['mt']; }else{$mt = null;}
@@ -2497,12 +2497,12 @@  discard block
 block discarded – undo
2497 2497
 			<?php
2498 2498
 
2499 2499
 
2500
-			}
2500
+            }
2501 2501
 
2502
-			if(method_exists($this,'block_global_js')){
2503
-					echo $this->block_global_js();
2504
-			}
2505
-			?>
2502
+            if(method_exists($this,'block_global_js')){
2503
+                    echo $this->block_global_js();
2504
+            }
2505
+            ?>
2506 2506
 
2507 2507
 jQuery(function() {
2508 2508
 
@@ -2555,13 +2555,13 @@  discard block
 block discarded – undo
2555 2555
 						icon: <?php echo $this->get_block_icon( $this->options['block-icon'] );?>,//'<?php echo isset( $this->options['block-icon'] ) ? esc_attr( $this->options['block-icon'] ) : 'shield-alt';?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
2556 2556
 						supports: {
2557 2557
 							<?php
2558
-							if(!isset($this->options['block-supports']['renaming'])){
2559
-								$this->options['block-supports']['renaming'] = false;
2560
-							}
2561
-							if ( isset( $this->options['block-supports'] ) ) {
2562
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2563
-							}
2564
-							?>
2558
+                            if(!isset($this->options['block-supports']['renaming'])){
2559
+                                $this->options['block-supports']['renaming'] = false;
2560
+                            }
2561
+                            if ( isset( $this->options['block-supports'] ) ) {
2562
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
2563
+                            }
2564
+                            ?>
2565 2565
 						},
2566 2566
 						__experimentalLabel( attributes, { context } ) {
2567 2567
 							var visibility_html = attributes && attributes.visibility_conditions ? ' &#128065;' : '';
@@ -2571,174 +2571,174 @@  discard block
 block discarded – undo
2571 2571
 						},
2572 2572
 						category: '<?php echo isset( $this->options['block-category'] ) ? esc_attr( $this->options['block-category'] ) : 'common';?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
2573 2573
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
2574
-						echo "keywords : " . $this->options['block-keywords'] . ",";
2575
-						}
2576
-
2577
-
2578
-						// block hover preview.
2579
-						$example_args = array();
2580
-						if(!empty($this->arguments)){
2581
-							foreach($this->arguments as $key => $a_args){
2582
-								if(isset($a_args['example'])){
2583
-									$example_args[$key] = $a_args['example'];
2584
-								}
2585
-							}
2586
-						}
2587
-						$viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2588
-						$example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2589
-						if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2590
-							// no preview if set to false
2591
-						}elseif( !empty( $example_args ) ){
2592
-							echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2593
-						}elseif( !empty( $this->options['example'] ) ){
2594
-							unset($this->options['example']['viewportWidth']);
2595
-							unset($this->options['example']['innerBlocks']);
2596
-							$example_atts = $this->array_to_attributes( $this->options['example'] );
2597
-							$example_parts = array();
2598
-							if($example_atts){
2599
-								$example_parts[] = rtrim($example_atts,",");
2600
-							}
2601
-							if($viewport_width){
2602
-								$example_parts[] = $viewport_width;
2603
-							}
2604
-							if($example_inner_blocks){
2605
-								$example_parts[] = $example_inner_blocks;
2606
-							}
2607
-							if(!empty($example_parts)){
2608
-								echo "example : {".implode(',', $example_parts)."},";
2609
-							}
2610
-						}else{
2611
-							echo 'example : {viewportWidth: 500},';
2612
-						}
2613
-
2614
-
2615
-
2616
-						// limit to parent
2617
-						if( !empty( $this->options['parent'] ) ){
2618
-							echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2619
-						}
2620
-
2621
-						// limit allowed blocks
2622
-						if( !empty( $this->options['allowed-blocks'] ) ){
2623
-							echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2624
-						}
2625
-
2626
-						// maybe set no_wrap
2627
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2628
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2629
-							$no_wrap = true;
2630
-						}
2631
-						if ( $no_wrap ) {
2632
-							$this->options['block-wrap'] = '';
2633
-						}
2634
-
2635
-						// maybe load the drag/drop functions.
2636
-						$img_drag_drop = false;
2637
-
2638
-						$show_alignment = false;
2639
-						// align feature
2640
-						/*echo "supports: {";
2574
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
2575
+                        }
2576
+
2577
+
2578
+                        // block hover preview.
2579
+                        $example_args = array();
2580
+                        if(!empty($this->arguments)){
2581
+                            foreach($this->arguments as $key => $a_args){
2582
+                                if(isset($a_args['example'])){
2583
+                                    $example_args[$key] = $a_args['example'];
2584
+                                }
2585
+                            }
2586
+                        }
2587
+                        $viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2588
+                        $example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2589
+                        if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2590
+                            // no preview if set to false
2591
+                        }elseif( !empty( $example_args ) ){
2592
+                            echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2593
+                        }elseif( !empty( $this->options['example'] ) ){
2594
+                            unset($this->options['example']['viewportWidth']);
2595
+                            unset($this->options['example']['innerBlocks']);
2596
+                            $example_atts = $this->array_to_attributes( $this->options['example'] );
2597
+                            $example_parts = array();
2598
+                            if($example_atts){
2599
+                                $example_parts[] = rtrim($example_atts,",");
2600
+                            }
2601
+                            if($viewport_width){
2602
+                                $example_parts[] = $viewport_width;
2603
+                            }
2604
+                            if($example_inner_blocks){
2605
+                                $example_parts[] = $example_inner_blocks;
2606
+                            }
2607
+                            if(!empty($example_parts)){
2608
+                                echo "example : {".implode(',', $example_parts)."},";
2609
+                            }
2610
+                        }else{
2611
+                            echo 'example : {viewportWidth: 500},';
2612
+                        }
2613
+
2614
+
2615
+
2616
+                        // limit to parent
2617
+                        if( !empty( $this->options['parent'] ) ){
2618
+                            echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2619
+                        }
2620
+
2621
+                        // limit allowed blocks
2622
+                        if( !empty( $this->options['allowed-blocks'] ) ){
2623
+                            echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2624
+                        }
2625
+
2626
+                        // maybe set no_wrap
2627
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2628
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2629
+                            $no_wrap = true;
2630
+                        }
2631
+                        if ( $no_wrap ) {
2632
+                            $this->options['block-wrap'] = '';
2633
+                        }
2634
+
2635
+                        // maybe load the drag/drop functions.
2636
+                        $img_drag_drop = false;
2637
+
2638
+                        $show_alignment = false;
2639
+                        // align feature
2640
+                        /*echo "supports: {";
2641 2641
 						echo "	align: true,";
2642 2642
 						echo "  html: false";
2643 2643
 						echo "},";*/
2644 2644
 
2645 2645
 
2646
-							echo "attributes : {";
2647
-
2648
-							if ( $show_advanced ) {
2649
-								echo "show_advanced: {";
2650
-								echo "	type: 'boolean',";
2651
-								echo "  default: false,";
2652
-								echo "},";
2653
-							}
2654
-
2655
-							// block wrap element
2656
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2657
-								echo "block_wrap: {";
2658
-								echo "	type: 'string',";
2659
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2660
-								echo "},";
2661
-							}
2662
-
2663
-
2664
-							if ( ! empty( $this->arguments ) ) {
2665
-
2666
-								foreach ( $this->arguments as $key => $args ) {
2667
-
2668
-									if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2669
-										$img_drag_drop = true;
2670
-									}
2671
-
2672
-									// set if we should show alignment
2673
-									if ( $key == 'alignment' ) {
2674
-										$show_alignment = true;
2675
-									}
2676
-
2677
-									$extra = '';
2678
-
2679
-									if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2680
-										continue;
2681
-									}
2682
-									elseif ( $args['type'] == 'checkbox' ) {
2683
-										$type    = 'boolean';
2684
-										$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2685
-									} elseif ( $args['type'] == 'number' ) {
2686
-										$type    = 'number';
2687
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2688
-									} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2689
-										$type = 'array';
2690
-										if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2691
-											$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2692
-										} else {
2693
-											$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2694
-										}
2695
-									} elseif ( $args['type'] == 'tagselect' ) {
2696
-										$type    = 'array';
2697
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2698
-									} elseif ( $args['type'] == 'multiselect' ) {
2699
-										$type    = 'array';
2700
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2701
-									} elseif ( $args['type'] == 'image_xy' ) {
2702
-										$type    = 'object';
2703
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2704
-									} elseif ( $args['type'] == 'image' ) {
2705
-										$type    = 'string';
2706
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2707
-
2708
-										// add a field for ID
2709
-	//                                    echo $key . "_id : {";
2710
-	//                                    echo "type : 'number',";
2711
-	//                                    echo "},";
2712
-	//                                    echo $key . "_xy : {";
2713
-	//                                    echo "type : 'object',";
2714
-	//                                    echo "},";
2715
-
2716
-									} else {
2717
-										$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2718
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2719
-
2720
-									}
2721
-									echo $key . " : {";
2722
-									echo "type : '$type',";
2723
-									echo "default : $default,";
2724
-									echo "},";
2725
-								}
2726
-							}
2727
-
2728
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2729
-							echo "sd_shortcode : {type : 'string',default: ''},";
2730
-
2731
-							if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2732
-								echo "sd_shortcode_close : {type : 'string',default: ''},";
2733
-							}
2734
-
2735
-							echo "className: { type: 'string', default: '' },";
2736
-
2737
-							echo "},";
2738
-
2739
-
2740
-
2741
-						?>
2646
+                            echo "attributes : {";
2647
+
2648
+                            if ( $show_advanced ) {
2649
+                                echo "show_advanced: {";
2650
+                                echo "	type: 'boolean',";
2651
+                                echo "  default: false,";
2652
+                                echo "},";
2653
+                            }
2654
+
2655
+                            // block wrap element
2656
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2657
+                                echo "block_wrap: {";
2658
+                                echo "	type: 'string',";
2659
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2660
+                                echo "},";
2661
+                            }
2662
+
2663
+
2664
+                            if ( ! empty( $this->arguments ) ) {
2665
+
2666
+                                foreach ( $this->arguments as $key => $args ) {
2667
+
2668
+                                    if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2669
+                                        $img_drag_drop = true;
2670
+                                    }
2671
+
2672
+                                    // set if we should show alignment
2673
+                                    if ( $key == 'alignment' ) {
2674
+                                        $show_alignment = true;
2675
+                                    }
2676
+
2677
+                                    $extra = '';
2678
+
2679
+                                    if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2680
+                                        continue;
2681
+                                    }
2682
+                                    elseif ( $args['type'] == 'checkbox' ) {
2683
+                                        $type    = 'boolean';
2684
+                                        $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2685
+                                    } elseif ( $args['type'] == 'number' ) {
2686
+                                        $type    = 'number';
2687
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2688
+                                    } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2689
+                                        $type = 'array';
2690
+                                        if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2691
+                                            $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2692
+                                        } else {
2693
+                                            $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2694
+                                        }
2695
+                                    } elseif ( $args['type'] == 'tagselect' ) {
2696
+                                        $type    = 'array';
2697
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2698
+                                    } elseif ( $args['type'] == 'multiselect' ) {
2699
+                                        $type    = 'array';
2700
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2701
+                                    } elseif ( $args['type'] == 'image_xy' ) {
2702
+                                        $type    = 'object';
2703
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2704
+                                    } elseif ( $args['type'] == 'image' ) {
2705
+                                        $type    = 'string';
2706
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2707
+
2708
+                                        // add a field for ID
2709
+    //                                    echo $key . "_id : {";
2710
+    //                                    echo "type : 'number',";
2711
+    //                                    echo "},";
2712
+    //                                    echo $key . "_xy : {";
2713
+    //                                    echo "type : 'object',";
2714
+    //                                    echo "},";
2715
+
2716
+                                    } else {
2717
+                                        $type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2718
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2719
+
2720
+                                    }
2721
+                                    echo $key . " : {";
2722
+                                    echo "type : '$type',";
2723
+                                    echo "default : $default,";
2724
+                                    echo "},";
2725
+                                }
2726
+                            }
2727
+
2728
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2729
+                            echo "sd_shortcode : {type : 'string',default: ''},";
2730
+
2731
+                            if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2732
+                                echo "sd_shortcode_close : {type : 'string',default: ''},";
2733
+                            }
2734
+
2735
+                            echo "className: { type: 'string', default: '' },";
2736
+
2737
+                            echo "},";
2738
+
2739
+
2740
+
2741
+                        ?>
2742 2742
 
2743 2743
 						// The "edit" property must be a valid function.
2744 2744
 						edit: function (props) {
@@ -2813,10 +2813,10 @@  discard block
 block discarded – undo
2813 2813
 							}
2814 2814
 
2815 2815
 							<?php
2816
-							if(!empty($this->options['block-edit-raw'])) {
2817
-								echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2818
-							}else{
2819
-							?>
2816
+                            if(!empty($this->options['block-edit-raw'])) {
2817
+                                echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2818
+                            }else{
2819
+                            ?>
2820 2820
 
2821 2821
 function hasSelectedInnerBlock(props) {
2822 2822
 	const select = wp.data.select('core/editor');
@@ -2838,9 +2838,9 @@  discard block
 block discarded – undo
2838 2838
 
2839 2839
 	var $value = '';
2840 2840
 	<?php
2841
-	// if we have a post_type and a category then link them
2842
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2843
-	?>
2841
+    // if we have a post_type and a category then link them
2842
+    if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2843
+    ?>
2844 2844
 	if(typeof(prev_attributes[props.clientId]) != 'undefined' && selectedBlock && selectedBlock.clientId === props.clientId){
2845 2845
 		$pt = props.attributes.post_type;
2846 2846
 		if(post_type_rest_slugs.length){
@@ -2853,11 +2853,11 @@  discard block
 block discarded – undo
2853 2853
 			term_query_type = $pt;
2854 2854
 		}
2855 2855
 <?php
2856
-	$cat_path = '';
2857
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2858
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2859
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2860
-	}
2856
+    $cat_path = '';
2857
+    if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2858
+        $cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2859
+        $cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2860
+    }
2861 2861
 ?>
2862 2862
 		/* taxonomies */
2863 2863
 		if($value && 'post_type' in prev_attributes[props.clientId] && 'category' in prev_attributes[props.clientId] && run){
@@ -2949,7 +2949,7 @@  discard block
 block discarded – undo
2949 2949
 <?php
2950 2950
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2951 2951
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2952
-	echo 'const { deviceType } = "";';
2952
+    echo 'const { deviceType } = "";';
2953 2953
 }else{
2954 2954
 ?>
2955 2955
 /** Get device type const. */
@@ -3013,8 +3013,8 @@  discard block
 block discarded – undo
3013 3013
 										'attributes': props.attributes,
3014 3014
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
3015 3015
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
3016
-										echo $post->ID;
3017
-									}else{echo '0';}?>,
3016
+                                        echo $post->ID;
3017
+                                    }else{echo '0';}?>,
3018 3018
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
3019 3019
 									};
3020 3020
 
@@ -3028,20 +3028,20 @@  discard block
 block discarded – undo
3028 3028
 										}
3029 3029
 
3030 3030
 										 <?php
3031
-										if(!empty($this->options['nested-block'])){
3032
-											?>
3031
+                                        if(!empty($this->options['nested-block'])){
3032
+                                            ?>
3033 3033
 											// props.setAttributes({content: env});
3034 3034
 										is_fetching = false;
3035 3035
 										prev_attributes[props.clientId] = props.attributes;
3036 3036
 											 <?php
3037
-										}else{
3038
-										?>
3037
+                                        }else{
3038
+                                        ?>
3039 3039
 										props.setAttributes({content: env});
3040 3040
 										is_fetching = false;
3041 3041
 										prev_attributes[props.clientId] = props.attributes;
3042 3042
 										<?php
3043
-										}
3044
-										?>
3043
+                                        }
3044
+                                        ?>
3045 3045
 
3046 3046
 
3047 3047
 										// if AUI is active call the js init function
@@ -3060,31 +3060,31 @@  discard block
 block discarded – undo
3060 3060
 							}
3061 3061
 
3062 3062
 							<?php
3063
-							if(!empty($this->options['block-edit-js'])) {
3064
-								echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
3065
-							}
3063
+                            if(!empty($this->options['block-edit-js'])) {
3064
+                                echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
3065
+                            }
3066 3066
 
3067 3067
 
3068 3068
 
3069 3069
 
3070
-							if(empty($this->options['block-save-return'])){
3071
-							?>
3070
+                            if(empty($this->options['block-save-return'])){
3071
+                            ?>
3072 3072
 								///////////////////////////////////////////////////////////////////////
3073 3073
 
3074 3074
 									 // build the shortcode.
3075 3075
 								shortcode = "[<?php echo $this->options['base_id'];?>";
3076 3076
 								<?php
3077 3077
 
3078
-								if(! empty( $this->arguments )){
3078
+                                if(! empty( $this->arguments )){
3079 3079
 
3080
-								foreach($this->arguments as $key => $args){
3081
-								   // if($args['type']=='tabs'){continue;}
3080
+                                foreach($this->arguments as $key => $args){
3081
+                                    // if($args['type']=='tabs'){continue;}
3082 3082
 
3083
-								   // don't add metadata arguments
3084
-								   if (substr($key, 0, 9 ) === 'metadata_') {
3085
-									   continue;
3086
-								   }
3087
-								?>
3083
+                                    // don't add metadata arguments
3084
+                                    if (substr($key, 0, 9 ) === 'metadata_') {
3085
+                                        continue;
3086
+                                    }
3087
+                                ?>
3088 3088
 								if (props.attributes.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3089 3089
 									if ('<?php echo esc_attr( $key );?>' == 'html') {
3090 3090
 									} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
@@ -3095,10 +3095,10 @@  discard block
 block discarded – undo
3095 3095
 									}
3096 3096
 								}
3097 3097
 								<?php
3098
-								}
3099
-								}
3098
+                                }
3099
+                                }
3100 3100
 
3101
-								?>
3101
+                                ?>
3102 3102
 								shortcode += "]";
3103 3103
 
3104 3104
 								if(shortcode){
@@ -3110,17 +3110,17 @@  discard block
 block discarded – undo
3110 3110
 
3111 3111
 
3112 3112
 									<?php
3113
-									if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3114
-										echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3115
-									}
3116
-									?>
3113
+                                    if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3114
+                                        echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3115
+                                    }
3116
+                                    ?>
3117 3117
 								}
3118 3118
 
3119 3119
 
3120 3120
 							///////////////////////////////////////////////////////////////////////
3121 3121
 							<?php
3122
-							} // end nested block check
3123
-							?>
3122
+                            } // end nested block check
3123
+                            ?>
3124 3124
 
3125 3125
 							return [
3126 3126
 
@@ -3144,10 +3144,10 @@  discard block
 block discarded – undo
3144 3144
 
3145 3145
 									<?php
3146 3146
 
3147
-									if(! empty( $this->arguments )){
3147
+                                    if(! empty( $this->arguments )){
3148 3148
 
3149
-									if ( $show_advanced ) {
3150
-									?>
3149
+                                    if ( $show_advanced ) {
3150
+                                    ?>
3151 3151
 									el('div', {
3152 3152
 											style: {'padding-left': '16px','padding-right': '16px'}
3153 3153
 										},
@@ -3164,119 +3164,119 @@  discard block
 block discarded – undo
3164 3164
 									)
3165 3165
 									,
3166 3166
 									<?php
3167
-									}
3168
-
3169
-									$arguments = $this->group_arguments( $this->arguments );
3170
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3171
-
3172
-									// Do we have sections?
3173
-									$has_sections = $arguments == $this->arguments ? false : true;
3174
-
3175
-									if($has_sections){
3176
-									$panel_count = 0;
3177
-									$open_tab = '';
3178
-
3179
-									$open_tab_groups = array();
3180
-									$used_tabs = array();
3181
-
3182
-									foreach ( $arguments as $key => $args ) {
3183
-										$close_tab = false;
3184
-										$close_tabs = false;
3185
-
3186
-										 if ( ! empty( $block_group_tabs ) ) {
3187
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3188
-												if ( in_array( $key, $tab_args['groups'] ) ) {
3189
-													$open_tab_groups[] = $key;
3190
-
3191
-													if ( $open_tab != $tab_name ) {
3192
-														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3193
-														$tab_args['tab']['open'] = true;
3194
-
3195
-														$this->block_tab_start( '', $tab_args );
3196
-														$open_tab = $tab_name;
3197
-														$used_tabs[] = $tab_name;
3198
-													}
3199
-
3200
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3201
-														$close_tab = true;
3202
-														$open_tab_groups = array();
3203
-
3204
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3205
-															$close_tabs = true;
3206
-														}
3207
-													}
3208
-												}
3209
-											}
3210
-										}
3211
-										?>
3167
+                                    }
3168
+
3169
+                                    $arguments = $this->group_arguments( $this->arguments );
3170
+                                    $block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3171
+
3172
+                                    // Do we have sections?
3173
+                                    $has_sections = $arguments == $this->arguments ? false : true;
3174
+
3175
+                                    if($has_sections){
3176
+                                    $panel_count = 0;
3177
+                                    $open_tab = '';
3178
+
3179
+                                    $open_tab_groups = array();
3180
+                                    $used_tabs = array();
3181
+
3182
+                                    foreach ( $arguments as $key => $args ) {
3183
+                                        $close_tab = false;
3184
+                                        $close_tabs = false;
3185
+
3186
+                                            if ( ! empty( $block_group_tabs ) ) {
3187
+                                            foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3188
+                                                if ( in_array( $key, $tab_args['groups'] ) ) {
3189
+                                                    $open_tab_groups[] = $key;
3190
+
3191
+                                                    if ( $open_tab != $tab_name ) {
3192
+                                                        $tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3193
+                                                        $tab_args['tab']['open'] = true;
3194
+
3195
+                                                        $this->block_tab_start( '', $tab_args );
3196
+                                                        $open_tab = $tab_name;
3197
+                                                        $used_tabs[] = $tab_name;
3198
+                                                    }
3199
+
3200
+                                                    if ( $open_tab_groups == $tab_args['groups'] ) {
3201
+                                                        $close_tab = true;
3202
+                                                        $open_tab_groups = array();
3203
+
3204
+                                                        if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3205
+                                                            $close_tabs = true;
3206
+                                                        }
3207
+                                                    }
3208
+                                                }
3209
+                                            }
3210
+                                        }
3211
+                                        ?>
3212 3212
 										el(wp.components.PanelBody, {
3213 3213
 												title: '<?php esc_attr_e( $key ); ?>',
3214 3214
 												initialOpen: <?php if ( $panel_count ) {
3215
-												echo "false";
3216
-											} else {
3217
-												echo "true";
3218
-											}?>
3215
+                                                echo "false";
3216
+                                            } else {
3217
+                                                echo "true";
3218
+                                            }?>
3219 3219
 											},
3220 3220
 											<?php
3221
-											foreach ( $args as $k => $a ) {
3222
-												$this->block_tab_start( $k, $a );
3223
-												$this->block_row_start( $k, $a );
3224
-												$this->build_block_arguments( $k, $a );
3225
-												$this->block_row_end( $k, $a );
3226
-												$this->block_tab_end( $k, $a );
3227
-											}
3228
-											?>
3221
+                                            foreach ( $args as $k => $a ) {
3222
+                                                $this->block_tab_start( $k, $a );
3223
+                                                $this->block_row_start( $k, $a );
3224
+                                                $this->build_block_arguments( $k, $a );
3225
+                                                $this->block_row_end( $k, $a );
3226
+                                                $this->block_tab_end( $k, $a );
3227
+                                            }
3228
+                                            ?>
3229 3229
 										),
3230 3230
 										<?php
3231
-										$panel_count ++;
3231
+                                        $panel_count ++;
3232 3232
 
3233
-										if($close_tab || $close_tabs){
3234
-											$tab_args = array(
3235
-												'tab'	=> array(
3236
-													'tabs_close' => $close_tabs,
3237
-												'close' => true,
3238
-												)
3233
+                                        if($close_tab || $close_tabs){
3234
+                                            $tab_args = array(
3235
+                                                'tab'	=> array(
3236
+                                                    'tabs_close' => $close_tabs,
3237
+                                                'close' => true,
3238
+                                                )
3239 3239
 
3240
-											);
3241
-											$this->block_tab_end( '', $tab_args );
3240
+                                            );
3241
+                                            $this->block_tab_end( '', $tab_args );
3242 3242
 //											echo '###close'; print_r($tab_args);
3243
-											$panel_count = 0;
3244
-										}
3243
+                                            $panel_count = 0;
3244
+                                        }
3245 3245
 //
3246 3246
 
3247
-									}
3248
-									}else {
3249
-									?>
3247
+                                    }
3248
+                                    }else {
3249
+                                    ?>
3250 3250
 									el(wp.components.PanelBody, {
3251 3251
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3252 3252
 											initialOpen: true
3253 3253
 										},
3254 3254
 										<?php
3255
-										foreach ( $this->arguments as $key => $args ) {
3256
-											$this->block_row_start( $key, $args );
3257
-											$this->build_block_arguments( $key, $args );
3258
-											$this->block_row_end( $key, $args );
3259
-										}
3260
-										?>
3255
+                                        foreach ( $this->arguments as $key => $args ) {
3256
+                                            $this->block_row_start( $key, $args );
3257
+                                            $this->build_block_arguments( $key, $args );
3258
+                                            $this->block_row_end( $key, $args );
3259
+                                        }
3260
+                                        ?>
3261 3261
 									),
3262 3262
 									<?php
3263
-									}
3263
+                                    }
3264 3264
 
3265
-									}
3266
-									?>
3265
+                                    }
3266
+                                    ?>
3267 3267
 
3268 3268
 								),
3269 3269
 
3270 3270
 								<?php
3271
-								// If the user sets block-output array then build it
3272
-								if ( ! empty( $this->options['block-output'] ) ) {
3273
-								$this->block_element( $this->options['block-output'] );
3274
-							}elseif(!empty($this->options['block-edit-return'])){
3275
-								   echo $this->options['block-edit-return'];
3276
-							}else{
3277
-								// if no block-output is set then we try and get the shortcode html output via ajax.
3278
-								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3279
-								?>
3271
+                                // If the user sets block-output array then build it
3272
+                                if ( ! empty( $this->options['block-output'] ) ) {
3273
+                                $this->block_element( $this->options['block-output'] );
3274
+                            }elseif(!empty($this->options['block-edit-return'])){
3275
+                                    echo $this->options['block-edit-return'];
3276
+                            }else{
3277
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
3278
+                                $block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3279
+                                ?>
3280 3280
 								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
3281 3281
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
3282 3282
 									className: props.className,
@@ -3284,13 +3284,13 @@  discard block
 block discarded – undo
3284 3284
 									style: {'minHeight': '30px'}
3285 3285
 								}))
3286 3286
 								<?php
3287
-								}
3288
-								?>
3287
+                                }
3288
+                                ?>
3289 3289
 							]; // end return
3290 3290
 
3291 3291
 							<?php
3292
-							} // end block-edit-raw else
3293
-							?>
3292
+                            } // end block-edit-raw else
3293
+                            ?>
3294 3294
 						},
3295 3295
 
3296 3296
 						// The "save" property must be specified and must be a valid function.
@@ -3304,16 +3304,16 @@  discard block
 block discarded – undo
3304 3304
 							$html = '';
3305 3305
 							<?php
3306 3306
 
3307
-							if(! empty( $this->arguments )){
3307
+                            if(! empty( $this->arguments )){
3308 3308
 
3309
-							foreach($this->arguments as $key => $args){
3310
-							   // if($args['type']=='tabs'){continue;}
3309
+                            foreach($this->arguments as $key => $args){
3310
+                                // if($args['type']=='tabs'){continue;}
3311 3311
 
3312
-							   // don't add metadata arguments
3313
-							   if (substr($key, 0, 9 ) === 'metadata_') {
3314
-								   continue;
3315
-							   }
3316
-							?>
3312
+                                // don't add metadata arguments
3313
+                                if (substr($key, 0, 9 ) === 'metadata_') {
3314
+                                    continue;
3315
+                                }
3316
+                            ?>
3317 3317
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3318 3318
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
3319 3319
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -3324,10 +3324,10 @@  discard block
 block discarded – undo
3324 3324
 								}
3325 3325
 							}
3326 3326
 							<?php
3327
-							}
3328
-							}
3327
+                            }
3328
+                            }
3329 3329
 
3330
-							?>
3330
+                            ?>
3331 3331
 							content += "]";
3332 3332
 							 content = '';
3333 3333
 
@@ -3337,7 +3337,7 @@  discard block
 block discarded – undo
3337 3337
 //                                $html = 'el( InnerBlocks.Content )';
3338 3338
 //                                <?php
3339 3339
 //                            }
3340
-							?>
3340
+                            ?>
3341 3341
 							// if has html element
3342 3342
 							if ($html) {
3343 3343
 								//content += $html + "[/<?php echo $this->options['base_id'];?>]";
@@ -3370,12 +3370,12 @@  discard block
 block discarded – undo
3370 3370
 //                                <x?php
3371 3371
 //							}else
3372 3372
 
3373
-							if(!empty($this->options['block-output'])){
3373
+                            if(!empty($this->options['block-output'])){
3374 3374
 //                               echo "return";
3375 3375
 //                               $this->block_element( $this->options['block-output'], true );
3376 3376
 //                               echo ";";
3377 3377
 
3378
-							   ?>
3378
+                                ?>
3379 3379
 							  return el(
3380 3380
 								   '',
3381 3381
 								   {},
@@ -3385,10 +3385,10 @@  discard block
 block discarded – undo
3385 3385
 							   );
3386 3386
 								<?php
3387 3387
 
3388
-							}elseif(!empty($this->options['block-save-return'])){
3389
-								   echo 'return ' . $this->options['block-save-return'];
3390
-							}elseif(!empty($this->options['nested-block'])){
3391
-								?>
3388
+                            }elseif(!empty($this->options['block-save-return'])){
3389
+                                    echo 'return ' . $this->options['block-save-return'];
3390
+                            }elseif(!empty($this->options['nested-block'])){
3391
+                                ?>
3392 3392
 							  return el(
3393 3393
 								   '',
3394 3394
 								   {},
@@ -3397,22 +3397,22 @@  discard block
 block discarded – undo
3397 3397
 								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3398 3398
 							   );
3399 3399
 								<?php
3400
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3401
-								echo "return ". $this->options['block-edit-return'].";";
3402
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3403
-							?>
3400
+                            }elseif(!empty( $this->options['block-save-return'] ) ){
3401
+                                echo "return ". $this->options['block-edit-return'].";";
3402
+                            }elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3403
+                            ?>
3404 3404
 							return content;
3405 3405
 							<?php
3406
-							}else{
3407
-							?>
3406
+                            }else{
3407
+                            ?>
3408 3408
 							var block_wrap = 'div';
3409 3409
 							if (attr.hasOwnProperty("block_wrap")) {
3410 3410
 								block_wrap = attr.block_wrap;
3411 3411
 							}
3412 3412
 							return el(block_wrap, wp.blockEditor.useBlockProps.save( {dangerouslySetInnerHTML: {__html: content}, className: align} ));
3413 3413
 							<?php
3414
-							}
3415
-							?>
3414
+                            }
3415
+                            ?>
3416 3416
 
3417 3417
 
3418 3418
 						}
@@ -3426,43 +3426,43 @@  discard block
 block discarded – undo
3426 3426
 				});
3427 3427
 			</script>
3428 3428
 			<?php
3429
-			$output = ob_get_clean();
3429
+            $output = ob_get_clean();
3430 3430
 
3431
-			/*
3431
+            /*
3432 3432
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3433 3433
 			 */
3434 3434
 
3435
-			return str_replace( array(
3436
-				'<script>',
3437
-				'</script>'
3438
-			), '', $output );
3439
-		}
3435
+            return str_replace( array(
3436
+                '<script>',
3437
+                '</script>'
3438
+            ), '', $output );
3439
+        }
3440 3440
 
3441 3441
 
3442 3442
 
3443
-		public function block_row_start($key, $args){
3443
+        public function block_row_start($key, $args){
3444 3444
 
3445
-			// check for row
3446
-			if(!empty($args['row'])){
3445
+            // check for row
3446
+            if(!empty($args['row'])){
3447 3447
 
3448
-				if(!empty($args['row']['open'])){
3448
+                if(!empty($args['row']['open'])){
3449 3449
 
3450
-				// element require
3451
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3452
-				$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3453
-				$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3454
-				$device_type_icon = '';
3455
-				if($device_type=='Desktop'){
3456
-					$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3457
-				}elseif($device_type=='Tablet'){
3458
-					$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3459
-				}elseif($device_type=='Mobile'){
3460
-					$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3461
-				}
3462
-				echo $element_require;
3463
-				echo $device_type_require;
3450
+                // element require
3451
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3452
+                $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3453
+                $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3454
+                $device_type_icon = '';
3455
+                if($device_type=='Desktop'){
3456
+                    $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3457
+                }elseif($device_type=='Tablet'){
3458
+                    $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3459
+                }elseif($device_type=='Mobile'){
3460
+                    $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3461
+                }
3462
+                echo $element_require;
3463
+                echo $device_type_require;
3464 3464
 
3465
-					if(false){?><script><?php }?>
3465
+                    if(false){?><script><?php }?>
3466 3466
 						el('div', {
3467 3467
 								className: 'bsui components-base-control',
3468 3468
 							},
@@ -3475,8 +3475,8 @@  discard block
 block discarded – undo
3475 3475
 								<?php if($device_type_icon){ ?>
3476 3476
 									deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})
3477 3477
 								<?php
3478
-								}
3479
-								?>
3478
+                                }
3479
+                                ?>
3480 3480
 
3481 3481
 
3482 3482
 							),
@@ -3500,51 +3500,51 @@  discard block
 block discarded – undo
3500 3500
 									},
3501 3501
 
3502 3502
 					<?php
3503
-					if(false){?></script><?php }
3504
-				}elseif(!empty($args['row']['close'])){
3505
-					if(false){?><script><?php }?>
3503
+                    if(false){?></script><?php }
3504
+                }elseif(!empty($args['row']['close'])){
3505
+                    if(false){?><script><?php }?>
3506 3506
 						el(
3507 3507
 							'div',
3508 3508
 							{
3509 3509
 								className: 'col pl-0 ps-0',
3510 3510
 							},
3511 3511
 					<?php
3512
-					if(false){?></script><?php }
3513
-				}else{
3514
-					if(false){?><script><?php }?>
3512
+                    if(false){?></script><?php }
3513
+                }else{
3514
+                    if(false){?><script><?php }?>
3515 3515
 						el(
3516 3516
 							'div',
3517 3517
 							{
3518 3518
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3519 3519
 							},
3520 3520
 					<?php
3521
-					if(false){?></script><?php }
3522
-				}
3521
+                    if(false){?></script><?php }
3522
+                }
3523 3523
 
3524
-			}
3524
+            }
3525 3525
 
3526
-		}
3526
+        }
3527 3527
 
3528
-		public function block_row_end($key, $args){
3528
+        public function block_row_end($key, $args){
3529 3529
 
3530
-			if(!empty($args['row'])){
3531
-				// maybe close
3532
-				if(!empty($args['row']['close'])){
3533
-					echo "))";
3534
-				}
3530
+            if(!empty($args['row'])){
3531
+                // maybe close
3532
+                if(!empty($args['row']['close'])){
3533
+                    echo "))";
3534
+                }
3535 3535
 
3536
-				echo "),";
3537
-			}
3538
-		}
3536
+                echo "),";
3537
+            }
3538
+        }
3539 3539
 
3540
-		public function block_tab_start($key, $args){
3540
+        public function block_tab_start($key, $args){
3541 3541
 
3542
-			// check for row
3543
-			if(!empty($args['tab'])){
3542
+            // check for row
3543
+            if(!empty($args['tab'])){
3544 3544
 
3545
-				if(!empty($args['tab']['tabs_open'])){
3545
+                if(!empty($args['tab']['tabs_open'])){
3546 3546
 
3547
-					if(false){?><script><?php }?>
3547
+                    if(false){?><script><?php }?>
3548 3548
 
3549 3549
 el('div',{className: 'bsui'},
3550 3550
 
@@ -3557,12 +3557,12 @@  discard block
 block discarded – undo
3557 3557
 										tabs: [
3558 3558
 
3559 3559
 					<?php
3560
-					if(false){?></script><?php }
3561
-				}
3560
+                    if(false){?></script><?php }
3561
+                }
3562 3562
 
3563
-				if(!empty($args['tab']['open'])){
3563
+                if(!empty($args['tab']['open'])){
3564 3564
 
3565
-					if(false){?><script><?php }?>
3565
+                    if(false){?><script><?php }?>
3566 3566
 							{
3567 3567
 												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3568 3568
 												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
@@ -3571,93 +3571,93 @@  discard block
 block discarded – undo
3571 3571
 									className: 'components-base-control__help mb-0',
3572 3572
 									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3573 3573
 								}),<?php }
3574
-					if(false){?></script><?php }
3575
-				}
3574
+                    if(false){?></script><?php }
3575
+                }
3576 3576
 
3577
-			}
3577
+            }
3578 3578
 
3579
-		}
3579
+        }
3580 3580
 
3581
-		public function block_tab_end($key, $args){
3581
+        public function block_tab_end($key, $args){
3582 3582
 
3583
-			if(!empty($args['tab'])){
3584
-				// maybe close
3585
-				if(!empty($args['tab']['close'])){
3586
-					echo ")}, /* tab close */";
3587
-				}
3583
+            if(!empty($args['tab'])){
3584
+                // maybe close
3585
+                if(!empty($args['tab']['close'])){
3586
+                    echo ")}, /* tab close */";
3587
+                }
3588 3588
 
3589
-				if(!empty($args['tab']['tabs_close'])){
3590
-					if(false){?><script><?php }?>
3589
+                if(!empty($args['tab']['tabs_close'])){
3590
+                    if(false){?><script><?php }?>
3591 3591
 						]}, ( tab ) => {
3592 3592
 								return tab.content;
3593 3593
 							}
3594 3594
 						)), /* tabs close */
3595 3595
 					<?php if(false){ ?></script><?php }
3596
-				}
3597
-			}
3598
-		}
3596
+                }
3597
+            }
3598
+        }
3599 3599
 
3600
-		public function build_block_arguments( $key, $args ) {
3601
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3602
-			$options           = '';
3603
-			$extra             = '';
3604
-			$require           = '';
3605
-			$inside_elements   = '';
3606
-			$after_elements	   = '';
3607
-
3608
-			// `content` is a protected and special argument
3609
-			if ( $key == 'content' ) {
3610
-				return;
3611
-			}
3600
+        public function build_block_arguments( $key, $args ) {
3601
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3602
+            $options           = '';
3603
+            $extra             = '';
3604
+            $require           = '';
3605
+            $inside_elements   = '';
3606
+            $after_elements	   = '';
3607
+
3608
+            // `content` is a protected and special argument
3609
+            if ( $key == 'content' ) {
3610
+                return;
3611
+            }
3612 3612
 
3613
-			$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3614
-			$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3615
-			$device_type_icon = '';
3616
-			if($device_type=='Desktop'){
3617
-				$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3618
-			}elseif($device_type=='Tablet'){
3619
-				$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3620
-			}elseif($device_type=='Mobile'){
3621
-				$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3622
-			}
3613
+            $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3614
+            $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3615
+            $device_type_icon = '';
3616
+            if($device_type=='Desktop'){
3617
+                $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3618
+            }elseif($device_type=='Tablet'){
3619
+                $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3620
+            }elseif($device_type=='Mobile'){
3621
+                $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3622
+            }
3623 3623
 
3624
-			// icon
3625
-			$icon = '';
3626
-			if( !empty( $args['icon'] ) ){
3627
-				$icon .= "el('div', {";
3628
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3629
-									$icon .= "className: 'text-center',";
3630
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3631
-								$icon .= "}),";
3632
-
3633
-				// blank title as its added to the icon.
3634
-				$args['title'] = '';
3635
-			}
3624
+            // icon
3625
+            $icon = '';
3626
+            if( !empty( $args['icon'] ) ){
3627
+                $icon .= "el('div', {";
3628
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3629
+                                    $icon .= "className: 'text-center',";
3630
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
3631
+                                $icon .= "}),";
3632
+
3633
+                // blank title as its added to the icon.
3634
+                $args['title'] = '';
3635
+            }
3636 3636
 
3637
-			// require advanced
3638
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3637
+            // require advanced
3638
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3639 3639
 
3640
-			// element require
3641
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3640
+            // element require
3641
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3642 3642
 
3643 3643
 
3644
-			$onchange  = "props.setAttributes({ $key: $key } )";
3645
-			$onchangecomplete  = "";
3646
-			$value     = "props.attributes.$key";
3647
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3648
-			if ( in_array( $args['type'], $text_type ) ) {
3649
-				$type = 'TextControl';
3650
-				// Save numbers as numbers and not strings
3651
-				if ( $args['type'] == 'number' ) {
3652
-					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3653
-				}
3644
+            $onchange  = "props.setAttributes({ $key: $key } )";
3645
+            $onchangecomplete  = "";
3646
+            $value     = "props.attributes.$key";
3647
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3648
+            if ( in_array( $args['type'], $text_type ) ) {
3649
+                $type = 'TextControl';
3650
+                // Save numbers as numbers and not strings
3651
+                if ( $args['type'] == 'number' ) {
3652
+                    $onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3653
+                }
3654 3654
 
3655
-				if (substr($key, 0, 9 ) === 'metadata_') {
3656
-					$real_key = str_replace('metadata_','', $key );
3657
-					$onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3658
-					$value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3659
-				}
3660
-			}
3655
+                if (substr($key, 0, 9 ) === 'metadata_') {
3656
+                    $real_key = str_replace('metadata_','', $key );
3657
+                    $onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3658
+                    $value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3659
+                }
3660
+            }
3661 3661
 //			else if ( $args['type'] == 'popup' ) {
3662 3662
 //				$type = 'TextControl';
3663 3663
 //				$args['type'] == 'text';
@@ -3675,21 +3675,21 @@  discard block
 block discarded – undo
3675 3675
 //
3676 3676
 //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3677 3677
 //			}
3678
-			else if ( $args['type'] == 'styleid' ) {
3679
-				$type = 'TextControl';
3680
-				$args['type'] == 'text';
3681
-				// Save numbers as numbers and not strings
3682
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3683
-			}else if ( $args['type'] == 'notice' ) {
3684
-
3685
-				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3686
-				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3687
-
3688
-				$notice = "el('div',{className:'bsui'},el(wp.components.Notice, {status: '$notice_status',isDismissible: false,className: 'm-0 pr-0 pe-0 mb-3'},el('div',{dangerouslySetInnerHTML: {__html: '$notice_message'}}))),";
3689
-				echo $notice_message ? $element_require . $notice : '';
3690
-				return;
3691
-			}
3692
-			/*
3678
+            else if ( $args['type'] == 'styleid' ) {
3679
+                $type = 'TextControl';
3680
+                $args['type'] == 'text';
3681
+                // Save numbers as numbers and not strings
3682
+                $value     = "props.attributes.$key ? props.attributes.$key : ''";
3683
+            }else if ( $args['type'] == 'notice' ) {
3684
+
3685
+                $notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3686
+                $notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3687
+
3688
+                $notice = "el('div',{className:'bsui'},el(wp.components.Notice, {status: '$notice_status',isDismissible: false,className: 'm-0 pr-0 pe-0 mb-3'},el('div',{dangerouslySetInnerHTML: {__html: '$notice_message'}}))),";
3689
+                echo $notice_message ? $element_require . $notice : '';
3690
+                return;
3691
+            }
3692
+            /*
3693 3693
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
3694 3694
 						elseif($args['type']=='tabs'){
3695 3695
 							?>
@@ -3742,22 +3742,22 @@  discard block
 block discarded – undo
3742 3742
 							return;
3743 3743
 						}
3744 3744
 */
3745
-			elseif ( $args['type'] == 'color' ) {
3746
-				$type = 'ColorPicker';
3747
-				$onchange = "";
3748
-				$extra = "color: $value,";
3749
-				if(!empty($args['disable_alpha'])){
3750
-					$extra .= "disableAlpha: true,";
3751
-				}
3752
-				$onchangecomplete = "onChangeComplete: function($key) {
3745
+            elseif ( $args['type'] == 'color' ) {
3746
+                $type = 'ColorPicker';
3747
+                $onchange = "";
3748
+                $extra = "color: $value,";
3749
+                if(!empty($args['disable_alpha'])){
3750
+                    $extra .= "disableAlpha: true,";
3751
+                }
3752
+                $onchangecomplete = "onChangeComplete: function($key) {
3753 3753
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
3754 3754
 						props.setAttributes({
3755 3755
 							$key: value
3756 3756
 						});
3757 3757
 					},";
3758
-			}elseif ( $args['type'] == 'gradient' ) {
3759
-				$type = 'GradientPicker';
3760
-				$extra .= "gradients: [{
3758
+            }elseif ( $args['type'] == 'gradient' ) {
3759
+                $type = 'GradientPicker';
3760
+                $extra .= "gradients: [{
3761 3761
 			name: 'Vivid cyan blue to vivid purple',
3762 3762
 			gradient:
3763 3763
 				'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
@@ -3794,10 +3794,10 @@  discard block
 block discarded – undo
3794 3794
 			slug: 'cool-to-warm-spectrum',
3795 3795
 		}],";
3796 3796
 
3797
-			}elseif ( $args['type'] == 'image' ) {
3797
+            }elseif ( $args['type'] == 'image' ) {
3798 3798
 //                print_r($args);
3799 3799
 
3800
-				$img_preview = isset($args['focalpoint']) && !$args['focalpoint'] ? " props.attributes.$key && el('img', { src: props.attributes.$key,style: {maxWidth:'100%',background: '#ccc'}})," : " ( props.attributes.$key ||  props.attributes.{$key}_use_featured ) && el(wp.components.FocalPointPicker,{
3800
+                $img_preview = isset($args['focalpoint']) && !$args['focalpoint'] ? " props.attributes.$key && el('img', { src: props.attributes.$key,style: {maxWidth:'100%',background: '#ccc'}})," : " ( props.attributes.$key ||  props.attributes.{$key}_use_featured ) && el(wp.components.FocalPointPicker,{
3801 3801
 							url:  props.attributes.{$key}_use_featured === true ? ''  : props.attributes.$key,
3802 3802
 							value: props.attributes.{$key}_xy.x !== undefined && props.attributes.{$key}_xy.x >= 0 ? props.attributes.{$key}_xy  : {x: 0.5,y: 0.5,},
3803 3803
 //                            value: props.attributes.{$key}_xy,
@@ -3818,16 +3818,16 @@  discard block
 block discarded – undo
3818 3818
 						}), ";
3819 3819
 
3820 3820
 
3821
-				$value = '""';
3822
-				$type = 'MediaUpload';
3823
-				$extra .= "onSelect: function(media){
3821
+                $value = '""';
3822
+                $type = 'MediaUpload';
3823
+                $extra .= "onSelect: function(media){
3824 3824
 					  return props.setAttributes({
3825 3825
 						  $key: media.url,
3826 3826
 						  {$key}_id: media.id
3827 3827
 						});
3828 3828
 					  },";
3829
-				   $extra .= "type: 'image',";
3830
-				   $extra .= "render: function (obj) {
3829
+                    $extra .= "type: 'image',";
3830
+                    $extra .= "render: function (obj) {
3831 3831
 						return el( 'div',{},
3832 3832
 						( !props.attributes.$key && !props.attributes.{$key}_use_featured ) && el( wp.components.Button, {
3833 3833
 						  className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
@@ -3853,11 +3853,11 @@  discard block
 block discarded – undo
3853 3853
 
3854 3854
 
3855 3855
 					  }";
3856
-				$onchange = "";
3856
+                $onchange = "";
3857 3857
 
3858
-				//$inside_elements = ",el('div',{},'file upload')";
3859
-			} else if ( $args['type'] == 'images' ) {
3860
-				$img_preview = "props.attributes.$key && (function() {
3858
+                //$inside_elements = ",el('div',{},'file upload')";
3859
+            } else if ( $args['type'] == 'images' ) {
3860
+                $img_preview = "props.attributes.$key && (function() {
3861 3861
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3862 3862
 	let images = [];
3863 3863
 	uploads.map((upload, index) => (
@@ -3884,9 +3884,9 @@  discard block
 block discarded – undo
3884 3884
 })(),";
3885 3885
 
3886 3886
 
3887
-				$value = '""';
3888
-				$type = 'MediaUpload';
3889
-				$extra .= "onSelect: function(media){
3887
+                $value = '""';
3888
+                $type = 'MediaUpload';
3889
+                $extra .= "onSelect: function(media){
3890 3890
 	let slim_images = props.attributes.$key ? JSON.parse('['+props.attributes.$key+']') : [];
3891 3891
 	if(media.length){
3892 3892
 		for (var i=0; i < media.length; i++) {
@@ -3899,9 +3899,9 @@  discard block
 block discarded – undo
3899 3899
 	}
3900 3900
 	return props.setAttributes({ $key: slimImagesV});
3901 3901
 },";
3902
-				$extra .= "type: 'image',";
3903
-				$extra .= "multiple: true,";
3904
-				$extra .= "render: function (obj) {
3902
+                $extra .= "type: 'image',";
3903
+                $extra .= "multiple: true,";
3904
+                $extra .= "render: function (obj) {
3905 3905
 	/* Init the sort */
3906 3906
 	enableDragSort('sd-sortable');
3907 3907
 	return el( 'div',{},
@@ -3928,40 +3928,40 @@  discard block
 block discarded – undo
3928 3928
 		)
3929 3929
 	)
3930 3930
 }";
3931
-				$onchange = "";
3931
+                $onchange = "";
3932 3932
 
3933
-				//$inside_elements = ",el('div',{},'file upload')";
3934
-			}
3935
-			elseif ( $args['type'] == 'checkbox' ) {
3936
-				$type = 'CheckboxControl';
3937
-				$extra .= "checked: props.attributes.$key,";
3938
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3939
-			} elseif ( $args['type'] == 'textarea' ) {
3940
-				$type = 'TextareaControl';
3941
-
3942
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3943
-				$type = 'SelectControl';
3944
-
3945
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3946
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3947
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3948
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3949
-				}else {
3950
-
3951
-					if ( ! empty( $args['options'] ) ) {
3952
-						$options .= "options: [";
3953
-						foreach ( $args['options'] as $option_val => $option_label ) {
3954
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3955
-						}
3956
-						$options .= "],";
3957
-					}
3958
-				}
3959
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3960
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3961
-				}
3933
+                //$inside_elements = ",el('div',{},'file upload')";
3934
+            }
3935
+            elseif ( $args['type'] == 'checkbox' ) {
3936
+                $type = 'CheckboxControl';
3937
+                $extra .= "checked: props.attributes.$key,";
3938
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3939
+            } elseif ( $args['type'] == 'textarea' ) {
3940
+                $type = 'TextareaControl';
3941
+
3942
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3943
+                $type = 'SelectControl';
3944
+
3945
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3946
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3947
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3948
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3949
+                }else {
3950
+
3951
+                    if ( ! empty( $args['options'] ) ) {
3952
+                        $options .= "options: [";
3953
+                        foreach ( $args['options'] as $option_val => $option_label ) {
3954
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3955
+                        }
3956
+                        $options .= "],";
3957
+                    }
3958
+                }
3959
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3960
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3961
+                }
3962 3962
 
3963
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3964
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3963
+                if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3964
+                    $after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3965 3965
 									  className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3966 3966
 									  style: {margin:'-8px 0 8px 0',display: 'block'},
3967 3967
 									  onClick: function(){
@@ -3972,8 +3972,8 @@  discard block
 block discarded – undo
3972 3972
 									},
3973 3973
 									'Clear'
3974 3974
 							),";
3975
-				}
3976
-			} elseif ( $args['type'] == 'tagselect' ) {
3975
+                }
3976
+            } elseif ( $args['type'] == 'tagselect' ) {
3977 3977
 //				$type = 'FormTokenField';
3978 3978
 //
3979 3979
 //				if ( ! empty( $args['options'] ) ) {
@@ -4008,20 +4008,20 @@  discard block
 block discarded – undo
4008 4008
 //				$value     = "[]";
4009 4009
 //				$extra .= ' __experimentalExpandOnFocus: true,';
4010 4010
 
4011
-			} else if ( $args['type'] == 'alignment' ) {
4012
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
4013
-			} else if ( $args['type'] == 'margins' ) {
4014
-
4015
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
4016
-				$type = 'TextControl';
4017
-				$value = "(props.attributes.$key ? props.attributes.$key : '')";
4018
-				$args['type'] = 'text';
4019
-				$options .= 'disabled:true,';
4020
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
4021
-				$bsvc_body = $this->block_visibility_fields( $args );
4022
-				// @TODO reset button
4023
-				$bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __( 'Reset', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __( 'Close', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __( 'Save Rules', 'ayecode-connect' ) . '</button>';
4024
-				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
4011
+            } else if ( $args['type'] == 'alignment' ) {
4012
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
4013
+            } else if ( $args['type'] == 'margins' ) {
4014
+
4015
+            } else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
4016
+                $type = 'TextControl';
4017
+                $value = "(props.attributes.$key ? props.attributes.$key : '')";
4018
+                $args['type'] = 'text';
4019
+                $options .= 'disabled:true,';
4020
+                $bsvc_title = esc_attr( addslashes( $args['title'] ) );
4021
+                $bsvc_body = $this->block_visibility_fields( $args );
4022
+                // @TODO reset button
4023
+                $bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __( 'Reset', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __( 'Close', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __( 'Save Rules', 'ayecode-connect' ) . '</button>';
4024
+                $after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
4025 4025
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
4026 4026
 						onClick: function() {
4027 4027
 							var sValue = props.attributes." . $key . ";
@@ -4047,39 +4047,39 @@  discard block
 block discarded – undo
4047 4047
 					},
4048 4048
 					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
4049 4049
 				) ),";
4050
-			} else {
4051
-				return;// if we have not implemented the control then don't break the JS.
4052
-			}
4050
+            } else {
4051
+                return;// if we have not implemented the control then don't break the JS.
4052
+            }
4053 4053
 
4054
-			// color input does not show the labels so we add them
4055
-			if($args['type']=='color'){
4056
-				// add show only if advanced
4057
-				echo $require_advanced;
4058
-				// add setting require if defined
4059
-				echo $element_require;
4060
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
4061
-			}
4054
+            // color input does not show the labels so we add them
4055
+            if($args['type']=='color'){
4056
+                // add show only if advanced
4057
+                echo $require_advanced;
4058
+                // add setting require if defined
4059
+                echo $element_require;
4060
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
4061
+            }
4062 4062
 
4063
-			// add show only if advanced
4064
-			echo $require_advanced;
4065
-			// add setting require if defined
4066
-			echo $element_require;
4067
-			echo $device_type_require;
4063
+            // add show only if advanced
4064
+            echo $require_advanced;
4065
+            // add setting require if defined
4066
+            echo $element_require;
4067
+            echo $device_type_require;
4068 4068
 
4069
-			// icon
4070
-			echo $icon;
4071
-			?>
4069
+            // icon
4070
+            echo $icon;
4071
+            ?>
4072 4072
 			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
4073 4073
 			label: <?php if ( empty( $args['title'] ) ) { echo "''"; } else if ( empty( $args['row'] ) && ! empty( $args['device_type'] ) ) { ?>el('label',{className:'components-base-control__label',style:{width:"100%"}},el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['title'] ) ?>'}}),<?php if ( $device_type_icon ) { ?>deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})<?php } ?>)<?php
4074
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
4074
+            } else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
4075 4075
 			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
4076 4076
 			value: <?php echo $value; ?>,
4077 4077
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
4078
-				echo "type: '" . addslashes( $args['type'] ) . "',";
4079
-			} ?>
4078
+                echo "type: '" . addslashes( $args['type'] ) . "',";
4079
+            } ?>
4080 4080
 			<?php if ( ! empty( $args['placeholder'] ) ) {
4081
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
4082
-			} ?>
4081
+                echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
4082
+            } ?>
4083 4083
 			<?php echo $options; ?>
4084 4084
 			<?php echo $extra; ?>
4085 4085
 			<?php echo $custom_attributes; ?>
@@ -4091,1366 +4091,1366 @@  discard block
 block discarded – undo
4091 4091
 			<?php } ?>
4092 4092
 		} <?php echo $inside_elements; ?> ),
4093 4093
 			<?php
4094
-			echo $after_elements;
4095
-		}
4094
+            echo $after_elements;
4095
+        }
4096 4096
 
4097
-		/**
4098
-		 * Convert an array of attributes to block string.
4099
-		 *
4100
-		 * @param $custom_attributes
4101
-		 *
4102
-		 * @return string
4103
-		 *@todo there is prob a faster way to do this, also we could add some validation here.
4104
-		 *
4105
-		 */
4106
-		public function array_to_attributes( $custom_attributes, $html = false ) {
4107
-			$attributes = '';
4108
-			if ( ! empty( $custom_attributes ) ) {
4109
-
4110
-				foreach ( $custom_attributes as $key => $val ) {
4111
-					if(is_array($val)){
4112
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4113
-					}else{
4114
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4115
-					}
4116
-				}
4097
+        /**
4098
+         * Convert an array of attributes to block string.
4099
+         *
4100
+         * @param $custom_attributes
4101
+         *
4102
+         * @return string
4103
+         *@todo there is prob a faster way to do this, also we could add some validation here.
4104
+         *
4105
+         */
4106
+        public function array_to_attributes( $custom_attributes, $html = false ) {
4107
+            $attributes = '';
4108
+            if ( ! empty( $custom_attributes ) ) {
4109
+
4110
+                foreach ( $custom_attributes as $key => $val ) {
4111
+                    if(is_array($val)){
4112
+                        $attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4113
+                    }else{
4114
+                        $attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4115
+                    }
4116
+                }
4117 4117
 
4118
-			}
4118
+            }
4119 4119
 
4120
-			return $attributes;
4121
-		}
4120
+            return $attributes;
4121
+        }
4122 4122
 
4123 4123
 
4124 4124
 
4125
-		/**
4126
-		 * A self looping function to create the output for JS block elements.
4127
-		 *
4128
-		 * This is what is output in the WP Editor visual view.
4129
-		 *
4130
-		 * @param $args
4131
-		 */
4132
-		public function block_element( $args, $save = false ) {
4125
+        /**
4126
+         * A self looping function to create the output for JS block elements.
4127
+         *
4128
+         * This is what is output in the WP Editor visual view.
4129
+         *
4130
+         * @param $args
4131
+         */
4132
+        public function block_element( $args, $save = false ) {
4133 4133
 
4134 4134
 //            print_r($args);echo '###';exit;
4135 4135
 
4136
-			if ( ! empty( $args ) ) {
4137
-				foreach ( $args as $element => $new_args ) {
4136
+            if ( ! empty( $args ) ) {
4137
+                foreach ( $args as $element => $new_args ) {
4138 4138
 
4139
-					if ( is_array( $new_args ) ) { // its an element
4139
+                    if ( is_array( $new_args ) ) { // its an element
4140 4140
 
4141 4141
 
4142
-						if ( isset( $new_args['element'] ) ) {
4142
+                        if ( isset( $new_args['element'] ) ) {
4143 4143
 
4144
-							if ( isset( $new_args['element_require'] ) ) {
4145
-								echo str_replace( array(
4146
-										"'+",
4147
-										"+'"
4148
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4149
-								unset( $new_args['element_require'] );
4150
-							}
4144
+                            if ( isset( $new_args['element_require'] ) ) {
4145
+                                echo str_replace( array(
4146
+                                        "'+",
4147
+                                        "+'"
4148
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4149
+                                unset( $new_args['element_require'] );
4150
+                            }
4151 4151
 
4152
-							if($new_args['element']=='InnerBlocks'){
4153
-								echo "\n el( InnerBlocks, {";
4154
-							}elseif($new_args['element']=='innerBlocksProps'){
4155
-								$element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4156
-							  //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4152
+                            if($new_args['element']=='InnerBlocks'){
4153
+                                echo "\n el( InnerBlocks, {";
4154
+                            }elseif($new_args['element']=='innerBlocksProps'){
4155
+                                $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4156
+                                //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4157 4157
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4158
-								echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4159
-								echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4160
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4161
-
4162
-								echo "} ), {";
4163
-								echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4164
-							//    echo '###';
4165
-
4166
-							  //  echo '###';
4167
-							}elseif($new_args['element']=='BlocksProps'){
4168
-
4169
-								if ( isset($new_args['if_inner_element']) ) {
4170
-									$element = $new_args['if_inner_element'];
4171
-								}else {
4172
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4173
-								}
4174
-
4175
-								unset($new_args['inner_element']);
4176
-								echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4177
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4178
-
4179
-
4180
-							   // echo "} ),";
4181
-
4182
-							}else{
4183
-								echo "\n el( '" . $new_args['element'] . "', {";
4184
-							}
4185
-
4186
-
4187
-							// get the attributes
4188
-							foreach ( $new_args as $new_key => $new_value ) {
4189
-
4190
-
4191
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4192
-									// do nothing
4193
-								} else {
4194
-									echo $this->block_element( array( $new_key => $new_value ),$save );
4195
-								}
4196
-							}
4197
-
4198
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4199
-
4200
-							// get the content
4201
-							$first_item = 0;
4202
-							foreach ( $new_args as $new_key => $new_value ) {
4203
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4204
-
4205
-									if ( $new_key === 'content' ) {
4206
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4207
-									}else if ( $new_key === 'if_content' ) {
4208
-										echo  $this->block_props_replace(  $new_value  );
4209
-									}
4210
-
4211
-									if ( is_array( $new_value ) ) {
4212
-
4213
-										if ( isset( $new_value['element_require'] ) ) {
4214
-											echo str_replace( array(
4215
-													"'+",
4216
-													"+'"
4217
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4218
-											unset( $new_value['element_require'] );
4219
-										}
4220
-
4221
-										if ( isset( $new_value['element_repeat'] ) ) {
4222
-											$x = 1;
4223
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4224
-												$this->block_element( array( '' => $new_value ),$save );
4225
-												$x ++;
4226
-											}
4227
-										} else {
4228
-											$this->block_element( array( '' => $new_value ),$save );
4229
-										}
4230
-									}
4231
-									$first_item ++;
4232
-								}
4233
-							}
4234
-
4235
-							if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4236
-								echo "))";// end content
4237
-							}else{
4238
-								echo ")";// end content
4239
-							}
4240
-
4241
-
4242
-							echo ", \n";
4243
-
4244
-						}
4245
-					} else {
4246
-
4247
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4248
-							$extra = '';
4249
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4250
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4251
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4252
-							}
4253
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4254
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4255
-							$new_args = str_replace('[%WrapStyle%]','',$new_args);
4256
-							echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4158
+                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4159
+                                echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4160
+                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4161
+
4162
+                                echo "} ), {";
4163
+                                echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4164
+                            //    echo '###';
4165
+
4166
+                                //  echo '###';
4167
+                            }elseif($new_args['element']=='BlocksProps'){
4168
+
4169
+                                if ( isset($new_args['if_inner_element']) ) {
4170
+                                    $element = $new_args['if_inner_element'];
4171
+                                }else {
4172
+                                    $element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4173
+                                }
4174
+
4175
+                                unset($new_args['inner_element']);
4176
+                                echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4177
+                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4178
+
4179
+
4180
+                                // echo "} ),";
4181
+
4182
+                            }else{
4183
+                                echo "\n el( '" . $new_args['element'] . "', {";
4184
+                            }
4185
+
4186
+
4187
+                            // get the attributes
4188
+                            foreach ( $new_args as $new_key => $new_value ) {
4189
+
4190
+
4191
+                                if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4192
+                                    // do nothing
4193
+                                } else {
4194
+                                    echo $this->block_element( array( $new_key => $new_value ),$save );
4195
+                                }
4196
+                            }
4197
+
4198
+                            echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4199
+
4200
+                            // get the content
4201
+                            $first_item = 0;
4202
+                            foreach ( $new_args as $new_key => $new_value ) {
4203
+                                if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4204
+
4205
+                                    if ( $new_key === 'content' ) {
4206
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4207
+                                    }else if ( $new_key === 'if_content' ) {
4208
+                                        echo  $this->block_props_replace(  $new_value  );
4209
+                                    }
4210
+
4211
+                                    if ( is_array( $new_value ) ) {
4212
+
4213
+                                        if ( isset( $new_value['element_require'] ) ) {
4214
+                                            echo str_replace( array(
4215
+                                                    "'+",
4216
+                                                    "+'"
4217
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4218
+                                            unset( $new_value['element_require'] );
4219
+                                        }
4220
+
4221
+                                        if ( isset( $new_value['element_repeat'] ) ) {
4222
+                                            $x = 1;
4223
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
4224
+                                                $this->block_element( array( '' => $new_value ),$save );
4225
+                                                $x ++;
4226
+                                            }
4227
+                                        } else {
4228
+                                            $this->block_element( array( '' => $new_value ),$save );
4229
+                                        }
4230
+                                    }
4231
+                                    $first_item ++;
4232
+                                }
4233
+                            }
4234
+
4235
+                            if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4236
+                                echo "))";// end content
4237
+                            }else{
4238
+                                echo ")";// end content
4239
+                            }
4240
+
4241
+
4242
+                            echo ", \n";
4243
+
4244
+                        }
4245
+                    } else {
4246
+
4247
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
4248
+                            $extra = '';
4249
+                            if( strpos($new_args, '[%WrapClass%]') !== false ){
4250
+                                $new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4251
+                                $new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4252
+                            }
4253
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4254
+                        } elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4255
+                            $new_args = str_replace('[%WrapStyle%]','',$new_args);
4256
+                            echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4257 4257
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4258
-						} elseif ( $element == 'style' ) {
4259
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4260
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4261
-							$new_args = str_replace('[%WrapClass%]','',$new_args);
4262
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4263
-						} elseif ( $element == 'template' && $new_args ) {
4264
-							echo $element . ": $new_args,";
4265
-						} else {
4266
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4267
-						}
4268
-
4269
-					}
4270
-				}
4271
-			}
4272
-		}
4258
+                        } elseif ( $element == 'style' ) {
4259
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4260
+                        } elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4261
+                            $new_args = str_replace('[%WrapClass%]','',$new_args);
4262
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4263
+                        } elseif ( $element == 'template' && $new_args ) {
4264
+                            echo $element . ": $new_args,";
4265
+                        } else {
4266
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4267
+                        }
4268
+
4269
+                    }
4270
+                }
4271
+            }
4272
+        }
4273 4273
 
4274
-		/**
4275
-		 * Replace block attributes placeholders with the proper naming.
4276
-		 *
4277
-		 * @param $string
4278
-		 *
4279
-		 * @return mixed
4280
-		 */
4281
-		public function block_props_replace( $string, $no_wrap = false ) {
4282
-			if ( $no_wrap ) {
4283
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4284
-			} else {
4285
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4286
-			}
4274
+        /**
4275
+         * Replace block attributes placeholders with the proper naming.
4276
+         *
4277
+         * @param $string
4278
+         *
4279
+         * @return mixed
4280
+         */
4281
+        public function block_props_replace( $string, $no_wrap = false ) {
4282
+            if ( $no_wrap ) {
4283
+                $string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4284
+            } else {
4285
+                $string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4286
+            }
4287 4287
 
4288
-			return $string;
4289
-		}
4288
+            return $string;
4289
+        }
4290 4290
 
4291
-		/**
4292
-		 * Outputs the content of the widget
4293
-		 *
4294
-		 * @param array $args
4295
-		 * @param array $instance
4296
-		 */
4297
-		public function widget( $args, $instance ) {
4298
-			if ( ! is_array( $args ) ) {
4299
-				$args = array();
4300
-			}
4291
+        /**
4292
+         * Outputs the content of the widget
4293
+         *
4294
+         * @param array $args
4295
+         * @param array $instance
4296
+         */
4297
+        public function widget( $args, $instance ) {
4298
+            if ( ! is_array( $args ) ) {
4299
+                $args = array();
4300
+            }
4301 4301
 
4302
-			// Get the filtered values
4303
-			$argument_values = $this->argument_values( $instance );
4304
-			$argument_values = $this->string_to_bool( $argument_values );
4305
-			$output          = $this->output( $argument_values, $args );
4302
+            // Get the filtered values
4303
+            $argument_values = $this->argument_values( $instance );
4304
+            $argument_values = $this->string_to_bool( $argument_values );
4305
+            $output          = $this->output( $argument_values, $args );
4306 4306
 
4307
-			$no_wrap = false;
4308
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4309
-				$no_wrap = true;
4310
-			}
4307
+            $no_wrap = false;
4308
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4309
+                $no_wrap = true;
4310
+            }
4311 4311
 
4312
-			ob_start();
4313
-			if ( $output && ! $no_wrap ) {
4312
+            ob_start();
4313
+            if ( $output && ! $no_wrap ) {
4314 4314
 
4315
-				$class_original = $this->options['widget_ops']['classname'];
4316
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4315
+                $class_original = $this->options['widget_ops']['classname'];
4316
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4317 4317
 
4318
-				// Before widget
4319
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4320
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4321
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4322
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4318
+                // Before widget
4319
+                $before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4320
+                $before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4321
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4322
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4323 4323
 
4324
-				// After widget
4325
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4326
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4327
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4324
+                // After widget
4325
+                $after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4326
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4327
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4328 4328
 
4329
-				echo $before_widget;
4330
-				// elementor strips the widget wrapping div so we check for and add it back if needed
4331
-				if ( $this->is_elementor_widget_output() ) {
4332
-					// Filter class & attrs for elementor widget output.
4333
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4334
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4329
+                echo $before_widget;
4330
+                // elementor strips the widget wrapping div so we check for and add it back if needed
4331
+                if ( $this->is_elementor_widget_output() ) {
4332
+                    // Filter class & attrs for elementor widget output.
4333
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4334
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4335 4335
 
4336
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4337
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4336
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4337
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4338 4338
 
4339
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4340
-				}
4341
-				echo $this->output_title( $args, $instance );
4342
-				echo $output;
4343
-				if ( $this->is_elementor_widget_output() ) {
4344
-					echo "</span>";
4345
-				}
4346
-				echo $after_widget;
4347
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4348
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4349
-				echo $output;
4350
-			} elseif ( $output && $no_wrap ) {
4351
-				echo $output;
4352
-			}
4353
-			$output = ob_get_clean();
4339
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4340
+                }
4341
+                echo $this->output_title( $args, $instance );
4342
+                echo $output;
4343
+                if ( $this->is_elementor_widget_output() ) {
4344
+                    echo "</span>";
4345
+                }
4346
+                echo $after_widget;
4347
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4348
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4349
+                echo $output;
4350
+            } elseif ( $output && $no_wrap ) {
4351
+                echo $output;
4352
+            }
4353
+            $output = ob_get_clean();
4354 4354
 
4355
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4355
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4356 4356
 
4357
-			echo $output;
4358
-		}
4357
+            echo $output;
4358
+        }
4359 4359
 
4360
-		/**
4361
-		 * Tests if the current output is inside a elementor container.
4362
-		 *
4363
-		 * @return bool
4364
-		 *@since 1.0.4
4365
-		 */
4366
-		public function is_elementor_widget_output() {
4367
-			$result = false;
4368
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4369
-				$result = true;
4370
-			}
4360
+        /**
4361
+         * Tests if the current output is inside a elementor container.
4362
+         *
4363
+         * @return bool
4364
+         *@since 1.0.4
4365
+         */
4366
+        public function is_elementor_widget_output() {
4367
+            $result = false;
4368
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4369
+                $result = true;
4370
+            }
4371 4371
 
4372
-			return $result;
4373
-		}
4372
+            return $result;
4373
+        }
4374 4374
 
4375
-		/**
4376
-		 * Tests if the current output is inside a elementor preview.
4377
-		 *
4378
-		 * @return bool
4379
-		 *@since 1.0.4
4380
-		 */
4381
-		public function is_elementor_preview() {
4382
-			$result = false;
4383
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4384
-				$result = true;
4385
-			}
4375
+        /**
4376
+         * Tests if the current output is inside a elementor preview.
4377
+         *
4378
+         * @return bool
4379
+         *@since 1.0.4
4380
+         */
4381
+        public function is_elementor_preview() {
4382
+            $result = false;
4383
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4384
+                $result = true;
4385
+            }
4386 4386
 
4387
-			return $result;
4388
-		}
4387
+            return $result;
4388
+        }
4389 4389
 
4390
-		/**
4391
-		 * Tests if the current output is inside a Divi preview.
4392
-		 *
4393
-		 * @return bool
4394
-		 *@since 1.0.6
4395
-		 */
4396
-		public function is_divi_preview() {
4397
-			$result = false;
4398
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4399
-				$result = true;
4400
-			}
4390
+        /**
4391
+         * Tests if the current output is inside a Divi preview.
4392
+         *
4393
+         * @return bool
4394
+         *@since 1.0.6
4395
+         */
4396
+        public function is_divi_preview() {
4397
+            $result = false;
4398
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4399
+                $result = true;
4400
+            }
4401 4401
 
4402
-			return $result;
4403
-		}
4402
+            return $result;
4403
+        }
4404 4404
 
4405
-		/**
4406
-		 * Tests if the current output is inside a Beaver builder preview.
4407
-		 *
4408
-		 * @return bool
4409
-		 *@since 1.0.6
4410
-		 */
4411
-		public function is_beaver_preview() {
4412
-			$result = false;
4413
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4414
-				$result = true;
4415
-			}
4405
+        /**
4406
+         * Tests if the current output is inside a Beaver builder preview.
4407
+         *
4408
+         * @return bool
4409
+         *@since 1.0.6
4410
+         */
4411
+        public function is_beaver_preview() {
4412
+            $result = false;
4413
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
4414
+                $result = true;
4415
+            }
4416 4416
 
4417
-			return $result;
4418
-		}
4417
+            return $result;
4418
+        }
4419 4419
 
4420
-		/**
4421
-		 * Tests if the current output is inside a siteorigin builder preview.
4422
-		 *
4423
-		 * @return bool
4424
-		 *@since 1.0.6
4425
-		 */
4426
-		public function is_siteorigin_preview() {
4427
-			$result = false;
4428
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4429
-				$result = true;
4430
-			}
4420
+        /**
4421
+         * Tests if the current output is inside a siteorigin builder preview.
4422
+         *
4423
+         * @return bool
4424
+         *@since 1.0.6
4425
+         */
4426
+        public function is_siteorigin_preview() {
4427
+            $result = false;
4428
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4429
+                $result = true;
4430
+            }
4431 4431
 
4432
-			return $result;
4433
-		}
4432
+            return $result;
4433
+        }
4434 4434
 
4435
-		/**
4436
-		 * Tests if the current output is inside a cornerstone builder preview.
4437
-		 *
4438
-		 * @return bool
4439
-		 *@since 1.0.8
4440
-		 */
4441
-		public function is_cornerstone_preview() {
4442
-			$result = false;
4443
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4444
-				$result = true;
4445
-			}
4435
+        /**
4436
+         * Tests if the current output is inside a cornerstone builder preview.
4437
+         *
4438
+         * @return bool
4439
+         *@since 1.0.8
4440
+         */
4441
+        public function is_cornerstone_preview() {
4442
+            $result = false;
4443
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4444
+                $result = true;
4445
+            }
4446 4446
 
4447
-			return $result;
4448
-		}
4447
+            return $result;
4448
+        }
4449 4449
 
4450
-		/**
4451
-		 * Tests if the current output is inside a fusion builder preview.
4452
-		 *
4453
-		 * @return bool
4454
-		 *@since 1.1.0
4455
-		 */
4456
-		public function is_fusion_preview() {
4457
-			$result = false;
4458
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4459
-				$result = true;
4460
-			}
4450
+        /**
4451
+         * Tests if the current output is inside a fusion builder preview.
4452
+         *
4453
+         * @return bool
4454
+         *@since 1.1.0
4455
+         */
4456
+        public function is_fusion_preview() {
4457
+            $result = false;
4458
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4459
+                $result = true;
4460
+            }
4461 4461
 
4462
-			return $result;
4463
-		}
4462
+            return $result;
4463
+        }
4464 4464
 
4465
-		/**
4466
-		 * Tests if the current output is inside a Oxygen builder preview.
4467
-		 *
4468
-		 * @return bool
4469
-		 *@since 1.0.18
4470
-		 */
4471
-		public function is_oxygen_preview() {
4472
-			$result = false;
4473
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4474
-				$result = true;
4475
-			}
4465
+        /**
4466
+         * Tests if the current output is inside a Oxygen builder preview.
4467
+         *
4468
+         * @return bool
4469
+         *@since 1.0.18
4470
+         */
4471
+        public function is_oxygen_preview() {
4472
+            $result = false;
4473
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4474
+                $result = true;
4475
+            }
4476 4476
 
4477
-			return $result;
4478
-		}
4477
+            return $result;
4478
+        }
4479 4479
 
4480
-		/**
4481
-		 * Check for Kallyas theme Zion builder preview.
4482
-		 *
4483
-		 * @since 1.1.22
4484
-		 *
4485
-		 * @return bool True when preview page otherwise false.
4486
-		 */
4487
-		public function is_kallyas_zion_preview() {
4488
-			$result = false;
4489
-
4490
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4491
-				$result = true;
4492
-			}
4480
+        /**
4481
+         * Check for Kallyas theme Zion builder preview.
4482
+         *
4483
+         * @since 1.1.22
4484
+         *
4485
+         * @return bool True when preview page otherwise false.
4486
+         */
4487
+        public function is_kallyas_zion_preview() {
4488
+            $result = false;
4493 4489
 
4494
-			return $result;
4495
-		}
4490
+            if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4491
+                $result = true;
4492
+            }
4496 4493
 
4497
-		/**
4498
-		 * Check for Bricks theme builder preview.
4499
-		 *
4500
-		 * @since 1.1.31
4501
-		 *
4502
-		 * @return bool True when preview page otherwise false.
4503
-		 */
4504
-		public function is_bricks_preview() {
4505
-			$result = false;
4506
-
4507
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4508
-				$result = true;
4509
-			}
4494
+            return $result;
4495
+        }
4510 4496
 
4511
-			return $result;
4512
-		}
4497
+        /**
4498
+         * Check for Bricks theme builder preview.
4499
+         *
4500
+         * @since 1.1.31
4501
+         *
4502
+         * @return bool True when preview page otherwise false.
4503
+         */
4504
+        public function is_bricks_preview() {
4505
+            $result = false;
4513 4506
 
4514
-		/**
4515
-		 * General function to check if we are in a preview situation.
4516
-		 *
4517
-		 * @return bool
4518
-		 *@since 1.0.6
4519
-		 */
4520
-		public function is_preview() {
4521
-			$preview = false;
4522
-			if ( $this->is_divi_preview() ) {
4523
-				$preview = true;
4524
-			} elseif ( $this->is_elementor_preview() ) {
4525
-				$preview = true;
4526
-			} elseif ( $this->is_beaver_preview() ) {
4527
-				$preview = true;
4528
-			} elseif ( $this->is_siteorigin_preview() ) {
4529
-				$preview = true;
4530
-			} elseif ( $this->is_cornerstone_preview() ) {
4531
-				$preview = true;
4532
-			} elseif ( $this->is_fusion_preview() ) {
4533
-				$preview = true;
4534
-			} elseif ( $this->is_oxygen_preview() ) {
4535
-				$preview = true;
4536
-			} elseif( $this->is_kallyas_zion_preview() ) {
4537
-				$preview = true;
4538
-			} elseif( $this->is_block_content_call() ) {
4539
-				$preview = true;
4540
-			} elseif( $this->is_bricks_preview() ) {
4541
-				$preview = true;
4542
-			}
4507
+            if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4508
+                $result = true;
4509
+            }
4543 4510
 
4544
-			return $preview;
4545
-		}
4511
+            return $result;
4512
+        }
4546 4513
 
4547
-		/**
4548
-		 * Output the super title.
4549
-		 *
4550
-		 * @param $args
4551
-		 * @param array $instance
4552
-		 *
4553
-		 * @return string
4554
-		 */
4555
-		public function output_title( $args, $instance = array() ) {
4556
-			$output = '';
4557
-			if ( ! empty( $instance['title'] ) ) {
4558
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4559
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4560
-
4561
-				if ( empty( $instance['widget_title_tag'] ) ) {
4562
-					if ( ! isset( $args['before_title'] ) ) {
4563
-						$args['before_title'] = '';
4564
-					}
4514
+        /**
4515
+         * General function to check if we are in a preview situation.
4516
+         *
4517
+         * @return bool
4518
+         *@since 1.0.6
4519
+         */
4520
+        public function is_preview() {
4521
+            $preview = false;
4522
+            if ( $this->is_divi_preview() ) {
4523
+                $preview = true;
4524
+            } elseif ( $this->is_elementor_preview() ) {
4525
+                $preview = true;
4526
+            } elseif ( $this->is_beaver_preview() ) {
4527
+                $preview = true;
4528
+            } elseif ( $this->is_siteorigin_preview() ) {
4529
+                $preview = true;
4530
+            } elseif ( $this->is_cornerstone_preview() ) {
4531
+                $preview = true;
4532
+            } elseif ( $this->is_fusion_preview() ) {
4533
+                $preview = true;
4534
+            } elseif ( $this->is_oxygen_preview() ) {
4535
+                $preview = true;
4536
+            } elseif( $this->is_kallyas_zion_preview() ) {
4537
+                $preview = true;
4538
+            } elseif( $this->is_block_content_call() ) {
4539
+                $preview = true;
4540
+            } elseif( $this->is_bricks_preview() ) {
4541
+                $preview = true;
4542
+            }
4565 4543
 
4566
-					if ( ! isset( $args['after_title'] ) ) {
4567
-						$args['after_title'] = '';
4568
-					}
4544
+            return $preview;
4545
+        }
4569 4546
 
4570
-					$output = $args['before_title'] . $title . $args['after_title'];
4571
-				} else {
4572
-					$tag 			= esc_attr( $instance['widget_title_tag'] );
4573
-					$allowed_tags 	= array( 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p' );
4574
-					$title_tag      = in_array( $tag, $allowed_tags, true ) ? esc_attr( $tag ) : 'h2';
4575
-
4576
-					// classes
4577
-					$title_classes = array();
4578
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4579
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4580
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4581
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4582
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4583
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4584
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4585
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4586
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4587
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4588
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4589
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4590
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4591
-
4592
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4593
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
4594
-				}
4547
+        /**
4548
+         * Output the super title.
4549
+         *
4550
+         * @param $args
4551
+         * @param array $instance
4552
+         *
4553
+         * @return string
4554
+         */
4555
+        public function output_title( $args, $instance = array() ) {
4556
+            $output = '';
4557
+            if ( ! empty( $instance['title'] ) ) {
4558
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4559
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4560
+
4561
+                if ( empty( $instance['widget_title_tag'] ) ) {
4562
+                    if ( ! isset( $args['before_title'] ) ) {
4563
+                        $args['before_title'] = '';
4564
+                    }
4565
+
4566
+                    if ( ! isset( $args['after_title'] ) ) {
4567
+                        $args['after_title'] = '';
4568
+                    }
4569
+
4570
+                    $output = $args['before_title'] . $title . $args['after_title'];
4571
+                } else {
4572
+                    $tag 			= esc_attr( $instance['widget_title_tag'] );
4573
+                    $allowed_tags 	= array( 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p' );
4574
+                    $title_tag      = in_array( $tag, $allowed_tags, true ) ? esc_attr( $tag ) : 'h2';
4575
+
4576
+                    // classes
4577
+                    $title_classes = array();
4578
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4579
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4580
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4581
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4582
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4583
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4584
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4585
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4586
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4587
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4588
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4589
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4590
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4591
+
4592
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4593
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
4594
+                }
4595 4595
 
4596
-			}
4596
+            }
4597 4597
 
4598
-			return $output;
4599
-		}
4598
+            return $output;
4599
+        }
4600 4600
 
4601
-		/**
4602
-		 * Outputs the options form inputs for the widget.
4603
-		 *
4604
-		 * @param array $instance The widget options.
4605
-		 */
4606
-		public function form( $instance ) {
4601
+        /**
4602
+         * Outputs the options form inputs for the widget.
4603
+         *
4604
+         * @param array $instance The widget options.
4605
+         */
4606
+        public function form( $instance ) {
4607 4607
 
4608
-			// set widget instance
4609
-			$this->instance = $instance;
4608
+            // set widget instance
4609
+            $this->instance = $instance;
4610 4610
 
4611
-			// set it as a SD widget
4612
-			echo $this->widget_advanced_toggle();
4611
+            // set it as a SD widget
4612
+            echo $this->widget_advanced_toggle();
4613 4613
 
4614
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4615
-			$arguments_raw = $this->get_arguments();
4614
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4615
+            $arguments_raw = $this->get_arguments();
4616 4616
 
4617
-			if ( is_array( $arguments_raw ) ) {
4617
+            if ( is_array( $arguments_raw ) ) {
4618 4618
 
4619
-				$arguments = $this->group_arguments( $arguments_raw );
4619
+                $arguments = $this->group_arguments( $arguments_raw );
4620 4620
 
4621
-				// Do we have sections?
4622
-				$has_sections = $arguments == $arguments_raw ? false : true;
4621
+                // Do we have sections?
4622
+                $has_sections = $arguments == $arguments_raw ? false : true;
4623 4623
 
4624 4624
 
4625
-				if ( $has_sections ) {
4626
-					$panel_count = 0;
4627
-					foreach ( $arguments as $key => $args ) {
4625
+                if ( $has_sections ) {
4626
+                    $panel_count = 0;
4627
+                    foreach ( $arguments as $key => $args ) {
4628 4628
 
4629
-						?>
4629
+                        ?>
4630 4630
 						<script>
4631 4631
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
4632 4632
 						</script>
4633 4633
 						<?php
4634 4634
 
4635
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
4636
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4637
-						echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
4638
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4635
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
4636
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4637
+                        echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
4638
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4639 4639
 
4640
-						foreach ( $args as $k => $a ) {
4640
+                        foreach ( $args as $k => $a ) {
4641 4641
 
4642
-							$this->widget_inputs_row_start($k, $a);
4643
-							$this->widget_inputs( $a, $instance );
4644
-							$this->widget_inputs_row_end($k, $a);
4642
+                            $this->widget_inputs_row_start($k, $a);
4643
+                            $this->widget_inputs( $a, $instance );
4644
+                            $this->widget_inputs_row_end($k, $a);
4645 4645
 
4646
-						}
4646
+                        }
4647 4647
 
4648
-						echo "</div>";
4648
+                        echo "</div>";
4649 4649
 
4650
-						$panel_count ++;
4650
+                        $panel_count ++;
4651 4651
 
4652
-					}
4653
-				} else {
4654
-					foreach ( $arguments as $key => $args ) {
4655
-						$this->widget_inputs_row_start($key, $args);
4656
-						$this->widget_inputs( $args, $instance );
4657
-						$this->widget_inputs_row_end($key, $args);
4658
-					}
4659
-				}
4652
+                    }
4653
+                } else {
4654
+                    foreach ( $arguments as $key => $args ) {
4655
+                        $this->widget_inputs_row_start($key, $args);
4656
+                        $this->widget_inputs( $args, $instance );
4657
+                        $this->widget_inputs_row_end($key, $args);
4658
+                    }
4659
+                }
4660 4660
 
4661
-			}
4662
-		}
4661
+            }
4662
+        }
4663 4663
 
4664
-		public function widget_inputs_row_start( $key, $args ) {
4665
-			if ( ! empty( $args['row'] ) ) {
4666
-				// Maybe open
4667
-				if ( ! empty( $args['row']['open'] ) ) {
4668
-					?>
4664
+        public function widget_inputs_row_start( $key, $args ) {
4665
+            if ( ! empty( $args['row'] ) ) {
4666
+                // Maybe open
4667
+                if ( ! empty( $args['row']['open'] ) ) {
4668
+                    ?>
4669 4669
 					<div class='bsui sd-argument' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php echo ( ! empty( $args['row']['element_require'] ) ? $this->convert_element_require( $args['row']['element_require'] ) : '' ); ?>'>
4670 4670
 					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4671 4671
 					<?php
4672
-						if ( isset( $args['row']['icon'] ) ) {
4673
-							$args['row']['icon'] = '';
4674
-						}
4675
-
4676
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4677
-							$args['row']['device_type'] = $args['device_type'];
4678
-						}
4679
-					?>
4672
+                        if ( isset( $args['row']['icon'] ) ) {
4673
+                            $args['row']['icon'] = '';
4674
+                        }
4675
+
4676
+                        if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4677
+                            $args['row']['device_type'] = $args['device_type'];
4678
+                        }
4679
+                    ?>
4680 4680
 					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4681 4681
 					<?php } ?>
4682 4682
 					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4683 4683
 					<div class='col pr-2'>
4684 4684
 					<?php
4685
-				} else if ( ! empty( $args['row']['close'] ) ) {
4686
-					echo "<div class='col pl-0 ps-0'>";
4687
-				} else {
4688
-					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4689
-				}
4690
-			}
4691
-		}
4685
+                } else if ( ! empty( $args['row']['close'] ) ) {
4686
+                    echo "<div class='col pl-0 ps-0'>";
4687
+                } else {
4688
+                    echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4689
+                }
4690
+            }
4691
+        }
4692 4692
 
4693
-		public function widget_inputs_row_end( $key, $args ) {
4694
-			if ( ! empty( $args['row'] ) ) {
4695
-				// Maybe close
4696
-				if ( ! empty( $args['row']['close'] ) ) {
4697
-					echo "</div></div>";
4698
-				}
4699
-				echo "</div>";
4700
-			}
4701
-		}
4693
+        public function widget_inputs_row_end( $key, $args ) {
4694
+            if ( ! empty( $args['row'] ) ) {
4695
+                // Maybe close
4696
+                if ( ! empty( $args['row']['close'] ) ) {
4697
+                    echo "</div></div>";
4698
+                }
4699
+                echo "</div>";
4700
+            }
4701
+        }
4702 4702
 
4703
-		/**
4704
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
4705
-		 *
4706
-		 * @return string
4707
-		 */
4708
-		public function widget_advanced_toggle() {
4703
+        /**
4704
+         * Get the hidden input that when added makes the advanced button show on widget settings.
4705
+         *
4706
+         * @return string
4707
+         */
4708
+        public function widget_advanced_toggle() {
4709 4709
 
4710
-			$output = '';
4711
-			if ( $this->block_show_advanced() ) {
4712
-				$val = 1;
4713
-			} else {
4714
-				$val = 0;
4715
-			}
4710
+            $output = '';
4711
+            if ( $this->block_show_advanced() ) {
4712
+                $val = 1;
4713
+            } else {
4714
+                $val = 0;
4715
+            }
4716 4716
 
4717
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4717
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4718 4718
 
4719
-			return $output;
4720
-		}
4719
+            return $output;
4720
+        }
4721 4721
 
4722
-		/**
4723
-		 * Convert require element.
4724
-		 *
4725
-		 * @param string $input Input element.
4726
-		 *
4727
-		 * @return string $output
4728
-		 *@since 1.0.0
4729
-		 *
4730
-		 */
4731
-		public function convert_element_require( $input ) {
4732
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4733
-
4734
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4735
-				"jQuery(form).find('[data-argument=\"",
4736
-				"\"]').find('input,select,textarea').val()",
4737
-				"\"]').find('input:checked').val()"
4738
-			), $input ) );
4739
-
4740
-			return $output;
4741
-		}
4722
+        /**
4723
+         * Convert require element.
4724
+         *
4725
+         * @param string $input Input element.
4726
+         *
4727
+         * @return string $output
4728
+         *@since 1.0.0
4729
+         *
4730
+         */
4731
+        public function convert_element_require( $input ) {
4732
+            $input = str_replace( "'", '"', $input );// we only want double quotes
4742 4733
 
4743
-		/**
4744
-		 * Builds the inputs for the widget options.
4745
-		 *
4746
-		 * @param $args
4747
-		 * @param $instance
4748
-		 */
4749
-		public function widget_inputs( $args, $instance ) {
4750
-
4751
-			$class             = "";
4752
-			$element_require   = "";
4753
-			$custom_attributes = "";
4754
-
4755
-			// get value
4756
-			if ( isset( $instance[ $args['name'] ] ) ) {
4757
-				$value = $instance[ $args['name'] ];
4758
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4759
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4760
-			} else {
4761
-				$value = '';
4762
-			}
4734
+            $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4735
+                "jQuery(form).find('[data-argument=\"",
4736
+                "\"]').find('input,select,textarea').val()",
4737
+                "\"]').find('input:checked').val()"
4738
+            ), $input ) );
4763 4739
 
4764
-			// get placeholder
4765
-			if ( ! empty( $args['placeholder'] ) ) {
4766
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4767
-			} else {
4768
-				$placeholder = '';
4769
-			}
4740
+            return $output;
4741
+        }
4770 4742
 
4771
-			// get if advanced
4772
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4773
-				$class .= " sd-advanced-setting ";
4774
-			}
4743
+        /**
4744
+         * Builds the inputs for the widget options.
4745
+         *
4746
+         * @param $args
4747
+         * @param $instance
4748
+         */
4749
+        public function widget_inputs( $args, $instance ) {
4750
+
4751
+            $class             = "";
4752
+            $element_require   = "";
4753
+            $custom_attributes = "";
4754
+
4755
+            // get value
4756
+            if ( isset( $instance[ $args['name'] ] ) ) {
4757
+                $value = $instance[ $args['name'] ];
4758
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4759
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4760
+            } else {
4761
+                $value = '';
4762
+            }
4775 4763
 
4776
-			// element_require
4777
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4778
-				$element_require = $args['element_require'];
4779
-			}
4764
+            // get placeholder
4765
+            if ( ! empty( $args['placeholder'] ) ) {
4766
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4767
+            } else {
4768
+                $placeholder = '';
4769
+            }
4780 4770
 
4781
-			// custom_attributes
4782
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4783
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4784
-			}
4771
+            // get if advanced
4772
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4773
+                $class .= " sd-advanced-setting ";
4774
+            }
4785 4775
 
4786
-			// before wrapper
4787
-			?>
4776
+            // element_require
4777
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4778
+                $element_require = $args['element_require'];
4779
+            }
4780
+
4781
+            // custom_attributes
4782
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4783
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4784
+            }
4785
+
4786
+            // before wrapper
4787
+            ?>
4788 4788
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>" data-argument='<?php echo esc_attr( $args['name'] ); ?>' data-element_require='<?php if ( $element_require ) { echo $this->convert_element_require( $element_require );} ?>'>
4789 4789
 			<?php
4790
-			switch ( $args['type'] ) {
4791
-				//array('text','password','number','email','tel','url','color')
4792
-				case "text":
4793
-				case "password":
4794
-				case "number":
4795
-				case "email":
4796
-				case "tel":
4797
-				case "url":
4798
-				case "color":
4799
-					?>
4790
+            switch ( $args['type'] ) {
4791
+                //array('text','password','number','email','tel','url','color')
4792
+                case "text":
4793
+                case "password":
4794
+                case "number":
4795
+                case "email":
4796
+                case "tel":
4797
+                case "url":
4798
+                case "color":
4799
+                    ?>
4800 4800
 					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
4801 4801
 					<input <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="<?php echo esc_attr( $args['type'] ); ?>" value="<?php echo esc_attr( $value ); ?>">
4802 4802
 					<?php
4803 4803
 
4804
-					break;
4805
-				case "select":
4806
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4807
-					if ( $multiple ) {
4808
-						if ( empty( $value ) ) {
4809
-							$value = array();
4810
-						}
4811
-					}
4812
-					?>
4804
+                    break;
4805
+                case "select":
4806
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4807
+                    if ( $multiple ) {
4808
+                        if ( empty( $value ) ) {
4809
+                            $value = array();
4810
+                        }
4811
+                    }
4812
+                    ?>
4813 4813
 					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
4814 4814
 					<select <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); if ( $multiple ) { echo "[]"; } ?>"
4815 4815
 						<?php if ( $multiple ) {
4816
-							echo "multiple";
4817
-						} //@todo not implemented yet due to gutenberg not supporting it
4818
-						?>>
4816
+                            echo "multiple";
4817
+                        } //@todo not implemented yet due to gutenberg not supporting it
4818
+                        ?>>
4819 4819
 						<?php
4820 4820
 
4821
-						if ( ! empty( $args['options'] ) ) {
4822
-							foreach ( $args['options'] as $val => $label ) {
4823
-								if ( $multiple ) {
4824
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4825
-								} else {
4826
-									$selected = selected( $value, $val, false );
4827
-								}
4828
-								echo "<option value='$val' " . $selected . ">$label</option>";
4829
-							}
4830
-						}
4831
-						?>
4821
+                        if ( ! empty( $args['options'] ) ) {
4822
+                            foreach ( $args['options'] as $val => $label ) {
4823
+                                if ( $multiple ) {
4824
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4825
+                                } else {
4826
+                                    $selected = selected( $value, $val, false );
4827
+                                }
4828
+                                echo "<option value='$val' " . $selected . ">$label</option>";
4829
+                            }
4830
+                        }
4831
+                        ?>
4832 4832
 					</select>
4833 4833
 					<?php
4834
-					break;
4835
-				case "checkbox":
4836
-					?>
4834
+                    break;
4835
+                case "checkbox":
4836
+                    ?>
4837 4837
 					<input <?php echo $placeholder; ?> <?php checked( 1, $value, true ) ?> <?php echo $custom_attributes; ?> class="widefat" id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="checkbox" value="1">
4838 4838
 					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
4839 4839
 					<?php
4840
-					break;
4841
-				case "textarea":
4842
-					?>
4840
+                    break;
4841
+                case "textarea":
4842
+                    ?>
4843 4843
 					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
4844 4844
 					<textarea <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>"><?php echo esc_attr( $value ); ?></textarea>
4845 4845
 					<?php
4846 4846
 
4847
-					break;
4848
-				case "hidden":
4849
-					?>
4847
+                    break;
4848
+                case "hidden":
4849
+                    ?>
4850 4850
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden" value="<?php echo esc_attr( $value ); ?>">
4851 4851
 					<?php
4852
-					break;
4853
-				default:
4854
-					echo "No input type found!"; // @todo we need to add more input types.
4855
-			}
4856
-			// after wrapper
4857
-			?></p><?php
4858
-		}
4852
+                    break;
4853
+                default:
4854
+                    echo "No input type found!"; // @todo we need to add more input types.
4855
+            }
4856
+            // after wrapper
4857
+            ?></p><?php
4858
+        }
4859 4859
 
4860
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4861
-			if($icon=='box-top'){
4862
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
4863
-			}elseif($icon=='box-right'){
4864
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
4865
-			}elseif($icon=='box-bottom'){
4866
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
4867
-			}elseif($icon=='box-left'){
4868
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
4869
-			}
4870
-		}
4860
+        public function get_widget_icon($icon = 'box-top', $title = ''){
4861
+            if($icon=='box-top'){
4862
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
4863
+            }elseif($icon=='box-right'){
4864
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
4865
+            }elseif($icon=='box-bottom'){
4866
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
4867
+            }elseif($icon=='box-left'){
4868
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
4869
+            }
4870
+        }
4871 4871
 
4872
-		/**
4873
-		 * Get the widget input description html.
4874
-		 *
4875
-		 * @param $args
4876
-		 *
4877
-		 * @return string
4878
-		 * @todo, need to make its own tooltip script
4879
-		 */
4880
-		public function widget_field_desc( $args ) {
4881
-
4882
-			$description = '';
4883
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4884
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4885
-					$description = $this->desc_tip( $args['desc'] );
4886
-				} else {
4887
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4888
-				}
4889
-			}
4872
+        /**
4873
+         * Get the widget input description html.
4874
+         *
4875
+         * @param $args
4876
+         *
4877
+         * @return string
4878
+         * @todo, need to make its own tooltip script
4879
+         */
4880
+        public function widget_field_desc( $args ) {
4881
+
4882
+            $description = '';
4883
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
4884
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4885
+                    $description = $this->desc_tip( $args['desc'] );
4886
+                } else {
4887
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4888
+                }
4889
+            }
4890 4890
 
4891
-			return $description;
4892
-		}
4891
+            return $description;
4892
+        }
4893 4893
 
4894
-		/**
4895
-		 * Get the widget input title html.
4896
-		 *
4897
-		 * @param $args
4898
-		 *
4899
-		 * @return string
4900
-		 */
4901
-		public function widget_field_title( $args ) {
4902
-			$title = '';
4903
-
4904
-			if ( isset( $args['title'] ) && $args['title'] ) {
4905
-				if ( ! empty( $args['device_type'] ) ) {
4906
-					$args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4907
-				}
4894
+        /**
4895
+         * Get the widget input title html.
4896
+         *
4897
+         * @param $args
4898
+         *
4899
+         * @return string
4900
+         */
4901
+        public function widget_field_title( $args ) {
4902
+            $title = '';
4908 4903
 
4909
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4910
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4911
-				} else {
4912
-					$title = esc_attr( $args['title'] );
4913
-				}
4914
-			}
4904
+            if ( isset( $args['title'] ) && $args['title'] ) {
4905
+                if ( ! empty( $args['device_type'] ) ) {
4906
+                    $args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4907
+                }
4915 4908
 
4916
-			return $title;
4917
-		}
4909
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
4910
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
4911
+                } else {
4912
+                    $title = esc_attr( $args['title'] );
4913
+                }
4914
+            }
4918 4915
 
4919
-		/**
4920
-		 * Get the tool tip html.
4921
-		 *
4922
-		 * @param $tip
4923
-		 * @param bool $allow_html
4924
-		 *
4925
-		 * @return string
4926
-		 */
4927
-		function desc_tip( $tip, $allow_html = false ) {
4928
-			if ( $allow_html ) {
4929
-				$tip = $this->sanitize_tooltip( $tip );
4930
-			} else {
4931
-				$tip = esc_attr( $tip );
4932
-			}
4916
+            return $title;
4917
+        }
4933 4918
 
4934
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4935
-		}
4919
+        /**
4920
+         * Get the tool tip html.
4921
+         *
4922
+         * @param $tip
4923
+         * @param bool $allow_html
4924
+         *
4925
+         * @return string
4926
+         */
4927
+        function desc_tip( $tip, $allow_html = false ) {
4928
+            if ( $allow_html ) {
4929
+                $tip = $this->sanitize_tooltip( $tip );
4930
+            } else {
4931
+                $tip = esc_attr( $tip );
4932
+            }
4936 4933
 
4937
-		/**
4938
-		 * Sanitize a string destined to be a tooltip.
4939
-		 *
4940
-		 * @param string $var
4941
-		 *
4942
-		 * @return string
4943
-		 */
4944
-		public function sanitize_tooltip( $var ) {
4945
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4946
-				'br'     => array(),
4947
-				'em'     => array(),
4948
-				'strong' => array(),
4949
-				'small'  => array(),
4950
-				'span'   => array(),
4951
-				'ul'     => array(),
4952
-				'li'     => array(),
4953
-				'ol'     => array(),
4954
-				'p'      => array(),
4955
-			) ) );
4956
-		}
4934
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4935
+        }
4957 4936
 
4958
-		/**
4959
-		 * Processing widget options on save
4960
-		 *
4961
-		 * @param array $new_instance The new options
4962
-		 * @param array $old_instance The previous options
4963
-		 *
4964
-		 * @return array
4965
-		 * @todo we should add some sanitation here.
4966
-		 */
4967
-		public function update( $new_instance, $old_instance ) {
4968
-
4969
-			//save the widget
4970
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4971
-
4972
-			// set widget instance
4973
-			$this->instance = $instance;
4974
-
4975
-			if ( empty( $this->arguments ) ) {
4976
-				$this->get_arguments();
4977
-			}
4937
+        /**
4938
+         * Sanitize a string destined to be a tooltip.
4939
+         *
4940
+         * @param string $var
4941
+         *
4942
+         * @return string
4943
+         */
4944
+        public function sanitize_tooltip( $var ) {
4945
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4946
+                'br'     => array(),
4947
+                'em'     => array(),
4948
+                'strong' => array(),
4949
+                'small'  => array(),
4950
+                'span'   => array(),
4951
+                'ul'     => array(),
4952
+                'li'     => array(),
4953
+                'ol'     => array(),
4954
+                'p'      => array(),
4955
+            ) ) );
4956
+        }
4978 4957
 
4979
-			// check for checkboxes
4980
-			if ( ! empty( $this->arguments ) ) {
4981
-				foreach ( $this->arguments as $argument ) {
4982
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4983
-						$instance[ $argument['name'] ] = '0';
4984
-					}
4985
-				}
4986
-			}
4958
+        /**
4959
+         * Processing widget options on save
4960
+         *
4961
+         * @param array $new_instance The new options
4962
+         * @param array $old_instance The previous options
4963
+         *
4964
+         * @return array
4965
+         * @todo we should add some sanitation here.
4966
+         */
4967
+        public function update( $new_instance, $old_instance ) {
4968
+
4969
+            //save the widget
4970
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
4971
+
4972
+            // set widget instance
4973
+            $this->instance = $instance;
4974
+
4975
+            if ( empty( $this->arguments ) ) {
4976
+                $this->get_arguments();
4977
+            }
4978
+
4979
+            // check for checkboxes
4980
+            if ( ! empty( $this->arguments ) ) {
4981
+                foreach ( $this->arguments as $argument ) {
4982
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4983
+                        $instance[ $argument['name'] ] = '0';
4984
+                    }
4985
+                }
4986
+            }
4987 4987
 
4988 4988
             // maybe sanitize widget title
4989 4989
             if(!empty($instance['title'])) {
4990 4990
                 $instance['title'] = wp_kses_post( $instance['title'] );
4991 4991
             }
4992 4992
 
4993
-			return $instance;
4994
-		}
4993
+            return $instance;
4994
+        }
4995 4995
 
4996
-		/**
4997
-		 * Checks if the current call is a ajax call to get the block content.
4998
-		 *
4999
-		 * This can be used in your widget to return different content as the block content.
5000
-		 *
5001
-		 * @return bool
5002
-		 *@since 1.0.3
5003
-		 */
5004
-		public function is_block_content_call() {
5005
-			$result = false;
5006
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
5007
-				$result = true;
5008
-			}
4996
+        /**
4997
+         * Checks if the current call is a ajax call to get the block content.
4998
+         *
4999
+         * This can be used in your widget to return different content as the block content.
5000
+         *
5001
+         * @return bool
5002
+         *@since 1.0.3
5003
+         */
5004
+        public function is_block_content_call() {
5005
+            $result = false;
5006
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
5007
+                $result = true;
5008
+            }
5009 5009
 
5010
-			return $result;
5011
-		}
5010
+            return $result;
5011
+        }
5012 5012
 
5013
-		/**
5014
-		 * Get an instance hash that will be unique to the type and settings.
5015
-		 *
5016
-		 * @return string
5017
-		 *@since 1.0.20
5018
-		 */
5019
-		public function get_instance_hash(){
5020
-			$instance_string = $this->base_id.serialize($this->instance);
5021
-			return hash('crc32b',$instance_string);
5022
-		}
5013
+        /**
5014
+         * Get an instance hash that will be unique to the type and settings.
5015
+         *
5016
+         * @return string
5017
+         *@since 1.0.20
5018
+         */
5019
+        public function get_instance_hash(){
5020
+            $instance_string = $this->base_id.serialize($this->instance);
5021
+            return hash('crc32b',$instance_string);
5022
+        }
5023 5023
 
5024
-		/**
5025
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
5026
-		 *
5027
-		 * @param array $rules
5028
-		 *
5029
-		 * @return string
5030
-		 *@since 1.0.20
5031
-		 */
5032
-		public function get_instance_style($rules = array()){
5033
-			$css = '';
5034
-
5035
-			if(!empty($rules)){
5036
-				$rules = array_unique($rules);
5037
-				$instance_hash = $this->get_instance_hash();
5038
-				$css .= "<style>";
5039
-				foreach($rules as $rule){
5040
-					$css .= ".sdel-$instance_hash $rule";
5041
-				}
5042
-				$css .= "</style>";
5043
-			}
5024
+        /**
5025
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
5026
+         *
5027
+         * @param array $rules
5028
+         *
5029
+         * @return string
5030
+         *@since 1.0.20
5031
+         */
5032
+        public function get_instance_style($rules = array()){
5033
+            $css = '';
5034
+
5035
+            if(!empty($rules)){
5036
+                $rules = array_unique($rules);
5037
+                $instance_hash = $this->get_instance_hash();
5038
+                $css .= "<style>";
5039
+                foreach($rules as $rule){
5040
+                    $css .= ".sdel-$instance_hash $rule";
5041
+                }
5042
+                $css .= "</style>";
5043
+            }
5044 5044
 
5045
-			return $css;
5046
-		}
5045
+            return $css;
5046
+        }
5047 5047
 
5048
-		/**
5049
-		 * Encode shortcodes tags.
5050
-		 *
5051
-		 * @param string $content Content to search for shortcode tags.
5052
-		 *
5048
+        /**
5049
+         * Encode shortcodes tags.
5050
+         *
5051
+         * @param string $content Content to search for shortcode tags.
5052
+         *
5053 5053
 *@return string Content with shortcode tags removed.
5054
-		 *@since 1.0.28
5055
-		 *
5056
-		 */
5057
-		public function encode_shortcodes( $content ) {
5058
-			// Avoids existing encoded tags.
5059
-			$trans   = array(
5060
-				'&#91;' => '&#091;',
5061
-				'&#93;' => '&#093;',
5062
-				'&amp;#91;' => '&#091;',
5063
-				'&amp;#93;' => '&#093;',
5064
-				'&lt;' => '&0lt;',
5065
-				'&gt;' => '&0gt;',
5066
-				'&amp;lt;' => '&0lt;',
5067
-				'&amp;gt;' => '&0gt;',
5068
-			);
5069
-
5070
-			$content = strtr( $content, $trans );
5071
-
5072
-			$trans   = array(
5073
-				'[' => '&#91;',
5074
-				']' => '&#93;',
5075
-				'<' => '&lt;',
5076
-				'>' => '&gt;',
5077
-				'"' => '&quot;',
5078
-				"'" => '&#39;',
5079
-			);
5080
-
5081
-			$content = strtr( $content, $trans );
5082
-
5083
-			return $content;
5084
-		}
5054
+         *@since 1.0.28
5055
+         *
5056
+         */
5057
+        public function encode_shortcodes( $content ) {
5058
+            // Avoids existing encoded tags.
5059
+            $trans   = array(
5060
+                '&#91;' => '&#091;',
5061
+                '&#93;' => '&#093;',
5062
+                '&amp;#91;' => '&#091;',
5063
+                '&amp;#93;' => '&#093;',
5064
+                '&lt;' => '&0lt;',
5065
+                '&gt;' => '&0gt;',
5066
+                '&amp;lt;' => '&0lt;',
5067
+                '&amp;gt;' => '&0gt;',
5068
+            );
5069
+
5070
+            $content = strtr( $content, $trans );
5071
+
5072
+            $trans   = array(
5073
+                '[' => '&#91;',
5074
+                ']' => '&#93;',
5075
+                '<' => '&lt;',
5076
+                '>' => '&gt;',
5077
+                '"' => '&quot;',
5078
+                "'" => '&#39;',
5079
+            );
5080
+
5081
+            $content = strtr( $content, $trans );
5082
+
5083
+            return $content;
5084
+        }
5085 5085
 
5086
-		/**
5087
-		 * Remove encoded shortcod tags.
5088
-		 *
5089
-		 * @param string $content Content to search for shortcode tags.
5090
-		 *
5086
+        /**
5087
+         * Remove encoded shortcod tags.
5088
+         *
5089
+         * @param string $content Content to search for shortcode tags.
5090
+         *
5091 5091
 *@return string Content with decoded shortcode tags.
5092
-		 *@since 1.0.28
5093
-		 *
5094
-		 */
5095
-		public function decode_shortcodes( $content ) {
5096
-			$trans   = array(
5097
-				'&#91;' => '[',
5098
-				'&#93;' => ']',
5099
-				'&amp;#91;' => '[',
5100
-				'&amp;#93;' => ']',
5101
-				'&lt;' => '<',
5102
-				'&gt;' => '>',
5103
-				'&amp;lt;' => '<',
5104
-				'&amp;gt;' => '>',
5105
-				'&quot;' => '"',
5106
-				'&apos;' => "'",
5107
-			);
5108
-
5109
-			$content = strtr( $content, $trans );
5110
-
5111
-			$trans   = array(
5112
-				'&#091;' => '&#91;',
5113
-				'&#093;' => '&#93;',
5114
-				'&amp;#091;' => '&#91;',
5115
-				'&amp;#093;' => '&#93;',
5116
-				'&0lt;' => '&lt;',
5117
-				'&0gt;' => '&gt;',
5118
-				'&amp;0lt;' => '&lt;',
5119
-				'&amp;0gt;' => '&gt;',
5120
-			);
5121
-
5122
-			$content = strtr( $content, $trans );
5123
-
5124
-			return $content;
5125
-		}
5126
-
5127
-		public function block_visibility_fields( $args ) {
5128
-			$value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
5129
-			$content = '<div class="bs-vc-rule-template d-none">';
5130
-				$content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
5131
-					$content .= '<div class="row">';
5132
-						$content .= '<div class="col-sm-12">';
5133
-							$content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__( 'Remove Rule', 'ayecode-connect' ) . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5134
-							$content .= aui()->select(
5135
-								array(
5136
-									'id'          => 'bsvc_rule_BSVCINDEX',
5137
-									'name'        => 'bsvc_rule_BSVCINDEX',
5138
-									'label'       => __( 'Rule', 'ayecode-connect' ),
5139
-									'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
5140
-									'class'       => 'bsvc_rule form-select-sm no-select2 mw-100',
5141
-									'options'     => sd_visibility_rules_options(),
5142
-									'default'     => '',
5143
-									'value'       => '',
5144
-									'label_type'  => '',
5145
-									'select2'     => false,
5146
-									'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
5147
-									'extra_attributes' => array(
5148
-										'data-minimum-results-for-search' => '-1'
5149
-									)
5150
-								)
5151
-							);
5152
-
5153
-						$content .= '</div>';
5154
-
5155
-						if ( class_exists( 'GeoDirectory' ) ) {
5156
-							$content .= '<div class="col-md-7 col-sm-12">';
5157
-
5158
-								$content .= aui()->select(
5159
-									array(
5160
-										'id'          => 'bsvc_gd_field_BSVCINDEX',
5161
-										'name'        => 'bsvc_gd_field_BSVCINDEX',
5162
-										'label'       => __( 'FIELD', 'ayecode-connect' ),
5163
-										'placeholder' => __( 'FIELD', 'ayecode-connect' ),
5164
-										'class'       => 'bsvc_gd_field form-select-sm no-select2 mw-100',
5165
-										'options'     => sd_visibility_gd_field_options(),
5166
-										'default'     => '',
5167
-										'value'       => '',
5168
-										'label_type'  => '',
5169
-										'select2'     => false,
5170
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5171
-										'extra_attributes' => array(
5172
-											'data-minimum-results-for-search' => '-1'
5173
-										)
5174
-									)
5175
-								);
5176
-
5177
-							$content .= '</div>';
5178
-							$content .= '<div class="col-md-5 col-sm-12">';
5179
-
5180
-								$content .= aui()->select(
5181
-									array(
5182
-										'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
5183
-										'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
5184
-										'label'       => __( 'CONDITION', 'ayecode-connect' ),
5185
-										'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
5186
-										'class'       => 'bsvc_gd_field_condition form-select-sm no-select2 mw-100',
5187
-										'options'     => sd_visibility_field_condition_options(),
5188
-										'default'     => '',
5189
-										'value'       => '',
5190
-										'label_type'  => '',
5191
-										'select2'     => false,
5192
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5193
-										'extra_attributes' => array(
5194
-											'data-minimum-results-for-search' => '-1'
5195
-										)
5196
-									)
5197
-								);
5198
-
5199
-							$content .= '</div>';
5200
-							$content .= '<div class="col-sm-12">';
5201
-
5202
-								$content .= aui()->input(
5203
-									array(
5204
-										'type'            => 'text',
5205
-										'id'              => 'bsvc_gd_field_search_BSVCINDEX',
5206
-										'name'            => 'bsvc_gd_field_search_BSVCINDEX',
5207
-										'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5208
-										'class'           => 'bsvc_gd_field_search form-control-sm',
5209
-										'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5210
-										'label_type'      => '',
5211
-										'value'           => '',
5212
-										'element_require' => '([%bsvc_rule_BSVCINDEX%]=="gd_field" && [%bsvc_gd_field_condition_BSVCINDEX%] && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_empty" && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_not_empty")'
5213
-									)
5214
-								);
5092
+         *@since 1.0.28
5093
+         *
5094
+         */
5095
+        public function decode_shortcodes( $content ) {
5096
+            $trans   = array(
5097
+                '&#91;' => '[',
5098
+                '&#93;' => ']',
5099
+                '&amp;#91;' => '[',
5100
+                '&amp;#93;' => ']',
5101
+                '&lt;' => '<',
5102
+                '&gt;' => '>',
5103
+                '&amp;lt;' => '<',
5104
+                '&amp;gt;' => '>',
5105
+                '&quot;' => '"',
5106
+                '&apos;' => "'",
5107
+            );
5108
+
5109
+            $content = strtr( $content, $trans );
5110
+
5111
+            $trans   = array(
5112
+                '&#091;' => '&#91;',
5113
+                '&#093;' => '&#93;',
5114
+                '&amp;#091;' => '&#91;',
5115
+                '&amp;#093;' => '&#93;',
5116
+                '&0lt;' => '&lt;',
5117
+                '&0gt;' => '&gt;',
5118
+                '&amp;0lt;' => '&lt;',
5119
+                '&amp;0gt;' => '&gt;',
5120
+            );
5121
+
5122
+            $content = strtr( $content, $trans );
5123
+
5124
+            return $content;
5125
+        }
5215 5126
 
5216
-							$content .= '</div>';
5217
-						}
5127
+        public function block_visibility_fields( $args ) {
5128
+            $value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
5129
+            $content = '<div class="bs-vc-rule-template d-none">';
5130
+                $content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
5131
+                    $content .= '<div class="row">';
5132
+                        $content .= '<div class="col-sm-12">';
5133
+                            $content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__( 'Remove Rule', 'ayecode-connect' ) . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5134
+                            $content .= aui()->select(
5135
+                                array(
5136
+                                    'id'          => 'bsvc_rule_BSVCINDEX',
5137
+                                    'name'        => 'bsvc_rule_BSVCINDEX',
5138
+                                    'label'       => __( 'Rule', 'ayecode-connect' ),
5139
+                                    'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
5140
+                                    'class'       => 'bsvc_rule form-select-sm no-select2 mw-100',
5141
+                                    'options'     => sd_visibility_rules_options(),
5142
+                                    'default'     => '',
5143
+                                    'value'       => '',
5144
+                                    'label_type'  => '',
5145
+                                    'select2'     => false,
5146
+                                    'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
5147
+                                    'extra_attributes' => array(
5148
+                                        'data-minimum-results-for-search' => '-1'
5149
+                                    )
5150
+                                )
5151
+                            );
5152
+
5153
+                        $content .= '</div>';
5154
+
5155
+                        if ( class_exists( 'GeoDirectory' ) ) {
5156
+                            $content .= '<div class="col-md-7 col-sm-12">';
5157
+
5158
+                                $content .= aui()->select(
5159
+                                    array(
5160
+                                        'id'          => 'bsvc_gd_field_BSVCINDEX',
5161
+                                        'name'        => 'bsvc_gd_field_BSVCINDEX',
5162
+                                        'label'       => __( 'FIELD', 'ayecode-connect' ),
5163
+                                        'placeholder' => __( 'FIELD', 'ayecode-connect' ),
5164
+                                        'class'       => 'bsvc_gd_field form-select-sm no-select2 mw-100',
5165
+                                        'options'     => sd_visibility_gd_field_options(),
5166
+                                        'default'     => '',
5167
+                                        'value'       => '',
5168
+                                        'label_type'  => '',
5169
+                                        'select2'     => false,
5170
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5171
+                                        'extra_attributes' => array(
5172
+                                            'data-minimum-results-for-search' => '-1'
5173
+                                        )
5174
+                                    )
5175
+                                );
5176
+
5177
+                            $content .= '</div>';
5178
+                            $content .= '<div class="col-md-5 col-sm-12">';
5179
+
5180
+                                $content .= aui()->select(
5181
+                                    array(
5182
+                                        'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
5183
+                                        'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
5184
+                                        'label'       => __( 'CONDITION', 'ayecode-connect' ),
5185
+                                        'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
5186
+                                        'class'       => 'bsvc_gd_field_condition form-select-sm no-select2 mw-100',
5187
+                                        'options'     => sd_visibility_field_condition_options(),
5188
+                                        'default'     => '',
5189
+                                        'value'       => '',
5190
+                                        'label_type'  => '',
5191
+                                        'select2'     => false,
5192
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5193
+                                        'extra_attributes' => array(
5194
+                                            'data-minimum-results-for-search' => '-1'
5195
+                                        )
5196
+                                    )
5197
+                                );
5198
+
5199
+                            $content .= '</div>';
5200
+                            $content .= '<div class="col-sm-12">';
5201
+
5202
+                                $content .= aui()->input(
5203
+                                    array(
5204
+                                        'type'            => 'text',
5205
+                                        'id'              => 'bsvc_gd_field_search_BSVCINDEX',
5206
+                                        'name'            => 'bsvc_gd_field_search_BSVCINDEX',
5207
+                                        'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5208
+                                        'class'           => 'bsvc_gd_field_search form-control-sm',
5209
+                                        'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5210
+                                        'label_type'      => '',
5211
+                                        'value'           => '',
5212
+                                        'element_require' => '([%bsvc_rule_BSVCINDEX%]=="gd_field" && [%bsvc_gd_field_condition_BSVCINDEX%] && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_empty" && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_not_empty")'
5213
+                                    )
5214
+                                );
5215
+
5216
+                            $content .= '</div>';
5217
+                        }
5218 5218
 
5219 5219
                         $content .= apply_filters( 'sd_block_visibility_fields', '', $args );
5220 5220
 
5221
-					$content .= '</div>';
5222
-
5223
-					$content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __( 'Select User Roles:', 'ayecode-connect' ) . '</label>';
5224
-						$role_options = sd_user_roles_options();
5225
-
5226
-						$role_option_i = 0;
5227
-						foreach ( $role_options as $role_option_key => $role_option_name ) {
5228
-							$role_option_i++;
5229
-
5230
-							$content .= '<div class="col-sm-6">';
5231
-							$content .= aui()->input(
5232
-								array(
5233
-									'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5234
-									'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5235
-									'type'             => 'checkbox',
5236
-									'label'            => $role_option_name,
5237
-									'label_type'       => 'hidden',
5238
-									'class'            => 'bsvc_user_roles',
5239
-									'value'            => $role_option_key,
5240
-									'switch'           => 'md',
5241
-									'no_wrap'          => true
5242
-								)
5243
-							);
5244
-							$content .= '</div>';
5245
-						}
5246
-					$content .= '</div>';
5247
-					$content .= '<div class="bs-vc-sep-wrap text-center position-absolute top-0 mt-n3"><div class="bs-vc-sep-cond d-inline-block badge text-dark bg-gray mt-1">' . esc_html__( 'AND', 'ayecode-connect' ) . '</div></div>';
5248
-				$content .= '</div>';
5249
-			$content .= '</div>';
5250
-			$content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5251
-			$content .= '<div class="bs-vc-rule-sets"></div>';
5252
-			$content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __( 'Add Rule', 'ayecode-connect' ) . '</button></div></div>';
5253
-			$content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5254
-			$content .= aui()->select(
5255
-				array(
5256
-					'id'          => 'bsvc_output',
5257
-					'name'        => 'bsvc_output',
5258
-					'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5259
-					'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5260
-					'class'       => 'bsvc_output form-select-sm no-select2 mw-100',
5261
-					'options'     => sd_visibility_output_options(),
5262
-					'default'     => '',
5263
-					'value'       => '',
5264
-					'label_type'  => 'top',
5265
-					'select2'     => false,
5266
-					'extra_attributes' => array(
5267
-						'data-minimum-results-for-search' => '-1'
5268
-					)
5269
-				)
5270
-			);
5271
-
5272
-			$content .= '</div><div class="col-md-6 col-sm-12">';
5273
-
5274
-			$content .= aui()->select(
5275
-				array(
5276
-					'id'              => 'bsvc_page',
5277
-					'name'            => 'bsvc_page',
5278
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5279
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5280
-					'class'           => 'bsvc_page form-select-sm no-select2 mw-100',
5281
-					'options'         => sd_template_page_options(),
5282
-					'default'         => '',
5283
-					'value'           => '',
5284
-					'label_type'      => 'top',
5285
-					'select2'         => false,
5286
-					'element_require' => '[%bsvc_output%]=="page"'
5287
-				)
5288
-			);
5289
-
5290
-			$content .= aui()->select(
5291
-				array(
5292
-					'id'          => 'bsvc_tmpl_part',
5293
-					'name'        => 'bsvc_tmpl_part',
5294
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5295
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5296
-					'class'       => 'bsvc_tmpl_part form-select-sm no-select2 mw-100',
5297
-					'options'     => sd_template_part_options(),
5298
-					'default'     => '',
5299
-					'value'       => '',
5300
-					'label_type'  => 'top',
5301
-					'select2'     => false,
5302
-					'element_require'  => '[%bsvc_output%]=="template_part"',
5303
-					'extra_attributes' => array(
5304
-						'data-minimum-results-for-search' => '-1'
5305
-					)
5306
-				)
5307
-			);
5308
-
5309
-			$content .= aui()->select(
5310
-				array(
5311
-					'id'               => 'bsvc_message_type',
5312
-					'name'             => 'bsvc_message_type',
5313
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5314
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5315
-					'class'            => 'bsvc_message_type form-select-sm no-select2 mw-100',
5316
-					'options'          => sd_aui_colors(),
5317
-					'default'          => '',
5318
-					'value'            => '',
5319
-					'label_type'       => 'top',
5320
-					'select2'          => false,
5321
-					'element_require'  => '[%bsvc_output%]=="message"',
5322
-					'extra_attributes' => array(
5323
-						'data-minimum-results-for-search' => '-1'
5324
-					)
5325
-				)
5326
-			);
5327
-
5328
-			$content .= '</div><div class="col-sm-12">';
5329
-
5330
-			$content .= aui()->input(
5331
-				array(
5332
-					'type'            => 'text',
5333
-					'id'              => 'bsvc_message',
5334
-					'name'            => 'bsvc_message',
5335
-					'label'           => '',
5336
-					'class'           => 'bsvc_message form-control-sm mb-3',
5337
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5338
-					'label_type'      => '',
5339
-					'value'           => '',
5340
-					'form_group_class' => ' ',
5341
-					'element_require' => '[%bsvc_output%]=="message"',
5342
-				)
5343
-			);
5344
-
5345
-			$content .= '</div></div><div class="row"><div class="col col-12"><div class="pt-3 mt-1 border-top"></div></div><div class="col-md-6 col-sm-12">';
5346
-			$content .= aui()->select(
5347
-				array(
5348
-					'id'          => 'bsvc_output_n',
5349
-					'name'        => 'bsvc_output_n',
5350
-					'label'       => __( 'What should happen if rules NOT met.', 'ayecode-connect' ),
5351
-					'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5352
-					'class'       => 'bsvc_output_n form-select-sm no-select2 mw-100',
5353
-					'options'     => sd_visibility_output_options(),
5354
-					'default'     => '',
5355
-					'value'       => '',
5356
-					'label_type'  => 'top',
5357
-					'select2'     => false,
5358
-					'extra_attributes' => array(
5359
-						'data-minimum-results-for-search' => '-1'
5360
-					)
5361
-				)
5362
-			);
5363
-
5364
-			$content .= '</div><div class="col-md-6 col-sm-12">';
5365
-
5366
-			$content .= aui()->select(
5367
-				array(
5368
-					'id'              => 'bsvc_page_n',
5369
-					'name'            => 'bsvc_page_n',
5370
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5371
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5372
-					'class'           => 'bsvc_page_n form-select-sm no-select2 mw-100',
5373
-					'options'         => sd_template_page_options(),
5374
-					'default'         => '',
5375
-					'value'           => '',
5376
-					'label_type'      => 'top',
5377
-					'select2'         => false,
5378
-					'element_require' => '[%bsvc_output_n%]=="page"'
5379
-				)
5380
-			);
5381
-
5382
-			$content .= aui()->select(
5383
-				array(
5384
-					'id'          => 'bsvc_tmpl_part_n',
5385
-					'name'        => 'bsvc_tmpl_part_n',
5386
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5387
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5388
-					'class'       => 'bsvc_tmpl_part_n form-select-sm no-select2 mw-100',
5389
-					'options'     => sd_template_part_options(),
5390
-					'default'     => '',
5391
-					'value'       => '',
5392
-					'label_type'  => 'top',
5393
-					'select2'     => false,
5394
-					'element_require'  => '[%bsvc_output_n%]=="template_part"',
5395
-					'extra_attributes' => array(
5396
-						'data-minimum-results-for-search' => '-1'
5397
-					)
5398
-				)
5399
-			);
5400
-
5401
-			$content .= aui()->select(
5402
-				array(
5403
-					'id'               => 'bsvc_message_type_n',
5404
-					'name'             => 'bsvc_message_type_n',
5405
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5406
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5407
-					'class'            => 'bsvc_message_type_n form-select-sm no-select2 mw-100',
5408
-					'options'          => sd_aui_colors(),
5409
-					'default'          => '',
5410
-					'value'            => '',
5411
-					'label_type'       => 'top',
5412
-					'select2'          => false,
5413
-					'element_require'  => '[%bsvc_output_n%]=="message"',
5414
-					'extra_attributes' => array(
5415
-						'data-minimum-results-for-search' => '-1'
5416
-					)
5417
-				)
5418
-			);
5419
-
5420
-			$content .= '</div><div class="col-sm-12">';
5421
-
5422
-			$content .= aui()->input(
5423
-				array(
5424
-					'type'            => 'text',
5425
-					'id'              => 'bsvc_message_n',
5426
-					'name'            => 'bsvc_message_n',
5427
-					'label'           => '',
5428
-					'class'           => 'bsvc_message_n form-control-sm',
5429
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5430
-					'label_type'      => '',
5431
-					'value'           => '',
5432
-					'form_group_class' => ' ',
5433
-					'element_require' => '[%bsvc_output_n%]=="message"',
5434
-				)
5435
-			);
5436
-
5437
-			$content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5438
-
5439
-			return $content;
5440
-		}
5221
+                    $content .= '</div>';
5222
+
5223
+                    $content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __( 'Select User Roles:', 'ayecode-connect' ) . '</label>';
5224
+                        $role_options = sd_user_roles_options();
5225
+
5226
+                        $role_option_i = 0;
5227
+                        foreach ( $role_options as $role_option_key => $role_option_name ) {
5228
+                            $role_option_i++;
5229
+
5230
+                            $content .= '<div class="col-sm-6">';
5231
+                            $content .= aui()->input(
5232
+                                array(
5233
+                                    'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5234
+                                    'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5235
+                                    'type'             => 'checkbox',
5236
+                                    'label'            => $role_option_name,
5237
+                                    'label_type'       => 'hidden',
5238
+                                    'class'            => 'bsvc_user_roles',
5239
+                                    'value'            => $role_option_key,
5240
+                                    'switch'           => 'md',
5241
+                                    'no_wrap'          => true
5242
+                                )
5243
+                            );
5244
+                            $content .= '</div>';
5245
+                        }
5246
+                    $content .= '</div>';
5247
+                    $content .= '<div class="bs-vc-sep-wrap text-center position-absolute top-0 mt-n3"><div class="bs-vc-sep-cond d-inline-block badge text-dark bg-gray mt-1">' . esc_html__( 'AND', 'ayecode-connect' ) . '</div></div>';
5248
+                $content .= '</div>';
5249
+            $content .= '</div>';
5250
+            $content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5251
+            $content .= '<div class="bs-vc-rule-sets"></div>';
5252
+            $content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __( 'Add Rule', 'ayecode-connect' ) . '</button></div></div>';
5253
+            $content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5254
+            $content .= aui()->select(
5255
+                array(
5256
+                    'id'          => 'bsvc_output',
5257
+                    'name'        => 'bsvc_output',
5258
+                    'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5259
+                    'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5260
+                    'class'       => 'bsvc_output form-select-sm no-select2 mw-100',
5261
+                    'options'     => sd_visibility_output_options(),
5262
+                    'default'     => '',
5263
+                    'value'       => '',
5264
+                    'label_type'  => 'top',
5265
+                    'select2'     => false,
5266
+                    'extra_attributes' => array(
5267
+                        'data-minimum-results-for-search' => '-1'
5268
+                    )
5269
+                )
5270
+            );
5271
+
5272
+            $content .= '</div><div class="col-md-6 col-sm-12">';
5273
+
5274
+            $content .= aui()->select(
5275
+                array(
5276
+                    'id'              => 'bsvc_page',
5277
+                    'name'            => 'bsvc_page',
5278
+                    'label'           => __( 'Page Content', 'ayecode-connect' ),
5279
+                    'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5280
+                    'class'           => 'bsvc_page form-select-sm no-select2 mw-100',
5281
+                    'options'         => sd_template_page_options(),
5282
+                    'default'         => '',
5283
+                    'value'           => '',
5284
+                    'label_type'      => 'top',
5285
+                    'select2'         => false,
5286
+                    'element_require' => '[%bsvc_output%]=="page"'
5287
+                )
5288
+            );
5289
+
5290
+            $content .= aui()->select(
5291
+                array(
5292
+                    'id'          => 'bsvc_tmpl_part',
5293
+                    'name'        => 'bsvc_tmpl_part',
5294
+                    'label'       => __( 'Template Part', 'ayecode-connect' ),
5295
+                    'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5296
+                    'class'       => 'bsvc_tmpl_part form-select-sm no-select2 mw-100',
5297
+                    'options'     => sd_template_part_options(),
5298
+                    'default'     => '',
5299
+                    'value'       => '',
5300
+                    'label_type'  => 'top',
5301
+                    'select2'     => false,
5302
+                    'element_require'  => '[%bsvc_output%]=="template_part"',
5303
+                    'extra_attributes' => array(
5304
+                        'data-minimum-results-for-search' => '-1'
5305
+                    )
5306
+                )
5307
+            );
5308
+
5309
+            $content .= aui()->select(
5310
+                array(
5311
+                    'id'               => 'bsvc_message_type',
5312
+                    'name'             => 'bsvc_message_type',
5313
+                    'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5314
+                    'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5315
+                    'class'            => 'bsvc_message_type form-select-sm no-select2 mw-100',
5316
+                    'options'          => sd_aui_colors(),
5317
+                    'default'          => '',
5318
+                    'value'            => '',
5319
+                    'label_type'       => 'top',
5320
+                    'select2'          => false,
5321
+                    'element_require'  => '[%bsvc_output%]=="message"',
5322
+                    'extra_attributes' => array(
5323
+                        'data-minimum-results-for-search' => '-1'
5324
+                    )
5325
+                )
5326
+            );
5327
+
5328
+            $content .= '</div><div class="col-sm-12">';
5329
+
5330
+            $content .= aui()->input(
5331
+                array(
5332
+                    'type'            => 'text',
5333
+                    'id'              => 'bsvc_message',
5334
+                    'name'            => 'bsvc_message',
5335
+                    'label'           => '',
5336
+                    'class'           => 'bsvc_message form-control-sm mb-3',
5337
+                    'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5338
+                    'label_type'      => '',
5339
+                    'value'           => '',
5340
+                    'form_group_class' => ' ',
5341
+                    'element_require' => '[%bsvc_output%]=="message"',
5342
+                )
5343
+            );
5344
+
5345
+            $content .= '</div></div><div class="row"><div class="col col-12"><div class="pt-3 mt-1 border-top"></div></div><div class="col-md-6 col-sm-12">';
5346
+            $content .= aui()->select(
5347
+                array(
5348
+                    'id'          => 'bsvc_output_n',
5349
+                    'name'        => 'bsvc_output_n',
5350
+                    'label'       => __( 'What should happen if rules NOT met.', 'ayecode-connect' ),
5351
+                    'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5352
+                    'class'       => 'bsvc_output_n form-select-sm no-select2 mw-100',
5353
+                    'options'     => sd_visibility_output_options(),
5354
+                    'default'     => '',
5355
+                    'value'       => '',
5356
+                    'label_type'  => 'top',
5357
+                    'select2'     => false,
5358
+                    'extra_attributes' => array(
5359
+                        'data-minimum-results-for-search' => '-1'
5360
+                    )
5361
+                )
5362
+            );
5363
+
5364
+            $content .= '</div><div class="col-md-6 col-sm-12">';
5365
+
5366
+            $content .= aui()->select(
5367
+                array(
5368
+                    'id'              => 'bsvc_page_n',
5369
+                    'name'            => 'bsvc_page_n',
5370
+                    'label'           => __( 'Page Content', 'ayecode-connect' ),
5371
+                    'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5372
+                    'class'           => 'bsvc_page_n form-select-sm no-select2 mw-100',
5373
+                    'options'         => sd_template_page_options(),
5374
+                    'default'         => '',
5375
+                    'value'           => '',
5376
+                    'label_type'      => 'top',
5377
+                    'select2'         => false,
5378
+                    'element_require' => '[%bsvc_output_n%]=="page"'
5379
+                )
5380
+            );
5381
+
5382
+            $content .= aui()->select(
5383
+                array(
5384
+                    'id'          => 'bsvc_tmpl_part_n',
5385
+                    'name'        => 'bsvc_tmpl_part_n',
5386
+                    'label'       => __( 'Template Part', 'ayecode-connect' ),
5387
+                    'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5388
+                    'class'       => 'bsvc_tmpl_part_n form-select-sm no-select2 mw-100',
5389
+                    'options'     => sd_template_part_options(),
5390
+                    'default'     => '',
5391
+                    'value'       => '',
5392
+                    'label_type'  => 'top',
5393
+                    'select2'     => false,
5394
+                    'element_require'  => '[%bsvc_output_n%]=="template_part"',
5395
+                    'extra_attributes' => array(
5396
+                        'data-minimum-results-for-search' => '-1'
5397
+                    )
5398
+                )
5399
+            );
5400
+
5401
+            $content .= aui()->select(
5402
+                array(
5403
+                    'id'               => 'bsvc_message_type_n',
5404
+                    'name'             => 'bsvc_message_type_n',
5405
+                    'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5406
+                    'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5407
+                    'class'            => 'bsvc_message_type_n form-select-sm no-select2 mw-100',
5408
+                    'options'          => sd_aui_colors(),
5409
+                    'default'          => '',
5410
+                    'value'            => '',
5411
+                    'label_type'       => 'top',
5412
+                    'select2'          => false,
5413
+                    'element_require'  => '[%bsvc_output_n%]=="message"',
5414
+                    'extra_attributes' => array(
5415
+                        'data-minimum-results-for-search' => '-1'
5416
+                    )
5417
+                )
5418
+            );
5419
+
5420
+            $content .= '</div><div class="col-sm-12">';
5421
+
5422
+            $content .= aui()->input(
5423
+                array(
5424
+                    'type'            => 'text',
5425
+                    'id'              => 'bsvc_message_n',
5426
+                    'name'            => 'bsvc_message_n',
5427
+                    'label'           => '',
5428
+                    'class'           => 'bsvc_message_n form-control-sm',
5429
+                    'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5430
+                    'label_type'      => '',
5431
+                    'value'           => '',
5432
+                    'form_group_class' => ' ',
5433
+                    'element_require' => '[%bsvc_output_n%]=="message"',
5434
+                )
5435
+            );
5436
+
5437
+            $content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5438
+
5439
+            return $content;
5440
+        }
5441 5441
 
5442
-		/**
5443
-		 * Handle media_buttons hook.
5444
-		 *
5445
-		 * @since 1.2.7
5446
-		 */
5447
-		public function wp_media_buttons() {
5448
-			global $shortcode_insert_button_once;
5449
-
5450
-			// Fix conflicts with UpSolution Core in header template edit element.
5451
-			if ( defined( 'US_CORE_DIR' ) && ! empty( $_REQUEST['action'] ) && $_REQUEST['action'] == 'us_ajax_hb_get_ebuilder_html' ) {
5452
-				$shortcode_insert_button_once = true;
5453
-			}
5454
-		}
5455
-	}
5442
+        /**
5443
+         * Handle media_buttons hook.
5444
+         *
5445
+         * @since 1.2.7
5446
+         */
5447
+        public function wp_media_buttons() {
5448
+            global $shortcode_insert_button_once;
5449
+
5450
+            // Fix conflicts with UpSolution Core in header template edit element.
5451
+            if ( defined( 'US_CORE_DIR' ) && ! empty( $_REQUEST['action'] ) && $_REQUEST['action'] == 'us_ajax_hb_get_ebuilder_html' ) {
5452
+                $shortcode_insert_button_once = true;
5453
+            }
5454
+        }
5455
+    }
5456 5456
 }
Please login to merge, or discard this patch.
Spacing   +835 added lines, -835 removed lines patch added patch discarded remove patch
@@ -1,11 +1,11 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) {
2
+if (!defined('ABSPATH')) {
3 3
 	exit;
4 4
 }
5 5
 
6
-if ( ! class_exists( 'WP_Super_Duper' ) ) {
6
+if (!class_exists('WP_Super_Duper')) {
7 7
 
8
-	define( 'SUPER_DUPER_VER', '1.2.22' );
8
+	define('SUPER_DUPER_VER', '1.2.22');
9 9
 
10 10
 	/**
11 11
 	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
@@ -38,40 +38,40 @@  discard block
 block discarded – undo
38 38
 		/**
39 39
 		 * Take the array options and use them to build.
40 40
 		 */
41
-		public function __construct( $options ) {
41
+		public function __construct($options) {
42 42
 			global $sd_widgets;
43 43
 
44
-			$sd_widgets[ $options['base_id'] ] = array(
44
+			$sd_widgets[$options['base_id']] = array(
45 45
 				'name'       => $options['name'],
46 46
 				'class_name' => $options['class_name'],
47 47
 				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48 48
 			);
49
-			$this->base_id                     = $options['base_id'];
49
+			$this->base_id = $options['base_id'];
50 50
 			// lets filter the options before we do anything
51
-			$options       = apply_filters( "wp_super_duper_options", $options );
52
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
-			$options       = $this->add_name_from_key( $options );
51
+			$options       = apply_filters("wp_super_duper_options", $options);
52
+			$options       = apply_filters("wp_super_duper_options_{$this->base_id}", $options);
53
+			$options       = $this->add_name_from_key($options);
54 54
 			$this->options = $options;
55 55
 
56 56
 			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
57
+			$this->arguments = isset($options['arguments']) ? $options['arguments'] : array();
58 58
 
59 59
 			// nested blocks can't work as a widget
60
-			if(!empty($this->options['nested-block'])){
61
-				if(empty($this->options['output_types'])){
62
-					$this->options['output_types'] = array('shortcode','block');
60
+			if (!empty($this->options['nested-block'])) {
61
+				if (empty($this->options['output_types'])) {
62
+					$this->options['output_types'] = array('shortcode', 'block');
63 63
 				}elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64 64
 					unset($this->options['output_types'][$key]);
65 65
 				}
66 66
 			}
67 67
 
68 68
 			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
-				parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
69
+			if (empty($this->options['output_types']) || in_array('widget', $this->options['output_types'])) {
70
+				parent::__construct($options['base_id'], $options['name'], $options['widget_ops']);
71 71
 			}
72 72
 
73 73
 
74
-			if ( isset( $options['class_name'] ) ) {
74
+			if (isset($options['class_name'])) {
75 75
 				// register widget
76 76
 				$this->class_name = $options['class_name'];
77 77
 
@@ -80,67 +80,67 @@  discard block
 block discarded – undo
80 80
 
81 81
 
82 82
 				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
83
+				if (function_exists('fusion_builder_map')) {
84
+					add_action('init', array($this, 'register_fusion_element'));
85 85
 				}
86 86
 
87 87
                 // maybe load the Bricks transformer class
88
-                if( class_exists('\Bricks\Elements', false) ){
89
-					add_action( 'init', array( $this, 'load_bricks_element_class' ) );
88
+                if (class_exists('\Bricks\Elements', false)) {
89
+					add_action('init', array($this, 'load_bricks_element_class'));
90 90
                 }
91 91
 
92 92
 				// register block
93
-				if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
94
-					add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
93
+				if (empty($this->options['output_types']) || in_array('block', $this->options['output_types'])) {
94
+					add_action('admin_enqueue_scripts', array($this, 'register_block'));
95 95
 				}
96 96
 			}
97 97
 
98 98
 			// add the CSS and JS we need ONCE
99 99
 			global $sd_widget_scripts;
100 100
 
101
-			if ( ! $sd_widget_scripts ) {
102
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
103
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
104
-				wp_add_inline_style( 'widgets', $this->widget_css() );
101
+			if (!$sd_widget_scripts) {
102
+				wp_add_inline_script('admin-widgets', $this->widget_js());
103
+				wp_add_inline_script('customize-controls', $this->widget_js());
104
+				wp_add_inline_style('widgets', $this->widget_css());
105 105
 
106 106
 				// maybe add elementor editor styles
107
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
107
+				add_action('elementor/editor/after_enqueue_styles', array($this, 'elementor_editor_styles'));
108 108
 
109 109
 				$sd_widget_scripts = true;
110 110
 
111 111
 				// add shortcode insert button once
112
-				add_action( 'media_buttons', array( $this, 'wp_media_buttons' ), 1 );
113
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
112
+				add_action('media_buttons', array($this, 'wp_media_buttons'), 1);
113
+				add_action('media_buttons', array($this, 'shortcode_insert_button'));
114 114
 				// generatepress theme sections compatibility
115
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
116
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
115
+				if (function_exists('generate_sections_sections_metabox')) {
116
+					add_action('generate_sections_metabox', array($this, 'shortcode_insert_button_script'));
117 117
 				}
118 118
 				/* Load script on Divi theme builder page */
119
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
119
+				if (function_exists('et_builder_is_tb_admin_screen') && et_builder_is_tb_admin_screen()) {
120 120
 					add_thickbox();
121
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
121
+					add_action('admin_footer', array($this, 'shortcode_insert_button_script'));
122 122
 				}
123 123
 
124
-				if ( $this->is_preview() ) {
125
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
124
+				if ($this->is_preview()) {
125
+					add_action('wp_footer', array($this, 'shortcode_insert_button_script'));
126 126
 					// this makes the insert button work for elementor
127
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
127
+					add_action('elementor/editor/after_enqueue_scripts', array(
128 128
 						$this,
129 129
 						'shortcode_insert_button_script'
130
-					) ); // for elementor
130
+					)); // for elementor
131 131
 				}
132 132
 				// this makes the insert button work for cornerstone
133
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
133
+				add_action('wp_print_footer_scripts', array(__CLASS__, 'maybe_cornerstone_builder'));
134 134
 
135
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
136
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
135
+				add_action('wp_ajax_super_duper_get_widget_settings', array(__CLASS__, 'get_widget_settings'));
136
+				add_action('wp_ajax_super_duper_get_picker', array(__CLASS__, 'get_picker'));
137 137
 
138 138
 				// add generator text to head
139
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
140
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
139
+				add_action('admin_head', array($this, 'generator'), 99);
140
+				add_action('wp_head', array($this, 'generator'), 99);
141 141
 			}
142 142
 
143
-			do_action( 'wp_super_duper_widget_init', $options, $this );
143
+			do_action('wp_super_duper_widget_init', $options, $this);
144 144
 		}
145 145
 
146 146
         /**
@@ -156,7 +156,7 @@  discard block
 block discarded – undo
156 156
 		 * @return void
157 157
 		 */
158 158
 		public function _register() {
159
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
159
+			if (empty($this->options['output_types']) || in_array('widget', $this->options['output_types'])) {
160 160
 				parent::_register();
161 161
 			}
162 162
 		}
@@ -165,14 +165,14 @@  discard block
 block discarded – undo
165 165
 		 * Add our widget CSS to elementor editor.
166 166
 		 */
167 167
 		public function elementor_editor_styles() {
168
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
168
+			wp_add_inline_style('elementor-editor', $this->widget_css(false));
169 169
 		}
170 170
 
171 171
 		public function register_fusion_element() {
172 172
 
173 173
 			$options = $this->options;
174 174
 
175
-			if ( $this->base_id ) {
175
+			if ($this->base_id) {
176 176
 
177 177
 				$params = $this->get_fusion_params();
178 178
 
@@ -183,11 +183,11 @@  discard block
 block discarded – undo
183 183
 					'allow_generator' => true,
184 184
 				);
185 185
 
186
-				if ( ! empty( $params ) ) {
186
+				if (!empty($params)) {
187 187
 					$args['params'] = $params;
188 188
 				}
189 189
 
190
-				fusion_builder_map( $args );
190
+				fusion_builder_map($args);
191 191
 			}
192 192
 
193 193
 		}
@@ -196,8 +196,8 @@  discard block
 block discarded – undo
196 196
 			$params    = array();
197 197
 			$arguments = $this->get_arguments();
198 198
 
199
-			if ( ! empty( $arguments ) ) {
200
-				foreach ( $arguments as $key => $val ) {
199
+			if (!empty($arguments)) {
200
+				foreach ($arguments as $key => $val) {
201 201
 					$param = array();
202 202
 					// type
203 203
 					$param['type'] = str_replace(
@@ -219,38 +219,38 @@  discard block
 block discarded – undo
219 219
 						$val['type'] );
220 220
 
221 221
 					// multiselect
222
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
222
+					if ($val['type'] == 'multiselect' || (($param['type'] == 'select' || $val['type'] == 'select') && !empty($val['multiple']))) {
223 223
 						$param['type']     = 'multiple_select';
224 224
 						$param['multiple'] = true;
225 225
 					}
226 226
 
227 227
 					// heading
228
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
228
+					$param['heading'] = isset($val['title']) ? $val['title'] : '';
229 229
 
230 230
 					// description
231
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
231
+					$param['description'] = isset($val['desc']) ? $val['desc'] : '';
232 232
 
233 233
 					// param_name
234 234
 					$param['param_name'] = $key;
235 235
 
236 236
 					// Default
237
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
237
+					$param['default'] = isset($val['default']) ? $val['default'] : '';
238 238
 
239 239
 					// Group
240
-					if ( isset( $val['group'] ) ) {
240
+					if (isset($val['group'])) {
241 241
 						$param['group'] = $val['group'];
242 242
 					}
243 243
 
244 244
 					// value
245
-					if ( $val['type'] == 'checkbox' ) {
246
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
247
-							unset( $param['default'] );
245
+					if ($val['type'] == 'checkbox') {
246
+						if (isset($val['default']) && $val['default'] == '0') {
247
+							unset($param['default']);
248 248
 						}
249
-						$param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
250
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
251
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
249
+						$param['value'] = array('0' => __("No", 'ayecode-connect'), '1' => __("Yes", 'ayecode-connect'));
250
+					} elseif ($param['type'] == 'select' || $param['type'] == 'multiple_select') {
251
+						$param['value'] = isset($val['options']) ? $val['options'] : array();
252 252
 					} else {
253
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
253
+						$param['value'] = isset($val['default']) ? $val['default'] : '';
254 254
 					}
255 255
 
256 256
 					// setup the param
@@ -267,7 +267,7 @@  discard block
 block discarded – undo
267 267
 		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
268 268
 		 */
269 269
 		public static function maybe_cornerstone_builder() {
270
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
270
+			if (did_action('cornerstone_before_boot_app')) {
271 271
 				self::shortcode_insert_button_script();
272 272
 			}
273 273
 		}
@@ -279,12 +279,12 @@  discard block
 block discarded – undo
279 279
 		 *
280 280
 		 * @return string
281 281
 		 */
282
-		public static function get_picker( $editor_id = '' ) {
282
+		public static function get_picker($editor_id = '') {
283 283
 
284 284
 			ob_start();
285
-			if ( isset( $_POST['editor_id'] ) ) {
286
-				$editor_id = esc_attr( $_POST['editor_id'] );
287
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
285
+			if (isset($_POST['editor_id'])) {
286
+				$editor_id = esc_attr($_POST['editor_id']);
287
+			} elseif (isset($_REQUEST['et_fb'])) {
288 288
 				$editor_id = 'main_content_content_vb_tiny_mce';
289 289
 			}
290 290
 
@@ -295,14 +295,14 @@  discard block
 block discarded – undo
295 295
 
296 296
 			<div class="sd-shortcode-left-wrap">
297 297
 				<?php
298
-				ksort( $sd_widgets );
298
+				ksort($sd_widgets);
299 299
 				//				print_r($sd_widgets);exit;
300
-				if ( ! empty( $sd_widgets ) ) {
300
+				if (!empty($sd_widgets)) {
301 301
 					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
302
-					echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
303
-					foreach ( $sd_widgets as $shortcode => $class ) {
304
-						if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
305
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
302
+					echo "<option>" . __('Select shortcode', 'ayecode-connect') . "</option>";
303
+					foreach ($sd_widgets as $shortcode => $class) {
304
+						if (!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])) { continue; }
305
+						echo "<option value='" . esc_attr($shortcode) . "'>" . esc_attr($shortcode) . " (" . esc_attr($class['name']) . ")</option>";
306 306
 					}
307 307
 					echo "</select>";
308 308
 
@@ -315,37 +315,37 @@  discard block
 block discarded – undo
315 315
 			<div class="sd-shortcode-right-wrap">
316 316
 				<textarea id='sd-shortcode-output' disabled></textarea>
317 317
 				<div id='sd-shortcode-output-actions'>
318
-					<?php if ( $editor_id != '' ) { ?>
318
+					<?php if ($editor_id != '') { ?>
319 319
 						<button class="button sd-insert-shortcode-button"
320
-								onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
320
+								onclick="sd_insert_shortcode(<?php if (!empty($editor_id)) {
321 321
 									echo "'" . $editor_id . "'";
322
-								} ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
322
+								} ?>)"><?php _e('Insert shortcode', 'ayecode-connect'); ?></button>
323 323
 					<?php } ?>
324 324
 					<button class="button"
325
-							onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
325
+							onclick="sd_copy_to_clipboard()"><?php _e('Copy shortcode'); ?></button>
326 326
 				</div>
327 327
 			</div>
328 328
 			<?php
329 329
 
330 330
 			$html = ob_get_clean();
331 331
 
332
-			if ( wp_doing_ajax() ) {
332
+			if (wp_doing_ajax()) {
333 333
 				echo $html;
334 334
 				$should_die = true;
335 335
 
336 336
 				// some builder get the editor via ajax so we should not die on those occasions
337 337
 				$dont_die = array(
338
-					'parent_tag',// WP Bakery
338
+					'parent_tag', // WP Bakery
339 339
 					'avia_request' // enfold
340 340
 				);
341 341
 
342
-				foreach ( $dont_die as $request ) {
343
-					if ( isset( $_REQUEST[ $request ] ) ) {
342
+				foreach ($dont_die as $request) {
343
+					if (isset($_REQUEST[$request])) {
344 344
 						$should_die = false;
345 345
 					}
346 346
 				}
347 347
 
348
-				if ( $should_die ) {
348
+				if ($should_die) {
349 349
 					wp_die();
350 350
 				}
351 351
 
@@ -361,22 +361,22 @@  discard block
 block discarded – undo
361 361
 		 * Output the version in the header.
362 362
 		 */
363 363
 		public function generator() {
364
-			$file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
365
-			$plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
364
+			$file = str_replace(array("/", "\\"), "/", realpath(__FILE__));
365
+			$plugins_dir = str_replace(array("/", "\\"), "/", realpath(WP_PLUGIN_DIR));
366 366
 
367 367
 			// Find source plugin/theme of SD
368 368
 			$source = array();
369
-			if ( strpos( $file, $plugins_dir ) !== false ) {
370
-				$source = explode( "/", plugin_basename( $file ) );
371
-			} else if ( function_exists( 'get_theme_root' ) ) {
372
-				$themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
369
+			if (strpos($file, $plugins_dir) !== false) {
370
+				$source = explode("/", plugin_basename($file));
371
+			} else if (function_exists('get_theme_root')) {
372
+				$themes_dir = str_replace(array("/", "\\"), "/", realpath(get_theme_root()));
373 373
 
374
-				if ( strpos( $file, $themes_dir ) !== false ) {
375
-					$source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
374
+				if (strpos($file, $themes_dir) !== false) {
375
+					$source = explode("/", ltrim(str_replace($themes_dir, "", $file), "/"));
376 376
 				}
377 377
 			}
378 378
 
379
-			echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
379
+			echo '<meta name="generator" content="WP Super Duper v' . esc_attr($this->version) . '"' . (!empty($source[0]) ? ' data-sd-source="' . esc_attr($source[0]) . '"' : '') . ' />';
380 380
 		}
381 381
 
382 382
 		/**
@@ -387,16 +387,16 @@  discard block
 block discarded – undo
387 387
 		public static function get_widget_settings() {
388 388
 			global $sd_widgets;
389 389
 
390
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
391
-			if ( ! $shortcode ) {
390
+			$shortcode = isset($_REQUEST['shortcode']) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes($_REQUEST['shortcode']) : '';
391
+			if (!$shortcode) {
392 392
 				wp_die();
393 393
 			}
394
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
395
-			if ( ! $widget_args ) {
394
+			$widget_args = isset($sd_widgets[$shortcode]) ? $sd_widgets[$shortcode] : '';
395
+			if (!$widget_args) {
396 396
 				wp_die();
397 397
 			}
398
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
-			if ( ! $class_name ) {
398
+			$class_name = isset($widget_args['class_name']) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
+			if (!$class_name) {
400 400
 				wp_die();
401 401
 			}
402 402
 
@@ -404,7 +404,7 @@  discard block
 block discarded – undo
404 404
 			$widget = new $class_name;
405 405
 
406 406
 			ob_start();
407
-			$widget->form( array() );
407
+			$widget->form(array());
408 408
 			$form = ob_get_clean();
409 409
 			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
410 410
 			echo "<style>" . $widget->widget_css() . "</style>";
@@ -423,9 +423,9 @@  discard block
 block discarded – undo
423 423
 		 *@since 1.0.0
424 424
 		 *
425 425
 		 */
426
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
426
+		public static function shortcode_insert_button($editor_id = '', $insert_shortcode_function = '') {
427 427
 			global $sd_widgets, $shortcode_insert_button_once;
428
-			if ( $shortcode_insert_button_once ) {
428
+			if ($shortcode_insert_button_once) {
429 429
 				return;
430 430
 			}
431 431
 			add_thickbox();
@@ -435,21 +435,21 @@  discard block
 block discarded – undo
435 435
 			 * Cornerstone makes us play dirty tricks :/
436 436
 			 * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
437 437
 			 */
438
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
438
+			if (function_exists('cornerstone_plugin_init') && !is_admin()) {
439 439
 				echo '<span id="insert-media-button">';
440 440
 			}
441 441
 
442
-			echo self::shortcode_button( 'this', 'true' );
442
+			echo self::shortcode_button('this', 'true');
443 443
 
444 444
 			// see opening note
445
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
445
+			if (function_exists('cornerstone_plugin_init') && !is_admin()) {
446 446
 				echo '</span>'; // end #insert-media-button
447 447
 			}
448 448
 
449 449
 			// Add separate script for generatepress theme sections
450
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
450
+			if (function_exists('generate_sections_sections_metabox') && did_action('generate_sections_metabox')) {
451 451
 			} else {
452
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
452
+				self::shortcode_insert_button_script($editor_id, $insert_shortcode_function);
453 453
 			}
454 454
 
455 455
 			$shortcode_insert_button_once = true;
@@ -463,12 +463,12 @@  discard block
 block discarded – undo
463 463
 		 *
464 464
 		 * @return mixed
465 465
 		 */
466
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
466
+		public static function shortcode_button($id = '', $search_for_id = '') {
467 467
 			ob_start();
468 468
 			?>
469 469
 			<span class="sd-lable-shortcode-inserter">
470 470
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
471
-				if ( $search_for_id ) {
471
+				if ($search_for_id) {
472 472
 					echo "," . $search_for_id;
473 473
 				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
474 474
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
@@ -484,7 +484,7 @@  discard block
 block discarded – undo
484 484
 			$html = ob_get_clean();
485 485
 
486 486
 			// remove line breaks so we can use it in js
487
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
487
+			return preg_replace("/\r|\n/", "", trim($html));
488 488
 		}
489 489
 
490 490
 		/**
@@ -542,7 +542,7 @@  discard block
 block discarded – undo
542 542
 						jQuery($this).data('sd-widget-enabled', true);
543 543
 					}
544 544
 
545
-					var $button = '<button title="<?php _e( 'Advanced Settings', 'ayecode-connect' );?>" class="button button-primary right sd-advanced-button" onclick="sd_so_toggle_advanced(this);return false;"><i class="fas fa-sliders-h" aria-hidden="true"></i></button>';
545
+					var $button = '<button title="<?php _e('Advanced Settings', 'ayecode-connect'); ?>" class="button button-primary right sd-advanced-button" onclick="sd_so_toggle_advanced(this);return false;"><i class="fas fa-sliders-h" aria-hidden="true"></i></button>';
546 546
 					var form = jQuery($this).parents('' + $selector + '');
547 547
 
548 548
 					if (jQuery($this).val() == '1' && jQuery(form).find('.sd-advanced-button').length == 0) {
@@ -577,10 +577,10 @@  discard block
 block discarded – undo
577 577
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
578 578
 			 */
579 579
 
580
-			return str_replace( array(
580
+			return str_replace(array(
581 581
 				'<script>',
582 582
 				'</script>'
583
-			), '', $output );
583
+			), '', $output);
584 584
 		}
585 585
 
586 586
 		/**
@@ -592,7 +592,7 @@  discard block
 block discarded – undo
592 592
 		 *@since 1.0.6
593 593
 		 *
594 594
 		 */
595
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
595
+		public static function shortcode_insert_button_script($editor_id = '', $insert_shortcode_function = '') {
596 596
 			?>
597 597
 			<style>
598 598
 				.sd-shortcode-left-wrap {
@@ -711,25 +711,25 @@  discard block
 block discarded – undo
711 711
 					width: 100%;
712 712
 				}
713 713
 
714
-				<?php if ( function_exists( 'generate_sections_sections_metabox' ) ) { ?>
714
+				<?php if (function_exists('generate_sections_sections_metabox')) { ?>
715 715
 				.generate-sections-modal #custom-media-buttons > .sd-lable-shortcode-inserter {
716 716
 					display: inline;
717 717
 				}
718 718
 				<?php } ?>
719
-				<?php if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) { ?>
719
+				<?php if (function_exists('et_builder_is_tb_admin_screen') && et_builder_is_tb_admin_screen()) { ?>
720 720
 				body.divi_page_et_theme_builder div#TB_window.gd-tb-window{z-index:9999999}
721 721
 				<?php } ?>
722 722
 			</style>
723 723
 			<?php
724
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
724
+			if (class_exists('SiteOrigin_Panels')) {
725 725
 				echo "<script>" . self::siteorigin_js() . "</script>";
726 726
 			}
727 727
 			?>
728 728
 			<script>
729 729
 				<?php
730
-				if(! empty( $insert_shortcode_function )){
730
+				if (!empty($insert_shortcode_function)) {
731 731
 					echo $insert_shortcode_function;
732
-				}else{
732
+				} else {
733 733
 
734 734
 				/**
735 735
 				 * Function for super duper insert shortcode.
@@ -742,9 +742,9 @@  discard block
 block discarded – undo
742 742
 					if ($shortcode) {
743 743
 						if (!$editor_id) {
744 744
 							<?php
745
-							if ( isset( $_REQUEST['et_fb'] ) ) {
745
+							if (isset($_REQUEST['et_fb'])) {
746 746
 								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
747
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
747
+							} elseif (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') {
748 748
 								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
749 749
 							} else {
750 750
 								echo '$editor_id = "#wp-content-editor-container textarea";';
@@ -827,11 +827,11 @@  discard block
 block discarded – undo
827 827
 							'shortcode': $short_code,
828 828
 							'attributes': 123,
829 829
 							'post_id': 321,
830
-							'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
830
+							'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_output_shortcode'); ?>'
831 831
 						};
832 832
 
833 833
 						if (typeof ajaxurl === 'undefined') {
834
-							var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' );?>";
834
+							var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
835 835
 						}
836 836
 
837 837
 						jQuery.post(ajaxurl, data, function (response) {
@@ -1030,11 +1030,11 @@  discard block
 block discarded – undo
1030 1030
 					var data = {
1031 1031
 						'action': 'super_duper_get_picker',
1032 1032
 						'editor_id': $id,
1033
-						'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_picker' );?>'
1033
+						'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_picker'); ?>'
1034 1034
 					};
1035 1035
 
1036 1036
 					if (!ajaxurl) {
1037
-						var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' ); ?>";
1037
+						var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
1038 1038
 					}
1039 1039
 
1040 1040
 					jQuery.post(ajaxurl, data, function (response) {
@@ -1056,9 +1056,9 @@  discard block
 block discarded – undo
1056 1056
 				 */
1057 1057
 				function sd_shortcode_button($id) {
1058 1058
 					if ($id) {
1059
-						return '<?php echo self::shortcode_button( "\\''+\$id+'\\'" );?>';
1059
+						return '<?php echo self::shortcode_button("\\''+\$id+'\\'"); ?>';
1060 1060
 					} else {
1061
-						return '<?php echo self::shortcode_button();?>';
1061
+						return '<?php echo self::shortcode_button(); ?>';
1062 1062
 					}
1063 1063
 				}
1064 1064
 			</script>
@@ -1072,11 +1072,11 @@  discard block
 block discarded – undo
1072 1072
 		 *
1073 1073
 		 * @return mixed
1074 1074
 		 */
1075
-		public function widget_css( $advanced = true ) {
1075
+		public function widget_css($advanced = true) {
1076 1076
 			ob_start();
1077 1077
 			?>
1078 1078
 			<style>
1079
-				<?php if( $advanced ){ ?>
1079
+				<?php if ($advanced) { ?>
1080 1080
 				.sd-advanced-setting {
1081 1081
 					display: none;
1082 1082
 				}
@@ -1120,10 +1120,10 @@  discard block
 block discarded – undo
1120 1120
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1121 1121
 			 */
1122 1122
 
1123
-			return str_replace( array(
1123
+			return str_replace(array(
1124 1124
 				'<style>',
1125 1125
 				'</style>'
1126
-			), '', $output );
1126
+			), '', $output);
1127 1127
 		}
1128 1128
 
1129 1129
 		/**
@@ -1190,7 +1190,7 @@  discard block
 block discarded – undo
1190 1190
 						jQuery($this).data('sd-widget-enabled', true);
1191 1191
 					}
1192 1192
 
1193
-					var $button = '<button title="<?php _e( 'Advanced Settings', 'ayecode-connect' );?>" style="line-height: 28px;" class="button button-primary right sd-advanced-button" onclick="sd_toggle_advanced(this);return false;"><span class="dashicons dashicons-admin-settings" style="width: 28px;font-size: 28px;"></span></button>';
1193
+					var $button = '<button title="<?php _e('Advanced Settings', 'ayecode-connect'); ?>" style="line-height: 28px;" class="button button-primary right sd-advanced-button" onclick="sd_toggle_advanced(this);return false;"><span class="dashicons dashicons-admin-settings" style="width: 28px;font-size: 28px;"></span></button>';
1194 1194
 					var form = $form ? $form : jQuery($this).parents('' + $selector + '');
1195 1195
 
1196 1196
 					if (jQuery($this).val() == '1' && jQuery(form).find('.sd-advanced-button').length == 0) {
@@ -1281,7 +1281,7 @@  discard block
 block discarded – undo
1281 1281
 					});
1282 1282
 
1283 1283
 				}
1284
-				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1284
+				<?php do_action('wp_super_duper_widget_js', $this); ?>
1285 1285
 			</script>
1286 1286
 			<?php
1287 1287
 			$output = ob_get_clean();
@@ -1290,10 +1290,10 @@  discard block
 block discarded – undo
1290 1290
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1291 1291
 			 */
1292 1292
 
1293
-			return str_replace( array(
1293
+			return str_replace(array(
1294 1294
 				'<script>',
1295 1295
 				'</script>'
1296
-			), '', $output );
1296
+			), '', $output);
1297 1297
 		}
1298 1298
 
1299 1299
 
@@ -1304,14 +1304,14 @@  discard block
 block discarded – undo
1304 1304
 		 *
1305 1305
 		 * @return mixed
1306 1306
 		 */
1307
-		private function add_name_from_key( $options, $arguments = false ) {
1308
-			if ( ! empty( $options['arguments'] ) ) {
1309
-				foreach ( $options['arguments'] as $key => $val ) {
1310
-					$options['arguments'][ $key ]['name'] = $key;
1307
+		private function add_name_from_key($options, $arguments = false) {
1308
+			if (!empty($options['arguments'])) {
1309
+				foreach ($options['arguments'] as $key => $val) {
1310
+					$options['arguments'][$key]['name'] = $key;
1311 1311
 				}
1312
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1313
-				foreach ( $options as $key => $val ) {
1314
-					$options[ $key ]['name'] = $key;
1312
+			} elseif ($arguments && is_array($options) && !empty($options)) {
1313
+				foreach ($options as $key => $val) {
1314
+					$options[$key]['name'] = $key;
1315 1315
 				}
1316 1316
 			}
1317 1317
 
@@ -1324,8 +1324,8 @@  discard block
 block discarded – undo
1324 1324
 		 * @since 1.0.0
1325 1325
 		 */
1326 1326
 		public function register_shortcode() {
1327
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1328
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1327
+			add_shortcode($this->base_id, array($this, 'shortcode_output'));
1328
+			add_action('wp_ajax_super_duper_output_shortcode', array($this, 'render_shortcode'));
1329 1329
 		}
1330 1330
 
1331 1331
 		/**
@@ -1334,50 +1334,50 @@  discard block
 block discarded – undo
1334 1334
 		 * @since 1.0.0
1335 1335
 		 */
1336 1336
 		public function render_shortcode() {
1337
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1338
-			if ( ! current_user_can( 'manage_options' ) ) {
1337
+			check_ajax_referer('super_duper_output_shortcode', '_ajax_nonce', true);
1338
+			if (!current_user_can('manage_options')) {
1339 1339
 				wp_die();
1340 1340
 			}
1341 1341
 
1342 1342
 			// we might need the $post value here so lets set it.
1343
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1344
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1345
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1343
+			if (isset($_POST['post_id']) && $_POST['post_id']) {
1344
+				$post_obj = get_post(absint($_POST['post_id']));
1345
+				if (!empty($post_obj) && empty($post)) {
1346 1346
 					global $post;
1347 1347
 					$post = $post_obj;
1348 1348
 				}
1349 1349
 			}
1350 1350
 
1351
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1351
+			if (isset($_POST['shortcode']) && $_POST['shortcode']) {
1352 1352
 				$is_preview = $this->is_preview();
1353
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1354
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1353
+				$shortcode_name   = sanitize_title_with_dashes($_POST['shortcode']);
1354
+				$attributes_array = isset($_POST['attributes']) && $_POST['attributes'] ? $_POST['attributes'] : array();
1355 1355
 				$attributes       = '';
1356
-				if ( ! empty( $attributes_array ) ) {
1357
-					foreach ( $attributes_array as $key => $value ) {
1358
-						if ( is_array( $value ) ) {
1359
-							$value = implode( ",", $value );
1356
+				if (!empty($attributes_array)) {
1357
+					foreach ($attributes_array as $key => $value) {
1358
+						if (is_array($value)) {
1359
+							$value = implode(",", $value);
1360 1360
 						}
1361 1361
 
1362
-						if ( ! empty( $value ) ) {
1363
-							$value = wp_unslash( $value );
1362
+						if (!empty($value)) {
1363
+							$value = wp_unslash($value);
1364 1364
 
1365 1365
 							// Encode [ and ].
1366
-							if ( $is_preview ) {
1367
-								$value = $this->encode_shortcodes( $value );
1366
+							if ($is_preview) {
1367
+								$value = $this->encode_shortcodes($value);
1368 1368
 							}
1369 1369
 						}
1370
-						$attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1370
+						$attributes .= " " . esc_attr(sanitize_title_with_dashes($key)) . "='" . esc_attr($value) . "' ";
1371 1371
 					}
1372 1372
 				}
1373 1373
 
1374
-				$shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1374
+				$shortcode = "[" . esc_attr($shortcode_name) . " " . $attributes . "]";
1375 1375
 
1376
-				$content = do_shortcode( $shortcode );
1376
+				$content = do_shortcode($shortcode);
1377 1377
 
1378 1378
 				// Decode [ and ].
1379
-				if ( ! empty( $content ) && $is_preview ) {
1380
-					$content = $this->decode_shortcodes( $content );
1379
+				if (!empty($content) && $is_preview) {
1380
+					$content = $this->decode_shortcodes($content);
1381 1381
 				}
1382 1382
 
1383 1383
 				echo $content;
@@ -1393,21 +1393,21 @@  discard block
 block discarded – undo
1393 1393
 		 *
1394 1394
 		 * @return string
1395 1395
 		 */
1396
-		public function shortcode_output( $args = array(), $content = '' ) {
1396
+		public function shortcode_output($args = array(), $content = '') {
1397 1397
 			$_instance = $args;
1398 1398
 
1399
-			$args = $this->argument_values( $args );
1399
+			$args = $this->argument_values($args);
1400 1400
 
1401 1401
 			// add extra argument so we know its a output to gutenberg
1402 1402
 			//$args
1403
-			$args = $this->string_to_bool( $args );
1403
+			$args = $this->string_to_bool($args);
1404 1404
 
1405 1405
 			// if we have a enclosed shortcode we add it to the special `html` argument
1406
-			if ( ! empty( $content ) ) {
1406
+			if (!empty($content)) {
1407 1407
 				$args['html'] = $content;
1408 1408
 			}
1409 1409
 
1410
-			if ( ! $this->is_preview() ) {
1410
+			if (!$this->is_preview()) {
1411 1411
 				/**
1412 1412
 				 * Filters the settings for a particular widget args.
1413 1413
 				 *
@@ -1418,40 +1418,40 @@  discard block
 block discarded – undo
1418 1418
 				 *@since 1.0.28
1419 1419
 				 *
1420 1420
 				 */
1421
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1421
+				$args = apply_filters('wp_super_duper_widget_display_callback', $args, $this, $_instance);
1422 1422
 
1423
-				if ( ! is_array( $args ) ) {
1423
+				if (!is_array($args)) {
1424 1424
 					return $args;
1425 1425
 				}
1426 1426
 			}
1427 1427
 
1428
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1429
-			$class .= " sdel-".$this->get_instance_hash();
1428
+			$class = isset($this->options['widget_ops']['classname']) ? esc_attr($this->options['widget_ops']['classname']) : '';
1429
+			$class .= " sdel-" . $this->get_instance_hash();
1430 1430
 
1431
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1432
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1431
+			$class = apply_filters('wp_super_duper_div_classname', $class, $args, $this);
1432
+			$class = apply_filters('wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this);
1433 1433
 
1434
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1435
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1434
+			$attrs = apply_filters('wp_super_duper_div_attrs', '', $args, $this);
1435
+			$attrs = apply_filters('wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this);
1436 1436
 
1437 1437
 			$shortcode_args = array();
1438 1438
 			$output         = '';
1439
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1440
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1439
+			$no_wrap        = isset($this->options['no_wrap']) && $this->options['no_wrap'] ? true : false;
1440
+			if (isset($args['no_wrap']) && $args['no_wrap']) {
1441 1441
 				$no_wrap = true;
1442 1442
 			}
1443
-			$main_content = $this->output( $args, $shortcode_args, $content );
1444
-			if ( $main_content && ! $no_wrap ) {
1443
+			$main_content = $this->output($args, $shortcode_args, $content);
1444
+			if ($main_content && !$no_wrap) {
1445 1445
 				// wrap the shortcode in a div with the same class as the widget
1446 1446
 				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1447
-				if ( ! empty( $args['title'] ) ) {
1447
+				if (!empty($args['title'])) {
1448 1448
 					// if its a shortcode and there is a title try to grab the title wrappers
1449
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1450
-					if ( empty( $instance ) ) {
1449
+					$shortcode_args = array('before_title' => '', 'after_title' => '');
1450
+					if (empty($instance)) {
1451 1451
 						global $wp_registered_sidebars;
1452
-						if ( ! empty( $wp_registered_sidebars ) ) {
1453
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1454
-								if ( ! empty( $sidebar['before_title'] ) ) {
1452
+						if (!empty($wp_registered_sidebars)) {
1453
+							foreach ($wp_registered_sidebars as $sidebar) {
1454
+								if (!empty($sidebar['before_title'])) {
1455 1455
 									$shortcode_args['before_title'] = $sidebar['before_title'];
1456 1456
 									$shortcode_args['after_title']  = $sidebar['after_title'];
1457 1457
 									break;
@@ -1459,20 +1459,20 @@  discard block
 block discarded – undo
1459 1459
 							}
1460 1460
 						}
1461 1461
 					}
1462
-					$output .= $this->output_title( $shortcode_args, $args );
1462
+					$output .= $this->output_title($shortcode_args, $args);
1463 1463
 				}
1464 1464
 				$output .= $main_content;
1465 1465
 				$output .= '</div>';
1466
-			} elseif ( $main_content && $no_wrap ) {
1466
+			} elseif ($main_content && $no_wrap) {
1467 1467
 				$output .= $main_content;
1468 1468
 			}
1469 1469
 
1470 1470
 			// if preview show a placeholder if empty
1471
-			if ( $this->is_preview() && $output == '' ) {
1472
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1471
+			if ($this->is_preview() && $output == '') {
1472
+				$output = $this->preview_placeholder_text("{{" . $this->base_id . "}}");
1473 1473
 			}
1474 1474
 
1475
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1475
+			return apply_filters('wp_super_duper_widget_output', $output, $args, $shortcode_args, $this);
1476 1476
 		}
1477 1477
 
1478 1478
 		/**
@@ -1482,8 +1482,8 @@  discard block
 block discarded – undo
1482 1482
 		 *
1483 1483
 		 * @return string
1484 1484
 		 */
1485
-		public function preview_placeholder_text( $name = '' ) {
1486
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1485
+		public function preview_placeholder_text($name = '') {
1486
+			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf(__('Placeholder for: %s', 'ayecode-connect'), $name) . "</div>";
1487 1487
 		}
1488 1488
 
1489 1489
 		/**
@@ -1493,13 +1493,13 @@  discard block
 block discarded – undo
1493 1493
 		 *
1494 1494
 		 * @return mixed
1495 1495
 		 */
1496
-		public function string_to_bool( $options ) {
1496
+		public function string_to_bool($options) {
1497 1497
 			// convert bool strings to booleans
1498
-			foreach ( $options as $key => $val ) {
1499
-				if ( $val == 'false' ) {
1500
-					$options[ $key ] = false;
1501
-				} elseif ( $val == 'true' ) {
1502
-					$options[ $key ] = true;
1498
+			foreach ($options as $key => $val) {
1499
+				if ($val == 'false') {
1500
+					$options[$key] = false;
1501
+				} elseif ($val == 'true') {
1502
+					$options[$key] = true;
1503 1503
 				}
1504 1504
 			}
1505 1505
 
@@ -1515,26 +1515,26 @@  discard block
 block discarded – undo
1515 1515
 		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1516 1516
 		 *
1517 1517
 		 */
1518
-		public function argument_values( $instance ) {
1518
+		public function argument_values($instance) {
1519 1519
 			$argument_values = array();
1520 1520
 
1521 1521
 			// set widget instance
1522 1522
 			$this->instance = $instance;
1523 1523
 
1524
-			if ( empty( $this->arguments ) ) {
1524
+			if (empty($this->arguments)) {
1525 1525
 				$this->arguments = $this->get_arguments();
1526 1526
 			}
1527 1527
 
1528
-			if ( ! empty( $this->arguments ) ) {
1529
-				foreach ( $this->arguments as $key => $args ) {
1528
+			if (!empty($this->arguments)) {
1529
+				foreach ($this->arguments as $key => $args) {
1530 1530
 					// set the input name from the key
1531 1531
 					$args['name'] = $key;
1532 1532
 					//
1533
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1534
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1533
+					$argument_values[$key] = isset($instance[$key]) ? $instance[$key] : '';
1534
+					if ($args['type'] == 'checkbox' && $argument_values[$key] == '') {
1535 1535
 						// don't set default for an empty checkbox
1536
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1537
-						$argument_values[ $key ] = $args['default'];
1536
+					} elseif ($argument_values[$key] == '' && isset($args['default'])) {
1537
+						$argument_values[$key] = $args['default'];
1538 1538
 					}
1539 1539
 				}
1540 1540
 			}
@@ -1561,15 +1561,15 @@  discard block
 block discarded – undo
1561 1561
 		 *
1562 1562
 		 */
1563 1563
 		public function get_arguments() {
1564
-			if ( empty( $this->arguments ) ) {
1564
+			if (empty($this->arguments)) {
1565 1565
 				$this->arguments = $this->set_arguments();
1566 1566
 			}
1567 1567
 
1568
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1569
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1568
+			$this->arguments = apply_filters('wp_super_duper_arguments', $this->arguments, $this->options, $this->instance);
1569
+			$this->arguments = $this->add_name_from_key($this->arguments, true);
1570 1570
 
1571
-            if( !empty( $this->arguments['title']['value'] ) ){
1572
-                $this->arguments['title']['value'] = wp_kses_post( $this->arguments['title']['value'] );
1571
+            if (!empty($this->arguments['title']['value'])) {
1572
+                $this->arguments['title']['value'] = wp_kses_post($this->arguments['title']['value']);
1573 1573
             }
1574 1574
 
1575 1575
 			return $this->arguments;
@@ -1582,7 +1582,7 @@  discard block
 block discarded – undo
1582 1582
 		 * @param array $widget_args
1583 1583
 		 * @param string $content
1584 1584
 		 */
1585
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1585
+		public function output($args = array(), $widget_args = array(), $content = '') {
1586 1586
 
1587 1587
 		}
1588 1588
 
@@ -1590,9 +1590,9 @@  discard block
 block discarded – undo
1590 1590
 		 * Add the dynamic block code inline when the wp-block in enqueued.
1591 1591
 		 */
1592 1592
 		public function register_block() {
1593
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1594
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1595
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1593
+			wp_add_inline_script('wp-blocks', $this->block());
1594
+			if (class_exists('SiteOrigin_Panels')) {
1595
+				wp_add_inline_script('wp-blocks', $this->siteorigin_js());
1596 1596
 			}
1597 1597
 		}
1598 1598
 
@@ -1606,9 +1606,9 @@  discard block
 block discarded – undo
1606 1606
 			$show      = false;
1607 1607
 			$arguments = $this->get_arguments();
1608 1608
 
1609
-			if ( ! empty( $arguments ) ) {
1610
-				foreach ( $arguments as $argument ) {
1611
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1609
+			if (!empty($arguments)) {
1610
+				foreach ($arguments as $argument) {
1611
+					if (isset($argument['advanced']) && $argument['advanced']) {
1612 1612
 						$show = true;
1613 1613
 						break; // no need to continue if we know we have it
1614 1614
 					}
@@ -1626,19 +1626,19 @@  discard block
 block discarded – undo
1626 1626
 		public function get_url() {
1627 1627
 			$url = $this->url;
1628 1628
 
1629
-			if ( ! $url ) {
1630
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1631
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1629
+			if (!$url) {
1630
+				$content_dir = wp_normalize_path(untrailingslashit(WP_CONTENT_DIR));
1631
+				$content_url = untrailingslashit(WP_CONTENT_URL);
1632 1632
 
1633 1633
 				// Replace http:// to https://.
1634
-				if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1635
-					$content_url = str_replace( 'http://', 'https://', $content_url );
1634
+				if (strpos($content_url, 'http://') === 0 && strpos(plugins_url(), 'https://') === 0) {
1635
+					$content_url = str_replace('http://', 'https://', $content_url);
1636 1636
 				}
1637 1637
 
1638 1638
 				// Check if we are inside a plugin
1639
-				$file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1640
-				$url = str_replace( $content_dir, $content_url, $file_dir );
1641
-				$url = trailingslashit( $url );
1639
+				$file_dir = str_replace("/includes", "", wp_normalize_path(dirname(__FILE__)));
1640
+				$url = str_replace($content_dir, $content_url, $file_dir);
1641
+				$url = trailingslashit($url);
1642 1642
 				$this->url = $url;
1643 1643
 			}
1644 1644
 
@@ -1654,15 +1654,15 @@  discard block
 block discarded – undo
1654 1654
 
1655 1655
 			$url = $this->url;
1656 1656
 
1657
-			if ( ! $url ) {
1657
+			if (!$url) {
1658 1658
 				// check if we are inside a plugin
1659
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1659
+				$file_dir = str_replace("/includes", "", dirname(__FILE__));
1660 1660
 
1661
-				$dir_parts = explode( "/wp-content/", $file_dir );
1662
-				$url_parts = explode( "/wp-content/", plugins_url() );
1661
+				$dir_parts = explode("/wp-content/", $file_dir);
1662
+				$url_parts = explode("/wp-content/", plugins_url());
1663 1663
 
1664
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1665
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1664
+				if (!empty($url_parts[0]) && !empty($dir_parts[1])) {
1665
+					$url       = trailingslashit($url_parts[0] . "/wp-content/" . $dir_parts[1]);
1666 1666
 					$this->url = $url;
1667 1667
 				}
1668 1668
 			}
@@ -1683,45 +1683,45 @@  discard block
 block discarded – undo
1683 1683
 		 * @return string
1684 1684
 		 *@since 1.1.0
1685 1685
 		 */
1686
-		public function get_block_icon( $icon ) {
1686
+		public function get_block_icon($icon) {
1687 1687
 
1688 1688
 			// check if we have a Font Awesome icon
1689 1689
 			$fa_type = '';
1690
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1690
+			if (substr($icon, 0, 7) === "fas fa-") {
1691 1691
 				$fa_type = 'solid';
1692
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1692
+			} elseif (substr($icon, 0, 7) === "far fa-") {
1693 1693
 				$fa_type = 'regular';
1694
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1694
+			} elseif (substr($icon, 0, 7) === "fab fa-") {
1695 1695
 				$fa_type = 'brands';
1696 1696
 			} else {
1697 1697
 				$icon = "'" . $icon . "'";
1698 1698
 			}
1699 1699
 
1700 1700
 			// set the icon if we found one
1701
-			if ( $fa_type ) {
1702
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1701
+			if ($fa_type) {
1702
+				$fa_icon = str_replace(array("fas fa-", "far fa-", "fab fa-"), "", $icon);
1703 1703
 				$icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1704 1704
 			}
1705 1705
 
1706 1706
 			return $icon;
1707 1707
 		}
1708 1708
 
1709
-		public function group_arguments( $arguments ) {
1710
-			if ( ! empty( $arguments ) ) {
1709
+		public function group_arguments($arguments) {
1710
+			if (!empty($arguments)) {
1711 1711
 				$temp_arguments = array();
1712
-				$general        = __( "General", 'ayecode-connect' );
1712
+				$general        = __("General", 'ayecode-connect');
1713 1713
 				$add_sections   = false;
1714
-				foreach ( $arguments as $key => $args ) {
1715
-					if ( isset( $args['group'] ) ) {
1716
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1714
+				foreach ($arguments as $key => $args) {
1715
+					if (isset($args['group'])) {
1716
+						$temp_arguments[$args['group']][$key] = $args;
1717 1717
 						$add_sections                             = true;
1718 1718
 					} else {
1719
-						$temp_arguments[ $general ][ $key ] = $args;
1719
+						$temp_arguments[$general][$key] = $args;
1720 1720
 					}
1721 1721
 				}
1722 1722
 
1723 1723
 				// only add sections if more than one
1724
-				if ( $add_sections ) {
1724
+				if ($add_sections) {
1725 1725
 					$arguments = $temp_arguments;
1726 1726
 				}
1727 1727
 			}
@@ -1734,38 +1734,38 @@  discard block
 block discarded – undo
1734 1734
 		 *
1735 1735
 		 * @since 1.1.17
1736 1736
 		 */
1737
-		public function group_block_tabs( $tabs, $arguments ) {
1738
-			if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1737
+		public function group_block_tabs($tabs, $arguments) {
1738
+			if (!empty($tabs) && !empty($arguments)) {
1739 1739
 				$has_sections = false;
1740 1740
 
1741
-				foreach ( $this->arguments as $key => $args ) {
1742
-					if ( isset( $args['group'] ) ) {
1741
+				foreach ($this->arguments as $key => $args) {
1742
+					if (isset($args['group'])) {
1743 1743
 						$has_sections = true;
1744 1744
 						break;
1745 1745
 					}
1746 1746
 				}
1747 1747
 
1748
-				if ( ! $has_sections ) {
1748
+				if (!$has_sections) {
1749 1749
 					return $tabs;
1750 1750
 				}
1751 1751
 
1752 1752
 				$new_tabs = array();
1753 1753
 
1754
-				foreach ( $tabs as $tab_key => $tab ) {
1754
+				foreach ($tabs as $tab_key => $tab) {
1755 1755
 					$new_groups = array();
1756 1756
 
1757
-					if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1758
-						foreach ( $tab['groups'] as $group ) {
1759
-							if ( isset( $arguments[ $group ] ) ) {
1757
+					if (!empty($tab['groups']) && is_array($tab['groups'])) {
1758
+						foreach ($tab['groups'] as $group) {
1759
+							if (isset($arguments[$group])) {
1760 1760
 								$new_groups[] = $group;
1761 1761
 							}
1762 1762
 						}
1763 1763
 					}
1764 1764
 
1765
-					if ( ! empty( $new_groups ) ) {
1765
+					if (!empty($new_groups)) {
1766 1766
 						$tab['groups'] = $new_groups;
1767 1767
 
1768
-						$new_tabs[ $tab_key ] = $tab;
1768
+						$new_tabs[$tab_key] = $tab;
1769 1769
 					}
1770 1770
 				}
1771 1771
 
@@ -1792,7 +1792,7 @@  discard block
 block discarded – undo
1792 1792
 			?>
1793 1793
 			<script>
1794 1794
 			<?php
1795
-			if ( ! $sd_is_js_functions_loaded ) {
1795
+			if (!$sd_is_js_functions_loaded) {
1796 1796
 				$sd_is_js_functions_loaded = true;
1797 1797
 			?>
1798 1798
 function sd_show_view_options($this){
@@ -2115,7 +2115,7 @@  discard block
 block discarded – undo
2115 2115
 	}
2116 2116
 }
2117 2117
 
2118
-<?php if( !isset( $_REQUEST['sd-block-recover-debug'] ) ){ ?>
2118
+<?php if (!isset($_REQUEST['sd-block-recover-debug'])) { ?>
2119 2119
 // Wait will window is loaded before calling.
2120 2120
 window.onload = function() {
2121 2121
 	sd_auto_recover_blocks();
@@ -2294,7 +2294,7 @@  discard block
 block discarded – undo
2294 2294
 				$classes = [];
2295 2295
 
2296 2296
 				<?php
2297
-				if($aui_bs5){
2297
+				if ($aui_bs5) {
2298 2298
 					?>
2299 2299
 				$aui_bs5 = true;
2300 2300
 				$p_ml = 'ms-';
@@ -2303,7 +2303,7 @@  discard block
 block discarded – undo
2303 2303
 				$p_pl = 'ps-';
2304 2304
 				$p_pr = 'pe-';
2305 2305
 					<?php
2306
-				}else{
2306
+				} else {
2307 2307
 						?>
2308 2308
 				$aui_bs5 = false;
2309 2309
 				$p_ml = 'ml-';
@@ -2491,7 +2491,7 @@  discard block
 block discarded – undo
2491 2491
 			}
2492 2492
 
2493 2493
 			function sd_get_class_build_keys(){
2494
-				return <?php echo json_encode(sd_get_class_build_keys());?>;
2494
+				return <?php echo json_encode(sd_get_class_build_keys()); ?>;
2495 2495
 			}
2496 2496
 
2497 2497
 			<?php
@@ -2499,7 +2499,7 @@  discard block
 block discarded – undo
2499 2499
 
2500 2500
 			}
2501 2501
 
2502
-			if(method_exists($this,'block_global_js')){
2502
+			if (method_exists($this, 'block_global_js')) {
2503 2503
 					echo $this->block_global_js();
2504 2504
 			}
2505 2505
 			?>
@@ -2531,9 +2531,9 @@  discard block
 block discarded – undo
2531 2531
 					var InnerBlocks = blockEditor.InnerBlocks;
2532 2532
 
2533 2533
 					var term_query_type = '';
2534
-					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";}else{echo "[]";} ?>;
2535
-					const taxonomies_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2536
-					const sort_by_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2534
+					var post_type_rest_slugs = <?php if (!empty($this->arguments) && isset($this->arguments['post_type']['onchange_rest']['values'])) {echo "[" . json_encode($this->arguments['post_type']['onchange_rest']['values']) . "]"; } else {echo "[]"; } ?>;
2535
+					const taxonomies_<?php echo str_replace("-", "_", $this->id); ?> = [{label: "Please wait", value: 0}];
2536
+					const sort_by_<?php echo str_replace("-", "_", $this->id); ?> = [{label: "Please wait", value: 0}];
2537 2537
 					const MediaUpload = wp.blockEditor.MediaUpload;
2538 2538
 
2539 2539
 					/**
@@ -2548,87 +2548,87 @@  discard block
 block discarded – undo
2548 2548
 					 * @return {?WPBlock}          The block, if it has been successfully
2549 2549
 					 *                             registered; otherwise `undefined`.
2550 2550
 					 */
2551
-					registerBlockType('<?php echo str_replace( "_", "-", sanitize_title_with_dashes( $this->options['textdomain'] ) . '/' . sanitize_title_with_dashes( $this->options['class_name'] ) );  ?>', { // Block name. Block names must be string that contains a namespace prefix. Example: my-plugin/my-custom-block.
2552
-						apiVersion: <?php echo isset($this->options['block-api-version']) ? absint($this->options['block-api-version']) : 2 ; ?>,
2553
-						title: '<?php echo addslashes( $this->options['name'] ); ?>', // Block title.
2554
-						description: '<?php echo addslashes( $this->options['widget_ops']['description'] )?>', // Block title.
2555
-						icon: <?php echo $this->get_block_icon( $this->options['block-icon'] );?>,//'<?php echo isset( $this->options['block-icon'] ) ? esc_attr( $this->options['block-icon'] ) : 'shield-alt';?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
2551
+					registerBlockType('<?php echo str_replace("_", "-", sanitize_title_with_dashes($this->options['textdomain']) . '/' . sanitize_title_with_dashes($this->options['class_name'])); ?>', { // Block name. Block names must be string that contains a namespace prefix. Example: my-plugin/my-custom-block.
2552
+						apiVersion: <?php echo isset($this->options['block-api-version']) ? absint($this->options['block-api-version']) : 2; ?>,
2553
+						title: '<?php echo addslashes($this->options['name']); ?>', // Block title.
2554
+						description: '<?php echo addslashes($this->options['widget_ops']['description'])?>', // Block title.
2555
+						icon: <?php echo $this->get_block_icon($this->options['block-icon']); ?>,//'<?php echo isset($this->options['block-icon']) ? esc_attr($this->options['block-icon']) : 'shield-alt'; ?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
2556 2556
 						supports: {
2557 2557
 							<?php
2558
-							if(!isset($this->options['block-supports']['renaming'])){
2558
+							if (!isset($this->options['block-supports']['renaming'])) {
2559 2559
 								$this->options['block-supports']['renaming'] = false;
2560 2560
 							}
2561
-							if ( isset( $this->options['block-supports'] ) ) {
2562
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2561
+							if (isset($this->options['block-supports'])) {
2562
+								echo $this->array_to_attributes($this->options['block-supports']);
2563 2563
 							}
2564 2564
 							?>
2565 2565
 						},
2566 2566
 						__experimentalLabel( attributes, { context } ) {
2567 2567
 							var visibility_html = attributes && attributes.visibility_conditions ? ' &#128065;' : '';
2568 2568
 							var metadata_name = attributes && attributes.metadata && attributes.metadata.name ? attributes.metadata.name : '';
2569
-							var label_name = <?php echo !empty($this->options['block-label']) ? $this->options['block-label'] : "'" . esc_attr( addslashes( $this->options['name'] ) ) . "'"; ?>;
2569
+							var label_name = <?php echo !empty($this->options['block-label']) ? $this->options['block-label'] : "'" . esc_attr(addslashes($this->options['name'])) . "'"; ?>;
2570 2570
 							return metadata_name ? metadata_name + visibility_html  : label_name + visibility_html;
2571 2571
 						},
2572
-						category: '<?php echo isset( $this->options['block-category'] ) ? esc_attr( $this->options['block-category'] ) : 'common';?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
2573
-						<?php if ( isset( $this->options['block-keywords'] ) ) {
2572
+						category: '<?php echo isset($this->options['block-category']) ? esc_attr($this->options['block-category']) : 'common'; ?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
2573
+						<?php if (isset($this->options['block-keywords'])) {
2574 2574
 						echo "keywords : " . $this->options['block-keywords'] . ",";
2575 2575
 						}
2576 2576
 
2577 2577
 
2578 2578
 						// block hover preview.
2579 2579
 						$example_args = array();
2580
-						if(!empty($this->arguments)){
2581
-							foreach($this->arguments as $key => $a_args){
2582
-								if(isset($a_args['example'])){
2580
+						if (!empty($this->arguments)) {
2581
+							foreach ($this->arguments as $key => $a_args) {
2582
+								if (isset($a_args['example'])) {
2583 2583
 									$example_args[$key] = $a_args['example'];
2584 2584
 								}
2585 2585
 							}
2586 2586
 						}
2587
-						$viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2587
+						$viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: ' . absint($this->options['example']['viewportWidth']) : '';
2588 2588
 						$example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2589
-						if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2589
+						if (isset($this->options['example']) && $this->options['example'] === false) {
2590 2590
 							// no preview if set to false
2591
-						}elseif( !empty( $example_args ) ){
2592
-							echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2593
-						}elseif( !empty( $this->options['example'] ) ){
2591
+						}elseif (!empty($example_args)) {
2592
+							echo "example : {attributes:{" . $this->array_to_attributes($example_args) . "},$viewport_width},";
2593
+						}elseif (!empty($this->options['example'])) {
2594 2594
 							unset($this->options['example']['viewportWidth']);
2595 2595
 							unset($this->options['example']['innerBlocks']);
2596
-							$example_atts = $this->array_to_attributes( $this->options['example'] );
2596
+							$example_atts = $this->array_to_attributes($this->options['example']);
2597 2597
 							$example_parts = array();
2598
-							if($example_atts){
2599
-								$example_parts[] = rtrim($example_atts,",");
2598
+							if ($example_atts) {
2599
+								$example_parts[] = rtrim($example_atts, ",");
2600 2600
 							}
2601
-							if($viewport_width){
2601
+							if ($viewport_width) {
2602 2602
 								$example_parts[] = $viewport_width;
2603 2603
 							}
2604
-							if($example_inner_blocks){
2604
+							if ($example_inner_blocks) {
2605 2605
 								$example_parts[] = $example_inner_blocks;
2606 2606
 							}
2607
-							if(!empty($example_parts)){
2608
-								echo "example : {".implode(',', $example_parts)."},";
2607
+							if (!empty($example_parts)) {
2608
+								echo "example : {" . implode(',', $example_parts) . "},";
2609 2609
 							}
2610
-						}else{
2610
+						} else {
2611 2611
 							echo 'example : {viewportWidth: 500},';
2612 2612
 						}
2613 2613
 
2614 2614
 
2615 2615
 
2616 2616
 						// limit to parent
2617
-						if( !empty( $this->options['parent'] ) ){
2618
-							echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2617
+						if (!empty($this->options['parent'])) {
2618
+							echo "parent : " . wp_json_encode($this->options['parent']) . ",";
2619 2619
 						}
2620 2620
 
2621 2621
 						// limit allowed blocks
2622
-						if( !empty( $this->options['allowed-blocks'] ) ){
2623
-							echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2622
+						if (!empty($this->options['allowed-blocks'])) {
2623
+							echo "allowedBlocks : " . wp_json_encode($this->options['allowed-blocks']) . ",";
2624 2624
 						}
2625 2625
 
2626 2626
 						// maybe set no_wrap
2627
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2628
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2627
+						$no_wrap = isset($this->options['no_wrap']) && $this->options['no_wrap'] ? true : false;
2628
+						if (isset($this->arguments['no_wrap']) && $this->arguments['no_wrap']) {
2629 2629
 							$no_wrap = true;
2630 2630
 						}
2631
-						if ( $no_wrap ) {
2631
+						if ($no_wrap) {
2632 2632
 							$this->options['block-wrap'] = '';
2633 2633
 						}
2634 2634
 
@@ -2645,7 +2645,7 @@  discard block
 block discarded – undo
2645 2645
 
2646 2646
 							echo "attributes : {";
2647 2647
 
2648
-							if ( $show_advanced ) {
2648
+							if ($show_advanced) {
2649 2649
 								echo "show_advanced: {";
2650 2650
 								echo "	type: 'boolean',";
2651 2651
 								echo "  default: false,";
@@ -2653,57 +2653,57 @@  discard block
 block discarded – undo
2653 2653
 							}
2654 2654
 
2655 2655
 							// block wrap element
2656
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2656
+							if (!empty($this->options['block-wrap'])) { //@todo we should validate this?
2657 2657
 								echo "block_wrap: {";
2658 2658
 								echo "	type: 'string',";
2659
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2659
+								echo "  default: '" . esc_attr($this->options['block-wrap']) . "',";
2660 2660
 								echo "},";
2661 2661
 							}
2662 2662
 
2663 2663
 
2664
-							if ( ! empty( $this->arguments ) ) {
2664
+							if (!empty($this->arguments)) {
2665 2665
 
2666
-								foreach ( $this->arguments as $key => $args ) {
2666
+								foreach ($this->arguments as $key => $args) {
2667 2667
 
2668
-									if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2668
+									if ($args['type'] == 'image' || $args['type'] == 'images') {
2669 2669
 										$img_drag_drop = true;
2670 2670
 									}
2671 2671
 
2672 2672
 									// set if we should show alignment
2673
-									if ( $key == 'alignment' ) {
2673
+									if ($key == 'alignment') {
2674 2674
 										$show_alignment = true;
2675 2675
 									}
2676 2676
 
2677 2677
 									$extra = '';
2678 2678
 
2679
-									if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2679
+									if ($args['type'] == 'notice' || $args['type'] == 'tab') {
2680 2680
 										continue;
2681 2681
 									}
2682
-									elseif ( $args['type'] == 'checkbox' ) {
2682
+									elseif ($args['type'] == 'checkbox') {
2683 2683
 										$type    = 'boolean';
2684
-										$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2685
-									} elseif ( $args['type'] == 'number' ) {
2684
+										$default = isset($args['default']) && $args['default'] ? 'true' : 'false';
2685
+									} elseif ($args['type'] == 'number') {
2686 2686
 										$type    = 'number';
2687
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2688
-									} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2687
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2688
+									} elseif ($args['type'] == 'select' && !empty($args['multiple'])) {
2689 2689
 										$type = 'array';
2690
-										if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2691
-											$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2690
+										if (isset($args['default']) && is_array($args['default'])) {
2691
+											$default = !empty($args['default']) ? "['" . implode("','", $args['default']) . "']" : "[]";
2692 2692
 										} else {
2693
-											$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2693
+											$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2694 2694
 										}
2695
-									} elseif ( $args['type'] == 'tagselect' ) {
2695
+									} elseif ($args['type'] == 'tagselect') {
2696 2696
 										$type    = 'array';
2697
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2698
-									} elseif ( $args['type'] == 'multiselect' ) {
2697
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2698
+									} elseif ($args['type'] == 'multiselect') {
2699 2699
 										$type    = 'array';
2700
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2701
-									} elseif ( $args['type'] == 'image_xy' ) {
2700
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2701
+									} elseif ($args['type'] == 'image_xy') {
2702 2702
 										$type    = 'object';
2703
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2704
-									} elseif ( $args['type'] == 'image' ) {
2703
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2704
+									} elseif ($args['type'] == 'image') {
2705 2705
 										$type    = 'string';
2706
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2706
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2707 2707
 
2708 2708
 										// add a field for ID
2709 2709
 	//                                    echo $key . "_id : {";
@@ -2715,7 +2715,7 @@  discard block
 block discarded – undo
2715 2715
 
2716 2716
 									} else {
2717 2717
 										$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2718
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2718
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2719 2719
 
2720 2720
 									}
2721 2721
 									echo $key . " : {";
@@ -2728,7 +2728,7 @@  discard block
 block discarded – undo
2728 2728
 							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2729 2729
 							echo "sd_shortcode : {type : 'string',default: ''},";
2730 2730
 
2731
-							if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2731
+							if (!empty($this->options['nested-block']) || !empty($this->arguments['html'])) {
2732 2732
 								echo "sd_shortcode_close : {type : 'string',default: ''},";
2733 2733
 							}
2734 2734
 
@@ -2747,7 +2747,7 @@  discard block
 block discarded – undo
2747 2747
 
2748 2748
 <?php
2749 2749
 // only include the drag/drop functions if required.
2750
-if( $img_drag_drop ){
2750
+if ($img_drag_drop) {
2751 2751
 
2752 2752
 ?>
2753 2753
 
@@ -2813,9 +2813,9 @@  discard block
 block discarded – undo
2813 2813
 							}
2814 2814
 
2815 2815
 							<?php
2816
-							if(!empty($this->options['block-edit-raw'])) {
2816
+							if (!empty($this->options['block-edit-raw'])) {
2817 2817
 								echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2818
-							}else{
2818
+							} else {
2819 2819
 							?>
2820 2820
 
2821 2821
 function hasSelectedInnerBlock(props) {
@@ -2839,7 +2839,7 @@  discard block
 block discarded – undo
2839 2839
 	var $value = '';
2840 2840
 	<?php
2841 2841
 	// if we have a post_type and a category then link them
2842
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2842
+	if (isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked'])) {
2843 2843
 	?>
2844 2844
 	if(typeof(prev_attributes[props.clientId]) != 'undefined' && selectedBlock && selectedBlock.clientId === props.clientId){
2845 2845
 		$pt = props.attributes.post_type;
@@ -2854,9 +2854,9 @@  discard block
 block discarded – undo
2854 2854
 		}
2855 2855
 <?php
2856 2856
 	$cat_path = '';
2857
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2858
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2859
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2857
+	if (!empty($this->arguments['post_type']['onchange_rest']['path'])) {
2858
+		$cat_path = esc_js(strip_tags($this->arguments['post_type']['onchange_rest']['path']));
2859
+		$cat_path = str_replace(array('&quot;', '&#039;'), array('"', "'"), $cat_path);
2860 2860
 	}
2861 2861
 ?>
2862 2862
 		/* taxonomies */
@@ -2864,15 +2864,15 @@  discard block
 block discarded – undo
2864 2864
 			if (!window.gdCPTCats) {
2865 2865
 				window.gdCPTCats = [];
2866 2866
 			}
2867
-			var gdCatPath = "<?php echo ( ! empty( $cat_path ) ? $cat_path : "/wp/v2/" + $value + "/categories/?per_page=100" ); ?>";
2867
+			var gdCatPath = "<?php echo (!empty($cat_path) ? $cat_path : "/wp/v2/" +$value + "/categories/?per_page=100"); ?>";
2868 2868
 			if (window.gdCPTCats[gdCatPath]) {
2869 2869
 				terms = window.gdCPTCats[gdCatPath];
2870
-				while (taxonomies_<?php echo str_replace("-","_", $this->id);?>.length) {
2871
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.pop();
2870
+				while (taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2871
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2872 2872
 				}
2873
-				taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: "All", value: 0});
2873
+				taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: "All", value: 0});
2874 2874
 				jQuery.each( terms, function( key, val ) {
2875
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: val.name, value: val.id});
2875
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val.name, value: val.id});
2876 2876
 				});
2877 2877
 
2878 2878
 				/* Setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options. */
@@ -2882,12 +2882,12 @@  discard block
 block discarded – undo
2882 2882
 			} else {
2883 2883
 				wp.apiFetch({path: gdCatPath}).then(terms => {
2884 2884
 					window.gdCPTCats[gdCatPath] = terms;
2885
-					while (taxonomies_<?php echo str_replace("-","_", $this->id);?>.length) {
2886
-						taxonomies_<?php echo str_replace("-","_", $this->id);?>.pop();
2885
+					while (taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2886
+						taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2887 2887
 					}
2888
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: "All", value: 0});
2888
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: "All", value: 0});
2889 2889
 					jQuery.each( terms, function( key, val ) {
2890
-						taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: val.name, value: val.id});
2890
+						taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val.name, value: val.id});
2891 2891
 					});
2892 2892
 
2893 2893
 					/* Setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options. */
@@ -2895,7 +2895,7 @@  discard block
 block discarded – undo
2895 2895
 					props.setAttributes({category: [0] });
2896 2896
 					props.setAttributes({category: $old_cat_value });
2897 2897
 
2898
-					return taxonomies_<?php echo str_replace("-","_", $this->id);?>;
2898
+					return taxonomies_<?php echo str_replace("-", "_", $this->id); ?>;
2899 2899
 				});
2900 2900
 			}
2901 2901
 		}
@@ -2907,12 +2907,12 @@  discard block
 block discarded – undo
2907 2907
 			}
2908 2908
 			if (window.gdCPTSort[$pt]) {
2909 2909
 				response = window.gdCPTSort[$pt];
2910
-				while (sort_by_<?php echo str_replace("-","_", $this->id);?>.length) {
2911
-					sort_by_<?php echo str_replace("-","_", $this->id);?>.pop();
2910
+				while (sort_by_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2911
+					sort_by_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2912 2912
 				}
2913 2913
 
2914 2914
 				jQuery.each( response, function( key, val ) {
2915
-					sort_by_<?php echo str_replace("-","_", $this->id);?>.push({label: val, value: key});
2915
+					sort_by_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val, value: key});
2916 2916
 				});
2917 2917
 
2918 2918
 				// setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options.
@@ -2927,12 +2927,12 @@  discard block
 block discarded – undo
2927 2927
 				jQuery.post(ajaxurl, data, function(response) {
2928 2928
 					response = JSON.parse(response);
2929 2929
 					window.gdCPTSort[$pt] = response;
2930
-					while (sort_by_<?php echo str_replace("-","_", $this->id);?>.length) {
2931
-						sort_by_<?php echo str_replace("-","_", $this->id);?>.pop();
2930
+					while (sort_by_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2931
+						sort_by_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2932 2932
 					}
2933 2933
 
2934 2934
 					jQuery.each( response, function( key, val ) {
2935
-						sort_by_<?php echo str_replace("-","_", $this->id);?>.push({label: val, value: key});
2935
+						sort_by_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val, value: key});
2936 2936
 					});
2937 2937
 
2938 2938
 					// setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options.
@@ -2940,7 +2940,7 @@  discard block
 block discarded – undo
2940 2940
 					props.setAttributes({sort_by: [0] });
2941 2941
 					props.setAttributes({sort_by: $old_sort_by_value });
2942 2942
 
2943
-					return sort_by_<?php echo str_replace("-","_", $this->id);?>;
2943
+					return sort_by_<?php echo str_replace("-", "_", $this->id); ?>;
2944 2944
 				});
2945 2945
 			}
2946 2946
 		}
@@ -2948,9 +2948,9 @@  discard block
 block discarded – undo
2948 2948
 	<?php } ?>
2949 2949
 <?php
2950 2950
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2951
-if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2951
+if (!empty($current_screen->base) && $current_screen->base === 'widgets') {
2952 2952
 	echo 'const { deviceType } = "";';
2953
-}else{
2953
+} else {
2954 2954
 ?>
2955 2955
 /** Get device type const. */
2956 2956
 const wpVersion = '<?php global $wp_version; echo esc_attr($wp_version); ?>';
@@ -3009,13 +3009,13 @@  discard block
 block discarded – undo
3009 3009
 
3010 3010
 									var data = {
3011 3011
 										'action': 'super_duper_output_shortcode',
3012
-										'shortcode': '<?php echo $this->options['base_id'];?>',
3012
+										'shortcode': '<?php echo $this->options['base_id']; ?>',
3013 3013
 										'attributes': props.attributes,
3014 3014
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
3015
-										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
3015
+										'post_id': <?php global $post; if (isset($post->ID)) {
3016 3016
 										echo $post->ID;
3017
-									}else{echo '0';}?>,
3018
-										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
3017
+									} else {echo '0'; }?>,
3018
+										'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_output_shortcode'); ?>'
3019 3019
 									};
3020 3020
 
3021 3021
 									jQuery.post(ajaxurl, data, function (response) {
@@ -3024,17 +3024,17 @@  discard block
 block discarded – undo
3024 3024
 
3025 3025
 										// if the content is empty then we place some placeholder text
3026 3026
 										if (env == '') {
3027
-											env = "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" + "<?php _e( 'Placeholder for:', 'ayecode-connect' );?> " + props.name + "</div>";
3027
+											env = "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" + "<?php _e('Placeholder for:', 'ayecode-connect'); ?> " + props.name + "</div>";
3028 3028
 										}
3029 3029
 
3030 3030
 										 <?php
3031
-										if(!empty($this->options['nested-block'])){
3031
+										if (!empty($this->options['nested-block'])) {
3032 3032
 											?>
3033 3033
 											// props.setAttributes({content: env});
3034 3034
 										is_fetching = false;
3035 3035
 										prev_attributes[props.clientId] = props.attributes;
3036 3036
 											 <?php
3037
-										}else{
3037
+										} else {
3038 3038
 										?>
3039 3039
 										props.setAttributes({content: env});
3040 3040
 										is_fetching = false;
@@ -3060,38 +3060,38 @@  discard block
 block discarded – undo
3060 3060
 							}
3061 3061
 
3062 3062
 							<?php
3063
-							if(!empty($this->options['block-edit-js'])) {
3064
-								echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
3063
+							if (!empty($this->options['block-edit-js'])) {
3064
+								echo  $this->options['block-edit-js']; // strings have to be in single quotes, may cause issues
3065 3065
 							}
3066 3066
 
3067 3067
 
3068 3068
 
3069 3069
 
3070
-							if(empty($this->options['block-save-return'])){
3070
+							if (empty($this->options['block-save-return'])) {
3071 3071
 							?>
3072 3072
 								///////////////////////////////////////////////////////////////////////
3073 3073
 
3074 3074
 									 // build the shortcode.
3075
-								shortcode = "[<?php echo $this->options['base_id'];?>";
3075
+								shortcode = "[<?php echo $this->options['base_id']; ?>";
3076 3076
 								<?php
3077 3077
 
3078
-								if(! empty( $this->arguments )){
3078
+								if (!empty($this->arguments)) {
3079 3079
 
3080
-								foreach($this->arguments as $key => $args){
3080
+								foreach ($this->arguments as $key => $args) {
3081 3081
 								   // if($args['type']=='tabs'){continue;}
3082 3082
 
3083 3083
 								   // don't add metadata arguments
3084
-								   if (substr($key, 0, 9 ) === 'metadata_') {
3084
+								   if (substr($key, 0, 9) === 'metadata_') {
3085 3085
 									   continue;
3086 3086
 								   }
3087 3087
 								?>
3088
-								if (props.attributes.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3089
-									if ('<?php echo esc_attr( $key );?>' == 'html') {
3090
-									} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
3091
-										shortcode += props.attributes.<?php echo esc_attr( $key );?>.length && ( props.attributes.<?php echo esc_attr( $key );?>.x.length || props.attributes.<?php echo esc_attr( $key );?>.y.length ) ? " <?php echo esc_attr( $key );?>='{x:" + props.attributes.<?php echo esc_attr( $key );?>.x + ",y:"+props.attributes.<?php echo esc_attr( $key );?>.y +"}' " : "";
3088
+								if (props.attributes.hasOwnProperty("<?php echo esc_attr($key); ?>")) {
3089
+									if ('<?php echo esc_attr($key); ?>' == 'html') {
3090
+									} else if ('<?php echo esc_attr($args['type']); ?>' == 'image_xy') {
3091
+										shortcode += props.attributes.<?php echo esc_attr($key); ?>.length && ( props.attributes.<?php echo esc_attr($key); ?>.x.length || props.attributes.<?php echo esc_attr($key); ?>.y.length ) ? " <?php echo esc_attr($key); ?>='{x:" + props.attributes.<?php echo esc_attr($key); ?>.x + ",y:"+props.attributes.<?php echo esc_attr($key); ?>.y +"}' " : "";
3092 3092
 									} else {
3093
-										//shortcode += props.attributes.<?php echo esc_attr( $key );?>.length ? " <?php echo esc_attr( $key );?>='" + props.attributes.<?php echo esc_attr( $key );?>.toString().replace('\'','&#39;') + "' " : "";
3094
-										shortcode +=  " <?php echo esc_attr( $key );?>='" + props.attributes.<?php echo esc_attr( $key );?>.toString().replace('\'','&#39;') + "' ";
3093
+										//shortcode += props.attributes.<?php echo esc_attr($key); ?>.length ? " <?php echo esc_attr($key); ?>='" + props.attributes.<?php echo esc_attr($key); ?>.toString().replace('\'','&#39;') + "' " : "";
3094
+										shortcode +=  " <?php echo esc_attr($key); ?>='" + props.attributes.<?php echo esc_attr($key); ?>.toString().replace('\'','&#39;') + "' ";
3095 3095
 									}
3096 3096
 								}
3097 3097
 								<?php
@@ -3110,8 +3110,8 @@  discard block
 block discarded – undo
3110 3110
 
3111 3111
 
3112 3112
 									<?php
3113
-									if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3114
-										echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3113
+									if (!empty($this->options['nested-block']) || !empty($this->arguments['html'])) {
3114
+										echo "props.setAttributes({sd_shortcode_close: '[/" . esc_attr($this->options['base_id']) . "]'});";
3115 3115
 									}
3116 3116
 									?>
3117 3117
 								}
@@ -3126,7 +3126,7 @@  discard block
 block discarded – undo
3126 3126
 
3127 3127
 								el(wp.blockEditor.BlockControls, {key: 'controls'},
3128 3128
 
3129
-									<?php if($show_alignment){?>
3129
+									<?php if ($show_alignment) {?>
3130 3130
 									el(
3131 3131
 										wp.blockEditor.AlignmentToolbar,
3132 3132
 										{
@@ -3144,9 +3144,9 @@  discard block
 block discarded – undo
3144 3144
 
3145 3145
 									<?php
3146 3146
 
3147
-									if(! empty( $this->arguments )){
3147
+									if (!empty($this->arguments)) {
3148 3148
 
3149
-									if ( $show_advanced ) {
3149
+									if ($show_advanced) {
3150 3150
 									?>
3151 3151
 									el('div', {
3152 3152
 											style: {'padding-left': '16px','padding-right': '16px'}
@@ -3166,42 +3166,42 @@  discard block
 block discarded – undo
3166 3166
 									<?php
3167 3167
 									}
3168 3168
 
3169
-									$arguments = $this->group_arguments( $this->arguments );
3170
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3169
+									$arguments = $this->group_arguments($this->arguments);
3170
+									$block_group_tabs = !empty($this->options['block_group_tabs']) ? $this->group_block_tabs($this->options['block_group_tabs'], $arguments) : array();
3171 3171
 
3172 3172
 									// Do we have sections?
3173 3173
 									$has_sections = $arguments == $this->arguments ? false : true;
3174 3174
 
3175
-									if($has_sections){
3175
+									if ($has_sections) {
3176 3176
 									$panel_count = 0;
3177 3177
 									$open_tab = '';
3178 3178
 
3179 3179
 									$open_tab_groups = array();
3180 3180
 									$used_tabs = array();
3181 3181
 
3182
-									foreach ( $arguments as $key => $args ) {
3182
+									foreach ($arguments as $key => $args) {
3183 3183
 										$close_tab = false;
3184 3184
 										$close_tabs = false;
3185 3185
 
3186
-										 if ( ! empty( $block_group_tabs ) ) {
3187
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3188
-												if ( in_array( $key, $tab_args['groups'] ) ) {
3186
+										 if (!empty($block_group_tabs)) {
3187
+											foreach ($block_group_tabs as $tab_name => $tab_args) {
3188
+												if (in_array($key, $tab_args['groups'])) {
3189 3189
 													$open_tab_groups[] = $key;
3190 3190
 
3191
-													if ( $open_tab != $tab_name ) {
3191
+													if ($open_tab != $tab_name) {
3192 3192
 														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3193 3193
 														$tab_args['tab']['open'] = true;
3194 3194
 
3195
-														$this->block_tab_start( '', $tab_args );
3195
+														$this->block_tab_start('', $tab_args);
3196 3196
 														$open_tab = $tab_name;
3197 3197
 														$used_tabs[] = $tab_name;
3198 3198
 													}
3199 3199
 
3200
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3200
+													if ($open_tab_groups == $tab_args['groups']) {
3201 3201
 														$close_tab = true;
3202 3202
 														$open_tab_groups = array();
3203 3203
 
3204
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3204
+														if ($used_tabs == array_keys($block_group_tabs)) {
3205 3205
 															$close_tabs = true;
3206 3206
 														}
3207 3207
 													}
@@ -3210,27 +3210,27 @@  discard block
 block discarded – undo
3210 3210
 										}
3211 3211
 										?>
3212 3212
 										el(wp.components.PanelBody, {
3213
-												title: '<?php esc_attr_e( $key ); ?>',
3214
-												initialOpen: <?php if ( $panel_count ) {
3213
+												title: '<?php esc_attr_e($key); ?>',
3214
+												initialOpen: <?php if ($panel_count) {
3215 3215
 												echo "false";
3216 3216
 											} else {
3217 3217
 												echo "true";
3218 3218
 											}?>
3219 3219
 											},
3220 3220
 											<?php
3221
-											foreach ( $args as $k => $a ) {
3222
-												$this->block_tab_start( $k, $a );
3223
-												$this->block_row_start( $k, $a );
3224
-												$this->build_block_arguments( $k, $a );
3225
-												$this->block_row_end( $k, $a );
3226
-												$this->block_tab_end( $k, $a );
3221
+											foreach ($args as $k => $a) {
3222
+												$this->block_tab_start($k, $a);
3223
+												$this->block_row_start($k, $a);
3224
+												$this->build_block_arguments($k, $a);
3225
+												$this->block_row_end($k, $a);
3226
+												$this->block_tab_end($k, $a);
3227 3227
 											}
3228 3228
 											?>
3229 3229
 										),
3230 3230
 										<?php
3231
-										$panel_count ++;
3231
+										$panel_count++;
3232 3232
 
3233
-										if($close_tab || $close_tabs){
3233
+										if ($close_tab || $close_tabs) {
3234 3234
 											$tab_args = array(
3235 3235
 												'tab'	=> array(
3236 3236
 													'tabs_close' => $close_tabs,
@@ -3238,24 +3238,24 @@  discard block
 block discarded – undo
3238 3238
 												)
3239 3239
 
3240 3240
 											);
3241
-											$this->block_tab_end( '', $tab_args );
3241
+											$this->block_tab_end('', $tab_args);
3242 3242
 //											echo '###close'; print_r($tab_args);
3243 3243
 											$panel_count = 0;
3244 3244
 										}
3245 3245
 //
3246 3246
 
3247 3247
 									}
3248
-									}else {
3248
+									} else {
3249 3249
 									?>
3250 3250
 									el(wp.components.PanelBody, {
3251
-											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3251
+											title: '<?php esc_attr_e("Settings", 'ayecode-connect'); ?>',
3252 3252
 											initialOpen: true
3253 3253
 										},
3254 3254
 										<?php
3255
-										foreach ( $this->arguments as $key => $args ) {
3256
-											$this->block_row_start( $key, $args );
3257
-											$this->build_block_arguments( $key, $args );
3258
-											$this->block_row_end( $key, $args );
3255
+										foreach ($this->arguments as $key => $args) {
3256
+											$this->block_row_start($key, $args);
3257
+											$this->build_block_arguments($key, $args);
3258
+											$this->block_row_end($key, $args);
3259 3259
 										}
3260 3260
 										?>
3261 3261
 									),
@@ -3269,11 +3269,11 @@  discard block
 block discarded – undo
3269 3269
 
3270 3270
 								<?php
3271 3271
 								// If the user sets block-output array then build it
3272
-								if ( ! empty( $this->options['block-output'] ) ) {
3273
-								$this->block_element( $this->options['block-output'] );
3274
-							}elseif(!empty($this->options['block-edit-return'])){
3272
+								if (!empty($this->options['block-output'])) {
3273
+								$this->block_element($this->options['block-output']);
3274
+							}elseif (!empty($this->options['block-edit-return'])) {
3275 3275
 								   echo $this->options['block-edit-return'];
3276
-							}else{
3276
+							} else {
3277 3277
 								// if no block-output is set then we try and get the shortcode html output via ajax.
3278 3278
 								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3279 3279
 								?>
@@ -3300,27 +3300,27 @@  discard block
 block discarded – undo
3300 3300
 							var align = '';
3301 3301
 
3302 3302
 							// build the shortcode.
3303
-							var content = "[<?php echo $this->options['base_id'];?>";
3303
+							var content = "[<?php echo $this->options['base_id']; ?>";
3304 3304
 							$html = '';
3305 3305
 							<?php
3306 3306
 
3307
-							if(! empty( $this->arguments )){
3307
+							if (!empty($this->arguments)) {
3308 3308
 
3309
-							foreach($this->arguments as $key => $args){
3309
+							foreach ($this->arguments as $key => $args) {
3310 3310
 							   // if($args['type']=='tabs'){continue;}
3311 3311
 
3312 3312
 							   // don't add metadata arguments
3313
-							   if (substr($key, 0, 9 ) === 'metadata_') {
3313
+							   if (substr($key, 0, 9) === 'metadata_') {
3314 3314
 								   continue;
3315 3315
 							   }
3316 3316
 							?>
3317
-							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3318
-								if ('<?php echo esc_attr( $key );?>' == 'html') {
3319
-									$html = attr.<?php echo esc_attr( $key );?>;
3320
-								} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
3321
-									content += " <?php echo esc_attr( $key );?>='{x:" + attr.<?php echo esc_attr( $key );?>.x + ",y:"+attr.<?php echo esc_attr( $key );?>.y +"}' ";
3317
+							if (attr.hasOwnProperty("<?php echo esc_attr($key); ?>")) {
3318
+								if ('<?php echo esc_attr($key); ?>' == 'html') {
3319
+									$html = attr.<?php echo esc_attr($key); ?>;
3320
+								} else if ('<?php echo esc_attr($args['type']); ?>' == 'image_xy') {
3321
+									content += " <?php echo esc_attr($key); ?>='{x:" + attr.<?php echo esc_attr($key); ?>.x + ",y:"+attr.<?php echo esc_attr($key); ?>.y +"}' ";
3322 3322
 								} else {
3323
-									content += " <?php echo esc_attr( $key );?>='" + attr.<?php echo esc_attr( $key );?>.toString().replace('\'','&#39;') + "' ";
3323
+									content += " <?php echo esc_attr($key); ?>='" + attr.<?php echo esc_attr($key); ?>.toString().replace('\'','&#39;') + "' ";
3324 3324
 								}
3325 3325
 							}
3326 3326
 							<?php
@@ -3340,7 +3340,7 @@  discard block
 block discarded – undo
3340 3340
 							?>
3341 3341
 							// if has html element
3342 3342
 							if ($html) {
3343
-								//content += $html + "[/<?php echo $this->options['base_id'];?>]";
3343
+								//content += $html + "[/<?php echo $this->options['base_id']; ?>]";
3344 3344
 							}
3345 3345
 
3346 3346
 							// @todo should we add inline style here or just css classes?
@@ -3370,7 +3370,7 @@  discard block
 block discarded – undo
3370 3370
 //                                <x?php
3371 3371
 //							}else
3372 3372
 
3373
-							if(!empty($this->options['block-output'])){
3373
+							if (!empty($this->options['block-output'])) {
3374 3374
 //                               echo "return";
3375 3375
 //                               $this->block_element( $this->options['block-output'], true );
3376 3376
 //                               echo ";";
@@ -3380,30 +3380,30 @@  discard block
 block discarded – undo
3380 3380
 								   '',
3381 3381
 								   {},
3382 3382
 								  // el('', {dangerouslySetInnerHTML: {__html: content}}),
3383
-								   <?php $this->block_element( $this->options['block-output'], true ); ?>
3384
-								  // el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3383
+								   <?php $this->block_element($this->options['block-output'], true); ?>
3384
+								  // el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id']; ?>]"}})
3385 3385
 							   );
3386 3386
 								<?php
3387 3387
 
3388
-							}elseif(!empty($this->options['block-save-return'])){
3388
+							}elseif (!empty($this->options['block-save-return'])) {
3389 3389
 								   echo 'return ' . $this->options['block-save-return'];
3390
-							}elseif(!empty($this->options['nested-block'])){
3390
+							}elseif (!empty($this->options['nested-block'])) {
3391 3391
 								?>
3392 3392
 							  return el(
3393 3393
 								   '',
3394 3394
 								   {},
3395 3395
 								   el('', {dangerouslySetInnerHTML: {__html: content+"\n"}}),
3396 3396
 								   InnerBlocks.Content ? el( InnerBlocks.Content ) : '', // @todo i think we need a comma here
3397
-								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3397
+								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id']; ?>]"}})
3398 3398
 							   );
3399 3399
 								<?php
3400
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3401
-								echo "return ". $this->options['block-edit-return'].";";
3402
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3400
+							}elseif (!empty($this->options['block-save-return'])) {
3401
+								echo "return " . $this->options['block-edit-return'] . ";";
3402
+							}elseif (isset($this->options['block-wrap']) && $this->options['block-wrap'] == '') {
3403 3403
 							?>
3404 3404
 							return content;
3405 3405
 							<?php
3406
-							}else{
3406
+							} else {
3407 3407
 							?>
3408 3408
 							var block_wrap = 'div';
3409 3409
 							if (attr.hasOwnProperty("block_wrap")) {
@@ -3432,48 +3432,48 @@  discard block
 block discarded – undo
3432 3432
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3433 3433
 			 */
3434 3434
 
3435
-			return str_replace( array(
3435
+			return str_replace(array(
3436 3436
 				'<script>',
3437 3437
 				'</script>'
3438
-			), '', $output );
3438
+			), '', $output);
3439 3439
 		}
3440 3440
 
3441 3441
 
3442 3442
 
3443
-		public function block_row_start($key, $args){
3443
+		public function block_row_start($key, $args) {
3444 3444
 
3445 3445
 			// check for row
3446
-			if(!empty($args['row'])){
3446
+			if (!empty($args['row'])) {
3447 3447
 
3448
-				if(!empty($args['row']['open'])){
3448
+				if (!empty($args['row']['open'])) {
3449 3449
 
3450 3450
 				// element require
3451
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3452
-				$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3453
-				$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3451
+				$element_require = !empty($args['element_require']) ? $this->block_props_replace($args['element_require'], true) . " && " : "";
3452
+				$device_type = !empty($args['device_type']) ? esc_attr($args['device_type']) : '';
3453
+				$device_type_require = !empty($args['device_type']) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3454 3454
 				$device_type_icon = '';
3455
-				if($device_type=='Desktop'){
3455
+				if ($device_type == 'Desktop') {
3456 3456
 					$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3457
-				}elseif($device_type=='Tablet'){
3457
+				}elseif ($device_type == 'Tablet') {
3458 3458
 					$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3459
-				}elseif($device_type=='Mobile'){
3459
+				}elseif ($device_type == 'Mobile') {
3460 3460
 					$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3461 3461
 				}
3462 3462
 				echo $element_require;
3463 3463
 				echo $device_type_require;
3464 3464
 
3465
-					if(false){?><script><?php }?>
3465
+					if (false) {?><script><?php }?>
3466 3466
 						el('div', {
3467 3467
 								className: 'bsui components-base-control',
3468 3468
 							},
3469
-							<?php if(!empty($args['row']['title'])){ ?>
3469
+							<?php if (!empty($args['row']['title'])) { ?>
3470 3470
 							el('label', {
3471 3471
 									className: 'components-base-control__label position-relative',
3472 3472
 									style: {width:"100%"}
3473 3473
 								},
3474
-								el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['row']['title'] ) ?>'}}),
3475
-								<?php if($device_type_icon){ ?>
3476
-									deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})
3474
+								el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes($args['row']['title']) ?>'}}),
3475
+								<?php if ($device_type_icon) { ?>
3476
+									deviceType == '<?php echo $device_type; ?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})
3477 3477
 								<?php
3478 3478
 								}
3479 3479
 								?>
@@ -3481,17 +3481,17 @@  discard block
 block discarded – undo
3481 3481
 
3482 3482
 							),
3483 3483
 							<?php }?>
3484
-							<?php if(!empty($args['row']['desc'])){ ?>
3484
+							<?php if (!empty($args['row']['desc'])) { ?>
3485 3485
 							el('p', {
3486 3486
 									className: 'components-base-control__help mb-0',
3487 3487
 								},
3488
-								'<?php echo addslashes( $args['row']['desc'] ); ?>'
3488
+								'<?php echo addslashes($args['row']['desc']); ?>'
3489 3489
 							),
3490 3490
 							<?php }?>
3491 3491
 							el(
3492 3492
 								'div',
3493 3493
 								{
3494
-									className: 'row mb-n2 <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>',
3494
+									className: 'row mb-n2 <?php if (!empty($args['row']['class'])) { echo esc_attr($args['row']['class']); } ?>',
3495 3495
 								},
3496 3496
 								el(
3497 3497
 									'div',
@@ -3500,36 +3500,36 @@  discard block
 block discarded – undo
3500 3500
 									},
3501 3501
 
3502 3502
 					<?php
3503
-					if(false){?></script><?php }
3504
-				}elseif(!empty($args['row']['close'])){
3505
-					if(false){?><script><?php }?>
3503
+					if (false) {?></script><?php }
3504
+				}elseif (!empty($args['row']['close'])) {
3505
+					if (false) {?><script><?php }?>
3506 3506
 						el(
3507 3507
 							'div',
3508 3508
 							{
3509 3509
 								className: 'col pl-0 ps-0',
3510 3510
 							},
3511 3511
 					<?php
3512
-					if(false){?></script><?php }
3513
-				}else{
3514
-					if(false){?><script><?php }?>
3512
+					if (false) {?></script><?php }
3513
+				} else {
3514
+					if (false) {?><script><?php }?>
3515 3515
 						el(
3516 3516
 							'div',
3517 3517
 							{
3518 3518
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3519 3519
 							},
3520 3520
 					<?php
3521
-					if(false){?></script><?php }
3521
+					if (false) {?></script><?php }
3522 3522
 				}
3523 3523
 
3524 3524
 			}
3525 3525
 
3526 3526
 		}
3527 3527
 
3528
-		public function block_row_end($key, $args){
3528
+		public function block_row_end($key, $args) {
3529 3529
 
3530
-			if(!empty($args['row'])){
3530
+			if (!empty($args['row'])) {
3531 3531
 				// maybe close
3532
-				if(!empty($args['row']['close'])){
3532
+				if (!empty($args['row']['close'])) {
3533 3533
 					echo "))";
3534 3534
 				}
3535 3535
 
@@ -3537,14 +3537,14 @@  discard block
 block discarded – undo
3537 3537
 			}
3538 3538
 		}
3539 3539
 
3540
-		public function block_tab_start($key, $args){
3540
+		public function block_tab_start($key, $args) {
3541 3541
 
3542 3542
 			// check for row
3543
-			if(!empty($args['tab'])){
3543
+			if (!empty($args['tab'])) {
3544 3544
 
3545
-				if(!empty($args['tab']['tabs_open'])){
3545
+				if (!empty($args['tab']['tabs_open'])) {
3546 3546
 
3547
-					if(false){?><script><?php }?>
3547
+					if (false) {?><script><?php }?>
3548 3548
 
3549 3549
 el('div',{className: 'bsui'},
3550 3550
 
@@ -3553,52 +3553,52 @@  discard block
 block discarded – undo
3553 3553
 									{
3554 3554
 										activeClass: 'is-active',
3555 3555
 										className: 'btn-groupx',
3556
-										initialTabName: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3556
+										initialTabName: '<?php echo addslashes(esc_attr($args['tab']['key'])); ?>',
3557 3557
 										tabs: [
3558 3558
 
3559 3559
 					<?php
3560
-					if(false){?></script><?php }
3560
+					if (false) {?></script><?php }
3561 3561
 				}
3562 3562
 
3563
-				if(!empty($args['tab']['open'])){
3563
+				if (!empty($args['tab']['open'])) {
3564 3564
 
3565
-					if(false){?><script><?php }?>
3565
+					if (false) {?><script><?php }?>
3566 3566
 							{
3567
-												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3568
-												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
3569
-												className: '<?php echo addslashes( esc_attr( $args['tab']['class']) ); ?>',
3570
-												content: el('div',{}, <?php if(!empty($args['tab']['desc'])){ ?>el('p', {
3567
+												name: '<?php echo addslashes(esc_attr($args['tab']['key'])); ?>',
3568
+												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes(esc_attr($args['tab']['title'])); ?>'}}),
3569
+												className: '<?php echo addslashes(esc_attr($args['tab']['class'])); ?>',
3570
+												content: el('div',{}, <?php if (!empty($args['tab']['desc'])) { ?>el('p', {
3571 3571
 									className: 'components-base-control__help mb-0',
3572
-									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3572
+									dangerouslySetInnerHTML: {__html:'<?php echo addslashes($args['tab']['desc']); ?>'}
3573 3573
 								}),<?php }
3574
-					if(false){?></script><?php }
3574
+					if (false) {?></script><?php }
3575 3575
 				}
3576 3576
 
3577 3577
 			}
3578 3578
 
3579 3579
 		}
3580 3580
 
3581
-		public function block_tab_end($key, $args){
3581
+		public function block_tab_end($key, $args) {
3582 3582
 
3583
-			if(!empty($args['tab'])){
3583
+			if (!empty($args['tab'])) {
3584 3584
 				// maybe close
3585
-				if(!empty($args['tab']['close'])){
3585
+				if (!empty($args['tab']['close'])) {
3586 3586
 					echo ")}, /* tab close */";
3587 3587
 				}
3588 3588
 
3589
-				if(!empty($args['tab']['tabs_close'])){
3590
-					if(false){?><script><?php }?>
3589
+				if (!empty($args['tab']['tabs_close'])) {
3590
+					if (false) {?><script><?php }?>
3591 3591
 						]}, ( tab ) => {
3592 3592
 								return tab.content;
3593 3593
 							}
3594 3594
 						)), /* tabs close */
3595
-					<?php if(false){ ?></script><?php }
3595
+					<?php if (false) { ?></script><?php }
3596 3596
 				}
3597 3597
 			}
3598 3598
 		}
3599 3599
 
3600
-		public function build_block_arguments( $key, $args ) {
3601
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3600
+		public function build_block_arguments($key, $args) {
3601
+			$custom_attributes = !empty($args['custom_attributes']) ? $this->array_to_attributes($args['custom_attributes']) : '';
3602 3602
 			$options           = '';
3603 3603
 			$extra             = '';
3604 3604
 			$require           = '';
@@ -3606,28 +3606,28 @@  discard block
 block discarded – undo
3606 3606
 			$after_elements	   = '';
3607 3607
 
3608 3608
 			// `content` is a protected and special argument
3609
-			if ( $key == 'content' ) {
3609
+			if ($key == 'content') {
3610 3610
 				return;
3611 3611
 			}
3612 3612
 
3613
-			$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3614
-			$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3613
+			$device_type = !empty($args['device_type']) ? esc_attr($args['device_type']) : '';
3614
+			$device_type_require = !empty($args['device_type']) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3615 3615
 			$device_type_icon = '';
3616
-			if($device_type=='Desktop'){
3616
+			if ($device_type == 'Desktop') {
3617 3617
 				$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3618
-			}elseif($device_type=='Tablet'){
3618
+			}elseif ($device_type == 'Tablet') {
3619 3619
 				$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3620
-			}elseif($device_type=='Mobile'){
3620
+			}elseif ($device_type == 'Mobile') {
3621 3621
 				$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3622 3622
 			}
3623 3623
 
3624 3624
 			// icon
3625 3625
 			$icon = '';
3626
-			if( !empty( $args['icon'] ) ){
3626
+			if (!empty($args['icon'])) {
3627 3627
 				$icon .= "el('div', {";
3628
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3628
+									$icon .= "dangerouslySetInnerHTML: {__html: '" . self::get_widget_icon(esc_attr($args['icon'])) . "'},";
3629 3629
 									$icon .= "className: 'text-center',";
3630
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3630
+									$icon .= "title: '" . addslashes($args['title']) . "',";
3631 3631
 								$icon .= "}),";
3632 3632
 
3633 3633
 				// blank title as its added to the icon.
@@ -3635,27 +3635,27 @@  discard block
 block discarded – undo
3635 3635
 			}
3636 3636
 
3637 3637
 			// require advanced
3638
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3638
+			$require_advanced = !empty($args['advanced']) ? "props.attributes.show_advanced && " : "";
3639 3639
 
3640 3640
 			// element require
3641
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3641
+			$element_require = !empty($args['element_require']) ? $this->block_props_replace($args['element_require'], true) . " && " : "";
3642 3642
 
3643 3643
 
3644 3644
 			$onchange  = "props.setAttributes({ $key: $key } )";
3645
-			$onchangecomplete  = "";
3645
+			$onchangecomplete = "";
3646 3646
 			$value     = "props.attributes.$key";
3647
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3648
-			if ( in_array( $args['type'], $text_type ) ) {
3647
+			$text_type = array('text', 'password', 'number', 'email', 'tel', 'url', 'colorx', 'range');
3648
+			if (in_array($args['type'], $text_type)) {
3649 3649
 				$type = 'TextControl';
3650 3650
 				// Save numbers as numbers and not strings
3651
-				if ( $args['type'] == 'number' ) {
3651
+				if ($args['type'] == 'number') {
3652 3652
 					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3653 3653
 				}
3654 3654
 
3655
-				if (substr($key, 0, 9 ) === 'metadata_') {
3656
-					$real_key = str_replace('metadata_','', $key );
3655
+				if (substr($key, 0, 9) === 'metadata_') {
3656
+					$real_key = str_replace('metadata_', '', $key);
3657 3657
 					$onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3658
-					$value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3658
+					$value = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3659 3659
 				}
3660 3660
 			}
3661 3661
 //			else if ( $args['type'] == 'popup' ) {
@@ -3675,12 +3675,12 @@  discard block
 block discarded – undo
3675 3675
 //
3676 3676
 //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3677 3677
 //			}
3678
-			else if ( $args['type'] == 'styleid' ) {
3678
+			else if ($args['type'] == 'styleid') {
3679 3679
 				$type = 'TextControl';
3680 3680
 				$args['type'] == 'text';
3681 3681
 				// Save numbers as numbers and not strings
3682
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3683
-			}else if ( $args['type'] == 'notice' ) {
3682
+				$value = "props.attributes.$key ? props.attributes.$key : ''";
3683
+			} else if ($args['type'] == 'notice') {
3684 3684
 
3685 3685
 				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3686 3686
 				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
@@ -3742,11 +3742,11 @@  discard block
 block discarded – undo
3742 3742
 							return;
3743 3743
 						}
3744 3744
 */
3745
-			elseif ( $args['type'] == 'color' ) {
3745
+			elseif ($args['type'] == 'color') {
3746 3746
 				$type = 'ColorPicker';
3747 3747
 				$onchange = "";
3748 3748
 				$extra = "color: $value,";
3749
-				if(!empty($args['disable_alpha'])){
3749
+				if (!empty($args['disable_alpha'])) {
3750 3750
 					$extra .= "disableAlpha: true,";
3751 3751
 				}
3752 3752
 				$onchangecomplete = "onChangeComplete: function($key) {
@@ -3755,7 +3755,7 @@  discard block
 block discarded – undo
3755 3755
 							$key: value
3756 3756
 						});
3757 3757
 					},";
3758
-			}elseif ( $args['type'] == 'gradient' ) {
3758
+			}elseif ($args['type'] == 'gradient') {
3759 3759
 				$type = 'GradientPicker';
3760 3760
 				$extra .= "gradients: [{
3761 3761
 			name: 'Vivid cyan blue to vivid purple',
@@ -3794,7 +3794,7 @@  discard block
 block discarded – undo
3794 3794
 			slug: 'cool-to-warm-spectrum',
3795 3795
 		}],";
3796 3796
 
3797
-			}elseif ( $args['type'] == 'image' ) {
3797
+			}elseif ($args['type'] == 'image') {
3798 3798
 //                print_r($args);
3799 3799
 
3800 3800
 				$img_preview = isset($args['focalpoint']) && !$args['focalpoint'] ? " props.attributes.$key && el('img', { src: props.attributes.$key,style: {maxWidth:'100%',background: '#ccc'}})," : " ( props.attributes.$key ||  props.attributes.{$key}_use_featured ) && el(wp.components.FocalPointPicker,{
@@ -3856,7 +3856,7 @@  discard block
 block discarded – undo
3856 3856
 				$onchange = "";
3857 3857
 
3858 3858
 				//$inside_elements = ",el('div',{},'file upload')";
3859
-			} else if ( $args['type'] == 'images' ) {
3859
+			} else if ($args['type'] == 'images') {
3860 3860
 				$img_preview = "props.attributes.$key && (function() {
3861 3861
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3862 3862
 	let images = [];
@@ -3869,7 +3869,7 @@  discard block
 block discarded – undo
3869 3869
 			el('i',{
3870 3870
 				className: 'fas fa-times-circle text-danger position-absolute  ml-n2 mt-n1 bg-white rounded-circle c-pointer',
3871 3871
 				onClick: function() {
3872
-					aui_confirm('".esc_attr__('Are you sure?')."', '".esc_attr__('Delete')."', '".esc_attr__('Cancel')."', true).then(function(confirmed) {
3872
+					aui_confirm('" . esc_attr__('Are you sure?') . "', '" . esc_attr__('Delete') . "', '" . esc_attr__('Cancel') . "', true).then(function(confirmed) {
3873 3873
 						if (confirmed) {
3874 3874
 							let new_uploads = JSON.parse('['+props.attributes.$key+']');
3875 3875
 							new_uploads.splice(index, 1);
@@ -3932,36 +3932,36 @@  discard block
 block discarded – undo
3932 3932
 
3933 3933
 				//$inside_elements = ",el('div',{},'file upload')";
3934 3934
 			}
3935
-			elseif ( $args['type'] == 'checkbox' ) {
3935
+			elseif ($args['type'] == 'checkbox') {
3936 3936
 				$type = 'CheckboxControl';
3937 3937
 				$extra .= "checked: props.attributes.$key,";
3938 3938
 				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3939
-			} elseif ( $args['type'] == 'textarea' ) {
3939
+			} elseif ($args['type'] == 'textarea') {
3940 3940
 				$type = 'TextareaControl';
3941 3941
 
3942
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3942
+			} elseif ($args['type'] == 'select' || $args['type'] == 'multiselect') {
3943 3943
 				$type = 'SelectControl';
3944 3944
 
3945
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3946
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3947
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3948
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3949
-				}else {
3945
+				if ($args['name'] == 'category' && !empty($args['post_type_linked'])) {
3946
+					$options .= "options: taxonomies_" . str_replace("-", "_", $this->id) . ",";
3947
+				}elseif ($args['name'] == 'sort_by' && !empty($args['post_type_linked'])) {
3948
+					$options .= "options: sort_by_" . str_replace("-", "_", $this->id) . ",";
3949
+				} else {
3950 3950
 
3951
-					if ( ! empty( $args['options'] ) ) {
3951
+					if (!empty($args['options'])) {
3952 3952
 						$options .= "options: [";
3953
-						foreach ( $args['options'] as $option_val => $option_label ) {
3954
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3953
+						foreach ($args['options'] as $option_val => $option_label) {
3954
+							$options .= "{ value: '" . esc_attr($option_val) . "', label: '" . esc_js(addslashes($option_label)) . "' },";
3955 3955
 						}
3956 3956
 						$options .= "],";
3957 3957
 					}
3958 3958
 				}
3959
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3959
+				if (isset($args['multiple']) && $args['multiple']) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3960 3960
 					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3961 3961
 				}
3962 3962
 
3963
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3964
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3963
+				if ($args['type'] == 'multiselect' || (isset($args['multiple']) && $args['multiple'])) {
3964
+					$after_elements .= "props.attributes.$key && el( wp.components.Button, {
3965 3965
 									  className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3966 3966
 									  style: {margin:'-8px 0 8px 0',display: 'block'},
3967 3967
 									  onClick: function(){
@@ -3973,7 +3973,7 @@  discard block
 block discarded – undo
3973 3973
 									'Clear'
3974 3974
 							),";
3975 3975
 				}
3976
-			} elseif ( $args['type'] == 'tagselect' ) {
3976
+			} elseif ($args['type'] == 'tagselect') {
3977 3977
 //				$type = 'FormTokenField';
3978 3978
 //
3979 3979
 //				if ( ! empty( $args['options'] ) ) {
@@ -4008,19 +4008,19 @@  discard block
 block discarded – undo
4008 4008
 //				$value     = "[]";
4009 4009
 //				$extra .= ' __experimentalExpandOnFocus: true,';
4010 4010
 
4011
-			} else if ( $args['type'] == 'alignment' ) {
4011
+			} else if ($args['type'] == 'alignment') {
4012 4012
 				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
4013
-			} else if ( $args['type'] == 'margins' ) {
4013
+			} else if ($args['type'] == 'margins') {
4014 4014
 
4015
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
4015
+			} else if ($args['type'] == 'visibility_conditions' && (function_exists('wp_is_block_theme') && wp_is_block_theme())) {
4016 4016
 				$type = 'TextControl';
4017 4017
 				$value = "(props.attributes.$key ? props.attributes.$key : '')";
4018 4018
 				$args['type'] = 'text';
4019 4019
 				$options .= 'disabled:true,';
4020
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
4021
-				$bsvc_body = $this->block_visibility_fields( $args );
4020
+				$bsvc_title = esc_attr(addslashes($args['title']));
4021
+				$bsvc_body = $this->block_visibility_fields($args);
4022 4022
 				// @TODO reset button
4023
-				$bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __( 'Reset', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __( 'Close', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __( 'Save Rules', 'ayecode-connect' ) . '</button>';
4023
+				$bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __('Reset', 'ayecode-connect') . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __('Close', 'ayecode-connect') . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __('Save Rules', 'ayecode-connect') . '</button>';
4024 4024
 				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
4025 4025
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
4026 4026
 						onClick: function() {
@@ -4039,25 +4039,25 @@  discard block
 block discarded – undo
4039 4039
 									jQuery('.bs-vc-modal-form').trigger('change');
4040 4040
 								}
4041 4041
 							});
4042
-							aui_modal('" . $bsvc_title . "', '" . addslashes( $bsvc_body ) . "', '" . $bsvc_footer . "', true, 'bs-vc-modal', 'modal-lg', '');
4042
+							aui_modal('" . $bsvc_title . "', '" . addslashes($bsvc_body) . "', '" . $bsvc_footer . "', true, 'bs-vc-modal', 'modal-lg', '');
4043 4043
 							jQuery(document).off('change', '#bsvc_raw_value').on('change', '#bsvc_raw_value', function(e) {
4044 4044
 								props.setAttributes({" . $key . ": e.target.value});
4045 4045
 							});
4046 4046
 						}
4047 4047
 					},
4048
-					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
4048
+					'" . addslashes(!empty($args['button_title']) ? $args['button_title'] : $args['title']) . "'
4049 4049
 				) ),";
4050 4050
 			} else {
4051
-				return;// if we have not implemented the control then don't break the JS.
4051
+				return; // if we have not implemented the control then don't break the JS.
4052 4052
 			}
4053 4053
 
4054 4054
 			// color input does not show the labels so we add them
4055
-			if($args['type']=='color'){
4055
+			if ($args['type'] == 'color') {
4056 4056
 				// add show only if advanced
4057 4057
 				echo $require_advanced;
4058 4058
 				// add setting require if defined
4059 4059
 				echo $element_require;
4060
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
4060
+				echo "el('div', {style: {'marginBottom': '8px'}}, '" . addslashes($args['title']) . "'),";
4061 4061
 			}
4062 4062
 
4063 4063
 			// add show only if advanced
@@ -4069,22 +4069,22 @@  discard block
 block discarded – undo
4069 4069
 			// icon
4070 4070
 			echo $icon;
4071 4071
 			?>
4072
-			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
4073
-			label: <?php if ( empty( $args['title'] ) ) { echo "''"; } else if ( empty( $args['row'] ) && ! empty( $args['device_type'] ) ) { ?>el('label',{className:'components-base-control__label',style:{width:"100%"}},el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['title'] ) ?>'}}),<?php if ( $device_type_icon ) { ?>deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})<?php } ?>)<?php
4074
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
4075
-			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
4072
+			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type : "wp.components." . $type; ?>, {
4073
+			label: <?php if (empty($args['title'])) { echo "''"; } else if (empty($args['row']) && !empty($args['device_type'])) { ?>el('label',{className:'components-base-control__label',style:{width:"100%"}},el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes($args['title']) ?>'}}),<?php if ($device_type_icon) { ?>deviceType == '<?php echo $device_type; ?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})<?php } ?>)<?php
4074
+			} else { ?>'<?php echo addslashes(trim(esc_html($args['title']))); ?>'<?php } ?>,
4075
+			help: <?php echo (isset($args['desc']) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim(wp_kses_post(addslashes($args['desc']))) . "'}})" : "''"); ?>,
4076 4076
 			value: <?php echo $value; ?>,
4077
-			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
4078
-				echo "type: '" . addslashes( $args['type'] ) . "',";
4077
+			<?php if ($type == 'TextControl' && $args['type'] != 'text') {
4078
+				echo "type: '" . addslashes($args['type']) . "',";
4079 4079
 			} ?>
4080
-			<?php if ( ! empty( $args['placeholder'] ) ) {
4081
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
4080
+			<?php if (!empty($args['placeholder'])) {
4081
+				echo "placeholder: '" . esc_js(addslashes(trim(esc_html($args['placeholder'])))) . "',";
4082 4082
 			} ?>
4083 4083
 			<?php echo $options; ?>
4084 4084
 			<?php echo $extra; ?>
4085 4085
 			<?php echo $custom_attributes; ?>
4086 4086
 			<?php echo $onchangecomplete; ?>
4087
-			<?php if ( $onchange ) { ?>
4087
+			<?php if ($onchange) { ?>
4088 4088
 			onChange: function ( <?php echo $key; ?> ) {
4089 4089
 				<?php echo $onchange; ?>
4090 4090
 			}
@@ -4103,15 +4103,15 @@  discard block
 block discarded – undo
4103 4103
 		 *@todo there is prob a faster way to do this, also we could add some validation here.
4104 4104
 		 *
4105 4105
 		 */
4106
-		public function array_to_attributes( $custom_attributes, $html = false ) {
4106
+		public function array_to_attributes($custom_attributes, $html = false) {
4107 4107
 			$attributes = '';
4108
-			if ( ! empty( $custom_attributes ) ) {
4108
+			if (!empty($custom_attributes)) {
4109 4109
 
4110
-				foreach ( $custom_attributes as $key => $val ) {
4111
-					if(is_array($val)){
4112
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4113
-					}else{
4114
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4110
+				foreach ($custom_attributes as $key => $val) {
4111
+					if (is_array($val)) {
4112
+						$attributes .= $key . ': {' . $this->array_to_attributes($val, $html) . '},';
4113
+					} else {
4114
+						$attributes .= $html ? " $key='$val' " : "'$key': '$val',";
4115 4115
 					}
4116 4116
 				}
4117 4117
 
@@ -4129,113 +4129,113 @@  discard block
 block discarded – undo
4129 4129
 		 *
4130 4130
 		 * @param $args
4131 4131
 		 */
4132
-		public function block_element( $args, $save = false ) {
4132
+		public function block_element($args, $save = false) {
4133 4133
 
4134 4134
 //            print_r($args);echo '###';exit;
4135 4135
 
4136
-			if ( ! empty( $args ) ) {
4137
-				foreach ( $args as $element => $new_args ) {
4136
+			if (!empty($args)) {
4137
+				foreach ($args as $element => $new_args) {
4138 4138
 
4139
-					if ( is_array( $new_args ) ) { // its an element
4139
+					if (is_array($new_args)) { // its an element
4140 4140
 
4141 4141
 
4142
-						if ( isset( $new_args['element'] ) ) {
4142
+						if (isset($new_args['element'])) {
4143 4143
 
4144
-							if ( isset( $new_args['element_require'] ) ) {
4145
-								echo str_replace( array(
4144
+							if (isset($new_args['element_require'])) {
4145
+								echo str_replace(array(
4146 4146
 										"'+",
4147 4147
 										"+'"
4148
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4149
-								unset( $new_args['element_require'] );
4148
+									), '', $this->block_props_replace($new_args['element_require'])) . " &&  ";
4149
+								unset($new_args['element_require']);
4150 4150
 							}
4151 4151
 
4152
-							if($new_args['element']=='InnerBlocks'){
4152
+							if ($new_args['element'] == 'InnerBlocks') {
4153 4153
 								echo "\n el( InnerBlocks, {";
4154
-							}elseif($new_args['element']=='innerBlocksProps'){
4154
+							}elseif ($new_args['element'] == 'innerBlocksProps') {
4155 4155
 								$element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4156 4156
 							  //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4157 4157
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4158 4158
 								echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4159 4159
 								echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4160
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4160
+								echo !empty($new_args['blockProps']) ? $this->block_element($new_args['blockProps'], $save) : '';
4161 4161
 
4162 4162
 								echo "} ), {";
4163
-								echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4163
+								echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element($new_args['innerBlocksProps'], $save) : '';
4164 4164
 							//    echo '###';
4165 4165
 
4166 4166
 							  //  echo '###';
4167
-							}elseif($new_args['element']=='BlocksProps'){
4167
+							}elseif ($new_args['element'] == 'BlocksProps') {
4168 4168
 
4169
-								if ( isset($new_args['if_inner_element']) ) {
4169
+								if (isset($new_args['if_inner_element'])) {
4170 4170
 									$element = $new_args['if_inner_element'];
4171
-								}else {
4172
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4171
+								} else {
4172
+									$element = isset($new_args['inner_element']) ? "'" . esc_attr($new_args['inner_element']) . "'" : "'div'";
4173 4173
 								}
4174 4174
 
4175 4175
 								unset($new_args['inner_element']);
4176 4176
 								echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4177
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4177
+								echo !empty($new_args['blockProps']) ? $this->block_element($new_args['blockProps'], $save) : '';
4178 4178
 
4179 4179
 
4180 4180
 							   // echo "} ),";
4181 4181
 
4182
-							}else{
4182
+							} else {
4183 4183
 								echo "\n el( '" . $new_args['element'] . "', {";
4184 4184
 							}
4185 4185
 
4186 4186
 
4187 4187
 							// get the attributes
4188
-							foreach ( $new_args as $new_key => $new_value ) {
4188
+							foreach ($new_args as $new_key => $new_value) {
4189 4189
 
4190 4190
 
4191
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4191
+								if ($new_key == 'element' || $new_key == 'content' || $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array($new_value)) {
4192 4192
 									// do nothing
4193 4193
 								} else {
4194
-									echo $this->block_element( array( $new_key => $new_value ),$save );
4194
+									echo $this->block_element(array($new_key => $new_value), $save);
4195 4195
 								}
4196 4196
 							}
4197 4197
 
4198
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4198
+							echo $new_args['element'] == 'BlocksProps' ? '} ),' : "},"; // end attributes
4199 4199
 
4200 4200
 							// get the content
4201 4201
 							$first_item = 0;
4202
-							foreach ( $new_args as $new_key => $new_value ) {
4203
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4202
+							foreach ($new_args as $new_key => $new_value) {
4203
+								if ($new_key === 'content' || $new_key === 'if_content' || is_array($new_value)) {
4204 4204
 
4205
-									if ( $new_key === 'content' ) {
4206
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4207
-									}else if ( $new_key === 'if_content' ) {
4208
-										echo  $this->block_props_replace(  $new_value  );
4205
+									if ($new_key === 'content') {
4206
+										echo "'" . $this->block_props_replace(wp_slash($new_value)) . "'";
4207
+									} else if ($new_key === 'if_content') {
4208
+										echo  $this->block_props_replace($new_value);
4209 4209
 									}
4210 4210
 
4211
-									if ( is_array( $new_value ) ) {
4211
+									if (is_array($new_value)) {
4212 4212
 
4213
-										if ( isset( $new_value['element_require'] ) ) {
4214
-											echo str_replace( array(
4213
+										if (isset($new_value['element_require'])) {
4214
+											echo str_replace(array(
4215 4215
 													"'+",
4216 4216
 													"+'"
4217
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4218
-											unset( $new_value['element_require'] );
4217
+												), '', $this->block_props_replace($new_value['element_require'])) . " &&  ";
4218
+											unset($new_value['element_require']);
4219 4219
 										}
4220 4220
 
4221
-										if ( isset( $new_value['element_repeat'] ) ) {
4221
+										if (isset($new_value['element_repeat'])) {
4222 4222
 											$x = 1;
4223
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4224
-												$this->block_element( array( '' => $new_value ),$save );
4225
-												$x ++;
4223
+											while ($x <= absint($new_value['element_repeat'])) {
4224
+												$this->block_element(array('' => $new_value), $save);
4225
+												$x++;
4226 4226
 											}
4227 4227
 										} else {
4228
-											$this->block_element( array( '' => $new_value ),$save );
4228
+											$this->block_element(array('' => $new_value), $save);
4229 4229
 										}
4230 4230
 									}
4231
-									$first_item ++;
4231
+									$first_item++;
4232 4232
 								}
4233 4233
 							}
4234 4234
 
4235
-							if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4236
-								echo "))";// end content
4237
-							}else{
4238
-								echo ")";// end content
4235
+							if ($new_args['element'] == 'innerBlocksProps' || $new_args['element'] == 'xBlocksProps') {
4236
+								echo "))"; // end content
4237
+							} else {
4238
+								echo ")"; // end content
4239 4239
 							}
4240 4240
 
4241 4241
 
@@ -4244,26 +4244,26 @@  discard block
 block discarded – undo
4244 4244
 						}
4245 4245
 					} else {
4246 4246
 
4247
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4247
+						if (substr($element, 0, 3) === "if_") {
4248 4248
 							$extra = '';
4249
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4250
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4251
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4249
+							if (strpos($new_args, '[%WrapClass%]') !== false) {
4250
+								$new_args = str_replace('[%WrapClass%]"', '" + sd_build_aui_class(props.attributes)', $new_args);
4251
+								$new_args = str_replace('[%WrapClass%]', '+ sd_build_aui_class(props.attributes)', $new_args);
4252 4252
 							}
4253
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4254
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4255
-							$new_args = str_replace('[%WrapStyle%]','',$new_args);
4256
-							echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4253
+							echo str_replace("if_", "", $element) . ": " . $this->block_props_replace($new_args, true) . ",";
4254
+						} elseif ($element == 'style' && strpos($new_args, '[%WrapStyle%]') !== false) {
4255
+							$new_args = str_replace('[%WrapStyle%]', '', $new_args);
4256
+							echo $element . ": {..." . $this->block_props_replace($new_args) . " , ...sd_build_aui_styles(props.attributes) },";
4257 4257
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4258
-						} elseif ( $element == 'style' ) {
4259
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4260
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4261
-							$new_args = str_replace('[%WrapClass%]','',$new_args);
4262
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4263
-						} elseif ( $element == 'template' && $new_args ) {
4258
+						} elseif ($element == 'style') {
4259
+							echo $element . ": " . $this->block_props_replace($new_args) . ",";
4260
+						} elseif (($element == 'class' || $element == 'className') && strpos($new_args, '[%WrapClass%]') !== false) {
4261
+							$new_args = str_replace('[%WrapClass%]', '', $new_args);
4262
+							echo $element . ": '" . $this->block_props_replace($new_args) . "' + sd_build_aui_class(props.attributes),";
4263
+						} elseif ($element == 'template' && $new_args) {
4264 4264
 							echo $element . ": $new_args,";
4265 4265
 						} else {
4266
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4266
+							echo $element . ": '" . $this->block_props_replace($new_args) . "',";
4267 4267
 						}
4268 4268
 
4269 4269
 					}
@@ -4278,11 +4278,11 @@  discard block
 block discarded – undo
4278 4278
 		 *
4279 4279
 		 * @return mixed
4280 4280
 		 */
4281
-		public function block_props_replace( $string, $no_wrap = false ) {
4282
-			if ( $no_wrap ) {
4283
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4281
+		public function block_props_replace($string, $no_wrap = false) {
4282
+			if ($no_wrap) {
4283
+				$string = str_replace(array("[%", "%]", "%:checked]"), array("props.attributes.", "", ""), $string);
4284 4284
 			} else {
4285
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4285
+				$string = str_replace(array("![%", "[%", "%]", "%:checked]"), array("'+!props.attributes.", "'+props.attributes.", "+'", "+'"), $string);
4286 4286
 			}
4287 4287
 
4288 4288
 			return $string;
@@ -4294,65 +4294,65 @@  discard block
 block discarded – undo
4294 4294
 		 * @param array $args
4295 4295
 		 * @param array $instance
4296 4296
 		 */
4297
-		public function widget( $args, $instance ) {
4298
-			if ( ! is_array( $args ) ) {
4297
+		public function widget($args, $instance) {
4298
+			if (!is_array($args)) {
4299 4299
 				$args = array();
4300 4300
 			}
4301 4301
 
4302 4302
 			// Get the filtered values
4303
-			$argument_values = $this->argument_values( $instance );
4304
-			$argument_values = $this->string_to_bool( $argument_values );
4305
-			$output          = $this->output( $argument_values, $args );
4303
+			$argument_values = $this->argument_values($instance);
4304
+			$argument_values = $this->string_to_bool($argument_values);
4305
+			$output          = $this->output($argument_values, $args);
4306 4306
 
4307 4307
 			$no_wrap = false;
4308
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4308
+			if (isset($argument_values['no_wrap']) && $argument_values['no_wrap']) {
4309 4309
 				$no_wrap = true;
4310 4310
 			}
4311 4311
 
4312 4312
 			ob_start();
4313
-			if ( $output && ! $no_wrap ) {
4313
+			if ($output && !$no_wrap) {
4314 4314
 
4315 4315
 				$class_original = $this->options['widget_ops']['classname'];
4316
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4316
+				$class = $this->options['widget_ops']['classname'] . " sdel-" . $this->get_instance_hash();
4317 4317
 
4318 4318
 				// Before widget
4319
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4320
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4321
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4322
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4319
+				$before_widget = !empty($args['before_widget']) ? $args['before_widget'] : '';
4320
+				$before_widget = $before_widget ? str_replace($class_original, $class, $before_widget) : $before_widget;
4321
+				$before_widget = apply_filters('wp_super_duper_before_widget', $before_widget, $args, $instance, $this);
4322
+				$before_widget = apply_filters('wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this);
4323 4323
 
4324 4324
 				// After widget
4325
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4326
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4327
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4325
+				$after_widget = !empty($args['after_widget']) ? $args['after_widget'] : '';
4326
+				$after_widget = apply_filters('wp_super_duper_after_widget', $after_widget, $args, $instance, $this);
4327
+				$after_widget = apply_filters('wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this);
4328 4328
 
4329 4329
 				echo $before_widget;
4330 4330
 				// elementor strips the widget wrapping div so we check for and add it back if needed
4331
-				if ( $this->is_elementor_widget_output() ) {
4331
+				if ($this->is_elementor_widget_output()) {
4332 4332
 					// Filter class & attrs for elementor widget output.
4333
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4334
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4333
+					$class = apply_filters('wp_super_duper_div_classname', $class, $args, $this);
4334
+					$class = apply_filters('wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this);
4335 4335
 
4336
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4337
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4336
+					$attrs = apply_filters('wp_super_duper_div_attrs', '', $args, $this);
4337
+					$attrs = apply_filters('wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this);
4338 4338
 
4339
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4339
+					echo "<span class='" . esc_attr($class) . "' " . $attrs . ">";
4340 4340
 				}
4341
-				echo $this->output_title( $args, $instance );
4341
+				echo $this->output_title($args, $instance);
4342 4342
 				echo $output;
4343
-				if ( $this->is_elementor_widget_output() ) {
4343
+				if ($this->is_elementor_widget_output()) {
4344 4344
 					echo "</span>";
4345 4345
 				}
4346 4346
 				echo $after_widget;
4347
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4348
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4347
+			} elseif ($this->is_preview() && $output == '') {// if preview show a placeholder if empty
4348
+				$output = $this->preview_placeholder_text("{{" . $this->base_id . "}}");
4349 4349
 				echo $output;
4350
-			} elseif ( $output && $no_wrap ) {
4350
+			} elseif ($output && $no_wrap) {
4351 4351
 				echo $output;
4352 4352
 			}
4353 4353
 			$output = ob_get_clean();
4354 4354
 
4355
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4355
+			$output = apply_filters('wp_super_duper_widget_output', $output, $instance, $args, $this);
4356 4356
 
4357 4357
 			echo $output;
4358 4358
 		}
@@ -4365,7 +4365,7 @@  discard block
 block discarded – undo
4365 4365
 		 */
4366 4366
 		public function is_elementor_widget_output() {
4367 4367
 			$result = false;
4368
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4368
+			if (defined('ELEMENTOR_VERSION') && isset($this->number) && $this->number == 'REPLACE_TO_ID') {
4369 4369
 				$result = true;
4370 4370
 			}
4371 4371
 
@@ -4380,7 +4380,7 @@  discard block
 block discarded – undo
4380 4380
 		 */
4381 4381
 		public function is_elementor_preview() {
4382 4382
 			$result = false;
4383
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4383
+			if (isset($_REQUEST['elementor-preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') || (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor_ajax')) {
4384 4384
 				$result = true;
4385 4385
 			}
4386 4386
 
@@ -4395,7 +4395,7 @@  discard block
 block discarded – undo
4395 4395
 		 */
4396 4396
 		public function is_divi_preview() {
4397 4397
 			$result = false;
4398
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4398
+			if (isset($_REQUEST['et_fb']) || isset($_REQUEST['et_pb_preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor')) {
4399 4399
 				$result = true;
4400 4400
 			}
4401 4401
 
@@ -4410,7 +4410,7 @@  discard block
 block discarded – undo
4410 4410
 		 */
4411 4411
 		public function is_beaver_preview() {
4412 4412
 			$result = false;
4413
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4413
+			if (isset($_REQUEST['fl_builder'])) {
4414 4414
 				$result = true;
4415 4415
 			}
4416 4416
 
@@ -4425,7 +4425,7 @@  discard block
 block discarded – undo
4425 4425
 		 */
4426 4426
 		public function is_siteorigin_preview() {
4427 4427
 			$result = false;
4428
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4428
+			if (!empty($_REQUEST['siteorigin_panels_live_editor'])) {
4429 4429
 				$result = true;
4430 4430
 			}
4431 4431
 
@@ -4440,7 +4440,7 @@  discard block
 block discarded – undo
4440 4440
 		 */
4441 4441
 		public function is_cornerstone_preview() {
4442 4442
 			$result = false;
4443
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4443
+			if (!empty($_REQUEST['cornerstone_preview']) || basename($_SERVER['REQUEST_URI']) == 'cornerstone-endpoint') {
4444 4444
 				$result = true;
4445 4445
 			}
4446 4446
 
@@ -4455,7 +4455,7 @@  discard block
 block discarded – undo
4455 4455
 		 */
4456 4456
 		public function is_fusion_preview() {
4457 4457
 			$result = false;
4458
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4458
+			if (!empty($_REQUEST['fb-edit']) || !empty($_REQUEST['fusion_load_nonce'])) {
4459 4459
 				$result = true;
4460 4460
 			}
4461 4461
 
@@ -4470,7 +4470,7 @@  discard block
 block discarded – undo
4470 4470
 		 */
4471 4471
 		public function is_oxygen_preview() {
4472 4472
 			$result = false;
4473
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4473
+			if (!empty($_REQUEST['ct_builder']) || (!empty($_REQUEST['action']) && (substr($_REQUEST['action'], 0, 11) === "oxy_render_" || substr($_REQUEST['action'], 0, 10) === "ct_render_"))) {
4474 4474
 				$result = true;
4475 4475
 			}
4476 4476
 
@@ -4487,7 +4487,7 @@  discard block
 block discarded – undo
4487 4487
 		public function is_kallyas_zion_preview() {
4488 4488
 			$result = false;
4489 4489
 
4490
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4490
+			if (function_exists('znhg_kallyas_theme_config') && !empty($_REQUEST['zn_pb_edit'])) {
4491 4491
 				$result = true;
4492 4492
 			}
4493 4493
 
@@ -4504,7 +4504,7 @@  discard block
 block discarded – undo
4504 4504
 		public function is_bricks_preview() {
4505 4505
 			$result = false;
4506 4506
 
4507
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4507
+			if (function_exists('bricks_is_builder') && (bricks_is_builder() || bricks_is_builder_call())) {
4508 4508
 				$result = true;
4509 4509
 			}
4510 4510
 
@@ -4519,25 +4519,25 @@  discard block
 block discarded – undo
4519 4519
 		 */
4520 4520
 		public function is_preview() {
4521 4521
 			$preview = false;
4522
-			if ( $this->is_divi_preview() ) {
4522
+			if ($this->is_divi_preview()) {
4523 4523
 				$preview = true;
4524
-			} elseif ( $this->is_elementor_preview() ) {
4524
+			} elseif ($this->is_elementor_preview()) {
4525 4525
 				$preview = true;
4526
-			} elseif ( $this->is_beaver_preview() ) {
4526
+			} elseif ($this->is_beaver_preview()) {
4527 4527
 				$preview = true;
4528
-			} elseif ( $this->is_siteorigin_preview() ) {
4528
+			} elseif ($this->is_siteorigin_preview()) {
4529 4529
 				$preview = true;
4530
-			} elseif ( $this->is_cornerstone_preview() ) {
4530
+			} elseif ($this->is_cornerstone_preview()) {
4531 4531
 				$preview = true;
4532
-			} elseif ( $this->is_fusion_preview() ) {
4532
+			} elseif ($this->is_fusion_preview()) {
4533 4533
 				$preview = true;
4534
-			} elseif ( $this->is_oxygen_preview() ) {
4534
+			} elseif ($this->is_oxygen_preview()) {
4535 4535
 				$preview = true;
4536
-			} elseif( $this->is_kallyas_zion_preview() ) {
4536
+			} elseif ($this->is_kallyas_zion_preview()) {
4537 4537
 				$preview = true;
4538
-			} elseif( $this->is_block_content_call() ) {
4538
+			} elseif ($this->is_block_content_call()) {
4539 4539
 				$preview = true;
4540
-			} elseif( $this->is_bricks_preview() ) {
4540
+			} elseif ($this->is_bricks_preview()) {
4541 4541
 				$preview = true;
4542 4542
 			}
4543 4543
 
@@ -4552,44 +4552,44 @@  discard block
 block discarded – undo
4552 4552
 		 *
4553 4553
 		 * @return string
4554 4554
 		 */
4555
-		public function output_title( $args, $instance = array() ) {
4555
+		public function output_title($args, $instance = array()) {
4556 4556
 			$output = '';
4557
-			if ( ! empty( $instance['title'] ) ) {
4557
+			if (!empty($instance['title'])) {
4558 4558
 				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4559
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4559
+				$title = apply_filters('widget_title', $instance['title'], $instance, $this->id_base);
4560 4560
 
4561
-				if ( empty( $instance['widget_title_tag'] ) ) {
4562
-					if ( ! isset( $args['before_title'] ) ) {
4561
+				if (empty($instance['widget_title_tag'])) {
4562
+					if (!isset($args['before_title'])) {
4563 4563
 						$args['before_title'] = '';
4564 4564
 					}
4565 4565
 
4566
-					if ( ! isset( $args['after_title'] ) ) {
4566
+					if (!isset($args['after_title'])) {
4567 4567
 						$args['after_title'] = '';
4568 4568
 					}
4569 4569
 
4570 4570
 					$output = $args['before_title'] . $title . $args['after_title'];
4571 4571
 				} else {
4572
-					$tag 			= esc_attr( $instance['widget_title_tag'] );
4573
-					$allowed_tags 	= array( 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p' );
4574
-					$title_tag      = in_array( $tag, $allowed_tags, true ) ? esc_attr( $tag ) : 'h2';
4572
+					$tag 			= esc_attr($instance['widget_title_tag']);
4573
+					$allowed_tags = array('h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p');
4574
+					$title_tag = in_array($tag, $allowed_tags, true) ? esc_attr($tag) : 'h2';
4575 4575
 
4576 4576
 					// classes
4577 4577
 					$title_classes = array();
4578
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4579
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4580
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4581
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4582
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4583
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4584
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4585
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4586
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4587
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4588
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4589
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4590
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4591
-
4592
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4578
+					$title_classes[] = !empty($instance['widget_title_size_class']) ? sanitize_html_class($instance['widget_title_size_class']) : '';
4579
+					$title_classes[] = !empty($instance['widget_title_align_class']) ? sanitize_html_class($instance['widget_title_align_class']) : '';
4580
+					$title_classes[] = !empty($instance['widget_title_color_class']) ? "text-" . sanitize_html_class($instance['widget_title_color_class']) : '';
4581
+					$title_classes[] = !empty($instance['widget_title_border_class']) ? sanitize_html_class($instance['widget_title_border_class']) : '';
4582
+					$title_classes[] = !empty($instance['widget_title_border_color_class']) ? "border-" . sanitize_html_class($instance['widget_title_border_color_class']) : '';
4583
+					$title_classes[] = !empty($instance['widget_title_mt_class']) ? "mt-" . absint($instance['widget_title_mt_class']) : '';
4584
+					$title_classes[] = !empty($instance['widget_title_mr_class']) ? "mr-" . absint($instance['widget_title_mr_class']) : '';
4585
+					$title_classes[] = !empty($instance['widget_title_mb_class']) ? "mb-" . absint($instance['widget_title_mb_class']) : '';
4586
+					$title_classes[] = !empty($instance['widget_title_ml_class']) ? "ml-" . absint($instance['widget_title_ml_class']) : '';
4587
+					$title_classes[] = !empty($instance['widget_title_pt_class']) ? "pt-" . absint($instance['widget_title_pt_class']) : '';
4588
+					$title_classes[] = !empty($instance['widget_title_pr_class']) ? "pr-" . absint($instance['widget_title_pr_class']) : '';
4589
+					$title_classes[] = !empty($instance['widget_title_pb_class']) ? "pb-" . absint($instance['widget_title_pb_class']) : '';
4590
+					$title_classes[] = !empty($instance['widget_title_pl_class']) ? "pl-" . absint($instance['widget_title_pl_class']) : '';
4591
+
4592
+					$class = !empty($title_classes) ? implode(" ", $title_classes) : '';
4593 4593
 					$output = "<$title_tag class='$class' >$title</$title_tag>";
4594 4594
 				}
4595 4595
 
@@ -4603,7 +4603,7 @@  discard block
 block discarded – undo
4603 4603
 		 *
4604 4604
 		 * @param array $instance The widget options.
4605 4605
 		 */
4606
-		public function form( $instance ) {
4606
+		public function form($instance) {
4607 4607
 
4608 4608
 			// set widget instance
4609 4609
 			$this->instance = $instance;
@@ -4611,20 +4611,20 @@  discard block
 block discarded – undo
4611 4611
 			// set it as a SD widget
4612 4612
 			echo $this->widget_advanced_toggle();
4613 4613
 
4614
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4614
+			echo "<p>" . esc_attr($this->options['widget_ops']['description']) . "</p>";
4615 4615
 			$arguments_raw = $this->get_arguments();
4616 4616
 
4617
-			if ( is_array( $arguments_raw ) ) {
4617
+			if (is_array($arguments_raw)) {
4618 4618
 
4619
-				$arguments = $this->group_arguments( $arguments_raw );
4619
+				$arguments = $this->group_arguments($arguments_raw);
4620 4620
 
4621 4621
 				// Do we have sections?
4622 4622
 				$has_sections = $arguments == $arguments_raw ? false : true;
4623 4623
 
4624 4624
 
4625
-				if ( $has_sections ) {
4625
+				if ($has_sections) {
4626 4626
 					$panel_count = 0;
4627
-					foreach ( $arguments as $key => $args ) {
4627
+					foreach ($arguments as $key => $args) {
4628 4628
 
4629 4629
 						?>
4630 4630
 						<script>
@@ -4634,26 +4634,26 @@  discard block
 block discarded – undo
4634 4634
 
4635 4635
 						$hide       = $panel_count ? ' style="display:none;" ' : '';
4636 4636
 						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4637
-						echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
4638
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4637
+						echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes($key) . "'>" . esc_attr($key) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
4638
+						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes($key) . "' $hide>";
4639 4639
 
4640
-						foreach ( $args as $k => $a ) {
4640
+						foreach ($args as $k => $a) {
4641 4641
 
4642 4642
 							$this->widget_inputs_row_start($k, $a);
4643
-							$this->widget_inputs( $a, $instance );
4643
+							$this->widget_inputs($a, $instance);
4644 4644
 							$this->widget_inputs_row_end($k, $a);
4645 4645
 
4646 4646
 						}
4647 4647
 
4648 4648
 						echo "</div>";
4649 4649
 
4650
-						$panel_count ++;
4650
+						$panel_count++;
4651 4651
 
4652 4652
 					}
4653 4653
 				} else {
4654
-					foreach ( $arguments as $key => $args ) {
4654
+					foreach ($arguments as $key => $args) {
4655 4655
 						$this->widget_inputs_row_start($key, $args);
4656
-						$this->widget_inputs( $args, $instance );
4656
+						$this->widget_inputs($args, $instance);
4657 4657
 						$this->widget_inputs_row_end($key, $args);
4658 4658
 					}
4659 4659
 				}
@@ -4661,28 +4661,28 @@  discard block
 block discarded – undo
4661 4661
 			}
4662 4662
 		}
4663 4663
 
4664
-		public function widget_inputs_row_start( $key, $args ) {
4665
-			if ( ! empty( $args['row'] ) ) {
4664
+		public function widget_inputs_row_start($key, $args) {
4665
+			if (!empty($args['row'])) {
4666 4666
 				// Maybe open
4667
-				if ( ! empty( $args['row']['open'] ) ) {
4667
+				if (!empty($args['row']['open'])) {
4668 4668
 					?>
4669
-					<div class='bsui sd-argument' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php echo ( ! empty( $args['row']['element_require'] ) ? $this->convert_element_require( $args['row']['element_require'] ) : '' ); ?>'>
4670
-					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4669
+					<div class='bsui sd-argument' data-argument='<?php echo esc_attr($args['row']['key']); ?>' data-element_require='<?php echo (!empty($args['row']['element_require']) ? $this->convert_element_require($args['row']['element_require']) : ''); ?>'>
4670
+					<?php if (!empty($args['row']['title'])) { ?>
4671 4671
 					<?php
4672
-						if ( isset( $args['row']['icon'] ) ) {
4672
+						if (isset($args['row']['icon'])) {
4673 4673
 							$args['row']['icon'] = '';
4674 4674
 						}
4675 4675
 
4676
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4676
+						if (!isset($args['row']['device_type']) && isset($args['device_type'])) {
4677 4677
 							$args['row']['device_type'] = $args['device_type'];
4678 4678
 						}
4679 4679
 					?>
4680
-					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4680
+					<label class="mb-0"><?php echo $this->widget_field_title($args['row']); ?><?php echo $this->widget_field_desc($args['row']); ?></label>
4681 4681
 					<?php } ?>
4682
-					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4682
+					<div class='row<?php echo (!empty($args['row']['class']) ? ' ' . esc_attr($args['row']['class']) : ''); ?>'>
4683 4683
 					<div class='col pr-2'>
4684 4684
 					<?php
4685
-				} else if ( ! empty( $args['row']['close'] ) ) {
4685
+				} else if (!empty($args['row']['close'])) {
4686 4686
 					echo "<div class='col pl-0 ps-0'>";
4687 4687
 				} else {
4688 4688
 					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
@@ -4690,10 +4690,10 @@  discard block
 block discarded – undo
4690 4690
 			}
4691 4691
 		}
4692 4692
 
4693
-		public function widget_inputs_row_end( $key, $args ) {
4694
-			if ( ! empty( $args['row'] ) ) {
4693
+		public function widget_inputs_row_end($key, $args) {
4694
+			if (!empty($args['row'])) {
4695 4695
 				// Maybe close
4696
-				if ( ! empty( $args['row']['close'] ) ) {
4696
+				if (!empty($args['row']['close'])) {
4697 4697
 					echo "</div></div>";
4698 4698
 				}
4699 4699
 				echo "</div>";
@@ -4708,7 +4708,7 @@  discard block
 block discarded – undo
4708 4708
 		public function widget_advanced_toggle() {
4709 4709
 
4710 4710
 			$output = '';
4711
-			if ( $this->block_show_advanced() ) {
4711
+			if ($this->block_show_advanced()) {
4712 4712
 				$val = 1;
4713 4713
 			} else {
4714 4714
 				$val = 0;
@@ -4728,14 +4728,14 @@  discard block
 block discarded – undo
4728 4728
 		 *@since 1.0.0
4729 4729
 		 *
4730 4730
 		 */
4731
-		public function convert_element_require( $input ) {
4732
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4731
+		public function convert_element_require($input) {
4732
+			$input = str_replace("'", '"', $input); // we only want double quotes
4733 4733
 
4734
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4734
+			$output = esc_attr(str_replace(array("[%", "%]", "%:checked]"), array(
4735 4735
 				"jQuery(form).find('[data-argument=\"",
4736 4736
 				"\"]').find('input,select,textarea').val()",
4737 4737
 				"\"]').find('input:checked').val()"
4738
-			), $input ) );
4738
+			), $input));
4739 4739
 
4740 4740
 			return $output;
4741 4741
 		}
@@ -4746,48 +4746,48 @@  discard block
 block discarded – undo
4746 4746
 		 * @param $args
4747 4747
 		 * @param $instance
4748 4748
 		 */
4749
-		public function widget_inputs( $args, $instance ) {
4749
+		public function widget_inputs($args, $instance) {
4750 4750
 
4751 4751
 			$class             = "";
4752 4752
 			$element_require   = "";
4753 4753
 			$custom_attributes = "";
4754 4754
 
4755 4755
 			// get value
4756
-			if ( isset( $instance[ $args['name'] ] ) ) {
4757
-				$value = $instance[ $args['name'] ];
4758
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4759
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4756
+			if (isset($instance[$args['name']])) {
4757
+				$value = $instance[$args['name']];
4758
+			} elseif (!isset($instance[$args['name']]) && !empty($args['default'])) {
4759
+				$value = is_array($args['default']) ? array_map("esc_html", $args['default']) : esc_html($args['default']);
4760 4760
 			} else {
4761 4761
 				$value = '';
4762 4762
 			}
4763 4763
 
4764 4764
 			// get placeholder
4765
-			if ( ! empty( $args['placeholder'] ) ) {
4766
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4765
+			if (!empty($args['placeholder'])) {
4766
+				$placeholder = "placeholder='" . esc_html($args['placeholder']) . "'";
4767 4767
 			} else {
4768 4768
 				$placeholder = '';
4769 4769
 			}
4770 4770
 
4771 4771
 			// get if advanced
4772
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4772
+			if (isset($args['advanced']) && $args['advanced']) {
4773 4773
 				$class .= " sd-advanced-setting ";
4774 4774
 			}
4775 4775
 
4776 4776
 			// element_require
4777
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4777
+			if (isset($args['element_require']) && $args['element_require']) {
4778 4778
 				$element_require = $args['element_require'];
4779 4779
 			}
4780 4780
 
4781 4781
 			// custom_attributes
4782
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4783
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4782
+			if (isset($args['custom_attributes']) && $args['custom_attributes']) {
4783
+				$custom_attributes = $this->array_to_attributes($args['custom_attributes'], true);
4784 4784
 			}
4785 4785
 
4786 4786
 			// before wrapper
4787 4787
 			?>
4788
-			<p class="sd-argument <?php echo esc_attr( $class ); ?>" data-argument='<?php echo esc_attr( $args['name'] ); ?>' data-element_require='<?php if ( $element_require ) { echo $this->convert_element_require( $element_require );} ?>'>
4788
+			<p class="sd-argument <?php echo esc_attr($class); ?>" data-argument='<?php echo esc_attr($args['name']); ?>' data-element_require='<?php if ($element_require) { echo $this->convert_element_require($element_require); } ?>'>
4789 4789
 			<?php
4790
-			switch ( $args['type'] ) {
4790
+			switch ($args['type']) {
4791 4791
 				//array('text','password','number','email','tel','url','color')
4792 4792
 				case "text":
4793 4793
 				case "password":
@@ -4797,33 +4797,33 @@  discard block
 block discarded – undo
4797 4797
 				case "url":
4798 4798
 				case "color":
4799 4799
 					?>
4800
-					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
4801
-					<input <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="<?php echo esc_attr( $args['type'] ); ?>" value="<?php echo esc_attr( $value ); ?>">
4800
+					<label for="<?php echo esc_attr($this->get_field_id($args['name'])); ?>"><?php echo $this->widget_field_title($args); ?><?php echo $this->widget_field_desc($args); ?></label>
4801
+					<input <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr($this->get_field_id($args['name'])); ?>" name="<?php echo esc_attr($this->get_field_name($args['name'])); ?>" type="<?php echo esc_attr($args['type']); ?>" value="<?php echo esc_attr($value); ?>">
4802 4802
 					<?php
4803 4803
 
4804 4804
 					break;
4805 4805
 				case "select":
4806
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4807
-					if ( $multiple ) {
4808
-						if ( empty( $value ) ) {
4806
+					$multiple = isset($args['multiple']) && $args['multiple'] ? true : false;
4807
+					if ($multiple) {
4808
+						if (empty($value)) {
4809 4809
 							$value = array();
4810 4810
 						}
4811 4811
 					}
4812 4812
 					?>
4813
-					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
4814
-					<select <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); if ( $multiple ) { echo "[]"; } ?>"
4815
-						<?php if ( $multiple ) {
4813
+					<label for="<?php echo esc_attr($this->get_field_id($args['name'])); ?>"><?php echo $this->widget_field_title($args); ?><?php echo $this->widget_field_desc($args); ?></label>
4814
+					<select <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr($this->get_field_id($args['name'])); ?>" name="<?php echo esc_attr($this->get_field_name($args['name'])); if ($multiple) { echo "[]"; } ?>"
4815
+						<?php if ($multiple) {
4816 4816
 							echo "multiple";
4817 4817
 						} //@todo not implemented yet due to gutenberg not supporting it
4818 4818
 						?>>
4819 4819
 						<?php
4820 4820
 
4821
-						if ( ! empty( $args['options'] ) ) {
4822
-							foreach ( $args['options'] as $val => $label ) {
4823
-								if ( $multiple ) {
4824
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4821
+						if (!empty($args['options'])) {
4822
+							foreach ($args['options'] as $val => $label) {
4823
+								if ($multiple) {
4824
+									$selected = in_array($val, $value) ? 'selected="selected"' : '';
4825 4825
 								} else {
4826
-									$selected = selected( $value, $val, false );
4826
+									$selected = selected($value, $val, false);
4827 4827
 								}
4828 4828
 								echo "<option value='$val' " . $selected . ">$label</option>";
4829 4829
 							}
@@ -4834,20 +4834,20 @@  discard block
 block discarded – undo
4834 4834
 					break;
4835 4835
 				case "checkbox":
4836 4836
 					?>
4837
-					<input <?php echo $placeholder; ?> <?php checked( 1, $value, true ) ?> <?php echo $custom_attributes; ?> class="widefat" id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="checkbox" value="1">
4838
-					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
4837
+					<input <?php echo $placeholder; ?> <?php checked(1, $value, true) ?> <?php echo $custom_attributes; ?> class="widefat" id="<?php echo esc_attr($this->get_field_id($args['name'])); ?>" name="<?php echo esc_attr($this->get_field_name($args['name'])); ?>" type="checkbox" value="1">
4838
+					<label for="<?php echo esc_attr($this->get_field_id($args['name'])); ?>"><?php echo $this->widget_field_title($args); ?><?php echo $this->widget_field_desc($args); ?></label>
4839 4839
 					<?php
4840 4840
 					break;
4841 4841
 				case "textarea":
4842 4842
 					?>
4843
-					<label for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
4844
-					<textarea <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>"><?php echo esc_attr( $value ); ?></textarea>
4843
+					<label for="<?php echo esc_attr($this->get_field_id($args['name'])); ?>"><?php echo $this->widget_field_title($args); ?><?php echo $this->widget_field_desc($args); ?></label>
4844
+					<textarea <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr($this->get_field_id($args['name'])); ?>" name="<?php echo esc_attr($this->get_field_name($args['name'])); ?>"><?php echo esc_attr($value); ?></textarea>
4845 4845
 					<?php
4846 4846
 
4847 4847
 					break;
4848 4848
 				case "hidden":
4849 4849
 					?>
4850
-					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden" value="<?php echo esc_attr( $value ); ?>">
4850
+					<input id="<?php echo esc_attr($this->get_field_id($args['name'])); ?>" name="<?php echo esc_attr($this->get_field_name($args['name'])); ?>" type="hidden" value="<?php echo esc_attr($value); ?>">
4851 4851
 					<?php
4852 4852
 					break;
4853 4853
 				default:
@@ -4857,15 +4857,15 @@  discard block
 block discarded – undo
4857 4857
 			?></p><?php
4858 4858
 		}
4859 4859
 
4860
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4861
-			if($icon=='box-top'){
4862
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
4863
-			}elseif($icon=='box-right'){
4864
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
4865
-			}elseif($icon=='box-bottom'){
4866
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
4867
-			}elseif($icon=='box-left'){
4868
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
4860
+		public function get_widget_icon($icon = 'box-top', $title = '') {
4861
+			if ($icon == 'box-top') {
4862
+				return '<svg title="' . esc_attr($title) . '" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
4863
+			}elseif ($icon == 'box-right') {
4864
+				return '<svg title="' . esc_attr($title) . '" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
4865
+			}elseif ($icon == 'box-bottom') {
4866
+				return '<svg title="' . esc_attr($title) . '" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
4867
+			}elseif ($icon == 'box-left') {
4868
+				return '<svg title="' . esc_attr($title) . '" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
4869 4869
 			}
4870 4870
 		}
4871 4871
 
@@ -4877,14 +4877,14 @@  discard block
 block discarded – undo
4877 4877
 		 * @return string
4878 4878
 		 * @todo, need to make its own tooltip script
4879 4879
 		 */
4880
-		public function widget_field_desc( $args ) {
4880
+		public function widget_field_desc($args) {
4881 4881
 
4882 4882
 			$description = '';
4883
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4884
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4885
-					$description = $this->desc_tip( $args['desc'] );
4883
+			if (isset($args['desc']) && $args['desc']) {
4884
+				if (isset($args['desc_tip']) && $args['desc_tip']) {
4885
+					$description = $this->desc_tip($args['desc']);
4886 4886
 				} else {
4887
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4887
+					$description = '<span class="description">' . wp_kses_post($args['desc']) . '</span>';
4888 4888
 				}
4889 4889
 			}
4890 4890
 
@@ -4898,18 +4898,18 @@  discard block
 block discarded – undo
4898 4898
 		 *
4899 4899
 		 * @return string
4900 4900
 		 */
4901
-		public function widget_field_title( $args ) {
4901
+		public function widget_field_title($args) {
4902 4902
 			$title = '';
4903 4903
 
4904
-			if ( isset( $args['title'] ) && $args['title'] ) {
4905
-				if ( ! empty( $args['device_type'] ) ) {
4904
+			if (isset($args['title']) && $args['title']) {
4905
+				if (!empty($args['device_type'])) {
4906 4906
 					$args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4907 4907
 				}
4908 4908
 
4909
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4910
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4909
+				if (isset($args['icon']) && $args['icon']) {
4910
+					$title = self::get_widget_icon($args['icon'], $args['title']);
4911 4911
 				} else {
4912
-					$title = esc_attr( $args['title'] );
4912
+					$title = esc_attr($args['title']);
4913 4913
 				}
4914 4914
 			}
4915 4915
 
@@ -4924,11 +4924,11 @@  discard block
 block discarded – undo
4924 4924
 		 *
4925 4925
 		 * @return string
4926 4926
 		 */
4927
-		function desc_tip( $tip, $allow_html = false ) {
4928
-			if ( $allow_html ) {
4929
-				$tip = $this->sanitize_tooltip( $tip );
4927
+		function desc_tip($tip, $allow_html = false) {
4928
+			if ($allow_html) {
4929
+				$tip = $this->sanitize_tooltip($tip);
4930 4930
 			} else {
4931
-				$tip = esc_attr( $tip );
4931
+				$tip = esc_attr($tip);
4932 4932
 			}
4933 4933
 
4934 4934
 			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
@@ -4941,8 +4941,8 @@  discard block
 block discarded – undo
4941 4941
 		 *
4942 4942
 		 * @return string
4943 4943
 		 */
4944
-		public function sanitize_tooltip( $var ) {
4945
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4944
+		public function sanitize_tooltip($var) {
4945
+			return htmlspecialchars(wp_kses(html_entity_decode($var), array(
4946 4946
 				'br'     => array(),
4947 4947
 				'em'     => array(),
4948 4948
 				'strong' => array(),
@@ -4952,7 +4952,7 @@  discard block
 block discarded – undo
4952 4952
 				'li'     => array(),
4953 4953
 				'ol'     => array(),
4954 4954
 				'p'      => array(),
4955
-			) ) );
4955
+			)));
4956 4956
 		}
4957 4957
 
4958 4958
 		/**
@@ -4964,30 +4964,30 @@  discard block
 block discarded – undo
4964 4964
 		 * @return array
4965 4965
 		 * @todo we should add some sanitation here.
4966 4966
 		 */
4967
-		public function update( $new_instance, $old_instance ) {
4967
+		public function update($new_instance, $old_instance) {
4968 4968
 
4969 4969
 			//save the widget
4970
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4970
+			$instance = array_merge((array) $old_instance, (array) $new_instance);
4971 4971
 
4972 4972
 			// set widget instance
4973 4973
 			$this->instance = $instance;
4974 4974
 
4975
-			if ( empty( $this->arguments ) ) {
4975
+			if (empty($this->arguments)) {
4976 4976
 				$this->get_arguments();
4977 4977
 			}
4978 4978
 
4979 4979
 			// check for checkboxes
4980
-			if ( ! empty( $this->arguments ) ) {
4981
-				foreach ( $this->arguments as $argument ) {
4982
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4983
-						$instance[ $argument['name'] ] = '0';
4980
+			if (!empty($this->arguments)) {
4981
+				foreach ($this->arguments as $argument) {
4982
+					if (isset($argument['type']) && $argument['type'] == 'checkbox' && !isset($new_instance[$argument['name']])) {
4983
+						$instance[$argument['name']] = '0';
4984 4984
 					}
4985 4985
 				}
4986 4986
 			}
4987 4987
 
4988 4988
             // maybe sanitize widget title
4989
-            if(!empty($instance['title'])) {
4990
-                $instance['title'] = wp_kses_post( $instance['title'] );
4989
+            if (!empty($instance['title'])) {
4990
+                $instance['title'] = wp_kses_post($instance['title']);
4991 4991
             }
4992 4992
 
4993 4993
 			return $instance;
@@ -5003,7 +5003,7 @@  discard block
 block discarded – undo
5003 5003
 		 */
5004 5004
 		public function is_block_content_call() {
5005 5005
 			$result = false;
5006
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
5006
+			if (wp_doing_ajax() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'super_duper_output_shortcode') {
5007 5007
 				$result = true;
5008 5008
 			}
5009 5009
 
@@ -5016,9 +5016,9 @@  discard block
 block discarded – undo
5016 5016
 		 * @return string
5017 5017
 		 *@since 1.0.20
5018 5018
 		 */
5019
-		public function get_instance_hash(){
5020
-			$instance_string = $this->base_id.serialize($this->instance);
5021
-			return hash('crc32b',$instance_string);
5019
+		public function get_instance_hash() {
5020
+			$instance_string = $this->base_id . serialize($this->instance);
5021
+			return hash('crc32b', $instance_string);
5022 5022
 		}
5023 5023
 
5024 5024
 		/**
@@ -5029,14 +5029,14 @@  discard block
 block discarded – undo
5029 5029
 		 * @return string
5030 5030
 		 *@since 1.0.20
5031 5031
 		 */
5032
-		public function get_instance_style($rules = array()){
5032
+		public function get_instance_style($rules = array()) {
5033 5033
 			$css = '';
5034 5034
 
5035
-			if(!empty($rules)){
5035
+			if (!empty($rules)) {
5036 5036
 				$rules = array_unique($rules);
5037 5037
 				$instance_hash = $this->get_instance_hash();
5038 5038
 				$css .= "<style>";
5039
-				foreach($rules as $rule){
5039
+				foreach ($rules as $rule) {
5040 5040
 					$css .= ".sdel-$instance_hash $rule";
5041 5041
 				}
5042 5042
 				$css .= "</style>";
@@ -5054,9 +5054,9 @@  discard block
 block discarded – undo
5054 5054
 		 *@since 1.0.28
5055 5055
 		 *
5056 5056
 		 */
5057
-		public function encode_shortcodes( $content ) {
5057
+		public function encode_shortcodes($content) {
5058 5058
 			// Avoids existing encoded tags.
5059
-			$trans   = array(
5059
+			$trans = array(
5060 5060
 				'&#91;' => '&#091;',
5061 5061
 				'&#93;' => '&#093;',
5062 5062
 				'&amp;#91;' => '&#091;',
@@ -5067,7 +5067,7 @@  discard block
 block discarded – undo
5067 5067
 				'&amp;gt;' => '&0gt;',
5068 5068
 			);
5069 5069
 
5070
-			$content = strtr( $content, $trans );
5070
+			$content = strtr($content, $trans);
5071 5071
 
5072 5072
 			$trans   = array(
5073 5073
 				'[' => '&#91;',
@@ -5078,7 +5078,7 @@  discard block
 block discarded – undo
5078 5078
 				"'" => '&#39;',
5079 5079
 			);
5080 5080
 
5081
-			$content = strtr( $content, $trans );
5081
+			$content = strtr($content, $trans);
5082 5082
 
5083 5083
 			return $content;
5084 5084
 		}
@@ -5092,8 +5092,8 @@  discard block
 block discarded – undo
5092 5092
 		 *@since 1.0.28
5093 5093
 		 *
5094 5094
 		 */
5095
-		public function decode_shortcodes( $content ) {
5096
-			$trans   = array(
5095
+		public function decode_shortcodes($content) {
5096
+			$trans = array(
5097 5097
 				'&#91;' => '[',
5098 5098
 				'&#93;' => ']',
5099 5099
 				'&amp;#91;' => '[',
@@ -5106,7 +5106,7 @@  discard block
 block discarded – undo
5106 5106
 				'&apos;' => "'",
5107 5107
 			);
5108 5108
 
5109
-			$content = strtr( $content, $trans );
5109
+			$content = strtr($content, $trans);
5110 5110
 
5111 5111
 			$trans   = array(
5112 5112
 				'&#091;' => '&#91;',
@@ -5119,31 +5119,31 @@  discard block
 block discarded – undo
5119 5119
 				'&amp;0gt;' => '&gt;',
5120 5120
 			);
5121 5121
 
5122
-			$content = strtr( $content, $trans );
5122
+			$content = strtr($content, $trans);
5123 5123
 
5124 5124
 			return $content;
5125 5125
 		}
5126 5126
 
5127
-		public function block_visibility_fields( $args ) {
5128
-			$value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
5127
+		public function block_visibility_fields($args) {
5128
+			$value = !empty($args['value']) ? esc_attr($args['value']) : '';
5129 5129
 			$content = '<div class="bs-vc-rule-template d-none">';
5130 5130
 				$content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
5131 5131
 					$content .= '<div class="row">';
5132 5132
 						$content .= '<div class="col-sm-12">';
5133
-							$content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__( 'Remove Rule', 'ayecode-connect' ) . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5133
+							$content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__('Remove Rule', 'ayecode-connect') . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5134 5134
 							$content .= aui()->select(
5135 5135
 								array(
5136 5136
 									'id'          => 'bsvc_rule_BSVCINDEX',
5137 5137
 									'name'        => 'bsvc_rule_BSVCINDEX',
5138
-									'label'       => __( 'Rule', 'ayecode-connect' ),
5139
-									'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
5138
+									'label'       => __('Rule', 'ayecode-connect'),
5139
+									'placeholder' => __('Select Rule...', 'ayecode-connect'),
5140 5140
 									'class'       => 'bsvc_rule form-select-sm no-select2 mw-100',
5141 5141
 									'options'     => sd_visibility_rules_options(),
5142 5142
 									'default'     => '',
5143 5143
 									'value'       => '',
5144 5144
 									'label_type'  => '',
5145 5145
 									'select2'     => false,
5146
-									'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
5146
+									'input_group_left' => __('Rule:', 'ayecode-connect'),
5147 5147
 									'extra_attributes' => array(
5148 5148
 										'data-minimum-results-for-search' => '-1'
5149 5149
 									)
@@ -5152,15 +5152,15 @@  discard block
 block discarded – undo
5152 5152
 
5153 5153
 						$content .= '</div>';
5154 5154
 
5155
-						if ( class_exists( 'GeoDirectory' ) ) {
5155
+						if (class_exists('GeoDirectory')) {
5156 5156
 							$content .= '<div class="col-md-7 col-sm-12">';
5157 5157
 
5158 5158
 								$content .= aui()->select(
5159 5159
 									array(
5160 5160
 										'id'          => 'bsvc_gd_field_BSVCINDEX',
5161 5161
 										'name'        => 'bsvc_gd_field_BSVCINDEX',
5162
-										'label'       => __( 'FIELD', 'ayecode-connect' ),
5163
-										'placeholder' => __( 'FIELD', 'ayecode-connect' ),
5162
+										'label'       => __('FIELD', 'ayecode-connect'),
5163
+										'placeholder' => __('FIELD', 'ayecode-connect'),
5164 5164
 										'class'       => 'bsvc_gd_field form-select-sm no-select2 mw-100',
5165 5165
 										'options'     => sd_visibility_gd_field_options(),
5166 5166
 										'default'     => '',
@@ -5181,8 +5181,8 @@  discard block
 block discarded – undo
5181 5181
 									array(
5182 5182
 										'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
5183 5183
 										'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
5184
-										'label'       => __( 'CONDITION', 'ayecode-connect' ),
5185
-										'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
5184
+										'label'       => __('CONDITION', 'ayecode-connect'),
5185
+										'placeholder' => __('CONDITION', 'ayecode-connect'),
5186 5186
 										'class'       => 'bsvc_gd_field_condition form-select-sm no-select2 mw-100',
5187 5187
 										'options'     => sd_visibility_field_condition_options(),
5188 5188
 										'default'     => '',
@@ -5204,9 +5204,9 @@  discard block
 block discarded – undo
5204 5204
 										'type'            => 'text',
5205 5205
 										'id'              => 'bsvc_gd_field_search_BSVCINDEX',
5206 5206
 										'name'            => 'bsvc_gd_field_search_BSVCINDEX',
5207
-										'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5207
+										'label'           => __('VALUE TO MATCH', 'ayecode-connect'),
5208 5208
 										'class'           => 'bsvc_gd_field_search form-control-sm',
5209
-										'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5209
+										'placeholder'     => __('VALUE TO MATCH', 'ayecode-connect'),
5210 5210
 										'label_type'      => '',
5211 5211
 										'value'           => '',
5212 5212
 										'element_require' => '([%bsvc_rule_BSVCINDEX%]=="gd_field" && [%bsvc_gd_field_condition_BSVCINDEX%] && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_empty" && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_not_empty")'
@@ -5216,15 +5216,15 @@  discard block
 block discarded – undo
5216 5216
 							$content .= '</div>';
5217 5217
 						}
5218 5218
 
5219
-                        $content .= apply_filters( 'sd_block_visibility_fields', '', $args );
5219
+                        $content .= apply_filters('sd_block_visibility_fields', '', $args);
5220 5220
 
5221 5221
 					$content .= '</div>';
5222 5222
 
5223
-					$content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __( 'Select User Roles:', 'ayecode-connect' ) . '</label>';
5223
+					$content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __('Select User Roles:', 'ayecode-connect') . '</label>';
5224 5224
 						$role_options = sd_user_roles_options();
5225 5225
 
5226 5226
 						$role_option_i = 0;
5227
-						foreach ( $role_options as $role_option_key => $role_option_name ) {
5227
+						foreach ($role_options as $role_option_key => $role_option_name) {
5228 5228
 							$role_option_i++;
5229 5229
 
5230 5230
 							$content .= '<div class="col-sm-6">';
@@ -5244,19 +5244,19 @@  discard block
 block discarded – undo
5244 5244
 							$content .= '</div>';
5245 5245
 						}
5246 5246
 					$content .= '</div>';
5247
-					$content .= '<div class="bs-vc-sep-wrap text-center position-absolute top-0 mt-n3"><div class="bs-vc-sep-cond d-inline-block badge text-dark bg-gray mt-1">' . esc_html__( 'AND', 'ayecode-connect' ) . '</div></div>';
5247
+					$content .= '<div class="bs-vc-sep-wrap text-center position-absolute top-0 mt-n3"><div class="bs-vc-sep-cond d-inline-block badge text-dark bg-gray mt-1">' . esc_html__('AND', 'ayecode-connect') . '</div></div>';
5248 5248
 				$content .= '</div>';
5249 5249
 			$content .= '</div>';
5250 5250
 			$content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5251 5251
 			$content .= '<div class="bs-vc-rule-sets"></div>';
5252
-			$content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __( 'Add Rule', 'ayecode-connect' ) . '</button></div></div>';
5252
+			$content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __('Add Rule', 'ayecode-connect') . '</button></div></div>';
5253 5253
 			$content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5254 5254
 			$content .= aui()->select(
5255 5255
 				array(
5256 5256
 					'id'          => 'bsvc_output',
5257 5257
 					'name'        => 'bsvc_output',
5258
-					'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5259
-					'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5258
+					'label'       => __('What should happen if rules met.', 'ayecode-connect'),
5259
+					'placeholder' => __('Show Block', 'ayecode-connect'),
5260 5260
 					'class'       => 'bsvc_output form-select-sm no-select2 mw-100',
5261 5261
 					'options'     => sd_visibility_output_options(),
5262 5262
 					'default'     => '',
@@ -5275,8 +5275,8 @@  discard block
 block discarded – undo
5275 5275
 				array(
5276 5276
 					'id'              => 'bsvc_page',
5277 5277
 					'name'            => 'bsvc_page',
5278
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5279
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5278
+					'label'           => __('Page Content', 'ayecode-connect'),
5279
+					'placeholder'     => __('Select Page ID...', 'ayecode-connect'),
5280 5280
 					'class'           => 'bsvc_page form-select-sm no-select2 mw-100',
5281 5281
 					'options'         => sd_template_page_options(),
5282 5282
 					'default'         => '',
@@ -5291,8 +5291,8 @@  discard block
 block discarded – undo
5291 5291
 				array(
5292 5292
 					'id'          => 'bsvc_tmpl_part',
5293 5293
 					'name'        => 'bsvc_tmpl_part',
5294
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5295
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5294
+					'label'       => __('Template Part', 'ayecode-connect'),
5295
+					'placeholder' => __('Select Template Part...', 'ayecode-connect'),
5296 5296
 					'class'       => 'bsvc_tmpl_part form-select-sm no-select2 mw-100',
5297 5297
 					'options'     => sd_template_part_options(),
5298 5298
 					'default'     => '',
@@ -5310,8 +5310,8 @@  discard block
 block discarded – undo
5310 5310
 				array(
5311 5311
 					'id'               => 'bsvc_message_type',
5312 5312
 					'name'             => 'bsvc_message_type',
5313
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5314
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5313
+					'label'            => __('Custom Message Type', 'ayecode-connect'),
5314
+					'placeholder'      => __('Default (none)', 'ayecode-connect'),
5315 5315
 					'class'            => 'bsvc_message_type form-select-sm no-select2 mw-100',
5316 5316
 					'options'          => sd_aui_colors(),
5317 5317
 					'default'          => '',
@@ -5334,7 +5334,7 @@  discard block
 block discarded – undo
5334 5334
 					'name'            => 'bsvc_message',
5335 5335
 					'label'           => '',
5336 5336
 					'class'           => 'bsvc_message form-control-sm mb-3',
5337
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5337
+					'placeholder'     => __('CUSTOM MESSAGE TO SHOW', 'ayecode-connect'),
5338 5338
 					'label_type'      => '',
5339 5339
 					'value'           => '',
5340 5340
 					'form_group_class' => ' ',
@@ -5347,8 +5347,8 @@  discard block
 block discarded – undo
5347 5347
 				array(
5348 5348
 					'id'          => 'bsvc_output_n',
5349 5349
 					'name'        => 'bsvc_output_n',
5350
-					'label'       => __( 'What should happen if rules NOT met.', 'ayecode-connect' ),
5351
-					'placeholder' => __( 'Show Block', 'ayecode-connect' ),
5350
+					'label'       => __('What should happen if rules NOT met.', 'ayecode-connect'),
5351
+					'placeholder' => __('Show Block', 'ayecode-connect'),
5352 5352
 					'class'       => 'bsvc_output_n form-select-sm no-select2 mw-100',
5353 5353
 					'options'     => sd_visibility_output_options(),
5354 5354
 					'default'     => '',
@@ -5367,8 +5367,8 @@  discard block
 block discarded – undo
5367 5367
 				array(
5368 5368
 					'id'              => 'bsvc_page_n',
5369 5369
 					'name'            => 'bsvc_page_n',
5370
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5371
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5370
+					'label'           => __('Page Content', 'ayecode-connect'),
5371
+					'placeholder'     => __('Select Page ID...', 'ayecode-connect'),
5372 5372
 					'class'           => 'bsvc_page_n form-select-sm no-select2 mw-100',
5373 5373
 					'options'         => sd_template_page_options(),
5374 5374
 					'default'         => '',
@@ -5383,8 +5383,8 @@  discard block
 block discarded – undo
5383 5383
 				array(
5384 5384
 					'id'          => 'bsvc_tmpl_part_n',
5385 5385
 					'name'        => 'bsvc_tmpl_part_n',
5386
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5387
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5386
+					'label'       => __('Template Part', 'ayecode-connect'),
5387
+					'placeholder' => __('Select Template Part...', 'ayecode-connect'),
5388 5388
 					'class'       => 'bsvc_tmpl_part_n form-select-sm no-select2 mw-100',
5389 5389
 					'options'     => sd_template_part_options(),
5390 5390
 					'default'     => '',
@@ -5402,8 +5402,8 @@  discard block
 block discarded – undo
5402 5402
 				array(
5403 5403
 					'id'               => 'bsvc_message_type_n',
5404 5404
 					'name'             => 'bsvc_message_type_n',
5405
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5406
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5405
+					'label'            => __('Custom Message Type', 'ayecode-connect'),
5406
+					'placeholder'      => __('Default (none)', 'ayecode-connect'),
5407 5407
 					'class'            => 'bsvc_message_type_n form-select-sm no-select2 mw-100',
5408 5408
 					'options'          => sd_aui_colors(),
5409 5409
 					'default'          => '',
@@ -5426,7 +5426,7 @@  discard block
 block discarded – undo
5426 5426
 					'name'            => 'bsvc_message_n',
5427 5427
 					'label'           => '',
5428 5428
 					'class'           => 'bsvc_message_n form-control-sm',
5429
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5429
+					'placeholder'     => __('CUSTOM MESSAGE TO SHOW', 'ayecode-connect'),
5430 5430
 					'label_type'      => '',
5431 5431
 					'value'           => '',
5432 5432
 					'form_group_class' => ' ',
@@ -5448,7 +5448,7 @@  discard block
 block discarded – undo
5448 5448
 			global $shortcode_insert_button_once;
5449 5449
 
5450 5450
 			// Fix conflicts with UpSolution Core in header template edit element.
5451
-			if ( defined( 'US_CORE_DIR' ) && ! empty( $_REQUEST['action'] ) && $_REQUEST['action'] == 'us_ajax_hb_get_ebuilder_html' ) {
5451
+			if (defined('US_CORE_DIR') && !empty($_REQUEST['action']) && $_REQUEST['action'] == 'us_ajax_hb_get_ebuilder_html') {
5452 5452
 				$shortcode_insert_button_once = true;
5453 5453
 			}
5454 5454
 		}
Please login to merge, or discard this patch.
includes/reports/class-getpaid-reports.php 2 patches
Indentation   +100 added lines, -100 removed lines patch added patch discarded remove patch
@@ -12,49 +12,49 @@  discard block
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Reports {
14 14
 
15
-	/**
16
-	 * Class constructor.
17
-	 *
18
-	 */
19
-	public function __construct() {
20
-		add_action( 'admin_menu', array( $this, 'register_reports_page' ), 20 );
21
-		add_action( 'wpinv_reports_tab_reports', array( $this, 'display_reports_tab' ) );
22
-		add_action( 'wpinv_reports_tab_export', array( $this, 'display_exports_tab' ) );
23
-		add_action( 'getpaid_authenticated_admin_action_download_graph', array( $this, 'download_graph' ) );
24
-		add_action( 'getpaid_authenticated_admin_action_export_invoices', array( $this, 'export_invoices' ) );
25
-
26
-	}
27
-
28
-	/**
29
-	 * Registers the reports page.
30
-	 *
31
-	 */
32
-	public function register_reports_page() {
33
-
34
-		add_submenu_page(
15
+    /**
16
+     * Class constructor.
17
+     *
18
+     */
19
+    public function __construct() {
20
+        add_action( 'admin_menu', array( $this, 'register_reports_page' ), 20 );
21
+        add_action( 'wpinv_reports_tab_reports', array( $this, 'display_reports_tab' ) );
22
+        add_action( 'wpinv_reports_tab_export', array( $this, 'display_exports_tab' ) );
23
+        add_action( 'getpaid_authenticated_admin_action_download_graph', array( $this, 'download_graph' ) );
24
+        add_action( 'getpaid_authenticated_admin_action_export_invoices', array( $this, 'export_invoices' ) );
25
+
26
+    }
27
+
28
+    /**
29
+     * Registers the reports page.
30
+     *
31
+     */
32
+    public function register_reports_page() {
33
+
34
+        add_submenu_page(
35 35
             'wpinv',
36 36
             __( 'Reports', 'invoicing' ),
37 37
             __( 'Reports', 'invoicing' ),
38 38
             wpinv_get_capability(),
39 39
             'wpinv-reports',
40 40
             array( $this, 'display_reports_page' )
41
-		);
41
+        );
42 42
 
43
-	}
43
+    }
44 44
 
45
-	/**
46
-	 * Displays the reports page.
47
-	 *
48
-	 */
49
-	public function display_reports_page() {
45
+    /**
46
+     * Displays the reports page.
47
+     *
48
+     */
49
+    public function display_reports_page() {
50 50
 
51
-		// Prepare variables.
52
-		$tabs        = $this->get_tabs();
53
-		$current_tab = isset( $_GET['tab'] ) ? sanitize_text_field( $_GET['tab'] ) : 'reports';
54
-		$current_tab = array_key_exists( $current_tab, $tabs ) ? $current_tab : 'reports';
51
+        // Prepare variables.
52
+        $tabs        = $this->get_tabs();
53
+        $current_tab = isset( $_GET['tab'] ) ? sanitize_text_field( $_GET['tab'] ) : 'reports';
54
+        $current_tab = array_key_exists( $current_tab, $tabs ) ? $current_tab : 'reports';
55 55
 
56
-		// Display the current tab.
57
-		?>
56
+        // Display the current tab.
57
+        ?>
58 58
 
59 59
         <div class="wrap">
60 60
 
@@ -63,19 +63,19 @@  discard block
 block discarded – undo
63 63
 			<nav class="nav-tab-wrapper">
64 64
 
65 65
 				<?php
66
-					foreach ( $tabs as $key => $label ) {
66
+                    foreach ( $tabs as $key => $label ) {
67 67
 
68
-					$key   = sanitize_key( $key );
69
-					$label = esc_html( $label );
70
-					$class = $key == $current_tab ? 'nav-tab nav-tab-active' : 'nav-tab ';
71
-					$url   = esc_url(
68
+                    $key   = sanitize_key( $key );
69
+                    $label = esc_html( $label );
70
+                    $class = $key == $current_tab ? 'nav-tab nav-tab-active' : 'nav-tab ';
71
+                    $url   = esc_url(
72 72
                         add_query_arg( 'tab', $key, admin_url( 'admin.php?page=wpinv-reports' ) )
73 73
                     );
74 74
 
75
-				echo wp_kses_post( "\n\t\t\t<a href='$url' class='" . $class . "'>$label</a>" );
75
+                echo wp_kses_post( "\n\t\t\t<a href='$url' class='" . $class . "'>$label</a>" );
76 76
 
77
-					}
78
-				?>
77
+                    }
78
+                ?>
79 79
 
80 80
 			</nav>
81 81
 
@@ -86,82 +86,82 @@  discard block
 block discarded – undo
86 86
         </div>
87 87
 		<?php
88 88
 
89
-			// Wordfence loads an unsupported version of chart js on our page.
90
-			wp_deregister_style( 'chart-js' );
91
-			wp_deregister_script( 'chart-js' );
92
-			wp_enqueue_script( 'chart-js', WPINV_PLUGIN_URL . 'assets/js/chart.min.js', array( 'jquery' ), '3.7.1', true );
89
+            // Wordfence loads an unsupported version of chart js on our page.
90
+            wp_deregister_style( 'chart-js' );
91
+            wp_deregister_script( 'chart-js' );
92
+            wp_enqueue_script( 'chart-js', WPINV_PLUGIN_URL . 'assets/js/chart.min.js', array( 'jquery' ), '3.7.1', true );
93 93
 
94
-	}
94
+    }
95 95
 
96
-	/**
97
-	 * Retrieves reports page tabs.
98
-	 *
99
-	 * @return array
100
-	 */
101
-	public function get_tabs() {
96
+    /**
97
+     * Retrieves reports page tabs.
98
+     *
99
+     * @return array
100
+     */
101
+    public function get_tabs() {
102 102
 
103
-		$tabs = array(
104
-			'reports' => __( 'Reports', 'invoicing' ),
105
-			'export'  => __( 'Export', 'invoicing' ),
106
-		);
103
+        $tabs = array(
104
+            'reports' => __( 'Reports', 'invoicing' ),
105
+            'export'  => __( 'Export', 'invoicing' ),
106
+        );
107 107
 
108
-		return apply_filters( 'getpaid_report_tabs', $tabs );
109
-	}
108
+        return apply_filters( 'getpaid_report_tabs', $tabs );
109
+    }
110 110
 
111
-	/**
112
-	 * Displays the reports tab.
113
-	 *
114
-	 */
115
-	public function display_reports_tab() {
111
+    /**
112
+     * Displays the reports tab.
113
+     *
114
+     */
115
+    public function display_reports_tab() {
116 116
 
117
-		$reports = new GetPaid_Reports_Report();
118
-		$reports->display();
117
+        $reports = new GetPaid_Reports_Report();
118
+        $reports->display();
119 119
 
120
-	}
120
+    }
121 121
 
122
-	/**
123
-	 * Displays the exports tab.
124
-	 *
125
-	 */
126
-	public function display_exports_tab() {
122
+    /**
123
+     * Displays the exports tab.
124
+     *
125
+     */
126
+    public function display_exports_tab() {
127 127
 
128
-		$exports = new GetPaid_Reports_Export();
129
-		$exports->display();
128
+        $exports = new GetPaid_Reports_Export();
129
+        $exports->display();
130 130
 
131
-	}
131
+    }
132 132
 
133
-	/**
134
-	 * Donwnloads a graph.
135
-	 *
136
-	 * @param array $args
137
-	 */
138
-	public function download_graph( $args ) {
133
+    /**
134
+     * Donwnloads a graph.
135
+     *
136
+     * @param array $args
137
+     */
138
+    public function download_graph( $args ) {
139 139
 
140
-		if ( ! empty( $args['graph'] ) ) {
141
-			$downloader = new GetPaid_Graph_Downloader();
142
-			$downloader->download( $args['graph'] );
143
-		}
140
+        if ( ! empty( $args['graph'] ) ) {
141
+            $downloader = new GetPaid_Graph_Downloader();
142
+            $downloader->download( $args['graph'] );
143
+        }
144 144
 
145
-	}
145
+    }
146 146
 
147
-	/**
148
-	 * Exports invoices.
149
-	 *
150
-	 * @param array $args
151
-	 */
152
-	public function export_invoices( $args ) {
147
+    /**
148
+     * Exports invoices.
149
+     *
150
+     * @param array $args
151
+     */
152
+    public function export_invoices( $args ) {
153 153
 
154
-		if ( ! empty( $args['post_type'] ) ) {
154
+        if ( ! empty( $args['post_type'] ) ) {
155 155
 
156
-			if ( 'subscriptions' === $args['post_type'] ) {
157
-				$downloader = new GetPaid_Subscription_Exporter();
158
-			} else {
159
-				$downloader = new GetPaid_Invoice_Exporter();
160
-			}
156
+            if ( 'subscriptions' === $args['post_type'] ) {
157
+                $downloader = new GetPaid_Subscription_Exporter();
158
+            } else {
159
+                $downloader = new GetPaid_Invoice_Exporter();
160
+            }
161 161
 
162
-			$downloader->export( $args['post_type'], $args );
163
-		}
162
+            $downloader->export( $args['post_type'], $args );
163
+        }
164 164
 
165
-	}
165
+    }
166 166
 
167 167
 }
Please login to merge, or discard this patch.
Spacing   +32 added lines, -32 removed lines patch added patch discarded remove patch
@@ -5,7 +5,7 @@  discard block
 block discarded – undo
5 5
  *
6 6
  */
7 7
 
8
-defined( 'ABSPATH' ) || exit;
8
+defined('ABSPATH') || exit;
9 9
 
10 10
 /**
11 11
  * GetPaid_Reports Class.
@@ -17,11 +17,11 @@  discard block
 block discarded – undo
17 17
 	 *
18 18
 	 */
19 19
 	public function __construct() {
20
-		add_action( 'admin_menu', array( $this, 'register_reports_page' ), 20 );
21
-		add_action( 'wpinv_reports_tab_reports', array( $this, 'display_reports_tab' ) );
22
-		add_action( 'wpinv_reports_tab_export', array( $this, 'display_exports_tab' ) );
23
-		add_action( 'getpaid_authenticated_admin_action_download_graph', array( $this, 'download_graph' ) );
24
-		add_action( 'getpaid_authenticated_admin_action_export_invoices', array( $this, 'export_invoices' ) );
20
+		add_action('admin_menu', array($this, 'register_reports_page'), 20);
21
+		add_action('wpinv_reports_tab_reports', array($this, 'display_reports_tab'));
22
+		add_action('wpinv_reports_tab_export', array($this, 'display_exports_tab'));
23
+		add_action('getpaid_authenticated_admin_action_download_graph', array($this, 'download_graph'));
24
+		add_action('getpaid_authenticated_admin_action_export_invoices', array($this, 'export_invoices'));
25 25
 
26 26
 	}
27 27
 
@@ -33,11 +33,11 @@  discard block
 block discarded – undo
33 33
 
34 34
 		add_submenu_page(
35 35
             'wpinv',
36
-            __( 'Reports', 'invoicing' ),
37
-            __( 'Reports', 'invoicing' ),
36
+            __('Reports', 'invoicing'),
37
+            __('Reports', 'invoicing'),
38 38
             wpinv_get_capability(),
39 39
             'wpinv-reports',
40
-            array( $this, 'display_reports_page' )
40
+            array($this, 'display_reports_page')
41 41
 		);
42 42
 
43 43
 	}
@@ -50,46 +50,46 @@  discard block
 block discarded – undo
50 50
 
51 51
 		// Prepare variables.
52 52
 		$tabs        = $this->get_tabs();
53
-		$current_tab = isset( $_GET['tab'] ) ? sanitize_text_field( $_GET['tab'] ) : 'reports';
54
-		$current_tab = array_key_exists( $current_tab, $tabs ) ? $current_tab : 'reports';
53
+		$current_tab = isset($_GET['tab']) ? sanitize_text_field($_GET['tab']) : 'reports';
54
+		$current_tab = array_key_exists($current_tab, $tabs) ? $current_tab : 'reports';
55 55
 
56 56
 		// Display the current tab.
57 57
 		?>
58 58
 
59 59
         <div class="wrap">
60 60
 
61
-			<h1><?php echo esc_html( $tabs[ $current_tab ] ); ?></h1>
61
+			<h1><?php echo esc_html($tabs[$current_tab]); ?></h1>
62 62
 
63 63
 			<nav class="nav-tab-wrapper">
64 64
 
65 65
 				<?php
66
-					foreach ( $tabs as $key => $label ) {
66
+					foreach ($tabs as $key => $label) {
67 67
 
68
-					$key   = sanitize_key( $key );
69
-					$label = esc_html( $label );
68
+					$key   = sanitize_key($key);
69
+					$label = esc_html($label);
70 70
 					$class = $key == $current_tab ? 'nav-tab nav-tab-active' : 'nav-tab ';
71 71
 					$url   = esc_url(
72
-                        add_query_arg( 'tab', $key, admin_url( 'admin.php?page=wpinv-reports' ) )
72
+                        add_query_arg('tab', $key, admin_url('admin.php?page=wpinv-reports'))
73 73
                     );
74 74
 
75
-				echo wp_kses_post( "\n\t\t\t<a href='$url' class='" . $class . "'>$label</a>" );
75
+				echo wp_kses_post("\n\t\t\t<a href='$url' class='" . $class . "'>$label</a>");
76 76
 
77 77
 					}
78 78
 				?>
79 79
 
80 80
 			</nav>
81 81
 
82
-			<div class="bsui <?php echo esc_attr( $current_tab ); ?>">
83
-				<?php do_action( "wpinv_reports_tab_{$current_tab}" ); ?>
82
+			<div class="bsui <?php echo esc_attr($current_tab); ?>">
83
+				<?php do_action("wpinv_reports_tab_{$current_tab}"); ?>
84 84
 			</div>
85 85
 
86 86
         </div>
87 87
 		<?php
88 88
 
89 89
 			// Wordfence loads an unsupported version of chart js on our page.
90
-			wp_deregister_style( 'chart-js' );
91
-			wp_deregister_script( 'chart-js' );
92
-			wp_enqueue_script( 'chart-js', WPINV_PLUGIN_URL . 'assets/js/chart.min.js', array( 'jquery' ), '3.7.1', true );
90
+			wp_deregister_style('chart-js');
91
+			wp_deregister_script('chart-js');
92
+			wp_enqueue_script('chart-js', WPINV_PLUGIN_URL . 'assets/js/chart.min.js', array('jquery'), '3.7.1', true);
93 93
 
94 94
 	}
95 95
 
@@ -101,11 +101,11 @@  discard block
 block discarded – undo
101 101
 	public function get_tabs() {
102 102
 
103 103
 		$tabs = array(
104
-			'reports' => __( 'Reports', 'invoicing' ),
105
-			'export'  => __( 'Export', 'invoicing' ),
104
+			'reports' => __('Reports', 'invoicing'),
105
+			'export'  => __('Export', 'invoicing'),
106 106
 		);
107 107
 
108
-		return apply_filters( 'getpaid_report_tabs', $tabs );
108
+		return apply_filters('getpaid_report_tabs', $tabs);
109 109
 	}
110 110
 
111 111
 	/**
@@ -135,11 +135,11 @@  discard block
 block discarded – undo
135 135
 	 *
136 136
 	 * @param array $args
137 137
 	 */
138
-	public function download_graph( $args ) {
138
+	public function download_graph($args) {
139 139
 
140
-		if ( ! empty( $args['graph'] ) ) {
140
+		if (!empty($args['graph'])) {
141 141
 			$downloader = new GetPaid_Graph_Downloader();
142
-			$downloader->download( $args['graph'] );
142
+			$downloader->download($args['graph']);
143 143
 		}
144 144
 
145 145
 	}
@@ -149,17 +149,17 @@  discard block
 block discarded – undo
149 149
 	 *
150 150
 	 * @param array $args
151 151
 	 */
152
-	public function export_invoices( $args ) {
152
+	public function export_invoices($args) {
153 153
 
154
-		if ( ! empty( $args['post_type'] ) ) {
154
+		if (!empty($args['post_type'])) {
155 155
 
156
-			if ( 'subscriptions' === $args['post_type'] ) {
156
+			if ('subscriptions' === $args['post_type']) {
157 157
 				$downloader = new GetPaid_Subscription_Exporter();
158 158
 			} else {
159 159
 				$downloader = new GetPaid_Invoice_Exporter();
160 160
 			}
161 161
 
162
-			$downloader->export( $args['post_type'], $args );
162
+			$downloader->export($args['post_type'], $args);
163 163
 		}
164 164
 
165 165
 	}
Please login to merge, or discard this patch.
includes/class-getpaid-daily-maintenance.php 2 patches
Indentation   +137 added lines, -137 removed lines patch added patch discarded remove patch
@@ -12,142 +12,142 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Daily_Maintenance {
14 14
 
15
-	/**
16
-	 * Class constructor.
17
-	 */
18
-	public function __construct() {
19
-
20
-		// Clear deprecated events.
21
-		add_action( 'wp', array( $this, 'maybe_clear_deprecated_events' ) );
22
-
23
-		// (Maybe) schedule a cron that runs daily.
24
-		add_action( 'wp', array( $this, 'maybe_create_scheduled_event' ) );
25
-
26
-		// Fired everyday at 7 a.m (this might vary for sites with few visitors)
27
-		add_action( 'getpaid_daily_maintenance', array( $this, 'log_cron_run' ) );
28
-		add_action( 'getpaid_daily_maintenance', array( $this, 'backwards_compat' ) );
29
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_expire_subscriptions' ) );
30
-		add_action( 'getpaid_daily_maintenance', array( $this, 'check_renewing_subscriptions' ) );
31
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_update_geoip_databases' ) );
32
-
33
-	}
34
-
35
-	/**
36
-	 * Schedules a cron to run every day at 7 a.m
37
-	 *
38
-	 */
39
-	public function maybe_create_scheduled_event() {
40
-
41
-		if ( ! wp_next_scheduled( 'getpaid_daily_maintenance' ) ) {
42
-			$timestamp = strtotime( 'tomorrow 07:00:00', current_time( 'timestamp' ) );
43
-			wp_schedule_event( $timestamp, 'daily', 'getpaid_daily_maintenance' );
44
-		}
45
-
46
-	}
47
-
48
-	/**
49
-	 * Clears deprecated events.
50
-	 *
51
-	 */
52
-	public function maybe_clear_deprecated_events() {
53
-
54
-		if ( ! get_option( 'wpinv_cleared_old_events' ) ) {
55
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_twicedaily' );
56
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_daily' );
57
-			update_option( 'wpinv_cleared_old_events', 1 );
58
-		}
59
-
60
-	}
61
-
62
-	/**
63
-	 * Fires the old hook for backwards compatibility.
64
-	 *
65
-	 */
66
-	public function backwards_compat() {
67
-		do_action( 'wpinv_register_schedule_event_daily' );
68
-	}
69
-
70
-	/**
71
-	 * Checks for subscriptions that are scheduled to renew.
72
-	 *
73
-	 */
74
-	public function check_renewing_subscriptions() {
75
-
76
-		// Fetch subscriptions that expire today.
77
-		$args  = array(
78
-			'number'             => -1,
79
-			'count_total'        => false,
80
-			'status'             => 'trialling active',
81
-			'date_expires_query' => array(
82
-				array(
83
-					'year'    => gmdate( 'Y' ),
84
-					'month'   => gmdate( 'n' ),
85
-					'day'     => gmdate( 'j' ),
86
-					'compare' => '=',
87
-				),
88
-			),
89
-		);
90
-
91
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
92
-
93
-		foreach ( $subscriptions->get_results() as $subscription ) {
94
-			/** @var WPInv_Subscription $subscription */
95
-			if ( $subscription->is_last_renewal() ) {
96
-				$subscription->complete();
97
-			} else {
98
-				do_action( 'getpaid_should_renew_subscription', $subscription, $subscription->get_parent_invoice() );
99
-			}
100
-		}
101
-	}
102
-
103
-	/**
104
-	 * Expires expired subscriptions.
105
-	 *
106
-	 */
107
-	public function maybe_expire_subscriptions() {
108
-
109
-		// Fetch expired subscriptions (skips those that expire today).
110
-		$args  = array(
111
-			'number'             => -1,
112
-			'count_total'        => false,
113
-			'status'             => 'trialling active failing cancelled',
114
-			'date_expires_query' => array(
115
-				'before'    => 'yesterday',
116
-				'inclusive' => false,
117
-			),
118
-		);
119
-
120
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
121
-
122
-		foreach ( $subscriptions->get_results() as $subscription ) {
123
-			if ( apply_filters( 'getpaid_daily_maintenance_should_expire_subscription', false, $subscription ) ) {
124
-				$subscription->set_status( 'expired' );
125
-				$subscription->save();
126
-			}
127
-		}
128
-
129
-	}
130
-
131
-	/**
132
-	 * Logs cron runs.
133
-	 *
134
-	 */
135
-	public function log_cron_run() {
136
-		wpinv_error_log( 'GetPaid Daily Cron', false );
137
-	}
138
-
139
-	/**
140
-	 * Updates GeoIP databases.
141
-	 *
142
-	 */
143
-	public function maybe_update_geoip_databases() {
144
-		$updated = get_transient( 'getpaid_updated_geoip_databases' );
145
-
146
-		if ( false === $updated ) {
147
-			set_transient( 'getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS );
148
-			do_action( 'getpaid_update_geoip_databases' );
149
-		}
150
-
151
-	}
15
+    /**
16
+     * Class constructor.
17
+     */
18
+    public function __construct() {
19
+
20
+        // Clear deprecated events.
21
+        add_action( 'wp', array( $this, 'maybe_clear_deprecated_events' ) );
22
+
23
+        // (Maybe) schedule a cron that runs daily.
24
+        add_action( 'wp', array( $this, 'maybe_create_scheduled_event' ) );
25
+
26
+        // Fired everyday at 7 a.m (this might vary for sites with few visitors)
27
+        add_action( 'getpaid_daily_maintenance', array( $this, 'log_cron_run' ) );
28
+        add_action( 'getpaid_daily_maintenance', array( $this, 'backwards_compat' ) );
29
+        add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_expire_subscriptions' ) );
30
+        add_action( 'getpaid_daily_maintenance', array( $this, 'check_renewing_subscriptions' ) );
31
+        add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_update_geoip_databases' ) );
32
+
33
+    }
34
+
35
+    /**
36
+     * Schedules a cron to run every day at 7 a.m
37
+     *
38
+     */
39
+    public function maybe_create_scheduled_event() {
40
+
41
+        if ( ! wp_next_scheduled( 'getpaid_daily_maintenance' ) ) {
42
+            $timestamp = strtotime( 'tomorrow 07:00:00', current_time( 'timestamp' ) );
43
+            wp_schedule_event( $timestamp, 'daily', 'getpaid_daily_maintenance' );
44
+        }
45
+
46
+    }
47
+
48
+    /**
49
+     * Clears deprecated events.
50
+     *
51
+     */
52
+    public function maybe_clear_deprecated_events() {
53
+
54
+        if ( ! get_option( 'wpinv_cleared_old_events' ) ) {
55
+            wp_clear_scheduled_hook( 'wpinv_register_schedule_event_twicedaily' );
56
+            wp_clear_scheduled_hook( 'wpinv_register_schedule_event_daily' );
57
+            update_option( 'wpinv_cleared_old_events', 1 );
58
+        }
59
+
60
+    }
61
+
62
+    /**
63
+     * Fires the old hook for backwards compatibility.
64
+     *
65
+     */
66
+    public function backwards_compat() {
67
+        do_action( 'wpinv_register_schedule_event_daily' );
68
+    }
69
+
70
+    /**
71
+     * Checks for subscriptions that are scheduled to renew.
72
+     *
73
+     */
74
+    public function check_renewing_subscriptions() {
75
+
76
+        // Fetch subscriptions that expire today.
77
+        $args  = array(
78
+            'number'             => -1,
79
+            'count_total'        => false,
80
+            'status'             => 'trialling active',
81
+            'date_expires_query' => array(
82
+                array(
83
+                    'year'    => gmdate( 'Y' ),
84
+                    'month'   => gmdate( 'n' ),
85
+                    'day'     => gmdate( 'j' ),
86
+                    'compare' => '=',
87
+                ),
88
+            ),
89
+        );
90
+
91
+        $subscriptions = new GetPaid_Subscriptions_Query( $args );
92
+
93
+        foreach ( $subscriptions->get_results() as $subscription ) {
94
+            /** @var WPInv_Subscription $subscription */
95
+            if ( $subscription->is_last_renewal() ) {
96
+                $subscription->complete();
97
+            } else {
98
+                do_action( 'getpaid_should_renew_subscription', $subscription, $subscription->get_parent_invoice() );
99
+            }
100
+        }
101
+    }
102
+
103
+    /**
104
+     * Expires expired subscriptions.
105
+     *
106
+     */
107
+    public function maybe_expire_subscriptions() {
108
+
109
+        // Fetch expired subscriptions (skips those that expire today).
110
+        $args  = array(
111
+            'number'             => -1,
112
+            'count_total'        => false,
113
+            'status'             => 'trialling active failing cancelled',
114
+            'date_expires_query' => array(
115
+                'before'    => 'yesterday',
116
+                'inclusive' => false,
117
+            ),
118
+        );
119
+
120
+        $subscriptions = new GetPaid_Subscriptions_Query( $args );
121
+
122
+        foreach ( $subscriptions->get_results() as $subscription ) {
123
+            if ( apply_filters( 'getpaid_daily_maintenance_should_expire_subscription', false, $subscription ) ) {
124
+                $subscription->set_status( 'expired' );
125
+                $subscription->save();
126
+            }
127
+        }
128
+
129
+    }
130
+
131
+    /**
132
+     * Logs cron runs.
133
+     *
134
+     */
135
+    public function log_cron_run() {
136
+        wpinv_error_log( 'GetPaid Daily Cron', false );
137
+    }
138
+
139
+    /**
140
+     * Updates GeoIP databases.
141
+     *
142
+     */
143
+    public function maybe_update_geoip_databases() {
144
+        $updated = get_transient( 'getpaid_updated_geoip_databases' );
145
+
146
+        if ( false === $updated ) {
147
+            set_transient( 'getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS );
148
+            do_action( 'getpaid_update_geoip_databases' );
149
+        }
150
+
151
+    }
152 152
 
153 153
 }
Please login to merge, or discard this patch.
Spacing   +34 added lines, -34 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
  * Daily maintenance class.
@@ -18,17 +18,17 @@  discard block
 block discarded – undo
18 18
 	public function __construct() {
19 19
 
20 20
 		// Clear deprecated events.
21
-		add_action( 'wp', array( $this, 'maybe_clear_deprecated_events' ) );
21
+		add_action('wp', array($this, 'maybe_clear_deprecated_events'));
22 22
 
23 23
 		// (Maybe) schedule a cron that runs daily.
24
-		add_action( 'wp', array( $this, 'maybe_create_scheduled_event' ) );
24
+		add_action('wp', array($this, 'maybe_create_scheduled_event'));
25 25
 
26 26
 		// Fired everyday at 7 a.m (this might vary for sites with few visitors)
27
-		add_action( 'getpaid_daily_maintenance', array( $this, 'log_cron_run' ) );
28
-		add_action( 'getpaid_daily_maintenance', array( $this, 'backwards_compat' ) );
29
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_expire_subscriptions' ) );
30
-		add_action( 'getpaid_daily_maintenance', array( $this, 'check_renewing_subscriptions' ) );
31
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_update_geoip_databases' ) );
27
+		add_action('getpaid_daily_maintenance', array($this, 'log_cron_run'));
28
+		add_action('getpaid_daily_maintenance', array($this, 'backwards_compat'));
29
+		add_action('getpaid_daily_maintenance', array($this, 'maybe_expire_subscriptions'));
30
+		add_action('getpaid_daily_maintenance', array($this, 'check_renewing_subscriptions'));
31
+		add_action('getpaid_daily_maintenance', array($this, 'maybe_update_geoip_databases'));
32 32
 
33 33
 	}
34 34
 
@@ -38,9 +38,9 @@  discard block
 block discarded – undo
38 38
 	 */
39 39
 	public function maybe_create_scheduled_event() {
40 40
 
41
-		if ( ! wp_next_scheduled( 'getpaid_daily_maintenance' ) ) {
42
-			$timestamp = strtotime( 'tomorrow 07:00:00', current_time( 'timestamp' ) );
43
-			wp_schedule_event( $timestamp, 'daily', 'getpaid_daily_maintenance' );
41
+		if (!wp_next_scheduled('getpaid_daily_maintenance')) {
42
+			$timestamp = strtotime('tomorrow 07:00:00', current_time('timestamp'));
43
+			wp_schedule_event($timestamp, 'daily', 'getpaid_daily_maintenance');
44 44
 		}
45 45
 
46 46
 	}
@@ -51,10 +51,10 @@  discard block
 block discarded – undo
51 51
 	 */
52 52
 	public function maybe_clear_deprecated_events() {
53 53
 
54
-		if ( ! get_option( 'wpinv_cleared_old_events' ) ) {
55
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_twicedaily' );
56
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_daily' );
57
-			update_option( 'wpinv_cleared_old_events', 1 );
54
+		if (!get_option('wpinv_cleared_old_events')) {
55
+			wp_clear_scheduled_hook('wpinv_register_schedule_event_twicedaily');
56
+			wp_clear_scheduled_hook('wpinv_register_schedule_event_daily');
57
+			update_option('wpinv_cleared_old_events', 1);
58 58
 		}
59 59
 
60 60
 	}
@@ -64,7 +64,7 @@  discard block
 block discarded – undo
64 64
 	 *
65 65
 	 */
66 66
 	public function backwards_compat() {
67
-		do_action( 'wpinv_register_schedule_event_daily' );
67
+		do_action('wpinv_register_schedule_event_daily');
68 68
 	}
69 69
 
70 70
 	/**
@@ -74,28 +74,28 @@  discard block
 block discarded – undo
74 74
 	public function check_renewing_subscriptions() {
75 75
 
76 76
 		// Fetch subscriptions that expire today.
77
-		$args  = array(
77
+		$args = array(
78 78
 			'number'             => -1,
79 79
 			'count_total'        => false,
80 80
 			'status'             => 'trialling active',
81 81
 			'date_expires_query' => array(
82 82
 				array(
83
-					'year'    => gmdate( 'Y' ),
84
-					'month'   => gmdate( 'n' ),
85
-					'day'     => gmdate( 'j' ),
83
+					'year'    => gmdate('Y'),
84
+					'month'   => gmdate('n'),
85
+					'day'     => gmdate('j'),
86 86
 					'compare' => '=',
87 87
 				),
88 88
 			),
89 89
 		);
90 90
 
91
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
91
+		$subscriptions = new GetPaid_Subscriptions_Query($args);
92 92
 
93
-		foreach ( $subscriptions->get_results() as $subscription ) {
93
+		foreach ($subscriptions->get_results() as $subscription) {
94 94
 			/** @var WPInv_Subscription $subscription */
95
-			if ( $subscription->is_last_renewal() ) {
95
+			if ($subscription->is_last_renewal()) {
96 96
 				$subscription->complete();
97 97
 			} else {
98
-				do_action( 'getpaid_should_renew_subscription', $subscription, $subscription->get_parent_invoice() );
98
+				do_action('getpaid_should_renew_subscription', $subscription, $subscription->get_parent_invoice());
99 99
 			}
100 100
 		}
101 101
 	}
@@ -107,7 +107,7 @@  discard block
 block discarded – undo
107 107
 	public function maybe_expire_subscriptions() {
108 108
 
109 109
 		// Fetch expired subscriptions (skips those that expire today).
110
-		$args  = array(
110
+		$args = array(
111 111
 			'number'             => -1,
112 112
 			'count_total'        => false,
113 113
 			'status'             => 'trialling active failing cancelled',
@@ -117,11 +117,11 @@  discard block
 block discarded – undo
117 117
 			),
118 118
 		);
119 119
 
120
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
120
+		$subscriptions = new GetPaid_Subscriptions_Query($args);
121 121
 
122
-		foreach ( $subscriptions->get_results() as $subscription ) {
123
-			if ( apply_filters( 'getpaid_daily_maintenance_should_expire_subscription', false, $subscription ) ) {
124
-				$subscription->set_status( 'expired' );
122
+		foreach ($subscriptions->get_results() as $subscription) {
123
+			if (apply_filters('getpaid_daily_maintenance_should_expire_subscription', false, $subscription)) {
124
+				$subscription->set_status('expired');
125 125
 				$subscription->save();
126 126
 			}
127 127
 		}
@@ -133,7 +133,7 @@  discard block
 block discarded – undo
133 133
 	 *
134 134
 	 */
135 135
 	public function log_cron_run() {
136
-		wpinv_error_log( 'GetPaid Daily Cron', false );
136
+		wpinv_error_log('GetPaid Daily Cron', false);
137 137
 	}
138 138
 
139 139
 	/**
@@ -141,11 +141,11 @@  discard block
 block discarded – undo
141 141
 	 *
142 142
 	 */
143 143
 	public function maybe_update_geoip_databases() {
144
-		$updated = get_transient( 'getpaid_updated_geoip_databases' );
144
+		$updated = get_transient('getpaid_updated_geoip_databases');
145 145
 
146
-		if ( false === $updated ) {
147
-			set_transient( 'getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS );
148
-			do_action( 'getpaid_update_geoip_databases' );
146
+		if (false === $updated) {
147
+			set_transient('getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS);
148
+			do_action('getpaid_update_geoip_databases');
149 149
 		}
150 150
 
151 151
 	}
Please login to merge, or discard this patch.
includes/gateways/class-getpaid-manual-gateway.php 2 patches
Indentation   +52 added lines, -52 removed lines patch added patch discarded remove patch
@@ -13,17 +13,17 @@  discard block
 block discarded – undo
13 13
 class GetPaid_Manual_Gateway extends GetPaid_Payment_Gateway {
14 14
 
15 15
     /**
16
-	 * Payment method id.
17
-	 *
18
-	 * @var string
19
-	 */
16
+     * Payment method id.
17
+     *
18
+     * @var string
19
+     */
20 20
     public $id = 'manual';
21 21
 
22 22
     /**
23
-	 * An array of features that this gateway supports.
24
-	 *
25
-	 * @var array
26
-	 */
23
+     * An array of features that this gateway supports.
24
+     *
25
+     * @var array
26
+     */
27 27
     protected $supports = array(
28 28
         'subscription',
29 29
         'addons',
@@ -34,16 +34,16 @@  discard block
 block discarded – undo
34 34
     );
35 35
 
36 36
     /**
37
-	 * Payment method order.
38
-	 *
39
-	 * @var int
40
-	 */
41
-	public $order = 11;
37
+     * Payment method order.
38
+     *
39
+     * @var int
40
+     */
41
+    public $order = 11;
42 42
 
43 43
     /**
44
-	 * Class constructor.
45
-	 */
46
-	public function __construct() {
44
+     * Class constructor.
45
+     */
46
+    public function __construct() {
47 47
         parent::__construct();
48 48
 
49 49
         $this->title        = __( 'Test Gateway', 'invoicing' );
@@ -53,15 +53,15 @@  discard block
 block discarded – undo
53 53
     }
54 54
 
55 55
     /**
56
-	 * Process Payment.
57
-	 *
58
-	 *
59
-	 * @param WPInv_Invoice $invoice Invoice.
60
-	 * @param array $submission_data Posted checkout fields.
61
-	 * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
62
-	 * @return array
63
-	 */
64
-	public function process_payment( $invoice, $submission_data, $submission ) {
56
+     * Process Payment.
57
+     *
58
+     *
59
+     * @param WPInv_Invoice $invoice Invoice.
60
+     * @param array $submission_data Posted checkout fields.
61
+     * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
62
+     * @return array
63
+     */
64
+    public function process_payment( $invoice, $submission_data, $submission ) {
65 65
 
66 66
         // Mark it as paid.
67 67
         $invoice->mark_paid();
@@ -90,35 +90,35 @@  discard block
 block discarded – undo
90 90
 
91 91
     }
92 92
 
93
-	/**
94
-	 * (Maybe) renews a manual subscription profile.
95
-	 *
96
-	 *
97
-	 * @param WPInv_Subscription $subscription
98
-	 */
99
-	public function maybe_renew_subscription( $subscription, $parent_invoice ) {
100
-		// Ensure its our subscription && it's active.
101
-		if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
102
-			// Renew the subscription.
103
-			$subscription->add_payment(
104
-				array(
105
-					'transaction_id' => $subscription->get_parent_payment()->generate_key(),
106
-					'gateway'        => $this->id,
107
-				)
108
-			);
109
-
110
-			$subscription->renew();
111
-		}
112
-	}
93
+    /**
94
+     * (Maybe) renews a manual subscription profile.
95
+     *
96
+     *
97
+     * @param WPInv_Subscription $subscription
98
+     */
99
+    public function maybe_renew_subscription( $subscription, $parent_invoice ) {
100
+        // Ensure its our subscription && it's active.
101
+        if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
102
+            // Renew the subscription.
103
+            $subscription->add_payment(
104
+                array(
105
+                    'transaction_id' => $subscription->get_parent_payment()->generate_key(),
106
+                    'gateway'        => $this->id,
107
+                )
108
+            );
109
+
110
+            $subscription->renew();
111
+        }
112
+    }
113 113
 
114 114
     /**
115
-	 * Processes invoice addons.
116
-	 *
117
-	 * @param WPInv_Invoice $invoice
118
-	 * @param GetPaid_Form_Item[] $items
119
-	 * @return WPInv_Invoice
120
-	 */
121
-	public function process_addons( $invoice, $items ) {
115
+     * Processes invoice addons.
116
+     *
117
+     * @param WPInv_Invoice $invoice
118
+     * @param GetPaid_Form_Item[] $items
119
+     * @return WPInv_Invoice
120
+     */
121
+    public function process_addons( $invoice, $items ) {
122 122
 
123 123
         foreach ( $items as $item ) {
124 124
             $invoice->add_item( $item );
Please login to merge, or discard this patch.
Spacing   +21 added lines, -21 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
  * Manual Payment Gateway class.
@@ -46,10 +46,10 @@  discard block
 block discarded – undo
46 46
 	public function __construct() {
47 47
         parent::__construct();
48 48
 
49
-        $this->title        = __( 'Test Gateway', 'invoicing' );
50
-        $this->method_title = __( 'Test Gateway', 'invoicing' );
49
+        $this->title        = __('Test Gateway', 'invoicing');
50
+        $this->method_title = __('Test Gateway', 'invoicing');
51 51
 
52
-        add_action( 'getpaid_should_renew_subscription', array( $this, 'maybe_renew_subscription' ), 10, 2 );
52
+        add_action('getpaid_should_renew_subscription', array($this, 'maybe_renew_subscription'), 10, 2);
53 53
     }
54 54
 
55 55
     /**
@@ -61,32 +61,32 @@  discard block
 block discarded – undo
61 61
 	 * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
62 62
 	 * @return array
63 63
 	 */
64
-	public function process_payment( $invoice, $submission_data, $submission ) {
64
+	public function process_payment($invoice, $submission_data, $submission) {
65 65
 
66 66
         // Mark it as paid.
67 67
         $invoice->mark_paid();
68 68
 
69 69
         // (Maybe) activate subscriptions.
70
-        $subscriptions = getpaid_get_invoice_subscriptions( $invoice );
70
+        $subscriptions = getpaid_get_invoice_subscriptions($invoice);
71 71
 
72
-        if ( ! empty( $subscriptions ) ) {
73
-            $subscriptions = is_array( $subscriptions ) ? $subscriptions : array( $subscriptions );
72
+        if (!empty($subscriptions)) {
73
+            $subscriptions = is_array($subscriptions) ? $subscriptions : array($subscriptions);
74 74
 
75
-            foreach ( $subscriptions as $subscription ) {
76
-                if ( $subscription->exists() ) {
77
-                    $duration = strtotime( $subscription->get_expiration() ) - strtotime( $subscription->get_date_created() );
78
-                    $expiry   = gmdate( 'Y-m-d H:i:s', ( current_time( 'timestamp' ) + $duration ) );
75
+            foreach ($subscriptions as $subscription) {
76
+                if ($subscription->exists()) {
77
+                    $duration = strtotime($subscription->get_expiration()) - strtotime($subscription->get_date_created());
78
+                    $expiry   = gmdate('Y-m-d H:i:s', (current_time('timestamp') + $duration));
79 79
 
80
-                    $subscription->set_next_renewal_date( $expiry );
81
-                    $subscription->set_date_created( current_time( 'mysql' ) );
82
-                    $subscription->set_profile_id( $invoice->generate_key( 'manual_sub_' . $invoice->get_id() . '_' . $subscription->get_id() ) );
80
+                    $subscription->set_next_renewal_date($expiry);
81
+                    $subscription->set_date_created(current_time('mysql'));
82
+                    $subscription->set_profile_id($invoice->generate_key('manual_sub_' . $invoice->get_id() . '_' . $subscription->get_id()));
83 83
                     $subscription->activate();
84 84
                 }
85 85
             }
86 86
         }
87 87
 
88 88
         // Send to the success page.
89
-        wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
89
+        wpinv_send_to_success_page(array('invoice_key' => $invoice->get_key()));
90 90
 
91 91
     }
92 92
 
@@ -96,9 +96,9 @@  discard block
 block discarded – undo
96 96
 	 *
97 97
 	 * @param WPInv_Subscription $subscription
98 98
 	 */
99
-	public function maybe_renew_subscription( $subscription, $parent_invoice ) {
99
+	public function maybe_renew_subscription($subscription, $parent_invoice) {
100 100
 		// Ensure its our subscription && it's active.
101
-		if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
101
+		if (!empty($parent_invoice) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status('active trialling')) {
102 102
 			// Renew the subscription.
103 103
 			$subscription->add_payment(
104 104
 				array(
@@ -118,10 +118,10 @@  discard block
 block discarded – undo
118 118
 	 * @param GetPaid_Form_Item[] $items
119 119
 	 * @return WPInv_Invoice
120 120
 	 */
121
-	public function process_addons( $invoice, $items ) {
121
+	public function process_addons($invoice, $items) {
122 122
 
123
-        foreach ( $items as $item ) {
124
-            $invoice->add_item( $item );
123
+        foreach ($items as $item) {
124
+            $invoice->add_item($item);
125 125
         }
126 126
 
127 127
         $invoice->recalculate_total();
Please login to merge, or discard this patch.
includes/gateways/class-getpaid-authorize-net-gateway.php 2 patches
Indentation   +237 added lines, -237 removed lines patch added patch discarded remove patch
@@ -13,17 +13,17 @@  discard block
 block discarded – undo
13 13
 class GetPaid_Authorize_Net_Gateway extends GetPaid_Authorize_Net_Legacy_Gateway {
14 14
 
15 15
     /**
16
-	 * Payment method id.
17
-	 *
18
-	 * @var string
19
-	 */
16
+     * Payment method id.
17
+     *
18
+     * @var string
19
+     */
20 20
     public $id = 'authorizenet';
21 21
 
22 22
     /**
23
-	 * An array of features that this gateway supports.
24
-	 *
25
-	 * @var array
26
-	 */
23
+     * An array of features that this gateway supports.
24
+     *
25
+     * @var array
26
+     */
27 27
     protected $supports = array(
28 28
         'subscription',
29 29
         'sandbox',
@@ -36,44 +36,44 @@  discard block
 block discarded – undo
36 36
     );
37 37
 
38 38
     /**
39
-	 * Payment method order.
40
-	 *
41
-	 * @var int
42
-	 */
39
+     * Payment method order.
40
+     *
41
+     * @var int
42
+     */
43 43
     public $order = 4;
44 44
 
45 45
     /**
46
-	 * Endpoint for requests from Authorize.net.
47
-	 *
48
-	 * @var string
49
-	 */
50
-	protected $notify_url;
51
-
52
-	/**
53
-	 * Endpoint for requests to Authorize.net.
54
-	 *
55
-	 * @var string
56
-	 */
46
+     * Endpoint for requests from Authorize.net.
47
+     *
48
+     * @var string
49
+     */
50
+    protected $notify_url;
51
+
52
+    /**
53
+     * Endpoint for requests to Authorize.net.
54
+     *
55
+     * @var string
56
+     */
57 57
     protected $endpoint;
58 58
 
59 59
     /**
60
-	 * Currencies this gateway is allowed for.
61
-	 *
62
-	 * @var array
63
-	 */
64
-	public $currencies = array( 'USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD' );
60
+     * Currencies this gateway is allowed for.
61
+     *
62
+     * @var array
63
+     */
64
+    public $currencies = array( 'USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD' );
65 65
 
66 66
     /**
67
-	 * URL to view a transaction.
68
-	 *
69
-	 * @var string
70
-	 */
67
+     * URL to view a transaction.
68
+     *
69
+     * @var string
70
+     */
71 71
     public $view_transaction_url = 'https://{sandbox}authorize.net/ui/themes/sandbox/Transaction/TransactionReceipt.aspx?transid=%s';
72 72
 
73 73
     /**
74
-	 * Class constructor.
75
-	 */
76
-	public function __construct() {
74
+     * Class constructor.
75
+     */
76
+    public function __construct() {
77 77
 
78 78
         $this->title                = __( 'Credit Card / Debit Card', 'invoicing' );
79 79
         $this->method_title         = __( 'Authorize.Net', 'invoicing' );
@@ -85,11 +85,11 @@  discard block
 block discarded – undo
85 85
     }
86 86
 
87 87
     /**
88
-	 * Displays the payment method select field.
89
-	 *
90
-	 * @param int $invoice_id 0 or invoice id.
91
-	 * @param GetPaid_Payment_Form $form Current payment form.
92
-	 */
88
+     * Displays the payment method select field.
89
+     *
90
+     * @param int $invoice_id 0 or invoice id.
91
+     * @param GetPaid_Payment_Form $form Current payment form.
92
+     */
93 93
     public function payment_fields( $invoice_id, $form ) {
94 94
 
95 95
         // Let the user select a payment method.
@@ -100,16 +100,16 @@  discard block
 block discarded – undo
100 100
     }
101 101
 
102 102
     /**
103
-	 * Creates a customer profile.
104
-	 *
105
-	 *
106
-	 * @param WPInv_Invoice $invoice Invoice.
103
+     * Creates a customer profile.
104
+     *
105
+     *
106
+     * @param WPInv_Invoice $invoice Invoice.
107 107
      * @param array $submission_data Posted checkout fields.
108 108
      * @param bool $save Whether or not to save the payment as a token.
109 109
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile
110
-	 * @return string|WP_Error Payment profile id.
111
-	 */
112
-	public function create_customer_profile( $invoice, $submission_data, $save = true ) {
110
+     * @return string|WP_Error Payment profile id.
111
+     */
112
+    public function create_customer_profile( $invoice, $submission_data, $save = true ) {
113 113
 
114 114
         // Remove non-digits from the number
115 115
         $submission_data['authorizenet']['cc_number'] = preg_replace( '/\D/', '', $submission_data['authorizenet']['cc_number'] );
@@ -191,14 +191,14 @@  discard block
 block discarded – undo
191 191
     }
192 192
 
193 193
     /**
194
-	 * Retrieves a customer profile.
195
-	 *
196
-	 *
197
-	 * @param string $profile_id profile id.
198
-	 * @return string|WP_Error Profile id.
194
+     * Retrieves a customer profile.
195
+     *
196
+     *
197
+     * @param string $profile_id profile id.
198
+     * @return string|WP_Error Profile id.
199 199
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-profile
200
-	 */
201
-	public function get_customer_profile( $profile_id ) {
200
+     */
201
+    public function get_customer_profile( $profile_id ) {
202 202
 
203 203
         // Generate args.
204 204
         $args = array(
@@ -213,17 +213,17 @@  discard block
 block discarded – undo
213 213
     }
214 214
 
215 215
     /**
216
-	 * Creates a customer profile.
217
-	 *
218
-	 *
216
+     * Creates a customer profile.
217
+     *
218
+     *
219 219
      * @param string $profile_id profile id.
220
-	 * @param WPInv_Invoice $invoice Invoice.
220
+     * @param WPInv_Invoice $invoice Invoice.
221 221
      * @param array $submission_data Posted checkout fields.
222 222
      * @param bool $save Whether or not to save the payment as a token.
223 223
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile
224
-	 * @return string|WP_Error Profile id.
225
-	 */
226
-	public function create_customer_payment_profile( $customer_profile, $invoice, $submission_data, $save ) {
224
+     * @return string|WP_Error Profile id.
225
+     */
226
+    public function create_customer_payment_profile( $customer_profile, $invoice, $submission_data, $save ) {
227 227
 
228 228
         // Remove non-digits from the number
229 229
         $submission_data['authorizenet']['cc_number'] = preg_replace( '/\D/', '', $submission_data['authorizenet']['cc_number'] );
@@ -311,13 +311,13 @@  discard block
 block discarded – undo
311 311
     }
312 312
 
313 313
     /**
314
-	 * Retrieves payment details from cache.
315
-	 *
316
-	 *
314
+     * Retrieves payment details from cache.
315
+     *
316
+     *
317 317
      * @param array $payment_details.
318
-	 * @return array|false Profile id.
319
-	 */
320
-	public function retrieve_payment_profile_from_cache( $payment_details, $customer_profile, $invoice ) {
318
+     * @return array|false Profile id.
319
+     */
320
+    public function retrieve_payment_profile_from_cache( $payment_details, $customer_profile, $invoice ) {
321 321
 
322 322
         $cached_information = get_option( 'getpaid_authorize_net_cached_profiles', array() );
323 323
         $payment_details    = hash_hmac( 'sha256', json_encode( $payment_details ), SECURE_AUTH_KEY );
@@ -342,13 +342,13 @@  discard block
 block discarded – undo
342 342
     }
343 343
 
344 344
     /**
345
-	 * Securely adds payment details to cache.
346
-	 *
347
-	 *
345
+     * Securely adds payment details to cache.
346
+     *
347
+     *
348 348
      * @param array $payment_details.
349 349
      * @param string $payment_profile_id.
350
-	 */
351
-	public function add_payment_profile_to_cache( $payment_details, $payment_profile_id ) {
350
+     */
351
+    public function add_payment_profile_to_cache( $payment_details, $payment_profile_id ) {
352 352
 
353 353
         $cached_information = get_option( 'getpaid_authorize_net_cached_profiles', array() );
354 354
         $cached_information = is_array( $cached_information ) ? $cached_information : array();
@@ -360,15 +360,15 @@  discard block
 block discarded – undo
360 360
     }
361 361
 
362 362
     /**
363
-	 * Retrieves a customer payment profile.
364
-	 *
365
-	 *
366
-	 * @param string $customer_profile_id customer profile id.
363
+     * Retrieves a customer payment profile.
364
+     *
365
+     *
366
+     * @param string $customer_profile_id customer profile id.
367 367
      * @param string $payment_profile_id payment profile id.
368
-	 * @return string|WP_Error Profile id.
368
+     * @return string|WP_Error Profile id.
369 369
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-payment-profile
370
-	 */
371
-	public function get_customer_payment_profile( $customer_profile_id, $payment_profile_id ) {
370
+     */
371
+    public function get_customer_payment_profile( $customer_profile_id, $payment_profile_id ) {
372 372
 
373 373
         // Generate args.
374 374
         $args = array(
@@ -384,15 +384,15 @@  discard block
 block discarded – undo
384 384
     }
385 385
 
386 386
     /**
387
-	 * Charges a customer payment profile.
388
-	 *
387
+     * Charges a customer payment profile.
388
+     *
389 389
      * @param string $customer_profile_id customer profile id.
390 390
      * @param string $payment_profile_id payment profile id.
391
-	 * @param WPInv_Invoice $invoice Invoice.
391
+     * @param WPInv_Invoice $invoice Invoice.
392 392
      * @link https://developer.authorize.net/api/reference/index.html#payment-transactions-charge-a-customer-profile
393
-	 * @return WP_Error|object
394
-	 */
395
-	public function charge_customer_payment_profile( $customer_profile_id, $payment_profile_id, $invoice ) {
393
+     * @return WP_Error|object
394
+     */
395
+    public function charge_customer_payment_profile( $customer_profile_id, $payment_profile_id, $invoice ) {
396 396
 
397 397
         // Generate args.
398 398
         $args = array(
@@ -438,43 +438,43 @@  discard block
 block discarded – undo
438 438
     }
439 439
 
440 440
     /**
441
-	 * Processes a customer charge.
442
-	 *
441
+     * Processes a customer charge.
442
+     *
443 443
      * @param stdClass $result Api response.
444
-	 * @param WPInv_Invoice $invoice Invoice.
445
-	 */
446
-	public function process_charge_response( $result, $invoice ) {
444
+     * @param WPInv_Invoice $invoice Invoice.
445
+     */
446
+    public function process_charge_response( $result, $invoice ) {
447 447
 
448 448
         wpinv_clear_errors();
449
-		$response_code = (int) $result->transactionResponse->responseCode;
449
+        $response_code = (int) $result->transactionResponse->responseCode;
450 450
 
451 451
         $invoice->add_note( 'Transaction Response: ' . print_r( $result->transactionResponse, true ), false, false, true );
452 452
 
453
-		// Succeeded.
454
-		if ( 1 == $response_code || 4 == $response_code ) {
453
+        // Succeeded.
454
+        if ( 1 == $response_code || 4 == $response_code ) {
455 455
 
456
-			// Maybe set a transaction id.
457
-			if ( ! empty( $result->transactionResponse->transId ) ) {
458
-				$invoice->set_transaction_id( $result->transactionResponse->transId );
459
-			}
456
+            // Maybe set a transaction id.
457
+            if ( ! empty( $result->transactionResponse->transId ) ) {
458
+                $invoice->set_transaction_id( $result->transactionResponse->transId );
459
+            }
460 460
 
461
-			$invoice->add_note( sprintf( __( 'Authentication code: %1$s (%2$s).', 'invoicing' ), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber ), false, false, true );
461
+            $invoice->add_note( sprintf( __( 'Authentication code: %1$s (%2$s).', 'invoicing' ), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber ), false, false, true );
462 462
 
463
-			if ( 1 == $response_code ) {
464
-				return $invoice->mark_paid();
465
-			}
463
+            if ( 1 == $response_code ) {
464
+                return $invoice->mark_paid();
465
+            }
466 466
 
467
-			$invoice->set_status( 'wpi-onhold' );
468
-        	$invoice->add_note(
467
+            $invoice->set_status( 'wpi-onhold' );
468
+            $invoice->add_note(
469 469
                 sprintf(
470 470
                     __( 'Held for review: %s', 'invoicing' ),
471 471
                     $result->transactionResponse->messages->message[0]->description
472 472
                 )
473
-			);
473
+            );
474 474
 
475
-			return $invoice->save();
475
+            return $invoice->save();
476 476
 
477
-		}
477
+        }
478 478
 
479 479
         wpinv_set_error( 'card_declined' );
480 480
 
@@ -486,13 +486,13 @@  discard block
 block discarded – undo
486 486
     }
487 487
 
488 488
     /**
489
-	 * Returns payment information.
490
-	 *
491
-	 *
492
-	 * @param array $card Card details.
493
-	 * @return array
494
-	 */
495
-	public function get_payment_information( $card ) {
489
+     * Returns payment information.
490
+     *
491
+     *
492
+     * @param array $card Card details.
493
+     * @return array
494
+     */
495
+    public function get_payment_information( $card ) {
496 496
         return array(
497 497
 
498 498
             'creditCard' => array(
@@ -505,25 +505,25 @@  discard block
 block discarded – undo
505 505
     }
506 506
 
507 507
     /**
508
-	 * Returns the customer profile meta name.
509
-	 *
510
-	 *
511
-	 * @param WPInv_Invoice $invoice Invoice.
512
-	 * @return string
513
-	 */
514
-	public function get_customer_profile_meta_name( $invoice ) {
508
+     * Returns the customer profile meta name.
509
+     *
510
+     *
511
+     * @param WPInv_Invoice $invoice Invoice.
512
+     * @return string
513
+     */
514
+    public function get_customer_profile_meta_name( $invoice ) {
515 515
         return $this->is_sandbox( $invoice ) ? 'getpaid_authorizenet_sandbox_customer_profile_id' : 'getpaid_authorizenet_customer_profile_id';
516 516
     }
517 517
 
518 518
     /**
519
-	 * Validates the submitted data.
520
-	 *
521
-	 *
522
-	 * @param array $submission_data Posted checkout fields.
519
+     * Validates the submitted data.
520
+     *
521
+     *
522
+     * @param array $submission_data Posted checkout fields.
523 523
      * @param WPInv_Invoice $invoice
524
-	 * @return WP_Error|string The payment profile id
525
-	 */
526
-	public function validate_submission_data( $submission_data, $invoice ) {
524
+     * @return WP_Error|string The payment profile id
525
+     */
526
+    public function validate_submission_data( $submission_data, $invoice ) {
527 527
 
528 528
         // Validate authentication details.
529 529
         $auth = $this->get_auth_params();
@@ -555,13 +555,13 @@  discard block
 block discarded – undo
555 555
     }
556 556
 
557 557
     /**
558
-	 * Returns invoice line items.
559
-	 *
560
-	 *
561
-	 * @param WPInv_Invoice $invoice Invoice.
562
-	 * @return array
563
-	 */
564
-	public function get_line_items( $invoice ) {
558
+     * Returns invoice line items.
559
+     *
560
+     *
561
+     * @param WPInv_Invoice $invoice Invoice.
562
+     * @return array
563
+     */
564
+    public function get_line_items( $invoice ) {
565 565
         $items = array();
566 566
 
567 567
         foreach ( $invoice->get_items() as $item ) {
@@ -598,15 +598,15 @@  discard block
 block discarded – undo
598 598
     }
599 599
 
600 600
     /**
601
-	 * Process Payment.
602
-	 *
603
-	 *
604
-	 * @param WPInv_Invoice $invoice Invoice.
605
-	 * @param array $submission_data Posted checkout fields.
606
-	 * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
607
-	 * @return array
608
-	 */
609
-	public function process_payment( $invoice, $submission_data, $submission ) {
601
+     * Process Payment.
602
+     *
603
+     *
604
+     * @param WPInv_Invoice $invoice Invoice.
605
+     * @param array $submission_data Posted checkout fields.
606
+     * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
607
+     * @return array
608
+     */
609
+    public function process_payment( $invoice, $submission_data, $submission ) {
610 610
 
611 611
         // Validate the submitted data.
612 612
         $payment_profile_id = $this->validate_submission_data( $submission_data, $invoice );
@@ -639,45 +639,45 @@  discard block
 block discarded – undo
639 639
 
640 640
         exit;
641 641
 
642
-	}
642
+    }
643 643
 
644
-	/**
645
-	 * Processes the initial payment.
646
-	 *
644
+    /**
645
+     * Processes the initial payment.
646
+     *
647 647
      * @param WPInv_Invoice $invoice Invoice.
648
-	 */
649
-	protected function process_initial_payment( $invoice ) {
648
+     */
649
+    protected function process_initial_payment( $invoice ) {
650 650
 
651
-		$payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
651
+        $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
652 652
         $customer_profile   = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
653
-		$result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice );
653
+        $result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice );
654 654
 
655
-		// Do we have an error?
656
-		if ( is_wp_error( $result ) ) {
657
-			wpinv_set_error( $result->get_error_code(), $result->get_error_message() );
658
-			wpinv_send_back_to_checkout( $invoice );
659
-		}
655
+        // Do we have an error?
656
+        if ( is_wp_error( $result ) ) {
657
+            wpinv_set_error( $result->get_error_code(), $result->get_error_message() );
658
+            wpinv_send_back_to_checkout( $invoice );
659
+        }
660 660
 
661
-		// Process the response.
662
-		$this->process_charge_response( $result, $invoice );
661
+        // Process the response.
662
+        $this->process_charge_response( $result, $invoice );
663 663
 
664
-		if ( wpinv_get_errors() ) {
665
-			wpinv_send_back_to_checkout( $invoice );
666
-		}
664
+        if ( wpinv_get_errors() ) {
665
+            wpinv_send_back_to_checkout( $invoice );
666
+        }
667 667
 
668
-	}
668
+    }
669 669
 
670 670
     /**
671
-	 * Processes recurring payments.
672
-	 *
671
+     * Processes recurring payments.
672
+     *
673 673
      * @param WPInv_Invoice $invoice Invoice.
674 674
      * @param WPInv_Subscription[]|WPInv_Subscription $subscriptions Subscriptions.
675
-	 */
676
-	public function process_subscription( $invoice, $subscriptions ) {
675
+     */
676
+    public function process_subscription( $invoice, $subscriptions ) {
677 677
 
678 678
         // Check if there is an initial amount to charge.
679 679
         if ( (float) $invoice->get_total() > 0 ) {
680
-			$this->process_initial_payment( $invoice );
680
+            $this->process_initial_payment( $invoice );
681 681
         }
682 682
 
683 683
         // Activate the subscriptions.
@@ -695,34 +695,34 @@  discard block
 block discarded – undo
695 695
             }
696 696
         }
697 697
 
698
-		// Redirect to the success page.
698
+        // Redirect to the success page.
699 699
         wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
700 700
 
701 701
     }
702 702
 
703
-	/**
704
-	 * (Maybe) renews an authorize.net subscription profile.
705
-	 *
706
-	 *
707
-	 * @param WPInv_Subscription $subscription
708
-	 */
709
-	public function maybe_renew_subscription( $subscription, $parent_invoice ) {
710
-		// Ensure its our subscription && it's active.
711
-		if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
712
-			$this->renew_subscription( $subscription );
713
-		}
714
-	}
703
+    /**
704
+     * (Maybe) renews an authorize.net subscription profile.
705
+     *
706
+     *
707
+     * @param WPInv_Subscription $subscription
708
+     */
709
+    public function maybe_renew_subscription( $subscription, $parent_invoice ) {
710
+        // Ensure its our subscription && it's active.
711
+        if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
712
+            $this->renew_subscription( $subscription );
713
+        }
714
+    }
715 715
 
716 716
     /**
717
-	 * Renews a subscription.
718
-	 *
717
+     * Renews a subscription.
718
+     *
719 719
      * @param WPInv_Subscription $subscription
720
-	 */
721
-	public function renew_subscription( $subscription ) {
720
+     */
721
+    public function renew_subscription( $subscription ) {
722 722
 
723
-		// Generate the renewal invoice.
724
-		$new_invoice = $subscription->create_payment();
725
-		$old_invoice = $subscription->get_parent_payment();
723
+        // Generate the renewal invoice.
724
+        $new_invoice = $subscription->create_payment();
725
+        $old_invoice = $subscription->get_parent_payment();
726 726
 
727 727
         if ( empty( $new_invoice ) ) {
728 728
             $old_invoice->add_note( __( 'Error generating a renewal invoice.', 'invoicing' ), false, false, false );
@@ -731,37 +731,37 @@  discard block
 block discarded – undo
731 731
         }
732 732
 
733 733
         // Charge the payment method.
734
-		$payment_profile_id = get_post_meta( $old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
735
-		$customer_profile   = get_user_meta( $old_invoice->get_user_id(), $this->get_customer_profile_meta_name( $old_invoice ), true );
736
-		$result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $new_invoice );
737
-
738
-		// Do we have an error?
739
-		if ( is_wp_error( $result ) ) {
740
-
741
-			$old_invoice->add_note(
742
-				sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), $result->get_error_message() ),
743
-				true,
744
-				false,
745
-				true
746
-			);
747
-			$subscription->failing();
748
-			return;
749
-
750
-		}
751
-
752
-		// Process the response.
753
-		$this->process_charge_response( $result, $new_invoice );
754
-
755
-		if ( wpinv_get_errors() ) {
756
-
757
-			$old_invoice->add_note(
758
-				sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), getpaid_get_errors_html() ),
759
-				true,
760
-				false,
761
-				true
762
-			);
763
-			$subscription->failing();
764
-			return;
734
+        $payment_profile_id = get_post_meta( $old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
735
+        $customer_profile   = get_user_meta( $old_invoice->get_user_id(), $this->get_customer_profile_meta_name( $old_invoice ), true );
736
+        $result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $new_invoice );
737
+
738
+        // Do we have an error?
739
+        if ( is_wp_error( $result ) ) {
740
+
741
+            $old_invoice->add_note(
742
+                sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), $result->get_error_message() ),
743
+                true,
744
+                false,
745
+                true
746
+            );
747
+            $subscription->failing();
748
+            return;
749
+
750
+        }
751
+
752
+        // Process the response.
753
+        $this->process_charge_response( $result, $new_invoice );
754
+
755
+        if ( wpinv_get_errors() ) {
756
+
757
+            $old_invoice->add_note(
758
+                sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), getpaid_get_errors_html() ),
759
+                true,
760
+                false,
761
+                true
762
+            );
763
+            $subscription->failing();
764
+            return;
765 765
 
766 766
         }
767 767
 
@@ -774,13 +774,13 @@  discard block
 block discarded – undo
774 774
     }
775 775
 
776 776
     /**
777
-	 * Processes invoice addons.
778
-	 *
779
-	 * @param WPInv_Invoice $invoice
780
-	 * @param GetPaid_Form_Item[] $items
781
-	 * @return WPInv_Invoice
782
-	 */
783
-	public function process_addons( $invoice, $items ) {
777
+     * Processes invoice addons.
778
+     *
779
+     * @param WPInv_Invoice $invoice
780
+     * @param GetPaid_Form_Item[] $items
781
+     * @return WPInv_Invoice
782
+     */
783
+    public function process_addons( $invoice, $items ) {
784 784
 
785 785
         global $getpaid_authorize_addons;
786 786
 
@@ -799,7 +799,7 @@  discard block
 block discarded – undo
799 799
         $invoice->recalculate_total();
800 800
 
801 801
         $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
802
-		$customer_profile   = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
802
+        $customer_profile   = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
803 803
 
804 804
         add_filter( 'getpaid_authorizenet_charge_customer_payment_profile_args', array( $this, 'filter_addons_request' ), 10, 2 );
805 805
         $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice );
@@ -814,11 +814,11 @@  discard block
 block discarded – undo
814 814
     }
815 815
 
816 816
     /**
817
-	 * Processes invoice addons.
818
-	 *
817
+     * Processes invoice addons.
818
+     *
819 819
      * @param array $args
820
-	 * @return array
821
-	 */
820
+     * @return array
821
+     */
822 822
     public function filter_addons_request( $args ) {
823 823
 
824 824
         global $getpaid_authorize_addons;
@@ -852,11 +852,11 @@  discard block
 block discarded – undo
852 852
     }
853 853
 
854 854
     /**
855
-	 * Filters the gateway settings.
856
-	 *
857
-	 * @param array $admin_settings
858
-	 */
859
-	public function admin_settings( $admin_settings ) {
855
+     * Filters the gateway settings.
856
+     *
857
+     * @param array $admin_settings
858
+     */
859
+    public function admin_settings( $admin_settings ) {
860 860
 
861 861
         $currencies = sprintf(
862 862
             __( 'Supported Currencies: %s', 'invoicing' ),
@@ -896,7 +896,7 @@  discard block
 block discarded – undo
896 896
             'readonly' => true,
897 897
         );
898 898
 
899
-		return $admin_settings;
900
-	}
899
+        return $admin_settings;
900
+    }
901 901
 
902 902
 }
Please login to merge, or discard this patch.
Spacing   +206 added lines, -206 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
  * Authorize.net Payment Gateway class.
@@ -61,7 +61,7 @@  discard block
 block discarded – undo
61 61
 	 *
62 62
 	 * @var array
63 63
 	 */
64
-	public $currencies = array( 'USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD' );
64
+	public $currencies = array('USD', 'CAD', 'GBP', 'DKK', 'NOK', 'PLN', 'SEK', 'AUD', 'EUR', 'NZD');
65 65
 
66 66
     /**
67 67
 	 * URL to view a transaction.
@@ -75,12 +75,12 @@  discard block
 block discarded – undo
75 75
 	 */
76 76
 	public function __construct() {
77 77
 
78
-        $this->title                = __( 'Credit Card / Debit Card', 'invoicing' );
79
-        $this->method_title         = __( 'Authorize.Net', 'invoicing' );
80
-        $this->notify_url           = getpaid_get_non_query_string_ipn_url( $this->id );
78
+        $this->title                = __('Credit Card / Debit Card', 'invoicing');
79
+        $this->method_title         = __('Authorize.Net', 'invoicing');
80
+        $this->notify_url           = getpaid_get_non_query_string_ipn_url($this->id);
81 81
 
82
-        add_action( 'getpaid_should_renew_subscription', array( $this, 'maybe_renew_subscription' ), 11, 2 );
83
-        add_filter( 'getpaid_authorizenet_sandbox_notice', array( $this, 'sandbox_notice' ) );
82
+        add_action('getpaid_should_renew_subscription', array($this, 'maybe_renew_subscription'), 11, 2);
83
+        add_filter('getpaid_authorizenet_sandbox_notice', array($this, 'sandbox_notice'));
84 84
         parent::__construct();
85 85
     }
86 86
 
@@ -90,13 +90,13 @@  discard block
 block discarded – undo
90 90
 	 * @param int $invoice_id 0 or invoice id.
91 91
 	 * @param GetPaid_Payment_Form $form Current payment form.
92 92
 	 */
93
-    public function payment_fields( $invoice_id, $form ) {
93
+    public function payment_fields($invoice_id, $form) {
94 94
 
95 95
         // Let the user select a payment method.
96 96
         $this->saved_payment_methods();
97 97
 
98 98
         // Show the credit card entry form.
99
-        $this->new_payment_method_entry( $this->get_cc_form( true ) );
99
+        $this->new_payment_method_entry($this->get_cc_form(true));
100 100
     }
101 101
 
102 102
     /**
@@ -109,79 +109,79 @@  discard block
 block discarded – undo
109 109
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile
110 110
 	 * @return string|WP_Error Payment profile id.
111 111
 	 */
112
-	public function create_customer_profile( $invoice, $submission_data, $save = true ) {
112
+	public function create_customer_profile($invoice, $submission_data, $save = true) {
113 113
 
114 114
         // Remove non-digits from the number
115
-        $submission_data['authorizenet']['cc_number'] = preg_replace( '/\D/', '', $submission_data['authorizenet']['cc_number'] );
115
+        $submission_data['authorizenet']['cc_number'] = preg_replace('/\D/', '', $submission_data['authorizenet']['cc_number']);
116 116
 
117 117
         // Generate args.
118 118
         $args = array(
119 119
             'createCustomerProfileRequest' => array(
120 120
                 'merchantAuthentication' => $this->get_auth_params(),
121 121
                 'profile'                => array(
122
-                    'merchantCustomerId' => getpaid_limit_length( $invoice->get_user_id(), 20 ),
123
-                    'description'        => getpaid_limit_length( $invoice->get_full_name(), 255 ),
124
-                    'email'              => getpaid_limit_length( $invoice->get_email(), 255 ),
122
+                    'merchantCustomerId' => getpaid_limit_length($invoice->get_user_id(), 20),
123
+                    'description'        => getpaid_limit_length($invoice->get_full_name(), 255),
124
+                    'email'              => getpaid_limit_length($invoice->get_email(), 255),
125 125
                     'paymentProfiles'    => array(
126 126
                         'customerType' => 'individual',
127 127
 
128 128
                         // Billing information.
129 129
                         'billTo'       => array(
130
-                            'firstName' => getpaid_limit_length( $invoice->get_first_name(), 50 ),
131
-                            'lastName'  => getpaid_limit_length( $invoice->get_last_name(), 50 ),
132
-                            'address'   => getpaid_limit_length( $invoice->get_address(), 60 ),
133
-                            'city'      => getpaid_limit_length( $invoice->get_city(), 40 ),
134
-                            'state'     => getpaid_limit_length( $invoice->get_state(), 40 ),
135
-                            'zip'       => getpaid_limit_length( $invoice->get_zip(), 20 ),
136
-                            'country'   => getpaid_limit_length( $invoice->get_country(), 60 ),
130
+                            'firstName' => getpaid_limit_length($invoice->get_first_name(), 50),
131
+                            'lastName'  => getpaid_limit_length($invoice->get_last_name(), 50),
132
+                            'address'   => getpaid_limit_length($invoice->get_address(), 60),
133
+                            'city'      => getpaid_limit_length($invoice->get_city(), 40),
134
+                            'state'     => getpaid_limit_length($invoice->get_state(), 40),
135
+                            'zip'       => getpaid_limit_length($invoice->get_zip(), 20),
136
+                            'country'   => getpaid_limit_length($invoice->get_country(), 60),
137 137
                         ),
138 138
 
139 139
                         // Payment information.
140
-                        'payment'      => $this->get_payment_information( $submission_data['authorizenet'] ),
140
+                        'payment'      => $this->get_payment_information($submission_data['authorizenet']),
141 141
                     ),
142 142
                 ),
143
-                'validationMode'         => $this->is_sandbox( $invoice ) ? 'testMode' : 'liveMode',
143
+                'validationMode'         => $this->is_sandbox($invoice) ? 'testMode' : 'liveMode',
144 144
             ),
145 145
         );
146 146
 
147
-        $response = $this->post( apply_filters( 'getpaid_authorizenet_customer_profile_args', $args, $invoice ), $invoice );
147
+        $response = $this->post(apply_filters('getpaid_authorizenet_customer_profile_args', $args, $invoice), $invoice);
148 148
 
149
-        if ( is_wp_error( $response ) ) {
149
+        if (is_wp_error($response)) {
150 150
 
151 151
             // In case the payment profile already exists remotely.
152
-            if ( 'dup_payment_profile' === $response->get_error_code() ) {
153
-                $customer_profile_id = strtok( $response->get_error_message(), '.' );
154
-                update_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), $customer_profile_id );
155
-                return strtok( '.' );
152
+            if ('dup_payment_profile' === $response->get_error_code()) {
153
+                $customer_profile_id = strtok($response->get_error_message(), '.');
154
+                update_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), $customer_profile_id);
155
+                return strtok('.');
156 156
             }
157 157
 
158 158
             // In case the customer profile already exists remotely.
159
-            if ( 'E00039' === $response->get_error_code() ) {
160
-                $customer_profile_id = str_replace( 'A duplicate record with ID ', '', $response->get_error_message() );
161
-                $customer_profile_id = str_replace( ' already exists.', '', $customer_profile_id );
162
-                return $this->create_customer_payment_profile( trim( $customer_profile_id ), $invoice, $submission_data, $save );
159
+            if ('E00039' === $response->get_error_code()) {
160
+                $customer_profile_id = str_replace('A duplicate record with ID ', '', $response->get_error_message());
161
+                $customer_profile_id = str_replace(' already exists.', '', $customer_profile_id);
162
+                return $this->create_customer_payment_profile(trim($customer_profile_id), $invoice, $submission_data, $save);
163 163
             }
164 164
 
165 165
             return $response;
166 166
         }
167 167
 
168
-        update_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), $response->customerProfileId );
168
+        update_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), $response->customerProfileId);
169 169
 
170 170
         // Save the payment token.
171
-        if ( $save ) {
171
+        if ($save) {
172 172
             $this->save_token(
173 173
                 array(
174 174
                     'id'      => $response->customerPaymentProfileIdList[0],
175
-                    'name'    => getpaid_get_card_name( $submission_data['authorizenet']['cc_number'] ) . '&middot;&middot;&middot;&middot;' . substr( $submission_data['authorizenet']['cc_number'], -4 ),
175
+                    'name'    => getpaid_get_card_name($submission_data['authorizenet']['cc_number']) . '&middot;&middot;&middot;&middot;' . substr($submission_data['authorizenet']['cc_number'], -4),
176 176
                     'default' => true,
177
-                    'type'    => $this->is_sandbox( $invoice ) ? 'sandbox' : 'live',
177
+                    'type'    => $this->is_sandbox($invoice) ? 'sandbox' : 'live',
178 178
                 )
179 179
             );
180 180
         }
181 181
 
182 182
         // Add a note about the validation response.
183 183
         $invoice->add_note(
184
-            sprintf( __( 'Created Authorize.NET customer profile: %s', 'invoicing' ), $response->validationDirectResponseList[0] ),
184
+            sprintf(__('Created Authorize.NET customer profile: %s', 'invoicing'), $response->validationDirectResponseList[0]),
185 185
             false,
186 186
             false,
187 187
             true
@@ -198,7 +198,7 @@  discard block
 block discarded – undo
198 198
 	 * @return string|WP_Error Profile id.
199 199
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-profile
200 200
 	 */
201
-	public function get_customer_profile( $profile_id ) {
201
+	public function get_customer_profile($profile_id) {
202 202
 
203 203
         // Generate args.
204 204
         $args = array(
@@ -208,7 +208,7 @@  discard block
 block discarded – undo
208 208
             ),
209 209
         );
210 210
 
211
-        return $this->post( $args, false );
211
+        return $this->post($args, false);
212 212
 
213 213
     }
214 214
 
@@ -223,18 +223,18 @@  discard block
 block discarded – undo
223 223
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-create-customer-profile
224 224
 	 * @return string|WP_Error Profile id.
225 225
 	 */
226
-	public function create_customer_payment_profile( $customer_profile, $invoice, $submission_data, $save ) {
226
+	public function create_customer_payment_profile($customer_profile, $invoice, $submission_data, $save) {
227 227
 
228 228
         // Remove non-digits from the number
229
-        $submission_data['authorizenet']['cc_number'] = preg_replace( '/\D/', '', $submission_data['authorizenet']['cc_number'] );
229
+        $submission_data['authorizenet']['cc_number'] = preg_replace('/\D/', '', $submission_data['authorizenet']['cc_number']);
230 230
 
231 231
         // Prepare card details.
232
-        $payment_information                          = $this->get_payment_information( $submission_data['authorizenet'] );
232
+        $payment_information                          = $this->get_payment_information($submission_data['authorizenet']);
233 233
 
234 234
         // Authorize.NET does not support saving the same card twice.
235
-        $cached_information                           = $this->retrieve_payment_profile_from_cache( $payment_information, $customer_profile, $invoice );
235
+        $cached_information                           = $this->retrieve_payment_profile_from_cache($payment_information, $customer_profile, $invoice);
236 236
 
237
-        if ( $cached_information ) {
237
+        if ($cached_information) {
238 238
             return $cached_information;
239 239
         }
240 240
 
@@ -247,34 +247,34 @@  discard block
 block discarded – undo
247 247
 
248 248
                     // Billing information.
249 249
                     'billTo'  => array(
250
-                        'firstName' => getpaid_limit_length( $invoice->get_first_name(), 50 ),
251
-                        'lastName'  => getpaid_limit_length( $invoice->get_last_name(), 50 ),
252
-                        'address'   => getpaid_limit_length( $invoice->get_address(), 60 ),
253
-                        'city'      => getpaid_limit_length( $invoice->get_city(), 40 ),
254
-                        'state'     => getpaid_limit_length( $invoice->get_state(), 40 ),
255
-                        'zip'       => getpaid_limit_length( $invoice->get_zip(), 20 ),
256
-                        'country'   => getpaid_limit_length( $invoice->get_country(), 60 ),
250
+                        'firstName' => getpaid_limit_length($invoice->get_first_name(), 50),
251
+                        'lastName'  => getpaid_limit_length($invoice->get_last_name(), 50),
252
+                        'address'   => getpaid_limit_length($invoice->get_address(), 60),
253
+                        'city'      => getpaid_limit_length($invoice->get_city(), 40),
254
+                        'state'     => getpaid_limit_length($invoice->get_state(), 40),
255
+                        'zip'       => getpaid_limit_length($invoice->get_zip(), 20),
256
+                        'country'   => getpaid_limit_length($invoice->get_country(), 60),
257 257
                     ),
258 258
 
259 259
                     // Payment information.
260 260
                     'payment' => $payment_information,
261 261
                 ),
262
-                'validationMode'         => $this->is_sandbox( $invoice ) ? 'testMode' : 'liveMode',
262
+                'validationMode'         => $this->is_sandbox($invoice) ? 'testMode' : 'liveMode',
263 263
             ),
264 264
         );
265 265
 
266
-        $response = $this->post( apply_filters( 'getpaid_authorizenet_create_customer_payment_profile_args', $args, $invoice ), $invoice );
266
+        $response = $this->post(apply_filters('getpaid_authorizenet_create_customer_payment_profile_args', $args, $invoice), $invoice);
267 267
 
268
-        if ( is_wp_error( $response ) ) {
268
+        if (is_wp_error($response)) {
269 269
 
270 270
             // In case the payment profile already exists remotely.
271
-            if ( 'dup_payment_profile' == $response->get_error_code() ) {
272
-                $customer_profile_id = strtok( $response->get_error_message(), '.' );
273
-                $payment_profile_id  = strtok( '.' );
274
-                update_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), $customer_profile_id );
271
+            if ('dup_payment_profile' == $response->get_error_code()) {
272
+                $customer_profile_id = strtok($response->get_error_message(), '.');
273
+                $payment_profile_id  = strtok('.');
274
+                update_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), $customer_profile_id);
275 275
 
276 276
                 // Cache payment profile id.
277
-                $this->add_payment_profile_to_cache( $payment_information, $payment_profile_id );
277
+                $this->add_payment_profile_to_cache($payment_information, $payment_profile_id);
278 278
 
279 279
                 return $payment_profile_id;
280 280
             }
@@ -283,29 +283,29 @@  discard block
 block discarded – undo
283 283
         }
284 284
 
285 285
         // Save the payment token.
286
-        if ( $save ) {
286
+        if ($save) {
287 287
             $this->save_token(
288 288
                 array(
289 289
                     'id'      => $response->customerPaymentProfileId,
290
-                    'name'    => getpaid_get_card_name( $submission_data['authorizenet']['cc_number'] ) . ' &middot;&middot;&middot;&middot; ' . substr( $submission_data['authorizenet']['cc_number'], -4 ),
290
+                    'name'    => getpaid_get_card_name($submission_data['authorizenet']['cc_number']) . ' &middot;&middot;&middot;&middot; ' . substr($submission_data['authorizenet']['cc_number'], -4),
291 291
                     'default' => true,
292
-                    'type'    => $this->is_sandbox( $invoice ) ? 'sandbox' : 'live',
292
+                    'type'    => $this->is_sandbox($invoice) ? 'sandbox' : 'live',
293 293
                 )
294 294
             );
295 295
         }
296 296
 
297 297
         // Cache payment profile id.
298
-        $this->add_payment_profile_to_cache( $payment_information, $response->customerPaymentProfileId );
298
+        $this->add_payment_profile_to_cache($payment_information, $response->customerPaymentProfileId);
299 299
 
300 300
         // Add a note about the validation response.
301 301
         $invoice->add_note(
302
-            sprintf( __( 'Saved Authorize.NET payment profile: %s', 'invoicing' ), $response->validationDirectResponse ),
302
+            sprintf(__('Saved Authorize.NET payment profile: %s', 'invoicing'), $response->validationDirectResponse),
303 303
             false,
304 304
             false,
305 305
             true
306 306
         );
307 307
 
308
-        update_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), $customer_profile );
308
+        update_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), $customer_profile);
309 309
 
310 310
         return $response->customerPaymentProfileId;
311 311
     }
@@ -317,12 +317,12 @@  discard block
 block discarded – undo
317 317
      * @param array $payment_details.
318 318
 	 * @return array|false Profile id.
319 319
 	 */
320
-	public function retrieve_payment_profile_from_cache( $payment_details, $customer_profile, $invoice ) {
320
+	public function retrieve_payment_profile_from_cache($payment_details, $customer_profile, $invoice) {
321 321
 
322
-        $cached_information = get_option( 'getpaid_authorize_net_cached_profiles', array() );
323
-        $payment_details    = hash_hmac( 'sha256', json_encode( $payment_details ), SECURE_AUTH_KEY );
322
+        $cached_information = get_option('getpaid_authorize_net_cached_profiles', array());
323
+        $payment_details    = hash_hmac('sha256', json_encode($payment_details), SECURE_AUTH_KEY);
324 324
 
325
-        if ( ! is_array( $cached_information ) || ! array_key_exists( $payment_details, $cached_information ) ) {
325
+        if (!is_array($cached_information) || !array_key_exists($payment_details, $cached_information)) {
326 326
             return false;
327 327
         }
328 328
 
@@ -331,13 +331,13 @@  discard block
 block discarded – undo
331 331
             'getCustomerPaymentProfileRequest' => array(
332 332
                 'merchantAuthentication'   => $this->get_auth_params(),
333 333
                 'customerProfileId'        => $customer_profile,
334
-                'customerPaymentProfileId' => $cached_information[ $payment_details ],
334
+                'customerPaymentProfileId' => $cached_information[$payment_details],
335 335
             ),
336 336
         );
337 337
 
338
-        $response = $this->post( $args, $invoice );
338
+        $response = $this->post($args, $invoice);
339 339
 
340
-        return is_wp_error( $response ) ? false : $cached_information[ $payment_details ];
340
+        return is_wp_error($response) ? false : $cached_information[$payment_details];
341 341
 
342 342
     }
343 343
 
@@ -348,14 +348,14 @@  discard block
 block discarded – undo
348 348
      * @param array $payment_details.
349 349
      * @param string $payment_profile_id.
350 350
 	 */
351
-	public function add_payment_profile_to_cache( $payment_details, $payment_profile_id ) {
351
+	public function add_payment_profile_to_cache($payment_details, $payment_profile_id) {
352 352
 
353
-        $cached_information = get_option( 'getpaid_authorize_net_cached_profiles', array() );
354
-        $cached_information = is_array( $cached_information ) ? $cached_information : array();
355
-        $payment_details    = hash_hmac( 'sha256', json_encode( $payment_details ), SECURE_AUTH_KEY );
353
+        $cached_information = get_option('getpaid_authorize_net_cached_profiles', array());
354
+        $cached_information = is_array($cached_information) ? $cached_information : array();
355
+        $payment_details    = hash_hmac('sha256', json_encode($payment_details), SECURE_AUTH_KEY);
356 356
 
357
-        $cached_information[ $payment_details ] = $payment_profile_id;
358
-        update_option( 'getpaid_authorize_net_cached_profiles', $cached_information );
357
+        $cached_information[$payment_details] = $payment_profile_id;
358
+        update_option('getpaid_authorize_net_cached_profiles', $cached_information);
359 359
 
360 360
     }
361 361
 
@@ -368,7 +368,7 @@  discard block
 block discarded – undo
368 368
 	 * @return string|WP_Error Profile id.
369 369
      * @link https://developer.authorize.net/api/reference/index.html#customer-profiles-get-customer-payment-profile
370 370
 	 */
371
-	public function get_customer_payment_profile( $customer_profile_id, $payment_profile_id ) {
371
+	public function get_customer_payment_profile($customer_profile_id, $payment_profile_id) {
372 372
 
373 373
         // Generate args.
374 374
         $args = array(
@@ -379,7 +379,7 @@  discard block
 block discarded – undo
379 379
             ),
380 380
         );
381 381
 
382
-        return $this->post( $args, false );
382
+        return $this->post($args, false);
383 383
 
384 384
     }
385 385
 
@@ -392,7 +392,7 @@  discard block
 block discarded – undo
392 392
      * @link https://developer.authorize.net/api/reference/index.html#payment-transactions-charge-a-customer-profile
393 393
 	 * @return WP_Error|object
394 394
 	 */
395
-	public function charge_customer_payment_profile( $customer_profile_id, $payment_profile_id, $invoice ) {
395
+	public function charge_customer_payment_profile($customer_profile_id, $payment_profile_id, $invoice) {
396 396
 
397 397
         // Generate args.
398 398
         $args = array(
@@ -412,28 +412,28 @@  discard block
 block discarded – undo
412 412
                         ),
413 413
                     ),
414 414
                     'order'           => array(
415
-                        'invoiceNumber' => getpaid_limit_length( $invoice->get_number(), 20 ),
415
+                        'invoiceNumber' => getpaid_limit_length($invoice->get_number(), 20),
416 416
                     ),
417
-                    'lineItems'       => array( 'lineItem' => $this->get_line_items( $invoice ) ),
417
+                    'lineItems'       => array('lineItem' => $this->get_line_items($invoice)),
418 418
                     'tax'             => array(
419 419
                         'amount' => $invoice->get_total_tax(),
420
-                        'name'   => __( 'TAX', 'invoicing' ),
420
+                        'name'   => __('TAX', 'invoicing'),
421 421
                     ),
422
-                    'poNumber'        => getpaid_limit_length( $invoice->get_number(), 25 ),
422
+                    'poNumber'        => getpaid_limit_length($invoice->get_number(), 25),
423 423
                     'customer'        => array(
424
-                        'id'    => getpaid_limit_length( $invoice->get_user_id(), 25 ),
425
-                        'email' => getpaid_limit_length( $invoice->get_email(), 25 ),
424
+                        'id'    => getpaid_limit_length($invoice->get_user_id(), 25),
425
+                        'email' => getpaid_limit_length($invoice->get_email(), 25),
426 426
                     ),
427 427
                     'customerIP'      => $invoice->get_ip(),
428 428
                 ),
429 429
             ),
430 430
         );
431 431
 
432
-        if ( 0 == $invoice->get_total_tax() ) {
433
-            unset( $args['createTransactionRequest']['transactionRequest']['tax'] );
432
+        if (0 == $invoice->get_total_tax()) {
433
+            unset($args['createTransactionRequest']['transactionRequest']['tax']);
434 434
         }
435 435
 
436
-        return $this->post( apply_filters( 'getpaid_authorizenet_charge_customer_payment_profile_args', $args, $invoice ), $invoice );
436
+        return $this->post(apply_filters('getpaid_authorizenet_charge_customer_payment_profile_args', $args, $invoice), $invoice);
437 437
 
438 438
     }
439 439
 
@@ -443,31 +443,31 @@  discard block
 block discarded – undo
443 443
      * @param stdClass $result Api response.
444 444
 	 * @param WPInv_Invoice $invoice Invoice.
445 445
 	 */
446
-	public function process_charge_response( $result, $invoice ) {
446
+	public function process_charge_response($result, $invoice) {
447 447
 
448 448
         wpinv_clear_errors();
449 449
 		$response_code = (int) $result->transactionResponse->responseCode;
450 450
 
451
-        $invoice->add_note( 'Transaction Response: ' . print_r( $result->transactionResponse, true ), false, false, true );
451
+        $invoice->add_note('Transaction Response: ' . print_r($result->transactionResponse, true), false, false, true);
452 452
 
453 453
 		// Succeeded.
454
-		if ( 1 == $response_code || 4 == $response_code ) {
454
+		if (1 == $response_code || 4 == $response_code) {
455 455
 
456 456
 			// Maybe set a transaction id.
457
-			if ( ! empty( $result->transactionResponse->transId ) ) {
458
-				$invoice->set_transaction_id( $result->transactionResponse->transId );
457
+			if (!empty($result->transactionResponse->transId)) {
458
+				$invoice->set_transaction_id($result->transactionResponse->transId);
459 459
 			}
460 460
 
461
-			$invoice->add_note( sprintf( __( 'Authentication code: %1$s (%2$s).', 'invoicing' ), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber ), false, false, true );
461
+			$invoice->add_note(sprintf(__('Authentication code: %1$s (%2$s).', 'invoicing'), $result->transactionResponse->authCode, $result->transactionResponse->accountNumber), false, false, true);
462 462
 
463
-			if ( 1 == $response_code ) {
463
+			if (1 == $response_code) {
464 464
 				return $invoice->mark_paid();
465 465
 			}
466 466
 
467
-			$invoice->set_status( 'wpi-onhold' );
467
+			$invoice->set_status('wpi-onhold');
468 468
         	$invoice->add_note(
469 469
                 sprintf(
470
-                    __( 'Held for review: %s', 'invoicing' ),
470
+                    __('Held for review: %s', 'invoicing'),
471 471
                     $result->transactionResponse->messages->message[0]->description
472 472
                 )
473 473
 			);
@@ -476,11 +476,11 @@  discard block
 block discarded – undo
476 476
 
477 477
 		}
478 478
 
479
-        wpinv_set_error( 'card_declined' );
479
+        wpinv_set_error('card_declined');
480 480
 
481
-        if ( ! empty( $result->transactionResponse->errors ) ) {
481
+        if (!empty($result->transactionResponse->errors)) {
482 482
             $errors = (object) $result->transactionResponse->errors;
483
-            wpinv_set_error( $errors->error[0]->errorCode, esc_html( $errors->error[0]->errorText ) );
483
+            wpinv_set_error($errors->error[0]->errorCode, esc_html($errors->error[0]->errorText));
484 484
         }
485 485
 
486 486
     }
@@ -492,7 +492,7 @@  discard block
 block discarded – undo
492 492
 	 * @param array $card Card details.
493 493
 	 * @return array
494 494
 	 */
495
-	public function get_payment_information( $card ) {
495
+	public function get_payment_information($card) {
496 496
         return array(
497 497
 
498 498
             'creditCard' => array(
@@ -511,8 +511,8 @@  discard block
 block discarded – undo
511 511
 	 * @param WPInv_Invoice $invoice Invoice.
512 512
 	 * @return string
513 513
 	 */
514
-	public function get_customer_profile_meta_name( $invoice ) {
515
-        return $this->is_sandbox( $invoice ) ? 'getpaid_authorizenet_sandbox_customer_profile_id' : 'getpaid_authorizenet_customer_profile_id';
514
+	public function get_customer_profile_meta_name($invoice) {
515
+        return $this->is_sandbox($invoice) ? 'getpaid_authorizenet_sandbox_customer_profile_id' : 'getpaid_authorizenet_customer_profile_id';
516 516
     }
517 517
 
518 518
     /**
@@ -523,34 +523,34 @@  discard block
 block discarded – undo
523 523
      * @param WPInv_Invoice $invoice
524 524
 	 * @return WP_Error|string The payment profile id
525 525
 	 */
526
-	public function validate_submission_data( $submission_data, $invoice ) {
526
+	public function validate_submission_data($submission_data, $invoice) {
527 527
 
528 528
         // Validate authentication details.
529 529
         $auth = $this->get_auth_params();
530 530
 
531
-        if ( empty( $auth['name'] ) || empty( $auth['transactionKey'] ) ) {
532
-            return new WP_Error( 'invalid_settings', __( 'Please set-up your login id and transaction key before using this gateway.', 'invoicing' ) );
531
+        if (empty($auth['name']) || empty($auth['transactionKey'])) {
532
+            return new WP_Error('invalid_settings', __('Please set-up your login id and transaction key before using this gateway.', 'invoicing'));
533 533
         }
534 534
 
535 535
         // Validate the payment method.
536
-        if ( empty( $submission_data['getpaid-authorizenet-payment-method'] ) ) {
537
-            return new WP_Error( 'invalid_payment_method', __( 'Please select a different payment method or add a new card.', 'invoicing' ) );
536
+        if (empty($submission_data['getpaid-authorizenet-payment-method'])) {
537
+            return new WP_Error('invalid_payment_method', __('Please select a different payment method or add a new card.', 'invoicing'));
538 538
         }
539 539
 
540 540
         // Are we adding a new payment method?
541
-        if ( 'new' != $submission_data['getpaid-authorizenet-payment-method'] ) {
541
+        if ('new' != $submission_data['getpaid-authorizenet-payment-method']) {
542 542
             return $submission_data['getpaid-authorizenet-payment-method'];
543 543
         }
544 544
 
545 545
         // Retrieve the customer profile id.
546
-        $profile_id = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
546
+        $profile_id = get_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), true);
547 547
 
548 548
         // Create payment method.
549
-        if ( empty( $profile_id ) ) {
550
-            return $this->create_customer_profile( $invoice, $submission_data, ! empty( $submission_data['getpaid-authorizenet-new-payment-method'] ) );
549
+        if (empty($profile_id)) {
550
+            return $this->create_customer_profile($invoice, $submission_data, !empty($submission_data['getpaid-authorizenet-new-payment-method']));
551 551
         }
552 552
 
553
-        return $this->create_customer_payment_profile( $profile_id, $invoice, $submission_data, ! empty( $submission_data['getpaid-authorizenet-new-payment-method'] ) );
553
+        return $this->create_customer_payment_profile($profile_id, $invoice, $submission_data, !empty($submission_data['getpaid-authorizenet-new-payment-method']));
554 554
 
555 555
     }
556 556
 
@@ -561,32 +561,32 @@  discard block
 block discarded – undo
561 561
 	 * @param WPInv_Invoice $invoice Invoice.
562 562
 	 * @return array
563 563
 	 */
564
-	public function get_line_items( $invoice ) {
564
+	public function get_line_items($invoice) {
565 565
         $items = array();
566 566
 
567
-        foreach ( $invoice->get_items() as $item ) {
567
+        foreach ($invoice->get_items() as $item) {
568 568
 
569 569
             $amount  = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
570 570
             $items[] = array(
571
-                'itemId'      => getpaid_limit_length( $item->get_id(), 31 ),
572
-                'name'        => getpaid_limit_length( $item->get_raw_name(), 31 ),
573
-                'description' => getpaid_limit_length( $item->get_description(), 255 ),
574
-                'quantity'    => (string) ( $invoice->get_template() == 'amount' ? 1 : $item->get_quantity() ),
571
+                'itemId'      => getpaid_limit_length($item->get_id(), 31),
572
+                'name'        => getpaid_limit_length($item->get_raw_name(), 31),
573
+                'description' => getpaid_limit_length($item->get_description(), 255),
574
+                'quantity'    => (string) ($invoice->get_template() == 'amount' ? 1 : $item->get_quantity()),
575 575
                 'unitPrice'   => (float) $amount,
576 576
                 'taxable'     => wpinv_use_taxes() && $invoice->is_taxable() && 'tax-exempt' != $item->get_vat_rule(),
577 577
             );
578 578
 
579 579
         }
580 580
 
581
-        foreach ( $invoice->get_fees() as $fee_name => $fee ) {
581
+        foreach ($invoice->get_fees() as $fee_name => $fee) {
582 582
 
583
-            $amount  = $invoice->is_renewal() ? $fee['recurring_fee'] : $fee['initial_fee'];
583
+            $amount = $invoice->is_renewal() ? $fee['recurring_fee'] : $fee['initial_fee'];
584 584
 
585
-            if ( $amount > 0 ) {
585
+            if ($amount > 0) {
586 586
                 $items[] = array(
587
-                    'itemId'      => getpaid_limit_length( $fee_name, 31 ),
588
-                    'name'        => getpaid_limit_length( $fee_name, 31 ),
589
-                    'description' => getpaid_limit_length( $fee_name, 255 ),
587
+                    'itemId'      => getpaid_limit_length($fee_name, 31),
588
+                    'name'        => getpaid_limit_length($fee_name, 31),
589
+                    'description' => getpaid_limit_length($fee_name, 255),
590 590
                     'quantity'    => '1',
591 591
                     'unitPrice'   => (float) $amount,
592 592
                     'taxable'     => false,
@@ -606,36 +606,36 @@  discard block
 block discarded – undo
606 606
 	 * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
607 607
 	 * @return array
608 608
 	 */
609
-	public function process_payment( $invoice, $submission_data, $submission ) {
609
+	public function process_payment($invoice, $submission_data, $submission) {
610 610
 
611 611
         // Validate the submitted data.
612
-        $payment_profile_id = $this->validate_submission_data( $submission_data, $invoice );
612
+        $payment_profile_id = $this->validate_submission_data($submission_data, $invoice);
613 613
 
614 614
         // Do we have an error?
615
-        if ( is_wp_error( $payment_profile_id ) ) {
616
-            wpinv_set_error( $payment_profile_id->get_error_code(), $payment_profile_id->get_error_message() );
617
-            wpinv_send_back_to_checkout( $invoice );
615
+        if (is_wp_error($payment_profile_id)) {
616
+            wpinv_set_error($payment_profile_id->get_error_code(), $payment_profile_id->get_error_message());
617
+            wpinv_send_back_to_checkout($invoice);
618 618
         }
619 619
 
620 620
         // Save the payment method to the order.
621
-        update_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', $payment_profile_id );
621
+        update_post_meta($invoice->get_id(), 'getpaid_authorizenet_profile_id', $payment_profile_id);
622 622
 
623 623
         // Check if this is a subscription or not.
624
-        $subscriptions = getpaid_get_invoice_subscriptions( $invoice );
625
-        if ( ! empty( $subscriptions ) ) {
626
-            $this->process_subscription( $invoice, $subscriptions );
624
+        $subscriptions = getpaid_get_invoice_subscriptions($invoice);
625
+        if (!empty($subscriptions)) {
626
+            $this->process_subscription($invoice, $subscriptions);
627 627
         }
628 628
 
629 629
         // If it is free, send to the success page.
630
-        if ( ! $invoice->needs_payment() ) {
630
+        if (!$invoice->needs_payment()) {
631 631
             $invoice->mark_paid();
632
-            wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
632
+            wpinv_send_to_success_page(array('invoice_key' => $invoice->get_key()));
633 633
         }
634 634
 
635 635
         // Charge the payment profile.
636
-        $this->process_initial_payment( $invoice );
636
+        $this->process_initial_payment($invoice);
637 637
 
638
-        wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
638
+        wpinv_send_to_success_page(array('invoice_key' => $invoice->get_key()));
639 639
 
640 640
         exit;
641 641
 
@@ -646,23 +646,23 @@  discard block
 block discarded – undo
646 646
 	 *
647 647
      * @param WPInv_Invoice $invoice Invoice.
648 648
 	 */
649
-	protected function process_initial_payment( $invoice ) {
649
+	protected function process_initial_payment($invoice) {
650 650
 
651
-		$payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
652
-        $customer_profile   = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
653
-		$result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice );
651
+		$payment_profile_id = get_post_meta($invoice->get_id(), 'getpaid_authorizenet_profile_id', true);
652
+        $customer_profile = get_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), true);
653
+		$result             = $this->charge_customer_payment_profile($customer_profile, $payment_profile_id, $invoice);
654 654
 
655 655
 		// Do we have an error?
656
-		if ( is_wp_error( $result ) ) {
657
-			wpinv_set_error( $result->get_error_code(), $result->get_error_message() );
658
-			wpinv_send_back_to_checkout( $invoice );
656
+		if (is_wp_error($result)) {
657
+			wpinv_set_error($result->get_error_code(), $result->get_error_message());
658
+			wpinv_send_back_to_checkout($invoice);
659 659
 		}
660 660
 
661 661
 		// Process the response.
662
-		$this->process_charge_response( $result, $invoice );
662
+		$this->process_charge_response($result, $invoice);
663 663
 
664
-		if ( wpinv_get_errors() ) {
665
-			wpinv_send_back_to_checkout( $invoice );
664
+		if (wpinv_get_errors()) {
665
+			wpinv_send_back_to_checkout($invoice);
666 666
 		}
667 667
 
668 668
 	}
@@ -673,30 +673,30 @@  discard block
 block discarded – undo
673 673
      * @param WPInv_Invoice $invoice Invoice.
674 674
      * @param WPInv_Subscription[]|WPInv_Subscription $subscriptions Subscriptions.
675 675
 	 */
676
-	public function process_subscription( $invoice, $subscriptions ) {
676
+	public function process_subscription($invoice, $subscriptions) {
677 677
 
678 678
         // Check if there is an initial amount to charge.
679
-        if ( (float) $invoice->get_total() > 0 ) {
680
-			$this->process_initial_payment( $invoice );
679
+        if ((float) $invoice->get_total() > 0) {
680
+			$this->process_initial_payment($invoice);
681 681
         }
682 682
 
683 683
         // Activate the subscriptions.
684
-        $subscriptions = is_array( $subscriptions ) ? $subscriptions : array( $subscriptions );
684
+        $subscriptions = is_array($subscriptions) ? $subscriptions : array($subscriptions);
685 685
 
686
-        foreach ( $subscriptions as $subscription ) {
687
-            if ( $subscription->exists() ) {
688
-                $duration = strtotime( $subscription->get_expiration() ) - strtotime( $subscription->get_date_created() );
689
-                $expiry   = date( 'Y-m-d H:i:s', ( current_time( 'timestamp' ) + $duration ) );
686
+        foreach ($subscriptions as $subscription) {
687
+            if ($subscription->exists()) {
688
+                $duration = strtotime($subscription->get_expiration()) - strtotime($subscription->get_date_created());
689
+                $expiry   = date('Y-m-d H:i:s', (current_time('timestamp') + $duration));
690 690
 
691
-                $subscription->set_next_renewal_date( $expiry );
692
-                $subscription->set_date_created( current_time( 'mysql' ) );
693
-                $subscription->set_profile_id( $invoice->generate_key( 'authnet_sub_' . $invoice->get_id() . '_' . $subscription->get_id() ) );
691
+                $subscription->set_next_renewal_date($expiry);
692
+                $subscription->set_date_created(current_time('mysql'));
693
+                $subscription->set_profile_id($invoice->generate_key('authnet_sub_' . $invoice->get_id() . '_' . $subscription->get_id()));
694 694
                 $subscription->activate();
695 695
             }
696 696
         }
697 697
 
698 698
 		// Redirect to the success page.
699
-        wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
699
+        wpinv_send_to_success_page(array('invoice_key' => $invoice->get_key()));
700 700
 
701 701
     }
702 702
 
@@ -706,10 +706,10 @@  discard block
 block discarded – undo
706 706
 	 *
707 707
 	 * @param WPInv_Subscription $subscription
708 708
 	 */
709
-	public function maybe_renew_subscription( $subscription, $parent_invoice ) {
709
+	public function maybe_renew_subscription($subscription, $parent_invoice) {
710 710
 		// Ensure its our subscription && it's active.
711
-		if ( ! empty( $parent_invoice ) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status( 'active trialling' ) ) {
712
-			$this->renew_subscription( $subscription );
711
+		if (!empty($parent_invoice) && $this->id === $parent_invoice->get_gateway() && $subscription->has_status('active trialling')) {
712
+			$this->renew_subscription($subscription);
713 713
 		}
714 714
 	}
715 715
 
@@ -718,28 +718,28 @@  discard block
 block discarded – undo
718 718
 	 *
719 719
      * @param WPInv_Subscription $subscription
720 720
 	 */
721
-	public function renew_subscription( $subscription ) {
721
+	public function renew_subscription($subscription) {
722 722
 
723 723
 		// Generate the renewal invoice.
724 724
 		$new_invoice = $subscription->create_payment();
725 725
 		$old_invoice = $subscription->get_parent_payment();
726 726
 
727
-        if ( empty( $new_invoice ) ) {
728
-            $old_invoice->add_note( __( 'Error generating a renewal invoice.', 'invoicing' ), false, false, false );
727
+        if (empty($new_invoice)) {
728
+            $old_invoice->add_note(__('Error generating a renewal invoice.', 'invoicing'), false, false, false);
729 729
             $subscription->failing();
730 730
             return;
731 731
         }
732 732
 
733 733
         // Charge the payment method.
734
-		$payment_profile_id = get_post_meta( $old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
735
-		$customer_profile   = get_user_meta( $old_invoice->get_user_id(), $this->get_customer_profile_meta_name( $old_invoice ), true );
736
-		$result             = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $new_invoice );
734
+		$payment_profile_id = get_post_meta($old_invoice->get_id(), 'getpaid_authorizenet_profile_id', true);
735
+		$customer_profile   = get_user_meta($old_invoice->get_user_id(), $this->get_customer_profile_meta_name($old_invoice), true);
736
+		$result             = $this->charge_customer_payment_profile($customer_profile, $payment_profile_id, $new_invoice);
737 737
 
738 738
 		// Do we have an error?
739
-		if ( is_wp_error( $result ) ) {
739
+		if (is_wp_error($result)) {
740 740
 
741 741
 			$old_invoice->add_note(
742
-				sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), $result->get_error_message() ),
742
+				sprintf(__('Error renewing subscription : ( %s ).', 'invoicing'), $result->get_error_message()),
743 743
 				true,
744 744
 				false,
745 745
 				true
@@ -750,12 +750,12 @@  discard block
 block discarded – undo
750 750
 		}
751 751
 
752 752
 		// Process the response.
753
-		$this->process_charge_response( $result, $new_invoice );
753
+		$this->process_charge_response($result, $new_invoice);
754 754
 
755
-		if ( wpinv_get_errors() ) {
755
+		if (wpinv_get_errors()) {
756 756
 
757 757
 			$old_invoice->add_note(
758
-				sprintf( __( 'Error renewing subscription : ( %s ).', 'invoicing' ), getpaid_get_errors_html() ),
758
+				sprintf(__('Error renewing subscription : ( %s ).', 'invoicing'), getpaid_get_errors_html()),
759 759
 				true,
760 760
 				false,
761 761
 				true
@@ -765,9 +765,9 @@  discard block
 block discarded – undo
765 765
 
766 766
         }
767 767
 
768
-        if ( ! $new_invoice->needs_payment() ) {
768
+        if (!$new_invoice->needs_payment()) {
769 769
             $subscription->renew();
770
-            $subscription->after_add_payment( $new_invoice );
770
+            $subscription->after_add_payment($new_invoice);
771 771
         } else {
772 772
             $subscription->failing();
773 773
         }
@@ -780,33 +780,33 @@  discard block
 block discarded – undo
780 780
 	 * @param GetPaid_Form_Item[] $items
781 781
 	 * @return WPInv_Invoice
782 782
 	 */
783
-	public function process_addons( $invoice, $items ) {
783
+	public function process_addons($invoice, $items) {
784 784
 
785 785
         global $getpaid_authorize_addons;
786 786
 
787 787
         $getpaid_authorize_addons = array();
788
-        foreach ( $items as $item ) {
788
+        foreach ($items as $item) {
789 789
 
790
-            if ( is_null( $invoice->get_item( $item->get_id() ) ) && ! is_wp_error( $invoice->add_item( $item ) ) ) {
790
+            if (is_null($invoice->get_item($item->get_id())) && !is_wp_error($invoice->add_item($item))) {
791 791
                 $getpaid_authorize_addons[] = $item;
792 792
             }
793 793
 }
794 794
 
795
-        if ( empty( $getpaid_authorize_addons ) ) {
795
+        if (empty($getpaid_authorize_addons)) {
796 796
             return;
797 797
         }
798 798
 
799 799
         $invoice->recalculate_total();
800 800
 
801
-        $payment_profile_id = get_post_meta( $invoice->get_id(), 'getpaid_authorizenet_profile_id', true );
802
-		$customer_profile   = get_user_meta( $invoice->get_user_id(), $this->get_customer_profile_meta_name( $invoice ), true );
801
+        $payment_profile_id = get_post_meta($invoice->get_id(), 'getpaid_authorizenet_profile_id', true);
802
+		$customer_profile = get_user_meta($invoice->get_user_id(), $this->get_customer_profile_meta_name($invoice), true);
803 803
 
804
-        add_filter( 'getpaid_authorizenet_charge_customer_payment_profile_args', array( $this, 'filter_addons_request' ), 10, 2 );
805
-        $result = $this->charge_customer_payment_profile( $customer_profile, $payment_profile_id, $invoice );
806
-        remove_filter( 'getpaid_authorizenet_charge_customer_payment_profile_args', array( $this, 'filter_addons_request' ) );
804
+        add_filter('getpaid_authorizenet_charge_customer_payment_profile_args', array($this, 'filter_addons_request'), 10, 2);
805
+        $result = $this->charge_customer_payment_profile($customer_profile, $payment_profile_id, $invoice);
806
+        remove_filter('getpaid_authorizenet_charge_customer_payment_profile_args', array($this, 'filter_addons_request'));
807 807
 
808
-        if ( is_wp_error( $result ) ) {
809
-            wpinv_set_error( $result->get_error_code(), $result->get_error_message() );
808
+        if (is_wp_error($result)) {
809
+            wpinv_set_error($result->get_error_code(), $result->get_error_message());
810 810
             return;
811 811
         }
812 812
 
@@ -819,19 +819,19 @@  discard block
 block discarded – undo
819 819
      * @param array $args
820 820
 	 * @return array
821 821
 	 */
822
-    public function filter_addons_request( $args ) {
822
+    public function filter_addons_request($args) {
823 823
 
824 824
         global $getpaid_authorize_addons;
825 825
         $total = 0;
826 826
 
827
-        foreach ( $getpaid_authorize_addons as $addon ) {
827
+        foreach ($getpaid_authorize_addons as $addon) {
828 828
             $total += $addon->get_sub_total();
829 829
         }
830 830
 
831 831
         $args['createTransactionRequest']['transactionRequest']['amount'] = $total;
832 832
 
833
-        if ( isset( $args['createTransactionRequest']['transactionRequest']['tax'] ) ) {
834
-            unset( $args['createTransactionRequest']['transactionRequest']['tax'] );
833
+        if (isset($args['createTransactionRequest']['transactionRequest']['tax'])) {
834
+            unset($args['createTransactionRequest']['transactionRequest']['tax']);
835 835
         }
836 836
 
837 837
         return $args;
@@ -844,7 +844,7 @@  discard block
 block discarded – undo
844 844
     public function sandbox_notice() {
845 845
 
846 846
         return sprintf(
847
-            __( 'SANDBOX ENABLED. You can use sandbox testing details only. See the %1$sAuthorize.NET Sandbox Testing Guide%2$s for more details.', 'invoicing' ),
847
+            __('SANDBOX ENABLED. You can use sandbox testing details only. See the %1$sAuthorize.NET Sandbox Testing Guide%2$s for more details.', 'invoicing'),
848 848
             '<a href="https://developer.authorize.net/hello_world/testing_guide.html">',
849 849
             '</a>'
850 850
         );
@@ -856,42 +856,42 @@  discard block
 block discarded – undo
856 856
 	 *
857 857
 	 * @param array $admin_settings
858 858
 	 */
859
-	public function admin_settings( $admin_settings ) {
859
+	public function admin_settings($admin_settings) {
860 860
 
861 861
         $currencies = sprintf(
862
-            __( 'Supported Currencies: %s', 'invoicing' ),
863
-            implode( ', ', $this->currencies )
862
+            __('Supported Currencies: %s', 'invoicing'),
863
+            implode(', ', $this->currencies)
864 864
         );
865 865
 
866 866
         $admin_settings['authorizenet_active']['desc'] .= " ($currencies)";
867
-        $admin_settings['authorizenet_desc']['std']     = __( 'Pay securely using your credit or debit card.', 'invoicing' );
867
+        $admin_settings['authorizenet_desc']['std']     = __('Pay securely using your credit or debit card.', 'invoicing');
868 868
 
869 869
         $admin_settings['authorizenet_login_id'] = array(
870 870
             'type' => 'text',
871 871
             'id'   => 'authorizenet_login_id',
872
-            'name' => __( 'API Login ID', 'invoicing' ),
873
-            'desc' => '<a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001271"><em>' . __( 'How do I obtain my API Login ID and Transaction Key?', 'invoicing' ) . '</em></a>',
872
+            'name' => __('API Login ID', 'invoicing'),
873
+            'desc' => '<a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001271"><em>' . __('How do I obtain my API Login ID and Transaction Key?', 'invoicing') . '</em></a>',
874 874
         );
875 875
 
876 876
         $admin_settings['authorizenet_transaction_key'] = array(
877 877
             'type' => 'text',
878 878
             'id'   => 'authorizenet_transaction_key',
879
-            'name' => __( 'Transaction Key', 'invoicing' ),
879
+            'name' => __('Transaction Key', 'invoicing'),
880 880
         );
881 881
 
882 882
         $admin_settings['authorizenet_signature_key'] = array(
883 883
             'type' => 'text',
884 884
             'id'   => 'authorizenet_signature_key',
885
-            'name' => __( 'Signature Key', 'invoicing' ),
886
-            'desc' => '<a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001271"><em>' . __( 'Learn more.', 'invoicing' ) . '</em></a>',
885
+            'name' => __('Signature Key', 'invoicing'),
886
+            'desc' => '<a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001271"><em>' . __('Learn more.', 'invoicing') . '</em></a>',
887 887
         );
888 888
 
889 889
         $admin_settings['authorizenet_ipn_url'] = array(
890 890
             'type'     => 'ipn_url',
891 891
             'id'       => 'authorizenet_ipn_url',
892
-            'name'     => __( 'Webhook URL', 'invoicing' ),
892
+            'name'     => __('Webhook URL', 'invoicing'),
893 893
             'std'      => $this->notify_url,
894
-            'desc'     => __( 'Create a new webhook using this URL as the endpoint URL and set it to receive all payment events.', 'invoicing' ) . ' <a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001542"><em>' . __( 'Learn more.', 'invoicing' ) . '</em></a>',
894
+            'desc'     => __('Create a new webhook using this URL as the endpoint URL and set it to receive all payment events.', 'invoicing') . ' <a href="https://support.authorize.net/knowledgebase/Knowledgearticle/?code=000001542"><em>' . __('Learn more.', 'invoicing') . '</em></a>',
895 895
             'custom'   => 'authorizenet',
896 896
             'readonly' => true,
897 897
         );
Please login to merge, or discard this patch.
templates/emails/invoice-item.php 2 patches
Indentation   +46 added lines, -46 removed lines patch added patch discarded remove patch
@@ -18,63 +18,63 @@
 block discarded – undo
18 18
 	<?php foreach ( array_keys( $columns ) as $column ) : ?>
19 19
 	<td class="<?php echo 'name' == $column ? 'text-left' : 'text-right'; ?> wpinv_cart_item_<?php echo esc_attr( $column ); ?>">
20 20
 		<?php
21
-		// Fires before printing a line item column.
22
-		do_action( "getpaid_email_line_item_before_$column", $item, $invoice );
21
+        // Fires before printing a line item column.
22
+        do_action( "getpaid_email_line_item_before_$column", $item, $invoice );
23 23
 
24
-		// Item name.
25
-		if ( 'name' == $column ) {
26
-			$has_featured_image = has_post_thumbnail( $item->get_id() );
24
+        // Item name.
25
+        if ( 'name' == $column ) {
26
+            $has_featured_image = has_post_thumbnail( $item->get_id() );
27 27
 
28
-			if ( $has_featured_image ) {
29
-				echo '<div class="getpaid-email-item-image-wrap" style="min-height:80px">';
30
-					echo '<div class="getpaid-email-image-wrap" style="display:inline-block;width:80px;height:80px;">';
31
-						echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'wpinv-email-item-image' ) );
32
-					echo '</div>';
33
-					echo '<div class="getpaid-email-item-name-wrap" style="display:inline-block;vertical-align:top;max-width:360px;">';
34
-			}
28
+            if ( $has_featured_image ) {
29
+                echo '<div class="getpaid-email-item-image-wrap" style="min-height:80px">';
30
+                    echo '<div class="getpaid-email-image-wrap" style="display:inline-block;width:80px;height:80px;">';
31
+                        echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'wpinv-email-item-image' ) );
32
+                    echo '</div>';
33
+                    echo '<div class="getpaid-email-item-name-wrap" style="display:inline-block;vertical-align:top;max-width:360px;">';
34
+            }
35 35
 
36
-			// Display the name.
37
-			echo '<div class="wpinv_email_cart_item_title">' . esc_html( $item->get_name() ) . '</div>';
36
+            // Display the name.
37
+            echo '<div class="wpinv_email_cart_item_title">' . esc_html( $item->get_name() ) . '</div>';
38 38
 
39
-			// And an optional description.
40
-			$description = $item->get_description();
39
+            // And an optional description.
40
+            $description = $item->get_description();
41 41
 
42
-			if ( ! empty( $description ) ) {
43
-				echo "<p class='small'>" . wp_kses_post( $description ) . "</p>";
44
-			}
42
+            if ( ! empty( $description ) ) {
43
+                echo "<p class='small'>" . wp_kses_post( $description ) . "</p>";
44
+            }
45 45
 
46
-			if ( $has_featured_image ) {
47
-					echo '</div>';
48
-				echo '</div>';
49
-			}
50
-		}
46
+            if ( $has_featured_image ) {
47
+                    echo '</div>';
48
+                echo '</div>';
49
+            }
50
+        }
51 51
 
52
-		// Item price.
53
-		if ( 'price' == $column ) {
54
-			// Display the item price (or recurring price if this is a renewal invoice)
55
-			$price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
56
-			wpinv_the_price( $price, $invoice->get_currency() );
57
-		}
52
+        // Item price.
53
+        if ( 'price' == $column ) {
54
+            // Display the item price (or recurring price if this is a renewal invoice)
55
+            $price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
56
+            wpinv_the_price( $price, $invoice->get_currency() );
57
+        }
58 58
 
59
-		// Item quantity.
60
-		if ( 'quantity' == $column ) {
61
-			echo (float) $item->get_quantity();
62
-		}
59
+        // Item quantity.
60
+        if ( 'quantity' == $column ) {
61
+            echo (float) $item->get_quantity();
62
+        }
63 63
 
64
-		// Tax rate.
65
-		if ( 'tax_rate' == $column ) {
66
-			echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
67
-		}
64
+        // Tax rate.
65
+        if ( 'tax_rate' == $column ) {
66
+            echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
67
+        }
68 68
 
69
-		// Item sub total.
70
-		if ( 'subtotal' == $column ) {
71
-			$subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
72
-			wpinv_the_price( $subtotal, $invoice->get_currency() );
73
-		}
69
+        // Item sub total.
70
+        if ( 'subtotal' == $column ) {
71
+            $subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
72
+            wpinv_the_price( $subtotal, $invoice->get_currency() );
73
+        }
74 74
 
75
-		// Fires when printing a line item column.
76
-		do_action( "getpaid_email_line_item_$column", $item, $invoice );
77
-		?>
75
+        // Fires when printing a line item column.
76
+        do_action( "getpaid_email_line_item_$column", $item, $invoice );
77
+        ?>
78 78
 	</td>
79 79
 	<?php endforeach; ?>
80 80
 </tr>
Please login to merge, or discard this patch.
Spacing   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -10,73 +10,73 @@
 block discarded – undo
10 10
  * @var array $columns
11 11
  */
12 12
 
13
-defined( 'ABSPATH' ) || exit;
13
+defined('ABSPATH') || exit;
14 14
 
15
-do_action( 'getpaid_before_email_line_item', $invoice, $item );
15
+do_action('getpaid_before_email_line_item', $invoice, $item);
16 16
 ?>
17
-<tr class="wpinv_cart_item item-type-<?php echo esc_attr( $item->get_type() ); ?>">
18
-	<?php foreach ( array_keys( $columns ) as $column ) : ?>
19
-	<td class="<?php echo 'name' == $column ? 'text-left' : 'text-right'; ?> wpinv_cart_item_<?php echo esc_attr( $column ); ?>">
17
+<tr class="wpinv_cart_item item-type-<?php echo esc_attr($item->get_type()); ?>">
18
+	<?php foreach (array_keys($columns) as $column) : ?>
19
+	<td class="<?php echo 'name' == $column ? 'text-left' : 'text-right'; ?> wpinv_cart_item_<?php echo esc_attr($column); ?>">
20 20
 		<?php
21 21
 		// Fires before printing a line item column.
22
-		do_action( "getpaid_email_line_item_before_$column", $item, $invoice );
22
+		do_action("getpaid_email_line_item_before_$column", $item, $invoice);
23 23
 
24 24
 		// Item name.
25
-		if ( 'name' == $column ) {
26
-			$has_featured_image = has_post_thumbnail( $item->get_id() );
25
+		if ('name' == $column) {
26
+			$has_featured_image = has_post_thumbnail($item->get_id());
27 27
 
28
-			if ( $has_featured_image ) {
28
+			if ($has_featured_image) {
29 29
 				echo '<div class="getpaid-email-item-image-wrap" style="min-height:80px">';
30 30
 					echo '<div class="getpaid-email-image-wrap" style="display:inline-block;width:80px;height:80px;">';
31
-						echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'wpinv-email-item-image' ) );
31
+						echo get_the_post_thumbnail($item->get_id(), array(75, 75), array('class' => 'wpinv-email-item-image'));
32 32
 					echo '</div>';
33 33
 					echo '<div class="getpaid-email-item-name-wrap" style="display:inline-block;vertical-align:top;max-width:360px;">';
34 34
 			}
35 35
 
36 36
 			// Display the name.
37
-			echo '<div class="wpinv_email_cart_item_title">' . esc_html( $item->get_name() ) . '</div>';
37
+			echo '<div class="wpinv_email_cart_item_title">' . esc_html($item->get_name()) . '</div>';
38 38
 
39 39
 			// And an optional description.
40 40
 			$description = $item->get_description();
41 41
 
42
-			if ( ! empty( $description ) ) {
43
-				echo "<p class='small'>" . wp_kses_post( $description ) . "</p>";
42
+			if (!empty($description)) {
43
+				echo "<p class='small'>" . wp_kses_post($description) . "</p>";
44 44
 			}
45 45
 
46
-			if ( $has_featured_image ) {
46
+			if ($has_featured_image) {
47 47
 					echo '</div>';
48 48
 				echo '</div>';
49 49
 			}
50 50
 		}
51 51
 
52 52
 		// Item price.
53
-		if ( 'price' == $column ) {
53
+		if ('price' == $column) {
54 54
 			// Display the item price (or recurring price if this is a renewal invoice)
55 55
 			$price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
56
-			wpinv_the_price( $price, $invoice->get_currency() );
56
+			wpinv_the_price($price, $invoice->get_currency());
57 57
 		}
58 58
 
59 59
 		// Item quantity.
60
-		if ( 'quantity' == $column ) {
60
+		if ('quantity' == $column) {
61 61
 			echo (float) $item->get_quantity();
62 62
 		}
63 63
 
64 64
 		// Tax rate.
65
-		if ( 'tax_rate' == $column ) {
66
-			echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
65
+		if ('tax_rate' == $column) {
66
+			echo floatval(round(getpaid_get_invoice_tax_rate($invoice, $item), 2)) . '%';
67 67
 		}
68 68
 
69 69
 		// Item sub total.
70
-		if ( 'subtotal' == $column ) {
70
+		if ('subtotal' == $column) {
71 71
 			$subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
72
-			wpinv_the_price( $subtotal, $invoice->get_currency() );
72
+			wpinv_the_price($subtotal, $invoice->get_currency());
73 73
 		}
74 74
 
75 75
 		// Fires when printing a line item column.
76
-		do_action( "getpaid_email_line_item_$column", $item, $invoice );
76
+		do_action("getpaid_email_line_item_$column", $item, $invoice);
77 77
 		?>
78 78
 	</td>
79 79
 	<?php endforeach; ?>
80 80
 </tr>
81 81
 
82
-<?php do_action( 'getpaid_after_email_line_item', $invoice, $item ); ?>
82
+<?php do_action('getpaid_after_email_line_item', $invoice, $item); ?>
Please login to merge, or discard this patch.
templates/invoice/line-item.php 2 patches
Indentation   +62 added lines, -62 removed lines patch added patch discarded remove patch
@@ -26,90 +26,90 @@
 block discarded – undo
26 26
 
27 27
 				<?php
28 28
 
29
-					// Fires before printing a line item column.
30
-					do_action( "getpaid_invoice_line_item_before_$column", $item, $invoice );
29
+                    // Fires before printing a line item column.
30
+                    do_action( "getpaid_invoice_line_item_before_$column", $item, $invoice );
31 31
 
32
-					// Item name.
33
-					if ( 'name' === $column ) {
32
+                    // Item name.
33
+                    if ( 'name' === $column ) {
34 34
 
35
-						$has_featured_image = has_post_thumbnail( $item->get_id() );
35
+                        $has_featured_image = has_post_thumbnail( $item->get_id() );
36 36
 
37
-						if ( $has_featured_image ) {
38
-							echo '<div class="d-flex align-items-center getpaid-form-item-has-featured-image">';
39
-							echo '<div class="getpaid-form-item-image-container mr-2" style="width:85px;">';
40
-							echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'getpaid-form-item-image mb-0' ) );
41
-							echo '</div>';
42
-							echo '<div class="getpaid-form-item-name-container">';
43
-						}
37
+                        if ( $has_featured_image ) {
38
+                            echo '<div class="d-flex align-items-center getpaid-form-item-has-featured-image">';
39
+                            echo '<div class="getpaid-form-item-image-container mr-2" style="width:85px;">';
40
+                            echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'getpaid-form-item-image mb-0' ) );
41
+                            echo '</div>';
42
+                            echo '<div class="getpaid-form-item-name-container">';
43
+                        }
44 44
 
45
-						// Display the name.
46
-						echo '<div class="mb-1">' . esc_html( $item->get_name() ) . '</div>';
45
+                        // Display the name.
46
+                        echo '<div class="mb-1">' . esc_html( $item->get_name() ) . '</div>';
47 47
 
48
-						// And an optional description.
49
-						$description = $item->get_description();
48
+                        // And an optional description.
49
+                        $description = $item->get_description();
50 50
 
51
-						if ( ! empty( $description ) ) {
52
-							echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post( $description ) . '</small>';
53
-						}
51
+                        if ( ! empty( $description ) ) {
52
+                            echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post( $description ) . '</small>';
53
+                        }
54 54
 
55
-						// Fires before printing the line item actions.
56
-						do_action( 'getpaid_before_invoice_line_item_actions', $item, $invoice );
55
+                        // Fires before printing the line item actions.
56
+                        do_action( 'getpaid_before_invoice_line_item_actions', $item, $invoice );
57 57
 
58
-						$actions = apply_filters( 'getpaid-invoice-page-line-item-actions', array(), $item, $invoice );
58
+                        $actions = apply_filters( 'getpaid-invoice-page-line-item-actions', array(), $item, $invoice );
59 59
 
60
-						if ( ! empty( $actions ) ) {
60
+                        if ( ! empty( $actions ) ) {
61 61
 
62
-							$sanitized  = array();
63
-							foreach ( $actions as $key => $item_action ) {
64
-								$key         = sanitize_html_class( $key );
65
-								$item_action = wp_kses_post( $item_action );
66
-								$sanitized[] = "<span class='$key'>$item_action</span>";
67
-							}
62
+                            $sanitized  = array();
63
+                            foreach ( $actions as $key => $item_action ) {
64
+                                $key         = sanitize_html_class( $key );
65
+                                $item_action = wp_kses_post( $item_action );
66
+                                $sanitized[] = "<span class='$key'>$item_action</span>";
67
+                            }
68 68
 
69
-							echo "<small class='form-text getpaid-line-item-actions'>";
70
-							echo wp_kses_post( implode( ' | ', $sanitized ) );
71
-							echo '</small>';
69
+                            echo "<small class='form-text getpaid-line-item-actions'>";
70
+                            echo wp_kses_post( implode( ' | ', $sanitized ) );
71
+                            echo '</small>';
72 72
 
73
-						}
73
+                        }
74 74
 
75
-						if ( $has_featured_image ) {
76
-							echo '</div>';
77
-							echo '</div>';
78
-						}
79
-					}
75
+                        if ( $has_featured_image ) {
76
+                            echo '</div>';
77
+                            echo '</div>';
78
+                        }
79
+                    }
80 80
 
81
-					// Item price.
82
-					if ( 'price' === $column ) {
81
+                    // Item price.
82
+                    if ( 'price' === $column ) {
83 83
 
84
-					// Display the item price (or recurring price if this is a renewal invoice)
85
-					$price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
86
-					wpinv_the_price( $price, $invoice->get_currency() );
84
+                    // Display the item price (or recurring price if this is a renewal invoice)
85
+                    $price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
86
+                    wpinv_the_price( $price, $invoice->get_currency() );
87 87
 
88
-					}
88
+                    }
89 89
 
90
-					// Tax rate.
91
-					if ( 'tax_rate' === $column ) {
92
-					echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
93
-					}
90
+                    // Tax rate.
91
+                    if ( 'tax_rate' === $column ) {
92
+                    echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
93
+                    }
94 94
 
95
-					// Item quantity.
96
-					if ( 'quantity' === $column ) {
97
-					echo (float) $item->get_quantity();
98
-					}
95
+                    // Item quantity.
96
+                    if ( 'quantity' === $column ) {
97
+                    echo (float) $item->get_quantity();
98
+                    }
99 99
 
100
-					// Item sub total.
101
-					if ( 'subtotal' === $column ) {
102
-					$subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
103
-					wpinv_the_price( $subtotal, $invoice->get_currency() );
104
-					}
100
+                    // Item sub total.
101
+                    if ( 'subtotal' === $column ) {
102
+                    $subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
103
+                    wpinv_the_price( $subtotal, $invoice->get_currency() );
104
+                    }
105 105
 
106
-					// Fires when printing a line item column.
107
-					do_action( "getpaid_invoice_line_item_$column", $item, $invoice );
106
+                    // Fires when printing a line item column.
107
+                    do_action( "getpaid_invoice_line_item_$column", $item, $invoice );
108 108
 
109
-					// Fires after printing a line item column.
110
-					do_action( "getpaid_invoice_line_item_after_$column", $item, $invoice );
109
+                    // Fires after printing a line item column.
110
+                    do_action( "getpaid_invoice_line_item_after_$column", $item, $invoice );
111 111
 
112
-				?>
112
+                ?>
113 113
 
114 114
 			</div>
115 115
 
Please login to merge, or discard this patch.
Spacing   +31 added lines, -31 removed lines patch added patch discarded remove patch
@@ -10,104 +10,104 @@
 block discarded – undo
10 10
  * @var array $columns
11 11
  */
12 12
 
13
-defined( 'ABSPATH' ) || exit;
13
+defined('ABSPATH') || exit;
14 14
 
15
-do_action( 'getpaid_before_invoice_line_item', $invoice, $item );
15
+do_action('getpaid_before_invoice_line_item', $invoice, $item);
16 16
 
17 17
 ?>
18 18
 
19
-<div class='getpaid-invoice-item item-<?php echo (int) $item->get_id(); ?> item-type-<?php echo esc_attr( $item->get_type() ); ?> border-bottom'>
19
+<div class='getpaid-invoice-item item-<?php echo (int) $item->get_id(); ?> item-type-<?php echo esc_attr($item->get_type()); ?> border-bottom'>
20 20
 
21 21
 	<div class="form-row row align-items-center">
22 22
 
23
-		<?php foreach ( array_keys( $columns ) as $column ) : ?>
23
+		<?php foreach (array_keys($columns) as $column) : ?>
24 24
 
25
-			<div class="<?php echo 'name' === $column ? 'col-12 col-sm-6' : 'col-12 col-sm'; ?> getpaid-invoice-item-<?php echo esc_attr( $column ); ?>">
25
+			<div class="<?php echo 'name' === $column ? 'col-12 col-sm-6' : 'col-12 col-sm'; ?> getpaid-invoice-item-<?php echo esc_attr($column); ?>">
26 26
 
27 27
 				<?php
28 28
 
29 29
 					// Fires before printing a line item column.
30
-					do_action( "getpaid_invoice_line_item_before_$column", $item, $invoice );
30
+					do_action("getpaid_invoice_line_item_before_$column", $item, $invoice);
31 31
 
32 32
 					// Item name.
33
-					if ( 'name' === $column ) {
33
+					if ('name' === $column) {
34 34
 
35
-						$has_featured_image = has_post_thumbnail( $item->get_id() );
35
+						$has_featured_image = has_post_thumbnail($item->get_id());
36 36
 
37
-						if ( $has_featured_image ) {
37
+						if ($has_featured_image) {
38 38
 							echo '<div class="d-flex align-items-center getpaid-form-item-has-featured-image">';
39 39
 							echo '<div class="getpaid-form-item-image-container mr-2" style="width:85px;">';
40
-							echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'getpaid-form-item-image mb-0' ) );
40
+							echo get_the_post_thumbnail($item->get_id(), array(75, 75), array('class' => 'getpaid-form-item-image mb-0'));
41 41
 							echo '</div>';
42 42
 							echo '<div class="getpaid-form-item-name-container">';
43 43
 						}
44 44
 
45 45
 						// Display the name.
46
-						echo '<div class="mb-1">' . esc_html( $item->get_name() ) . '</div>';
46
+						echo '<div class="mb-1">' . esc_html($item->get_name()) . '</div>';
47 47
 
48 48
 						// And an optional description.
49 49
 						$description = $item->get_description();
50 50
 
51
-						if ( ! empty( $description ) ) {
52
-							echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post( $description ) . '</small>';
51
+						if (!empty($description)) {
52
+							echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post($description) . '</small>';
53 53
 						}
54 54
 
55 55
 						// Fires before printing the line item actions.
56
-						do_action( 'getpaid_before_invoice_line_item_actions', $item, $invoice );
56
+						do_action('getpaid_before_invoice_line_item_actions', $item, $invoice);
57 57
 
58
-						$actions = apply_filters( 'getpaid-invoice-page-line-item-actions', array(), $item, $invoice );
58
+						$actions = apply_filters('getpaid-invoice-page-line-item-actions', array(), $item, $invoice);
59 59
 
60
-						if ( ! empty( $actions ) ) {
60
+						if (!empty($actions)) {
61 61
 
62
-							$sanitized  = array();
63
-							foreach ( $actions as $key => $item_action ) {
64
-								$key         = sanitize_html_class( $key );
65
-								$item_action = wp_kses_post( $item_action );
62
+							$sanitized = array();
63
+							foreach ($actions as $key => $item_action) {
64
+								$key         = sanitize_html_class($key);
65
+								$item_action = wp_kses_post($item_action);
66 66
 								$sanitized[] = "<span class='$key'>$item_action</span>";
67 67
 							}
68 68
 
69 69
 							echo "<small class='form-text getpaid-line-item-actions'>";
70
-							echo wp_kses_post( implode( ' | ', $sanitized ) );
70
+							echo wp_kses_post(implode(' | ', $sanitized));
71 71
 							echo '</small>';
72 72
 
73 73
 						}
74 74
 
75
-						if ( $has_featured_image ) {
75
+						if ($has_featured_image) {
76 76
 							echo '</div>';
77 77
 							echo '</div>';
78 78
 						}
79 79
 					}
80 80
 
81 81
 					// Item price.
82
-					if ( 'price' === $column ) {
82
+					if ('price' === $column) {
83 83
 
84 84
 					// Display the item price (or recurring price if this is a renewal invoice)
85 85
 					$price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
86
-					wpinv_the_price( $price, $invoice->get_currency() );
86
+					wpinv_the_price($price, $invoice->get_currency());
87 87
 
88 88
 					}
89 89
 
90 90
 					// Tax rate.
91
-					if ( 'tax_rate' === $column ) {
92
-					echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
91
+					if ('tax_rate' === $column) {
92
+					echo floatval(round(getpaid_get_invoice_tax_rate($invoice, $item), 2)) . '%';
93 93
 					}
94 94
 
95 95
 					// Item quantity.
96
-					if ( 'quantity' === $column ) {
96
+					if ('quantity' === $column) {
97 97
 					echo (float) $item->get_quantity();
98 98
 					}
99 99
 
100 100
 					// Item sub total.
101
-					if ( 'subtotal' === $column ) {
101
+					if ('subtotal' === $column) {
102 102
 					$subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
103
-					wpinv_the_price( $subtotal, $invoice->get_currency() );
103
+					wpinv_the_price($subtotal, $invoice->get_currency());
104 104
 					}
105 105
 
106 106
 					// Fires when printing a line item column.
107
-					do_action( "getpaid_invoice_line_item_$column", $item, $invoice );
107
+					do_action("getpaid_invoice_line_item_$column", $item, $invoice);
108 108
 
109 109
 					// Fires after printing a line item column.
110
-					do_action( "getpaid_invoice_line_item_after_$column", $item, $invoice );
110
+					do_action("getpaid_invoice_line_item_after_$column", $item, $invoice);
111 111
 
112 112
 				?>
113 113
 
Please login to merge, or discard this patch.
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   +797 added lines, -797 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
 		/**
@@ -856,32 +856,32 @@  discard block
 block discarded – undo
856 856
 		 */
857 857
 		public function get_settings() {
858 858
 
859
-			$db_settings = get_option( 'ayecode-ui-settings' );
859
+			$db_settings = get_option('ayecode-ui-settings');
860 860
 
861 861
             // Maybe show default version notice
862
-			$site_install_date = new DateTime( self::get_site_install_date() );
862
+			$site_install_date = new DateTime(self::get_site_install_date());
863 863
 			$switch_over_date = new DateTime("2024-02-01");
864
-			if ( empty( $db_settings ) && $site_install_date < $switch_over_date ) {
865
-				add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
864
+			if (empty($db_settings) && $site_install_date < $switch_over_date) {
865
+				add_action('admin_notices', array($this, 'show_admin_version_notice'));
866 866
 			}
867 867
 
868 868
 			$js_default = 'core-popper';
869 869
 			$js_default_backend = $js_default;
870 870
 
871 871
 			// maybe set defaults (if no settings set)
872
-			if(empty($db_settings)){
873
-				$active_theme = strtolower( get_template() ); // active parent theme.
872
+			if (empty($db_settings)) {
873
+				$active_theme = strtolower(get_template()); // active parent theme.
874 874
 				$theme_js_settings = self::theme_js_settings();
875
-				if(isset($theme_js_settings[$active_theme])){
875
+				if (isset($theme_js_settings[$active_theme])) {
876 876
 					$js_default = $theme_js_settings[$active_theme];
877
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
877
+					$js_default_backend = isset($theme_js_settings[$active_theme . "_backend"]) ? $theme_js_settings[$active_theme . "_backend"] : $js_default;
878 878
 				}
879 879
 			}
880 880
 
881 881
 			/**
882 882
 			 * Filter the default settings.
883 883
 			 */
884
-			$defaults = apply_filters( 'ayecode-ui-default-settings', array(
884
+			$defaults = apply_filters('ayecode-ui-default-settings', array(
885 885
 				'css'            => 'compatibility', // core, compatibility
886 886
 				'js'             => $js_default, // js to load, core-popper, popper
887 887
 				'html_font_size' => '16', // js to load, core-popper, popper
@@ -889,16 +889,16 @@  discard block
 block discarded – undo
889 889
 				'js_backend'     => $js_default_backend, // js to load, core-popper, popper
890 890
 				'disable_admin'  => '', // URL snippets to disable loading on admin
891 891
                 'bs_ver'         => '5', // The default bootstrap version to sue by default
892
-			), $db_settings );
892
+			), $db_settings);
893 893
 
894
-			$settings = wp_parse_args( $db_settings, $defaults );
894
+			$settings = wp_parse_args($db_settings, $defaults);
895 895
 
896 896
 			/**
897 897
 			 * Filter the Bootstrap settings.
898 898
 			 *
899 899
 			 * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
900 900
 			 */
901
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
901
+			return $this->settings = apply_filters('ayecode-ui-settings', $settings, $db_settings, $defaults);
902 902
 		}
903 903
 
904 904
 
@@ -906,109 +906,109 @@  discard block
 block discarded – undo
906 906
 		 * The settings page html output.
907 907
 		 */
908 908
 		public function settings_page() {
909
-			if ( ! current_user_can( 'manage_options' ) ) {
910
-				wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
909
+			if (!current_user_can('manage_options')) {
910
+				wp_die(esc_attr__('You do not have sufficient permissions to access this page.', 'ayecode-connect'));
911 911
 			}
912
-            $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
912
+            $overrides = apply_filters('ayecode-ui-settings', array(), array(), array());
913 913
 
914 914
 			?>
915 915
             <div class="wrap">
916
-                <h1><?php echo esc_attr( $this->name ); ?></h1>
917
-                <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>
916
+                <h1><?php echo esc_attr($this->name); ?></h1>
917
+                <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 918
                 <form method="post" action="options.php">
919 919
 					<?php
920
-					settings_fields( 'ayecode-ui-settings' );
921
-					do_settings_sections( 'ayecode-ui-settings' );
920
+					settings_fields('ayecode-ui-settings');
921
+					do_settings_sections('ayecode-ui-settings');
922 922
 					?>
923 923
 
924
-                    <h2><?php esc_html_e( 'BootStrap Version', 'ayecode-connect' ); ?></h2>
925
-                    <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>
924
+                    <h2><?php esc_html_e('BootStrap Version', 'ayecode-connect'); ?></h2>
925
+                    <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 926
 	                <div class="bsui"><?php
927
-	                if ( ! empty( $overrides ) ) {
927
+	                if (!empty($overrides)) {
928 928
 		                echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
929 929
 			                'type'=> 'info',
930
-			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
930
+			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect')
931 931
 		                ));
932 932
 	                }
933 933
 	                ?>
934 934
                     </div>
935 935
                     <table class="form-table wpbs-table-version-settings">
936 936
                         <tr valign="top">
937
-                            <th scope="row"><label for="wpbs-css"><?php esc_html_e( 'Version', 'ayecode-connect' ); ?></label></th>
937
+                            <th scope="row"><label for="wpbs-css"><?php esc_html_e('Version', 'ayecode-connect'); ?></label></th>
938 938
                             <td>
939 939
                                 <select name="ayecode-ui-settings[bs_ver]" id="wpbs-css" <?php echo !empty($overrides['bs_ver']) ? 'disabled' : ''; ?>>
940
-                                    <option	value="5" <?php selected( $this->settings['bs_ver'], '5' ); ?>><?php esc_html_e( 'v5 (recommended)', 'ayecode-connect' ); ?></option>
941
-                                    <option value="4" <?php selected( $this->settings['bs_ver'], '4' ); ?>><?php esc_html_e( 'v4 (legacy)', 'ayecode-connect' ); ?></option>
940
+                                    <option	value="5" <?php selected($this->settings['bs_ver'], '5'); ?>><?php esc_html_e('v5 (recommended)', 'ayecode-connect'); ?></option>
941
+                                    <option value="4" <?php selected($this->settings['bs_ver'], '4'); ?>><?php esc_html_e('v4 (legacy)', 'ayecode-connect'); ?></option>
942 942
                                 </select>
943 943
                             </td>
944 944
                         </tr>
945 945
                     </table>
946 946
 
947
-                    <h2><?php esc_html_e( 'Frontend', 'ayecode-connect' ); ?></h2>
947
+                    <h2><?php esc_html_e('Frontend', 'ayecode-connect'); ?></h2>
948 948
                     <table class="form-table wpbs-table-settings">
949 949
                         <tr valign="top">
950
-                            <th scope="row"><label for="wpbs-css"><?php esc_html_e( 'Load CSS', 'ayecode-connect' ); ?></label></th>
950
+                            <th scope="row"><label for="wpbs-css"><?php esc_html_e('Load CSS', 'ayecode-connect'); ?></label></th>
951 951
                             <td>
952 952
                                 <select name="ayecode-ui-settings[css]" id="wpbs-css" <?php echo !empty($overrides['css']) ? 'disabled' : ''; ?>>
953
-                                    <option	value="compatibility" <?php selected( $this->settings['css'], 'compatibility' ); ?>><?php esc_html_e( 'Compatibility Mode (default)', 'ayecode-connect' ); ?></option>
954
-                                    <option value="core" <?php selected( $this->settings['css'], 'core' ); ?>><?php esc_html_e( 'Full Mode', 'ayecode-connect' ); ?></option>
955
-                                    <option	value="" <?php selected( $this->settings['css'], '' ); ?>><?php esc_html_e( 'Disabled', 'ayecode-connect' ); ?></option>
953
+                                    <option	value="compatibility" <?php selected($this->settings['css'], 'compatibility'); ?>><?php esc_html_e('Compatibility Mode (default)', 'ayecode-connect'); ?></option>
954
+                                    <option value="core" <?php selected($this->settings['css'], 'core'); ?>><?php esc_html_e('Full Mode', 'ayecode-connect'); ?></option>
955
+                                    <option	value="" <?php selected($this->settings['css'], ''); ?>><?php esc_html_e('Disabled', 'ayecode-connect'); ?></option>
956 956
                                 </select>
957 957
                             </td>
958 958
                         </tr>
959 959
 
960 960
                         <tr valign="top">
961
-                            <th scope="row"><label for="wpbs-js"><?php esc_html_e( 'Load JS', 'ayecode-connect' ); ?></label></th>
961
+                            <th scope="row"><label for="wpbs-js"><?php esc_html_e('Load JS', 'ayecode-connect'); ?></label></th>
962 962
                             <td>
963 963
                                 <select name="ayecode-ui-settings[js]" id="wpbs-js" <?php echo !empty($overrides['js']) ? 'disabled' : ''; ?>>
964
-                                    <option	value="core-popper" <?php selected( $this->settings['js'], 'core-popper' ); ?>><?php esc_html_e( 'Core + Popper (default)', 'ayecode-connect' ); ?></option>
965
-                                    <option value="popper" <?php selected( $this->settings['js'], 'popper' ); ?>><?php esc_html_e( 'Popper', 'ayecode-connect' ); ?></option>
966
-                                    <option value="required" <?php selected( $this->settings['js'], 'required' ); ?>><?php esc_html_e( 'Required functions only', 'ayecode-connect' ); ?></option>
967
-                                    <option	value="" <?php selected( $this->settings['js'], '' ); ?>><?php esc_html_e( 'Disabled (not recommended)', 'ayecode-connect' ); ?></option>
964
+                                    <option	value="core-popper" <?php selected($this->settings['js'], 'core-popper'); ?>><?php esc_html_e('Core + Popper (default)', 'ayecode-connect'); ?></option>
965
+                                    <option value="popper" <?php selected($this->settings['js'], 'popper'); ?>><?php esc_html_e('Popper', 'ayecode-connect'); ?></option>
966
+                                    <option value="required" <?php selected($this->settings['js'], 'required'); ?>><?php esc_html_e('Required functions only', 'ayecode-connect'); ?></option>
967
+                                    <option	value="" <?php selected($this->settings['js'], ''); ?>><?php esc_html_e('Disabled (not recommended)', 'ayecode-connect'); ?></option>
968 968
                                 </select>
969 969
                             </td>
970 970
                         </tr>
971 971
 
972 972
                         <tr valign="top">
973
-                            <th scope="row"><label for="wpbs-font_size"><?php esc_html_e( 'HTML Font Size (px)', 'ayecode-connect' ); ?></label></th>
973
+                            <th scope="row"><label for="wpbs-font_size"><?php esc_html_e('HTML Font Size (px)', 'ayecode-connect'); ?></label></th>
974 974
                             <td>
975
-                                <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' : ''; ?> />
976
-                                <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>
975
+                                <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' : ''; ?> />
976
+                                <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 977
                             </td>
978 978
                         </tr>
979 979
 
980 980
                     </table>
981 981
 
982
-                    <h2><?php esc_html_e( 'Backend', 'ayecode-connect' ); ?> (wp-admin)</h2>
982
+                    <h2><?php esc_html_e('Backend', 'ayecode-connect'); ?> (wp-admin)</h2>
983 983
                     <table class="form-table wpbs-table-settings">
984 984
                         <tr valign="top">
985
-                            <th scope="row"><label for="wpbs-css-admin"><?php esc_html_e( 'Load CSS', 'ayecode-connect' ); ?></label></th>
985
+                            <th scope="row"><label for="wpbs-css-admin"><?php esc_html_e('Load CSS', 'ayecode-connect'); ?></label></th>
986 986
                             <td>
987 987
                                 <select name="ayecode-ui-settings[css_backend]" id="wpbs-css-admin" <?php echo !empty($overrides['css_backend']) ? 'disabled' : ''; ?>>
988
-                                    <option	value="compatibility" <?php selected( $this->settings['css_backend'], 'compatibility' ); ?>><?php esc_html_e( 'Compatibility Mode (default)', 'ayecode-connect' ); ?></option>
989
-                                    <option value="core" <?php selected( $this->settings['css_backend'], 'core' ); ?>><?php esc_html_e( 'Full Mode (will cause style issues)', 'ayecode-connect' ); ?></option>
990
-                                    <option	value="" <?php selected( $this->settings['css_backend'], '' ); ?>><?php esc_html_e( 'Disabled', 'ayecode-connect' ); ?></option>
988
+                                    <option	value="compatibility" <?php selected($this->settings['css_backend'], 'compatibility'); ?>><?php esc_html_e('Compatibility Mode (default)', 'ayecode-connect'); ?></option>
989
+                                    <option value="core" <?php selected($this->settings['css_backend'], 'core'); ?>><?php esc_html_e('Full Mode (will cause style issues)', 'ayecode-connect'); ?></option>
990
+                                    <option	value="" <?php selected($this->settings['css_backend'], ''); ?>><?php esc_html_e('Disabled', 'ayecode-connect'); ?></option>
991 991
                                 </select>
992 992
                             </td>
993 993
                         </tr>
994 994
 
995 995
                         <tr valign="top">
996
-                            <th scope="row"><label for="wpbs-js-admin"><?php esc_html_e( 'Load JS', 'ayecode-connect' ); ?></label></th>
996
+                            <th scope="row"><label for="wpbs-js-admin"><?php esc_html_e('Load JS', 'ayecode-connect'); ?></label></th>
997 997
                             <td>
998 998
                                 <select name="ayecode-ui-settings[js_backend]" id="wpbs-js-admin" <?php echo !empty($overrides['js_backend']) ? 'disabled' : ''; ?>>
999
-                                    <option	value="core-popper" <?php selected( $this->settings['js_backend'], 'core-popper' ); ?>><?php esc_html_e( 'Core + Popper (default)', 'ayecode-connect' ); ?></option>
1000
-                                    <option value="popper" <?php selected( $this->settings['js_backend'], 'popper' ); ?>><?php esc_html_e( 'Popper', 'ayecode-connect' ); ?></option>
1001
-                                    <option value="required" <?php selected( $this->settings['js_backend'], 'required' ); ?>><?php esc_html_e( 'Required functions only', 'ayecode-connect' ); ?></option>
1002
-                                    <option	value="" <?php selected( $this->settings['js_backend'], '' ); ?>><?php esc_html_e( 'Disabled (not recommended)', 'ayecode-connect' ); ?></option>
999
+                                    <option	value="core-popper" <?php selected($this->settings['js_backend'], 'core-popper'); ?>><?php esc_html_e('Core + Popper (default)', 'ayecode-connect'); ?></option>
1000
+                                    <option value="popper" <?php selected($this->settings['js_backend'], 'popper'); ?>><?php esc_html_e('Popper', 'ayecode-connect'); ?></option>
1001
+                                    <option value="required" <?php selected($this->settings['js_backend'], 'required'); ?>><?php esc_html_e('Required functions only', 'ayecode-connect'); ?></option>
1002
+                                    <option	value="" <?php selected($this->settings['js_backend'], ''); ?>><?php esc_html_e('Disabled (not recommended)', 'ayecode-connect'); ?></option>
1003 1003
                                 </select>
1004 1004
                             </td>
1005 1005
                         </tr>
1006 1006
 
1007 1007
                         <tr valign="top">
1008
-                            <th scope="row"><label for="wpbs-disable-admin"><?php esc_html_e( 'Disable load on URL', 'ayecode-connect' ); ?></label></th>
1008
+                            <th scope="row"><label for="wpbs-disable-admin"><?php esc_html_e('Disable load on URL', 'ayecode-connect'); ?></label></th>
1009 1009
                             <td>
1010
-                                <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>
1011
-                                <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>
1010
+                                <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>
1011
+                                <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 1012
                             </td>
1013 1013
                         </tr>
1014 1014
                     </table>
@@ -1017,33 +1017,33 @@  discard block
 block discarded – undo
1017 1017
 					submit_button();
1018 1018
 					?>
1019 1019
                 </form>
1020
-                <div id="wpbs-version" data-aui-source="<?php echo esc_attr( $this->get_load_source() ); ?>"><?php echo esc_html( $this->version ); ?></div>
1020
+                <div id="wpbs-version" data-aui-source="<?php echo esc_attr($this->get_load_source()); ?>"><?php echo esc_html($this->version); ?></div>
1021 1021
             </div>
1022 1022
 			<?php
1023 1023
 		}
1024 1024
 
1025
-        public function get_load_source(){
1026
-	        $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1027
-	        $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1025
+        public function get_load_source() {
1026
+	        $file = str_replace(array("/", "\\"), "/", realpath(__FILE__));
1027
+	        $plugins_dir = str_replace(array("/", "\\"), "/", realpath(WP_PLUGIN_DIR));
1028 1028
 
1029 1029
 	        // Find source plugin/theme of SD
1030 1030
 	        $source = array();
1031
-	        if ( strpos( $file, $plugins_dir ) !== false ) {
1032
-		        $source = explode( "/", plugin_basename( $file ) );
1033
-	        } else if ( function_exists( 'get_theme_root' ) ) {
1034
-		        $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1031
+	        if (strpos($file, $plugins_dir) !== false) {
1032
+		        $source = explode("/", plugin_basename($file));
1033
+	        } else if (function_exists('get_theme_root')) {
1034
+		        $themes_dir = str_replace(array("/", "\\"), "/", realpath(get_theme_root()));
1035 1035
 
1036
-		        if ( strpos( $file, $themes_dir ) !== false ) {
1037
-			        $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1036
+		        if (strpos($file, $themes_dir) !== false) {
1037
+			        $source = explode("/", ltrim(str_replace($themes_dir, "", $file), "/"));
1038 1038
 		        }
1039 1039
 	        }
1040 1040
 
1041 1041
             return isset($source[0]) ? esc_attr($source[0]) : '';
1042 1042
         }
1043 1043
 
1044
-		public function customizer_settings($wp_customize){
1044
+		public function customizer_settings($wp_customize) {
1045 1045
 			$wp_customize->add_section('aui_settings', array(
1046
-				'title'    => __('AyeCode UI', 'ayecode-connect' ),
1046
+				'title'    => __('AyeCode UI', 'ayecode-connect'),
1047 1047
 				'priority' => 120,
1048 1048
 			));
1049 1049
 
@@ -1057,8 +1057,8 @@  discard block
 block discarded – undo
1057 1057
 				'type'              => 'option',
1058 1058
 				'transport'         => 'refresh',
1059 1059
 			));
1060
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1061
-				'label'    => __('Primary Color', 'ayecode-connect' ),
1060
+			$wp_customize->add_control(new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1061
+				'label'    => __('Primary Color', 'ayecode-connect'),
1062 1062
 				'section'  => 'aui_settings',
1063 1063
 				'settings' => 'aui_options[color_primary]',
1064 1064
 			)));
@@ -1070,8 +1070,8 @@  discard block
 block discarded – undo
1070 1070
 				'type'              => 'option',
1071 1071
 				'transport'         => 'refresh',
1072 1072
 			));
1073
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1074
-				'label'    => __('Secondary Color', 'ayecode-connect' ),
1073
+			$wp_customize->add_control(new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1074
+				'label'    => __('Secondary Color', 'ayecode-connect'),
1075 1075
 				'section'  => 'aui_settings',
1076 1076
 				'settings' => 'aui_options[color_secondary]',
1077 1077
 			)));
@@ -1097,12 +1097,12 @@  discard block
 block discarded – undo
1097 1097
                 .collapse.show:not(.in){display: inherit;}
1098 1098
                 .fade.show{opacity: 1;}
1099 1099
 
1100
-                <?php if( defined( 'SVQ_THEME_VERSION' ) ){ ?>
1100
+                <?php if (defined('SVQ_THEME_VERSION')) { ?>
1101 1101
                 /* KLEO theme specific */
1102 1102
                 .kleo-main-header .navbar-collapse.collapse.show:not(.in){display: block !important;}
1103 1103
                 <?php } ?>
1104 1104
 
1105
-                <?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1105
+                <?php if (defined('FUSION_BUILDER_VERSION')) { ?>
1106 1106
                 /* With Avada builder */
1107 1107
                 body.modal-open .modal.in  {opacity:1;z-index: 99999}
1108 1108
                 body.modal-open .modal.bsui.in .modal-content  {box-shadow: none;}
@@ -1113,44 +1113,44 @@  discard block
 block discarded – undo
1113 1113
                 <?php } ?>
1114 1114
             </style>
1115 1115
 			<?php
1116
-			return str_replace( array(
1116
+			return str_replace(array(
1117 1117
 				'<style>',
1118 1118
 				'</style>'
1119
-			), '', self::minify_css( ob_get_clean() ) );
1119
+			), '', self::minify_css(ob_get_clean()));
1120 1120
 		}
1121 1121
 
1122
-		public static function custom_css( $compatibility = true, $is_fse = false ) {
1122
+		public static function custom_css($compatibility = true, $is_fse = false) {
1123 1123
 			global $aui_bs5;
1124 1124
 
1125 1125
 			$colors = array();
1126 1126
 
1127
-			if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1127
+			if (defined('BLOCKSTRAP_VERSION')) {
1128 1128
 				$setting = wp_get_global_settings();
1129 1129
 
1130
-				if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1131
-					foreach ( $setting['color']['palette']['theme'] as $color ) {
1132
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1130
+				if (!empty($setting['color']['palette']['theme'])) {
1131
+					foreach ($setting['color']['palette']['theme'] as $color) {
1132
+						$colors[$color['slug']] = esc_attr($color['color']);
1133 1133
 					}
1134 1134
 				}
1135 1135
 
1136
-				if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1137
-					foreach ( $setting['color']['palette']['custom'] as $color ) {
1138
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1136
+				if (!empty($setting['color']['palette']['custom'])) {
1137
+					foreach ($setting['color']['palette']['custom'] as $color) {
1138
+						$colors[$color['slug']] = esc_attr($color['color']);
1139 1139
 					}
1140 1140
 				}
1141 1141
 			} else {
1142
-				$settings = get_option( 'aui_options' );
1142
+				$settings = get_option('aui_options');
1143 1143
 
1144 1144
 				$colors = array(
1145
-					'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1146
-					'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1145
+					'primary'   => !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1146
+					'secondary' => !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1147 1147
 				);
1148 1148
 			}
1149 1149
 
1150 1150
 			ob_start();
1151 1151
 			?><style><?php
1152 1152
 			// BS v3 compat
1153
-			if( self::is_bs3_compat() ){
1153
+			if (self::is_bs3_compat()) {
1154 1154
 				echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1155 1155
 			}
1156 1156
 
@@ -1159,152 +1159,152 @@  discard block
 block discarded – undo
1159 1159
 				//$is_fse = true;
1160 1160
 			//}
1161 1161
 
1162
-			$custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1163
-			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1164
-            $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1162
+			$custom_front = !is_admin() ? true : apply_filters('ayecode_ui_custom_front', false);
1163
+			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false);
1164
+            $bs_custom_css = apply_filters('ayecode_ui_bs_custom_css', $custom_admin || $custom_front);
1165 1165
 			//$bs_custom_css = true; // Force true to fix any color issue.
1166 1166
 
1167 1167
 			$colors_css = '';
1168
-			if ( ! empty( $colors ) && $bs_custom_css ) {
1168
+			if (!empty($colors) && $bs_custom_css) {
1169 1169
 				$d_colors = self::get_colors(true);
1170 1170
 
1171
-				foreach ( $colors as $key => $color ) {
1172
-					if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1171
+				foreach ($colors as $key => $color) {
1172
+					if ((empty($d_colors[$key]) || $d_colors[$key] != $color) || $is_fse) {
1173 1173
 						$var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1174 1174
 						$compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1175 1175
 
1176
-						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1176
+						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5($key, $var, $compat, $color) : self::css_overwrite($key, $var, $compat, $color);
1177 1177
 					}
1178 1178
 				}
1179 1179
 			}
1180 1180
 
1181
-			if ( $colors_css ) {
1181
+			if ($colors_css) {
1182 1182
 				echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1183 1183
 			}
1184 1184
 
1185 1185
 			// Set admin bar z-index lower when modal is open.
1186 1186
 			echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1187 1187
 
1188
-			if ( is_admin() ) {
1188
+			if (is_admin()) {
1189 1189
 				echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1190 1190
 			}
1191 1191
 
1192 1192
 			$custom_css = '';
1193 1193
 
1194
-			if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1194
+			if ($aui_bs5 && defined('BLOCKSTRAP_VERSION') && $bs_custom_css) {
1195 1195
 				$css = '';
1196 1196
 				$theme_settings = wp_get_global_styles();
1197 1197
 
1198 1198
 				// Font face
1199
-				if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1200
-					$t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1199
+				if (!empty($theme_settings['typography']['fontFamily'])) {
1200
+					$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 1201
 					$css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1202 1202
 				}
1203 1203
 
1204 1204
 				// font size
1205
-				if( !empty( $theme_settings['typography']['fontSize'] ) ){
1206
-					$css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1205
+				if (!empty($theme_settings['typography']['fontSize'])) {
1206
+					$css .= '--bs-body-font-size: ' . esc_attr($theme_settings['typography']['fontSize']) . ' ;';
1207 1207
 				}
1208 1208
 
1209 1209
 				// line height
1210
-				 if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1211
-					$css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1210
+				 if (!empty($theme_settings['typography']['lineHeight'])) {
1211
+					$css .= '--bs-body-line-height: ' . esc_attr($theme_settings['typography']['lineHeight']) . ';';
1212 1212
 				}
1213 1213
 
1214 1214
 
1215 1215
 				   // font weight
1216
-				 if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1217
-					$css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1216
+				 if (!empty($theme_settings['typography']['fontWeight'])) {
1217
+					$css .= '--bs-body-font-weight: ' . esc_attr($theme_settings['typography']['fontWeight']) . ';';
1218 1218
 				}
1219 1219
 
1220 1220
 				// Background
1221
-				 if( !empty( $theme_settings['color']['background'] ) ){
1222
-					$css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1221
+				 if (!empty($theme_settings['color']['background'])) {
1222
+					$css .= '--bs-body-bg: ' . esc_attr($theme_settings['color']['background']) . ';';
1223 1223
 				}
1224 1224
 
1225 1225
 				 // Background Gradient
1226
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1227
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1226
+				 if (!empty($theme_settings['color']['gradient'])) {
1227
+					$css .= 'background: ' . esc_attr($theme_settings['color']['gradient']) . ';';
1228 1228
 				}
1229 1229
 
1230 1230
 				   // Background Gradient
1231
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1232
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1231
+				 if (!empty($theme_settings['color']['gradient'])) {
1232
+					$css .= 'background: ' . esc_attr($theme_settings['color']['gradient']) . ';';
1233 1233
 				}
1234 1234
 
1235 1235
 				// text color
1236
-				if( !empty( $theme_settings['color']['text'] ) ){
1237
-					$css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1236
+				if (!empty($theme_settings['color']['text'])) {
1237
+					$css .= '--bs-body-color: ' . esc_attr($theme_settings['color']['text']) . ';';
1238 1238
 				}
1239 1239
 
1240 1240
 
1241 1241
 				// link colors
1242
-				if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1243
-					$css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1242
+				if (!empty($theme_settings['elements']['link']['color']['text'])) {
1243
+					$css .= '--bs-link-color: ' . esc_attr($theme_settings['elements']['link']['color']['text']) . ';';
1244 1244
 				}
1245
-				if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1246
-					$css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1245
+				if (!empty($theme_settings['elements']['link'][':hover']['color']['text'])) {
1246
+					$css .= '--bs-link-hover-color: ' . esc_attr($theme_settings['elements']['link'][':hover']['color']['text']) . ';';
1247 1247
 				}
1248 1248
 
1249
-				if($css){
1250
-					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1249
+				if ($css) {
1250
+					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr($css) . '}' : 'body{' . esc_attr($css) . '}';
1251 1251
 				}
1252 1252
 
1253 1253
 				$bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1254 1254
 
1255 1255
 				// Headings
1256 1256
 				$headings_css = '';
1257
-				if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1258
-					$headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1257
+				if (!empty($theme_settings['elements']['heading']['color']['text'])) {
1258
+					$headings_css .= "color: " . esc_attr($theme_settings['elements']['heading']['color']['text']) . ";";
1259 1259
 				}
1260 1260
 
1261 1261
 				// heading background
1262
-				if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1263
-					$headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1262
+				if (!empty($theme_settings['elements']['heading']['color']['background'])) {
1263
+					$headings_css .= 'background: ' . esc_attr($theme_settings['elements']['heading']['color']['background']) . ';';
1264 1264
 				}
1265 1265
 
1266 1266
 				 // heading font family
1267
-				if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1268
-					$headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1267
+				if (!empty($theme_settings['elements']['heading']['typography']['fontFamily'])) {
1268
+					$headings_css .= 'font-family: ' . esc_attr($theme_settings['elements']['heading']['typography']['fontFamily']) . ';';
1269 1269
 				}
1270 1270
 
1271
-				if( $headings_css ){
1272
-					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1271
+				if ($headings_css) {
1272
+					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr($headings_css) . "}";
1273 1273
 				}
1274 1274
 
1275
-				$hs = array('h1','h2','h3','h4','h5','h6');
1275
+				$hs = array('h1', 'h2', 'h3', 'h4', 'h5', 'h6');
1276 1276
 
1277
-				foreach($hs as $hn){
1277
+				foreach ($hs as $hn) {
1278 1278
 					$h_css = '';
1279
-					 if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1280
-						$h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1279
+					 if (!empty($theme_settings['elements'][$hn]['color']['text'])) {
1280
+						$h_css .= 'color: ' . esc_attr($theme_settings['elements'][$hn]['color']['text']) . ';';
1281 1281
 					 }
1282 1282
 
1283
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1284
-						$h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1283
+					  if (!empty($theme_settings['elements'][$hn]['typography']['fontSize'])) {
1284
+						$h_css .= 'font-size: ' . esc_attr($theme_settings['elements'][$hn]['typography']['fontSize']) . ';';
1285 1285
 					 }
1286 1286
 
1287
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1288
-						$h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1287
+					  if (!empty($theme_settings['elements'][$hn]['typography']['fontFamily'])) {
1288
+						$h_css .= 'font-family: ' . esc_attr($theme_settings['elements'][$hn]['typography']['fontFamily']) . ';';
1289 1289
 					 }
1290 1290
 
1291
-					 if($h_css){
1292
-						$custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1291
+					 if ($h_css) {
1292
+						$custom_css .= esc_attr($bep . $hn) . '{' . esc_attr($h_css) . '}';
1293 1293
 					 }
1294 1294
 				}
1295 1295
 			}
1296 1296
 			
1297
-			if ( $custom_css ) {
1297
+			if ($custom_css) {
1298 1298
 				echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1299 1299
 			}
1300 1300
 
1301 1301
 			// Pagination on Hello Elementor theme.
1302
-			if ( function_exists( 'hello_elementor_setup' ) ) {
1302
+			if (function_exists('hello_elementor_setup')) {
1303 1303
 				echo '.aui-nav-links .pagination{justify-content:inherit}';
1304 1304
 			}
1305 1305
 
1306 1306
             // Astra theme - when woocommerce active they add compatibility CSS which breaks select2 in modals
1307
-            if( defined('ASTRA_THEME_VERSION')){
1307
+            if (defined('ASTRA_THEME_VERSION')) {
1308 1308
                 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;}';
1309 1309
             }
1310 1310
 
@@ -1314,10 +1314,10 @@  discard block
 block discarded – undo
1314 1314
 			/*
1315 1315
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1316 1316
 			 */
1317
-			return str_replace( array(
1317
+			return str_replace(array(
1318 1318
 				'<style>',
1319 1319
 				'</style>'
1320
-			), '', self::minify_css( $custom_css ) );
1320
+			), '', self::minify_css($custom_css));
1321 1321
 		}
1322 1322
 
1323 1323
 		/**
@@ -1325,34 +1325,34 @@  discard block
 block discarded – undo
1325 1325
 		 *
1326 1326
 		 * @return bool
1327 1327
 		 */
1328
-		public static function is_bs3_compat(){
1328
+		public static function is_bs3_compat() {
1329 1329
 			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1330 1330
 		}
1331 1331
 
1332
-		public static function hex_to_rgb( $hex ) {
1332
+		public static function hex_to_rgb($hex) {
1333 1333
 			// Remove '#' if present
1334
-			$hex = str_replace( '#', '', $hex );
1334
+			$hex = str_replace('#', '', $hex);
1335 1335
 
1336 1336
 			// Check if input is RGB
1337
-			if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1338
-				$_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1337
+			if (strpos($hex, 'rgba(') === 0 || strpos($hex, 'rgb(') === 0) {
1338
+				$_rgb = explode(',', str_replace(array('rgba(', 'rgb(', ')'), '', $hex));
1339 1339
 
1340
-				$rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1341
-				$rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1342
-				$rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1340
+				$rgb = (isset($_rgb[0]) ? (int) trim($_rgb[0]) : '0') . ',';
1341
+				$rgb .= (isset($_rgb[1]) ? (int) trim($_rgb[1]) : '0') . ',';
1342
+				$rgb .= (isset($_rgb[2]) ? (int) trim($_rgb[2]) : '0');
1343 1343
 
1344 1344
 				return $rgb;
1345 1345
 			}
1346 1346
 
1347 1347
 			// Convert 3-digit hex to 6-digit hex
1348
-			if ( strlen( $hex ) == 3 ) {
1349
-				$hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1348
+			if (strlen($hex) == 3) {
1349
+				$hex = str_repeat(substr($hex, 0, 1), 2) . str_repeat(substr($hex, 1, 1), 2) . str_repeat(substr($hex, 2, 1), 2);
1350 1350
 			}
1351 1351
 
1352 1352
 			// Convert hex to RGB
1353
-			$r = hexdec( substr( $hex, 0, 2 ) );
1354
-			$g = hexdec( substr( $hex, 2, 2 ) );
1355
-			$b = hexdec( substr( $hex, 4, 2 ) );
1353
+			$r = hexdec(substr($hex, 0, 2));
1354
+			$g = hexdec(substr($hex, 2, 2));
1355
+			$b = hexdec(substr($hex, 4, 2));
1356 1356
 
1357 1357
 			// Return RGB values as an array
1358 1358
 			return $r . ',' . $g . ',' . $b;
@@ -1367,13 +1367,13 @@  discard block
 block discarded – undo
1367 1367
 		 *
1368 1368
 		 * @return string
1369 1369
 		 */
1370
-		public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1370
+		public static function css_overwrite_bs5($type, $color_code, $compatibility, $hex = '') {
1371 1371
 			global $aui_bs5;
1372 1372
 
1373 1373
 			$is_var = false;
1374 1374
 			$is_custom = strpos($type, 'custom-') !== false ? true : false;
1375
-			if(!$color_code){return '';}
1376
-			if(strpos($color_code, 'var') !== false){
1375
+			if (!$color_code) {return ''; }
1376
+			if (strpos($color_code, 'var') !== false) {
1377 1377
 				//if(!sanitize_hex_color($color_code)){
1378 1378
 				$color_code = esc_attr($color_code);
1379 1379
 				$is_var = true;
@@ -1383,15 +1383,15 @@  discard block
 block discarded – undo
1383 1383
 
1384 1384
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1385 1385
 
1386
-			if(!$color_code){return '';}
1386
+			if (!$color_code) {return ''; }
1387 1387
 
1388 1388
 			$rgb = self::hex_to_rgb($hex);
1389 1389
 
1390
-			if($compatibility===true || $compatibility===1){
1390
+			if ($compatibility === true || $compatibility === 1) {
1391 1391
 				$compatibility = '.bsui';
1392
-			}elseif(!$compatibility){
1392
+			}elseif (!$compatibility) {
1393 1393
 				$compatibility = '';
1394
-			}else{
1394
+			} else {
1395 1395
 				$compatibility = esc_attr($compatibility);
1396 1396
 			}
1397 1397
 
@@ -1408,30 +1408,30 @@  discard block
 block discarded – undo
1408 1408
 			 * c = color, b = background color, o = border-color, f = fill
1409 1409
 			 */
1410 1410
 			$selectors = array(
1411
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1412
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1413
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1414
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1415
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1416
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1417
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1418
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1419
-				".badge-{$type}"                                            => array( 'b' ),
1420
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1421
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1422
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1423
-				".text-{$type}"                                     => array( 'c' ),
1411
+				".btn-{$type}"                                              => array('b', 'o'),
1412
+				".btn-{$type}.disabled"                                     => array('b', 'o'),
1413
+				".btn-{$type}:disabled"                                     => array('b', 'o'),
1414
+				".btn-outline-{$type}"                                      => array('c', 'o'),
1415
+				".btn-outline-{$type}:hover"                                => array('b', 'o'),
1416
+				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array('b', 'o'),
1417
+				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array('b', 'o'),
1418
+				".show>.btn-outline-{$type}.dropdown-toggle"                => array('b', 'o'),
1419
+				".badge-{$type}"                                            => array('b'),
1420
+				".alert-{$type}"                                            => array('b', 'o'),
1421
+				".bg-{$type}"                                               => array('b', 'f'),
1422
+				".btn-link.btn-{$type}"                                     => array('c'),
1423
+				".text-{$type}"                                     => array('c'),
1424 1424
 			);
1425 1425
 
1426
-			if ( $aui_bs5 ) {
1427
-				unset($selectors[".alert-{$type}" ]);
1426
+			if ($aui_bs5) {
1427
+				unset($selectors[".alert-{$type}"]);
1428 1428
 			}
1429 1429
 
1430
-			if ( $type == 'primary' ) {
1430
+			if ($type == 'primary') {
1431 1431
 				$selectors = $selectors + array(
1432
-						'a'                                                                                                    => array( 'c' ),
1433
-						'.btn-link'                                                                                            => array( 'c' ),
1434
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1432
+						'a'                                                                                                    => array('c'),
1433
+						'.btn-link'                                                                                            => array('c'),
1434
+						'.dropdown-item.active'                                                                                => array('b'),
1435 1435
 						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1436 1436
 							'b',
1437 1437
 							'o'
@@ -1440,57 +1440,57 @@  discard block
 block discarded – undo
1440 1440
 							'b',
1441 1441
 							'o'
1442 1442
 						),
1443
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1444
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1445
-						'.page-link'                                                                                           => array( 'c' ),
1443
+						'.nav-pills .nav-link.active'                                                                          => array('b'),
1444
+						'.nav-pills .show>.nav-link'                                                                           => array('b'),
1445
+						'.page-link'                                                                                           => array('c'),
1446 1446
 						'.page-item.active .page-link'                                                                         => array(
1447 1447
 							'b',
1448 1448
 							'o'
1449 1449
 						),
1450
-						'.progress-bar'                                                                                        => array( 'b' ),
1450
+						'.progress-bar'                                                                                        => array('b'),
1451 1451
 						'.list-group-item.active'                                                                              => array(
1452 1452
 							'b',
1453 1453
 							'o'
1454 1454
 						),
1455
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1455
+						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1456 1456
 					);
1457 1457
 			}
1458 1458
 
1459 1459
 
1460 1460
 
1461 1461
             // link
1462
-			if ( $type === 'primary' ) {
1463
-				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1464
-				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1465
-				$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).'; }';
1462
+			if ($type === 'primary') {
1463
+				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-' . esc_attr($type) . '-rgb), .75); --bs-link-color: var(--bs-' . esc_attr($type) . '); }';
1464
+				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: ' . esc_attr($color_code) . ';  }';
1465
+				$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) . '; }';
1466 1466
 
1467
-				$output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1468
-				$output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1467
+				$output .= $prefix . ' a{color: var(--bs-' . esc_attr($type) . ');}';
1468
+				$output .= $prefix . ' .text-primary{color: var(--bs-' . esc_attr($type) . ') !important;}';
1469 1469
 
1470 1470
                 // dropdown
1471
-				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1471
+				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-' . esc_attr($type) . '); --bs-dropdown-link-active-color: var(--bs-' . esc_attr($type) . ');}';
1472 1472
 
1473 1473
                 // pagination
1474
-				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1474
+				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-' . esc_attr($type) . '); --bs-pagination-active-bg: var(--bs-' . esc_attr($type) . ');}';
1475 1475
 
1476 1476
 			}
1477 1477
 
1478
-			$output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1479
-			$output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1478
+			$output .= $prefix . ' .link-' . esc_attr($type) . ' {color: var(--bs-' . esc_attr($type) . '-rgb) !important;}';
1479
+			$output .= $prefix . ' .link-' . esc_attr($type) . ':hover {color: rgba(var(--bs-' . esc_attr($type) . '-rgb), .8) !important;}';
1480 1480
 
1481 1481
 			//  buttons
1482
-			$output .= $prefix . ' .btn-'.esc_attr($type).'{';
1482
+			$output .= $prefix . ' .btn-' . esc_attr($type) . '{';
1483 1483
 			$output .= ' 
1484
-            --bs-btn-bg: '.esc_attr($color_code).';
1485
-            --bs-btn-border-color: '.esc_attr($color_code).';
1486
-            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1487
-            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1488
-            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type).'-rgb;
1489
-            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1490
-            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1484
+            --bs-btn-bg: '.esc_attr($color_code) . ';
1485
+            --bs-btn-border-color: '.esc_attr($color_code) . ';
1486
+            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1487
+            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1488
+            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type) . '-rgb;
1489
+            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1490
+            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1491 1491
             --bs-btn-active-shadow: unset;
1492
-            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1493
-            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1492
+            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .5);
1493
+            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .1);
1494 1494
             ';
1495 1495
 //			$output .= '
1496 1496
 //		    --bs-btn-color: #fff;
@@ -1501,18 +1501,18 @@  discard block
 block discarded – undo
1501 1501
 			$output .= '}';
1502 1502
 
1503 1503
 			//  buttons outline
1504
-			$output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1504
+			$output .= $prefix . ' .btn-outline-' . esc_attr($type) . '{';
1505 1505
 			$output .= ' 
1506
-			--bs-btn-color: '.esc_attr($color_code).';
1507
-            --bs-btn-border-color: '.esc_attr($color_code).';
1508
-            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1509
-            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1510
-            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type).'-rgb;
1511
-            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1512
-            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
1506
+			--bs-btn-color: '.esc_attr($color_code) . ';
1507
+            --bs-btn-border-color: '.esc_attr($color_code) . ';
1508
+            --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1509
+            --bs-btn-hover-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1510
+            --bs-btn-focus-shadow-rgb: --bs-'.esc_attr($type) . '-rgb;
1511
+            --bs-btn-active-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1512
+            --bs-btn-active-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .9);
1513 1513
             --bs-btn-active-shadow: unset;
1514
-            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1515
-            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1514
+            --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type) . '-rgb), .5);
1515
+            --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type) . '-rgb), .1);
1516 1516
             ';
1517 1517
 //			$output .= '
1518 1518
 //		    --bs-btn-color: #fff;
@@ -1524,32 +1524,32 @@  discard block
 block discarded – undo
1524 1524
 
1525 1525
 
1526 1526
             // button hover
1527
-			$output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1527
+			$output .= $prefix . ' .btn-' . esc_attr($type) . ':hover{';
1528 1528
 			$output .= ' 
1529
-            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);
1529
+            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);
1530 1530
             }
1531 1531
             ';
1532 1532
 
1533 1533
 
1534
-			if ( $aui_bs5 ) {
1534
+			if ($aui_bs5) {
1535 1535
 //				$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).'; }';
1536
-				$output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1537
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1536
+				$output .= 'html body {--bs-' . esc_attr($type) . ': ' . esc_attr($color_code) . '; }';
1537
+				$output .= 'html body {--bs-' . esc_attr($type) . '-rgb: ' . $rgb . '; }';
1538 1538
 			}
1539 1539
 
1540 1540
 
1541
-			if ( $is_custom ) {
1541
+			if ($is_custom) {
1542 1542
 
1543 1543
 //				echo '###'.$type;exit;
1544 1544
 
1545 1545
 				// build rules into each type
1546
-				foreach($selectors as $selector => $types){
1547
-					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1548
-					$types = array_combine($types,$types);
1549
-					if(isset($types['c'])){$color[] = $selector;}
1550
-					if(isset($types['b'])){$background[] = $selector;}
1551
-					if(isset($types['o'])){$border[] = $selector;}
1552
-					if(isset($types['f'])){$fill[] = $selector;}
1546
+				foreach ($selectors as $selector => $types) {
1547
+					$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1548
+					$types = array_combine($types, $types);
1549
+					if (isset($types['c'])) {$color[] = $selector; }
1550
+					if (isset($types['b'])) {$background[] = $selector; }
1551
+					if (isset($types['o'])) {$border[] = $selector; }
1552
+					if (isset($types['f'])) {$fill[] = $selector; }
1553 1553
 				}
1554 1554
 
1555 1555
 //				// build rules into each type
@@ -1563,36 +1563,36 @@  discard block
 block discarded – undo
1563 1563
 //				}
1564 1564
 
1565 1565
 				// add any color rules
1566
-				if(!empty($color)){
1567
-					$output .= implode(",",$color) . "{color: $color_code;} ";
1566
+				if (!empty($color)) {
1567
+					$output .= implode(",", $color) . "{color: $color_code;} ";
1568 1568
 				}
1569
-				if(!empty($color_i)){
1570
-					$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1569
+				if (!empty($color_i)) {
1570
+					$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1571 1571
 				}
1572 1572
 
1573 1573
 				// add any background color rules
1574
-				if(!empty($background)){
1575
-					$output .= implode(",",$background) . "{background-color: $color_code;} ";
1574
+				if (!empty($background)) {
1575
+					$output .= implode(",", $background) . "{background-color: $color_code;} ";
1576 1576
 				}
1577
-				if(!empty($background_i)){
1578
-					$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1577
+				if (!empty($background_i)) {
1578
+					$output .= $aui_bs5 ? '' : implode(",", $background_i) . "{background-color: $color_code !important;} ";
1579 1579
 //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1580 1580
 				}
1581 1581
 
1582 1582
 				// add any border color rules
1583
-				if(!empty($border)){
1584
-					$output .= implode(",",$border) . "{border-color: $color_code;} ";
1583
+				if (!empty($border)) {
1584
+					$output .= implode(",", $border) . "{border-color: $color_code;} ";
1585 1585
 				}
1586
-				if(!empty($border_i)){
1587
-					$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1586
+				if (!empty($border_i)) {
1587
+					$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1588 1588
 				}
1589 1589
 
1590 1590
 				// add any fill color rules
1591
-				if(!empty($fill)){
1592
-					$output .= implode(",",$fill) . "{fill: $color_code;} ";
1591
+				if (!empty($fill)) {
1592
+					$output .= implode(",", $fill) . "{fill: $color_code;} ";
1593 1593
 				}
1594
-				if(!empty($fill_i)){
1595
-					$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1594
+				if (!empty($fill_i)) {
1595
+					$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1596 1596
 				}
1597 1597
 
1598 1598
 			}
@@ -1602,26 +1602,26 @@  discard block
 block discarded – undo
1602 1602
 
1603 1603
 			$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;' : '';
1604 1604
 			// darken
1605
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1606
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1607
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1608
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1605
+			$darker_075 = $is_var ? $color_code . ';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code, "-0.075");
1606
+			$darker_10 = $is_var ? $color_code . ';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code, "-0.10");
1607
+			$darker_125 = $is_var ? $color_code . ';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code, "-0.125");
1608
+			$darker_40 = $is_var ? $color_code . ';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code, "-0.4");
1609 1609
 
1610 1610
 			// lighten
1611
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1611
+			$lighten_25 = $is_var ? $color_code . ';filter:brightness(1.25)' : self::css_hex_lighten_darken($color_code, "0.25");
1612 1612
 
1613 1613
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1614
-			$op_25 = $color_code."40"; // 25% opacity
1614
+			$op_25 = $color_code . "40"; // 25% opacity
1615 1615
 
1616 1616
 
1617 1617
 			// button states
1618
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1619
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1618
+			$output .= $is_var ? $prefix . " .btn-{$type}{{$transition }} " : '';
1619
+			$output .= $prefix . " .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
1620 1620
 //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1621
-			$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;} ";
1622
-			$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.";} ";
1623
-            $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;} ";
1624
-            $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);} ";
1621
+			$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;} ";
1622
+			$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 . ";} ";
1623
+            $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;} ";
1624
+            $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);} ";
1625 1625
 
1626 1626
 			// text
1627 1627
 //			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
@@ -1639,9 +1639,9 @@  discard block
 block discarded – undo
1639 1639
 //			}
1640 1640
 
1641 1641
 			// alerts
1642
-			if ( $aui_bs5 ) {
1642
+			if ($aui_bs5) {
1643 1643
 //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1644
-				$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;} ";
1644
+				$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;} ";
1645 1645
 			}
1646 1646
 
1647 1647
 			return $output;
@@ -1656,12 +1656,12 @@  discard block
 block discarded – undo
1656 1656
 		 *
1657 1657
 		 * @return string
1658 1658
 		 */
1659
-		public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1659
+		public static function css_overwrite($type, $color_code, $compatibility, $hex = '') {
1660 1660
             global $aui_bs5;
1661 1661
 
1662 1662
 			$is_var = false;
1663
-			if(!$color_code){return '';}
1664
-			if(strpos($color_code, 'var') !== false){
1663
+			if (!$color_code) {return ''; }
1664
+			if (strpos($color_code, 'var') !== false) {
1665 1665
 				//if(!sanitize_hex_color($color_code)){
1666 1666
 				$color_code = esc_attr($color_code);
1667 1667
 				$is_var = true;
@@ -1671,15 +1671,15 @@  discard block
 block discarded – undo
1671 1671
 
1672 1672
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1673 1673
 
1674
-			if(!$color_code){return '';}
1674
+			if (!$color_code) {return ''; }
1675 1675
 
1676 1676
             $rgb = self::hex_to_rgb($hex);
1677 1677
 
1678
-			if($compatibility===true || $compatibility===1){
1678
+			if ($compatibility === true || $compatibility === 1) {
1679 1679
 				$compatibility = '.bsui';
1680
-			}elseif(!$compatibility){
1680
+			}elseif (!$compatibility) {
1681 1681
 				$compatibility = '';
1682
-			}else{
1682
+			} else {
1683 1683
 				$compatibility = esc_attr($compatibility);
1684 1684
 			}
1685 1685
 
@@ -1693,29 +1693,29 @@  discard block
 block discarded – undo
1693 1693
 			 * c = color, b = background color, o = border-color, f = fill
1694 1694
 			 */
1695 1695
 			$selectors = array(
1696
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1697
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1698
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1699
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1700
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1701
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1702
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1703
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1704
-				".badge-{$type}"                                            => array( 'b' ),
1705
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1706
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1707
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1696
+				".btn-{$type}"                                              => array('b', 'o'),
1697
+				".btn-{$type}.disabled"                                     => array('b', 'o'),
1698
+				".btn-{$type}:disabled"                                     => array('b', 'o'),
1699
+				".btn-outline-{$type}"                                      => array('c', 'o'),
1700
+				".btn-outline-{$type}:hover"                                => array('b', 'o'),
1701
+				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array('b', 'o'),
1702
+				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array('b', 'o'),
1703
+				".show>.btn-outline-{$type}.dropdown-toggle"                => array('b', 'o'),
1704
+				".badge-{$type}"                                            => array('b'),
1705
+				".alert-{$type}"                                            => array('b', 'o'),
1706
+				".bg-{$type}"                                               => array('b', 'f'),
1707
+				".btn-link.btn-{$type}"                                     => array('c'),
1708 1708
 			);
1709 1709
 
1710
-			if ( $aui_bs5 ) {
1711
-                unset($selectors[".alert-{$type}" ]);
1710
+			if ($aui_bs5) {
1711
+                unset($selectors[".alert-{$type}"]);
1712 1712
 			}
1713 1713
 
1714
-			if ( $type == 'primary' ) {
1714
+			if ($type == 'primary') {
1715 1715
 				$selectors = $selectors + array(
1716
-						'a'                                                                                                    => array( 'c' ),
1717
-						'.btn-link'                                                                                            => array( 'c' ),
1718
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1716
+						'a'                                                                                                    => array('c'),
1717
+						'.btn-link'                                                                                            => array('c'),
1718
+						'.dropdown-item.active'                                                                                => array('b'),
1719 1719
 						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1720 1720
 							'b',
1721 1721
 							'o'
@@ -1724,19 +1724,19 @@  discard block
 block discarded – undo
1724 1724
 							'b',
1725 1725
 							'o'
1726 1726
 						),
1727
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1728
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1729
-						'.page-link'                                                                                           => array( 'c' ),
1727
+						'.nav-pills .nav-link.active'                                                                          => array('b'),
1728
+						'.nav-pills .show>.nav-link'                                                                           => array('b'),
1729
+						'.page-link'                                                                                           => array('c'),
1730 1730
 						'.page-item.active .page-link'                                                                         => array(
1731 1731
 							'b',
1732 1732
 							'o'
1733 1733
 						),
1734
-						'.progress-bar'                                                                                        => array( 'b' ),
1734
+						'.progress-bar'                                                                                        => array('b'),
1735 1735
 						'.list-group-item.active'                                                                              => array(
1736 1736
 							'b',
1737 1737
 							'o'
1738 1738
 						),
1739
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1739
+						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1740 1740
 //				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1741 1741
 //				    '.custom-range::-moz-range-thumb' => array('b'),
1742 1742
 //				    '.custom-range::-ms-thumb' => array('b'),
@@ -1744,7 +1744,7 @@  discard block
 block discarded – undo
1744 1744
 			}
1745 1745
 
1746 1746
 			$important_selectors = array(
1747
-				".bg-{$type}" => array('b','f'),
1747
+				".bg-{$type}" => array('b', 'f'),
1748 1748
 				".border-{$type}" => array('o'),
1749 1749
 				".text-{$type}" => array('c'),
1750 1750
 			);
@@ -1760,62 +1760,62 @@  discard block
 block discarded – undo
1760 1760
 
1761 1761
 			$output = '';
1762 1762
 
1763
-			if ( $aui_bs5 ) {
1763
+			if ($aui_bs5) {
1764 1764
 //				$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).'; }';
1765
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1765
+				$output .= 'html body {--bs-' . esc_attr($type) . '-rgb: ' . $rgb . '; }';
1766 1766
 			}
1767 1767
 
1768 1768
 			// build rules into each type
1769
-			foreach($selectors as $selector => $types){
1770
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1771
-				$types = array_combine($types,$types);
1772
-				if(isset($types['c'])){$color[] = $selector;}
1773
-				if(isset($types['b'])){$background[] = $selector;}
1774
-				if(isset($types['o'])){$border[] = $selector;}
1775
-				if(isset($types['f'])){$fill[] = $selector;}
1769
+			foreach ($selectors as $selector => $types) {
1770
+				$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1771
+				$types = array_combine($types, $types);
1772
+				if (isset($types['c'])) {$color[] = $selector; }
1773
+				if (isset($types['b'])) {$background[] = $selector; }
1774
+				if (isset($types['o'])) {$border[] = $selector; }
1775
+				if (isset($types['f'])) {$fill[] = $selector; }
1776 1776
 			}
1777 1777
 
1778 1778
 			// build rules into each type
1779
-			foreach($important_selectors as $selector => $types){
1780
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1781
-				$types = array_combine($types,$types);
1782
-				if(isset($types['c'])){$color_i[] = $selector;}
1783
-				if(isset($types['b'])){$background_i[] = $selector;}
1784
-				if(isset($types['o'])){$border_i[] = $selector;}
1785
-				if(isset($types['f'])){$fill_i[] = $selector;}
1779
+			foreach ($important_selectors as $selector => $types) {
1780
+				$selector = $compatibility ? $compatibility . " " . $selector : $selector;
1781
+				$types = array_combine($types, $types);
1782
+				if (isset($types['c'])) {$color_i[] = $selector; }
1783
+				if (isset($types['b'])) {$background_i[] = $selector; }
1784
+				if (isset($types['o'])) {$border_i[] = $selector; }
1785
+				if (isset($types['f'])) {$fill_i[] = $selector; }
1786 1786
 			}
1787 1787
 
1788 1788
 			// add any color rules
1789
-			if(!empty($color)){
1790
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1789
+			if (!empty($color)) {
1790
+				$output .= implode(",", $color) . "{color: $color_code;} ";
1791 1791
 			}
1792
-			if(!empty($color_i)){
1793
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1792
+			if (!empty($color_i)) {
1793
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1794 1794
 			}
1795 1795
 
1796 1796
 			// add any background color rules
1797
-			if(!empty($background)){
1798
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1797
+			if (!empty($background)) {
1798
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
1799 1799
 			}
1800
-			if(!empty($background_i)){
1801
-				$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1800
+			if (!empty($background_i)) {
1801
+				$output .= $aui_bs5 ? '' : implode(",", $background_i) . "{background-color: $color_code !important;} ";
1802 1802
 //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1803 1803
 			}
1804 1804
 
1805 1805
 			// add any border color rules
1806
-			if(!empty($border)){
1807
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1806
+			if (!empty($border)) {
1807
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
1808 1808
 			}
1809
-			if(!empty($border_i)){
1810
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1809
+			if (!empty($border_i)) {
1810
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1811 1811
 			}
1812 1812
 
1813 1813
 			// add any fill color rules
1814
-			if(!empty($fill)){
1815
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1814
+			if (!empty($fill)) {
1815
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
1816 1816
 			}
1817
-			if(!empty($fill_i)){
1818
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1817
+			if (!empty($fill_i)) {
1818
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1819 1819
 			}
1820 1820
 
1821 1821
 
@@ -1823,27 +1823,27 @@  discard block
 block discarded – undo
1823 1823
 
1824 1824
 			$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;' : '';
1825 1825
 			// darken
1826
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1827
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1828
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1829
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1826
+			$darker_075 = $is_var ? $color_code . ';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code, "-0.075");
1827
+			$darker_10 = $is_var ? $color_code . ';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code, "-0.10");
1828
+			$darker_125 = $is_var ? $color_code . ';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code, "-0.125");
1829
+			$darker_40 = $is_var ? $color_code . ';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code, "-0.4");
1830 1830
 
1831 1831
 			// lighten
1832
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1832
+			$lighten_25 = $is_var ? $color_code . ';filter:brightness(1.25)' : self::css_hex_lighten_darken($color_code, "0.25");
1833 1833
 
1834 1834
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1835
-			$op_25 = $color_code."40"; // 25% opacity
1835
+			$op_25 = $color_code . "40"; // 25% opacity
1836 1836
 
1837 1837
 
1838 1838
 			// button states
1839
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1840
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1839
+			$output .= $is_var ? $prefix . " .btn-{$type}{{$transition }} " : '';
1840
+			$output .= $prefix . " .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
1841 1841
 //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1842
-			$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;} ";
1843
-			$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.";} ";
1844
-			$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;} ";
1842
+			$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;} ";
1843
+			$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 . ";} ";
1844
+			$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;} ";
1845 1845
 
1846
-			if ( $type == 'primary' ) {
1846
+			if ($type == 'primary') {
1847 1847
 				// dropdown's
1848 1848
 				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1849 1849
 
@@ -1855,9 +1855,9 @@  discard block
 block discarded – undo
1855 1855
 			}
1856 1856
 
1857 1857
             // alerts
1858
-			if ( $aui_bs5 ) {
1858
+			if ($aui_bs5) {
1859 1859
 //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1860
-				$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;} ";
1860
+				$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;} ";
1861 1861
 			}
1862 1862
 
1863 1863
 			return $output;
@@ -1873,11 +1873,11 @@  discard block
 block discarded – undo
1873 1873
 		 *
1874 1874
 		 * @return string
1875 1875
 		 */
1876
-		public static function css_primary($color_code,$compatibility, $use_variable = false){
1876
+		public static function css_primary($color_code, $compatibility, $use_variable = false) {
1877 1877
 
1878
-			if(!$use_variable){
1878
+			if (!$use_variable) {
1879 1879
 				$color_code = sanitize_hex_color($color_code);
1880
-				if(!$color_code){return '';}
1880
+				if (!$color_code) {return ''; }
1881 1881
 			}
1882 1882
 
1883 1883
 			/**
@@ -1885,36 +1885,36 @@  discard block
 block discarded – undo
1885 1885
 			 */
1886 1886
 			$selectors = array(
1887 1887
 				'a' => array('c'),
1888
-				'.btn-primary' => array('b','o'),
1889
-				'.btn-primary.disabled' => array('b','o'),
1890
-				'.btn-primary:disabled' => array('b','o'),
1891
-				'.btn-outline-primary' => array('c','o'),
1892
-				'.btn-outline-primary:hover' => array('b','o'),
1893
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1894
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1895
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1888
+				'.btn-primary' => array('b', 'o'),
1889
+				'.btn-primary.disabled' => array('b', 'o'),
1890
+				'.btn-primary:disabled' => array('b', 'o'),
1891
+				'.btn-outline-primary' => array('c', 'o'),
1892
+				'.btn-outline-primary:hover' => array('b', 'o'),
1893
+				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b', 'o'),
1894
+				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b', 'o'),
1895
+				'.show>.btn-outline-primary.dropdown-toggle' => array('b', 'o'),
1896 1896
 				'.btn-link' => array('c'),
1897 1897
 				'.dropdown-item.active' => array('b'),
1898
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1899
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1898
+				'.custom-control-input:checked~.custom-control-label::before' => array('b', 'o'),
1899
+				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b', 'o'),
1900 1900
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1901 1901
 //				'.custom-range::-moz-range-thumb' => array('b'),
1902 1902
 //				'.custom-range::-ms-thumb' => array('b'),
1903 1903
 				'.nav-pills .nav-link.active' => array('b'),
1904 1904
 				'.nav-pills .show>.nav-link' => array('b'),
1905 1905
 				'.page-link' => array('c'),
1906
-				'.page-item.active .page-link' => array('b','o'),
1906
+				'.page-item.active .page-link' => array('b', 'o'),
1907 1907
 				'.badge-primary' => array('b'),
1908
-				'.alert-primary' => array('b','o'),
1908
+				'.alert-primary' => array('b', 'o'),
1909 1909
 				'.progress-bar' => array('b'),
1910
-				'.list-group-item.active' => array('b','o'),
1911
-				'.bg-primary' => array('b','f'),
1910
+				'.list-group-item.active' => array('b', 'o'),
1911
+				'.bg-primary' => array('b', 'f'),
1912 1912
 				'.btn-link.btn-primary' => array('c'),
1913 1913
 				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1914 1914
 			);
1915 1915
 
1916 1916
 			$important_selectors = array(
1917
-				'.bg-primary' => array('b','f'),
1917
+				'.bg-primary' => array('b', 'f'),
1918 1918
 				'.border-primary' => array('o'),
1919 1919
 				'.text-primary' => array('c'),
1920 1920
 			);
@@ -1931,88 +1931,88 @@  discard block
 block discarded – undo
1931 1931
 			$output = '';
1932 1932
 
1933 1933
 			// build rules into each type
1934
-			foreach($selectors as $selector => $types){
1935
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1936
-				$types = array_combine($types,$types);
1937
-				if(isset($types['c'])){$color[] = $selector;}
1938
-				if(isset($types['b'])){$background[] = $selector;}
1939
-				if(isset($types['o'])){$border[] = $selector;}
1940
-				if(isset($types['f'])){$fill[] = $selector;}
1934
+			foreach ($selectors as $selector => $types) {
1935
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
1936
+				$types = array_combine($types, $types);
1937
+				if (isset($types['c'])) {$color[] = $selector; }
1938
+				if (isset($types['b'])) {$background[] = $selector; }
1939
+				if (isset($types['o'])) {$border[] = $selector; }
1940
+				if (isset($types['f'])) {$fill[] = $selector; }
1941 1941
 			}
1942 1942
 
1943 1943
 			// build rules into each type
1944
-			foreach($important_selectors as $selector => $types){
1945
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1946
-				$types = array_combine($types,$types);
1947
-				if(isset($types['c'])){$color_i[] = $selector;}
1948
-				if(isset($types['b'])){$background_i[] = $selector;}
1949
-				if(isset($types['o'])){$border_i[] = $selector;}
1950
-				if(isset($types['f'])){$fill_i[] = $selector;}
1944
+			foreach ($important_selectors as $selector => $types) {
1945
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
1946
+				$types = array_combine($types, $types);
1947
+				if (isset($types['c'])) {$color_i[] = $selector; }
1948
+				if (isset($types['b'])) {$background_i[] = $selector; }
1949
+				if (isset($types['o'])) {$border_i[] = $selector; }
1950
+				if (isset($types['f'])) {$fill_i[] = $selector; }
1951 1951
 			}
1952 1952
 
1953 1953
 			// add any color rules
1954
-			if(!empty($color)){
1955
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1954
+			if (!empty($color)) {
1955
+				$output .= implode(",", $color) . "{color: $color_code;} ";
1956 1956
 			}
1957
-			if(!empty($color_i)){
1958
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1957
+			if (!empty($color_i)) {
1958
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
1959 1959
 			}
1960 1960
 
1961 1961
 			// add any background color rules
1962
-			if(!empty($background)){
1963
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1962
+			if (!empty($background)) {
1963
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
1964 1964
 			}
1965
-			if(!empty($background_i)){
1966
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1965
+			if (!empty($background_i)) {
1966
+				$output .= implode(",", $background_i) . "{background-color: $color_code !important;} ";
1967 1967
 			}
1968 1968
 
1969 1969
 			// add any border color rules
1970
-			if(!empty($border)){
1971
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1970
+			if (!empty($border)) {
1971
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
1972 1972
 			}
1973
-			if(!empty($border_i)){
1974
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1973
+			if (!empty($border_i)) {
1974
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
1975 1975
 			}
1976 1976
 
1977 1977
 			// add any fill color rules
1978
-			if(!empty($fill)){
1979
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1978
+			if (!empty($fill)) {
1979
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
1980 1980
 			}
1981
-			if(!empty($fill_i)){
1982
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1981
+			if (!empty($fill_i)) {
1982
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
1983 1983
 			}
1984 1984
 
1985 1985
 
1986 1986
 			$prefix = $compatibility ? ".bsui " : "";
1987 1987
 
1988 1988
 			// darken
1989
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1990
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1991
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1989
+			$darker_075 = self::css_hex_lighten_darken($color_code, "-0.075");
1990
+			$darker_10 = self::css_hex_lighten_darken($color_code, "-0.10");
1991
+			$darker_125 = self::css_hex_lighten_darken($color_code, "-0.125");
1992 1992
 
1993 1993
 			// lighten
1994
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1994
+			$lighten_25 = self::css_hex_lighten_darken($color_code, "0.25");
1995 1995
 
1996 1996
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
1997
-			$op_25 = $color_code."40"; // 25% opacity
1997
+			$op_25 = $color_code . "40"; // 25% opacity
1998 1998
 
1999 1999
 
2000 2000
 			// button states
2001
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2002
-			$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;} ";
2003
-			$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.";} ";
2004
-			$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;} ";
2001
+			$output .= $prefix . " .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
2002
+			$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;} ";
2003
+			$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 . ";} ";
2004
+			$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;} ";
2005 2005
 
2006 2006
 
2007 2007
 			// dropdown's
2008
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2008
+			$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2009 2009
 
2010 2010
 
2011 2011
 			// input states
2012
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2012
+			$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
2013 2013
 
2014 2014
 			// page link
2015
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2015
+			$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2016 2016
 
2017 2017
 			return $output;
2018 2018
 		}
@@ -2026,30 +2026,30 @@  discard block
 block discarded – undo
2026 2026
 		 *
2027 2027
 		 * @return string
2028 2028
 		 */
2029
-		public static function css_secondary($color_code,$compatibility){;
2029
+		public static function css_secondary($color_code, $compatibility) {;
2030 2030
 			$color_code = sanitize_hex_color($color_code);
2031
-			if(!$color_code){return '';}
2031
+			if (!$color_code) {return ''; }
2032 2032
 			/**
2033 2033
 			 * c = color, b = background color, o = border-color, f = fill
2034 2034
 			 */
2035 2035
 			$selectors = array(
2036
-				'.btn-secondary' => array('b','o'),
2037
-				'.btn-secondary.disabled' => array('b','o'),
2038
-				'.btn-secondary:disabled' => array('b','o'),
2039
-				'.btn-outline-secondary' => array('c','o'),
2040
-				'.btn-outline-secondary:hover' => array('b','o'),
2036
+				'.btn-secondary' => array('b', 'o'),
2037
+				'.btn-secondary.disabled' => array('b', 'o'),
2038
+				'.btn-secondary:disabled' => array('b', 'o'),
2039
+				'.btn-outline-secondary' => array('c', 'o'),
2040
+				'.btn-outline-secondary:hover' => array('b', 'o'),
2041 2041
 				'.btn-outline-secondary.disabled' => array('c'),
2042 2042
 				'.btn-outline-secondary:disabled' => array('c'),
2043
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2044
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2045
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2043
+				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b', 'o'),
2044
+				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b', 'o'),
2045
+				'.btn-outline-secondary.dropdown-toggle' => array('b', 'o'),
2046 2046
 				'.badge-secondary' => array('b'),
2047
-				'.alert-secondary' => array('b','o'),
2047
+				'.alert-secondary' => array('b', 'o'),
2048 2048
 				'.btn-link.btn-secondary' => array('c'),
2049 2049
 			);
2050 2050
 
2051 2051
 			$important_selectors = array(
2052
-				'.bg-secondary' => array('b','f'),
2052
+				'.bg-secondary' => array('b', 'f'),
2053 2053
 				'.border-secondary' => array('o'),
2054 2054
 				'.text-secondary' => array('c'),
2055 2055
 			);
@@ -2066,77 +2066,77 @@  discard block
 block discarded – undo
2066 2066
 			$output = '';
2067 2067
 
2068 2068
 			// build rules into each type
2069
-			foreach($selectors as $selector => $types){
2070
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2071
-				$types = array_combine($types,$types);
2072
-				if(isset($types['c'])){$color[] = $selector;}
2073
-				if(isset($types['b'])){$background[] = $selector;}
2074
-				if(isset($types['o'])){$border[] = $selector;}
2075
-				if(isset($types['f'])){$fill[] = $selector;}
2069
+			foreach ($selectors as $selector => $types) {
2070
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
2071
+				$types = array_combine($types, $types);
2072
+				if (isset($types['c'])) {$color[] = $selector; }
2073
+				if (isset($types['b'])) {$background[] = $selector; }
2074
+				if (isset($types['o'])) {$border[] = $selector; }
2075
+				if (isset($types['f'])) {$fill[] = $selector; }
2076 2076
 			}
2077 2077
 
2078 2078
 			// build rules into each type
2079
-			foreach($important_selectors as $selector => $types){
2080
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2081
-				$types = array_combine($types,$types);
2082
-				if(isset($types['c'])){$color_i[] = $selector;}
2083
-				if(isset($types['b'])){$background_i[] = $selector;}
2084
-				if(isset($types['o'])){$border_i[] = $selector;}
2085
-				if(isset($types['f'])){$fill_i[] = $selector;}
2079
+			foreach ($important_selectors as $selector => $types) {
2080
+				$selector = $compatibility ? ".bsui " . $selector : $selector;
2081
+				$types = array_combine($types, $types);
2082
+				if (isset($types['c'])) {$color_i[] = $selector; }
2083
+				if (isset($types['b'])) {$background_i[] = $selector; }
2084
+				if (isset($types['o'])) {$border_i[] = $selector; }
2085
+				if (isset($types['f'])) {$fill_i[] = $selector; }
2086 2086
 			}
2087 2087
 
2088 2088
 			// add any color rules
2089
-			if(!empty($color)){
2090
-				$output .= implode(",",$color) . "{color: $color_code;} ";
2089
+			if (!empty($color)) {
2090
+				$output .= implode(",", $color) . "{color: $color_code;} ";
2091 2091
 			}
2092
-			if(!empty($color_i)){
2093
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2092
+			if (!empty($color_i)) {
2093
+				$output .= implode(",", $color_i) . "{color: $color_code !important;} ";
2094 2094
 			}
2095 2095
 
2096 2096
 			// add any background color rules
2097
-			if(!empty($background)){
2098
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
2097
+			if (!empty($background)) {
2098
+				$output .= implode(",", $background) . "{background-color: $color_code;} ";
2099 2099
 			}
2100
-			if(!empty($background_i)){
2101
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2100
+			if (!empty($background_i)) {
2101
+				$output .= implode(",", $background_i) . "{background-color: $color_code !important;} ";
2102 2102
 			}
2103 2103
 
2104 2104
 			// add any border color rules
2105
-			if(!empty($border)){
2106
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
2105
+			if (!empty($border)) {
2106
+				$output .= implode(",", $border) . "{border-color: $color_code;} ";
2107 2107
 			}
2108
-			if(!empty($border_i)){
2109
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2108
+			if (!empty($border_i)) {
2109
+				$output .= implode(",", $border_i) . "{border-color: $color_code !important;} ";
2110 2110
 			}
2111 2111
 
2112 2112
 			// add any fill color rules
2113
-			if(!empty($fill)){
2114
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
2113
+			if (!empty($fill)) {
2114
+				$output .= implode(",", $fill) . "{fill: $color_code;} ";
2115 2115
 			}
2116
-			if(!empty($fill_i)){
2117
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2116
+			if (!empty($fill_i)) {
2117
+				$output .= implode(",", $fill_i) . "{fill: $color_code !important;} ";
2118 2118
 			}
2119 2119
 
2120 2120
 
2121 2121
 			$prefix = $compatibility ? ".bsui " : "";
2122 2122
 
2123 2123
 			// darken
2124
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2125
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2126
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2124
+			$darker_075 = self::css_hex_lighten_darken($color_code, "-0.075");
2125
+			$darker_10 = self::css_hex_lighten_darken($color_code, "-0.10");
2126
+			$darker_125 = self::css_hex_lighten_darken($color_code, "-0.125");
2127 2127
 
2128 2128
 			// lighten
2129
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2129
+			$lighten_25 = self::css_hex_lighten_darken($color_code, "0.25");
2130 2130
 
2131 2131
 			// opacity see https://css-tricks.com/8-digit-hex-codes/
2132
-			$op_25 = $color_code."40"; // 25% opacity
2132
+			$op_25 = $color_code . "40"; // 25% opacity
2133 2133
 
2134 2134
 
2135 2135
 			// button states
2136
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2137
-			$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;} ";
2138
-			$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.";} ";
2139
-			$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;} ";
2136
+			$output .= $prefix . " .btn-secondary:hover{background-color: " . $darker_075 . ";    border-color: " . $darker_10 . ";} ";
2137
+			$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;} ";
2138
+			$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 . ";} ";
2139
+			$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;} ";
2140 2140
 
2141 2141
 
2142 2142
 			return $output;
@@ -2153,7 +2153,7 @@  discard block
 block discarded – undo
2153 2153
 		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2154 2154
 			$hexCode = ltrim($hexCode, '#');
2155 2155
 
2156
-			if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2156
+			if (strpos($hexCode, 'rgba(') !== false || strpos($hexCode, 'rgb(') !== false) {
2157 2157
 				return $hexCode;
2158 2158
 			}
2159 2159
 
@@ -2176,8 +2176,8 @@  discard block
 block discarded – undo
2176 2176
 		/**
2177 2177
 		 * Check if we should display examples.
2178 2178
 		 */
2179
-		public function maybe_show_examples(){
2180
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2179
+		public function maybe_show_examples() {
2180
+			if (current_user_can('manage_options') && isset($_REQUEST['preview-aui'])) {
2181 2181
 				echo "<head>";
2182 2182
 				wp_head();
2183 2183
 				echo "</head>";
@@ -2193,7 +2193,7 @@  discard block
 block discarded – undo
2193 2193
 		 *
2194 2194
 		 * @return string
2195 2195
 		 */
2196
-		public function get_examples(){
2196
+		public function get_examples() {
2197 2197
 			$output = '';
2198 2198
 
2199 2199
 
@@ -2299,74 +2299,74 @@  discard block
 block discarded – undo
2299 2299
 		 */
2300 2300
 		public static function calendar_params() {
2301 2301
 			$params = array(
2302
-				'month_long_1' => __( 'January', 'ayecode-connect' ),
2303
-				'month_long_2' => __( 'February', 'ayecode-connect' ),
2304
-				'month_long_3' => __( 'March', 'ayecode-connect' ),
2305
-				'month_long_4' => __( 'April', 'ayecode-connect' ),
2306
-				'month_long_5' => __( 'May', 'ayecode-connect' ),
2307
-				'month_long_6' => __( 'June', 'ayecode-connect' ),
2308
-				'month_long_7' => __( 'July', 'ayecode-connect' ),
2309
-				'month_long_8' => __( 'August', 'ayecode-connect' ),
2310
-				'month_long_9' => __( 'September', 'ayecode-connect' ),
2311
-				'month_long_10' => __( 'October', 'ayecode-connect' ),
2312
-				'month_long_11' => __( 'November', 'ayecode-connect' ),
2313
-				'month_long_12' => __( 'December', 'ayecode-connect' ),
2314
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2315
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2316
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2317
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2318
-				'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2319
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2320
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2321
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2322
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2323
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2324
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2325
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2326
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2327
-				'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2328
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2329
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2330
-				'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2331
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2332
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2333
-				'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2334
-				'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2335
-				'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2336
-				'day_s2_4' => __( 'We', 'ayecode-connect' ),
2337
-				'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2338
-				'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2339
-				'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2340
-				'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2341
-				'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2342
-				'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2343
-				'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2344
-				'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2345
-				'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2346
-				'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2347
-				'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2348
-				'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2349
-				'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2350
-				'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2351
-				'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2352
-				'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2353
-				'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2354
-				'am_lower' => __( 'am', 'ayecode-connect' ),
2355
-				'pm_lower' => __( 'pm', 'ayecode-connect' ),
2356
-				'am_upper' => __( 'AM', 'ayecode-connect' ),
2357
-				'pm_upper' => __( 'PM', 'ayecode-connect' ),
2358
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2302
+				'month_long_1' => __('January', 'ayecode-connect'),
2303
+				'month_long_2' => __('February', 'ayecode-connect'),
2304
+				'month_long_3' => __('March', 'ayecode-connect'),
2305
+				'month_long_4' => __('April', 'ayecode-connect'),
2306
+				'month_long_5' => __('May', 'ayecode-connect'),
2307
+				'month_long_6' => __('June', 'ayecode-connect'),
2308
+				'month_long_7' => __('July', 'ayecode-connect'),
2309
+				'month_long_8' => __('August', 'ayecode-connect'),
2310
+				'month_long_9' => __('September', 'ayecode-connect'),
2311
+				'month_long_10' => __('October', 'ayecode-connect'),
2312
+				'month_long_11' => __('November', 'ayecode-connect'),
2313
+				'month_long_12' => __('December', 'ayecode-connect'),
2314
+				'month_s_1' => _x('Jan', 'January abbreviation', 'ayecode-connect'),
2315
+				'month_s_2' => _x('Feb', 'February abbreviation', 'ayecode-connect'),
2316
+				'month_s_3' => _x('Mar', 'March abbreviation', 'ayecode-connect'),
2317
+				'month_s_4' => _x('Apr', 'April abbreviation', 'ayecode-connect'),
2318
+				'month_s_5' => _x('May', 'May abbreviation', 'ayecode-connect'),
2319
+				'month_s_6' => _x('Jun', 'June abbreviation', 'ayecode-connect'),
2320
+				'month_s_7' => _x('Jul', 'July abbreviation', 'ayecode-connect'),
2321
+				'month_s_8' => _x('Aug', 'August abbreviation', 'ayecode-connect'),
2322
+				'month_s_9' => _x('Sep', 'September abbreviation', 'ayecode-connect'),
2323
+				'month_s_10' => _x('Oct', 'October abbreviation', 'ayecode-connect'),
2324
+				'month_s_11' => _x('Nov', 'November abbreviation', 'ayecode-connect'),
2325
+				'month_s_12' => _x('Dec', 'December abbreviation', 'ayecode-connect'),
2326
+				'day_s1_1' => _x('S', 'Sunday initial', 'ayecode-connect'),
2327
+				'day_s1_2' => _x('M', 'Monday initial', 'ayecode-connect'),
2328
+				'day_s1_3' => _x('T', 'Tuesday initial', 'ayecode-connect'),
2329
+				'day_s1_4' => _x('W', 'Wednesday initial', 'ayecode-connect'),
2330
+				'day_s1_5' => _x('T', 'Friday initial', 'ayecode-connect'),
2331
+				'day_s1_6' => _x('F', 'Thursday initial', 'ayecode-connect'),
2332
+				'day_s1_7' => _x('S', 'Saturday initial', 'ayecode-connect'),
2333
+				'day_s2_1' => __('Su', 'ayecode-connect'),
2334
+				'day_s2_2' => __('Mo', 'ayecode-connect'),
2335
+				'day_s2_3' => __('Tu', 'ayecode-connect'),
2336
+				'day_s2_4' => __('We', 'ayecode-connect'),
2337
+				'day_s2_5' => __('Th', 'ayecode-connect'),
2338
+				'day_s2_6' => __('Fr', 'ayecode-connect'),
2339
+				'day_s2_7' => __('Sa', 'ayecode-connect'),
2340
+				'day_s3_1' => __('Sun', 'ayecode-connect'),
2341
+				'day_s3_2' => __('Mon', 'ayecode-connect'),
2342
+				'day_s3_3' => __('Tue', 'ayecode-connect'),
2343
+				'day_s3_4' => __('Wed', 'ayecode-connect'),
2344
+				'day_s3_5' => __('Thu', 'ayecode-connect'),
2345
+				'day_s3_6' => __('Fri', 'ayecode-connect'),
2346
+				'day_s3_7' => __('Sat', 'ayecode-connect'),
2347
+				'day_s5_1' => __('Sunday', 'ayecode-connect'),
2348
+				'day_s5_2' => __('Monday', 'ayecode-connect'),
2349
+				'day_s5_3' => __('Tuesday', 'ayecode-connect'),
2350
+				'day_s5_4' => __('Wednesday', 'ayecode-connect'),
2351
+				'day_s5_5' => __('Thursday', 'ayecode-connect'),
2352
+				'day_s5_6' => __('Friday', 'ayecode-connect'),
2353
+				'day_s5_7' => __('Saturday', 'ayecode-connect'),
2354
+				'am_lower' => __('am', 'ayecode-connect'),
2355
+				'pm_lower' => __('pm', 'ayecode-connect'),
2356
+				'am_upper' => __('AM', 'ayecode-connect'),
2357
+				'pm_upper' => __('PM', 'ayecode-connect'),
2358
+				'firstDayOfWeek' => (int) get_option('start_of_week'),
2359 2359
 				'time_24hr' => false,
2360
-				'year' => __( 'Year', 'ayecode-connect' ),
2361
-				'hour' => __( 'Hour', 'ayecode-connect' ),
2362
-				'minute' => __( 'Minute', 'ayecode-connect' ),
2363
-				'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2364
-				'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2365
-				'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2366
-				'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2360
+				'year' => __('Year', 'ayecode-connect'),
2361
+				'hour' => __('Hour', 'ayecode-connect'),
2362
+				'minute' => __('Minute', 'ayecode-connect'),
2363
+				'weekAbbreviation' => __('Wk', 'ayecode-connect'),
2364
+				'rangeSeparator' => __(' to ', 'ayecode-connect'),
2365
+				'scrollTitle' => __('Scroll to increment', 'ayecode-connect'),
2366
+				'toggleTitle' => __('Click to toggle', 'ayecode-connect')
2367 2367
 			);
2368 2368
 
2369
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
2369
+			return apply_filters('ayecode_ui_calendar_params', $params);
2370 2370
 		}
2371 2371
 
2372 2372
 		/**
@@ -2379,47 +2379,47 @@  discard block
 block discarded – undo
2379 2379
 		public static function flatpickr_locale() {
2380 2380
 			$params = self::calendar_params();
2381 2381
 
2382
-			if ( is_string( $params ) ) {
2383
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2382
+			if (is_string($params)) {
2383
+				$params = html_entity_decode($params, ENT_QUOTES, 'UTF-8');
2384 2384
 			} else {
2385
-				foreach ( (array) $params as $key => $value ) {
2386
-					if ( ! is_scalar( $value ) ) {
2385
+				foreach ((array) $params as $key => $value) {
2386
+					if (!is_scalar($value)) {
2387 2387
 						continue;
2388 2388
 					}
2389 2389
 
2390
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2390
+					$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2391 2391
 				}
2392 2392
 			}
2393 2393
 
2394 2394
 			$day_s3 = array();
2395 2395
 			$day_s5 = array();
2396 2396
 
2397
-			for ( $i = 1; $i <= 7; $i ++ ) {
2398
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2397
+			for ($i = 1; $i <= 7; $i++) {
2398
+				$day_s3[] = addslashes($params['day_s3_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
+				$day_s5[] = addslashes($params['day_s3_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2400 2400
 			}
2401 2401
 
2402 2402
 			$month_s = array();
2403 2403
 			$month_long = array();
2404 2404
 
2405
-			for ( $i = 1; $i <= 12; $i ++ ) {
2406
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2407
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2405
+			for ($i = 1; $i <= 12; $i++) {
2406
+				$month_s[] = addslashes($params['month_s_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2407
+				$month_long[] = addslashes($params['month_long_' . $i]); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2408 2408
 			}
2409 2409
 
2410 2410
 			ob_start();
2411
-		if ( 0 ) { ?><script><?php } ?>
2411
+		if (0) { ?><script><?php } ?>
2412 2412
                 {
2413 2413
                     weekdays: {
2414
-                        shorthand: ['<?php echo implode( "','", $day_s3 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2415
-                            longhand: ['<?php echo implode( "','", $day_s5 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2414
+                        shorthand: ['<?php echo implode("','", $day_s3); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2415
+                            longhand: ['<?php echo implode("','", $day_s5); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2416 2416
                     },
2417 2417
                     months: {
2418
-                        shorthand: ['<?php echo implode( "','", $month_s ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2419
-                            longhand: ['<?php echo implode( "','", $month_long ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2418
+                        shorthand: ['<?php echo implode("','", $month_s); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2419
+                            longhand: ['<?php echo implode("','", $month_long); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
2420 2420
                     },
2421 2421
                     daysInMonth: [31,28,31,30,31,30,31,31,30,31,30,31],
2422
-                        firstDayOfWeek: <?php echo (int) $params[ 'firstDayOfWeek' ]; ?>,
2422
+                        firstDayOfWeek: <?php echo (int) $params['firstDayOfWeek']; ?>,
2423 2423
                     ordinal: function (nth) {
2424 2424
                         var s = nth % 100;
2425 2425
                         if (s > 3 && s < 21)
@@ -2435,21 +2435,21 @@  discard block
 block discarded – undo
2435 2435
                                 return "th";
2436 2436
                         }
2437 2437
                     },
2438
-                    rangeSeparator: '<?php echo esc_attr( $params[ 'rangeSeparator' ] ); ?>',
2439
-                        weekAbbreviation: '<?php echo esc_attr( $params[ 'weekAbbreviation' ] ); ?>',
2440
-                    scrollTitle: '<?php echo esc_attr( $params[ 'scrollTitle' ] ); ?>',
2441
-                    toggleTitle: '<?php echo esc_attr( $params[ 'toggleTitle' ] ); ?>',
2442
-                    amPM: ['<?php echo esc_attr( $params[ 'am_upper' ] ); ?>','<?php echo esc_attr( $params[ 'pm_upper' ] ); ?>'],
2443
-                    yearAriaLabel: '<?php echo esc_attr( $params[ 'year' ] ); ?>',
2444
-                    hourAriaLabel: '<?php echo esc_attr( $params[ 'hour' ] ); ?>',
2445
-                    minuteAriaLabel: '<?php echo esc_attr( $params[ 'minute' ] ); ?>',
2446
-                    time_24hr: <?php echo ( $params[ 'time_24hr' ] ? 'true' : 'false' ) ; ?>
2438
+                    rangeSeparator: '<?php echo esc_attr($params['rangeSeparator']); ?>',
2439
+                        weekAbbreviation: '<?php echo esc_attr($params['weekAbbreviation']); ?>',
2440
+                    scrollTitle: '<?php echo esc_attr($params['scrollTitle']); ?>',
2441
+                    toggleTitle: '<?php echo esc_attr($params['toggleTitle']); ?>',
2442
+                    amPM: ['<?php echo esc_attr($params['am_upper']); ?>','<?php echo esc_attr($params['pm_upper']); ?>'],
2443
+                    yearAriaLabel: '<?php echo esc_attr($params['year']); ?>',
2444
+                    hourAriaLabel: '<?php echo esc_attr($params['hour']); ?>',
2445
+                    minuteAriaLabel: '<?php echo esc_attr($params['minute']); ?>',
2446
+                    time_24hr: <?php echo ($params['time_24hr'] ? 'true' : 'false'); ?>
2447 2447
                 }
2448
-				<?php if ( 0 ) { ?></script><?php } ?>
2448
+				<?php if (0) { ?></script><?php } ?>
2449 2449
 			<?php
2450 2450
 			$locale = ob_get_clean();
2451 2451
 
2452
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2452
+			return apply_filters('ayecode_ui_flatpickr_locale', trim($locale));
2453 2453
 		}
2454 2454
 
2455 2455
 		/**
@@ -2461,20 +2461,20 @@  discard block
 block discarded – undo
2461 2461
 		 */
2462 2462
 		public static function select2_params() {
2463 2463
 			$params = array(
2464
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2465
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2466
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2467
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2468
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2469
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2470
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2471
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2472
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2473
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2474
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2464
+				'i18n_select_state_text'    => esc_attr__('Select an option&hellip;', 'ayecode-connect'),
2465
+				'i18n_no_matches'           => _x('No matches found', 'enhanced select', 'ayecode-connect'),
2466
+				'i18n_ajax_error'           => _x('Loading failed', 'enhanced select', 'ayecode-connect'),
2467
+				'i18n_input_too_short_1'    => _x('Please enter 1 or more characters', 'enhanced select', 'ayecode-connect'),
2468
+				'i18n_input_too_short_n'    => _x('Please enter %item% or more characters', 'enhanced select', 'ayecode-connect'),
2469
+				'i18n_input_too_long_1'     => _x('Please delete 1 character', 'enhanced select', 'ayecode-connect'),
2470
+				'i18n_input_too_long_n'     => _x('Please delete %item% characters', 'enhanced select', 'ayecode-connect'),
2471
+				'i18n_selection_too_long_1' => _x('You can only select 1 item', 'enhanced select', 'ayecode-connect'),
2472
+				'i18n_selection_too_long_n' => _x('You can only select %item% items', 'enhanced select', 'ayecode-connect'),
2473
+				'i18n_load_more'            => _x('Loading more results&hellip;', 'enhanced select', 'ayecode-connect'),
2474
+				'i18n_searching'            => _x('Searching&hellip;', 'enhanced select', 'ayecode-connect')
2475 2475
 			);
2476 2476
 
2477
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2477
+			return apply_filters('ayecode_ui_select2_params', $params);
2478 2478
 		}
2479 2479
 
2480 2480
 		/**
@@ -2487,17 +2487,17 @@  discard block
 block discarded – undo
2487 2487
 		public static function select2_locale() {
2488 2488
 			$params = self::select2_params();
2489 2489
 
2490
-			foreach ( (array) $params as $key => $value ) {
2491
-				if ( ! is_scalar( $value ) ) {
2490
+			foreach ((array) $params as $key => $value) {
2491
+				if (!is_scalar($value)) {
2492 2492
 					continue;
2493 2493
 				}
2494 2494
 
2495
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2495
+				$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2496 2496
 			}
2497 2497
 
2498
-			$locale = json_encode( $params );
2498
+			$locale = json_encode($params);
2499 2499
 
2500
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2500
+			return apply_filters('ayecode_ui_select2_locale', trim($locale));
2501 2501
 		}
2502 2502
 
2503 2503
 		/**
@@ -2510,35 +2510,35 @@  discard block
 block discarded – undo
2510 2510
 		public static function timeago_locale() {
2511 2511
 			$params = array(
2512 2512
 				'prefix_ago' => '',
2513
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2514
-				'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2513
+				'suffix_ago' => ' ' . _x('ago', 'time ago', 'ayecode-connect'),
2514
+				'prefix_after' => _x('after', 'time ago', 'ayecode-connect') . ' ',
2515 2515
 				'suffix_after' => '',
2516
-				'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2517
-				'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2518
-				'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2519
-				'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2520
-				'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2521
-				'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2522
-				'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2523
-				'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2524
-				'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2525
-				'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2526
-				'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2516
+				'seconds' => _x('less than a minute', 'time ago', 'ayecode-connect'),
2517
+				'minute' => _x('about a minute', 'time ago', 'ayecode-connect'),
2518
+				'minutes' => _x('%d minutes', 'time ago', 'ayecode-connect'),
2519
+				'hour' => _x('about an hour', 'time ago', 'ayecode-connect'),
2520
+				'hours' => _x('about %d hours', 'time ago', 'ayecode-connect'),
2521
+				'day' => _x('a day', 'time ago', 'ayecode-connect'),
2522
+				'days' => _x('%d days', 'time ago', 'ayecode-connect'),
2523
+				'month' => _x('about a month', 'time ago', 'ayecode-connect'),
2524
+				'months' => _x('%d months', 'time ago', 'ayecode-connect'),
2525
+				'year' => _x('about a year', 'time ago', 'ayecode-connect'),
2526
+				'years' => _x('%d years', 'time ago', 'ayecode-connect'),
2527 2527
 			);
2528 2528
 
2529
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2529
+			$params = apply_filters('ayecode_ui_timeago_params', $params);
2530 2530
 
2531
-			foreach ( (array) $params as $key => $value ) {
2532
-				if ( ! is_scalar( $value ) ) {
2531
+			foreach ((array) $params as $key => $value) {
2532
+				if (!is_scalar($value)) {
2533 2533
 					continue;
2534 2534
 				}
2535 2535
 
2536
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2536
+				$params[$key] = html_entity_decode((string) $value, ENT_QUOTES, 'UTF-8');
2537 2537
 			}
2538 2538
 
2539
-			$locale = json_encode( $params );
2539
+			$locale = json_encode($params);
2540 2540
 
2541
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2541
+			return apply_filters('ayecode_ui_timeago_locale', trim($locale));
2542 2542
 		}
2543 2543
 
2544 2544
 		/**
@@ -2549,7 +2549,7 @@  discard block
 block discarded – undo
2549 2549
 		 * @return mixed
2550 2550
 		 */
2551 2551
 		public static function minify_js($input) {
2552
-			if(trim($input) === "") return $input;
2552
+			if (trim($input) === "") return $input;
2553 2553
 			return preg_replace(
2554 2554
 				array(
2555 2555
 					// Remove comment(s)
@@ -2581,7 +2581,7 @@  discard block
 block discarded – undo
2581 2581
 		 * @return mixed
2582 2582
 		 */
2583 2583
 		public static function minify_css($input) {
2584
-			if(trim($input) === "") return $input;
2584
+			if (trim($input) === "") return $input;
2585 2585
 			return preg_replace(
2586 2586
 				array(
2587 2587
 					// Remove comment(s)
@@ -3161,12 +3161,12 @@  discard block
 block discarded – undo
3161 3161
                         });
3162 3162
                     }
3163 3163
                 }
3164
-				<?php do_action( 'aui_conditional_fields_js', $this ); ?>
3164
+				<?php do_action('aui_conditional_fields_js', $this); ?>
3165 3165
             </script>
3166 3166
 			<?php
3167 3167
 			$output = ob_get_clean();
3168 3168
 
3169
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3169
+			return str_replace(array('<script>', '</script>'), '', self::minify_js($output));
3170 3170
 		}
3171 3171
 
3172 3172
 		/**
@@ -3177,10 +3177,10 @@  discard block
 block discarded – undo
3177 3177
 		 * @return bool
3178 3178
 		 */
3179 3179
 		public static function is_block_editor() {
3180
-			if ( is_admin() ) {
3181
-				$current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3180
+			if (is_admin()) {
3181
+				$current_screen = function_exists('get_current_screen') ? get_current_screen() : array();
3182 3182
 
3183
-				if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3183
+				if (!empty($current_screen) && $current_screen->is_block_editor()) {
3184 3184
 					return true;
3185 3185
 				}
3186 3186
 			}
@@ -3199,7 +3199,7 @@  discard block
 block discarded – undo
3199 3199
 		 */
3200 3200
 		public static function is_block_content_call() {
3201 3201
 			$result = false;
3202
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3202
+			if (wp_doing_ajax() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'super_duper_output_shortcode') {
3203 3203
 				$result = true;
3204 3204
 			}
3205 3205
 
@@ -3215,7 +3215,7 @@  discard block
 block discarded – undo
3215 3215
 		 */
3216 3216
 		public static function is_divi_preview() {
3217 3217
 			$result = false;
3218
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3218
+			if (isset($_REQUEST['et_fb']) || isset($_REQUEST['et_pb_preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor')) {
3219 3219
 				$result = true;
3220 3220
 			}
3221 3221
 
@@ -3232,7 +3232,7 @@  discard block
 block discarded – undo
3232 3232
 		 */
3233 3233
 		public static function is_elementor_preview() {
3234 3234
 			$result = false;
3235
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3235
+			if (isset($_REQUEST['elementor-preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') || (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor_ajax')) {
3236 3236
 				$result = true;
3237 3237
 			}
3238 3238
 
@@ -3248,7 +3248,7 @@  discard block
 block discarded – undo
3248 3248
 		 */
3249 3249
 		public static function is_beaver_preview() {
3250 3250
 			$result = false;
3251
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3251
+			if (isset($_REQUEST['fl_builder'])) {
3252 3252
 				$result = true;
3253 3253
 			}
3254 3254
 
@@ -3264,7 +3264,7 @@  discard block
 block discarded – undo
3264 3264
 		 */
3265 3265
 		public static function is_siteorigin_preview() {
3266 3266
 			$result = false;
3267
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3267
+			if (!empty($_REQUEST['siteorigin_panels_live_editor'])) {
3268 3268
 				$result = true;
3269 3269
 			}
3270 3270
 
@@ -3280,7 +3280,7 @@  discard block
 block discarded – undo
3280 3280
 		 */
3281 3281
 		public static function is_cornerstone_preview() {
3282 3282
 			$result = false;
3283
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3283
+			if (!empty($_REQUEST['cornerstone_preview']) || basename($_SERVER['REQUEST_URI']) == 'cornerstone-endpoint') {
3284 3284
 				$result = true;
3285 3285
 			}
3286 3286
 
@@ -3295,7 +3295,7 @@  discard block
 block discarded – undo
3295 3295
 		 */
3296 3296
 		public static function is_fusion_preview() {
3297 3297
 			$result = false;
3298
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3298
+			if (!empty($_REQUEST['fb-edit']) || !empty($_REQUEST['fusion_load_nonce'])) {
3299 3299
 				$result = true;
3300 3300
 			}
3301 3301
 
@@ -3310,7 +3310,7 @@  discard block
 block discarded – undo
3310 3310
 		 */
3311 3311
 		public static function is_oxygen_preview() {
3312 3312
 			$result = false;
3313
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3313
+			if (!empty($_REQUEST['ct_builder']) || (!empty($_REQUEST['action']) && (substr($_REQUEST['action'], 0, 11) === "oxy_render_" || substr($_REQUEST['action'], 0, 10) === "ct_render_"))) {
3314 3314
 				$result = true;
3315 3315
 			}
3316 3316
 
@@ -3327,7 +3327,7 @@  discard block
 block discarded – undo
3327 3327
 		public static function is_kallyas_zion_preview() {
3328 3328
 			$result = false;
3329 3329
 
3330
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3330
+			if (function_exists('znhg_kallyas_theme_config') && !empty($_REQUEST['zn_pb_edit'])) {
3331 3331
 				$result = true;
3332 3332
 			}
3333 3333
 
@@ -3344,7 +3344,7 @@  discard block
 block discarded – undo
3344 3344
 		public static function is_bricks_preview() {
3345 3345
 			$result = false;
3346 3346
 
3347
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3347
+			if (function_exists('bricks_is_builder') && (bricks_is_builder() || bricks_is_builder_call())) {
3348 3348
 				$result = true;
3349 3349
 			}
3350 3350
 
@@ -3361,29 +3361,29 @@  discard block
 block discarded – undo
3361 3361
 		public static function is_preview() {
3362 3362
 			$preview = false;
3363 3363
 
3364
-			if ( self::is_block_editor() ) {
3364
+			if (self::is_block_editor()) {
3365 3365
 				return true;
3366 3366
 			}
3367 3367
 
3368
-			if( self::is_block_content_call() ) {
3368
+			if (self::is_block_content_call()) {
3369 3369
 				$preview = true;
3370
-			} elseif ( self::is_divi_preview() ) {
3370
+			} elseif (self::is_divi_preview()) {
3371 3371
 				$preview = true;
3372
-			} elseif ( self::is_elementor_preview() ) {
3372
+			} elseif (self::is_elementor_preview()) {
3373 3373
 				$preview = true;
3374
-			} elseif ( self::is_beaver_preview() ) {
3374
+			} elseif (self::is_beaver_preview()) {
3375 3375
 				$preview = true;
3376
-			} elseif ( self::is_siteorigin_preview() ) {
3376
+			} elseif (self::is_siteorigin_preview()) {
3377 3377
 				$preview = true;
3378
-			} elseif ( self::is_cornerstone_preview() ) {
3378
+			} elseif (self::is_cornerstone_preview()) {
3379 3379
 				$preview = true;
3380
-			} elseif ( self::is_fusion_preview() ) {
3380
+			} elseif (self::is_fusion_preview()) {
3381 3381
 				$preview = true;
3382
-			} elseif ( self::is_oxygen_preview() ) {
3382
+			} elseif (self::is_oxygen_preview()) {
3383 3383
 				$preview = true;
3384
-			} elseif( self::is_kallyas_zion_preview() ) {
3384
+			} elseif (self::is_kallyas_zion_preview()) {
3385 3385
 				$preview = true;
3386
-			} elseif( self::is_bricks_preview() ) {
3386
+			} elseif (self::is_bricks_preview()) {
3387 3387
 				$preview = true;
3388 3388
 			}
3389 3389
 
Please login to merge, or discard this patch.
Indentation   +2335 added lines, -2335 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.35';
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 {
119 32
 
120
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
33
+        /**
34
+         * Class version version.
35
+         *
36
+         * @var string
37
+         */
38
+        public $version = '0.2.35';
121 39
 
122
-				do_action( 'ayecode_ui_settings_loaded' );
123
-			}
40
+        /**
41
+         * Class textdomain.
42
+         *
43
+         * @var string
44
+         */
45
+        public $textdomain = 'aui';
124 46
 
125
-			return self::$instance;
126
-		}
47
+        /**
48
+         * Latest version of Bootstrap at time of publish published.
49
+         *
50
+         * @var string
51
+         */
52
+        public $latest = "5.2.2";
127 53
 
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 ){
54
+        /**
55
+         * Current version of select2 being used.
56
+         *
57
+         * @var string
58
+         */
59
+        public $select2_version = "4.0.11";
138 60
 
61
+        /**
62
+         * The title.
63
+         *
64
+         * @var string
65
+         */
66
+        public $name = 'AyeCode UI';
139 67
 
140
-			$setting = wp_get_global_settings();
68
+        /**
69
+         * The relative url to the assets.
70
+         *
71
+         * @var string
72
+         */
73
+        public $url = '';
141 74
 
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() {
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
+                }
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
+                    }
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
+        }
557 547
 
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' );
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 );
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
+                }
680 648
 
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' );
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() );
685 652
 
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
-		}
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,171 +766,171 @@  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
-
859
-			$db_settings = get_option( 'ayecode-ui-settings' );
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
+
859
+            $db_settings = get_option( 'ayecode-ui-settings' );
860 860
 
861 861
             // Maybe show default version notice
862
-			$site_install_date = new DateTime( self::get_site_install_date() );
863
-			$switch_over_date = new DateTime("2024-02-01");
864
-			if ( empty( $db_settings ) && $site_install_date < $switch_over_date ) {
865
-				add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
866
-			}
867
-
868
-			$js_default = 'core-popper';
869
-			$js_default_backend = $js_default;
870
-
871
-			// maybe set defaults (if no settings set)
872
-			if(empty($db_settings)){
873
-				$active_theme = strtolower( get_template() ); // active parent theme.
874
-				$theme_js_settings = self::theme_js_settings();
875
-				if(isset($theme_js_settings[$active_theme])){
876
-					$js_default = $theme_js_settings[$active_theme];
877
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
878
-				}
879
-			}
862
+            $site_install_date = new DateTime( self::get_site_install_date() );
863
+            $switch_over_date = new DateTime("2024-02-01");
864
+            if ( empty( $db_settings ) && $site_install_date < $switch_over_date ) {
865
+                add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
866
+            }
880 867
 
881
-			/**
882
-			 * Filter the default settings.
883
-			 */
884
-			$defaults = apply_filters( 'ayecode-ui-default-settings', array(
885
-				'css'            => 'compatibility', // core, compatibility
886
-				'js'             => $js_default, // js to load, core-popper, popper
887
-				'html_font_size' => '16', // js to load, core-popper, popper
888
-				'css_backend'    => 'compatibility', // core, compatibility
889
-				'js_backend'     => $js_default_backend, // js to load, core-popper, popper
890
-				'disable_admin'  => '', // URL snippets to disable loading on admin
868
+            $js_default = 'core-popper';
869
+            $js_default_backend = $js_default;
870
+
871
+            // maybe set defaults (if no settings set)
872
+            if(empty($db_settings)){
873
+                $active_theme = strtolower( get_template() ); // active parent theme.
874
+                $theme_js_settings = self::theme_js_settings();
875
+                if(isset($theme_js_settings[$active_theme])){
876
+                    $js_default = $theme_js_settings[$active_theme];
877
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
878
+                }
879
+            }
880
+
881
+            /**
882
+             * Filter the default settings.
883
+             */
884
+            $defaults = apply_filters( 'ayecode-ui-default-settings', array(
885
+                'css'            => 'compatibility', // core, compatibility
886
+                'js'             => $js_default, // js to load, core-popper, popper
887
+                'html_font_size' => '16', // js to load, core-popper, popper
888
+                'css_backend'    => 'compatibility', // core, compatibility
889
+                'js_backend'     => $js_default_backend, // js to load, core-popper, popper
890
+                'disable_admin'  => '', // URL snippets to disable loading on admin
891 891
                 'bs_ver'         => '5', // The default bootstrap version to sue by default
892
-			), $db_settings );
892
+            ), $db_settings );
893 893
 
894
-			$settings = wp_parse_args( $db_settings, $defaults );
894
+            $settings = wp_parse_args( $db_settings, $defaults );
895 895
 
896
-			/**
897
-			 * Filter the Bootstrap settings.
898
-			 *
899
-			 * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
900
-			 */
901
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
902
-		}
896
+            /**
897
+             * Filter the Bootstrap settings.
898
+             *
899
+             * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
900
+             */
901
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
902
+        }
903 903
 
904 904
 
905
-		/**
906
-		 * The settings page html output.
907
-		 */
908
-		public function settings_page() {
909
-			if ( ! current_user_can( 'manage_options' ) ) {
910
-				wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
911
-			}
905
+        /**
906
+         * The settings page html output.
907
+         */
908
+        public function settings_page() {
909
+            if ( ! current_user_can( 'manage_options' ) ) {
910
+                wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
911
+            }
912 912
             $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
913 913
 
914
-			?>
914
+            ?>
915 915
             <div class="wrap">
916 916
                 <h1><?php echo esc_attr( $this->name ); ?></h1>
917 917
                 <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 918
                 <form method="post" action="options.php">
919 919
 					<?php
920
-					settings_fields( 'ayecode-ui-settings' );
921
-					do_settings_sections( 'ayecode-ui-settings' );
922
-					?>
920
+                    settings_fields( 'ayecode-ui-settings' );
921
+                    do_settings_sections( 'ayecode-ui-settings' );
922
+                    ?>
923 923
 
924 924
                     <h2><?php esc_html_e( 'BootStrap Version', 'ayecode-connect' ); ?></h2>
925 925
                     <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 926
 	                <div class="bsui"><?php
927
-	                if ( ! empty( $overrides ) ) {
928
-		                echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
929
-			                'type'=> 'info',
930
-			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
931
-		                ));
932
-	                }
933
-	                ?>
927
+                    if ( ! empty( $overrides ) ) {
928
+                        echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
929
+                            'type'=> 'info',
930
+                            'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
931
+                        ));
932
+                    }
933
+                    ?>
934 934
                     </div>
935 935
                     <table class="form-table wpbs-table-version-settings">
936 936
                         <tr valign="top">
@@ -1014,77 +1014,77 @@  discard block
 block discarded – undo
1014 1014
                     </table>
1015 1015
 
1016 1016
 					<?php
1017
-					submit_button();
1018
-					?>
1017
+                    submit_button();
1018
+                    ?>
1019 1019
                 </form>
1020 1020
                 <div id="wpbs-version" data-aui-source="<?php echo esc_attr( $this->get_load_source() ); ?>"><?php echo esc_html( $this->version ); ?></div>
1021 1021
             </div>
1022 1022
 			<?php
1023
-		}
1023
+        }
1024 1024
 
1025 1025
         public function get_load_source(){
1026
-	        $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1027
-	        $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1028
-
1029
-	        // Find source plugin/theme of SD
1030
-	        $source = array();
1031
-	        if ( strpos( $file, $plugins_dir ) !== false ) {
1032
-		        $source = explode( "/", plugin_basename( $file ) );
1033
-	        } else if ( function_exists( 'get_theme_root' ) ) {
1034
-		        $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1035
-
1036
-		        if ( strpos( $file, $themes_dir ) !== false ) {
1037
-			        $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1038
-		        }
1039
-	        }
1026
+            $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1027
+            $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1028
+
1029
+            // Find source plugin/theme of SD
1030
+            $source = array();
1031
+            if ( strpos( $file, $plugins_dir ) !== false ) {
1032
+                $source = explode( "/", plugin_basename( $file ) );
1033
+            } else if ( function_exists( 'get_theme_root' ) ) {
1034
+                $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1035
+
1036
+                if ( strpos( $file, $themes_dir ) !== false ) {
1037
+                    $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1038
+                }
1039
+            }
1040 1040
 
1041 1041
             return isset($source[0]) ? esc_attr($source[0]) : '';
1042 1042
         }
1043 1043
 
1044
-		public function customizer_settings($wp_customize){
1045
-			$wp_customize->add_section('aui_settings', array(
1046
-				'title'    => __('AyeCode UI', 'ayecode-connect' ),
1047
-				'priority' => 120,
1048
-			));
1049
-
1050
-			//  =============================
1051
-			//  = Color Picker              =
1052
-			//  =============================
1053
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1054
-				'default'           => AUI_PRIMARY_COLOR,
1055
-				'sanitize_callback' => 'sanitize_hex_color',
1056
-				'capability'        => 'edit_theme_options',
1057
-				'type'              => 'option',
1058
-				'transport'         => 'refresh',
1059
-			));
1060
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1061
-				'label'    => __('Primary Color', 'ayecode-connect' ),
1062
-				'section'  => 'aui_settings',
1063
-				'settings' => 'aui_options[color_primary]',
1064
-			)));
1065
-
1066
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1067
-				'default'           => '#6c757d',
1068
-				'sanitize_callback' => 'sanitize_hex_color',
1069
-				'capability'        => 'edit_theme_options',
1070
-				'type'              => 'option',
1071
-				'transport'         => 'refresh',
1072
-			));
1073
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1074
-				'label'    => __('Secondary Color', 'ayecode-connect' ),
1075
-				'section'  => 'aui_settings',
1076
-				'settings' => 'aui_options[color_secondary]',
1077
-			)));
1078
-		}
1079
-
1080
-		/**
1081
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1082
-		 *
1083
-		 * @return mixed
1084
-		 */
1085
-		public static function bs3_compat_css() {
1086
-			ob_start();
1087
-			?>
1044
+        public function customizer_settings($wp_customize){
1045
+            $wp_customize->add_section('aui_settings', array(
1046
+                'title'    => __('AyeCode UI', 'ayecode-connect' ),
1047
+                'priority' => 120,
1048
+            ));
1049
+
1050
+            //  =============================
1051
+            //  = Color Picker              =
1052
+            //  =============================
1053
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1054
+                'default'           => AUI_PRIMARY_COLOR,
1055
+                'sanitize_callback' => 'sanitize_hex_color',
1056
+                'capability'        => 'edit_theme_options',
1057
+                'type'              => 'option',
1058
+                'transport'         => 'refresh',
1059
+            ));
1060
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1061
+                'label'    => __('Primary Color', 'ayecode-connect' ),
1062
+                'section'  => 'aui_settings',
1063
+                'settings' => 'aui_options[color_primary]',
1064
+            )));
1065
+
1066
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1067
+                'default'           => '#6c757d',
1068
+                'sanitize_callback' => 'sanitize_hex_color',
1069
+                'capability'        => 'edit_theme_options',
1070
+                'type'              => 'option',
1071
+                'transport'         => 'refresh',
1072
+            ));
1073
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1074
+                'label'    => __('Secondary Color', 'ayecode-connect' ),
1075
+                'section'  => 'aui_settings',
1076
+                'settings' => 'aui_options[color_secondary]',
1077
+            )));
1078
+        }
1079
+
1080
+        /**
1081
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1082
+         *
1083
+         * @return mixed
1084
+         */
1085
+        public static function bs3_compat_css() {
1086
+            ob_start();
1087
+            ?>
1088 1088
             <style>
1089 1089
                 /* Bootstrap 3 compatibility */
1090 1090
                 body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1113,374 +1113,374 @@  discard block
 block discarded – undo
1113 1113
                 <?php } ?>
1114 1114
             </style>
1115 1115
 			<?php
1116
-			return str_replace( array(
1117
-				'<style>',
1118
-				'</style>'
1119
-			), '', self::minify_css( ob_get_clean() ) );
1120
-		}
1116
+            return str_replace( array(
1117
+                '<style>',
1118
+                '</style>'
1119
+            ), '', self::minify_css( ob_get_clean() ) );
1120
+        }
1121 1121
 
1122
-		public static function custom_css( $compatibility = true, $is_fse = false ) {
1123
-			global $aui_bs5;
1122
+        public static function custom_css( $compatibility = true, $is_fse = false ) {
1123
+            global $aui_bs5;
1124 1124
 
1125
-			$colors = array();
1125
+            $colors = array();
1126 1126
 
1127
-			if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1128
-				$setting = wp_get_global_settings();
1127
+            if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1128
+                $setting = wp_get_global_settings();
1129 1129
 
1130
-				if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1131
-					foreach ( $setting['color']['palette']['theme'] as $color ) {
1132
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1133
-					}
1134
-				}
1130
+                if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1131
+                    foreach ( $setting['color']['palette']['theme'] as $color ) {
1132
+                        $colors[$color['slug']] = esc_attr( $color['color'] );
1133
+                    }
1134
+                }
1135 1135
 
1136
-				if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1137
-					foreach ( $setting['color']['palette']['custom'] as $color ) {
1138
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1139
-					}
1140
-				}
1141
-			} else {
1142
-				$settings = get_option( 'aui_options' );
1143
-
1144
-				$colors = array(
1145
-					'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1146
-					'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1147
-				);
1148
-			}
1149
-
1150
-			ob_start();
1151
-			?><style><?php
1152
-			// BS v3 compat
1153
-			if( self::is_bs3_compat() ){
1154
-				echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1155
-			}
1156
-
1157
-			//$is_fse = false;
1158
-			//if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1159
-				//$is_fse = true;
1160
-			//}
1161
-
1162
-			$custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1163
-			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1136
+                if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1137
+                    foreach ( $setting['color']['palette']['custom'] as $color ) {
1138
+                        $colors[$color['slug']] = esc_attr( $color['color'] );
1139
+                    }
1140
+                }
1141
+            } else {
1142
+                $settings = get_option( 'aui_options' );
1143
+
1144
+                $colors = array(
1145
+                    'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1146
+                    'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1147
+                );
1148
+            }
1149
+
1150
+            ob_start();
1151
+            ?><style><?php
1152
+            // BS v3 compat
1153
+            if( self::is_bs3_compat() ){
1154
+                echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1155
+            }
1156
+
1157
+            //$is_fse = false;
1158
+            //if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1159
+                //$is_fse = true;
1160
+            //}
1161
+
1162
+            $custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1163
+            $custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1164 1164
             $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1165
-			//$bs_custom_css = true; // Force true to fix any color issue.
1165
+            //$bs_custom_css = true; // Force true to fix any color issue.
1166 1166
 
1167
-			$colors_css = '';
1168
-			if ( ! empty( $colors ) && $bs_custom_css ) {
1169
-				$d_colors = self::get_colors(true);
1167
+            $colors_css = '';
1168
+            if ( ! empty( $colors ) && $bs_custom_css ) {
1169
+                $d_colors = self::get_colors(true);
1170 1170
 
1171
-				foreach ( $colors as $key => $color ) {
1172
-					if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1173
-						$var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1174
-						$compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1171
+                foreach ( $colors as $key => $color ) {
1172
+                    if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1173
+                        $var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1174
+                        $compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1175 1175
 
1176
-						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1177
-					}
1178
-				}
1179
-			}
1176
+                        $colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1177
+                    }
1178
+                }
1179
+            }
1180 1180
 
1181
-			if ( $colors_css ) {
1182
-				echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1183
-			}
1181
+            if ( $colors_css ) {
1182
+                echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1183
+            }
1184 1184
 
1185
-			// Set admin bar z-index lower when modal is open.
1186
-			echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1185
+            // Set admin bar z-index lower when modal is open.
1186
+            echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1187 1187
 
1188
-			if ( is_admin() ) {
1189
-				echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1190
-			}
1188
+            if ( is_admin() ) {
1189
+                echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1190
+            }
1191 1191
 
1192
-			$custom_css = '';
1192
+            $custom_css = '';
1193 1193
 
1194
-			if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1195
-				$css = '';
1196
-				$theme_settings = wp_get_global_styles();
1194
+            if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1195
+                $css = '';
1196
+                $theme_settings = wp_get_global_styles();
1197 1197
 
1198
-				// Font face
1199
-				if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1200
-					$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
-					$css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1202
-				}
1198
+                // Font face
1199
+                if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1200
+                    $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
+                    $css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1202
+                }
1203 1203
 
1204
-				// font size
1205
-				if( !empty( $theme_settings['typography']['fontSize'] ) ){
1206
-					$css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1207
-				}
1204
+                // font size
1205
+                if( !empty( $theme_settings['typography']['fontSize'] ) ){
1206
+                    $css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1207
+                }
1208 1208
 
1209
-				// line height
1210
-				 if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1211
-					$css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1212
-				}
1209
+                // line height
1210
+                    if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1211
+                    $css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1212
+                }
1213 1213
 
1214 1214
 
1215
-				   // font weight
1216
-				 if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1217
-					$css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1218
-				}
1215
+                    // font weight
1216
+                    if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1217
+                    $css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1218
+                }
1219 1219
 
1220
-				// Background
1221
-				 if( !empty( $theme_settings['color']['background'] ) ){
1222
-					$css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1223
-				}
1220
+                // Background
1221
+                    if( !empty( $theme_settings['color']['background'] ) ){
1222
+                    $css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1223
+                }
1224 1224
 
1225
-				 // Background Gradient
1226
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1227
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1228
-				}
1225
+                    // Background Gradient
1226
+                    if( !empty( $theme_settings['color']['gradient'] ) ){
1227
+                    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1228
+                }
1229 1229
 
1230
-				   // Background Gradient
1231
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1232
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1233
-				}
1230
+                    // Background Gradient
1231
+                    if( !empty( $theme_settings['color']['gradient'] ) ){
1232
+                    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1233
+                }
1234 1234
 
1235
-				// text color
1236
-				if( !empty( $theme_settings['color']['text'] ) ){
1237
-					$css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1238
-				}
1235
+                // text color
1236
+                if( !empty( $theme_settings['color']['text'] ) ){
1237
+                    $css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1238
+                }
1239 1239
 
1240 1240
 
1241
-				// link colors
1242
-				if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1243
-					$css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1244
-				}
1245
-				if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1246
-					$css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1247
-				}
1241
+                // link colors
1242
+                if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1243
+                    $css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1244
+                }
1245
+                if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1246
+                    $css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1247
+                }
1248 1248
 
1249
-				if($css){
1250
-					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1251
-				}
1249
+                if($css){
1250
+                    $custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1251
+                }
1252 1252
 
1253
-				$bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1253
+                $bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1254 1254
 
1255
-				// Headings
1256
-				$headings_css = '';
1257
-				if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1258
-					$headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1259
-				}
1255
+                // Headings
1256
+                $headings_css = '';
1257
+                if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1258
+                    $headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1259
+                }
1260 1260
 
1261
-				// heading background
1262
-				if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1263
-					$headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1264
-				}
1261
+                // heading background
1262
+                if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1263
+                    $headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1264
+                }
1265 1265
 
1266
-				 // heading font family
1267
-				if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1268
-					$headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1269
-				}
1266
+                    // heading font family
1267
+                if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1268
+                    $headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1269
+                }
1270 1270
 
1271
-				if( $headings_css ){
1272
-					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1273
-				}
1271
+                if( $headings_css ){
1272
+                    $custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1273
+                }
1274 1274
 
1275
-				$hs = array('h1','h2','h3','h4','h5','h6');
1275
+                $hs = array('h1','h2','h3','h4','h5','h6');
1276 1276
 
1277
-				foreach($hs as $hn){
1278
-					$h_css = '';
1279
-					 if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1280
-						$h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1281
-					 }
1277
+                foreach($hs as $hn){
1278
+                    $h_css = '';
1279
+                        if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1280
+                        $h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1281
+                        }
1282 1282
 
1283
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1284
-						$h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1285
-					 }
1283
+                        if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1284
+                        $h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1285
+                        }
1286 1286
 
1287
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1288
-						$h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1289
-					 }
1287
+                        if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1288
+                        $h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1289
+                        }
1290 1290
 
1291
-					 if($h_css){
1292
-						$custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1293
-					 }
1294
-				}
1295
-			}
1291
+                        if($h_css){
1292
+                        $custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1293
+                        }
1294
+                }
1295
+            }
1296 1296
 			
1297
-			if ( $custom_css ) {
1298
-				echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1299
-			}
1297
+            if ( $custom_css ) {
1298
+                echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1299
+            }
1300 1300
 
1301
-			// Pagination on Hello Elementor theme.
1302
-			if ( function_exists( 'hello_elementor_setup' ) ) {
1303
-				echo '.aui-nav-links .pagination{justify-content:inherit}';
1304
-			}
1301
+            // Pagination on Hello Elementor theme.
1302
+            if ( function_exists( 'hello_elementor_setup' ) ) {
1303
+                echo '.aui-nav-links .pagination{justify-content:inherit}';
1304
+            }
1305 1305
 
1306 1306
             // Astra theme - when woocommerce active they add compatibility CSS which breaks select2 in modals
1307 1307
             if( defined('ASTRA_THEME_VERSION')){
1308 1308
                 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;}';
1309 1309
             }
1310 1310
 
1311
-			?></style><?php
1312
-			$custom_css = ob_get_clean();
1311
+            ?></style><?php
1312
+            $custom_css = ob_get_clean();
1313 1313
 
1314
-			/*
1314
+            /*
1315 1315
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1316 1316
 			 */
1317
-			return str_replace( array(
1318
-				'<style>',
1319
-				'</style>'
1320
-			), '', self::minify_css( $custom_css ) );
1321
-		}
1322
-
1323
-		/**
1324
-		 * Check if we should add booststrap 3 compatibility changes.
1325
-		 *
1326
-		 * @return bool
1327
-		 */
1328
-		public static function is_bs3_compat(){
1329
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1330
-		}
1331
-
1332
-		public static function hex_to_rgb( $hex ) {
1333
-			// Remove '#' if present
1334
-			$hex = str_replace( '#', '', $hex );
1335
-
1336
-			// Check if input is RGB
1337
-			if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1338
-				$_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1339
-
1340
-				$rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1341
-				$rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1342
-				$rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1343
-
1344
-				return $rgb;
1345
-			}
1346
-
1347
-			// Convert 3-digit hex to 6-digit hex
1348
-			if ( strlen( $hex ) == 3 ) {
1349
-				$hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1350
-			}
1351
-
1352
-			// Convert hex to RGB
1353
-			$r = hexdec( substr( $hex, 0, 2 ) );
1354
-			$g = hexdec( substr( $hex, 2, 2 ) );
1355
-			$b = hexdec( substr( $hex, 4, 2 ) );
1356
-
1357
-			// Return RGB values as an array
1358
-			return $r . ',' . $g . ',' . $b;
1359
-		}
1360
-
1361
-		/**
1362
-		 * Build the CSS to overwrite a bootstrap color variable.
1363
-		 *
1364
-		 * @param $type
1365
-		 * @param $color_code
1366
-		 * @param $compatibility
1367
-		 *
1368
-		 * @return string
1369
-		 */
1370
-		public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1371
-			global $aui_bs5;
1372
-
1373
-			$is_var = false;
1374
-			$is_custom = strpos($type, 'custom-') !== false ? true : false;
1375
-			if(!$color_code){return '';}
1376
-			if(strpos($color_code, 'var') !== false){
1377
-				//if(!sanitize_hex_color($color_code)){
1378
-				$color_code = esc_attr($color_code);
1379
-				$is_var = true;
1317
+            return str_replace( array(
1318
+                '<style>',
1319
+                '</style>'
1320
+            ), '', self::minify_css( $custom_css ) );
1321
+        }
1322
+
1323
+        /**
1324
+         * Check if we should add booststrap 3 compatibility changes.
1325
+         *
1326
+         * @return bool
1327
+         */
1328
+        public static function is_bs3_compat(){
1329
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1330
+        }
1331
+
1332
+        public static function hex_to_rgb( $hex ) {
1333
+            // Remove '#' if present
1334
+            $hex = str_replace( '#', '', $hex );
1335
+
1336
+            // Check if input is RGB
1337
+            if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1338
+                $_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1339
+
1340
+                $rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1341
+                $rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1342
+                $rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1343
+
1344
+                return $rgb;
1345
+            }
1346
+
1347
+            // Convert 3-digit hex to 6-digit hex
1348
+            if ( strlen( $hex ) == 3 ) {
1349
+                $hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1350
+            }
1351
+
1352
+            // Convert hex to RGB
1353
+            $r = hexdec( substr( $hex, 0, 2 ) );
1354
+            $g = hexdec( substr( $hex, 2, 2 ) );
1355
+            $b = hexdec( substr( $hex, 4, 2 ) );
1356
+
1357
+            // Return RGB values as an array
1358
+            return $r . ',' . $g . ',' . $b;
1359
+        }
1360
+
1361
+        /**
1362
+         * Build the CSS to overwrite a bootstrap color variable.
1363
+         *
1364
+         * @param $type
1365
+         * @param $color_code
1366
+         * @param $compatibility
1367
+         *
1368
+         * @return string
1369
+         */
1370
+        public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1371
+            global $aui_bs5;
1372
+
1373
+            $is_var = false;
1374
+            $is_custom = strpos($type, 'custom-') !== false ? true : false;
1375
+            if(!$color_code){return '';}
1376
+            if(strpos($color_code, 'var') !== false){
1377
+                //if(!sanitize_hex_color($color_code)){
1378
+                $color_code = esc_attr($color_code);
1379
+                $is_var = true;
1380 1380
 //				$color_code = "rgba($color_code, 0.5)";
1381 1381
 //                echo '###1'.$color_code.'###';//exit;
1382
-			}
1382
+            }
1383 1383
 
1384 1384
 //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1385 1385
 
1386
-			if(!$color_code){return '';}
1386
+            if(!$color_code){return '';}
1387 1387
 
1388
-			$rgb = self::hex_to_rgb($hex);
1388
+            $rgb = self::hex_to_rgb($hex);
1389 1389
 
1390
-			if($compatibility===true || $compatibility===1){
1391
-				$compatibility = '.bsui';
1392
-			}elseif(!$compatibility){
1393
-				$compatibility = '';
1394
-			}else{
1395
-				$compatibility = esc_attr($compatibility);
1396
-			}
1390
+            if($compatibility===true || $compatibility===1){
1391
+                $compatibility = '.bsui';
1392
+            }elseif(!$compatibility){
1393
+                $compatibility = '';
1394
+            }else{
1395
+                $compatibility = esc_attr($compatibility);
1396
+            }
1397 1397
 
1398
-			$prefix = $compatibility ? $compatibility . " " : "";
1398
+            $prefix = $compatibility ? $compatibility . " " : "";
1399 1399
 
1400 1400
 
1401 1401
             $output = '';
1402 1402
 
1403 1403
 //            echo '####'.$color_code;exit;
1404 1404
 
1405
-			$type = sanitize_html_class($type);
1405
+            $type = sanitize_html_class($type);
1406
+
1407
+            /**
1408
+             * c = color, b = background color, o = border-color, f = fill
1409
+             */
1410
+            $selectors = array(
1411
+                ".btn-{$type}"                                              => array( 'b', 'o' ),
1412
+                ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1413
+                ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1414
+                ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1415
+                ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1416
+                ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1417
+                ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1418
+                ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1419
+                ".badge-{$type}"                                            => array( 'b' ),
1420
+                ".alert-{$type}"                                            => array( 'b', 'o' ),
1421
+                ".bg-{$type}"                                               => array( 'b', 'f' ),
1422
+                ".btn-link.btn-{$type}"                                     => array( 'c' ),
1423
+                ".text-{$type}"                                     => array( 'c' ),
1424
+            );
1425
+
1426
+            if ( $aui_bs5 ) {
1427
+                unset($selectors[".alert-{$type}" ]);
1428
+            }
1406 1429
 
1407
-			/**
1408
-			 * c = color, b = background color, o = border-color, f = fill
1409
-			 */
1410
-			$selectors = array(
1411
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1412
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1413
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1414
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1415
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1416
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1417
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1418
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1419
-				".badge-{$type}"                                            => array( 'b' ),
1420
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1421
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1422
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1423
-				".text-{$type}"                                     => array( 'c' ),
1424
-			);
1425
-
1426
-			if ( $aui_bs5 ) {
1427
-				unset($selectors[".alert-{$type}" ]);
1428
-			}
1429
-
1430
-			if ( $type == 'primary' ) {
1431
-				$selectors = $selectors + array(
1432
-						'a'                                                                                                    => array( 'c' ),
1433
-						'.btn-link'                                                                                            => array( 'c' ),
1434
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1435
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1436
-							'b',
1437
-							'o'
1438
-						),
1439
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1440
-							'b',
1441
-							'o'
1442
-						),
1443
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1444
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1445
-						'.page-link'                                                                                           => array( 'c' ),
1446
-						'.page-item.active .page-link'                                                                         => array(
1447
-							'b',
1448
-							'o'
1449
-						),
1450
-						'.progress-bar'                                                                                        => array( 'b' ),
1451
-						'.list-group-item.active'                                                                              => array(
1452
-							'b',
1453
-							'o'
1454
-						),
1455
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1456
-					);
1457
-			}
1430
+            if ( $type == 'primary' ) {
1431
+                $selectors = $selectors + array(
1432
+                        'a'                                                                                                    => array( 'c' ),
1433
+                        '.btn-link'                                                                                            => array( 'c' ),
1434
+                        '.dropdown-item.active'                                                                                => array( 'b' ),
1435
+                        '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1436
+                            'b',
1437
+                            'o'
1438
+                        ),
1439
+                        '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1440
+                            'b',
1441
+                            'o'
1442
+                        ),
1443
+                        '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1444
+                        '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1445
+                        '.page-link'                                                                                           => array( 'c' ),
1446
+                        '.page-item.active .page-link'                                                                         => array(
1447
+                            'b',
1448
+                            'o'
1449
+                        ),
1450
+                        '.progress-bar'                                                                                        => array( 'b' ),
1451
+                        '.list-group-item.active'                                                                              => array(
1452
+                            'b',
1453
+                            'o'
1454
+                        ),
1455
+                        '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1456
+                    );
1457
+            }
1458 1458
 
1459 1459
 
1460 1460
 
1461 1461
             // link
1462
-			if ( $type === 'primary' ) {
1463
-				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1464
-				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1465
-				$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).'; }';
1462
+            if ( $type === 'primary' ) {
1463
+                $output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1464
+                $output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1465
+                $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).'; }';
1466 1466
 
1467
-				$output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1468
-				$output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1467
+                $output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1468
+                $output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1469 1469
 
1470 1470
                 // dropdown
1471
-				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1471
+                $output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1472 1472
 
1473 1473
                 // pagination
1474
-				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1474
+                $output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1475 1475
 
1476
-			}
1476
+            }
1477 1477
 
1478
-			$output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1479
-			$output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1478
+            $output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1479
+            $output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1480 1480
 
1481
-			//  buttons
1482
-			$output .= $prefix . ' .btn-'.esc_attr($type).'{';
1483
-			$output .= ' 
1481
+            //  buttons
1482
+            $output .= $prefix . ' .btn-'.esc_attr($type).'{';
1483
+            $output .= ' 
1484 1484
             --bs-btn-bg: '.esc_attr($color_code).';
1485 1485
             --bs-btn-border-color: '.esc_attr($color_code).';
1486 1486
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1498,11 +1498,11 @@  discard block
 block discarded – undo
1498 1498
 //			--bs-btn-active-color: #fff;
1499 1499
 //			--bs-btn-disabled-color: #fff;
1500 1500
 //            ';
1501
-			$output .= '}';
1501
+            $output .= '}';
1502 1502
 
1503
-			//  buttons outline
1504
-			$output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1505
-			$output .= ' 
1503
+            //  buttons outline
1504
+            $output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1505
+            $output .= ' 
1506 1506
 			--bs-btn-color: '.esc_attr($color_code).';
1507 1507
             --bs-btn-border-color: '.esc_attr($color_code).';
1508 1508
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1520,37 +1520,37 @@  discard block
 block discarded – undo
1520 1520
 //			--bs-btn-active-color: #fff;
1521 1521
 //			--bs-btn-disabled-color: #fff;
1522 1522
 //            ';
1523
-			$output .= '}';
1523
+            $output .= '}';
1524 1524
 
1525 1525
 
1526 1526
             // button hover
1527
-			$output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1528
-			$output .= ' 
1527
+            $output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1528
+            $output .= ' 
1529 1529
             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);
1530 1530
             }
1531 1531
             ';
1532 1532
 
1533 1533
 
1534
-			if ( $aui_bs5 ) {
1534
+            if ( $aui_bs5 ) {
1535 1535
 //				$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).'; }';
1536
-				$output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1537
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1538
-			}
1536
+                $output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1537
+                $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1538
+            }
1539 1539
 
1540 1540
 
1541
-			if ( $is_custom ) {
1541
+            if ( $is_custom ) {
1542 1542
 
1543 1543
 //				echo '###'.$type;exit;
1544 1544
 
1545
-				// build rules into each type
1546
-				foreach($selectors as $selector => $types){
1547
-					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1548
-					$types = array_combine($types,$types);
1549
-					if(isset($types['c'])){$color[] = $selector;}
1550
-					if(isset($types['b'])){$background[] = $selector;}
1551
-					if(isset($types['o'])){$border[] = $selector;}
1552
-					if(isset($types['f'])){$fill[] = $selector;}
1553
-				}
1545
+                // build rules into each type
1546
+                foreach($selectors as $selector => $types){
1547
+                    $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1548
+                    $types = array_combine($types,$types);
1549
+                    if(isset($types['c'])){$color[] = $selector;}
1550
+                    if(isset($types['b'])){$background[] = $selector;}
1551
+                    if(isset($types['o'])){$border[] = $selector;}
1552
+                    if(isset($types['f'])){$fill[] = $selector;}
1553
+                }
1554 1554
 
1555 1555
 //				// build rules into each type
1556 1556
 //				foreach($important_selectors as $selector => $types){
@@ -1562,853 +1562,853 @@  discard block
 block discarded – undo
1562 1562
 //					if(isset($types['f'])){$fill_i[] = $selector;}
1563 1563
 //				}
1564 1564
 
1565
-				// add any color rules
1566
-				if(!empty($color)){
1567
-					$output .= implode(",",$color) . "{color: $color_code;} ";
1568
-				}
1569
-				if(!empty($color_i)){
1570
-					$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1571
-				}
1565
+                // add any color rules
1566
+                if(!empty($color)){
1567
+                    $output .= implode(",",$color) . "{color: $color_code;} ";
1568
+                }
1569
+                if(!empty($color_i)){
1570
+                    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1571
+                }
1572
+
1573
+                // add any background color rules
1574
+                if(!empty($background)){
1575
+                    $output .= implode(",",$background) . "{background-color: $color_code;} ";
1576
+                }
1577
+                if(!empty($background_i)){
1578
+                    $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1579
+//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1580
+                }
1581
+
1582
+                // add any border color rules
1583
+                if(!empty($border)){
1584
+                    $output .= implode(",",$border) . "{border-color: $color_code;} ";
1585
+                }
1586
+                if(!empty($border_i)){
1587
+                    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1588
+                }
1589
+
1590
+                // add any fill color rules
1591
+                if(!empty($fill)){
1592
+                    $output .= implode(",",$fill) . "{fill: $color_code;} ";
1593
+                }
1594
+                if(!empty($fill_i)){
1595
+                    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1596
+                }
1597
+
1598
+            }
1599
+
1600
+
1601
+
1602
+
1603
+            $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;' : '';
1604
+            // darken
1605
+            $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1606
+            $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1607
+            $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1608
+            $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1609
+
1610
+            // lighten
1611
+            $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1612
+
1613
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1614
+            $op_25 = $color_code."40"; // 25% opacity
1615
+
1616
+
1617
+            // button states
1618
+            $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1619
+            $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1620
+//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1621
+            $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;} ";
1622
+            $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.";} ";
1623
+            $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;} ";
1624
+            $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);} ";
1625
+
1626
+            // text
1627
+//			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
1628
+
1629
+
1630
+//			if ( $type == 'primary' ) {
1631
+//				// dropdown's
1632
+//				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1633
+//
1634
+//				// input states
1635
+//				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1636
+//
1637
+//				// page link
1638
+//				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1639
+//			}
1640
+
1641
+            // alerts
1642
+            if ( $aui_bs5 ) {
1643
+//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1644
+                $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;} ";
1645
+            }
1646
+
1647
+            return $output;
1648
+        }
1649
+
1650
+        /**
1651
+         * Build the CSS to overwrite a bootstrap color variable.
1652
+         *
1653
+         * @param $type
1654
+         * @param $color_code
1655
+         * @param $compatibility
1656
+         *
1657
+         * @return string
1658
+         */
1659
+        public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1660
+            global $aui_bs5;
1661
+
1662
+            $is_var = false;
1663
+            if(!$color_code){return '';}
1664
+            if(strpos($color_code, 'var') !== false){
1665
+                //if(!sanitize_hex_color($color_code)){
1666
+                $color_code = esc_attr($color_code);
1667
+                $is_var = true;
1668
+//				$color_code = "rgba($color_code, 0.5)";
1669
+//                echo '###1'.$color_code.'###';//exit;
1670
+            }
1671
+
1672
+//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1673
+
1674
+            if(!$color_code){return '';}
1675
+
1676
+            $rgb = self::hex_to_rgb($hex);
1677
+
1678
+            if($compatibility===true || $compatibility===1){
1679
+                $compatibility = '.bsui';
1680
+            }elseif(!$compatibility){
1681
+                $compatibility = '';
1682
+            }else{
1683
+                $compatibility = esc_attr($compatibility);
1684
+            }
1685
+
1686
+
1687
+
1688
+//            echo '####'.$color_code;exit;
1689
+
1690
+            $type = sanitize_html_class($type);
1691
+
1692
+            /**
1693
+             * c = color, b = background color, o = border-color, f = fill
1694
+             */
1695
+            $selectors = array(
1696
+                ".btn-{$type}"                                              => array( 'b', 'o' ),
1697
+                ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1698
+                ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1699
+                ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1700
+                ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1701
+                ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1702
+                ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1703
+                ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1704
+                ".badge-{$type}"                                            => array( 'b' ),
1705
+                ".alert-{$type}"                                            => array( 'b', 'o' ),
1706
+                ".bg-{$type}"                                               => array( 'b', 'f' ),
1707
+                ".btn-link.btn-{$type}"                                     => array( 'c' ),
1708
+            );
1709
+
1710
+            if ( $aui_bs5 ) {
1711
+                unset($selectors[".alert-{$type}" ]);
1712
+            }
1713
+
1714
+            if ( $type == 'primary' ) {
1715
+                $selectors = $selectors + array(
1716
+                        'a'                                                                                                    => array( 'c' ),
1717
+                        '.btn-link'                                                                                            => array( 'c' ),
1718
+                        '.dropdown-item.active'                                                                                => array( 'b' ),
1719
+                        '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1720
+                            'b',
1721
+                            'o'
1722
+                        ),
1723
+                        '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1724
+                            'b',
1725
+                            'o'
1726
+                        ),
1727
+                        '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1728
+                        '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1729
+                        '.page-link'                                                                                           => array( 'c' ),
1730
+                        '.page-item.active .page-link'                                                                         => array(
1731
+                            'b',
1732
+                            'o'
1733
+                        ),
1734
+                        '.progress-bar'                                                                                        => array( 'b' ),
1735
+                        '.list-group-item.active'                                                                              => array(
1736
+                            'b',
1737
+                            'o'
1738
+                        ),
1739
+                        '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1740
+//				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1741
+//				    '.custom-range::-moz-range-thumb' => array('b'),
1742
+//				    '.custom-range::-ms-thumb' => array('b'),
1743
+                    );
1744
+            }
1745
+
1746
+            $important_selectors = array(
1747
+                ".bg-{$type}" => array('b','f'),
1748
+                ".border-{$type}" => array('o'),
1749
+                ".text-{$type}" => array('c'),
1750
+            );
1751
+
1752
+            $color = array();
1753
+            $color_i = array();
1754
+            $background = array();
1755
+            $background_i = array();
1756
+            $border = array();
1757
+            $border_i = array();
1758
+            $fill = array();
1759
+            $fill_i = array();
1760
+
1761
+            $output = '';
1762
+
1763
+            if ( $aui_bs5 ) {
1764
+//				$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).'; }';
1765
+                $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1766
+            }
1767
+
1768
+            // build rules into each type
1769
+            foreach($selectors as $selector => $types){
1770
+                $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1771
+                $types = array_combine($types,$types);
1772
+                if(isset($types['c'])){$color[] = $selector;}
1773
+                if(isset($types['b'])){$background[] = $selector;}
1774
+                if(isset($types['o'])){$border[] = $selector;}
1775
+                if(isset($types['f'])){$fill[] = $selector;}
1776
+            }
1777
+
1778
+            // build rules into each type
1779
+            foreach($important_selectors as $selector => $types){
1780
+                $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1781
+                $types = array_combine($types,$types);
1782
+                if(isset($types['c'])){$color_i[] = $selector;}
1783
+                if(isset($types['b'])){$background_i[] = $selector;}
1784
+                if(isset($types['o'])){$border_i[] = $selector;}
1785
+                if(isset($types['f'])){$fill_i[] = $selector;}
1786
+            }
1787
+
1788
+            // add any color rules
1789
+            if(!empty($color)){
1790
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1791
+            }
1792
+            if(!empty($color_i)){
1793
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1794
+            }
1795
+
1796
+            // add any background color rules
1797
+            if(!empty($background)){
1798
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1799
+            }
1800
+            if(!empty($background_i)){
1801
+                $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1802
+//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1803
+            }
1804
+
1805
+            // add any border color rules
1806
+            if(!empty($border)){
1807
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1808
+            }
1809
+            if(!empty($border_i)){
1810
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1811
+            }
1812
+
1813
+            // add any fill color rules
1814
+            if(!empty($fill)){
1815
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1816
+            }
1817
+            if(!empty($fill_i)){
1818
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1819
+            }
1820
+
1821
+
1822
+            $prefix = $compatibility ? $compatibility . " " : "";
1823
+
1824
+            $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;' : '';
1825
+            // darken
1826
+            $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1827
+            $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1828
+            $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1829
+            $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1830
+
1831
+            // lighten
1832
+            $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1833
+
1834
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1835
+            $op_25 = $color_code."40"; // 25% opacity
1836
+
1837
+
1838
+            // button states
1839
+            $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1840
+            $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1841
+//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1842
+            $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;} ";
1843
+            $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.";} ";
1844
+            $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;} ";
1845
+
1846
+            if ( $type == 'primary' ) {
1847
+                // dropdown's
1848
+                $output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1849
+
1850
+                // input states
1851
+                $output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1852
+
1853
+                // page link
1854
+                $output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1855
+            }
1856
+
1857
+            // alerts
1858
+            if ( $aui_bs5 ) {
1859
+//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1860
+                $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;} ";
1861
+            }
1862
+
1863
+            return $output;
1864
+        }
1865
+
1866
+        /**
1867
+         *
1868
+         * @deprecated 0.1.76 Use css_overwrite()
1869
+         *
1870
+         * @param $color_code
1871
+         * @param $compatibility
1872
+         * @param $use_variable
1873
+         *
1874
+         * @return string
1875
+         */
1876
+        public static function css_primary($color_code,$compatibility, $use_variable = false){
1877
+
1878
+            if(!$use_variable){
1879
+                $color_code = sanitize_hex_color($color_code);
1880
+                if(!$color_code){return '';}
1881
+            }
1882
+
1883
+            /**
1884
+             * c = color, b = background color, o = border-color, f = fill
1885
+             */
1886
+            $selectors = array(
1887
+                'a' => array('c'),
1888
+                '.btn-primary' => array('b','o'),
1889
+                '.btn-primary.disabled' => array('b','o'),
1890
+                '.btn-primary:disabled' => array('b','o'),
1891
+                '.btn-outline-primary' => array('c','o'),
1892
+                '.btn-outline-primary:hover' => array('b','o'),
1893
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1894
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1895
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1896
+                '.btn-link' => array('c'),
1897
+                '.dropdown-item.active' => array('b'),
1898
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1899
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1900
+//				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1901
+//				'.custom-range::-moz-range-thumb' => array('b'),
1902
+//				'.custom-range::-ms-thumb' => array('b'),
1903
+                '.nav-pills .nav-link.active' => array('b'),
1904
+                '.nav-pills .show>.nav-link' => array('b'),
1905
+                '.page-link' => array('c'),
1906
+                '.page-item.active .page-link' => array('b','o'),
1907
+                '.badge-primary' => array('b'),
1908
+                '.alert-primary' => array('b','o'),
1909
+                '.progress-bar' => array('b'),
1910
+                '.list-group-item.active' => array('b','o'),
1911
+                '.bg-primary' => array('b','f'),
1912
+                '.btn-link.btn-primary' => array('c'),
1913
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1914
+            );
1915
+
1916
+            $important_selectors = array(
1917
+                '.bg-primary' => array('b','f'),
1918
+                '.border-primary' => array('o'),
1919
+                '.text-primary' => array('c'),
1920
+            );
1921
+
1922
+            $color = array();
1923
+            $color_i = array();
1924
+            $background = array();
1925
+            $background_i = array();
1926
+            $border = array();
1927
+            $border_i = array();
1928
+            $fill = array();
1929
+            $fill_i = array();
1930
+
1931
+            $output = '';
1932
+
1933
+            // build rules into each type
1934
+            foreach($selectors as $selector => $types){
1935
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1936
+                $types = array_combine($types,$types);
1937
+                if(isset($types['c'])){$color[] = $selector;}
1938
+                if(isset($types['b'])){$background[] = $selector;}
1939
+                if(isset($types['o'])){$border[] = $selector;}
1940
+                if(isset($types['f'])){$fill[] = $selector;}
1941
+            }
1942
+
1943
+            // build rules into each type
1944
+            foreach($important_selectors as $selector => $types){
1945
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1946
+                $types = array_combine($types,$types);
1947
+                if(isset($types['c'])){$color_i[] = $selector;}
1948
+                if(isset($types['b'])){$background_i[] = $selector;}
1949
+                if(isset($types['o'])){$border_i[] = $selector;}
1950
+                if(isset($types['f'])){$fill_i[] = $selector;}
1951
+            }
1952
+
1953
+            // add any color rules
1954
+            if(!empty($color)){
1955
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1956
+            }
1957
+            if(!empty($color_i)){
1958
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1959
+            }
1960
+
1961
+            // add any background color rules
1962
+            if(!empty($background)){
1963
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1964
+            }
1965
+            if(!empty($background_i)){
1966
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1967
+            }
1968
+
1969
+            // add any border color rules
1970
+            if(!empty($border)){
1971
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1972
+            }
1973
+            if(!empty($border_i)){
1974
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1975
+            }
1976
+
1977
+            // add any fill color rules
1978
+            if(!empty($fill)){
1979
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1980
+            }
1981
+            if(!empty($fill_i)){
1982
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1983
+            }
1984
+
1572 1985
 
1573
-				// add any background color rules
1574
-				if(!empty($background)){
1575
-					$output .= implode(",",$background) . "{background-color: $color_code;} ";
1576
-				}
1577
-				if(!empty($background_i)){
1578
-					$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1579
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1580
-				}
1986
+            $prefix = $compatibility ? ".bsui " : "";
1581 1987
 
1582
-				// add any border color rules
1583
-				if(!empty($border)){
1584
-					$output .= implode(",",$border) . "{border-color: $color_code;} ";
1585
-				}
1586
-				if(!empty($border_i)){
1587
-					$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1588
-				}
1988
+            // darken
1989
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1990
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1991
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1589 1992
 
1590
-				// add any fill color rules
1591
-				if(!empty($fill)){
1592
-					$output .= implode(",",$fill) . "{fill: $color_code;} ";
1593
-				}
1594
-				if(!empty($fill_i)){
1595
-					$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1596
-				}
1993
+            // lighten
1994
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1597 1995
 
1598
-			}
1996
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1997
+            $op_25 = $color_code."40"; // 25% opacity
1599 1998
 
1600 1999
 
2000
+            // button states
2001
+            $output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2002
+            $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;} ";
2003
+            $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.";} ";
2004
+            $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;} ";
1601 2005
 
1602 2006
 
1603
-			$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;' : '';
1604
-			// darken
1605
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1606
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1607
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1608
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
2007
+            // dropdown's
2008
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1609 2009
 
1610
-			// lighten
1611
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1612 2010
 
1613
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1614
-			$op_25 = $color_code."40"; // 25% opacity
2011
+            // input states
2012
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1615 2013
 
2014
+            // page link
2015
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1616 2016
 
1617
-			// button states
1618
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1619
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1620
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1621
-			$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;} ";
1622
-			$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.";} ";
1623
-            $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;} ";
1624
-            $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);} ";
2017
+            return $output;
2018
+        }
1625 2019
 
1626
-			// text
1627
-//			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
2020
+        /**
2021
+         *
2022
+         * @deprecated 0.1.76 Use css_overwrite()
2023
+         *
2024
+         * @param $color_code
2025
+         * @param $compatibility
2026
+         *
2027
+         * @return string
2028
+         */
2029
+        public static function css_secondary($color_code,$compatibility){;
2030
+            $color_code = sanitize_hex_color($color_code);
2031
+            if(!$color_code){return '';}
2032
+            /**
2033
+             * c = color, b = background color, o = border-color, f = fill
2034
+             */
2035
+            $selectors = array(
2036
+                '.btn-secondary' => array('b','o'),
2037
+                '.btn-secondary.disabled' => array('b','o'),
2038
+                '.btn-secondary:disabled' => array('b','o'),
2039
+                '.btn-outline-secondary' => array('c','o'),
2040
+                '.btn-outline-secondary:hover' => array('b','o'),
2041
+                '.btn-outline-secondary.disabled' => array('c'),
2042
+                '.btn-outline-secondary:disabled' => array('c'),
2043
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2044
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2045
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2046
+                '.badge-secondary' => array('b'),
2047
+                '.alert-secondary' => array('b','o'),
2048
+                '.btn-link.btn-secondary' => array('c'),
2049
+            );
2050
+
2051
+            $important_selectors = array(
2052
+                '.bg-secondary' => array('b','f'),
2053
+                '.border-secondary' => array('o'),
2054
+                '.text-secondary' => array('c'),
2055
+            );
2056
+
2057
+            $color = array();
2058
+            $color_i = array();
2059
+            $background = array();
2060
+            $background_i = array();
2061
+            $border = array();
2062
+            $border_i = array();
2063
+            $fill = array();
2064
+            $fill_i = array();
1628 2065
 
2066
+            $output = '';
1629 2067
 
1630
-//			if ( $type == 'primary' ) {
1631
-//				// dropdown's
1632
-//				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1633
-//
1634
-//				// input states
1635
-//				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1636
-//
1637
-//				// page link
1638
-//				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1639
-//			}
2068
+            // build rules into each type
2069
+            foreach($selectors as $selector => $types){
2070
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
2071
+                $types = array_combine($types,$types);
2072
+                if(isset($types['c'])){$color[] = $selector;}
2073
+                if(isset($types['b'])){$background[] = $selector;}
2074
+                if(isset($types['o'])){$border[] = $selector;}
2075
+                if(isset($types['f'])){$fill[] = $selector;}
2076
+            }
1640 2077
 
1641
-			// alerts
1642
-			if ( $aui_bs5 ) {
1643
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1644
-				$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;} ";
1645
-			}
1646
-
1647
-			return $output;
1648
-		}
1649
-
1650
-		/**
1651
-		 * Build the CSS to overwrite a bootstrap color variable.
1652
-		 *
1653
-		 * @param $type
1654
-		 * @param $color_code
1655
-		 * @param $compatibility
1656
-		 *
1657
-		 * @return string
1658
-		 */
1659
-		public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1660
-            global $aui_bs5;
2078
+            // build rules into each type
2079
+            foreach($important_selectors as $selector => $types){
2080
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
2081
+                $types = array_combine($types,$types);
2082
+                if(isset($types['c'])){$color_i[] = $selector;}
2083
+                if(isset($types['b'])){$background_i[] = $selector;}
2084
+                if(isset($types['o'])){$border_i[] = $selector;}
2085
+                if(isset($types['f'])){$fill_i[] = $selector;}
2086
+            }
1661 2087
 
1662
-			$is_var = false;
1663
-			if(!$color_code){return '';}
1664
-			if(strpos($color_code, 'var') !== false){
1665
-				//if(!sanitize_hex_color($color_code)){
1666
-				$color_code = esc_attr($color_code);
1667
-				$is_var = true;
1668
-//				$color_code = "rgba($color_code, 0.5)";
1669
-//                echo '###1'.$color_code.'###';//exit;
1670
-			}
2088
+            // add any color rules
2089
+            if(!empty($color)){
2090
+                $output .= implode(",",$color) . "{color: $color_code;} ";
2091
+            }
2092
+            if(!empty($color_i)){
2093
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2094
+            }
1671 2095
 
1672
-//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
2096
+            // add any background color rules
2097
+            if(!empty($background)){
2098
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
2099
+            }
2100
+            if(!empty($background_i)){
2101
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2102
+            }
1673 2103
 
1674
-			if(!$color_code){return '';}
2104
+            // add any border color rules
2105
+            if(!empty($border)){
2106
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
2107
+            }
2108
+            if(!empty($border_i)){
2109
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2110
+            }
1675 2111
 
1676
-            $rgb = self::hex_to_rgb($hex);
2112
+            // add any fill color rules
2113
+            if(!empty($fill)){
2114
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
2115
+            }
2116
+            if(!empty($fill_i)){
2117
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2118
+            }
1677 2119
 
1678
-			if($compatibility===true || $compatibility===1){
1679
-				$compatibility = '.bsui';
1680
-			}elseif(!$compatibility){
1681
-				$compatibility = '';
1682
-			}else{
1683
-				$compatibility = esc_attr($compatibility);
1684
-			}
1685 2120
 
2121
+            $prefix = $compatibility ? ".bsui " : "";
1686 2122
 
2123
+            // darken
2124
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2125
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2126
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1687 2127
 
1688
-//            echo '####'.$color_code;exit;
2128
+            // lighten
2129
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1689 2130
 
1690
-			$type = sanitize_html_class($type);
2131
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
2132
+            $op_25 = $color_code."40"; // 25% opacity
1691 2133
 
1692
-			/**
1693
-			 * c = color, b = background color, o = border-color, f = fill
1694
-			 */
1695
-			$selectors = array(
1696
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1697
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1698
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1699
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1700
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1701
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1702
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1703
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1704
-				".badge-{$type}"                                            => array( 'b' ),
1705
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1706
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1707
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1708
-			);
1709
-
1710
-			if ( $aui_bs5 ) {
1711
-                unset($selectors[".alert-{$type}" ]);
1712
-			}
1713
-
1714
-			if ( $type == 'primary' ) {
1715
-				$selectors = $selectors + array(
1716
-						'a'                                                                                                    => array( 'c' ),
1717
-						'.btn-link'                                                                                            => array( 'c' ),
1718
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1719
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1720
-							'b',
1721
-							'o'
1722
-						),
1723
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1724
-							'b',
1725
-							'o'
1726
-						),
1727
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1728
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1729
-						'.page-link'                                                                                           => array( 'c' ),
1730
-						'.page-item.active .page-link'                                                                         => array(
1731
-							'b',
1732
-							'o'
1733
-						),
1734
-						'.progress-bar'                                                                                        => array( 'b' ),
1735
-						'.list-group-item.active'                                                                              => array(
1736
-							'b',
1737
-							'o'
1738
-						),
1739
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1740
-//				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1741
-//				    '.custom-range::-moz-range-thumb' => array('b'),
1742
-//				    '.custom-range::-ms-thumb' => array('b'),
1743
-					);
1744
-			}
1745
-
1746
-			$important_selectors = array(
1747
-				".bg-{$type}" => array('b','f'),
1748
-				".border-{$type}" => array('o'),
1749
-				".text-{$type}" => array('c'),
1750
-			);
1751
-
1752
-			$color = array();
1753
-			$color_i = array();
1754
-			$background = array();
1755
-			$background_i = array();
1756
-			$border = array();
1757
-			$border_i = array();
1758
-			$fill = array();
1759
-			$fill_i = array();
1760
-
1761
-			$output = '';
1762
-
1763
-			if ( $aui_bs5 ) {
1764
-//				$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).'; }';
1765
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1766
-			}
1767
-
1768
-			// build rules into each type
1769
-			foreach($selectors as $selector => $types){
1770
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1771
-				$types = array_combine($types,$types);
1772
-				if(isset($types['c'])){$color[] = $selector;}
1773
-				if(isset($types['b'])){$background[] = $selector;}
1774
-				if(isset($types['o'])){$border[] = $selector;}
1775
-				if(isset($types['f'])){$fill[] = $selector;}
1776
-			}
1777
-
1778
-			// build rules into each type
1779
-			foreach($important_selectors as $selector => $types){
1780
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1781
-				$types = array_combine($types,$types);
1782
-				if(isset($types['c'])){$color_i[] = $selector;}
1783
-				if(isset($types['b'])){$background_i[] = $selector;}
1784
-				if(isset($types['o'])){$border_i[] = $selector;}
1785
-				if(isset($types['f'])){$fill_i[] = $selector;}
1786
-			}
1787
-
1788
-			// add any color rules
1789
-			if(!empty($color)){
1790
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1791
-			}
1792
-			if(!empty($color_i)){
1793
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1794
-			}
1795
-
1796
-			// add any background color rules
1797
-			if(!empty($background)){
1798
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1799
-			}
1800
-			if(!empty($background_i)){
1801
-				$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1802
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1803
-			}
1804 2134
 
1805
-			// add any border color rules
1806
-			if(!empty($border)){
1807
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1808
-			}
1809
-			if(!empty($border_i)){
1810
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1811
-			}
2135
+            // button states
2136
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2137
+            $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;} ";
2138
+            $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.";} ";
2139
+            $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;} ";
1812 2140
 
1813
-			// add any fill color rules
1814
-			if(!empty($fill)){
1815
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1816
-			}
1817
-			if(!empty($fill_i)){
1818
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1819
-			}
1820 2141
 
2142
+            return $output;
2143
+        }
1821 2144
 
1822
-			$prefix = $compatibility ? $compatibility . " " : "";
2145
+        /**
2146
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
2147
+         *
2148
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
2149
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
2150
+         *
2151
+         * @return  string
2152
+         */
2153
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2154
+            $hexCode = ltrim($hexCode, '#');
1823 2155
 
1824
-			$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;' : '';
1825
-			// darken
1826
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1827
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1828
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1829
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
2156
+            if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2157
+                return $hexCode;
2158
+            }
1830 2159
 
1831
-			// lighten
1832
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
2160
+            if (strlen($hexCode) == 3) {
2161
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2162
+            }
1833 2163
 
1834
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1835
-			$op_25 = $color_code."40"; // 25% opacity
2164
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1836 2165
 
2166
+            foreach ($hexCode as & $color) {
2167
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2168
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1837 2169
 
1838
-			// button states
1839
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1840
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1841
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1842
-			$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;} ";
1843
-			$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.";} ";
1844
-			$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;} ";
2170
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2171
+            }
1845 2172
 
1846
-			if ( $type == 'primary' ) {
1847
-				// dropdown's
1848
-				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2173
+            return '#' . implode($hexCode);
2174
+        }
1849 2175
 
1850
-				// input states
1851
-				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
2176
+        /**
2177
+         * Check if we should display examples.
2178
+         */
2179
+        public function maybe_show_examples(){
2180
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2181
+                echo "<head>";
2182
+                wp_head();
2183
+                echo "</head>";
2184
+                echo "<body>";
2185
+                echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2186
+                echo "</body>";
2187
+                exit;
2188
+            }
2189
+        }
1852 2190
 
1853
-				// page link
1854
-				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1855
-			}
2191
+        /**
2192
+         * Get developer examples.
2193
+         *
2194
+         * @return string
2195
+         */
2196
+        public function get_examples(){
2197
+            $output = '';
1856 2198
 
1857
-            // alerts
1858
-			if ( $aui_bs5 ) {
1859
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1860
-				$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;} ";
1861
-			}
1862
-
1863
-			return $output;
1864
-		}
1865
-
1866
-		/**
1867
-		 *
1868
-		 * @deprecated 0.1.76 Use css_overwrite()
1869
-		 *
1870
-		 * @param $color_code
1871
-		 * @param $compatibility
1872
-		 * @param $use_variable
1873
-		 *
1874
-		 * @return string
1875
-		 */
1876
-		public static function css_primary($color_code,$compatibility, $use_variable = false){
1877
-
1878
-			if(!$use_variable){
1879
-				$color_code = sanitize_hex_color($color_code);
1880
-				if(!$color_code){return '';}
1881
-			}
1882
-
1883
-			/**
1884
-			 * c = color, b = background color, o = border-color, f = fill
1885
-			 */
1886
-			$selectors = array(
1887
-				'a' => array('c'),
1888
-				'.btn-primary' => array('b','o'),
1889
-				'.btn-primary.disabled' => array('b','o'),
1890
-				'.btn-primary:disabled' => array('b','o'),
1891
-				'.btn-outline-primary' => array('c','o'),
1892
-				'.btn-outline-primary:hover' => array('b','o'),
1893
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1894
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1895
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1896
-				'.btn-link' => array('c'),
1897
-				'.dropdown-item.active' => array('b'),
1898
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1899
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1900
-//				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1901
-//				'.custom-range::-moz-range-thumb' => array('b'),
1902
-//				'.custom-range::-ms-thumb' => array('b'),
1903
-				'.nav-pills .nav-link.active' => array('b'),
1904
-				'.nav-pills .show>.nav-link' => array('b'),
1905
-				'.page-link' => array('c'),
1906
-				'.page-item.active .page-link' => array('b','o'),
1907
-				'.badge-primary' => array('b'),
1908
-				'.alert-primary' => array('b','o'),
1909
-				'.progress-bar' => array('b'),
1910
-				'.list-group-item.active' => array('b','o'),
1911
-				'.bg-primary' => array('b','f'),
1912
-				'.btn-link.btn-primary' => array('c'),
1913
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1914
-			);
1915
-
1916
-			$important_selectors = array(
1917
-				'.bg-primary' => array('b','f'),
1918
-				'.border-primary' => array('o'),
1919
-				'.text-primary' => array('c'),
1920
-			);
1921
-
1922
-			$color = array();
1923
-			$color_i = array();
1924
-			$background = array();
1925
-			$background_i = array();
1926
-			$border = array();
1927
-			$border_i = array();
1928
-			$fill = array();
1929
-			$fill_i = array();
1930
-
1931
-			$output = '';
1932
-
1933
-			// build rules into each type
1934
-			foreach($selectors as $selector => $types){
1935
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1936
-				$types = array_combine($types,$types);
1937
-				if(isset($types['c'])){$color[] = $selector;}
1938
-				if(isset($types['b'])){$background[] = $selector;}
1939
-				if(isset($types['o'])){$border[] = $selector;}
1940
-				if(isset($types['f'])){$fill[] = $selector;}
1941
-			}
1942
-
1943
-			// build rules into each type
1944
-			foreach($important_selectors as $selector => $types){
1945
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1946
-				$types = array_combine($types,$types);
1947
-				if(isset($types['c'])){$color_i[] = $selector;}
1948
-				if(isset($types['b'])){$background_i[] = $selector;}
1949
-				if(isset($types['o'])){$border_i[] = $selector;}
1950
-				if(isset($types['f'])){$fill_i[] = $selector;}
1951
-			}
1952
-
1953
-			// add any color rules
1954
-			if(!empty($color)){
1955
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1956
-			}
1957
-			if(!empty($color_i)){
1958
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1959
-			}
1960
-
1961
-			// add any background color rules
1962
-			if(!empty($background)){
1963
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1964
-			}
1965
-			if(!empty($background_i)){
1966
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1967
-			}
1968
-
1969
-			// add any border color rules
1970
-			if(!empty($border)){
1971
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1972
-			}
1973
-			if(!empty($border_i)){
1974
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1975
-			}
1976
-
1977
-			// add any fill color rules
1978
-			if(!empty($fill)){
1979
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1980
-			}
1981
-			if(!empty($fill_i)){
1982
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1983
-			}
1984
-
1985
-
1986
-			$prefix = $compatibility ? ".bsui " : "";
1987
-
1988
-			// darken
1989
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1990
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1991
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1992
-
1993
-			// lighten
1994
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1995
-
1996
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1997
-			$op_25 = $color_code."40"; // 25% opacity
1998
-
1999
-
2000
-			// button states
2001
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2002
-			$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;} ";
2003
-			$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.";} ";
2004
-			$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;} ";
2005
-
2006
-
2007
-			// dropdown's
2008
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2009
-
2010
-
2011
-			// input states
2012
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2013
-
2014
-			// page link
2015
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2016
-
2017
-			return $output;
2018
-		}
2019
-
2020
-		/**
2021
-		 *
2022
-		 * @deprecated 0.1.76 Use css_overwrite()
2023
-		 *
2024
-		 * @param $color_code
2025
-		 * @param $compatibility
2026
-		 *
2027
-		 * @return string
2028
-		 */
2029
-		public static function css_secondary($color_code,$compatibility){;
2030
-			$color_code = sanitize_hex_color($color_code);
2031
-			if(!$color_code){return '';}
2032
-			/**
2033
-			 * c = color, b = background color, o = border-color, f = fill
2034
-			 */
2035
-			$selectors = array(
2036
-				'.btn-secondary' => array('b','o'),
2037
-				'.btn-secondary.disabled' => array('b','o'),
2038
-				'.btn-secondary:disabled' => array('b','o'),
2039
-				'.btn-outline-secondary' => array('c','o'),
2040
-				'.btn-outline-secondary:hover' => array('b','o'),
2041
-				'.btn-outline-secondary.disabled' => array('c'),
2042
-				'.btn-outline-secondary:disabled' => array('c'),
2043
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2044
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2045
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2046
-				'.badge-secondary' => array('b'),
2047
-				'.alert-secondary' => array('b','o'),
2048
-				'.btn-link.btn-secondary' => array('c'),
2049
-			);
2050
-
2051
-			$important_selectors = array(
2052
-				'.bg-secondary' => array('b','f'),
2053
-				'.border-secondary' => array('o'),
2054
-				'.text-secondary' => array('c'),
2055
-			);
2056
-
2057
-			$color = array();
2058
-			$color_i = array();
2059
-			$background = array();
2060
-			$background_i = array();
2061
-			$border = array();
2062
-			$border_i = array();
2063
-			$fill = array();
2064
-			$fill_i = array();
2065
-
2066
-			$output = '';
2067
-
2068
-			// build rules into each type
2069
-			foreach($selectors as $selector => $types){
2070
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2071
-				$types = array_combine($types,$types);
2072
-				if(isset($types['c'])){$color[] = $selector;}
2073
-				if(isset($types['b'])){$background[] = $selector;}
2074
-				if(isset($types['o'])){$border[] = $selector;}
2075
-				if(isset($types['f'])){$fill[] = $selector;}
2076
-			}
2077
-
2078
-			// build rules into each type
2079
-			foreach($important_selectors as $selector => $types){
2080
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2081
-				$types = array_combine($types,$types);
2082
-				if(isset($types['c'])){$color_i[] = $selector;}
2083
-				if(isset($types['b'])){$background_i[] = $selector;}
2084
-				if(isset($types['o'])){$border_i[] = $selector;}
2085
-				if(isset($types['f'])){$fill_i[] = $selector;}
2086
-			}
2087
-
2088
-			// add any color rules
2089
-			if(!empty($color)){
2090
-				$output .= implode(",",$color) . "{color: $color_code;} ";
2091
-			}
2092
-			if(!empty($color_i)){
2093
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2094
-			}
2095
-
2096
-			// add any background color rules
2097
-			if(!empty($background)){
2098
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
2099
-			}
2100
-			if(!empty($background_i)){
2101
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2102
-			}
2103
-
2104
-			// add any border color rules
2105
-			if(!empty($border)){
2106
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
2107
-			}
2108
-			if(!empty($border_i)){
2109
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2110
-			}
2111
-
2112
-			// add any fill color rules
2113
-			if(!empty($fill)){
2114
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
2115
-			}
2116
-			if(!empty($fill_i)){
2117
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2118
-			}
2119
-
2120
-
2121
-			$prefix = $compatibility ? ".bsui " : "";
2122
-
2123
-			// darken
2124
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2125
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2126
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2127
-
2128
-			// lighten
2129
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2130
-
2131
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
2132
-			$op_25 = $color_code."40"; // 25% opacity
2133
-
2134
-
2135
-			// button states
2136
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2137
-			$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;} ";
2138
-			$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.";} ";
2139
-			$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;} ";
2140
-
2141
-
2142
-			return $output;
2143
-		}
2144
-
2145
-		/**
2146
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
2147
-		 *
2148
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
2149
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
2150
-		 *
2151
-		 * @return  string
2152
-		 */
2153
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2154
-			$hexCode = ltrim($hexCode, '#');
2155
-
2156
-			if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2157
-				return $hexCode;
2158
-			}
2159
-
2160
-			if (strlen($hexCode) == 3) {
2161
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2162
-			}
2163
-
2164
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
2165
-
2166
-			foreach ($hexCode as & $color) {
2167
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2168
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
2169
-
2170
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2171
-			}
2172
-
2173
-			return '#' . implode($hexCode);
2174
-		}
2175
-
2176
-		/**
2177
-		 * Check if we should display examples.
2178
-		 */
2179
-		public function maybe_show_examples(){
2180
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2181
-				echo "<head>";
2182
-				wp_head();
2183
-				echo "</head>";
2184
-				echo "<body>";
2185
-				echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2186
-				echo "</body>";
2187
-				exit;
2188
-			}
2189
-		}
2190
-
2191
-		/**
2192
-		 * Get developer examples.
2193
-		 *
2194
-		 * @return string
2195
-		 */
2196
-		public function get_examples(){
2197
-			$output = '';
2198
-
2199
-
2200
-			// open form
2201
-			$output .= "<form class='p-5 m-5 border rounded'>";
2202
-
2203
-			// input example
2204
-			$output .= aui()->input(array(
2205
-				'type'  =>  'text',
2206
-				'id'    =>  'text-example',
2207
-				'name'    =>  'text-example',
2208
-				'placeholder'   => 'text placeholder',
2209
-				'title'   => 'Text input example',
2210
-				'value' =>  '',
2211
-				'required'  => false,
2212
-				'help_text' => 'help text',
2213
-				'label' => 'Text input example label'
2214
-			));
2215
-
2216
-			// input example
2217
-			$output .= aui()->input(array(
2218
-				'type'  =>  'url',
2219
-				'id'    =>  'text-example2',
2220
-				'name'    =>  'text-example',
2221
-				'placeholder'   => 'url placeholder',
2222
-				'title'   => 'Text input example',
2223
-				'value' =>  '',
2224
-				'required'  => false,
2225
-				'help_text' => 'help text',
2226
-				'label' => 'Text input example label'
2227
-			));
2228
-
2229
-			// checkbox example
2230
-			$output .= aui()->input(array(
2231
-				'type'  =>  'checkbox',
2232
-				'id'    =>  'checkbox-example',
2233
-				'name'    =>  'checkbox-example',
2234
-				'placeholder'   => 'checkbox-example',
2235
-				'title'   => 'Checkbox example',
2236
-				'value' =>  '1',
2237
-				'checked'   => true,
2238
-				'required'  => false,
2239
-				'help_text' => 'help text',
2240
-				'label' => 'Checkbox checked'
2241
-			));
2242
-
2243
-			// checkbox example
2244
-			$output .= aui()->input(array(
2245
-				'type'  =>  'checkbox',
2246
-				'id'    =>  'checkbox-example2',
2247
-				'name'    =>  'checkbox-example2',
2248
-				'placeholder'   => 'checkbox-example',
2249
-				'title'   => 'Checkbox example',
2250
-				'value' =>  '1',
2251
-				'checked'   => false,
2252
-				'required'  => false,
2253
-				'help_text' => 'help text',
2254
-				'label' => 'Checkbox un-checked'
2255
-			));
2256
-
2257
-			// switch example
2258
-			$output .= aui()->input(array(
2259
-				'type'  =>  'checkbox',
2260
-				'id'    =>  'switch-example',
2261
-				'name'    =>  'switch-example',
2262
-				'placeholder'   => 'checkbox-example',
2263
-				'title'   => 'Switch example',
2264
-				'value' =>  '1',
2265
-				'checked'   => true,
2266
-				'switch'    => true,
2267
-				'required'  => false,
2268
-				'help_text' => 'help text',
2269
-				'label' => 'Switch on'
2270
-			));
2271
-
2272
-			// switch example
2273
-			$output .= aui()->input(array(
2274
-				'type'  =>  'checkbox',
2275
-				'id'    =>  'switch-example2',
2276
-				'name'    =>  'switch-example2',
2277
-				'placeholder'   => 'checkbox-example',
2278
-				'title'   => 'Switch example',
2279
-				'value' =>  '1',
2280
-				'checked'   => false,
2281
-				'switch'    => true,
2282
-				'required'  => false,
2283
-				'help_text' => 'help text',
2284
-				'label' => 'Switch off'
2285
-			));
2286
-
2287
-			// close form
2288
-			$output .= "</form>";
2289
-
2290
-			return $output;
2291
-		}
2292
-
2293
-		/**
2294
-		 * Calendar params.
2295
-		 *
2296
-		 * @since 0.1.44
2297
-		 *
2298
-		 * @return array Calendar params.
2299
-		 */
2300
-		public static function calendar_params() {
2301
-			$params = array(
2302
-				'month_long_1' => __( 'January', 'ayecode-connect' ),
2303
-				'month_long_2' => __( 'February', 'ayecode-connect' ),
2304
-				'month_long_3' => __( 'March', 'ayecode-connect' ),
2305
-				'month_long_4' => __( 'April', 'ayecode-connect' ),
2306
-				'month_long_5' => __( 'May', 'ayecode-connect' ),
2307
-				'month_long_6' => __( 'June', 'ayecode-connect' ),
2308
-				'month_long_7' => __( 'July', 'ayecode-connect' ),
2309
-				'month_long_8' => __( 'August', 'ayecode-connect' ),
2310
-				'month_long_9' => __( 'September', 'ayecode-connect' ),
2311
-				'month_long_10' => __( 'October', 'ayecode-connect' ),
2312
-				'month_long_11' => __( 'November', 'ayecode-connect' ),
2313
-				'month_long_12' => __( 'December', 'ayecode-connect' ),
2314
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2315
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2316
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2317
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2318
-				'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2319
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2320
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2321
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2322
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2323
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2324
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2325
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2326
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2327
-				'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2328
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2329
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2330
-				'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2331
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2332
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2333
-				'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2334
-				'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2335
-				'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2336
-				'day_s2_4' => __( 'We', 'ayecode-connect' ),
2337
-				'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2338
-				'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2339
-				'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2340
-				'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2341
-				'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2342
-				'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2343
-				'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2344
-				'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2345
-				'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2346
-				'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2347
-				'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2348
-				'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2349
-				'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2350
-				'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2351
-				'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2352
-				'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2353
-				'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2354
-				'am_lower' => __( 'am', 'ayecode-connect' ),
2355
-				'pm_lower' => __( 'pm', 'ayecode-connect' ),
2356
-				'am_upper' => __( 'AM', 'ayecode-connect' ),
2357
-				'pm_upper' => __( 'PM', 'ayecode-connect' ),
2358
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2359
-				'time_24hr' => false,
2360
-				'year' => __( 'Year', 'ayecode-connect' ),
2361
-				'hour' => __( 'Hour', 'ayecode-connect' ),
2362
-				'minute' => __( 'Minute', 'ayecode-connect' ),
2363
-				'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2364
-				'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2365
-				'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2366
-				'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2367
-			);
2368
-
2369
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
2370
-		}
2371
-
2372
-		/**
2373
-		 * Flatpickr calendar localize.
2374
-		 *
2375
-		 * @since 0.1.44
2376
-		 *
2377
-		 * @return string Calendar locale.
2378
-		 */
2379
-		public static function flatpickr_locale() {
2380
-			$params = self::calendar_params();
2381
-
2382
-			if ( is_string( $params ) ) {
2383
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2384
-			} else {
2385
-				foreach ( (array) $params as $key => $value ) {
2386
-					if ( ! is_scalar( $value ) ) {
2387
-						continue;
2388
-					}
2389
-
2390
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2391
-				}
2392
-			}
2393 2199
 
2394
-			$day_s3 = array();
2395
-			$day_s5 = array();
2200
+            // open form
2201
+            $output .= "<form class='p-5 m-5 border rounded'>";
2202
+
2203
+            // input example
2204
+            $output .= aui()->input(array(
2205
+                'type'  =>  'text',
2206
+                'id'    =>  'text-example',
2207
+                'name'    =>  'text-example',
2208
+                'placeholder'   => 'text placeholder',
2209
+                'title'   => 'Text input example',
2210
+                'value' =>  '',
2211
+                'required'  => false,
2212
+                'help_text' => 'help text',
2213
+                'label' => 'Text input example label'
2214
+            ));
2215
+
2216
+            // input example
2217
+            $output .= aui()->input(array(
2218
+                'type'  =>  'url',
2219
+                'id'    =>  'text-example2',
2220
+                'name'    =>  'text-example',
2221
+                'placeholder'   => 'url placeholder',
2222
+                'title'   => 'Text input example',
2223
+                'value' =>  '',
2224
+                'required'  => false,
2225
+                'help_text' => 'help text',
2226
+                'label' => 'Text input example label'
2227
+            ));
2228
+
2229
+            // checkbox example
2230
+            $output .= aui()->input(array(
2231
+                'type'  =>  'checkbox',
2232
+                'id'    =>  'checkbox-example',
2233
+                'name'    =>  'checkbox-example',
2234
+                'placeholder'   => 'checkbox-example',
2235
+                'title'   => 'Checkbox example',
2236
+                'value' =>  '1',
2237
+                'checked'   => true,
2238
+                'required'  => false,
2239
+                'help_text' => 'help text',
2240
+                'label' => 'Checkbox checked'
2241
+            ));
2242
+
2243
+            // checkbox example
2244
+            $output .= aui()->input(array(
2245
+                'type'  =>  'checkbox',
2246
+                'id'    =>  'checkbox-example2',
2247
+                'name'    =>  'checkbox-example2',
2248
+                'placeholder'   => 'checkbox-example',
2249
+                'title'   => 'Checkbox example',
2250
+                'value' =>  '1',
2251
+                'checked'   => false,
2252
+                'required'  => false,
2253
+                'help_text' => 'help text',
2254
+                'label' => 'Checkbox un-checked'
2255
+            ));
2256
+
2257
+            // switch example
2258
+            $output .= aui()->input(array(
2259
+                'type'  =>  'checkbox',
2260
+                'id'    =>  'switch-example',
2261
+                'name'    =>  'switch-example',
2262
+                'placeholder'   => 'checkbox-example',
2263
+                'title'   => 'Switch example',
2264
+                'value' =>  '1',
2265
+                'checked'   => true,
2266
+                'switch'    => true,
2267
+                'required'  => false,
2268
+                'help_text' => 'help text',
2269
+                'label' => 'Switch on'
2270
+            ));
2271
+
2272
+            // switch example
2273
+            $output .= aui()->input(array(
2274
+                'type'  =>  'checkbox',
2275
+                'id'    =>  'switch-example2',
2276
+                'name'    =>  'switch-example2',
2277
+                'placeholder'   => 'checkbox-example',
2278
+                'title'   => 'Switch example',
2279
+                'value' =>  '1',
2280
+                'checked'   => false,
2281
+                'switch'    => true,
2282
+                'required'  => false,
2283
+                'help_text' => 'help text',
2284
+                'label' => 'Switch off'
2285
+            ));
2286
+
2287
+            // close form
2288
+            $output .= "</form>";
2289
+
2290
+            return $output;
2291
+        }
2292
+
2293
+        /**
2294
+         * Calendar params.
2295
+         *
2296
+         * @since 0.1.44
2297
+         *
2298
+         * @return array Calendar params.
2299
+         */
2300
+        public static function calendar_params() {
2301
+            $params = array(
2302
+                'month_long_1' => __( 'January', 'ayecode-connect' ),
2303
+                'month_long_2' => __( 'February', 'ayecode-connect' ),
2304
+                'month_long_3' => __( 'March', 'ayecode-connect' ),
2305
+                'month_long_4' => __( 'April', 'ayecode-connect' ),
2306
+                'month_long_5' => __( 'May', 'ayecode-connect' ),
2307
+                'month_long_6' => __( 'June', 'ayecode-connect' ),
2308
+                'month_long_7' => __( 'July', 'ayecode-connect' ),
2309
+                'month_long_8' => __( 'August', 'ayecode-connect' ),
2310
+                'month_long_9' => __( 'September', 'ayecode-connect' ),
2311
+                'month_long_10' => __( 'October', 'ayecode-connect' ),
2312
+                'month_long_11' => __( 'November', 'ayecode-connect' ),
2313
+                'month_long_12' => __( 'December', 'ayecode-connect' ),
2314
+                'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2315
+                'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2316
+                'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2317
+                'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2318
+                'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2319
+                'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2320
+                'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2321
+                'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2322
+                'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2323
+                'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2324
+                'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2325
+                'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2326
+                'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2327
+                'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2328
+                'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2329
+                'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2330
+                'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2331
+                'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2332
+                'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2333
+                'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2334
+                'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2335
+                'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2336
+                'day_s2_4' => __( 'We', 'ayecode-connect' ),
2337
+                'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2338
+                'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2339
+                'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2340
+                'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2341
+                'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2342
+                'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2343
+                'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2344
+                'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2345
+                'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2346
+                'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2347
+                'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2348
+                'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2349
+                'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2350
+                'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2351
+                'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2352
+                'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2353
+                'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2354
+                'am_lower' => __( 'am', 'ayecode-connect' ),
2355
+                'pm_lower' => __( 'pm', 'ayecode-connect' ),
2356
+                'am_upper' => __( 'AM', 'ayecode-connect' ),
2357
+                'pm_upper' => __( 'PM', 'ayecode-connect' ),
2358
+                'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2359
+                'time_24hr' => false,
2360
+                'year' => __( 'Year', 'ayecode-connect' ),
2361
+                'hour' => __( 'Hour', 'ayecode-connect' ),
2362
+                'minute' => __( 'Minute', 'ayecode-connect' ),
2363
+                'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2364
+                'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2365
+                'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2366
+                'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2367
+            );
2368
+
2369
+            return apply_filters( 'ayecode_ui_calendar_params', $params );
2370
+        }
2371
+
2372
+        /**
2373
+         * Flatpickr calendar localize.
2374
+         *
2375
+         * @since 0.1.44
2376
+         *
2377
+         * @return string Calendar locale.
2378
+         */
2379
+        public static function flatpickr_locale() {
2380
+            $params = self::calendar_params();
2381
+
2382
+            if ( is_string( $params ) ) {
2383
+                $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2384
+            } else {
2385
+                foreach ( (array) $params as $key => $value ) {
2386
+                    if ( ! is_scalar( $value ) ) {
2387
+                        continue;
2388
+                    }
2389
+
2390
+                    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2391
+                }
2392
+            }
2396 2393
 
2397
-			for ( $i = 1; $i <= 7; $i ++ ) {
2398
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2400
-			}
2394
+            $day_s3 = array();
2395
+            $day_s5 = array();
2396
+
2397
+            for ( $i = 1; $i <= 7; $i ++ ) {
2398
+                $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
+                $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2400
+            }
2401 2401
 
2402
-			$month_s = array();
2403
-			$month_long = array();
2402
+            $month_s = array();
2403
+            $month_long = array();
2404 2404
 
2405
-			for ( $i = 1; $i <= 12; $i ++ ) {
2406
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2407
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2408
-			}
2405
+            for ( $i = 1; $i <= 12; $i ++ ) {
2406
+                $month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2407
+                $month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2408
+            }
2409 2409
 
2410
-			ob_start();
2411
-		if ( 0 ) { ?><script><?php } ?>
2410
+            ob_start();
2411
+        if ( 0 ) { ?><script><?php } ?>
2412 2412
                 {
2413 2413
                     weekdays: {
2414 2414
                         shorthand: ['<?php echo implode( "','", $day_s3 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
@@ -2447,189 +2447,189 @@  discard block
 block discarded – undo
2447 2447
                 }
2448 2448
 				<?php if ( 0 ) { ?></script><?php } ?>
2449 2449
 			<?php
2450
-			$locale = ob_get_clean();
2451
-
2452
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2453
-		}
2454
-
2455
-		/**
2456
-		 * Select2 JS params.
2457
-		 *
2458
-		 * @since 0.1.44
2459
-		 *
2460
-		 * @return array Select2 JS params.
2461
-		 */
2462
-		public static function select2_params() {
2463
-			$params = array(
2464
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2465
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2466
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2467
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2468
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2469
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2470
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2471
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2472
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2473
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2474
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2475
-			);
2476
-
2477
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2478
-		}
2479
-
2480
-		/**
2481
-		 * Select2 JS localize.
2482
-		 *
2483
-		 * @since 0.1.44
2484
-		 *
2485
-		 * @return string Select2 JS locale.
2486
-		 */
2487
-		public static function select2_locale() {
2488
-			$params = self::select2_params();
2489
-
2490
-			foreach ( (array) $params as $key => $value ) {
2491
-				if ( ! is_scalar( $value ) ) {
2492
-					continue;
2493
-				}
2450
+            $locale = ob_get_clean();
2494 2451
 
2495
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2496
-			}
2497
-
2498
-			$locale = json_encode( $params );
2499
-
2500
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2501
-		}
2502
-
2503
-		/**
2504
-		 * Time ago JS localize.
2505
-		 *
2506
-		 * @since 0.1.47
2507
-		 *
2508
-		 * @return string Time ago JS locale.
2509
-		 */
2510
-		public static function timeago_locale() {
2511
-			$params = array(
2512
-				'prefix_ago' => '',
2513
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2514
-				'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2515
-				'suffix_after' => '',
2516
-				'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2517
-				'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2518
-				'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2519
-				'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2520
-				'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2521
-				'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2522
-				'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2523
-				'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2524
-				'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2525
-				'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2526
-				'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2527
-			);
2528
-
2529
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2530
-
2531
-			foreach ( (array) $params as $key => $value ) {
2532
-				if ( ! is_scalar( $value ) ) {
2533
-					continue;
2534
-				}
2452
+            return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2453
+        }
2454
+
2455
+        /**
2456
+         * Select2 JS params.
2457
+         *
2458
+         * @since 0.1.44
2459
+         *
2460
+         * @return array Select2 JS params.
2461
+         */
2462
+        public static function select2_params() {
2463
+            $params = array(
2464
+                'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2465
+                'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2466
+                'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2467
+                'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2468
+                'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2469
+                'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2470
+                'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2471
+                'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2472
+                'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2473
+                'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2474
+                'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2475
+            );
2476
+
2477
+            return apply_filters( 'ayecode_ui_select2_params', $params );
2478
+        }
2479
+
2480
+        /**
2481
+         * Select2 JS localize.
2482
+         *
2483
+         * @since 0.1.44
2484
+         *
2485
+         * @return string Select2 JS locale.
2486
+         */
2487
+        public static function select2_locale() {
2488
+            $params = self::select2_params();
2489
+
2490
+            foreach ( (array) $params as $key => $value ) {
2491
+                if ( ! is_scalar( $value ) ) {
2492
+                    continue;
2493
+                }
2494
+
2495
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2496
+            }
2497
+
2498
+            $locale = json_encode( $params );
2499
+
2500
+            return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2501
+        }
2502
+
2503
+        /**
2504
+         * Time ago JS localize.
2505
+         *
2506
+         * @since 0.1.47
2507
+         *
2508
+         * @return string Time ago JS locale.
2509
+         */
2510
+        public static function timeago_locale() {
2511
+            $params = array(
2512
+                'prefix_ago' => '',
2513
+                'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2514
+                'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2515
+                'suffix_after' => '',
2516
+                'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2517
+                'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2518
+                'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2519
+                'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2520
+                'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2521
+                'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2522
+                'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2523
+                'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2524
+                'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2525
+                'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2526
+                'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2527
+            );
2528
+
2529
+            $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2530
+
2531
+            foreach ( (array) $params as $key => $value ) {
2532
+                if ( ! is_scalar( $value ) ) {
2533
+                    continue;
2534
+                }
2535 2535
 
2536
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2537
-			}
2538
-
2539
-			$locale = json_encode( $params );
2540
-
2541
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2542
-		}
2543
-
2544
-		/**
2545
-		 * JavaScript Minifier
2546
-		 *
2547
-		 * @param $input
2548
-		 *
2549
-		 * @return mixed
2550
-		 */
2551
-		public static function minify_js($input) {
2552
-			if(trim($input) === "") return $input;
2553
-			return preg_replace(
2554
-				array(
2555
-					// Remove comment(s)
2556
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2557
-					// Remove white-space(s) outside the string and regex
2558
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2559
-					// Remove the last semicolon
2560
-					'#;+\}#',
2561
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2562
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2563
-					// --ibid. From `foo['bar']` to `foo.bar`
2564
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2565
-				),
2566
-				array(
2567
-					'$1',
2568
-					'$1$2',
2569
-					'}',
2570
-					'$1$3',
2571
-					'$1.$3'
2572
-				),
2573
-				$input);
2574
-		}
2575
-
2576
-		/**
2577
-		 * Minify CSS
2578
-		 *
2579
-		 * @param $input
2580
-		 *
2581
-		 * @return mixed
2582
-		 */
2583
-		public static function minify_css($input) {
2584
-			if(trim($input) === "") return $input;
2585
-			return preg_replace(
2586
-				array(
2587
-					// Remove comment(s)
2588
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2589
-					// Remove unused white-space(s)
2590
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2591
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2592
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2593
-					// Replace `:0 0 0 0` with `:0`
2594
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2595
-					// Replace `background-position:0` with `background-position:0 0`
2596
-					'#(background-position):0(?=[;\}])#si',
2597
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2598
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2599
-					// Minify string value
2600
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2601
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2602
-					// Minify HEX color code
2603
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2604
-					// Replace `(border|outline):none` with `(border|outline):0`
2605
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2606
-					// Remove empty selector(s)
2607
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2608
-				),
2609
-				array(
2610
-					'$1',
2611
-					'$1$2$3$4$5$6$7',
2612
-					'$1',
2613
-					':0',
2614
-					'$1:0 0',
2615
-					'.$1',
2616
-					'$1$3',
2617
-					'$1$2$4$5',
2618
-					'$1$2$3',
2619
-					'$1:0',
2620
-					'$1$2'
2621
-				),
2622
-				$input);
2623
-		}
2624
-
2625
-		/**
2626
-		 * Get the conditional fields JavaScript.
2627
-		 *
2628
-		 * @return mixed
2629
-		 */
2630
-		public function conditional_fields_js() {
2631
-			ob_start();
2632
-			?>
2536
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2537
+            }
2538
+
2539
+            $locale = json_encode( $params );
2540
+
2541
+            return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2542
+        }
2543
+
2544
+        /**
2545
+         * JavaScript Minifier
2546
+         *
2547
+         * @param $input
2548
+         *
2549
+         * @return mixed
2550
+         */
2551
+        public static function minify_js($input) {
2552
+            if(trim($input) === "") return $input;
2553
+            return preg_replace(
2554
+                array(
2555
+                    // Remove comment(s)
2556
+                    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2557
+                    // Remove white-space(s) outside the string and regex
2558
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2559
+                    // Remove the last semicolon
2560
+                    '#;+\}#',
2561
+                    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2562
+                    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2563
+                    // --ibid. From `foo['bar']` to `foo.bar`
2564
+                    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2565
+                ),
2566
+                array(
2567
+                    '$1',
2568
+                    '$1$2',
2569
+                    '}',
2570
+                    '$1$3',
2571
+                    '$1.$3'
2572
+                ),
2573
+                $input);
2574
+        }
2575
+
2576
+        /**
2577
+         * Minify CSS
2578
+         *
2579
+         * @param $input
2580
+         *
2581
+         * @return mixed
2582
+         */
2583
+        public static function minify_css($input) {
2584
+            if(trim($input) === "") return $input;
2585
+            return preg_replace(
2586
+                array(
2587
+                    // Remove comment(s)
2588
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2589
+                    // Remove unused white-space(s)
2590
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2591
+                    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2592
+                    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2593
+                    // Replace `:0 0 0 0` with `:0`
2594
+                    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2595
+                    // Replace `background-position:0` with `background-position:0 0`
2596
+                    '#(background-position):0(?=[;\}])#si',
2597
+                    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2598
+                    '#(?<=[\s:,\-])0+\.(\d+)#s',
2599
+                    // Minify string value
2600
+                    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2601
+                    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2602
+                    // Minify HEX color code
2603
+                    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2604
+                    // Replace `(border|outline):none` with `(border|outline):0`
2605
+                    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2606
+                    // Remove empty selector(s)
2607
+                    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2608
+                ),
2609
+                array(
2610
+                    '$1',
2611
+                    '$1$2$3$4$5$6$7',
2612
+                    '$1',
2613
+                    ':0',
2614
+                    '$1:0 0',
2615
+                    '.$1',
2616
+                    '$1$3',
2617
+                    '$1$2$4$5',
2618
+                    '$1$2$3',
2619
+                    '$1:0',
2620
+                    '$1$2'
2621
+                ),
2622
+                $input);
2623
+        }
2624
+
2625
+        /**
2626
+         * Get the conditional fields JavaScript.
2627
+         *
2628
+         * @return mixed
2629
+         */
2630
+        public function conditional_fields_js() {
2631
+            ob_start();
2632
+            ?>
2633 2633
             <script>
2634 2634
                 /**
2635 2635
                  * Conditional Fields
@@ -3164,237 +3164,237 @@  discard block
 block discarded – undo
3164 3164
 				<?php do_action( 'aui_conditional_fields_js', $this ); ?>
3165 3165
             </script>
3166 3166
 			<?php
3167
-			$output = ob_get_clean();
3168
-
3169
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3170
-		}
3171
-
3172
-		/**
3173
-		 * Check if block editor page.
3174
-		 *
3175
-		 * @since 0.2.27
3176
-		 *
3177
-		 * @return bool
3178
-		 */
3179
-		public static function is_block_editor() {
3180
-			if ( is_admin() ) {
3181
-				$current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3182
-
3183
-				if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3184
-					return true;
3185
-				}
3186
-			}
3187
-
3188
-			return false;
3189
-		}
3190
-
3191
-		/**
3192
-		 * Checks if the current call is a ajax call to get the block content.
3193
-		 *
3194
-		 * This can be used in your widget to return different content as the block content.
3195
-		 *
3196
-		 * @since 0.2.27
3197
-		 *
3198
-		 * @return bool
3199
-		 */
3200
-		public static function is_block_content_call() {
3201
-			$result = false;
3202
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3203
-				$result = true;
3204
-			}
3205
-
3206
-			return $result;
3207
-		}
3208
-
3209
-		/**
3210
-		 * Tests if the current output is inside a Divi preview.
3211
-		 *
3212
-		 * @since 0.2.27
3213
-		 *
3214
-		 * @return bool
3215
-		 */
3216
-		public static function is_divi_preview() {
3217
-			$result = false;
3218
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3219
-				$result = true;
3220
-			}
3221
-
3222
-			return $result;
3223
-		}
3224
-
3225
-		/**
3226
-		 * Tests if the current output is inside a elementor preview.
3227
-		 *
3228
-		 *
3229
-		 * @since 0.2.27
3230
-		 *
3231
-		 * @return bool
3232
-		 */
3233
-		public static function is_elementor_preview() {
3234
-			$result = false;
3235
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3236
-				$result = true;
3237
-			}
3238
-
3239
-			return $result;
3240
-		}
3241
-
3242
-		/**
3243
-		 * Tests if the current output is inside a Beaver builder preview.
3244
-		 *
3245
-		 * @since 0.2.27
3246
-		 *
3247
-		 * @return bool
3248
-		 */
3249
-		public static function is_beaver_preview() {
3250
-			$result = false;
3251
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3252
-				$result = true;
3253
-			}
3254
-
3255
-			return $result;
3256
-		}
3257
-
3258
-		/**
3259
-		 * Tests if the current output is inside a siteorigin builder preview.
3260
-		 *
3261
-		 * @since 0.2.27
3262
-		 *
3263
-		 * @return bool
3264
-		 */
3265
-		public static function is_siteorigin_preview() {
3266
-			$result = false;
3267
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3268
-				$result = true;
3269
-			}
3270
-
3271
-			return $result;
3272
-		}
3273
-
3274
-		/**
3275
-		 * Tests if the current output is inside a cornerstone builder preview.
3276
-		 *
3277
-		 * @since 0.2.27
3278
-		 *
3279
-		 * @return bool
3280
-		 */
3281
-		public static function is_cornerstone_preview() {
3282
-			$result = false;
3283
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3284
-				$result = true;
3285
-			}
3286
-
3287
-			return $result;
3288
-		}
3289
-
3290
-		/**
3291
-		 * Tests if the current output is inside a fusion builder preview.
3292
-		 *
3293
-		 * @return bool
3294
-		 *@since 1.1.0
3295
-		 */
3296
-		public static function is_fusion_preview() {
3297
-			$result = false;
3298
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3299
-				$result = true;
3300
-			}
3301
-
3302
-			return $result;
3303
-		}
3304
-
3305
-		/**
3306
-		 * Tests if the current output is inside a Oxygen builder preview.
3307
-		 *
3308
-		 * @return bool
3309
-		 *@since 1.0.18
3310
-		 */
3311
-		public static function is_oxygen_preview() {
3312
-			$result = false;
3313
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3314
-				$result = true;
3315
-			}
3316
-
3317
-			return $result;
3318
-		}
3319
-
3320
-		/**
3321
-		 * Check for Kallyas theme Zion builder preview.
3322
-		 *
3323
-		 * @since 0.2.27
3324
-		 *
3325
-		 * @return bool
3326
-		 */
3327
-		public static function is_kallyas_zion_preview() {
3328
-			$result = false;
3329
-
3330
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3331
-				$result = true;
3332
-			}
3333
-
3334
-			return $result;
3335
-		}
3336
-
3337
-		/**
3338
-		 * Check for Bricks theme builder preview.
3339
-		 *
3340
-		 * @since 0.2.27
3341
-		 *
3342
-		 * @return bool
3343
-		 */
3344
-		public static function is_bricks_preview() {
3345
-			$result = false;
3346
-
3347
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3348
-				$result = true;
3349
-			}
3350
-
3351
-			return $result;
3352
-		}
3353
-
3354
-		/**
3355
-		 * General function to check if we are in a preview situation.
3356
-		 *
3357
-		 * @since 0.2.27
3358
-		 *
3359
-		 * @return bool
3360
-		 */
3361
-		public static function is_preview() {
3362
-			$preview = false;
3363
-
3364
-			if ( self::is_block_editor() ) {
3365
-				return true;
3366
-			}
3367
-
3368
-			if( self::is_block_content_call() ) {
3369
-				$preview = true;
3370
-			} elseif ( self::is_divi_preview() ) {
3371
-				$preview = true;
3372
-			} elseif ( self::is_elementor_preview() ) {
3373
-				$preview = true;
3374
-			} elseif ( self::is_beaver_preview() ) {
3375
-				$preview = true;
3376
-			} elseif ( self::is_siteorigin_preview() ) {
3377
-				$preview = true;
3378
-			} elseif ( self::is_cornerstone_preview() ) {
3379
-				$preview = true;
3380
-			} elseif ( self::is_fusion_preview() ) {
3381
-				$preview = true;
3382
-			} elseif ( self::is_oxygen_preview() ) {
3383
-				$preview = true;
3384
-			} elseif( self::is_kallyas_zion_preview() ) {
3385
-				$preview = true;
3386
-			} elseif( self::is_bricks_preview() ) {
3387
-				$preview = true;
3388
-			}
3389
-
3390
-			return $preview;
3391
-		}
3392
-	}
3393
-
3394
-	global $ayecode_ui_settings;
3395
-
3396
-	/**
3397
-	 * Run the class if found.
3398
-	 */
3399
-	$ayecode_ui_settings = AyeCode_UI_Settings::instance();
3167
+            $output = ob_get_clean();
3168
+
3169
+            return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3170
+        }
3171
+
3172
+        /**
3173
+         * Check if block editor page.
3174
+         *
3175
+         * @since 0.2.27
3176
+         *
3177
+         * @return bool
3178
+         */
3179
+        public static function is_block_editor() {
3180
+            if ( is_admin() ) {
3181
+                $current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3182
+
3183
+                if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3184
+                    return true;
3185
+                }
3186
+            }
3187
+
3188
+            return false;
3189
+        }
3190
+
3191
+        /**
3192
+         * Checks if the current call is a ajax call to get the block content.
3193
+         *
3194
+         * This can be used in your widget to return different content as the block content.
3195
+         *
3196
+         * @since 0.2.27
3197
+         *
3198
+         * @return bool
3199
+         */
3200
+        public static function is_block_content_call() {
3201
+            $result = false;
3202
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3203
+                $result = true;
3204
+            }
3205
+
3206
+            return $result;
3207
+        }
3208
+
3209
+        /**
3210
+         * Tests if the current output is inside a Divi preview.
3211
+         *
3212
+         * @since 0.2.27
3213
+         *
3214
+         * @return bool
3215
+         */
3216
+        public static function is_divi_preview() {
3217
+            $result = false;
3218
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3219
+                $result = true;
3220
+            }
3221
+
3222
+            return $result;
3223
+        }
3224
+
3225
+        /**
3226
+         * Tests if the current output is inside a elementor preview.
3227
+         *
3228
+         *
3229
+         * @since 0.2.27
3230
+         *
3231
+         * @return bool
3232
+         */
3233
+        public static function is_elementor_preview() {
3234
+            $result = false;
3235
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3236
+                $result = true;
3237
+            }
3238
+
3239
+            return $result;
3240
+        }
3241
+
3242
+        /**
3243
+         * Tests if the current output is inside a Beaver builder preview.
3244
+         *
3245
+         * @since 0.2.27
3246
+         *
3247
+         * @return bool
3248
+         */
3249
+        public static function is_beaver_preview() {
3250
+            $result = false;
3251
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
3252
+                $result = true;
3253
+            }
3254
+
3255
+            return $result;
3256
+        }
3257
+
3258
+        /**
3259
+         * Tests if the current output is inside a siteorigin builder preview.
3260
+         *
3261
+         * @since 0.2.27
3262
+         *
3263
+         * @return bool
3264
+         */
3265
+        public static function is_siteorigin_preview() {
3266
+            $result = false;
3267
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3268
+                $result = true;
3269
+            }
3270
+
3271
+            return $result;
3272
+        }
3273
+
3274
+        /**
3275
+         * Tests if the current output is inside a cornerstone builder preview.
3276
+         *
3277
+         * @since 0.2.27
3278
+         *
3279
+         * @return bool
3280
+         */
3281
+        public static function is_cornerstone_preview() {
3282
+            $result = false;
3283
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3284
+                $result = true;
3285
+            }
3286
+
3287
+            return $result;
3288
+        }
3289
+
3290
+        /**
3291
+         * Tests if the current output is inside a fusion builder preview.
3292
+         *
3293
+         * @return bool
3294
+         *@since 1.1.0
3295
+         */
3296
+        public static function is_fusion_preview() {
3297
+            $result = false;
3298
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3299
+                $result = true;
3300
+            }
3301
+
3302
+            return $result;
3303
+        }
3304
+
3305
+        /**
3306
+         * Tests if the current output is inside a Oxygen builder preview.
3307
+         *
3308
+         * @return bool
3309
+         *@since 1.0.18
3310
+         */
3311
+        public static function is_oxygen_preview() {
3312
+            $result = false;
3313
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3314
+                $result = true;
3315
+            }
3316
+
3317
+            return $result;
3318
+        }
3319
+
3320
+        /**
3321
+         * Check for Kallyas theme Zion builder preview.
3322
+         *
3323
+         * @since 0.2.27
3324
+         *
3325
+         * @return bool
3326
+         */
3327
+        public static function is_kallyas_zion_preview() {
3328
+            $result = false;
3329
+
3330
+            if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3331
+                $result = true;
3332
+            }
3333
+
3334
+            return $result;
3335
+        }
3336
+
3337
+        /**
3338
+         * Check for Bricks theme builder preview.
3339
+         *
3340
+         * @since 0.2.27
3341
+         *
3342
+         * @return bool
3343
+         */
3344
+        public static function is_bricks_preview() {
3345
+            $result = false;
3346
+
3347
+            if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3348
+                $result = true;
3349
+            }
3350
+
3351
+            return $result;
3352
+        }
3353
+
3354
+        /**
3355
+         * General function to check if we are in a preview situation.
3356
+         *
3357
+         * @since 0.2.27
3358
+         *
3359
+         * @return bool
3360
+         */
3361
+        public static function is_preview() {
3362
+            $preview = false;
3363
+
3364
+            if ( self::is_block_editor() ) {
3365
+                return true;
3366
+            }
3367
+
3368
+            if( self::is_block_content_call() ) {
3369
+                $preview = true;
3370
+            } elseif ( self::is_divi_preview() ) {
3371
+                $preview = true;
3372
+            } elseif ( self::is_elementor_preview() ) {
3373
+                $preview = true;
3374
+            } elseif ( self::is_beaver_preview() ) {
3375
+                $preview = true;
3376
+            } elseif ( self::is_siteorigin_preview() ) {
3377
+                $preview = true;
3378
+            } elseif ( self::is_cornerstone_preview() ) {
3379
+                $preview = true;
3380
+            } elseif ( self::is_fusion_preview() ) {
3381
+                $preview = true;
3382
+            } elseif ( self::is_oxygen_preview() ) {
3383
+                $preview = true;
3384
+            } elseif( self::is_kallyas_zion_preview() ) {
3385
+                $preview = true;
3386
+            } elseif( self::is_bricks_preview() ) {
3387
+                $preview = true;
3388
+            }
3389
+
3390
+            return $preview;
3391
+        }
3392
+    }
3393
+
3394
+    global $ayecode_ui_settings;
3395
+
3396
+    /**
3397
+     * Run the class if found.
3398
+     */
3399
+    $ayecode_ui_settings = AyeCode_UI_Settings::instance();
3400 3400
 }
3401 3401
\ No newline at end of file
Please login to merge, or discard this patch.