Passed
Push — master ( 30e673...96cf3c )
by Brian
06:42 queued 01:20
created
includes/data/eu-states.php 1 patch
Indentation   +27 added lines, -27 removed lines patch added patch discarded remove patch
@@ -9,31 +9,31 @@
 block discarded – undo
9 9
 defined( 'ABSPATH' ) || exit;
10 10
 
11 11
 return array(
12
-	'AT',
13
-	'BE',
14
-	'BG',
15
-	'HR',
16
-	'CY',
17
-	'CZ',
18
-	'DK',
19
-	'EE',
20
-	'FI',
21
-	'FR',
22
-	'DE',
23
-	'GR',
24
-	'HU',
25
-	'IE',
26
-	'IT',
27
-	'LV',
28
-	'LT',
29
-	'LU',
30
-	'MT',
31
-	'NL',
32
-	'PL',
33
-	'PT',
34
-	'RO',
35
-	'SK',
36
-	'SI',
37
-	'ES',
38
-	'SE'
12
+    'AT',
13
+    'BE',
14
+    'BG',
15
+    'HR',
16
+    'CY',
17
+    'CZ',
18
+    'DK',
19
+    'EE',
20
+    'FI',
21
+    'FR',
22
+    'DE',
23
+    'GR',
24
+    'HU',
25
+    'IE',
26
+    'IT',
27
+    'LV',
28
+    'LT',
29
+    'LU',
30
+    'MT',
31
+    'NL',
32
+    'PL',
33
+    'PT',
34
+    'RO',
35
+    'SK',
36
+    'SI',
37
+    'ES',
38
+    'SE'
39 39
 );
Please login to merge, or discard this patch.
includes/user-functions.php 1 patch
Indentation   +15 added lines, -15 removed lines patch added patch discarded remove patch
@@ -34,11 +34,11 @@  discard block
 block discarded – undo
34 34
  */
35 35
 function wpinv_get_capability( $capalibilty = 'manage_invoicing' ) {
36 36
 
37
-	if ( current_user_can( 'manage_options' ) ) {
38
-		return 'manage_options';
39
-	};
37
+    if ( current_user_can( 'manage_options' ) ) {
38
+        return 'manage_options';
39
+    };
40 40
 
41
-	return $capalibilty;
41
+    return $capalibilty;
42 42
 }
43 43
 
44 44
 /**
@@ -62,10 +62,10 @@  discard block
 block discarded – undo
62 62
     // Prepare user values.
63 63
     $prefix = preg_replace( '/\s+/', '', $prefix );
64 64
     $prefix = empty( $prefix ) ? $email : $prefix;
65
-	$args   = array(
66
-		'user_login' => wpinv_generate_user_name( $prefix ),
67
-		'user_pass'  => wp_generate_password(),
68
-		'user_email' => $email,
65
+    $args   = array(
66
+        'user_login' => wpinv_generate_user_name( $prefix ),
67
+        'user_pass'  => wp_generate_password(),
68
+        'user_email' => $email,
69 69
         'role'       => 'subscriber',
70 70
     );
71 71
 
@@ -82,16 +82,16 @@  discard block
 block discarded – undo
82 82
 function wpinv_generate_user_name( $prefix = '' ) {
83 83
 
84 84
     // If prefix is an email, retrieve the part before the email.
85
-	$prefix = strtok( $prefix, '@' );
85
+    $prefix = strtok( $prefix, '@' );
86 86
     $prefix = trim( $prefix, '.' );
87 87
 
88
-	// Sanitize the username.
89
-	$prefix = sanitize_user( $prefix, true );
88
+    // Sanitize the username.
89
+    $prefix = sanitize_user( $prefix, true );
90 90
 
91
-	$illegal_logins = (array) apply_filters( 'illegal_user_logins', array() );
92
-	if ( empty( $prefix ) || in_array( strtolower( $prefix ), array_map( 'strtolower', $illegal_logins ), true ) ) {
93
-		$prefix = 'gtp_' . zeroise( wp_rand( 0, 9999 ), 4 );
94
-	}
91
+    $illegal_logins = (array) apply_filters( 'illegal_user_logins', array() );
92
+    if ( empty( $prefix ) || in_array( strtolower( $prefix ), array_map( 'strtolower', $illegal_logins ), true ) ) {
93
+        $prefix = 'gtp_' . zeroise( wp_rand( 0, 9999 ), 4 );
94
+    }
95 95
 
96 96
     $username = $prefix;
97 97
     $postfix  = 2;
Please login to merge, or discard this patch.
includes/payments/class-getpaid-payment-form-submission.php 1 patch
Indentation   +777 added lines, -777 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 /**
@@ -10,187 +10,187 @@  discard block
 block discarded – undo
10 10
 class GetPaid_Payment_Form_Submission {
11 11
 
12 12
     /**
13
-	 * Submission ID
14
-	 *
15
-	 * @var string
16
-	 */
17
-	public $id = null;
18
-
19
-	/**
20
-	 * The raw submission data.
21
-	 *
22
-	 * @var array
23
-	 */
24
-	protected $data = null;
25
-
26
-	/**
27
-	 * Submission totals
28
-	 *
29
-	 * @var array
30
-	 */
31
-	protected $totals = array(
32
-
33
-		'subtotal'      => array(
34
-			'initial'   => 0,
35
-			'recurring' => 0,
36
-		),
37
-
38
-		'discount'      => array(
39
-			'initial'   => 0,
40
-			'recurring' => 0,
41
-		),
42
-
43
-		'fees'          => array(
44
-			'initial'   => 0,
45
-			'recurring' => 0,
46
-		),
47
-
48
-		'taxes'         => array(
49
-			'initial'   => 0,
50
-			'recurring' => 0,
51
-		),
52
-
53
-	);
54
-
55
-	/**
56
-	 * Sets the associated payment form.
57
-	 *
58
-	 * @var GetPaid_Payment_Form
59
-	 */
13
+     * Submission ID
14
+     *
15
+     * @var string
16
+     */
17
+    public $id = null;
18
+
19
+    /**
20
+     * The raw submission data.
21
+     *
22
+     * @var array
23
+     */
24
+    protected $data = null;
25
+
26
+    /**
27
+     * Submission totals
28
+     *
29
+     * @var array
30
+     */
31
+    protected $totals = array(
32
+
33
+        'subtotal'      => array(
34
+            'initial'   => 0,
35
+            'recurring' => 0,
36
+        ),
37
+
38
+        'discount'      => array(
39
+            'initial'   => 0,
40
+            'recurring' => 0,
41
+        ),
42
+
43
+        'fees'          => array(
44
+            'initial'   => 0,
45
+            'recurring' => 0,
46
+        ),
47
+
48
+        'taxes'         => array(
49
+            'initial'   => 0,
50
+            'recurring' => 0,
51
+        ),
52
+
53
+    );
54
+
55
+    /**
56
+     * Sets the associated payment form.
57
+     *
58
+     * @var GetPaid_Payment_Form
59
+     */
60 60
     protected $payment_form = null;
61 61
 
62 62
     /**
63
-	 * The country for the submission.
64
-	 *
65
-	 * @var string
66
-	 */
67
-	public $country = null;
68
-
69
-    /**
70
-	 * The state for the submission.
71
-	 *
72
-	 * @since 1.0.19
73
-	 * @var string
74
-	 */
75
-	public $state = null;
76
-
77
-	/**
78
-	 * The invoice associated with the submission.
79
-	 *
80
-	 * @var WPInv_Invoice
81
-	 */
82
-	protected $invoice = null;
83
-
84
-	/**
85
-	 * The recurring item for the submission.
86
-	 *
87
-	 * @var int
88
-	 */
89
-	public $has_recurring = 0;
90
-
91
-	/**
92
-	 * An array of fees for the submission.
93
-	 *
94
-	 * @var array
95
-	 */
96
-	protected $fees = array();
97
-
98
-	/**
99
-	 * An array of discounts for the submission.
100
-	 *
101
-	 * @var array
102
-	 */
103
-	protected $discounts = array();
104
-
105
-	/**
106
-	 * An array of taxes for the submission.
107
-	 *
108
-	 * @var array
109
-	 */
110
-	protected $taxes = array();
111
-
112
-	/**
113
-	 * An array of items for the submission.
114
-	 *
115
-	 * @var GetPaid_Form_Item[]
116
-	 */
117
-	protected $items = array();
118
-
119
-	/**
120
-	 * The last error.
121
-	 *
122
-	 * @var string
123
-	 */
124
-	public $last_error = null;
125
-
126
-    /**
127
-	 * Class constructor.
128
-	 *
129
-	 */
130
-	public function __construct() {
131
-
132
-		// Set the state and country to the default state and country.
133
-		$this->country = wpinv_default_billing_country();
134
-		$this->state   = wpinv_get_default_state();
135
-
136
-		// Do we have an actual submission?
137
-		if ( isset( $_POST['getpaid_payment_form_submission'] ) ) {
138
-			$this->load_data( $_POST );
139
-		}
140
-
141
-	}
142
-
143
-	/**
144
-	 * Loads submission data.
145
-	 *
146
-	 * @param array $data
147
-	 */
148
-	public function load_data( $data ) {
149
-
150
-		// Remove slashes from the submitted data...
151
-		$data       = wp_unslash( $data );
152
-
153
-		// Allow plugins to filter the data.
154
-		$data       = apply_filters( 'getpaid_submission_data', $data, $this );
155
-
156
-		// Cache it...
157
-		$this->data = $data;
158
-
159
-		// Then generate a unique id from the data.
160
-		$this->id   = md5( wp_json_encode( $data ) );
161
-
162
-		// Finally, process the submission.
163
-		try {
164
-
165
-			// Each process is passed an instance of the class (with reference)
166
-			// and should throw an Exception whenever it encounters one.
167
-			$processors = apply_filters(
168
-				'getpaid_payment_form_submission_processors',
169
-				array(
170
-					array( $this, 'process_payment_form' ),
171
-					array( $this, 'process_invoice' ),
172
-					array( $this, 'process_fees' ),
173
-					array( $this, 'process_items' ),
174
-					array( $this, 'process_discount' ),
175
-					array( $this, 'process_taxes' ),
176
-				),
177
-				$this		
178
-			);
179
-
180
-			foreach ( $processors as $processor ) {
181
-				call_user_func_array( $processor, array( &$this ) );
182
-			}
183
-
184
-		} catch ( Exception $e ) {
185
-			$this->last_error = $e->getMessage();
186
-		}
187
-
188
-		// Fired when we are done processing a submission.
189
-		do_action_ref_array( 'getpaid_process_submission', array( &$this ) );
190
-
191
-	}
192
-
193
-	/*
63
+     * The country for the submission.
64
+     *
65
+     * @var string
66
+     */
67
+    public $country = null;
68
+
69
+    /**
70
+     * The state for the submission.
71
+     *
72
+     * @since 1.0.19
73
+     * @var string
74
+     */
75
+    public $state = null;
76
+
77
+    /**
78
+     * The invoice associated with the submission.
79
+     *
80
+     * @var WPInv_Invoice
81
+     */
82
+    protected $invoice = null;
83
+
84
+    /**
85
+     * The recurring item for the submission.
86
+     *
87
+     * @var int
88
+     */
89
+    public $has_recurring = 0;
90
+
91
+    /**
92
+     * An array of fees for the submission.
93
+     *
94
+     * @var array
95
+     */
96
+    protected $fees = array();
97
+
98
+    /**
99
+     * An array of discounts for the submission.
100
+     *
101
+     * @var array
102
+     */
103
+    protected $discounts = array();
104
+
105
+    /**
106
+     * An array of taxes for the submission.
107
+     *
108
+     * @var array
109
+     */
110
+    protected $taxes = array();
111
+
112
+    /**
113
+     * An array of items for the submission.
114
+     *
115
+     * @var GetPaid_Form_Item[]
116
+     */
117
+    protected $items = array();
118
+
119
+    /**
120
+     * The last error.
121
+     *
122
+     * @var string
123
+     */
124
+    public $last_error = null;
125
+
126
+    /**
127
+     * Class constructor.
128
+     *
129
+     */
130
+    public function __construct() {
131
+
132
+        // Set the state and country to the default state and country.
133
+        $this->country = wpinv_default_billing_country();
134
+        $this->state   = wpinv_get_default_state();
135
+
136
+        // Do we have an actual submission?
137
+        if ( isset( $_POST['getpaid_payment_form_submission'] ) ) {
138
+            $this->load_data( $_POST );
139
+        }
140
+
141
+    }
142
+
143
+    /**
144
+     * Loads submission data.
145
+     *
146
+     * @param array $data
147
+     */
148
+    public function load_data( $data ) {
149
+
150
+        // Remove slashes from the submitted data...
151
+        $data       = wp_unslash( $data );
152
+
153
+        // Allow plugins to filter the data.
154
+        $data       = apply_filters( 'getpaid_submission_data', $data, $this );
155
+
156
+        // Cache it...
157
+        $this->data = $data;
158
+
159
+        // Then generate a unique id from the data.
160
+        $this->id   = md5( wp_json_encode( $data ) );
161
+
162
+        // Finally, process the submission.
163
+        try {
164
+
165
+            // Each process is passed an instance of the class (with reference)
166
+            // and should throw an Exception whenever it encounters one.
167
+            $processors = apply_filters(
168
+                'getpaid_payment_form_submission_processors',
169
+                array(
170
+                    array( $this, 'process_payment_form' ),
171
+                    array( $this, 'process_invoice' ),
172
+                    array( $this, 'process_fees' ),
173
+                    array( $this, 'process_items' ),
174
+                    array( $this, 'process_discount' ),
175
+                    array( $this, 'process_taxes' ),
176
+                ),
177
+                $this		
178
+            );
179
+
180
+            foreach ( $processors as $processor ) {
181
+                call_user_func_array( $processor, array( &$this ) );
182
+            }
183
+
184
+        } catch ( Exception $e ) {
185
+            $this->last_error = $e->getMessage();
186
+        }
187
+
188
+        // Fired when we are done processing a submission.
189
+        do_action_ref_array( 'getpaid_process_submission', array( &$this ) );
190
+
191
+    }
192
+
193
+    /*
194 194
 	|--------------------------------------------------------------------------
195 195
 	| Payment Forms.
196 196
 	|--------------------------------------------------------------------------
@@ -199,39 +199,39 @@  discard block
 block discarded – undo
199 199
 	| submission has an active payment form etc.
200 200
     */
201 201
 
202
-	/**
203
-	 * Prepares the submission's payment form.
204
-	 *
205
-	 * @since 1.0.19
206
-	 */
207
-	public function process_payment_form() {
202
+    /**
203
+     * Prepares the submission's payment form.
204
+     *
205
+     * @since 1.0.19
206
+     */
207
+    public function process_payment_form() {
208 208
 
209
-		// Every submission needs an active payment form.
210
-		if ( empty( $this->data['form_id'] ) ) {
211
-			throw new Exception( __( 'Missing payment form', 'invoicing' ) );
212
-		}
209
+        // Every submission needs an active payment form.
210
+        if ( empty( $this->data['form_id'] ) ) {
211
+            throw new Exception( __( 'Missing payment form', 'invoicing' ) );
212
+        }
213 213
 
214
-		// Fetch the payment form.
215
-		$this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] );
214
+        // Fetch the payment form.
215
+        $this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] );
216 216
 
217
-		if ( ! $this->payment_form->is_active() ) {
218
-			throw new Exception( __( 'Payment form not active', 'invoicing' ) );
219
-		}
217
+        if ( ! $this->payment_form->is_active() ) {
218
+            throw new Exception( __( 'Payment form not active', 'invoicing' ) );
219
+        }
220 220
 
221
-		do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) );
222
-	}
221
+        do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) );
222
+    }
223 223
 
224 224
     /**
225
-	 * Returns the payment form.
226
-	 *
227
-	 * @since 1.0.19
228
-	 * @return GetPaid_Payment_Form
229
-	 */
230
-	public function get_payment_form() {
231
-		return $this->payment_form;
232
-	}
225
+     * Returns the payment form.
226
+     *
227
+     * @since 1.0.19
228
+     * @return GetPaid_Payment_Form
229
+     */
230
+    public function get_payment_form() {
231
+        return $this->payment_form;
232
+    }
233 233
 
234
-	/*
234
+    /*
235 235
 	|--------------------------------------------------------------------------
236 236
 	| Invoices.
237 237
 	|--------------------------------------------------------------------------
@@ -240,61 +240,61 @@  discard block
 block discarded – undo
240 240
 	| might be for an existing invoice.
241 241
 	*/
242 242
 
243
-	/**
244
-	 * Prepares the submission's invoice.
245
-	 *
246
-	 * @since 1.0.19
247
-	 */
248
-	public function process_invoice() {
243
+    /**
244
+     * Prepares the submission's invoice.
245
+     *
246
+     * @since 1.0.19
247
+     */
248
+    public function process_invoice() {
249 249
 
250
-		// Abort if there is no invoice.
251
-		if ( empty( $this->data['invoice_id'] ) ) {
252
-			return;
253
-		}
250
+        // Abort if there is no invoice.
251
+        if ( empty( $this->data['invoice_id'] ) ) {
252
+            return;
253
+        }
254 254
 
255
-		// If the submission is for an existing invoice, ensure that it exists
256
-		// and that it is not paid for.
257
-		$invoice = wpinv_get_invoice( $this->data['invoice_id'] );
255
+        // If the submission is for an existing invoice, ensure that it exists
256
+        // and that it is not paid for.
257
+        $invoice = wpinv_get_invoice( $this->data['invoice_id'] );
258 258
 
259 259
         if ( empty( $invoice ) ) {
260
-			throw new Exception( __( 'Invalid invoice', 'invoicing' ) );
261
-		}
262
-
263
-		if ( $invoice->is_paid() ) {
264
-			throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) );
265
-		}
266
-
267
-		$this->payment_form->set_items( $invoice->get_items() );
268
-		$this->payment_form->invoice = $invoice;
269
-
270
-		$this->country = $invoice->get_country();
271
-		$this->state   = $invoice->get_state();
272
-		$this->invoice = $invoice;
273
-
274
-		do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) );
275
-	}
276
-
277
-	/**
278
-	 * Returns the associated invoice.
279
-	 *
280
-	 * @since 1.0.19
281
-	 * @return WPInv_Invoice
282
-	 */
283
-	public function get_invoice() {
284
-		return $this->invoice;
285
-	}
286
-
287
-	/**
288
-	 * Checks whether there is an invoice associated with this submission.
289
-	 *
290
-	 * @since 1.0.19
291
-	 * @return bool
292
-	 */
293
-	public function has_invoice() {
294
-		return ! empty( $this->invoice );
295
-	}
296
-
297
-	/*
260
+            throw new Exception( __( 'Invalid invoice', 'invoicing' ) );
261
+        }
262
+
263
+        if ( $invoice->is_paid() ) {
264
+            throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) );
265
+        }
266
+
267
+        $this->payment_form->set_items( $invoice->get_items() );
268
+        $this->payment_form->invoice = $invoice;
269
+
270
+        $this->country = $invoice->get_country();
271
+        $this->state   = $invoice->get_state();
272
+        $this->invoice = $invoice;
273
+
274
+        do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) );
275
+    }
276
+
277
+    /**
278
+     * Returns the associated invoice.
279
+     *
280
+     * @since 1.0.19
281
+     * @return WPInv_Invoice
282
+     */
283
+    public function get_invoice() {
284
+        return $this->invoice;
285
+    }
286
+
287
+    /**
288
+     * Checks whether there is an invoice associated with this submission.
289
+     *
290
+     * @since 1.0.19
291
+     * @return bool
292
+     */
293
+    public function has_invoice() {
294
+        return ! empty( $this->invoice );
295
+    }
296
+
297
+    /*
298 298
 	|--------------------------------------------------------------------------
299 299
 	| Items.
300 300
 	|--------------------------------------------------------------------------
@@ -303,115 +303,115 @@  discard block
 block discarded – undo
303 303
 	| recurring item. But can have an unlimited number of non-recurring items.
304 304
 	*/
305 305
 
306
-	/**
307
-	 * Prepares the submission's items.
308
-	 *
309
-	 * @since 1.0.19
310
-	 */
311
-	public function process_items() {
312
-
313
-		$processor = new GetPaid_Payment_Form_Submission_Items( $this );
314
-
315
-		foreach ( $processor->items as $item ) {
316
-			$this->add_item( $item );
317
-		}
318
-
319
-		do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) );
320
-	}
321
-
322
-	/**
323
-	 * Adds an item to the submission.
324
-	 *
325
-	 * @since 1.0.19
326
-	 * @param GetPaid_Form_Item $item
327
-	 */
328
-	public function add_item( $item ) {
329
-
330
-		// Make sure that it is available for purchase.
331
-		if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) {
332
-			return;
333
-		}
334
-
335
-		// Each submission can only contain one recurring item.
336
-		if ( $item->is_recurring() ) {
337
-
338
-			if ( $this->has_recurring != 0 ) {
339
-				throw new Exception( __( 'You can only buy one recurring item at a time.', 'invoicing' ) );
340
-			}
341
-
342
-			$this->has_recurring = $item->get_id();
343
-
344
-		}
345
-
346
-		// Update the items and totals.
347
-		$this->items[ $item->get_id() ]         = $item;
348
-		$this->totals['subtotal']['initial']   += $item->get_sub_total();
349
-		$this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total();
350
-
351
-	}
352
-
353
-	/**
354
-	 * Removes a specific item.
355
-	 * 
356
-	 * You should not call this method after the discounts and taxes
357
-	 * have been calculated.
358
-	 *
359
-	 * @since 1.0.19
360
-	 */
361
-	public function remove_item( $item_id ) {
362
-
363
-		if ( isset( $this->items[ $item_id ] ) ) {
364
-			$this->totals['subtotal']['initial']   -= $this->items[ $item_id ]->get_sub_total();
365
-			$this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total();
366
-
367
-			if ( $this->items[ $item_id ]->is_recurring() ) {
368
-				$this->has_recurring = 0;
369
-			}
370
-
371
-			unset( $this->items[ $item_id ] );
372
-		}
373
-
374
-	}
375
-
376
-	/**
377
-	 * Returns the subtotal.
378
-	 *
379
-	 * @since 1.0.19
380
-	 */
381
-	public function get_subtotal() {
382
-
383
-		if ( wpinv_prices_include_tax() ) {
384
-			return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial'];
385
-		}
386
-
387
-		return $this->totals['subtotal']['initial'];
388
-	}
389
-
390
-	/**
391
-	 * Returns the recurring subtotal.
392
-	 *
393
-	 * @since 1.0.19
394
-	 */
395
-	public function get_recurring_subtotal() {
396
-
397
-		if ( wpinv_prices_include_tax() ) {
398
-			return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring'];
399
-		}
400
-
401
-		return $this->totals['subtotal']['recurring'];
402
-	}
403
-
404
-	/**
405
-	 * Returns all items.
406
-	 *
407
-	 * @since 1.0.19
408
-	 * @return GetPaid_Form_Item[]
409
-	 */
410
-	public function get_items() {
411
-		return $this->items;
412
-	}
413
-
414
-	/*
306
+    /**
307
+     * Prepares the submission's items.
308
+     *
309
+     * @since 1.0.19
310
+     */
311
+    public function process_items() {
312
+
313
+        $processor = new GetPaid_Payment_Form_Submission_Items( $this );
314
+
315
+        foreach ( $processor->items as $item ) {
316
+            $this->add_item( $item );
317
+        }
318
+
319
+        do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) );
320
+    }
321
+
322
+    /**
323
+     * Adds an item to the submission.
324
+     *
325
+     * @since 1.0.19
326
+     * @param GetPaid_Form_Item $item
327
+     */
328
+    public function add_item( $item ) {
329
+
330
+        // Make sure that it is available for purchase.
331
+        if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) {
332
+            return;
333
+        }
334
+
335
+        // Each submission can only contain one recurring item.
336
+        if ( $item->is_recurring() ) {
337
+
338
+            if ( $this->has_recurring != 0 ) {
339
+                throw new Exception( __( 'You can only buy one recurring item at a time.', 'invoicing' ) );
340
+            }
341
+
342
+            $this->has_recurring = $item->get_id();
343
+
344
+        }
345
+
346
+        // Update the items and totals.
347
+        $this->items[ $item->get_id() ]         = $item;
348
+        $this->totals['subtotal']['initial']   += $item->get_sub_total();
349
+        $this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total();
350
+
351
+    }
352
+
353
+    /**
354
+     * Removes a specific item.
355
+     * 
356
+     * You should not call this method after the discounts and taxes
357
+     * have been calculated.
358
+     *
359
+     * @since 1.0.19
360
+     */
361
+    public function remove_item( $item_id ) {
362
+
363
+        if ( isset( $this->items[ $item_id ] ) ) {
364
+            $this->totals['subtotal']['initial']   -= $this->items[ $item_id ]->get_sub_total();
365
+            $this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total();
366
+
367
+            if ( $this->items[ $item_id ]->is_recurring() ) {
368
+                $this->has_recurring = 0;
369
+            }
370
+
371
+            unset( $this->items[ $item_id ] );
372
+        }
373
+
374
+    }
375
+
376
+    /**
377
+     * Returns the subtotal.
378
+     *
379
+     * @since 1.0.19
380
+     */
381
+    public function get_subtotal() {
382
+
383
+        if ( wpinv_prices_include_tax() ) {
384
+            return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial'];
385
+        }
386
+
387
+        return $this->totals['subtotal']['initial'];
388
+    }
389
+
390
+    /**
391
+     * Returns the recurring subtotal.
392
+     *
393
+     * @since 1.0.19
394
+     */
395
+    public function get_recurring_subtotal() {
396
+
397
+        if ( wpinv_prices_include_tax() ) {
398
+            return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring'];
399
+        }
400
+
401
+        return $this->totals['subtotal']['recurring'];
402
+    }
403
+
404
+    /**
405
+     * Returns all items.
406
+     *
407
+     * @since 1.0.19
408
+     * @return GetPaid_Form_Item[]
409
+     */
410
+    public function get_items() {
411
+        return $this->items;
412
+    }
413
+
414
+    /*
415 415
 	|--------------------------------------------------------------------------
416 416
 	| Taxes
417 417
 	|--------------------------------------------------------------------------
@@ -420,128 +420,128 @@  discard block
 block discarded – undo
420 420
 	| or only one-time.
421 421
     */
422 422
 
423
-	/**
424
-	 * Prepares the submission's taxes.
425
-	 *
426
-	 * @since 1.0.19
427
-	 */
428
-	public function process_taxes() {
429
-
430
-		// Abort if we're not using taxes.
431
-		if ( ! $this->use_taxes() ) {
432
-			return;
433
-		}
434
-
435
-		// If a custom country && state has been passed in, use it to calculate taxes.
436
-		$country = $this->get_field( 'wpinv_country', 'billing' );
437
-		if ( ! empty( $country ) ) {
438
-			$this->country = $country;
439
-		}
440
-
441
-		$state = $this->get_field( 'wpinv_state', 'billing' );
442
-		if ( ! empty( $state ) ) {
443
-			$this->state = $state;
444
-		}
445
-
446
-		// Confirm if the provided country and the ip country are similar.
447
-		$address_confirmed = $this->get_field( 'confirm-address' );
448
-		if ( wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) {
449
-			throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) );
450
-		}
451
-
452
-		// Abort if the country is not taxable.
453
-		if ( ! wpinv_is_country_taxable( $this->country ) ) {
454
-			return;
455
-		}
456
-
457
-		$processor = new GetPaid_Payment_Form_Submission_Taxes( $this );
458
-
459
-		foreach ( $processor->taxes as $tax ) {
460
-			$this->add_tax( $tax );
461
-		}
462
-
463
-		do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) );
464
-	}
465
-
466
-	/**
467
-	 * Adds a tax to the submission.
468
-	 *
469
-	 * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required.
470
-	 * @since 1.0.19
471
-	 */
472
-	public function add_tax( $tax ) {
473
-
474
-		if ( wpinv_round_tax_per_tax_rate() ) {
475
-			$tax['initial_tax']   = wpinv_round_amount( $tax['initial_tax'] );
476
-			$tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] );
477
-		}
478
-
479
-		$this->taxes[ $tax['name'] ]         = $tax;
480
-		$this->totals['taxes']['initial']   += wpinv_sanitize_amount( $tax['initial_tax'] );
481
-		$this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] );
482
-
483
-	}
484
-
485
-	/**
486
-	 * Removes a specific tax.
487
-	 *
488
-	 * @since 1.0.19
489
-	 */
490
-	public function remove_tax( $tax_name ) {
491
-
492
-		if ( isset( $this->taxes[ $tax_name ] ) ) {
493
-			$this->totals['taxes']['initial']   -= $this->taxes[ $tax_name ]['initial_tax'];
494
-			$this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax'];
495
-			unset( $this->taxes[ $tax_name ] );
496
-		}
497
-
498
-	}
499
-
500
-	/**
501
-	 * Whether or not we'll use taxes for the submission.
502
-	 *
503
-	 * @since 1.0.19
504
-	 */
505
-	public function use_taxes() {
506
-
507
-		$use_taxes = wpinv_use_taxes();
508
-
509
-		if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) {
510
-			$use_taxes = false;
511
-		}
512
-
513
-		return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this );
514
-
515
-	}
516
-
517
-	/**
518
-	 * Returns the tax.
519
-	 *
520
-	 * @since 1.0.19
521
-	 */
522
-	public function get_tax() {
523
-		return $this->totals['taxes']['initial'];
524
-	}
525
-
526
-	/**
527
-	 * Returns the recurring tax.
528
-	 *
529
-	 * @since 1.0.19
530
-	 */
531
-	public function get_recurring_tax() {
532
-		return $this->totals['taxes']['recurring'];
533
-	}
534
-
535
-	/**
536
-	 * Returns all taxes.
537
-	 *
538
-	 * @since 1.0.19
539
-	 */
540
-	public function get_taxes() {
541
-		return $this->taxes;
542
-	}
543
-
544
-	/*
423
+    /**
424
+     * Prepares the submission's taxes.
425
+     *
426
+     * @since 1.0.19
427
+     */
428
+    public function process_taxes() {
429
+
430
+        // Abort if we're not using taxes.
431
+        if ( ! $this->use_taxes() ) {
432
+            return;
433
+        }
434
+
435
+        // If a custom country && state has been passed in, use it to calculate taxes.
436
+        $country = $this->get_field( 'wpinv_country', 'billing' );
437
+        if ( ! empty( $country ) ) {
438
+            $this->country = $country;
439
+        }
440
+
441
+        $state = $this->get_field( 'wpinv_state', 'billing' );
442
+        if ( ! empty( $state ) ) {
443
+            $this->state = $state;
444
+        }
445
+
446
+        // Confirm if the provided country and the ip country are similar.
447
+        $address_confirmed = $this->get_field( 'confirm-address' );
448
+        if ( wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) {
449
+            throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) );
450
+        }
451
+
452
+        // Abort if the country is not taxable.
453
+        if ( ! wpinv_is_country_taxable( $this->country ) ) {
454
+            return;
455
+        }
456
+
457
+        $processor = new GetPaid_Payment_Form_Submission_Taxes( $this );
458
+
459
+        foreach ( $processor->taxes as $tax ) {
460
+            $this->add_tax( $tax );
461
+        }
462
+
463
+        do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) );
464
+    }
465
+
466
+    /**
467
+     * Adds a tax to the submission.
468
+     *
469
+     * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required.
470
+     * @since 1.0.19
471
+     */
472
+    public function add_tax( $tax ) {
473
+
474
+        if ( wpinv_round_tax_per_tax_rate() ) {
475
+            $tax['initial_tax']   = wpinv_round_amount( $tax['initial_tax'] );
476
+            $tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] );
477
+        }
478
+
479
+        $this->taxes[ $tax['name'] ]         = $tax;
480
+        $this->totals['taxes']['initial']   += wpinv_sanitize_amount( $tax['initial_tax'] );
481
+        $this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] );
482
+
483
+    }
484
+
485
+    /**
486
+     * Removes a specific tax.
487
+     *
488
+     * @since 1.0.19
489
+     */
490
+    public function remove_tax( $tax_name ) {
491
+
492
+        if ( isset( $this->taxes[ $tax_name ] ) ) {
493
+            $this->totals['taxes']['initial']   -= $this->taxes[ $tax_name ]['initial_tax'];
494
+            $this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax'];
495
+            unset( $this->taxes[ $tax_name ] );
496
+        }
497
+
498
+    }
499
+
500
+    /**
501
+     * Whether or not we'll use taxes for the submission.
502
+     *
503
+     * @since 1.0.19
504
+     */
505
+    public function use_taxes() {
506
+
507
+        $use_taxes = wpinv_use_taxes();
508
+
509
+        if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) {
510
+            $use_taxes = false;
511
+        }
512
+
513
+        return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this );
514
+
515
+    }
516
+
517
+    /**
518
+     * Returns the tax.
519
+     *
520
+     * @since 1.0.19
521
+     */
522
+    public function get_tax() {
523
+        return $this->totals['taxes']['initial'];
524
+    }
525
+
526
+    /**
527
+     * Returns the recurring tax.
528
+     *
529
+     * @since 1.0.19
530
+     */
531
+    public function get_recurring_tax() {
532
+        return $this->totals['taxes']['recurring'];
533
+    }
534
+
535
+    /**
536
+     * Returns all taxes.
537
+     *
538
+     * @since 1.0.19
539
+     */
540
+    public function get_taxes() {
541
+        return $this->taxes;
542
+    }
543
+
544
+    /*
545 545
 	|--------------------------------------------------------------------------
546 546
 	| Discounts
547 547
 	|--------------------------------------------------------------------------
@@ -550,99 +550,99 @@  discard block
 block discarded – undo
550 550
 	| or only one-time. They also do not have to come from a discount code.
551 551
     */
552 552
 
553
-	/**
554
-	 * Prepares the submission's discount.
555
-	 *
556
-	 * @since 1.0.19
557
-	 */
558
-	public function process_discount() {
559
-
560
-		$initial_total    = $this->get_subtotal() + $this->get_fee() + $this->get_tax();
561
-		$recurring_total  = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax();
562
-		$processor        = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total );
563
-
564
-		foreach ( $processor->discounts as $discount ) {
565
-			$this->add_discount( $discount );
566
-		}
567
-
568
-		do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) );
569
-	}
570
-
571
-	/**
572
-	 * Adds a discount to the submission.
573
-	 *
574
-	 * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code.
575
-	 * @since 1.0.19
576
-	 */
577
-	public function add_discount( $discount ) {
578
-		$this->discounts[ $discount['name'] ]   = $discount;
579
-		$this->totals['discount']['initial']   += wpinv_sanitize_amount( $discount['initial_discount'] );
580
-		$this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] );
581
-	}
582
-
583
-	/**
584
-	 * Removes a discount from the submission.
585
-	 *
586
-	 * @since 1.0.19
587
-	 */
588
-	public function remove_discount( $name ) {
589
-
590
-		if ( isset( $this->discounts[ $name ] ) ) {
591
-			$this->totals['discount']['initial']   -= $this->discounts[ $name ]['initial_discount'];
592
-			$this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount'];
593
-			unset( $this->discounts[ $name ] );
594
-		}
595
-
596
-	}
597
-
598
-	/**
599
-	 * Checks whether there is a discount code associated with this submission.
600
-	 *
601
-	 * @since 1.0.19
602
-	 * @return bool
603
-	 */
604
-	public function has_discount_code() {
605
-		return ! empty( $this->discounts['discount_code'] );
606
-	}
607
-
608
-	/**
609
-	 * Returns the discount code.
610
-	 *
611
-	 * @since 1.0.19
612
-	 * @return string
613
-	 */
614
-	public function get_discount_code() {
615
-		return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : '';
616
-	}
617
-
618
-	/**
619
-	 * Returns the discount.
620
-	 *
621
-	 * @since 1.0.19
622
-	 */
623
-	public function get_discount() {
624
-		return $this->totals['discount']['initial'];
625
-	}
626
-
627
-	/**
628
-	 * Returns the recurring discount.
629
-	 *
630
-	 * @since 1.0.19
631
-	 */
632
-	public function get_recurring_discount() {
633
-		return $this->totals['discount']['recurring'];
634
-	}
635
-
636
-	/**
637
-	 * Returns all discounts.
638
-	 *
639
-	 * @since 1.0.19
640
-	 */
641
-	public function get_discounts() {
642
-		return $this->discounts;
643
-	}
644
-
645
-	/*
553
+    /**
554
+     * Prepares the submission's discount.
555
+     *
556
+     * @since 1.0.19
557
+     */
558
+    public function process_discount() {
559
+
560
+        $initial_total    = $this->get_subtotal() + $this->get_fee() + $this->get_tax();
561
+        $recurring_total  = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax();
562
+        $processor        = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total );
563
+
564
+        foreach ( $processor->discounts as $discount ) {
565
+            $this->add_discount( $discount );
566
+        }
567
+
568
+        do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) );
569
+    }
570
+
571
+    /**
572
+     * Adds a discount to the submission.
573
+     *
574
+     * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code.
575
+     * @since 1.0.19
576
+     */
577
+    public function add_discount( $discount ) {
578
+        $this->discounts[ $discount['name'] ]   = $discount;
579
+        $this->totals['discount']['initial']   += wpinv_sanitize_amount( $discount['initial_discount'] );
580
+        $this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] );
581
+    }
582
+
583
+    /**
584
+     * Removes a discount from the submission.
585
+     *
586
+     * @since 1.0.19
587
+     */
588
+    public function remove_discount( $name ) {
589
+
590
+        if ( isset( $this->discounts[ $name ] ) ) {
591
+            $this->totals['discount']['initial']   -= $this->discounts[ $name ]['initial_discount'];
592
+            $this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount'];
593
+            unset( $this->discounts[ $name ] );
594
+        }
595
+
596
+    }
597
+
598
+    /**
599
+     * Checks whether there is a discount code associated with this submission.
600
+     *
601
+     * @since 1.0.19
602
+     * @return bool
603
+     */
604
+    public function has_discount_code() {
605
+        return ! empty( $this->discounts['discount_code'] );
606
+    }
607
+
608
+    /**
609
+     * Returns the discount code.
610
+     *
611
+     * @since 1.0.19
612
+     * @return string
613
+     */
614
+    public function get_discount_code() {
615
+        return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : '';
616
+    }
617
+
618
+    /**
619
+     * Returns the discount.
620
+     *
621
+     * @since 1.0.19
622
+     */
623
+    public function get_discount() {
624
+        return $this->totals['discount']['initial'];
625
+    }
626
+
627
+    /**
628
+     * Returns the recurring discount.
629
+     *
630
+     * @since 1.0.19
631
+     */
632
+    public function get_recurring_discount() {
633
+        return $this->totals['discount']['recurring'];
634
+    }
635
+
636
+    /**
637
+     * Returns all discounts.
638
+     *
639
+     * @since 1.0.19
640
+     */
641
+    public function get_discounts() {
642
+        return $this->discounts;
643
+    }
644
+
645
+    /*
646 646
 	|--------------------------------------------------------------------------
647 647
 	| Fees
648 648
 	|--------------------------------------------------------------------------
@@ -652,89 +652,89 @@  discard block
 block discarded – undo
652 652
 	| fees.
653 653
     */
654 654
 
655
-	/**
656
-	 * Prepares the submission's fees.
657
-	 *
658
-	 * @since 1.0.19
659
-	 */
660
-	public function process_fees() {
661
-
662
-		$fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this );
663
-
664
-		foreach ( $fees_processor->fees as $fee ) {
665
-			$this->add_fee( $fee );
666
-		}
667
-
668
-		do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) );
669
-	}
670
-
671
-	/**
672
-	 * Adds a fee to the submission.
673
-	 *
674
-	 * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required.
675
-	 * @since 1.0.19
676
-	 */
677
-	public function add_fee( $fee ) {
678
-
679
-		$this->fees[ $fee['name'] ]         = $fee;
680
-		$this->totals['fees']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
681
-		$this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
682
-
683
-	}
684
-
685
-	/**
686
-	 * Removes a fee from the submission.
687
-	 *
688
-	 * @since 1.0.19
689
-	 */
690
-	public function remove_fee( $name ) {
691
-
692
-		if ( isset( $this->fees[ $name ] ) ) {
693
-			$this->totals['fees']['initial']   -= $this->fees[ $name ]['initial_fee'];
694
-			$this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee'];
695
-			unset( $this->fees[ $name ] );
696
-		}
697
-
698
-	}
699
-
700
-	/**
701
-	 * Returns the fees.
702
-	 *
703
-	 * @since 1.0.19
704
-	 */
705
-	public function get_fee() {
706
-		return $this->totals['fees']['initial'];
707
-	}
708
-
709
-	/**
710
-	 * Returns the recurring fees.
711
-	 *
712
-	 * @since 1.0.19
713
-	 */
714
-	public function get_recurring_fee() {
715
-		return $this->totals['fees']['recurring'];
716
-	}
717
-
718
-	/**
719
-	 * Returns all fees.
720
-	 *
721
-	 * @since 1.0.19
722
-	 */
723
-	public function get_fees() {
724
-		return $this->fees;
725
-	}
726
-
727
-	/**
728
-	 * Checks if there are any fees for the form.
729
-	 *
730
-	 * @return bool
731
-	 * @since 1.0.19
732
-	 */
733
-	public function has_fees() {
734
-		return count( $this->fees ) !== 0;
735
-	}
736
-
737
-	/*
655
+    /**
656
+     * Prepares the submission's fees.
657
+     *
658
+     * @since 1.0.19
659
+     */
660
+    public function process_fees() {
661
+
662
+        $fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this );
663
+
664
+        foreach ( $fees_processor->fees as $fee ) {
665
+            $this->add_fee( $fee );
666
+        }
667
+
668
+        do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) );
669
+    }
670
+
671
+    /**
672
+     * Adds a fee to the submission.
673
+     *
674
+     * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required.
675
+     * @since 1.0.19
676
+     */
677
+    public function add_fee( $fee ) {
678
+
679
+        $this->fees[ $fee['name'] ]         = $fee;
680
+        $this->totals['fees']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
681
+        $this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
682
+
683
+    }
684
+
685
+    /**
686
+     * Removes a fee from the submission.
687
+     *
688
+     * @since 1.0.19
689
+     */
690
+    public function remove_fee( $name ) {
691
+
692
+        if ( isset( $this->fees[ $name ] ) ) {
693
+            $this->totals['fees']['initial']   -= $this->fees[ $name ]['initial_fee'];
694
+            $this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee'];
695
+            unset( $this->fees[ $name ] );
696
+        }
697
+
698
+    }
699
+
700
+    /**
701
+     * Returns the fees.
702
+     *
703
+     * @since 1.0.19
704
+     */
705
+    public function get_fee() {
706
+        return $this->totals['fees']['initial'];
707
+    }
708
+
709
+    /**
710
+     * Returns the recurring fees.
711
+     *
712
+     * @since 1.0.19
713
+     */
714
+    public function get_recurring_fee() {
715
+        return $this->totals['fees']['recurring'];
716
+    }
717
+
718
+    /**
719
+     * Returns all fees.
720
+     *
721
+     * @since 1.0.19
722
+     */
723
+    public function get_fees() {
724
+        return $this->fees;
725
+    }
726
+
727
+    /**
728
+     * Checks if there are any fees for the form.
729
+     *
730
+     * @return bool
731
+     * @since 1.0.19
732
+     */
733
+    public function has_fees() {
734
+        return count( $this->fees ) !== 0;
735
+    }
736
+
737
+    /*
738 738
 	|--------------------------------------------------------------------------
739 739
 	| MISC
740 740
 	|--------------------------------------------------------------------------
@@ -742,119 +742,119 @@  discard block
 block discarded – undo
742 742
 	| Extra submission functions.
743 743
     */
744 744
 
745
-	/**
746
-	 * Checks if this is the initial fetch.
747
-	 *
748
-	 * @return bool
749
-	 * @since 1.0.19
750
-	 */
751
-	public function is_initial_fetch() {
752
-		return empty( $this->data['initial_state'] );
753
-	}
754
-
755
-	/**
756
-	 * Returns the total amount to collect for this submission.
757
-	 *
758
-	 * @since 1.0.19
759
-	 */
760
-	public function get_total() {
761
-		$total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() - $this->get_discount();
762
-		return max( $total, 0 );
763
-	}
764
-
765
-	/**
766
-	 * Returns the recurring total amount to collect for this submission.
767
-	 *
768
-	 * @since 1.0.19
769
-	 */
770
-	public function get_recurring_total() {
771
-		$total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() - $this->get_recurring_discount();
772
-		return max( $total, 0 );
773
-	}
774
-
775
-	/**
776
-	 * Whether payment details should be collected for this submission.
777
-	 *
778
-	 * @since 1.0.19
779
-	 */
780
-	public function should_collect_payment_details() {
781
-		$initial   = $this->get_total();
782
-		$recurring = $this->get_recurring_total();
783
-
784
-		if ( $this->has_recurring == 0 ) {
785
-			$recurring = 0;
786
-		}
787
-
788
-		$collect = $initial > 0 || $recurring > 0;
789
-		return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this  );
790
-	}
791
-
792
-	/**
793
-	 * Returns the billing email of the user.
794
-	 *
795
-	 * @since 1.0.19
796
-	 */
797
-	public function get_billing_email() {
798
-		return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this  );
799
-	}
800
-
801
-	/**
802
-	 * Checks if the submitter has a billing email.
803
-	 *
804
-	 * @since 1.0.19
805
-	 */
806
-	public function has_billing_email() {
807
-		$billing_email = $this->get_billing_email();
808
-		return ! empty( $billing_email ) && is_email( $billing_email );
809
-	}
810
-
811
-	/**
812
-	 * Returns the appropriate currency for the submission.
813
-	 *
814
-	 * @since 1.0.19
815
-	 * @return string
816
-	 */
817
-	public function get_currency() {
818
-		return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency();
819
-    }
820
-
821
-    /**
822
-	 * Returns the raw submission data.
823
-	 *
824
-	 * @since 1.0.19
825
-	 * @return array
826
-	 */
827
-	public function get_data() {
828
-		return $this->data;
829
-	}
830
-
831
-	/**
832
-	 * Returns a field from the submission data
833
-	 *
834
-	 * @param string $field
835
-	 * @since 1.0.19
836
-	 * @return mixed|null
837
-	 */
838
-	public function get_field( $field, $sub_array_key = null ) {
839
-		return getpaid_get_array_field( $this->data, $field, $sub_array_key );
840
-	}
841
-
842
-	/**
843
-	 * Checks if a required field is set.
844
-	 *
845
-	 * @since 1.0.19
846
-	 */
847
-	public function is_required_field_set( $field ) {
848
-		return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] );
849
-	}
850
-
851
-	/**
852
-	 * Formats an amount
853
-	 *
854
-	 * @since 1.0.19
855
-	 */
856
-	public function format_amount( $amount ) {
857
-		return wpinv_price( $amount, $this->get_currency() );
858
-	}
745
+    /**
746
+     * Checks if this is the initial fetch.
747
+     *
748
+     * @return bool
749
+     * @since 1.0.19
750
+     */
751
+    public function is_initial_fetch() {
752
+        return empty( $this->data['initial_state'] );
753
+    }
754
+
755
+    /**
756
+     * Returns the total amount to collect for this submission.
757
+     *
758
+     * @since 1.0.19
759
+     */
760
+    public function get_total() {
761
+        $total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() - $this->get_discount();
762
+        return max( $total, 0 );
763
+    }
764
+
765
+    /**
766
+     * Returns the recurring total amount to collect for this submission.
767
+     *
768
+     * @since 1.0.19
769
+     */
770
+    public function get_recurring_total() {
771
+        $total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() - $this->get_recurring_discount();
772
+        return max( $total, 0 );
773
+    }
774
+
775
+    /**
776
+     * Whether payment details should be collected for this submission.
777
+     *
778
+     * @since 1.0.19
779
+     */
780
+    public function should_collect_payment_details() {
781
+        $initial   = $this->get_total();
782
+        $recurring = $this->get_recurring_total();
783
+
784
+        if ( $this->has_recurring == 0 ) {
785
+            $recurring = 0;
786
+        }
787
+
788
+        $collect = $initial > 0 || $recurring > 0;
789
+        return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this  );
790
+    }
791
+
792
+    /**
793
+     * Returns the billing email of the user.
794
+     *
795
+     * @since 1.0.19
796
+     */
797
+    public function get_billing_email() {
798
+        return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this  );
799
+    }
800
+
801
+    /**
802
+     * Checks if the submitter has a billing email.
803
+     *
804
+     * @since 1.0.19
805
+     */
806
+    public function has_billing_email() {
807
+        $billing_email = $this->get_billing_email();
808
+        return ! empty( $billing_email ) && is_email( $billing_email );
809
+    }
810
+
811
+    /**
812
+     * Returns the appropriate currency for the submission.
813
+     *
814
+     * @since 1.0.19
815
+     * @return string
816
+     */
817
+    public function get_currency() {
818
+        return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency();
819
+    }
820
+
821
+    /**
822
+     * Returns the raw submission data.
823
+     *
824
+     * @since 1.0.19
825
+     * @return array
826
+     */
827
+    public function get_data() {
828
+        return $this->data;
829
+    }
830
+
831
+    /**
832
+     * Returns a field from the submission data
833
+     *
834
+     * @param string $field
835
+     * @since 1.0.19
836
+     * @return mixed|null
837
+     */
838
+    public function get_field( $field, $sub_array_key = null ) {
839
+        return getpaid_get_array_field( $this->data, $field, $sub_array_key );
840
+    }
841
+
842
+    /**
843
+     * Checks if a required field is set.
844
+     *
845
+     * @since 1.0.19
846
+     */
847
+    public function is_required_field_set( $field ) {
848
+        return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] );
849
+    }
850
+
851
+    /**
852
+     * Formats an amount
853
+     *
854
+     * @since 1.0.19
855
+     */
856
+    public function format_amount( $amount ) {
857
+        return wpinv_price( $amount, $this->get_currency() );
858
+    }
859 859
 
860 860
 }
Please login to merge, or discard this patch.
includes/gateways/class-getpaid-bank-transfer-gateway.php 1 patch
Indentation   +175 added lines, -175 removed lines patch added patch discarded remove patch
@@ -13,30 +13,30 @@  discard block
 block discarded – undo
13 13
 class GetPaid_Bank_Transfer_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 = 'bank_transfer';
21 21
 
22
-	/**
23
-	 * An array of features that this gateway supports.
24
-	 *
25
-	 * @var array
26
-	 */
27
-	protected $supports = array( 'addons' );
22
+    /**
23
+     * An array of features that this gateway supports.
24
+     *
25
+     * @var array
26
+     */
27
+    protected $supports = array( 'addons' );
28 28
 
29 29
     /**
30
-	 * Payment method order.
31
-	 *
32
-	 * @var int
33
-	 */
34
-	public $order = 8;
30
+     * Payment method order.
31
+     *
32
+     * @var int
33
+     */
34
+    public $order = 8;
35 35
 
36 36
     /**
37
-	 * Class constructor.
38
-	 */
39
-	public function __construct() {
37
+     * Class constructor.
38
+     */
39
+    public function __construct() {
40 40
         parent::__construct();
41 41
 
42 42
         $this->title                = __( 'Direct bank transfer', 'invoicing' );
@@ -44,23 +44,23 @@  discard block
 block discarded – undo
44 44
         $this->checkout_button_text = __( 'Proceed', 'invoicing' );
45 45
         $this->instructions         = apply_filters( 'wpinv_bank_instructions', $this->get_option( 'info' ) );
46 46
 
47
-		add_action( 'wpinv_receipt_end', array( $this, 'thankyou_page' ) );
48
-		add_action( 'getpaid_invoice_line_items', array( $this, 'thankyou_page' ), 40 );
49
-		add_action( 'wpinv_pdf_content_billing', array( $this, 'thankyou_page' ), 11 );
50
-		add_action( 'wpinv_email_invoice_details', array( $this, 'email_instructions' ), 10, 3 );
47
+        add_action( 'wpinv_receipt_end', array( $this, 'thankyou_page' ) );
48
+        add_action( 'getpaid_invoice_line_items', array( $this, 'thankyou_page' ), 40 );
49
+        add_action( 'wpinv_pdf_content_billing', array( $this, 'thankyou_page' ), 11 );
50
+        add_action( 'wpinv_email_invoice_details', array( $this, 'email_instructions' ), 10, 3 );
51 51
 
52 52
     }
53 53
 
54 54
     /**
55
-	 * Process Payment.
56
-	 *
57
-	 *
58
-	 * @param WPInv_Invoice $invoice Invoice.
59
-	 * @param array $submission_data Posted checkout fields.
60
-	 * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
61
-	 * @return array
62
-	 */
63
-	public function process_payment( $invoice, $submission_data, $submission ) {
55
+     * Process Payment.
56
+     *
57
+     *
58
+     * @param WPInv_Invoice $invoice Invoice.
59
+     * @param array $submission_data Posted checkout fields.
60
+     * @param GetPaid_Payment_Form_Submission $submission Checkout submission.
61
+     * @return array
62
+     */
63
+    public function process_payment( $invoice, $submission_data, $submission ) {
64 64
 
65 65
         // Add a transaction id.
66 66
         $invoice->set_transaction_id( $invoice->generate_key('trans_') );
@@ -81,66 +81,66 @@  discard block
 block discarded – undo
81 81
     }
82 82
 
83 83
     /**
84
-	 * Output for the order received page.
85
-	 *
86
-	 * @param WPInv_Invoice $invoice Invoice.
87
-	 */
88
-	public function thankyou_page( $invoice ) {
84
+     * Output for the order received page.
85
+     *
86
+     * @param WPInv_Invoice $invoice Invoice.
87
+     */
88
+    public function thankyou_page( $invoice ) {
89 89
 
90 90
         if ( 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) {
91 91
 
92
-			echo '<div class="mt-4 mb-2 getpaid-bank-transfer-details">' . PHP_EOL;
92
+            echo '<div class="mt-4 mb-2 getpaid-bank-transfer-details">' . PHP_EOL;
93 93
 
94 94
             if ( ! empty( $this->instructions ) ) {
95 95
                 echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) );
96
-			}
96
+            }
97 97
 
98
-			$this->bank_details( $invoice );
98
+            $this->bank_details( $invoice );
99 99
 
100
-			echo '</div>';
100
+            echo '</div>';
101 101
 
102 102
         }
103 103
 
104
-	}
104
+    }
105 105
 
106 106
     /**
107
-	 * Add content to the WPI emails.
108
-	 *
109
-	 * @param WPInv_Invoice $invoice Invoice.
110
-	 * @param string     $email_type Email format: plain text or HTML.
111
-	 * @param bool     $sent_to_admin Sent to admin.
112
-	 */
113
-	public function email_instructions( $invoice, $email_type, $sent_to_admin ) {
107
+     * Add content to the WPI emails.
108
+     *
109
+     * @param WPInv_Invoice $invoice Invoice.
110
+     * @param string     $email_type Email format: plain text or HTML.
111
+     * @param bool     $sent_to_admin Sent to admin.
112
+     */
113
+    public function email_instructions( $invoice, $email_type, $sent_to_admin ) {
114 114
 
115
-		if ( ! $sent_to_admin && 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) {
115
+        if ( ! $sent_to_admin && 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) {
116 116
 
117
-			echo '<div class="wpi-email-row getpaid-bank-transfer-details">';
117
+            echo '<div class="wpi-email-row getpaid-bank-transfer-details">';
118 118
 
119
-			if ( $this->instructions ) {
120
-				echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) . PHP_EOL );
119
+            if ( $this->instructions ) {
120
+                echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) . PHP_EOL );
121 121
             }
122 122
 
123
-			$this->bank_details( $invoice );
123
+            $this->bank_details( $invoice );
124 124
 			
125
-			echo '</div>';
125
+            echo '</div>';
126 126
 
127
-		}
127
+        }
128 128
 
129 129
     }
130 130
     
131 131
     /**
132
-	 * Get bank details and place into a list format.
133
-	 *
134
-	 * @param WPInv_Invoice $invoice Invoice.
135
-	 */
136
-	protected function bank_details( $invoice ) {
132
+     * Get bank details and place into a list format.
133
+     *
134
+     * @param WPInv_Invoice $invoice Invoice.
135
+     */
136
+    protected function bank_details( $invoice ) {
137 137
 
138
-		// Get the invoice country and country $locale.
139
-		$country = $invoice->get_country();
140
-		$locale  = $this->get_country_locale();
138
+        // Get the invoice country and country $locale.
139
+        $country = $invoice->get_country();
140
+        $locale  = $this->get_country_locale();
141 141
 
142
-		// Get sortcode label in the $locale array and use appropriate one.
143
-		$sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' );
142
+        // Get sortcode label in the $locale array and use appropriate one.
143
+        $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' );
144 144
 
145 145
         $bank_fields = array(
146 146
             'ac_name'     => __( 'Account Name', 'invoicing' ),
@@ -169,144 +169,144 @@  discard block
 block discarded – undo
169 169
             return;
170 170
         }
171 171
 
172
-		echo '<h3 class="getpaid-bank-transfer-title"> ' . apply_filters( 'wpinv_receipt_bank_details_title', __( 'Bank Details', 'invoicing' ) ) . '</h3>' . PHP_EOL;
172
+        echo '<h3 class="getpaid-bank-transfer-title"> ' . apply_filters( 'wpinv_receipt_bank_details_title', __( 'Bank Details', 'invoicing' ) ) . '</h3>' . PHP_EOL;
173 173
 
174
-		echo '<table class="table table-bordered getpaid-bank-transfer-details">' . PHP_EOL;
174
+        echo '<table class="table table-bordered getpaid-bank-transfer-details">' . PHP_EOL;
175 175
 
176
-		foreach ( $bank_info as $key => $data ) {
176
+        foreach ( $bank_info as $key => $data ) {
177 177
 
178
-			$key   = sanitize_html_class( $key );
179
-			$label = wp_kses_post( $data['label'] );
180
-			$value = wp_kses_post( wptexturize( $data['value'] ) );
178
+            $key   = sanitize_html_class( $key );
179
+            $label = wp_kses_post( $data['label'] );
180
+            $value = wp_kses_post( wptexturize( $data['value'] ) );
181 181
 
182
-			echo "<tr class='getpaid-bank-transfer-$key'><th class='font-weight-bold'>$label</th><td class='w-75'>$value</td></tr>" . PHP_EOL;
183
-		}
182
+            echo "<tr class='getpaid-bank-transfer-$key'><th class='font-weight-bold'>$label</th><td class='w-75'>$value</td></tr>" . PHP_EOL;
183
+        }
184 184
 
185
-		echo '</table>';
185
+        echo '</table>';
186 186
 
187 187
     }
188 188
     
189 189
     /**
190
-	 * Get country locale if localized.
191
-	 *
192
-	 * @return array
193
-	 */
194
-	public function get_country_locale() {
195
-
196
-		if ( empty( $this->locale ) ) {
197
-
198
-			// Locale information to be used - only those that are not 'Sort Code'.
199
-			$this->locale = apply_filters(
200
-				'getpaid_get_bank_transfer_locale',
201
-				array(
202
-					'AU' => array(
203
-						'sortcode' => array(
204
-							'label' => __( 'BSB', 'invoicing' ),
205
-						),
206
-					),
207
-					'CA' => array(
208
-						'sortcode' => array(
209
-							'label' => __( 'Bank transit number', 'invoicing' ),
210
-						),
211
-					),
212
-					'IN' => array(
213
-						'sortcode' => array(
214
-							'label' => __( 'IFSC', 'invoicing' ),
215
-						),
216
-					),
217
-					'IT' => array(
218
-						'sortcode' => array(
219
-							'label' => __( 'Branch sort', 'invoicing' ),
220
-						),
221
-					),
222
-					'NZ' => array(
223
-						'sortcode' => array(
224
-							'label' => __( 'Bank code', 'invoicing' ),
225
-						),
226
-					),
227
-					'SE' => array(
228
-						'sortcode' => array(
229
-							'label' => __( 'Bank code', 'invoicing' ),
230
-						),
231
-					),
232
-					'US' => array(
233
-						'sortcode' => array(
234
-							'label' => __( 'Routing number', 'invoicing' ),
235
-						),
236
-					),
237
-					'ZA' => array(
238
-						'sortcode' => array(
239
-							'label' => __( 'Branch code', 'invoicing' ),
240
-						),
241
-					),
242
-				)
243
-			);
244
-
245
-		}
246
-
247
-		return $this->locale;
248
-
249
-	}
250
-
251
-	/**
252
-	 * Filters the gateway settings.
253
-	 * 
254
-	 * @param array $admin_settings
255
-	 */
256
-	public function admin_settings( $admin_settings ) {
190
+     * Get country locale if localized.
191
+     *
192
+     * @return array
193
+     */
194
+    public function get_country_locale() {
195
+
196
+        if ( empty( $this->locale ) ) {
197
+
198
+            // Locale information to be used - only those that are not 'Sort Code'.
199
+            $this->locale = apply_filters(
200
+                'getpaid_get_bank_transfer_locale',
201
+                array(
202
+                    'AU' => array(
203
+                        'sortcode' => array(
204
+                            'label' => __( 'BSB', 'invoicing' ),
205
+                        ),
206
+                    ),
207
+                    'CA' => array(
208
+                        'sortcode' => array(
209
+                            'label' => __( 'Bank transit number', 'invoicing' ),
210
+                        ),
211
+                    ),
212
+                    'IN' => array(
213
+                        'sortcode' => array(
214
+                            'label' => __( 'IFSC', 'invoicing' ),
215
+                        ),
216
+                    ),
217
+                    'IT' => array(
218
+                        'sortcode' => array(
219
+                            'label' => __( 'Branch sort', 'invoicing' ),
220
+                        ),
221
+                    ),
222
+                    'NZ' => array(
223
+                        'sortcode' => array(
224
+                            'label' => __( 'Bank code', 'invoicing' ),
225
+                        ),
226
+                    ),
227
+                    'SE' => array(
228
+                        'sortcode' => array(
229
+                            'label' => __( 'Bank code', 'invoicing' ),
230
+                        ),
231
+                    ),
232
+                    'US' => array(
233
+                        'sortcode' => array(
234
+                            'label' => __( 'Routing number', 'invoicing' ),
235
+                        ),
236
+                    ),
237
+                    'ZA' => array(
238
+                        'sortcode' => array(
239
+                            'label' => __( 'Branch code', 'invoicing' ),
240
+                        ),
241
+                    ),
242
+                )
243
+            );
244
+
245
+        }
246
+
247
+        return $this->locale;
248
+
249
+    }
250
+
251
+    /**
252
+     * Filters the gateway settings.
253
+     * 
254
+     * @param array $admin_settings
255
+     */
256
+    public function admin_settings( $admin_settings ) {
257 257
 
258 258
         $admin_settings['bank_transfer_desc']['std']    = __( "Make your payment directly into our bank account. Please use your Invoice Number as the payment reference. Your invoice won't be processed until the funds have cleared in our account.", 'invoicing' );
259
-		$admin_settings['bank_transfer_active']['desc'] = __( 'Enable bank transfer', 'invoicing' );
259
+        $admin_settings['bank_transfer_active']['desc'] = __( 'Enable bank transfer', 'invoicing' );
260 260
 
261
-		$locale  = $this->get_country_locale();
261
+        $locale  = $this->get_country_locale();
262 262
 
263
-		// Get sortcode label in the $locale array and use appropriate one.
264
-		$country  = wpinv_default_billing_country();
265
-		$sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' );
263
+        // Get sortcode label in the $locale array and use appropriate one.
264
+        $country  = wpinv_default_billing_country();
265
+        $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' );
266 266
 
267
-		$admin_settings['bank_transfer_ac_name'] = array(
267
+        $admin_settings['bank_transfer_ac_name'] = array(
268 268
             'type' => 'text',
269 269
             'id'   => 'bank_transfer_ac_name',
270 270
             'name' => __( 'Account Name', 'invoicing' ),
271
-		);
271
+        );
272 272
 		
273
-		$admin_settings['bank_transfer_ac_no'] = array(
273
+        $admin_settings['bank_transfer_ac_no'] = array(
274 274
             'type' => 'text',
275 275
             'id'   => 'bank_transfer_ac_no',
276 276
             'name' => __( 'Account Number', 'invoicing' ),
277
-		);
277
+        );
278 278
 		
279
-		$admin_settings['bank_transfer_bank_name'] = array(
279
+        $admin_settings['bank_transfer_bank_name'] = array(
280 280
             'type' => 'text',
281 281
             'id'   => 'bank_transfer_bank_name',
282 282
             'name' => __( 'Bank Name', 'invoicing' ),
283
-		);
283
+        );
284 284
 
285
-		$admin_settings['bank_transfer_ifsc'] = array(
285
+        $admin_settings['bank_transfer_ifsc'] = array(
286 286
             'type' => 'text',
287 287
             'id'   => 'bank_transfer_ifsc',
288 288
             'name' => __( 'IFSC Code', 'invoicing' ),
289
-		);
289
+        );
290 290
 
291
-		$admin_settings['bank_transfer_iban'] = array(
291
+        $admin_settings['bank_transfer_iban'] = array(
292 292
             'type' => 'text',
293 293
             'id'   => 'bank_transfer_iban',
294 294
             'name' => __( 'IBAN', 'invoicing' ),
295
-		);
295
+        );
296 296
 
297
-		$admin_settings['bank_transfer_bic'] = array(
297
+        $admin_settings['bank_transfer_bic'] = array(
298 298
             'type' => 'text',
299 299
             'id'   => 'bank_transfer_bic',
300 300
             'name' => __( 'BIC/Swift Code', 'invoicing' ),
301
-		);
301
+        );
302 302
 		
303
-		$admin_settings['bank_transfer_sort_code'] = array(
304
-			'type' => 'text',
305
-			'id'   => 'bank_transfer_sort_code',
306
-			'name' => $sortcode,
307
-		);
303
+        $admin_settings['bank_transfer_sort_code'] = array(
304
+            'type' => 'text',
305
+            'id'   => 'bank_transfer_sort_code',
306
+            'name' => $sortcode,
307
+        );
308 308
 
309
-		$admin_settings['bank_transfer_info'] = array(
309
+        $admin_settings['bank_transfer_info'] = array(
310 310
             'id'   => 'bank_transfer_info',
311 311
             'name' => __( 'Instructions', 'invoicing' ),
312 312
             'desc' => __( 'Instructions that will be added to the thank you page and emails.', 'invoicing' ),
@@ -316,17 +316,17 @@  discard block
 block discarded – undo
316 316
             'rows' => 5
317 317
         );
318 318
 
319
-		return $admin_settings;
320
-	}
319
+        return $admin_settings;
320
+    }
321 321
 
322
-	/**
323
-	 * Processes invoice addons.
324
-	 *
325
-	 * @param WPInv_Invoice $invoice
326
-	 * @param GetPaid_Form_Item[] $items
327
-	 * @return WPInv_Invoice
328
-	 */
329
-	public function process_addons( $invoice, $items ) {
322
+    /**
323
+     * Processes invoice addons.
324
+     *
325
+     * @param WPInv_Invoice $invoice
326
+     * @param GetPaid_Form_Item[] $items
327
+     * @return WPInv_Invoice
328
+     */
329
+    public function process_addons( $invoice, $items ) {
330 330
 
331 331
         foreach ( $items as $item ) {
332 332
             $invoice->add_item( $item );
@@ -334,6 +334,6 @@  discard block
 block discarded – undo
334 334
 
335 335
         $invoice->recalculate_total();
336 336
         $invoice->save();
337
-	}
337
+    }
338 338
 
339 339
 }
Please login to merge, or discard this patch.
templates/payment-forms/cart-item.php 1 patch
Indentation   +57 added lines, -57 removed lines patch added patch discarded remove patch
@@ -24,64 +24,64 @@  discard block
 block discarded – undo
24 24
 
25 25
 				<?php
26 26
 
27
-					// Fires before printing a line item column.
28
-					do_action( "getpaid_form_cart_item_before_$key", $item, $form );
27
+                    // Fires before printing a line item column.
28
+                    do_action( "getpaid_form_cart_item_before_$key", $item, $form );
29 29
 
30
-					// Item name.
31
-					if ( 'name' == $key ) {
30
+                    // Item name.
31
+                    if ( 'name' == $key ) {
32 32
 
33
-						// Display the name.
34
-						echo '<div class="mb-1">' . sanitize_text_field( $item->get_name() ) . '</div>';
33
+                        // Display the name.
34
+                        echo '<div class="mb-1">' . sanitize_text_field( $item->get_name() ) . '</div>';
35 35
 
36
-						// And an optional description.
36
+                        // And an optional description.
37 37
                         $description = $item->get_description();
38 38
 
39 39
                         if ( ! empty( $description ) ) {
40 40
                             $description = wp_kses_post( $description );
41 41
                             echo "<small class='form-text text-muted pr-2 m-0'>$description</small>";
42
-						}
42
+                        }
43 43
 
44
-						// Price help text.
44
+                        // Price help text.
45 45
                         $description = getpaid_item_recurring_price_help_text( $item, $currency );
46 46
                         if ( $description ) {
47 47
                             echo "<small class='getpaid-form-item-price-desc form-text text-muted pr-2 m-0'>$description</small>";
48
-						}
48
+                        }
49 49
 
50
-					}
50
+                    }
51 51
 
52
-					// Item price.
53
-					if ( 'price' == $key ) {
52
+                    // Item price.
53
+                    if ( 'price' == $key ) {
54 54
 
55
-						// Set the currency position.
56
-						$position = wpinv_currency_position();
55
+                        // Set the currency position.
56
+                        $position = wpinv_currency_position();
57 57
 
58
-						if ( $position == 'left_space' ) {
59
-							$position = 'left';
60
-						}
58
+                        if ( $position == 'left_space' ) {
59
+                            $position = 'left';
60
+                        }
61 61
 
62
-						if ( $position == 'right_space' ) {
63
-							$position = 'right';
64
-						}
62
+                        if ( $position == 'right_space' ) {
63
+                            $position = 'right';
64
+                        }
65 65
 
66
-						if ( $item->user_can_set_their_price() ) {
67
-							$price            = max( (float) $item->get_price(), (float) $item->get_minimum_price() );
68
-							$minimum          = (float) $item->get_minimum_price();
69
-							$validate_minimum = '';
70
-							$class            = '';
71
-							$data_minimum     = '';
66
+                        if ( $item->user_can_set_their_price() ) {
67
+                            $price            = max( (float) $item->get_price(), (float) $item->get_minimum_price() );
68
+                            $minimum          = (float) $item->get_minimum_price();
69
+                            $validate_minimum = '';
70
+                            $class            = '';
71
+                            $data_minimum     = '';
72 72
 
73
-							if ( $minimum > 0 ) {
74
-								$validate_minimum = sprintf(
75
-									esc_attr__( 'The minimum allowed amount is %s', 'invoicing' ),
76
-									sanitize_text_field( wpinv_price( $minimum, $currency ) )
77
-								);
73
+                            if ( $minimum > 0 ) {
74
+                                $validate_minimum = sprintf(
75
+                                    esc_attr__( 'The minimum allowed amount is %s', 'invoicing' ),
76
+                                    sanitize_text_field( wpinv_price( $minimum, $currency ) )
77
+                                );
78 78
 
79
-								$class = 'getpaid-validate-minimum-amount';
79
+                                $class = 'getpaid-validate-minimum-amount';
80 80
 
81
-								$data_minimum     = "data-minimum-amount='$minimum'";
82
-							}
81
+                                $data_minimum     = "data-minimum-amount='$minimum'";
82
+                            }
83 83
 
84
-							?>
84
+                            ?>
85 85
 								<div class="input-group input-group-sm">
86 86
 									<?php if( 'left' == $position ) : ?>
87 87
 										<div class="input-group-prepend">
@@ -105,37 +105,37 @@  discard block
 block discarded – undo
105 105
 								</div>
106 106
 
107 107
 							<?php
108
-						} else {
109
-							echo wpinv_price( $item->get_price(), $currency );
110
-							?>
108
+                        } else {
109
+                            echo wpinv_price( $item->get_price(), $currency );
110
+                            ?>
111 111
 								<input name='getpaid-items[<?php echo (int) $item->get_id(); ?>][price]' type='hidden' class='getpaid-item-price-input' value='<?php echo esc_attr( $item->get_price() ); ?>'>
112 112
 							<?php
113
-						}
114
-					}
113
+                        }
114
+                    }
115 115
 
116
-					// Item quantity.
117
-					if ( 'quantity' == $key ) {
116
+                    // Item quantity.
117
+                    if ( 'quantity' == $key ) {
118 118
 
119
-						if ( $item->allows_quantities() ) {
120
-							?>
119
+                        if ( $item->allows_quantities() ) {
120
+                            ?>
121 121
 								<input name='getpaid-items[<?php echo (int) $item->get_id(); ?>][quantity]' type='text' style='width: 64px; line-height: 1; min-height: 35px;' class='getpaid-item-quantity-input p-1 align-middle font-weight-normal shadow-none m-0 rounded-0 text-center border' value='<?php echo (float) $item->get_quantity(); ?>' min='1' required>
122 122
 							<?php
123
-						} else {
124
-							echo (float) $item->get_quantity();
125
-							echo '&nbsp;&nbsp;&nbsp;';
126
-							?>
123
+                        } else {
124
+                            echo (float) $item->get_quantity();
125
+                            echo '&nbsp;&nbsp;&nbsp;';
126
+                            ?>
127 127
 								<input type='hidden' name='getpaid-items[<?php echo (int) $item->get_id(); ?>][quantity]' class='getpaid-item-quantity-input' value='<?php echo (float) $item->get_quantity(); ?>'>
128 128
 							<?php
129
-						}
130
-					}
129
+                        }
130
+                    }
131 131
 
132
-					// Item sub total.
133
-					if ( 'subtotal' == $key ) {
134
-						echo wpinv_price( $item->get_sub_total(), $currency );
135
-					}
132
+                    // Item sub total.
133
+                    if ( 'subtotal' == $key ) {
134
+                        echo wpinv_price( $item->get_sub_total(), $currency );
135
+                    }
136 136
 
137
-					do_action( "getpaid_payment_form_cart_item_$key", $item, $form );
138
-				?>
137
+                    do_action( "getpaid_payment_form_cart_item_$key", $item, $form );
138
+                ?>
139 139
 
140 140
 			</div>
141 141
 
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +1930 added lines, -1930 removed lines patch added patch discarded remove patch
@@ -1,262 +1,262 @@  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 8
 
9
-	/**
10
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
-	 *
12
-	 * Should not be called direct but extended instead.
13
-	 *
14
-	 * Class WP_Super_Duper
15
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
-	 * @ver 1.0.19
17
-	 */
18
-	class WP_Super_Duper extends WP_Widget {
19
-
20
-		public $version = "1.0.24";
21
-		public $font_awesome_icon_version = "5.11.2";
22
-		public $block_code;
23
-		public $options;
24
-		public $base_id;
25
-		public $settings_hash;
26
-		public $arguments = array();
27
-		public $instance = array();
28
-		private $class_name;
29
-
30
-		/**
31
-		 * The relative url to the current folder.
32
-		 *
33
-		 * @var string
34
-		 */
35
-		public $url = '';
36
-
37
-		/**
38
-		 * Take the array options and use them to build.
39
-		 */
40
-		public function __construct( $options ) {
41
-			global $sd_widgets;
42
-
43
-			$sd_widgets[ $options['base_id'] ] = array(
44
-				'name'       => $options['name'],
45
-				'class_name' => $options['class_name']
46
-			);
47
-			$this->base_id                     = $options['base_id'];
48
-			// lets filter the options before we do anything
49
-			$options       = apply_filters( "wp_super_duper_options", $options );
50
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
-			$options       = $this->add_name_from_key( $options );
52
-			$this->options = $options;
53
-
54
-			$this->base_id   = $options['base_id'];
55
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
-
57
-			// init parent
58
-			parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
-
60
-			if ( isset( $options['class_name'] ) ) {
61
-				// register widget
62
-				$this->class_name = $options['class_name'];
63
-
64
-				// register shortcode
65
-				$this->register_shortcode();
66
-
67
-				// Fusion Builder (avada) support
68
-				if ( function_exists( 'fusion_builder_map' ) ) {
69
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
70
-				}
71
-
72
-				// register block
73
-				add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
-			}
75
-
76
-			// add the CSS and JS we need ONCE
77
-			global $sd_widget_scripts;
78
-
79
-			if ( ! $sd_widget_scripts ) {
80
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
-				wp_add_inline_style( 'widgets', $this->widget_css() );
83
-
84
-				// maybe add elementor editor styles
85
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
-
87
-				$sd_widget_scripts = true;
88
-
89
-				// add shortcode insert button once
90
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
-				// generatepress theme sections compatibility
92
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
-				}
95
-				if ( $this->is_preview() ) {
96
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
97
-					// this makes the insert button work for elementor
98
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
99
-						$this,
100
-						'shortcode_insert_button_script'
101
-					) ); // for elementor
102
-				}
103
-				// this makes the insert button work for cornerstone
104
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
105
-
106
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
107
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
108
-
109
-				// add generator text to admin head
110
-				add_action( 'admin_head', array( $this, 'generator' ) );
111
-			}
112
-
113
-			do_action( 'wp_super_duper_widget_init', $options, $this );
114
-		}
115
-
116
-		/**
117
-		 * Add our widget CSS to elementor editor.
118
-		 */
119
-		public function elementor_editor_styles() {
120
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
121
-		}
122
-
123
-		public function register_fusion_element() {
124
-
125
-			$options = $this->options;
126
-
127
-			if ( $this->base_id ) {
128
-
129
-				$params = $this->get_fusion_params();
130
-
131
-				$args = array(
132
-					'name'            => $options['name'],
133
-					'shortcode'       => $this->base_id,
134
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
135
-					'allow_generator' => true,
136
-				);
137
-
138
-				if ( ! empty( $params ) ) {
139
-					$args['params'] = $params;
140
-				}
141
-
142
-				fusion_builder_map( $args );
143
-			}
144
-
145
-		}
146
-
147
-		public function get_fusion_params() {
148
-			$params    = array();
149
-			$arguments = $this->get_arguments();
150
-
151
-			if ( ! empty( $arguments ) ) {
152
-				foreach ( $arguments as $key => $val ) {
153
-					$param = array();
154
-					// type
155
-					$param['type'] = str_replace(
156
-						array(
157
-							"text",
158
-							"number",
159
-							"email",
160
-							"color",
161
-							"checkbox"
162
-						),
163
-						array(
164
-							"textfield",
165
-							"textfield",
166
-							"textfield",
167
-							"colorpicker",
168
-							"select",
169
-
170
-						),
171
-						$val['type'] );
172
-
173
-					// multiselect
174
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
175
-						$param['type']     = 'multiple_select';
176
-						$param['multiple'] = true;
177
-					}
178
-
179
-					// heading
180
-					$param['heading'] = $val['title'];
181
-
182
-					// description
183
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
184
-
185
-					// param_name
186
-					$param['param_name'] = $key;
187
-
188
-					// Default
189
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
190
-
191
-					// Group
192
-					if ( isset( $val['group'] ) ) {
193
-						$param['group'] = $val['group'];
194
-					}
195
-
196
-					// value
197
-					if ( $val['type'] == 'checkbox' ) {
198
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
199
-							unset( $param['default'] );
200
-						}
201
-						$param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
202
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
203
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
204
-					} else {
205
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
206
-					}
207
-
208
-					// setup the param
209
-					$params[] = $param;
210
-
211
-				}
212
-			}
213
-
214
-
215
-			return $params;
216
-		}
217
-
218
-		/**
219
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
220
-		 */
221
-		public static function maybe_cornerstone_builder() {
222
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
223
-				self::shortcode_insert_button_script();
224
-			}
225
-		}
226
-
227
-		/**
228
-		 * A function to ge the shortcode builder picker html.
229
-		 *
230
-		 * @param string $editor_id
231
-		 *
232
-		 * @return string
233
-		 */
234
-		public static function get_picker( $editor_id = '' ) {
235
-
236
-			ob_start();
237
-			if ( isset( $_POST['editor_id'] ) ) {
238
-				$editor_id = esc_attr( $_POST['editor_id'] );
239
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
240
-				$editor_id = 'main_content_content_vb_tiny_mce';
241
-			}
242
-
243
-			global $sd_widgets;
244
-			?>
9
+    /**
10
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
+     *
12
+     * Should not be called direct but extended instead.
13
+     *
14
+     * Class WP_Super_Duper
15
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
+     * @ver 1.0.19
17
+     */
18
+    class WP_Super_Duper extends WP_Widget {
19
+
20
+        public $version = "1.0.24";
21
+        public $font_awesome_icon_version = "5.11.2";
22
+        public $block_code;
23
+        public $options;
24
+        public $base_id;
25
+        public $settings_hash;
26
+        public $arguments = array();
27
+        public $instance = array();
28
+        private $class_name;
29
+
30
+        /**
31
+         * The relative url to the current folder.
32
+         *
33
+         * @var string
34
+         */
35
+        public $url = '';
36
+
37
+        /**
38
+         * Take the array options and use them to build.
39
+         */
40
+        public function __construct( $options ) {
41
+            global $sd_widgets;
42
+
43
+            $sd_widgets[ $options['base_id'] ] = array(
44
+                'name'       => $options['name'],
45
+                'class_name' => $options['class_name']
46
+            );
47
+            $this->base_id                     = $options['base_id'];
48
+            // lets filter the options before we do anything
49
+            $options       = apply_filters( "wp_super_duper_options", $options );
50
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
+            $options       = $this->add_name_from_key( $options );
52
+            $this->options = $options;
53
+
54
+            $this->base_id   = $options['base_id'];
55
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
+
57
+            // init parent
58
+            parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
+
60
+            if ( isset( $options['class_name'] ) ) {
61
+                // register widget
62
+                $this->class_name = $options['class_name'];
63
+
64
+                // register shortcode
65
+                $this->register_shortcode();
66
+
67
+                // Fusion Builder (avada) support
68
+                if ( function_exists( 'fusion_builder_map' ) ) {
69
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
70
+                }
71
+
72
+                // register block
73
+                add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
+            }
75
+
76
+            // add the CSS and JS we need ONCE
77
+            global $sd_widget_scripts;
78
+
79
+            if ( ! $sd_widget_scripts ) {
80
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
+                wp_add_inline_style( 'widgets', $this->widget_css() );
83
+
84
+                // maybe add elementor editor styles
85
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
+
87
+                $sd_widget_scripts = true;
88
+
89
+                // add shortcode insert button once
90
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
+                // generatepress theme sections compatibility
92
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
+                }
95
+                if ( $this->is_preview() ) {
96
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
97
+                    // this makes the insert button work for elementor
98
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
99
+                        $this,
100
+                        'shortcode_insert_button_script'
101
+                    ) ); // for elementor
102
+                }
103
+                // this makes the insert button work for cornerstone
104
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
105
+
106
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
107
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
108
+
109
+                // add generator text to admin head
110
+                add_action( 'admin_head', array( $this, 'generator' ) );
111
+            }
112
+
113
+            do_action( 'wp_super_duper_widget_init', $options, $this );
114
+        }
115
+
116
+        /**
117
+         * Add our widget CSS to elementor editor.
118
+         */
119
+        public function elementor_editor_styles() {
120
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
121
+        }
122
+
123
+        public function register_fusion_element() {
124
+
125
+            $options = $this->options;
126
+
127
+            if ( $this->base_id ) {
128
+
129
+                $params = $this->get_fusion_params();
130
+
131
+                $args = array(
132
+                    'name'            => $options['name'],
133
+                    'shortcode'       => $this->base_id,
134
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
135
+                    'allow_generator' => true,
136
+                );
137
+
138
+                if ( ! empty( $params ) ) {
139
+                    $args['params'] = $params;
140
+                }
141
+
142
+                fusion_builder_map( $args );
143
+            }
144
+
145
+        }
146
+
147
+        public function get_fusion_params() {
148
+            $params    = array();
149
+            $arguments = $this->get_arguments();
150
+
151
+            if ( ! empty( $arguments ) ) {
152
+                foreach ( $arguments as $key => $val ) {
153
+                    $param = array();
154
+                    // type
155
+                    $param['type'] = str_replace(
156
+                        array(
157
+                            "text",
158
+                            "number",
159
+                            "email",
160
+                            "color",
161
+                            "checkbox"
162
+                        ),
163
+                        array(
164
+                            "textfield",
165
+                            "textfield",
166
+                            "textfield",
167
+                            "colorpicker",
168
+                            "select",
169
+
170
+                        ),
171
+                        $val['type'] );
172
+
173
+                    // multiselect
174
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
175
+                        $param['type']     = 'multiple_select';
176
+                        $param['multiple'] = true;
177
+                    }
178
+
179
+                    // heading
180
+                    $param['heading'] = $val['title'];
181
+
182
+                    // description
183
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
184
+
185
+                    // param_name
186
+                    $param['param_name'] = $key;
187
+
188
+                    // Default
189
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
190
+
191
+                    // Group
192
+                    if ( isset( $val['group'] ) ) {
193
+                        $param['group'] = $val['group'];
194
+                    }
195
+
196
+                    // value
197
+                    if ( $val['type'] == 'checkbox' ) {
198
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
199
+                            unset( $param['default'] );
200
+                        }
201
+                        $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
202
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
203
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
204
+                    } else {
205
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
206
+                    }
207
+
208
+                    // setup the param
209
+                    $params[] = $param;
210
+
211
+                }
212
+            }
213
+
214
+
215
+            return $params;
216
+        }
217
+
218
+        /**
219
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
220
+         */
221
+        public static function maybe_cornerstone_builder() {
222
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
223
+                self::shortcode_insert_button_script();
224
+            }
225
+        }
226
+
227
+        /**
228
+         * A function to ge the shortcode builder picker html.
229
+         *
230
+         * @param string $editor_id
231
+         *
232
+         * @return string
233
+         */
234
+        public static function get_picker( $editor_id = '' ) {
235
+
236
+            ob_start();
237
+            if ( isset( $_POST['editor_id'] ) ) {
238
+                $editor_id = esc_attr( $_POST['editor_id'] );
239
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
240
+                $editor_id = 'main_content_content_vb_tiny_mce';
241
+            }
242
+
243
+            global $sd_widgets;
244
+            ?>
245 245
 
246 246
 			<div class="sd-shortcode-left-wrap">
247 247
 				<?php
248
-				ksort( $sd_widgets );
249
-				//				print_r($sd_widgets);exit;
250
-				if ( ! empty( $sd_widgets ) ) {
251
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
252
-					echo "<option>" . __( 'Select shortcode' ) . "</option>";
253
-					foreach ( $sd_widgets as $shortcode => $class ) {
254
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
255
-					}
256
-					echo "</select>";
257
-
258
-				}
259
-				?>
248
+                ksort( $sd_widgets );
249
+                //				print_r($sd_widgets);exit;
250
+                if ( ! empty( $sd_widgets ) ) {
251
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
252
+                    echo "<option>" . __( 'Select shortcode' ) . "</option>";
253
+                    foreach ( $sd_widgets as $shortcode => $class ) {
254
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
255
+                    }
256
+                    echo "</select>";
257
+
258
+                }
259
+                ?>
260 260
 				<div class="sd-shortcode-settings"></div>
261 261
 
262 262
 			</div>
@@ -267,8 +267,8 @@  discard block
 block discarded – undo
267 267
 					<?php if ( $editor_id != '' ) { ?>
268 268
 						<button class="button sd-insert-shortcode-button"
269 269
 						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
270
-							        echo "'" . $editor_id . "'";
271
-						        } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
270
+                                    echo "'" . $editor_id . "'";
271
+                                } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
272 272
 					<?php } ?>
273 273
 					<button class="button"
274 274
 					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -276,134 +276,134 @@  discard block
 block discarded – undo
276 276
 			</div>
277 277
 			<?php
278 278
 
279
-			$html = ob_get_clean();
280
-
281
-			if ( wp_doing_ajax() ) {
282
-				echo $html;
283
-				$should_die = true;
284
-
285
-				// some builder get the editor via ajax so we should not die on those ocasions
286
-				$dont_die = array(
287
-					'parent_tag',// WP Bakery
288
-					'avia_request' // enfold
289
-				);
290
-
291
-				foreach ( $dont_die as $request ) {
292
-					if ( isset( $_REQUEST[ $request ] ) ) {
293
-						$should_die = false;
294
-					}
295
-				}
296
-
297
-				if ( $should_die ) {
298
-					wp_die();
299
-				}
300
-
301
-			} else {
302
-				return $html;
303
-			}
304
-
305
-			return '';
306
-
307
-		}
308
-
309
-		/**
310
-		 * Output the version in the admin header.
311
-		 */
312
-		public function generator() {
313
-			echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
314
-		}
315
-
316
-		/**
317
-		 * Get widget settings.
318
-		 *
319
-		 * @since 1.0.0
320
-		 */
321
-		public static function get_widget_settings() {
322
-			global $sd_widgets;
323
-
324
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
325
-			if ( ! $shortcode ) {
326
-				wp_die();
327
-			}
328
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
329
-			if ( ! $widget_args ) {
330
-				wp_die();
331
-			}
332
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
333
-			if ( ! $class_name ) {
334
-				wp_die();
335
-			}
336
-
337
-			// invoke an instance method
338
-			$widget = new $class_name;
339
-
340
-			ob_start();
341
-			$widget->form( array() );
342
-			$form = ob_get_clean();
343
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
344
-			echo "<style>" . $widget->widget_css() . "</style>";
345
-			echo "<script>" . $widget->widget_js() . "</script>";
346
-			?>
279
+            $html = ob_get_clean();
280
+
281
+            if ( wp_doing_ajax() ) {
282
+                echo $html;
283
+                $should_die = true;
284
+
285
+                // some builder get the editor via ajax so we should not die on those ocasions
286
+                $dont_die = array(
287
+                    'parent_tag',// WP Bakery
288
+                    'avia_request' // enfold
289
+                );
290
+
291
+                foreach ( $dont_die as $request ) {
292
+                    if ( isset( $_REQUEST[ $request ] ) ) {
293
+                        $should_die = false;
294
+                    }
295
+                }
296
+
297
+                if ( $should_die ) {
298
+                    wp_die();
299
+                }
300
+
301
+            } else {
302
+                return $html;
303
+            }
304
+
305
+            return '';
306
+
307
+        }
308
+
309
+        /**
310
+         * Output the version in the admin header.
311
+         */
312
+        public function generator() {
313
+            echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
314
+        }
315
+
316
+        /**
317
+         * Get widget settings.
318
+         *
319
+         * @since 1.0.0
320
+         */
321
+        public static function get_widget_settings() {
322
+            global $sd_widgets;
323
+
324
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
325
+            if ( ! $shortcode ) {
326
+                wp_die();
327
+            }
328
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
329
+            if ( ! $widget_args ) {
330
+                wp_die();
331
+            }
332
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
333
+            if ( ! $class_name ) {
334
+                wp_die();
335
+            }
336
+
337
+            // invoke an instance method
338
+            $widget = new $class_name;
339
+
340
+            ob_start();
341
+            $widget->form( array() );
342
+            $form = ob_get_clean();
343
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
344
+            echo "<style>" . $widget->widget_css() . "</style>";
345
+            echo "<script>" . $widget->widget_js() . "</script>";
346
+            ?>
347 347
 			<?php
348
-			wp_die();
349
-		}
350
-
351
-		/**
352
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
353
-		 *
354
-		 * @since 1.0.0
355
-		 *
356
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
357
-		 * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null.
358
-		 */
359
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
360
-			global $sd_widgets, $shortcode_insert_button_once;
361
-			if ( $shortcode_insert_button_once ) {
362
-				return;
363
-			}
364
-			add_thickbox();
365
-
366
-
367
-			/**
368
-			 * Cornerstone makes us play dirty tricks :/
369
-			 * 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.
370
-			 */
371
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
372
-				echo '<span id="insert-media-button">';
373
-			}
374
-
375
-			echo self::shortcode_button( 'this', 'true' );
376
-
377
-			// see opening note
378
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
379
-				echo '</span>'; // end #insert-media-button
380
-			}
381
-
382
-			// Add separate script for generatepress theme sections
383
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
384
-			} else {
385
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
386
-			}
387
-
388
-			$shortcode_insert_button_once = true;
389
-		}
390
-
391
-		/**
392
-		 * Gets the shortcode insert button html.
393
-		 *
394
-		 * @param string $id
395
-		 * @param string $search_for_id
396
-		 *
397
-		 * @return mixed
398
-		 */
399
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
400
-			ob_start();
401
-			?>
348
+            wp_die();
349
+        }
350
+
351
+        /**
352
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
353
+         *
354
+         * @since 1.0.0
355
+         *
356
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
357
+         * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null.
358
+         */
359
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
360
+            global $sd_widgets, $shortcode_insert_button_once;
361
+            if ( $shortcode_insert_button_once ) {
362
+                return;
363
+            }
364
+            add_thickbox();
365
+
366
+
367
+            /**
368
+             * Cornerstone makes us play dirty tricks :/
369
+             * 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.
370
+             */
371
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
372
+                echo '<span id="insert-media-button">';
373
+            }
374
+
375
+            echo self::shortcode_button( 'this', 'true' );
376
+
377
+            // see opening note
378
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
379
+                echo '</span>'; // end #insert-media-button
380
+            }
381
+
382
+            // Add separate script for generatepress theme sections
383
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
384
+            } else {
385
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
386
+            }
387
+
388
+            $shortcode_insert_button_once = true;
389
+        }
390
+
391
+        /**
392
+         * Gets the shortcode insert button html.
393
+         *
394
+         * @param string $id
395
+         * @param string $search_for_id
396
+         *
397
+         * @return mixed
398
+         */
399
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
400
+            ob_start();
401
+            ?>
402 402
 			<span class="sd-lable-shortcode-inserter">
403 403
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
404
-				if ( $search_for_id ) {
405
-					echo "," . $search_for_id;
406
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
404
+                if ( $search_for_id ) {
405
+                    echo "," . $search_for_id;
406
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
407 407
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
408 408
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
409 409
 					      class="dashicons dashicons-screenoptions"></span>
@@ -414,21 +414,21 @@  discard block
 block discarded – undo
414 414
 			</span>
415 415
 
416 416
 			<?php
417
-			$html = ob_get_clean();
418
-
419
-			// remove line breaks so we can use it in js
420
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
421
-		}
422
-
423
-		/**
424
-		 * Makes SD work with the siteOrigin page builder.
425
-		 *
426
-		 * @since 1.0.6
427
-		 * @return mixed
428
-		 */
429
-		public static function siteorigin_js() {
430
-			ob_start();
431
-			?>
417
+            $html = ob_get_clean();
418
+
419
+            // remove line breaks so we can use it in js
420
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
421
+        }
422
+
423
+        /**
424
+         * Makes SD work with the siteOrigin page builder.
425
+         *
426
+         * @since 1.0.6
427
+         * @return mixed
428
+         */
429
+        public static function siteorigin_js() {
430
+            ob_start();
431
+            ?>
432 432
 			<script>
433 433
 				/**
434 434
 				 * Check a form to see what items shoudl be shown or hidden.
@@ -506,28 +506,28 @@  discard block
 block discarded – undo
506 506
 				});
507 507
 			</script>
508 508
 			<?php
509
-			$output = ob_get_clean();
509
+            $output = ob_get_clean();
510 510
 
511
-			/*
511
+            /*
512 512
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
513 513
 			 */
514 514
 
515
-			return str_replace( array(
516
-				'<script>',
517
-				'</script>'
518
-			), '', $output );
519
-		}
520
-
521
-		/**
522
-		 * Output the JS and CSS for the shortcode insert button.
523
-		 *
524
-		 * @since 1.0.6
525
-		 *
526
-		 * @param string $editor_id
527
-		 * @param string $insert_shortcode_function
528
-		 */
529
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
530
-			?>
515
+            return str_replace( array(
516
+                '<script>',
517
+                '</script>'
518
+            ), '', $output );
519
+        }
520
+
521
+        /**
522
+         * Output the JS and CSS for the shortcode insert button.
523
+         *
524
+         * @since 1.0.6
525
+         *
526
+         * @param string $editor_id
527
+         * @param string $insert_shortcode_function
528
+         */
529
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
530
+            ?>
531 531
 			<style>
532 532
 				.sd-shortcode-left-wrap {
533 533
 					float: left;
@@ -653,35 +653,35 @@  discard block
 block discarded – undo
653 653
 				<?php } ?>
654 654
 			</style>
655 655
 			<?php
656
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
657
-				echo "<script>" . self::siteorigin_js() . "</script>";
658
-			}
659
-			?>
656
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
657
+                echo "<script>" . self::siteorigin_js() . "</script>";
658
+            }
659
+            ?>
660 660
 			<script>
661 661
 				<?php
662
-				if(! empty( $insert_shortcode_function )){
663
-					echo $insert_shortcode_function;
664
-				}else{
665
-
666
-				/**
667
-				 * Function for super duper insert shortcode.
668
-				 *
669
-				 * @since 1.0.0
670
-				 */
671
-				?>
662
+                if(! empty( $insert_shortcode_function )){
663
+                    echo $insert_shortcode_function;
664
+                }else{
665
+
666
+                /**
667
+                 * Function for super duper insert shortcode.
668
+                 *
669
+                 * @since 1.0.0
670
+                 */
671
+                ?>
672 672
 				function sd_insert_shortcode($editor_id) {
673 673
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
674 674
 					if ($shortcode) {
675 675
 						if (!$editor_id) {
676 676
 							<?php
677
-							if ( isset( $_REQUEST['et_fb'] ) ) {
678
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
679
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
680
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
681
-							} else {
682
-								echo '$editor_id = "#wp-content-editor-container textarea";';
683
-							}
684
-							?>
677
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
678
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
679
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
680
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
681
+                            } else {
682
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
683
+                            }
684
+                            ?>
685 685
 						} else {
686 686
 							$editor_id = '#' + $editor_id;
687 687
 						}
@@ -1007,18 +1007,18 @@  discard block
 block discarded – undo
1007 1007
 
1008 1008
 			</script>
1009 1009
 			<?php
1010
-		}
1011
-
1012
-		/**
1013
-		 * Gets some CSS for the widgets screen.
1014
-		 *
1015
-		 * @param bool $advanced If we should include advanced CSS.
1016
-		 *
1017
-		 * @return mixed
1018
-		 */
1019
-		public function widget_css( $advanced = true ) {
1020
-			ob_start();
1021
-			?>
1010
+        }
1011
+
1012
+        /**
1013
+         * Gets some CSS for the widgets screen.
1014
+         *
1015
+         * @param bool $advanced If we should include advanced CSS.
1016
+         *
1017
+         * @return mixed
1018
+         */
1019
+        public function widget_css( $advanced = true ) {
1020
+            ob_start();
1021
+            ?>
1022 1022
 			<style>
1023 1023
 				<?php if( $advanced ){ ?>
1024 1024
 				.sd-advanced-setting {
@@ -1056,26 +1056,26 @@  discard block
 block discarded – undo
1056 1056
 				}
1057 1057
 			</style>
1058 1058
 			<?php
1059
-			$output = ob_get_clean();
1059
+            $output = ob_get_clean();
1060 1060
 
1061
-			/*
1061
+            /*
1062 1062
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1063 1063
 			 */
1064 1064
 
1065
-			return str_replace( array(
1066
-				'<style>',
1067
-				'</style>'
1068
-			), '', $output );
1069
-		}
1070
-
1071
-		/**
1072
-		 * Gets some JS for the widgets screen.
1073
-		 *
1074
-		 * @return mixed
1075
-		 */
1076
-		public function widget_js() {
1077
-			ob_start();
1078
-			?>
1065
+            return str_replace( array(
1066
+                '<style>',
1067
+                '</style>'
1068
+            ), '', $output );
1069
+        }
1070
+
1071
+        /**
1072
+         * Gets some JS for the widgets screen.
1073
+         *
1074
+         * @return mixed
1075
+         */
1076
+        public function widget_js() {
1077
+            ob_start();
1078
+            ?>
1079 1079
 			<script>
1080 1080
 
1081 1081
 				/**
@@ -1233,402 +1233,402 @@  discard block
 block discarded – undo
1233 1233
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1234 1234
 			</script>
1235 1235
 			<?php
1236
-			$output = ob_get_clean();
1236
+            $output = ob_get_clean();
1237 1237
 
1238
-			/*
1238
+            /*
1239 1239
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1240 1240
 			 */
1241 1241
 
1242
-			return str_replace( array(
1243
-				'<script>',
1244
-				'</script>'
1245
-			), '', $output );
1246
-		}
1247
-
1248
-
1249
-		/**
1250
-		 * Set the name from the argument key.
1251
-		 *
1252
-		 * @param $options
1253
-		 *
1254
-		 * @return mixed
1255
-		 */
1256
-		private function add_name_from_key( $options, $arguments = false ) {
1257
-			if ( ! empty( $options['arguments'] ) ) {
1258
-				foreach ( $options['arguments'] as $key => $val ) {
1259
-					$options['arguments'][ $key ]['name'] = $key;
1260
-				}
1261
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1262
-				foreach ( $options as $key => $val ) {
1263
-					$options[ $key ]['name'] = $key;
1264
-				}
1265
-			}
1266
-
1267
-			return $options;
1268
-		}
1269
-
1270
-		/**
1271
-		 * Register the parent shortcode.
1272
-		 *
1273
-		 * @since 1.0.0
1274
-		 */
1275
-		public function register_shortcode() {
1276
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1277
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1278
-		}
1279
-
1280
-		/**
1281
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1282
-		 *
1283
-		 * @since 1.0.0
1284
-		 */
1285
-		public static function render_shortcode() {
1286
-
1287
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1288
-			if ( ! current_user_can( 'manage_options' ) ) {
1289
-				wp_die();
1290
-			}
1291
-
1292
-			// we might need the $post value here so lets set it.
1293
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1294
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1295
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1296
-					global $post;
1297
-					$post = $post_obj;
1298
-				}
1299
-			}
1300
-
1301
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1302
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1303
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1304
-				$attributes       = '';
1305
-				if ( ! empty( $attributes_array ) ) {
1306
-					foreach ( $attributes_array as $key => $value ) {
1307
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1308
-					}
1309
-				}
1310
-
1311
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1312
-
1313
-				echo do_shortcode( $shortcode );
1314
-
1315
-			}
1316
-			wp_die();
1317
-		}
1318
-
1319
-		/**
1320
-		 * Output the shortcode.
1321
-		 *
1322
-		 * @param array $args
1323
-		 * @param string $content
1324
-		 *
1325
-		 * @return string
1326
-		 */
1327
-		public function shortcode_output( $args = array(), $content = '' ) {
1328
-			$args = $this->argument_values( $args );
1329
-
1330
-			// add extra argument so we know its a output to gutenberg
1331
-			//$args
1332
-			$args = $this->string_to_bool( $args );
1333
-
1334
-			// if we have a enclosed shortcode we add it to the special `html` argument
1335
-			if ( ! empty( $content ) ) {
1336
-				$args['html'] = $content;
1337
-			}
1338
-
1339
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1340
-			$class .= " sdel-".$this->get_instance_hash();
1341
-
1342
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1343
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1344
-
1345
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1346
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1347
-
1348
-			$shortcode_args = array();
1349
-			$output         = '';
1350
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1351
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1352
-				$no_wrap = true;
1353
-			}
1354
-			$main_content = $this->output( $args, $shortcode_args, $content );
1355
-			if ( $main_content && ! $no_wrap ) {
1356
-				// wrap the shortcode in a div with the same class as the widget
1357
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1358
-				if ( ! empty( $args['title'] ) ) {
1359
-					// if its a shortcode and there is a title try to grab the title wrappers
1360
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1361
-					if ( empty( $instance ) ) {
1362
-						global $wp_registered_sidebars;
1363
-						if ( ! empty( $wp_registered_sidebars ) ) {
1364
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1365
-								if ( ! empty( $sidebar['before_title'] ) ) {
1366
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1367
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1368
-									break;
1369
-								}
1370
-							}
1371
-						}
1372
-					}
1373
-					$output .= $this->output_title( $shortcode_args, $args );
1374
-				}
1375
-				$output .= $main_content;
1376
-				$output .= '</div>';
1377
-			} elseif ( $main_content && $no_wrap ) {
1378
-				$output .= $main_content;
1379
-			}
1380
-
1381
-			// if preview show a placeholder if empty
1382
-			if ( $this->is_preview() && $output == '' ) {
1383
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1384
-			}
1385
-
1386
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1387
-		}
1388
-
1389
-		/**
1390
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1391
-		 *
1392
-		 * @param string $name
1393
-		 *
1394
-		 * @return string
1395
-		 */
1396
-		public function preview_placeholder_text( $name = '' ) {
1397
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1398
-		}
1399
-
1400
-		/**
1401
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1402
-		 *
1403
-		 * @param $options
1404
-		 *
1405
-		 * @return mixed
1406
-		 */
1407
-		public function string_to_bool( $options ) {
1408
-			// convert bool strings to booleans
1409
-			foreach ( $options as $key => $val ) {
1410
-				if ( $val == 'false' ) {
1411
-					$options[ $key ] = false;
1412
-				} elseif ( $val == 'true' ) {
1413
-					$options[ $key ] = true;
1414
-				}
1415
-			}
1416
-
1417
-			return $options;
1418
-		}
1419
-
1420
-		/**
1421
-		 * Get the argument values that are also filterable.
1422
-		 *
1423
-		 * @param $instance
1424
-		 *
1425
-		 * @since 1.0.12 Don't set checkbox default value if the value is empty.
1426
-		 *
1427
-		 * @return array
1428
-		 */
1429
-		public function argument_values( $instance ) {
1430
-			$argument_values = array();
1431
-
1432
-			// set widget instance
1433
-			$this->instance = $instance;
1434
-
1435
-			if ( empty( $this->arguments ) ) {
1436
-				$this->arguments = $this->get_arguments();
1437
-			}
1438
-
1439
-			if ( ! empty( $this->arguments ) ) {
1440
-				foreach ( $this->arguments as $key => $args ) {
1441
-					// set the input name from the key
1442
-					$args['name'] = $key;
1443
-					//
1444
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1445
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1446
-						// don't set default for an empty checkbox
1447
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1448
-						$argument_values[ $key ] = $args['default'];
1449
-					}
1450
-				}
1451
-			}
1452
-
1453
-			return $argument_values;
1454
-		}
1455
-
1456
-		/**
1457
-		 * Set arguments in super duper.
1458
-		 *
1459
-		 * @since 1.0.0
1460
-		 *
1461
-		 * @return array Set arguments.
1462
-		 */
1463
-		public function set_arguments() {
1464
-			return $this->arguments;
1465
-		}
1466
-
1467
-		/**
1468
-		 * Get arguments in super duper.
1469
-		 *
1470
-		 * @since 1.0.0
1471
-		 *
1472
-		 * @return array Get arguments.
1473
-		 */
1474
-		public function get_arguments() {
1475
-			if ( empty( $this->arguments ) ) {
1476
-				$this->arguments = $this->set_arguments();
1477
-			}
1478
-
1479
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1480
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1481
-
1482
-			return $this->arguments;
1483
-		}
1484
-
1485
-		/**
1486
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1487
-		 *
1488
-		 * @param array $args
1489
-		 * @param array $widget_args
1490
-		 * @param string $content
1491
-		 */
1492
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1493
-
1494
-		}
1495
-
1496
-		/**
1497
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1498
-		 */
1499
-		public function register_block() {
1500
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1501
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1502
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1503
-			}
1504
-		}
1505
-
1506
-		/**
1507
-		 * Check if we need to show advanced options.
1508
-		 *
1509
-		 * @return bool
1510
-		 */
1511
-		public function block_show_advanced() {
1512
-
1513
-			$show      = false;
1514
-			$arguments = $this->arguments;
1515
-
1516
-			if ( empty( $arguments ) ) {
1517
-				$arguments = $this->get_arguments();
1518
-			}
1519
-
1520
-			if ( ! empty( $arguments ) ) {
1521
-				foreach ( $arguments as $argument ) {
1522
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1523
-						$show = true;
1524
-						break; // no need to continue if we know we have it
1525
-					}
1526
-				}
1527
-			}
1528
-
1529
-			return $show;
1530
-		}
1531
-
1532
-		/**
1533
-		 * Get the url path to the current folder.
1534
-		 *
1535
-		 * @return string
1536
-		 */
1537
-		public function get_url() {
1538
-
1539
-			$url = $this->url;
1540
-
1541
-			if ( ! $url ) {
1542
-				// check if we are inside a plugin
1543
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1544
-
1545
-				$dir_parts = explode( "/wp-content/", $file_dir );
1546
-				$url_parts = explode( "/wp-content/", plugins_url() );
1547
-
1548
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1549
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1550
-					$this->url = $url;
1551
-				}
1552
-			}
1553
-
1554
-
1555
-			return $url;
1556
-		}
1557
-
1558
-		/**
1559
-		 * Generate the block icon.
1560
-		 *
1561
-		 * Enables the use of Font Awesome icons.
1562
-		 *
1563
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1564
-		 *
1565
-		 * @param $icon
1566
-		 *
1567
-		 * @since 1.1.0
1568
-		 * @return string
1569
-		 */
1570
-		public function get_block_icon( $icon ) {
1571
-
1572
-			// check if we have a Font Awesome icon
1573
-			$fa_type = '';
1574
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1575
-				$fa_type = 'solid';
1576
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1577
-				$fa_type = 'regular';
1578
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1579
-				$fa_type = 'brands';
1580
-			} else {
1581
-				$icon = "'" . $icon . "'";
1582
-			}
1583
-
1584
-			// set the icon if we found one
1585
-			if ( $fa_type ) {
1586
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1587
-				$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 . "'}))";
1588
-			}
1589
-
1590
-			return $icon;
1591
-		}
1592
-
1593
-		public function group_arguments( $arguments ) {
1242
+            return str_replace( array(
1243
+                '<script>',
1244
+                '</script>'
1245
+            ), '', $output );
1246
+        }
1247
+
1248
+
1249
+        /**
1250
+         * Set the name from the argument key.
1251
+         *
1252
+         * @param $options
1253
+         *
1254
+         * @return mixed
1255
+         */
1256
+        private function add_name_from_key( $options, $arguments = false ) {
1257
+            if ( ! empty( $options['arguments'] ) ) {
1258
+                foreach ( $options['arguments'] as $key => $val ) {
1259
+                    $options['arguments'][ $key ]['name'] = $key;
1260
+                }
1261
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1262
+                foreach ( $options as $key => $val ) {
1263
+                    $options[ $key ]['name'] = $key;
1264
+                }
1265
+            }
1266
+
1267
+            return $options;
1268
+        }
1269
+
1270
+        /**
1271
+         * Register the parent shortcode.
1272
+         *
1273
+         * @since 1.0.0
1274
+         */
1275
+        public function register_shortcode() {
1276
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1277
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1278
+        }
1279
+
1280
+        /**
1281
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1282
+         *
1283
+         * @since 1.0.0
1284
+         */
1285
+        public static function render_shortcode() {
1286
+
1287
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1288
+            if ( ! current_user_can( 'manage_options' ) ) {
1289
+                wp_die();
1290
+            }
1291
+
1292
+            // we might need the $post value here so lets set it.
1293
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1294
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1295
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1296
+                    global $post;
1297
+                    $post = $post_obj;
1298
+                }
1299
+            }
1300
+
1301
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1302
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1303
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1304
+                $attributes       = '';
1305
+                if ( ! empty( $attributes_array ) ) {
1306
+                    foreach ( $attributes_array as $key => $value ) {
1307
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1308
+                    }
1309
+                }
1310
+
1311
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1312
+
1313
+                echo do_shortcode( $shortcode );
1314
+
1315
+            }
1316
+            wp_die();
1317
+        }
1318
+
1319
+        /**
1320
+         * Output the shortcode.
1321
+         *
1322
+         * @param array $args
1323
+         * @param string $content
1324
+         *
1325
+         * @return string
1326
+         */
1327
+        public function shortcode_output( $args = array(), $content = '' ) {
1328
+            $args = $this->argument_values( $args );
1329
+
1330
+            // add extra argument so we know its a output to gutenberg
1331
+            //$args
1332
+            $args = $this->string_to_bool( $args );
1333
+
1334
+            // if we have a enclosed shortcode we add it to the special `html` argument
1335
+            if ( ! empty( $content ) ) {
1336
+                $args['html'] = $content;
1337
+            }
1338
+
1339
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1340
+            $class .= " sdel-".$this->get_instance_hash();
1341
+
1342
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1343
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1344
+
1345
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1346
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1347
+
1348
+            $shortcode_args = array();
1349
+            $output         = '';
1350
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1351
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1352
+                $no_wrap = true;
1353
+            }
1354
+            $main_content = $this->output( $args, $shortcode_args, $content );
1355
+            if ( $main_content && ! $no_wrap ) {
1356
+                // wrap the shortcode in a div with the same class as the widget
1357
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1358
+                if ( ! empty( $args['title'] ) ) {
1359
+                    // if its a shortcode and there is a title try to grab the title wrappers
1360
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1361
+                    if ( empty( $instance ) ) {
1362
+                        global $wp_registered_sidebars;
1363
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1364
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1365
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1366
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1367
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1368
+                                    break;
1369
+                                }
1370
+                            }
1371
+                        }
1372
+                    }
1373
+                    $output .= $this->output_title( $shortcode_args, $args );
1374
+                }
1375
+                $output .= $main_content;
1376
+                $output .= '</div>';
1377
+            } elseif ( $main_content && $no_wrap ) {
1378
+                $output .= $main_content;
1379
+            }
1380
+
1381
+            // if preview show a placeholder if empty
1382
+            if ( $this->is_preview() && $output == '' ) {
1383
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1384
+            }
1385
+
1386
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1387
+        }
1388
+
1389
+        /**
1390
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1391
+         *
1392
+         * @param string $name
1393
+         *
1394
+         * @return string
1395
+         */
1396
+        public function preview_placeholder_text( $name = '' ) {
1397
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1398
+        }
1399
+
1400
+        /**
1401
+         * Sometimes booleans values can be turned to strings, so we fix that.
1402
+         *
1403
+         * @param $options
1404
+         *
1405
+         * @return mixed
1406
+         */
1407
+        public function string_to_bool( $options ) {
1408
+            // convert bool strings to booleans
1409
+            foreach ( $options as $key => $val ) {
1410
+                if ( $val == 'false' ) {
1411
+                    $options[ $key ] = false;
1412
+                } elseif ( $val == 'true' ) {
1413
+                    $options[ $key ] = true;
1414
+                }
1415
+            }
1416
+
1417
+            return $options;
1418
+        }
1419
+
1420
+        /**
1421
+         * Get the argument values that are also filterable.
1422
+         *
1423
+         * @param $instance
1424
+         *
1425
+         * @since 1.0.12 Don't set checkbox default value if the value is empty.
1426
+         *
1427
+         * @return array
1428
+         */
1429
+        public function argument_values( $instance ) {
1430
+            $argument_values = array();
1431
+
1432
+            // set widget instance
1433
+            $this->instance = $instance;
1434
+
1435
+            if ( empty( $this->arguments ) ) {
1436
+                $this->arguments = $this->get_arguments();
1437
+            }
1438
+
1439
+            if ( ! empty( $this->arguments ) ) {
1440
+                foreach ( $this->arguments as $key => $args ) {
1441
+                    // set the input name from the key
1442
+                    $args['name'] = $key;
1443
+                    //
1444
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1445
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1446
+                        // don't set default for an empty checkbox
1447
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1448
+                        $argument_values[ $key ] = $args['default'];
1449
+                    }
1450
+                }
1451
+            }
1452
+
1453
+            return $argument_values;
1454
+        }
1455
+
1456
+        /**
1457
+         * Set arguments in super duper.
1458
+         *
1459
+         * @since 1.0.0
1460
+         *
1461
+         * @return array Set arguments.
1462
+         */
1463
+        public function set_arguments() {
1464
+            return $this->arguments;
1465
+        }
1466
+
1467
+        /**
1468
+         * Get arguments in super duper.
1469
+         *
1470
+         * @since 1.0.0
1471
+         *
1472
+         * @return array Get arguments.
1473
+         */
1474
+        public function get_arguments() {
1475
+            if ( empty( $this->arguments ) ) {
1476
+                $this->arguments = $this->set_arguments();
1477
+            }
1478
+
1479
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1480
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1481
+
1482
+            return $this->arguments;
1483
+        }
1484
+
1485
+        /**
1486
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1487
+         *
1488
+         * @param array $args
1489
+         * @param array $widget_args
1490
+         * @param string $content
1491
+         */
1492
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1493
+
1494
+        }
1495
+
1496
+        /**
1497
+         * Add the dynamic block code inline when the wp-block in enqueued.
1498
+         */
1499
+        public function register_block() {
1500
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1501
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1502
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1503
+            }
1504
+        }
1505
+
1506
+        /**
1507
+         * Check if we need to show advanced options.
1508
+         *
1509
+         * @return bool
1510
+         */
1511
+        public function block_show_advanced() {
1512
+
1513
+            $show      = false;
1514
+            $arguments = $this->arguments;
1515
+
1516
+            if ( empty( $arguments ) ) {
1517
+                $arguments = $this->get_arguments();
1518
+            }
1519
+
1520
+            if ( ! empty( $arguments ) ) {
1521
+                foreach ( $arguments as $argument ) {
1522
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1523
+                        $show = true;
1524
+                        break; // no need to continue if we know we have it
1525
+                    }
1526
+                }
1527
+            }
1528
+
1529
+            return $show;
1530
+        }
1531
+
1532
+        /**
1533
+         * Get the url path to the current folder.
1534
+         *
1535
+         * @return string
1536
+         */
1537
+        public function get_url() {
1538
+
1539
+            $url = $this->url;
1540
+
1541
+            if ( ! $url ) {
1542
+                // check if we are inside a plugin
1543
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1544
+
1545
+                $dir_parts = explode( "/wp-content/", $file_dir );
1546
+                $url_parts = explode( "/wp-content/", plugins_url() );
1547
+
1548
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1549
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1550
+                    $this->url = $url;
1551
+                }
1552
+            }
1553
+
1554
+
1555
+            return $url;
1556
+        }
1557
+
1558
+        /**
1559
+         * Generate the block icon.
1560
+         *
1561
+         * Enables the use of Font Awesome icons.
1562
+         *
1563
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1564
+         *
1565
+         * @param $icon
1566
+         *
1567
+         * @since 1.1.0
1568
+         * @return string
1569
+         */
1570
+        public function get_block_icon( $icon ) {
1571
+
1572
+            // check if we have a Font Awesome icon
1573
+            $fa_type = '';
1574
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1575
+                $fa_type = 'solid';
1576
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1577
+                $fa_type = 'regular';
1578
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1579
+                $fa_type = 'brands';
1580
+            } else {
1581
+                $icon = "'" . $icon . "'";
1582
+            }
1583
+
1584
+            // set the icon if we found one
1585
+            if ( $fa_type ) {
1586
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1587
+                $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 . "'}))";
1588
+            }
1589
+
1590
+            return $icon;
1591
+        }
1592
+
1593
+        public function group_arguments( $arguments ) {
1594 1594
 //			echo '###';print_r($arguments);
1595
-			if ( ! empty( $arguments ) ) {
1596
-				$temp_arguments = array();
1597
-				$general        = __( "General" );
1598
-				$add_sections   = false;
1599
-				foreach ( $arguments as $key => $args ) {
1600
-					if ( isset( $args['group'] ) ) {
1601
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1602
-						$add_sections                             = true;
1603
-					} else {
1604
-						$temp_arguments[ $general ][ $key ] = $args;
1605
-					}
1606
-				}
1607
-
1608
-				// only add sections if more than one
1609
-				if ( $add_sections ) {
1610
-					$arguments = $temp_arguments;
1611
-				}
1612
-			}
1595
+            if ( ! empty( $arguments ) ) {
1596
+                $temp_arguments = array();
1597
+                $general        = __( "General" );
1598
+                $add_sections   = false;
1599
+                foreach ( $arguments as $key => $args ) {
1600
+                    if ( isset( $args['group'] ) ) {
1601
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1602
+                        $add_sections                             = true;
1603
+                    } else {
1604
+                        $temp_arguments[ $general ][ $key ] = $args;
1605
+                    }
1606
+                }
1607
+
1608
+                // only add sections if more than one
1609
+                if ( $add_sections ) {
1610
+                    $arguments = $temp_arguments;
1611
+                }
1612
+            }
1613 1613
 
1614 1614
 //			echo '###';print_r($arguments);
1615
-			return $arguments;
1616
-		}
1617
-
1618
-
1619
-		/**
1620
-		 * Output the JS for building the dynamic Guntenberg block.
1621
-		 *
1622
-		 * @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.
1623
-		 * @since 1.0.9 Save numbers as numbers and not strings.
1624
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1625
-		 * @return mixed
1626
-		 */
1627
-		public function block() {
1628
-			ob_start();
1629
-
1630
-			$show_advanced = $this->block_show_advanced();
1631
-			?>
1615
+            return $arguments;
1616
+        }
1617
+
1618
+
1619
+        /**
1620
+         * Output the JS for building the dynamic Guntenberg block.
1621
+         *
1622
+         * @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.
1623
+         * @since 1.0.9 Save numbers as numbers and not strings.
1624
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1625
+         * @return mixed
1626
+         */
1627
+        public function block() {
1628
+            ob_start();
1629
+
1630
+            $show_advanced = $this->block_show_advanced();
1631
+            ?>
1632 1632
 			<script>
1633 1633
 				/**
1634 1634
 				 * BLOCK: Basic
@@ -1672,97 +1672,97 @@  discard block
 block discarded – undo
1672 1672
 						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/.
1673 1673
 						supports: {
1674 1674
 							<?php
1675
-							if ( isset( $this->options['block-supports'] ) ) {
1676
-								echo $this->array_to_attributes( $this->options['block-supports'] );
1677
-							}
1678
-							?>
1675
+                            if ( isset( $this->options['block-supports'] ) ) {
1676
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
1677
+                            }
1678
+                            ?>
1679 1679
 						},
1680 1680
 						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.
1681 1681
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
1682
-						echo "keywords : " . $this->options['block-keywords'] . ",";
1683
-					}?>
1682
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
1683
+                    }?>
1684 1684
 
1685 1685
 						<?php
1686 1686
 
1687
-						// maybe set no_wrap
1688
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1689
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1690
-							$no_wrap = true;
1691
-						}
1692
-						if ( $no_wrap ) {
1693
-							$this->options['block-wrap'] = '';
1694
-						}
1687
+                        // maybe set no_wrap
1688
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1689
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1690
+                            $no_wrap = true;
1691
+                        }
1692
+                        if ( $no_wrap ) {
1693
+                            $this->options['block-wrap'] = '';
1694
+                        }
1695 1695
 
1696 1696
 
1697 1697
 
1698
-						$show_alignment = false;
1699
-						// align feature
1700
-						/*echo "supports: {";
1698
+                        $show_alignment = false;
1699
+                        // align feature
1700
+                        /*echo "supports: {";
1701 1701
 						echo "	align: true,";
1702 1702
 						echo "  html: false";
1703 1703
 						echo "},";*/
1704 1704
 
1705
-						if ( ! empty( $this->arguments ) ) {
1706
-							echo "attributes : {";
1707
-
1708
-							if ( $show_advanced ) {
1709
-								echo "show_advanced: {";
1710
-								echo "	type: 'boolean',";
1711
-								echo "  default: false,";
1712
-								echo "},";
1713
-							}
1714
-
1715
-							// block wrap element
1716
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1717
-								echo "block_wrap: {";
1718
-								echo "	type: 'string',";
1719
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1720
-								echo "},";
1721
-							}
1722
-
1723
-							foreach ( $this->arguments as $key => $args ) {
1724
-
1725
-								// set if we should show alignment
1726
-								if ( $key == 'alignment' ) {
1727
-									$show_alignment = true;
1728
-								}
1729
-
1730
-								$extra = '';
1731
-
1732
-								if ( $args['type'] == 'checkbox' ) {
1733
-									$type    = 'boolean';
1734
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1735
-								} elseif ( $args['type'] == 'number' ) {
1736
-									$type    = 'number';
1737
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1738
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1739
-									$type = 'array';
1740
-									if ( is_array( $args['default'] ) ) {
1741
-										$default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1742
-									} else {
1743
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1744
-									}
1745
-								} elseif ( $args['type'] == 'multiselect' ) {
1746
-									$type    = 'array';
1747
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1748
-								} else {
1749
-									$type    = 'string';
1750
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1751
-								}
1752
-								echo $key . " : {";
1753
-								echo "type : '$type',";
1754
-								echo "default : $default,";
1755
-								echo "},";
1756
-							}
1757
-
1758
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1759
-							echo "className: { type: 'string', default: '' },";
1760
-
1761
-							echo "},";
1762
-
1763
-						}
1764
-
1765
-						?>
1705
+                        if ( ! empty( $this->arguments ) ) {
1706
+                            echo "attributes : {";
1707
+
1708
+                            if ( $show_advanced ) {
1709
+                                echo "show_advanced: {";
1710
+                                echo "	type: 'boolean',";
1711
+                                echo "  default: false,";
1712
+                                echo "},";
1713
+                            }
1714
+
1715
+                            // block wrap element
1716
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1717
+                                echo "block_wrap: {";
1718
+                                echo "	type: 'string',";
1719
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1720
+                                echo "},";
1721
+                            }
1722
+
1723
+                            foreach ( $this->arguments as $key => $args ) {
1724
+
1725
+                                // set if we should show alignment
1726
+                                if ( $key == 'alignment' ) {
1727
+                                    $show_alignment = true;
1728
+                                }
1729
+
1730
+                                $extra = '';
1731
+
1732
+                                if ( $args['type'] == 'checkbox' ) {
1733
+                                    $type    = 'boolean';
1734
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1735
+                                } elseif ( $args['type'] == 'number' ) {
1736
+                                    $type    = 'number';
1737
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1738
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1739
+                                    $type = 'array';
1740
+                                    if ( is_array( $args['default'] ) ) {
1741
+                                        $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1742
+                                    } else {
1743
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1744
+                                    }
1745
+                                } elseif ( $args['type'] == 'multiselect' ) {
1746
+                                    $type    = 'array';
1747
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1748
+                                } else {
1749
+                                    $type    = 'string';
1750
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1751
+                                }
1752
+                                echo $key . " : {";
1753
+                                echo "type : '$type',";
1754
+                                echo "default : $default,";
1755
+                                echo "},";
1756
+                            }
1757
+
1758
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1759
+                            echo "className: { type: 'string', default: '' },";
1760
+
1761
+                            echo "},";
1762
+
1763
+                        }
1764
+
1765
+                        ?>
1766 1766
 
1767 1767
 						// The "edit" property must be a valid function.
1768 1768
 						edit: function (props) {
@@ -1770,9 +1770,9 @@  discard block
 block discarded – undo
1770 1770
 
1771 1771
 							var $value = '';
1772 1772
 							<?php
1773
-							// if we have a post_type and a category then link them
1774
-							if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1775
-							?>
1773
+                            // if we have a post_type and a category then link them
1774
+                            if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1775
+                            ?>
1776 1776
 							if(typeof(prev_attributes[props.id]) != 'undefined' ){
1777 1777
 								$pt = props.attributes.post_type;
1778 1778
 								if(post_type_rest_slugs.length){
@@ -1856,8 +1856,8 @@  discard block
 block discarded – undo
1856 1856
 										'shortcode': '<?php echo $this->options['base_id'];?>',
1857 1857
 										'attributes': props.attributes,
1858 1858
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
1859
-										echo $post->ID;
1860
-									}else{echo '0';}?>,
1859
+                                        echo $post->ID;
1860
+                                    }else{echo '0';}?>,
1861 1861
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
1862 1862
 									};
1863 1863
 
@@ -1909,10 +1909,10 @@  discard block
 block discarded – undo
1909 1909
 
1910 1910
 									<?php
1911 1911
 
1912
-									if(! empty( $this->arguments )){
1912
+                                    if(! empty( $this->arguments )){
1913 1913
 
1914
-									if ( $show_advanced ) {
1915
-									?>
1914
+                                    if ( $show_advanced ) {
1915
+                                    ?>
1916 1916
 									el('div', {
1917 1917
 											style: {'padding-left': '16px','padding-right': '16px'}
1918 1918
 										},
@@ -1930,79 +1930,79 @@  discard block
 block discarded – undo
1930 1930
 									,
1931 1931
 									<?php
1932 1932
 
1933
-									}
1933
+                                    }
1934 1934
 
1935
-									$arguments = $this->group_arguments( $this->arguments );
1935
+                                    $arguments = $this->group_arguments( $this->arguments );
1936 1936
 
1937
-									// Do we have sections?
1938
-									$has_sections = $arguments == $this->arguments ? false : true;
1937
+                                    // Do we have sections?
1938
+                                    $has_sections = $arguments == $this->arguments ? false : true;
1939 1939
 
1940 1940
 
1941
-									if($has_sections){
1942
-									$panel_count = 0;
1943
-									foreach($arguments as $key => $args){
1944
-									?>
1941
+                                    if($has_sections){
1942
+                                    $panel_count = 0;
1943
+                                    foreach($arguments as $key => $args){
1944
+                                    ?>
1945 1945
 									el(wp.components.PanelBody, {
1946 1946
 											title: '<?php esc_attr_e( $key ); ?>',
1947 1947
 											initialOpen: <?php if ( $panel_count ) {
1948
-											echo "false";
1949
-										} else {
1950
-											echo "true";
1951
-										}?>
1948
+                                            echo "false";
1949
+                                        } else {
1950
+                                            echo "true";
1951
+                                        }?>
1952 1952
 										},
1953 1953
 										<?php
1954 1954
 
1955 1955
 
1956 1956
 
1957
-										foreach ( $args as $k => $a ) {
1957
+                                        foreach ( $args as $k => $a ) {
1958 1958
 
1959
-											$this->block_row_start( $k, $a );
1960
-											$this->build_block_arguments( $k, $a );
1961
-											$this->block_row_end( $k, $a );
1962
-										}
1963
-										?>
1959
+                                            $this->block_row_start( $k, $a );
1960
+                                            $this->build_block_arguments( $k, $a );
1961
+                                            $this->block_row_end( $k, $a );
1962
+                                        }
1963
+                                        ?>
1964 1964
 									),
1965 1965
 									<?php
1966
-									$panel_count ++;
1966
+                                    $panel_count ++;
1967 1967
 
1968
-									}
1969
-									}else {
1970
-									?>
1968
+                                    }
1969
+                                    }else {
1970
+                                    ?>
1971 1971
 									el(wp.components.PanelBody, {
1972 1972
 											title: '<?php esc_attr_e( "Settings" ); ?>',
1973 1973
 											initialOpen: true
1974 1974
 										},
1975 1975
 										<?php
1976
-										foreach ( $this->arguments as $key => $args ) {
1977
-											$this->block_row_start( $key, $args );
1978
-											$this->build_block_arguments( $key, $args );
1979
-											$this->block_row_end( $key, $args );
1980
-										}
1981
-										?>
1976
+                                        foreach ( $this->arguments as $key => $args ) {
1977
+                                            $this->block_row_start( $key, $args );
1978
+                                            $this->build_block_arguments( $key, $args );
1979
+                                            $this->block_row_end( $key, $args );
1980
+                                        }
1981
+                                        ?>
1982 1982
 									),
1983 1983
 									<?php
1984
-									}
1984
+                                    }
1985 1985
 
1986
-									}
1987
-									?>
1986
+                                    }
1987
+                                    ?>
1988 1988
 
1989 1989
 								),
1990 1990
 
1991 1991
 								<?php
1992
-								// If the user sets block-output array then build it
1993
-								if ( ! empty( $this->options['block-output'] ) ) {
1994
-								$this->block_element( $this->options['block-output'] );
1995
-							}else{
1996
-								// if no block-output is set then we try and get the shortcode html output via ajax.
1997
-								?>
1992
+                                // If the user sets block-output array then build it
1993
+                                if ( ! empty( $this->options['block-output'] ) ) {
1994
+                                $this->block_element( $this->options['block-output'] );
1995
+                            }else{
1996
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
1997
+                                ?>
1998 1998
 								el('div', {
1999 1999
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
2000 2000
 									className: props.className,
2001 2001
 									style: {'minHeight': '30px'}
2002 2002
 								})
2003 2003
 								<?php
2004
-								}
2005
-								?>
2004
+                                }
2005
+                                ?>
2006 2006
 							]; // end return
2007 2007
 						},
2008 2008
 
@@ -2020,10 +2020,10 @@  discard block
 block discarded – undo
2020 2020
 							$html = '';
2021 2021
 							<?php
2022 2022
 
2023
-							if(! empty( $this->arguments )){
2023
+                            if(! empty( $this->arguments )){
2024 2024
 
2025
-							foreach($this->arguments as $key => $args){
2026
-							?>
2025
+                            foreach($this->arguments as $key => $args){
2026
+                            ?>
2027 2027
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2028 2028
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2029 2029
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2032,10 +2032,10 @@  discard block
 block discarded – undo
2032 2032
 								}
2033 2033
 							}
2034 2034
 							<?php
2035
-							}
2036
-							}
2035
+                            }
2036
+                            }
2037 2037
 
2038
-							?>
2038
+                            ?>
2039 2039
 							content += "]";
2040 2040
 
2041 2041
 							// if has html element
@@ -2058,20 +2058,20 @@  discard block
 block discarded – undo
2058 2058
 							}
2059 2059
 
2060 2060
 							<?php
2061
-							if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2062
-							?>
2061
+                            if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2062
+                            ?>
2063 2063
 							return content;
2064 2064
 							<?php
2065
-							}else{
2066
-							?>
2065
+                            }else{
2066
+                            ?>
2067 2067
 							var block_wrap = 'div';
2068 2068
 							if (attr.hasOwnProperty("block_wrap")) {
2069 2069
 								block_wrap = attr.block_wrap;
2070 2070
 							}
2071 2071
 							return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align});
2072 2072
 							<?php
2073
-							}
2074
-							?>
2073
+                            }
2074
+                            ?>
2075 2075
 
2076 2076
 
2077 2077
 						}
@@ -2079,30 +2079,30 @@  discard block
 block discarded – undo
2079 2079
 				})();
2080 2080
 			</script>
2081 2081
 			<?php
2082
-			$output = ob_get_clean();
2082
+            $output = ob_get_clean();
2083 2083
 
2084
-			/*
2084
+            /*
2085 2085
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2086 2086
 			 */
2087 2087
 
2088
-			return str_replace( array(
2089
-				'<script>',
2090
-				'</script>'
2091
-			), '', $output );
2092
-		}
2088
+            return str_replace( array(
2089
+                '<script>',
2090
+                '</script>'
2091
+            ), '', $output );
2092
+        }
2093 2093
 
2094
-		public function block_row_start($key, $args){
2094
+        public function block_row_start($key, $args){
2095 2095
 
2096
-			// check for row
2097
-			if(!empty($args['row'])){
2096
+            // check for row
2097
+            if(!empty($args['row'])){
2098 2098
 
2099
-				if(!empty($args['row']['open'])){
2099
+                if(!empty($args['row']['open'])){
2100 2100
 
2101
-				// element require
2102
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2103
-				echo $element_require;
2101
+                // element require
2102
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2103
+                echo $element_require;
2104 2104
 
2105
-					if(false){?><script><?php }?>
2105
+                    if(false){?><script><?php }?>
2106 2106
 						el('div', {
2107 2107
 								className: 'bsui components-base-control',
2108 2108
 							},
@@ -2132,87 +2132,87 @@  discard block
 block discarded – undo
2132 2132
 									},
2133 2133
 
2134 2134
 					<?php
2135
-					if(false){?></script><?php }
2136
-				}elseif(!empty($args['row']['close'])){
2137
-					if(false){?><script><?php }?>
2135
+                    if(false){?></script><?php }
2136
+                }elseif(!empty($args['row']['close'])){
2137
+                    if(false){?><script><?php }?>
2138 2138
 						el(
2139 2139
 							'div',
2140 2140
 							{
2141 2141
 								className: 'col pl-0',
2142 2142
 							},
2143 2143
 					<?php
2144
-					if(false){?></script><?php }
2145
-				}else{
2146
-					if(false){?><script><?php }?>
2144
+                    if(false){?></script><?php }
2145
+                }else{
2146
+                    if(false){?><script><?php }?>
2147 2147
 						el(
2148 2148
 							'div',
2149 2149
 							{
2150 2150
 								className: 'col pl-0 pr-2',
2151 2151
 							},
2152 2152
 					<?php
2153
-					if(false){?></script><?php }
2154
-				}
2155
-
2156
-			}
2157
-
2158
-		}
2159
-
2160
-		public function block_row_end($key, $args){
2161
-
2162
-			if(!empty($args['row'])){
2163
-				// maybe close
2164
-				if(!empty($args['row']['close'])){
2165
-					echo "))";
2166
-				}
2167
-
2168
-				echo "),";
2169
-			}
2170
-		}
2171
-
2172
-		public function build_block_arguments( $key, $args ) {
2173
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2174
-			$options           = '';
2175
-			$extra             = '';
2176
-			$require           = '';
2177
-
2178
-			// `content` is a protected and special argument
2179
-			if ( $key == 'content' ) {
2180
-				return;
2181
-			}
2182
-
2183
-
2184
-			// icon
2185
-			$icon = '';
2186
-			if( !empty( $args['icon'] ) ){
2187
-				$icon .= "el('div', {";
2188
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2189
-									$icon .= "className: 'text-center',";
2190
-									$icon .= "title: '".addslashes( $args['title'] )."',";
2191
-								$icon .= "}),";
2192
-
2193
-				// blank title as its added to the icon.
2194
-				$args['title'] = '';
2195
-			}
2196
-
2197
-			// require advanced
2198
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2199
-
2200
-			// element require
2201
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2202
-
2203
-
2204
-			$onchange  = "props.setAttributes({ $key: $key } )";
2205
-			$onchangecomplete  = "";
2206
-			$value     = "props.attributes.$key";
2207
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2208
-			if ( in_array( $args['type'], $text_type ) ) {
2209
-				$type = 'TextControl';
2210
-				// Save numbers as numbers and not strings
2211
-				if ( $args['type'] == 'number' ) {
2212
-					$onchange = "props.setAttributes({ $key: Number($key) } )";
2213
-				}
2214
-			}
2215
-			/*
2153
+                    if(false){?></script><?php }
2154
+                }
2155
+
2156
+            }
2157
+
2158
+        }
2159
+
2160
+        public function block_row_end($key, $args){
2161
+
2162
+            if(!empty($args['row'])){
2163
+                // maybe close
2164
+                if(!empty($args['row']['close'])){
2165
+                    echo "))";
2166
+                }
2167
+
2168
+                echo "),";
2169
+            }
2170
+        }
2171
+
2172
+        public function build_block_arguments( $key, $args ) {
2173
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2174
+            $options           = '';
2175
+            $extra             = '';
2176
+            $require           = '';
2177
+
2178
+            // `content` is a protected and special argument
2179
+            if ( $key == 'content' ) {
2180
+                return;
2181
+            }
2182
+
2183
+
2184
+            // icon
2185
+            $icon = '';
2186
+            if( !empty( $args['icon'] ) ){
2187
+                $icon .= "el('div', {";
2188
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2189
+                                    $icon .= "className: 'text-center',";
2190
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
2191
+                                $icon .= "}),";
2192
+
2193
+                // blank title as its added to the icon.
2194
+                $args['title'] = '';
2195
+            }
2196
+
2197
+            // require advanced
2198
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2199
+
2200
+            // element require
2201
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2202
+
2203
+
2204
+            $onchange  = "props.setAttributes({ $key: $key } )";
2205
+            $onchangecomplete  = "";
2206
+            $value     = "props.attributes.$key";
2207
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2208
+            if ( in_array( $args['type'], $text_type ) ) {
2209
+                $type = 'TextControl';
2210
+                // Save numbers as numbers and not strings
2211
+                if ( $args['type'] == 'number' ) {
2212
+                    $onchange = "props.setAttributes({ $key: Number($key) } )";
2213
+                }
2214
+            }
2215
+            /*
2216 2216
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
2217 2217
 						elseif($args['type']=='tabs'){
2218 2218
 							?>
@@ -2246,85 +2246,85 @@  discard block
 block discarded – undo
2246 2246
 							return;
2247 2247
 						}
2248 2248
 			*/
2249
-			elseif ( $args['type'] == 'color' ) {
2250
-				$type = 'ColorPicker';
2251
-				$onchange = "";
2252
-				$extra = "color: $value,";
2253
-				if(!empty($args['disable_alpha'])){
2254
-					$extra .= "disableAlpha: true,";
2255
-				}
2256
-				$onchangecomplete = "onChangeComplete: function($key) {
2249
+            elseif ( $args['type'] == 'color' ) {
2250
+                $type = 'ColorPicker';
2251
+                $onchange = "";
2252
+                $extra = "color: $value,";
2253
+                if(!empty($args['disable_alpha'])){
2254
+                    $extra .= "disableAlpha: true,";
2255
+                }
2256
+                $onchangecomplete = "onChangeComplete: function($key) {
2257 2257
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
2258 2258
                         props.setAttributes({
2259 2259
                             $key: value
2260 2260
                         });
2261 2261
                     },";
2262
-			}
2263
-			elseif ( $args['type'] == 'checkbox' ) {
2264
-				$type = 'CheckboxControl';
2265
-				$extra .= "checked: props.attributes.$key,";
2266
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2267
-			} elseif ( $args['type'] == 'textarea' ) {
2268
-				$type = 'TextareaControl';
2269
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2270
-				$type = 'SelectControl';
2271
-
2272
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2273
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2274
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2275
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2276
-				}else {
2277
-
2278
-					if ( ! empty( $args['options'] ) ) {
2279
-						$options .= "options: [";
2280
-						foreach ( $args['options'] as $option_val => $option_label ) {
2281
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2282
-						}
2283
-						$options .= "],";
2284
-					}
2285
-				}
2286
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2287
-					$extra .= ' multiple: true, ';
2288
-				}
2289
-			} elseif ( $args['type'] == 'alignment' ) {
2290
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2291
-			}elseif ( $args['type'] == 'margins' ) {
2292
-
2293
-			} else {
2294
-				return;// if we have not implemented the control then don't break the JS.
2295
-			}
2296
-
2297
-
2298
-
2299
-			// color input does not show the labels so we add them
2300
-			if($args['type']=='color'){
2301
-				// add show only if advanced
2302
-				echo $require_advanced;
2303
-				// add setting require if defined
2304
-				echo $element_require;
2305
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2306
-			}
2307
-
2308
-			// add show only if advanced
2309
-			echo $require_advanced;
2310
-			// add setting require if defined
2311
-			echo $element_require;
2312
-
2313
-			// icon
2314
-			echo $icon;
2315
-			?>
2262
+            }
2263
+            elseif ( $args['type'] == 'checkbox' ) {
2264
+                $type = 'CheckboxControl';
2265
+                $extra .= "checked: props.attributes.$key,";
2266
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2267
+            } elseif ( $args['type'] == 'textarea' ) {
2268
+                $type = 'TextareaControl';
2269
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2270
+                $type = 'SelectControl';
2271
+
2272
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2273
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2274
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2275
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2276
+                }else {
2277
+
2278
+                    if ( ! empty( $args['options'] ) ) {
2279
+                        $options .= "options: [";
2280
+                        foreach ( $args['options'] as $option_val => $option_label ) {
2281
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2282
+                        }
2283
+                        $options .= "],";
2284
+                    }
2285
+                }
2286
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2287
+                    $extra .= ' multiple: true, ';
2288
+                }
2289
+            } elseif ( $args['type'] == 'alignment' ) {
2290
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2291
+            }elseif ( $args['type'] == 'margins' ) {
2292
+
2293
+            } else {
2294
+                return;// if we have not implemented the control then don't break the JS.
2295
+            }
2296
+
2297
+
2298
+
2299
+            // color input does not show the labels so we add them
2300
+            if($args['type']=='color'){
2301
+                // add show only if advanced
2302
+                echo $require_advanced;
2303
+                // add setting require if defined
2304
+                echo $element_require;
2305
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2306
+            }
2307
+
2308
+            // add show only if advanced
2309
+            echo $require_advanced;
2310
+            // add setting require if defined
2311
+            echo $element_require;
2312
+
2313
+            // icon
2314
+            echo $icon;
2315
+            ?>
2316 2316
 			el( wp.components.<?php echo $type; ?>, {
2317 2317
 			label: '<?php echo addslashes( $args['title'] ); ?>',
2318 2318
 			help: '<?php if ( isset( $args['desc'] ) ) {
2319
-				echo addslashes( $args['desc'] );
2320
-			} ?>',
2319
+                echo addslashes( $args['desc'] );
2320
+            } ?>',
2321 2321
 			value: <?php echo $value; ?>,
2322 2322
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
2323
-				echo "type: '" . addslashes( $args['type'] ) . "',";
2324
-			} ?>
2323
+                echo "type: '" . addslashes( $args['type'] ) . "',";
2324
+            } ?>
2325 2325
 			<?php if ( ! empty( $args['placeholder'] ) ) {
2326
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2327
-			} ?>
2326
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2327
+            } ?>
2328 2328
 			<?php echo $options; ?>
2329 2329
 			<?php echo $extra; ?>
2330 2330
 			<?php echo $custom_attributes; ?>
@@ -2336,601 +2336,601 @@  discard block
 block discarded – undo
2336 2336
 			<?php
2337 2337
 
2338 2338
 
2339
-		}
2340
-
2341
-		/**
2342
-		 * Convert an array of attributes to block string.
2343
-		 *
2344
-		 * @todo there is prob a faster way to do this, also we could add some validation here.
2345
-		 *
2346
-		 * @param $custom_attributes
2347
-		 *
2348
-		 * @return string
2349
-		 */
2350
-		public function array_to_attributes( $custom_attributes, $html = false ) {
2351
-			$attributes = '';
2352
-			if ( ! empty( $custom_attributes ) ) {
2353
-
2354
-				if ( $html ) {
2355
-					foreach ( $custom_attributes as $key => $val ) {
2356
-						$attributes .= " $key='$val' ";
2357
-					}
2358
-				} else {
2359
-					foreach ( $custom_attributes as $key => $val ) {
2360
-						$attributes .= "'$key': '$val',";
2361
-					}
2362
-				}
2363
-			}
2364
-
2365
-			return $attributes;
2366
-		}
2367
-
2368
-		/**
2369
-		 * A self looping function to create the output for JS block elements.
2370
-		 *
2371
-		 * This is what is output in the WP Editor visual view.
2372
-		 *
2373
-		 * @param $args
2374
-		 */
2375
-		public function block_element( $args ) {
2376
-
2377
-
2378
-			if ( ! empty( $args ) ) {
2379
-				foreach ( $args as $element => $new_args ) {
2380
-
2381
-					if ( is_array( $new_args ) ) { // its an element
2382
-
2383
-
2384
-						if ( isset( $new_args['element'] ) ) {
2385
-
2386
-							if ( isset( $new_args['element_require'] ) ) {
2387
-								echo str_replace( array(
2388
-										"'+",
2389
-										"+'"
2390
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2391
-								unset( $new_args['element_require'] );
2392
-							}
2393
-
2394
-							echo "\n el( '" . $new_args['element'] . "', {";
2395
-
2396
-							// get the attributes
2397
-							foreach ( $new_args as $new_key => $new_value ) {
2398
-
2399
-
2400
-								if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2401
-									// do nothing
2402
-								} else {
2403
-									echo $this->block_element( array( $new_key => $new_value ) );
2404
-								}
2405
-							}
2406
-
2407
-							echo "},";// end attributes
2408
-
2409
-							// get the content
2410
-							$first_item = 0;
2411
-							foreach ( $new_args as $new_key => $new_value ) {
2412
-								if ( $new_key === 'content' || is_array( $new_value ) ) {
2413
-
2414
-									if ( $new_key === 'content' ) {
2415
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2416
-									}
2417
-
2418
-									if ( is_array( $new_value ) ) {
2419
-
2420
-										if ( isset( $new_value['element_require'] ) ) {
2421
-											echo str_replace( array(
2422
-													"'+",
2423
-													"+'"
2424
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2425
-											unset( $new_value['element_require'] );
2426
-										}
2427
-
2428
-										if ( isset( $new_value['element_repeat'] ) ) {
2429
-											$x = 1;
2430
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
2431
-												$this->block_element( array( '' => $new_value ) );
2432
-												$x ++;
2433
-											}
2434
-										} else {
2435
-											$this->block_element( array( '' => $new_value ) );
2436
-										}
2437
-									}
2438
-									$first_item ++;
2439
-								}
2440
-							}
2441
-
2442
-							echo ")";// end content
2443
-
2444
-							echo ", \n";
2445
-
2446
-						}
2447
-					} else {
2448
-
2449
-						if ( substr( $element, 0, 3 ) === "if_" ) {
2450
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2451
-						} elseif ( $element == 'style' ) {
2452
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2453
-						} else {
2454
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2455
-						}
2456
-
2457
-					}
2458
-				}
2459
-			}
2460
-		}
2461
-
2462
-		/**
2463
-		 * Replace block attributes placeholders with the proper naming.
2464
-		 *
2465
-		 * @param $string
2466
-		 *
2467
-		 * @return mixed
2468
-		 */
2469
-		public function block_props_replace( $string, $no_wrap = false ) {
2470
-
2471
-			if ( $no_wrap ) {
2472
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2473
-			} else {
2474
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2475
-			}
2476
-
2477
-			return $string;
2478
-		}
2479
-
2480
-		/**
2481
-		 * Outputs the content of the widget
2482
-		 *
2483
-		 * @param array $args
2484
-		 * @param array $instance
2485
-		 */
2486
-		public function widget( $args, $instance ) {
2487
-
2488
-			// get the filtered values
2489
-			$argument_values = $this->argument_values( $instance );
2490
-			$argument_values = $this->string_to_bool( $argument_values );
2491
-			$output          = $this->output( $argument_values, $args );
2492
-
2493
-			$no_wrap = false;
2494
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2495
-				$no_wrap = true;
2496
-			}
2497
-
2498
-			ob_start();
2499
-			if ( $output && ! $no_wrap ) {
2500
-
2501
-				$class_original = $this->options['widget_ops']['classname'];
2502
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2503
-
2504
-				// Before widget
2505
-				$before_widget = $args['before_widget'];
2506
-				$before_widget = str_replace($class_original,$class,$before_widget);
2507
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2508
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2509
-
2510
-				// After widget
2511
-				$after_widget = $args['after_widget'];
2512
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2513
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2514
-
2515
-				echo $before_widget;
2516
-				// elementor strips the widget wrapping div so we check for and add it back if needed
2517
-				if ( $this->is_elementor_widget_output() ) {
2518
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2519
-				}
2520
-				echo $this->output_title( $args, $instance );
2521
-				echo $output;
2522
-				if ( $this->is_elementor_widget_output() ) {
2523
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2524
-				}
2525
-				echo $after_widget;
2526
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2527
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2528
-				echo $output;
2529
-			} elseif ( $output && $no_wrap ) {
2530
-				echo $output;
2531
-			}
2532
-			$output = ob_get_clean();
2533
-
2534
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2535
-
2536
-			echo $output;
2537
-		}
2538
-
2539
-		/**
2540
-		 * Tests if the current output is inside a elementor container.
2541
-		 *
2542
-		 * @since 1.0.4
2543
-		 * @return bool
2544
-		 */
2545
-		public function is_elementor_widget_output() {
2546
-			$result = false;
2547
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2548
-				$result = true;
2549
-			}
2550
-
2551
-			return $result;
2552
-		}
2553
-
2554
-		/**
2555
-		 * Tests if the current output is inside a elementor preview.
2556
-		 *
2557
-		 * @since 1.0.4
2558
-		 * @return bool
2559
-		 */
2560
-		public function is_elementor_preview() {
2561
-			$result = false;
2562
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2563
-				$result = true;
2564
-			}
2565
-
2566
-			return $result;
2567
-		}
2568
-
2569
-		/**
2570
-		 * Tests if the current output is inside a Divi preview.
2571
-		 *
2572
-		 * @since 1.0.6
2573
-		 * @return bool
2574
-		 */
2575
-		public function is_divi_preview() {
2576
-			$result = false;
2577
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2578
-				$result = true;
2579
-			}
2580
-
2581
-			return $result;
2582
-		}
2583
-
2584
-		/**
2585
-		 * Tests if the current output is inside a Beaver builder preview.
2586
-		 *
2587
-		 * @since 1.0.6
2588
-		 * @return bool
2589
-		 */
2590
-		public function is_beaver_preview() {
2591
-			$result = false;
2592
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
2593
-				$result = true;
2594
-			}
2595
-
2596
-			return $result;
2597
-		}
2598
-
2599
-		/**
2600
-		 * Tests if the current output is inside a siteorigin builder preview.
2601
-		 *
2602
-		 * @since 1.0.6
2603
-		 * @return bool
2604
-		 */
2605
-		public function is_siteorigin_preview() {
2606
-			$result = false;
2607
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2608
-				$result = true;
2609
-			}
2610
-
2611
-			return $result;
2612
-		}
2613
-
2614
-		/**
2615
-		 * Tests if the current output is inside a cornerstone builder preview.
2616
-		 *
2617
-		 * @since 1.0.8
2618
-		 * @return bool
2619
-		 */
2620
-		public function is_cornerstone_preview() {
2621
-			$result = false;
2622
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2623
-				$result = true;
2624
-			}
2625
-
2626
-			return $result;
2627
-		}
2628
-
2629
-		/**
2630
-		 * Tests if the current output is inside a fusion builder preview.
2631
-		 *
2632
-		 * @since 1.1.0
2633
-		 * @return bool
2634
-		 */
2635
-		public function is_fusion_preview() {
2636
-			$result = false;
2637
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2638
-				$result = true;
2639
-			}
2640
-
2641
-			return $result;
2642
-		}
2643
-
2644
-		/**
2645
-		 * Tests if the current output is inside a Oxygen builder preview.
2646
-		 *
2647
-		 * @since 1.0.18
2648
-		 * @return bool
2649
-		 */
2650
-		public function is_oxygen_preview() {
2651
-			$result = false;
2652
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2653
-				$result = true;
2654
-			}
2655
-
2656
-			return $result;
2657
-		}
2658
-
2659
-		/**
2660
-		 * General function to check if we are in a preview situation.
2661
-		 *
2662
-		 * @since 1.0.6
2663
-		 * @return bool
2664
-		 */
2665
-		public function is_preview() {
2666
-			$preview = false;
2667
-			if ( $this->is_divi_preview() ) {
2668
-				$preview = true;
2669
-			} elseif ( $this->is_elementor_preview() ) {
2670
-				$preview = true;
2671
-			} elseif ( $this->is_beaver_preview() ) {
2672
-				$preview = true;
2673
-			} elseif ( $this->is_siteorigin_preview() ) {
2674
-				$preview = true;
2675
-			} elseif ( $this->is_cornerstone_preview() ) {
2676
-				$preview = true;
2677
-			} elseif ( $this->is_fusion_preview() ) {
2678
-				$preview = true;
2679
-			} elseif ( $this->is_oxygen_preview() ) {
2680
-				$preview = true;
2681
-			} elseif( $this->is_block_content_call() ) {
2682
-				$preview = true;
2683
-			}
2684
-
2685
-			return $preview;
2686
-		}
2687
-
2688
-		/**
2689
-		 * Output the super title.
2690
-		 *
2691
-		 * @param $args
2692
-		 * @param array $instance
2693
-		 *
2694
-		 * @return string
2695
-		 */
2696
-		public function output_title( $args, $instance = array() ) {
2697
-			$output = '';
2698
-			if ( ! empty( $instance['title'] ) ) {
2699
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2700
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2701
-
2702
-				if(empty($instance['widget_title_tag'])){
2703
-					$output = $args['before_title'] . $title . $args['after_title'];
2704
-				}else{
2705
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
2706
-
2707
-					// classes
2708
-					$title_classes = array();
2709
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2710
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2711
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2712
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2713
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2714
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2715
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2716
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2717
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2718
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2719
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2720
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2721
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2722
-
2723
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2724
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
2725
-				}
2726
-
2727
-			}
2728
-
2729
-			return $output;
2730
-		}
2731
-
2732
-		/**
2733
-		 * Outputs the options form inputs for the widget.
2734
-		 *
2735
-		 * @param array $instance The widget options.
2736
-		 */
2737
-		public function form( $instance ) {
2738
-
2739
-			// set widget instance
2740
-			$this->instance = $instance;
2741
-
2742
-			// set it as a SD widget
2743
-			echo $this->widget_advanced_toggle();
2744
-
2745
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2746
-			$arguments_raw = $this->get_arguments();
2747
-
2748
-			if ( is_array( $arguments_raw ) ) {
2749
-
2750
-				$arguments = $this->group_arguments( $arguments_raw );
2751
-
2752
-				// Do we have sections?
2753
-				$has_sections = $arguments == $arguments_raw ? false : true;
2754
-
2755
-
2756
-				if ( $has_sections ) {
2757
-					$panel_count = 0;
2758
-					foreach ( $arguments as $key => $args ) {
2759
-
2760
-						?>
2339
+        }
2340
+
2341
+        /**
2342
+         * Convert an array of attributes to block string.
2343
+         *
2344
+         * @todo there is prob a faster way to do this, also we could add some validation here.
2345
+         *
2346
+         * @param $custom_attributes
2347
+         *
2348
+         * @return string
2349
+         */
2350
+        public function array_to_attributes( $custom_attributes, $html = false ) {
2351
+            $attributes = '';
2352
+            if ( ! empty( $custom_attributes ) ) {
2353
+
2354
+                if ( $html ) {
2355
+                    foreach ( $custom_attributes as $key => $val ) {
2356
+                        $attributes .= " $key='$val' ";
2357
+                    }
2358
+                } else {
2359
+                    foreach ( $custom_attributes as $key => $val ) {
2360
+                        $attributes .= "'$key': '$val',";
2361
+                    }
2362
+                }
2363
+            }
2364
+
2365
+            return $attributes;
2366
+        }
2367
+
2368
+        /**
2369
+         * A self looping function to create the output for JS block elements.
2370
+         *
2371
+         * This is what is output in the WP Editor visual view.
2372
+         *
2373
+         * @param $args
2374
+         */
2375
+        public function block_element( $args ) {
2376
+
2377
+
2378
+            if ( ! empty( $args ) ) {
2379
+                foreach ( $args as $element => $new_args ) {
2380
+
2381
+                    if ( is_array( $new_args ) ) { // its an element
2382
+
2383
+
2384
+                        if ( isset( $new_args['element'] ) ) {
2385
+
2386
+                            if ( isset( $new_args['element_require'] ) ) {
2387
+                                echo str_replace( array(
2388
+                                        "'+",
2389
+                                        "+'"
2390
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2391
+                                unset( $new_args['element_require'] );
2392
+                            }
2393
+
2394
+                            echo "\n el( '" . $new_args['element'] . "', {";
2395
+
2396
+                            // get the attributes
2397
+                            foreach ( $new_args as $new_key => $new_value ) {
2398
+
2399
+
2400
+                                if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2401
+                                    // do nothing
2402
+                                } else {
2403
+                                    echo $this->block_element( array( $new_key => $new_value ) );
2404
+                                }
2405
+                            }
2406
+
2407
+                            echo "},";// end attributes
2408
+
2409
+                            // get the content
2410
+                            $first_item = 0;
2411
+                            foreach ( $new_args as $new_key => $new_value ) {
2412
+                                if ( $new_key === 'content' || is_array( $new_value ) ) {
2413
+
2414
+                                    if ( $new_key === 'content' ) {
2415
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2416
+                                    }
2417
+
2418
+                                    if ( is_array( $new_value ) ) {
2419
+
2420
+                                        if ( isset( $new_value['element_require'] ) ) {
2421
+                                            echo str_replace( array(
2422
+                                                    "'+",
2423
+                                                    "+'"
2424
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2425
+                                            unset( $new_value['element_require'] );
2426
+                                        }
2427
+
2428
+                                        if ( isset( $new_value['element_repeat'] ) ) {
2429
+                                            $x = 1;
2430
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
2431
+                                                $this->block_element( array( '' => $new_value ) );
2432
+                                                $x ++;
2433
+                                            }
2434
+                                        } else {
2435
+                                            $this->block_element( array( '' => $new_value ) );
2436
+                                        }
2437
+                                    }
2438
+                                    $first_item ++;
2439
+                                }
2440
+                            }
2441
+
2442
+                            echo ")";// end content
2443
+
2444
+                            echo ", \n";
2445
+
2446
+                        }
2447
+                    } else {
2448
+
2449
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
2450
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2451
+                        } elseif ( $element == 'style' ) {
2452
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2453
+                        } else {
2454
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2455
+                        }
2456
+
2457
+                    }
2458
+                }
2459
+            }
2460
+        }
2461
+
2462
+        /**
2463
+         * Replace block attributes placeholders with the proper naming.
2464
+         *
2465
+         * @param $string
2466
+         *
2467
+         * @return mixed
2468
+         */
2469
+        public function block_props_replace( $string, $no_wrap = false ) {
2470
+
2471
+            if ( $no_wrap ) {
2472
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2473
+            } else {
2474
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2475
+            }
2476
+
2477
+            return $string;
2478
+        }
2479
+
2480
+        /**
2481
+         * Outputs the content of the widget
2482
+         *
2483
+         * @param array $args
2484
+         * @param array $instance
2485
+         */
2486
+        public function widget( $args, $instance ) {
2487
+
2488
+            // get the filtered values
2489
+            $argument_values = $this->argument_values( $instance );
2490
+            $argument_values = $this->string_to_bool( $argument_values );
2491
+            $output          = $this->output( $argument_values, $args );
2492
+
2493
+            $no_wrap = false;
2494
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2495
+                $no_wrap = true;
2496
+            }
2497
+
2498
+            ob_start();
2499
+            if ( $output && ! $no_wrap ) {
2500
+
2501
+                $class_original = $this->options['widget_ops']['classname'];
2502
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2503
+
2504
+                // Before widget
2505
+                $before_widget = $args['before_widget'];
2506
+                $before_widget = str_replace($class_original,$class,$before_widget);
2507
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2508
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2509
+
2510
+                // After widget
2511
+                $after_widget = $args['after_widget'];
2512
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2513
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2514
+
2515
+                echo $before_widget;
2516
+                // elementor strips the widget wrapping div so we check for and add it back if needed
2517
+                if ( $this->is_elementor_widget_output() ) {
2518
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2519
+                }
2520
+                echo $this->output_title( $args, $instance );
2521
+                echo $output;
2522
+                if ( $this->is_elementor_widget_output() ) {
2523
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2524
+                }
2525
+                echo $after_widget;
2526
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2527
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2528
+                echo $output;
2529
+            } elseif ( $output && $no_wrap ) {
2530
+                echo $output;
2531
+            }
2532
+            $output = ob_get_clean();
2533
+
2534
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2535
+
2536
+            echo $output;
2537
+        }
2538
+
2539
+        /**
2540
+         * Tests if the current output is inside a elementor container.
2541
+         *
2542
+         * @since 1.0.4
2543
+         * @return bool
2544
+         */
2545
+        public function is_elementor_widget_output() {
2546
+            $result = false;
2547
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2548
+                $result = true;
2549
+            }
2550
+
2551
+            return $result;
2552
+        }
2553
+
2554
+        /**
2555
+         * Tests if the current output is inside a elementor preview.
2556
+         *
2557
+         * @since 1.0.4
2558
+         * @return bool
2559
+         */
2560
+        public function is_elementor_preview() {
2561
+            $result = false;
2562
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2563
+                $result = true;
2564
+            }
2565
+
2566
+            return $result;
2567
+        }
2568
+
2569
+        /**
2570
+         * Tests if the current output is inside a Divi preview.
2571
+         *
2572
+         * @since 1.0.6
2573
+         * @return bool
2574
+         */
2575
+        public function is_divi_preview() {
2576
+            $result = false;
2577
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2578
+                $result = true;
2579
+            }
2580
+
2581
+            return $result;
2582
+        }
2583
+
2584
+        /**
2585
+         * Tests if the current output is inside a Beaver builder preview.
2586
+         *
2587
+         * @since 1.0.6
2588
+         * @return bool
2589
+         */
2590
+        public function is_beaver_preview() {
2591
+            $result = false;
2592
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
2593
+                $result = true;
2594
+            }
2595
+
2596
+            return $result;
2597
+        }
2598
+
2599
+        /**
2600
+         * Tests if the current output is inside a siteorigin builder preview.
2601
+         *
2602
+         * @since 1.0.6
2603
+         * @return bool
2604
+         */
2605
+        public function is_siteorigin_preview() {
2606
+            $result = false;
2607
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2608
+                $result = true;
2609
+            }
2610
+
2611
+            return $result;
2612
+        }
2613
+
2614
+        /**
2615
+         * Tests if the current output is inside a cornerstone builder preview.
2616
+         *
2617
+         * @since 1.0.8
2618
+         * @return bool
2619
+         */
2620
+        public function is_cornerstone_preview() {
2621
+            $result = false;
2622
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2623
+                $result = true;
2624
+            }
2625
+
2626
+            return $result;
2627
+        }
2628
+
2629
+        /**
2630
+         * Tests if the current output is inside a fusion builder preview.
2631
+         *
2632
+         * @since 1.1.0
2633
+         * @return bool
2634
+         */
2635
+        public function is_fusion_preview() {
2636
+            $result = false;
2637
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2638
+                $result = true;
2639
+            }
2640
+
2641
+            return $result;
2642
+        }
2643
+
2644
+        /**
2645
+         * Tests if the current output is inside a Oxygen builder preview.
2646
+         *
2647
+         * @since 1.0.18
2648
+         * @return bool
2649
+         */
2650
+        public function is_oxygen_preview() {
2651
+            $result = false;
2652
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2653
+                $result = true;
2654
+            }
2655
+
2656
+            return $result;
2657
+        }
2658
+
2659
+        /**
2660
+         * General function to check if we are in a preview situation.
2661
+         *
2662
+         * @since 1.0.6
2663
+         * @return bool
2664
+         */
2665
+        public function is_preview() {
2666
+            $preview = false;
2667
+            if ( $this->is_divi_preview() ) {
2668
+                $preview = true;
2669
+            } elseif ( $this->is_elementor_preview() ) {
2670
+                $preview = true;
2671
+            } elseif ( $this->is_beaver_preview() ) {
2672
+                $preview = true;
2673
+            } elseif ( $this->is_siteorigin_preview() ) {
2674
+                $preview = true;
2675
+            } elseif ( $this->is_cornerstone_preview() ) {
2676
+                $preview = true;
2677
+            } elseif ( $this->is_fusion_preview() ) {
2678
+                $preview = true;
2679
+            } elseif ( $this->is_oxygen_preview() ) {
2680
+                $preview = true;
2681
+            } elseif( $this->is_block_content_call() ) {
2682
+                $preview = true;
2683
+            }
2684
+
2685
+            return $preview;
2686
+        }
2687
+
2688
+        /**
2689
+         * Output the super title.
2690
+         *
2691
+         * @param $args
2692
+         * @param array $instance
2693
+         *
2694
+         * @return string
2695
+         */
2696
+        public function output_title( $args, $instance = array() ) {
2697
+            $output = '';
2698
+            if ( ! empty( $instance['title'] ) ) {
2699
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2700
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2701
+
2702
+                if(empty($instance['widget_title_tag'])){
2703
+                    $output = $args['before_title'] . $title . $args['after_title'];
2704
+                }else{
2705
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
2706
+
2707
+                    // classes
2708
+                    $title_classes = array();
2709
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2710
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2711
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2712
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2713
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2714
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2715
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2716
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2717
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2718
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2719
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2720
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2721
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2722
+
2723
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2724
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
2725
+                }
2726
+
2727
+            }
2728
+
2729
+            return $output;
2730
+        }
2731
+
2732
+        /**
2733
+         * Outputs the options form inputs for the widget.
2734
+         *
2735
+         * @param array $instance The widget options.
2736
+         */
2737
+        public function form( $instance ) {
2738
+
2739
+            // set widget instance
2740
+            $this->instance = $instance;
2741
+
2742
+            // set it as a SD widget
2743
+            echo $this->widget_advanced_toggle();
2744
+
2745
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2746
+            $arguments_raw = $this->get_arguments();
2747
+
2748
+            if ( is_array( $arguments_raw ) ) {
2749
+
2750
+                $arguments = $this->group_arguments( $arguments_raw );
2751
+
2752
+                // Do we have sections?
2753
+                $has_sections = $arguments == $arguments_raw ? false : true;
2754
+
2755
+
2756
+                if ( $has_sections ) {
2757
+                    $panel_count = 0;
2758
+                    foreach ( $arguments as $key => $args ) {
2759
+
2760
+                        ?>
2761 2761
 						<script>
2762 2762
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
2763 2763
 						</script>
2764 2764
 						<?php
2765 2765
 
2766
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
2767
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2768
-						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>";
2769
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2766
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
2767
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2768
+                        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>";
2769
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2770 2770
 
2771
-						foreach ( $args as $k => $a ) {
2771
+                        foreach ( $args as $k => $a ) {
2772 2772
 
2773
-							$this->widget_inputs_row_start($k, $a);
2774
-							$this->widget_inputs( $a, $instance );
2775
-							$this->widget_inputs_row_end($k, $a);
2773
+                            $this->widget_inputs_row_start($k, $a);
2774
+                            $this->widget_inputs( $a, $instance );
2775
+                            $this->widget_inputs_row_end($k, $a);
2776 2776
 
2777
-						}
2777
+                        }
2778 2778
 
2779
-						echo "</div>";
2779
+                        echo "</div>";
2780 2780
 
2781
-						$panel_count ++;
2781
+                        $panel_count ++;
2782 2782
 
2783
-					}
2784
-				} else {
2785
-					foreach ( $arguments as $key => $args ) {
2786
-						$this->widget_inputs_row_start($key, $args);
2787
-						$this->widget_inputs( $args, $instance );
2788
-						$this->widget_inputs_row_end($key, $args);
2789
-					}
2790
-				}
2783
+                    }
2784
+                } else {
2785
+                    foreach ( $arguments as $key => $args ) {
2786
+                        $this->widget_inputs_row_start($key, $args);
2787
+                        $this->widget_inputs( $args, $instance );
2788
+                        $this->widget_inputs_row_end($key, $args);
2789
+                    }
2790
+                }
2791 2791
 
2792
-			}
2793
-		}
2792
+            }
2793
+        }
2794 2794
 
2795
-		public function widget_inputs_row_start($key, $args){
2796
-			if(!empty($args['row'])){
2797
-				// maybe open
2798
-				if(!empty($args['row']['open'])){
2799
-					?>
2795
+        public function widget_inputs_row_start($key, $args){
2796
+            if(!empty($args['row'])){
2797
+                // maybe open
2798
+                if(!empty($args['row']['open'])){
2799
+                    ?>
2800 2800
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
2801
-						echo $this->convert_element_require( $args['row']['element_require'] );
2802
-					} ?>'>
2801
+                        echo $this->convert_element_require( $args['row']['element_require'] );
2802
+                    } ?>'>
2803 2803
 					<?php if(!empty($args['row']['title'])){ ?>
2804 2804
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
2805 2805
 					<?php }?>
2806 2806
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
2807 2807
 					<div class='col pr-2'>
2808 2808
 					<?php
2809
-				}elseif(!empty($args['row']['close'])){
2810
-					echo "<div class='col pl-0'>";
2811
-				}else{
2812
-					echo "<div class='col pl-0 pr-2'>";
2813
-				}
2814
-			}
2815
-		}
2816
-
2817
-		public function widget_inputs_row_end($key, $args){
2818
-
2819
-			if(!empty($args['row'])){
2820
-				// maybe close
2821
-				if(!empty($args['row']['close'])){
2822
-					echo "</div></div>";
2823
-				}
2824
-
2825
-				echo "</div>";
2826
-			}
2827
-		}
2828
-
2829
-		/**
2830
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
2831
-		 *
2832
-		 * @return string
2833
-		 */
2834
-		public function widget_advanced_toggle() {
2835
-
2836
-			$output = '';
2837
-			if ( $this->block_show_advanced() ) {
2838
-				$val = 1;
2839
-			} else {
2840
-				$val = 0;
2841
-			}
2842
-
2843
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2844
-
2845
-			return $output;
2846
-		}
2847
-
2848
-		/**
2849
-		 * Convert require element.
2850
-		 *
2851
-		 * @since 1.0.0
2852
-		 *
2853
-		 * @param string $input Input element.
2854
-		 *
2855
-		 * @return string $output
2856
-		 */
2857
-		public function convert_element_require( $input ) {
2858
-
2859
-			$input = str_replace( "'", '"', $input );// we only want double quotes
2860
-
2861
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
2862
-				"jQuery(form).find('[data-argument=\"",
2863
-				"\"]').find('input,select,textarea').val()"
2864
-			), $input ) );
2865
-
2866
-			return $output;
2867
-		}
2868
-
2869
-		/**
2870
-		 * Builds the inputs for the widget options.
2871
-		 *
2872
-		 * @param $args
2873
-		 * @param $instance
2874
-		 */
2875
-		public function widget_inputs( $args, $instance ) {
2876
-
2877
-			$class             = "";
2878
-			$element_require   = "";
2879
-			$custom_attributes = "";
2880
-
2881
-			// get value
2882
-			if ( isset( $instance[ $args['name'] ] ) ) {
2883
-				$value = $instance[ $args['name'] ];
2884
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2885
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2886
-			} else {
2887
-				$value = '';
2888
-			}
2889
-
2890
-			// get placeholder
2891
-			if ( ! empty( $args['placeholder'] ) ) {
2892
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2893
-			} else {
2894
-				$placeholder = '';
2895
-			}
2896
-
2897
-			// get if advanced
2898
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2899
-				$class .= " sd-advanced-setting ";
2900
-			}
2901
-
2902
-			// element_require
2903
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2904
-				$element_require = $args['element_require'];
2905
-			}
2906
-
2907
-			// custom_attributes
2908
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2909
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2910
-			}
2911
-
2912
-
2913
-			// before wrapper
2914
-			?>
2809
+                }elseif(!empty($args['row']['close'])){
2810
+                    echo "<div class='col pl-0'>";
2811
+                }else{
2812
+                    echo "<div class='col pl-0 pr-2'>";
2813
+                }
2814
+            }
2815
+        }
2816
+
2817
+        public function widget_inputs_row_end($key, $args){
2818
+
2819
+            if(!empty($args['row'])){
2820
+                // maybe close
2821
+                if(!empty($args['row']['close'])){
2822
+                    echo "</div></div>";
2823
+                }
2824
+
2825
+                echo "</div>";
2826
+            }
2827
+        }
2828
+
2829
+        /**
2830
+         * Get the hidden input that when added makes the advanced button show on widget settings.
2831
+         *
2832
+         * @return string
2833
+         */
2834
+        public function widget_advanced_toggle() {
2835
+
2836
+            $output = '';
2837
+            if ( $this->block_show_advanced() ) {
2838
+                $val = 1;
2839
+            } else {
2840
+                $val = 0;
2841
+            }
2842
+
2843
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2844
+
2845
+            return $output;
2846
+        }
2847
+
2848
+        /**
2849
+         * Convert require element.
2850
+         *
2851
+         * @since 1.0.0
2852
+         *
2853
+         * @param string $input Input element.
2854
+         *
2855
+         * @return string $output
2856
+         */
2857
+        public function convert_element_require( $input ) {
2858
+
2859
+            $input = str_replace( "'", '"', $input );// we only want double quotes
2860
+
2861
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
2862
+                "jQuery(form).find('[data-argument=\"",
2863
+                "\"]').find('input,select,textarea').val()"
2864
+            ), $input ) );
2865
+
2866
+            return $output;
2867
+        }
2868
+
2869
+        /**
2870
+         * Builds the inputs for the widget options.
2871
+         *
2872
+         * @param $args
2873
+         * @param $instance
2874
+         */
2875
+        public function widget_inputs( $args, $instance ) {
2876
+
2877
+            $class             = "";
2878
+            $element_require   = "";
2879
+            $custom_attributes = "";
2880
+
2881
+            // get value
2882
+            if ( isset( $instance[ $args['name'] ] ) ) {
2883
+                $value = $instance[ $args['name'] ];
2884
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2885
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2886
+            } else {
2887
+                $value = '';
2888
+            }
2889
+
2890
+            // get placeholder
2891
+            if ( ! empty( $args['placeholder'] ) ) {
2892
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2893
+            } else {
2894
+                $placeholder = '';
2895
+            }
2896
+
2897
+            // get if advanced
2898
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2899
+                $class .= " sd-advanced-setting ";
2900
+            }
2901
+
2902
+            // element_require
2903
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2904
+                $element_require = $args['element_require'];
2905
+            }
2906
+
2907
+            // custom_attributes
2908
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2909
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2910
+            }
2911
+
2912
+
2913
+            // before wrapper
2914
+            ?>
2915 2915
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
2916 2916
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
2917 2917
 			data-element_require='<?php if ( $element_require ) {
2918
-				echo $this->convert_element_require( $element_require );
2919
-			} ?>'
2918
+                echo $this->convert_element_require( $element_require );
2919
+            } ?>'
2920 2920
 			>
2921 2921
 			<?php
2922 2922
 
2923 2923
 
2924
-			switch ( $args['type'] ) {
2925
-				//array('text','password','number','email','tel','url','color')
2926
-				case "text":
2927
-				case "password":
2928
-				case "number":
2929
-				case "email":
2930
-				case "tel":
2931
-				case "url":
2932
-				case "color":
2933
-					?>
2924
+            switch ( $args['type'] ) {
2925
+                //array('text','password','number','email','tel','url','color')
2926
+                case "text":
2927
+                case "password":
2928
+                case "number":
2929
+                case "email":
2930
+                case "tel":
2931
+                case "url":
2932
+                case "color":
2933
+                    ?>
2934 2934
 					<label
2935 2935
 						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>
2936 2936
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -2941,47 +2941,47 @@  discard block
 block discarded – undo
2941 2941
 						                               value="<?php echo esc_attr( $value ); ?>">
2942 2942
 					<?php
2943 2943
 
2944
-					break;
2945
-				case "select":
2946
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2947
-					if ( $multiple ) {
2948
-						if ( empty( $value ) ) {
2949
-							$value = array();
2950
-						}
2951
-					}
2952
-					?>
2944
+                    break;
2945
+                case "select":
2946
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2947
+                    if ( $multiple ) {
2948
+                        if ( empty( $value ) ) {
2949
+                            $value = array();
2950
+                        }
2951
+                    }
2952
+                    ?>
2953 2953
 					<label
2954 2954
 						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>
2955 2955
 					<select <?php echo $placeholder; ?> class="widefat"
2956 2956
 						<?php echo $custom_attributes; ?>
2957 2957
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
2958 2958
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
2959
-						                                if ( $multiple ) {
2960
-							                                echo "[]";
2961
-						                                } ?>"
2959
+                                                        if ( $multiple ) {
2960
+                                                            echo "[]";
2961
+                                                        } ?>"
2962 2962
 						<?php if ( $multiple ) {
2963
-							echo "multiple";
2964
-						} //@todo not implemented yet due to gutenberg not supporting it
2965
-						?>
2963
+                            echo "multiple";
2964
+                        } //@todo not implemented yet due to gutenberg not supporting it
2965
+                        ?>
2966 2966
 					>
2967 2967
 						<?php
2968 2968
 
2969
-						if ( ! empty( $args['options'] ) ) {
2970
-							foreach ( $args['options'] as $val => $label ) {
2971
-								if ( $multiple ) {
2972
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2973
-								} else {
2974
-									$selected = selected( $value, $val, false );
2975
-								}
2976
-								echo "<option value='$val' " . $selected . ">$label</option>";
2977
-							}
2978
-						}
2979
-						?>
2969
+                        if ( ! empty( $args['options'] ) ) {
2970
+                            foreach ( $args['options'] as $val => $label ) {
2971
+                                if ( $multiple ) {
2972
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2973
+                                } else {
2974
+                                    $selected = selected( $value, $val, false );
2975
+                                }
2976
+                                echo "<option value='$val' " . $selected . ">$label</option>";
2977
+                            }
2978
+                        }
2979
+                        ?>
2980 2980
 					</select>
2981 2981
 					<?php
2982
-					break;
2983
-				case "checkbox":
2984
-					?>
2982
+                    break;
2983
+                case "checkbox":
2984
+                    ?>
2985 2985
 					<input <?php echo $placeholder; ?>
2986 2986
 						<?php checked( 1, $value, true ) ?>
2987 2987
 						<?php echo $custom_attributes; ?>
@@ -2991,9 +2991,9 @@  discard block
 block discarded – undo
2991 2991
 					<label
2992 2992
 						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>
2993 2993
 					<?php
2994
-					break;
2995
-				case "textarea":
2996
-					?>
2994
+                    break;
2995
+                case "textarea":
2996
+                    ?>
2997 2997
 					<label
2998 2998
 						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>
2999 2999
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -3003,207 +3003,207 @@  discard block
 block discarded – undo
3003 3003
 					><?php echo esc_attr( $value ); ?></textarea>
3004 3004
 					<?php
3005 3005
 
3006
-					break;
3007
-				case "hidden":
3008
-					?>
3006
+                    break;
3007
+                case "hidden":
3008
+                    ?>
3009 3009
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3010 3010
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
3011 3011
 					       value="<?php echo esc_attr( $value ); ?>">
3012 3012
 					<?php
3013
-					break;
3014
-				default:
3015
-					echo "No input type found!"; // @todo we need to add more input types.
3016
-			}
3013
+                    break;
3014
+                default:
3015
+                    echo "No input type found!"; // @todo we need to add more input types.
3016
+            }
3017 3017
 
3018
-			// after wrapper
3019
-			?>
3018
+            // after wrapper
3019
+            ?>
3020 3020
 			</p>
3021 3021
 			<?php
3022 3022
 
3023 3023
 
3024
-		}
3025
-
3026
-		public function get_widget_icon($icon = 'box-top', $title = ''){
3027
-			if($icon=='box-top'){
3028
-				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>';
3029
-			}elseif($icon=='box-right'){
3030
-				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>';
3031
-			}elseif($icon=='box-bottom'){
3032
-				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>';
3033
-			}elseif($icon=='box-left'){
3034
-				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>';
3035
-			}
3036
-		}
3037
-
3038
-		/**
3039
-		 * Get the widget input description html.
3040
-		 *
3041
-		 * @param $args
3042
-		 *
3043
-		 * @return string
3044
-		 * @todo, need to make its own tooltip script
3045
-		 */
3046
-		public function widget_field_desc( $args ) {
3047
-
3048
-			$description = '';
3049
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
3050
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3051
-					$description = $this->desc_tip( $args['desc'] );
3052
-				} else {
3053
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3054
-				}
3055
-			}
3056
-
3057
-			return $description;
3058
-		}
3059
-
3060
-		/**
3061
-		 * Get the widget input title html.
3062
-		 *
3063
-		 * @param $args
3064
-		 *
3065
-		 * @return string
3066
-		 */
3067
-		public function widget_field_title( $args ) {
3068
-
3069
-			$title = '';
3070
-			if ( isset( $args['title'] ) && $args['title'] ) {
3071
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
3072
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
3073
-				} else {
3074
-					$title = esc_attr($args['title']);
3075
-				}
3076
-			}
3077
-
3078
-			return $title;
3079
-		}
3080
-
3081
-		/**
3082
-		 * Get the tool tip html.
3083
-		 *
3084
-		 * @param $tip
3085
-		 * @param bool $allow_html
3086
-		 *
3087
-		 * @return string
3088
-		 */
3089
-		function desc_tip( $tip, $allow_html = false ) {
3090
-			if ( $allow_html ) {
3091
-				$tip = $this->sanitize_tooltip( $tip );
3092
-			} else {
3093
-				$tip = esc_attr( $tip );
3094
-			}
3095
-
3096
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3097
-		}
3098
-
3099
-		/**
3100
-		 * Sanitize a string destined to be a tooltip.
3101
-		 *
3102
-		 * @param string $var
3103
-		 *
3104
-		 * @return string
3105
-		 */
3106
-		public function sanitize_tooltip( $var ) {
3107
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3108
-				'br'     => array(),
3109
-				'em'     => array(),
3110
-				'strong' => array(),
3111
-				'small'  => array(),
3112
-				'span'   => array(),
3113
-				'ul'     => array(),
3114
-				'li'     => array(),
3115
-				'ol'     => array(),
3116
-				'p'      => array(),
3117
-			) ) );
3118
-		}
3119
-
3120
-		/**
3121
-		 * Processing widget options on save
3122
-		 *
3123
-		 * @param array $new_instance The new options
3124
-		 * @param array $old_instance The previous options
3125
-		 *
3126
-		 * @return array
3127
-		 * @todo we should add some sanitation here.
3128
-		 */
3129
-		public function update( $new_instance, $old_instance ) {
3130
-
3131
-			//save the widget
3132
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
3133
-
3134
-			// set widget instance
3135
-			$this->instance = $instance;
3136
-
3137
-			if ( empty( $this->arguments ) ) {
3138
-				$this->get_arguments();
3139
-			}
3140
-
3141
-			// check for checkboxes
3142
-			if ( ! empty( $this->arguments ) ) {
3143
-				foreach ( $this->arguments as $argument ) {
3144
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3145
-						$instance[ $argument['name'] ] = '0';
3146
-					}
3147
-				}
3148
-			}
3149
-
3150
-			return $instance;
3151
-		}
3152
-
3153
-		/**
3154
-		 * Checks if the current call is a ajax call to get the block content.
3155
-		 *
3156
-		 * This can be used in your widget to return different content as the block content.
3157
-		 *
3158
-		 * @since 1.0.3
3159
-		 * @return bool
3160
-		 */
3161
-		public function is_block_content_call() {
3162
-			$result = false;
3163
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3164
-				$result = true;
3165
-			}
3166
-
3167
-			return $result;
3168
-		}
3169
-
3170
-		/**
3171
-		 * Get an instance hash that will be unique to the type and settings.
3172
-		 *
3173
-		 * @since 1.0.20
3174
-		 * @return string
3175
-		 */
3176
-		public function get_instance_hash(){
3177
-			$instance_string = $this->base_id.serialize($this->instance);
3178
-			return hash('crc32b',$instance_string);
3179
-		}
3180
-
3181
-		/**
3182
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3183
-		 *
3184
-		 * @param array $rules
3185
-		 *
3186
-		 * @since 1.0.20
3187
-		 * @return string
3188
-		 */
3189
-		public function get_instance_style($rules = array()){
3190
-			$css = '';
3191
-
3192
-			if(!empty($rules)){
3193
-				$rules = array_unique($rules);
3194
-				$instance_hash = $this->get_instance_hash();
3195
-				$css .= "<style>";
3196
-				foreach($rules as $rule){
3197
-					$css .= ".sdel-$instance_hash $rule";
3198
-				}
3199
-				$css .= "</style>";
3200
-			}
3201
-
3202
-
3203
-			return $css;
3204
-
3205
-		}
3206
-
3207
-	}
3024
+        }
3025
+
3026
+        public function get_widget_icon($icon = 'box-top', $title = ''){
3027
+            if($icon=='box-top'){
3028
+                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>';
3029
+            }elseif($icon=='box-right'){
3030
+                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>';
3031
+            }elseif($icon=='box-bottom'){
3032
+                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>';
3033
+            }elseif($icon=='box-left'){
3034
+                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>';
3035
+            }
3036
+        }
3037
+
3038
+        /**
3039
+         * Get the widget input description html.
3040
+         *
3041
+         * @param $args
3042
+         *
3043
+         * @return string
3044
+         * @todo, need to make its own tooltip script
3045
+         */
3046
+        public function widget_field_desc( $args ) {
3047
+
3048
+            $description = '';
3049
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
3050
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3051
+                    $description = $this->desc_tip( $args['desc'] );
3052
+                } else {
3053
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3054
+                }
3055
+            }
3056
+
3057
+            return $description;
3058
+        }
3059
+
3060
+        /**
3061
+         * Get the widget input title html.
3062
+         *
3063
+         * @param $args
3064
+         *
3065
+         * @return string
3066
+         */
3067
+        public function widget_field_title( $args ) {
3068
+
3069
+            $title = '';
3070
+            if ( isset( $args['title'] ) && $args['title'] ) {
3071
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
3072
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
3073
+                } else {
3074
+                    $title = esc_attr($args['title']);
3075
+                }
3076
+            }
3077
+
3078
+            return $title;
3079
+        }
3080
+
3081
+        /**
3082
+         * Get the tool tip html.
3083
+         *
3084
+         * @param $tip
3085
+         * @param bool $allow_html
3086
+         *
3087
+         * @return string
3088
+         */
3089
+        function desc_tip( $tip, $allow_html = false ) {
3090
+            if ( $allow_html ) {
3091
+                $tip = $this->sanitize_tooltip( $tip );
3092
+            } else {
3093
+                $tip = esc_attr( $tip );
3094
+            }
3095
+
3096
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3097
+        }
3098
+
3099
+        /**
3100
+         * Sanitize a string destined to be a tooltip.
3101
+         *
3102
+         * @param string $var
3103
+         *
3104
+         * @return string
3105
+         */
3106
+        public function sanitize_tooltip( $var ) {
3107
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3108
+                'br'     => array(),
3109
+                'em'     => array(),
3110
+                'strong' => array(),
3111
+                'small'  => array(),
3112
+                'span'   => array(),
3113
+                'ul'     => array(),
3114
+                'li'     => array(),
3115
+                'ol'     => array(),
3116
+                'p'      => array(),
3117
+            ) ) );
3118
+        }
3119
+
3120
+        /**
3121
+         * Processing widget options on save
3122
+         *
3123
+         * @param array $new_instance The new options
3124
+         * @param array $old_instance The previous options
3125
+         *
3126
+         * @return array
3127
+         * @todo we should add some sanitation here.
3128
+         */
3129
+        public function update( $new_instance, $old_instance ) {
3130
+
3131
+            //save the widget
3132
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
3133
+
3134
+            // set widget instance
3135
+            $this->instance = $instance;
3136
+
3137
+            if ( empty( $this->arguments ) ) {
3138
+                $this->get_arguments();
3139
+            }
3140
+
3141
+            // check for checkboxes
3142
+            if ( ! empty( $this->arguments ) ) {
3143
+                foreach ( $this->arguments as $argument ) {
3144
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3145
+                        $instance[ $argument['name'] ] = '0';
3146
+                    }
3147
+                }
3148
+            }
3149
+
3150
+            return $instance;
3151
+        }
3152
+
3153
+        /**
3154
+         * Checks if the current call is a ajax call to get the block content.
3155
+         *
3156
+         * This can be used in your widget to return different content as the block content.
3157
+         *
3158
+         * @since 1.0.3
3159
+         * @return bool
3160
+         */
3161
+        public function is_block_content_call() {
3162
+            $result = false;
3163
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3164
+                $result = true;
3165
+            }
3166
+
3167
+            return $result;
3168
+        }
3169
+
3170
+        /**
3171
+         * Get an instance hash that will be unique to the type and settings.
3172
+         *
3173
+         * @since 1.0.20
3174
+         * @return string
3175
+         */
3176
+        public function get_instance_hash(){
3177
+            $instance_string = $this->base_id.serialize($this->instance);
3178
+            return hash('crc32b',$instance_string);
3179
+        }
3180
+
3181
+        /**
3182
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3183
+         *
3184
+         * @param array $rules
3185
+         *
3186
+         * @since 1.0.20
3187
+         * @return string
3188
+         */
3189
+        public function get_instance_style($rules = array()){
3190
+            $css = '';
3191
+
3192
+            if(!empty($rules)){
3193
+                $rules = array_unique($rules);
3194
+                $instance_hash = $this->get_instance_hash();
3195
+                $css .= "<style>";
3196
+                foreach($rules as $rule){
3197
+                    $css .= ".sdel-$instance_hash $rule";
3198
+                }
3199
+                $css .= "</style>";
3200
+            }
3201
+
3202
+
3203
+            return $css;
3204
+
3205
+        }
3206
+
3207
+    }
3208 3208
 
3209 3209
 }
Please login to merge, or discard this patch.
includes/class-bp-getpaid-component.php 1 patch
Indentation   +129 added lines, -129 removed lines patch added patch discarded remove patch
@@ -17,45 +17,45 @@  discard block
 block discarded – undo
17 17
  */
18 18
 class BP_GetPaid_Component extends BP_Component {
19 19
 
20
-	/**
21
-	 * Start the component setup process.
22
-	 *
23
-	 * @since 2.1.5
24
-	 */
25
-	public function __construct() {
26
-		parent::start(
27
-			'getpaid',
28
-			'GetPaid',
29
-			buddypress()->plugin_dir,
30
-			array(
31
-				'adminbar_myaccount_order' => 30,
32
-			)
33
-		);
34
-	}
20
+    /**
21
+     * Start the component setup process.
22
+     *
23
+     * @since 2.1.5
24
+     */
25
+    public function __construct() {
26
+        parent::start(
27
+            'getpaid',
28
+            'GetPaid',
29
+            buddypress()->plugin_dir,
30
+            array(
31
+                'adminbar_myaccount_order' => 30,
32
+            )
33
+        );
34
+    }
35 35
 
36 36
     /**
37
-	 * Set up component global variables.
38
-	 *
39
-	 * @since 2.1.5
40
-	 *
41
-	 *
42
-	 * @param array $args {
43
-	 *     All values are optional.
44
-	 *     @type string   $slug                  The component slug. Used to construct certain URLs, such as 'friends' in
45
-	 *                                           http://example.com/members/joe/friends/. Default: the value of $this->id.
46
-	 *     @type string   $root_slug             The component root slug. Note that this value is generally unused if the
47
-	 *                                           component has a root directory (the slug will be overridden by the
48
-	 *                                           post_name of the directory page). Default: the slug of the directory page
49
-	 *                                           if one is found, otherwise an empty string.
50
-	 *     @type bool     $has_directory         Set to true if the component requires an associated WordPress page.
51
-	 *     @type callable $notification_callback Optional. The callable function that formats the component's notifications.
52
-	 *     @type string   $search_term           Optional. The placeholder text in the component directory search box. Eg,
53
-	 *                                           'Search Groups...'.
54
-	 *     @type array    $global_tables         Optional. An array of database table names.
55
-	 *     @type array    $meta_tables           Optional. An array of metadata table names.
56
-	 * }
57
-	 */
58
-	public function setup_globals( $args = array() ) {
37
+     * Set up component global variables.
38
+     *
39
+     * @since 2.1.5
40
+     *
41
+     *
42
+     * @param array $args {
43
+     *     All values are optional.
44
+     *     @type string   $slug                  The component slug. Used to construct certain URLs, such as 'friends' in
45
+     *                                           http://example.com/members/joe/friends/. Default: the value of $this->id.
46
+     *     @type string   $root_slug             The component root slug. Note that this value is generally unused if the
47
+     *                                           component has a root directory (the slug will be overridden by the
48
+     *                                           post_name of the directory page). Default: the slug of the directory page
49
+     *                                           if one is found, otherwise an empty string.
50
+     *     @type bool     $has_directory         Set to true if the component requires an associated WordPress page.
51
+     *     @type callable $notification_callback Optional. The callable function that formats the component's notifications.
52
+     *     @type string   $search_term           Optional. The placeholder text in the component directory search box. Eg,
53
+     *                                           'Search Groups...'.
54
+     *     @type array    $global_tables         Optional. An array of database table names.
55
+     *     @type array    $meta_tables           Optional. An array of metadata table names.
56
+     * }
57
+     */
58
+    public function setup_globals( $args = array() ) {
59 59
         parent::setup_globals(
60 60
             array(
61 61
                 'id'            => 'getpaid',
@@ -64,21 +64,21 @@  discard block
 block discarded – undo
64 64
                 'has_directory' => false
65 65
             )
66 66
         );
67
-	}
68
-
69
-	/**
70
-	 * Set up component navigation.
71
-	 *
72
-	 * @since 2.1.5
73
-	 *
74
-	 * @see BP_Component::setup_nav() for a description of arguments.
75
-	 *
76
-	 * @param array $main_nav Optional. See BP_Component::setup_nav() for description.
77
-	 * @param array $sub_nav  Optional. See BP_Component::setup_nav() for description.
78
-	 */
79
-	public function setup_nav( $main_nav = array(), $sub_nav = array() ) {
80
-
81
-		// Abort if the integration is inactive.
67
+    }
68
+
69
+    /**
70
+     * Set up component navigation.
71
+     *
72
+     * @since 2.1.5
73
+     *
74
+     * @see BP_Component::setup_nav() for a description of arguments.
75
+     *
76
+     * @param array $main_nav Optional. See BP_Component::setup_nav() for description.
77
+     * @param array $sub_nav  Optional. See BP_Component::setup_nav() for description.
78
+     */
79
+    public function setup_nav( $main_nav = array(), $sub_nav = array() ) {
80
+
81
+        // Abort if the integration is inactive.
82 82
         if ( ! getpaid_is_buddypress_integration_active() || ! is_user_logged_in() ) {
83 83
             return;
84 84
         }
@@ -88,25 +88,25 @@  discard block
 block discarded – undo
88 88
             return;
89 89
         }
90 90
 
91
-		// Determine user to use.
92
-		$user_domain   = bp_loggedin_user_domain();
93
-		$slug          = 'getpaid';
94
-		$payments_link = trailingslashit( $user_domain . $slug );
95
-
96
-		// Add 'Payments' to the main navigation.
97
-		$main_nav = array(
98
-			'name'                => _x( 'Billing', 'BuddyPress profile payments screen nav', 'invoicing' ),
99
-			'slug'                => $slug,
100
-			'position'            => apply_filters( 'wpinv_bp_nav_position', wpinv_get_option( 'wpinv_menu_position', 91 ), $slug ),
101
-			'screen_function'     => array( $this, 'display_current_tab' ),
102
-			'default_subnav_slug' => 'gp-edit-address',
91
+        // Determine user to use.
92
+        $user_domain   = bp_loggedin_user_domain();
93
+        $slug          = 'getpaid';
94
+        $payments_link = trailingslashit( $user_domain . $slug );
95
+
96
+        // Add 'Payments' to the main navigation.
97
+        $main_nav = array(
98
+            'name'                => _x( 'Billing', 'BuddyPress profile payments screen nav', 'invoicing' ),
99
+            'slug'                => $slug,
100
+            'position'            => apply_filters( 'wpinv_bp_nav_position', wpinv_get_option( 'wpinv_menu_position', 91 ), $slug ),
101
+            'screen_function'     => array( $this, 'display_current_tab' ),
102
+            'default_subnav_slug' => 'gp-edit-address',
103 103
             'show_for_displayed_user' => false,
104
-			'item_css_id'         => $this->id,
105
-			'parent_url'          => $user_domain,
106
-			'parent_slug'         => buddypress()->slug,
107
-		);
104
+            'item_css_id'         => $this->id,
105
+            'parent_url'          => $user_domain,
106
+            'parent_slug'         => buddypress()->slug,
107
+        );
108 108
 
109
-		// Add the subnav items to the payments nav item if we are using a theme that supports this.
109
+        // Add the subnav items to the payments nav item if we are using a theme that supports this.
110 110
         foreach ( getpaid_get_user_content_tabs() as $_slug => $tab ) {
111 111
 
112 112
             $sub_nav[] = array(
@@ -116,8 +116,8 @@  discard block
 block discarded – undo
116 116
                 'parent_slug'     => $slug,
117 117
                 'position' => 10,
118 118
                 'screen_function'        => function() use ( $tab ) {
119
-					$GLOBALS['getpaid_bp_current_tab'] = $tab;
120
-					$this->display_current_tab();
119
+                    $GLOBALS['getpaid_bp_current_tab'] = $tab;
120
+                    $this->display_current_tab();
121 121
                 },
122 122
                 'show_for_displayed_user' => false,
123 123
                 'item_css_id'             => "getpaid-bp-$_slug",
@@ -125,27 +125,27 @@  discard block
 block discarded – undo
125 125
 
126 126
         }
127 127
 
128
-		parent::setup_nav( $main_nav, $sub_nav );
129
-	}
130
-
131
-	/**
132
-	 * Set up the component entries in the WordPress Admin Bar.
133
-	 *
134
-	 * @since 2.1.5
135
-	 *
136
-	 * @see BP_Component::setup_nav() for a description of the $wp_admin_nav
137
-	 *      parameter array.
138
-	 *
139
-	 * @param array $wp_admin_nav See BP_Component::setup_admin_bar() for a
140
-	 *                            description.
141
-	 */
142
-	public function setup_admin_bar( $wp_admin_nav = array() ) {
143
-
144
-		// Menus for logged in user.
145
-		if ( is_user_logged_in() ) {
128
+        parent::setup_nav( $main_nav, $sub_nav );
129
+    }
146 130
 
147
-			// Setup the logged in user variables.
148
-			$payments_link = trailingslashit( bp_loggedin_user_domain() . 'getpaid/' );
131
+    /**
132
+     * Set up the component entries in the WordPress Admin Bar.
133
+     *
134
+     * @since 2.1.5
135
+     *
136
+     * @see BP_Component::setup_nav() for a description of the $wp_admin_nav
137
+     *      parameter array.
138
+     *
139
+     * @param array $wp_admin_nav See BP_Component::setup_admin_bar() for a
140
+     *                            description.
141
+     */
142
+    public function setup_admin_bar( $wp_admin_nav = array() ) {
143
+
144
+        // Menus for logged in user.
145
+        if ( is_user_logged_in() ) {
146
+
147
+            // Setup the logged in user variables.
148
+            $payments_link = trailingslashit( bp_loggedin_user_domain() . 'getpaid/' );
149 149
 
150 150
             // Add the "Payments" sub menu.
151 151
             $wp_admin_nav[] = array(
@@ -167,50 +167,50 @@  discard block
 block discarded – undo
167 167
 
168 168
             }
169 169
 
170
-		}
171
-
172
-		parent::setup_admin_bar( $wp_admin_nav );
173
-	}
170
+        }
174 171
 
175
-	/**
176
-	 * Retrieves the current tab.
177
-	 *
178
-	 * @since 2.1.5
179
-	 */
180
-	public function get_current_tab() {
181
-		global $getpaid_bp_current_tab;
172
+        parent::setup_admin_bar( $wp_admin_nav );
173
+    }
182 174
 
183
-		if ( empty( $getpaid_bp_current_tab ) ) {
184
-			return array(
185
-				'label'     => __( 'Invoices', 'invoicing' ),
186
-				'content'   => '[wpinv_history]',
187
-				'icon'      => 'fas fa-file-invoice',
188
-			);
189
-		}
175
+    /**
176
+     * Retrieves the current tab.
177
+     *
178
+     * @since 2.1.5
179
+     */
180
+    public function get_current_tab() {
181
+        global $getpaid_bp_current_tab;
182
+
183
+        if ( empty( $getpaid_bp_current_tab ) ) {
184
+            return array(
185
+                'label'     => __( 'Invoices', 'invoicing' ),
186
+                'content'   => '[wpinv_history]',
187
+                'icon'      => 'fas fa-file-invoice',
188
+            );
189
+        }
190 190
 
191
-		return $getpaid_bp_current_tab;
192
-	}
191
+        return $getpaid_bp_current_tab;
192
+    }
193 193
 
194
-	/**
195
-	 * Displays the current tab.
196
-	 *
197
-	 * @since 2.1.5
198
-	 */
199
-	public function display_current_tab() {
194
+    /**
195
+     * Displays the current tab.
196
+     *
197
+     * @since 2.1.5
198
+     */
199
+    public function display_current_tab() {
200 200
 
201
-		add_action( 'bp_template_content', array( $this, 'handle_display_current_tab' ) );
202
-		$template = apply_filters( 'bp_core_template_plugin', 'members/single/plugins' );
201
+        add_action( 'bp_template_content', array( $this, 'handle_display_current_tab' ) );
202
+        $template = apply_filters( 'bp_core_template_plugin', 'members/single/plugins' );
203 203
 
204 204
         bp_core_load_template( apply_filters( 'wpinv_bp_core_template_plugin', $template ) );
205
-	}
206
-
207
-	/**
208
-	 * Handles the actual display of the current tab.
209
-	 *
210
-	 * @since 2.1.5
211
-	 */
212
-	public function handle_display_current_tab() {
213
-		echo getpaid_prepare_user_content_tab( $this->get_current_tab() );
214
-	}
205
+    }
206
+
207
+    /**
208
+     * Handles the actual display of the current tab.
209
+     *
210
+     * @since 2.1.5
211
+     */
212
+    public function handle_display_current_tab() {
213
+        echo getpaid_prepare_user_content_tab( $this->get_current_tab() );
214
+    }
215 215
 
216 216
 }
Please login to merge, or discard this patch.
includes/admin/class-wpinv-subscriptions-list-table.php 1 patch
Indentation   +383 added lines, -383 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
 if ( ! defined( 'ABSPATH' ) ) exit;
7 7
 
8 8
 if ( ! class_exists( 'WP_List_Table' ) ) {
9
-	include_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php';
9
+    include_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php';
10 10
 }
11 11
 
12 12
 /**
@@ -14,387 +14,387 @@  discard block
 block discarded – undo
14 14
  */
15 15
 class WPInv_Subscriptions_List_Table extends WP_List_Table {
16 16
 
17
-	/**
18
-	 * URL of this page
19
-	 *
20
-	 * @var   string
21
-	 * @since 1.0.19
22
-	 */
23
-	public $base_url;
24
-
25
-	/**
26
-	 * Query
27
-	 *
28
-	 * @var   GetPaid_Subscriptions_Query
29
-	 * @since 1.0.19
30
-	 */
31
-	public $query;
32
-
33
-	/**
34
-	 * Total subscriptions
35
-	 *
36
-	 * @var   string
37
-	 * @since 1.0.0
38
-	 */
39
-	public $total_count;
40
-
41
-	/**
42
-	 * Current status subscriptions
43
-	 *
44
-	 * @var   string
45
-	 * @since 1.0.0
46
-	 */
47
-	public $current_total_count;
48
-
49
-	/**
50
-	 * Status counts
51
-	 *
52
-	 * @var   array
53
-	 * @since 1.0.19
54
-	 */
55
-	public $status_counts;
56
-
57
-	/**
58
-	 * Number of results to show per page
59
-	 *
60
-	 * @var   int
61
-	 * @since 1.0.0
62
-	 */
63
-	public $per_page = 10;
64
-
65
-	/**
66
-	 *  Constructor function.
67
-	 */
68
-	public function __construct() {
69
-
70
-		parent::__construct(
71
-			array(
72
-				'singular' => 'subscription',
73
-				'plural'   => 'subscriptions',
74
-			)
75
-		);
76
-
77
-		$this->process_bulk_action();
78
-
79
-		$this->prepare_query();
80
-
81
-		$this->base_url = remove_query_arg( 'status' );
82
-
83
-	}
84
-
85
-	/**
86
-	 *  Prepares the display query
87
-	 */
88
-	public function prepare_query() {
89
-
90
-		// Prepare query args.
91
-		$query = array(
92
-			'number'  => $this->per_page,
93
-			'paged'   => $this->get_paged(),
94
-			'status'  => ( isset( $_GET['status'] ) && array_key_exists( $_GET['status'], getpaid_get_subscription_statuses() ) ) ? $_GET['status'] : 'all',
95
-			'orderby' => ( isset( $_GET['orderby'] ) ) ? $_GET['orderby'] : 'id',
96
-			'order'   => ( isset( $_GET['order'] ) ) ? $_GET['order'] : 'DESC',
97
-		);
98
-
99
-		// Prepare class properties.
100
-		$this->query               = new GetPaid_Subscriptions_Query( $query );
101
-		$this->total_count         = $this->query->get_total();
102
-		$this->current_total_count = $this->query->get_total();
103
-		$this->items               = $this->query->get_results();
104
-		$this->status_counts       = getpaid_get_subscription_status_counts( $query );
105
-
106
-		if ( 'all' != $query['status'] ) {
107
-			unset( $query['status'] );
108
-			$this->total_count   = getpaid_get_subscriptions( $query, 'count' );
109
-		}
110
-
111
-	}
112
-
113
-	/**
114
-	 * Gets the list of views available on this table.
115
-	 *
116
-	 * The format is an associative array:
117
-	 * - `'id' => 'link'`
118
-	 *
119
-	 * @since 1.0.0
120
-	 *
121
-	 * @return array
122
-	 */
123
-	public function get_views() {
124
-
125
-		$current  = isset( $_GET['status'] ) ? $_GET['status'] : 'all';
126
-		$views    = array(
127
-
128
-			'all' => sprintf(
129
-				'<a href="%s" %s>%s&nbsp;<span class="count">(%d)</span></a>',
130
-				esc_url( add_query_arg( 'status', false, $this->base_url ) ),
131
-				$current === 'all' ? ' class="current"' : '',
132
-				__('All','invoicing' ),
133
-				$this->total_count
134
-			)
135
-
136
-		);
137
-
138
-		foreach ( array_filter( $this->status_counts ) as $status => $count ) {
139
-
140
-			$views[ $status ] = sprintf(
141
-				'<a href="%s" %s>%s&nbsp;<span class="count">(%d)</span></a>',
142
-				esc_url( add_query_arg( 'status', urlencode( $status ), $this->base_url ) ),
143
-				$current === $status ? ' class="current"' : '',
144
-				sanitize_text_field( getpaid_get_subscription_status_label( $status ) ),
145
-				$count
146
-			);
147
-
148
-		}
149
-
150
-		return $views;
151
-
152
-	}
153
-
154
-	/**
155
-	 * Render most columns
156
-	 *
157
-	 * @access      private
158
-	 * @since       1.0.0
159
-	 * @return      string
160
-	 */
161
-	public function column_default( $item, $column_name ) {
162
-		return apply_filters( "getpaid_subscriptions_table_column_$column_name", $item->$column_name );
163
-	}
164
-
165
-	/**
166
-	 * This is how checkbox column renders.
167
-	 *
168
-	 * @param WPInv_Subscription $item
169
-	 * @return string
170
-	 */
171
-	public function column_cb( $item ) {
172
-		return sprintf( '<input type="checkbox" name="id[]" value="%s" />', esc_html( $item->get_id() ) );
173
-	}
174
-
175
-	/**
176
-	 * Status column
177
-	 *
178
-	 * @param WPInv_Subscription $item
179
-	 * @since       1.0.0
180
-	 * @return      string
181
-	 */
182
-	public function column_status( $item ) {
183
-		return $item->get_status_label_html();
184
-	}
185
-
186
-	/**
187
-	 * Subscription column
188
-	 *
189
-	 * @param WPInv_Subscription $item
190
-	 * @since       1.0.0
191
-	 * @return      string
192
-	 */
193
-	public function column_subscription( $item ) {
194
-
195
-		$username = __( '(Missing User)', 'invoicing' );
196
-
197
-		$user = get_userdata( $item->get_customer_id() );
198
-		if ( $user ) {
199
-
200
-			$username = sprintf(
201
-				'<a href="user-edit.php?user_id=%s">%s</a>',
202
-				absint( $user->ID ),
203
-				! empty( $user->display_name ) ? sanitize_text_field( $user->display_name ) : sanitize_email( $user->user_email )
204
-			);
205
-
206
-		}
207
-
208
-		// translators: $1: is opening link, $2: is subscription id number, $3: is closing link tag, $4: is user's name
209
-		$column_content = sprintf(
210
-			_x( '%1$s#%2$s%3$s for %4$s', 'Subscription title on admin table. (e.g.: #211 for John Doe)', 'invoicing' ),
211
-			'<a href="' . esc_url( admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $item->get_id() ) ) ) . '">',
212
-			'<strong>' . esc_attr( $item->get_id() ) . '</strong>', '</a>',
213
-			$username
214
-		);
215
-
216
-		$row_actions = array();
217
-
218
-		// View subscription.
219
-		$view_url    = esc_url( add_query_arg( 'id', $item->get_id(), admin_url( 'admin.php?page=wpinv-subscriptions' ) ));
220
-		$row_actions['view'] = '<a href="' . $view_url . '">' . __( 'View Subscription', 'invoicing' ) . '</a>';
221
-
222
-		// View invoice.
223
-		$invoice = get_post( $item->get_parent_invoice_id() );
224
-
225
-		if ( ! empty( $invoice ) ) {
226
-			$invoice_url            = get_edit_post_link( $invoice );
227
-			$row_actions['invoice'] = '<a href="' . $invoice_url . '">' . __( 'View Invoice', 'invoicing' ) . '</a>';
228
-		}
229
-
230
-		$delete_url            = esc_url(
231
-			wp_nonce_url(
232
-				add_query_arg(
233
-					array(
234
-						'getpaid-admin-action' => 'subscription_manual_delete',
235
-						'id'                   => $item->get_id(),
236
-					)
237
-				),
238
-				'getpaid-nonce',
239
-				'getpaid-nonce'
240
-			)
241
-		);
242
-		$row_actions['delete'] = '<a class="text-danger" href="' . $delete_url . '">' . __( 'Delete Subscription', 'invoicing' ) . '</a>';
243
-
244
-		$row_actions = $this->row_actions( apply_filters( 'getpaid_subscription_table_row_actions', $row_actions, $item ) );
245
-
246
-		return "<strong>$column_content</strong>" . $this->column_amount( $item ) . $row_actions;
247
-	}
248
-
249
-	/**
250
-	 * Renewal date column
251
-	 *
252
-	 * @param WPInv_Subscription $item
253
-	 * @since       1.0.0
254
-	 * @return      string
255
-	 */
256
-	public function column_renewal_date( $item ) {
257
-		return getpaid_format_date_value( $item->get_expiration() );
258
-	}
259
-
260
-	/**
261
-	 * Start date column
262
-	 *
263
-	 * @param WPInv_Subscription $item
264
-	 * @since       1.0.0
265
-	 * @return      string
266
-	 */
267
-	public function column_start_date( $item ) {
268
-		return getpaid_format_date_value( $item->get_date_created() );
269
-	}
270
-
271
-	/**
272
-	 * Amount column
273
-	 *
274
-	 * @param WPInv_Subscription $item
275
-	 * @since       1.0.19
276
-	 * @return      string
277
-	 */
278
-	public function column_amount( $item ) {
279
-		$amount = getpaid_get_formatted_subscription_amount( $item );
280
-		return "<span class='text-muted form-text mt-2 mb-2'>$amount</span>";
281
-	}
282
-
283
-	/**
284
-	 * Billing Times column
285
-	 *
286
-	 * @param WPInv_Subscription $item
287
-	 * @since       1.0.0
288
-	 * @return      string
289
-	 */
290
-	public function column_renewals( $item ) {
291
-		$max_bills = $item->get_bill_times();
292
-		return $item->get_times_billed() . ' / ' . ( empty( $max_bills ) ? "&infin;" : $max_bills );
293
-	}
294
-
295
-	/**
296
-	 * Product ID column
297
-	 *
298
-	 * @param WPInv_Subscription $item
299
-	 * @since       1.0.0
300
-	 * @return      string
301
-	 */
302
-	public function column_item( $item ) {
303
-		$_item = get_post( $item->get_product_id() );
304
-
305
-		if ( ! empty( $_item ) ) {
306
-			$link = get_edit_post_link( $_item );
307
-			$link = esc_url( $link );
308
-			$name = esc_html( get_the_title( $_item ) );
309
-			return "<a href='$link'>$name</a>";
310
-		} else {
311
-			return sprintf( __( 'Item #%s', 'invoicing' ), $item->get_product_id() );
312
-		}
313
-
314
-	}
315
-
316
-	/**
317
-	 * Retrieve the current page number
318
-	 *
319
-	 * @return      int
320
-	 */
321
-	public function get_paged() {
322
-		return isset( $_GET['paged'] ) ? absint( $_GET['paged'] ) : 1;
323
-	}
324
-
325
-	/**
326
-	 * Setup the final data for the table
327
-	 *
328
-	 */
329
-	public function prepare_items() {
330
-
331
-		$columns  = $this->get_columns();
332
-		$hidden   = array();
333
-		$sortable = $this->get_sortable_columns();
334
-
335
-		$this->_column_headers = array( $columns, $hidden, $sortable );
336
-
337
-		$this->set_pagination_args(
338
-			array(
339
-			'total_items' => $this->current_total_count,
340
-			'per_page'    => $this->per_page,
341
-			'total_pages' => ceil( $this->current_total_count / $this->per_page )
342
-			)
343
-		);
344
-	}
345
-
346
-	/**
347
-	 * Table columns
348
-	 *
349
-	 * @return array
350
-	 */
351
-	public function get_columns(){
352
-		$columns = array(
353
-			'cb'                => '<input type="checkbox" />',
354
-			'subscription'      => __( 'Subscription', 'invoicing' ),
355
-			'start_date'        => __( 'Start Date', 'invoicing' ),
356
-			'renewal_date'      => __( 'Next Payment', 'invoicing' ),
357
-			'renewals'          => __( 'Payments', 'invoicing' ),
358
-			'item'              => __( 'Item', 'invoicing' ),
359
-			'status'            => __( 'Status', 'invoicing' ),
360
-		);
361
-
362
-		return apply_filters( 'manage_getpaid_subscriptions_table_columns', $columns );
363
-	}
364
-
365
-	/**
366
-	 * Sortable table columns.
367
-	 *
368
-	 * @return array
369
-	 */
370
-	public function get_sortable_columns() {
371
-		$sortable = array(
372
-			'subscription' => array( 'id', true ),
373
-			'start_date'   => array( 'created', true ),
374
-			'renewal_date' => array( 'expiration', true ),
375
-			'renewals'     => array( 'bill_times', true ),
376
-			'item'         => array( 'product_id', true ),
377
-			'status'       => array( 'status', true ),
378
-		);
379
-
380
-		return apply_filters( 'manage_getpaid_subscriptions_sortable_table_columns', $sortable );
381
-	}
382
-
383
-	/**
384
-	 * Whether the table has items to display or not
385
-	 *
386
-	 * @return bool
387
-	 */
388
-	public function has_items() {
389
-		return ! empty( $this->current_total_count );
390
-	}
391
-
392
-	/**
393
-	 * Processes bulk actions.
394
-	 *
395
-	 */
396
-	public function process_bulk_action() {
397
-
398
-	}
17
+    /**
18
+     * URL of this page
19
+     *
20
+     * @var   string
21
+     * @since 1.0.19
22
+     */
23
+    public $base_url;
24
+
25
+    /**
26
+     * Query
27
+     *
28
+     * @var   GetPaid_Subscriptions_Query
29
+     * @since 1.0.19
30
+     */
31
+    public $query;
32
+
33
+    /**
34
+     * Total subscriptions
35
+     *
36
+     * @var   string
37
+     * @since 1.0.0
38
+     */
39
+    public $total_count;
40
+
41
+    /**
42
+     * Current status subscriptions
43
+     *
44
+     * @var   string
45
+     * @since 1.0.0
46
+     */
47
+    public $current_total_count;
48
+
49
+    /**
50
+     * Status counts
51
+     *
52
+     * @var   array
53
+     * @since 1.0.19
54
+     */
55
+    public $status_counts;
56
+
57
+    /**
58
+     * Number of results to show per page
59
+     *
60
+     * @var   int
61
+     * @since 1.0.0
62
+     */
63
+    public $per_page = 10;
64
+
65
+    /**
66
+     *  Constructor function.
67
+     */
68
+    public function __construct() {
69
+
70
+        parent::__construct(
71
+            array(
72
+                'singular' => 'subscription',
73
+                'plural'   => 'subscriptions',
74
+            )
75
+        );
76
+
77
+        $this->process_bulk_action();
78
+
79
+        $this->prepare_query();
80
+
81
+        $this->base_url = remove_query_arg( 'status' );
82
+
83
+    }
84
+
85
+    /**
86
+     *  Prepares the display query
87
+     */
88
+    public function prepare_query() {
89
+
90
+        // Prepare query args.
91
+        $query = array(
92
+            'number'  => $this->per_page,
93
+            'paged'   => $this->get_paged(),
94
+            'status'  => ( isset( $_GET['status'] ) && array_key_exists( $_GET['status'], getpaid_get_subscription_statuses() ) ) ? $_GET['status'] : 'all',
95
+            'orderby' => ( isset( $_GET['orderby'] ) ) ? $_GET['orderby'] : 'id',
96
+            'order'   => ( isset( $_GET['order'] ) ) ? $_GET['order'] : 'DESC',
97
+        );
98
+
99
+        // Prepare class properties.
100
+        $this->query               = new GetPaid_Subscriptions_Query( $query );
101
+        $this->total_count         = $this->query->get_total();
102
+        $this->current_total_count = $this->query->get_total();
103
+        $this->items               = $this->query->get_results();
104
+        $this->status_counts       = getpaid_get_subscription_status_counts( $query );
105
+
106
+        if ( 'all' != $query['status'] ) {
107
+            unset( $query['status'] );
108
+            $this->total_count   = getpaid_get_subscriptions( $query, 'count' );
109
+        }
110
+
111
+    }
112
+
113
+    /**
114
+     * Gets the list of views available on this table.
115
+     *
116
+     * The format is an associative array:
117
+     * - `'id' => 'link'`
118
+     *
119
+     * @since 1.0.0
120
+     *
121
+     * @return array
122
+     */
123
+    public function get_views() {
124
+
125
+        $current  = isset( $_GET['status'] ) ? $_GET['status'] : 'all';
126
+        $views    = array(
127
+
128
+            'all' => sprintf(
129
+                '<a href="%s" %s>%s&nbsp;<span class="count">(%d)</span></a>',
130
+                esc_url( add_query_arg( 'status', false, $this->base_url ) ),
131
+                $current === 'all' ? ' class="current"' : '',
132
+                __('All','invoicing' ),
133
+                $this->total_count
134
+            )
135
+
136
+        );
137
+
138
+        foreach ( array_filter( $this->status_counts ) as $status => $count ) {
139
+
140
+            $views[ $status ] = sprintf(
141
+                '<a href="%s" %s>%s&nbsp;<span class="count">(%d)</span></a>',
142
+                esc_url( add_query_arg( 'status', urlencode( $status ), $this->base_url ) ),
143
+                $current === $status ? ' class="current"' : '',
144
+                sanitize_text_field( getpaid_get_subscription_status_label( $status ) ),
145
+                $count
146
+            );
147
+
148
+        }
149
+
150
+        return $views;
151
+
152
+    }
153
+
154
+    /**
155
+     * Render most columns
156
+     *
157
+     * @access      private
158
+     * @since       1.0.0
159
+     * @return      string
160
+     */
161
+    public function column_default( $item, $column_name ) {
162
+        return apply_filters( "getpaid_subscriptions_table_column_$column_name", $item->$column_name );
163
+    }
164
+
165
+    /**
166
+     * This is how checkbox column renders.
167
+     *
168
+     * @param WPInv_Subscription $item
169
+     * @return string
170
+     */
171
+    public function column_cb( $item ) {
172
+        return sprintf( '<input type="checkbox" name="id[]" value="%s" />', esc_html( $item->get_id() ) );
173
+    }
174
+
175
+    /**
176
+     * Status column
177
+     *
178
+     * @param WPInv_Subscription $item
179
+     * @since       1.0.0
180
+     * @return      string
181
+     */
182
+    public function column_status( $item ) {
183
+        return $item->get_status_label_html();
184
+    }
185
+
186
+    /**
187
+     * Subscription column
188
+     *
189
+     * @param WPInv_Subscription $item
190
+     * @since       1.0.0
191
+     * @return      string
192
+     */
193
+    public function column_subscription( $item ) {
194
+
195
+        $username = __( '(Missing User)', 'invoicing' );
196
+
197
+        $user = get_userdata( $item->get_customer_id() );
198
+        if ( $user ) {
199
+
200
+            $username = sprintf(
201
+                '<a href="user-edit.php?user_id=%s">%s</a>',
202
+                absint( $user->ID ),
203
+                ! empty( $user->display_name ) ? sanitize_text_field( $user->display_name ) : sanitize_email( $user->user_email )
204
+            );
205
+
206
+        }
207
+
208
+        // translators: $1: is opening link, $2: is subscription id number, $3: is closing link tag, $4: is user's name
209
+        $column_content = sprintf(
210
+            _x( '%1$s#%2$s%3$s for %4$s', 'Subscription title on admin table. (e.g.: #211 for John Doe)', 'invoicing' ),
211
+            '<a href="' . esc_url( admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $item->get_id() ) ) ) . '">',
212
+            '<strong>' . esc_attr( $item->get_id() ) . '</strong>', '</a>',
213
+            $username
214
+        );
215
+
216
+        $row_actions = array();
217
+
218
+        // View subscription.
219
+        $view_url    = esc_url( add_query_arg( 'id', $item->get_id(), admin_url( 'admin.php?page=wpinv-subscriptions' ) ));
220
+        $row_actions['view'] = '<a href="' . $view_url . '">' . __( 'View Subscription', 'invoicing' ) . '</a>';
221
+
222
+        // View invoice.
223
+        $invoice = get_post( $item->get_parent_invoice_id() );
224
+
225
+        if ( ! empty( $invoice ) ) {
226
+            $invoice_url            = get_edit_post_link( $invoice );
227
+            $row_actions['invoice'] = '<a href="' . $invoice_url . '">' . __( 'View Invoice', 'invoicing' ) . '</a>';
228
+        }
229
+
230
+        $delete_url            = esc_url(
231
+            wp_nonce_url(
232
+                add_query_arg(
233
+                    array(
234
+                        'getpaid-admin-action' => 'subscription_manual_delete',
235
+                        'id'                   => $item->get_id(),
236
+                    )
237
+                ),
238
+                'getpaid-nonce',
239
+                'getpaid-nonce'
240
+            )
241
+        );
242
+        $row_actions['delete'] = '<a class="text-danger" href="' . $delete_url . '">' . __( 'Delete Subscription', 'invoicing' ) . '</a>';
243
+
244
+        $row_actions = $this->row_actions( apply_filters( 'getpaid_subscription_table_row_actions', $row_actions, $item ) );
245
+
246
+        return "<strong>$column_content</strong>" . $this->column_amount( $item ) . $row_actions;
247
+    }
248
+
249
+    /**
250
+     * Renewal date column
251
+     *
252
+     * @param WPInv_Subscription $item
253
+     * @since       1.0.0
254
+     * @return      string
255
+     */
256
+    public function column_renewal_date( $item ) {
257
+        return getpaid_format_date_value( $item->get_expiration() );
258
+    }
259
+
260
+    /**
261
+     * Start date column
262
+     *
263
+     * @param WPInv_Subscription $item
264
+     * @since       1.0.0
265
+     * @return      string
266
+     */
267
+    public function column_start_date( $item ) {
268
+        return getpaid_format_date_value( $item->get_date_created() );
269
+    }
270
+
271
+    /**
272
+     * Amount column
273
+     *
274
+     * @param WPInv_Subscription $item
275
+     * @since       1.0.19
276
+     * @return      string
277
+     */
278
+    public function column_amount( $item ) {
279
+        $amount = getpaid_get_formatted_subscription_amount( $item );
280
+        return "<span class='text-muted form-text mt-2 mb-2'>$amount</span>";
281
+    }
282
+
283
+    /**
284
+     * Billing Times column
285
+     *
286
+     * @param WPInv_Subscription $item
287
+     * @since       1.0.0
288
+     * @return      string
289
+     */
290
+    public function column_renewals( $item ) {
291
+        $max_bills = $item->get_bill_times();
292
+        return $item->get_times_billed() . ' / ' . ( empty( $max_bills ) ? "&infin;" : $max_bills );
293
+    }
294
+
295
+    /**
296
+     * Product ID column
297
+     *
298
+     * @param WPInv_Subscription $item
299
+     * @since       1.0.0
300
+     * @return      string
301
+     */
302
+    public function column_item( $item ) {
303
+        $_item = get_post( $item->get_product_id() );
304
+
305
+        if ( ! empty( $_item ) ) {
306
+            $link = get_edit_post_link( $_item );
307
+            $link = esc_url( $link );
308
+            $name = esc_html( get_the_title( $_item ) );
309
+            return "<a href='$link'>$name</a>";
310
+        } else {
311
+            return sprintf( __( 'Item #%s', 'invoicing' ), $item->get_product_id() );
312
+        }
313
+
314
+    }
315
+
316
+    /**
317
+     * Retrieve the current page number
318
+     *
319
+     * @return      int
320
+     */
321
+    public function get_paged() {
322
+        return isset( $_GET['paged'] ) ? absint( $_GET['paged'] ) : 1;
323
+    }
324
+
325
+    /**
326
+     * Setup the final data for the table
327
+     *
328
+     */
329
+    public function prepare_items() {
330
+
331
+        $columns  = $this->get_columns();
332
+        $hidden   = array();
333
+        $sortable = $this->get_sortable_columns();
334
+
335
+        $this->_column_headers = array( $columns, $hidden, $sortable );
336
+
337
+        $this->set_pagination_args(
338
+            array(
339
+            'total_items' => $this->current_total_count,
340
+            'per_page'    => $this->per_page,
341
+            'total_pages' => ceil( $this->current_total_count / $this->per_page )
342
+            )
343
+        );
344
+    }
345
+
346
+    /**
347
+     * Table columns
348
+     *
349
+     * @return array
350
+     */
351
+    public function get_columns(){
352
+        $columns = array(
353
+            'cb'                => '<input type="checkbox" />',
354
+            'subscription'      => __( 'Subscription', 'invoicing' ),
355
+            'start_date'        => __( 'Start Date', 'invoicing' ),
356
+            'renewal_date'      => __( 'Next Payment', 'invoicing' ),
357
+            'renewals'          => __( 'Payments', 'invoicing' ),
358
+            'item'              => __( 'Item', 'invoicing' ),
359
+            'status'            => __( 'Status', 'invoicing' ),
360
+        );
361
+
362
+        return apply_filters( 'manage_getpaid_subscriptions_table_columns', $columns );
363
+    }
364
+
365
+    /**
366
+     * Sortable table columns.
367
+     *
368
+     * @return array
369
+     */
370
+    public function get_sortable_columns() {
371
+        $sortable = array(
372
+            'subscription' => array( 'id', true ),
373
+            'start_date'   => array( 'created', true ),
374
+            'renewal_date' => array( 'expiration', true ),
375
+            'renewals'     => array( 'bill_times', true ),
376
+            'item'         => array( 'product_id', true ),
377
+            'status'       => array( 'status', true ),
378
+        );
379
+
380
+        return apply_filters( 'manage_getpaid_subscriptions_sortable_table_columns', $sortable );
381
+    }
382
+
383
+    /**
384
+     * Whether the table has items to display or not
385
+     *
386
+     * @return bool
387
+     */
388
+    public function has_items() {
389
+        return ! empty( $this->current_total_count );
390
+    }
391
+
392
+    /**
393
+     * Processes bulk actions.
394
+     *
395
+     */
396
+    public function process_bulk_action() {
397
+
398
+    }
399 399
 
400 400
 }
Please login to merge, or discard this patch.
includes/wpinv-discount-functions.php 1 patch
Indentation   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -159,7 +159,7 @@
 block discarded – undo
159 159
 function getpaid_calculate_invoice_discount( $invoice, $discount ) {
160 160
 
161 161
     $initial_discount   = 0;
162
-	$recurring_discount = 0;
162
+    $recurring_discount = 0;
163 163
 
164 164
     foreach ( $invoice->get_items() as $item ) {
165 165
 
Please login to merge, or discard this patch.