Passed
Push — master ( 1dfee0...b8b308 )
by Brian
11:47 queued 10s
created
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>$label</th><td>$value</td></tr>" . PHP_EOL;
183
-		}
182
+            echo "<tr class='getpaid-bank-transfer-$key'><th>$label</th><td>$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.
includes/api/class-getpaid-rest-settings-controller.php 1 patch
Indentation   +749 added lines, -749 removed lines patch added patch discarded remove patch
@@ -18,758 +18,758 @@
 block discarded – undo
18 18
  */
19 19
 class GetPaid_REST_Settings_Controller extends GetPaid_REST_Controller {
20 20
 
21
-	/**
22
-	 * An array of available settings.
23
-	 *
24
-	 * @var string
25
-	 */
26
-	protected $settings;
27
-
28
-	/**
29
-	 * Route base.
30
-	 *
31
-	 * @var string
32
-	 */
33
-	protected $rest_base = 'settings';
34
-
35
-	/**
36
-	 * Registers the routes for the objects of the controller.
37
-	 *
38
-	 * @since 2.0.0
39
-	 *
40
-	 * @see register_rest_route()
41
-	 */
42
-	public function register_namespace_routes( $namespace ) {
43
-
44
-		// List all registered tabs.
45
-		register_rest_route(
46
-			$namespace,
47
-			$this->rest_base,
48
-			array(
49
-				array(
50
-					'methods'             => WP_REST_Server::READABLE,
51
-					'callback'            => array( $this, 'get_tabs' ),
52
-					'permission_callback' => array( $this, 'get_items_permissions_check' ),
53
-				),
54
-				'schema' => '__return_empty_array',
55
-			)
56
-		);
57
-
58
-		// View/Update a single setting.
59
-		register_rest_route(
60
-			$namespace,
61
-			$this->rest_base . '/setting/(?P<id>[\w-]+)',
62
-			array(
63
-				'args'   => array(
64
-					'id'    => array(
65
-						'description' => __( 'Unique identifier for the setting.', 'invoicing' ),
66
-						'type'        => 'string',
67
-						'required'    => true,
68
-					),
69
-				),
70
-				array(
71
-					'methods'             => WP_REST_Server::READABLE,
72
-					'callback'            => array( $this, 'get_item' ),
73
-					'permission_callback' => array( $this, 'get_items_permissions_check' ),
74
-				),
75
-				array(
76
-					'methods'             => WP_REST_Server::EDITABLE,
77
-					'callback'            => array( $this, 'update_item' ),
78
-					'permission_callback' => array( $this, 'update_items_permissions_check' ),
79
-					'args'                => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ),
80
-				),
81
-				'schema' => array( $this, 'get_public_item_schema' ),
82
-			)
83
-		);
84
-
85
-		// List registered sections for a given tab.
86
-		register_rest_route(
87
-			$namespace,
88
-			$this->rest_base . '/(?P<tab>[\w-]+)',
89
-			array(
90
-				'args'   => array(
91
-					'tab'    => array(
92
-						'description' => __( 'Unique identifier for the tab whose sections should be retrieved.', 'invoicing' ),
93
-						'type'        => 'string',
94
-						'required'    => true,
95
-						'enum'        => array_keys( wpinv_get_settings_tabs() ),
96
-					),
97
-				),
98
-				array(
99
-					'methods'             => WP_REST_Server::READABLE,
100
-					'callback'            => array( $this, 'get_sections' ),
101
-					'permission_callback' => array( $this, 'get_items_permissions_check' ),
102
-				),
103
-				'schema' => '__return_empty_array',
104
-			)
105
-		);
106
-
107
-		// List all registered settings for a given tab.
108
-		register_rest_route(
109
-			$namespace,
110
-			$this->rest_base . '/(?P<tab>[\w-]+)/(?P<section>[\w-]+)',
111
-			array(
112
-				'args'   => array(
113
-					'tab'    => array(
114
-						'description' => __( 'Unique identifier for the tab whose settings should be retrieved.', 'invoicing' ),
115
-						'type'        => 'string',
116
-						'required'    => true,
117
-						'enum'        => array_keys( wpinv_get_settings_tabs() ),
118
-					),
119
-					'section'    => array(
120
-						'description' => __( 'The section in the tab whose settings should be retrieved.', 'invoicing' ),
121
-						'type'        => 'string',
122
-						'required'    => true,
123
-					),
124
-				),
125
-				array(
126
-					'methods'             => WP_REST_Server::READABLE,
127
-					'callback'            => array( $this, 'get_items' ),
128
-					'permission_callback' => array( $this, 'get_items_permissions_check' ),
129
-				),
130
-				'schema' => array( $this, 'get_public_item_schema' ),
131
-			)
132
-		);
133
-
134
-		register_rest_route(
135
-			$namespace,
136
-			'/' . $this->rest_base . '/batch',
137
-			array(
138
-				'args'   => array(
139
-					'id'              => array(
140
-						'description' => __( 'Setting ID.', 'invoicing' ),
141
-						'type'        => 'string',
142
-					),
143
-				),
144
-				array(
145
-					'methods'             => WP_REST_Server::EDITABLE,
146
-					'callback'            => array( $this, 'batch_items' ),
147
-					'permission_callback' => array( $this, 'batch_items_permissions_check' ),
148
-					'args'                => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ),
149
-				),
150
-				'schema' => array( $this, 'get_public_batch_schema' ),
151
-			)
152
-		);
153
-
154
-	}
21
+    /**
22
+     * An array of available settings.
23
+     *
24
+     * @var string
25
+     */
26
+    protected $settings;
27
+
28
+    /**
29
+     * Route base.
30
+     *
31
+     * @var string
32
+     */
33
+    protected $rest_base = 'settings';
34
+
35
+    /**
36
+     * Registers the routes for the objects of the controller.
37
+     *
38
+     * @since 2.0.0
39
+     *
40
+     * @see register_rest_route()
41
+     */
42
+    public function register_namespace_routes( $namespace ) {
43
+
44
+        // List all registered tabs.
45
+        register_rest_route(
46
+            $namespace,
47
+            $this->rest_base,
48
+            array(
49
+                array(
50
+                    'methods'             => WP_REST_Server::READABLE,
51
+                    'callback'            => array( $this, 'get_tabs' ),
52
+                    'permission_callback' => array( $this, 'get_items_permissions_check' ),
53
+                ),
54
+                'schema' => '__return_empty_array',
55
+            )
56
+        );
57
+
58
+        // View/Update a single setting.
59
+        register_rest_route(
60
+            $namespace,
61
+            $this->rest_base . '/setting/(?P<id>[\w-]+)',
62
+            array(
63
+                'args'   => array(
64
+                    'id'    => array(
65
+                        'description' => __( 'Unique identifier for the setting.', 'invoicing' ),
66
+                        'type'        => 'string',
67
+                        'required'    => true,
68
+                    ),
69
+                ),
70
+                array(
71
+                    'methods'             => WP_REST_Server::READABLE,
72
+                    'callback'            => array( $this, 'get_item' ),
73
+                    'permission_callback' => array( $this, 'get_items_permissions_check' ),
74
+                ),
75
+                array(
76
+                    'methods'             => WP_REST_Server::EDITABLE,
77
+                    'callback'            => array( $this, 'update_item' ),
78
+                    'permission_callback' => array( $this, 'update_items_permissions_check' ),
79
+                    'args'                => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ),
80
+                ),
81
+                'schema' => array( $this, 'get_public_item_schema' ),
82
+            )
83
+        );
84
+
85
+        // List registered sections for a given tab.
86
+        register_rest_route(
87
+            $namespace,
88
+            $this->rest_base . '/(?P<tab>[\w-]+)',
89
+            array(
90
+                'args'   => array(
91
+                    'tab'    => array(
92
+                        'description' => __( 'Unique identifier for the tab whose sections should be retrieved.', 'invoicing' ),
93
+                        'type'        => 'string',
94
+                        'required'    => true,
95
+                        'enum'        => array_keys( wpinv_get_settings_tabs() ),
96
+                    ),
97
+                ),
98
+                array(
99
+                    'methods'             => WP_REST_Server::READABLE,
100
+                    'callback'            => array( $this, 'get_sections' ),
101
+                    'permission_callback' => array( $this, 'get_items_permissions_check' ),
102
+                ),
103
+                'schema' => '__return_empty_array',
104
+            )
105
+        );
106
+
107
+        // List all registered settings for a given tab.
108
+        register_rest_route(
109
+            $namespace,
110
+            $this->rest_base . '/(?P<tab>[\w-]+)/(?P<section>[\w-]+)',
111
+            array(
112
+                'args'   => array(
113
+                    'tab'    => array(
114
+                        'description' => __( 'Unique identifier for the tab whose settings should be retrieved.', 'invoicing' ),
115
+                        'type'        => 'string',
116
+                        'required'    => true,
117
+                        'enum'        => array_keys( wpinv_get_settings_tabs() ),
118
+                    ),
119
+                    'section'    => array(
120
+                        'description' => __( 'The section in the tab whose settings should be retrieved.', 'invoicing' ),
121
+                        'type'        => 'string',
122
+                        'required'    => true,
123
+                    ),
124
+                ),
125
+                array(
126
+                    'methods'             => WP_REST_Server::READABLE,
127
+                    'callback'            => array( $this, 'get_items' ),
128
+                    'permission_callback' => array( $this, 'get_items_permissions_check' ),
129
+                ),
130
+                'schema' => array( $this, 'get_public_item_schema' ),
131
+            )
132
+        );
133
+
134
+        register_rest_route(
135
+            $namespace,
136
+            '/' . $this->rest_base . '/batch',
137
+            array(
138
+                'args'   => array(
139
+                    'id'              => array(
140
+                        'description' => __( 'Setting ID.', 'invoicing' ),
141
+                        'type'        => 'string',
142
+                    ),
143
+                ),
144
+                array(
145
+                    'methods'             => WP_REST_Server::EDITABLE,
146
+                    'callback'            => array( $this, 'batch_items' ),
147
+                    'permission_callback' => array( $this, 'batch_items_permissions_check' ),
148
+                    'args'                => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ),
149
+                ),
150
+                'schema' => array( $this, 'get_public_batch_schema' ),
151
+            )
152
+        );
153
+
154
+    }
155 155
 	
156
-	/**
157
-	 * Return all settings.
158
-	 *
159
-	 * @since  2.0.0
160
-	 * @param  WP_REST_Request $request Request data.
161
-	 * @return WP_Error|WP_REST_Response
162
-	 */
163
-	public function get_items( $request ) {
164
-
165
-		$settings = $this->get_settings();
166
-
167
-		if ( ! isset( $settings[ $request['tab'] ] ) ) {
168
-			return new WP_Error( 'rest_invalid_tab', __( 'Invalid tab.', 'invoicing' ), array( 'status' => 400 ) );
169
-		}
170
-
171
-		if ( ! isset( $settings[ $request['tab'] ][ $request['section'] ] ) ) {
172
-			return new WP_Error( 'rest_invalid_section', __( 'Invalid section.', 'invoicing' ), array( 'status' => 400 ) );
173
-		}
174
-
175
-		$settings = $settings[ $request['tab'] ][ $request['section'] ];
176
-		$prepared = array();
177
-
178
-		foreach ( $settings as $setting ) {
179
-
180
-			$setting      = $this->sanitize_setting( $setting );
181
-			$setting_data = $this->prepare_item_for_response( $setting, $request );
182
-			$setting_data = $this->prepare_response_for_collection( $setting_data );
183
-
184
-			if ( $this->is_setting_type_valid( $setting['type'] ) ) {
185
-				$prepared[]   = $setting_data;
186
-			}
187
-
188
-		}
189
-
190
-		return rest_ensure_response( $prepared );
191
-	}
192
-
193
-	/**
194
-	 * Return a single setting.
195
-	 *
196
-	 * @since  2.0.0
197
-	 * @param  WP_REST_Request $request Request data.
198
-	 * @return WP_Error|WP_REST_Response
199
-	 */
200
-	public function get_item( $request ) {
201
-		$setting  = $this->get_setting( $request['id'] );
202
-
203
-		if ( is_wp_error( $setting ) ) {
204
-			return $setting;
205
-		}
206
-
207
-		$setting  = $this->sanitize_setting( $setting );
208
-		$response = $this->prepare_item_for_response( $setting, $request );
209
-		return rest_ensure_response( $response );
210
-	}
211
-
212
-	/**
213
-	 * Update a single setting.
214
-	 *
215
-	 * @since  2.0.0
216
-	 * @param  WP_REST_Request $request Request data.
217
-	 * @return WP_Error|WP_REST_Response
218
-	 */
219
-	public function update_item( $request ) {
220
-		$setting = $this->get_setting( $request['id'] );
221
-
222
-		if ( is_wp_error( $setting ) ) {
223
-			return $setting;
224
-		}
225
-
226
-		if ( is_callable( array( $this, 'validate_setting_' . $setting['type'] . '_field' ) ) ) {
227
-			$value = $this->{'validate_setting_' . $setting['type'] . '_field'}( $request['value'], $setting );
228
-		} else {
229
-			$value = $this->validate_setting_text_field( $request['value'], $setting );
230
-		}
231
-
232
-		if ( is_wp_error( $value ) ) {
233
-			return $value;
234
-		}
235
-
236
-		wpinv_update_option( $request['id'], $value );
237
-		$setting['value'] = $value;
238
-		$setting          = $this->sanitize_setting( $setting );
239
-		$response         = $this->prepare_item_for_response( $setting, $request );
240
-
241
-		return rest_ensure_response( $response );
242
-	}
243
-
244
-	/**
245
-	 * Makes sure the current user has access to READ the settings APIs.
246
-	 *
247
-	 * @since  2.0.0
248
-	 * @param WP_REST_Request $request Full data about the request.
249
-	 * @return WP_Error|boolean
250
-	 */
251
-	public function get_items_permissions_check( $request ) {
252
-		if ( ! wpinv_current_user_can_manage_invoicing() ) {
253
-			return new WP_Error( 'rest_cannot_view', __( 'Sorry, you cannot list resources.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
254
-		}
255
-
256
-		return true;
257
-	}
258
-
259
-	/**
260
-	 * Makes sure the current user has access to WRITE the settings APIs.
261
-	 *
262
-	 * @since  2.0.0
263
-	 * @param WP_REST_Request $request Full data about the request.
264
-	 * @return WP_Error|boolean
265
-	 */
266
-	public function update_items_permissions_check( $request ) {
267
-		if ( ! wpinv_current_user_can_manage_invoicing() ) {
268
-			return new WP_Error( 'rest_cannot_edit', __( 'Sorry, you cannot edit this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
269
-		}
270
-
271
-		return true;
272
-	}
273
-
274
-	/**
275
-	 * Check if a given request has access batch create, update and delete items.
276
-	 *
277
-	 * @param  WP_REST_Request $request Full details about the request.
278
-	 *
279
-	 * @return boolean|WP_Error
280
-	 */
281
-	public function batch_items_permissions_check( $request ) {
282
-		return wpinv_current_user_can_manage_invoicing() ? true : new WP_Error( 'rest_cannot_batch', __( 'Sorry, you are not allowed to batch manipulate this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
283
-	}
284
-
285
-	/**
286
-	 * Prepare links for the request.
287
-	 *
288
-	 * @param string $setting_id Setting ID.
289
-	 * @return array Links for the given setting.
290
-	 */
291
-	protected function prepare_links( $setting_id ) {
292
-
293
-		$links = array(
294
-			'self'       => array(
295
-				'href'   => rest_url( sprintf( '/%s/%s/setting/%s', $this->namespace, $this->rest_base, $setting_id ) ),
296
-			),
297
-			'collection' => array(
298
-				'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
299
-			),
300
-		);
301
-
302
-		return $links;
303
-	}
304
-
305
-	/**
306
-	 * Prepare a settings object for serialization.
307
-	 *
308
-	 * @since  2.0.0
309
-	 * @param array           $item Setting object.
310
-	 * @param WP_REST_Request $request Request object.
311
-	 * @return WP_REST_Response $response Response data.
312
-	 */
313
-	public function prepare_item_for_response( $item, $request ) {
314
-		$context = empty( $request['context'] ) ? 'view' : $request['context'];
315
-		$data    = $this->add_additional_fields_to_object( $item, $request );
316
-		$data    = $this->filter_response_by_context( $data, $context );
317
-
318
-		$response = rest_ensure_response( $data );
319
-
320
-		$response->add_links( $this->prepare_links( $item['id'] ) );
321
-
322
-		return $response;
323
-	}
324
-
325
-	/**
326
-	 * Filters out bad values from the settings array/filter so we
327
-	 * only return known values via the API.
328
-	 *
329
-	 * @since 2.0.0
330
-	 * @param  array $setting Setting.
331
-	 * @return array
332
-	 */
333
-	public function filter_setting( $setting ) {
334
-		return array_intersect_key(
335
-			$setting,
336
-			array_flip( array_filter( array_keys( $setting ), array( $this, 'allowed_setting_keys' ) ) )
337
-		);
338
-	}
339
-
340
-	/**
341
-	 * Callback for allowed keys for each setting response.
342
-	 *
343
-	 * @param  string $key Key to check.
344
-	 * @return boolean
345
-	 */
346
-	public function allowed_setting_keys( $key ) {
347
-		return in_array( $key, array_keys( $this->setting_defaults() ), true );
348
-	}
349
-
350
-	/**
351
-	 * Returns default options for a setting. null means the field is required.
352
-	 *
353
-	 * @since  2.0.0
354
-	 * @return array
355
-	 */
356
-	protected function setting_defaults() {
357
-		return array(
358
-			'id'          => null,
359
-			'name'        => null,
360
-			'desc'        => '',
361
-			'options'     => array(),
362
-			'std'         => false,
363
-			'value'       => false,
364
-			'placeholder' => '',
365
-			'readonly'    => false,
366
-			'faux'        => false,
367
-			'section'     => 'main',
368
-			'tab'         => 'general',
369
-			'type'        => 'text',
370
-		);
371
-	}
372
-
373
-	/**
374
-	 * Sanitizes a setting's field.
375
-	 *
376
-	 * @param  array $setting The setting to sanitize.
377
-	 * @return array
378
-	 */
379
-	public function sanitize_setting( $setting ) {
156
+    /**
157
+     * Return all settings.
158
+     *
159
+     * @since  2.0.0
160
+     * @param  WP_REST_Request $request Request data.
161
+     * @return WP_Error|WP_REST_Response
162
+     */
163
+    public function get_items( $request ) {
164
+
165
+        $settings = $this->get_settings();
166
+
167
+        if ( ! isset( $settings[ $request['tab'] ] ) ) {
168
+            return new WP_Error( 'rest_invalid_tab', __( 'Invalid tab.', 'invoicing' ), array( 'status' => 400 ) );
169
+        }
170
+
171
+        if ( ! isset( $settings[ $request['tab'] ][ $request['section'] ] ) ) {
172
+            return new WP_Error( 'rest_invalid_section', __( 'Invalid section.', 'invoicing' ), array( 'status' => 400 ) );
173
+        }
174
+
175
+        $settings = $settings[ $request['tab'] ][ $request['section'] ];
176
+        $prepared = array();
177
+
178
+        foreach ( $settings as $setting ) {
179
+
180
+            $setting      = $this->sanitize_setting( $setting );
181
+            $setting_data = $this->prepare_item_for_response( $setting, $request );
182
+            $setting_data = $this->prepare_response_for_collection( $setting_data );
183
+
184
+            if ( $this->is_setting_type_valid( $setting['type'] ) ) {
185
+                $prepared[]   = $setting_data;
186
+            }
187
+
188
+        }
189
+
190
+        return rest_ensure_response( $prepared );
191
+    }
192
+
193
+    /**
194
+     * Return a single setting.
195
+     *
196
+     * @since  2.0.0
197
+     * @param  WP_REST_Request $request Request data.
198
+     * @return WP_Error|WP_REST_Response
199
+     */
200
+    public function get_item( $request ) {
201
+        $setting  = $this->get_setting( $request['id'] );
202
+
203
+        if ( is_wp_error( $setting ) ) {
204
+            return $setting;
205
+        }
206
+
207
+        $setting  = $this->sanitize_setting( $setting );
208
+        $response = $this->prepare_item_for_response( $setting, $request );
209
+        return rest_ensure_response( $response );
210
+    }
211
+
212
+    /**
213
+     * Update a single setting.
214
+     *
215
+     * @since  2.0.0
216
+     * @param  WP_REST_Request $request Request data.
217
+     * @return WP_Error|WP_REST_Response
218
+     */
219
+    public function update_item( $request ) {
220
+        $setting = $this->get_setting( $request['id'] );
221
+
222
+        if ( is_wp_error( $setting ) ) {
223
+            return $setting;
224
+        }
225
+
226
+        if ( is_callable( array( $this, 'validate_setting_' . $setting['type'] . '_field' ) ) ) {
227
+            $value = $this->{'validate_setting_' . $setting['type'] . '_field'}( $request['value'], $setting );
228
+        } else {
229
+            $value = $this->validate_setting_text_field( $request['value'], $setting );
230
+        }
231
+
232
+        if ( is_wp_error( $value ) ) {
233
+            return $value;
234
+        }
235
+
236
+        wpinv_update_option( $request['id'], $value );
237
+        $setting['value'] = $value;
238
+        $setting          = $this->sanitize_setting( $setting );
239
+        $response         = $this->prepare_item_for_response( $setting, $request );
240
+
241
+        return rest_ensure_response( $response );
242
+    }
243
+
244
+    /**
245
+     * Makes sure the current user has access to READ the settings APIs.
246
+     *
247
+     * @since  2.0.0
248
+     * @param WP_REST_Request $request Full data about the request.
249
+     * @return WP_Error|boolean
250
+     */
251
+    public function get_items_permissions_check( $request ) {
252
+        if ( ! wpinv_current_user_can_manage_invoicing() ) {
253
+            return new WP_Error( 'rest_cannot_view', __( 'Sorry, you cannot list resources.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
254
+        }
255
+
256
+        return true;
257
+    }
258
+
259
+    /**
260
+     * Makes sure the current user has access to WRITE the settings APIs.
261
+     *
262
+     * @since  2.0.0
263
+     * @param WP_REST_Request $request Full data about the request.
264
+     * @return WP_Error|boolean
265
+     */
266
+    public function update_items_permissions_check( $request ) {
267
+        if ( ! wpinv_current_user_can_manage_invoicing() ) {
268
+            return new WP_Error( 'rest_cannot_edit', __( 'Sorry, you cannot edit this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
269
+        }
270
+
271
+        return true;
272
+    }
273
+
274
+    /**
275
+     * Check if a given request has access batch create, update and delete items.
276
+     *
277
+     * @param  WP_REST_Request $request Full details about the request.
278
+     *
279
+     * @return boolean|WP_Error
280
+     */
281
+    public function batch_items_permissions_check( $request ) {
282
+        return wpinv_current_user_can_manage_invoicing() ? true : new WP_Error( 'rest_cannot_batch', __( 'Sorry, you are not allowed to batch manipulate this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) );
283
+    }
284
+
285
+    /**
286
+     * Prepare links for the request.
287
+     *
288
+     * @param string $setting_id Setting ID.
289
+     * @return array Links for the given setting.
290
+     */
291
+    protected function prepare_links( $setting_id ) {
292
+
293
+        $links = array(
294
+            'self'       => array(
295
+                'href'   => rest_url( sprintf( '/%s/%s/setting/%s', $this->namespace, $this->rest_base, $setting_id ) ),
296
+            ),
297
+            'collection' => array(
298
+                'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
299
+            ),
300
+        );
301
+
302
+        return $links;
303
+    }
304
+
305
+    /**
306
+     * Prepare a settings object for serialization.
307
+     *
308
+     * @since  2.0.0
309
+     * @param array           $item Setting object.
310
+     * @param WP_REST_Request $request Request object.
311
+     * @return WP_REST_Response $response Response data.
312
+     */
313
+    public function prepare_item_for_response( $item, $request ) {
314
+        $context = empty( $request['context'] ) ? 'view' : $request['context'];
315
+        $data    = $this->add_additional_fields_to_object( $item, $request );
316
+        $data    = $this->filter_response_by_context( $data, $context );
317
+
318
+        $response = rest_ensure_response( $data );
319
+
320
+        $response->add_links( $this->prepare_links( $item['id'] ) );
321
+
322
+        return $response;
323
+    }
324
+
325
+    /**
326
+     * Filters out bad values from the settings array/filter so we
327
+     * only return known values via the API.
328
+     *
329
+     * @since 2.0.0
330
+     * @param  array $setting Setting.
331
+     * @return array
332
+     */
333
+    public function filter_setting( $setting ) {
334
+        return array_intersect_key(
335
+            $setting,
336
+            array_flip( array_filter( array_keys( $setting ), array( $this, 'allowed_setting_keys' ) ) )
337
+        );
338
+    }
339
+
340
+    /**
341
+     * Callback for allowed keys for each setting response.
342
+     *
343
+     * @param  string $key Key to check.
344
+     * @return boolean
345
+     */
346
+    public function allowed_setting_keys( $key ) {
347
+        return in_array( $key, array_keys( $this->setting_defaults() ), true );
348
+    }
349
+
350
+    /**
351
+     * Returns default options for a setting. null means the field is required.
352
+     *
353
+     * @since  2.0.0
354
+     * @return array
355
+     */
356
+    protected function setting_defaults() {
357
+        return array(
358
+            'id'          => null,
359
+            'name'        => null,
360
+            'desc'        => '',
361
+            'options'     => array(),
362
+            'std'         => false,
363
+            'value'       => false,
364
+            'placeholder' => '',
365
+            'readonly'    => false,
366
+            'faux'        => false,
367
+            'section'     => 'main',
368
+            'tab'         => 'general',
369
+            'type'        => 'text',
370
+        );
371
+    }
372
+
373
+    /**
374
+     * Sanitizes a setting's field.
375
+     *
376
+     * @param  array $setting The setting to sanitize.
377
+     * @return array
378
+     */
379
+    public function sanitize_setting( $setting ) {
380 380
 		
381
-		$setting          = wp_parse_args( $setting, $this->setting_defaults() );
382
-		$setting['value'] = wpinv_get_option( $setting['id'], $setting['std'] );
383
-		return $this->filter_setting( $setting );
384
-
385
-	}
386
-
387
-	/**
388
-	 * Get setting data.
389
-	 *
390
-	 * @since  2.0.0
391
-	 * @param string $setting_id Setting ID.
392
-	 * @return array|WP_Error
393
-	 */
394
-	public function get_setting( $setting_id ) {
395
-
396
-		if ( empty( $setting_id ) ) {
397
-			return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) );
398
-		}
399
-
400
-		$settings  = $this->get_settings();
401
-
402
-		foreach ( $settings as $tabs ) {
403
-
404
-			foreach ( $tabs as $sections ) {
405
-
406
-				if ( isset( $sections[ $setting_id ] ) ) {
407
-					if ( ! $this->is_setting_type_valid( $sections[ $setting_id ]['type'] ) ) {
408
-						return new WP_Error( 'rest_setting_setting_type_invalid', __( 'Invalid setting type.', 'invoicing' ), array( 'status' => 404 ) );
409
-					}
410
-
411
-					return $sections[ $setting_id ];
412
-				}
413
-
414
-			}
415
-
416
-		}
417
-
418
-		return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) );
419
-	}
420
-
421
-	/**
422
-	 * Get all tabs.
423
-	 *
424
-	 * @param  WP_REST_Request $request Request data.
425
-	 * @return array
426
-	 */
427
-	public function get_tabs( $request ) {
428
-		$tabs     = wpinv_get_settings_tabs();
429
-		$prepared = array();
430
-
431
-		foreach ( $tabs as $id => $tab ) {
432
-
433
-			$_request        = $request;
434
-			$_request['tab'] = sanitize_title( $id );
435
-			$data            = array(
436
-				'id'       => sanitize_title( $id ),
437
-				'label'    => sanitize_text_field( $tab ),
438
-				'sections' => $this->get_sections( $_request ),
439
-			);
440
-
441
-			$data     = $this->add_additional_fields_to_object( $data, $request );
442
-			$response = rest_ensure_response( $data );
443
-
444
-			if ( ! is_wp_error( $response ) ) {
445
-				$links = array(
446
-					'sections'   => array(
447
-						'href'   => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $id ) ),
448
-					),
449
-					'collection' => array(
450
-						'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
451
-					),
452
-				);
453
-				$response->add_links( $links );
454
-				$response = $this->prepare_response_for_collection( $response );
455
-			}
456
-
457
-			$prepared[] = $response;
458
-
459
-		}
460
-
461
-		return rest_ensure_response( $prepared );
462
-	}
463
-
464
-	/**
465
-	 * Get all sections.
466
-	 *
467
-	 * @param  WP_REST_Request $request Request data.
468
-	 * @return array
469
-	 */
470
-	public function get_sections( $request ) {
471
-
472
-		$tab      = sanitize_title( $request['tab'] );
473
-		$sections = wpinv_get_settings_tab_sections( $tab );
474
-		$prepared = array();
475
-
476
-		foreach ( $sections as $id => $section ) {
477
-
478
-			$data            = array(
479
-				'id'       => sanitize_title( $id ),
480
-				'label'    => sanitize_text_field( $section ),
481
-			);
482
-
483
-			$data     = $this->add_additional_fields_to_object( $data, $request );
484
-			$response = rest_ensure_response( $data );
485
-
486
-			if ( ! is_wp_error( $response ) ) {
487
-				$links = array(
488
-					'settings'   => array(
489
-						'href'   => rest_url( sprintf( '/%s/%s/%s/%s', $this->namespace, $this->rest_base, $tab, $id ) ),
490
-					),
491
-					'collection' => array(
492
-						'href'   => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $tab ) ),
493
-					),
494
-					'tabs'       => array(
495
-						'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
496
-					),
497
-				);
498
-				$response->add_links( $links );
499
-				$response = $this->prepare_response_for_collection( $response );
500
-			}
501
-
502
-			$prepared[] = $response;
503
-
504
-		}
505
-
506
-		return rest_ensure_response( $prepared );
507
-	}
508
-
509
-	/**
510
-	 * Get all settings.
511
-	 *
512
-	 * @return array
513
-	 */
514
-	public function get_settings() {
515
-
516
-		if ( empty( $this->settings ) ) {
517
-			$this->settings = wpinv_get_registered_settings();
518
-		}
519
-
520
-		return $this->settings;
521
-
522
-	}
523
-
524
-	/**
525
-	 * Boolean for if a setting type is a valid supported setting type.
526
-	 *
527
-	 * @since  2.0.0
528
-	 * @param  string $type Type.
529
-	 * @return bool
530
-	 */
531
-	public function is_setting_type_valid( $type ) {
532
-
533
-		return in_array(
534
-			$type, array(
535
-				'text',         // Validates with validate_setting_text_field.
536
-				'email',        // Validates with validate_setting_text_field.
537
-				'number',       // Validates with validate_setting_text_field.
538
-				'color',        // Validates with validate_setting_text_field.
539
-				'password',     // Validates with validate_setting_text_field.
540
-				'textarea',     // Validates with validate_setting_textarea_field.
541
-				'select',       // Validates with validate_setting_select_field.
542
-				'multiselect',  // Validates with validate_setting_multiselect_field.
543
-				'radio',        // Validates with validate_setting_radio_field (-> validate_setting_select_field).
544
-				'checkbox',     // Validates with validate_setting_checkbox_field.
545
-				'header',       // Validates with validate_setting_text_field.
546
-			)
547
-		);
548
-
549
-	}
550
-
551
-	/**
552
-	 * Get the settings schema, conforming to JSON Schema.
553
-	 *
554
-	 * @return array
555
-	 */
556
-	public function get_item_schema() {
557
-
558
-		// Maybe retrieve the schema from cache.
559
-		if ( ! empty( $this->schema ) ) {
560
-			return $this->add_additional_fields_schema( $this->schema );
561
-		}
562
-
563
-		$schema = array(
564
-			'$schema'    => 'http://json-schema.org/draft-04/schema#',
565
-			'title'      => 'setting',
566
-			'type'       => 'object',
567
-			'properties' => array(
568
-				'id'          => array(
569
-					'description' => __( 'A unique identifier for the setting.', 'invoicing' ),
570
-					'type'        => 'string',
571
-					'arg_options' => array(
572
-						'sanitize_callback' => 'sanitize_title',
573
-					),
574
-					'context'     => array( 'view', 'edit' ),
575
-					'readonly'    => true,
576
-				),
577
-				'tab'         => array(
578
-					'description' => __( 'An identifier for the tab this setting belongs to.', 'invoicing' ),
579
-					'type'        => 'string',
580
-					'arg_options' => array(
581
-						'sanitize_callback' => 'sanitize_title',
582
-					),
583
-					'context'     => array( 'view', 'edit' ),
584
-					'readonly'    => true,
585
-				),
586
-				'section'     => array(
587
-					'description' => __( 'An identifier for the section this setting belongs to.', 'invoicing' ),
588
-					'type'        => 'string',
589
-					'arg_options' => array(
590
-						'sanitize_callback' => 'sanitize_title',
591
-					),
592
-					'context'     => array( 'view', 'edit' ),
593
-					'readonly'    => true,
594
-				),
595
-				'name'       => array(
596
-					'description' => __( 'A human readable label for the setting used in interfaces.', 'invoicing' ),
597
-					'type'        => 'string',
598
-					'arg_options' => array(
599
-						'sanitize_callback' => 'sanitize_text_field',
600
-					),
601
-					'context'     => array( 'view', 'edit' ),
602
-					'readonly'    => true,
603
-				),
604
-				'desc'        => array(
605
-					'description' => __( 'A human readable description for the setting used in interfaces.', 'invoicing' ),
606
-					'type'        => 'string',
607
-					'context'     => array( 'view', 'edit' ),
608
-					'readonly'    => true,
609
-				),
610
-				'value'       => array(
611
-					'description' => __( 'The current value of this setting.', 'invoicing' ),
612
-					'type'        => 'mixed',
613
-					'context'     => array( 'view', 'edit' ),
614
-				),
615
-				'default'     => array(
616
-					'description' => __( 'Default value for the setting.', 'invoicing' ),
617
-					'type'        => 'mixed',
618
-					'context'     => array( 'view', 'edit' ),
619
-					'readonly'    => true,
620
-				),
621
-				'placeholder' => array(
622
-					'description' => __( 'Placeholder text to be displayed in text inputs.', 'invoicing' ),
623
-					'type'        => 'string',
624
-					'arg_options' => array(
625
-						'sanitize_callback' => 'sanitize_text_field',
626
-					),
627
-					'context'     => array( 'view', 'edit' ),
628
-					'readonly'    => true,
629
-				),
630
-				'type'        => array(
631
-					'description' => __( 'Type of setting.', 'invoicing' ),
632
-					'type'        => 'string',
633
-					'arg_options' => array(
634
-						'sanitize_callback' => 'sanitize_text_field',
635
-					),
636
-					'context'     => array( 'view', 'edit' ),
637
-					'enum'        => array( 'text', 'email', 'number', 'color', 'password', 'textarea', 'select', 'multiselect', 'radio', 'image_width', 'checkbox', 'raw_html' ),
638
-					'readonly'    => true,
639
-				),
640
-				'options'     => array(
641
-					'description' => __( 'Array of options (key value pairs) for inputs such as select, multiselect, and radio buttons.', 'invoicing' ),
642
-					'type'        => 'object',
643
-					'context'     => array( 'view', 'edit' ),
644
-					'readonly'    => true,
645
-				),
646
-				'readonly'        => array(
647
-					'description' => __( 'Whether or not this setting is readonly', 'invoicing' ),
648
-					'type'        => 'string',
649
-					'context'     => array( 'view' ),
650
-					'readonly'    => true,
651
-				),
652
-				'faux'            => array(
653
-					'description' => __( 'Whether or not this setting is readonly/faux', 'invoicing' ),
654
-					'type'        => 'string',
655
-					'context'     => array( 'view' ),
656
-					'readonly'    => true,
657
-				),
658
-			),
659
-		);
660
-
661
-		// Filters the settings schema for the REST API.
381
+        $setting          = wp_parse_args( $setting, $this->setting_defaults() );
382
+        $setting['value'] = wpinv_get_option( $setting['id'], $setting['std'] );
383
+        return $this->filter_setting( $setting );
384
+
385
+    }
386
+
387
+    /**
388
+     * Get setting data.
389
+     *
390
+     * @since  2.0.0
391
+     * @param string $setting_id Setting ID.
392
+     * @return array|WP_Error
393
+     */
394
+    public function get_setting( $setting_id ) {
395
+
396
+        if ( empty( $setting_id ) ) {
397
+            return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) );
398
+        }
399
+
400
+        $settings  = $this->get_settings();
401
+
402
+        foreach ( $settings as $tabs ) {
403
+
404
+            foreach ( $tabs as $sections ) {
405
+
406
+                if ( isset( $sections[ $setting_id ] ) ) {
407
+                    if ( ! $this->is_setting_type_valid( $sections[ $setting_id ]['type'] ) ) {
408
+                        return new WP_Error( 'rest_setting_setting_type_invalid', __( 'Invalid setting type.', 'invoicing' ), array( 'status' => 404 ) );
409
+                    }
410
+
411
+                    return $sections[ $setting_id ];
412
+                }
413
+
414
+            }
415
+
416
+        }
417
+
418
+        return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) );
419
+    }
420
+
421
+    /**
422
+     * Get all tabs.
423
+     *
424
+     * @param  WP_REST_Request $request Request data.
425
+     * @return array
426
+     */
427
+    public function get_tabs( $request ) {
428
+        $tabs     = wpinv_get_settings_tabs();
429
+        $prepared = array();
430
+
431
+        foreach ( $tabs as $id => $tab ) {
432
+
433
+            $_request        = $request;
434
+            $_request['tab'] = sanitize_title( $id );
435
+            $data            = array(
436
+                'id'       => sanitize_title( $id ),
437
+                'label'    => sanitize_text_field( $tab ),
438
+                'sections' => $this->get_sections( $_request ),
439
+            );
440
+
441
+            $data     = $this->add_additional_fields_to_object( $data, $request );
442
+            $response = rest_ensure_response( $data );
443
+
444
+            if ( ! is_wp_error( $response ) ) {
445
+                $links = array(
446
+                    'sections'   => array(
447
+                        'href'   => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $id ) ),
448
+                    ),
449
+                    'collection' => array(
450
+                        'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
451
+                    ),
452
+                );
453
+                $response->add_links( $links );
454
+                $response = $this->prepare_response_for_collection( $response );
455
+            }
456
+
457
+            $prepared[] = $response;
458
+
459
+        }
460
+
461
+        return rest_ensure_response( $prepared );
462
+    }
463
+
464
+    /**
465
+     * Get all sections.
466
+     *
467
+     * @param  WP_REST_Request $request Request data.
468
+     * @return array
469
+     */
470
+    public function get_sections( $request ) {
471
+
472
+        $tab      = sanitize_title( $request['tab'] );
473
+        $sections = wpinv_get_settings_tab_sections( $tab );
474
+        $prepared = array();
475
+
476
+        foreach ( $sections as $id => $section ) {
477
+
478
+            $data            = array(
479
+                'id'       => sanitize_title( $id ),
480
+                'label'    => sanitize_text_field( $section ),
481
+            );
482
+
483
+            $data     = $this->add_additional_fields_to_object( $data, $request );
484
+            $response = rest_ensure_response( $data );
485
+
486
+            if ( ! is_wp_error( $response ) ) {
487
+                $links = array(
488
+                    'settings'   => array(
489
+                        'href'   => rest_url( sprintf( '/%s/%s/%s/%s', $this->namespace, $this->rest_base, $tab, $id ) ),
490
+                    ),
491
+                    'collection' => array(
492
+                        'href'   => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $tab ) ),
493
+                    ),
494
+                    'tabs'       => array(
495
+                        'href'   => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ),
496
+                    ),
497
+                );
498
+                $response->add_links( $links );
499
+                $response = $this->prepare_response_for_collection( $response );
500
+            }
501
+
502
+            $prepared[] = $response;
503
+
504
+        }
505
+
506
+        return rest_ensure_response( $prepared );
507
+    }
508
+
509
+    /**
510
+     * Get all settings.
511
+     *
512
+     * @return array
513
+     */
514
+    public function get_settings() {
515
+
516
+        if ( empty( $this->settings ) ) {
517
+            $this->settings = wpinv_get_registered_settings();
518
+        }
519
+
520
+        return $this->settings;
521
+
522
+    }
523
+
524
+    /**
525
+     * Boolean for if a setting type is a valid supported setting type.
526
+     *
527
+     * @since  2.0.0
528
+     * @param  string $type Type.
529
+     * @return bool
530
+     */
531
+    public function is_setting_type_valid( $type ) {
532
+
533
+        return in_array(
534
+            $type, array(
535
+                'text',         // Validates with validate_setting_text_field.
536
+                'email',        // Validates with validate_setting_text_field.
537
+                'number',       // Validates with validate_setting_text_field.
538
+                'color',        // Validates with validate_setting_text_field.
539
+                'password',     // Validates with validate_setting_text_field.
540
+                'textarea',     // Validates with validate_setting_textarea_field.
541
+                'select',       // Validates with validate_setting_select_field.
542
+                'multiselect',  // Validates with validate_setting_multiselect_field.
543
+                'radio',        // Validates with validate_setting_radio_field (-> validate_setting_select_field).
544
+                'checkbox',     // Validates with validate_setting_checkbox_field.
545
+                'header',       // Validates with validate_setting_text_field.
546
+            )
547
+        );
548
+
549
+    }
550
+
551
+    /**
552
+     * Get the settings schema, conforming to JSON Schema.
553
+     *
554
+     * @return array
555
+     */
556
+    public function get_item_schema() {
557
+
558
+        // Maybe retrieve the schema from cache.
559
+        if ( ! empty( $this->schema ) ) {
560
+            return $this->add_additional_fields_schema( $this->schema );
561
+        }
562
+
563
+        $schema = array(
564
+            '$schema'    => 'http://json-schema.org/draft-04/schema#',
565
+            'title'      => 'setting',
566
+            'type'       => 'object',
567
+            'properties' => array(
568
+                'id'          => array(
569
+                    'description' => __( 'A unique identifier for the setting.', 'invoicing' ),
570
+                    'type'        => 'string',
571
+                    'arg_options' => array(
572
+                        'sanitize_callback' => 'sanitize_title',
573
+                    ),
574
+                    'context'     => array( 'view', 'edit' ),
575
+                    'readonly'    => true,
576
+                ),
577
+                'tab'         => array(
578
+                    'description' => __( 'An identifier for the tab this setting belongs to.', 'invoicing' ),
579
+                    'type'        => 'string',
580
+                    'arg_options' => array(
581
+                        'sanitize_callback' => 'sanitize_title',
582
+                    ),
583
+                    'context'     => array( 'view', 'edit' ),
584
+                    'readonly'    => true,
585
+                ),
586
+                'section'     => array(
587
+                    'description' => __( 'An identifier for the section this setting belongs to.', 'invoicing' ),
588
+                    'type'        => 'string',
589
+                    'arg_options' => array(
590
+                        'sanitize_callback' => 'sanitize_title',
591
+                    ),
592
+                    'context'     => array( 'view', 'edit' ),
593
+                    'readonly'    => true,
594
+                ),
595
+                'name'       => array(
596
+                    'description' => __( 'A human readable label for the setting used in interfaces.', 'invoicing' ),
597
+                    'type'        => 'string',
598
+                    'arg_options' => array(
599
+                        'sanitize_callback' => 'sanitize_text_field',
600
+                    ),
601
+                    'context'     => array( 'view', 'edit' ),
602
+                    'readonly'    => true,
603
+                ),
604
+                'desc'        => array(
605
+                    'description' => __( 'A human readable description for the setting used in interfaces.', 'invoicing' ),
606
+                    'type'        => 'string',
607
+                    'context'     => array( 'view', 'edit' ),
608
+                    'readonly'    => true,
609
+                ),
610
+                'value'       => array(
611
+                    'description' => __( 'The current value of this setting.', 'invoicing' ),
612
+                    'type'        => 'mixed',
613
+                    'context'     => array( 'view', 'edit' ),
614
+                ),
615
+                'default'     => array(
616
+                    'description' => __( 'Default value for the setting.', 'invoicing' ),
617
+                    'type'        => 'mixed',
618
+                    'context'     => array( 'view', 'edit' ),
619
+                    'readonly'    => true,
620
+                ),
621
+                'placeholder' => array(
622
+                    'description' => __( 'Placeholder text to be displayed in text inputs.', 'invoicing' ),
623
+                    'type'        => 'string',
624
+                    'arg_options' => array(
625
+                        'sanitize_callback' => 'sanitize_text_field',
626
+                    ),
627
+                    'context'     => array( 'view', 'edit' ),
628
+                    'readonly'    => true,
629
+                ),
630
+                'type'        => array(
631
+                    'description' => __( 'Type of setting.', 'invoicing' ),
632
+                    'type'        => 'string',
633
+                    'arg_options' => array(
634
+                        'sanitize_callback' => 'sanitize_text_field',
635
+                    ),
636
+                    'context'     => array( 'view', 'edit' ),
637
+                    'enum'        => array( 'text', 'email', 'number', 'color', 'password', 'textarea', 'select', 'multiselect', 'radio', 'image_width', 'checkbox', 'raw_html' ),
638
+                    'readonly'    => true,
639
+                ),
640
+                'options'     => array(
641
+                    'description' => __( 'Array of options (key value pairs) for inputs such as select, multiselect, and radio buttons.', 'invoicing' ),
642
+                    'type'        => 'object',
643
+                    'context'     => array( 'view', 'edit' ),
644
+                    'readonly'    => true,
645
+                ),
646
+                'readonly'        => array(
647
+                    'description' => __( 'Whether or not this setting is readonly', 'invoicing' ),
648
+                    'type'        => 'string',
649
+                    'context'     => array( 'view' ),
650
+                    'readonly'    => true,
651
+                ),
652
+                'faux'            => array(
653
+                    'description' => __( 'Whether or not this setting is readonly/faux', 'invoicing' ),
654
+                    'type'        => 'string',
655
+                    'context'     => array( 'view' ),
656
+                    'readonly'    => true,
657
+                ),
658
+            ),
659
+        );
660
+
661
+        // Filters the settings schema for the REST API.
662 662
         $schema = apply_filters( 'getpaid_rest_settings_schema', $schema );
663 663
 
664
-		// Cache the settings schema.
665
-		$this->schema = $schema;
666
-
667
-		return $this->add_additional_fields_schema( $this->schema );
668
-
669
-	}
670
-
671
-	/**
672
-	 * Validate a text value for a text based setting.
673
-	 *
674
-	 * @since 2.0.0
675
-	 * @param string $value Value.
676
-	 * @param array  $setting Setting.
677
-	 * @return string
678
-	 */
679
-	public function validate_setting_text_field( $value ) {
680
-		$value = is_null( $value ) ? '' : $value;
681
-		return wp_kses_post( trim( stripslashes( $value ) ) );
682
-	}
683
-
684
-	/**
685
-	 * Validate select based settings.
686
-	 *
687
-	 * @since 2.0.0
688
-	 * @param string $value Value.
689
-	 * @param array  $setting Setting.
690
-	 * @return string|WP_Error
691
-	 */
692
-	public function validate_setting_select_field( $value, $setting ) {
693
-		if ( array_key_exists( $value, $setting['options'] ) ) {
694
-			return $value;
695
-		} else {
696
-			return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) );
697
-		}
698
-	}
699
-
700
-	/**
701
-	 * Validate multiselect based settings.
702
-	 *
703
-	 * @since 2.0.0
704
-	 * @param array $values Values.
705
-	 * @param array $setting Setting.
706
-	 * @return array|WP_Error
707
-	 */
708
-	public function validate_setting_multiselect_field( $values, $setting ) {
709
-		if ( empty( $values ) ) {
710
-			return array();
711
-		}
712
-
713
-		if ( ! is_array( $values ) ) {
714
-			return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) );
715
-		}
716
-
717
-		$final_values = array();
718
-		foreach ( $values as $value ) {
719
-			if ( array_key_exists( $value, $setting['options'] ) ) {
720
-				$final_values[] = $value;
721
-			}
722
-		}
723
-
724
-		return $final_values;
725
-	}
726
-
727
-	/**
728
-	 * Validate radio based settings.
729
-	 *
730
-	 * @since 2.0.0
731
-	 * @param string $value Value.
732
-	 * @param array  $setting Setting.
733
-	 * @return string|WP_Error
734
-	 */
735
-	public function validate_setting_radio_field( $value, $setting ) {
736
-		return $this->validate_setting_select_field( $value, $setting );
737
-	}
738
-
739
-	/**
740
-	 * Validate checkbox based settings.
741
-	 *
742
-	 * @since 2.0.0
743
-	 * @param string $value Value.
744
-	 * @return int
745
-	 */
746
-	public function validate_setting_checkbox_field( $value ) {
747
-		return (int) ! empty( $value );
748
-	}
749
-
750
-	/**
751
-	 * Validate textarea based settings.
752
-	 *
753
-	 * @since 2.0.0
754
-	 * @param string $value Value.
755
-	 * @return string
756
-	 */
757
-	public function validate_setting_textarea_field( $value ) {
758
-		$value = is_null( $value ) ? '' : $value;
759
-		return wp_kses(
760
-			trim( stripslashes( $value ) ),
761
-			array_merge(
762
-				array(
763
-					'iframe' => array(
764
-						'src'   => true,
765
-						'style' => true,
766
-						'id'    => true,
767
-						'class' => true,
768
-					),
769
-				),
770
-				wp_kses_allowed_html( 'post' )
771
-			)
772
-		);
773
-	}
664
+        // Cache the settings schema.
665
+        $this->schema = $schema;
666
+
667
+        return $this->add_additional_fields_schema( $this->schema );
668
+
669
+    }
670
+
671
+    /**
672
+     * Validate a text value for a text based setting.
673
+     *
674
+     * @since 2.0.0
675
+     * @param string $value Value.
676
+     * @param array  $setting Setting.
677
+     * @return string
678
+     */
679
+    public function validate_setting_text_field( $value ) {
680
+        $value = is_null( $value ) ? '' : $value;
681
+        return wp_kses_post( trim( stripslashes( $value ) ) );
682
+    }
683
+
684
+    /**
685
+     * Validate select based settings.
686
+     *
687
+     * @since 2.0.0
688
+     * @param string $value Value.
689
+     * @param array  $setting Setting.
690
+     * @return string|WP_Error
691
+     */
692
+    public function validate_setting_select_field( $value, $setting ) {
693
+        if ( array_key_exists( $value, $setting['options'] ) ) {
694
+            return $value;
695
+        } else {
696
+            return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) );
697
+        }
698
+    }
699
+
700
+    /**
701
+     * Validate multiselect based settings.
702
+     *
703
+     * @since 2.0.0
704
+     * @param array $values Values.
705
+     * @param array $setting Setting.
706
+     * @return array|WP_Error
707
+     */
708
+    public function validate_setting_multiselect_field( $values, $setting ) {
709
+        if ( empty( $values ) ) {
710
+            return array();
711
+        }
712
+
713
+        if ( ! is_array( $values ) ) {
714
+            return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) );
715
+        }
716
+
717
+        $final_values = array();
718
+        foreach ( $values as $value ) {
719
+            if ( array_key_exists( $value, $setting['options'] ) ) {
720
+                $final_values[] = $value;
721
+            }
722
+        }
723
+
724
+        return $final_values;
725
+    }
726
+
727
+    /**
728
+     * Validate radio based settings.
729
+     *
730
+     * @since 2.0.0
731
+     * @param string $value Value.
732
+     * @param array  $setting Setting.
733
+     * @return string|WP_Error
734
+     */
735
+    public function validate_setting_radio_field( $value, $setting ) {
736
+        return $this->validate_setting_select_field( $value, $setting );
737
+    }
738
+
739
+    /**
740
+     * Validate checkbox based settings.
741
+     *
742
+     * @since 2.0.0
743
+     * @param string $value Value.
744
+     * @return int
745
+     */
746
+    public function validate_setting_checkbox_field( $value ) {
747
+        return (int) ! empty( $value );
748
+    }
749
+
750
+    /**
751
+     * Validate textarea based settings.
752
+     *
753
+     * @since 2.0.0
754
+     * @param string $value Value.
755
+     * @return string
756
+     */
757
+    public function validate_setting_textarea_field( $value ) {
758
+        $value = is_null( $value ) ? '' : $value;
759
+        return wp_kses(
760
+            trim( stripslashes( $value ) ),
761
+            array_merge(
762
+                array(
763
+                    'iframe' => array(
764
+                        'src'   => true,
765
+                        'style' => true,
766
+                        'id'    => true,
767
+                        'class' => true,
768
+                    ),
769
+                ),
770
+                wp_kses_allowed_html( 'post' )
771
+            )
772
+        );
773
+    }
774 774
 
775 775
 }
Please login to merge, or discard this patch.
includes/reports/class-getpaid-reports-helper.php 1 patch
Indentation   +276 added lines, -276 removed lines patch added patch discarded remove patch
@@ -12,294 +12,294 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Reports_Helper {
14 14
 
15
-	/**
16
-	 * Get report totals such as invoice totals and discount amounts.
17
-	 *
18
-	 * Data example:
19
-	 *
20
-	 * 'subtotal' => array(
21
-	 *     'type'     => 'invoice_data',
22
-	 *     'function' => 'SUM',
23
-	 *     'name'     => 'subtotal'
24
-	 * )
25
-	 *
26
-	 * @param  array $args
27
-	 * @return mixed depending on query_type
28
-	 */
29
-	public static function get_invoice_report_data( $args = array() ) {
30
-		global $wpdb;
31
-
32
-		$default_args = array(
33
-			'data'                  => array(), // The data to retrieve.
34
-			'where'                 => array(), // An array of where queries.
35
-			'query_type'            => 'get_row', // wpdb query to run.
36
-			'group_by'              => '', // What to group results by.
37
-			'order_by'              => '', // What to order by.
38
-			'limit'                 => '', // Results limit.
39
-			'filter_range'          => array(), // An array of before and after dates to limit results by.
40
-			'invoice_types'         => array( 'wpi_invoice' ), // An array of post types to retrieve.
41
-			'invoice_status'        => array( 'publish', 'wpi-processing', 'wpi-onhold' ),
42
-			'parent_invoice_status' => false, // Optionally filter by parent invoice status.
43
-		);
44
-
45
-		$args         = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args );
46
-		$args         = wp_parse_args( $args, $default_args );
47
-
48
-		extract( $args );
49
-
50
-		if ( empty( $data ) ) {
51
-			return '';
52
-		}
53
-
54
-		$query           = array();
55
-		$query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) );
56
-		$query['from']   = "FROM {$wpdb->posts} AS posts";
57
-		$query['join']   = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) );
58
-
59
-		$query['where']  = "
15
+    /**
16
+     * Get report totals such as invoice totals and discount amounts.
17
+     *
18
+     * Data example:
19
+     *
20
+     * 'subtotal' => array(
21
+     *     'type'     => 'invoice_data',
22
+     *     'function' => 'SUM',
23
+     *     'name'     => 'subtotal'
24
+     * )
25
+     *
26
+     * @param  array $args
27
+     * @return mixed depending on query_type
28
+     */
29
+    public static function get_invoice_report_data( $args = array() ) {
30
+        global $wpdb;
31
+
32
+        $default_args = array(
33
+            'data'                  => array(), // The data to retrieve.
34
+            'where'                 => array(), // An array of where queries.
35
+            'query_type'            => 'get_row', // wpdb query to run.
36
+            'group_by'              => '', // What to group results by.
37
+            'order_by'              => '', // What to order by.
38
+            'limit'                 => '', // Results limit.
39
+            'filter_range'          => array(), // An array of before and after dates to limit results by.
40
+            'invoice_types'         => array( 'wpi_invoice' ), // An array of post types to retrieve.
41
+            'invoice_status'        => array( 'publish', 'wpi-processing', 'wpi-onhold' ),
42
+            'parent_invoice_status' => false, // Optionally filter by parent invoice status.
43
+        );
44
+
45
+        $args         = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args );
46
+        $args         = wp_parse_args( $args, $default_args );
47
+
48
+        extract( $args );
49
+
50
+        if ( empty( $data ) ) {
51
+            return '';
52
+        }
53
+
54
+        $query           = array();
55
+        $query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) );
56
+        $query['from']   = "FROM {$wpdb->posts} AS posts";
57
+        $query['join']   = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) );
58
+
59
+        $query['where']  = "
60 60
 			WHERE 	posts.post_type 	IN ( '" . implode( "','", $invoice_types ) . "' )
61 61
 			";
62 62
 
63
-		if ( ! empty( $invoice_status ) ) {
64
-			$query['where'] .= "
63
+        if ( ! empty( $invoice_status ) ) {
64
+            $query['where'] .= "
65 65
 				AND 	posts.post_status 	IN ( '" . implode( "','", $invoice_status ) . "' )
66 66
 			";
67
-		}
68
-
69
-		if ( ! empty( $parent_invoice_status ) ) {
70
-			if ( ! empty( $invoice_status ) ) {
71
-				$query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) ";
72
-			} else {
73
-				$query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) ";
74
-			}
75
-		}
76
-
77
-		if ( ! empty( $filter_range['before'] ) ) {
78
-			$query['where'] .= "
67
+        }
68
+
69
+        if ( ! empty( $parent_invoice_status ) ) {
70
+            if ( ! empty( $invoice_status ) ) {
71
+                $query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) ";
72
+            } else {
73
+                $query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) ";
74
+            }
75
+        }
76
+
77
+        if ( ! empty( $filter_range['before'] ) ) {
78
+            $query['where'] .= "
79 79
 				AND 	posts.post_date < '" . date( 'Y-m-d H:i:s', strtotime( $filter_range['before'] ) ) . "'
80 80
 			";
81
-		}
81
+        }
82 82
 
83
-		if ( ! empty( $filter_range['after'] ) ) {
84
-			$query['where'] .= "
83
+        if ( ! empty( $filter_range['after'] ) ) {
84
+            $query['where'] .= "
85 85
 				AND 	posts.post_date > '" . date( 'Y-m-d H:i:s', strtotime( $filter_range['after'] ) ) . "'
86 86
 			";
87
-		}
87
+        }
88 88
 
89
-		if ( ! empty( $where ) ) {
89
+        if ( ! empty( $where ) ) {
90 90
 
91
-			foreach ( $where as $value ) {
91
+            foreach ( $where as $value ) {
92 92
 
93
-				if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) {
94
-
95
-					if ( is_array( $value['value'] ) ) {
96
-						$value['value'] = implode( "','", $value['value'] );
97
-					}
98
-
99
-					if ( ! empty( $value['value'] ) ) {
100
-						$where_value = "{$value['operator']} ('{$value['value']}')";
101
-					}
102
-				} else {
103
-					$where_value = "{$value['operator']} '{$value['value']}'";
104
-				}
105
-
106
-				if ( ! empty( $where_value ) ) {
107
-					$query['where'] .= " AND {$value['key']} {$where_value}";
108
-				}
109
-			}
110
-		}
111
-
112
-		if ( $group_by ) {
113
-			$query['group_by'] = "GROUP BY {$group_by}";
114
-		}
115
-
116
-		if ( $order_by ) {
117
-			$query['order_by'] = "ORDER BY {$order_by}";
118
-		}
119
-
120
-		if ( $limit ) {
121
-			$query['limit'] = "LIMIT {$limit}";
122
-		}
123
-
124
-		$query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data );
125
-		$query = implode( ' ', $query );
126
-
127
-		return self::execute( $query_type, $query );
128
-
129
-	}
130
-
131
-	/**
132
-	 * Prepares the data to select.
133
-	 *
134
-	 *
135
-	 * @param  array $data
136
-	 * @return array
137
-	 */
138
-	public static function prepare_invoice_data( $data ) {
139
-
140
-		$prepared = array();
141
-
142
-		foreach ( $data as $raw_key => $value ) {
143
-			$key      = sanitize_key( $raw_key );
144
-			$distinct = '';
145
-
146
-			if ( isset( $value['distinct'] ) ) {
147
-				$distinct = 'DISTINCT';
148
-			}
149
-
150
-			$get_key = self::get_invoice_table_key( $key, $value['type'] );
151
-
152
-			if ( false === $get_key ) {
153
-				// Skip to the next foreach iteration else the query will be invalid.
154
-				continue;
155
-			}
156
-
157
-			if ( ! empty( $value['function'] ) ) {
158
-				$get = "{$value['function']}({$distinct} {$get_key})";
159
-			} else {
160
-				$get = "{$distinct} {$get_key}";
161
-			}
162
-
163
-			$prepared[] = "{$get} as {$value['name']}";
164
-		}
165
-
166
-		return $prepared;
167
-
168
-	}
169
-
170
-	/**
171
-	 * Prepares the joins to use.
172
-	 *
173
-	 *
174
-	 * @param  array $data
175
-	 * @param  bool $with_parent
176
-	 * @return array
177
-	 */
178
-	public static function prepare_invoice_joins( $data, $with_parent ) {
179
-		global $wpdb;
180
-
181
-		$prepared = array();
182
-
183
-		foreach ( $data as $raw_key => $value ) {
184
-			$join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER';
185
-			$type      = isset( $value['type'] ) ? $value['type'] : false;
186
-			$key       = sanitize_key( $raw_key );
187
-
188
-			switch ( $type ) {
189
-				case 'meta':
190
-					$prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )";
191
-					break;
192
-				case 'parent_meta':
193
-					$prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')";
194
-					break;
195
-				case 'invoice_data':
196
-					$prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id";
197
-					break;
198
-				case 'invoice_item':
199
-					$prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id";
200
-					break;
201
-			}
202
-		}
203
-
204
-		if ( $with_parent ) {
205
-			$prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID";
206
-		}
207
-
208
-		return $prepared;
209
-
210
-	}
211
-
212
-	/**
213
-	 * Retrieves the appropriate table key to use.
214
-	 *
215
-	 *
216
-	 * @param  string $key
217
-	 * @param  string $table
218
-	 * @return string|false
219
-	 */
220
-	public static function get_invoice_table_key( $key, $table ) {
221
-
222
-		$keys = array(
223
-			'meta'         => "meta_{$key}.meta_value",
224
-			'parent_meta'  => "parent_meta_{$key}.meta_value",
225
-			'post_data'    => "posts.{$key}",
226
-			'invoice_data' => "invoices.{$key}",
227
-			'invoice_item' => "invoice_items.{$key}",
228
-		);
229
-
230
-		return isset( $keys[ $table ] ) ? $keys[ $table ] : false;
231
-
232
-	}
233
-
234
-	/**
235
-	 * Executes a query and caches the result for a minute.
236
-	 *
237
-	 *
238
-	 * @param  string $query_type
239
-	 * @param  string $query
240
-	 * @return mixed depending on query_type
241
-	 */
242
-	public static function execute( $query_type, $query ) {
243
-		global $wpdb;
244
-
245
-		$query_hash = md5( $query_type . $query );
246
-		$result     = self::get_cached_query( $query_hash );
247
-		if ( $result === false ) {
248
-			self::enable_big_selects();
249
-
250
-			$result = $wpdb->$query_type( $query );
251
-			self::set_cached_query( $query_hash, $result );
252
-		}
253
-
254
-		return $result;
255
-
256
-	}
257
-
258
-	/**
259
-	 * Enables big mysql selects for reports, just once for this session.
260
-	 */
261
-	protected static function enable_big_selects() {
262
-		static $big_selects = false;
263
-
264
-		global $wpdb;
265
-
266
-		if ( ! $big_selects ) {
267
-			$wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' );
268
-			$big_selects = true;
269
-		}
270
-	}
271
-
272
-	/**
273
-	 * Get the cached query result or null if it's not in the cache.
274
-	 *
275
-	 * @param string $query_hash The query hash.
276
-	 *
277
-	 * @return mixed|false The cache contents on success, false on failure to retrieve contents.
278
-	 */
279
-	protected static function get_cached_query( $query_hash ) {
280
-
281
-		return wp_cache_get(
282
-			$query_hash,
283
-			strtolower( __CLASS__ )
284
-		);
285
-
286
-	}
287
-
288
-	/**
289
-	 * Set the cached query result.
290
-	 *
291
-	 * @param string $query_hash The query hash.
292
-	 * @param mixed  $data The data to cache.
293
-	 */
294
-	protected static function set_cached_query( $query_hash, $data ) {
295
-
296
-		wp_cache_set(
297
-			$query_hash,
298
-			$data,
299
-			strtolower( __CLASS__ ),
300
-			5 * MINUTE_IN_SECONDS
301
-		);
302
-
303
-	}
93
+                if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) {
94
+
95
+                    if ( is_array( $value['value'] ) ) {
96
+                        $value['value'] = implode( "','", $value['value'] );
97
+                    }
98
+
99
+                    if ( ! empty( $value['value'] ) ) {
100
+                        $where_value = "{$value['operator']} ('{$value['value']}')";
101
+                    }
102
+                } else {
103
+                    $where_value = "{$value['operator']} '{$value['value']}'";
104
+                }
105
+
106
+                if ( ! empty( $where_value ) ) {
107
+                    $query['where'] .= " AND {$value['key']} {$where_value}";
108
+                }
109
+            }
110
+        }
111
+
112
+        if ( $group_by ) {
113
+            $query['group_by'] = "GROUP BY {$group_by}";
114
+        }
115
+
116
+        if ( $order_by ) {
117
+            $query['order_by'] = "ORDER BY {$order_by}";
118
+        }
119
+
120
+        if ( $limit ) {
121
+            $query['limit'] = "LIMIT {$limit}";
122
+        }
123
+
124
+        $query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data );
125
+        $query = implode( ' ', $query );
126
+
127
+        return self::execute( $query_type, $query );
128
+
129
+    }
130
+
131
+    /**
132
+     * Prepares the data to select.
133
+     *
134
+     *
135
+     * @param  array $data
136
+     * @return array
137
+     */
138
+    public static function prepare_invoice_data( $data ) {
139
+
140
+        $prepared = array();
141
+
142
+        foreach ( $data as $raw_key => $value ) {
143
+            $key      = sanitize_key( $raw_key );
144
+            $distinct = '';
145
+
146
+            if ( isset( $value['distinct'] ) ) {
147
+                $distinct = 'DISTINCT';
148
+            }
149
+
150
+            $get_key = self::get_invoice_table_key( $key, $value['type'] );
151
+
152
+            if ( false === $get_key ) {
153
+                // Skip to the next foreach iteration else the query will be invalid.
154
+                continue;
155
+            }
156
+
157
+            if ( ! empty( $value['function'] ) ) {
158
+                $get = "{$value['function']}({$distinct} {$get_key})";
159
+            } else {
160
+                $get = "{$distinct} {$get_key}";
161
+            }
162
+
163
+            $prepared[] = "{$get} as {$value['name']}";
164
+        }
165
+
166
+        return $prepared;
167
+
168
+    }
169
+
170
+    /**
171
+     * Prepares the joins to use.
172
+     *
173
+     *
174
+     * @param  array $data
175
+     * @param  bool $with_parent
176
+     * @return array
177
+     */
178
+    public static function prepare_invoice_joins( $data, $with_parent ) {
179
+        global $wpdb;
180
+
181
+        $prepared = array();
182
+
183
+        foreach ( $data as $raw_key => $value ) {
184
+            $join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER';
185
+            $type      = isset( $value['type'] ) ? $value['type'] : false;
186
+            $key       = sanitize_key( $raw_key );
187
+
188
+            switch ( $type ) {
189
+                case 'meta':
190
+                    $prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )";
191
+                    break;
192
+                case 'parent_meta':
193
+                    $prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')";
194
+                    break;
195
+                case 'invoice_data':
196
+                    $prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id";
197
+                    break;
198
+                case 'invoice_item':
199
+                    $prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id";
200
+                    break;
201
+            }
202
+        }
203
+
204
+        if ( $with_parent ) {
205
+            $prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID";
206
+        }
207
+
208
+        return $prepared;
209
+
210
+    }
211
+
212
+    /**
213
+     * Retrieves the appropriate table key to use.
214
+     *
215
+     *
216
+     * @param  string $key
217
+     * @param  string $table
218
+     * @return string|false
219
+     */
220
+    public static function get_invoice_table_key( $key, $table ) {
221
+
222
+        $keys = array(
223
+            'meta'         => "meta_{$key}.meta_value",
224
+            'parent_meta'  => "parent_meta_{$key}.meta_value",
225
+            'post_data'    => "posts.{$key}",
226
+            'invoice_data' => "invoices.{$key}",
227
+            'invoice_item' => "invoice_items.{$key}",
228
+        );
229
+
230
+        return isset( $keys[ $table ] ) ? $keys[ $table ] : false;
231
+
232
+    }
233
+
234
+    /**
235
+     * Executes a query and caches the result for a minute.
236
+     *
237
+     *
238
+     * @param  string $query_type
239
+     * @param  string $query
240
+     * @return mixed depending on query_type
241
+     */
242
+    public static function execute( $query_type, $query ) {
243
+        global $wpdb;
244
+
245
+        $query_hash = md5( $query_type . $query );
246
+        $result     = self::get_cached_query( $query_hash );
247
+        if ( $result === false ) {
248
+            self::enable_big_selects();
249
+
250
+            $result = $wpdb->$query_type( $query );
251
+            self::set_cached_query( $query_hash, $result );
252
+        }
253
+
254
+        return $result;
255
+
256
+    }
257
+
258
+    /**
259
+     * Enables big mysql selects for reports, just once for this session.
260
+     */
261
+    protected static function enable_big_selects() {
262
+        static $big_selects = false;
263
+
264
+        global $wpdb;
265
+
266
+        if ( ! $big_selects ) {
267
+            $wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' );
268
+            $big_selects = true;
269
+        }
270
+    }
271
+
272
+    /**
273
+     * Get the cached query result or null if it's not in the cache.
274
+     *
275
+     * @param string $query_hash The query hash.
276
+     *
277
+     * @return mixed|false The cache contents on success, false on failure to retrieve contents.
278
+     */
279
+    protected static function get_cached_query( $query_hash ) {
280
+
281
+        return wp_cache_get(
282
+            $query_hash,
283
+            strtolower( __CLASS__ )
284
+        );
285
+
286
+    }
287
+
288
+    /**
289
+     * Set the cached query result.
290
+     *
291
+     * @param string $query_hash The query hash.
292
+     * @param mixed  $data The data to cache.
293
+     */
294
+    protected static function set_cached_query( $query_hash, $data ) {
295
+
296
+        wp_cache_set(
297
+            $query_hash,
298
+            $data,
299
+            strtolower( __CLASS__ ),
300
+            5 * MINUTE_IN_SECONDS
301
+        );
302
+
303
+    }
304 304
 
305 305
 }
Please login to merge, or discard this patch.
includes/api/class-getpaid-rest-report-top-earners-controller.php 1 patch
Indentation   +42 added lines, -42 removed lines patch added patch discarded remove patch
@@ -18,50 +18,50 @@
 block discarded – undo
18 18
  */
19 19
 class GetPaid_REST_Report_Top_Earners_Controller extends GetPaid_REST_Report_Top_Sellers_Controller {
20 20
 
21
-	/**
22
-	 * Route base.
23
-	 *
24
-	 * @var string
25
-	 */
26
-	protected $rest_base = 'reports/top_earners';
21
+    /**
22
+     * Route base.
23
+     *
24
+     * @var string
25
+     */
26
+    protected $rest_base = 'reports/top_earners';
27 27
 
28
-	/**
29
-	 * Get all data needed for this report and store in the class.
30
-	 */
31
-	protected function query_report_data() {
28
+    /**
29
+     * Get all data needed for this report and store in the class.
30
+     */
31
+    protected function query_report_data() {
32 32
 
33
-		$this->report_data = GetPaid_Reports_Helper::get_invoice_report_data(
34
-			array(
35
-				'data'              => array(
36
-					'quantity'      => array(
37
-						'type'            => 'invoice_item',
38
-						'function'        => 'SUM',
39
-						'name'            => 'invoice_item_qty',
40
-					),
41
-					'item_id'             => array(
42
-						'type'            => 'invoice_item',
43
-						'function'        => '',
44
-						'name'            => 'invoice_item_id',
45
-					),
46
-					'item_name'           => array(
47
-						'type'            => 'invoice_item',
48
-						'function'        => '',
49
-						'name'            => 'invoice_item_name',
50
-					),
51
-					'price'               => array(
52
-						'type'            => 'invoice_item',
53
-						'function'        => 'SUM',
54
-						'name'            => 'invoice_item_price',
55
-					),
56
-				),
57
-				'group_by'       => 'invoice_item_id',
58
-				'order_by'       => 'invoice_item_price DESC',
59
-				'query_type'     => 'get_results',
60
-				'limit'          => 10,
61
-				'filter_range'   => $this->report_range,
62
-			)
63
-		);
33
+        $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data(
34
+            array(
35
+                'data'              => array(
36
+                    'quantity'      => array(
37
+                        'type'            => 'invoice_item',
38
+                        'function'        => 'SUM',
39
+                        'name'            => 'invoice_item_qty',
40
+                    ),
41
+                    'item_id'             => array(
42
+                        'type'            => 'invoice_item',
43
+                        'function'        => '',
44
+                        'name'            => 'invoice_item_id',
45
+                    ),
46
+                    'item_name'           => array(
47
+                        'type'            => 'invoice_item',
48
+                        'function'        => '',
49
+                        'name'            => 'invoice_item_name',
50
+                    ),
51
+                    'price'               => array(
52
+                        'type'            => 'invoice_item',
53
+                        'function'        => 'SUM',
54
+                        'name'            => 'invoice_item_price',
55
+                    ),
56
+                ),
57
+                'group_by'       => 'invoice_item_id',
58
+                'order_by'       => 'invoice_item_price DESC',
59
+                'query_type'     => 'get_results',
60
+                'limit'          => 10,
61
+                'filter_range'   => $this->report_range,
62
+            )
63
+        );
64 64
 
65
-	}
65
+    }
66 66
 
67 67
 }
Please login to merge, or discard this patch.
includes/api/class-getpaid-rest-report-top-sellers-controller.php 1 patch
Indentation   +175 added lines, -175 removed lines patch added patch discarded remove patch
@@ -18,179 +18,179 @@
 block discarded – undo
18 18
  */
19 19
 class GetPaid_REST_Report_Top_Sellers_Controller extends GetPaid_REST_Report_Sales_Controller {
20 20
 
21
-	/**
22
-	 * Route base.
23
-	 *
24
-	 * @var string
25
-	 */
26
-	protected $rest_base = 'reports/top_sellers';
27
-
28
-	/**
29
-	 * Get top sellers report.
30
-	 *
31
-	 * @param WP_REST_Request $request
32
-	 * @return array|WP_Error
33
-	 */
34
-	public function get_items( $request ) {
35
-
36
-		// Prepare items.
37
-		$this->report_range = $this->get_date_range( $request );
38
-		$report_data        = $this->get_report_data();
39
-
40
-		$top_sellers = array();
41
-
42
-		foreach ( $report_data as $item ) {
43
-
44
-			$item_obj  = new WPInv_Item( $item );
45
-			$item_name = $item->invoice_item_name;
46
-			$item_qty  = absint( $item->invoice_item_qty );
47
-			$item_id   = absint( $item->invoice_item_id );
48
-			$price     = sanitize_text_field( wpinv_price( $item->invoice_item_price ) );
49
-
50
-			$item_obj  = new WPInv_Item( $item_id );
51
-
52
-			if ( $item_obj->exists() ) {
53
-				$item_name = $item_obj->get_name();
54
-			} else {
55
-				$item_id   = 0; 
56
-			}
57
-
58
-			$top_sellers[] = array(
59
-				'name'               =>sanitize_text_field( $item_name ),
60
-				'item_id'            => $item_id,
61
-				'quantity'           => $item_qty,
62
-				'earnings'           => wpinv_round_amount( $item->invoice_item_price ),
63
-				'earnings_formatted' => sanitize_text_field( wpinv_price( $price ) ),
64
-			);
65
-
66
-		}
67
-
68
-		$data = array();
69
-		foreach ( $top_sellers as $top_seller ) {
70
-			$item   = $this->prepare_item_for_response( (object) $top_seller, $request );
71
-			$data[] = $this->prepare_response_for_collection( $item );
72
-		}
73
-
74
-		return rest_ensure_response( $data );
75
-
76
-	}
77
-
78
-	/**
79
-	 * Prepare a report sales object for serialization.
80
-	 *
81
-	 * @param stdClass $top_seller
82
-	 * @param WP_REST_Request $request Request object.
83
-	 * @return WP_REST_Response $response Response data.
84
-	 */
85
-	public function prepare_item_for_response( $top_seller, $request ) {
86
-		$data    = (array) $top_seller;
87
-
88
-		$context = ! empty( $request['context'] ) ? $request['context'] : 'view';
89
-		$data    = $this->add_additional_fields_to_object( $data, $request );
90
-		$data    = $this->filter_response_by_context( $data, $context );
91
-
92
-		// Wrap the data in a response object.
93
-		$response = rest_ensure_response( $data );
94
-		$links = array(
95
-			'about' => array(
96
-				'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ),
97
-			),
98
-		);
99
-
100
-		if ( ! empty( $top_seller->item_id ) ) {
101
-			$links['item']   = array(
102
-				'href'       => rest_url( sprintf( '/%s/items/%s', $this->namespace, $top_seller->item_id ) ),
103
-				'embeddable' => true,
104
-			);
105
-		}
106
-
107
-		$response->add_links( $links );
108
-		return apply_filters( 'getpaid_rest_prepare_report_' . $this->rest_base, $response, $top_seller, $request );
109
-	}
110
-
111
-	/**
112
-	 * Get all data needed for this report and store in the class.
113
-	 */
114
-	protected function query_report_data() {
115
-
116
-		$this->report_data = GetPaid_Reports_Helper::get_invoice_report_data(
117
-			array(
118
-				'data'              => array(
119
-					'quantity'      => array(
120
-						'type'            => 'invoice_item',
121
-						'function'        => 'SUM',
122
-						'name'            => 'invoice_item_qty',
123
-					),
124
-					'item_id'             => array(
125
-						'type'            => 'invoice_item',
126
-						'function'        => '',
127
-						'name'            => 'invoice_item_id',
128
-					),
129
-					'item_name'           => array(
130
-						'type'            => 'invoice_item',
131
-						'function'        => '',
132
-						'name'            => 'invoice_item_name',
133
-					),
134
-					'price'               => array(
135
-						'type'            => 'invoice_item',
136
-						'function'        => 'SUM',
137
-						'name'            => 'invoice_item_price',
138
-					),
139
-				),
140
-				'group_by'       => 'invoice_item_id',
141
-				'order_by'       => 'invoice_item_qty DESC',
142
-				'query_type'     => 'get_results',
143
-				'limit'          => 10,
144
-				'filter_range'   => $this->report_range,
145
-			)
146
-		);
147
-
148
-	}
149
-
150
-	/**
151
-	 * Get the Report's schema, conforming to JSON Schema.
152
-	 *
153
-	 * @return array
154
-	 */
155
-	public function get_item_schema() {
156
-		$schema = array(
157
-			'$schema'    => 'http://json-schema.org/draft-04/schema#',
158
-			'title'      => $this->rest_base,
159
-			'type'       => 'object',
160
-			'properties' => array(
161
-				'name' => array(
162
-					'description' => __( 'Item name.', 'invoicing' ),
163
-					'type'        => 'string',
164
-					'context'     => array( 'view' ),
165
-					'readonly'    => true,
166
-				),
167
-				'item_id'         => array(
168
-					'description' => __( 'Item ID.', 'invoicing' ),
169
-					'type'        => 'integer',
170
-					'context'     => array( 'view' ),
171
-					'readonly'    => true,
172
-				),
173
-				'quantity' => array(
174
-					'description' => __( 'Total number of purchases.', 'invoicing' ),
175
-					'type'        => 'integer',
176
-					'context'     => array( 'view' ),
177
-					'readonly'    => true,
178
-				),
179
-				'earnings' => array(
180
-					'description' => __( 'Total earnings for the item.', 'invoicing' ),
181
-					'type'        => 'double',
182
-					'context'     => array( 'view' ),
183
-					'readonly'    => true,
184
-				),
185
-				'earnings_formatted"' => array(
186
-					'description' => __( 'Total earnings (formatted) for the item.', 'invoicing' ),
187
-					'type'        => 'string',
188
-					'context'     => array( 'view' ),
189
-					'readonly'    => true,
190
-				),
191
-			),
192
-		);
193
-
194
-		return $this->add_additional_fields_schema( $schema );
195
-	}
21
+    /**
22
+     * Route base.
23
+     *
24
+     * @var string
25
+     */
26
+    protected $rest_base = 'reports/top_sellers';
27
+
28
+    /**
29
+     * Get top sellers report.
30
+     *
31
+     * @param WP_REST_Request $request
32
+     * @return array|WP_Error
33
+     */
34
+    public function get_items( $request ) {
35
+
36
+        // Prepare items.
37
+        $this->report_range = $this->get_date_range( $request );
38
+        $report_data        = $this->get_report_data();
39
+
40
+        $top_sellers = array();
41
+
42
+        foreach ( $report_data as $item ) {
43
+
44
+            $item_obj  = new WPInv_Item( $item );
45
+            $item_name = $item->invoice_item_name;
46
+            $item_qty  = absint( $item->invoice_item_qty );
47
+            $item_id   = absint( $item->invoice_item_id );
48
+            $price     = sanitize_text_field( wpinv_price( $item->invoice_item_price ) );
49
+
50
+            $item_obj  = new WPInv_Item( $item_id );
51
+
52
+            if ( $item_obj->exists() ) {
53
+                $item_name = $item_obj->get_name();
54
+            } else {
55
+                $item_id   = 0; 
56
+            }
57
+
58
+            $top_sellers[] = array(
59
+                'name'               =>sanitize_text_field( $item_name ),
60
+                'item_id'            => $item_id,
61
+                'quantity'           => $item_qty,
62
+                'earnings'           => wpinv_round_amount( $item->invoice_item_price ),
63
+                'earnings_formatted' => sanitize_text_field( wpinv_price( $price ) ),
64
+            );
65
+
66
+        }
67
+
68
+        $data = array();
69
+        foreach ( $top_sellers as $top_seller ) {
70
+            $item   = $this->prepare_item_for_response( (object) $top_seller, $request );
71
+            $data[] = $this->prepare_response_for_collection( $item );
72
+        }
73
+
74
+        return rest_ensure_response( $data );
75
+
76
+    }
77
+
78
+    /**
79
+     * Prepare a report sales object for serialization.
80
+     *
81
+     * @param stdClass $top_seller
82
+     * @param WP_REST_Request $request Request object.
83
+     * @return WP_REST_Response $response Response data.
84
+     */
85
+    public function prepare_item_for_response( $top_seller, $request ) {
86
+        $data    = (array) $top_seller;
87
+
88
+        $context = ! empty( $request['context'] ) ? $request['context'] : 'view';
89
+        $data    = $this->add_additional_fields_to_object( $data, $request );
90
+        $data    = $this->filter_response_by_context( $data, $context );
91
+
92
+        // Wrap the data in a response object.
93
+        $response = rest_ensure_response( $data );
94
+        $links = array(
95
+            'about' => array(
96
+                'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ),
97
+            ),
98
+        );
99
+
100
+        if ( ! empty( $top_seller->item_id ) ) {
101
+            $links['item']   = array(
102
+                'href'       => rest_url( sprintf( '/%s/items/%s', $this->namespace, $top_seller->item_id ) ),
103
+                'embeddable' => true,
104
+            );
105
+        }
106
+
107
+        $response->add_links( $links );
108
+        return apply_filters( 'getpaid_rest_prepare_report_' . $this->rest_base, $response, $top_seller, $request );
109
+    }
110
+
111
+    /**
112
+     * Get all data needed for this report and store in the class.
113
+     */
114
+    protected function query_report_data() {
115
+
116
+        $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data(
117
+            array(
118
+                'data'              => array(
119
+                    'quantity'      => array(
120
+                        'type'            => 'invoice_item',
121
+                        'function'        => 'SUM',
122
+                        'name'            => 'invoice_item_qty',
123
+                    ),
124
+                    'item_id'             => array(
125
+                        'type'            => 'invoice_item',
126
+                        'function'        => '',
127
+                        'name'            => 'invoice_item_id',
128
+                    ),
129
+                    'item_name'           => array(
130
+                        'type'            => 'invoice_item',
131
+                        'function'        => '',
132
+                        'name'            => 'invoice_item_name',
133
+                    ),
134
+                    'price'               => array(
135
+                        'type'            => 'invoice_item',
136
+                        'function'        => 'SUM',
137
+                        'name'            => 'invoice_item_price',
138
+                    ),
139
+                ),
140
+                'group_by'       => 'invoice_item_id',
141
+                'order_by'       => 'invoice_item_qty DESC',
142
+                'query_type'     => 'get_results',
143
+                'limit'          => 10,
144
+                'filter_range'   => $this->report_range,
145
+            )
146
+        );
147
+
148
+    }
149
+
150
+    /**
151
+     * Get the Report's schema, conforming to JSON Schema.
152
+     *
153
+     * @return array
154
+     */
155
+    public function get_item_schema() {
156
+        $schema = array(
157
+            '$schema'    => 'http://json-schema.org/draft-04/schema#',
158
+            'title'      => $this->rest_base,
159
+            'type'       => 'object',
160
+            'properties' => array(
161
+                'name' => array(
162
+                    'description' => __( 'Item name.', 'invoicing' ),
163
+                    'type'        => 'string',
164
+                    'context'     => array( 'view' ),
165
+                    'readonly'    => true,
166
+                ),
167
+                'item_id'         => array(
168
+                    'description' => __( 'Item ID.', 'invoicing' ),
169
+                    'type'        => 'integer',
170
+                    'context'     => array( 'view' ),
171
+                    'readonly'    => true,
172
+                ),
173
+                'quantity' => array(
174
+                    'description' => __( 'Total number of purchases.', 'invoicing' ),
175
+                    'type'        => 'integer',
176
+                    'context'     => array( 'view' ),
177
+                    'readonly'    => true,
178
+                ),
179
+                'earnings' => array(
180
+                    'description' => __( 'Total earnings for the item.', 'invoicing' ),
181
+                    'type'        => 'double',
182
+                    'context'     => array( 'view' ),
183
+                    'readonly'    => true,
184
+                ),
185
+                'earnings_formatted"' => array(
186
+                    'description' => __( 'Total earnings (formatted) for the item.', 'invoicing' ),
187
+                    'type'        => 'string',
188
+                    'context'     => array( 'view' ),
189
+                    'readonly'    => true,
190
+                ),
191
+            ),
192
+        );
193
+
194
+        return $this->add_additional_fields_schema( $schema );
195
+    }
196 196
 }
Please login to merge, or discard this patch.
includes/api/class-getpaid-rest-report-invoice-counts-controller.php 1 patch
Indentation   +98 added lines, -98 removed lines patch added patch discarded remove patch
@@ -18,102 +18,102 @@
 block discarded – undo
18 18
  */
19 19
 class GetPaid_REST_Report_Invoice_Counts_Controller extends GetPaid_REST_Reports_Controller {
20 20
 
21
-	/**
22
-	 * Route base.
23
-	 *
24
-	 * @var string
25
-	 */
26
-	protected $rest_base = 'reports/invoices/counts';
27
-
28
-	/**
29
-	 * Prepare a report object for serialization.
30
-	 *
31
-	 * @param  stdClass        $report Report data.
32
-	 * @param  WP_REST_Request $request Request object.
33
-	 * @return WP_REST_Response $response Response data.
34
-	 */
35
-	public function prepare_item_for_response( $report, $request ) {
36
-
37
-		$data    = (array) $report;
38
-		$context = ! empty( $request['context'] ) ? $request['context'] : 'view';
39
-		$data    = $this->add_additional_fields_to_object( $data, $request );
40
-		$data    = $this->filter_response_by_context( $data, $context );
41
-
42
-		// Wrap the data in a response object.
43
-		$response = rest_ensure_response( $data );
44
-
45
-		$response->add_links(
46
-			array(
47
-				'about' => array(
48
-					'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ),
49
-				),
50
-			)
51
-		);
52
-
53
-		return apply_filters( 'getpaid_rest_prepare_report_invoices_count', $response, $report, $request );
54
-	}
55
-
56
-	/**
57
-	 * Get reports list.
58
-	 *
59
-	 * @since 2.0.0
60
-	 * @return array
61
-	 */
62
-	protected function get_reports() {
63
-
64
-		$counts = wp_count_posts( 'wpi_invoice' );
65
-		$data   = array();
66
-
67
-		foreach ( wpinv_get_invoice_statuses() as $slug => $name ) {
68
-
69
-			if ( ! isset( $counts->$slug ) ) {
70
-				continue;
71
-			}
72
-
73
-			$data[] = array(
74
-				'slug'  => $slug,
75
-				'name'  => $name,
76
-				'count' => (int) $counts->$slug,
77
-			);
78
-
79
-		}
80
-
81
-		return $data;
82
-
83
-	}
84
-
85
-	/**
86
-	 * Get the Report's schema, conforming to JSON Schema.
87
-	 *
88
-	 * @return array
89
-	 */
90
-	public function get_item_schema() {
91
-		$schema = array(
92
-			'$schema'    => 'http://json-schema.org/draft-04/schema#',
93
-			'title'      => 'report_invoice_counts',
94
-			'type'       => 'object',
95
-			'properties' => array(
96
-				'slug'  => array(
97
-					'description' => __( 'An alphanumeric identifier for the resource.', 'invoicing' ),
98
-					'type'        => 'string',
99
-					'context'     => array( 'view' ),
100
-					'readonly'    => true,
101
-				),
102
-				'name'  => array(
103
-					'description' => __( 'Invoice status name.', 'invoicing' ),
104
-					'type'        => 'string',
105
-					'context'     => array( 'view' ),
106
-					'readonly'    => true,
107
-				),
108
-				'count' => array(
109
-					'description' => __( 'Number of invoices.', 'invoicing' ),
110
-					'type'        => 'string',
111
-					'context'     => array( 'view' ),
112
-					'readonly'    => true,
113
-				),
114
-			),
115
-		);
116
-
117
-		return $this->add_additional_fields_schema( $schema );
118
-	}
21
+    /**
22
+     * Route base.
23
+     *
24
+     * @var string
25
+     */
26
+    protected $rest_base = 'reports/invoices/counts';
27
+
28
+    /**
29
+     * Prepare a report object for serialization.
30
+     *
31
+     * @param  stdClass        $report Report data.
32
+     * @param  WP_REST_Request $request Request object.
33
+     * @return WP_REST_Response $response Response data.
34
+     */
35
+    public function prepare_item_for_response( $report, $request ) {
36
+
37
+        $data    = (array) $report;
38
+        $context = ! empty( $request['context'] ) ? $request['context'] : 'view';
39
+        $data    = $this->add_additional_fields_to_object( $data, $request );
40
+        $data    = $this->filter_response_by_context( $data, $context );
41
+
42
+        // Wrap the data in a response object.
43
+        $response = rest_ensure_response( $data );
44
+
45
+        $response->add_links(
46
+            array(
47
+                'about' => array(
48
+                    'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ),
49
+                ),
50
+            )
51
+        );
52
+
53
+        return apply_filters( 'getpaid_rest_prepare_report_invoices_count', $response, $report, $request );
54
+    }
55
+
56
+    /**
57
+     * Get reports list.
58
+     *
59
+     * @since 2.0.0
60
+     * @return array
61
+     */
62
+    protected function get_reports() {
63
+
64
+        $counts = wp_count_posts( 'wpi_invoice' );
65
+        $data   = array();
66
+
67
+        foreach ( wpinv_get_invoice_statuses() as $slug => $name ) {
68
+
69
+            if ( ! isset( $counts->$slug ) ) {
70
+                continue;
71
+            }
72
+
73
+            $data[] = array(
74
+                'slug'  => $slug,
75
+                'name'  => $name,
76
+                'count' => (int) $counts->$slug,
77
+            );
78
+
79
+        }
80
+
81
+        return $data;
82
+
83
+    }
84
+
85
+    /**
86
+     * Get the Report's schema, conforming to JSON Schema.
87
+     *
88
+     * @return array
89
+     */
90
+    public function get_item_schema() {
91
+        $schema = array(
92
+            '$schema'    => 'http://json-schema.org/draft-04/schema#',
93
+            'title'      => 'report_invoice_counts',
94
+            'type'       => 'object',
95
+            'properties' => array(
96
+                'slug'  => array(
97
+                    'description' => __( 'An alphanumeric identifier for the resource.', 'invoicing' ),
98
+                    'type'        => 'string',
99
+                    'context'     => array( 'view' ),
100
+                    'readonly'    => true,
101
+                ),
102
+                'name'  => array(
103
+                    'description' => __( 'Invoice status name.', 'invoicing' ),
104
+                    'type'        => 'string',
105
+                    'context'     => array( 'view' ),
106
+                    'readonly'    => true,
107
+                ),
108
+                'count' => array(
109
+                    'description' => __( 'Number of invoices.', 'invoicing' ),
110
+                    'type'        => 'string',
111
+                    'context'     => array( 'view' ),
112
+                    'readonly'    => true,
113
+                ),
114
+            ),
115
+        );
116
+
117
+        return $this->add_additional_fields_schema( $schema );
118
+    }
119 119
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php 1 patch
Indentation   +18 added lines, -18 removed lines patch added patch discarded remove patch
@@ -7,40 +7,40 @@
 block discarded – undo
7 7
  * Bail if we are not in WP.
8 8
  */
9 9
 if ( ! defined( 'ABSPATH' ) ) {
10
-	exit;
10
+    exit;
11 11
 }
12 12
 
13 13
 /**
14 14
  * Set the version only if its the current newest while loading.
15 15
  */
16 16
 add_action('after_setup_theme', function () {
17
-	global $ayecode_ui_version,$ayecode_ui_file_key;
18
-	$this_version = "0.1.38";
19
-	if(version_compare($this_version , $ayecode_ui_version, '>')){
20
-		$ayecode_ui_version = $this_version ;
21
-		$ayecode_ui_file_key = wp_hash( __FILE__ );
22
-	}
17
+    global $ayecode_ui_version,$ayecode_ui_file_key;
18
+    $this_version = "0.1.38";
19
+    if(version_compare($this_version , $ayecode_ui_version, '>')){
20
+        $ayecode_ui_version = $this_version ;
21
+        $ayecode_ui_file_key = wp_hash( __FILE__ );
22
+    }
23 23
 },0);
24 24
 
25 25
 /**
26 26
  * Load this version of WP Bootstrap Settings only if the file hash is the current one.
27 27
  */
28 28
 add_action('after_setup_theme', function () {
29
-	global $ayecode_ui_file_key;
30
-	if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
-		include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
-		include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
-	}
29
+    global $ayecode_ui_file_key;
30
+    if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
+        include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
+        include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
+    }
34 34
 },1);
35 35
 
36 36
 /**
37 37
  * Add the function that calls the class.
38 38
  */
39 39
 if(!function_exists('aui')){
40
-	function aui(){
41
-		if(!class_exists("AUI",false)){
42
-			return false;
43
-		}
44
-		return AUI::instance();
45
-	}
40
+    function aui(){
41
+        if(!class_exists("AUI",false)){
42
+            return false;
43
+        }
44
+        return AUI::instance();
45
+    }
46 46
 }
47 47
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/class-aui.php 1 patch
Indentation   +227 added lines, -227 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,231 +11,231 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI {
13 13
 
14
-	/**
15
-	 * Holds the class instance.
16
-	 *
17
-	 * @since 1.0.0
18
-	 * @var null
19
-	 */
20
-	private static $instance = null;
21
-
22
-	/**
23
-	 * Holds the current AUI version number.
24
-	 *
25
-	 * @var string $ver The current version number.
26
-	 */
27
-	public static $ver = '0.1.38';
28
-
29
-	public static $options = null;
30
-
31
-	/**
32
-	 * There can be only one.
33
-	 *
34
-	 * @since 1.0.0
35
-	 * @return AUI|null
36
-	 */
37
-	public static function instance() {
38
-		if ( self::$instance == null ) {
39
-			self::$instance = new AUI();
40
-		}
41
-
42
-		return self::$instance;
43
-	}
44
-
45
-	/**
46
-	 * AUI constructor.
47
-	 *
48
-	 * @since 1.0.0
49
-	 */
50
-	private function __construct() {
51
-		if ( function_exists( "__autoload" ) ) {
52
-			spl_autoload_register( "__autoload" );
53
-		}
54
-		spl_autoload_register( array( $this, 'autoload' ) );
55
-
56
-		// load options
57
-		self::$options = get_option('aui_options');
58
-	}
59
-
60
-	/**
61
-	 * Autoload any components on the fly.
62
-	 *
63
-	 * @since 1.0.0
64
-	 *
65
-	 * @param $classname
66
-	 */
67
-	private function autoload( $classname ) {
68
-		$class     = str_replace( '_', '-', strtolower( $classname ) );
69
-		$file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
-		if ( $file_path && is_readable( $file_path ) ) {
71
-			include_once( $file_path );
72
-		}
73
-	}
74
-
75
-	/**
76
-	 * Get the AUI options.
77
-	 *
78
-	 * @param $option
79
-	 *
80
-	 * @return string|void
81
-	 */
82
-	public function get_option( $option ){
83
-		$result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
-
85
-		if ( ! $result && $option) {
86
-			if( $option == 'color_primary' ){
87
-				$result = AUI_PRIMARY_COLOR;
88
-			}elseif( $option == 'color_secondary' ){
89
-				$result = AUI_SECONDARY_COLOR;
90
-			}
91
-		}
92
-		return $result;
93
-	}
94
-
95
-	public function render( $items = array() ) {
96
-		$output = '';
97
-
98
-		if ( ! empty( $items ) ) {
99
-			foreach ( $items as $args ) {
100
-				$render = isset( $args['render'] ) ? $args['render'] : '';
101
-				if ( $render && method_exists( __CLASS__, $render ) ) {
102
-					$output .= $this->$render( $args );
103
-				}
104
-			}
105
-		}
106
-
107
-		return $output;
108
-	}
109
-
110
-	/**
111
-	 * Render and return a bootstrap alert component.
112
-	 *
113
-	 * @since 1.0.0
114
-	 *
115
-	 * @param array $args
116
-	 *
117
-	 * @return string The rendered component.
118
-	 */
119
-	public function alert( $args = array() ) {
120
-		return AUI_Component_Alert::get( $args );
121
-	}
122
-
123
-	/**
124
-	 * Render and return a bootstrap input component.
125
-	 *
126
-	 * @since 1.0.0
127
-	 *
128
-	 * @param array $args
129
-	 *
130
-	 * @return string The rendered component.
131
-	 */
132
-	public function input( $args = array() ) {
133
-		return AUI_Component_Input::input( $args );
134
-	}
135
-
136
-	/**
137
-	 * Render and return a bootstrap textarea component.
138
-	 *
139
-	 * @since 1.0.0
140
-	 *
141
-	 * @param array $args
142
-	 *
143
-	 * @return string The rendered component.
144
-	 */
145
-	public function textarea( $args = array() ) {
146
-		return AUI_Component_Input::textarea( $args );
147
-	}
148
-
149
-	/**
150
-	 * Render and return a bootstrap button component.
151
-	 *
152
-	 * @since 1.0.0
153
-	 *
154
-	 * @param array $args
155
-	 *
156
-	 * @return string The rendered component.
157
-	 */
158
-	public function button( $args = array() ) {
159
-		return AUI_Component_Button::get( $args );
160
-	}
161
-
162
-	/**
163
-	 * Render and return a bootstrap button component.
164
-	 *
165
-	 * @since 1.0.0
166
-	 *
167
-	 * @param array $args
168
-	 *
169
-	 * @return string The rendered component.
170
-	 */
171
-	public function badge( $args = array() ) {
172
-		$defaults = array(
173
-			'class' => 'badge badge-primary align-middle',
174
-		);
175
-
176
-		// maybe set type
177
-		if ( empty( $args['href'] ) ) {
178
-			$defaults['type'] = 'badge';
179
-		}
180
-
181
-		/**
182
-		 * Parse incoming $args into an array and merge it with $defaults
183
-		 */
184
-		$args = wp_parse_args( $args, $defaults );
185
-
186
-		return AUI_Component_Button::get( $args );
187
-	}
188
-
189
-	/**
190
-	 * Render and return a bootstrap dropdown component.
191
-	 *
192
-	 * @since 1.0.0
193
-	 *
194
-	 * @param array $args
195
-	 *
196
-	 * @return string The rendered component.
197
-	 */
198
-	public function dropdown( $args = array() ) {
199
-		return AUI_Component_Dropdown::get( $args );
200
-	}
201
-
202
-	/**
203
-	 * Render and return a bootstrap select component.
204
-	 *
205
-	 * @since 1.0.0
206
-	 *
207
-	 * @param array $args
208
-	 *
209
-	 * @return string The rendered component.
210
-	 */
211
-	public function select( $args = array() ) {
212
-		return AUI_Component_Input::select( $args );
213
-	}
214
-
215
-	/**
216
-	 * Render and return a bootstrap radio component.
217
-	 *
218
-	 * @since 1.0.0
219
-	 *
220
-	 * @param array $args
221
-	 *
222
-	 * @return string The rendered component.
223
-	 */
224
-	public function radio( $args = array() ) {
225
-		return AUI_Component_Input::radio( $args );
226
-	}
227
-
228
-	/**
229
-	 * Render and return a bootstrap pagination component.
230
-	 *
231
-	 * @since 1.0.0
232
-	 *
233
-	 * @param array $args
234
-	 *
235
-	 * @return string The rendered component.
236
-	 */
237
-	public function pagination( $args = array() ) {
238
-		return AUI_Component_Pagination::get( $args );
239
-	}
14
+    /**
15
+     * Holds the class instance.
16
+     *
17
+     * @since 1.0.0
18
+     * @var null
19
+     */
20
+    private static $instance = null;
21
+
22
+    /**
23
+     * Holds the current AUI version number.
24
+     *
25
+     * @var string $ver The current version number.
26
+     */
27
+    public static $ver = '0.1.38';
28
+
29
+    public static $options = null;
30
+
31
+    /**
32
+     * There can be only one.
33
+     *
34
+     * @since 1.0.0
35
+     * @return AUI|null
36
+     */
37
+    public static function instance() {
38
+        if ( self::$instance == null ) {
39
+            self::$instance = new AUI();
40
+        }
41
+
42
+        return self::$instance;
43
+    }
44
+
45
+    /**
46
+     * AUI constructor.
47
+     *
48
+     * @since 1.0.0
49
+     */
50
+    private function __construct() {
51
+        if ( function_exists( "__autoload" ) ) {
52
+            spl_autoload_register( "__autoload" );
53
+        }
54
+        spl_autoload_register( array( $this, 'autoload' ) );
55
+
56
+        // load options
57
+        self::$options = get_option('aui_options');
58
+    }
59
+
60
+    /**
61
+     * Autoload any components on the fly.
62
+     *
63
+     * @since 1.0.0
64
+     *
65
+     * @param $classname
66
+     */
67
+    private function autoload( $classname ) {
68
+        $class     = str_replace( '_', '-', strtolower( $classname ) );
69
+        $file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
+        if ( $file_path && is_readable( $file_path ) ) {
71
+            include_once( $file_path );
72
+        }
73
+    }
74
+
75
+    /**
76
+     * Get the AUI options.
77
+     *
78
+     * @param $option
79
+     *
80
+     * @return string|void
81
+     */
82
+    public function get_option( $option ){
83
+        $result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
+
85
+        if ( ! $result && $option) {
86
+            if( $option == 'color_primary' ){
87
+                $result = AUI_PRIMARY_COLOR;
88
+            }elseif( $option == 'color_secondary' ){
89
+                $result = AUI_SECONDARY_COLOR;
90
+            }
91
+        }
92
+        return $result;
93
+    }
94
+
95
+    public function render( $items = array() ) {
96
+        $output = '';
97
+
98
+        if ( ! empty( $items ) ) {
99
+            foreach ( $items as $args ) {
100
+                $render = isset( $args['render'] ) ? $args['render'] : '';
101
+                if ( $render && method_exists( __CLASS__, $render ) ) {
102
+                    $output .= $this->$render( $args );
103
+                }
104
+            }
105
+        }
106
+
107
+        return $output;
108
+    }
109
+
110
+    /**
111
+     * Render and return a bootstrap alert component.
112
+     *
113
+     * @since 1.0.0
114
+     *
115
+     * @param array $args
116
+     *
117
+     * @return string The rendered component.
118
+     */
119
+    public function alert( $args = array() ) {
120
+        return AUI_Component_Alert::get( $args );
121
+    }
122
+
123
+    /**
124
+     * Render and return a bootstrap input component.
125
+     *
126
+     * @since 1.0.0
127
+     *
128
+     * @param array $args
129
+     *
130
+     * @return string The rendered component.
131
+     */
132
+    public function input( $args = array() ) {
133
+        return AUI_Component_Input::input( $args );
134
+    }
135
+
136
+    /**
137
+     * Render and return a bootstrap textarea component.
138
+     *
139
+     * @since 1.0.0
140
+     *
141
+     * @param array $args
142
+     *
143
+     * @return string The rendered component.
144
+     */
145
+    public function textarea( $args = array() ) {
146
+        return AUI_Component_Input::textarea( $args );
147
+    }
148
+
149
+    /**
150
+     * Render and return a bootstrap button component.
151
+     *
152
+     * @since 1.0.0
153
+     *
154
+     * @param array $args
155
+     *
156
+     * @return string The rendered component.
157
+     */
158
+    public function button( $args = array() ) {
159
+        return AUI_Component_Button::get( $args );
160
+    }
161
+
162
+    /**
163
+     * Render and return a bootstrap button component.
164
+     *
165
+     * @since 1.0.0
166
+     *
167
+     * @param array $args
168
+     *
169
+     * @return string The rendered component.
170
+     */
171
+    public function badge( $args = array() ) {
172
+        $defaults = array(
173
+            'class' => 'badge badge-primary align-middle',
174
+        );
175
+
176
+        // maybe set type
177
+        if ( empty( $args['href'] ) ) {
178
+            $defaults['type'] = 'badge';
179
+        }
180
+
181
+        /**
182
+         * Parse incoming $args into an array and merge it with $defaults
183
+         */
184
+        $args = wp_parse_args( $args, $defaults );
185
+
186
+        return AUI_Component_Button::get( $args );
187
+    }
188
+
189
+    /**
190
+     * Render and return a bootstrap dropdown component.
191
+     *
192
+     * @since 1.0.0
193
+     *
194
+     * @param array $args
195
+     *
196
+     * @return string The rendered component.
197
+     */
198
+    public function dropdown( $args = array() ) {
199
+        return AUI_Component_Dropdown::get( $args );
200
+    }
201
+
202
+    /**
203
+     * Render and return a bootstrap select component.
204
+     *
205
+     * @since 1.0.0
206
+     *
207
+     * @param array $args
208
+     *
209
+     * @return string The rendered component.
210
+     */
211
+    public function select( $args = array() ) {
212
+        return AUI_Component_Input::select( $args );
213
+    }
214
+
215
+    /**
216
+     * Render and return a bootstrap radio component.
217
+     *
218
+     * @since 1.0.0
219
+     *
220
+     * @param array $args
221
+     *
222
+     * @return string The rendered component.
223
+     */
224
+    public function radio( $args = array() ) {
225
+        return AUI_Component_Input::radio( $args );
226
+    }
227
+
228
+    /**
229
+     * Render and return a bootstrap pagination component.
230
+     *
231
+     * @since 1.0.0
232
+     *
233
+     * @param array $args
234
+     *
235
+     * @return string The rendered component.
236
+     */
237
+    public function pagination( $args = array() ) {
238
+        return AUI_Component_Pagination::get( $args );
239
+    }
240 240
 
241 241
 }
242 242
\ No newline at end of file
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.23";
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.23";
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
 				/**
@@ -1230,402 +1230,402 @@  discard block
 block discarded – undo
1230 1230
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1231 1231
 			</script>
1232 1232
 			<?php
1233
-			$output = ob_get_clean();
1233
+            $output = ob_get_clean();
1234 1234
 
1235
-			/*
1235
+            /*
1236 1236
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1237 1237
 			 */
1238 1238
 
1239
-			return str_replace( array(
1240
-				'<script>',
1241
-				'</script>'
1242
-			), '', $output );
1243
-		}
1244
-
1245
-
1246
-		/**
1247
-		 * Set the name from the argument key.
1248
-		 *
1249
-		 * @param $options
1250
-		 *
1251
-		 * @return mixed
1252
-		 */
1253
-		private function add_name_from_key( $options, $arguments = false ) {
1254
-			if ( ! empty( $options['arguments'] ) ) {
1255
-				foreach ( $options['arguments'] as $key => $val ) {
1256
-					$options['arguments'][ $key ]['name'] = $key;
1257
-				}
1258
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1259
-				foreach ( $options as $key => $val ) {
1260
-					$options[ $key ]['name'] = $key;
1261
-				}
1262
-			}
1263
-
1264
-			return $options;
1265
-		}
1266
-
1267
-		/**
1268
-		 * Register the parent shortcode.
1269
-		 *
1270
-		 * @since 1.0.0
1271
-		 */
1272
-		public function register_shortcode() {
1273
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1274
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1275
-		}
1276
-
1277
-		/**
1278
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1279
-		 *
1280
-		 * @since 1.0.0
1281
-		 */
1282
-		public static function render_shortcode() {
1283
-
1284
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1285
-			if ( ! current_user_can( 'manage_options' ) ) {
1286
-				wp_die();
1287
-			}
1288
-
1289
-			// we might need the $post value here so lets set it.
1290
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1291
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1292
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1293
-					global $post;
1294
-					$post = $post_obj;
1295
-				}
1296
-			}
1297
-
1298
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1299
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1300
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1301
-				$attributes       = '';
1302
-				if ( ! empty( $attributes_array ) ) {
1303
-					foreach ( $attributes_array as $key => $value ) {
1304
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1305
-					}
1306
-				}
1307
-
1308
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1309
-
1310
-				echo do_shortcode( $shortcode );
1311
-
1312
-			}
1313
-			wp_die();
1314
-		}
1315
-
1316
-		/**
1317
-		 * Output the shortcode.
1318
-		 *
1319
-		 * @param array $args
1320
-		 * @param string $content
1321
-		 *
1322
-		 * @return string
1323
-		 */
1324
-		public function shortcode_output( $args = array(), $content = '' ) {
1325
-			$args = $this->argument_values( $args );
1326
-
1327
-			// add extra argument so we know its a output to gutenberg
1328
-			//$args
1329
-			$args = $this->string_to_bool( $args );
1330
-
1331
-			// if we have a enclosed shortcode we add it to the special `html` argument
1332
-			if ( ! empty( $content ) ) {
1333
-				$args['html'] = $content;
1334
-			}
1335
-
1336
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1337
-			$class .= " sdel-".$this->get_instance_hash();
1338
-
1339
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1340
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1341
-
1342
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1343
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1344
-
1345
-			$shortcode_args = array();
1346
-			$output         = '';
1347
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1348
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1349
-				$no_wrap = true;
1350
-			}
1351
-			$main_content = $this->output( $args, $shortcode_args, $content );
1352
-			if ( $main_content && ! $no_wrap ) {
1353
-				// wrap the shortcode in a div with the same class as the widget
1354
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1355
-				if ( ! empty( $args['title'] ) ) {
1356
-					// if its a shortcode and there is a title try to grab the title wrappers
1357
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1358
-					if ( empty( $instance ) ) {
1359
-						global $wp_registered_sidebars;
1360
-						if ( ! empty( $wp_registered_sidebars ) ) {
1361
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1362
-								if ( ! empty( $sidebar['before_title'] ) ) {
1363
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1364
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1365
-									break;
1366
-								}
1367
-							}
1368
-						}
1369
-					}
1370
-					$output .= $this->output_title( $shortcode_args, $args );
1371
-				}
1372
-				$output .= $main_content;
1373
-				$output .= '</div>';
1374
-			} elseif ( $main_content && $no_wrap ) {
1375
-				$output .= $main_content;
1376
-			}
1377
-
1378
-			// if preview show a placeholder if empty
1379
-			if ( $this->is_preview() && $output == '' ) {
1380
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1381
-			}
1382
-
1383
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1384
-		}
1385
-
1386
-		/**
1387
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1388
-		 *
1389
-		 * @param string $name
1390
-		 *
1391
-		 * @return string
1392
-		 */
1393
-		public function preview_placeholder_text( $name = '' ) {
1394
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1395
-		}
1396
-
1397
-		/**
1398
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1399
-		 *
1400
-		 * @param $options
1401
-		 *
1402
-		 * @return mixed
1403
-		 */
1404
-		public function string_to_bool( $options ) {
1405
-			// convert bool strings to booleans
1406
-			foreach ( $options as $key => $val ) {
1407
-				if ( $val == 'false' ) {
1408
-					$options[ $key ] = false;
1409
-				} elseif ( $val == 'true' ) {
1410
-					$options[ $key ] = true;
1411
-				}
1412
-			}
1413
-
1414
-			return $options;
1415
-		}
1416
-
1417
-		/**
1418
-		 * Get the argument values that are also filterable.
1419
-		 *
1420
-		 * @param $instance
1421
-		 *
1422
-		 * @since 1.0.12 Don't set checkbox default value if the value is empty.
1423
-		 *
1424
-		 * @return array
1425
-		 */
1426
-		public function argument_values( $instance ) {
1427
-			$argument_values = array();
1428
-
1429
-			// set widget instance
1430
-			$this->instance = $instance;
1431
-
1432
-			if ( empty( $this->arguments ) ) {
1433
-				$this->arguments = $this->get_arguments();
1434
-			}
1435
-
1436
-			if ( ! empty( $this->arguments ) ) {
1437
-				foreach ( $this->arguments as $key => $args ) {
1438
-					// set the input name from the key
1439
-					$args['name'] = $key;
1440
-					//
1441
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1442
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1443
-						// don't set default for an empty checkbox
1444
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1445
-						$argument_values[ $key ] = $args['default'];
1446
-					}
1447
-				}
1448
-			}
1449
-
1450
-			return $argument_values;
1451
-		}
1452
-
1453
-		/**
1454
-		 * Set arguments in super duper.
1455
-		 *
1456
-		 * @since 1.0.0
1457
-		 *
1458
-		 * @return array Set arguments.
1459
-		 */
1460
-		public function set_arguments() {
1461
-			return $this->arguments;
1462
-		}
1463
-
1464
-		/**
1465
-		 * Get arguments in super duper.
1466
-		 *
1467
-		 * @since 1.0.0
1468
-		 *
1469
-		 * @return array Get arguments.
1470
-		 */
1471
-		public function get_arguments() {
1472
-			if ( empty( $this->arguments ) ) {
1473
-				$this->arguments = $this->set_arguments();
1474
-			}
1475
-
1476
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1477
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1478
-
1479
-			return $this->arguments;
1480
-		}
1481
-
1482
-		/**
1483
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1484
-		 *
1485
-		 * @param array $args
1486
-		 * @param array $widget_args
1487
-		 * @param string $content
1488
-		 */
1489
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1490
-
1491
-		}
1492
-
1493
-		/**
1494
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1495
-		 */
1496
-		public function register_block() {
1497
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1498
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1499
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1500
-			}
1501
-		}
1502
-
1503
-		/**
1504
-		 * Check if we need to show advanced options.
1505
-		 *
1506
-		 * @return bool
1507
-		 */
1508
-		public function block_show_advanced() {
1509
-
1510
-			$show      = false;
1511
-			$arguments = $this->arguments;
1512
-
1513
-			if ( empty( $arguments ) ) {
1514
-				$arguments = $this->get_arguments();
1515
-			}
1516
-
1517
-			if ( ! empty( $arguments ) ) {
1518
-				foreach ( $arguments as $argument ) {
1519
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1520
-						$show = true;
1521
-						break; // no need to continue if we know we have it
1522
-					}
1523
-				}
1524
-			}
1525
-
1526
-			return $show;
1527
-		}
1528
-
1529
-		/**
1530
-		 * Get the url path to the current folder.
1531
-		 *
1532
-		 * @return string
1533
-		 */
1534
-		public function get_url() {
1535
-
1536
-			$url = $this->url;
1537
-
1538
-			if ( ! $url ) {
1539
-				// check if we are inside a plugin
1540
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1541
-
1542
-				$dir_parts = explode( "/wp-content/", $file_dir );
1543
-				$url_parts = explode( "/wp-content/", plugins_url() );
1544
-
1545
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1546
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1547
-					$this->url = $url;
1548
-				}
1549
-			}
1550
-
1551
-
1552
-			return $url;
1553
-		}
1554
-
1555
-		/**
1556
-		 * Generate the block icon.
1557
-		 *
1558
-		 * Enables the use of Font Awesome icons.
1559
-		 *
1560
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1561
-		 *
1562
-		 * @param $icon
1563
-		 *
1564
-		 * @since 1.1.0
1565
-		 * @return string
1566
-		 */
1567
-		public function get_block_icon( $icon ) {
1568
-
1569
-			// check if we have a Font Awesome icon
1570
-			$fa_type = '';
1571
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1572
-				$fa_type = 'solid';
1573
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1574
-				$fa_type = 'regular';
1575
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1576
-				$fa_type = 'brands';
1577
-			} else {
1578
-				$icon = "'" . $icon . "'";
1579
-			}
1580
-
1581
-			// set the icon if we found one
1582
-			if ( $fa_type ) {
1583
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1584
-				$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 . "'}))";
1585
-			}
1586
-
1587
-			return $icon;
1588
-		}
1589
-
1590
-		public function group_arguments( $arguments ) {
1239
+            return str_replace( array(
1240
+                '<script>',
1241
+                '</script>'
1242
+            ), '', $output );
1243
+        }
1244
+
1245
+
1246
+        /**
1247
+         * Set the name from the argument key.
1248
+         *
1249
+         * @param $options
1250
+         *
1251
+         * @return mixed
1252
+         */
1253
+        private function add_name_from_key( $options, $arguments = false ) {
1254
+            if ( ! empty( $options['arguments'] ) ) {
1255
+                foreach ( $options['arguments'] as $key => $val ) {
1256
+                    $options['arguments'][ $key ]['name'] = $key;
1257
+                }
1258
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1259
+                foreach ( $options as $key => $val ) {
1260
+                    $options[ $key ]['name'] = $key;
1261
+                }
1262
+            }
1263
+
1264
+            return $options;
1265
+        }
1266
+
1267
+        /**
1268
+         * Register the parent shortcode.
1269
+         *
1270
+         * @since 1.0.0
1271
+         */
1272
+        public function register_shortcode() {
1273
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1274
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1275
+        }
1276
+
1277
+        /**
1278
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1279
+         *
1280
+         * @since 1.0.0
1281
+         */
1282
+        public static function render_shortcode() {
1283
+
1284
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1285
+            if ( ! current_user_can( 'manage_options' ) ) {
1286
+                wp_die();
1287
+            }
1288
+
1289
+            // we might need the $post value here so lets set it.
1290
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1291
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1292
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1293
+                    global $post;
1294
+                    $post = $post_obj;
1295
+                }
1296
+            }
1297
+
1298
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1299
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1300
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1301
+                $attributes       = '';
1302
+                if ( ! empty( $attributes_array ) ) {
1303
+                    foreach ( $attributes_array as $key => $value ) {
1304
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1305
+                    }
1306
+                }
1307
+
1308
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1309
+
1310
+                echo do_shortcode( $shortcode );
1311
+
1312
+            }
1313
+            wp_die();
1314
+        }
1315
+
1316
+        /**
1317
+         * Output the shortcode.
1318
+         *
1319
+         * @param array $args
1320
+         * @param string $content
1321
+         *
1322
+         * @return string
1323
+         */
1324
+        public function shortcode_output( $args = array(), $content = '' ) {
1325
+            $args = $this->argument_values( $args );
1326
+
1327
+            // add extra argument so we know its a output to gutenberg
1328
+            //$args
1329
+            $args = $this->string_to_bool( $args );
1330
+
1331
+            // if we have a enclosed shortcode we add it to the special `html` argument
1332
+            if ( ! empty( $content ) ) {
1333
+                $args['html'] = $content;
1334
+            }
1335
+
1336
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1337
+            $class .= " sdel-".$this->get_instance_hash();
1338
+
1339
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1340
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1341
+
1342
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1343
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1344
+
1345
+            $shortcode_args = array();
1346
+            $output         = '';
1347
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1348
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1349
+                $no_wrap = true;
1350
+            }
1351
+            $main_content = $this->output( $args, $shortcode_args, $content );
1352
+            if ( $main_content && ! $no_wrap ) {
1353
+                // wrap the shortcode in a div with the same class as the widget
1354
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1355
+                if ( ! empty( $args['title'] ) ) {
1356
+                    // if its a shortcode and there is a title try to grab the title wrappers
1357
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1358
+                    if ( empty( $instance ) ) {
1359
+                        global $wp_registered_sidebars;
1360
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1361
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1362
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1363
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1364
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1365
+                                    break;
1366
+                                }
1367
+                            }
1368
+                        }
1369
+                    }
1370
+                    $output .= $this->output_title( $shortcode_args, $args );
1371
+                }
1372
+                $output .= $main_content;
1373
+                $output .= '</div>';
1374
+            } elseif ( $main_content && $no_wrap ) {
1375
+                $output .= $main_content;
1376
+            }
1377
+
1378
+            // if preview show a placeholder if empty
1379
+            if ( $this->is_preview() && $output == '' ) {
1380
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1381
+            }
1382
+
1383
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1384
+        }
1385
+
1386
+        /**
1387
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1388
+         *
1389
+         * @param string $name
1390
+         *
1391
+         * @return string
1392
+         */
1393
+        public function preview_placeholder_text( $name = '' ) {
1394
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1395
+        }
1396
+
1397
+        /**
1398
+         * Sometimes booleans values can be turned to strings, so we fix that.
1399
+         *
1400
+         * @param $options
1401
+         *
1402
+         * @return mixed
1403
+         */
1404
+        public function string_to_bool( $options ) {
1405
+            // convert bool strings to booleans
1406
+            foreach ( $options as $key => $val ) {
1407
+                if ( $val == 'false' ) {
1408
+                    $options[ $key ] = false;
1409
+                } elseif ( $val == 'true' ) {
1410
+                    $options[ $key ] = true;
1411
+                }
1412
+            }
1413
+
1414
+            return $options;
1415
+        }
1416
+
1417
+        /**
1418
+         * Get the argument values that are also filterable.
1419
+         *
1420
+         * @param $instance
1421
+         *
1422
+         * @since 1.0.12 Don't set checkbox default value if the value is empty.
1423
+         *
1424
+         * @return array
1425
+         */
1426
+        public function argument_values( $instance ) {
1427
+            $argument_values = array();
1428
+
1429
+            // set widget instance
1430
+            $this->instance = $instance;
1431
+
1432
+            if ( empty( $this->arguments ) ) {
1433
+                $this->arguments = $this->get_arguments();
1434
+            }
1435
+
1436
+            if ( ! empty( $this->arguments ) ) {
1437
+                foreach ( $this->arguments as $key => $args ) {
1438
+                    // set the input name from the key
1439
+                    $args['name'] = $key;
1440
+                    //
1441
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1442
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1443
+                        // don't set default for an empty checkbox
1444
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1445
+                        $argument_values[ $key ] = $args['default'];
1446
+                    }
1447
+                }
1448
+            }
1449
+
1450
+            return $argument_values;
1451
+        }
1452
+
1453
+        /**
1454
+         * Set arguments in super duper.
1455
+         *
1456
+         * @since 1.0.0
1457
+         *
1458
+         * @return array Set arguments.
1459
+         */
1460
+        public function set_arguments() {
1461
+            return $this->arguments;
1462
+        }
1463
+
1464
+        /**
1465
+         * Get arguments in super duper.
1466
+         *
1467
+         * @since 1.0.0
1468
+         *
1469
+         * @return array Get arguments.
1470
+         */
1471
+        public function get_arguments() {
1472
+            if ( empty( $this->arguments ) ) {
1473
+                $this->arguments = $this->set_arguments();
1474
+            }
1475
+
1476
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1477
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1478
+
1479
+            return $this->arguments;
1480
+        }
1481
+
1482
+        /**
1483
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1484
+         *
1485
+         * @param array $args
1486
+         * @param array $widget_args
1487
+         * @param string $content
1488
+         */
1489
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1490
+
1491
+        }
1492
+
1493
+        /**
1494
+         * Add the dynamic block code inline when the wp-block in enqueued.
1495
+         */
1496
+        public function register_block() {
1497
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1498
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1499
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1500
+            }
1501
+        }
1502
+
1503
+        /**
1504
+         * Check if we need to show advanced options.
1505
+         *
1506
+         * @return bool
1507
+         */
1508
+        public function block_show_advanced() {
1509
+
1510
+            $show      = false;
1511
+            $arguments = $this->arguments;
1512
+
1513
+            if ( empty( $arguments ) ) {
1514
+                $arguments = $this->get_arguments();
1515
+            }
1516
+
1517
+            if ( ! empty( $arguments ) ) {
1518
+                foreach ( $arguments as $argument ) {
1519
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1520
+                        $show = true;
1521
+                        break; // no need to continue if we know we have it
1522
+                    }
1523
+                }
1524
+            }
1525
+
1526
+            return $show;
1527
+        }
1528
+
1529
+        /**
1530
+         * Get the url path to the current folder.
1531
+         *
1532
+         * @return string
1533
+         */
1534
+        public function get_url() {
1535
+
1536
+            $url = $this->url;
1537
+
1538
+            if ( ! $url ) {
1539
+                // check if we are inside a plugin
1540
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1541
+
1542
+                $dir_parts = explode( "/wp-content/", $file_dir );
1543
+                $url_parts = explode( "/wp-content/", plugins_url() );
1544
+
1545
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1546
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1547
+                    $this->url = $url;
1548
+                }
1549
+            }
1550
+
1551
+
1552
+            return $url;
1553
+        }
1554
+
1555
+        /**
1556
+         * Generate the block icon.
1557
+         *
1558
+         * Enables the use of Font Awesome icons.
1559
+         *
1560
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1561
+         *
1562
+         * @param $icon
1563
+         *
1564
+         * @since 1.1.0
1565
+         * @return string
1566
+         */
1567
+        public function get_block_icon( $icon ) {
1568
+
1569
+            // check if we have a Font Awesome icon
1570
+            $fa_type = '';
1571
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1572
+                $fa_type = 'solid';
1573
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1574
+                $fa_type = 'regular';
1575
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1576
+                $fa_type = 'brands';
1577
+            } else {
1578
+                $icon = "'" . $icon . "'";
1579
+            }
1580
+
1581
+            // set the icon if we found one
1582
+            if ( $fa_type ) {
1583
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1584
+                $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 . "'}))";
1585
+            }
1586
+
1587
+            return $icon;
1588
+        }
1589
+
1590
+        public function group_arguments( $arguments ) {
1591 1591
 //			echo '###';print_r($arguments);
1592
-			if ( ! empty( $arguments ) ) {
1593
-				$temp_arguments = array();
1594
-				$general        = __( "General" );
1595
-				$add_sections   = false;
1596
-				foreach ( $arguments as $key => $args ) {
1597
-					if ( isset( $args['group'] ) ) {
1598
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1599
-						$add_sections                             = true;
1600
-					} else {
1601
-						$temp_arguments[ $general ][ $key ] = $args;
1602
-					}
1603
-				}
1604
-
1605
-				// only add sections if more than one
1606
-				if ( $add_sections ) {
1607
-					$arguments = $temp_arguments;
1608
-				}
1609
-			}
1592
+            if ( ! empty( $arguments ) ) {
1593
+                $temp_arguments = array();
1594
+                $general        = __( "General" );
1595
+                $add_sections   = false;
1596
+                foreach ( $arguments as $key => $args ) {
1597
+                    if ( isset( $args['group'] ) ) {
1598
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1599
+                        $add_sections                             = true;
1600
+                    } else {
1601
+                        $temp_arguments[ $general ][ $key ] = $args;
1602
+                    }
1603
+                }
1604
+
1605
+                // only add sections if more than one
1606
+                if ( $add_sections ) {
1607
+                    $arguments = $temp_arguments;
1608
+                }
1609
+            }
1610 1610
 
1611 1611
 //			echo '###';print_r($arguments);
1612
-			return $arguments;
1613
-		}
1614
-
1615
-
1616
-		/**
1617
-		 * Output the JS for building the dynamic Guntenberg block.
1618
-		 *
1619
-		 * @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.
1620
-		 * @since 1.0.9 Save numbers as numbers and not strings.
1621
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1622
-		 * @return mixed
1623
-		 */
1624
-		public function block() {
1625
-			ob_start();
1626
-
1627
-			$show_advanced = $this->block_show_advanced();
1628
-			?>
1612
+            return $arguments;
1613
+        }
1614
+
1615
+
1616
+        /**
1617
+         * Output the JS for building the dynamic Guntenberg block.
1618
+         *
1619
+         * @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.
1620
+         * @since 1.0.9 Save numbers as numbers and not strings.
1621
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1622
+         * @return mixed
1623
+         */
1624
+        public function block() {
1625
+            ob_start();
1626
+
1627
+            $show_advanced = $this->block_show_advanced();
1628
+            ?>
1629 1629
 			<script>
1630 1630
 				/**
1631 1631
 				 * BLOCK: Basic
@@ -1669,97 +1669,97 @@  discard block
 block discarded – undo
1669 1669
 						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/.
1670 1670
 						supports: {
1671 1671
 							<?php
1672
-							if ( isset( $this->options['block-supports'] ) ) {
1673
-								echo $this->array_to_attributes( $this->options['block-supports'] );
1674
-							}
1675
-							?>
1672
+                            if ( isset( $this->options['block-supports'] ) ) {
1673
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
1674
+                            }
1675
+                            ?>
1676 1676
 						},
1677 1677
 						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.
1678 1678
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
1679
-						echo "keywords : " . $this->options['block-keywords'] . ",";
1680
-					}?>
1679
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
1680
+                    }?>
1681 1681
 
1682 1682
 						<?php
1683 1683
 
1684
-						// maybe set no_wrap
1685
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1686
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1687
-							$no_wrap = true;
1688
-						}
1689
-						if ( $no_wrap ) {
1690
-							$this->options['block-wrap'] = '';
1691
-						}
1684
+                        // maybe set no_wrap
1685
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1686
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1687
+                            $no_wrap = true;
1688
+                        }
1689
+                        if ( $no_wrap ) {
1690
+                            $this->options['block-wrap'] = '';
1691
+                        }
1692 1692
 
1693 1693
 
1694 1694
 
1695
-						$show_alignment = false;
1696
-						// align feature
1697
-						/*echo "supports: {";
1695
+                        $show_alignment = false;
1696
+                        // align feature
1697
+                        /*echo "supports: {";
1698 1698
 						echo "	align: true,";
1699 1699
 						echo "  html: false";
1700 1700
 						echo "},";*/
1701 1701
 
1702
-						if ( ! empty( $this->arguments ) ) {
1703
-							echo "attributes : {";
1704
-
1705
-							if ( $show_advanced ) {
1706
-								echo "show_advanced: {";
1707
-								echo "	type: 'boolean',";
1708
-								echo "  default: false,";
1709
-								echo "},";
1710
-							}
1711
-
1712
-							// block wrap element
1713
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1714
-								echo "block_wrap: {";
1715
-								echo "	type: 'string',";
1716
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1717
-								echo "},";
1718
-							}
1719
-
1720
-							foreach ( $this->arguments as $key => $args ) {
1721
-
1722
-								// set if we should show alignment
1723
-								if ( $key == 'alignment' ) {
1724
-									$show_alignment = true;
1725
-								}
1726
-
1727
-								$extra = '';
1728
-
1729
-								if ( $args['type'] == 'checkbox' ) {
1730
-									$type    = 'boolean';
1731
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1732
-								} elseif ( $args['type'] == 'number' ) {
1733
-									$type    = 'number';
1734
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1735
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1736
-									$type = 'array';
1737
-									if ( is_array( $args['default'] ) ) {
1738
-										$default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1739
-									} else {
1740
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1741
-									}
1742
-								} elseif ( $args['type'] == 'multiselect' ) {
1743
-									$type    = 'array';
1744
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1745
-								} else {
1746
-									$type    = 'string';
1747
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1748
-								}
1749
-								echo $key . " : {";
1750
-								echo "type : '$type',";
1751
-								echo "default : $default,";
1752
-								echo "},";
1753
-							}
1754
-
1755
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1756
-							echo "className: { type: 'string', default: '' },";
1757
-
1758
-							echo "},";
1759
-
1760
-						}
1761
-
1762
-						?>
1702
+                        if ( ! empty( $this->arguments ) ) {
1703
+                            echo "attributes : {";
1704
+
1705
+                            if ( $show_advanced ) {
1706
+                                echo "show_advanced: {";
1707
+                                echo "	type: 'boolean',";
1708
+                                echo "  default: false,";
1709
+                                echo "},";
1710
+                            }
1711
+
1712
+                            // block wrap element
1713
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1714
+                                echo "block_wrap: {";
1715
+                                echo "	type: 'string',";
1716
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1717
+                                echo "},";
1718
+                            }
1719
+
1720
+                            foreach ( $this->arguments as $key => $args ) {
1721
+
1722
+                                // set if we should show alignment
1723
+                                if ( $key == 'alignment' ) {
1724
+                                    $show_alignment = true;
1725
+                                }
1726
+
1727
+                                $extra = '';
1728
+
1729
+                                if ( $args['type'] == 'checkbox' ) {
1730
+                                    $type    = 'boolean';
1731
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1732
+                                } elseif ( $args['type'] == 'number' ) {
1733
+                                    $type    = 'number';
1734
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1735
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1736
+                                    $type = 'array';
1737
+                                    if ( is_array( $args['default'] ) ) {
1738
+                                        $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1739
+                                    } else {
1740
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1741
+                                    }
1742
+                                } elseif ( $args['type'] == 'multiselect' ) {
1743
+                                    $type    = 'array';
1744
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1745
+                                } else {
1746
+                                    $type    = 'string';
1747
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1748
+                                }
1749
+                                echo $key . " : {";
1750
+                                echo "type : '$type',";
1751
+                                echo "default : $default,";
1752
+                                echo "},";
1753
+                            }
1754
+
1755
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1756
+                            echo "className: { type: 'string', default: '' },";
1757
+
1758
+                            echo "},";
1759
+
1760
+                        }
1761
+
1762
+                        ?>
1763 1763
 
1764 1764
 						// The "edit" property must be a valid function.
1765 1765
 						edit: function (props) {
@@ -1767,9 +1767,9 @@  discard block
 block discarded – undo
1767 1767
 
1768 1768
 							var $value = '';
1769 1769
 							<?php
1770
-							// if we have a post_type and a category then link them
1771
-							if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1772
-							?>
1770
+                            // if we have a post_type and a category then link them
1771
+                            if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1772
+                            ?>
1773 1773
 							if(typeof(prev_attributes[props.id]) != 'undefined' ){
1774 1774
 								$pt = props.attributes.post_type;
1775 1775
 								if(post_type_rest_slugs.length){
@@ -1853,8 +1853,8 @@  discard block
 block discarded – undo
1853 1853
 										'shortcode': '<?php echo $this->options['base_id'];?>',
1854 1854
 										'attributes': props.attributes,
1855 1855
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
1856
-										echo $post->ID;
1857
-									}?>,
1856
+                                        echo $post->ID;
1857
+                                    }?>,
1858 1858
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
1859 1859
 									};
1860 1860
 
@@ -1906,10 +1906,10 @@  discard block
 block discarded – undo
1906 1906
 
1907 1907
 									<?php
1908 1908
 
1909
-									if(! empty( $this->arguments )){
1909
+                                    if(! empty( $this->arguments )){
1910 1910
 
1911
-									if ( $show_advanced ) {
1912
-									?>
1911
+                                    if ( $show_advanced ) {
1912
+                                    ?>
1913 1913
 									el('div', {
1914 1914
 											style: {'padding-left': '16px','padding-right': '16px'}
1915 1915
 										},
@@ -1927,79 +1927,79 @@  discard block
 block discarded – undo
1927 1927
 									,
1928 1928
 									<?php
1929 1929
 
1930
-									}
1930
+                                    }
1931 1931
 
1932
-									$arguments = $this->group_arguments( $this->arguments );
1932
+                                    $arguments = $this->group_arguments( $this->arguments );
1933 1933
 
1934
-									// Do we have sections?
1935
-									$has_sections = $arguments == $this->arguments ? false : true;
1934
+                                    // Do we have sections?
1935
+                                    $has_sections = $arguments == $this->arguments ? false : true;
1936 1936
 
1937 1937
 
1938
-									if($has_sections){
1939
-									$panel_count = 0;
1940
-									foreach($arguments as $key => $args){
1941
-									?>
1938
+                                    if($has_sections){
1939
+                                    $panel_count = 0;
1940
+                                    foreach($arguments as $key => $args){
1941
+                                    ?>
1942 1942
 									el(wp.components.PanelBody, {
1943 1943
 											title: '<?php esc_attr_e( $key ); ?>',
1944 1944
 											initialOpen: <?php if ( $panel_count ) {
1945
-											echo "false";
1946
-										} else {
1947
-											echo "true";
1948
-										}?>
1945
+                                            echo "false";
1946
+                                        } else {
1947
+                                            echo "true";
1948
+                                        }?>
1949 1949
 										},
1950 1950
 										<?php
1951 1951
 
1952 1952
 
1953 1953
 
1954
-										foreach ( $args as $k => $a ) {
1954
+                                        foreach ( $args as $k => $a ) {
1955 1955
 
1956
-											$this->block_row_start( $k, $a );
1957
-											$this->build_block_arguments( $k, $a );
1958
-											$this->block_row_end( $k, $a );
1959
-										}
1960
-										?>
1956
+                                            $this->block_row_start( $k, $a );
1957
+                                            $this->build_block_arguments( $k, $a );
1958
+                                            $this->block_row_end( $k, $a );
1959
+                                        }
1960
+                                        ?>
1961 1961
 									),
1962 1962
 									<?php
1963
-									$panel_count ++;
1963
+                                    $panel_count ++;
1964 1964
 
1965
-									}
1966
-									}else {
1967
-									?>
1965
+                                    }
1966
+                                    }else {
1967
+                                    ?>
1968 1968
 									el(wp.components.PanelBody, {
1969 1969
 											title: '<?php esc_attr_e( "Settings" ); ?>',
1970 1970
 											initialOpen: true
1971 1971
 										},
1972 1972
 										<?php
1973
-										foreach ( $this->arguments as $key => $args ) {
1974
-											$this->block_row_start( $key, $args );
1975
-											$this->build_block_arguments( $key, $args );
1976
-											$this->block_row_end( $key, $args );
1977
-										}
1978
-										?>
1973
+                                        foreach ( $this->arguments as $key => $args ) {
1974
+                                            $this->block_row_start( $key, $args );
1975
+                                            $this->build_block_arguments( $key, $args );
1976
+                                            $this->block_row_end( $key, $args );
1977
+                                        }
1978
+                                        ?>
1979 1979
 									),
1980 1980
 									<?php
1981
-									}
1981
+                                    }
1982 1982
 
1983
-									}
1984
-									?>
1983
+                                    }
1984
+                                    ?>
1985 1985
 
1986 1986
 								),
1987 1987
 
1988 1988
 								<?php
1989
-								// If the user sets block-output array then build it
1990
-								if ( ! empty( $this->options['block-output'] ) ) {
1991
-								$this->block_element( $this->options['block-output'] );
1992
-							}else{
1993
-								// if no block-output is set then we try and get the shortcode html output via ajax.
1994
-								?>
1989
+                                // If the user sets block-output array then build it
1990
+                                if ( ! empty( $this->options['block-output'] ) ) {
1991
+                                $this->block_element( $this->options['block-output'] );
1992
+                            }else{
1993
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
1994
+                                ?>
1995 1995
 								el('div', {
1996 1996
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
1997 1997
 									className: props.className,
1998 1998
 									style: {'minHeight': '30px'}
1999 1999
 								})
2000 2000
 								<?php
2001
-								}
2002
-								?>
2001
+                                }
2002
+                                ?>
2003 2003
 							]; // end return
2004 2004
 						},
2005 2005
 
@@ -2017,10 +2017,10 @@  discard block
 block discarded – undo
2017 2017
 							$html = '';
2018 2018
 							<?php
2019 2019
 
2020
-							if(! empty( $this->arguments )){
2020
+                            if(! empty( $this->arguments )){
2021 2021
 
2022
-							foreach($this->arguments as $key => $args){
2023
-							?>
2022
+                            foreach($this->arguments as $key => $args){
2023
+                            ?>
2024 2024
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2025 2025
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2026 2026
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2029,10 +2029,10 @@  discard block
 block discarded – undo
2029 2029
 								}
2030 2030
 							}
2031 2031
 							<?php
2032
-							}
2033
-							}
2032
+                            }
2033
+                            }
2034 2034
 
2035
-							?>
2035
+                            ?>
2036 2036
 							content += "]";
2037 2037
 
2038 2038
 							// if has html element
@@ -2055,20 +2055,20 @@  discard block
 block discarded – undo
2055 2055
 							}
2056 2056
 
2057 2057
 							<?php
2058
-							if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2059
-							?>
2058
+                            if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2059
+                            ?>
2060 2060
 							return content;
2061 2061
 							<?php
2062
-							}else{
2063
-							?>
2062
+                            }else{
2063
+                            ?>
2064 2064
 							var block_wrap = 'div';
2065 2065
 							if (attr.hasOwnProperty("block_wrap")) {
2066 2066
 								block_wrap = attr.block_wrap;
2067 2067
 							}
2068 2068
 							return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align});
2069 2069
 							<?php
2070
-							}
2071
-							?>
2070
+                            }
2071
+                            ?>
2072 2072
 
2073 2073
 
2074 2074
 						}
@@ -2076,30 +2076,30 @@  discard block
 block discarded – undo
2076 2076
 				})();
2077 2077
 			</script>
2078 2078
 			<?php
2079
-			$output = ob_get_clean();
2079
+            $output = ob_get_clean();
2080 2080
 
2081
-			/*
2081
+            /*
2082 2082
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2083 2083
 			 */
2084 2084
 
2085
-			return str_replace( array(
2086
-				'<script>',
2087
-				'</script>'
2088
-			), '', $output );
2089
-		}
2085
+            return str_replace( array(
2086
+                '<script>',
2087
+                '</script>'
2088
+            ), '', $output );
2089
+        }
2090 2090
 
2091
-		public function block_row_start($key, $args){
2091
+        public function block_row_start($key, $args){
2092 2092
 
2093
-			// check for row
2094
-			if(!empty($args['row'])){
2093
+            // check for row
2094
+            if(!empty($args['row'])){
2095 2095
 
2096
-				if(!empty($args['row']['open'])){
2096
+                if(!empty($args['row']['open'])){
2097 2097
 
2098
-				// element require
2099
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2100
-				echo $element_require;
2098
+                // element require
2099
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2100
+                echo $element_require;
2101 2101
 
2102
-					if(false){?><script><?php }?>
2102
+                    if(false){?><script><?php }?>
2103 2103
 						el('div', {
2104 2104
 								className: 'bsui components-base-control',
2105 2105
 							},
@@ -2129,87 +2129,87 @@  discard block
 block discarded – undo
2129 2129
 									},
2130 2130
 
2131 2131
 					<?php
2132
-					if(false){?></script><?php }
2133
-				}elseif(!empty($args['row']['close'])){
2134
-					if(false){?><script><?php }?>
2132
+                    if(false){?></script><?php }
2133
+                }elseif(!empty($args['row']['close'])){
2134
+                    if(false){?><script><?php }?>
2135 2135
 						el(
2136 2136
 							'div',
2137 2137
 							{
2138 2138
 								className: 'col pl-0',
2139 2139
 							},
2140 2140
 					<?php
2141
-					if(false){?></script><?php }
2142
-				}else{
2143
-					if(false){?><script><?php }?>
2141
+                    if(false){?></script><?php }
2142
+                }else{
2143
+                    if(false){?><script><?php }?>
2144 2144
 						el(
2145 2145
 							'div',
2146 2146
 							{
2147 2147
 								className: 'col pl-0 pr-2',
2148 2148
 							},
2149 2149
 					<?php
2150
-					if(false){?></script><?php }
2151
-				}
2152
-
2153
-			}
2154
-
2155
-		}
2156
-
2157
-		public function block_row_end($key, $args){
2158
-
2159
-			if(!empty($args['row'])){
2160
-				// maybe close
2161
-				if(!empty($args['row']['close'])){
2162
-					echo "))";
2163
-				}
2164
-
2165
-				echo "),";
2166
-			}
2167
-		}
2168
-
2169
-		public function build_block_arguments( $key, $args ) {
2170
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2171
-			$options           = '';
2172
-			$extra             = '';
2173
-			$require           = '';
2174
-
2175
-			// `content` is a protected and special argument
2176
-			if ( $key == 'content' ) {
2177
-				return;
2178
-			}
2179
-
2180
-
2181
-			// icon
2182
-			$icon = '';
2183
-			if( !empty( $args['icon'] ) ){
2184
-				$icon .= "el('div', {";
2185
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2186
-									$icon .= "className: 'text-center',";
2187
-									$icon .= "title: '".addslashes( $args['title'] )."',";
2188
-								$icon .= "}),";
2189
-
2190
-				// blank title as its added to the icon.
2191
-				$args['title'] = '';
2192
-			}
2193
-
2194
-			// require advanced
2195
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2196
-
2197
-			// element require
2198
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2199
-
2200
-
2201
-			$onchange  = "props.setAttributes({ $key: $key } )";
2202
-			$onchangecomplete  = "";
2203
-			$value     = "props.attributes.$key";
2204
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2205
-			if ( in_array( $args['type'], $text_type ) ) {
2206
-				$type = 'TextControl';
2207
-				// Save numbers as numbers and not strings
2208
-				if ( $args['type'] == 'number' ) {
2209
-					$onchange = "props.setAttributes({ $key: Number($key) } )";
2210
-				}
2211
-			}
2212
-			/*
2150
+                    if(false){?></script><?php }
2151
+                }
2152
+
2153
+            }
2154
+
2155
+        }
2156
+
2157
+        public function block_row_end($key, $args){
2158
+
2159
+            if(!empty($args['row'])){
2160
+                // maybe close
2161
+                if(!empty($args['row']['close'])){
2162
+                    echo "))";
2163
+                }
2164
+
2165
+                echo "),";
2166
+            }
2167
+        }
2168
+
2169
+        public function build_block_arguments( $key, $args ) {
2170
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2171
+            $options           = '';
2172
+            $extra             = '';
2173
+            $require           = '';
2174
+
2175
+            // `content` is a protected and special argument
2176
+            if ( $key == 'content' ) {
2177
+                return;
2178
+            }
2179
+
2180
+
2181
+            // icon
2182
+            $icon = '';
2183
+            if( !empty( $args['icon'] ) ){
2184
+                $icon .= "el('div', {";
2185
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2186
+                                    $icon .= "className: 'text-center',";
2187
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
2188
+                                $icon .= "}),";
2189
+
2190
+                // blank title as its added to the icon.
2191
+                $args['title'] = '';
2192
+            }
2193
+
2194
+            // require advanced
2195
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2196
+
2197
+            // element require
2198
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2199
+
2200
+
2201
+            $onchange  = "props.setAttributes({ $key: $key } )";
2202
+            $onchangecomplete  = "";
2203
+            $value     = "props.attributes.$key";
2204
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2205
+            if ( in_array( $args['type'], $text_type ) ) {
2206
+                $type = 'TextControl';
2207
+                // Save numbers as numbers and not strings
2208
+                if ( $args['type'] == 'number' ) {
2209
+                    $onchange = "props.setAttributes({ $key: Number($key) } )";
2210
+                }
2211
+            }
2212
+            /*
2213 2213
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
2214 2214
 						elseif($args['type']=='tabs'){
2215 2215
 							?>
@@ -2243,85 +2243,85 @@  discard block
 block discarded – undo
2243 2243
 							return;
2244 2244
 						}
2245 2245
 			*/
2246
-			elseif ( $args['type'] == 'color' ) {
2247
-				$type = 'ColorPicker';
2248
-				$onchange = "";
2249
-				$extra = "color: $value,";
2250
-				if(!empty($args['disable_alpha'])){
2251
-					$extra .= "disableAlpha: true,";
2252
-				}
2253
-				$onchangecomplete = "onChangeComplete: function($key) {
2246
+            elseif ( $args['type'] == 'color' ) {
2247
+                $type = 'ColorPicker';
2248
+                $onchange = "";
2249
+                $extra = "color: $value,";
2250
+                if(!empty($args['disable_alpha'])){
2251
+                    $extra .= "disableAlpha: true,";
2252
+                }
2253
+                $onchangecomplete = "onChangeComplete: function($key) {
2254 2254
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
2255 2255
                         props.setAttributes({
2256 2256
                             $key: value
2257 2257
                         });
2258 2258
                     },";
2259
-			}
2260
-			elseif ( $args['type'] == 'checkbox' ) {
2261
-				$type = 'CheckboxControl';
2262
-				$extra .= "checked: props.attributes.$key,";
2263
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2264
-			} elseif ( $args['type'] == 'textarea' ) {
2265
-				$type = 'TextareaControl';
2266
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2267
-				$type = 'SelectControl';
2268
-
2269
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2270
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2271
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2272
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2273
-				}else {
2274
-
2275
-					if ( ! empty( $args['options'] ) ) {
2276
-						$options .= "options: [";
2277
-						foreach ( $args['options'] as $option_val => $option_label ) {
2278
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2279
-						}
2280
-						$options .= "],";
2281
-					}
2282
-				}
2283
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2284
-					$extra .= ' multiple: true, ';
2285
-				}
2286
-			} elseif ( $args['type'] == 'alignment' ) {
2287
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2288
-			}elseif ( $args['type'] == 'margins' ) {
2289
-
2290
-			} else {
2291
-				return;// if we have not implemented the control then don't break the JS.
2292
-			}
2293
-
2294
-
2295
-
2296
-			// color input does not show the labels so we add them
2297
-			if($args['type']=='color'){
2298
-				// add show only if advanced
2299
-				echo $require_advanced;
2300
-				// add setting require if defined
2301
-				echo $element_require;
2302
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2303
-			}
2304
-
2305
-			// add show only if advanced
2306
-			echo $require_advanced;
2307
-			// add setting require if defined
2308
-			echo $element_require;
2309
-
2310
-			// icon
2311
-			echo $icon;
2312
-			?>
2259
+            }
2260
+            elseif ( $args['type'] == 'checkbox' ) {
2261
+                $type = 'CheckboxControl';
2262
+                $extra .= "checked: props.attributes.$key,";
2263
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2264
+            } elseif ( $args['type'] == 'textarea' ) {
2265
+                $type = 'TextareaControl';
2266
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2267
+                $type = 'SelectControl';
2268
+
2269
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2270
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2271
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2272
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2273
+                }else {
2274
+
2275
+                    if ( ! empty( $args['options'] ) ) {
2276
+                        $options .= "options: [";
2277
+                        foreach ( $args['options'] as $option_val => $option_label ) {
2278
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2279
+                        }
2280
+                        $options .= "],";
2281
+                    }
2282
+                }
2283
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2284
+                    $extra .= ' multiple: true, ';
2285
+                }
2286
+            } elseif ( $args['type'] == 'alignment' ) {
2287
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2288
+            }elseif ( $args['type'] == 'margins' ) {
2289
+
2290
+            } else {
2291
+                return;// if we have not implemented the control then don't break the JS.
2292
+            }
2293
+
2294
+
2295
+
2296
+            // color input does not show the labels so we add them
2297
+            if($args['type']=='color'){
2298
+                // add show only if advanced
2299
+                echo $require_advanced;
2300
+                // add setting require if defined
2301
+                echo $element_require;
2302
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2303
+            }
2304
+
2305
+            // add show only if advanced
2306
+            echo $require_advanced;
2307
+            // add setting require if defined
2308
+            echo $element_require;
2309
+
2310
+            // icon
2311
+            echo $icon;
2312
+            ?>
2313 2313
 			el( wp.components.<?php echo $type; ?>, {
2314 2314
 			label: '<?php echo addslashes( $args['title'] ); ?>',
2315 2315
 			help: '<?php if ( isset( $args['desc'] ) ) {
2316
-				echo addslashes( $args['desc'] );
2317
-			} ?>',
2316
+                echo addslashes( $args['desc'] );
2317
+            } ?>',
2318 2318
 			value: <?php echo $value; ?>,
2319 2319
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
2320
-				echo "type: '" . addslashes( $args['type'] ) . "',";
2321
-			} ?>
2320
+                echo "type: '" . addslashes( $args['type'] ) . "',";
2321
+            } ?>
2322 2322
 			<?php if ( ! empty( $args['placeholder'] ) ) {
2323
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2324
-			} ?>
2323
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2324
+            } ?>
2325 2325
 			<?php echo $options; ?>
2326 2326
 			<?php echo $extra; ?>
2327 2327
 			<?php echo $custom_attributes; ?>
@@ -2333,601 +2333,601 @@  discard block
 block discarded – undo
2333 2333
 			<?php
2334 2334
 
2335 2335
 
2336
-		}
2337
-
2338
-		/**
2339
-		 * Convert an array of attributes to block string.
2340
-		 *
2341
-		 * @todo there is prob a faster way to do this, also we could add some validation here.
2342
-		 *
2343
-		 * @param $custom_attributes
2344
-		 *
2345
-		 * @return string
2346
-		 */
2347
-		public function array_to_attributes( $custom_attributes, $html = false ) {
2348
-			$attributes = '';
2349
-			if ( ! empty( $custom_attributes ) ) {
2350
-
2351
-				if ( $html ) {
2352
-					foreach ( $custom_attributes as $key => $val ) {
2353
-						$attributes .= " $key='$val' ";
2354
-					}
2355
-				} else {
2356
-					foreach ( $custom_attributes as $key => $val ) {
2357
-						$attributes .= "'$key': '$val',";
2358
-					}
2359
-				}
2360
-			}
2361
-
2362
-			return $attributes;
2363
-		}
2364
-
2365
-		/**
2366
-		 * A self looping function to create the output for JS block elements.
2367
-		 *
2368
-		 * This is what is output in the WP Editor visual view.
2369
-		 *
2370
-		 * @param $args
2371
-		 */
2372
-		public function block_element( $args ) {
2373
-
2374
-
2375
-			if ( ! empty( $args ) ) {
2376
-				foreach ( $args as $element => $new_args ) {
2377
-
2378
-					if ( is_array( $new_args ) ) { // its an element
2379
-
2380
-
2381
-						if ( isset( $new_args['element'] ) ) {
2382
-
2383
-							if ( isset( $new_args['element_require'] ) ) {
2384
-								echo str_replace( array(
2385
-										"'+",
2386
-										"+'"
2387
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2388
-								unset( $new_args['element_require'] );
2389
-							}
2390
-
2391
-							echo "\n el( '" . $new_args['element'] . "', {";
2392
-
2393
-							// get the attributes
2394
-							foreach ( $new_args as $new_key => $new_value ) {
2395
-
2396
-
2397
-								if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2398
-									// do nothing
2399
-								} else {
2400
-									echo $this->block_element( array( $new_key => $new_value ) );
2401
-								}
2402
-							}
2403
-
2404
-							echo "},";// end attributes
2405
-
2406
-							// get the content
2407
-							$first_item = 0;
2408
-							foreach ( $new_args as $new_key => $new_value ) {
2409
-								if ( $new_key === 'content' || is_array( $new_value ) ) {
2410
-
2411
-									if ( $new_key === 'content' ) {
2412
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2413
-									}
2414
-
2415
-									if ( is_array( $new_value ) ) {
2416
-
2417
-										if ( isset( $new_value['element_require'] ) ) {
2418
-											echo str_replace( array(
2419
-													"'+",
2420
-													"+'"
2421
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2422
-											unset( $new_value['element_require'] );
2423
-										}
2424
-
2425
-										if ( isset( $new_value['element_repeat'] ) ) {
2426
-											$x = 1;
2427
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
2428
-												$this->block_element( array( '' => $new_value ) );
2429
-												$x ++;
2430
-											}
2431
-										} else {
2432
-											$this->block_element( array( '' => $new_value ) );
2433
-										}
2434
-									}
2435
-									$first_item ++;
2436
-								}
2437
-							}
2438
-
2439
-							echo ")";// end content
2440
-
2441
-							echo ", \n";
2442
-
2443
-						}
2444
-					} else {
2445
-
2446
-						if ( substr( $element, 0, 3 ) === "if_" ) {
2447
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2448
-						} elseif ( $element == 'style' ) {
2449
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2450
-						} else {
2451
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2452
-						}
2453
-
2454
-					}
2455
-				}
2456
-			}
2457
-		}
2458
-
2459
-		/**
2460
-		 * Replace block attributes placeholders with the proper naming.
2461
-		 *
2462
-		 * @param $string
2463
-		 *
2464
-		 * @return mixed
2465
-		 */
2466
-		public function block_props_replace( $string, $no_wrap = false ) {
2467
-
2468
-			if ( $no_wrap ) {
2469
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2470
-			} else {
2471
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2472
-			}
2473
-
2474
-			return $string;
2475
-		}
2476
-
2477
-		/**
2478
-		 * Outputs the content of the widget
2479
-		 *
2480
-		 * @param array $args
2481
-		 * @param array $instance
2482
-		 */
2483
-		public function widget( $args, $instance ) {
2484
-
2485
-			// get the filtered values
2486
-			$argument_values = $this->argument_values( $instance );
2487
-			$argument_values = $this->string_to_bool( $argument_values );
2488
-			$output          = $this->output( $argument_values, $args );
2489
-
2490
-			$no_wrap = false;
2491
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2492
-				$no_wrap = true;
2493
-			}
2494
-
2495
-			ob_start();
2496
-			if ( $output && ! $no_wrap ) {
2497
-
2498
-				$class_original = $this->options['widget_ops']['classname'];
2499
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2500
-
2501
-				// Before widget
2502
-				$before_widget = $args['before_widget'];
2503
-				$before_widget = str_replace($class_original,$class,$before_widget);
2504
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2505
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2506
-
2507
-				// After widget
2508
-				$after_widget = $args['after_widget'];
2509
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2510
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2511
-
2512
-				echo $before_widget;
2513
-				// elementor strips the widget wrapping div so we check for and add it back if needed
2514
-				if ( $this->is_elementor_widget_output() ) {
2515
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2516
-				}
2517
-				echo $this->output_title( $args, $instance );
2518
-				echo $output;
2519
-				if ( $this->is_elementor_widget_output() ) {
2520
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2521
-				}
2522
-				echo $after_widget;
2523
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2524
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2525
-				echo $output;
2526
-			} elseif ( $output && $no_wrap ) {
2527
-				echo $output;
2528
-			}
2529
-			$output = ob_get_clean();
2530
-
2531
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2532
-
2533
-			echo $output;
2534
-		}
2535
-
2536
-		/**
2537
-		 * Tests if the current output is inside a elementor container.
2538
-		 *
2539
-		 * @since 1.0.4
2540
-		 * @return bool
2541
-		 */
2542
-		public function is_elementor_widget_output() {
2543
-			$result = false;
2544
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2545
-				$result = true;
2546
-			}
2547
-
2548
-			return $result;
2549
-		}
2550
-
2551
-		/**
2552
-		 * Tests if the current output is inside a elementor preview.
2553
-		 *
2554
-		 * @since 1.0.4
2555
-		 * @return bool
2556
-		 */
2557
-		public function is_elementor_preview() {
2558
-			$result = false;
2559
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2560
-				$result = true;
2561
-			}
2562
-
2563
-			return $result;
2564
-		}
2565
-
2566
-		/**
2567
-		 * Tests if the current output is inside a Divi preview.
2568
-		 *
2569
-		 * @since 1.0.6
2570
-		 * @return bool
2571
-		 */
2572
-		public function is_divi_preview() {
2573
-			$result = false;
2574
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2575
-				$result = true;
2576
-			}
2577
-
2578
-			return $result;
2579
-		}
2580
-
2581
-		/**
2582
-		 * Tests if the current output is inside a Beaver builder preview.
2583
-		 *
2584
-		 * @since 1.0.6
2585
-		 * @return bool
2586
-		 */
2587
-		public function is_beaver_preview() {
2588
-			$result = false;
2589
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
2590
-				$result = true;
2591
-			}
2592
-
2593
-			return $result;
2594
-		}
2595
-
2596
-		/**
2597
-		 * Tests if the current output is inside a siteorigin builder preview.
2598
-		 *
2599
-		 * @since 1.0.6
2600
-		 * @return bool
2601
-		 */
2602
-		public function is_siteorigin_preview() {
2603
-			$result = false;
2604
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2605
-				$result = true;
2606
-			}
2607
-
2608
-			return $result;
2609
-		}
2610
-
2611
-		/**
2612
-		 * Tests if the current output is inside a cornerstone builder preview.
2613
-		 *
2614
-		 * @since 1.0.8
2615
-		 * @return bool
2616
-		 */
2617
-		public function is_cornerstone_preview() {
2618
-			$result = false;
2619
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2620
-				$result = true;
2621
-			}
2622
-
2623
-			return $result;
2624
-		}
2625
-
2626
-		/**
2627
-		 * Tests if the current output is inside a fusion builder preview.
2628
-		 *
2629
-		 * @since 1.1.0
2630
-		 * @return bool
2631
-		 */
2632
-		public function is_fusion_preview() {
2633
-			$result = false;
2634
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2635
-				$result = true;
2636
-			}
2637
-
2638
-			return $result;
2639
-		}
2640
-
2641
-		/**
2642
-		 * Tests if the current output is inside a Oxygen builder preview.
2643
-		 *
2644
-		 * @since 1.0.18
2645
-		 * @return bool
2646
-		 */
2647
-		public function is_oxygen_preview() {
2648
-			$result = false;
2649
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2650
-				$result = true;
2651
-			}
2652
-
2653
-			return $result;
2654
-		}
2655
-
2656
-		/**
2657
-		 * General function to check if we are in a preview situation.
2658
-		 *
2659
-		 * @since 1.0.6
2660
-		 * @return bool
2661
-		 */
2662
-		public function is_preview() {
2663
-			$preview = false;
2664
-			if ( $this->is_divi_preview() ) {
2665
-				$preview = true;
2666
-			} elseif ( $this->is_elementor_preview() ) {
2667
-				$preview = true;
2668
-			} elseif ( $this->is_beaver_preview() ) {
2669
-				$preview = true;
2670
-			} elseif ( $this->is_siteorigin_preview() ) {
2671
-				$preview = true;
2672
-			} elseif ( $this->is_cornerstone_preview() ) {
2673
-				$preview = true;
2674
-			} elseif ( $this->is_fusion_preview() ) {
2675
-				$preview = true;
2676
-			} elseif ( $this->is_oxygen_preview() ) {
2677
-				$preview = true;
2678
-			} elseif( $this->is_block_content_call() ) {
2679
-				$preview = true;
2680
-			}
2681
-
2682
-			return $preview;
2683
-		}
2684
-
2685
-		/**
2686
-		 * Output the super title.
2687
-		 *
2688
-		 * @param $args
2689
-		 * @param array $instance
2690
-		 *
2691
-		 * @return string
2692
-		 */
2693
-		public function output_title( $args, $instance = array() ) {
2694
-			$output = '';
2695
-			if ( ! empty( $instance['title'] ) ) {
2696
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2697
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2698
-
2699
-				if(empty($instance['widget_title_tag'])){
2700
-					$output = $args['before_title'] . $title . $args['after_title'];
2701
-				}else{
2702
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
2703
-
2704
-					// classes
2705
-					$title_classes = array();
2706
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2707
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2708
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2709
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2710
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2711
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2712
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2713
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2714
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2715
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2716
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2717
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2718
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2719
-
2720
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2721
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
2722
-				}
2723
-
2724
-			}
2725
-
2726
-			return $output;
2727
-		}
2728
-
2729
-		/**
2730
-		 * Outputs the options form inputs for the widget.
2731
-		 *
2732
-		 * @param array $instance The widget options.
2733
-		 */
2734
-		public function form( $instance ) {
2735
-
2736
-			// set widget instance
2737
-			$this->instance = $instance;
2738
-
2739
-			// set it as a SD widget
2740
-			echo $this->widget_advanced_toggle();
2741
-
2742
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2743
-			$arguments_raw = $this->get_arguments();
2744
-
2745
-			if ( is_array( $arguments_raw ) ) {
2746
-
2747
-				$arguments = $this->group_arguments( $arguments_raw );
2748
-
2749
-				// Do we have sections?
2750
-				$has_sections = $arguments == $arguments_raw ? false : true;
2751
-
2752
-
2753
-				if ( $has_sections ) {
2754
-					$panel_count = 0;
2755
-					foreach ( $arguments as $key => $args ) {
2756
-
2757
-						?>
2336
+        }
2337
+
2338
+        /**
2339
+         * Convert an array of attributes to block string.
2340
+         *
2341
+         * @todo there is prob a faster way to do this, also we could add some validation here.
2342
+         *
2343
+         * @param $custom_attributes
2344
+         *
2345
+         * @return string
2346
+         */
2347
+        public function array_to_attributes( $custom_attributes, $html = false ) {
2348
+            $attributes = '';
2349
+            if ( ! empty( $custom_attributes ) ) {
2350
+
2351
+                if ( $html ) {
2352
+                    foreach ( $custom_attributes as $key => $val ) {
2353
+                        $attributes .= " $key='$val' ";
2354
+                    }
2355
+                } else {
2356
+                    foreach ( $custom_attributes as $key => $val ) {
2357
+                        $attributes .= "'$key': '$val',";
2358
+                    }
2359
+                }
2360
+            }
2361
+
2362
+            return $attributes;
2363
+        }
2364
+
2365
+        /**
2366
+         * A self looping function to create the output for JS block elements.
2367
+         *
2368
+         * This is what is output in the WP Editor visual view.
2369
+         *
2370
+         * @param $args
2371
+         */
2372
+        public function block_element( $args ) {
2373
+
2374
+
2375
+            if ( ! empty( $args ) ) {
2376
+                foreach ( $args as $element => $new_args ) {
2377
+
2378
+                    if ( is_array( $new_args ) ) { // its an element
2379
+
2380
+
2381
+                        if ( isset( $new_args['element'] ) ) {
2382
+
2383
+                            if ( isset( $new_args['element_require'] ) ) {
2384
+                                echo str_replace( array(
2385
+                                        "'+",
2386
+                                        "+'"
2387
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2388
+                                unset( $new_args['element_require'] );
2389
+                            }
2390
+
2391
+                            echo "\n el( '" . $new_args['element'] . "', {";
2392
+
2393
+                            // get the attributes
2394
+                            foreach ( $new_args as $new_key => $new_value ) {
2395
+
2396
+
2397
+                                if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2398
+                                    // do nothing
2399
+                                } else {
2400
+                                    echo $this->block_element( array( $new_key => $new_value ) );
2401
+                                }
2402
+                            }
2403
+
2404
+                            echo "},";// end attributes
2405
+
2406
+                            // get the content
2407
+                            $first_item = 0;
2408
+                            foreach ( $new_args as $new_key => $new_value ) {
2409
+                                if ( $new_key === 'content' || is_array( $new_value ) ) {
2410
+
2411
+                                    if ( $new_key === 'content' ) {
2412
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2413
+                                    }
2414
+
2415
+                                    if ( is_array( $new_value ) ) {
2416
+
2417
+                                        if ( isset( $new_value['element_require'] ) ) {
2418
+                                            echo str_replace( array(
2419
+                                                    "'+",
2420
+                                                    "+'"
2421
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2422
+                                            unset( $new_value['element_require'] );
2423
+                                        }
2424
+
2425
+                                        if ( isset( $new_value['element_repeat'] ) ) {
2426
+                                            $x = 1;
2427
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
2428
+                                                $this->block_element( array( '' => $new_value ) );
2429
+                                                $x ++;
2430
+                                            }
2431
+                                        } else {
2432
+                                            $this->block_element( array( '' => $new_value ) );
2433
+                                        }
2434
+                                    }
2435
+                                    $first_item ++;
2436
+                                }
2437
+                            }
2438
+
2439
+                            echo ")";// end content
2440
+
2441
+                            echo ", \n";
2442
+
2443
+                        }
2444
+                    } else {
2445
+
2446
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
2447
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2448
+                        } elseif ( $element == 'style' ) {
2449
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2450
+                        } else {
2451
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2452
+                        }
2453
+
2454
+                    }
2455
+                }
2456
+            }
2457
+        }
2458
+
2459
+        /**
2460
+         * Replace block attributes placeholders with the proper naming.
2461
+         *
2462
+         * @param $string
2463
+         *
2464
+         * @return mixed
2465
+         */
2466
+        public function block_props_replace( $string, $no_wrap = false ) {
2467
+
2468
+            if ( $no_wrap ) {
2469
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2470
+            } else {
2471
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2472
+            }
2473
+
2474
+            return $string;
2475
+        }
2476
+
2477
+        /**
2478
+         * Outputs the content of the widget
2479
+         *
2480
+         * @param array $args
2481
+         * @param array $instance
2482
+         */
2483
+        public function widget( $args, $instance ) {
2484
+
2485
+            // get the filtered values
2486
+            $argument_values = $this->argument_values( $instance );
2487
+            $argument_values = $this->string_to_bool( $argument_values );
2488
+            $output          = $this->output( $argument_values, $args );
2489
+
2490
+            $no_wrap = false;
2491
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2492
+                $no_wrap = true;
2493
+            }
2494
+
2495
+            ob_start();
2496
+            if ( $output && ! $no_wrap ) {
2497
+
2498
+                $class_original = $this->options['widget_ops']['classname'];
2499
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2500
+
2501
+                // Before widget
2502
+                $before_widget = $args['before_widget'];
2503
+                $before_widget = str_replace($class_original,$class,$before_widget);
2504
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2505
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2506
+
2507
+                // After widget
2508
+                $after_widget = $args['after_widget'];
2509
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2510
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2511
+
2512
+                echo $before_widget;
2513
+                // elementor strips the widget wrapping div so we check for and add it back if needed
2514
+                if ( $this->is_elementor_widget_output() ) {
2515
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2516
+                }
2517
+                echo $this->output_title( $args, $instance );
2518
+                echo $output;
2519
+                if ( $this->is_elementor_widget_output() ) {
2520
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2521
+                }
2522
+                echo $after_widget;
2523
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2524
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2525
+                echo $output;
2526
+            } elseif ( $output && $no_wrap ) {
2527
+                echo $output;
2528
+            }
2529
+            $output = ob_get_clean();
2530
+
2531
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2532
+
2533
+            echo $output;
2534
+        }
2535
+
2536
+        /**
2537
+         * Tests if the current output is inside a elementor container.
2538
+         *
2539
+         * @since 1.0.4
2540
+         * @return bool
2541
+         */
2542
+        public function is_elementor_widget_output() {
2543
+            $result = false;
2544
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2545
+                $result = true;
2546
+            }
2547
+
2548
+            return $result;
2549
+        }
2550
+
2551
+        /**
2552
+         * Tests if the current output is inside a elementor preview.
2553
+         *
2554
+         * @since 1.0.4
2555
+         * @return bool
2556
+         */
2557
+        public function is_elementor_preview() {
2558
+            $result = false;
2559
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2560
+                $result = true;
2561
+            }
2562
+
2563
+            return $result;
2564
+        }
2565
+
2566
+        /**
2567
+         * Tests if the current output is inside a Divi preview.
2568
+         *
2569
+         * @since 1.0.6
2570
+         * @return bool
2571
+         */
2572
+        public function is_divi_preview() {
2573
+            $result = false;
2574
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2575
+                $result = true;
2576
+            }
2577
+
2578
+            return $result;
2579
+        }
2580
+
2581
+        /**
2582
+         * Tests if the current output is inside a Beaver builder preview.
2583
+         *
2584
+         * @since 1.0.6
2585
+         * @return bool
2586
+         */
2587
+        public function is_beaver_preview() {
2588
+            $result = false;
2589
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
2590
+                $result = true;
2591
+            }
2592
+
2593
+            return $result;
2594
+        }
2595
+
2596
+        /**
2597
+         * Tests if the current output is inside a siteorigin builder preview.
2598
+         *
2599
+         * @since 1.0.6
2600
+         * @return bool
2601
+         */
2602
+        public function is_siteorigin_preview() {
2603
+            $result = false;
2604
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2605
+                $result = true;
2606
+            }
2607
+
2608
+            return $result;
2609
+        }
2610
+
2611
+        /**
2612
+         * Tests if the current output is inside a cornerstone builder preview.
2613
+         *
2614
+         * @since 1.0.8
2615
+         * @return bool
2616
+         */
2617
+        public function is_cornerstone_preview() {
2618
+            $result = false;
2619
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2620
+                $result = true;
2621
+            }
2622
+
2623
+            return $result;
2624
+        }
2625
+
2626
+        /**
2627
+         * Tests if the current output is inside a fusion builder preview.
2628
+         *
2629
+         * @since 1.1.0
2630
+         * @return bool
2631
+         */
2632
+        public function is_fusion_preview() {
2633
+            $result = false;
2634
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2635
+                $result = true;
2636
+            }
2637
+
2638
+            return $result;
2639
+        }
2640
+
2641
+        /**
2642
+         * Tests if the current output is inside a Oxygen builder preview.
2643
+         *
2644
+         * @since 1.0.18
2645
+         * @return bool
2646
+         */
2647
+        public function is_oxygen_preview() {
2648
+            $result = false;
2649
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2650
+                $result = true;
2651
+            }
2652
+
2653
+            return $result;
2654
+        }
2655
+
2656
+        /**
2657
+         * General function to check if we are in a preview situation.
2658
+         *
2659
+         * @since 1.0.6
2660
+         * @return bool
2661
+         */
2662
+        public function is_preview() {
2663
+            $preview = false;
2664
+            if ( $this->is_divi_preview() ) {
2665
+                $preview = true;
2666
+            } elseif ( $this->is_elementor_preview() ) {
2667
+                $preview = true;
2668
+            } elseif ( $this->is_beaver_preview() ) {
2669
+                $preview = true;
2670
+            } elseif ( $this->is_siteorigin_preview() ) {
2671
+                $preview = true;
2672
+            } elseif ( $this->is_cornerstone_preview() ) {
2673
+                $preview = true;
2674
+            } elseif ( $this->is_fusion_preview() ) {
2675
+                $preview = true;
2676
+            } elseif ( $this->is_oxygen_preview() ) {
2677
+                $preview = true;
2678
+            } elseif( $this->is_block_content_call() ) {
2679
+                $preview = true;
2680
+            }
2681
+
2682
+            return $preview;
2683
+        }
2684
+
2685
+        /**
2686
+         * Output the super title.
2687
+         *
2688
+         * @param $args
2689
+         * @param array $instance
2690
+         *
2691
+         * @return string
2692
+         */
2693
+        public function output_title( $args, $instance = array() ) {
2694
+            $output = '';
2695
+            if ( ! empty( $instance['title'] ) ) {
2696
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2697
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2698
+
2699
+                if(empty($instance['widget_title_tag'])){
2700
+                    $output = $args['before_title'] . $title . $args['after_title'];
2701
+                }else{
2702
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
2703
+
2704
+                    // classes
2705
+                    $title_classes = array();
2706
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2707
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2708
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2709
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2710
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2711
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2712
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2713
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2714
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2715
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2716
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2717
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2718
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2719
+
2720
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2721
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
2722
+                }
2723
+
2724
+            }
2725
+
2726
+            return $output;
2727
+        }
2728
+
2729
+        /**
2730
+         * Outputs the options form inputs for the widget.
2731
+         *
2732
+         * @param array $instance The widget options.
2733
+         */
2734
+        public function form( $instance ) {
2735
+
2736
+            // set widget instance
2737
+            $this->instance = $instance;
2738
+
2739
+            // set it as a SD widget
2740
+            echo $this->widget_advanced_toggle();
2741
+
2742
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2743
+            $arguments_raw = $this->get_arguments();
2744
+
2745
+            if ( is_array( $arguments_raw ) ) {
2746
+
2747
+                $arguments = $this->group_arguments( $arguments_raw );
2748
+
2749
+                // Do we have sections?
2750
+                $has_sections = $arguments == $arguments_raw ? false : true;
2751
+
2752
+
2753
+                if ( $has_sections ) {
2754
+                    $panel_count = 0;
2755
+                    foreach ( $arguments as $key => $args ) {
2756
+
2757
+                        ?>
2758 2758
 						<script>
2759 2759
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
2760 2760
 						</script>
2761 2761
 						<?php
2762 2762
 
2763
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
2764
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2765
-						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>";
2766
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2763
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
2764
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2765
+                        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>";
2766
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2767 2767
 
2768
-						foreach ( $args as $k => $a ) {
2768
+                        foreach ( $args as $k => $a ) {
2769 2769
 
2770
-							$this->widget_inputs_row_start($k, $a);
2771
-							$this->widget_inputs( $a, $instance );
2772
-							$this->widget_inputs_row_end($k, $a);
2770
+                            $this->widget_inputs_row_start($k, $a);
2771
+                            $this->widget_inputs( $a, $instance );
2772
+                            $this->widget_inputs_row_end($k, $a);
2773 2773
 
2774
-						}
2774
+                        }
2775 2775
 
2776
-						echo "</div>";
2776
+                        echo "</div>";
2777 2777
 
2778
-						$panel_count ++;
2778
+                        $panel_count ++;
2779 2779
 
2780
-					}
2781
-				} else {
2782
-					foreach ( $arguments as $key => $args ) {
2783
-						$this->widget_inputs_row_start($key, $args);
2784
-						$this->widget_inputs( $args, $instance );
2785
-						$this->widget_inputs_row_end($key, $args);
2786
-					}
2787
-				}
2780
+                    }
2781
+                } else {
2782
+                    foreach ( $arguments as $key => $args ) {
2783
+                        $this->widget_inputs_row_start($key, $args);
2784
+                        $this->widget_inputs( $args, $instance );
2785
+                        $this->widget_inputs_row_end($key, $args);
2786
+                    }
2787
+                }
2788 2788
 
2789
-			}
2790
-		}
2789
+            }
2790
+        }
2791 2791
 
2792
-		public function widget_inputs_row_start($key, $args){
2793
-			if(!empty($args['row'])){
2794
-				// maybe open
2795
-				if(!empty($args['row']['open'])){
2796
-					?>
2792
+        public function widget_inputs_row_start($key, $args){
2793
+            if(!empty($args['row'])){
2794
+                // maybe open
2795
+                if(!empty($args['row']['open'])){
2796
+                    ?>
2797 2797
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
2798
-						echo $this->convert_element_require( $args['row']['element_require'] );
2799
-					} ?>'>
2798
+                        echo $this->convert_element_require( $args['row']['element_require'] );
2799
+                    } ?>'>
2800 2800
 					<?php if(!empty($args['row']['title'])){ ?>
2801 2801
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
2802 2802
 					<?php }?>
2803 2803
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
2804 2804
 					<div class='col pr-2'>
2805 2805
 					<?php
2806
-				}elseif(!empty($args['row']['close'])){
2807
-					echo "<div class='col pl-0'>";
2808
-				}else{
2809
-					echo "<div class='col pl-0 pr-2'>";
2810
-				}
2811
-			}
2812
-		}
2813
-
2814
-		public function widget_inputs_row_end($key, $args){
2815
-
2816
-			if(!empty($args['row'])){
2817
-				// maybe close
2818
-				if(!empty($args['row']['close'])){
2819
-					echo "</div></div>";
2820
-				}
2821
-
2822
-				echo "</div>";
2823
-			}
2824
-		}
2825
-
2826
-		/**
2827
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
2828
-		 *
2829
-		 * @return string
2830
-		 */
2831
-		public function widget_advanced_toggle() {
2832
-
2833
-			$output = '';
2834
-			if ( $this->block_show_advanced() ) {
2835
-				$val = 1;
2836
-			} else {
2837
-				$val = 0;
2838
-			}
2839
-
2840
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2841
-
2842
-			return $output;
2843
-		}
2844
-
2845
-		/**
2846
-		 * Convert require element.
2847
-		 *
2848
-		 * @since 1.0.0
2849
-		 *
2850
-		 * @param string $input Input element.
2851
-		 *
2852
-		 * @return string $output
2853
-		 */
2854
-		public function convert_element_require( $input ) {
2855
-
2856
-			$input = str_replace( "'", '"', $input );// we only want double quotes
2857
-
2858
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
2859
-				"jQuery(form).find('[data-argument=\"",
2860
-				"\"]').find('input,select,textarea').val()"
2861
-			), $input ) );
2862
-
2863
-			return $output;
2864
-		}
2865
-
2866
-		/**
2867
-		 * Builds the inputs for the widget options.
2868
-		 *
2869
-		 * @param $args
2870
-		 * @param $instance
2871
-		 */
2872
-		public function widget_inputs( $args, $instance ) {
2873
-
2874
-			$class             = "";
2875
-			$element_require   = "";
2876
-			$custom_attributes = "";
2877
-
2878
-			// get value
2879
-			if ( isset( $instance[ $args['name'] ] ) ) {
2880
-				$value = $instance[ $args['name'] ];
2881
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2882
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2883
-			} else {
2884
-				$value = '';
2885
-			}
2886
-
2887
-			// get placeholder
2888
-			if ( ! empty( $args['placeholder'] ) ) {
2889
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2890
-			} else {
2891
-				$placeholder = '';
2892
-			}
2893
-
2894
-			// get if advanced
2895
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2896
-				$class .= " sd-advanced-setting ";
2897
-			}
2898
-
2899
-			// element_require
2900
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2901
-				$element_require = $args['element_require'];
2902
-			}
2903
-
2904
-			// custom_attributes
2905
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2906
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2907
-			}
2908
-
2909
-
2910
-			// before wrapper
2911
-			?>
2806
+                }elseif(!empty($args['row']['close'])){
2807
+                    echo "<div class='col pl-0'>";
2808
+                }else{
2809
+                    echo "<div class='col pl-0 pr-2'>";
2810
+                }
2811
+            }
2812
+        }
2813
+
2814
+        public function widget_inputs_row_end($key, $args){
2815
+
2816
+            if(!empty($args['row'])){
2817
+                // maybe close
2818
+                if(!empty($args['row']['close'])){
2819
+                    echo "</div></div>";
2820
+                }
2821
+
2822
+                echo "</div>";
2823
+            }
2824
+        }
2825
+
2826
+        /**
2827
+         * Get the hidden input that when added makes the advanced button show on widget settings.
2828
+         *
2829
+         * @return string
2830
+         */
2831
+        public function widget_advanced_toggle() {
2832
+
2833
+            $output = '';
2834
+            if ( $this->block_show_advanced() ) {
2835
+                $val = 1;
2836
+            } else {
2837
+                $val = 0;
2838
+            }
2839
+
2840
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2841
+
2842
+            return $output;
2843
+        }
2844
+
2845
+        /**
2846
+         * Convert require element.
2847
+         *
2848
+         * @since 1.0.0
2849
+         *
2850
+         * @param string $input Input element.
2851
+         *
2852
+         * @return string $output
2853
+         */
2854
+        public function convert_element_require( $input ) {
2855
+
2856
+            $input = str_replace( "'", '"', $input );// we only want double quotes
2857
+
2858
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
2859
+                "jQuery(form).find('[data-argument=\"",
2860
+                "\"]').find('input,select,textarea').val()"
2861
+            ), $input ) );
2862
+
2863
+            return $output;
2864
+        }
2865
+
2866
+        /**
2867
+         * Builds the inputs for the widget options.
2868
+         *
2869
+         * @param $args
2870
+         * @param $instance
2871
+         */
2872
+        public function widget_inputs( $args, $instance ) {
2873
+
2874
+            $class             = "";
2875
+            $element_require   = "";
2876
+            $custom_attributes = "";
2877
+
2878
+            // get value
2879
+            if ( isset( $instance[ $args['name'] ] ) ) {
2880
+                $value = $instance[ $args['name'] ];
2881
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2882
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2883
+            } else {
2884
+                $value = '';
2885
+            }
2886
+
2887
+            // get placeholder
2888
+            if ( ! empty( $args['placeholder'] ) ) {
2889
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2890
+            } else {
2891
+                $placeholder = '';
2892
+            }
2893
+
2894
+            // get if advanced
2895
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2896
+                $class .= " sd-advanced-setting ";
2897
+            }
2898
+
2899
+            // element_require
2900
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2901
+                $element_require = $args['element_require'];
2902
+            }
2903
+
2904
+            // custom_attributes
2905
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2906
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2907
+            }
2908
+
2909
+
2910
+            // before wrapper
2911
+            ?>
2912 2912
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
2913 2913
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
2914 2914
 			data-element_require='<?php if ( $element_require ) {
2915
-				echo $this->convert_element_require( $element_require );
2916
-			} ?>'
2915
+                echo $this->convert_element_require( $element_require );
2916
+            } ?>'
2917 2917
 			>
2918 2918
 			<?php
2919 2919
 
2920 2920
 
2921
-			switch ( $args['type'] ) {
2922
-				//array('text','password','number','email','tel','url','color')
2923
-				case "text":
2924
-				case "password":
2925
-				case "number":
2926
-				case "email":
2927
-				case "tel":
2928
-				case "url":
2929
-				case "color":
2930
-					?>
2921
+            switch ( $args['type'] ) {
2922
+                //array('text','password','number','email','tel','url','color')
2923
+                case "text":
2924
+                case "password":
2925
+                case "number":
2926
+                case "email":
2927
+                case "tel":
2928
+                case "url":
2929
+                case "color":
2930
+                    ?>
2931 2931
 					<label
2932 2932
 						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>
2933 2933
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -2938,47 +2938,47 @@  discard block
 block discarded – undo
2938 2938
 						                               value="<?php echo esc_attr( $value ); ?>">
2939 2939
 					<?php
2940 2940
 
2941
-					break;
2942
-				case "select":
2943
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2944
-					if ( $multiple ) {
2945
-						if ( empty( $value ) ) {
2946
-							$value = array();
2947
-						}
2948
-					}
2949
-					?>
2941
+                    break;
2942
+                case "select":
2943
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2944
+                    if ( $multiple ) {
2945
+                        if ( empty( $value ) ) {
2946
+                            $value = array();
2947
+                        }
2948
+                    }
2949
+                    ?>
2950 2950
 					<label
2951 2951
 						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>
2952 2952
 					<select <?php echo $placeholder; ?> class="widefat"
2953 2953
 						<?php echo $custom_attributes; ?>
2954 2954
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
2955 2955
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
2956
-						                                if ( $multiple ) {
2957
-							                                echo "[]";
2958
-						                                } ?>"
2956
+                                                        if ( $multiple ) {
2957
+                                                            echo "[]";
2958
+                                                        } ?>"
2959 2959
 						<?php if ( $multiple ) {
2960
-							echo "multiple";
2961
-						} //@todo not implemented yet due to gutenberg not supporting it
2962
-						?>
2960
+                            echo "multiple";
2961
+                        } //@todo not implemented yet due to gutenberg not supporting it
2962
+                        ?>
2963 2963
 					>
2964 2964
 						<?php
2965 2965
 
2966
-						if ( ! empty( $args['options'] ) ) {
2967
-							foreach ( $args['options'] as $val => $label ) {
2968
-								if ( $multiple ) {
2969
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2970
-								} else {
2971
-									$selected = selected( $value, $val, false );
2972
-								}
2973
-								echo "<option value='$val' " . $selected . ">$label</option>";
2974
-							}
2975
-						}
2976
-						?>
2966
+                        if ( ! empty( $args['options'] ) ) {
2967
+                            foreach ( $args['options'] as $val => $label ) {
2968
+                                if ( $multiple ) {
2969
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2970
+                                } else {
2971
+                                    $selected = selected( $value, $val, false );
2972
+                                }
2973
+                                echo "<option value='$val' " . $selected . ">$label</option>";
2974
+                            }
2975
+                        }
2976
+                        ?>
2977 2977
 					</select>
2978 2978
 					<?php
2979
-					break;
2980
-				case "checkbox":
2981
-					?>
2979
+                    break;
2980
+                case "checkbox":
2981
+                    ?>
2982 2982
 					<input <?php echo $placeholder; ?>
2983 2983
 						<?php checked( 1, $value, true ) ?>
2984 2984
 						<?php echo $custom_attributes; ?>
@@ -2988,9 +2988,9 @@  discard block
 block discarded – undo
2988 2988
 					<label
2989 2989
 						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>
2990 2990
 					<?php
2991
-					break;
2992
-				case "textarea":
2993
-					?>
2991
+                    break;
2992
+                case "textarea":
2993
+                    ?>
2994 2994
 					<label
2995 2995
 						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>
2996 2996
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -3000,207 +3000,207 @@  discard block
 block discarded – undo
3000 3000
 					><?php echo esc_attr( $value ); ?></textarea>
3001 3001
 					<?php
3002 3002
 
3003
-					break;
3004
-				case "hidden":
3005
-					?>
3003
+                    break;
3004
+                case "hidden":
3005
+                    ?>
3006 3006
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3007 3007
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
3008 3008
 					       value="<?php echo esc_attr( $value ); ?>">
3009 3009
 					<?php
3010
-					break;
3011
-				default:
3012
-					echo "No input type found!"; // @todo we need to add more input types.
3013
-			}
3010
+                    break;
3011
+                default:
3012
+                    echo "No input type found!"; // @todo we need to add more input types.
3013
+            }
3014 3014
 
3015
-			// after wrapper
3016
-			?>
3015
+            // after wrapper
3016
+            ?>
3017 3017
 			</p>
3018 3018
 			<?php
3019 3019
 
3020 3020
 
3021
-		}
3022
-
3023
-		public function get_widget_icon($icon = 'box-top', $title = ''){
3024
-			if($icon=='box-top'){
3025
-				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>';
3026
-			}elseif($icon=='box-right'){
3027
-				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>';
3028
-			}elseif($icon=='box-bottom'){
3029
-				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>';
3030
-			}elseif($icon=='box-left'){
3031
-				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>';
3032
-			}
3033
-		}
3034
-
3035
-		/**
3036
-		 * Get the widget input description html.
3037
-		 *
3038
-		 * @param $args
3039
-		 *
3040
-		 * @return string
3041
-		 * @todo, need to make its own tooltip script
3042
-		 */
3043
-		public function widget_field_desc( $args ) {
3044
-
3045
-			$description = '';
3046
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
3047
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3048
-					$description = $this->desc_tip( $args['desc'] );
3049
-				} else {
3050
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3051
-				}
3052
-			}
3053
-
3054
-			return $description;
3055
-		}
3056
-
3057
-		/**
3058
-		 * Get the widget input title html.
3059
-		 *
3060
-		 * @param $args
3061
-		 *
3062
-		 * @return string
3063
-		 */
3064
-		public function widget_field_title( $args ) {
3065
-
3066
-			$title = '';
3067
-			if ( isset( $args['title'] ) && $args['title'] ) {
3068
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
3069
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
3070
-				} else {
3071
-					$title = esc_attr($args['title']);
3072
-				}
3073
-			}
3074
-
3075
-			return $title;
3076
-		}
3077
-
3078
-		/**
3079
-		 * Get the tool tip html.
3080
-		 *
3081
-		 * @param $tip
3082
-		 * @param bool $allow_html
3083
-		 *
3084
-		 * @return string
3085
-		 */
3086
-		function desc_tip( $tip, $allow_html = false ) {
3087
-			if ( $allow_html ) {
3088
-				$tip = $this->sanitize_tooltip( $tip );
3089
-			} else {
3090
-				$tip = esc_attr( $tip );
3091
-			}
3092
-
3093
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3094
-		}
3095
-
3096
-		/**
3097
-		 * Sanitize a string destined to be a tooltip.
3098
-		 *
3099
-		 * @param string $var
3100
-		 *
3101
-		 * @return string
3102
-		 */
3103
-		public function sanitize_tooltip( $var ) {
3104
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3105
-				'br'     => array(),
3106
-				'em'     => array(),
3107
-				'strong' => array(),
3108
-				'small'  => array(),
3109
-				'span'   => array(),
3110
-				'ul'     => array(),
3111
-				'li'     => array(),
3112
-				'ol'     => array(),
3113
-				'p'      => array(),
3114
-			) ) );
3115
-		}
3116
-
3117
-		/**
3118
-		 * Processing widget options on save
3119
-		 *
3120
-		 * @param array $new_instance The new options
3121
-		 * @param array $old_instance The previous options
3122
-		 *
3123
-		 * @return array
3124
-		 * @todo we should add some sanitation here.
3125
-		 */
3126
-		public function update( $new_instance, $old_instance ) {
3127
-
3128
-			//save the widget
3129
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
3130
-
3131
-			// set widget instance
3132
-			$this->instance = $instance;
3133
-
3134
-			if ( empty( $this->arguments ) ) {
3135
-				$this->get_arguments();
3136
-			}
3137
-
3138
-			// check for checkboxes
3139
-			if ( ! empty( $this->arguments ) ) {
3140
-				foreach ( $this->arguments as $argument ) {
3141
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3142
-						$instance[ $argument['name'] ] = '0';
3143
-					}
3144
-				}
3145
-			}
3146
-
3147
-			return $instance;
3148
-		}
3149
-
3150
-		/**
3151
-		 * Checks if the current call is a ajax call to get the block content.
3152
-		 *
3153
-		 * This can be used in your widget to return different content as the block content.
3154
-		 *
3155
-		 * @since 1.0.3
3156
-		 * @return bool
3157
-		 */
3158
-		public function is_block_content_call() {
3159
-			$result = false;
3160
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3161
-				$result = true;
3162
-			}
3163
-
3164
-			return $result;
3165
-		}
3166
-
3167
-		/**
3168
-		 * Get an instance hash that will be unique to the type and settings.
3169
-		 *
3170
-		 * @since 1.0.20
3171
-		 * @return string
3172
-		 */
3173
-		public function get_instance_hash(){
3174
-			$instance_string = $this->base_id.serialize($this->instance);
3175
-			return hash('crc32b',$instance_string);
3176
-		}
3177
-
3178
-		/**
3179
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3180
-		 *
3181
-		 * @param array $rules
3182
-		 *
3183
-		 * @since 1.0.20
3184
-		 * @return string
3185
-		 */
3186
-		public function get_instance_style($rules = array()){
3187
-			$css = '';
3188
-
3189
-			if(!empty($rules)){
3190
-				$rules = array_unique($rules);
3191
-				$instance_hash = $this->get_instance_hash();
3192
-				$css .= "<style>";
3193
-				foreach($rules as $rule){
3194
-					$css .= ".sdel-$instance_hash $rule";
3195
-				}
3196
-				$css .= "</style>";
3197
-			}
3198
-
3199
-
3200
-			return $css;
3201
-
3202
-		}
3203
-
3204
-	}
3021
+        }
3022
+
3023
+        public function get_widget_icon($icon = 'box-top', $title = ''){
3024
+            if($icon=='box-top'){
3025
+                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>';
3026
+            }elseif($icon=='box-right'){
3027
+                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>';
3028
+            }elseif($icon=='box-bottom'){
3029
+                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>';
3030
+            }elseif($icon=='box-left'){
3031
+                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>';
3032
+            }
3033
+        }
3034
+
3035
+        /**
3036
+         * Get the widget input description html.
3037
+         *
3038
+         * @param $args
3039
+         *
3040
+         * @return string
3041
+         * @todo, need to make its own tooltip script
3042
+         */
3043
+        public function widget_field_desc( $args ) {
3044
+
3045
+            $description = '';
3046
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
3047
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3048
+                    $description = $this->desc_tip( $args['desc'] );
3049
+                } else {
3050
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3051
+                }
3052
+            }
3053
+
3054
+            return $description;
3055
+        }
3056
+
3057
+        /**
3058
+         * Get the widget input title html.
3059
+         *
3060
+         * @param $args
3061
+         *
3062
+         * @return string
3063
+         */
3064
+        public function widget_field_title( $args ) {
3065
+
3066
+            $title = '';
3067
+            if ( isset( $args['title'] ) && $args['title'] ) {
3068
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
3069
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
3070
+                } else {
3071
+                    $title = esc_attr($args['title']);
3072
+                }
3073
+            }
3074
+
3075
+            return $title;
3076
+        }
3077
+
3078
+        /**
3079
+         * Get the tool tip html.
3080
+         *
3081
+         * @param $tip
3082
+         * @param bool $allow_html
3083
+         *
3084
+         * @return string
3085
+         */
3086
+        function desc_tip( $tip, $allow_html = false ) {
3087
+            if ( $allow_html ) {
3088
+                $tip = $this->sanitize_tooltip( $tip );
3089
+            } else {
3090
+                $tip = esc_attr( $tip );
3091
+            }
3092
+
3093
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3094
+        }
3095
+
3096
+        /**
3097
+         * Sanitize a string destined to be a tooltip.
3098
+         *
3099
+         * @param string $var
3100
+         *
3101
+         * @return string
3102
+         */
3103
+        public function sanitize_tooltip( $var ) {
3104
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3105
+                'br'     => array(),
3106
+                'em'     => array(),
3107
+                'strong' => array(),
3108
+                'small'  => array(),
3109
+                'span'   => array(),
3110
+                'ul'     => array(),
3111
+                'li'     => array(),
3112
+                'ol'     => array(),
3113
+                'p'      => array(),
3114
+            ) ) );
3115
+        }
3116
+
3117
+        /**
3118
+         * Processing widget options on save
3119
+         *
3120
+         * @param array $new_instance The new options
3121
+         * @param array $old_instance The previous options
3122
+         *
3123
+         * @return array
3124
+         * @todo we should add some sanitation here.
3125
+         */
3126
+        public function update( $new_instance, $old_instance ) {
3127
+
3128
+            //save the widget
3129
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
3130
+
3131
+            // set widget instance
3132
+            $this->instance = $instance;
3133
+
3134
+            if ( empty( $this->arguments ) ) {
3135
+                $this->get_arguments();
3136
+            }
3137
+
3138
+            // check for checkboxes
3139
+            if ( ! empty( $this->arguments ) ) {
3140
+                foreach ( $this->arguments as $argument ) {
3141
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3142
+                        $instance[ $argument['name'] ] = '0';
3143
+                    }
3144
+                }
3145
+            }
3146
+
3147
+            return $instance;
3148
+        }
3149
+
3150
+        /**
3151
+         * Checks if the current call is a ajax call to get the block content.
3152
+         *
3153
+         * This can be used in your widget to return different content as the block content.
3154
+         *
3155
+         * @since 1.0.3
3156
+         * @return bool
3157
+         */
3158
+        public function is_block_content_call() {
3159
+            $result = false;
3160
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3161
+                $result = true;
3162
+            }
3163
+
3164
+            return $result;
3165
+        }
3166
+
3167
+        /**
3168
+         * Get an instance hash that will be unique to the type and settings.
3169
+         *
3170
+         * @since 1.0.20
3171
+         * @return string
3172
+         */
3173
+        public function get_instance_hash(){
3174
+            $instance_string = $this->base_id.serialize($this->instance);
3175
+            return hash('crc32b',$instance_string);
3176
+        }
3177
+
3178
+        /**
3179
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3180
+         *
3181
+         * @param array $rules
3182
+         *
3183
+         * @since 1.0.20
3184
+         * @return string
3185
+         */
3186
+        public function get_instance_style($rules = array()){
3187
+            $css = '';
3188
+
3189
+            if(!empty($rules)){
3190
+                $rules = array_unique($rules);
3191
+                $instance_hash = $this->get_instance_hash();
3192
+                $css .= "<style>";
3193
+                foreach($rules as $rule){
3194
+                    $css .= ".sdel-$instance_hash $rule";
3195
+                }
3196
+                $css .= "</style>";
3197
+            }
3198
+
3199
+
3200
+            return $css;
3201
+
3202
+        }
3203
+
3204
+    }
3205 3205
 
3206 3206
 }
Please login to merge, or discard this patch.