Passed
Push — master ( 02cd26...7c0663 )
by Brian
04:41
created
includes/admin/class-getpaid-post-types-admin.php 1 patch
Indentation   +730 added lines, -730 removed lines patch added patch discarded remove patch
@@ -13,732 +13,732 @@  discard block
 block discarded – undo
13 13
 class GetPaid_Post_Types_Admin {
14 14
 
15 15
     /**
16
-	 * Hook in methods.
17
-	 */
18
-	public static function init() {
19
-
20
-		// Init metaboxes.
21
-		GetPaid_Metaboxes::init();
22
-
23
-		// Filter the post updated messages.
24
-		add_filter( 'post_updated_messages', 'GetPaid_Post_Types_Admin::post_updated_messages' );
25
-
26
-		// Filter post actions.
27
-		add_filter( 'post_row_actions', 'GetPaid_Post_Types_Admin::post_row_actions', 10, 2 );
28
-		add_filter( 'post_row_actions', 'GetPaid_Post_Types_Admin::filter_invoice_row_actions', 90, 2 );
29
-
30
-		// Invoice table columns.
31
-		add_filter( 'manage_wpi_invoice_posts_columns', array( __CLASS__, 'invoice_columns' ), 100 );
32
-		add_action( 'manage_wpi_invoice_posts_custom_column', array( __CLASS__, 'display_invoice_columns' ), 10, 2 );
33
-		add_filter( 'bulk_actions-edit-wpi_invoice', array( __CLASS__, 'invoice_bulk_actions' ) );
34
-		add_filter( 'handle_bulk_actions-edit-wpi_invoice', array( __CLASS__, 'handle_invoice_bulk_actions' ), 10, 3 );
35
-
36
-		// Items table columns.
37
-		add_filter( 'manage_wpi_item_posts_columns', array( __CLASS__, 'item_columns' ), 100 );
38
-		add_filter( 'manage_edit-wpi_item_sortable_columns', array( __CLASS__, 'sortable_item_columns' ), 20 );
39
-		add_action( 'manage_wpi_item_posts_custom_column', array( __CLASS__, 'display_item_columns' ), 10, 2 );
40
-		add_action( 'restrict_manage_posts', array( __CLASS__, 'add_item_filters' ), 100 );
41
-		add_action( 'parse_query', array( __CLASS__, 'filter_item_query' ), 100 );
42
-		add_action( 'request', array( __CLASS__, 'reorder_items' ), 100 );
43
-
44
-		// Payment forms columns.
45
-		add_filter( 'manage_wpi_payment_form_posts_columns', array( __CLASS__, 'payment_form_columns' ), 100 );
46
-		add_action( 'manage_wpi_payment_form_posts_custom_column', array( __CLASS__, 'display_payment_form_columns' ), 10, 2 );
47
-		add_filter( 'display_post_states', array( __CLASS__, 'filter_payment_form_state' ), 10, 2 );
48
-
49
-		// Discount table columns.
50
-		add_filter( 'manage_wpi_discount_posts_columns', array( __CLASS__, 'discount_columns' ), 100 );
51
-		add_filter( 'bulk_actions-edit-wpi_discount', '__return_empty_array', 100 );
52
-
53
-		// Deleting posts.
54
-		add_action( 'delete_post', array( __CLASS__, 'delete_post' ) );
55
-		add_filter( 'display_post_states', array( __CLASS__, 'filter_discount_state' ), 10, 2 );
56
-
57
-		add_filter( 'display_post_states', array( __CLASS__, 'add_display_post_states' ), 10, 2 );
58
-	}
59
-
60
-	/**
61
-	 * Post updated messages.
62
-	 */
63
-	public static function post_updated_messages( $messages ) {
64
-		global $post;
65
-
66
-		$messages['wpi_discount'] = array(
67
-			0   => '',
68
-			1   => __( 'Discount updated.', 'invoicing' ),
69
-			2   => __( 'Custom field updated.', 'invoicing' ),
70
-			3   => __( 'Custom field deleted.', 'invoicing' ),
71
-			4   => __( 'Discount updated.', 'invoicing' ),
72
-			5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Discount restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
73
-			6   => __( 'Discount updated.', 'invoicing' ),
74
-			7   => __( 'Discount saved.', 'invoicing' ),
75
-			8   => __( 'Discount submitted.', 'invoicing' ),
76
-			9   => wp_sprintf( __( 'Discount scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
77
-			10  => __( 'Discount draft updated.', 'invoicing' ),
78
-		);
79
-
80
-		$messages['wpi_payment_form'] = array(
81
-			0   => '',
82
-			1   => __( 'Payment Form updated.', 'invoicing' ),
83
-			2   => __( 'Custom field updated.', 'invoicing' ),
84
-			3   => __( 'Custom field deleted.', 'invoicing' ),
85
-			4   => __( 'Payment Form updated.', 'invoicing' ),
86
-			5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Payment Form restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
87
-			6   => __( 'Payment Form updated.', 'invoicing' ),
88
-			7   => __( 'Payment Form saved.', 'invoicing' ),
89
-			8   => __( 'Payment Form submitted.', 'invoicing' ),
90
-			9   => wp_sprintf( __( 'Payment Form scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
91
-			10  => __( 'Payment Form draft updated.', 'invoicing' ),
92
-		);
93
-
94
-		return $messages;
95
-
96
-	}
97
-
98
-	/**
99
-	 * Post row actions.
100
-	 */
101
-	public static function post_row_actions( $actions, $post ) {
102
-
103
-		$post = get_post( $post );
104
-
105
-		// We do not want to edit the default payment form.
106
-		if ( 'wpi_payment_form' == $post->post_type ) {
107
-
108
-			if ( $post->ID == wpinv_get_default_payment_form() ) {
109
-				unset( $actions['trash'] );
110
-				unset( $actions['inline hide-if-no-js'] );
111
-			}
112
-
113
-			$actions['duplicate'] =  sprintf(
114
-				'<a href="%1$s">%2$s</a>',
115
-				esc_url(
116
-					wp_nonce_url(
117
-						add_query_arg(
118
-							array(
119
-								'getpaid-admin-action' => 'duplicate_form',
120
-								'form_id'              => $post->ID
121
-							)
122
-						),
123
-						'getpaid-nonce',
124
-						'getpaid-nonce'
125
-					)
126
-				),
127
-				esc_html( __( 'Duplicate', 'invoicing' ) )
128
-			);
129
-
130
-		}
131
-
132
-		// Link to item payment form.
133
-		if ( 'wpi_item' == $post->post_type ) {
134
-
135
-			if ( in_array( get_post_meta( $post->ID, '_wpinv_type', true ), array( '', 'fee', 'custom' ) ) ) {
136
-
137
-				$actions['buy'] =  sprintf(
138
-					'<a href="%1$s">%2$s</a>',
139
-					esc_url( getpaid_embed_url( false, $post->ID . '|0' ) ),
140
-					esc_html( __( 'Buy', 'invoicing' ) )
141
-				);
142
-
143
-			}
144
-
145
-		}
146
-
147
-		return $actions;
148
-	}
149
-
150
-	/**
16
+     * Hook in methods.
17
+     */
18
+    public static function init() {
19
+
20
+        // Init metaboxes.
21
+        GetPaid_Metaboxes::init();
22
+
23
+        // Filter the post updated messages.
24
+        add_filter( 'post_updated_messages', 'GetPaid_Post_Types_Admin::post_updated_messages' );
25
+
26
+        // Filter post actions.
27
+        add_filter( 'post_row_actions', 'GetPaid_Post_Types_Admin::post_row_actions', 10, 2 );
28
+        add_filter( 'post_row_actions', 'GetPaid_Post_Types_Admin::filter_invoice_row_actions', 90, 2 );
29
+
30
+        // Invoice table columns.
31
+        add_filter( 'manage_wpi_invoice_posts_columns', array( __CLASS__, 'invoice_columns' ), 100 );
32
+        add_action( 'manage_wpi_invoice_posts_custom_column', array( __CLASS__, 'display_invoice_columns' ), 10, 2 );
33
+        add_filter( 'bulk_actions-edit-wpi_invoice', array( __CLASS__, 'invoice_bulk_actions' ) );
34
+        add_filter( 'handle_bulk_actions-edit-wpi_invoice', array( __CLASS__, 'handle_invoice_bulk_actions' ), 10, 3 );
35
+
36
+        // Items table columns.
37
+        add_filter( 'manage_wpi_item_posts_columns', array( __CLASS__, 'item_columns' ), 100 );
38
+        add_filter( 'manage_edit-wpi_item_sortable_columns', array( __CLASS__, 'sortable_item_columns' ), 20 );
39
+        add_action( 'manage_wpi_item_posts_custom_column', array( __CLASS__, 'display_item_columns' ), 10, 2 );
40
+        add_action( 'restrict_manage_posts', array( __CLASS__, 'add_item_filters' ), 100 );
41
+        add_action( 'parse_query', array( __CLASS__, 'filter_item_query' ), 100 );
42
+        add_action( 'request', array( __CLASS__, 'reorder_items' ), 100 );
43
+
44
+        // Payment forms columns.
45
+        add_filter( 'manage_wpi_payment_form_posts_columns', array( __CLASS__, 'payment_form_columns' ), 100 );
46
+        add_action( 'manage_wpi_payment_form_posts_custom_column', array( __CLASS__, 'display_payment_form_columns' ), 10, 2 );
47
+        add_filter( 'display_post_states', array( __CLASS__, 'filter_payment_form_state' ), 10, 2 );
48
+
49
+        // Discount table columns.
50
+        add_filter( 'manage_wpi_discount_posts_columns', array( __CLASS__, 'discount_columns' ), 100 );
51
+        add_filter( 'bulk_actions-edit-wpi_discount', '__return_empty_array', 100 );
52
+
53
+        // Deleting posts.
54
+        add_action( 'delete_post', array( __CLASS__, 'delete_post' ) );
55
+        add_filter( 'display_post_states', array( __CLASS__, 'filter_discount_state' ), 10, 2 );
56
+
57
+        add_filter( 'display_post_states', array( __CLASS__, 'add_display_post_states' ), 10, 2 );
58
+    }
59
+
60
+    /**
61
+     * Post updated messages.
62
+     */
63
+    public static function post_updated_messages( $messages ) {
64
+        global $post;
65
+
66
+        $messages['wpi_discount'] = array(
67
+            0   => '',
68
+            1   => __( 'Discount updated.', 'invoicing' ),
69
+            2   => __( 'Custom field updated.', 'invoicing' ),
70
+            3   => __( 'Custom field deleted.', 'invoicing' ),
71
+            4   => __( 'Discount updated.', 'invoicing' ),
72
+            5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Discount restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
73
+            6   => __( 'Discount updated.', 'invoicing' ),
74
+            7   => __( 'Discount saved.', 'invoicing' ),
75
+            8   => __( 'Discount submitted.', 'invoicing' ),
76
+            9   => wp_sprintf( __( 'Discount scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
77
+            10  => __( 'Discount draft updated.', 'invoicing' ),
78
+        );
79
+
80
+        $messages['wpi_payment_form'] = array(
81
+            0   => '',
82
+            1   => __( 'Payment Form updated.', 'invoicing' ),
83
+            2   => __( 'Custom field updated.', 'invoicing' ),
84
+            3   => __( 'Custom field deleted.', 'invoicing' ),
85
+            4   => __( 'Payment Form updated.', 'invoicing' ),
86
+            5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Payment Form restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
87
+            6   => __( 'Payment Form updated.', 'invoicing' ),
88
+            7   => __( 'Payment Form saved.', 'invoicing' ),
89
+            8   => __( 'Payment Form submitted.', 'invoicing' ),
90
+            9   => wp_sprintf( __( 'Payment Form scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
91
+            10  => __( 'Payment Form draft updated.', 'invoicing' ),
92
+        );
93
+
94
+        return $messages;
95
+
96
+    }
97
+
98
+    /**
99
+     * Post row actions.
100
+     */
101
+    public static function post_row_actions( $actions, $post ) {
102
+
103
+        $post = get_post( $post );
104
+
105
+        // We do not want to edit the default payment form.
106
+        if ( 'wpi_payment_form' == $post->post_type ) {
107
+
108
+            if ( $post->ID == wpinv_get_default_payment_form() ) {
109
+                unset( $actions['trash'] );
110
+                unset( $actions['inline hide-if-no-js'] );
111
+            }
112
+
113
+            $actions['duplicate'] =  sprintf(
114
+                '<a href="%1$s">%2$s</a>',
115
+                esc_url(
116
+                    wp_nonce_url(
117
+                        add_query_arg(
118
+                            array(
119
+                                'getpaid-admin-action' => 'duplicate_form',
120
+                                'form_id'              => $post->ID
121
+                            )
122
+                        ),
123
+                        'getpaid-nonce',
124
+                        'getpaid-nonce'
125
+                    )
126
+                ),
127
+                esc_html( __( 'Duplicate', 'invoicing' ) )
128
+            );
129
+
130
+        }
131
+
132
+        // Link to item payment form.
133
+        if ( 'wpi_item' == $post->post_type ) {
134
+
135
+            if ( in_array( get_post_meta( $post->ID, '_wpinv_type', true ), array( '', 'fee', 'custom' ) ) ) {
136
+
137
+                $actions['buy'] =  sprintf(
138
+                    '<a href="%1$s">%2$s</a>',
139
+                    esc_url( getpaid_embed_url( false, $post->ID . '|0' ) ),
140
+                    esc_html( __( 'Buy', 'invoicing' ) )
141
+                );
142
+
143
+            }
144
+
145
+        }
146
+
147
+        return $actions;
148
+    }
149
+
150
+    /**
151 151
      * Remove bulk edit option from admin side quote listing
152 152
      *
153 153
      * @since    1.0.0
154 154
      * @param array $actions post actions
155
-	 * @param WP_Post $post
155
+     * @param WP_Post $post
156 156
      * @return array $actions actions without edit option
157 157
      */
158 158
     public static function filter_invoice_row_actions( $actions, $post ) {
159 159
 
160 160
         if ( getpaid_is_invoice_post_type( $post->post_type ) ) {
161 161
 
162
-			$actions = array();
163
-			$invoice = new WPInv_Invoice( $post );
164
-
165
-			$actions['edit'] =  sprintf(
166
-				'<a href="%1$s">%2$s</a>',
167
-				esc_url( get_edit_post_link( $invoice->get_id() ) ),
168
-				esc_html( __( 'Edit', 'invoicing' ) )
169
-			);
170
-
171
-			if ( ! $invoice->is_draft() ) {
172
-
173
-				$actions['view'] =  sprintf(
174
-					'<a href="%1$s">%2$s</a>',
175
-					esc_url( $invoice->get_view_url() ),
176
-					sprintf(
177
-						esc_html( __( 'View %s', 'invoicing' ) ),
178
-						getpaid_get_post_type_label( $invoice->get_post_type(), false )
179
-					)
180
-				);
181
-
182
-				$actions['send'] =  sprintf(
183
-					'<a href="%1$s">%2$s</a>',
184
-					esc_url(
185
-						wp_nonce_url(
186
-							add_query_arg(
187
-								array(
188
-									'getpaid-admin-action' => 'send_invoice',
189
-									'invoice_id'           => $invoice->get_id()
190
-								)
191
-							),
192
-							'getpaid-nonce',
193
-							'getpaid-nonce'
194
-						)
195
-					),
196
-					esc_html( __( 'Send to Customer', 'invoicing' ) )
197
-				);
198
-
199
-			}
200
-
201
-			$actions['duplicate'] =  sprintf(
202
-				'<a href="%1$s">%2$s</a>',
203
-				esc_url(
204
-					wp_nonce_url(
205
-						add_query_arg(
206
-							array(
207
-								'getpaid-admin-action' => 'duplicate_invoice',
208
-								'invoice_id'           => $post->ID
209
-							)
210
-						),
211
-						'getpaid-nonce',
212
-						'getpaid-nonce'
213
-					)
214
-				),
215
-				esc_html( __( 'Duplicate', 'invoicing' ) )
216
-			);
162
+            $actions = array();
163
+            $invoice = new WPInv_Invoice( $post );
164
+
165
+            $actions['edit'] =  sprintf(
166
+                '<a href="%1$s">%2$s</a>',
167
+                esc_url( get_edit_post_link( $invoice->get_id() ) ),
168
+                esc_html( __( 'Edit', 'invoicing' ) )
169
+            );
170
+
171
+            if ( ! $invoice->is_draft() ) {
172
+
173
+                $actions['view'] =  sprintf(
174
+                    '<a href="%1$s">%2$s</a>',
175
+                    esc_url( $invoice->get_view_url() ),
176
+                    sprintf(
177
+                        esc_html( __( 'View %s', 'invoicing' ) ),
178
+                        getpaid_get_post_type_label( $invoice->get_post_type(), false )
179
+                    )
180
+                );
181
+
182
+                $actions['send'] =  sprintf(
183
+                    '<a href="%1$s">%2$s</a>',
184
+                    esc_url(
185
+                        wp_nonce_url(
186
+                            add_query_arg(
187
+                                array(
188
+                                    'getpaid-admin-action' => 'send_invoice',
189
+                                    'invoice_id'           => $invoice->get_id()
190
+                                )
191
+                            ),
192
+                            'getpaid-nonce',
193
+                            'getpaid-nonce'
194
+                        )
195
+                    ),
196
+                    esc_html( __( 'Send to Customer', 'invoicing' ) )
197
+                );
198
+
199
+            }
200
+
201
+            $actions['duplicate'] =  sprintf(
202
+                '<a href="%1$s">%2$s</a>',
203
+                esc_url(
204
+                    wp_nonce_url(
205
+                        add_query_arg(
206
+                            array(
207
+                                'getpaid-admin-action' => 'duplicate_invoice',
208
+                                'invoice_id'           => $post->ID
209
+                            )
210
+                        ),
211
+                        'getpaid-nonce',
212
+                        'getpaid-nonce'
213
+                    )
214
+                ),
215
+                esc_html( __( 'Duplicate', 'invoicing' ) )
216
+            );
217 217
 
218 218
         }
219 219
 
220 220
         return $actions;
221
-	}
222
-
223
-	/**
224
-	 * Returns an array of invoice table columns.
225
-	 */
226
-	public static function invoice_columns( $columns ) {
227
-
228
-		$columns = array(
229
-			'cb'                => $columns['cb'],
230
-			'number'            => __( 'Invoice', 'invoicing' ),
231
-			'customer'          => __( 'Customer', 'invoicing' ),
232
-			'invoice_date'      => __( 'Created', 'invoicing' ),
233
-			'payment_date'      => __( 'Completed', 'invoicing' ),
234
-			'amount'            => __( 'Amount', 'invoicing' ),
235
-			'recurring'         => __( 'Recurring', 'invoicing' ),
236
-			'status'            => __( 'Status', 'invoicing' ),
237
-		);
238
-
239
-		return apply_filters( 'wpi_invoice_table_columns', $columns );
240
-	}
241
-
242
-	/**
243
-	 * Displays invoice table columns.
244
-	 */
245
-	public static function display_invoice_columns( $column_name, $post_id ) {
246
-
247
-		$invoice = new WPInv_Invoice( $post_id );
248
-
249
-		switch ( $column_name ) {
250
-
251
-			case 'invoice_date' :
252
-				$date_time = esc_attr( $invoice->get_created_date() );
253
-				$date      = esc_html( getpaid_format_date_value( $date_time, "&mdash;", true ) );
254
-				echo "<span title='$date_time'>$date</span>";
255
-				break;
256
-
257
-			case 'payment_date' :
258
-
259
-				if ( $invoice->is_paid() ) {
260
-					$date_time = esc_attr( $invoice->get_completed_date() );
261
-					$date      = esc_html( getpaid_format_date_value( $date_time, "&mdash;", true ) );
262
-					echo "<span title='$date_time'>$date</span>";
263
-				} else {
264
-					echo "&mdash;";
265
-				}
221
+    }
222
+
223
+    /**
224
+     * Returns an array of invoice table columns.
225
+     */
226
+    public static function invoice_columns( $columns ) {
227
+
228
+        $columns = array(
229
+            'cb'                => $columns['cb'],
230
+            'number'            => __( 'Invoice', 'invoicing' ),
231
+            'customer'          => __( 'Customer', 'invoicing' ),
232
+            'invoice_date'      => __( 'Created', 'invoicing' ),
233
+            'payment_date'      => __( 'Completed', 'invoicing' ),
234
+            'amount'            => __( 'Amount', 'invoicing' ),
235
+            'recurring'         => __( 'Recurring', 'invoicing' ),
236
+            'status'            => __( 'Status', 'invoicing' ),
237
+        );
238
+
239
+        return apply_filters( 'wpi_invoice_table_columns', $columns );
240
+    }
241
+
242
+    /**
243
+     * Displays invoice table columns.
244
+     */
245
+    public static function display_invoice_columns( $column_name, $post_id ) {
246
+
247
+        $invoice = new WPInv_Invoice( $post_id );
248
+
249
+        switch ( $column_name ) {
250
+
251
+            case 'invoice_date' :
252
+                $date_time = esc_attr( $invoice->get_created_date() );
253
+                $date      = esc_html( getpaid_format_date_value( $date_time, "&mdash;", true ) );
254
+                echo "<span title='$date_time'>$date</span>";
255
+                break;
256
+
257
+            case 'payment_date' :
258
+
259
+                if ( $invoice->is_paid() ) {
260
+                    $date_time = esc_attr( $invoice->get_completed_date() );
261
+                    $date      = esc_html( getpaid_format_date_value( $date_time, "&mdash;", true ) );
262
+                    echo "<span title='$date_time'>$date</span>";
263
+                } else {
264
+                    echo "&mdash;";
265
+                }
266 266
 				
267
-				break;
267
+                break;
268 268
 
269
-			case 'amount' :
269
+            case 'amount' :
270 270
 
271
-				$amount = $invoice->get_total();
272
-				$formated_amount = wp_kses_post( wpinv_price( $amount, $invoice->get_currency() ) );
271
+                $amount = $invoice->get_total();
272
+                $formated_amount = wp_kses_post( wpinv_price( $amount, $invoice->get_currency() ) );
273 273
 
274
-				if ( $invoice->is_refunded() ) {
275
-					$refunded_amount = wp_kses_post( wpinv_price( 0, $invoice->get_currency() ) );
276
-					echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
277
-				} else {
274
+                if ( $invoice->is_refunded() ) {
275
+                    $refunded_amount = wp_kses_post( wpinv_price( 0, $invoice->get_currency() ) );
276
+                    echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
277
+                } else {
278 278
 
279
-					$discount = $invoice->get_total_discount();
279
+                    $discount = $invoice->get_total_discount();
280 280
 
281
-					if ( ! empty( $discount ) ) {
282
-						$new_amount = wp_kses_post( wpinv_price( $amount + $discount, $invoice->get_currency() ) );
283
-						echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
284
-					} else {
285
-						echo $formated_amount;
286
-					}
281
+                    if ( ! empty( $discount ) ) {
282
+                        $new_amount = wp_kses_post( wpinv_price( $amount + $discount, $invoice->get_currency() ) );
283
+                        echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
284
+                    } else {
285
+                        echo $formated_amount;
286
+                    }
287 287
 
288
-				}
288
+                }
289 289
 
290
-				break;
290
+                break;
291 291
 
292
-			case 'status' :
293
-				$status       = esc_html( $invoice->get_status() );
294
-				$status_label = esc_html( $invoice->get_status_nicename() );
292
+            case 'status' :
293
+                $status       = esc_html( $invoice->get_status() );
294
+                $status_label = esc_html( $invoice->get_status_nicename() );
295 295
 
296
-				// If it is paid, show the gateway title.
297
-				if ( $invoice->is_paid() ) {
298
-					$gateway = esc_html( $invoice->get_gateway_title() );
299
-					$gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), esc_html( $gateway ) );
296
+                // If it is paid, show the gateway title.
297
+                if ( $invoice->is_paid() ) {
298
+                    $gateway = esc_html( $invoice->get_gateway_title() );
299
+                    $gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), esc_html( $gateway ) );
300 300
 
301
-					echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
302
-				} else {
303
-					echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
304
-				}
301
+                    echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
302
+                } else {
303
+                    echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
304
+                }
305 305
 
306
-				// If it is not paid, display the overdue and view status.
307
-				if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
306
+                // If it is not paid, display the overdue and view status.
307
+                if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
308 308
 
309
-					// Invoice view status.
310
-					if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
311
-						echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
312
-					} else {
313
-						echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
314
-					}
309
+                    // Invoice view status.
310
+                    if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
311
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
312
+                    } else {
313
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
314
+                    }
315 315
 
316
-					// Display the overview status.
317
-					if ( wpinv_get_option( 'overdue_active' ) ) {
318
-						$due_date = $invoice->get_due_date();
319
-						$fomatted = getpaid_format_date( $due_date );
316
+                    // Display the overview status.
317
+                    if ( wpinv_get_option( 'overdue_active' ) ) {
318
+                        $due_date = $invoice->get_due_date();
319
+                        $fomatted = getpaid_format_date( $due_date );
320 320
 
321
-						if ( ! empty( $fomatted ) ) {
322
-							$date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
323
-							echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
324
-						}
325
-					}
321
+                        if ( ! empty( $fomatted ) ) {
322
+                            $date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
323
+                            echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
324
+                        }
325
+                    }
326 326
 
327
-				}
327
+                }
328 328
 
329
-				break;
329
+                break;
330 330
 
331
-			case 'recurring':
331
+            case 'recurring':
332 332
 
333
-				if ( $invoice->is_recurring() ) {
334
-					echo '<i class="fa fa-check" style="color:#43850a;"></i>';
335
-				} else {
336
-					echo '<i class="fa fa-times" style="color:#616161;"></i>';
337
-				}
338
-				break;
333
+                if ( $invoice->is_recurring() ) {
334
+                    echo '<i class="fa fa-check" style="color:#43850a;"></i>';
335
+                } else {
336
+                    echo '<i class="fa fa-times" style="color:#616161;"></i>';
337
+                }
338
+                break;
339 339
 
340
-			case 'number' :
340
+            case 'number' :
341 341
 
342
-				$edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
343
-				$invoice_number  = esc_html( $invoice->get_number() );
344
-				$invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
342
+                $edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
343
+                $invoice_number  = esc_html( $invoice->get_number() );
344
+                $invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
345 345
 
346
-				echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
346
+                echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
347 347
 
348
-				break;
348
+                break;
349 349
 
350
-			case 'customer' :
350
+            case 'customer' :
351 351
 	
352
-				$customer_name = $invoice->get_user_full_name();
352
+                $customer_name = $invoice->get_user_full_name();
353 353
 	
354
-				if ( empty( $customer_name ) ) {
355
-					$customer_name = $invoice->get_email();
356
-				}
354
+                if ( empty( $customer_name ) ) {
355
+                    $customer_name = $invoice->get_email();
356
+                }
357 357
 	
358
-				if ( ! empty( $customer_name ) ) {
359
-					$customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
360
-					$view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
361
-					echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
362
-				} else {
363
-					echo '<div>&mdash;</div>';
364
-				}
358
+                if ( ! empty( $customer_name ) ) {
359
+                    $customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
360
+                    $view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
361
+                    echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
362
+                } else {
363
+                    echo '<div>&mdash;</div>';
364
+                }
365 365
 
366
-				break;
366
+                break;
367 367
 
368
-		}
368
+        }
369 369
 
370
-	}
370
+    }
371 371
 
372
-	/**
373
-	 * Displays invoice bulk actions.
374
-	 */
375
-	public static function invoice_bulk_actions( $actions ) {
376
-		$actions['resend-invoice'] = __( 'Send to Customer', 'invoicing' );
377
-		return $actions;
378
-	}
372
+    /**
373
+     * Displays invoice bulk actions.
374
+     */
375
+    public static function invoice_bulk_actions( $actions ) {
376
+        $actions['resend-invoice'] = __( 'Send to Customer', 'invoicing' );
377
+        return $actions;
378
+    }
379 379
 
380
-	/**
381
-	 * Processes invoice bulk actions.
382
-	 */
383
-	public static function handle_invoice_bulk_actions( $redirect_url, $action, $post_ids ) {
380
+    /**
381
+     * Processes invoice bulk actions.
382
+     */
383
+    public static function handle_invoice_bulk_actions( $redirect_url, $action, $post_ids ) {
384 384
 
385
-		if ( $action == 'resend-invoice' ) {
386
-			foreach ( $post_ids as $post_id ) {
387
-				getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $post_id ), true );
388
-			}
389
-		}
385
+        if ( $action == 'resend-invoice' ) {
386
+            foreach ( $post_ids as $post_id ) {
387
+                getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $post_id ), true );
388
+            }
389
+        }
390 390
 
391
-		return $redirect_url;
391
+        return $redirect_url;
392 392
 
393
-	}
393
+    }
394 394
 
395
-	/**
396
-	 * Returns an array of payment forms table columns.
397
-	 */
398
-	public static function payment_form_columns( $columns ) {
395
+    /**
396
+     * Returns an array of payment forms table columns.
397
+     */
398
+    public static function payment_form_columns( $columns ) {
399 399
 
400
-		$columns = array(
401
-			'cb'                => $columns['cb'],
402
-			'title'             => __( 'Name', 'invoicing' ),
403
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
404
-			'earnings'          => __( 'Revenue', 'invoicing' ),
405
-			'refunds'           => __( 'Refunded', 'invoicing' ),
406
-			'items'             => __( 'Items', 'invoicing' ),
407
-			'date'              => __( 'Date', 'invoicing' ),
408
-		);
400
+        $columns = array(
401
+            'cb'                => $columns['cb'],
402
+            'title'             => __( 'Name', 'invoicing' ),
403
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
404
+            'earnings'          => __( 'Revenue', 'invoicing' ),
405
+            'refunds'           => __( 'Refunded', 'invoicing' ),
406
+            'items'             => __( 'Items', 'invoicing' ),
407
+            'date'              => __( 'Date', 'invoicing' ),
408
+        );
409 409
 
410
-		return apply_filters( 'wpi_payment_form_table_columns', $columns );
410
+        return apply_filters( 'wpi_payment_form_table_columns', $columns );
411 411
 
412
-	}
412
+    }
413 413
 
414
-	/**
415
-	 * Displays payment form table columns.
416
-	 */
417
-	public static function display_payment_form_columns( $column_name, $post_id ) {
414
+    /**
415
+     * Displays payment form table columns.
416
+     */
417
+    public static function display_payment_form_columns( $column_name, $post_id ) {
418 418
 
419
-		// Retrieve the payment form.
420
-		$form = new GetPaid_Payment_Form( $post_id );
419
+        // Retrieve the payment form.
420
+        $form = new GetPaid_Payment_Form( $post_id );
421 421
 
422
-		switch ( $column_name ) {
422
+        switch ( $column_name ) {
423 423
 
424
-			case 'earnings' :
425
-				echo wpinv_price( $form->get_earned() );
426
-				break;
424
+            case 'earnings' :
425
+                echo wpinv_price( $form->get_earned() );
426
+                break;
427 427
 
428
-			case 'refunds' :
429
-				echo wpinv_price( $form->get_refunded() );
430
-				break;
428
+            case 'refunds' :
429
+                echo wpinv_price( $form->get_refunded() );
430
+                break;
431 431
 
432
-			case 'refunds' :
433
-				echo wpinv_price( $form->get_refunded() );
434
-				break;
432
+            case 'refunds' :
433
+                echo wpinv_price( $form->get_refunded() );
434
+                break;
435 435
 
436
-			case 'shortcode' :
436
+            case 'shortcode' :
437 437
 
438
-				if ( $form->is_default() ) {
439
-					echo '&mdash;';
440
-				} else {
441
-					echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
442
-				}
438
+                if ( $form->is_default() ) {
439
+                    echo '&mdash;';
440
+                } else {
441
+                    echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
442
+                }
443 443
 
444
-				break;
444
+                break;
445 445
 
446
-			case 'items' :
446
+            case 'items' :
447 447
 
448
-				$items = $form->get_items();
448
+                $items = $form->get_items();
449 449
 
450
-				if ( $form->is_default() || empty( $items ) ) {
451
-					echo '&mdash;';
452
-					return;
453
-				}
450
+                if ( $form->is_default() || empty( $items ) ) {
451
+                    echo '&mdash;';
452
+                    return;
453
+                }
454 454
 
455
-				$_items = array();
455
+                $_items = array();
456 456
 
457
-				foreach ( $items as $item ) {
458
-					$url = $item->get_edit_url();
457
+                foreach ( $items as $item ) {
458
+                    $url = $item->get_edit_url();
459 459
 
460
-					if ( empty( $url ) ) {
461
-						$_items[] = esc_html( $item->get_name() );
462
-					} else {
463
-						$_items[] = sprintf(
464
-							'<a href="%s">%s</a>',
465
-							esc_url( $url ),
466
-							esc_html( $item->get_name() )
467
-						);
468
-					}
460
+                    if ( empty( $url ) ) {
461
+                        $_items[] = esc_html( $item->get_name() );
462
+                    } else {
463
+                        $_items[] = sprintf(
464
+                            '<a href="%s">%s</a>',
465
+                            esc_url( $url ),
466
+                            esc_html( $item->get_name() )
467
+                        );
468
+                    }
469 469
 
470
-				}
470
+                }
471 471
 
472
-				echo implode( '<br>', $_items );
472
+                echo implode( '<br>', $_items );
473 473
 
474
-				break;
474
+                break;
475 475
 
476
-		}
476
+        }
477 477
 
478
-	}
478
+    }
479 479
 
480
-	/**
481
-	 * Filters post states.
482
-	 */
483
-	public static function filter_payment_form_state( $post_states, $post ) {
480
+    /**
481
+     * Filters post states.
482
+     */
483
+    public static function filter_payment_form_state( $post_states, $post ) {
484 484
 
485
-		if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
486
-			$post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
487
-		}
485
+        if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
486
+            $post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
487
+        }
488 488
 	
489
-		return $post_states;
490
-
491
-	}
492
-
493
-	/**
494
-	 * Returns an array of coupon table columns.
495
-	 */
496
-	public static function discount_columns( $columns ) {
497
-
498
-		$columns = array(
499
-			'cb'                => $columns['cb'],
500
-			'title'             => __( 'Name', 'invoicing' ),
501
-			'code'              => __( 'Code', 'invoicing' ),
502
-			'amount'            => __( 'Amount', 'invoicing' ),
503
-			'usage'             => __( 'Usage / Limit', 'invoicing' ),
504
-			'start_date'        => __( 'Start Date', 'invoicing' ),
505
-			'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
506
-		);
507
-
508
-		return apply_filters( 'wpi_discount_table_columns', $columns );
509
-	}
510
-
511
-	/**
512
-	 * Filters post states.
513
-	 */
514
-	public static function filter_discount_state( $post_states, $post ) {
515
-
516
-		if ( 'wpi_discount' == $post->post_type ) {
517
-
518
-			$discount = new WPInv_Discount( $post );
519
-
520
-			$status = $discount->is_expired() ? 'expired' : $discount->get_status();
521
-
522
-			if ( $status != 'publish' ) {
523
-				return array(
524
-					'discount_status' => wpinv_discount_status( $status ),
525
-				);
526
-			}
527
-
528
-			return array();
529
-
530
-		}
531
-
532
-		return $post_states;
533
-
534
-	}
535
-
536
-	/**
537
-	 * Returns an array of items table columns.
538
-	 */
539
-	public static function item_columns( $columns ) {
540
-
541
-		$columns = array(
542
-			'cb'                => $columns['cb'],
543
-			'title'             => __( 'Name', 'invoicing' ),
544
-			'price'             => __( 'Price', 'invoicing' ),
545
-			'vat_rule'          => __( 'VAT rule', 'invoicing' ),
546
-			'vat_class'         => __( 'VAT class', 'invoicing' ),
547
-			'type'              => __( 'Type', 'invoicing' ),
548
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
549
-		);
550
-
551
-		if ( ! wpinv_use_taxes() ) {
552
-			unset( $columns['vat_rule'] );
553
-			unset( $columns['vat_class'] );
554
-		}
555
-
556
-		return apply_filters( 'wpi_item_table_columns', $columns );
557
-	}
558
-
559
-	/**
560
-	 * Returns an array of sortable items table columns.
561
-	 */
562
-	public static function sortable_item_columns( $columns ) {
563
-
564
-		return array_merge(
565
-			$columns,
566
-			array(
567
-				'price'     => 'price',
568
-				'vat_rule'  => 'vat_rule',
569
-				'vat_class' => 'vat_class',
570
-				'type'      => 'type',
571
-			)
572
-		);
573
-
574
-	}
575
-
576
-	/**
577
-	 * Displays items table columns.
578
-	 */
579
-	public static function display_item_columns( $column_name, $post_id ) {
489
+        return $post_states;
490
+
491
+    }
492
+
493
+    /**
494
+     * Returns an array of coupon table columns.
495
+     */
496
+    public static function discount_columns( $columns ) {
497
+
498
+        $columns = array(
499
+            'cb'                => $columns['cb'],
500
+            'title'             => __( 'Name', 'invoicing' ),
501
+            'code'              => __( 'Code', 'invoicing' ),
502
+            'amount'            => __( 'Amount', 'invoicing' ),
503
+            'usage'             => __( 'Usage / Limit', 'invoicing' ),
504
+            'start_date'        => __( 'Start Date', 'invoicing' ),
505
+            'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
506
+        );
507
+
508
+        return apply_filters( 'wpi_discount_table_columns', $columns );
509
+    }
510
+
511
+    /**
512
+     * Filters post states.
513
+     */
514
+    public static function filter_discount_state( $post_states, $post ) {
515
+
516
+        if ( 'wpi_discount' == $post->post_type ) {
517
+
518
+            $discount = new WPInv_Discount( $post );
519
+
520
+            $status = $discount->is_expired() ? 'expired' : $discount->get_status();
521
+
522
+            if ( $status != 'publish' ) {
523
+                return array(
524
+                    'discount_status' => wpinv_discount_status( $status ),
525
+                );
526
+            }
527
+
528
+            return array();
529
+
530
+        }
531
+
532
+        return $post_states;
533
+
534
+    }
535
+
536
+    /**
537
+     * Returns an array of items table columns.
538
+     */
539
+    public static function item_columns( $columns ) {
540
+
541
+        $columns = array(
542
+            'cb'                => $columns['cb'],
543
+            'title'             => __( 'Name', 'invoicing' ),
544
+            'price'             => __( 'Price', 'invoicing' ),
545
+            'vat_rule'          => __( 'VAT rule', 'invoicing' ),
546
+            'vat_class'         => __( 'VAT class', 'invoicing' ),
547
+            'type'              => __( 'Type', 'invoicing' ),
548
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
549
+        );
550
+
551
+        if ( ! wpinv_use_taxes() ) {
552
+            unset( $columns['vat_rule'] );
553
+            unset( $columns['vat_class'] );
554
+        }
555
+
556
+        return apply_filters( 'wpi_item_table_columns', $columns );
557
+    }
558
+
559
+    /**
560
+     * Returns an array of sortable items table columns.
561
+     */
562
+    public static function sortable_item_columns( $columns ) {
563
+
564
+        return array_merge(
565
+            $columns,
566
+            array(
567
+                'price'     => 'price',
568
+                'vat_rule'  => 'vat_rule',
569
+                'vat_class' => 'vat_class',
570
+                'type'      => 'type',
571
+            )
572
+        );
573
+
574
+    }
575
+
576
+    /**
577
+     * Displays items table columns.
578
+     */
579
+    public static function display_item_columns( $column_name, $post_id ) {
580 580
  
581
-		$item = new WPInv_Item( $post_id );
581
+        $item = new WPInv_Item( $post_id );
582 582
 
583
-		switch ( $column_name ) {
583
+        switch ( $column_name ) {
584 584
 
585
-			case 'price' :
585
+            case 'price' :
586 586
 
587
-				if ( ! $item->is_recurring() ) {
588
-					echo $item->get_the_price();
589
-					break;
590
-				}
587
+                if ( ! $item->is_recurring() ) {
588
+                    echo $item->get_the_price();
589
+                    break;
590
+                }
591 591
 
592
-				$price = wp_sprintf(
593
-					__( '%s / %s', 'invoicing' ),
594
-					$item->get_the_price(),
595
-					getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
596
-				);
592
+                $price = wp_sprintf(
593
+                    __( '%s / %s', 'invoicing' ),
594
+                    $item->get_the_price(),
595
+                    getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
596
+                );
597 597
 
598
-				if ( $item->get_the_price() == $item->get_the_initial_price() ) {
599
-					echo $price;
600
-					break;
601
-				}
598
+                if ( $item->get_the_price() == $item->get_the_initial_price() ) {
599
+                    echo $price;
600
+                    break;
601
+                }
602 602
 
603
-				echo $item->get_the_initial_price();
603
+                echo $item->get_the_initial_price();
604 604
 
605
-				echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
606
-				break;
605
+                echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
606
+                break;
607 607
 
608
-			case 'vat_rule' :
609
-				echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
610
-				break;
608
+            case 'vat_rule' :
609
+                echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
610
+                break;
611 611
 
612
-			case 'vat_class' :
613
-				echo getpaid_get_tax_class_label( $item->get_vat_class() );
614
-				break;
612
+            case 'vat_class' :
613
+                echo getpaid_get_tax_class_label( $item->get_vat_class() );
614
+                break;
615 615
 
616
-			case 'shortcode' :
616
+            case 'shortcode' :
617 617
 
618
-				if ( $item->is_type( array( '', 'fee', 'custom' ) ) ) {
619
-					echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
620
-				} else {
621
-					echo "&mdash;";
622
-				}
618
+                if ( $item->is_type( array( '', 'fee', 'custom' ) ) ) {
619
+                    echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
620
+                } else {
621
+                    echo "&mdash;";
622
+                }
623 623
 				
624
-				break;
624
+                break;
625 625
 
626
-			case 'type' :
627
-				echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
628
-				break;
626
+            case 'type' :
627
+                echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
628
+                break;
629 629
 
630
-		}
630
+        }
631 631
 
632
-	}
632
+    }
633 633
 
634
-	/**
635
-	 * Lets users filter items using taxes.
636
-	 */
637
-	public static function add_item_filters( $post_type ) {
634
+    /**
635
+     * Lets users filter items using taxes.
636
+     */
637
+    public static function add_item_filters( $post_type ) {
638 638
 
639
-		// Abort if we're not dealing with items.
640
-		if ( $post_type != 'wpi_item' ) {
641
-			return;
642
-		}
639
+        // Abort if we're not dealing with items.
640
+        if ( $post_type != 'wpi_item' ) {
641
+            return;
642
+        }
643 643
 
644
-		// Filter by vat rules.
645
-		if ( wpinv_use_taxes() ) {
644
+        // Filter by vat rules.
645
+        if ( wpinv_use_taxes() ) {
646 646
 	
647
-			// Sanitize selected vat rule.
648
-			$vat_rule   = '';
649
-			$vat_rules  = getpaid_get_tax_rules();
650
-			if ( isset( $_GET['vat_rule'] ) ) {
651
-				$vat_rule   =  sanitize_text_field( $_GET['vat_rule'] );
652
-			}
653
-
654
-			// Filter by VAT rule.
655
-			echo wpinv_html_select(
656
-				array(
657
-					'options'          => array_merge(
658
-						array(
659
-							'' => __( 'All VAT rules', 'invoicing' )
660
-						),
661
-						$vat_rules
662
-					),
663
-					'name'             => 'vat_rule',
664
-					'id'               => 'vat_rule',
665
-					'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
666
-					'show_option_all'  => false,
667
-					'show_option_none' => false,
668
-				)
669
-			);
670
-
671
-			// Filter by VAT class.
647
+            // Sanitize selected vat rule.
648
+            $vat_rule   = '';
649
+            $vat_rules  = getpaid_get_tax_rules();
650
+            if ( isset( $_GET['vat_rule'] ) ) {
651
+                $vat_rule   =  sanitize_text_field( $_GET['vat_rule'] );
652
+            }
653
+
654
+            // Filter by VAT rule.
655
+            echo wpinv_html_select(
656
+                array(
657
+                    'options'          => array_merge(
658
+                        array(
659
+                            '' => __( 'All VAT rules', 'invoicing' )
660
+                        ),
661
+                        $vat_rules
662
+                    ),
663
+                    'name'             => 'vat_rule',
664
+                    'id'               => 'vat_rule',
665
+                    'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
666
+                    'show_option_all'  => false,
667
+                    'show_option_none' => false,
668
+                )
669
+            );
670
+
671
+            // Filter by VAT class.
672 672
 	
673
-			// Sanitize selected vat rule.
674
-			$vat_class   = '';
675
-			$vat_classes = getpaid_get_tax_classes();
676
-			if ( isset( $_GET['vat_class'] ) ) {
677
-				$vat_class   = sanitize_text_field( $_GET['vat_class'] );
678
-			}
679
-
680
-			echo wpinv_html_select(
681
-				array(
682
-					'options'          => array_merge(
683
-						array(
684
-							'' => __( 'All VAT classes', 'invoicing' )
685
-						),
686
-						$vat_classes
687
-					),
688
-					'name'             => 'vat_class',
689
-					'id'               => 'vat_class',
690
-					'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
691
-					'show_option_all'  => false,
692
-					'show_option_none' => false,
693
-				)
694
-			);
695
-
696
-		}
697
-
698
-		// Filter by item type.
699
-		$type   = '';
700
-		if ( isset( $_GET['type'] ) ) {
701
-			$type   = sanitize_text_field( $_GET['type'] );
702
-		}
703
-
704
-		echo wpinv_html_select(
705
-			array(
706
-				'options'          => array_merge(
707
-					array(
708
-						'' => __( 'All item types', 'invoicing' )
709
-					),
710
-					wpinv_get_item_types()
711
-				),
712
-				'name'             => 'type',
713
-				'id'               => 'type',
714
-				'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
715
-				'show_option_all'  => false,
716
-				'show_option_none' => false,
717
-			)
718
-		);
719
-
720
-	}
721
-
722
-	/**
723
-	 * Filters the item query.
724
-	 */
725
-	public static function filter_item_query( $query ) {
726
-
727
-		// modify the query only if it admin and main query.
728
-		if ( ! ( is_admin() && $query->is_main_query() ) ){ 
729
-			return $query;
730
-		}
731
-
732
-		// we want to modify the query for our items.
733
-		if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
734
-			return $query;
735
-		}
736
-
737
-		if ( empty( $query->query_vars['meta_query'] ) ) {
738
-			$query->query_vars['meta_query'] = array();
739
-		}
740
-
741
-		// Filter vat rule type
673
+            // Sanitize selected vat rule.
674
+            $vat_class   = '';
675
+            $vat_classes = getpaid_get_tax_classes();
676
+            if ( isset( $_GET['vat_class'] ) ) {
677
+                $vat_class   = sanitize_text_field( $_GET['vat_class'] );
678
+            }
679
+
680
+            echo wpinv_html_select(
681
+                array(
682
+                    'options'          => array_merge(
683
+                        array(
684
+                            '' => __( 'All VAT classes', 'invoicing' )
685
+                        ),
686
+                        $vat_classes
687
+                    ),
688
+                    'name'             => 'vat_class',
689
+                    'id'               => 'vat_class',
690
+                    'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
691
+                    'show_option_all'  => false,
692
+                    'show_option_none' => false,
693
+                )
694
+            );
695
+
696
+        }
697
+
698
+        // Filter by item type.
699
+        $type   = '';
700
+        if ( isset( $_GET['type'] ) ) {
701
+            $type   = sanitize_text_field( $_GET['type'] );
702
+        }
703
+
704
+        echo wpinv_html_select(
705
+            array(
706
+                'options'          => array_merge(
707
+                    array(
708
+                        '' => __( 'All item types', 'invoicing' )
709
+                    ),
710
+                    wpinv_get_item_types()
711
+                ),
712
+                'name'             => 'type',
713
+                'id'               => 'type',
714
+                'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
715
+                'show_option_all'  => false,
716
+                'show_option_none' => false,
717
+            )
718
+        );
719
+
720
+    }
721
+
722
+    /**
723
+     * Filters the item query.
724
+     */
725
+    public static function filter_item_query( $query ) {
726
+
727
+        // modify the query only if it admin and main query.
728
+        if ( ! ( is_admin() && $query->is_main_query() ) ){ 
729
+            return $query;
730
+        }
731
+
732
+        // we want to modify the query for our items.
733
+        if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
734
+            return $query;
735
+        }
736
+
737
+        if ( empty( $query->query_vars['meta_query'] ) ) {
738
+            $query->query_vars['meta_query'] = array();
739
+        }
740
+
741
+        // Filter vat rule type
742 742
         if ( ! empty( $_GET['vat_rule'] ) ) {
743 743
             $query->query_vars['meta_query'][] = array(
744 744
                 'key'     => '_wpinv_vat_rule',
@@ -763,97 +763,97 @@  discard block
 block discarded – undo
763 763
                 'value'   => sanitize_text_field( $_GET['type'] ),
764 764
                 'compare' => '='
765 765
             );
766
-		}
767
-
768
-	}
769
-
770
-	/**
771
-	 * Reorders items.
772
-	 */
773
-	public static function reorder_items( $vars ) {
774
-		global $typenow;
775
-
776
-		if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
777
-			return $vars;
778
-		}
779
-
780
-		// By item type.
781
-		if ( 'type' == $vars['orderby'] ) {
782
-			return array_merge(
783
-				$vars,
784
-				array(
785
-					'meta_key' => '_wpinv_type',
786
-					'orderby'  => 'meta_value'
787
-				)
788
-			);
789
-		}
790
-
791
-		// By vat class.
792
-		if ( 'vat_class' == $vars['orderby'] ) {
793
-			return array_merge(
794
-				$vars,
795
-				array(
796
-					'meta_key' => '_wpinv_vat_class',
797
-					'orderby'  => 'meta_value'
798
-				)
799
-			);
800
-		}
801
-
802
-		// By vat rule.
803
-		if ( 'vat_rule' == $vars['orderby'] ) {
804
-			return array_merge(
805
-				$vars,
806
-				array(
807
-					'meta_key' => '_wpinv_vat_rule',
808
-					'orderby'  => 'meta_value'
809
-				)
810
-			);
811
-		}
812
-
813
-		// By price.
814
-		if ( 'price' == $vars['orderby'] ) {
815
-			return array_merge(
816
-				$vars,
817
-				array(
818
-					'meta_key' => '_wpinv_price',
819
-					'orderby'  => 'meta_value_num'
820
-				)
821
-			);
822
-		}
823
-
824
-		return $vars;
825
-
826
-	}
827
-
828
-	/**
829
-	 * Fired when deleting a post.
830
-	 */
831
-	public static function delete_post( $post_id ) {
832
-
833
-		switch ( get_post_type( $post_id ) ) {
834
-
835
-			case 'wpi_item' :
836
-				do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
837
-				break;
838
-
839
-			case 'wpi_payment_form' :
840
-				do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
841
-				break;
842
-
843
-			case 'wpi_discount' :
844
-				do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
845
-				break;
846
-
847
-			case 'wpi_invoice' :
848
-				$invoice = new WPInv_Invoice( $post_id );
849
-				do_action( "getpaid_before_delete_invoice", $invoice );
850
-				$invoice->get_data_store()->delete_items( $invoice );
851
-				$invoice->get_data_store()->delete_special_fields( $invoice );
852
-				break;
853
-		}
854
-	}
855
-
856
-	/**
766
+        }
767
+
768
+    }
769
+
770
+    /**
771
+     * Reorders items.
772
+     */
773
+    public static function reorder_items( $vars ) {
774
+        global $typenow;
775
+
776
+        if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
777
+            return $vars;
778
+        }
779
+
780
+        // By item type.
781
+        if ( 'type' == $vars['orderby'] ) {
782
+            return array_merge(
783
+                $vars,
784
+                array(
785
+                    'meta_key' => '_wpinv_type',
786
+                    'orderby'  => 'meta_value'
787
+                )
788
+            );
789
+        }
790
+
791
+        // By vat class.
792
+        if ( 'vat_class' == $vars['orderby'] ) {
793
+            return array_merge(
794
+                $vars,
795
+                array(
796
+                    'meta_key' => '_wpinv_vat_class',
797
+                    'orderby'  => 'meta_value'
798
+                )
799
+            );
800
+        }
801
+
802
+        // By vat rule.
803
+        if ( 'vat_rule' == $vars['orderby'] ) {
804
+            return array_merge(
805
+                $vars,
806
+                array(
807
+                    'meta_key' => '_wpinv_vat_rule',
808
+                    'orderby'  => 'meta_value'
809
+                )
810
+            );
811
+        }
812
+
813
+        // By price.
814
+        if ( 'price' == $vars['orderby'] ) {
815
+            return array_merge(
816
+                $vars,
817
+                array(
818
+                    'meta_key' => '_wpinv_price',
819
+                    'orderby'  => 'meta_value_num'
820
+                )
821
+            );
822
+        }
823
+
824
+        return $vars;
825
+
826
+    }
827
+
828
+    /**
829
+     * Fired when deleting a post.
830
+     */
831
+    public static function delete_post( $post_id ) {
832
+
833
+        switch ( get_post_type( $post_id ) ) {
834
+
835
+            case 'wpi_item' :
836
+                do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
837
+                break;
838
+
839
+            case 'wpi_payment_form' :
840
+                do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
841
+                break;
842
+
843
+            case 'wpi_discount' :
844
+                do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
845
+                break;
846
+
847
+            case 'wpi_invoice' :
848
+                $invoice = new WPInv_Invoice( $post_id );
849
+                do_action( "getpaid_before_delete_invoice", $invoice );
850
+                $invoice->get_data_store()->delete_items( $invoice );
851
+                $invoice->get_data_store()->delete_special_fields( $invoice );
852
+                break;
853
+        }
854
+    }
855
+
856
+    /**
857 857
      * Add a post display state for special GetPaid pages in the page list table.
858 858
      *
859 859
      * @param array   $post_states An array of post display states.
@@ -867,22 +867,22 @@  discard block
 block discarded – undo
867 867
             $post_states['getpaid_success_page'] = __( 'GetPaid Receipt Page', 'invoicing' );
868 868
         }
869 869
 
870
-		foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
870
+        foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
871 871
 
872
-			if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
873
-				$post_states["getpaid_{$post_type}_history_page"] = sprintf(
874
-					__( 'GetPaid %s History Page', 'invoicing' ),
875
-					$label
876
-				);
877
-			}
872
+            if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
873
+                $post_states["getpaid_{$post_type}_history_page"] = sprintf(
874
+                    __( 'GetPaid %s History Page', 'invoicing' ),
875
+                    $label
876
+                );
877
+            }
878 878
 
879
-		}
879
+        }
880 880
 		
881
-		if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
881
+        if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
882 882
             $post_states['getpaid_invoice_subscription_page'] = __( 'GetPaid Subscription Page', 'invoicing' );
883 883
         }
884 884
 
885
-		if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
885
+        if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
886 886
             $post_states['getpaid_checkout_page'] = __( 'GetPaid Checkout Page', 'invoicing' );
887 887
         }
888 888
 
Please login to merge, or discard this patch.
includes/payments/class-getpaid-payment-form-submission.php 1 patch
Indentation   +859 added lines, -859 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 /**
@@ -10,200 +10,200 @@  discard block
 block discarded – undo
10 10
 class GetPaid_Payment_Form_Submission {
11 11
 
12 12
     /**
13
-	 * Submission ID
14
-	 *
15
-	 * @var string
16
-	 */
17
-	public $id = null;
18
-
19
-	/**
20
-	 * The raw submission data.
21
-	 *
22
-	 * @var array
23
-	 */
24
-	protected $data = null;
25
-
26
-	/**
27
-	 * Submission totals
28
-	 *
29
-	 * @var array
30
-	 */
31
-	protected $totals = array(
32
-
33
-		'subtotal'      => array(
34
-			'initial'   => 0,
35
-			'recurring' => 0,
36
-		),
37
-
38
-		'discount'      => array(
39
-			'initial'   => 0,
40
-			'recurring' => 0,
41
-		),
42
-
43
-		'fees'          => array(
44
-			'initial'   => 0,
45
-			'recurring' => 0,
46
-		),
47
-
48
-		'taxes'         => array(
49
-			'initial'   => 0,
50
-			'recurring' => 0,
51
-		),
52
-
53
-		'shipping'         => array(
54
-			'initial'   => 0,
55
-			'recurring' => 0,
56
-		),
57
-
58
-	);
59
-
60
-	/**
61
-	 * Sets the associated payment form.
62
-	 *
63
-	 * @var GetPaid_Payment_Form
64
-	 */
13
+     * Submission ID
14
+     *
15
+     * @var string
16
+     */
17
+    public $id = null;
18
+
19
+    /**
20
+     * The raw submission data.
21
+     *
22
+     * @var array
23
+     */
24
+    protected $data = null;
25
+
26
+    /**
27
+     * Submission totals
28
+     *
29
+     * @var array
30
+     */
31
+    protected $totals = array(
32
+
33
+        'subtotal'      => array(
34
+            'initial'   => 0,
35
+            'recurring' => 0,
36
+        ),
37
+
38
+        'discount'      => array(
39
+            'initial'   => 0,
40
+            'recurring' => 0,
41
+        ),
42
+
43
+        'fees'          => array(
44
+            'initial'   => 0,
45
+            'recurring' => 0,
46
+        ),
47
+
48
+        'taxes'         => array(
49
+            'initial'   => 0,
50
+            'recurring' => 0,
51
+        ),
52
+
53
+        'shipping'         => array(
54
+            'initial'   => 0,
55
+            'recurring' => 0,
56
+        ),
57
+
58
+    );
59
+
60
+    /**
61
+     * Sets the associated payment form.
62
+     *
63
+     * @var GetPaid_Payment_Form
64
+     */
65 65
     protected $payment_form = null;
66 66
 
67 67
     /**
68
-	 * The country for the submission.
69
-	 *
70
-	 * @var string
71
-	 */
72
-	public $country = null;
73
-
74
-    /**
75
-	 * The state for the submission.
76
-	 *
77
-	 * @since 1.0.19
78
-	 * @var string
79
-	 */
80
-	public $state = null;
81
-
82
-	/**
83
-	 * The invoice associated with the submission.
84
-	 *
85
-	 * @var WPInv_Invoice
86
-	 */
87
-	protected $invoice = null;
88
-
89
-	/**
90
-	 * The recurring item for the submission.
91
-	 *
92
-	 * @var int
93
-	 */
94
-	public $has_recurring = 0;
95
-
96
-	/**
97
-	 * An array of fees for the submission.
98
-	 *
99
-	 * @var array
100
-	 */
101
-	protected $fees = array();
102
-
103
-	/**
104
-	 * An array of discounts for the submission.
105
-	 *
106
-	 * @var array
107
-	 */
108
-	protected $discounts = array();
109
-
110
-	/**
111
-	 * An array of taxes for the submission.
112
-	 *
113
-	 * @var array
114
-	 */
115
-	protected $taxes = array();
116
-
117
-	/**
118
-	 * An array of items for the submission.
119
-	 *
120
-	 * @var GetPaid_Form_Item[]
121
-	 */
122
-	protected $items = array();
123
-
124
-	/**
125
-	 * The last error.
126
-	 *
127
-	 * @var string
128
-	 */
129
-	public $last_error = null;
130
-
131
-	/**
132
-	 * The last error code.
133
-	 *
134
-	 * @var string
135
-	 */
136
-	public $last_error_code = null;
137
-
138
-    /**
139
-	 * Class constructor.
140
-	 *
141
-	 */
142
-	public function __construct() {
143
-
144
-		// Set the state and country to the default state and country.
145
-		$this->country = wpinv_default_billing_country();
146
-		$this->state   = wpinv_get_default_state();
147
-
148
-		// Do we have an actual submission?
149
-		if ( isset( $_POST['getpaid_payment_form_submission'] ) ) {
150
-			$this->load_data( wp_kses_post_deep( wp_unslash( $_POST ) ) );
151
-		}
152
-
153
-	}
154
-
155
-	/**
156
-	 * Loads submission data.
157
-	 *
158
-	 * @param array $data
159
-	 */
160
-	public function load_data( $data ) {
161
-
162
-		// Allow plugins to filter the data.
163
-		$data       = apply_filters( 'getpaid_submission_data', $data, $this );
164
-
165
-		// Cache it...
166
-		$this->data = $data;
167
-
168
-		// Then generate a unique id from the data.
169
-		$this->id   = md5( wp_json_encode( $data ) );
170
-
171
-		// Finally, process the submission.
172
-		try {
173
-
174
-			// Each process is passed an instance of the class (with reference)
175
-			// and should throw an Exception whenever it encounters one.
176
-			$processors = apply_filters(
177
-				'getpaid_payment_form_submission_processors',
178
-				array(
179
-					array( $this, 'process_payment_form' ),
180
-					array( $this, 'process_invoice' ),
181
-					array( $this, 'process_fees' ),
182
-					array( $this, 'process_items' ),
183
-					array( $this, 'process_discount' ),
184
-					array( $this, 'process_taxes' ),
185
-				),
186
-				$this		
187
-			);
188
-
189
-			foreach ( $processors as $processor ) {
190
-				call_user_func_array( $processor, array( &$this ) );
191
-			}
192
-
193
-		} catch( GetPaid_Payment_Exception $e ) {
194
-			$this->last_error      = $e->getMessage();
195
-			$this->last_error_code = $e->getErrorCode();
196
-		} catch ( Exception $e ) {
197
-			$this->last_error      = $e->getMessage();
198
-			$this->last_error_code = $e->getCode();
199
-		}
200
-
201
-		// Fired when we are done processing a submission.
202
-		do_action_ref_array( 'getpaid_process_submission', array( &$this ) );
203
-
204
-	}
205
-
206
-	/*
68
+     * The country for the submission.
69
+     *
70
+     * @var string
71
+     */
72
+    public $country = null;
73
+
74
+    /**
75
+     * The state for the submission.
76
+     *
77
+     * @since 1.0.19
78
+     * @var string
79
+     */
80
+    public $state = null;
81
+
82
+    /**
83
+     * The invoice associated with the submission.
84
+     *
85
+     * @var WPInv_Invoice
86
+     */
87
+    protected $invoice = null;
88
+
89
+    /**
90
+     * The recurring item for the submission.
91
+     *
92
+     * @var int
93
+     */
94
+    public $has_recurring = 0;
95
+
96
+    /**
97
+     * An array of fees for the submission.
98
+     *
99
+     * @var array
100
+     */
101
+    protected $fees = array();
102
+
103
+    /**
104
+     * An array of discounts for the submission.
105
+     *
106
+     * @var array
107
+     */
108
+    protected $discounts = array();
109
+
110
+    /**
111
+     * An array of taxes for the submission.
112
+     *
113
+     * @var array
114
+     */
115
+    protected $taxes = array();
116
+
117
+    /**
118
+     * An array of items for the submission.
119
+     *
120
+     * @var GetPaid_Form_Item[]
121
+     */
122
+    protected $items = array();
123
+
124
+    /**
125
+     * The last error.
126
+     *
127
+     * @var string
128
+     */
129
+    public $last_error = null;
130
+
131
+    /**
132
+     * The last error code.
133
+     *
134
+     * @var string
135
+     */
136
+    public $last_error_code = null;
137
+
138
+    /**
139
+     * Class constructor.
140
+     *
141
+     */
142
+    public function __construct() {
143
+
144
+        // Set the state and country to the default state and country.
145
+        $this->country = wpinv_default_billing_country();
146
+        $this->state   = wpinv_get_default_state();
147
+
148
+        // Do we have an actual submission?
149
+        if ( isset( $_POST['getpaid_payment_form_submission'] ) ) {
150
+            $this->load_data( wp_kses_post_deep( wp_unslash( $_POST ) ) );
151
+        }
152
+
153
+    }
154
+
155
+    /**
156
+     * Loads submission data.
157
+     *
158
+     * @param array $data
159
+     */
160
+    public function load_data( $data ) {
161
+
162
+        // Allow plugins to filter the data.
163
+        $data       = apply_filters( 'getpaid_submission_data', $data, $this );
164
+
165
+        // Cache it...
166
+        $this->data = $data;
167
+
168
+        // Then generate a unique id from the data.
169
+        $this->id   = md5( wp_json_encode( $data ) );
170
+
171
+        // Finally, process the submission.
172
+        try {
173
+
174
+            // Each process is passed an instance of the class (with reference)
175
+            // and should throw an Exception whenever it encounters one.
176
+            $processors = apply_filters(
177
+                'getpaid_payment_form_submission_processors',
178
+                array(
179
+                    array( $this, 'process_payment_form' ),
180
+                    array( $this, 'process_invoice' ),
181
+                    array( $this, 'process_fees' ),
182
+                    array( $this, 'process_items' ),
183
+                    array( $this, 'process_discount' ),
184
+                    array( $this, 'process_taxes' ),
185
+                ),
186
+                $this		
187
+            );
188
+
189
+            foreach ( $processors as $processor ) {
190
+                call_user_func_array( $processor, array( &$this ) );
191
+            }
192
+
193
+        } catch( GetPaid_Payment_Exception $e ) {
194
+            $this->last_error      = $e->getMessage();
195
+            $this->last_error_code = $e->getErrorCode();
196
+        } catch ( Exception $e ) {
197
+            $this->last_error      = $e->getMessage();
198
+            $this->last_error_code = $e->getCode();
199
+        }
200
+
201
+        // Fired when we are done processing a submission.
202
+        do_action_ref_array( 'getpaid_process_submission', array( &$this ) );
203
+
204
+    }
205
+
206
+    /*
207 207
 	|--------------------------------------------------------------------------
208 208
 	| Payment Forms.
209 209
 	|--------------------------------------------------------------------------
@@ -212,39 +212,39 @@  discard block
 block discarded – undo
212 212
 	| submission has an active payment form etc.
213 213
     */
214 214
 
215
-	/**
216
-	 * Prepares the submission's payment form.
217
-	 *
218
-	 * @since 1.0.19
219
-	 */
220
-	public function process_payment_form() {
215
+    /**
216
+     * Prepares the submission's payment form.
217
+     *
218
+     * @since 1.0.19
219
+     */
220
+    public function process_payment_form() {
221 221
 
222
-		// Every submission needs an active payment form.
223
-		if ( empty( $this->data['form_id'] ) ) {
224
-			throw new Exception( __( 'Missing payment form', 'invoicing' ) );
225
-		}
222
+        // Every submission needs an active payment form.
223
+        if ( empty( $this->data['form_id'] ) ) {
224
+            throw new Exception( __( 'Missing payment form', 'invoicing' ) );
225
+        }
226 226
 
227
-		// Fetch the payment form.
228
-		$this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] );
227
+        // Fetch the payment form.
228
+        $this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] );
229 229
 
230
-		if ( ! $this->payment_form->is_active() ) {
231
-			throw new Exception( __( 'Payment form not active', 'invoicing' ) );
232
-		}
230
+        if ( ! $this->payment_form->is_active() ) {
231
+            throw new Exception( __( 'Payment form not active', 'invoicing' ) );
232
+        }
233 233
 
234
-		do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) );
235
-	}
234
+        do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) );
235
+    }
236 236
 
237 237
     /**
238
-	 * Returns the payment form.
239
-	 *
240
-	 * @since 1.0.19
241
-	 * @return GetPaid_Payment_Form
242
-	 */
243
-	public function get_payment_form() {
244
-		return $this->payment_form;
245
-	}
238
+     * Returns the payment form.
239
+     *
240
+     * @since 1.0.19
241
+     * @return GetPaid_Payment_Form
242
+     */
243
+    public function get_payment_form() {
244
+        return $this->payment_form;
245
+    }
246 246
 
247
-	/*
247
+    /*
248 248
 	|--------------------------------------------------------------------------
249 249
 	| Invoices.
250 250
 	|--------------------------------------------------------------------------
@@ -253,84 +253,84 @@  discard block
 block discarded – undo
253 253
 	| might be for an existing invoice.
254 254
 	*/
255 255
 
256
-	/**
257
-	 * Prepares the submission's invoice.
258
-	 *
259
-	 * @since 1.0.19
260
-	 */
261
-	public function process_invoice() {
256
+    /**
257
+     * Prepares the submission's invoice.
258
+     *
259
+     * @since 1.0.19
260
+     */
261
+    public function process_invoice() {
262 262
 
263
-		// Abort if there is no invoice.
264
-		if ( empty( $this->data['invoice_id'] ) ) {
265
-			return;
266
-		}
263
+        // Abort if there is no invoice.
264
+        if ( empty( $this->data['invoice_id'] ) ) {
265
+            return;
266
+        }
267 267
 
268
-		// If the submission is for an existing invoice, ensure that it exists
269
-		// and that it is not paid for.
270
-		$invoice = wpinv_get_invoice( $this->data['invoice_id'] );
268
+        // If the submission is for an existing invoice, ensure that it exists
269
+        // and that it is not paid for.
270
+        $invoice = wpinv_get_invoice( $this->data['invoice_id'] );
271 271
 
272 272
         if ( empty( $invoice ) ) {
273
-			throw new Exception( __( 'Invalid invoice', 'invoicing' ) );
274
-		}
273
+            throw new Exception( __( 'Invalid invoice', 'invoicing' ) );
274
+        }
275 275
 
276
-		if ( $invoice->is_paid() ) {
277
-			throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) );
278
-		}
276
+        if ( $invoice->is_paid() ) {
277
+            throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) );
278
+        }
279 279
 
280
-		$this->payment_form->invoice = $invoice;
281
-		if ( ! $this->payment_form->is_default() ) {
280
+        $this->payment_form->invoice = $invoice;
281
+        if ( ! $this->payment_form->is_default() ) {
282 282
 
283
-			$items    = array();
284
-			$item_ids = array();
283
+            $items    = array();
284
+            $item_ids = array();
285 285
 	
286
-			foreach ( $invoice->get_items() as $item ) {
287
-				if ( ! in_array( $item->get_id(), $item_ids ) ) {
288
-					$item_ids[] = $item->get_id();
289
-					$items[]    = $item;
290
-				}
291
-			}
286
+            foreach ( $invoice->get_items() as $item ) {
287
+                if ( ! in_array( $item->get_id(), $item_ids ) ) {
288
+                    $item_ids[] = $item->get_id();
289
+                    $items[]    = $item;
290
+                }
291
+            }
292 292
 	
293
-			foreach ( $this->payment_form->get_items() as $item ) {
294
-				if ( ! in_array( $item->get_id(), $item_ids ) ) {
295
-					$item_ids[] = $item->get_id();
296
-					$items[]    = $item;
297
-				}
298
-			}
293
+            foreach ( $this->payment_form->get_items() as $item ) {
294
+                if ( ! in_array( $item->get_id(), $item_ids ) ) {
295
+                    $item_ids[] = $item->get_id();
296
+                    $items[]    = $item;
297
+                }
298
+            }
299 299
 	
300
-			$this->payment_form->set_items( $items );
300
+            $this->payment_form->set_items( $items );
301 301
 	
302
-		} else {
303
-			$this->payment_form->set_items( $invoice->get_items() );
304
-		}
305
-
306
-		$this->country = $invoice->get_country();
307
-		$this->state   = $invoice->get_state();
308
-		$this->invoice = $invoice;
309
-
310
-		do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) );
311
-	}
312
-
313
-	/**
314
-	 * Returns the associated invoice.
315
-	 *
316
-	 * @since 1.0.19
317
-	 * @return WPInv_Invoice
318
-	 */
319
-	public function get_invoice() {
320
-		return $this->invoice;
321
-	}
322
-
323
-	/**
324
-	 * Checks whether there is an invoice associated with this submission.
325
-	 *
326
-	 * @since 1.0.19
327
-	 * @return bool
328
-	 */
329
-	public function has_invoice() {
330
-		return ! empty( $this->invoice );
331
-	}
332
-
333
-	/*
302
+        } else {
303
+            $this->payment_form->set_items( $invoice->get_items() );
304
+        }
305
+
306
+        $this->country = $invoice->get_country();
307
+        $this->state   = $invoice->get_state();
308
+        $this->invoice = $invoice;
309
+
310
+        do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) );
311
+    }
312
+
313
+    /**
314
+     * Returns the associated invoice.
315
+     *
316
+     * @since 1.0.19
317
+     * @return WPInv_Invoice
318
+     */
319
+    public function get_invoice() {
320
+        return $this->invoice;
321
+    }
322
+
323
+    /**
324
+     * Checks whether there is an invoice associated with this submission.
325
+     *
326
+     * @since 1.0.19
327
+     * @return bool
328
+     */
329
+    public function has_invoice() {
330
+        return ! empty( $this->invoice );
331
+    }
332
+
333
+    /*
334 334
 	|--------------------------------------------------------------------------
335 335
 	| Items.
336 336
 	|--------------------------------------------------------------------------
@@ -339,129 +339,129 @@  discard block
 block discarded – undo
339 339
 	| recurring item. But can have an unlimited number of non-recurring items.
340 340
 	*/
341 341
 
342
-	/**
343
-	 * Prepares the submission's items.
344
-	 *
345
-	 * @since 1.0.19
346
-	 */
347
-	public function process_items() {
348
-
349
-		$processor = new GetPaid_Payment_Form_Submission_Items( $this );
350
-
351
-		foreach ( $processor->items as $item ) {
352
-			$this->add_item( $item );
353
-		}
354
-
355
-		do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) );
356
-	}
357
-
358
-	/**
359
-	 * Adds an item to the submission.
360
-	 *
361
-	 * @since 1.0.19
362
-	 * @param GetPaid_Form_Item $item
363
-	 */
364
-	public function add_item( $item ) {
365
-
366
-		// Make sure that it is available for purchase.
367
-		if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) {
368
-			return;
369
-		}
370
-
371
-		// Each submission can only contain one recurring item.
372
-		if ( $item->is_recurring() ) {
373
-			$this->has_recurring = $item->get_id();
374
-		}
375
-
376
-		// Update the items and totals.
377
-		$this->items[ $item->get_id() ]         = $item;
378
-		$this->totals['subtotal']['initial']   += $item->get_sub_total();
379
-		$this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total();
380
-
381
-	}
382
-
383
-	/**
384
-	 * Removes a specific item.
385
-	 * 
386
-	 * You should not call this method after the discounts and taxes
387
-	 * have been calculated.
388
-	 *
389
-	 * @since 1.0.19
390
-	 */
391
-	public function remove_item( $item_id ) {
392
-
393
-		if ( isset( $this->items[ $item_id ] ) ) {
394
-			$this->totals['subtotal']['initial']   -= $this->items[ $item_id ]->get_sub_total();
395
-			$this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total();
396
-
397
-			if ( $this->items[ $item_id ]->is_recurring() ) {
398
-				$this->has_recurring = 0;
399
-			}
400
-
401
-			unset( $this->items[ $item_id ] );
402
-		}
403
-
404
-	}
405
-
406
-	/**
407
-	 * Returns the subtotal.
408
-	 *
409
-	 * @since 1.0.19
410
-	 */
411
-	public function get_subtotal() {
412
-
413
-		if ( wpinv_prices_include_tax() ) {
414
-			return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial'];
415
-		}
416
-
417
-		return $this->totals['subtotal']['initial'];
418
-	}
419
-
420
-	/**
421
-	 * Returns the recurring subtotal.
422
-	 *
423
-	 * @since 1.0.19
424
-	 */
425
-	public function get_recurring_subtotal() {
426
-
427
-		if ( wpinv_prices_include_tax() ) {
428
-			return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring'];
429
-		}
430
-
431
-		return $this->totals['subtotal']['recurring'];
432
-	}
433
-
434
-	/**
435
-	 * Returns all items.
436
-	 *
437
-	 * @since 1.0.19
438
-	 * @return GetPaid_Form_Item[]
439
-	 */
440
-	public function get_items() {
441
-		return $this->items;
442
-	}
443
-
444
-	/**
445
-	 * Checks if there's a single subscription group in the submission.
446
-	 *
447
-	 * @since 2.3.0
448
-	 * @return bool
449
-	 */
450
-	public function has_subscription_group() {
451
-		return $this->has_recurring && getpaid_should_group_subscriptions( $this ) && 1 == count( getpaid_get_subscription_groups( $this ) );
452
-	}
453
-
454
-	/**
455
-	 * Checks if there are multipe subscription groups in the submission.
456
-	 *
457
-	 * @since 2.3.0
458
-	 * @return bool
459
-	 */
460
-	public function has_multiple_subscription_groups() {
461
-		return $this->has_recurring && 1 < count( getpaid_get_subscription_groups( $this ) );
462
-	}
463
-
464
-	/*
342
+    /**
343
+     * Prepares the submission's items.
344
+     *
345
+     * @since 1.0.19
346
+     */
347
+    public function process_items() {
348
+
349
+        $processor = new GetPaid_Payment_Form_Submission_Items( $this );
350
+
351
+        foreach ( $processor->items as $item ) {
352
+            $this->add_item( $item );
353
+        }
354
+
355
+        do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) );
356
+    }
357
+
358
+    /**
359
+     * Adds an item to the submission.
360
+     *
361
+     * @since 1.0.19
362
+     * @param GetPaid_Form_Item $item
363
+     */
364
+    public function add_item( $item ) {
365
+
366
+        // Make sure that it is available for purchase.
367
+        if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) {
368
+            return;
369
+        }
370
+
371
+        // Each submission can only contain one recurring item.
372
+        if ( $item->is_recurring() ) {
373
+            $this->has_recurring = $item->get_id();
374
+        }
375
+
376
+        // Update the items and totals.
377
+        $this->items[ $item->get_id() ]         = $item;
378
+        $this->totals['subtotal']['initial']   += $item->get_sub_total();
379
+        $this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total();
380
+
381
+    }
382
+
383
+    /**
384
+     * Removes a specific item.
385
+     * 
386
+     * You should not call this method after the discounts and taxes
387
+     * have been calculated.
388
+     *
389
+     * @since 1.0.19
390
+     */
391
+    public function remove_item( $item_id ) {
392
+
393
+        if ( isset( $this->items[ $item_id ] ) ) {
394
+            $this->totals['subtotal']['initial']   -= $this->items[ $item_id ]->get_sub_total();
395
+            $this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total();
396
+
397
+            if ( $this->items[ $item_id ]->is_recurring() ) {
398
+                $this->has_recurring = 0;
399
+            }
400
+
401
+            unset( $this->items[ $item_id ] );
402
+        }
403
+
404
+    }
405
+
406
+    /**
407
+     * Returns the subtotal.
408
+     *
409
+     * @since 1.0.19
410
+     */
411
+    public function get_subtotal() {
412
+
413
+        if ( wpinv_prices_include_tax() ) {
414
+            return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial'];
415
+        }
416
+
417
+        return $this->totals['subtotal']['initial'];
418
+    }
419
+
420
+    /**
421
+     * Returns the recurring subtotal.
422
+     *
423
+     * @since 1.0.19
424
+     */
425
+    public function get_recurring_subtotal() {
426
+
427
+        if ( wpinv_prices_include_tax() ) {
428
+            return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring'];
429
+        }
430
+
431
+        return $this->totals['subtotal']['recurring'];
432
+    }
433
+
434
+    /**
435
+     * Returns all items.
436
+     *
437
+     * @since 1.0.19
438
+     * @return GetPaid_Form_Item[]
439
+     */
440
+    public function get_items() {
441
+        return $this->items;
442
+    }
443
+
444
+    /**
445
+     * Checks if there's a single subscription group in the submission.
446
+     *
447
+     * @since 2.3.0
448
+     * @return bool
449
+     */
450
+    public function has_subscription_group() {
451
+        return $this->has_recurring && getpaid_should_group_subscriptions( $this ) && 1 == count( getpaid_get_subscription_groups( $this ) );
452
+    }
453
+
454
+    /**
455
+     * Checks if there are multipe subscription groups in the submission.
456
+     *
457
+     * @since 2.3.0
458
+     * @return bool
459
+     */
460
+    public function has_multiple_subscription_groups() {
461
+        return $this->has_recurring && 1 < count( getpaid_get_subscription_groups( $this ) );
462
+    }
463
+
464
+    /*
465 465
 	|--------------------------------------------------------------------------
466 466
 	| Taxes
467 467
 	|--------------------------------------------------------------------------
@@ -470,128 +470,128 @@  discard block
 block discarded – undo
470 470
 	| or only one-time.
471 471
     */
472 472
 
473
-	/**
474
-	 * Prepares the submission's taxes.
475
-	 *
476
-	 * @since 1.0.19
477
-	 */
478
-	public function process_taxes() {
479
-
480
-		// Abort if we're not using taxes.
481
-		if ( ! $this->use_taxes() ) {
482
-			return;
483
-		}
484
-
485
-		// If a custom country && state has been passed in, use it to calculate taxes.
486
-		$country = $this->get_field( 'wpinv_country', 'billing' );
487
-		if ( ! empty( $country ) ) {
488
-			$this->country = $country;
489
-		}
490
-
491
-		$state = $this->get_field( 'wpinv_state', 'billing' );
492
-		if ( ! empty( $state ) ) {
493
-			$this->state = $state;
494
-		}
495
-
496
-		// Confirm if the provided country and the ip country are similar.
497
-		$address_confirmed = $this->get_field( 'confirm-address' );
498
-		if ( isset( $_POST['billing']['country'] ) && wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) {
499
-			throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) );
500
-		}
501
-
502
-		// Abort if the country is not taxable.
503
-		if ( ! wpinv_is_country_taxable( $this->country ) ) {
504
-			return;
505
-		}
506
-
507
-		$processor = new GetPaid_Payment_Form_Submission_Taxes( $this );
508
-
509
-		foreach ( $processor->taxes as $tax ) {
510
-			$this->add_tax( $tax );
511
-		}
512
-
513
-		do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) );
514
-	}
515
-
516
-	/**
517
-	 * Adds a tax to the submission.
518
-	 *
519
-	 * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required.
520
-	 * @since 1.0.19
521
-	 */
522
-	public function add_tax( $tax ) {
523
-
524
-		if ( wpinv_round_tax_per_tax_rate() ) {
525
-			$tax['initial_tax']   = wpinv_round_amount( $tax['initial_tax'] );
526
-			$tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] );
527
-		}
528
-
529
-		$this->taxes[ $tax['name'] ]         = $tax;
530
-		$this->totals['taxes']['initial']   += wpinv_sanitize_amount( $tax['initial_tax'] );
531
-		$this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] );
532
-
533
-	}
534
-
535
-	/**
536
-	 * Removes a specific tax.
537
-	 *
538
-	 * @since 1.0.19
539
-	 */
540
-	public function remove_tax( $tax_name ) {
541
-
542
-		if ( isset( $this->taxes[ $tax_name ] ) ) {
543
-			$this->totals['taxes']['initial']   -= $this->taxes[ $tax_name ]['initial_tax'];
544
-			$this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax'];
545
-			unset( $this->taxes[ $tax_name ] );
546
-		}
547
-
548
-	}
549
-
550
-	/**
551
-	 * Whether or not we'll use taxes for the submission.
552
-	 *
553
-	 * @since 1.0.19
554
-	 */
555
-	public function use_taxes() {
556
-
557
-		$use_taxes = wpinv_use_taxes();
558
-
559
-		if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) {
560
-			$use_taxes = false;
561
-		}
562
-
563
-		return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this );
564
-
565
-	}
566
-
567
-	/**
568
-	 * Returns the tax.
569
-	 *
570
-	 * @since 1.0.19
571
-	 */
572
-	public function get_tax() {
573
-		return $this->totals['taxes']['initial'];
574
-	}
575
-
576
-	/**
577
-	 * Returns the recurring tax.
578
-	 *
579
-	 * @since 1.0.19
580
-	 */
581
-	public function get_recurring_tax() {
582
-		return $this->totals['taxes']['recurring'];
583
-	}
584
-
585
-	/**
586
-	 * Returns all taxes.
587
-	 *
588
-	 * @since 1.0.19
589
-	 */
590
-	public function get_taxes() {
591
-		return $this->taxes;
592
-	}
593
-
594
-	/*
473
+    /**
474
+     * Prepares the submission's taxes.
475
+     *
476
+     * @since 1.0.19
477
+     */
478
+    public function process_taxes() {
479
+
480
+        // Abort if we're not using taxes.
481
+        if ( ! $this->use_taxes() ) {
482
+            return;
483
+        }
484
+
485
+        // If a custom country && state has been passed in, use it to calculate taxes.
486
+        $country = $this->get_field( 'wpinv_country', 'billing' );
487
+        if ( ! empty( $country ) ) {
488
+            $this->country = $country;
489
+        }
490
+
491
+        $state = $this->get_field( 'wpinv_state', 'billing' );
492
+        if ( ! empty( $state ) ) {
493
+            $this->state = $state;
494
+        }
495
+
496
+        // Confirm if the provided country and the ip country are similar.
497
+        $address_confirmed = $this->get_field( 'confirm-address' );
498
+        if ( isset( $_POST['billing']['country'] ) && wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) {
499
+            throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) );
500
+        }
501
+
502
+        // Abort if the country is not taxable.
503
+        if ( ! wpinv_is_country_taxable( $this->country ) ) {
504
+            return;
505
+        }
506
+
507
+        $processor = new GetPaid_Payment_Form_Submission_Taxes( $this );
508
+
509
+        foreach ( $processor->taxes as $tax ) {
510
+            $this->add_tax( $tax );
511
+        }
512
+
513
+        do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) );
514
+    }
515
+
516
+    /**
517
+     * Adds a tax to the submission.
518
+     *
519
+     * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required.
520
+     * @since 1.0.19
521
+     */
522
+    public function add_tax( $tax ) {
523
+
524
+        if ( wpinv_round_tax_per_tax_rate() ) {
525
+            $tax['initial_tax']   = wpinv_round_amount( $tax['initial_tax'] );
526
+            $tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] );
527
+        }
528
+
529
+        $this->taxes[ $tax['name'] ]         = $tax;
530
+        $this->totals['taxes']['initial']   += wpinv_sanitize_amount( $tax['initial_tax'] );
531
+        $this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] );
532
+
533
+    }
534
+
535
+    /**
536
+     * Removes a specific tax.
537
+     *
538
+     * @since 1.0.19
539
+     */
540
+    public function remove_tax( $tax_name ) {
541
+
542
+        if ( isset( $this->taxes[ $tax_name ] ) ) {
543
+            $this->totals['taxes']['initial']   -= $this->taxes[ $tax_name ]['initial_tax'];
544
+            $this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax'];
545
+            unset( $this->taxes[ $tax_name ] );
546
+        }
547
+
548
+    }
549
+
550
+    /**
551
+     * Whether or not we'll use taxes for the submission.
552
+     *
553
+     * @since 1.0.19
554
+     */
555
+    public function use_taxes() {
556
+
557
+        $use_taxes = wpinv_use_taxes();
558
+
559
+        if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) {
560
+            $use_taxes = false;
561
+        }
562
+
563
+        return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this );
564
+
565
+    }
566
+
567
+    /**
568
+     * Returns the tax.
569
+     *
570
+     * @since 1.0.19
571
+     */
572
+    public function get_tax() {
573
+        return $this->totals['taxes']['initial'];
574
+    }
575
+
576
+    /**
577
+     * Returns the recurring tax.
578
+     *
579
+     * @since 1.0.19
580
+     */
581
+    public function get_recurring_tax() {
582
+        return $this->totals['taxes']['recurring'];
583
+    }
584
+
585
+    /**
586
+     * Returns all taxes.
587
+     *
588
+     * @since 1.0.19
589
+     */
590
+    public function get_taxes() {
591
+        return $this->taxes;
592
+    }
593
+
594
+    /*
595 595
 	|--------------------------------------------------------------------------
596 596
 	| Discounts
597 597
 	|--------------------------------------------------------------------------
@@ -600,99 +600,99 @@  discard block
 block discarded – undo
600 600
 	| or only one-time. They also do not have to come from a discount code.
601 601
     */
602 602
 
603
-	/**
604
-	 * Prepares the submission's discount.
605
-	 *
606
-	 * @since 1.0.19
607
-	 */
608
-	public function process_discount() {
609
-
610
-		$initial_total    = $this->get_subtotal() + $this->get_fee() + $this->get_tax();
611
-		$recurring_total  = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax();
612
-		$processor        = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total );
613
-
614
-		foreach ( $processor->discounts as $discount ) {
615
-			$this->add_discount( $discount );
616
-		}
617
-
618
-		do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) );
619
-	}
620
-
621
-	/**
622
-	 * Adds a discount to the submission.
623
-	 *
624
-	 * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code.
625
-	 * @since 1.0.19
626
-	 */
627
-	public function add_discount( $discount ) {
628
-		$this->discounts[ $discount['name'] ]   = $discount;
629
-		$this->totals['discount']['initial']   += wpinv_sanitize_amount( $discount['initial_discount'] );
630
-		$this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] );
631
-	}
632
-
633
-	/**
634
-	 * Removes a discount from the submission.
635
-	 *
636
-	 * @since 1.0.19
637
-	 */
638
-	public function remove_discount( $name ) {
639
-
640
-		if ( isset( $this->discounts[ $name ] ) ) {
641
-			$this->totals['discount']['initial']   -= $this->discounts[ $name ]['initial_discount'];
642
-			$this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount'];
643
-			unset( $this->discounts[ $name ] );
644
-		}
645
-
646
-	}
647
-
648
-	/**
649
-	 * Checks whether there is a discount code associated with this submission.
650
-	 *
651
-	 * @since 1.0.19
652
-	 * @return bool
653
-	 */
654
-	public function has_discount_code() {
655
-		return ! empty( $this->discounts['discount_code'] );
656
-	}
657
-
658
-	/**
659
-	 * Returns the discount code.
660
-	 *
661
-	 * @since 1.0.19
662
-	 * @return string
663
-	 */
664
-	public function get_discount_code() {
665
-		return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : '';
666
-	}
667
-
668
-	/**
669
-	 * Returns the discount.
670
-	 *
671
-	 * @since 1.0.19
672
-	 */
673
-	public function get_discount() {
674
-		return $this->totals['discount']['initial'];
675
-	}
676
-
677
-	/**
678
-	 * Returns the recurring discount.
679
-	 *
680
-	 * @since 1.0.19
681
-	 */
682
-	public function get_recurring_discount() {
683
-		return $this->totals['discount']['recurring'];
684
-	}
685
-
686
-	/**
687
-	 * Returns all discounts.
688
-	 *
689
-	 * @since 1.0.19
690
-	 */
691
-	public function get_discounts() {
692
-		return $this->discounts;
693
-	}
694
-
695
-	/*
603
+    /**
604
+     * Prepares the submission's discount.
605
+     *
606
+     * @since 1.0.19
607
+     */
608
+    public function process_discount() {
609
+
610
+        $initial_total    = $this->get_subtotal() + $this->get_fee() + $this->get_tax();
611
+        $recurring_total  = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax();
612
+        $processor        = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total );
613
+
614
+        foreach ( $processor->discounts as $discount ) {
615
+            $this->add_discount( $discount );
616
+        }
617
+
618
+        do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) );
619
+    }
620
+
621
+    /**
622
+     * Adds a discount to the submission.
623
+     *
624
+     * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code.
625
+     * @since 1.0.19
626
+     */
627
+    public function add_discount( $discount ) {
628
+        $this->discounts[ $discount['name'] ]   = $discount;
629
+        $this->totals['discount']['initial']   += wpinv_sanitize_amount( $discount['initial_discount'] );
630
+        $this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] );
631
+    }
632
+
633
+    /**
634
+     * Removes a discount from the submission.
635
+     *
636
+     * @since 1.0.19
637
+     */
638
+    public function remove_discount( $name ) {
639
+
640
+        if ( isset( $this->discounts[ $name ] ) ) {
641
+            $this->totals['discount']['initial']   -= $this->discounts[ $name ]['initial_discount'];
642
+            $this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount'];
643
+            unset( $this->discounts[ $name ] );
644
+        }
645
+
646
+    }
647
+
648
+    /**
649
+     * Checks whether there is a discount code associated with this submission.
650
+     *
651
+     * @since 1.0.19
652
+     * @return bool
653
+     */
654
+    public function has_discount_code() {
655
+        return ! empty( $this->discounts['discount_code'] );
656
+    }
657
+
658
+    /**
659
+     * Returns the discount code.
660
+     *
661
+     * @since 1.0.19
662
+     * @return string
663
+     */
664
+    public function get_discount_code() {
665
+        return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : '';
666
+    }
667
+
668
+    /**
669
+     * Returns the discount.
670
+     *
671
+     * @since 1.0.19
672
+     */
673
+    public function get_discount() {
674
+        return $this->totals['discount']['initial'];
675
+    }
676
+
677
+    /**
678
+     * Returns the recurring discount.
679
+     *
680
+     * @since 1.0.19
681
+     */
682
+    public function get_recurring_discount() {
683
+        return $this->totals['discount']['recurring'];
684
+    }
685
+
686
+    /**
687
+     * Returns all discounts.
688
+     *
689
+     * @since 1.0.19
690
+     */
691
+    public function get_discounts() {
692
+        return $this->discounts;
693
+    }
694
+
695
+    /*
696 696
 	|--------------------------------------------------------------------------
697 697
 	| Fees
698 698
 	|--------------------------------------------------------------------------
@@ -702,100 +702,100 @@  discard block
 block discarded – undo
702 702
 	| fees.
703 703
     */
704 704
 
705
-	/**
706
-	 * Prepares the submission's fees.
707
-	 *
708
-	 * @since 1.0.19
709
-	 */
710
-	public function process_fees() {
711
-
712
-		$fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this );
713
-
714
-		foreach ( $fees_processor->fees as $fee ) {
715
-			$this->add_fee( $fee );
716
-		}
717
-
718
-		do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) );
719
-	}
720
-
721
-	/**
722
-	 * Adds a fee to the submission.
723
-	 *
724
-	 * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required.
725
-	 * @since 1.0.19
726
-	 */
727
-	public function add_fee( $fee ) {
728
-
729
-		if ( $fee['name'] == 'shipping' ) {
730
-			$this->totals['shipping']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
731
-			$this->totals['shipping']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
732
-			return;
733
-		}
734
-
735
-		$this->fees[ $fee['name'] ]         = $fee;
736
-		$this->totals['fees']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
737
-		$this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
738
-
739
-	}
740
-
741
-	/**
742
-	 * Removes a fee from the submission.
743
-	 *
744
-	 * @since 1.0.19
745
-	 */
746
-	public function remove_fee( $name ) {
747
-
748
-		if ( isset( $this->fees[ $name ] ) ) {
749
-			$this->totals['fees']['initial']   -= $this->fees[ $name ]['initial_fee'];
750
-			$this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee'];
751
-			unset( $this->fees[ $name ] );
752
-		}
753
-
754
-		if ( 'shipping' == $name ) {
755
-			$this->totals['shipping']['initial']   = 0;
756
-			$this->totals['shipping']['recurring'] = 0;
757
-		}
758
-
759
-	}
760
-
761
-	/**
762
-	 * Returns the fees.
763
-	 *
764
-	 * @since 1.0.19
765
-	 */
766
-	public function get_fee() {
767
-		return $this->totals['fees']['initial'];
768
-	}
769
-
770
-	/**
771
-	 * Returns the recurring fees.
772
-	 *
773
-	 * @since 1.0.19
774
-	 */
775
-	public function get_recurring_fee() {
776
-		return $this->totals['fees']['recurring'];
777
-	}
778
-
779
-	/**
780
-	 * Returns all fees.
781
-	 *
782
-	 * @since 1.0.19
783
-	 */
784
-	public function get_fees() {
785
-		return $this->fees;
786
-	}
787
-
788
-	/**
789
-	 * Checks if there are any fees for the form.
790
-	 *
791
-	 * @return bool
792
-	 * @since 1.0.19
793
-	 */
794
-	public function has_fees() {
795
-		return count( $this->fees ) !== 0;
796
-	}
797
-
798
-	/*
705
+    /**
706
+     * Prepares the submission's fees.
707
+     *
708
+     * @since 1.0.19
709
+     */
710
+    public function process_fees() {
711
+
712
+        $fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this );
713
+
714
+        foreach ( $fees_processor->fees as $fee ) {
715
+            $this->add_fee( $fee );
716
+        }
717
+
718
+        do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) );
719
+    }
720
+
721
+    /**
722
+     * Adds a fee to the submission.
723
+     *
724
+     * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required.
725
+     * @since 1.0.19
726
+     */
727
+    public function add_fee( $fee ) {
728
+
729
+        if ( $fee['name'] == 'shipping' ) {
730
+            $this->totals['shipping']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
731
+            $this->totals['shipping']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
732
+            return;
733
+        }
734
+
735
+        $this->fees[ $fee['name'] ]         = $fee;
736
+        $this->totals['fees']['initial']   += wpinv_sanitize_amount( $fee['initial_fee'] );
737
+        $this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] );
738
+
739
+    }
740
+
741
+    /**
742
+     * Removes a fee from the submission.
743
+     *
744
+     * @since 1.0.19
745
+     */
746
+    public function remove_fee( $name ) {
747
+
748
+        if ( isset( $this->fees[ $name ] ) ) {
749
+            $this->totals['fees']['initial']   -= $this->fees[ $name ]['initial_fee'];
750
+            $this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee'];
751
+            unset( $this->fees[ $name ] );
752
+        }
753
+
754
+        if ( 'shipping' == $name ) {
755
+            $this->totals['shipping']['initial']   = 0;
756
+            $this->totals['shipping']['recurring'] = 0;
757
+        }
758
+
759
+    }
760
+
761
+    /**
762
+     * Returns the fees.
763
+     *
764
+     * @since 1.0.19
765
+     */
766
+    public function get_fee() {
767
+        return $this->totals['fees']['initial'];
768
+    }
769
+
770
+    /**
771
+     * Returns the recurring fees.
772
+     *
773
+     * @since 1.0.19
774
+     */
775
+    public function get_recurring_fee() {
776
+        return $this->totals['fees']['recurring'];
777
+    }
778
+
779
+    /**
780
+     * Returns all fees.
781
+     *
782
+     * @since 1.0.19
783
+     */
784
+    public function get_fees() {
785
+        return $this->fees;
786
+    }
787
+
788
+    /**
789
+     * Checks if there are any fees for the form.
790
+     *
791
+     * @return bool
792
+     * @since 1.0.19
793
+     */
794
+    public function has_fees() {
795
+        return count( $this->fees ) !== 0;
796
+    }
797
+
798
+    /*
799 799
 	|--------------------------------------------------------------------------
800 800
 	| MISC
801 801
 	|--------------------------------------------------------------------------
@@ -803,147 +803,147 @@  discard block
 block discarded – undo
803 803
 	| Extra submission functions.
804 804
     */
805 805
 
806
-	/**
807
-	 * Returns the shipping amount.
808
-	 *
809
-	 * @since 1.0.19
810
-	 */
811
-	public function get_shipping() {
812
-		return $this->totals['shipping']['initial'];
813
-	}
814
-
815
-	/**
816
-	 * Returns the recurring shipping.
817
-	 *
818
-	 * @since 1.0.19
819
-	 */
820
-	public function get_recurring_shipping() {
821
-		return $this->totals['shipping']['recurring'];
822
-	}
823
-
824
-	/**
825
-	 * Checks if there are any shipping fees for the form.
826
-	 *
827
-	 * @return bool
828
-	 * @since 1.0.19
829
-	 */
830
-	public function has_shipping() {
831
-		return apply_filters( 'getpaid_payment_form_has_shipping', false, $this );
832
-	}
833
-
834
-	/**
835
-	 * Checks if this is the initial fetch.
836
-	 *
837
-	 * @return bool
838
-	 * @since 1.0.19
839
-	 */
840
-	public function is_initial_fetch() {
841
-		return empty( $this->data['initial_state'] );
842
-	}
843
-
844
-	/**
845
-	 * Returns the total amount to collect for this submission.
846
-	 *
847
-	 * @since 1.0.19
848
-	 */
849
-	public function get_total() {
850
-		$total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() + $this->get_shipping() - $this->get_discount();
851
-		return max( $total, 0 );
852
-	}
853
-
854
-	/**
855
-	 * Returns the recurring total amount to collect for this submission.
856
-	 *
857
-	 * @since 1.0.19
858
-	 */
859
-	public function get_recurring_total() {
860
-		$total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() + $this->get_recurring_shipping() - $this->get_recurring_discount();
861
-		return max( $total, 0 );
862
-	}
863
-
864
-	/**
865
-	 * Whether payment details should be collected for this submission.
866
-	 *
867
-	 * @since 1.0.19
868
-	 */
869
-	public function should_collect_payment_details() {
870
-		$initial   = $this->get_total();
871
-		$recurring = $this->get_recurring_total();
872
-
873
-		if ( $this->has_recurring == 0 ) {
874
-			$recurring = 0;
875
-		}
876
-
877
-		$collect = $initial > 0 || $recurring > 0;
878
-		return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this  );
879
-	}
880
-
881
-	/**
882
-	 * Returns the billing email of the user.
883
-	 *
884
-	 * @since 1.0.19
885
-	 */
886
-	public function get_billing_email() {
887
-		return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this  );
888
-	}
889
-
890
-	/**
891
-	 * Checks if the submitter has a billing email.
892
-	 *
893
-	 * @since 1.0.19
894
-	 */
895
-	public function has_billing_email() {
896
-		$billing_email = $this->get_billing_email();
897
-		return ! empty( $billing_email ) && is_email( $billing_email );
898
-	}
899
-
900
-	/**
901
-	 * Returns the appropriate currency for the submission.
902
-	 *
903
-	 * @since 1.0.19
904
-	 * @return string
905
-	 */
906
-	public function get_currency() {
907
-		return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency();
908
-    }
909
-
910
-    /**
911
-	 * Returns the raw submission data.
912
-	 *
913
-	 * @since 1.0.19
914
-	 * @return array
915
-	 */
916
-	public function get_data() {
917
-		return $this->data;
918
-	}
919
-
920
-	/**
921
-	 * Returns a field from the submission data
922
-	 *
923
-	 * @param string $field
924
-	 * @since 1.0.19
925
-	 * @return mixed|null
926
-	 */
927
-	public function get_field( $field, $sub_array_key = null ) {
928
-		return getpaid_get_array_field( $this->data, $field, $sub_array_key );
929
-	}
930
-
931
-	/**
932
-	 * Checks if a required field is set.
933
-	 *
934
-	 * @since 1.0.19
935
-	 */
936
-	public function is_required_field_set( $field ) {
937
-		return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] );
938
-	}
939
-
940
-	/**
941
-	 * Formats an amount
942
-	 *
943
-	 * @since 1.0.19
944
-	 */
945
-	public function format_amount( $amount ) {
946
-		return wpinv_price( $amount, $this->get_currency() );
947
-	}
806
+    /**
807
+     * Returns the shipping amount.
808
+     *
809
+     * @since 1.0.19
810
+     */
811
+    public function get_shipping() {
812
+        return $this->totals['shipping']['initial'];
813
+    }
814
+
815
+    /**
816
+     * Returns the recurring shipping.
817
+     *
818
+     * @since 1.0.19
819
+     */
820
+    public function get_recurring_shipping() {
821
+        return $this->totals['shipping']['recurring'];
822
+    }
823
+
824
+    /**
825
+     * Checks if there are any shipping fees for the form.
826
+     *
827
+     * @return bool
828
+     * @since 1.0.19
829
+     */
830
+    public function has_shipping() {
831
+        return apply_filters( 'getpaid_payment_form_has_shipping', false, $this );
832
+    }
833
+
834
+    /**
835
+     * Checks if this is the initial fetch.
836
+     *
837
+     * @return bool
838
+     * @since 1.0.19
839
+     */
840
+    public function is_initial_fetch() {
841
+        return empty( $this->data['initial_state'] );
842
+    }
843
+
844
+    /**
845
+     * Returns the total amount to collect for this submission.
846
+     *
847
+     * @since 1.0.19
848
+     */
849
+    public function get_total() {
850
+        $total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() + $this->get_shipping() - $this->get_discount();
851
+        return max( $total, 0 );
852
+    }
853
+
854
+    /**
855
+     * Returns the recurring total amount to collect for this submission.
856
+     *
857
+     * @since 1.0.19
858
+     */
859
+    public function get_recurring_total() {
860
+        $total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() + $this->get_recurring_shipping() - $this->get_recurring_discount();
861
+        return max( $total, 0 );
862
+    }
863
+
864
+    /**
865
+     * Whether payment details should be collected for this submission.
866
+     *
867
+     * @since 1.0.19
868
+     */
869
+    public function should_collect_payment_details() {
870
+        $initial   = $this->get_total();
871
+        $recurring = $this->get_recurring_total();
872
+
873
+        if ( $this->has_recurring == 0 ) {
874
+            $recurring = 0;
875
+        }
876
+
877
+        $collect = $initial > 0 || $recurring > 0;
878
+        return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this  );
879
+    }
880
+
881
+    /**
882
+     * Returns the billing email of the user.
883
+     *
884
+     * @since 1.0.19
885
+     */
886
+    public function get_billing_email() {
887
+        return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this  );
888
+    }
889
+
890
+    /**
891
+     * Checks if the submitter has a billing email.
892
+     *
893
+     * @since 1.0.19
894
+     */
895
+    public function has_billing_email() {
896
+        $billing_email = $this->get_billing_email();
897
+        return ! empty( $billing_email ) && is_email( $billing_email );
898
+    }
899
+
900
+    /**
901
+     * Returns the appropriate currency for the submission.
902
+     *
903
+     * @since 1.0.19
904
+     * @return string
905
+     */
906
+    public function get_currency() {
907
+        return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency();
908
+    }
909
+
910
+    /**
911
+     * Returns the raw submission data.
912
+     *
913
+     * @since 1.0.19
914
+     * @return array
915
+     */
916
+    public function get_data() {
917
+        return $this->data;
918
+    }
919
+
920
+    /**
921
+     * Returns a field from the submission data
922
+     *
923
+     * @param string $field
924
+     * @since 1.0.19
925
+     * @return mixed|null
926
+     */
927
+    public function get_field( $field, $sub_array_key = null ) {
928
+        return getpaid_get_array_field( $this->data, $field, $sub_array_key );
929
+    }
930
+
931
+    /**
932
+     * Checks if a required field is set.
933
+     *
934
+     * @since 1.0.19
935
+     */
936
+    public function is_required_field_set( $field ) {
937
+        return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] );
938
+    }
939
+
940
+    /**
941
+     * Formats an amount
942
+     *
943
+     * @since 1.0.19
944
+     */
945
+    public function format_amount( $amount ) {
946
+        return wpinv_price( $amount, $this->get_currency() );
947
+    }
948 948
 
949 949
 }
Please login to merge, or discard this patch.
includes/class-wpinv.php 1 patch
Indentation   +573 added lines, -573 removed lines patch added patch discarded remove patch
@@ -14,621 +14,621 @@
 block discarded – undo
14 14
  */
15 15
 class WPInv_Plugin {
16 16
 
17
-	/**
18
-	 * GetPaid version.
19
-	 *
20
-	 * @var string
21
-	 */
22
-	public $version;
23
-
24
-	/**
25
-	 * Data container.
26
-	 *
27
-	 * @var array
28
-	 */
29
-	protected $data = array();
30
-
31
-	/**
32
-	 * Form elements instance.
33
-	 *
34
-	 * @var WPInv_Payment_Form_Elements
35
-	 */
36
-	public $form_elements;
37
-
38
-	/**
39
-	 * @var array An array of payment gateways.
40
-	 */
41
-	public $gateways;
42
-
43
-	/**
44
-	 * Class constructor.
45
-	 */
46
-	public function __construct() {
47
-		$this->define_constants();
48
-		$this->includes();
49
-		$this->init_hooks();
50
-		$this->set_properties();
51
-	}
52
-
53
-	/**
54
-	 * Sets a custom data property.
55
-	 *
56
-	 * @param string $prop The prop to set.
57
-	 * @param mixed $value The value to retrieve.
58
-	 */
59
-	public function set( $prop, $value ) {
60
-		$this->data[ $prop ] = $value;
61
-	}
62
-
63
-	/**
64
-	 * Gets a custom data property.
65
-	 *
66
-	 * @param string $prop The prop to set.
67
-	 * @return mixed The value.
68
-	 */
69
-	public function get( $prop ) {
70
-
71
-		if ( isset( $this->data[ $prop ] ) ) {
72
-			return $this->data[ $prop ];
73
-		}
74
-
75
-		return null;
76
-	}
77
-
78
-	/**
79
-	 * Define class properties.
80
-	 */
81
-	public function set_properties() {
82
-
83
-		// Sessions.
84
-		$this->set( 'session', new WPInv_Session_Handler() );
85
-		$GLOBALS['wpi_session'] = $this->get( 'session' ); // Backwards compatibility.
86
-		$GLOBALS['wpinv_euvat'] = new WPInv_EUVat(); // Backwards compatibility.
87
-
88
-		// Init other objects.
89
-		$this->set( 'session', new WPInv_Session_Handler() );
90
-		$this->set( 'notes', new WPInv_Notes() );
91
-		$this->set( 'api', new WPInv_API() );
92
-		$this->set( 'post_types', new GetPaid_Post_Types() );
93
-		$this->set( 'template', new GetPaid_Template() );
94
-		$this->set( 'admin', new GetPaid_Admin() );
95
-		$this->set( 'subscriptions', new WPInv_Subscriptions() );
96
-		$this->set( 'invoice_emails', new GetPaid_Invoice_Notification_Emails() );
97
-		$this->set( 'subscription_emails', new GetPaid_Subscription_Notification_Emails() );
98
-		$this->set( 'daily_maintenace', new GetPaid_Daily_Maintenance() );
99
-		$this->set( 'payment_forms', new GetPaid_Payment_Forms() );
100
-		$this->set( 'maxmind', new GetPaid_MaxMind_Geolocation() );
101
-
102
-	}
103
-
104
-	 /**
105
-	 * Define plugin constants.
106
-	 */
107
-	public function define_constants() {
108
-		define( 'WPINV_PLUGIN_DIR', plugin_dir_path( WPINV_PLUGIN_FILE ) );
109
-		define( 'WPINV_PLUGIN_URL', plugin_dir_url( WPINV_PLUGIN_FILE ) );
110
-		$this->version = WPINV_VERSION;
111
-	}
112
-
113
-	/**
114
-	 * Hook into actions and filters.
115
-	 *
116
-	 * @since 1.0.19
117
-	 */
118
-	protected function init_hooks() {
119
-		/* Internationalize the text strings used. */
120
-		add_action( 'plugins_loaded', array( &$this, 'plugins_loaded' ) );
121
-
122
-		// Init the plugin after WordPress inits.
123
-		add_action( 'init', array( $this, 'init' ), 1 );
124
-		add_action( 'init', array( $this, 'maybe_process_ipn' ), 10 );
125
-		add_action( 'init', array( $this, 'wpinv_actions' ) );
126
-		add_action( 'init', array( $this, 'maybe_do_authenticated_action' ), 100 );
127
-		add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 11 );
128
-		add_action( 'wp_footer', array( $this, 'wp_footer' ) );
129
-		add_action( 'wp_head', array( $this, 'wp_head' ) );
130
-		add_action( 'widgets_init', array( $this, 'register_widgets' ) );
131
-		add_filter( 'wpseo_exclude_from_sitemap_by_post_ids', array( $this, 'wpseo_exclude_from_sitemap_by_post_ids' ) );
132
-		add_filter( 'pre_get_posts', array( &$this, 'pre_get_posts' ) );
133
-
134
-		add_filter( 'query_vars', array( $this, 'custom_query_vars' ) );
17
+    /**
18
+     * GetPaid version.
19
+     *
20
+     * @var string
21
+     */
22
+    public $version;
23
+
24
+    /**
25
+     * Data container.
26
+     *
27
+     * @var array
28
+     */
29
+    protected $data = array();
30
+
31
+    /**
32
+     * Form elements instance.
33
+     *
34
+     * @var WPInv_Payment_Form_Elements
35
+     */
36
+    public $form_elements;
37
+
38
+    /**
39
+     * @var array An array of payment gateways.
40
+     */
41
+    public $gateways;
42
+
43
+    /**
44
+     * Class constructor.
45
+     */
46
+    public function __construct() {
47
+        $this->define_constants();
48
+        $this->includes();
49
+        $this->init_hooks();
50
+        $this->set_properties();
51
+    }
52
+
53
+    /**
54
+     * Sets a custom data property.
55
+     *
56
+     * @param string $prop The prop to set.
57
+     * @param mixed $value The value to retrieve.
58
+     */
59
+    public function set( $prop, $value ) {
60
+        $this->data[ $prop ] = $value;
61
+    }
62
+
63
+    /**
64
+     * Gets a custom data property.
65
+     *
66
+     * @param string $prop The prop to set.
67
+     * @return mixed The value.
68
+     */
69
+    public function get( $prop ) {
70
+
71
+        if ( isset( $this->data[ $prop ] ) ) {
72
+            return $this->data[ $prop ];
73
+        }
74
+
75
+        return null;
76
+    }
77
+
78
+    /**
79
+     * Define class properties.
80
+     */
81
+    public function set_properties() {
82
+
83
+        // Sessions.
84
+        $this->set( 'session', new WPInv_Session_Handler() );
85
+        $GLOBALS['wpi_session'] = $this->get( 'session' ); // Backwards compatibility.
86
+        $GLOBALS['wpinv_euvat'] = new WPInv_EUVat(); // Backwards compatibility.
87
+
88
+        // Init other objects.
89
+        $this->set( 'session', new WPInv_Session_Handler() );
90
+        $this->set( 'notes', new WPInv_Notes() );
91
+        $this->set( 'api', new WPInv_API() );
92
+        $this->set( 'post_types', new GetPaid_Post_Types() );
93
+        $this->set( 'template', new GetPaid_Template() );
94
+        $this->set( 'admin', new GetPaid_Admin() );
95
+        $this->set( 'subscriptions', new WPInv_Subscriptions() );
96
+        $this->set( 'invoice_emails', new GetPaid_Invoice_Notification_Emails() );
97
+        $this->set( 'subscription_emails', new GetPaid_Subscription_Notification_Emails() );
98
+        $this->set( 'daily_maintenace', new GetPaid_Daily_Maintenance() );
99
+        $this->set( 'payment_forms', new GetPaid_Payment_Forms() );
100
+        $this->set( 'maxmind', new GetPaid_MaxMind_Geolocation() );
101
+
102
+    }
103
+
104
+        /**
105
+         * Define plugin constants.
106
+         */
107
+    public function define_constants() {
108
+        define( 'WPINV_PLUGIN_DIR', plugin_dir_path( WPINV_PLUGIN_FILE ) );
109
+        define( 'WPINV_PLUGIN_URL', plugin_dir_url( WPINV_PLUGIN_FILE ) );
110
+        $this->version = WPINV_VERSION;
111
+    }
112
+
113
+    /**
114
+     * Hook into actions and filters.
115
+     *
116
+     * @since 1.0.19
117
+     */
118
+    protected function init_hooks() {
119
+        /* Internationalize the text strings used. */
120
+        add_action( 'plugins_loaded', array( &$this, 'plugins_loaded' ) );
121
+
122
+        // Init the plugin after WordPress inits.
123
+        add_action( 'init', array( $this, 'init' ), 1 );
124
+        add_action( 'init', array( $this, 'maybe_process_ipn' ), 10 );
125
+        add_action( 'init', array( $this, 'wpinv_actions' ) );
126
+        add_action( 'init', array( $this, 'maybe_do_authenticated_action' ), 100 );
127
+        add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 11 );
128
+        add_action( 'wp_footer', array( $this, 'wp_footer' ) );
129
+        add_action( 'wp_head', array( $this, 'wp_head' ) );
130
+        add_action( 'widgets_init', array( $this, 'register_widgets' ) );
131
+        add_filter( 'wpseo_exclude_from_sitemap_by_post_ids', array( $this, 'wpseo_exclude_from_sitemap_by_post_ids' ) );
132
+        add_filter( 'pre_get_posts', array( &$this, 'pre_get_posts' ) );
133
+
134
+        add_filter( 'query_vars', array( $this, 'custom_query_vars' ) );
135 135
         add_action( 'init', array( $this, 'add_rewrite_rule' ), 10, 0 );
136
-		add_action( 'pre_get_posts', array( $this, 'maybe_process_new_ipn' ), 1 );
137
-
138
-		// Fires after registering actions.
139
-		do_action( 'wpinv_actions', $this );
140
-		do_action( 'getpaid_actions', $this );
141
-
142
-	}
143
-
144
-	public function plugins_loaded() {
145
-		/* Internationalize the text strings used. */
146
-		$this->load_textdomain();
147
-
148
-		do_action( 'wpinv_loaded' );
149
-
150
-		// Fix oxygen page builder conflict
151
-		if ( function_exists( 'ct_css_output' ) ) {
152
-			wpinv_oxygen_fix_conflict();
153
-		}
154
-	}
155
-
156
-	/**
157
-	 * Load Localisation files.
158
-	 *
159
-	 * Note: the first-loaded translation file overrides any following ones if the same translation is present.
160
-	 *
161
-	 * Locales found in:
162
-	 *      - WP_LANG_DIR/plugins/invoicing-LOCALE.mo
163
-	 *      - WP_PLUGIN_DIR/invoicing/languages/invoicing-LOCALE.mo
164
-	 *
165
-	 * @since 1.0.0
166
-	 */
167
-	public function load_textdomain() {
168
-
169
-		load_plugin_textdomain(
170
-			'invoicing',
171
-			false,
172
-			plugin_basename( dirname( WPINV_PLUGIN_FILE ) ) . '/languages/'
173
-		);
174
-
175
-	}
176
-
177
-	/**
178
-	 * Include required core files used in admin and on the frontend.
179
-	 */
180
-	public function includes() {
181
-
182
-		// Start with the settings.
183
-		require_once( WPINV_PLUGIN_DIR . 'includes/admin/register-settings.php' );
184
-
185
-		// Packages/libraries.
186
-		require_once( WPINV_PLUGIN_DIR . 'vendor/autoload.php' );
187
-		require_once( WPINV_PLUGIN_DIR . 'vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php' );
188
-
189
-		// Load functions.
190
-		require_once( WPINV_PLUGIN_DIR . 'includes/deprecated-functions.php' );
191
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-email-functions.php' );
192
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-general-functions.php' );
193
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-helper-functions.php' );
194
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-tax-functions.php' );
195
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-template-functions.php' );
196
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-address-functions.php' );
197
-		require_once( WPINV_PLUGIN_DIR . 'includes/invoice-functions.php' );
198
-		require_once( WPINV_PLUGIN_DIR . 'includes/subscription-functions.php' );
199
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-item-functions.php' );
200
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-discount-functions.php' );
201
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-gateway-functions.php' );
202
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-payment-functions.php' );
203
-		require_once( WPINV_PLUGIN_DIR . 'includes/user-functions.php' );
204
-		require_once( WPINV_PLUGIN_DIR . 'includes/error-functions.php' );
205
-
206
-		// Register autoloader.
207
-		try {
208
-			spl_autoload_register( array( $this, 'autoload' ), true );
209
-		} catch ( Exception $e ) {
210
-			wpinv_error_log( $e->getMessage(), '', __FILE__, 149, true );
211
-		}
212
-
213
-		require_once( WPINV_PLUGIN_DIR . 'includes/abstracts/abstract-wpinv-session.php' );
214
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-session-handler.php' );
215
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-ajax.php' );
216
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-api.php' );
217
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-cache-helper.php' );
218
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-db.php' );
219
-		require_once( WPINV_PLUGIN_DIR . 'includes/admin/subscriptions.php' );
220
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-subscriptions-db.php' );
221
-		require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-subscription.php' );
222
-		require_once( WPINV_PLUGIN_DIR . 'includes/abstracts/abstract-wpinv-privacy.php' );
223
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-privacy.php' );
224
-		require_once( WPINV_PLUGIN_DIR . 'includes/libraries/class-ayecode-addons.php' );
225
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-addons.php' );
226
-		require_once( WPINV_PLUGIN_DIR . 'widgets/checkout.php' );
227
-		require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-history.php' );
228
-		require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-receipt.php' );
229
-		require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-messages.php' );
230
-		require_once( WPINV_PLUGIN_DIR . 'widgets/subscriptions.php' );
231
-		require_once( WPINV_PLUGIN_DIR . 'widgets/buy-item.php' );
232
-		require_once( WPINV_PLUGIN_DIR . 'widgets/getpaid.php' );
233
-		require_once( WPINV_PLUGIN_DIR . 'widgets/invoice.php' );
234
-		require_once( WPINV_PLUGIN_DIR . 'includes/admin/admin-pages.php' );
235
-
236
-		if ( is_admin() || ( defined( 'WP_CLI' ) && WP_CLI ) ) {
237
-			GetPaid_Post_Types_Admin::init();
238
-
239
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/wpinv-admin-functions.php' );
240
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/meta-boxes/class-mb-payment-form.php' );
241
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/meta-boxes/class-mb-invoice-notes.php' );
242
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-wpinv-admin-menus.php' );
243
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-wpinv-users.php' );
244
-			require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-getpaid-admin-profile.php' );
245
-			// load the user class only on the users.php page
246
-			global $pagenow;
247
-			if($pagenow=='users.php'){
248
-				new WPInv_Admin_Users();
249
-			}
250
-		}
251
-
252
-		// Register cli commands
253
-		if ( defined( 'WP_CLI' ) && WP_CLI ) {
254
-			require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-cli.php' );
255
-			WP_CLI::add_command( 'invoicing', 'WPInv_CLI' );
256
-		}
257
-
258
-	}
259
-
260
-	/**
261
-	 * Class autoloader
262
-	 *
263
-	 * @param       string $class_name The name of the class to load.
264
-	 * @access      public
265
-	 * @since       1.0.19
266
-	 * @return      void
267
-	 */
268
-	public function autoload( $class_name ) {
269
-
270
-		// Normalize the class name...
271
-		$class_name  = strtolower( $class_name );
272
-
273
-		// ... and make sure it is our class.
274
-		if ( false === strpos( $class_name, 'getpaid_' ) && false === strpos( $class_name, 'wpinv_' ) ) {
275
-			return;
276
-		}
277
-
278
-		// Next, prepare the file name from the class.
279
-		$file_name = 'class-' . str_replace( '_', '-', $class_name ) . '.php';
280
-
281
-		// Base path of the classes.
282
-		$plugin_path = untrailingslashit( WPINV_PLUGIN_DIR );
283
-
284
-		// And an array of possible locations in order of importance.
285
-		$locations = array(
286
-			"$plugin_path/includes",
287
-			"$plugin_path/includes/data-stores",
288
-			"$plugin_path/includes/gateways",
289
-			"$plugin_path/includes/payments",
290
-			"$plugin_path/includes/geolocation",
291
-			"$plugin_path/includes/reports",
292
-			"$plugin_path/includes/api",
293
-			"$plugin_path/includes/admin",
294
-			"$plugin_path/includes/admin/meta-boxes",
295
-		);
296
-
297
-		foreach ( apply_filters( 'getpaid_autoload_locations', $locations ) as $location ) {
298
-
299
-			if ( file_exists( trailingslashit( $location ) . $file_name ) ) {
300
-				include trailingslashit( $location ) . $file_name;
301
-				break;
302
-			}
303
-
304
-		}
305
-
306
-	}
307
-
308
-	/**
309
-	 * Inits hooks etc.
310
-	 */
311
-	public function init() {
312
-
313
-		// Fires before getpaid inits.
314
-		do_action( 'before_getpaid_init', $this );
315
-
316
-		// Maybe upgrade.
317
-		$this->maybe_upgrade_database();
318
-
319
-		// Load default gateways.
320
-		$gateways = apply_filters(
321
-			'getpaid_default_gateways',
322
-			array(
323
-				'manual'        => 'GetPaid_Manual_Gateway',
324
-				'paypal'        => 'GetPaid_Paypal_Gateway',
325
-				'worldpay'      => 'GetPaid_Worldpay_Gateway',
326
-				'bank_transfer' => 'GetPaid_Bank_Transfer_Gateway',
327
-				'authorizenet'  => 'GetPaid_Authorize_Net_Gateway',
328
-			)
329
-		);
330
-
331
-		foreach ( $gateways as $id => $class ) {
332
-			$this->gateways[ $id ] = new $class();
333
-		}
334
-
335
-		if ( 'yes' != get_option( 'wpinv_renamed_gateways' ) ) {
336
-			GetPaid_Installer::rename_gateways_label();
337
-			update_option( 'wpinv_renamed_gateways', 'yes' );
338
-		}
339
-
340
-		// Fires after getpaid inits.
341
-		do_action( 'getpaid_init', $this );
342
-
343
-	}
344
-
345
-	/**
346
-	 * Checks if this is an IPN request and processes it.
347
-	 */
348
-	public function maybe_process_ipn() {
349
-
350
-		// Ensure that this is an IPN request.
351
-		if ( empty( $_GET['wpi-listener'] ) || 'IPN' !== $_GET['wpi-listener'] || empty( $_GET['wpi-gateway'] ) ) {
352
-			return;
353
-		}
354
-
355
-		$gateway = sanitize_text_field( $_GET['wpi-gateway'] );
356
-
357
-		do_action( 'wpinv_verify_payment_ipn', $gateway );
358
-		do_action( "wpinv_verify_{$gateway}_ipn" );
359
-		exit;
360
-
361
-	}
362
-
363
-	public function enqueue_scripts() {
364
-
365
-		// Fires before adding scripts.
366
-		do_action( 'getpaid_enqueue_scripts' );
367
-
368
-		$localize                         = array();
369
-		$localize['ajax_url']             = admin_url( 'admin-ajax.php' );
370
-		$localize['thousands']            = wpinv_thousands_separator();
371
-		$localize['decimals']             = wpinv_decimal_separator();
372
-		$localize['nonce']                = wp_create_nonce( 'wpinv-nonce' );
373
-		$localize['txtComplete']          = __( 'Continue', 'invoicing' );
374
-		$localize['UseTaxes']             = wpinv_use_taxes();
375
-		$localize['formNonce']            = wp_create_nonce( 'getpaid_form_nonce' );
376
-		$localize['loading']              = __( 'Loading...', 'invoicing' );
377
-		$localize['connectionError']      = __( 'Could not establish a connection to the server.', 'invoicing' );
378
-
379
-		$localize = apply_filters( 'wpinv_front_js_localize', $localize );
380
-
381
-		$version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/payment-forms.js' );
382
-		wp_enqueue_script( 'wpinv-front-script', WPINV_PLUGIN_URL . 'assets/js/payment-forms.js', array( 'jquery' ),  $version, true );
383
-		wp_localize_script( 'wpinv-front-script', 'WPInv', $localize );
384
-	}
385
-
386
-	public function wpinv_actions() {
387
-		if ( isset( $_REQUEST['wpi_action'] ) ) {
388
-			do_action( 'wpinv_' . wpinv_sanitize_key( $_REQUEST['wpi_action'] ), $_REQUEST );
389
-		}
390
-
391
-		if ( defined( 'WP_ALL_IMPORT_ROOT_DIR' ) ) {
392
-			include plugin_dir_path( __FILE__ ) . 'libraries/wp-all-import/class-getpaid-wp-all-import.php';
393
-		}
394
-	}
136
+        add_action( 'pre_get_posts', array( $this, 'maybe_process_new_ipn' ), 1 );
137
+
138
+        // Fires after registering actions.
139
+        do_action( 'wpinv_actions', $this );
140
+        do_action( 'getpaid_actions', $this );
141
+
142
+    }
143
+
144
+    public function plugins_loaded() {
145
+        /* Internationalize the text strings used. */
146
+        $this->load_textdomain();
147
+
148
+        do_action( 'wpinv_loaded' );
149
+
150
+        // Fix oxygen page builder conflict
151
+        if ( function_exists( 'ct_css_output' ) ) {
152
+            wpinv_oxygen_fix_conflict();
153
+        }
154
+    }
155
+
156
+    /**
157
+     * Load Localisation files.
158
+     *
159
+     * Note: the first-loaded translation file overrides any following ones if the same translation is present.
160
+     *
161
+     * Locales found in:
162
+     *      - WP_LANG_DIR/plugins/invoicing-LOCALE.mo
163
+     *      - WP_PLUGIN_DIR/invoicing/languages/invoicing-LOCALE.mo
164
+     *
165
+     * @since 1.0.0
166
+     */
167
+    public function load_textdomain() {
168
+
169
+        load_plugin_textdomain(
170
+            'invoicing',
171
+            false,
172
+            plugin_basename( dirname( WPINV_PLUGIN_FILE ) ) . '/languages/'
173
+        );
174
+
175
+    }
176
+
177
+    /**
178
+     * Include required core files used in admin and on the frontend.
179
+     */
180
+    public function includes() {
181
+
182
+        // Start with the settings.
183
+        require_once( WPINV_PLUGIN_DIR . 'includes/admin/register-settings.php' );
184
+
185
+        // Packages/libraries.
186
+        require_once( WPINV_PLUGIN_DIR . 'vendor/autoload.php' );
187
+        require_once( WPINV_PLUGIN_DIR . 'vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php' );
188
+
189
+        // Load functions.
190
+        require_once( WPINV_PLUGIN_DIR . 'includes/deprecated-functions.php' );
191
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-email-functions.php' );
192
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-general-functions.php' );
193
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-helper-functions.php' );
194
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-tax-functions.php' );
195
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-template-functions.php' );
196
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-address-functions.php' );
197
+        require_once( WPINV_PLUGIN_DIR . 'includes/invoice-functions.php' );
198
+        require_once( WPINV_PLUGIN_DIR . 'includes/subscription-functions.php' );
199
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-item-functions.php' );
200
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-discount-functions.php' );
201
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-gateway-functions.php' );
202
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-payment-functions.php' );
203
+        require_once( WPINV_PLUGIN_DIR . 'includes/user-functions.php' );
204
+        require_once( WPINV_PLUGIN_DIR . 'includes/error-functions.php' );
205
+
206
+        // Register autoloader.
207
+        try {
208
+            spl_autoload_register( array( $this, 'autoload' ), true );
209
+        } catch ( Exception $e ) {
210
+            wpinv_error_log( $e->getMessage(), '', __FILE__, 149, true );
211
+        }
212
+
213
+        require_once( WPINV_PLUGIN_DIR . 'includes/abstracts/abstract-wpinv-session.php' );
214
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-session-handler.php' );
215
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-ajax.php' );
216
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-api.php' );
217
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-cache-helper.php' );
218
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-db.php' );
219
+        require_once( WPINV_PLUGIN_DIR . 'includes/admin/subscriptions.php' );
220
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-subscriptions-db.php' );
221
+        require_once( WPINV_PLUGIN_DIR . 'includes/wpinv-subscription.php' );
222
+        require_once( WPINV_PLUGIN_DIR . 'includes/abstracts/abstract-wpinv-privacy.php' );
223
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-privacy.php' );
224
+        require_once( WPINV_PLUGIN_DIR . 'includes/libraries/class-ayecode-addons.php' );
225
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-addons.php' );
226
+        require_once( WPINV_PLUGIN_DIR . 'widgets/checkout.php' );
227
+        require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-history.php' );
228
+        require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-receipt.php' );
229
+        require_once( WPINV_PLUGIN_DIR . 'widgets/invoice-messages.php' );
230
+        require_once( WPINV_PLUGIN_DIR . 'widgets/subscriptions.php' );
231
+        require_once( WPINV_PLUGIN_DIR . 'widgets/buy-item.php' );
232
+        require_once( WPINV_PLUGIN_DIR . 'widgets/getpaid.php' );
233
+        require_once( WPINV_PLUGIN_DIR . 'widgets/invoice.php' );
234
+        require_once( WPINV_PLUGIN_DIR . 'includes/admin/admin-pages.php' );
235
+
236
+        if ( is_admin() || ( defined( 'WP_CLI' ) && WP_CLI ) ) {
237
+            GetPaid_Post_Types_Admin::init();
238
+
239
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/wpinv-admin-functions.php' );
240
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/meta-boxes/class-mb-payment-form.php' );
241
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/meta-boxes/class-mb-invoice-notes.php' );
242
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-wpinv-admin-menus.php' );
243
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-wpinv-users.php' );
244
+            require_once( WPINV_PLUGIN_DIR . 'includes/admin/class-getpaid-admin-profile.php' );
245
+            // load the user class only on the users.php page
246
+            global $pagenow;
247
+            if($pagenow=='users.php'){
248
+                new WPInv_Admin_Users();
249
+            }
250
+        }
251
+
252
+        // Register cli commands
253
+        if ( defined( 'WP_CLI' ) && WP_CLI ) {
254
+            require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-cli.php' );
255
+            WP_CLI::add_command( 'invoicing', 'WPInv_CLI' );
256
+        }
257
+
258
+    }
259
+
260
+    /**
261
+     * Class autoloader
262
+     *
263
+     * @param       string $class_name The name of the class to load.
264
+     * @access      public
265
+     * @since       1.0.19
266
+     * @return      void
267
+     */
268
+    public function autoload( $class_name ) {
269
+
270
+        // Normalize the class name...
271
+        $class_name  = strtolower( $class_name );
272
+
273
+        // ... and make sure it is our class.
274
+        if ( false === strpos( $class_name, 'getpaid_' ) && false === strpos( $class_name, 'wpinv_' ) ) {
275
+            return;
276
+        }
277
+
278
+        // Next, prepare the file name from the class.
279
+        $file_name = 'class-' . str_replace( '_', '-', $class_name ) . '.php';
280
+
281
+        // Base path of the classes.
282
+        $plugin_path = untrailingslashit( WPINV_PLUGIN_DIR );
283
+
284
+        // And an array of possible locations in order of importance.
285
+        $locations = array(
286
+            "$plugin_path/includes",
287
+            "$plugin_path/includes/data-stores",
288
+            "$plugin_path/includes/gateways",
289
+            "$plugin_path/includes/payments",
290
+            "$plugin_path/includes/geolocation",
291
+            "$plugin_path/includes/reports",
292
+            "$plugin_path/includes/api",
293
+            "$plugin_path/includes/admin",
294
+            "$plugin_path/includes/admin/meta-boxes",
295
+        );
296
+
297
+        foreach ( apply_filters( 'getpaid_autoload_locations', $locations ) as $location ) {
298
+
299
+            if ( file_exists( trailingslashit( $location ) . $file_name ) ) {
300
+                include trailingslashit( $location ) . $file_name;
301
+                break;
302
+            }
303
+
304
+        }
305
+
306
+    }
307
+
308
+    /**
309
+     * Inits hooks etc.
310
+     */
311
+    public function init() {
312
+
313
+        // Fires before getpaid inits.
314
+        do_action( 'before_getpaid_init', $this );
315
+
316
+        // Maybe upgrade.
317
+        $this->maybe_upgrade_database();
318
+
319
+        // Load default gateways.
320
+        $gateways = apply_filters(
321
+            'getpaid_default_gateways',
322
+            array(
323
+                'manual'        => 'GetPaid_Manual_Gateway',
324
+                'paypal'        => 'GetPaid_Paypal_Gateway',
325
+                'worldpay'      => 'GetPaid_Worldpay_Gateway',
326
+                'bank_transfer' => 'GetPaid_Bank_Transfer_Gateway',
327
+                'authorizenet'  => 'GetPaid_Authorize_Net_Gateway',
328
+            )
329
+        );
330
+
331
+        foreach ( $gateways as $id => $class ) {
332
+            $this->gateways[ $id ] = new $class();
333
+        }
334
+
335
+        if ( 'yes' != get_option( 'wpinv_renamed_gateways' ) ) {
336
+            GetPaid_Installer::rename_gateways_label();
337
+            update_option( 'wpinv_renamed_gateways', 'yes' );
338
+        }
339
+
340
+        // Fires after getpaid inits.
341
+        do_action( 'getpaid_init', $this );
342
+
343
+    }
395 344
 
396
-	/**
345
+    /**
346
+     * Checks if this is an IPN request and processes it.
347
+     */
348
+    public function maybe_process_ipn() {
349
+
350
+        // Ensure that this is an IPN request.
351
+        if ( empty( $_GET['wpi-listener'] ) || 'IPN' !== $_GET['wpi-listener'] || empty( $_GET['wpi-gateway'] ) ) {
352
+            return;
353
+        }
354
+
355
+        $gateway = sanitize_text_field( $_GET['wpi-gateway'] );
356
+
357
+        do_action( 'wpinv_verify_payment_ipn', $gateway );
358
+        do_action( "wpinv_verify_{$gateway}_ipn" );
359
+        exit;
360
+
361
+    }
362
+
363
+    public function enqueue_scripts() {
364
+
365
+        // Fires before adding scripts.
366
+        do_action( 'getpaid_enqueue_scripts' );
367
+
368
+        $localize                         = array();
369
+        $localize['ajax_url']             = admin_url( 'admin-ajax.php' );
370
+        $localize['thousands']            = wpinv_thousands_separator();
371
+        $localize['decimals']             = wpinv_decimal_separator();
372
+        $localize['nonce']                = wp_create_nonce( 'wpinv-nonce' );
373
+        $localize['txtComplete']          = __( 'Continue', 'invoicing' );
374
+        $localize['UseTaxes']             = wpinv_use_taxes();
375
+        $localize['formNonce']            = wp_create_nonce( 'getpaid_form_nonce' );
376
+        $localize['loading']              = __( 'Loading...', 'invoicing' );
377
+        $localize['connectionError']      = __( 'Could not establish a connection to the server.', 'invoicing' );
378
+
379
+        $localize = apply_filters( 'wpinv_front_js_localize', $localize );
380
+
381
+        $version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/payment-forms.js' );
382
+        wp_enqueue_script( 'wpinv-front-script', WPINV_PLUGIN_URL . 'assets/js/payment-forms.js', array( 'jquery' ),  $version, true );
383
+        wp_localize_script( 'wpinv-front-script', 'WPInv', $localize );
384
+    }
385
+
386
+    public function wpinv_actions() {
387
+        if ( isset( $_REQUEST['wpi_action'] ) ) {
388
+            do_action( 'wpinv_' . wpinv_sanitize_key( $_REQUEST['wpi_action'] ), $_REQUEST );
389
+        }
390
+
391
+        if ( defined( 'WP_ALL_IMPORT_ROOT_DIR' ) ) {
392
+            include plugin_dir_path( __FILE__ ) . 'libraries/wp-all-import/class-getpaid-wp-all-import.php';
393
+        }
394
+    }
395
+
396
+    /**
397 397
      * Fires an action after verifying that a user can fire them.
398
-	 *
399
-	 * Note: If the action is on an invoice, subscription etc, esure that the
400
-	 * current user owns the invoice/subscription.
398
+     *
399
+     * Note: If the action is on an invoice, subscription etc, esure that the
400
+     * current user owns the invoice/subscription.
401 401
      */
402 402
     public function maybe_do_authenticated_action() {
403 403
 
404
-		if ( isset( $_REQUEST['getpaid-action'] ) && isset( $_REQUEST['getpaid-nonce'] ) && wp_verify_nonce( $_REQUEST['getpaid-nonce'], 'getpaid-nonce' ) ) {
404
+        if ( isset( $_REQUEST['getpaid-action'] ) && isset( $_REQUEST['getpaid-nonce'] ) && wp_verify_nonce( $_REQUEST['getpaid-nonce'], 'getpaid-nonce' ) ) {
405
+
406
+            $key  = sanitize_key( $_REQUEST['getpaid-action'] );
407
+            $data = wp_unslash( $_REQUEST );
408
+            if ( is_user_logged_in() ) {
409
+                do_action( "getpaid_authenticated_action_$key", $data );
410
+            }
411
+
412
+            do_action( "getpaid_unauthenticated_action_$key", $data );
413
+
414
+        }
415
+
416
+    }
417
+
418
+    public function pre_get_posts( $wp_query ) {
419
+
420
+        if ( ! is_admin() && ! empty( $wp_query->query_vars['post_type'] ) && getpaid_is_invoice_post_type( $wp_query->query_vars['post_type'] ) && is_user_logged_in() && is_single() && $wp_query->is_main_query() ) {
421
+            $wp_query->query_vars['post_status'] = array_keys( wpinv_get_invoice_statuses( false, false, $wp_query->query_vars['post_type'] ) );
422
+        }
423
+
424
+        return $wp_query;
425
+    }
426
+
427
+    /**
428
+     * Register widgets
429
+     *
430
+     */
431
+    public function register_widgets() {
432
+        global $pagenow;
433
+
434
+        // Currently, UX Builder does not work particulaly well with SuperDuper.
435
+        // So we disable our widgets when editing a page with UX Builder.
436
+        if ( function_exists( 'ux_builder_is_active' ) && ux_builder_is_active() ) {
437
+            return;
438
+        }
439
+
440
+        $block_widget_init_screens = function_exists('sd_pagenow_exclude') ? sd_pagenow_exclude() : array();
441
+
442
+        if ( is_admin() && $pagenow && in_array($pagenow, $block_widget_init_screens)) {
443
+            // don't initiate in these conditions.
444
+        }else{
445
+
446
+            // Only load allowed widgets.
447
+            $exclude = function_exists( 'sd_widget_exclude' ) ? sd_widget_exclude() : array();
448
+            $widgets = apply_filters(
449
+                'getpaid_widget_classes',
450
+                array(
451
+                    'WPInv_Checkout_Widget',
452
+                    'WPInv_History_Widget',
453
+                    'WPInv_Receipt_Widget',
454
+                    'WPInv_Subscriptions_Widget',
455
+                    'WPInv_Buy_Item_Widget',
456
+                    'WPInv_Messages_Widget',
457
+                    'WPInv_GetPaid_Widget',
458
+                    'WPInv_Invoice_Widget'
459
+                )
460
+            );
461
+
462
+            // For each widget...
463
+            foreach ( $widgets as $widget ) {
464
+
465
+                // Abort early if it is excluded for this page.
466
+                if ( in_array( $widget, $exclude ) ) {
467
+                    continue;
468
+                }
469
+
470
+                // SD V1 used to extend the widget class. V2 does not, so we cannot call register widget on it.
471
+                if ( is_subclass_of( $widget, 'WP_Widget' ) ) {
472
+                    register_widget( $widget );
473
+                } else {
474
+                    new $widget();
475
+                }
476
+
477
+            }
478
+
479
+        }
480
+
481
+    }
482
+
483
+    /**
484
+     * Upgrades the database.
485
+     *
486
+     * @since 2.0.2
487
+     */
488
+    public function maybe_upgrade_database() {
489
+
490
+        $wpi_version = get_option( 'wpinv_version', 0 );
491
+
492
+        if ( $wpi_version == WPINV_VERSION ) {
493
+            return;
494
+        }
495
+
496
+        $installer = new GetPaid_Installer();
497
+
498
+        if ( empty( $wpi_version ) ) {
499
+            return $installer->upgrade_db( 0 );
500
+        }
501
+
502
+        $upgrades  = array(
503
+            '0.0.5' => '004',
504
+            '1.0.3' => '102',
505
+            '2.0.0' => '118',
506
+            '2.0.8' => '207',
507
+        );
508
+
509
+        foreach ( $upgrades as $key => $method ) {
510
+
511
+            if ( version_compare( $wpi_version, $key, '<' ) ) {
512
+                return $installer->upgrade_db( $method );
513
+            }
514
+
515
+        }
405 516
 
406
-			$key  = sanitize_key( $_REQUEST['getpaid-action'] );
407
-			$data = wp_unslash( $_REQUEST );
408
-			if ( is_user_logged_in() ) {
409
-				do_action( "getpaid_authenticated_action_$key", $data );
410
-			}
517
+    }
411 518
 
412
-			do_action( "getpaid_unauthenticated_action_$key", $data );
519
+    /**
520
+     * Flushes the permalinks if needed.
521
+     *
522
+     * @since 2.0.8
523
+     */
524
+    public function maybe_flush_permalinks() {
413 525
 
414
-		}
526
+        $flush = get_option( 'wpinv_flush_permalinks', 0 );
527
+
528
+        if ( ! empty( $flush ) ) {
529
+            flush_rewrite_rules();
530
+            delete_option( 'wpinv_flush_permalinks' );
531
+        }
415 532
 
416 533
     }
417 534
 
418
-	public function pre_get_posts( $wp_query ) {
535
+    /**
536
+     * Remove our pages from yoast sitemaps.
537
+     *
538
+     * @since 1.0.19
539
+     * @param int[] $excluded_posts_ids
540
+     */
541
+    public function wpseo_exclude_from_sitemap_by_post_ids( $excluded_posts_ids ){
419 542
 
420
-		if ( ! is_admin() && ! empty( $wp_query->query_vars['post_type'] ) && getpaid_is_invoice_post_type( $wp_query->query_vars['post_type'] ) && is_user_logged_in() && is_single() && $wp_query->is_main_query() ) {
421
-			$wp_query->query_vars['post_status'] = array_keys( wpinv_get_invoice_statuses( false, false, $wp_query->query_vars['post_type'] ) );
422
-		}
423
-
424
-		return $wp_query;
425
-	}
426
-
427
-	/**
428
-	 * Register widgets
429
-	 *
430
-	 */
431
-	public function register_widgets() {
432
-		global $pagenow;
433
-
434
-		// Currently, UX Builder does not work particulaly well with SuperDuper.
435
-		// So we disable our widgets when editing a page with UX Builder.
436
-		if ( function_exists( 'ux_builder_is_active' ) && ux_builder_is_active() ) {
437
-			return;
438
-		}
439
-
440
-		$block_widget_init_screens = function_exists('sd_pagenow_exclude') ? sd_pagenow_exclude() : array();
441
-
442
-		if ( is_admin() && $pagenow && in_array($pagenow, $block_widget_init_screens)) {
443
-			// don't initiate in these conditions.
444
-		}else{
445
-
446
-			// Only load allowed widgets.
447
-			$exclude = function_exists( 'sd_widget_exclude' ) ? sd_widget_exclude() : array();
448
-			$widgets = apply_filters(
449
-				'getpaid_widget_classes',
450
-				array(
451
-					'WPInv_Checkout_Widget',
452
-					'WPInv_History_Widget',
453
-					'WPInv_Receipt_Widget',
454
-					'WPInv_Subscriptions_Widget',
455
-					'WPInv_Buy_Item_Widget',
456
-					'WPInv_Messages_Widget',
457
-					'WPInv_GetPaid_Widget',
458
-					'WPInv_Invoice_Widget'
459
-				)
460
-			);
461
-
462
-			// For each widget...
463
-			foreach ( $widgets as $widget ) {
464
-
465
-				// Abort early if it is excluded for this page.
466
-				if ( in_array( $widget, $exclude ) ) {
467
-					continue;
468
-				}
543
+        // Ensure that we have an array.
544
+        if ( ! is_array( $excluded_posts_ids ) ) {
545
+            $excluded_posts_ids = array();
546
+        }
469 547
 
470
-				// SD V1 used to extend the widget class. V2 does not, so we cannot call register widget on it.
471
-				if ( is_subclass_of( $widget, 'WP_Widget' ) ) {
472
-					register_widget( $widget );
473
-				} else {
474
-					new $widget();
475
-				}
548
+        // Prepare our pages.
549
+        $our_pages = array();
476 550
 
477
-			}
551
+        // Checkout page.
552
+        $our_pages[] = wpinv_get_option( 'checkout_page', false );
478 553
 
479
-		}
480
-
481
-	}
554
+        // Success page.
555
+        $our_pages[] = wpinv_get_option( 'success_page', false );
482 556
 
483
-	/**
484
-	 * Upgrades the database.
485
-	 *
486
-	 * @since 2.0.2
487
-	 */
488
-	public function maybe_upgrade_database() {
489
-
490
-		$wpi_version = get_option( 'wpinv_version', 0 );
491
-
492
-		if ( $wpi_version == WPINV_VERSION ) {
493
-			return;
494
-		}
495
-
496
-		$installer = new GetPaid_Installer();
497
-
498
-		if ( empty( $wpi_version ) ) {
499
-			return $installer->upgrade_db( 0 );
500
-		}
501
-
502
-		$upgrades  = array(
503
-			'0.0.5' => '004',
504
-			'1.0.3' => '102',
505
-			'2.0.0' => '118',
506
-			'2.0.8' => '207',
507
-		);
508
-
509
-		foreach ( $upgrades as $key => $method ) {
510
-
511
-			if ( version_compare( $wpi_version, $key, '<' ) ) {
512
-				return $installer->upgrade_db( $method );
513
-			}
514
-
515
-		}
516
-
517
-	}
518
-
519
-	/**
520
-	 * Flushes the permalinks if needed.
521
-	 *
522
-	 * @since 2.0.8
523
-	 */
524
-	public function maybe_flush_permalinks() {
525
-
526
-		$flush = get_option( 'wpinv_flush_permalinks', 0 );
527
-
528
-		if ( ! empty( $flush ) ) {
529
-			flush_rewrite_rules();
530
-			delete_option( 'wpinv_flush_permalinks' );
531
-		}
532
-
533
-	}
534
-
535
-	/**
536
-	 * Remove our pages from yoast sitemaps.
537
-	 *
538
-	 * @since 1.0.19
539
-	 * @param int[] $excluded_posts_ids
540
-	 */
541
-	public function wpseo_exclude_from_sitemap_by_post_ids( $excluded_posts_ids ){
542
-
543
-		// Ensure that we have an array.
544
-		if ( ! is_array( $excluded_posts_ids ) ) {
545
-			$excluded_posts_ids = array();
546
-		}
547
-
548
-		// Prepare our pages.
549
-		$our_pages = array();
550
-
551
-		// Checkout page.
552
-		$our_pages[] = wpinv_get_option( 'checkout_page', false );
553
-
554
-		// Success page.
555
-		$our_pages[] = wpinv_get_option( 'success_page', false );
556
-
557
-		// Failure page.
558
-		$our_pages[] = wpinv_get_option( 'failure_page', false );
557
+        // Failure page.
558
+        $our_pages[] = wpinv_get_option( 'failure_page', false );
559 559
 
560
-		// History page.
561
-		$our_pages[] = wpinv_get_option( 'invoice_history_page', false );
560
+        // History page.
561
+        $our_pages[] = wpinv_get_option( 'invoice_history_page', false );
562 562
 
563
-		// Subscriptions page.
564
-		$our_pages[] = wpinv_get_option( 'invoice_subscription_page', false );
563
+        // Subscriptions page.
564
+        $our_pages[] = wpinv_get_option( 'invoice_subscription_page', false );
565 565
 
566
-		$our_pages   = array_map( 'intval', array_filter( $our_pages ) );
566
+        $our_pages   = array_map( 'intval', array_filter( $our_pages ) );
567 567
 
568
-		$excluded_posts_ids = $excluded_posts_ids + $our_pages;
569
-		return array_unique( $excluded_posts_ids );
568
+        $excluded_posts_ids = $excluded_posts_ids + $our_pages;
569
+        return array_unique( $excluded_posts_ids );
570 570
 
571
-	}
571
+    }
572 572
 
573
-	/**
574
-	 * Displays additional footer code.
575
-	 *
576
-	 * @since 2.0.0
577
-	 */
578
-	public function wp_footer() {
579
-		wpinv_get_template( 'frontend-footer.php' );
580
-	}
573
+    /**
574
+     * Displays additional footer code.
575
+     *
576
+     * @since 2.0.0
577
+     */
578
+    public function wp_footer() {
579
+        wpinv_get_template( 'frontend-footer.php' );
580
+    }
581 581
 
582
-	/**
583
-	 * Displays additional header code.
584
-	 *
585
-	 * @since 2.0.0
586
-	 */
587
-	public function wp_head() {
588
-		wpinv_get_template( 'frontend-head.php' );
589
-	}
582
+    /**
583
+     * Displays additional header code.
584
+     *
585
+     * @since 2.0.0
586
+     */
587
+    public function wp_head() {
588
+        wpinv_get_template( 'frontend-head.php' );
589
+    }
590 590
 
591
-	/**
592
-	 * Custom query vars.
593
-	 *
594
-	 */
595
-	public function custom_query_vars( $vars ) {
591
+    /**
592
+     * Custom query vars.
593
+     *
594
+     */
595
+    public function custom_query_vars( $vars ) {
596 596
         $vars[] = 'getpaid-ipn';
597 597
         return $vars;
598
-	}
598
+    }
599 599
 
600
-	/**
601
-	 * Add rewrite tags and rules.
602
-	 *
603
-	 */
604
-	public function add_rewrite_rule() {
600
+    /**
601
+     * Add rewrite tags and rules.
602
+     *
603
+     */
604
+    public function add_rewrite_rule() {
605 605
         $tag = 'getpaid-ipn';
606 606
         add_rewrite_tag( "%$tag%", '([^&]+)' );
607 607
         add_rewrite_rule( "^$tag/([^/]*)/?", "index.php?$tag=\$matches[1]",'top' );
608
-	}
608
+    }
609 609
 
610
-	/**
611
-	 * Processes non-query string ipns.
612
-	 *
613
-	 */
614
-	public function maybe_process_new_ipn( $query ) {
610
+    /**
611
+     * Processes non-query string ipns.
612
+     *
613
+     */
614
+    public function maybe_process_new_ipn( $query ) {
615 615
 
616 616
         if ( is_admin() || ! $query->is_main_query() ) {
617 617
             return;
618 618
         }
619 619
 
620
-		$gateway = get_query_var( 'getpaid-ipn' );
620
+        $gateway = get_query_var( 'getpaid-ipn' );
621 621
 
622 622
         if ( ! empty( $gateway ) ){
623 623
 
624
-			$gateway = sanitize_text_field( $gateway );
625
-			nocache_headers();
626
-			do_action( 'wpinv_verify_payment_ipn', $gateway );
627
-			do_action( "wpinv_verify_{$gateway}_ipn" );
628
-			exit;
624
+            $gateway = sanitize_text_field( $gateway );
625
+            nocache_headers();
626
+            do_action( 'wpinv_verify_payment_ipn', $gateway );
627
+            do_action( "wpinv_verify_{$gateway}_ipn" );
628
+            exit;
629 629
 
630 630
         }
631 631
 
632
-	}
632
+    }
633 633
 
634 634
 }
Please login to merge, or discard this patch.
includes/class-wpinv-ajax.php 1 patch
Indentation   +66 added lines, -66 removed lines patch added patch discarded remove patch
@@ -14,70 +14,70 @@  discard block
 block discarded – undo
14 14
 class WPInv_Ajax {
15 15
 
16 16
     /**
17
-	 * Hook in ajax handlers.
18
-	 */
19
-	public static function init() {
20
-		add_action( 'init', array( __CLASS__, 'define_ajax' ), 0 );
21
-		add_action( 'template_redirect', array( __CLASS__, 'do_wpinv_ajax' ), 0 );
22
-		self::add_ajax_events();
17
+     * Hook in ajax handlers.
18
+     */
19
+    public static function init() {
20
+        add_action( 'init', array( __CLASS__, 'define_ajax' ), 0 );
21
+        add_action( 'template_redirect', array( __CLASS__, 'do_wpinv_ajax' ), 0 );
22
+        self::add_ajax_events();
23 23
     }
24 24
 
25 25
     /**
26
-	 * Set GetPaid AJAX constant and headers.
27
-	 */
28
-	public static function define_ajax() {
29
-
30
-		if ( ! empty( $_GET['wpinv-ajax'] ) ) {
31
-			getpaid_maybe_define_constant( 'DOING_AJAX', true );
32
-			getpaid_maybe_define_constant( 'WPInv_DOING_AJAX', true );
33
-			if ( ! WP_DEBUG || ( WP_DEBUG && ! WP_DEBUG_DISPLAY ) ) {
34
-				/** @scrutinizer ignore-unhandled */ @ini_set( 'display_errors', 0 );
35
-			}
36
-			$GLOBALS['wpdb']->hide_errors();
37
-		}
26
+     * Set GetPaid AJAX constant and headers.
27
+     */
28
+    public static function define_ajax() {
29
+
30
+        if ( ! empty( $_GET['wpinv-ajax'] ) ) {
31
+            getpaid_maybe_define_constant( 'DOING_AJAX', true );
32
+            getpaid_maybe_define_constant( 'WPInv_DOING_AJAX', true );
33
+            if ( ! WP_DEBUG || ( WP_DEBUG && ! WP_DEBUG_DISPLAY ) ) {
34
+                /** @scrutinizer ignore-unhandled */ @ini_set( 'display_errors', 0 );
35
+            }
36
+            $GLOBALS['wpdb']->hide_errors();
37
+        }
38 38
 
39 39
     }
40 40
     
41 41
     /**
42
-	 * Send headers for GetPaid Ajax Requests.
43
-	 *
44
-	 * @since 1.0.18
45
-	 */
46
-	private static function wpinv_ajax_headers() {
47
-		if ( ! headers_sent() ) {
48
-			send_origin_headers();
49
-			send_nosniff_header();
50
-			nocache_headers();
51
-			header( 'Content-Type: text/html; charset=' . get_option( 'blog_charset' ) );
52
-			header( 'X-Robots-Tag: noindex' );
53
-			status_header( 200 );
54
-		}
42
+     * Send headers for GetPaid Ajax Requests.
43
+     *
44
+     * @since 1.0.18
45
+     */
46
+    private static function wpinv_ajax_headers() {
47
+        if ( ! headers_sent() ) {
48
+            send_origin_headers();
49
+            send_nosniff_header();
50
+            nocache_headers();
51
+            header( 'Content-Type: text/html; charset=' . get_option( 'blog_charset' ) );
52
+            header( 'X-Robots-Tag: noindex' );
53
+            status_header( 200 );
54
+        }
55 55
     }
56 56
     
57 57
     /**
58
-	 * Check for GetPaid Ajax request and fire action.
59
-	 */
60
-	public static function do_wpinv_ajax() {
61
-		global $wp_query;
58
+     * Check for GetPaid Ajax request and fire action.
59
+     */
60
+    public static function do_wpinv_ajax() {
61
+        global $wp_query;
62 62
 
63
-		if ( ! empty( $_GET['wpinv-ajax'] ) ) {
64
-			$wp_query->set( 'wpinv-ajax', sanitize_text_field( wp_unslash( $_GET['wpinv-ajax'] ) ) );
65
-		}
63
+        if ( ! empty( $_GET['wpinv-ajax'] ) ) {
64
+            $wp_query->set( 'wpinv-ajax', sanitize_text_field( wp_unslash( $_GET['wpinv-ajax'] ) ) );
65
+        }
66 66
 
67
-		$action = $wp_query->get( 'wpinv-ajax' );
67
+        $action = $wp_query->get( 'wpinv-ajax' );
68 68
 
69
-		if ( $action ) {
70
-			self::wpinv_ajax_headers();
71
-			$action = sanitize_text_field( $action );
72
-			do_action( 'wpinv_ajax_' . $action );
73
-			wp_die();
74
-		}
69
+        if ( $action ) {
70
+            self::wpinv_ajax_headers();
71
+            $action = sanitize_text_field( $action );
72
+            do_action( 'wpinv_ajax_' . $action );
73
+            wp_die();
74
+        }
75 75
 
76 76
     }
77 77
 
78 78
     /**
79
-	 * Hook in ajax methods.
80
-	 */
79
+     * Hook in ajax methods.
80
+     */
81 81
     public static function add_ajax_events() {
82 82
 
83 83
         // array( 'event' => is_frontend )
@@ -261,18 +261,18 @@  discard block
 block discarded – undo
261 261
         check_ajax_referer( 'getpaid_form_nonce' );
262 262
 
263 263
         // Is the request set up correctly?
264
-		if ( empty( $_GET['form'] ) && empty( $_GET['item'] ) && empty( $_GET['invoice'] ) ) {
265
-			echo aui()->alert(
266
-				array(
267
-					'type'    => 'warning',
268
-					'content' => __( 'No payment form or item provided', 'invoicing' ),
269
-				)
264
+        if ( empty( $_GET['form'] ) && empty( $_GET['item'] ) && empty( $_GET['invoice'] ) ) {
265
+            echo aui()->alert(
266
+                array(
267
+                    'type'    => 'warning',
268
+                    'content' => __( 'No payment form or item provided', 'invoicing' ),
269
+                )
270 270
             );
271 271
             exit;
272 272
         }
273 273
 
274 274
         // Payment form or button?
275
-		if ( ! empty( $_GET['form'] ) ) {
275
+        if ( ! empty( $_GET['form'] ) ) {
276 276
             $form = sanitize_text_field( urldecode( $_GET['form'] ) );
277 277
 
278 278
             if ( false !== strpos( $form, '|' ) ) {
@@ -326,11 +326,11 @@  discard block
 block discarded – undo
326 326
                 getpaid_display_payment_form( $form );
327 327
             }
328 328
 
329
-		} else if( ! empty( $_GET['invoice'] ) ) {
330
-		    getpaid_display_invoice_payment_form( (int) urldecode( $_GET['invoice'] ) );
329
+        } else if( ! empty( $_GET['invoice'] ) ) {
330
+            getpaid_display_invoice_payment_form( (int) urldecode( $_GET['invoice'] ) );
331 331
         } else {
332
-			$items = getpaid_convert_items_to_array( sanitize_text_field( urldecode( $_GET['item'] ) ) );
333
-		    getpaid_display_item_payment_form( $items );
332
+            $items = getpaid_convert_items_to_array( sanitize_text_field( urldecode( $_GET['item'] ) ) );
333
+            getpaid_display_item_payment_form( $items );
334 334
         }
335 335
 
336 336
         exit;
@@ -651,7 +651,7 @@  discard block
 block discarded – undo
651 651
         if ( is_wp_error( $error ) ) {
652 652
             $alert = $error->get_error_message();
653 653
             wp_send_json_success( compact( 'alert' ) );
654
-         }
654
+            }
655 655
 
656 656
         // Update totals.
657 657
         $invoice->recalculate_total();
@@ -1089,12 +1089,12 @@  discard block
 block discarded – undo
1089 1089
     }
1090 1090
 
1091 1091
     /**
1092
-	 * Handles file uploads.
1093
-	 *
1094
-	 * @since       1.0.0
1095
-	 * @return      void
1096
-	 */
1097
-	public static function file_upload() {
1092
+     * Handles file uploads.
1093
+     *
1094
+     * @since       1.0.0
1095
+     * @return      void
1096
+     */
1097
+    public static function file_upload() {
1098 1098
 
1099 1099
         // Check nonce.
1100 1100
         check_ajax_referer( 'getpaid_form_nonce' );
@@ -1155,7 +1155,7 @@  discard block
 block discarded – undo
1155 1155
 
1156 1156
         wp_send_json_success( $response );
1157 1157
 
1158
-	}
1158
+    }
1159 1159
 
1160 1160
 }
1161 1161
 
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +2049 added lines, -2049 removed lines patch added patch discarded remove patch
@@ -1,268 +1,268 @@  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.29";
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
-				/* Load script on Divi theme builder page */
96
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
97
-					add_thickbox();
98
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
99
-				}
100
-
101
-				if ( $this->is_preview() ) {
102
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
103
-					// this makes the insert button work for elementor
104
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
105
-						$this,
106
-						'shortcode_insert_button_script'
107
-					) ); // for elementor
108
-				}
109
-				// this makes the insert button work for cornerstone
110
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
111
-
112
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
113
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
114
-
115
-				// add generator text to admin head
116
-				add_action( 'admin_head', array( $this, 'generator' ) );
117
-			}
118
-
119
-			do_action( 'wp_super_duper_widget_init', $options, $this );
120
-		}
121
-
122
-		/**
123
-		 * Add our widget CSS to elementor editor.
124
-		 */
125
-		public function elementor_editor_styles() {
126
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
127
-		}
128
-
129
-		public function register_fusion_element() {
130
-
131
-			$options = $this->options;
132
-
133
-			if ( $this->base_id ) {
134
-
135
-				$params = $this->get_fusion_params();
136
-
137
-				$args = array(
138
-					'name'            => $options['name'],
139
-					'shortcode'       => $this->base_id,
140
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
141
-					'allow_generator' => true,
142
-				);
143
-
144
-				if ( ! empty( $params ) ) {
145
-					$args['params'] = $params;
146
-				}
147
-
148
-				fusion_builder_map( $args );
149
-			}
150
-
151
-		}
152
-
153
-		public function get_fusion_params() {
154
-			$params    = array();
155
-			$arguments = $this->get_arguments();
156
-
157
-			if ( ! empty( $arguments ) ) {
158
-				foreach ( $arguments as $key => $val ) {
159
-					$param = array();
160
-					// type
161
-					$param['type'] = str_replace(
162
-						array(
163
-							"text",
164
-							"number",
165
-							"email",
166
-							"color",
167
-							"checkbox"
168
-						),
169
-						array(
170
-							"textfield",
171
-							"textfield",
172
-							"textfield",
173
-							"colorpicker",
174
-							"select",
175
-
176
-						),
177
-						$val['type'] );
178
-
179
-					// multiselect
180
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
181
-						$param['type']     = 'multiple_select';
182
-						$param['multiple'] = true;
183
-					}
184
-
185
-					// heading
186
-					$param['heading'] = $val['title'];
187
-
188
-					// description
189
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
190
-
191
-					// param_name
192
-					$param['param_name'] = $key;
193
-
194
-					// Default
195
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
196
-
197
-					// Group
198
-					if ( isset( $val['group'] ) ) {
199
-						$param['group'] = $val['group'];
200
-					}
201
-
202
-					// value
203
-					if ( $val['type'] == 'checkbox' ) {
204
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
205
-							unset( $param['default'] );
206
-						}
207
-						$param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
208
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
209
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
210
-					} else {
211
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
212
-					}
213
-
214
-					// setup the param
215
-					$params[] = $param;
216
-
217
-				}
218
-			}
219
-
220
-
221
-			return $params;
222
-		}
223
-
224
-		/**
225
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
226
-		 */
227
-		public static function maybe_cornerstone_builder() {
228
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
229
-				self::shortcode_insert_button_script();
230
-			}
231
-		}
232
-
233
-		/**
234
-		 * A function to ge the shortcode builder picker html.
235
-		 *
236
-		 * @param string $editor_id
237
-		 *
238
-		 * @return string
239
-		 */
240
-		public static function get_picker( $editor_id = '' ) {
241
-
242
-			ob_start();
243
-			if ( isset( $_POST['editor_id'] ) ) {
244
-				$editor_id = sanitize_text_field( $_POST['editor_id'] );
245
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
246
-				$editor_id = 'main_content_content_vb_tiny_mce';
247
-			}
248
-
249
-			global $sd_widgets;
250
-			?>
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.29";
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
+                /* Load script on Divi theme builder page */
96
+                if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
97
+                    add_thickbox();
98
+                    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
99
+                }
100
+
101
+                if ( $this->is_preview() ) {
102
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
103
+                    // this makes the insert button work for elementor
104
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
105
+                        $this,
106
+                        'shortcode_insert_button_script'
107
+                    ) ); // for elementor
108
+                }
109
+                // this makes the insert button work for cornerstone
110
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
111
+
112
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
113
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
114
+
115
+                // add generator text to admin head
116
+                add_action( 'admin_head', array( $this, 'generator' ) );
117
+            }
118
+
119
+            do_action( 'wp_super_duper_widget_init', $options, $this );
120
+        }
121
+
122
+        /**
123
+         * Add our widget CSS to elementor editor.
124
+         */
125
+        public function elementor_editor_styles() {
126
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
127
+        }
128
+
129
+        public function register_fusion_element() {
130
+
131
+            $options = $this->options;
132
+
133
+            if ( $this->base_id ) {
134
+
135
+                $params = $this->get_fusion_params();
136
+
137
+                $args = array(
138
+                    'name'            => $options['name'],
139
+                    'shortcode'       => $this->base_id,
140
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
141
+                    'allow_generator' => true,
142
+                );
143
+
144
+                if ( ! empty( $params ) ) {
145
+                    $args['params'] = $params;
146
+                }
147
+
148
+                fusion_builder_map( $args );
149
+            }
150
+
151
+        }
152
+
153
+        public function get_fusion_params() {
154
+            $params    = array();
155
+            $arguments = $this->get_arguments();
156
+
157
+            if ( ! empty( $arguments ) ) {
158
+                foreach ( $arguments as $key => $val ) {
159
+                    $param = array();
160
+                    // type
161
+                    $param['type'] = str_replace(
162
+                        array(
163
+                            "text",
164
+                            "number",
165
+                            "email",
166
+                            "color",
167
+                            "checkbox"
168
+                        ),
169
+                        array(
170
+                            "textfield",
171
+                            "textfield",
172
+                            "textfield",
173
+                            "colorpicker",
174
+                            "select",
175
+
176
+                        ),
177
+                        $val['type'] );
178
+
179
+                    // multiselect
180
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
181
+                        $param['type']     = 'multiple_select';
182
+                        $param['multiple'] = true;
183
+                    }
184
+
185
+                    // heading
186
+                    $param['heading'] = $val['title'];
187
+
188
+                    // description
189
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
190
+
191
+                    // param_name
192
+                    $param['param_name'] = $key;
193
+
194
+                    // Default
195
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
196
+
197
+                    // Group
198
+                    if ( isset( $val['group'] ) ) {
199
+                        $param['group'] = $val['group'];
200
+                    }
201
+
202
+                    // value
203
+                    if ( $val['type'] == 'checkbox' ) {
204
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
205
+                            unset( $param['default'] );
206
+                        }
207
+                        $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
208
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
209
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
210
+                    } else {
211
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
212
+                    }
213
+
214
+                    // setup the param
215
+                    $params[] = $param;
216
+
217
+                }
218
+            }
219
+
220
+
221
+            return $params;
222
+        }
223
+
224
+        /**
225
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
226
+         */
227
+        public static function maybe_cornerstone_builder() {
228
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
229
+                self::shortcode_insert_button_script();
230
+            }
231
+        }
232
+
233
+        /**
234
+         * A function to ge the shortcode builder picker html.
235
+         *
236
+         * @param string $editor_id
237
+         *
238
+         * @return string
239
+         */
240
+        public static function get_picker( $editor_id = '' ) {
241
+
242
+            ob_start();
243
+            if ( isset( $_POST['editor_id'] ) ) {
244
+                $editor_id = sanitize_text_field( $_POST['editor_id'] );
245
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
246
+                $editor_id = 'main_content_content_vb_tiny_mce';
247
+            }
248
+
249
+            global $sd_widgets;
250
+            ?>
251 251
 
252 252
 			<div class="sd-shortcode-left-wrap">
253 253
 				<?php
254
-				ksort( $sd_widgets );
255
-				//				print_r($sd_widgets);exit;
256
-				if ( ! empty( $sd_widgets ) ) {
257
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
258
-					echo "<option>" . __( 'Select shortcode' ) . "</option>";
259
-					foreach ( $sd_widgets as $shortcode => $class ) {
260
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
261
-					}
262
-					echo "</select>";
263
-
264
-				}
265
-				?>
254
+                ksort( $sd_widgets );
255
+                //				print_r($sd_widgets);exit;
256
+                if ( ! empty( $sd_widgets ) ) {
257
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
258
+                    echo "<option>" . __( 'Select shortcode' ) . "</option>";
259
+                    foreach ( $sd_widgets as $shortcode => $class ) {
260
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
261
+                    }
262
+                    echo "</select>";
263
+
264
+                }
265
+                ?>
266 266
 				<div class="sd-shortcode-settings"></div>
267 267
 
268 268
 			</div>
@@ -273,8 +273,8 @@  discard block
 block discarded – undo
273 273
 					<?php if ( $editor_id != '' ) { ?>
274 274
 						<button class="button sd-insert-shortcode-button"
275 275
 						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
276
-							        echo "'" . $editor_id . "'";
277
-						        } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
276
+                                    echo "'" . $editor_id . "'";
277
+                                } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
278 278
 					<?php } ?>
279 279
 					<button class="button"
280 280
 					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -282,134 +282,134 @@  discard block
 block discarded – undo
282 282
 			</div>
283 283
 			<?php
284 284
 
285
-			$html = ob_get_clean();
286
-
287
-			if ( wp_doing_ajax() ) {
288
-				echo $html;
289
-				$should_die = true;
290
-
291
-				// some builder get the editor via ajax so we should not die on those occasions
292
-				$dont_die = array(
293
-					'parent_tag',// WP Bakery
294
-					'avia_request' // enfold
295
-				);
296
-
297
-				foreach ( $dont_die as $request ) {
298
-					if ( isset( $_REQUEST[ $request ] ) ) {
299
-						$should_die = false;
300
-					}
301
-				}
302
-
303
-				if ( $should_die ) {
304
-					wp_die();
305
-				}
306
-
307
-			} else {
308
-				return $html;
309
-			}
310
-
311
-			return '';
312
-
313
-		}
314
-
315
-		/**
316
-		 * Output the version in the admin header.
317
-		 */
318
-		public function generator() {
319
-			echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
320
-		}
321
-
322
-		/**
323
-		 * Get widget settings.
324
-		 *
325
-		 * @since 1.0.0
326
-		 */
327
-		public static function get_widget_settings() {
328
-			global $sd_widgets;
329
-
330
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
331
-			if ( ! $shortcode ) {
332
-				wp_die();
333
-			}
334
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
335
-			if ( ! $widget_args ) {
336
-				wp_die();
337
-			}
338
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
339
-			if ( ! $class_name ) {
340
-				wp_die();
341
-			}
342
-
343
-			// invoke an instance method
344
-			$widget = new $class_name;
345
-
346
-			ob_start();
347
-			$widget->form( array() );
348
-			$form = ob_get_clean();
349
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
350
-			echo "<style>" . $widget->widget_css() . "</style>";
351
-			echo "<script>" . $widget->widget_js() . "</script>";
352
-			?>
285
+            $html = ob_get_clean();
286
+
287
+            if ( wp_doing_ajax() ) {
288
+                echo $html;
289
+                $should_die = true;
290
+
291
+                // some builder get the editor via ajax so we should not die on those occasions
292
+                $dont_die = array(
293
+                    'parent_tag',// WP Bakery
294
+                    'avia_request' // enfold
295
+                );
296
+
297
+                foreach ( $dont_die as $request ) {
298
+                    if ( isset( $_REQUEST[ $request ] ) ) {
299
+                        $should_die = false;
300
+                    }
301
+                }
302
+
303
+                if ( $should_die ) {
304
+                    wp_die();
305
+                }
306
+
307
+            } else {
308
+                return $html;
309
+            }
310
+
311
+            return '';
312
+
313
+        }
314
+
315
+        /**
316
+         * Output the version in the admin header.
317
+         */
318
+        public function generator() {
319
+            echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
320
+        }
321
+
322
+        /**
323
+         * Get widget settings.
324
+         *
325
+         * @since 1.0.0
326
+         */
327
+        public static function get_widget_settings() {
328
+            global $sd_widgets;
329
+
330
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
331
+            if ( ! $shortcode ) {
332
+                wp_die();
333
+            }
334
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
335
+            if ( ! $widget_args ) {
336
+                wp_die();
337
+            }
338
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
339
+            if ( ! $class_name ) {
340
+                wp_die();
341
+            }
342
+
343
+            // invoke an instance method
344
+            $widget = new $class_name;
345
+
346
+            ob_start();
347
+            $widget->form( array() );
348
+            $form = ob_get_clean();
349
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
350
+            echo "<style>" . $widget->widget_css() . "</style>";
351
+            echo "<script>" . $widget->widget_js() . "</script>";
352
+            ?>
353 353
 			<?php
354
-			wp_die();
355
-		}
356
-
357
-		/**
358
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
359
-		 *
360
-		 * @since 1.0.0
361
-		 *
362
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
363
-		 * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
364
-		 */
365
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
366
-			global $sd_widgets, $shortcode_insert_button_once;
367
-			if ( $shortcode_insert_button_once ) {
368
-				return;
369
-			}
370
-			add_thickbox();
371
-
372
-
373
-			/**
374
-			 * Cornerstone makes us play dirty tricks :/
375
-			 * 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.
376
-			 */
377
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
378
-				echo '<span id="insert-media-button">';
379
-			}
380
-
381
-			echo self::shortcode_button( 'this', 'true' );
382
-
383
-			// see opening note
384
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
385
-				echo '</span>'; // end #insert-media-button
386
-			}
387
-
388
-			// Add separate script for generatepress theme sections
389
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
390
-			} else {
391
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
392
-			}
393
-
394
-			$shortcode_insert_button_once = true;
395
-		}
396
-
397
-		/**
398
-		 * Gets the shortcode insert button html.
399
-		 *
400
-		 * @param string $id
401
-		 * @param string $search_for_id
402
-		 *
403
-		 * @return mixed
404
-		 */
405
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
406
-			ob_start();
407
-			?>
354
+            wp_die();
355
+        }
356
+
357
+        /**
358
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
359
+         *
360
+         * @since 1.0.0
361
+         *
362
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
363
+         * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
364
+         */
365
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
366
+            global $sd_widgets, $shortcode_insert_button_once;
367
+            if ( $shortcode_insert_button_once ) {
368
+                return;
369
+            }
370
+            add_thickbox();
371
+
372
+
373
+            /**
374
+             * Cornerstone makes us play dirty tricks :/
375
+             * 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.
376
+             */
377
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
378
+                echo '<span id="insert-media-button">';
379
+            }
380
+
381
+            echo self::shortcode_button( 'this', 'true' );
382
+
383
+            // see opening note
384
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
385
+                echo '</span>'; // end #insert-media-button
386
+            }
387
+
388
+            // Add separate script for generatepress theme sections
389
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
390
+            } else {
391
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
392
+            }
393
+
394
+            $shortcode_insert_button_once = true;
395
+        }
396
+
397
+        /**
398
+         * Gets the shortcode insert button html.
399
+         *
400
+         * @param string $id
401
+         * @param string $search_for_id
402
+         *
403
+         * @return mixed
404
+         */
405
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
406
+            ob_start();
407
+            ?>
408 408
 			<span class="sd-lable-shortcode-inserter">
409 409
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
410
-				if ( $search_for_id ) {
411
-					echo "," . $search_for_id;
412
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
410
+                if ( $search_for_id ) {
411
+                    echo "," . $search_for_id;
412
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
413 413
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
414 414
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
415 415
 					      class="dashicons dashicons-screenoptions"></span>
@@ -420,21 +420,21 @@  discard block
 block discarded – undo
420 420
 			</span>
421 421
 
422 422
 			<?php
423
-			$html = ob_get_clean();
424
-
425
-			// remove line breaks so we can use it in js
426
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
427
-		}
428
-
429
-		/**
430
-		 * Makes SD work with the siteOrigin page builder.
431
-		 *
432
-		 * @since 1.0.6
433
-		 * @return mixed
434
-		 */
435
-		public static function siteorigin_js() {
436
-			ob_start();
437
-			?>
423
+            $html = ob_get_clean();
424
+
425
+            // remove line breaks so we can use it in js
426
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
427
+        }
428
+
429
+        /**
430
+         * Makes SD work with the siteOrigin page builder.
431
+         *
432
+         * @since 1.0.6
433
+         * @return mixed
434
+         */
435
+        public static function siteorigin_js() {
436
+            ob_start();
437
+            ?>
438 438
 			<script>
439 439
 				/**
440 440
 				 * Check a form to see what items should be shown or hidden.
@@ -512,28 +512,28 @@  discard block
 block discarded – undo
512 512
 				});
513 513
 			</script>
514 514
 			<?php
515
-			$output = ob_get_clean();
515
+            $output = ob_get_clean();
516 516
 
517
-			/*
517
+            /*
518 518
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
519 519
 			 */
520 520
 
521
-			return str_replace( array(
522
-				'<script>',
523
-				'</script>'
524
-			), '', $output );
525
-		}
526
-
527
-		/**
528
-		 * Output the JS and CSS for the shortcode insert button.
529
-		 *
530
-		 * @since 1.0.6
531
-		 *
532
-		 * @param string $editor_id
533
-		 * @param string $insert_shortcode_function
534
-		 */
535
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
536
-			?>
521
+            return str_replace( array(
522
+                '<script>',
523
+                '</script>'
524
+            ), '', $output );
525
+        }
526
+
527
+        /**
528
+         * Output the JS and CSS for the shortcode insert button.
529
+         *
530
+         * @since 1.0.6
531
+         *
532
+         * @param string $editor_id
533
+         * @param string $insert_shortcode_function
534
+         */
535
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
536
+            ?>
537 537
 			<style>
538 538
 				.sd-shortcode-left-wrap {
539 539
 					float: left;
@@ -661,35 +661,35 @@  discard block
 block discarded – undo
661 661
 				<?php } ?>
662 662
 			</style>
663 663
 			<?php
664
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
665
-				echo "<script>" . self::siteorigin_js() . "</script>";
666
-			}
667
-			?>
664
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
665
+                echo "<script>" . self::siteorigin_js() . "</script>";
666
+            }
667
+            ?>
668 668
 			<script>
669 669
 				<?php
670
-				if(! empty( $insert_shortcode_function )){
671
-					echo $insert_shortcode_function;
672
-				}else{
673
-
674
-				/**
675
-				 * Function for super duper insert shortcode.
676
-				 *
677
-				 * @since 1.0.0
678
-				 */
679
-				?>
670
+                if(! empty( $insert_shortcode_function )){
671
+                    echo $insert_shortcode_function;
672
+                }else{
673
+
674
+                /**
675
+                 * Function for super duper insert shortcode.
676
+                 *
677
+                 * @since 1.0.0
678
+                 */
679
+                ?>
680 680
 				function sd_insert_shortcode($editor_id) {
681 681
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
682 682
 					if ($shortcode) {
683 683
 						if (!$editor_id) {
684 684
 							<?php
685
-							if ( isset( $_REQUEST['et_fb'] ) ) {
686
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
687
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
688
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
689
-							} else {
690
-								echo '$editor_id = "#wp-content-editor-container textarea";';
691
-							}
692
-							?>
685
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
686
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
687
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
688
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
689
+                            } else {
690
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
691
+                            }
692
+                            ?>
693 693
 						} else {
694 694
 							$editor_id = '#' + $editor_id;
695 695
 						}
@@ -1016,18 +1016,18 @@  discard block
 block discarded – undo
1016 1016
 
1017 1017
 			</script>
1018 1018
 			<?php
1019
-		}
1020
-
1021
-		/**
1022
-		 * Gets some CSS for the widgets screen.
1023
-		 *
1024
-		 * @param bool $advanced If we should include advanced CSS.
1025
-		 *
1026
-		 * @return mixed
1027
-		 */
1028
-		public function widget_css( $advanced = true ) {
1029
-			ob_start();
1030
-			?>
1019
+        }
1020
+
1021
+        /**
1022
+         * Gets some CSS for the widgets screen.
1023
+         *
1024
+         * @param bool $advanced If we should include advanced CSS.
1025
+         *
1026
+         * @return mixed
1027
+         */
1028
+        public function widget_css( $advanced = true ) {
1029
+            ob_start();
1030
+            ?>
1031 1031
 			<style>
1032 1032
 				<?php if( $advanced ){ ?>
1033 1033
 				.sd-advanced-setting {
@@ -1065,26 +1065,26 @@  discard block
 block discarded – undo
1065 1065
 				}
1066 1066
 			</style>
1067 1067
 			<?php
1068
-			$output = ob_get_clean();
1068
+            $output = ob_get_clean();
1069 1069
 
1070
-			/*
1070
+            /*
1071 1071
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1072 1072
 			 */
1073 1073
 
1074
-			return str_replace( array(
1075
-				'<style>',
1076
-				'</style>'
1077
-			), '', $output );
1078
-		}
1079
-
1080
-		/**
1081
-		 * Gets some JS for the widgets screen.
1082
-		 *
1083
-		 * @return mixed
1084
-		 */
1085
-		public function widget_js() {
1086
-			ob_start();
1087
-			?>
1074
+            return str_replace( array(
1075
+                '<style>',
1076
+                '</style>'
1077
+            ), '', $output );
1078
+        }
1079
+
1080
+        /**
1081
+         * Gets some JS for the widgets screen.
1082
+         *
1083
+         * @return mixed
1084
+         */
1085
+        public function widget_js() {
1086
+            ob_start();
1087
+            ?>
1088 1088
 			<script>
1089 1089
 
1090 1090
 				/**
@@ -1242,435 +1242,435 @@  discard block
 block discarded – undo
1242 1242
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1243 1243
 			</script>
1244 1244
 			<?php
1245
-			$output = ob_get_clean();
1245
+            $output = ob_get_clean();
1246 1246
 
1247
-			/*
1247
+            /*
1248 1248
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1249 1249
 			 */
1250 1250
 
1251
-			return str_replace( array(
1252
-				'<script>',
1253
-				'</script>'
1254
-			), '', $output );
1255
-		}
1256
-
1257
-
1258
-		/**
1259
-		 * Set the name from the argument key.
1260
-		 *
1261
-		 * @param $options
1262
-		 *
1263
-		 * @return mixed
1264
-		 */
1265
-		private function add_name_from_key( $options, $arguments = false ) {
1266
-			if ( ! empty( $options['arguments'] ) ) {
1267
-				foreach ( $options['arguments'] as $key => $val ) {
1268
-					$options['arguments'][ $key ]['name'] = $key;
1269
-				}
1270
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1271
-				foreach ( $options as $key => $val ) {
1272
-					$options[ $key ]['name'] = $key;
1273
-				}
1274
-			}
1275
-
1276
-			return $options;
1277
-		}
1278
-
1279
-		/**
1280
-		 * Register the parent shortcode.
1281
-		 *
1282
-		 * @since 1.0.0
1283
-		 */
1284
-		public function register_shortcode() {
1285
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1286
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1287
-		}
1288
-
1289
-		/**
1290
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1291
-		 *
1292
-		 * @since 1.0.0
1293
-		 */
1294
-		public function render_shortcode() {
1295
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1296
-			if ( ! current_user_can( 'manage_options' ) ) {
1297
-				wp_die();
1298
-			}
1299
-
1300
-			// we might need the $post value here so lets set it.
1301
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1302
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1303
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1304
-					global $post;
1305
-					$post = $post_obj;
1306
-				}
1307
-			}
1308
-
1309
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1310
-				$is_preview = $this->is_preview();
1311
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1312
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1313
-				$attributes       = '';
1314
-				if ( ! empty( $attributes_array ) ) {
1315
-					foreach ( $attributes_array as $key => $value ) {
1316
-						if ( is_array( $value ) ) {
1317
-							$value = implode( ",", $value );
1318
-						}
1319
-
1320
-						if ( ! empty( $value ) ) {
1321
-							$value = wp_unslash( $value );
1322
-
1323
-							// Encode [ and ].
1324
-							if ( $is_preview ) {
1325
-								$value = $this->encode_shortcodes( $value );
1326
-							}
1327
-						}
1328
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1329
-					}
1330
-				}
1331
-
1332
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1333
-
1334
-				$content = do_shortcode( $shortcode );
1335
-
1336
-				// Decode [ and ].
1337
-				if ( ! empty( $content ) && $is_preview ) {
1338
-					$content = $this->decode_shortcodes( $content );
1339
-				}
1340
-
1341
-				echo $content;
1342
-			}
1343
-			wp_die();
1344
-		}
1345
-
1346
-		/**
1347
-		 * Output the shortcode.
1348
-		 *
1349
-		 * @param array $args
1350
-		 * @param string $content
1351
-		 *
1352
-		 * @return string
1353
-		 */
1354
-		public function shortcode_output( $args = array(), $content = '' ) {
1355
-			$_instance = $args;
1356
-
1357
-			$args = $this->argument_values( $args );
1358
-
1359
-			// add extra argument so we know its a output to gutenberg
1360
-			//$args
1361
-			$args = $this->string_to_bool( $args );
1362
-
1363
-			// if we have a enclosed shortcode we add it to the special `html` argument
1364
-			if ( ! empty( $content ) ) {
1365
-				$args['html'] = $content;
1366
-			}
1367
-
1368
-			if ( ! $this->is_preview() ) {
1369
-				/**
1370
-				 * Filters the settings for a particular widget args.
1371
-				 *
1372
-				 * @since 1.0.28
1373
-				 *
1374
-				 * @param array          $args      The current widget instance's settings.
1375
-				 * @param WP_Super_Duper $widget    The current widget settings.
1376
-				 * @param array          $_instance An array of default widget arguments.
1377
-				 */
1378
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1379
-
1380
-				if ( ! is_array( $args ) ) {
1381
-					return $args;
1382
-				}
1383
-			}
1384
-
1385
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1386
-			$class .= " sdel-".$this->get_instance_hash();
1387
-
1388
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1389
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1390
-
1391
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1392
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1393
-
1394
-			$shortcode_args = array();
1395
-			$output         = '';
1396
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1397
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1398
-				$no_wrap = true;
1399
-			}
1400
-			$main_content = $this->output( $args, $shortcode_args, $content );
1401
-			if ( $main_content && ! $no_wrap ) {
1402
-				// wrap the shortcode in a div with the same class as the widget
1403
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1404
-				if ( ! empty( $args['title'] ) ) {
1405
-					// if its a shortcode and there is a title try to grab the title wrappers
1406
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1407
-					if ( empty( $instance ) ) {
1408
-						global $wp_registered_sidebars;
1409
-						if ( ! empty( $wp_registered_sidebars ) ) {
1410
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1411
-								if ( ! empty( $sidebar['before_title'] ) ) {
1412
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1413
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1414
-									break;
1415
-								}
1416
-							}
1417
-						}
1418
-					}
1419
-					$output .= $this->output_title( $shortcode_args, $args );
1420
-				}
1421
-				$output .= $main_content;
1422
-				$output .= '</div>';
1423
-			} elseif ( $main_content && $no_wrap ) {
1424
-				$output .= $main_content;
1425
-			}
1426
-
1427
-			// if preview show a placeholder if empty
1428
-			if ( $this->is_preview() && $output == '' ) {
1429
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1430
-			}
1431
-
1432
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1433
-		}
1434
-
1435
-		/**
1436
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1437
-		 *
1438
-		 * @param string $name
1439
-		 *
1440
-		 * @return string
1441
-		 */
1442
-		public function preview_placeholder_text( $name = '' ) {
1443
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1444
-		}
1445
-
1446
-		/**
1447
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1448
-		 *
1449
-		 * @param $options
1450
-		 *
1451
-		 * @return mixed
1452
-		 */
1453
-		public function string_to_bool( $options ) {
1454
-			// convert bool strings to booleans
1455
-			foreach ( $options as $key => $val ) {
1456
-				if ( $val == 'false' ) {
1457
-					$options[ $key ] = false;
1458
-				} elseif ( $val == 'true' ) {
1459
-					$options[ $key ] = true;
1460
-				}
1461
-			}
1462
-
1463
-			return $options;
1464
-		}
1465
-
1466
-		/**
1467
-		 * Get the argument values that are also filterable.
1468
-		 *
1469
-		 * @param $instance
1470
-		 *
1471
-		 * @since 1.0.12 Don't set checkbox default value if the value is empty.
1472
-		 *
1473
-		 * @return array
1474
-		 */
1475
-		public function argument_values( $instance ) {
1476
-			$argument_values = array();
1477
-
1478
-			// set widget instance
1479
-			$this->instance = $instance;
1480
-
1481
-			if ( empty( $this->arguments ) ) {
1482
-				$this->arguments = $this->get_arguments();
1483
-			}
1484
-
1485
-			if ( ! empty( $this->arguments ) ) {
1486
-				foreach ( $this->arguments as $key => $args ) {
1487
-					// set the input name from the key
1488
-					$args['name'] = $key;
1489
-					//
1490
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1491
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1492
-						// don't set default for an empty checkbox
1493
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1494
-						$argument_values[ $key ] = $args['default'];
1495
-					}
1496
-				}
1497
-			}
1498
-
1499
-			return $argument_values;
1500
-		}
1501
-
1502
-		/**
1503
-		 * Set arguments in super duper.
1504
-		 *
1505
-		 * @since 1.0.0
1506
-		 *
1507
-		 * @return array Set arguments.
1508
-		 */
1509
-		public function set_arguments() {
1510
-			return $this->arguments;
1511
-		}
1512
-
1513
-		/**
1514
-		 * Get arguments in super duper.
1515
-		 *
1516
-		 * @since 1.0.0
1517
-		 *
1518
-		 * @return array Get arguments.
1519
-		 */
1520
-		public function get_arguments() {
1521
-			if ( empty( $this->arguments ) ) {
1522
-				$this->arguments = $this->set_arguments();
1523
-			}
1524
-
1525
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1526
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1527
-
1528
-			return $this->arguments;
1529
-		}
1530
-
1531
-		/**
1532
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1533
-		 *
1534
-		 * @param array $args
1535
-		 * @param array $widget_args
1536
-		 * @param string $content
1537
-		 */
1538
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1539
-
1540
-		}
1541
-
1542
-		/**
1543
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1544
-		 */
1545
-		public function register_block() {
1546
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1547
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1548
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1549
-			}
1550
-		}
1551
-
1552
-		/**
1553
-		 * Check if we need to show advanced options.
1554
-		 *
1555
-		 * @return bool
1556
-		 */
1557
-		public function block_show_advanced() {
1558
-
1559
-			$show      = false;
1560
-			$arguments = $this->get_arguments();
1251
+            return str_replace( array(
1252
+                '<script>',
1253
+                '</script>'
1254
+            ), '', $output );
1255
+        }
1256
+
1257
+
1258
+        /**
1259
+         * Set the name from the argument key.
1260
+         *
1261
+         * @param $options
1262
+         *
1263
+         * @return mixed
1264
+         */
1265
+        private function add_name_from_key( $options, $arguments = false ) {
1266
+            if ( ! empty( $options['arguments'] ) ) {
1267
+                foreach ( $options['arguments'] as $key => $val ) {
1268
+                    $options['arguments'][ $key ]['name'] = $key;
1269
+                }
1270
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1271
+                foreach ( $options as $key => $val ) {
1272
+                    $options[ $key ]['name'] = $key;
1273
+                }
1274
+            }
1275
+
1276
+            return $options;
1277
+        }
1278
+
1279
+        /**
1280
+         * Register the parent shortcode.
1281
+         *
1282
+         * @since 1.0.0
1283
+         */
1284
+        public function register_shortcode() {
1285
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1286
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1287
+        }
1288
+
1289
+        /**
1290
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1291
+         *
1292
+         * @since 1.0.0
1293
+         */
1294
+        public function render_shortcode() {
1295
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1296
+            if ( ! current_user_can( 'manage_options' ) ) {
1297
+                wp_die();
1298
+            }
1299
+
1300
+            // we might need the $post value here so lets set it.
1301
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1302
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1303
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1304
+                    global $post;
1305
+                    $post = $post_obj;
1306
+                }
1307
+            }
1308
+
1309
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1310
+                $is_preview = $this->is_preview();
1311
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1312
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1313
+                $attributes       = '';
1314
+                if ( ! empty( $attributes_array ) ) {
1315
+                    foreach ( $attributes_array as $key => $value ) {
1316
+                        if ( is_array( $value ) ) {
1317
+                            $value = implode( ",", $value );
1318
+                        }
1319
+
1320
+                        if ( ! empty( $value ) ) {
1321
+                            $value = wp_unslash( $value );
1322
+
1323
+                            // Encode [ and ].
1324
+                            if ( $is_preview ) {
1325
+                                $value = $this->encode_shortcodes( $value );
1326
+                            }
1327
+                        }
1328
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1329
+                    }
1330
+                }
1331
+
1332
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1333
+
1334
+                $content = do_shortcode( $shortcode );
1335
+
1336
+                // Decode [ and ].
1337
+                if ( ! empty( $content ) && $is_preview ) {
1338
+                    $content = $this->decode_shortcodes( $content );
1339
+                }
1340
+
1341
+                echo $content;
1342
+            }
1343
+            wp_die();
1344
+        }
1345
+
1346
+        /**
1347
+         * Output the shortcode.
1348
+         *
1349
+         * @param array $args
1350
+         * @param string $content
1351
+         *
1352
+         * @return string
1353
+         */
1354
+        public function shortcode_output( $args = array(), $content = '' ) {
1355
+            $_instance = $args;
1356
+
1357
+            $args = $this->argument_values( $args );
1358
+
1359
+            // add extra argument so we know its a output to gutenberg
1360
+            //$args
1361
+            $args = $this->string_to_bool( $args );
1362
+
1363
+            // if we have a enclosed shortcode we add it to the special `html` argument
1364
+            if ( ! empty( $content ) ) {
1365
+                $args['html'] = $content;
1366
+            }
1367
+
1368
+            if ( ! $this->is_preview() ) {
1369
+                /**
1370
+                 * Filters the settings for a particular widget args.
1371
+                 *
1372
+                 * @since 1.0.28
1373
+                 *
1374
+                 * @param array          $args      The current widget instance's settings.
1375
+                 * @param WP_Super_Duper $widget    The current widget settings.
1376
+                 * @param array          $_instance An array of default widget arguments.
1377
+                 */
1378
+                $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1379
+
1380
+                if ( ! is_array( $args ) ) {
1381
+                    return $args;
1382
+                }
1383
+            }
1384
+
1385
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1386
+            $class .= " sdel-".$this->get_instance_hash();
1387
+
1388
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1389
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1390
+
1391
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1392
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1393
+
1394
+            $shortcode_args = array();
1395
+            $output         = '';
1396
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1397
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1398
+                $no_wrap = true;
1399
+            }
1400
+            $main_content = $this->output( $args, $shortcode_args, $content );
1401
+            if ( $main_content && ! $no_wrap ) {
1402
+                // wrap the shortcode in a div with the same class as the widget
1403
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1404
+                if ( ! empty( $args['title'] ) ) {
1405
+                    // if its a shortcode and there is a title try to grab the title wrappers
1406
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1407
+                    if ( empty( $instance ) ) {
1408
+                        global $wp_registered_sidebars;
1409
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1410
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1411
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1412
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1413
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1414
+                                    break;
1415
+                                }
1416
+                            }
1417
+                        }
1418
+                    }
1419
+                    $output .= $this->output_title( $shortcode_args, $args );
1420
+                }
1421
+                $output .= $main_content;
1422
+                $output .= '</div>';
1423
+            } elseif ( $main_content && $no_wrap ) {
1424
+                $output .= $main_content;
1425
+            }
1426
+
1427
+            // if preview show a placeholder if empty
1428
+            if ( $this->is_preview() && $output == '' ) {
1429
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1430
+            }
1431
+
1432
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1433
+        }
1434
+
1435
+        /**
1436
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1437
+         *
1438
+         * @param string $name
1439
+         *
1440
+         * @return string
1441
+         */
1442
+        public function preview_placeholder_text( $name = '' ) {
1443
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1444
+        }
1445
+
1446
+        /**
1447
+         * Sometimes booleans values can be turned to strings, so we fix that.
1448
+         *
1449
+         * @param $options
1450
+         *
1451
+         * @return mixed
1452
+         */
1453
+        public function string_to_bool( $options ) {
1454
+            // convert bool strings to booleans
1455
+            foreach ( $options as $key => $val ) {
1456
+                if ( $val == 'false' ) {
1457
+                    $options[ $key ] = false;
1458
+                } elseif ( $val == 'true' ) {
1459
+                    $options[ $key ] = true;
1460
+                }
1461
+            }
1462
+
1463
+            return $options;
1464
+        }
1465
+
1466
+        /**
1467
+         * Get the argument values that are also filterable.
1468
+         *
1469
+         * @param $instance
1470
+         *
1471
+         * @since 1.0.12 Don't set checkbox default value if the value is empty.
1472
+         *
1473
+         * @return array
1474
+         */
1475
+        public function argument_values( $instance ) {
1476
+            $argument_values = array();
1477
+
1478
+            // set widget instance
1479
+            $this->instance = $instance;
1480
+
1481
+            if ( empty( $this->arguments ) ) {
1482
+                $this->arguments = $this->get_arguments();
1483
+            }
1484
+
1485
+            if ( ! empty( $this->arguments ) ) {
1486
+                foreach ( $this->arguments as $key => $args ) {
1487
+                    // set the input name from the key
1488
+                    $args['name'] = $key;
1489
+                    //
1490
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1491
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1492
+                        // don't set default for an empty checkbox
1493
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1494
+                        $argument_values[ $key ] = $args['default'];
1495
+                    }
1496
+                }
1497
+            }
1498
+
1499
+            return $argument_values;
1500
+        }
1501
+
1502
+        /**
1503
+         * Set arguments in super duper.
1504
+         *
1505
+         * @since 1.0.0
1506
+         *
1507
+         * @return array Set arguments.
1508
+         */
1509
+        public function set_arguments() {
1510
+            return $this->arguments;
1511
+        }
1512
+
1513
+        /**
1514
+         * Get arguments in super duper.
1515
+         *
1516
+         * @since 1.0.0
1517
+         *
1518
+         * @return array Get arguments.
1519
+         */
1520
+        public function get_arguments() {
1521
+            if ( empty( $this->arguments ) ) {
1522
+                $this->arguments = $this->set_arguments();
1523
+            }
1524
+
1525
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1526
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1527
+
1528
+            return $this->arguments;
1529
+        }
1530
+
1531
+        /**
1532
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1533
+         *
1534
+         * @param array $args
1535
+         * @param array $widget_args
1536
+         * @param string $content
1537
+         */
1538
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1539
+
1540
+        }
1541
+
1542
+        /**
1543
+         * Add the dynamic block code inline when the wp-block in enqueued.
1544
+         */
1545
+        public function register_block() {
1546
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1547
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1548
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1549
+            }
1550
+        }
1551
+
1552
+        /**
1553
+         * Check if we need to show advanced options.
1554
+         *
1555
+         * @return bool
1556
+         */
1557
+        public function block_show_advanced() {
1558
+
1559
+            $show      = false;
1560
+            $arguments = $this->get_arguments();
1561 1561
 			
1562
-			if ( ! empty( $arguments ) ) {
1563
-				foreach ( $arguments as $argument ) {
1564
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1565
-						$show = true;
1566
-						break; // no need to continue if we know we have it
1567
-					}
1568
-				}
1569
-			}
1570
-
1571
-			return $show;
1572
-		}
1573
-
1574
-		/**
1575
-		 * Get the url path to the current folder.
1576
-		 *
1577
-		 * @return string
1578
-		 */
1579
-		public function get_url() {
1580
-
1581
-			$url = $this->url;
1582
-
1583
-			if ( ! $url ) {
1584
-				// check if we are inside a plugin
1585
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1586
-
1587
-				$dir_parts = explode( "/wp-content/", $file_dir );
1588
-				$url_parts = explode( "/wp-content/", plugins_url() );
1589
-
1590
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1591
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1592
-					$this->url = $url;
1593
-				}
1594
-			}
1595
-
1596
-
1597
-			return $url;
1598
-		}
1599
-
1600
-		/**
1601
-		 * Generate the block icon.
1602
-		 *
1603
-		 * Enables the use of Font Awesome icons.
1604
-		 *
1605
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1606
-		 *
1607
-		 * @param $icon
1608
-		 *
1609
-		 * @since 1.1.0
1610
-		 * @return string
1611
-		 */
1612
-		public function get_block_icon( $icon ) {
1613
-
1614
-			// check if we have a Font Awesome icon
1615
-			$fa_type = '';
1616
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1617
-				$fa_type = 'solid';
1618
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1619
-				$fa_type = 'regular';
1620
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1621
-				$fa_type = 'brands';
1622
-			} else {
1623
-				$icon = "'" . $icon . "'";
1624
-			}
1625
-
1626
-			// set the icon if we found one
1627
-			if ( $fa_type ) {
1628
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1629
-				$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 . "'}))";
1630
-			}
1631
-
1632
-			return $icon;
1633
-		}
1634
-
1635
-		public function group_arguments( $arguments ) {
1562
+            if ( ! empty( $arguments ) ) {
1563
+                foreach ( $arguments as $argument ) {
1564
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1565
+                        $show = true;
1566
+                        break; // no need to continue if we know we have it
1567
+                    }
1568
+                }
1569
+            }
1570
+
1571
+            return $show;
1572
+        }
1573
+
1574
+        /**
1575
+         * Get the url path to the current folder.
1576
+         *
1577
+         * @return string
1578
+         */
1579
+        public function get_url() {
1580
+
1581
+            $url = $this->url;
1582
+
1583
+            if ( ! $url ) {
1584
+                // check if we are inside a plugin
1585
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1586
+
1587
+                $dir_parts = explode( "/wp-content/", $file_dir );
1588
+                $url_parts = explode( "/wp-content/", plugins_url() );
1589
+
1590
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1591
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1592
+                    $this->url = $url;
1593
+                }
1594
+            }
1595
+
1596
+
1597
+            return $url;
1598
+        }
1599
+
1600
+        /**
1601
+         * Generate the block icon.
1602
+         *
1603
+         * Enables the use of Font Awesome icons.
1604
+         *
1605
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1606
+         *
1607
+         * @param $icon
1608
+         *
1609
+         * @since 1.1.0
1610
+         * @return string
1611
+         */
1612
+        public function get_block_icon( $icon ) {
1613
+
1614
+            // check if we have a Font Awesome icon
1615
+            $fa_type = '';
1616
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1617
+                $fa_type = 'solid';
1618
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1619
+                $fa_type = 'regular';
1620
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1621
+                $fa_type = 'brands';
1622
+            } else {
1623
+                $icon = "'" . $icon . "'";
1624
+            }
1625
+
1626
+            // set the icon if we found one
1627
+            if ( $fa_type ) {
1628
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1629
+                $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 . "'}))";
1630
+            }
1631
+
1632
+            return $icon;
1633
+        }
1634
+
1635
+        public function group_arguments( $arguments ) {
1636 1636
 //			echo '###';print_r($arguments);
1637
-			if ( ! empty( $arguments ) ) {
1638
-				$temp_arguments = array();
1639
-				$general        = __( "General" );
1640
-				$add_sections   = false;
1641
-				foreach ( $arguments as $key => $args ) {
1642
-					if ( isset( $args['group'] ) ) {
1643
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1644
-						$add_sections                             = true;
1645
-					} else {
1646
-						$temp_arguments[ $general ][ $key ] = $args;
1647
-					}
1648
-				}
1649
-
1650
-				// only add sections if more than one
1651
-				if ( $add_sections ) {
1652
-					$arguments = $temp_arguments;
1653
-				}
1654
-			}
1637
+            if ( ! empty( $arguments ) ) {
1638
+                $temp_arguments = array();
1639
+                $general        = __( "General" );
1640
+                $add_sections   = false;
1641
+                foreach ( $arguments as $key => $args ) {
1642
+                    if ( isset( $args['group'] ) ) {
1643
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1644
+                        $add_sections                             = true;
1645
+                    } else {
1646
+                        $temp_arguments[ $general ][ $key ] = $args;
1647
+                    }
1648
+                }
1649
+
1650
+                // only add sections if more than one
1651
+                if ( $add_sections ) {
1652
+                    $arguments = $temp_arguments;
1653
+                }
1654
+            }
1655 1655
 
1656 1656
 //			echo '###';print_r($arguments);
1657
-			return $arguments;
1658
-		}
1659
-
1660
-
1661
-		/**
1662
-		 * Output the JS for building the dynamic Guntenberg block.
1663
-		 *
1664
-		 * @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.
1665
-		 * @since 1.0.9 Save numbers as numbers and not strings.
1666
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1667
-		 * @return mixed
1668
-		 */
1669
-		public function block() {
1670
-			ob_start();
1671
-
1672
-			$show_advanced = $this->block_show_advanced();
1673
-			?>
1657
+            return $arguments;
1658
+        }
1659
+
1660
+
1661
+        /**
1662
+         * Output the JS for building the dynamic Guntenberg block.
1663
+         *
1664
+         * @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.
1665
+         * @since 1.0.9 Save numbers as numbers and not strings.
1666
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1667
+         * @return mixed
1668
+         */
1669
+        public function block() {
1670
+            ob_start();
1671
+
1672
+            $show_advanced = $this->block_show_advanced();
1673
+            ?>
1674 1674
 			<script>
1675 1675
 				/**
1676 1676
 				 * BLOCK: Basic
@@ -1714,97 +1714,97 @@  discard block
 block discarded – undo
1714 1714
 						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/.
1715 1715
 						supports: {
1716 1716
 							<?php
1717
-							if ( isset( $this->options['block-supports'] ) ) {
1718
-								echo $this->array_to_attributes( $this->options['block-supports'] );
1719
-							}
1720
-							?>
1717
+                            if ( isset( $this->options['block-supports'] ) ) {
1718
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
1719
+                            }
1720
+                            ?>
1721 1721
 						},
1722 1722
 						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.
1723 1723
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
1724
-						echo "keywords : " . $this->options['block-keywords'] . ",";
1725
-					}?>
1724
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
1725
+                    }?>
1726 1726
 
1727 1727
 						<?php
1728 1728
 
1729
-						// maybe set no_wrap
1730
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1731
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1732
-							$no_wrap = true;
1733
-						}
1734
-						if ( $no_wrap ) {
1735
-							$this->options['block-wrap'] = '';
1736
-						}
1729
+                        // maybe set no_wrap
1730
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1731
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1732
+                            $no_wrap = true;
1733
+                        }
1734
+                        if ( $no_wrap ) {
1735
+                            $this->options['block-wrap'] = '';
1736
+                        }
1737 1737
 
1738 1738
 
1739 1739
 
1740
-						$show_alignment = false;
1741
-						// align feature
1742
-						/*echo "supports: {";
1740
+                        $show_alignment = false;
1741
+                        // align feature
1742
+                        /*echo "supports: {";
1743 1743
 						echo "	align: true,";
1744 1744
 						echo "  html: false";
1745 1745
 						echo "},";*/
1746 1746
 
1747
-						if ( ! empty( $this->arguments ) ) {
1748
-							echo "attributes : {";
1749
-
1750
-							if ( $show_advanced ) {
1751
-								echo "show_advanced: {";
1752
-								echo "	type: 'boolean',";
1753
-								echo "  default: false,";
1754
-								echo "},";
1755
-							}
1756
-
1757
-							// block wrap element
1758
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1759
-								echo "block_wrap: {";
1760
-								echo "	type: 'string',";
1761
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1762
-								echo "},";
1763
-							}
1764
-
1765
-							foreach ( $this->arguments as $key => $args ) {
1766
-
1767
-								// set if we should show alignment
1768
-								if ( $key == 'alignment' ) {
1769
-									$show_alignment = true;
1770
-								}
1771
-
1772
-								$extra = '';
1773
-
1774
-								if ( $args['type'] == 'checkbox' ) {
1775
-									$type    = 'boolean';
1776
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1777
-								} elseif ( $args['type'] == 'number' ) {
1778
-									$type    = 'number';
1779
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1780
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1781
-									$type = 'array';
1782
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1783
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1784
-									} else {
1785
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1786
-									}
1787
-								} elseif ( $args['type'] == 'multiselect' ) {
1788
-									$type    = 'array';
1789
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1790
-								} else {
1791
-									$type    = 'string';
1792
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1793
-								}
1794
-								echo $key . " : {";
1795
-								echo "type : '$type',";
1796
-								echo "default : $default,";
1797
-								echo "},";
1798
-							}
1799
-
1800
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1801
-							echo "className: { type: 'string', default: '' },";
1802
-
1803
-							echo "},";
1804
-
1805
-						}
1806
-
1807
-						?>
1747
+                        if ( ! empty( $this->arguments ) ) {
1748
+                            echo "attributes : {";
1749
+
1750
+                            if ( $show_advanced ) {
1751
+                                echo "show_advanced: {";
1752
+                                echo "	type: 'boolean',";
1753
+                                echo "  default: false,";
1754
+                                echo "},";
1755
+                            }
1756
+
1757
+                            // block wrap element
1758
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1759
+                                echo "block_wrap: {";
1760
+                                echo "	type: 'string',";
1761
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1762
+                                echo "},";
1763
+                            }
1764
+
1765
+                            foreach ( $this->arguments as $key => $args ) {
1766
+
1767
+                                // set if we should show alignment
1768
+                                if ( $key == 'alignment' ) {
1769
+                                    $show_alignment = true;
1770
+                                }
1771
+
1772
+                                $extra = '';
1773
+
1774
+                                if ( $args['type'] == 'checkbox' ) {
1775
+                                    $type    = 'boolean';
1776
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1777
+                                } elseif ( $args['type'] == 'number' ) {
1778
+                                    $type    = 'number';
1779
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1780
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1781
+                                    $type = 'array';
1782
+                                    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1783
+                                        $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1784
+                                    } else {
1785
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1786
+                                    }
1787
+                                } elseif ( $args['type'] == 'multiselect' ) {
1788
+                                    $type    = 'array';
1789
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1790
+                                } else {
1791
+                                    $type    = 'string';
1792
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1793
+                                }
1794
+                                echo $key . " : {";
1795
+                                echo "type : '$type',";
1796
+                                echo "default : $default,";
1797
+                                echo "},";
1798
+                            }
1799
+
1800
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1801
+                            echo "className: { type: 'string', default: '' },";
1802
+
1803
+                            echo "},";
1804
+
1805
+                        }
1806
+
1807
+                        ?>
1808 1808
 
1809 1809
 						// The "edit" property must be a valid function.
1810 1810
 						edit: function (props) {
@@ -1812,9 +1812,9 @@  discard block
 block discarded – undo
1812 1812
 
1813 1813
 							var $value = '';
1814 1814
 							<?php
1815
-							// if we have a post_type and a category then link them
1816
-							if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1817
-							?>
1815
+                            // if we have a post_type and a category then link them
1816
+                            if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1817
+                            ?>
1818 1818
 							if(typeof(prev_attributes[props.id]) != 'undefined' ){
1819 1819
 								$pt = props.attributes.post_type;
1820 1820
 								if(post_type_rest_slugs.length){
@@ -1898,8 +1898,8 @@  discard block
 block discarded – undo
1898 1898
 										'shortcode': '<?php echo $this->options['base_id'];?>',
1899 1899
 										'attributes': props.attributes,
1900 1900
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
1901
-										echo $post->ID;
1902
-									}else{echo '0';}?>,
1901
+                                        echo $post->ID;
1902
+                                    }else{echo '0';}?>,
1903 1903
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
1904 1904
 									};
1905 1905
 
@@ -1951,10 +1951,10 @@  discard block
 block discarded – undo
1951 1951
 
1952 1952
 									<?php
1953 1953
 
1954
-									if(! empty( $this->arguments )){
1954
+                                    if(! empty( $this->arguments )){
1955 1955
 
1956
-									if ( $show_advanced ) {
1957
-									?>
1956
+                                    if ( $show_advanced ) {
1957
+                                    ?>
1958 1958
 									el('div', {
1959 1959
 											style: {'padding-left': '16px','padding-right': '16px'}
1960 1960
 										},
@@ -1972,79 +1972,79 @@  discard block
 block discarded – undo
1972 1972
 									,
1973 1973
 									<?php
1974 1974
 
1975
-									}
1975
+                                    }
1976 1976
 
1977
-									$arguments = $this->group_arguments( $this->arguments );
1977
+                                    $arguments = $this->group_arguments( $this->arguments );
1978 1978
 
1979
-									// Do we have sections?
1980
-									$has_sections = $arguments == $this->arguments ? false : true;
1979
+                                    // Do we have sections?
1980
+                                    $has_sections = $arguments == $this->arguments ? false : true;
1981 1981
 
1982 1982
 
1983
-									if($has_sections){
1984
-									$panel_count = 0;
1985
-									foreach($arguments as $key => $args){
1986
-									?>
1983
+                                    if($has_sections){
1984
+                                    $panel_count = 0;
1985
+                                    foreach($arguments as $key => $args){
1986
+                                    ?>
1987 1987
 									el(wp.components.PanelBody, {
1988 1988
 											title: '<?php esc_attr_e( $key ); ?>',
1989 1989
 											initialOpen: <?php if ( $panel_count ) {
1990
-											echo "false";
1991
-										} else {
1992
-											echo "true";
1993
-										}?>
1990
+                                            echo "false";
1991
+                                        } else {
1992
+                                            echo "true";
1993
+                                        }?>
1994 1994
 										},
1995 1995
 										<?php
1996 1996
 
1997 1997
 
1998 1998
 
1999
-										foreach ( $args as $k => $a ) {
1999
+                                        foreach ( $args as $k => $a ) {
2000 2000
 
2001
-											$this->block_row_start( $k, $a );
2002
-											$this->build_block_arguments( $k, $a );
2003
-											$this->block_row_end( $k, $a );
2004
-										}
2005
-										?>
2001
+                                            $this->block_row_start( $k, $a );
2002
+                                            $this->build_block_arguments( $k, $a );
2003
+                                            $this->block_row_end( $k, $a );
2004
+                                        }
2005
+                                        ?>
2006 2006
 									),
2007 2007
 									<?php
2008
-									$panel_count ++;
2008
+                                    $panel_count ++;
2009 2009
 
2010
-									}
2011
-									}else {
2012
-									?>
2010
+                                    }
2011
+                                    }else {
2012
+                                    ?>
2013 2013
 									el(wp.components.PanelBody, {
2014 2014
 											title: '<?php esc_attr_e( "Settings" ); ?>',
2015 2015
 											initialOpen: true
2016 2016
 										},
2017 2017
 										<?php
2018
-										foreach ( $this->arguments as $key => $args ) {
2019
-											$this->block_row_start( $key, $args );
2020
-											$this->build_block_arguments( $key, $args );
2021
-											$this->block_row_end( $key, $args );
2022
-										}
2023
-										?>
2018
+                                        foreach ( $this->arguments as $key => $args ) {
2019
+                                            $this->block_row_start( $key, $args );
2020
+                                            $this->build_block_arguments( $key, $args );
2021
+                                            $this->block_row_end( $key, $args );
2022
+                                        }
2023
+                                        ?>
2024 2024
 									),
2025 2025
 									<?php
2026
-									}
2026
+                                    }
2027 2027
 
2028
-									}
2029
-									?>
2028
+                                    }
2029
+                                    ?>
2030 2030
 
2031 2031
 								),
2032 2032
 
2033 2033
 								<?php
2034
-								// If the user sets block-output array then build it
2035
-								if ( ! empty( $this->options['block-output'] ) ) {
2036
-								$this->block_element( $this->options['block-output'] );
2037
-							}else{
2038
-								// if no block-output is set then we try and get the shortcode html output via ajax.
2039
-								?>
2034
+                                // If the user sets block-output array then build it
2035
+                                if ( ! empty( $this->options['block-output'] ) ) {
2036
+                                $this->block_element( $this->options['block-output'] );
2037
+                            }else{
2038
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
2039
+                                ?>
2040 2040
 								el('div', {
2041 2041
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
2042 2042
 									className: props.className,
2043 2043
 									style: {'minHeight': '30px'}
2044 2044
 								})
2045 2045
 								<?php
2046
-								}
2047
-								?>
2046
+                                }
2047
+                                ?>
2048 2048
 							]; // end return
2049 2049
 						},
2050 2050
 
@@ -2062,10 +2062,10 @@  discard block
 block discarded – undo
2062 2062
 							$html = '';
2063 2063
 							<?php
2064 2064
 
2065
-							if(! empty( $this->arguments )){
2065
+                            if(! empty( $this->arguments )){
2066 2066
 
2067
-							foreach($this->arguments as $key => $args){
2068
-							?>
2067
+                            foreach($this->arguments as $key => $args){
2068
+                            ?>
2069 2069
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2070 2070
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2071 2071
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2074,10 +2074,10 @@  discard block
 block discarded – undo
2074 2074
 								}
2075 2075
 							}
2076 2076
 							<?php
2077
-							}
2078
-							}
2077
+                            }
2078
+                            }
2079 2079
 
2080
-							?>
2080
+                            ?>
2081 2081
 							content += "]";
2082 2082
 
2083 2083
 							// if has html element
@@ -2100,20 +2100,20 @@  discard block
 block discarded – undo
2100 2100
 							}
2101 2101
 
2102 2102
 							<?php
2103
-							if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2104
-							?>
2103
+                            if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2104
+                            ?>
2105 2105
 							return content;
2106 2106
 							<?php
2107
-							}else{
2108
-							?>
2107
+                            }else{
2108
+                            ?>
2109 2109
 							var block_wrap = 'div';
2110 2110
 							if (attr.hasOwnProperty("block_wrap")) {
2111 2111
 								block_wrap = attr.block_wrap;
2112 2112
 							}
2113 2113
 							return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align});
2114 2114
 							<?php
2115
-							}
2116
-							?>
2115
+                            }
2116
+                            ?>
2117 2117
 
2118 2118
 
2119 2119
 						}
@@ -2121,30 +2121,30 @@  discard block
 block discarded – undo
2121 2121
 				})();
2122 2122
 			</script>
2123 2123
 			<?php
2124
-			$output = ob_get_clean();
2124
+            $output = ob_get_clean();
2125 2125
 
2126
-			/*
2126
+            /*
2127 2127
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2128 2128
 			 */
2129 2129
 
2130
-			return str_replace( array(
2131
-				'<script>',
2132
-				'</script>'
2133
-			), '', $output );
2134
-		}
2130
+            return str_replace( array(
2131
+                '<script>',
2132
+                '</script>'
2133
+            ), '', $output );
2134
+        }
2135 2135
 
2136
-		public function block_row_start($key, $args){
2136
+        public function block_row_start($key, $args){
2137 2137
 
2138
-			// check for row
2139
-			if(!empty($args['row'])){
2138
+            // check for row
2139
+            if(!empty($args['row'])){
2140 2140
 
2141
-				if(!empty($args['row']['open'])){
2141
+                if(!empty($args['row']['open'])){
2142 2142
 
2143
-				// element require
2144
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2145
-				echo $element_require;
2143
+                // element require
2144
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2145
+                echo $element_require;
2146 2146
 
2147
-					if(false){?><script><?php }?>
2147
+                    if(false){?><script><?php }?>
2148 2148
 						el('div', {
2149 2149
 								className: 'bsui components-base-control',
2150 2150
 							},
@@ -2174,87 +2174,87 @@  discard block
 block discarded – undo
2174 2174
 									},
2175 2175
 
2176 2176
 					<?php
2177
-					if(false){?></script><?php }
2178
-				}elseif(!empty($args['row']['close'])){
2179
-					if(false){?><script><?php }?>
2177
+                    if(false){?></script><?php }
2178
+                }elseif(!empty($args['row']['close'])){
2179
+                    if(false){?><script><?php }?>
2180 2180
 						el(
2181 2181
 							'div',
2182 2182
 							{
2183 2183
 								className: 'col pl-0',
2184 2184
 							},
2185 2185
 					<?php
2186
-					if(false){?></script><?php }
2187
-				}else{
2188
-					if(false){?><script><?php }?>
2186
+                    if(false){?></script><?php }
2187
+                }else{
2188
+                    if(false){?><script><?php }?>
2189 2189
 						el(
2190 2190
 							'div',
2191 2191
 							{
2192 2192
 								className: 'col pl-0 pr-2',
2193 2193
 							},
2194 2194
 					<?php
2195
-					if(false){?></script><?php }
2196
-				}
2197
-
2198
-			}
2199
-
2200
-		}
2201
-
2202
-		public function block_row_end($key, $args){
2203
-
2204
-			if(!empty($args['row'])){
2205
-				// maybe close
2206
-				if(!empty($args['row']['close'])){
2207
-					echo "))";
2208
-				}
2209
-
2210
-				echo "),";
2211
-			}
2212
-		}
2213
-
2214
-		public function build_block_arguments( $key, $args ) {
2215
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2216
-			$options           = '';
2217
-			$extra             = '';
2218
-			$require           = '';
2219
-
2220
-			// `content` is a protected and special argument
2221
-			if ( $key == 'content' ) {
2222
-				return;
2223
-			}
2224
-
2225
-
2226
-			// icon
2227
-			$icon = '';
2228
-			if( !empty( $args['icon'] ) ){
2229
-				$icon .= "el('div', {";
2230
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2231
-									$icon .= "className: 'text-center',";
2232
-									$icon .= "title: '".addslashes( $args['title'] )."',";
2233
-								$icon .= "}),";
2234
-
2235
-				// blank title as its added to the icon.
2236
-				$args['title'] = '';
2237
-			}
2238
-
2239
-			// require advanced
2240
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2241
-
2242
-			// element require
2243
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2244
-
2245
-
2246
-			$onchange  = "props.setAttributes({ $key: $key } )";
2247
-			$onchangecomplete  = "";
2248
-			$value     = "props.attributes.$key";
2249
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2250
-			if ( in_array( $args['type'], $text_type ) ) {
2251
-				$type = 'TextControl';
2252
-				// Save numbers as numbers and not strings
2253
-				if ( $args['type'] == 'number' ) {
2254
-					$onchange = "props.setAttributes({ $key: Number($key) } )";
2255
-				}
2256
-			}
2257
-			/*
2195
+                    if(false){?></script><?php }
2196
+                }
2197
+
2198
+            }
2199
+
2200
+        }
2201
+
2202
+        public function block_row_end($key, $args){
2203
+
2204
+            if(!empty($args['row'])){
2205
+                // maybe close
2206
+                if(!empty($args['row']['close'])){
2207
+                    echo "))";
2208
+                }
2209
+
2210
+                echo "),";
2211
+            }
2212
+        }
2213
+
2214
+        public function build_block_arguments( $key, $args ) {
2215
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2216
+            $options           = '';
2217
+            $extra             = '';
2218
+            $require           = '';
2219
+
2220
+            // `content` is a protected and special argument
2221
+            if ( $key == 'content' ) {
2222
+                return;
2223
+            }
2224
+
2225
+
2226
+            // icon
2227
+            $icon = '';
2228
+            if( !empty( $args['icon'] ) ){
2229
+                $icon .= "el('div', {";
2230
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2231
+                                    $icon .= "className: 'text-center',";
2232
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
2233
+                                $icon .= "}),";
2234
+
2235
+                // blank title as its added to the icon.
2236
+                $args['title'] = '';
2237
+            }
2238
+
2239
+            // require advanced
2240
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2241
+
2242
+            // element require
2243
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2244
+
2245
+
2246
+            $onchange  = "props.setAttributes({ $key: $key } )";
2247
+            $onchangecomplete  = "";
2248
+            $value     = "props.attributes.$key";
2249
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2250
+            if ( in_array( $args['type'], $text_type ) ) {
2251
+                $type = 'TextControl';
2252
+                // Save numbers as numbers and not strings
2253
+                if ( $args['type'] == 'number' ) {
2254
+                    $onchange = "props.setAttributes({ $key: Number($key) } )";
2255
+                }
2256
+            }
2257
+            /*
2258 2258
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
2259 2259
 						elseif($args['type']=='tabs'){
2260 2260
 							?>
@@ -2288,85 +2288,85 @@  discard block
 block discarded – undo
2288 2288
 							return;
2289 2289
 						}
2290 2290
 			*/
2291
-			elseif ( $args['type'] == 'color' ) {
2292
-				$type = 'ColorPicker';
2293
-				$onchange = "";
2294
-				$extra = "color: $value,";
2295
-				if(!empty($args['disable_alpha'])){
2296
-					$extra .= "disableAlpha: true,";
2297
-				}
2298
-				$onchangecomplete = "onChangeComplete: function($key) {
2291
+            elseif ( $args['type'] == 'color' ) {
2292
+                $type = 'ColorPicker';
2293
+                $onchange = "";
2294
+                $extra = "color: $value,";
2295
+                if(!empty($args['disable_alpha'])){
2296
+                    $extra .= "disableAlpha: true,";
2297
+                }
2298
+                $onchangecomplete = "onChangeComplete: function($key) {
2299 2299
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
2300 2300
                         props.setAttributes({
2301 2301
                             $key: value
2302 2302
                         });
2303 2303
                     },";
2304
-			}
2305
-			elseif ( $args['type'] == 'checkbox' ) {
2306
-				$type = 'CheckboxControl';
2307
-				$extra .= "checked: props.attributes.$key,";
2308
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2309
-			} elseif ( $args['type'] == 'textarea' ) {
2310
-				$type = 'TextareaControl';
2311
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2312
-				$type = 'SelectControl';
2313
-
2314
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2315
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2316
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2317
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2318
-				}else {
2319
-
2320
-					if ( ! empty( $args['options'] ) ) {
2321
-						$options .= "options: [";
2322
-						foreach ( $args['options'] as $option_val => $option_label ) {
2323
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2324
-						}
2325
-						$options .= "],";
2326
-					}
2327
-				}
2328
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2329
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px"}, ';
2330
-				}
2331
-			} elseif ( $args['type'] == 'alignment' ) {
2332
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2333
-			}elseif ( $args['type'] == 'margins' ) {
2334
-
2335
-			} else {
2336
-				return;// if we have not implemented the control then don't break the JS.
2337
-			}
2338
-
2339
-
2340
-
2341
-			// color input does not show the labels so we add them
2342
-			if($args['type']=='color'){
2343
-				// add show only if advanced
2344
-				echo $require_advanced;
2345
-				// add setting require if defined
2346
-				echo $element_require;
2347
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2348
-			}
2349
-
2350
-			// add show only if advanced
2351
-			echo $require_advanced;
2352
-			// add setting require if defined
2353
-			echo $element_require;
2354
-
2355
-			// icon
2356
-			echo $icon;
2357
-			?>
2304
+            }
2305
+            elseif ( $args['type'] == 'checkbox' ) {
2306
+                $type = 'CheckboxControl';
2307
+                $extra .= "checked: props.attributes.$key,";
2308
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2309
+            } elseif ( $args['type'] == 'textarea' ) {
2310
+                $type = 'TextareaControl';
2311
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2312
+                $type = 'SelectControl';
2313
+
2314
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2315
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2316
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2317
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2318
+                }else {
2319
+
2320
+                    if ( ! empty( $args['options'] ) ) {
2321
+                        $options .= "options: [";
2322
+                        foreach ( $args['options'] as $option_val => $option_label ) {
2323
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2324
+                        }
2325
+                        $options .= "],";
2326
+                    }
2327
+                }
2328
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2329
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px"}, ';
2330
+                }
2331
+            } elseif ( $args['type'] == 'alignment' ) {
2332
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2333
+            }elseif ( $args['type'] == 'margins' ) {
2334
+
2335
+            } else {
2336
+                return;// if we have not implemented the control then don't break the JS.
2337
+            }
2338
+
2339
+
2340
+
2341
+            // color input does not show the labels so we add them
2342
+            if($args['type']=='color'){
2343
+                // add show only if advanced
2344
+                echo $require_advanced;
2345
+                // add setting require if defined
2346
+                echo $element_require;
2347
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2348
+            }
2349
+
2350
+            // add show only if advanced
2351
+            echo $require_advanced;
2352
+            // add setting require if defined
2353
+            echo $element_require;
2354
+
2355
+            // icon
2356
+            echo $icon;
2357
+            ?>
2358 2358
 			el( wp.components.<?php echo $type; ?>, {
2359 2359
 			label: '<?php echo addslashes( $args['title'] ); ?>',
2360 2360
 			help: '<?php if ( isset( $args['desc'] ) ) {
2361
-				echo addslashes( $args['desc'] );
2362
-			} ?>',
2361
+                echo addslashes( $args['desc'] );
2362
+            } ?>',
2363 2363
 			value: <?php echo $value; ?>,
2364 2364
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
2365
-				echo "type: '" . addslashes( $args['type'] ) . "',";
2366
-			} ?>
2365
+                echo "type: '" . addslashes( $args['type'] ) . "',";
2366
+            } ?>
2367 2367
 			<?php if ( ! empty( $args['placeholder'] ) ) {
2368
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2369
-			} ?>
2368
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2369
+            } ?>
2370 2370
 			<?php echo $options; ?>
2371 2371
 			<?php echo $extra; ?>
2372 2372
 			<?php echo $custom_attributes; ?>
@@ -2378,608 +2378,608 @@  discard block
 block discarded – undo
2378 2378
 			<?php
2379 2379
 
2380 2380
 
2381
-		}
2382
-
2383
-		/**
2384
-		 * Convert an array of attributes to block string.
2385
-		 *
2386
-		 * @todo there is prob a faster way to do this, also we could add some validation here.
2387
-		 *
2388
-		 * @param $custom_attributes
2389
-		 *
2390
-		 * @return string
2391
-		 */
2392
-		public function array_to_attributes( $custom_attributes, $html = false ) {
2393
-			$attributes = '';
2394
-			if ( ! empty( $custom_attributes ) ) {
2395
-
2396
-				if ( $html ) {
2397
-					foreach ( $custom_attributes as $key => $val ) {
2398
-						$attributes .= " $key='$val' ";
2399
-					}
2400
-				} else {
2401
-					foreach ( $custom_attributes as $key => $val ) {
2402
-						$attributes .= "'$key': '$val',";
2403
-					}
2404
-				}
2405
-			}
2406
-
2407
-			return $attributes;
2408
-		}
2409
-
2410
-		/**
2411
-		 * A self looping function to create the output for JS block elements.
2412
-		 *
2413
-		 * This is what is output in the WP Editor visual view.
2414
-		 *
2415
-		 * @param $args
2416
-		 */
2417
-		public function block_element( $args ) {
2418
-
2419
-
2420
-			if ( ! empty( $args ) ) {
2421
-				foreach ( $args as $element => $new_args ) {
2422
-
2423
-					if ( is_array( $new_args ) ) { // its an element
2424
-
2425
-
2426
-						if ( isset( $new_args['element'] ) ) {
2427
-
2428
-							if ( isset( $new_args['element_require'] ) ) {
2429
-								echo str_replace( array(
2430
-										"'+",
2431
-										"+'"
2432
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2433
-								unset( $new_args['element_require'] );
2434
-							}
2435
-
2436
-							echo "\n el( '" . $new_args['element'] . "', {";
2437
-
2438
-							// get the attributes
2439
-							foreach ( $new_args as $new_key => $new_value ) {
2440
-
2441
-
2442
-								if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2443
-									// do nothing
2444
-								} else {
2445
-									echo $this->block_element( array( $new_key => $new_value ) );
2446
-								}
2447
-							}
2448
-
2449
-							echo "},";// end attributes
2450
-
2451
-							// get the content
2452
-							$first_item = 0;
2453
-							foreach ( $new_args as $new_key => $new_value ) {
2454
-								if ( $new_key === 'content' || is_array( $new_value ) ) {
2455
-
2456
-									if ( $new_key === 'content' ) {
2457
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2458
-									}
2459
-
2460
-									if ( is_array( $new_value ) ) {
2461
-
2462
-										if ( isset( $new_value['element_require'] ) ) {
2463
-											echo str_replace( array(
2464
-													"'+",
2465
-													"+'"
2466
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2467
-											unset( $new_value['element_require'] );
2468
-										}
2469
-
2470
-										if ( isset( $new_value['element_repeat'] ) ) {
2471
-											$x = 1;
2472
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
2473
-												$this->block_element( array( '' => $new_value ) );
2474
-												$x ++;
2475
-											}
2476
-										} else {
2477
-											$this->block_element( array( '' => $new_value ) );
2478
-										}
2479
-									}
2480
-									$first_item ++;
2481
-								}
2482
-							}
2483
-
2484
-							echo ")";// end content
2485
-
2486
-							echo ", \n";
2487
-
2488
-						}
2489
-					} else {
2490
-
2491
-						if ( substr( $element, 0, 3 ) === "if_" ) {
2492
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2493
-						} elseif ( $element == 'style' ) {
2494
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2495
-						} else {
2496
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2497
-						}
2498
-
2499
-					}
2500
-				}
2501
-			}
2502
-		}
2503
-
2504
-		/**
2505
-		 * Replace block attributes placeholders with the proper naming.
2506
-		 *
2507
-		 * @param $string
2508
-		 *
2509
-		 * @return mixed
2510
-		 */
2511
-		public function block_props_replace( $string, $no_wrap = false ) {
2512
-
2513
-			if ( $no_wrap ) {
2514
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2515
-			} else {
2516
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2517
-			}
2518
-
2519
-			return $string;
2520
-		}
2521
-
2522
-		/**
2523
-		 * Outputs the content of the widget
2524
-		 *
2525
-		 * @param array $args
2526
-		 * @param array $instance
2527
-		 */
2528
-		public function widget( $args, $instance ) {
2529
-
2530
-			// get the filtered values
2531
-			$argument_values = $this->argument_values( $instance );
2532
-			$argument_values = $this->string_to_bool( $argument_values );
2533
-			$output          = $this->output( $argument_values, $args );
2534
-
2535
-			$no_wrap = false;
2536
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2537
-				$no_wrap = true;
2538
-			}
2539
-
2540
-			ob_start();
2541
-			if ( $output && ! $no_wrap ) {
2542
-
2543
-				$class_original = $this->options['widget_ops']['classname'];
2544
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2545
-
2546
-				// Before widget
2547
-				$before_widget = $args['before_widget'];
2548
-				$before_widget = str_replace($class_original,$class,$before_widget);
2549
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2550
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2551
-
2552
-				// After widget
2553
-				$after_widget = $args['after_widget'];
2554
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2555
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2556
-
2557
-				echo $before_widget;
2558
-				// elementor strips the widget wrapping div so we check for and add it back if needed
2559
-				if ( $this->is_elementor_widget_output() ) {
2560
-					// Filter class & attrs for elementor widget output.
2561
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
2562
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
2563
-
2564
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
2565
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
2566
-
2567
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
2568
-				}
2569
-				echo $this->output_title( $args, $instance );
2570
-				echo $output;
2571
-				if ( $this->is_elementor_widget_output() ) {
2572
-					echo "</span>";
2573
-				}
2574
-				echo $after_widget;
2575
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2576
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2577
-				echo $output;
2578
-			} elseif ( $output && $no_wrap ) {
2579
-				echo $output;
2580
-			}
2581
-			$output = ob_get_clean();
2582
-
2583
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2584
-
2585
-			echo $output;
2586
-		}
2587
-
2588
-		/**
2589
-		 * Tests if the current output is inside a elementor container.
2590
-		 *
2591
-		 * @since 1.0.4
2592
-		 * @return bool
2593
-		 */
2594
-		public function is_elementor_widget_output() {
2595
-			$result = false;
2596
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2597
-				$result = true;
2598
-			}
2599
-
2600
-			return $result;
2601
-		}
2602
-
2603
-		/**
2604
-		 * Tests if the current output is inside a elementor preview.
2605
-		 *
2606
-		 * @since 1.0.4
2607
-		 * @return bool
2608
-		 */
2609
-		public function is_elementor_preview() {
2610
-			$result = false;
2611
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2612
-				$result = true;
2613
-			}
2614
-
2615
-			return $result;
2616
-		}
2617
-
2618
-		/**
2619
-		 * Tests if the current output is inside a Divi preview.
2620
-		 *
2621
-		 * @since 1.0.6
2622
-		 * @return bool
2623
-		 */
2624
-		public function is_divi_preview() {
2625
-			$result = false;
2626
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2627
-				$result = true;
2628
-			}
2629
-
2630
-			return $result;
2631
-		}
2632
-
2633
-		/**
2634
-		 * Tests if the current output is inside a Beaver builder preview.
2635
-		 *
2636
-		 * @since 1.0.6
2637
-		 * @return bool
2638
-		 */
2639
-		public function is_beaver_preview() {
2640
-			$result = false;
2641
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
2642
-				$result = true;
2643
-			}
2644
-
2645
-			return $result;
2646
-		}
2647
-
2648
-		/**
2649
-		 * Tests if the current output is inside a siteorigin builder preview.
2650
-		 *
2651
-		 * @since 1.0.6
2652
-		 * @return bool
2653
-		 */
2654
-		public function is_siteorigin_preview() {
2655
-			$result = false;
2656
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2657
-				$result = true;
2658
-			}
2659
-
2660
-			return $result;
2661
-		}
2662
-
2663
-		/**
2664
-		 * Tests if the current output is inside a cornerstone builder preview.
2665
-		 *
2666
-		 * @since 1.0.8
2667
-		 * @return bool
2668
-		 */
2669
-		public function is_cornerstone_preview() {
2670
-			$result = false;
2671
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2672
-				$result = true;
2673
-			}
2674
-
2675
-			return $result;
2676
-		}
2677
-
2678
-		/**
2679
-		 * Tests if the current output is inside a fusion builder preview.
2680
-		 *
2681
-		 * @since 1.1.0
2682
-		 * @return bool
2683
-		 */
2684
-		public function is_fusion_preview() {
2685
-			$result = false;
2686
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2687
-				$result = true;
2688
-			}
2689
-
2690
-			return $result;
2691
-		}
2692
-
2693
-		/**
2694
-		 * Tests if the current output is inside a Oxygen builder preview.
2695
-		 *
2696
-		 * @since 1.0.18
2697
-		 * @return bool
2698
-		 */
2699
-		public function is_oxygen_preview() {
2700
-			$result = false;
2701
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2702
-				$result = true;
2703
-			}
2704
-
2705
-			return $result;
2706
-		}
2707
-
2708
-		/**
2709
-		 * General function to check if we are in a preview situation.
2710
-		 *
2711
-		 * @since 1.0.6
2712
-		 * @return bool
2713
-		 */
2714
-		public function is_preview() {
2715
-			$preview = false;
2716
-			if ( $this->is_divi_preview() ) {
2717
-				$preview = true;
2718
-			} elseif ( $this->is_elementor_preview() ) {
2719
-				$preview = true;
2720
-			} elseif ( $this->is_beaver_preview() ) {
2721
-				$preview = true;
2722
-			} elseif ( $this->is_siteorigin_preview() ) {
2723
-				$preview = true;
2724
-			} elseif ( $this->is_cornerstone_preview() ) {
2725
-				$preview = true;
2726
-			} elseif ( $this->is_fusion_preview() ) {
2727
-				$preview = true;
2728
-			} elseif ( $this->is_oxygen_preview() ) {
2729
-				$preview = true;
2730
-			} elseif( $this->is_block_content_call() ) {
2731
-				$preview = true;
2732
-			}
2733
-
2734
-			return $preview;
2735
-		}
2736
-
2737
-		/**
2738
-		 * Output the super title.
2739
-		 *
2740
-		 * @param $args
2741
-		 * @param array $instance
2742
-		 *
2743
-		 * @return string
2744
-		 */
2745
-		public function output_title( $args, $instance = array() ) {
2746
-			$output = '';
2747
-			if ( ! empty( $instance['title'] ) ) {
2748
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2749
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2750
-
2751
-				if(empty($instance['widget_title_tag'])){
2752
-					$output = $args['before_title'] . $title . $args['after_title'];
2753
-				}else{
2754
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
2755
-
2756
-					// classes
2757
-					$title_classes = array();
2758
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2759
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2760
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2761
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2762
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2763
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2764
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2765
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2766
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2767
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2768
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2769
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2770
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2771
-
2772
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2773
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
2774
-				}
2775
-
2776
-			}
2777
-
2778
-			return $output;
2779
-		}
2780
-
2781
-		/**
2782
-		 * Outputs the options form inputs for the widget.
2783
-		 *
2784
-		 * @param array $instance The widget options.
2785
-		 */
2786
-		public function form( $instance ) {
2787
-
2788
-			// set widget instance
2789
-			$this->instance = $instance;
2790
-
2791
-			// set it as a SD widget
2792
-			echo $this->widget_advanced_toggle();
2793
-
2794
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2795
-			$arguments_raw = $this->get_arguments();
2796
-
2797
-			if ( is_array( $arguments_raw ) ) {
2798
-
2799
-				$arguments = $this->group_arguments( $arguments_raw );
2800
-
2801
-				// Do we have sections?
2802
-				$has_sections = $arguments == $arguments_raw ? false : true;
2803
-
2804
-
2805
-				if ( $has_sections ) {
2806
-					$panel_count = 0;
2807
-					foreach ( $arguments as $key => $args ) {
2808
-
2809
-						?>
2381
+        }
2382
+
2383
+        /**
2384
+         * Convert an array of attributes to block string.
2385
+         *
2386
+         * @todo there is prob a faster way to do this, also we could add some validation here.
2387
+         *
2388
+         * @param $custom_attributes
2389
+         *
2390
+         * @return string
2391
+         */
2392
+        public function array_to_attributes( $custom_attributes, $html = false ) {
2393
+            $attributes = '';
2394
+            if ( ! empty( $custom_attributes ) ) {
2395
+
2396
+                if ( $html ) {
2397
+                    foreach ( $custom_attributes as $key => $val ) {
2398
+                        $attributes .= " $key='$val' ";
2399
+                    }
2400
+                } else {
2401
+                    foreach ( $custom_attributes as $key => $val ) {
2402
+                        $attributes .= "'$key': '$val',";
2403
+                    }
2404
+                }
2405
+            }
2406
+
2407
+            return $attributes;
2408
+        }
2409
+
2410
+        /**
2411
+         * A self looping function to create the output for JS block elements.
2412
+         *
2413
+         * This is what is output in the WP Editor visual view.
2414
+         *
2415
+         * @param $args
2416
+         */
2417
+        public function block_element( $args ) {
2418
+
2419
+
2420
+            if ( ! empty( $args ) ) {
2421
+                foreach ( $args as $element => $new_args ) {
2422
+
2423
+                    if ( is_array( $new_args ) ) { // its an element
2424
+
2425
+
2426
+                        if ( isset( $new_args['element'] ) ) {
2427
+
2428
+                            if ( isset( $new_args['element_require'] ) ) {
2429
+                                echo str_replace( array(
2430
+                                        "'+",
2431
+                                        "+'"
2432
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2433
+                                unset( $new_args['element_require'] );
2434
+                            }
2435
+
2436
+                            echo "\n el( '" . $new_args['element'] . "', {";
2437
+
2438
+                            // get the attributes
2439
+                            foreach ( $new_args as $new_key => $new_value ) {
2440
+
2441
+
2442
+                                if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2443
+                                    // do nothing
2444
+                                } else {
2445
+                                    echo $this->block_element( array( $new_key => $new_value ) );
2446
+                                }
2447
+                            }
2448
+
2449
+                            echo "},";// end attributes
2450
+
2451
+                            // get the content
2452
+                            $first_item = 0;
2453
+                            foreach ( $new_args as $new_key => $new_value ) {
2454
+                                if ( $new_key === 'content' || is_array( $new_value ) ) {
2455
+
2456
+                                    if ( $new_key === 'content' ) {
2457
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2458
+                                    }
2459
+
2460
+                                    if ( is_array( $new_value ) ) {
2461
+
2462
+                                        if ( isset( $new_value['element_require'] ) ) {
2463
+                                            echo str_replace( array(
2464
+                                                    "'+",
2465
+                                                    "+'"
2466
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2467
+                                            unset( $new_value['element_require'] );
2468
+                                        }
2469
+
2470
+                                        if ( isset( $new_value['element_repeat'] ) ) {
2471
+                                            $x = 1;
2472
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
2473
+                                                $this->block_element( array( '' => $new_value ) );
2474
+                                                $x ++;
2475
+                                            }
2476
+                                        } else {
2477
+                                            $this->block_element( array( '' => $new_value ) );
2478
+                                        }
2479
+                                    }
2480
+                                    $first_item ++;
2481
+                                }
2482
+                            }
2483
+
2484
+                            echo ")";// end content
2485
+
2486
+                            echo ", \n";
2487
+
2488
+                        }
2489
+                    } else {
2490
+
2491
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
2492
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2493
+                        } elseif ( $element == 'style' ) {
2494
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2495
+                        } else {
2496
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2497
+                        }
2498
+
2499
+                    }
2500
+                }
2501
+            }
2502
+        }
2503
+
2504
+        /**
2505
+         * Replace block attributes placeholders with the proper naming.
2506
+         *
2507
+         * @param $string
2508
+         *
2509
+         * @return mixed
2510
+         */
2511
+        public function block_props_replace( $string, $no_wrap = false ) {
2512
+
2513
+            if ( $no_wrap ) {
2514
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2515
+            } else {
2516
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2517
+            }
2518
+
2519
+            return $string;
2520
+        }
2521
+
2522
+        /**
2523
+         * Outputs the content of the widget
2524
+         *
2525
+         * @param array $args
2526
+         * @param array $instance
2527
+         */
2528
+        public function widget( $args, $instance ) {
2529
+
2530
+            // get the filtered values
2531
+            $argument_values = $this->argument_values( $instance );
2532
+            $argument_values = $this->string_to_bool( $argument_values );
2533
+            $output          = $this->output( $argument_values, $args );
2534
+
2535
+            $no_wrap = false;
2536
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2537
+                $no_wrap = true;
2538
+            }
2539
+
2540
+            ob_start();
2541
+            if ( $output && ! $no_wrap ) {
2542
+
2543
+                $class_original = $this->options['widget_ops']['classname'];
2544
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2545
+
2546
+                // Before widget
2547
+                $before_widget = $args['before_widget'];
2548
+                $before_widget = str_replace($class_original,$class,$before_widget);
2549
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2550
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2551
+
2552
+                // After widget
2553
+                $after_widget = $args['after_widget'];
2554
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2555
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2556
+
2557
+                echo $before_widget;
2558
+                // elementor strips the widget wrapping div so we check for and add it back if needed
2559
+                if ( $this->is_elementor_widget_output() ) {
2560
+                    // Filter class & attrs for elementor widget output.
2561
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
2562
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
2563
+
2564
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
2565
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
2566
+
2567
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
2568
+                }
2569
+                echo $this->output_title( $args, $instance );
2570
+                echo $output;
2571
+                if ( $this->is_elementor_widget_output() ) {
2572
+                    echo "</span>";
2573
+                }
2574
+                echo $after_widget;
2575
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2576
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2577
+                echo $output;
2578
+            } elseif ( $output && $no_wrap ) {
2579
+                echo $output;
2580
+            }
2581
+            $output = ob_get_clean();
2582
+
2583
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2584
+
2585
+            echo $output;
2586
+        }
2587
+
2588
+        /**
2589
+         * Tests if the current output is inside a elementor container.
2590
+         *
2591
+         * @since 1.0.4
2592
+         * @return bool
2593
+         */
2594
+        public function is_elementor_widget_output() {
2595
+            $result = false;
2596
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2597
+                $result = true;
2598
+            }
2599
+
2600
+            return $result;
2601
+        }
2602
+
2603
+        /**
2604
+         * Tests if the current output is inside a elementor preview.
2605
+         *
2606
+         * @since 1.0.4
2607
+         * @return bool
2608
+         */
2609
+        public function is_elementor_preview() {
2610
+            $result = false;
2611
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2612
+                $result = true;
2613
+            }
2614
+
2615
+            return $result;
2616
+        }
2617
+
2618
+        /**
2619
+         * Tests if the current output is inside a Divi preview.
2620
+         *
2621
+         * @since 1.0.6
2622
+         * @return bool
2623
+         */
2624
+        public function is_divi_preview() {
2625
+            $result = false;
2626
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2627
+                $result = true;
2628
+            }
2629
+
2630
+            return $result;
2631
+        }
2632
+
2633
+        /**
2634
+         * Tests if the current output is inside a Beaver builder preview.
2635
+         *
2636
+         * @since 1.0.6
2637
+         * @return bool
2638
+         */
2639
+        public function is_beaver_preview() {
2640
+            $result = false;
2641
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
2642
+                $result = true;
2643
+            }
2644
+
2645
+            return $result;
2646
+        }
2647
+
2648
+        /**
2649
+         * Tests if the current output is inside a siteorigin builder preview.
2650
+         *
2651
+         * @since 1.0.6
2652
+         * @return bool
2653
+         */
2654
+        public function is_siteorigin_preview() {
2655
+            $result = false;
2656
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2657
+                $result = true;
2658
+            }
2659
+
2660
+            return $result;
2661
+        }
2662
+
2663
+        /**
2664
+         * Tests if the current output is inside a cornerstone builder preview.
2665
+         *
2666
+         * @since 1.0.8
2667
+         * @return bool
2668
+         */
2669
+        public function is_cornerstone_preview() {
2670
+            $result = false;
2671
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2672
+                $result = true;
2673
+            }
2674
+
2675
+            return $result;
2676
+        }
2677
+
2678
+        /**
2679
+         * Tests if the current output is inside a fusion builder preview.
2680
+         *
2681
+         * @since 1.1.0
2682
+         * @return bool
2683
+         */
2684
+        public function is_fusion_preview() {
2685
+            $result = false;
2686
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2687
+                $result = true;
2688
+            }
2689
+
2690
+            return $result;
2691
+        }
2692
+
2693
+        /**
2694
+         * Tests if the current output is inside a Oxygen builder preview.
2695
+         *
2696
+         * @since 1.0.18
2697
+         * @return bool
2698
+         */
2699
+        public function is_oxygen_preview() {
2700
+            $result = false;
2701
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2702
+                $result = true;
2703
+            }
2704
+
2705
+            return $result;
2706
+        }
2707
+
2708
+        /**
2709
+         * General function to check if we are in a preview situation.
2710
+         *
2711
+         * @since 1.0.6
2712
+         * @return bool
2713
+         */
2714
+        public function is_preview() {
2715
+            $preview = false;
2716
+            if ( $this->is_divi_preview() ) {
2717
+                $preview = true;
2718
+            } elseif ( $this->is_elementor_preview() ) {
2719
+                $preview = true;
2720
+            } elseif ( $this->is_beaver_preview() ) {
2721
+                $preview = true;
2722
+            } elseif ( $this->is_siteorigin_preview() ) {
2723
+                $preview = true;
2724
+            } elseif ( $this->is_cornerstone_preview() ) {
2725
+                $preview = true;
2726
+            } elseif ( $this->is_fusion_preview() ) {
2727
+                $preview = true;
2728
+            } elseif ( $this->is_oxygen_preview() ) {
2729
+                $preview = true;
2730
+            } elseif( $this->is_block_content_call() ) {
2731
+                $preview = true;
2732
+            }
2733
+
2734
+            return $preview;
2735
+        }
2736
+
2737
+        /**
2738
+         * Output the super title.
2739
+         *
2740
+         * @param $args
2741
+         * @param array $instance
2742
+         *
2743
+         * @return string
2744
+         */
2745
+        public function output_title( $args, $instance = array() ) {
2746
+            $output = '';
2747
+            if ( ! empty( $instance['title'] ) ) {
2748
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2749
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2750
+
2751
+                if(empty($instance['widget_title_tag'])){
2752
+                    $output = $args['before_title'] . $title . $args['after_title'];
2753
+                }else{
2754
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
2755
+
2756
+                    // classes
2757
+                    $title_classes = array();
2758
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2759
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2760
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2761
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2762
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2763
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2764
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2765
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2766
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2767
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2768
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2769
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2770
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2771
+
2772
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2773
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
2774
+                }
2775
+
2776
+            }
2777
+
2778
+            return $output;
2779
+        }
2780
+
2781
+        /**
2782
+         * Outputs the options form inputs for the widget.
2783
+         *
2784
+         * @param array $instance The widget options.
2785
+         */
2786
+        public function form( $instance ) {
2787
+
2788
+            // set widget instance
2789
+            $this->instance = $instance;
2790
+
2791
+            // set it as a SD widget
2792
+            echo $this->widget_advanced_toggle();
2793
+
2794
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2795
+            $arguments_raw = $this->get_arguments();
2796
+
2797
+            if ( is_array( $arguments_raw ) ) {
2798
+
2799
+                $arguments = $this->group_arguments( $arguments_raw );
2800
+
2801
+                // Do we have sections?
2802
+                $has_sections = $arguments == $arguments_raw ? false : true;
2803
+
2804
+
2805
+                if ( $has_sections ) {
2806
+                    $panel_count = 0;
2807
+                    foreach ( $arguments as $key => $args ) {
2808
+
2809
+                        ?>
2810 2810
 						<script>
2811 2811
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
2812 2812
 						</script>
2813 2813
 						<?php
2814 2814
 
2815
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
2816
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2817
-						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>";
2818
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2815
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
2816
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2817
+                        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>";
2818
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2819 2819
 
2820
-						foreach ( $args as $k => $a ) {
2820
+                        foreach ( $args as $k => $a ) {
2821 2821
 
2822
-							$this->widget_inputs_row_start($k, $a);
2823
-							$this->widget_inputs( $a, $instance );
2824
-							$this->widget_inputs_row_end($k, $a);
2822
+                            $this->widget_inputs_row_start($k, $a);
2823
+                            $this->widget_inputs( $a, $instance );
2824
+                            $this->widget_inputs_row_end($k, $a);
2825 2825
 
2826
-						}
2826
+                        }
2827 2827
 
2828
-						echo "</div>";
2828
+                        echo "</div>";
2829 2829
 
2830
-						$panel_count ++;
2830
+                        $panel_count ++;
2831 2831
 
2832
-					}
2833
-				} else {
2834
-					foreach ( $arguments as $key => $args ) {
2835
-						$this->widget_inputs_row_start($key, $args);
2836
-						$this->widget_inputs( $args, $instance );
2837
-						$this->widget_inputs_row_end($key, $args);
2838
-					}
2839
-				}
2832
+                    }
2833
+                } else {
2834
+                    foreach ( $arguments as $key => $args ) {
2835
+                        $this->widget_inputs_row_start($key, $args);
2836
+                        $this->widget_inputs( $args, $instance );
2837
+                        $this->widget_inputs_row_end($key, $args);
2838
+                    }
2839
+                }
2840 2840
 
2841
-			}
2842
-		}
2841
+            }
2842
+        }
2843 2843
 
2844
-		public function widget_inputs_row_start($key, $args){
2845
-			if(!empty($args['row'])){
2846
-				// maybe open
2847
-				if(!empty($args['row']['open'])){
2848
-					?>
2844
+        public function widget_inputs_row_start($key, $args){
2845
+            if(!empty($args['row'])){
2846
+                // maybe open
2847
+                if(!empty($args['row']['open'])){
2848
+                    ?>
2849 2849
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
2850
-						echo $this->convert_element_require( $args['row']['element_require'] );
2851
-					} ?>'>
2850
+                        echo $this->convert_element_require( $args['row']['element_require'] );
2851
+                    } ?>'>
2852 2852
 					<?php if(!empty($args['row']['title'])){ ?>
2853 2853
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
2854 2854
 					<?php }?>
2855 2855
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
2856 2856
 					<div class='col pr-2'>
2857 2857
 					<?php
2858
-				}elseif(!empty($args['row']['close'])){
2859
-					echo "<div class='col pl-0'>";
2860
-				}else{
2861
-					echo "<div class='col pl-0 pr-2'>";
2862
-				}
2863
-			}
2864
-		}
2865
-
2866
-		public function widget_inputs_row_end($key, $args){
2867
-
2868
-			if(!empty($args['row'])){
2869
-				// maybe close
2870
-				if(!empty($args['row']['close'])){
2871
-					echo "</div></div>";
2872
-				}
2873
-
2874
-				echo "</div>";
2875
-			}
2876
-		}
2877
-
2878
-		/**
2879
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
2880
-		 *
2881
-		 * @return string
2882
-		 */
2883
-		public function widget_advanced_toggle() {
2884
-
2885
-			$output = '';
2886
-			if ( $this->block_show_advanced() ) {
2887
-				$val = 1;
2888
-			} else {
2889
-				$val = 0;
2890
-			}
2891
-
2892
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2893
-
2894
-			return $output;
2895
-		}
2896
-
2897
-		/**
2898
-		 * Convert require element.
2899
-		 *
2900
-		 * @since 1.0.0
2901
-		 *
2902
-		 * @param string $input Input element.
2903
-		 *
2904
-		 * @return string $output
2905
-		 */
2906
-		public function convert_element_require( $input ) {
2907
-
2908
-			$input = str_replace( "'", '"', $input );// we only want double quotes
2909
-
2910
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
2911
-				"jQuery(form).find('[data-argument=\"",
2912
-				"\"]').find('input,select,textarea').val()"
2913
-			), $input ) );
2914
-
2915
-			return $output;
2916
-		}
2917
-
2918
-		/**
2919
-		 * Builds the inputs for the widget options.
2920
-		 *
2921
-		 * @param $args
2922
-		 * @param $instance
2923
-		 */
2924
-		public function widget_inputs( $args, $instance ) {
2925
-
2926
-			$class             = "";
2927
-			$element_require   = "";
2928
-			$custom_attributes = "";
2929
-
2930
-			// get value
2931
-			if ( isset( $instance[ $args['name'] ] ) ) {
2932
-				$value = $instance[ $args['name'] ];
2933
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2934
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2935
-			} else {
2936
-				$value = '';
2937
-			}
2938
-
2939
-			// get placeholder
2940
-			if ( ! empty( $args['placeholder'] ) ) {
2941
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2942
-			} else {
2943
-				$placeholder = '';
2944
-			}
2945
-
2946
-			// get if advanced
2947
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2948
-				$class .= " sd-advanced-setting ";
2949
-			}
2950
-
2951
-			// element_require
2952
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2953
-				$element_require = $args['element_require'];
2954
-			}
2955
-
2956
-			// custom_attributes
2957
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2958
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2959
-			}
2960
-
2961
-
2962
-			// before wrapper
2963
-			?>
2858
+                }elseif(!empty($args['row']['close'])){
2859
+                    echo "<div class='col pl-0'>";
2860
+                }else{
2861
+                    echo "<div class='col pl-0 pr-2'>";
2862
+                }
2863
+            }
2864
+        }
2865
+
2866
+        public function widget_inputs_row_end($key, $args){
2867
+
2868
+            if(!empty($args['row'])){
2869
+                // maybe close
2870
+                if(!empty($args['row']['close'])){
2871
+                    echo "</div></div>";
2872
+                }
2873
+
2874
+                echo "</div>";
2875
+            }
2876
+        }
2877
+
2878
+        /**
2879
+         * Get the hidden input that when added makes the advanced button show on widget settings.
2880
+         *
2881
+         * @return string
2882
+         */
2883
+        public function widget_advanced_toggle() {
2884
+
2885
+            $output = '';
2886
+            if ( $this->block_show_advanced() ) {
2887
+                $val = 1;
2888
+            } else {
2889
+                $val = 0;
2890
+            }
2891
+
2892
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2893
+
2894
+            return $output;
2895
+        }
2896
+
2897
+        /**
2898
+         * Convert require element.
2899
+         *
2900
+         * @since 1.0.0
2901
+         *
2902
+         * @param string $input Input element.
2903
+         *
2904
+         * @return string $output
2905
+         */
2906
+        public function convert_element_require( $input ) {
2907
+
2908
+            $input = str_replace( "'", '"', $input );// we only want double quotes
2909
+
2910
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
2911
+                "jQuery(form).find('[data-argument=\"",
2912
+                "\"]').find('input,select,textarea').val()"
2913
+            ), $input ) );
2914
+
2915
+            return $output;
2916
+        }
2917
+
2918
+        /**
2919
+         * Builds the inputs for the widget options.
2920
+         *
2921
+         * @param $args
2922
+         * @param $instance
2923
+         */
2924
+        public function widget_inputs( $args, $instance ) {
2925
+
2926
+            $class             = "";
2927
+            $element_require   = "";
2928
+            $custom_attributes = "";
2929
+
2930
+            // get value
2931
+            if ( isset( $instance[ $args['name'] ] ) ) {
2932
+                $value = $instance[ $args['name'] ];
2933
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2934
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2935
+            } else {
2936
+                $value = '';
2937
+            }
2938
+
2939
+            // get placeholder
2940
+            if ( ! empty( $args['placeholder'] ) ) {
2941
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2942
+            } else {
2943
+                $placeholder = '';
2944
+            }
2945
+
2946
+            // get if advanced
2947
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2948
+                $class .= " sd-advanced-setting ";
2949
+            }
2950
+
2951
+            // element_require
2952
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2953
+                $element_require = $args['element_require'];
2954
+            }
2955
+
2956
+            // custom_attributes
2957
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2958
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2959
+            }
2960
+
2961
+
2962
+            // before wrapper
2963
+            ?>
2964 2964
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
2965 2965
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
2966 2966
 			data-element_require='<?php if ( $element_require ) {
2967
-				echo $this->convert_element_require( $element_require );
2968
-			} ?>'
2967
+                echo $this->convert_element_require( $element_require );
2968
+            } ?>'
2969 2969
 			>
2970 2970
 			<?php
2971 2971
 
2972 2972
 
2973
-			switch ( $args['type'] ) {
2974
-				//array('text','password','number','email','tel','url','color')
2975
-				case "text":
2976
-				case "password":
2977
-				case "number":
2978
-				case "email":
2979
-				case "tel":
2980
-				case "url":
2981
-				case "color":
2982
-					?>
2973
+            switch ( $args['type'] ) {
2974
+                //array('text','password','number','email','tel','url','color')
2975
+                case "text":
2976
+                case "password":
2977
+                case "number":
2978
+                case "email":
2979
+                case "tel":
2980
+                case "url":
2981
+                case "color":
2982
+                    ?>
2983 2983
 					<label
2984 2984
 						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>
2985 2985
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -2990,47 +2990,47 @@  discard block
 block discarded – undo
2990 2990
 						                               value="<?php echo esc_attr( $value ); ?>">
2991 2991
 					<?php
2992 2992
 
2993
-					break;
2994
-				case "select":
2995
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2996
-					if ( $multiple ) {
2997
-						if ( empty( $value ) ) {
2998
-							$value = array();
2999
-						}
3000
-					}
3001
-					?>
2993
+                    break;
2994
+                case "select":
2995
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2996
+                    if ( $multiple ) {
2997
+                        if ( empty( $value ) ) {
2998
+                            $value = array();
2999
+                        }
3000
+                    }
3001
+                    ?>
3002 3002
 					<label
3003 3003
 						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>
3004 3004
 					<select <?php echo $placeholder; ?> class="widefat"
3005 3005
 						<?php echo $custom_attributes; ?>
3006 3006
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3007 3007
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
3008
-						                                if ( $multiple ) {
3009
-							                                echo "[]";
3010
-						                                } ?>"
3008
+                                                        if ( $multiple ) {
3009
+                                                            echo "[]";
3010
+                                                        } ?>"
3011 3011
 						<?php if ( $multiple ) {
3012
-							echo "multiple";
3013
-						} //@todo not implemented yet due to gutenberg not supporting it
3014
-						?>
3012
+                            echo "multiple";
3013
+                        } //@todo not implemented yet due to gutenberg not supporting it
3014
+                        ?>
3015 3015
 					>
3016 3016
 						<?php
3017 3017
 
3018
-						if ( ! empty( $args['options'] ) ) {
3019
-							foreach ( $args['options'] as $val => $label ) {
3020
-								if ( $multiple ) {
3021
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
3022
-								} else {
3023
-									$selected = selected( $value, $val, false );
3024
-								}
3025
-								echo "<option value='$val' " . $selected . ">$label</option>";
3026
-							}
3027
-						}
3028
-						?>
3018
+                        if ( ! empty( $args['options'] ) ) {
3019
+                            foreach ( $args['options'] as $val => $label ) {
3020
+                                if ( $multiple ) {
3021
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
3022
+                                } else {
3023
+                                    $selected = selected( $value, $val, false );
3024
+                                }
3025
+                                echo "<option value='$val' " . $selected . ">$label</option>";
3026
+                            }
3027
+                        }
3028
+                        ?>
3029 3029
 					</select>
3030 3030
 					<?php
3031
-					break;
3032
-				case "checkbox":
3033
-					?>
3031
+                    break;
3032
+                case "checkbox":
3033
+                    ?>
3034 3034
 					<input <?php echo $placeholder; ?>
3035 3035
 						<?php checked( 1, $value, true ) ?>
3036 3036
 						<?php echo $custom_attributes; ?>
@@ -3040,9 +3040,9 @@  discard block
 block discarded – undo
3040 3040
 					<label
3041 3041
 						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>
3042 3042
 					<?php
3043
-					break;
3044
-				case "textarea":
3045
-					?>
3043
+                    break;
3044
+                case "textarea":
3045
+                    ?>
3046 3046
 					<label
3047 3047
 						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>
3048 3048
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -3052,280 +3052,280 @@  discard block
 block discarded – undo
3052 3052
 					><?php echo esc_attr( $value ); ?></textarea>
3053 3053
 					<?php
3054 3054
 
3055
-					break;
3056
-				case "hidden":
3057
-					?>
3055
+                    break;
3056
+                case "hidden":
3057
+                    ?>
3058 3058
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3059 3059
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
3060 3060
 					       value="<?php echo esc_attr( $value ); ?>">
3061 3061
 					<?php
3062
-					break;
3063
-				default:
3064
-					echo "No input type found!"; // @todo we need to add more input types.
3065
-			}
3062
+                    break;
3063
+                default:
3064
+                    echo "No input type found!"; // @todo we need to add more input types.
3065
+            }
3066 3066
 
3067
-			// after wrapper
3068
-			?>
3067
+            // after wrapper
3068
+            ?>
3069 3069
 			</p>
3070 3070
 			<?php
3071 3071
 
3072 3072
 
3073
-		}
3074
-
3075
-		public function get_widget_icon($icon = 'box-top', $title = ''){
3076
-			if($icon=='box-top'){
3077
-				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>';
3078
-			}elseif($icon=='box-right'){
3079
-				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>';
3080
-			}elseif($icon=='box-bottom'){
3081
-				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>';
3082
-			}elseif($icon=='box-left'){
3083
-				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>';
3084
-			}
3085
-		}
3086
-
3087
-		/**
3088
-		 * Get the widget input description html.
3089
-		 *
3090
-		 * @param $args
3091
-		 *
3092
-		 * @return string
3093
-		 * @todo, need to make its own tooltip script
3094
-		 */
3095
-		public function widget_field_desc( $args ) {
3096
-
3097
-			$description = '';
3098
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
3099
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3100
-					$description = $this->desc_tip( $args['desc'] );
3101
-				} else {
3102
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3103
-				}
3104
-			}
3105
-
3106
-			return $description;
3107
-		}
3108
-
3109
-		/**
3110
-		 * Get the widget input title html.
3111
-		 *
3112
-		 * @param $args
3113
-		 *
3114
-		 * @return string
3115
-		 */
3116
-		public function widget_field_title( $args ) {
3117
-
3118
-			$title = '';
3119
-			if ( isset( $args['title'] ) && $args['title'] ) {
3120
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
3121
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
3122
-				} else {
3123
-					$title = esc_attr($args['title']);
3124
-				}
3125
-			}
3126
-
3127
-			return $title;
3128
-		}
3129
-
3130
-		/**
3131
-		 * Get the tool tip html.
3132
-		 *
3133
-		 * @param $tip
3134
-		 * @param bool $allow_html
3135
-		 *
3136
-		 * @return string
3137
-		 */
3138
-		function desc_tip( $tip, $allow_html = false ) {
3139
-			if ( $allow_html ) {
3140
-				$tip = $this->sanitize_tooltip( $tip );
3141
-			} else {
3142
-				$tip = esc_attr( $tip );
3143
-			}
3144
-
3145
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3146
-		}
3147
-
3148
-		/**
3149
-		 * Sanitize a string destined to be a tooltip.
3150
-		 *
3151
-		 * @param string $var
3152
-		 *
3153
-		 * @return string
3154
-		 */
3155
-		public function sanitize_tooltip( $var ) {
3156
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3157
-				'br'     => array(),
3158
-				'em'     => array(),
3159
-				'strong' => array(),
3160
-				'small'  => array(),
3161
-				'span'   => array(),
3162
-				'ul'     => array(),
3163
-				'li'     => array(),
3164
-				'ol'     => array(),
3165
-				'p'      => array(),
3166
-			) ) );
3167
-		}
3168
-
3169
-		/**
3170
-		 * Processing widget options on save
3171
-		 *
3172
-		 * @param array $new_instance The new options
3173
-		 * @param array $old_instance The previous options
3174
-		 *
3175
-		 * @return array
3176
-		 * @todo we should add some sanitation here.
3177
-		 */
3178
-		public function update( $new_instance, $old_instance ) {
3179
-
3180
-			//save the widget
3181
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
3182
-
3183
-			// set widget instance
3184
-			$this->instance = $instance;
3185
-
3186
-			if ( empty( $this->arguments ) ) {
3187
-				$this->get_arguments();
3188
-			}
3189
-
3190
-			// check for checkboxes
3191
-			if ( ! empty( $this->arguments ) ) {
3192
-				foreach ( $this->arguments as $argument ) {
3193
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3194
-						$instance[ $argument['name'] ] = '0';
3195
-					}
3196
-				}
3197
-			}
3198
-
3199
-			return $instance;
3200
-		}
3201
-
3202
-		/**
3203
-		 * Checks if the current call is a ajax call to get the block content.
3204
-		 *
3205
-		 * This can be used in your widget to return different content as the block content.
3206
-		 *
3207
-		 * @since 1.0.3
3208
-		 * @return bool
3209
-		 */
3210
-		public function is_block_content_call() {
3211
-			$result = false;
3212
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3213
-				$result = true;
3214
-			}
3215
-
3216
-			return $result;
3217
-		}
3218
-
3219
-		/**
3220
-		 * Get an instance hash that will be unique to the type and settings.
3221
-		 *
3222
-		 * @since 1.0.20
3223
-		 * @return string
3224
-		 */
3225
-		public function get_instance_hash(){
3226
-			$instance_string = $this->base_id.serialize($this->instance);
3227
-			return hash('crc32b',$instance_string);
3228
-		}
3229
-
3230
-		/**
3231
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3232
-		 *
3233
-		 * @param array $rules
3234
-		 *
3235
-		 * @since 1.0.20
3236
-		 * @return string
3237
-		 */
3238
-		public function get_instance_style($rules = array()){
3239
-			$css = '';
3240
-
3241
-			if(!empty($rules)){
3242
-				$rules = array_unique($rules);
3243
-				$instance_hash = $this->get_instance_hash();
3244
-				$css .= "<style>";
3245
-				foreach($rules as $rule){
3246
-					$css .= ".sdel-$instance_hash $rule";
3247
-				}
3248
-				$css .= "</style>";
3249
-			}
3250
-
3251
-			return $css;
3252
-		}
3253
-
3254
-		/**
3255
-		 * Encode shortcodes tags.
3256
-		 *
3257
-		 * @since 1.0.28
3258
-		 *
3259
-		 * @param string $content Content to search for shortcode tags.
3260
-		 * @return string Content with shortcode tags removed.
3261
-		 */
3262
-		public function encode_shortcodes( $content ) {
3263
-			// Avoids existing encoded tags.
3264
-			$trans   = array(
3265
-				'&#91;' => '&#091;',
3266
-				'&#93;' => '&#093;',
3267
-				'&amp;#91;' => '&#091;',
3268
-				'&amp;#93;' => '&#093;',
3269
-				'&lt;' => '&0lt;',
3270
-				'&gt;' => '&0gt;',
3271
-				'&amp;lt;' => '&0lt;',
3272
-				'&amp;gt;' => '&0gt;',
3273
-			);
3274
-
3275
-			$content = strtr( $content, $trans );
3276
-
3277
-			$trans   = array(
3278
-				'[' => '&#91;',
3279
-				']' => '&#93;',
3280
-				'<' => '&lt;',
3281
-				'>' => '&gt;',
3282
-				'"' => '&quot;',
3283
-				"'" => '&apos;',
3284
-			);
3285
-
3286
-			$content = strtr( $content, $trans );
3287
-
3288
-			return $content;
3289
-		}
3290
-
3291
-		/**
3292
-		 * Remove encoded shortcod tags.
3293
-		 *
3294
-		 * @since 1.0.28
3295
-		 *
3296
-		 * @param string $content Content to search for shortcode tags.
3297
-		 * @return string Content with decoded shortcode tags.
3298
-		 */
3299
-		public function decode_shortcodes( $content ) {
3300
-			$trans   = array(
3301
-				'&#91;' => '[',
3302
-				'&#93;' => ']',
3303
-				'&amp;#91;' => '[',
3304
-				'&amp;#93;' => ']',
3305
-				'&lt;' => '<',
3306
-				'&gt;' => '>',
3307
-				'&amp;lt;' => '<',
3308
-				'&amp;gt;' => '>',
3309
-				'&quot;' => '"',
3310
-				'&apos;' => "'",
3311
-			);
3312
-
3313
-			$content = strtr( $content, $trans );
3314
-
3315
-			$trans   = array(
3316
-				'&#091;' => '&#91;',
3317
-				'&#093;' => '&#93;',
3318
-				'&amp;#091;' => '&#91;',
3319
-				'&amp;#093;' => '&#93;',
3320
-				'&0lt;' => '&lt;',
3321
-				'&0gt;' => '&gt;',
3322
-				'&amp;0lt;' => '&lt;',
3323
-				'&amp;0gt;' => '&gt;',
3324
-			);
3325
-
3326
-			$content = strtr( $content, $trans );
3327
-
3328
-			return $content;
3329
-		}
3330
-	}
3073
+        }
3074
+
3075
+        public function get_widget_icon($icon = 'box-top', $title = ''){
3076
+            if($icon=='box-top'){
3077
+                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>';
3078
+            }elseif($icon=='box-right'){
3079
+                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>';
3080
+            }elseif($icon=='box-bottom'){
3081
+                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>';
3082
+            }elseif($icon=='box-left'){
3083
+                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>';
3084
+            }
3085
+        }
3086
+
3087
+        /**
3088
+         * Get the widget input description html.
3089
+         *
3090
+         * @param $args
3091
+         *
3092
+         * @return string
3093
+         * @todo, need to make its own tooltip script
3094
+         */
3095
+        public function widget_field_desc( $args ) {
3096
+
3097
+            $description = '';
3098
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
3099
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3100
+                    $description = $this->desc_tip( $args['desc'] );
3101
+                } else {
3102
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3103
+                }
3104
+            }
3105
+
3106
+            return $description;
3107
+        }
3108
+
3109
+        /**
3110
+         * Get the widget input title html.
3111
+         *
3112
+         * @param $args
3113
+         *
3114
+         * @return string
3115
+         */
3116
+        public function widget_field_title( $args ) {
3117
+
3118
+            $title = '';
3119
+            if ( isset( $args['title'] ) && $args['title'] ) {
3120
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
3121
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
3122
+                } else {
3123
+                    $title = esc_attr($args['title']);
3124
+                }
3125
+            }
3126
+
3127
+            return $title;
3128
+        }
3129
+
3130
+        /**
3131
+         * Get the tool tip html.
3132
+         *
3133
+         * @param $tip
3134
+         * @param bool $allow_html
3135
+         *
3136
+         * @return string
3137
+         */
3138
+        function desc_tip( $tip, $allow_html = false ) {
3139
+            if ( $allow_html ) {
3140
+                $tip = $this->sanitize_tooltip( $tip );
3141
+            } else {
3142
+                $tip = esc_attr( $tip );
3143
+            }
3144
+
3145
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3146
+        }
3147
+
3148
+        /**
3149
+         * Sanitize a string destined to be a tooltip.
3150
+         *
3151
+         * @param string $var
3152
+         *
3153
+         * @return string
3154
+         */
3155
+        public function sanitize_tooltip( $var ) {
3156
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3157
+                'br'     => array(),
3158
+                'em'     => array(),
3159
+                'strong' => array(),
3160
+                'small'  => array(),
3161
+                'span'   => array(),
3162
+                'ul'     => array(),
3163
+                'li'     => array(),
3164
+                'ol'     => array(),
3165
+                'p'      => array(),
3166
+            ) ) );
3167
+        }
3168
+
3169
+        /**
3170
+         * Processing widget options on save
3171
+         *
3172
+         * @param array $new_instance The new options
3173
+         * @param array $old_instance The previous options
3174
+         *
3175
+         * @return array
3176
+         * @todo we should add some sanitation here.
3177
+         */
3178
+        public function update( $new_instance, $old_instance ) {
3179
+
3180
+            //save the widget
3181
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
3182
+
3183
+            // set widget instance
3184
+            $this->instance = $instance;
3185
+
3186
+            if ( empty( $this->arguments ) ) {
3187
+                $this->get_arguments();
3188
+            }
3189
+
3190
+            // check for checkboxes
3191
+            if ( ! empty( $this->arguments ) ) {
3192
+                foreach ( $this->arguments as $argument ) {
3193
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3194
+                        $instance[ $argument['name'] ] = '0';
3195
+                    }
3196
+                }
3197
+            }
3198
+
3199
+            return $instance;
3200
+        }
3201
+
3202
+        /**
3203
+         * Checks if the current call is a ajax call to get the block content.
3204
+         *
3205
+         * This can be used in your widget to return different content as the block content.
3206
+         *
3207
+         * @since 1.0.3
3208
+         * @return bool
3209
+         */
3210
+        public function is_block_content_call() {
3211
+            $result = false;
3212
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3213
+                $result = true;
3214
+            }
3215
+
3216
+            return $result;
3217
+        }
3218
+
3219
+        /**
3220
+         * Get an instance hash that will be unique to the type and settings.
3221
+         *
3222
+         * @since 1.0.20
3223
+         * @return string
3224
+         */
3225
+        public function get_instance_hash(){
3226
+            $instance_string = $this->base_id.serialize($this->instance);
3227
+            return hash('crc32b',$instance_string);
3228
+        }
3229
+
3230
+        /**
3231
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3232
+         *
3233
+         * @param array $rules
3234
+         *
3235
+         * @since 1.0.20
3236
+         * @return string
3237
+         */
3238
+        public function get_instance_style($rules = array()){
3239
+            $css = '';
3240
+
3241
+            if(!empty($rules)){
3242
+                $rules = array_unique($rules);
3243
+                $instance_hash = $this->get_instance_hash();
3244
+                $css .= "<style>";
3245
+                foreach($rules as $rule){
3246
+                    $css .= ".sdel-$instance_hash $rule";
3247
+                }
3248
+                $css .= "</style>";
3249
+            }
3250
+
3251
+            return $css;
3252
+        }
3253
+
3254
+        /**
3255
+         * Encode shortcodes tags.
3256
+         *
3257
+         * @since 1.0.28
3258
+         *
3259
+         * @param string $content Content to search for shortcode tags.
3260
+         * @return string Content with shortcode tags removed.
3261
+         */
3262
+        public function encode_shortcodes( $content ) {
3263
+            // Avoids existing encoded tags.
3264
+            $trans   = array(
3265
+                '&#91;' => '&#091;',
3266
+                '&#93;' => '&#093;',
3267
+                '&amp;#91;' => '&#091;',
3268
+                '&amp;#93;' => '&#093;',
3269
+                '&lt;' => '&0lt;',
3270
+                '&gt;' => '&0gt;',
3271
+                '&amp;lt;' => '&0lt;',
3272
+                '&amp;gt;' => '&0gt;',
3273
+            );
3274
+
3275
+            $content = strtr( $content, $trans );
3276
+
3277
+            $trans   = array(
3278
+                '[' => '&#91;',
3279
+                ']' => '&#93;',
3280
+                '<' => '&lt;',
3281
+                '>' => '&gt;',
3282
+                '"' => '&quot;',
3283
+                "'" => '&apos;',
3284
+            );
3285
+
3286
+            $content = strtr( $content, $trans );
3287
+
3288
+            return $content;
3289
+        }
3290
+
3291
+        /**
3292
+         * Remove encoded shortcod tags.
3293
+         *
3294
+         * @since 1.0.28
3295
+         *
3296
+         * @param string $content Content to search for shortcode tags.
3297
+         * @return string Content with decoded shortcode tags.
3298
+         */
3299
+        public function decode_shortcodes( $content ) {
3300
+            $trans   = array(
3301
+                '&#91;' => '[',
3302
+                '&#93;' => ']',
3303
+                '&amp;#91;' => '[',
3304
+                '&amp;#93;' => ']',
3305
+                '&lt;' => '<',
3306
+                '&gt;' => '>',
3307
+                '&amp;lt;' => '<',
3308
+                '&amp;gt;' => '>',
3309
+                '&quot;' => '"',
3310
+                '&apos;' => "'",
3311
+            );
3312
+
3313
+            $content = strtr( $content, $trans );
3314
+
3315
+            $trans   = array(
3316
+                '&#091;' => '&#91;',
3317
+                '&#093;' => '&#93;',
3318
+                '&amp;#091;' => '&#91;',
3319
+                '&amp;#093;' => '&#93;',
3320
+                '&0lt;' => '&lt;',
3321
+                '&0gt;' => '&gt;',
3322
+                '&amp;0lt;' => '&lt;',
3323
+                '&amp;0gt;' => '&gt;',
3324
+            );
3325
+
3326
+            $content = strtr( $content, $trans );
3327
+
3328
+            return $content;
3329
+        }
3330
+    }
3331 3331
 }
Please login to merge, or discard this patch.