Passed
Push — master ( 32890d...b6d11a )
by Brian
13:10
created
includes/admin/class-getpaid-post-types-admin.php 1 patch
Indentation   +700 added lines, -700 removed lines patch added patch discarded remove patch
@@ -13,703 +13,703 @@  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
-		return $actions;
133
-	}
134
-
135
-	/**
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
+        return $actions;
133
+    }
134
+
135
+    /**
136 136
      * Remove bulk edit option from admin side quote listing
137 137
      *
138 138
      * @since    1.0.0
139 139
      * @param array $actions post actions
140
-	 * @param WP_Post $post
140
+     * @param WP_Post $post
141 141
      * @return array $actions actions without edit option
142 142
      */
143 143
     public static function filter_invoice_row_actions( $actions, $post ) {
144 144
 
145 145
         if ( getpaid_is_invoice_post_type( $post->post_type ) ) {
146 146
 
147
-			$actions = array();
148
-			$invoice = new WPInv_Invoice( $post );
149
-
150
-			$actions['edit'] =  sprintf(
151
-				'<a href="%1$s">%2$s</a>',
152
-				esc_url( get_edit_post_link( $invoice->get_id() ) ),
153
-				esc_html( __( 'Edit', 'invoicing' ) )
154
-			);
155
-
156
-			if ( ! $invoice->is_draft() ) {
157
-
158
-				$actions['view'] =  sprintf(
159
-					'<a href="%1$s">%2$s</a>',
160
-					esc_url( $invoice->get_view_url() ),
161
-					sprintf(
162
-						esc_html( __( 'View %s', 'invoicing' ) ),
163
-						getpaid_get_post_type_label( $invoice->get_post_type(), false )
164
-					)
165
-				);
166
-
167
-				$actions['send'] =  sprintf(
168
-					'<a href="%1$s">%2$s</a>',
169
-					esc_url(
170
-						wp_nonce_url(
171
-							add_query_arg(
172
-								array(
173
-									'getpaid-admin-action' => 'send_invoice',
174
-									'invoice_id'           => $invoice->get_id()
175
-								)
176
-							),
177
-							'getpaid-nonce',
178
-							'getpaid-nonce'
179
-						)
180
-					),
181
-					esc_html( __( 'Send to Customer', 'invoicing' ) )
182
-				);
183
-
184
-			}
147
+            $actions = array();
148
+            $invoice = new WPInv_Invoice( $post );
149
+
150
+            $actions['edit'] =  sprintf(
151
+                '<a href="%1$s">%2$s</a>',
152
+                esc_url( get_edit_post_link( $invoice->get_id() ) ),
153
+                esc_html( __( 'Edit', 'invoicing' ) )
154
+            );
155
+
156
+            if ( ! $invoice->is_draft() ) {
157
+
158
+                $actions['view'] =  sprintf(
159
+                    '<a href="%1$s">%2$s</a>',
160
+                    esc_url( $invoice->get_view_url() ),
161
+                    sprintf(
162
+                        esc_html( __( 'View %s', 'invoicing' ) ),
163
+                        getpaid_get_post_type_label( $invoice->get_post_type(), false )
164
+                    )
165
+                );
166
+
167
+                $actions['send'] =  sprintf(
168
+                    '<a href="%1$s">%2$s</a>',
169
+                    esc_url(
170
+                        wp_nonce_url(
171
+                            add_query_arg(
172
+                                array(
173
+                                    'getpaid-admin-action' => 'send_invoice',
174
+                                    'invoice_id'           => $invoice->get_id()
175
+                                )
176
+                            ),
177
+                            'getpaid-nonce',
178
+                            'getpaid-nonce'
179
+                        )
180
+                    ),
181
+                    esc_html( __( 'Send to Customer', 'invoicing' ) )
182
+                );
183
+
184
+            }
185 185
 
186 186
         }
187 187
 
188 188
         return $actions;
189
-	}
190
-
191
-	/**
192
-	 * Returns an array of invoice table columns.
193
-	 */
194
-	public static function invoice_columns( $columns ) {
195
-
196
-		$columns = array(
197
-			'cb'                => $columns['cb'],
198
-			'number'            => __( 'Invoice', 'invoicing' ),
199
-			'customer'          => __( 'Customer', 'invoicing' ),
200
-			'invoice_date'      => __( 'Created', 'invoicing' ),
201
-			'payment_date'      => __( 'Completed', 'invoicing' ),
202
-			'amount'            => __( 'Amount', 'invoicing' ),
203
-			'recurring'         => __( 'Recurring', 'invoicing' ),
204
-			'status'            => __( 'Status', 'invoicing' ),
205
-		);
206
-
207
-		return apply_filters( 'wpi_invoice_table_columns', $columns );
208
-	}
209
-
210
-	/**
211
-	 * Displays invoice table columns.
212
-	 */
213
-	public static function display_invoice_columns( $column_name, $post_id ) {
214
-
215
-		$invoice = new WPInv_Invoice( $post_id );
216
-
217
-		switch ( $column_name ) {
218
-
219
-			case 'invoice_date' :
220
-				$date_time = esc_attr( $invoice->get_created_date() );
221
-				$date      = getpaid_format_date_value( $date_time, "&mdash;", true );
222
-				echo "<span title='$date_time'>$date</span>";
223
-				break;
224
-
225
-			case 'payment_date' :
226
-
227
-				if ( $invoice->is_paid() ) {
228
-					$date_time = esc_attr( $invoice->get_completed_date() );
229
-					$date      = getpaid_format_date_value( $date_time, "&mdash;", true );
230
-					echo "<span title='$date_time'>$date</span>";
231
-				} else {
232
-					echo "&mdash;";
233
-				}
189
+    }
190
+
191
+    /**
192
+     * Returns an array of invoice table columns.
193
+     */
194
+    public static function invoice_columns( $columns ) {
195
+
196
+        $columns = array(
197
+            'cb'                => $columns['cb'],
198
+            'number'            => __( 'Invoice', 'invoicing' ),
199
+            'customer'          => __( 'Customer', 'invoicing' ),
200
+            'invoice_date'      => __( 'Created', 'invoicing' ),
201
+            'payment_date'      => __( 'Completed', 'invoicing' ),
202
+            'amount'            => __( 'Amount', 'invoicing' ),
203
+            'recurring'         => __( 'Recurring', 'invoicing' ),
204
+            'status'            => __( 'Status', 'invoicing' ),
205
+        );
206
+
207
+        return apply_filters( 'wpi_invoice_table_columns', $columns );
208
+    }
209
+
210
+    /**
211
+     * Displays invoice table columns.
212
+     */
213
+    public static function display_invoice_columns( $column_name, $post_id ) {
214
+
215
+        $invoice = new WPInv_Invoice( $post_id );
216
+
217
+        switch ( $column_name ) {
218
+
219
+            case 'invoice_date' :
220
+                $date_time = esc_attr( $invoice->get_created_date() );
221
+                $date      = getpaid_format_date_value( $date_time, "&mdash;", true );
222
+                echo "<span title='$date_time'>$date</span>";
223
+                break;
224
+
225
+            case 'payment_date' :
226
+
227
+                if ( $invoice->is_paid() ) {
228
+                    $date_time = esc_attr( $invoice->get_completed_date() );
229
+                    $date      = getpaid_format_date_value( $date_time, "&mdash;", true );
230
+                    echo "<span title='$date_time'>$date</span>";
231
+                } else {
232
+                    echo "&mdash;";
233
+                }
234 234
 				
235
-				break;
235
+                break;
236 236
 
237
-			case 'amount' :
237
+            case 'amount' :
238 238
 
239
-				$amount = $invoice->get_total();
240
-				$formated_amount = wpinv_price( $amount, $invoice->get_currency() );
239
+                $amount = $invoice->get_total();
240
+                $formated_amount = wpinv_price( $amount, $invoice->get_currency() );
241 241
 
242
-				if ( $invoice->is_refunded() ) {
243
-					$refunded_amount = wpinv_price( 0, $invoice->get_currency() );
244
-					echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
245
-				} else {
242
+                if ( $invoice->is_refunded() ) {
243
+                    $refunded_amount = wpinv_price( 0, $invoice->get_currency() );
244
+                    echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
245
+                } else {
246 246
 
247
-					$discount = $invoice->get_total_discount();
247
+                    $discount = $invoice->get_total_discount();
248 248
 
249
-					if ( ! empty( $discount ) ) {
250
-						$new_amount = wpinv_price( $amount + $discount, $invoice->get_currency() );
251
-						echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
252
-					} else {
253
-						echo $formated_amount;
254
-					}
249
+                    if ( ! empty( $discount ) ) {
250
+                        $new_amount = wpinv_price( $amount + $discount, $invoice->get_currency() );
251
+                        echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
252
+                    } else {
253
+                        echo $formated_amount;
254
+                    }
255 255
 
256
-				}
256
+                }
257 257
 
258
-				break;
258
+                break;
259 259
 
260
-			case 'status' :
261
-				$status       = sanitize_text_field( $invoice->get_status() );
262
-				$status_label = sanitize_text_field( $invoice->get_status_nicename() );
260
+            case 'status' :
261
+                $status       = sanitize_text_field( $invoice->get_status() );
262
+                $status_label = sanitize_text_field( $invoice->get_status_nicename() );
263 263
 
264
-				// If it is paid, show the gateway title.
265
-				if ( $invoice->is_paid() ) {
266
-					$gateway = sanitize_text_field( $invoice->get_gateway_title() );
267
-					$gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), $gateway );
264
+                // If it is paid, show the gateway title.
265
+                if ( $invoice->is_paid() ) {
266
+                    $gateway = sanitize_text_field( $invoice->get_gateway_title() );
267
+                    $gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), $gateway );
268 268
 
269
-					echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
270
-				} else {
271
-					echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
272
-				}
269
+                    echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
270
+                } else {
271
+                    echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
272
+                }
273 273
 
274
-				// If it is not paid, display the overdue and view status.
275
-				if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
274
+                // If it is not paid, display the overdue and view status.
275
+                if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
276 276
 
277
-					// Invoice view status.
278
-					if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
279
-						echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
280
-					} else {
281
-						echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
282
-					}
277
+                    // Invoice view status.
278
+                    if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
279
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
280
+                    } else {
281
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
282
+                    }
283 283
 
284
-					// Display the overview status.
285
-					if ( wpinv_get_option( 'overdue_active' ) ) {
286
-						$due_date = $invoice->get_due_date();
287
-						$fomatted = getpaid_format_date( $due_date );
284
+                    // Display the overview status.
285
+                    if ( wpinv_get_option( 'overdue_active' ) ) {
286
+                        $due_date = $invoice->get_due_date();
287
+                        $fomatted = getpaid_format_date( $due_date );
288 288
 
289
-						if ( ! empty( $fomatted ) ) {
290
-							$date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
291
-							echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
292
-						}
293
-					}
289
+                        if ( ! empty( $fomatted ) ) {
290
+                            $date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
291
+                            echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
292
+                        }
293
+                    }
294 294
 
295
-				}
295
+                }
296 296
 
297
-				break;
297
+                break;
298 298
 
299
-			case 'recurring':
299
+            case 'recurring':
300 300
 
301
-				if ( $invoice->is_recurring() ) {
302
-					echo '<i class="fa fa-check" style="color:#43850a;"></i>';
303
-				} else {
304
-					echo '<i class="fa fa-times" style="color:#616161;"></i>';
305
-				}
306
-				break;
301
+                if ( $invoice->is_recurring() ) {
302
+                    echo '<i class="fa fa-check" style="color:#43850a;"></i>';
303
+                } else {
304
+                    echo '<i class="fa fa-times" style="color:#616161;"></i>';
305
+                }
306
+                break;
307 307
 
308
-			case 'number' :
308
+            case 'number' :
309 309
 
310
-				$edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
311
-				$invoice_number  = sanitize_text_field( $invoice->get_number() );
312
-				$invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
310
+                $edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
311
+                $invoice_number  = sanitize_text_field( $invoice->get_number() );
312
+                $invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
313 313
 
314
-				echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
314
+                echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
315 315
 
316
-				break;
316
+                break;
317 317
 
318
-			case 'customer' :
318
+            case 'customer' :
319 319
 	
320
-				$customer_name = $invoice->get_user_full_name();
320
+                $customer_name = $invoice->get_user_full_name();
321 321
 	
322
-				if ( empty( $customer_name ) ) {
323
-					$customer_name = $invoice->get_email();
324
-				}
322
+                if ( empty( $customer_name ) ) {
323
+                    $customer_name = $invoice->get_email();
324
+                }
325 325
 	
326
-				if ( ! empty( $customer_name ) ) {
327
-					$customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
328
-					$view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
329
-					echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
330
-				} else {
331
-					echo '<div>&mdash;</div>';
332
-				}
326
+                if ( ! empty( $customer_name ) ) {
327
+                    $customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
328
+                    $view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
329
+                    echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
330
+                } else {
331
+                    echo '<div>&mdash;</div>';
332
+                }
333 333
 
334
-				break;
334
+                break;
335 335
 
336
-		}
336
+        }
337 337
 
338
-	}
338
+    }
339 339
 
340
-	/**
341
-	 * Displays invoice bulk actions.
342
-	 */
343
-	public static function invoice_bulk_actions( $actions ) {
344
-		$actions['resend-invoice'] = __( 'Send to Customer', 'invoicing' );
345
-		return $actions;
346
-	}
340
+    /**
341
+     * Displays invoice bulk actions.
342
+     */
343
+    public static function invoice_bulk_actions( $actions ) {
344
+        $actions['resend-invoice'] = __( 'Send to Customer', 'invoicing' );
345
+        return $actions;
346
+    }
347 347
 
348
-	/**
349
-	 * Processes invoice bulk actions.
350
-	 */
351
-	public static function handle_invoice_bulk_actions( $redirect_url, $action, $post_ids ) {
348
+    /**
349
+     * Processes invoice bulk actions.
350
+     */
351
+    public static function handle_invoice_bulk_actions( $redirect_url, $action, $post_ids ) {
352 352
 
353
-		if ( $action == 'resend-invoice' ) {
353
+        if ( $action == 'resend-invoice' ) {
354 354
 
355
-			$success = false;
356
-			foreach ( $post_ids as $post_id ) {
357
-				$success = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $post_id ), true );
358
-			}
355
+            $success = false;
356
+            foreach ( $post_ids as $post_id ) {
357
+                $success = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $post_id ), true );
358
+            }
359 359
 
360
-			if ( $success ) {
361
-				getpaid_admin()->show_success( __( 'Invoices were successfully sent', 'invoicing' ) );
362
-			} else {
363
-				getpaid_admin()->show_error( __( 'Could not send some invoices', 'invoicing' ) );
364
-			}
360
+            if ( $success ) {
361
+                getpaid_admin()->show_success( __( 'Invoices were successfully sent', 'invoicing' ) );
362
+            } else {
363
+                getpaid_admin()->show_error( __( 'Could not send some invoices', 'invoicing' ) );
364
+            }
365 365
 
366
-		}
366
+        }
367 367
 
368
-		return $redirect_url;
368
+        return $redirect_url;
369 369
 
370
-	}
370
+    }
371 371
 
372
-	/**
373
-	 * Returns an array of payment forms table columns.
374
-	 */
375
-	public static function payment_form_columns( $columns ) {
372
+    /**
373
+     * Returns an array of payment forms table columns.
374
+     */
375
+    public static function payment_form_columns( $columns ) {
376 376
 
377
-		$columns = array(
378
-			'cb'                => $columns['cb'],
379
-			'title'             => __( 'Name', 'invoicing' ),
380
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
381
-			'earnings'          => __( 'Revenue', 'invoicing' ),
382
-			'refunds'           => __( 'Refunded', 'invoicing' ),
383
-			'items'             => __( 'Items', 'invoicing' ),
384
-			'date'              => __( 'Date', 'invoicing' ),
385
-		);
377
+        $columns = array(
378
+            'cb'                => $columns['cb'],
379
+            'title'             => __( 'Name', 'invoicing' ),
380
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
381
+            'earnings'          => __( 'Revenue', 'invoicing' ),
382
+            'refunds'           => __( 'Refunded', 'invoicing' ),
383
+            'items'             => __( 'Items', 'invoicing' ),
384
+            'date'              => __( 'Date', 'invoicing' ),
385
+        );
386 386
 
387
-		return apply_filters( 'wpi_payment_form_table_columns', $columns );
387
+        return apply_filters( 'wpi_payment_form_table_columns', $columns );
388 388
 
389
-	}
389
+    }
390 390
 
391
-	/**
392
-	 * Displays payment form table columns.
393
-	 */
394
-	public static function display_payment_form_columns( $column_name, $post_id ) {
391
+    /**
392
+     * Displays payment form table columns.
393
+     */
394
+    public static function display_payment_form_columns( $column_name, $post_id ) {
395 395
 
396
-		// Retrieve the payment form.
397
-		$form = new GetPaid_Payment_Form( $post_id );
396
+        // Retrieve the payment form.
397
+        $form = new GetPaid_Payment_Form( $post_id );
398 398
 
399
-		switch ( $column_name ) {
399
+        switch ( $column_name ) {
400 400
 
401
-			case 'earnings' :
402
-				echo wpinv_price( $form->get_earned() );
403
-				break;
401
+            case 'earnings' :
402
+                echo wpinv_price( $form->get_earned() );
403
+                break;
404 404
 
405
-			case 'refunds' :
406
-				echo wpinv_price( $form->get_refunded() );
407
-				break;
405
+            case 'refunds' :
406
+                echo wpinv_price( $form->get_refunded() );
407
+                break;
408 408
 
409
-			case 'refunds' :
410
-				echo wpinv_price( $form->get_refunded() );
411
-				break;
409
+            case 'refunds' :
410
+                echo wpinv_price( $form->get_refunded() );
411
+                break;
412 412
 
413
-			case 'shortcode' :
413
+            case 'shortcode' :
414 414
 
415
-				if ( $form->is_default() ) {
416
-					echo '&mdash;';
417
-				} else {
418
-					echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
419
-				}
415
+                if ( $form->is_default() ) {
416
+                    echo '&mdash;';
417
+                } else {
418
+                    echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
419
+                }
420 420
 
421
-				break;
421
+                break;
422 422
 
423
-			case 'items' :
423
+            case 'items' :
424 424
 
425
-				$items = $form->get_items();
425
+                $items = $form->get_items();
426 426
 
427
-				if ( $form->is_default() || empty( $items ) ) {
428
-					echo '&mdash;';
429
-					return;
430
-				}
427
+                if ( $form->is_default() || empty( $items ) ) {
428
+                    echo '&mdash;';
429
+                    return;
430
+                }
431 431
 
432
-				$_items = array();
432
+                $_items = array();
433 433
 
434
-				foreach ( $items as $item ) {
435
-					$url = $item->get_edit_url();
434
+                foreach ( $items as $item ) {
435
+                    $url = $item->get_edit_url();
436 436
 
437
-					if ( empty( $url ) ) {
438
-						$_items[] = sanitize_text_field( $item->get_name() );
439
-					} else {
440
-						$_items[] = sprintf(
441
-							'<a href="%s">%s</a>',
442
-							esc_url( $url ),
443
-							sanitize_text_field( $item->get_name() )
444
-						);
445
-					}
437
+                    if ( empty( $url ) ) {
438
+                        $_items[] = sanitize_text_field( $item->get_name() );
439
+                    } else {
440
+                        $_items[] = sprintf(
441
+                            '<a href="%s">%s</a>',
442
+                            esc_url( $url ),
443
+                            sanitize_text_field( $item->get_name() )
444
+                        );
445
+                    }
446 446
 
447
-				}
447
+                }
448 448
 
449
-				echo implode( '<br>', $_items );
449
+                echo implode( '<br>', $_items );
450 450
 
451
-				break;
451
+                break;
452 452
 
453
-		}
453
+        }
454 454
 
455
-	}
455
+    }
456 456
 
457
-	/**
458
-	 * Filters post states.
459
-	 */
460
-	public static function filter_payment_form_state( $post_states, $post ) {
457
+    /**
458
+     * Filters post states.
459
+     */
460
+    public static function filter_payment_form_state( $post_states, $post ) {
461 461
 
462
-		if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
463
-			$post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
464
-		}
462
+        if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
463
+            $post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
464
+        }
465 465
 	
466
-		return $post_states;
467
-
468
-	}
469
-
470
-	/**
471
-	 * Returns an array of coupon table columns.
472
-	 */
473
-	public static function discount_columns( $columns ) {
474
-
475
-		$columns = array(
476
-			'cb'                => $columns['cb'],
477
-			'title'             => __( 'Name', 'invoicing' ),
478
-			'code'              => __( 'Code', 'invoicing' ),
479
-			'amount'            => __( 'Amount', 'invoicing' ),
480
-			'usage'             => __( 'Usage / Limit', 'invoicing' ),
481
-			'start_date'        => __( 'Start Date', 'invoicing' ),
482
-			'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
483
-		);
484
-
485
-		return apply_filters( 'wpi_discount_table_columns', $columns );
486
-	}
487
-
488
-	/**
489
-	 * Filters post states.
490
-	 */
491
-	public static function filter_discount_state( $post_states, $post ) {
492
-
493
-		if ( 'wpi_discount' == $post->post_type ) {
494
-
495
-			$discount = new WPInv_Discount( $post );
496
-
497
-			$status = $discount->is_expired() ? 'expired' : $discount->get_status();
498
-
499
-			if ( $status != 'publish' ) {
500
-				return array(
501
-					'discount_status' => wpinv_discount_status( $status ),
502
-				);
503
-			}
504
-
505
-			return array();
506
-
507
-		}
508
-
509
-		return $post_states;
510
-
511
-	}
512
-
513
-	/**
514
-	 * Returns an array of items table columns.
515
-	 */
516
-	public static function item_columns( $columns ) {
517
-
518
-		$columns = array(
519
-			'cb'                => $columns['cb'],
520
-			'title'             => __( 'Name', 'invoicing' ),
521
-			'price'             => __( 'Price', 'invoicing' ),
522
-			'vat_rule'          => __( 'VAT rule', 'invoicing' ),
523
-			'vat_class'         => __( 'VAT class', 'invoicing' ),
524
-			'type'              => __( 'Type', 'invoicing' ),
525
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
526
-		);
527
-
528
-		if ( ! wpinv_use_taxes() ) {
529
-			unset( $columns['vat_rule'] );
530
-			unset( $columns['vat_class'] );
531
-		}
532
-
533
-		return apply_filters( 'wpi_item_table_columns', $columns );
534
-	}
535
-
536
-	/**
537
-	 * Returns an array of sortable items table columns.
538
-	 */
539
-	public static function sortable_item_columns( $columns ) {
540
-
541
-		return array_merge(
542
-			$columns,
543
-			array(
544
-				'price'     => 'price',
545
-				'vat_rule'  => 'vat_rule',
546
-				'vat_class' => 'vat_class',
547
-				'type'      => 'type',
548
-			)
549
-		);
550
-
551
-	}
552
-
553
-	/**
554
-	 * Displays items table columns.
555
-	 */
556
-	public static function display_item_columns( $column_name, $post_id ) {
466
+        return $post_states;
467
+
468
+    }
469
+
470
+    /**
471
+     * Returns an array of coupon table columns.
472
+     */
473
+    public static function discount_columns( $columns ) {
474
+
475
+        $columns = array(
476
+            'cb'                => $columns['cb'],
477
+            'title'             => __( 'Name', 'invoicing' ),
478
+            'code'              => __( 'Code', 'invoicing' ),
479
+            'amount'            => __( 'Amount', 'invoicing' ),
480
+            'usage'             => __( 'Usage / Limit', 'invoicing' ),
481
+            'start_date'        => __( 'Start Date', 'invoicing' ),
482
+            'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
483
+        );
484
+
485
+        return apply_filters( 'wpi_discount_table_columns', $columns );
486
+    }
487
+
488
+    /**
489
+     * Filters post states.
490
+     */
491
+    public static function filter_discount_state( $post_states, $post ) {
492
+
493
+        if ( 'wpi_discount' == $post->post_type ) {
494
+
495
+            $discount = new WPInv_Discount( $post );
496
+
497
+            $status = $discount->is_expired() ? 'expired' : $discount->get_status();
498
+
499
+            if ( $status != 'publish' ) {
500
+                return array(
501
+                    'discount_status' => wpinv_discount_status( $status ),
502
+                );
503
+            }
504
+
505
+            return array();
506
+
507
+        }
508
+
509
+        return $post_states;
510
+
511
+    }
512
+
513
+    /**
514
+     * Returns an array of items table columns.
515
+     */
516
+    public static function item_columns( $columns ) {
517
+
518
+        $columns = array(
519
+            'cb'                => $columns['cb'],
520
+            'title'             => __( 'Name', 'invoicing' ),
521
+            'price'             => __( 'Price', 'invoicing' ),
522
+            'vat_rule'          => __( 'VAT rule', 'invoicing' ),
523
+            'vat_class'         => __( 'VAT class', 'invoicing' ),
524
+            'type'              => __( 'Type', 'invoicing' ),
525
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
526
+        );
527
+
528
+        if ( ! wpinv_use_taxes() ) {
529
+            unset( $columns['vat_rule'] );
530
+            unset( $columns['vat_class'] );
531
+        }
532
+
533
+        return apply_filters( 'wpi_item_table_columns', $columns );
534
+    }
535
+
536
+    /**
537
+     * Returns an array of sortable items table columns.
538
+     */
539
+    public static function sortable_item_columns( $columns ) {
540
+
541
+        return array_merge(
542
+            $columns,
543
+            array(
544
+                'price'     => 'price',
545
+                'vat_rule'  => 'vat_rule',
546
+                'vat_class' => 'vat_class',
547
+                'type'      => 'type',
548
+            )
549
+        );
550
+
551
+    }
552
+
553
+    /**
554
+     * Displays items table columns.
555
+     */
556
+    public static function display_item_columns( $column_name, $post_id ) {
557 557
  
558
-		$item = new WPInv_Item( $post_id );
558
+        $item = new WPInv_Item( $post_id );
559 559
 
560
-		switch ( $column_name ) {
560
+        switch ( $column_name ) {
561 561
 
562
-			case 'price' :
562
+            case 'price' :
563 563
 
564
-				if ( ! $item->is_recurring() ) {
565
-					echo $item->get_the_price();
566
-					break;
567
-				}
564
+                if ( ! $item->is_recurring() ) {
565
+                    echo $item->get_the_price();
566
+                    break;
567
+                }
568 568
 
569
-				$price = wp_sprintf(
570
-					__( '%s / %s', 'invoicing' ),
571
-					$item->get_the_price(),
572
-					getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
573
-				);
569
+                $price = wp_sprintf(
570
+                    __( '%s / %s', 'invoicing' ),
571
+                    $item->get_the_price(),
572
+                    getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
573
+                );
574 574
 
575
-				if ( $item->get_the_price() == $item->get_the_initial_price() ) {
576
-					echo $price;
577
-					break;
578
-				}
575
+                if ( $item->get_the_price() == $item->get_the_initial_price() ) {
576
+                    echo $price;
577
+                    break;
578
+                }
579 579
 
580
-				echo $item->get_the_initial_price();
580
+                echo $item->get_the_initial_price();
581 581
 
582
-				echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
583
-				break;
582
+                echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
583
+                break;
584 584
 
585
-			case 'vat_rule' :
586
-				echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
587
-				break;
585
+            case 'vat_rule' :
586
+                echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
587
+                break;
588 588
 
589
-			case 'vat_class' :
590
-				echo getpaid_get_tax_class_label( $item->get_vat_class() );
591
-				break;
589
+            case 'vat_class' :
590
+                echo getpaid_get_tax_class_label( $item->get_vat_class() );
591
+                break;
592 592
 
593
-			case 'shortcode' :
594
-				echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
595
-				break;
593
+            case 'shortcode' :
594
+                echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
595
+                break;
596 596
 
597
-			case 'type' :
598
-				echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
599
-				break;
597
+            case 'type' :
598
+                echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
599
+                break;
600 600
 
601
-		}
601
+        }
602 602
 
603
-	}
603
+    }
604 604
 
605
-	/**
606
-	 * Lets users filter items using taxes.
607
-	 */
608
-	public static function add_item_filters( $post_type ) {
605
+    /**
606
+     * Lets users filter items using taxes.
607
+     */
608
+    public static function add_item_filters( $post_type ) {
609 609
 
610
-		// Abort if we're not dealing with items.
611
-		if ( $post_type != 'wpi_item' ) {
612
-			return;
613
-		}
610
+        // Abort if we're not dealing with items.
611
+        if ( $post_type != 'wpi_item' ) {
612
+            return;
613
+        }
614 614
 
615
-		// Filter by vat rules.
616
-		if ( wpinv_use_taxes() ) {
615
+        // Filter by vat rules.
616
+        if ( wpinv_use_taxes() ) {
617 617
 	
618
-			// Sanitize selected vat rule.
619
-			$vat_rule   = '';
620
-			$vat_rules  = getpaid_get_tax_rules();
621
-			if ( isset( $_GET['vat_rule'] ) ) {
622
-				$vat_rule   =  $_GET['vat_rule'];
623
-			}
624
-
625
-			// Filter by VAT rule.
626
-			echo wpinv_html_select(
627
-				array(
628
-					'options'          => array_merge(
629
-						array(
630
-							'' => __( 'All VAT rules', 'invoicing' )
631
-						),
632
-						$vat_rules
633
-					),
634
-					'name'             => 'vat_rule',
635
-					'id'               => 'vat_rule',
636
-					'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
637
-					'show_option_all'  => false,
638
-					'show_option_none' => false,
639
-				)
640
-			);
641
-
642
-			// Filter by VAT class.
618
+            // Sanitize selected vat rule.
619
+            $vat_rule   = '';
620
+            $vat_rules  = getpaid_get_tax_rules();
621
+            if ( isset( $_GET['vat_rule'] ) ) {
622
+                $vat_rule   =  $_GET['vat_rule'];
623
+            }
624
+
625
+            // Filter by VAT rule.
626
+            echo wpinv_html_select(
627
+                array(
628
+                    'options'          => array_merge(
629
+                        array(
630
+                            '' => __( 'All VAT rules', 'invoicing' )
631
+                        ),
632
+                        $vat_rules
633
+                    ),
634
+                    'name'             => 'vat_rule',
635
+                    'id'               => 'vat_rule',
636
+                    'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
637
+                    'show_option_all'  => false,
638
+                    'show_option_none' => false,
639
+                )
640
+            );
641
+
642
+            // Filter by VAT class.
643 643
 	
644
-			// Sanitize selected vat rule.
645
-			$vat_class   = '';
646
-			$vat_classes = getpaid_get_tax_classes();
647
-			if ( isset( $_GET['vat_class'] ) ) {
648
-				$vat_class   =  $_GET['vat_class'];
649
-			}
650
-
651
-			echo wpinv_html_select(
652
-				array(
653
-					'options'          => array_merge(
654
-						array(
655
-							'' => __( 'All VAT classes', 'invoicing' )
656
-						),
657
-						$vat_classes
658
-					),
659
-					'name'             => 'vat_class',
660
-					'id'               => 'vat_class',
661
-					'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
662
-					'show_option_all'  => false,
663
-					'show_option_none' => false,
664
-				)
665
-			);
666
-
667
-		}
668
-
669
-		// Filter by item type.
670
-		$type   = '';
671
-		if ( isset( $_GET['type'] ) ) {
672
-			$type   =  $_GET['type'];
673
-		}
674
-
675
-		echo wpinv_html_select(
676
-			array(
677
-				'options'          => array_merge(
678
-					array(
679
-						'' => __( 'All item types', 'invoicing' )
680
-					),
681
-					wpinv_get_item_types()
682
-				),
683
-				'name'             => 'type',
684
-				'id'               => 'type',
685
-				'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
686
-				'show_option_all'  => false,
687
-				'show_option_none' => false,
688
-			)
689
-		);
690
-
691
-	}
692
-
693
-	/**
694
-	 * Filters the item query.
695
-	 */
696
-	public static function filter_item_query( $query ) {
697
-
698
-		// modify the query only if it admin and main query.
699
-		if ( ! ( is_admin() && $query->is_main_query() ) ){ 
700
-			return $query;
701
-		}
702
-
703
-		// we want to modify the query for our items.
704
-		if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
705
-			return $query;
706
-		}
707
-
708
-		if ( empty( $query->query_vars['meta_query'] ) ) {
709
-			$query->query_vars['meta_query'] = array();
710
-		}
711
-
712
-		// Filter vat rule type
644
+            // Sanitize selected vat rule.
645
+            $vat_class   = '';
646
+            $vat_classes = getpaid_get_tax_classes();
647
+            if ( isset( $_GET['vat_class'] ) ) {
648
+                $vat_class   =  $_GET['vat_class'];
649
+            }
650
+
651
+            echo wpinv_html_select(
652
+                array(
653
+                    'options'          => array_merge(
654
+                        array(
655
+                            '' => __( 'All VAT classes', 'invoicing' )
656
+                        ),
657
+                        $vat_classes
658
+                    ),
659
+                    'name'             => 'vat_class',
660
+                    'id'               => 'vat_class',
661
+                    'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
662
+                    'show_option_all'  => false,
663
+                    'show_option_none' => false,
664
+                )
665
+            );
666
+
667
+        }
668
+
669
+        // Filter by item type.
670
+        $type   = '';
671
+        if ( isset( $_GET['type'] ) ) {
672
+            $type   =  $_GET['type'];
673
+        }
674
+
675
+        echo wpinv_html_select(
676
+            array(
677
+                'options'          => array_merge(
678
+                    array(
679
+                        '' => __( 'All item types', 'invoicing' )
680
+                    ),
681
+                    wpinv_get_item_types()
682
+                ),
683
+                'name'             => 'type',
684
+                'id'               => 'type',
685
+                'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
686
+                'show_option_all'  => false,
687
+                'show_option_none' => false,
688
+            )
689
+        );
690
+
691
+    }
692
+
693
+    /**
694
+     * Filters the item query.
695
+     */
696
+    public static function filter_item_query( $query ) {
697
+
698
+        // modify the query only if it admin and main query.
699
+        if ( ! ( is_admin() && $query->is_main_query() ) ){ 
700
+            return $query;
701
+        }
702
+
703
+        // we want to modify the query for our items.
704
+        if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
705
+            return $query;
706
+        }
707
+
708
+        if ( empty( $query->query_vars['meta_query'] ) ) {
709
+            $query->query_vars['meta_query'] = array();
710
+        }
711
+
712
+        // Filter vat rule type
713 713
         if ( ! empty( $_GET['vat_rule'] ) ) {
714 714
             $query->query_vars['meta_query'][] = array(
715 715
                 'key'     => '_wpinv_vat_rule',
@@ -734,97 +734,97 @@  discard block
 block discarded – undo
734 734
                 'value'   => sanitize_text_field( $_GET['type'] ),
735 735
                 'compare' => '='
736 736
             );
737
-		}
738
-
739
-	}
740
-
741
-	/**
742
-	 * Reorders items.
743
-	 */
744
-	public static function reorder_items( $vars ) {
745
-		global $typenow;
746
-
747
-		if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
748
-			return $vars;
749
-		}
750
-
751
-		// By item type.
752
-		if ( 'type' == $vars['orderby'] ) {
753
-			return array_merge(
754
-				$vars,
755
-				array(
756
-					'meta_key' => '_wpinv_type',
757
-					'orderby'  => 'meta_value'
758
-				)
759
-			);
760
-		}
761
-
762
-		// By vat class.
763
-		if ( 'vat_class' == $vars['orderby'] ) {
764
-			return array_merge(
765
-				$vars,
766
-				array(
767
-					'meta_key' => '_wpinv_vat_class',
768
-					'orderby'  => 'meta_value'
769
-				)
770
-			);
771
-		}
772
-
773
-		// By vat rule.
774
-		if ( 'vat_rule' == $vars['orderby'] ) {
775
-			return array_merge(
776
-				$vars,
777
-				array(
778
-					'meta_key' => '_wpinv_vat_rule',
779
-					'orderby'  => 'meta_value'
780
-				)
781
-			);
782
-		}
783
-
784
-		// By price.
785
-		if ( 'price' == $vars['orderby'] ) {
786
-			return array_merge(
787
-				$vars,
788
-				array(
789
-					'meta_key' => '_wpinv_price',
790
-					'orderby'  => 'meta_value_num'
791
-				)
792
-			);
793
-		}
794
-
795
-		return $vars;
796
-
797
-	}
798
-
799
-	/**
800
-	 * Fired when deleting a post.
801
-	 */
802
-	public static function delete_post( $post_id ) {
803
-
804
-		switch ( get_post_type( $post_id ) ) {
805
-
806
-			case 'wpi_item' :
807
-				do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
808
-				break;
809
-
810
-			case 'wpi_payment_form' :
811
-				do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
812
-				break;
813
-
814
-			case 'wpi_discount' :
815
-				do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
816
-				break;
817
-
818
-			case 'wpi_invoice' :
819
-				$invoice = new WPInv_Invoice( $post_id );
820
-				do_action( "getpaid_before_delete_invoice", $invoice );
821
-				$invoice->get_data_store()->delete_items( $invoice );
822
-				$invoice->get_data_store()->delete_special_fields( $invoice );
823
-				break;
824
-		}
825
-	}
826
-
827
-	/**
737
+        }
738
+
739
+    }
740
+
741
+    /**
742
+     * Reorders items.
743
+     */
744
+    public static function reorder_items( $vars ) {
745
+        global $typenow;
746
+
747
+        if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
748
+            return $vars;
749
+        }
750
+
751
+        // By item type.
752
+        if ( 'type' == $vars['orderby'] ) {
753
+            return array_merge(
754
+                $vars,
755
+                array(
756
+                    'meta_key' => '_wpinv_type',
757
+                    'orderby'  => 'meta_value'
758
+                )
759
+            );
760
+        }
761
+
762
+        // By vat class.
763
+        if ( 'vat_class' == $vars['orderby'] ) {
764
+            return array_merge(
765
+                $vars,
766
+                array(
767
+                    'meta_key' => '_wpinv_vat_class',
768
+                    'orderby'  => 'meta_value'
769
+                )
770
+            );
771
+        }
772
+
773
+        // By vat rule.
774
+        if ( 'vat_rule' == $vars['orderby'] ) {
775
+            return array_merge(
776
+                $vars,
777
+                array(
778
+                    'meta_key' => '_wpinv_vat_rule',
779
+                    'orderby'  => 'meta_value'
780
+                )
781
+            );
782
+        }
783
+
784
+        // By price.
785
+        if ( 'price' == $vars['orderby'] ) {
786
+            return array_merge(
787
+                $vars,
788
+                array(
789
+                    'meta_key' => '_wpinv_price',
790
+                    'orderby'  => 'meta_value_num'
791
+                )
792
+            );
793
+        }
794
+
795
+        return $vars;
796
+
797
+    }
798
+
799
+    /**
800
+     * Fired when deleting a post.
801
+     */
802
+    public static function delete_post( $post_id ) {
803
+
804
+        switch ( get_post_type( $post_id ) ) {
805
+
806
+            case 'wpi_item' :
807
+                do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
808
+                break;
809
+
810
+            case 'wpi_payment_form' :
811
+                do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
812
+                break;
813
+
814
+            case 'wpi_discount' :
815
+                do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
816
+                break;
817
+
818
+            case 'wpi_invoice' :
819
+                $invoice = new WPInv_Invoice( $post_id );
820
+                do_action( "getpaid_before_delete_invoice", $invoice );
821
+                $invoice->get_data_store()->delete_items( $invoice );
822
+                $invoice->get_data_store()->delete_special_fields( $invoice );
823
+                break;
824
+        }
825
+    }
826
+
827
+    /**
828 828
      * Add a post display state for special GetPaid pages in the page list table.
829 829
      *
830 830
      * @param array   $post_states An array of post display states.
@@ -838,22 +838,22 @@  discard block
 block discarded – undo
838 838
             $post_states['getpaid_success_page'] = __( 'GetPaid Receipt Page', 'invoicing' );
839 839
         }
840 840
 
841
-		foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
841
+        foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
842 842
 
843
-			if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
844
-				$post_states["getpaid_{$post_type}_history_page"] = sprintf(
845
-					__( 'GetPaid %s History Page', 'invoicing' ),
846
-					$label
847
-				);
848
-			}
843
+            if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
844
+                $post_states["getpaid_{$post_type}_history_page"] = sprintf(
845
+                    __( 'GetPaid %s History Page', 'invoicing' ),
846
+                    $label
847
+                );
848
+            }
849 849
 
850
-		}
850
+        }
851 851
 		
852
-		if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
852
+        if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
853 853
             $post_states['getpaid_invoice_subscription_page'] = __( 'GetPaid Subscription Page', 'invoicing' );
854 854
         }
855 855
 
856
-		if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
856
+        if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
857 857
             $post_states['getpaid_checkout_page'] = __( 'GetPaid Checkout Page', 'invoicing' );
858 858
         }
859 859
 
Please login to merge, or discard this patch.
includes/payments/class-getpaid-payment-form-submission-taxes.php 1 patch
Indentation   +209 added lines, -209 removed lines patch added patch discarded remove patch
@@ -12,228 +12,228 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Payment_Form_Submission_Taxes {
14 14
 
15
-	/**
16
-	 * Submission taxes.
17
-	 * @var array
18
-	 */
19
-	public $taxes = array();
20
-
21
-	/**
22
-	 * Whether or not we should skip the taxes.
23
-	 * @var bool
24
-	 */
25
-	protected $skip_taxes = false;
15
+    /**
16
+     * Submission taxes.
17
+     * @var array
18
+     */
19
+    public $taxes = array();
20
+
21
+    /**
22
+     * Whether or not we should skip the taxes.
23
+     * @var bool
24
+     */
25
+    protected $skip_taxes = false;
26 26
 
27 27
     /**
28
-	 * Class constructor
29
-	 *
30
-	 * @param GetPaid_Payment_Form_Submission $submission
31
-	 */
32
-	public function __construct( $submission ) {
33
-
34
-		// Validate VAT number.
35
-		$this->validate_vat( $submission );
36
-
37
-		if ( $this->skip_taxes ) {
38
-			return;
39
-		}
40
-
41
-		foreach ( $submission->get_items() as $item ) {
42
-			$this->process_item_tax( $item, $submission );
43
-		}
44
-
45
-		// Process any existing invoice taxes.
46
-		if ( $submission->has_invoice() ) {
47
-			$this->taxes = array_replace( $submission->get_invoice()->get_taxes(), $this->taxes );
48
-		}
49
-
50
-	}
51
-
52
-	/**
53
-	 * Maybe process tax.
54
-	 *
55
-	 * @since 1.0.19
56
-	 * @param GetPaid_Form_Item $item
57
-	 * @param GetPaid_Payment_Form_Submission $submission
58
-	 */
59
-	public function process_item_tax( $item, $submission ) {
60
-
61
-		$rates    = getpaid_get_item_tax_rates( $item, $submission->country, $submission->state );
62
-		$rates    = getpaid_filter_item_tax_rates( $item, $rates );
63
-		$taxes    = getpaid_calculate_item_taxes( getpaid_get_taxable_amount( $item, false ), $rates );
64
-		$r_taxes  = getpaid_calculate_item_taxes( getpaid_get_taxable_amount( $item, true ), $rates );
65
-
66
-		foreach ( $taxes as $name => $amount ) {
67
-			$recurring = isset( $r_taxes[ $name ] ) ? $r_taxes[ $name ] : 0;
68
-			$tax       = getpaid_prepare_item_tax( $item, $name, $amount, $recurring );
69
-
70
-			$item->item_tax += wpinv_sanitize_amount( $tax['initial_tax'] );
71
-
72
-			if ( ! isset( $this->taxes[ $name ] ) ) {
73
-				$this->taxes[ $name ] = $tax;
74
-				continue;
75
-			}
76
-
77
-			$this->taxes[ $name ]['initial_tax']   += $tax['initial_tax'];
78
-			$this->taxes[ $name ]['recurring_tax'] += $tax['recurring_tax'];
79
-
80
-		}
81
-
82
-	}
83
-
84
-	/**
85
-	 * Checks if the submission has a digital item.
86
-	 *
87
-	 * @param GetPaid_Payment_Form_Submission $submission
88
-	 * @since 1.0.19
89
-	 * @return bool
90
-	 */
91
-	public function has_digital_item( $submission ) {
92
-
93
-		foreach ( $submission->get_items() as $item ) {
94
-
95
-			if ( 'digital' == $item->get_vat_rule() ) {
96
-				return true;
97
-			}
98
-
99
-		}
100
-
101
-		return false;
102
-	}
103
-
104
-	/**
105
-	 * Checks if this is an eu store.
106
-	 *
107
-	 * @since 1.0.19
108
-	 * @return bool
109
-	 */
110
-	public static function is_eu_store() {
111
-		return self::is_eu_country( wpinv_get_default_country() );
112
-	}
113
-
114
-	/**
115
-	 * Checks if this is an eu country.
116
-	 *
117
-	 * @param string $country
118
-	 * @since 1.0.19
119
-	 * @return bool
120
-	 */
121
-	public static function is_eu_country( $country ) {
122
-		return getpaid_is_eu_state( $country );
123
-	}
124
-
125
-	/**
126
-	 * Checks if this is an eu purchase.
127
-	 *
128
-	 * @param string $customer_country
129
-	 * @since 1.0.19
130
-	 * @return bool
131
-	 */
132
-	public static function is_eu_transaction( $customer_country ) {
133
-		return self::is_eu_country( $customer_country ) && self::is_eu_store();
134
-	}
135
-
136
-	/**
137
-	 * Retrieves the vat number.
138
-	 *
139
-	 * @param GetPaid_Payment_Form_Submission $submission
140
-	 * @since 1.0.19
141
-	 * @return string
142
-	 */
143
-	public function get_vat_number( $submission ) {
144
-
145
-		// Retrieve from the posted number.
146
-		$vat_number = $submission->get_field( 'wpinv_vat_number', 'billing' );
147
-		if ( ! is_null( $vat_number ) ) {
148
-			return wpinv_clean( $vat_number );
149
-		}
150
-
151
-		return $submission->has_invoice() ? $submission->get_invoice()->get_vat_number() : '';
152
-	}
153
-
154
-	/**
155
-	 * Retrieves the company.
156
-	 *
157
-	 * @param GetPaid_Payment_Form_Submission $submission
158
-	 * @since 1.0.19
159
-	 * @return string
160
-	 */
161
-	public function get_company( $submission ) {
162
-
163
-		// Retrieve from the posted data.
164
-		$company = $submission->get_field( 'wpinv_company', 'billing' );
165
-		if ( ! empty( $company ) ) {
166
-			return wpinv_clean( $company );
167
-		}
168
-
169
-		// Retrieve from the invoice.
170
-		return $submission->has_invoice() ? $submission->get_invoice()->get_company() : '';
171
-	}
172
-
173
-	/**
174
-	 * Checks if we require a VAT number.
175
-	 *
176
-	 * @param bool $ip_in_eu Whether the customer IP is from the EU
177
-	 * @param bool $country_in_eu Whether the customer country is from the EU
178
-	 * @since 1.0.19
179
-	 * @return string
180
-	 */
181
-	public function requires_vat( $ip_in_eu, $country_in_eu ) {
182
-
183
-		$prevent_b2c = wpinv_get_option( 'vat_prevent_b2c_purchase' );
184
-		$prevent_b2c = ! empty( $prevent_b2c );
185
-		$is_eu       = $ip_in_eu || $country_in_eu;
186
-
187
-		return $prevent_b2c && $is_eu;
188
-	}
189
-
190
-	/**
191
-	 * Validate VAT data.
192
-	 *
193
-	 * @param GetPaid_Payment_Form_Submission $submission
194
-	 * @since 1.0.19
195
-	 */
196
-	public function validate_vat( $submission ) {
197
-
198
-		$in_eu = $this->is_eu_transaction( $submission->country );
199
-
200
-		// Abort if we are not validating vat numbers.
201
-		if ( ! $in_eu ) {
28
+     * Class constructor
29
+     *
30
+     * @param GetPaid_Payment_Form_Submission $submission
31
+     */
32
+    public function __construct( $submission ) {
33
+
34
+        // Validate VAT number.
35
+        $this->validate_vat( $submission );
36
+
37
+        if ( $this->skip_taxes ) {
202 38
             return;
203
-		}
39
+        }
40
+
41
+        foreach ( $submission->get_items() as $item ) {
42
+            $this->process_item_tax( $item, $submission );
43
+        }
44
+
45
+        // Process any existing invoice taxes.
46
+        if ( $submission->has_invoice() ) {
47
+            $this->taxes = array_replace( $submission->get_invoice()->get_taxes(), $this->taxes );
48
+        }
49
+
50
+    }
51
+
52
+    /**
53
+     * Maybe process tax.
54
+     *
55
+     * @since 1.0.19
56
+     * @param GetPaid_Form_Item $item
57
+     * @param GetPaid_Payment_Form_Submission $submission
58
+     */
59
+    public function process_item_tax( $item, $submission ) {
60
+
61
+        $rates    = getpaid_get_item_tax_rates( $item, $submission->country, $submission->state );
62
+        $rates    = getpaid_filter_item_tax_rates( $item, $rates );
63
+        $taxes    = getpaid_calculate_item_taxes( getpaid_get_taxable_amount( $item, false ), $rates );
64
+        $r_taxes  = getpaid_calculate_item_taxes( getpaid_get_taxable_amount( $item, true ), $rates );
65
+
66
+        foreach ( $taxes as $name => $amount ) {
67
+            $recurring = isset( $r_taxes[ $name ] ) ? $r_taxes[ $name ] : 0;
68
+            $tax       = getpaid_prepare_item_tax( $item, $name, $amount, $recurring );
69
+
70
+            $item->item_tax += wpinv_sanitize_amount( $tax['initial_tax'] );
71
+
72
+            if ( ! isset( $this->taxes[ $name ] ) ) {
73
+                $this->taxes[ $name ] = $tax;
74
+                continue;
75
+            }
76
+
77
+            $this->taxes[ $name ]['initial_tax']   += $tax['initial_tax'];
78
+            $this->taxes[ $name ]['recurring_tax'] += $tax['recurring_tax'];
79
+
80
+        }
81
+
82
+    }
83
+
84
+    /**
85
+     * Checks if the submission has a digital item.
86
+     *
87
+     * @param GetPaid_Payment_Form_Submission $submission
88
+     * @since 1.0.19
89
+     * @return bool
90
+     */
91
+    public function has_digital_item( $submission ) {
92
+
93
+        foreach ( $submission->get_items() as $item ) {
94
+
95
+            if ( 'digital' == $item->get_vat_rule() ) {
96
+                return true;
97
+            }
98
+
99
+        }
204 100
 
205
-		// Prepare variables.
206
-		$vat_number  = $this->get_vat_number( $submission );
207
-		$ip_country  = getpaid_get_ip_country();
101
+        return false;
102
+    }
103
+
104
+    /**
105
+     * Checks if this is an eu store.
106
+     *
107
+     * @since 1.0.19
108
+     * @return bool
109
+     */
110
+    public static function is_eu_store() {
111
+        return self::is_eu_country( wpinv_get_default_country() );
112
+    }
113
+
114
+    /**
115
+     * Checks if this is an eu country.
116
+     *
117
+     * @param string $country
118
+     * @since 1.0.19
119
+     * @return bool
120
+     */
121
+    public static function is_eu_country( $country ) {
122
+        return getpaid_is_eu_state( $country );
123
+    }
124
+
125
+    /**
126
+     * Checks if this is an eu purchase.
127
+     *
128
+     * @param string $customer_country
129
+     * @since 1.0.19
130
+     * @return bool
131
+     */
132
+    public static function is_eu_transaction( $customer_country ) {
133
+        return self::is_eu_country( $customer_country ) && self::is_eu_store();
134
+    }
135
+
136
+    /**
137
+     * Retrieves the vat number.
138
+     *
139
+     * @param GetPaid_Payment_Form_Submission $submission
140
+     * @since 1.0.19
141
+     * @return string
142
+     */
143
+    public function get_vat_number( $submission ) {
144
+
145
+        // Retrieve from the posted number.
146
+        $vat_number = $submission->get_field( 'wpinv_vat_number', 'billing' );
147
+        if ( ! is_null( $vat_number ) ) {
148
+            return wpinv_clean( $vat_number );
149
+        }
150
+
151
+        return $submission->has_invoice() ? $submission->get_invoice()->get_vat_number() : '';
152
+    }
153
+
154
+    /**
155
+     * Retrieves the company.
156
+     *
157
+     * @param GetPaid_Payment_Form_Submission $submission
158
+     * @since 1.0.19
159
+     * @return string
160
+     */
161
+    public function get_company( $submission ) {
162
+
163
+        // Retrieve from the posted data.
164
+        $company = $submission->get_field( 'wpinv_company', 'billing' );
165
+        if ( ! empty( $company ) ) {
166
+            return wpinv_clean( $company );
167
+        }
168
+
169
+        // Retrieve from the invoice.
170
+        return $submission->has_invoice() ? $submission->get_invoice()->get_company() : '';
171
+    }
172
+
173
+    /**
174
+     * Checks if we require a VAT number.
175
+     *
176
+     * @param bool $ip_in_eu Whether the customer IP is from the EU
177
+     * @param bool $country_in_eu Whether the customer country is from the EU
178
+     * @since 1.0.19
179
+     * @return string
180
+     */
181
+    public function requires_vat( $ip_in_eu, $country_in_eu ) {
182
+
183
+        $prevent_b2c = wpinv_get_option( 'vat_prevent_b2c_purchase' );
184
+        $prevent_b2c = ! empty( $prevent_b2c );
185
+        $is_eu       = $ip_in_eu || $country_in_eu;
186
+
187
+        return $prevent_b2c && $is_eu;
188
+    }
189
+
190
+    /**
191
+     * Validate VAT data.
192
+     *
193
+     * @param GetPaid_Payment_Form_Submission $submission
194
+     * @since 1.0.19
195
+     */
196
+    public function validate_vat( $submission ) {
197
+
198
+        $in_eu = $this->is_eu_transaction( $submission->country );
199
+
200
+        // Abort if we are not validating vat numbers.
201
+        if ( ! $in_eu ) {
202
+            return;
203
+        }
204
+
205
+        // Prepare variables.
206
+        $vat_number  = $this->get_vat_number( $submission );
207
+        $ip_country  = getpaid_get_ip_country();
208 208
         $is_eu       = $this->is_eu_country( $submission->country );
209 209
         $is_ip_eu    = $this->is_eu_country( $ip_country );
210 210
 
211
-		// Maybe abort early for initial fetches.
212
-		if ( $submission->is_initial_fetch() && empty( $vat_number ) ) {
213
-			return;
214
-		}
211
+        // Maybe abort early for initial fetches.
212
+        if ( $submission->is_initial_fetch() && empty( $vat_number ) ) {
213
+            return;
214
+        }
215 215
 
216
-		// If we're preventing business to consumer purchases,
217
-		if ( $this->requires_vat( $is_ip_eu, $is_eu ) && empty( $vat_number ) ) {
216
+        // If we're preventing business to consumer purchases,
217
+        if ( $this->requires_vat( $is_ip_eu, $is_eu ) && empty( $vat_number ) ) {
218 218
 
219
-			// Ensure that a vat number has been specified.
220
-			throw new GetPaid_Payment_Exception( '.getpaid-error-billingwpinv_vat_number.getpaid-custom-payment-form-errors', __( 'Please enter your VAT number to verify your purchase is by an EU business.', 'invoicing' ) );
219
+            // Ensure that a vat number has been specified.
220
+            throw new GetPaid_Payment_Exception( '.getpaid-error-billingwpinv_vat_number.getpaid-custom-payment-form-errors', __( 'Please enter your VAT number to verify your purchase is by an EU business.', 'invoicing' ) );
221 221
 
222
-		}
222
+        }
223 223
 
224
-		if ( empty( $vat_number ) ) {
225
-			return;
226
-		}
224
+        if ( empty( $vat_number ) ) {
225
+            return;
226
+        }
227 227
 
228
-		if ( wpinv_should_validate_vat_number() && ! wpinv_validate_vat_number( $vat_number, $submission->country ) ) {
229
-			throw new GetPaid_Payment_Exception( '.getpaid-error-billingwpinv_vat_number.getpaid-custom-payment-form-errors', __( 'Your VAT number is invalid', 'invoicing' ) );
230
-		}
228
+        if ( wpinv_should_validate_vat_number() && ! wpinv_validate_vat_number( $vat_number, $submission->country ) ) {
229
+            throw new GetPaid_Payment_Exception( '.getpaid-error-billingwpinv_vat_number.getpaid-custom-payment-form-errors', __( 'Your VAT number is invalid', 'invoicing' ) );
230
+        }
231 231
 
232
-		if (  wpinv_default_billing_country() == $submission->country && 'vat_too' == wpinv_get_option( 'vat_same_country_rule', 'vat_too' ) ) {
233
-			return;
234
-		}
232
+        if (  wpinv_default_billing_country() == $submission->country && 'vat_too' == wpinv_get_option( 'vat_same_country_rule', 'vat_too' ) ) {
233
+            return;
234
+        }
235 235
 
236
-		$this->skip_taxes = true;
237
-	}
236
+        $this->skip_taxes = true;
237
+    }
238 238
 
239 239
 }
Please login to merge, or discard this patch.
includes/admin/class-getpaid-admin.php 1 patch
Indentation   +575 added lines, -575 removed lines patch added patch discarded remove patch
@@ -14,90 +14,90 @@  discard block
 block discarded – undo
14 14
 class GetPaid_Admin {
15 15
 
16 16
     /**
17
-	 * Local path to this plugins admin directory
18
-	 *
19
-	 * @var         string
20
-	 */
21
-	public $admin_path;
22
-
23
-	/**
24
-	 * Web path to this plugins admin directory
25
-	 *
26
-	 * @var         string
27
-	 */
28
-	public $admin_url;
17
+     * Local path to this plugins admin directory
18
+     *
19
+     * @var         string
20
+     */
21
+    public $admin_path;
22
+
23
+    /**
24
+     * Web path to this plugins admin directory
25
+     *
26
+     * @var         string
27
+     */
28
+    public $admin_url;
29 29
 	
30
-	/**
31
-	 * Reports components.
32
-	 *
33
-	 * @var GetPaid_Reports
34
-	 */
30
+    /**
31
+     * Reports components.
32
+     *
33
+     * @var GetPaid_Reports
34
+     */
35 35
     public $reports;
36 36
 
37 37
     /**
38
-	 * Class constructor.
39
-	 */
40
-	public function __construct(){
38
+     * Class constructor.
39
+     */
40
+    public function __construct(){
41 41
 
42 42
         $this->admin_path  = plugin_dir_path( __FILE__ );
43
-		$this->admin_url   = plugins_url( '/', __FILE__ );
44
-		$this->reports     = new GetPaid_Reports();
43
+        $this->admin_url   = plugins_url( '/', __FILE__ );
44
+        $this->reports     = new GetPaid_Reports();
45 45
 
46 46
         if ( is_admin() ) {
47
-			$this->init_admin_hooks();
47
+            $this->init_admin_hooks();
48 48
         }
49 49
 
50 50
     }
51 51
 
52 52
     /**
53
-	 * Init action and filter hooks
54
-	 *
55
-	 */
56
-	private function init_admin_hooks() {
53
+     * Init action and filter hooks
54
+     *
55
+     */
56
+    private function init_admin_hooks() {
57 57
         add_action( 'admin_enqueue_scripts', array( $this, 'enqeue_scripts' ) );
58 58
         add_filter( 'admin_body_class', array( $this, 'admin_body_class' ) );
59 59
         add_action( 'admin_init', array( $this, 'init_ayecode_connect_helper' ) );
60 60
         add_action( 'admin_init', array( $this, 'activation_redirect') );
61 61
         add_action( 'admin_init', array( $this, 'maybe_do_admin_action') );
62
-		add_action( 'admin_notices', array( $this, 'show_notices' ) );
63
-		add_action( 'getpaid_authenticated_admin_action_rate_plugin', array( $this, 'redirect_to_wordpress_rating_page' ) );
64
-		add_action( 'getpaid_authenticated_admin_action_duplicate_form', array( $this, 'duplicate_payment_form' ) );
65
-		add_action( 'getpaid_authenticated_admin_action_send_invoice', array( $this, 'send_customer_invoice' ) );
66
-		add_action( 'getpaid_authenticated_admin_action_send_invoice_reminder', array( $this, 'send_customer_payment_reminder' ) );
62
+        add_action( 'admin_notices', array( $this, 'show_notices' ) );
63
+        add_action( 'getpaid_authenticated_admin_action_rate_plugin', array( $this, 'redirect_to_wordpress_rating_page' ) );
64
+        add_action( 'getpaid_authenticated_admin_action_duplicate_form', array( $this, 'duplicate_payment_form' ) );
65
+        add_action( 'getpaid_authenticated_admin_action_send_invoice', array( $this, 'send_customer_invoice' ) );
66
+        add_action( 'getpaid_authenticated_admin_action_send_invoice_reminder', array( $this, 'send_customer_payment_reminder' ) );
67 67
         add_action( 'getpaid_authenticated_admin_action_reset_tax_rates', array( $this, 'admin_reset_tax_rates' ) );
68
-		add_action( 'getpaid_authenticated_admin_action_create_missing_pages', array( $this, 'admin_create_missing_pages' ) );
69
-		add_action( 'getpaid_authenticated_admin_action_create_missing_tables', array( $this, 'admin_create_missing_tables' ) );
70
-		add_action( 'getpaid_authenticated_admin_action_migrate_old_invoices', array( $this, 'admin_migrate_old_invoices' ) );
71
-		add_action( 'getpaid_authenticated_admin_action_download_customers', array( $this, 'admin_download_customers' ) );
72
-		add_action( 'getpaid_authenticated_admin_action_recalculate_discounts', array( $this, 'admin_recalculate_discounts' ) );
73
-		add_action( 'getpaid_authenticated_admin_action_install_plugin', array( $this, 'admin_install_plugin' ) );
74
-		add_action( 'getpaid_authenticated_admin_action_connect_gateway', array( $this, 'admin_connect_gateway' ) );
75
-		add_filter( 'admin_footer_text', array( $this, 'admin_footer_text' ) );
76
-		do_action( 'getpaid_init_admin_hooks', $this );
77
-
78
-		// Setup/welcome
79
-		if ( ! empty( $_GET['page'] ) ) {
80
-			switch ( $_GET['page'] ) {
81
-				case 'gp-setup' :
82
-					include_once( dirname( __FILE__ ) . '/class-getpaid-admin-setup-wizard.php' );
83
-					break;
84
-			}
85
-		}
68
+        add_action( 'getpaid_authenticated_admin_action_create_missing_pages', array( $this, 'admin_create_missing_pages' ) );
69
+        add_action( 'getpaid_authenticated_admin_action_create_missing_tables', array( $this, 'admin_create_missing_tables' ) );
70
+        add_action( 'getpaid_authenticated_admin_action_migrate_old_invoices', array( $this, 'admin_migrate_old_invoices' ) );
71
+        add_action( 'getpaid_authenticated_admin_action_download_customers', array( $this, 'admin_download_customers' ) );
72
+        add_action( 'getpaid_authenticated_admin_action_recalculate_discounts', array( $this, 'admin_recalculate_discounts' ) );
73
+        add_action( 'getpaid_authenticated_admin_action_install_plugin', array( $this, 'admin_install_plugin' ) );
74
+        add_action( 'getpaid_authenticated_admin_action_connect_gateway', array( $this, 'admin_connect_gateway' ) );
75
+        add_filter( 'admin_footer_text', array( $this, 'admin_footer_text' ) );
76
+        do_action( 'getpaid_init_admin_hooks', $this );
77
+
78
+        // Setup/welcome
79
+        if ( ! empty( $_GET['page'] ) ) {
80
+            switch ( $_GET['page'] ) {
81
+                case 'gp-setup' :
82
+                    include_once( dirname( __FILE__ ) . '/class-getpaid-admin-setup-wizard.php' );
83
+                    break;
84
+            }
85
+        }
86 86
 
87 87
     }
88 88
 
89 89
     /**
90
-	 * Register admin scripts
91
-	 *
92
-	 */
93
-	public function enqeue_scripts() {
90
+     * Register admin scripts
91
+     *
92
+     */
93
+    public function enqeue_scripts() {
94 94
         global $current_screen, $pagenow;
95 95
 
96
-		$page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
97
-		$editing = $pagenow == 'post.php' || $pagenow == 'post-new.php';
96
+        $page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
97
+        $editing = $pagenow == 'post.php' || $pagenow == 'post-new.php';
98 98
 
99 99
         if ( ! empty( $current_screen->post_type ) ) {
100
-			$page = $current_screen->post_type;
100
+            $page = $current_screen->post_type;
101 101
         }
102 102
 
103 103
         // General styles.
@@ -118,54 +118,54 @@  discard block
 block discarded – undo
118 118
         }
119 119
 
120 120
         // Payment form scripts.
121
-		if ( 'wpi_payment_form' == $page && $editing ) {
121
+        if ( 'wpi_payment_form' == $page && $editing ) {
122 122
             $this->load_payment_form_scripts();
123 123
         }
124 124
 
125
-		if ( $page == 'wpinv-subscriptions' ) {
126
-			wp_enqueue_script( 'postbox' );
127
-		}
125
+        if ( $page == 'wpinv-subscriptions' ) {
126
+            wp_enqueue_script( 'postbox' );
127
+        }
128 128
 
129 129
     }
130 130
 
131 131
     /**
132
-	 * Returns admin js translations.
133
-	 *
134
-	 */
135
-	protected function get_admin_i18() {
132
+     * Returns admin js translations.
133
+     *
134
+     */
135
+    protected function get_admin_i18() {
136 136
         global $post;
137 137
 
138
-		$date_range = array(
139
-			'period' => isset( $_GET['date_range'] ) ? sanitize_text_field( $_GET['date_range'] ) : '7_days'
140
-		);
138
+        $date_range = array(
139
+            'period' => isset( $_GET['date_range'] ) ? sanitize_text_field( $_GET['date_range'] ) : '7_days'
140
+        );
141 141
 
142
-		if ( $date_range['period'] == 'custom' ) {
142
+        if ( $date_range['period'] == 'custom' ) {
143 143
 			
144
-			if ( isset( $_GET['from'] ) ) {
145
-				$date_range[ 'after' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['from'] ), current_time( 'timestamp' ) ) - DAY_IN_SECONDS );
146
-			}
144
+            if ( isset( $_GET['from'] ) ) {
145
+                $date_range[ 'after' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['from'] ), current_time( 'timestamp' ) ) - DAY_IN_SECONDS );
146
+            }
147 147
 
148
-			if ( isset( $_GET['to'] ) ) {
149
-				$date_range[ 'before' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['to'] ), current_time( 'timestamp' ) ) + DAY_IN_SECONDS );
150
-			}
148
+            if ( isset( $_GET['to'] ) ) {
149
+                $date_range[ 'before' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['to'] ), current_time( 'timestamp' ) ) + DAY_IN_SECONDS );
150
+            }
151 151
 
152
-		}
152
+        }
153 153
 
154 154
         $i18n = array(
155 155
             'ajax_url'                  => admin_url( 'admin-ajax.php' ),
156 156
             'post_ID'                   => isset( $post->ID ) ? $post->ID : '',
157
-			'wpinv_nonce'               => wp_create_nonce( 'wpinv-nonce' ),
158
-			'rest_nonce'                => wp_create_nonce( 'wp_rest' ),
159
-			'rest_root'                 => esc_url_raw( rest_url() ),
160
-			'date_range'                => $date_range,
157
+            'wpinv_nonce'               => wp_create_nonce( 'wpinv-nonce' ),
158
+            'rest_nonce'                => wp_create_nonce( 'wp_rest' ),
159
+            'rest_root'                 => esc_url_raw( rest_url() ),
160
+            'date_range'                => $date_range,
161 161
             'add_invoice_note_nonce'    => wp_create_nonce( 'add-invoice-note' ),
162 162
             'delete_invoice_note_nonce' => wp_create_nonce( 'delete-invoice-note' ),
163 163
             'invoice_item_nonce'        => wp_create_nonce( 'invoice-item' ),
164 164
             'billing_details_nonce'     => wp_create_nonce( 'get-billing-details' ),
165 165
             'tax'                       => wpinv_tax_amount(),
166 166
             'discount'                  => 0,
167
-			'currency_symbol'           => wpinv_currency_symbol(),
168
-			'currency'                  => wpinv_get_currency(),
167
+            'currency_symbol'           => wpinv_currency_symbol(),
168
+            'currency'                  => wpinv_get_currency(),
169 169
             'currency_pos'              => wpinv_currency_position(),
170 170
             'thousand_sep'              => wpinv_thousands_separator(),
171 171
             'decimal_sep'               => wpinv_decimal_separator(),
@@ -185,118 +185,118 @@  discard block
 block discarded – undo
185 185
             'item_description'          => __( 'Item Description', 'invoicing' ),
186 186
             'invoice_description'       => __( 'Invoice Description', 'invoicing' ),
187 187
             'discount_description'      => __( 'Discount Description', 'invoicing' ),
188
-			'searching'                 => __( 'Searching', 'invoicing' ),
189
-			'loading'                   => __( 'Loading...', 'invoicing' ),
190
-			'search_customers'          => __( 'Enter customer name or email', 'invoicing' ),
191
-			'search_items'              => __( 'Enter item name', 'invoicing' ),
188
+            'searching'                 => __( 'Searching', 'invoicing' ),
189
+            'loading'                   => __( 'Loading...', 'invoicing' ),
190
+            'search_customers'          => __( 'Enter customer name or email', 'invoicing' ),
191
+            'search_items'              => __( 'Enter item name', 'invoicing' ),
192 192
         );
193 193
 
194
-		if ( ! empty( $post ) && getpaid_is_invoice_post_type( $post->post_type ) ) {
194
+        if ( ! empty( $post ) && getpaid_is_invoice_post_type( $post->post_type ) ) {
195 195
 
196
-			$invoice              = new WPInv_Invoice( $post );
197
-			$i18n['save_invoice'] = sprintf(
198
-				__( 'Save %s', 'invoicing' ),
199
-				ucfirst( $invoice->get_invoice_quote_type() )
200
-			);
196
+            $invoice              = new WPInv_Invoice( $post );
197
+            $i18n['save_invoice'] = sprintf(
198
+                __( 'Save %s', 'invoicing' ),
199
+                ucfirst( $invoice->get_invoice_quote_type() )
200
+            );
201 201
 
202
-			$i18n['invoice_description'] = sprintf(
203
-				__( '%s Description', 'invoicing' ),
204
-				ucfirst( $invoice->get_invoice_quote_type() )
205
-			);
202
+            $i18n['invoice_description'] = sprintf(
203
+                __( '%s Description', 'invoicing' ),
204
+                ucfirst( $invoice->get_invoice_quote_type() )
205
+            );
206 206
 
207
-		}
208
-		return $i18n;
209
-	}
207
+        }
208
+        return $i18n;
209
+    }
210 210
 
211
-	/**
212
-	 * Change the admin footer text on GetPaid admin pages.
213
-	 *
214
-	 * @since  2.0.0
215
-	 * @param  string $footer_text
216
-	 * @return string
217
-	 */
218
-	public function admin_footer_text( $footer_text ) {
219
-		global $current_screen;
211
+    /**
212
+     * Change the admin footer text on GetPaid admin pages.
213
+     *
214
+     * @since  2.0.0
215
+     * @param  string $footer_text
216
+     * @return string
217
+     */
218
+    public function admin_footer_text( $footer_text ) {
219
+        global $current_screen;
220 220
 
221
-		$page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
221
+        $page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
222 222
 
223 223
         if ( ! empty( $current_screen->post_type ) ) {
224
-			$page = $current_screen->post_type;
224
+            $page = $current_screen->post_type;
225 225
         }
226 226
 
227 227
         // General styles.
228 228
         if ( apply_filters( 'getpaid_display_admin_footer_text', wpinv_current_user_can_manage_invoicing() ) && false !== stripos( $page, 'wpi' ) ) {
229 229
 
230
-			// Change the footer text
231
-			if ( ! get_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', true ) ) {
232
-
233
-				$rating_url  = esc_url(
234
-					wp_nonce_url(
235
-						admin_url( 'admin.php?page=wpinv-reports&getpaid-admin-action=rate_plugin' ),
236
-						'getpaid-nonce',
237
-						'getpaid-nonce'
238
-						)
239
-				);
240
-
241
-				$footer_text = sprintf(
242
-					/* translators: %s: five stars */
243
-					__( 'If you like <strong>GetPaid</strong>, please leave us a %s rating. A huge thanks in advance!', 'invoicing' ),
244
-					"<a href='$rating_url'>&#9733;&#9733;&#9733;&#9733;&#9733;</a>"
245
-				);
246
-
247
-			} else {
248
-
249
-				$footer_text = sprintf(
250
-					/* translators: %s: GetPaid */
251
-					__( 'Thank you for using %s!', 'invoicing' ),
252
-					"<a href='https://wpgetpaid.com/' target='_blank'><strong>GetPaid</strong></a>"
253
-				);
254
-
255
-			}
256
-
257
-		}
258
-
259
-		return $footer_text;
260
-	}
261
-
262
-	/**
263
-	 * Redirects to wp.org to rate the plugin.
264
-	 *
265
-	 * @since  2.0.0
266
-	 */
267
-	public function redirect_to_wordpress_rating_page() {
268
-		update_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', 1 );
269
-		wp_redirect( 'https://wordpress.org/support/plugin/invoicing/reviews?rate=5#new-post' );
270
-		exit;
271
-	}
272
-
273
-    /**
274
-	 * Loads payment form js.
275
-	 *
276
-	 */
277
-	protected function load_payment_form_scripts() {
230
+            // Change the footer text
231
+            if ( ! get_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', true ) ) {
232
+
233
+                $rating_url  = esc_url(
234
+                    wp_nonce_url(
235
+                        admin_url( 'admin.php?page=wpinv-reports&getpaid-admin-action=rate_plugin' ),
236
+                        'getpaid-nonce',
237
+                        'getpaid-nonce'
238
+                        )
239
+                );
240
+
241
+                $footer_text = sprintf(
242
+                    /* translators: %s: five stars */
243
+                    __( 'If you like <strong>GetPaid</strong>, please leave us a %s rating. A huge thanks in advance!', 'invoicing' ),
244
+                    "<a href='$rating_url'>&#9733;&#9733;&#9733;&#9733;&#9733;</a>"
245
+                );
246
+
247
+            } else {
248
+
249
+                $footer_text = sprintf(
250
+                    /* translators: %s: GetPaid */
251
+                    __( 'Thank you for using %s!', 'invoicing' ),
252
+                    "<a href='https://wpgetpaid.com/' target='_blank'><strong>GetPaid</strong></a>"
253
+                );
254
+
255
+            }
256
+
257
+        }
258
+
259
+        return $footer_text;
260
+    }
261
+
262
+    /**
263
+     * Redirects to wp.org to rate the plugin.
264
+     *
265
+     * @since  2.0.0
266
+     */
267
+    public function redirect_to_wordpress_rating_page() {
268
+        update_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', 1 );
269
+        wp_redirect( 'https://wordpress.org/support/plugin/invoicing/reviews?rate=5#new-post' );
270
+        exit;
271
+    }
272
+
273
+    /**
274
+     * Loads payment form js.
275
+     *
276
+     */
277
+    protected function load_payment_form_scripts() {
278 278
         global $post;
279 279
 
280 280
         wp_enqueue_script( 'vue', WPINV_PLUGIN_URL . 'assets/js/vue/vue.min.js', array(), WPINV_VERSION );
281
-		wp_enqueue_script( 'sortable', WPINV_PLUGIN_URL . 'assets/js/sortable.min.js', array(), WPINV_VERSION );
282
-		wp_enqueue_script( 'vue_draggable', WPINV_PLUGIN_URL . 'assets/js/vue/vuedraggable.min.js', array( 'sortable', 'vue' ), WPINV_VERSION );
281
+        wp_enqueue_script( 'sortable', WPINV_PLUGIN_URL . 'assets/js/sortable.min.js', array(), WPINV_VERSION );
282
+        wp_enqueue_script( 'vue_draggable', WPINV_PLUGIN_URL . 'assets/js/vue/vuedraggable.min.js', array( 'sortable', 'vue' ), WPINV_VERSION );
283 283
 
284
-		$version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/admin-payment-forms.js' );
285
-		wp_register_script( 'wpinv-admin-payment-form-script', WPINV_PLUGIN_URL . 'assets/js/admin-payment-forms.js', array( 'wpinv-admin-script', 'vue_draggable' ),  $version );
284
+        $version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/admin-payment-forms.js' );
285
+        wp_register_script( 'wpinv-admin-payment-form-script', WPINV_PLUGIN_URL . 'assets/js/admin-payment-forms.js', array( 'wpinv-admin-script', 'vue_draggable' ),  $version );
286 286
 
287
-		wp_localize_script(
287
+        wp_localize_script(
288 288
             'wpinv-admin-payment-form-script',
289 289
             'wpinvPaymentFormAdmin',
290 290
             array(
291
-				'elements'      => wpinv_get_data( 'payment-form-elements' ),
292
-				'form_elements' => getpaid_get_payment_form_elements( $post->ID ),
293
-				'currency'      => wpinv_currency_symbol(),
294
-				'position'      => wpinv_currency_position(),
295
-				'decimals'      => (int) wpinv_decimals(),
296
-				'thousands_sep' => wpinv_thousands_separator(),
297
-				'decimals_sep'  => wpinv_decimal_separator(),
298
-				'form_items'    => gepaid_get_form_items( $post->ID ),
299
-				'is_default'    => $post->ID == wpinv_get_default_payment_form(),
291
+                'elements'      => wpinv_get_data( 'payment-form-elements' ),
292
+                'form_elements' => getpaid_get_payment_form_elements( $post->ID ),
293
+                'currency'      => wpinv_currency_symbol(),
294
+                'position'      => wpinv_currency_position(),
295
+                'decimals'      => (int) wpinv_decimals(),
296
+                'thousands_sep' => wpinv_thousands_separator(),
297
+                'decimals_sep'  => wpinv_decimal_separator(),
298
+                'form_items'    => gepaid_get_form_items( $post->ID ),
299
+                'is_default'    => $post->ID == wpinv_get_default_payment_form(),
300 300
             )
301 301
         );
302 302
 
@@ -305,20 +305,20 @@  discard block
 block discarded – undo
305 305
     }
306 306
 
307 307
     /**
308
-	 * Add our classes to admin pages.
308
+     * Add our classes to admin pages.
309 309
      *
310 310
      * @param string $classes
311 311
      * @return string
312
-	 *
313
-	 */
312
+     *
313
+     */
314 314
     public function admin_body_class( $classes ) {
315
-		global $pagenow, $post, $current_screen;
315
+        global $pagenow, $post, $current_screen;
316 316
 
317 317
 
318 318
         $page = isset( $_GET['page'] ) ? $_GET['page'] : '';
319 319
 
320 320
         if ( ! empty( $current_screen->post_type ) ) {
321
-			$page = $current_screen->post_type;
321
+            $page = $current_screen->post_type;
322 322
         }
323 323
 
324 324
         if ( false !== stripos( $page, 'wpi' ) ) {
@@ -327,68 +327,68 @@  discard block
 block discarded – undo
327 327
 
328 328
         if ( in_array( $page, wpinv_parse_list( 'wpi_invoice wpi_payment_form wpi_quote' ) ) ) {
329 329
             $classes .= ' wpinv-cpt wpinv';
330
-		}
330
+        }
331 331
 		
332
-		if ( getpaid_is_invoice_post_type( $page ) ) {
332
+        if ( getpaid_is_invoice_post_type( $page ) ) {
333 333
             $classes .= ' getpaid-is-invoice-cpt';
334 334
         }
335 335
 
336
-		return $classes;
336
+        return $classes;
337 337
     }
338 338
 
339 339
     /**
340
-	 * Maybe show the AyeCode Connect Notice.
341
-	 */
342
-	public function init_ayecode_connect_helper(){
340
+     * Maybe show the AyeCode Connect Notice.
341
+     */
342
+    public function init_ayecode_connect_helper(){
343 343
 
344
-		// Register with the deactivation survey class.
345
-		AyeCode_Deactivation_Survey::instance(array(
346
-			'slug'		        => 'invoicing',
347
-			'version'	        => WPINV_VERSION,
348
-			'support_url'       => 'https://wpgetpaid.com/support/',
349
-			'documentation_url' => 'https://docs.wpgetpaid.com/',
350
-			'activated'         => (int) get_option( 'gepaid_installed_on' ),
351
-		));
344
+        // Register with the deactivation survey class.
345
+        AyeCode_Deactivation_Survey::instance(array(
346
+            'slug'		        => 'invoicing',
347
+            'version'	        => WPINV_VERSION,
348
+            'support_url'       => 'https://wpgetpaid.com/support/',
349
+            'documentation_url' => 'https://docs.wpgetpaid.com/',
350
+            'activated'         => (int) get_option( 'gepaid_installed_on' ),
351
+        ));
352 352
 
353 353
         new AyeCode_Connect_Helper(
354 354
             array(
355
-				'connect_title' => __("WP Invoicing - an AyeCode product!","invoicing"),
356
-				'connect_external'  => __( "Please confirm you wish to connect your site?","invoicing" ),
357
-				'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s","invoicing" ),"<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>","</a>" ),
358
-				'connect_button'    => __("Connect Site","invoicing"),
359
-				'connecting_button'    => __("Connecting...","invoicing"),
360
-				'error_localhost'   => __( "This service will only work with a live domain, not a localhost.","invoicing" ),
361
-				'error'             => __( "Something went wrong, please refresh and try again.","invoicing" ),
355
+                'connect_title' => __("WP Invoicing - an AyeCode product!","invoicing"),
356
+                'connect_external'  => __( "Please confirm you wish to connect your site?","invoicing" ),
357
+                'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s","invoicing" ),"<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>","</a>" ),
358
+                'connect_button'    => __("Connect Site","invoicing"),
359
+                'connecting_button'    => __("Connecting...","invoicing"),
360
+                'error_localhost'   => __( "This service will only work with a live domain, not a localhost.","invoicing" ),
361
+                'error'             => __( "Something went wrong, please refresh and try again.","invoicing" ),
362 362
             ),
363 363
             array( 'wpi-addons' )
364 364
         );
365 365
 
366 366
     }
367 367
 
368
-	/**
369
-	 * Redirect users to settings on activation.
370
-	 *
371
-	 * @return void
372
-	 */
373
-	public function activation_redirect() {
368
+    /**
369
+     * Redirect users to settings on activation.
370
+     *
371
+     * @return void
372
+     */
373
+    public function activation_redirect() {
374 374
 
375
-		$redirected = get_option( 'wpinv_redirected_to_settings' );
375
+        $redirected = get_option( 'wpinv_redirected_to_settings' );
376 376
 
377
-		if ( ! empty( $redirected ) || wp_doing_ajax() || ! current_user_can( 'manage_options' ) ) {
378
-			return;
379
-		}
377
+        if ( ! empty( $redirected ) || wp_doing_ajax() || ! current_user_can( 'manage_options' ) ) {
378
+            return;
379
+        }
380 380
 
381
-		// Bail if activating from network, or bulk
382
-		if ( is_network_admin() || isset( $_GET['activate-multi'] ) ) {
383
-			return;
384
-		}
381
+        // Bail if activating from network, or bulk
382
+        if ( is_network_admin() || isset( $_GET['activate-multi'] ) ) {
383
+            return;
384
+        }
385 385
 
386
-	    update_option( 'wpinv_redirected_to_settings', 1 );
386
+        update_option( 'wpinv_redirected_to_settings', 1 );
387 387
 
388 388
         wp_safe_redirect( admin_url( 'index.php?page=gp-setup' ) );
389 389
         exit;
390 390
 
391
-	}
391
+    }
392 392
 
393 393
     /**
394 394
      * Fires an admin action after verifying that a user can fire them.
@@ -402,498 +402,498 @@  discard block
 block discarded – undo
402 402
 
403 403
     }
404 404
 
405
-	/**
405
+    /**
406 406
      * Sends a payment reminder to a customer.
407
-	 * 
408
-	 * @param array $args
407
+     * 
408
+     * @param array $args
409 409
      */
410 410
     public function duplicate_payment_form( $args ) {
411 411
 
412
-		if ( empty( $args['form_id'] ) ) {
413
-			return;
414
-		}
415
-
416
-		$form = new GetPaid_Payment_Form( $args['form_id'] );
412
+        if ( empty( $args['form_id'] ) ) {
413
+            return;
414
+        }
417 415
 
418
-		if ( ! $form->exists() ) {
419
-			return;
420
-		}
416
+        $form = new GetPaid_Payment_Form( $args['form_id'] );
421 417
 
422
-		$new_form = new GetPaid_Payment_Form();
423
-		$new_form->set_author( $form->get_author( 'edit' ) );
424
-		$new_form->set_name( $form->get_name( 'edit' ) . __( '(copy)', 'invoicing' ) );
425
-		$new_form->set_elements( $form->get_elements( 'edit' ) );
426
-		$new_form->set_items( $form->get_items( 'edit' ) );
427
-		$new_form->save();
418
+        if ( ! $form->exists() ) {
419
+            return;
420
+        }
428 421
 
429
-		if ( $new_form->exists() ) {
430
-			$this->show_success( __( 'Form duplicated successfully', 'invoicing' ) );
431
-			$url = get_edit_post_link( $new_form->get_id(), 'edit' );
432
-		} else {
433
-			$this->show_error( __( 'Unable to duplicate form', 'invoicing' ) );
434
-			$url = remove_query_arg( array( 'getpaid-admin-action', 'form_id', 'getpaid-nonce' ) );
435
-		}
422
+        $new_form = new GetPaid_Payment_Form();
423
+        $new_form->set_author( $form->get_author( 'edit' ) );
424
+        $new_form->set_name( $form->get_name( 'edit' ) . __( '(copy)', 'invoicing' ) );
425
+        $new_form->set_elements( $form->get_elements( 'edit' ) );
426
+        $new_form->set_items( $form->get_items( 'edit' ) );
427
+        $new_form->save();
428
+
429
+        if ( $new_form->exists() ) {
430
+            $this->show_success( __( 'Form duplicated successfully', 'invoicing' ) );
431
+            $url = get_edit_post_link( $new_form->get_id(), 'edit' );
432
+        } else {
433
+            $this->show_error( __( 'Unable to duplicate form', 'invoicing' ) );
434
+            $url = remove_query_arg( array( 'getpaid-admin-action', 'form_id', 'getpaid-nonce' ) );
435
+        }
436 436
 
437
-		wp_redirect( $url );
438
-		exit;
439
-	}
437
+        wp_redirect( $url );
438
+        exit;
439
+    }
440 440
 
441
-	/**
441
+    /**
442 442
      * Sends a payment reminder to a customer.
443
-	 * 
444
-	 * @param array $args
443
+     * 
444
+     * @param array $args
445 445
      */
446 446
     public function send_customer_invoice( $args ) {
447
-		$sent = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $args['invoice_id'] ), true );
447
+        $sent = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $args['invoice_id'] ), true );
448 448
 
449
-		if ( $sent ) {
450
-			$this->show_success( __( 'Invoice was successfully sent to the customer', 'invoicing' ) );
451
-		} else {
452
-			$this->show_error( __( 'Could not send the invoice to the customer', 'invoicing' ) );
453
-		}
449
+        if ( $sent ) {
450
+            $this->show_success( __( 'Invoice was successfully sent to the customer', 'invoicing' ) );
451
+        } else {
452
+            $this->show_error( __( 'Could not send the invoice to the customer', 'invoicing' ) );
453
+        }
454 454
 
455
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
456
-		exit;
457
-	}
455
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
456
+        exit;
457
+    }
458 458
 
459
-	/**
459
+    /**
460 460
      * Sends a payment reminder to a customer.
461
-	 * 
462
-	 * @param array $args
461
+     * 
462
+     * @param array $args
463 463
      */
464 464
     public function send_customer_payment_reminder( $args ) {
465
-		$sent = getpaid()->get( 'invoice_emails' )->force_send_overdue_notice( new WPInv_Invoice( $args['invoice_id'] ) );
465
+        $sent = getpaid()->get( 'invoice_emails' )->force_send_overdue_notice( new WPInv_Invoice( $args['invoice_id'] ) );
466 466
 
467
-		if ( $sent ) {
468
-			$this->show_success( __( 'Payment reminder was successfully sent to the customer', 'invoicing' ) );
469
-		} else {
470
-			$this->show_error( __( 'Could not sent payment reminder to the customer', 'invoicing' ) );
471
-		}
467
+        if ( $sent ) {
468
+            $this->show_success( __( 'Payment reminder was successfully sent to the customer', 'invoicing' ) );
469
+        } else {
470
+            $this->show_error( __( 'Could not sent payment reminder to the customer', 'invoicing' ) );
471
+        }
472 472
 
473
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
474
-		exit;
475
-	}
473
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
474
+        exit;
475
+    }
476 476
 
477
-	/**
477
+    /**
478 478
      * Resets tax rates.
479
-	 * 
479
+     * 
480 480
      */
481 481
     public function admin_reset_tax_rates() {
482 482
 
483
-		update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
484
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
485
-		exit;
483
+        update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
484
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
485
+        exit;
486 486
 
487
-	}
487
+    }
488 488
 
489
-	/**
489
+    /**
490 490
      * Resets admin pages.
491
-	 * 
491
+     * 
492 492
      */
493 493
     public function admin_create_missing_pages() {
494
-		$installer = new GetPaid_Installer();
495
-		$installer->create_pages();
496
-		$this->show_success( __( 'GetPaid pages updated.', 'invoicing' ) );
497
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
498
-		exit;
499
-	}
500
-
501
-	/**
494
+        $installer = new GetPaid_Installer();
495
+        $installer->create_pages();
496
+        $this->show_success( __( 'GetPaid pages updated.', 'invoicing' ) );
497
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
498
+        exit;
499
+    }
500
+
501
+    /**
502 502
      * Creates an missing admin tables.
503
-	 * 
503
+     * 
504 504
      */
505 505
     public function admin_create_missing_tables() {
506
-		global $wpdb;
507
-		$installer = new GetPaid_Installer();
506
+        global $wpdb;
507
+        $installer = new GetPaid_Installer();
508 508
 
509
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}wpinv_subscriptions'" ) != $wpdb->prefix . 'wpinv_subscriptions' ) {
510
-			$installer->create_subscriptions_table();
509
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}wpinv_subscriptions'" ) != $wpdb->prefix . 'wpinv_subscriptions' ) {
510
+            $installer->create_subscriptions_table();
511 511
 
512
-			if ( $wpdb->last_error !== '' ) {
513
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
514
-			}
515
-		}
512
+            if ( $wpdb->last_error !== '' ) {
513
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
514
+            }
515
+        }
516 516
 
517
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoices'" ) != $wpdb->prefix . 'getpaid_invoices' ) {
518
-			$installer->create_invoices_table();
517
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoices'" ) != $wpdb->prefix . 'getpaid_invoices' ) {
518
+            $installer->create_invoices_table();
519 519
 
520
-			if ( $wpdb->last_error !== '' ) {
521
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
522
-			}
523
-		}
520
+            if ( $wpdb->last_error !== '' ) {
521
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
522
+            }
523
+        }
524 524
 
525
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoice_items'" ) != $wpdb->prefix . 'getpaid_invoice_items' ) {
526
-			$installer->create_invoice_items_table();
525
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoice_items'" ) != $wpdb->prefix . 'getpaid_invoice_items' ) {
526
+            $installer->create_invoice_items_table();
527 527
 
528
-			if ( $wpdb->last_error !== '' ) {
529
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
530
-			}
531
-		}
528
+            if ( $wpdb->last_error !== '' ) {
529
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
530
+            }
531
+        }
532 532
 
533
-		if ( ! $this->has_notices() ) {
534
-			$this->show_success( __( 'Your GetPaid tables have been updated.', 'invoicing' ) );
535
-		}
533
+        if ( ! $this->has_notices() ) {
534
+            $this->show_success( __( 'Your GetPaid tables have been updated.', 'invoicing' ) );
535
+        }
536 536
 
537
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
538
-		exit;
539
-	}
537
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
538
+        exit;
539
+    }
540 540
 
541
-	/**
541
+    /**
542 542
      * Migrates old invoices to the new database tables.
543
-	 * 
543
+     * 
544 544
      */
545 545
     public function admin_migrate_old_invoices() {
546 546
 
547
-		// Migrate the invoices.
548
-		$installer = new GetPaid_Installer();
549
-		$installer->migrate_old_invoices();
547
+        // Migrate the invoices.
548
+        $installer = new GetPaid_Installer();
549
+        $installer->migrate_old_invoices();
550 550
 
551
-		// Show an admin message.
552
-		$this->show_success( __( 'Your invoices have been migrated.', 'invoicing' ) );
551
+        // Show an admin message.
552
+        $this->show_success( __( 'Your invoices have been migrated.', 'invoicing' ) );
553 553
 
554
-		// Redirect the admin.
555
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
556
-		exit;
554
+        // Redirect the admin.
555
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
556
+        exit;
557 557
 
558
-	}
558
+    }
559 559
 
560
-	/**
560
+    /**
561 561
      * Download customers.
562
-	 * 
562
+     * 
563 563
      */
564 564
     public function admin_download_customers() {
565
-		global $wpdb;
565
+        global $wpdb;
566 566
 
567
-		$output = fopen( 'php://output', 'w' ) or die( __( 'Unsupported server', 'invoicing' ) );
567
+        $output = fopen( 'php://output', 'w' ) or die( __( 'Unsupported server', 'invoicing' ) );
568 568
 
569
-		header( "Content-Type:text/csv" );
570
-		header( "Content-Disposition:attachment;filename=customers.csv" );
569
+        header( "Content-Type:text/csv" );
570
+        header( "Content-Disposition:attachment;filename=customers.csv" );
571 571
 
572
-		$post_types = '';
572
+        $post_types = '';
573 573
 
574
-		foreach ( array_keys( getpaid_get_invoice_post_types() ) as $post_type ) {
575
-			$post_types .= $wpdb->prepare( "post_type=%s OR ", $post_type );
576
-		}
574
+        foreach ( array_keys( getpaid_get_invoice_post_types() ) as $post_type ) {
575
+            $post_types .= $wpdb->prepare( "post_type=%s OR ", $post_type );
576
+        }
577 577
 
578
-		$post_types = rtrim( $post_types, ' OR' );
578
+        $post_types = rtrim( $post_types, ' OR' );
579 579
 
580
-		$customers = $wpdb->get_col(
581
-			$wpdb->prepare(
582
-				"SELECT DISTINCT( post_author ) FROM $wpdb->posts WHERE $post_types"
583
-			)
584
-		);
580
+        $customers = $wpdb->get_col(
581
+            $wpdb->prepare(
582
+                "SELECT DISTINCT( post_author ) FROM $wpdb->posts WHERE $post_types"
583
+            )
584
+        );
585 585
 
586
-		$columns = array(
587
-			'name'     => __( 'Name', 'invoicing' ),
588
-			'email'    => __( 'Email', 'invoicing' ),
589
-			'country'  => __( 'Country', 'invoicing' ),
590
-			'state'    => __( 'State', 'invoicing' ),
591
-			'city'     => __( 'City', 'invoicing' ),
592
-			'zip'      => __( 'ZIP', 'invoicing' ),
593
-			'address'  => __( 'Address', 'invoicing' ),
594
-			'phone'    => __( 'Phone', 'invoicing' ),
595
-			'company'  => __( 'Company', 'invoicing' ),
596
-			'company_id'  => __( 'Company ID', 'invoicing' ),
597
-			'invoices' => __( 'Invoices', 'invoicing' ),
598
-			'total_raw' => __( 'Total Spend', 'invoicing' ),
599
-			'signup'   => __( 'Date created', 'invoicing' ),
600
-		);
586
+        $columns = array(
587
+            'name'     => __( 'Name', 'invoicing' ),
588
+            'email'    => __( 'Email', 'invoicing' ),
589
+            'country'  => __( 'Country', 'invoicing' ),
590
+            'state'    => __( 'State', 'invoicing' ),
591
+            'city'     => __( 'City', 'invoicing' ),
592
+            'zip'      => __( 'ZIP', 'invoicing' ),
593
+            'address'  => __( 'Address', 'invoicing' ),
594
+            'phone'    => __( 'Phone', 'invoicing' ),
595
+            'company'  => __( 'Company', 'invoicing' ),
596
+            'company_id'  => __( 'Company ID', 'invoicing' ),
597
+            'invoices' => __( 'Invoices', 'invoicing' ),
598
+            'total_raw' => __( 'Total Spend', 'invoicing' ),
599
+            'signup'   => __( 'Date created', 'invoicing' ),
600
+        );
601 601
 
602
-		// Output the csv column headers.
603
-		fputcsv( $output, array_values( $columns ) );
602
+        // Output the csv column headers.
603
+        fputcsv( $output, array_values( $columns ) );
604 604
 
605
-		// Loop through
606
-		$table = new WPInv_Customers_Table();
607
-		foreach ( $customers as $customer_id ) {
605
+        // Loop through
606
+        $table = new WPInv_Customers_Table();
607
+        foreach ( $customers as $customer_id ) {
608 608
 
609
-			$user = get_user_by( 'id', $customer_id );
610
-			$row  = array();
611
-			if ( empty( $user ) ) {
612
-				continue;
613
-			}
609
+            $user = get_user_by( 'id', $customer_id );
610
+            $row  = array();
611
+            if ( empty( $user ) ) {
612
+                continue;
613
+            }
614 614
 
615
-			foreach ( array_keys( $columns ) as $column ) {
615
+            foreach ( array_keys( $columns ) as $column ) {
616 616
 
617
-				$method = 'column_' . $column;
617
+                $method = 'column_' . $column;
618 618
 
619
-				if ( 'name' == $column ) {
620
-					$value = sanitize_text_field( $user->display_name );
621
-				} else if( 'email' == $column ) {
622
-					$value = sanitize_email( $user->user_email );
623
-				} else if ( is_callable( array( $table, $method ) ) ) {
624
-					$value = strip_tags( $table->$method( $user ) );
625
-				}
619
+                if ( 'name' == $column ) {
620
+                    $value = sanitize_text_field( $user->display_name );
621
+                } else if( 'email' == $column ) {
622
+                    $value = sanitize_email( $user->user_email );
623
+                } else if ( is_callable( array( $table, $method ) ) ) {
624
+                    $value = strip_tags( $table->$method( $user ) );
625
+                }
626 626
 
627
-				if ( empty( $value ) ) {
628
-					$value = sanitize_text_field( get_user_meta( $user->ID, '_wpinv_' . $column, true ) );
629
-				}
627
+                if ( empty( $value ) ) {
628
+                    $value = sanitize_text_field( get_user_meta( $user->ID, '_wpinv_' . $column, true ) );
629
+                }
630 630
 
631
-				$row[] = $value;
631
+                $row[] = $value;
632 632
 
633
-			}
633
+            }
634 634
 
635
-			fputcsv( $output, $row );
636
-		}
635
+            fputcsv( $output, $row );
636
+        }
637 637
 
638
-		fclose( $output );
639
-		exit;
638
+        fclose( $output );
639
+        exit;
640 640
 
641
-	}
641
+    }
642 642
 
643
-	/**
643
+    /**
644 644
      * Installs a plugin.
645
-	 *
646
-	 * @param array $data
645
+     *
646
+     * @param array $data
647 647
      */
648 648
     public function admin_install_plugin( $data ) {
649 649
 
650
-		if ( ! empty( $data['plugins'] ) ) {
651
-			include_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
652
-			wp_cache_flush();
650
+        if ( ! empty( $data['plugins'] ) ) {
651
+            include_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
652
+            wp_cache_flush();
653 653
 
654
-			foreach ( $data['plugins'] as $slug => $file ) {
655
-				$plugin_zip = esc_url( 'https://downloads.wordpress.org/plugin/' . $slug . '.latest-stable.zip' );
656
-				$upgrader   = new Plugin_Upgrader( new Automatic_Upgrader_Skin() );
657
-				$installed  = $upgrader->install( $plugin_zip );
654
+            foreach ( $data['plugins'] as $slug => $file ) {
655
+                $plugin_zip = esc_url( 'https://downloads.wordpress.org/plugin/' . $slug . '.latest-stable.zip' );
656
+                $upgrader   = new Plugin_Upgrader( new Automatic_Upgrader_Skin() );
657
+                $installed  = $upgrader->install( $plugin_zip );
658 658
 
659
-				if ( ! is_wp_error( $installed ) && $installed ) {
660
-					activate_plugin( $file, '', false, true );
661
-				} else {
662
-					wpinv_error_log( $upgrader->skin->get_upgrade_messages(), false );
663
-				}
659
+                if ( ! is_wp_error( $installed ) && $installed ) {
660
+                    activate_plugin( $file, '', false, true );
661
+                } else {
662
+                    wpinv_error_log( $upgrader->skin->get_upgrade_messages(), false );
663
+                }
664 664
 
665
-			}
665
+            }
666 666
 
667
-		}
667
+        }
668 668
 
669
-		$redirect = isset( $data['redirect'] ) ? esc_url_raw( $data['redirect'] ) : admin_url( 'plugins.php' );
670
-		wp_safe_redirect( $redirect );
671
-		exit;
669
+        $redirect = isset( $data['redirect'] ) ? esc_url_raw( $data['redirect'] ) : admin_url( 'plugins.php' );
670
+        wp_safe_redirect( $redirect );
671
+        exit;
672 672
 
673
-	}
673
+    }
674 674
 
675
-	/**
675
+    /**
676 676
      * Connects a gateway.
677
-	 *
678
-	 * @param array $data
677
+     *
678
+     * @param array $data
679 679
      */
680 680
     public function admin_connect_gateway( $data ) {
681 681
 
682
-		if ( ! empty( $data['plugin'] ) ) {
682
+        if ( ! empty( $data['plugin'] ) ) {
683 683
 
684
-			$gateway     = sanitize_key( $data['plugin'] );
685
-			$connect_url = apply_filters( "getpaid_get_{$gateway}_connect_url", false, $data );
684
+            $gateway     = sanitize_key( $data['plugin'] );
685
+            $connect_url = apply_filters( "getpaid_get_{$gateway}_connect_url", false, $data );
686 686
 
687
-			if ( ! empty( $connect_url ) ) {
688
-				wp_redirect( $connect_url );
689
-				exit;
690
-			}
687
+            if ( ! empty( $connect_url ) ) {
688
+                wp_redirect( $connect_url );
689
+                exit;
690
+            }
691 691
 
692
-			if ( 'stripe' == $data['plugin'] ) {
693
-				require_once ABSPATH . 'wp-admin/includes/plugin.php';
694
-				include_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
695
-				wp_cache_flush();
692
+            if ( 'stripe' == $data['plugin'] ) {
693
+                require_once ABSPATH . 'wp-admin/includes/plugin.php';
694
+                include_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php';
695
+                wp_cache_flush();
696 696
 
697
-				if ( ! array_key_exists( 'getpaid-stripe-payments/getpaid-stripe-payments.php', get_plugins() ) ) {
698
-					$plugin_zip = esc_url( 'https://downloads.wordpress.org/plugin/getpaid-stripe-payments.latest-stable.zip' );
699
-					$upgrader   = new Plugin_Upgrader( new Automatic_Upgrader_Skin() );
700
-					$upgrader->install( $plugin_zip );
701
-				}
697
+                if ( ! array_key_exists( 'getpaid-stripe-payments/getpaid-stripe-payments.php', get_plugins() ) ) {
698
+                    $plugin_zip = esc_url( 'https://downloads.wordpress.org/plugin/getpaid-stripe-payments.latest-stable.zip' );
699
+                    $upgrader   = new Plugin_Upgrader( new Automatic_Upgrader_Skin() );
700
+                    $upgrader->install( $plugin_zip );
701
+                }
702 702
 
703
-				activate_plugin( 'getpaid-stripe-payments/getpaid-stripe-payments.php', '', false, true );
704
-			}
703
+                activate_plugin( 'getpaid-stripe-payments/getpaid-stripe-payments.php', '', false, true );
704
+            }
705 705
 
706
-			$connect_url = apply_filters( "getpaid_get_{$gateway}_connect_url", false, $data );
707
-			if ( ! empty( $connect_url ) ) {
708
-				wp_redirect( $connect_url );
709
-				exit;
710
-			}
706
+            $connect_url = apply_filters( "getpaid_get_{$gateway}_connect_url", false, $data );
707
+            if ( ! empty( $connect_url ) ) {
708
+                wp_redirect( $connect_url );
709
+                exit;
710
+            }
711 711
 
712
-		}
712
+        }
713 713
 
714
-		$redirect = isset( $data['redirect'] ) ? esc_url_raw( urldecode( $data['redirect'] ) ) : admin_url( 'admin.php?page=wpinv-settings&tab=gateways' );
715
-		wp_safe_redirect( $redirect );
716
-		exit;
714
+        $redirect = isset( $data['redirect'] ) ? esc_url_raw( urldecode( $data['redirect'] ) ) : admin_url( 'admin.php?page=wpinv-settings&tab=gateways' );
715
+        wp_safe_redirect( $redirect );
716
+        exit;
717 717
 
718
-	}
718
+    }
719 719
 
720
-	/**
720
+    /**
721 721
      * Recalculates discounts.
722
-	 * 
722
+     * 
723 723
      */
724 724
     public function admin_recalculate_discounts() {
725
-		global $wpdb;
725
+        global $wpdb;
726 726
 
727
-		// Fetch all invoices that have discount codes.
728
-		$table    = $wpdb->prefix . 'getpaid_invoices';
729
-		$invoices = $wpdb->get_col( "SELECT `post_id` FROM `$table` WHERE `discount` = 0 && `discount_code` <> ''" );
727
+        // Fetch all invoices that have discount codes.
728
+        $table    = $wpdb->prefix . 'getpaid_invoices';
729
+        $invoices = $wpdb->get_col( "SELECT `post_id` FROM `$table` WHERE `discount` = 0 && `discount_code` <> ''" );
730 730
 
731
-		foreach ( $invoices as $invoice ) {
731
+        foreach ( $invoices as $invoice ) {
732 732
 
733
-			$invoice = new WPInv_Invoice( $invoice );
733
+            $invoice = new WPInv_Invoice( $invoice );
734 734
 
735
-			if ( ! $invoice->exists() ) {
736
-				continue;
737
-			}
735
+            if ( ! $invoice->exists() ) {
736
+                continue;
737
+            }
738 738
 
739
-			// Abort if the discount does not exist or does not apply here.
740
-			$discount = new WPInv_Discount( $invoice->get_discount_code() );
741
-			if ( ! $discount->exists() ) {
742
-				continue;
743
-			}
739
+            // Abort if the discount does not exist or does not apply here.
740
+            $discount = new WPInv_Discount( $invoice->get_discount_code() );
741
+            if ( ! $discount->exists() ) {
742
+                continue;
743
+            }
744 744
 
745
-			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
746
-			$invoice->recalculate_total();
745
+            $invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
746
+            $invoice->recalculate_total();
747 747
 
748
-			if ( $invoice->get_total_discount() > 0 ) {
749
-				$invoice->save();
750
-			}
748
+            if ( $invoice->get_total_discount() > 0 ) {
749
+                $invoice->save();
750
+            }
751 751
 
752
-		}
752
+        }
753 753
 
754
-		// Show an admin message.
755
-		$this->show_success( __( 'Discounts have been recalculated.', 'invoicing' ) );
754
+        // Show an admin message.
755
+        $this->show_success( __( 'Discounts have been recalculated.', 'invoicing' ) );
756 756
 
757
-		// Redirect the admin.
758
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
759
-		exit;
757
+        // Redirect the admin.
758
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
759
+        exit;
760 760
 
761
-	}
761
+    }
762 762
 
763 763
     /**
764
-	 * Returns an array of admin notices.
765
-	 *
766
-	 * @since       1.0.19
764
+     * Returns an array of admin notices.
765
+     *
766
+     * @since       1.0.19
767 767
      * @return array
768
-	 */
769
-	public function get_notices() {
770
-		$notices = get_option( 'wpinv_admin_notices' );
768
+     */
769
+    public function get_notices() {
770
+        $notices = get_option( 'wpinv_admin_notices' );
771 771
         return is_array( $notices ) ? $notices : array();
772
-	}
772
+    }
773 773
 
774
-	/**
775
-	 * Checks if we have any admin notices.
776
-	 *
777
-	 * @since       2.0.4
774
+    /**
775
+     * Checks if we have any admin notices.
776
+     *
777
+     * @since       2.0.4
778 778
      * @return array
779
-	 */
780
-	public function has_notices() {
781
-		return count( $this->get_notices() ) > 0;
782
-	}
783
-
784
-	/**
785
-	 * Clears all admin notices
786
-	 *
787
-	 * @access      public
788
-	 * @since       1.0.19
789
-	 */
790
-	public function clear_notices() {
791
-		delete_option( 'wpinv_admin_notices' );
792
-	}
793
-
794
-	/**
795
-	 * Saves a new admin notice
796
-	 *
797
-	 * @access      public
798
-	 * @since       1.0.19
799
-	 */
800
-	public function save_notice( $type, $message ) {
801
-		$notices = $this->get_notices();
802
-
803
-		if ( empty( $notices[ $type ] ) || ! is_array( $notices[ $type ]) ) {
804
-			$notices[ $type ] = array();
805
-		}
806
-
807
-		$notices[ $type ][] = $message;
808
-
809
-		update_option( 'wpinv_admin_notices', $notices );
810
-	}
811
-
812
-	/**
813
-	 * Displays a success notice
814
-	 *
815
-	 * @param       string $msg The message to qeue.
816
-	 * @access      public
817
-	 * @since       1.0.19
818
-	 */
819
-	public function show_success( $msg ) {
820
-		$this->save_notice( 'success', $msg );
821
-	}
822
-
823
-	/**
824
-	 * Displays a error notice
825
-	 *
826
-	 * @access      public
827
-	 * @param       string $msg The message to qeue.
828
-	 * @since       1.0.19
829
-	 */
830
-	public function show_error( $msg ) {
831
-		$this->save_notice( 'error', $msg );
832
-	}
833
-
834
-	/**
835
-	 * Displays a warning notice
836
-	 *
837
-	 * @access      public
838
-	 * @param       string $msg The message to qeue.
839
-	 * @since       1.0.19
840
-	 */
841
-	public function show_warning( $msg ) {
842
-		$this->save_notice( 'warning', $msg );
843
-	}
844
-
845
-	/**
846
-	 * Displays a info notice
847
-	 *
848
-	 * @access      public
849
-	 * @param       string $msg The message to qeue.
850
-	 * @since       1.0.19
851
-	 */
852
-	public function show_info( $msg ) {
853
-		$this->save_notice( 'info', $msg );
854
-	}
855
-
856
-	/**
857
-	 * Show notices
858
-	 *
859
-	 * @access      public
860
-	 * @since       1.0.19
861
-	 */
862
-	public function show_notices() {
779
+     */
780
+    public function has_notices() {
781
+        return count( $this->get_notices() ) > 0;
782
+    }
783
+
784
+    /**
785
+     * Clears all admin notices
786
+     *
787
+     * @access      public
788
+     * @since       1.0.19
789
+     */
790
+    public function clear_notices() {
791
+        delete_option( 'wpinv_admin_notices' );
792
+    }
793
+
794
+    /**
795
+     * Saves a new admin notice
796
+     *
797
+     * @access      public
798
+     * @since       1.0.19
799
+     */
800
+    public function save_notice( $type, $message ) {
801
+        $notices = $this->get_notices();
802
+
803
+        if ( empty( $notices[ $type ] ) || ! is_array( $notices[ $type ]) ) {
804
+            $notices[ $type ] = array();
805
+        }
806
+
807
+        $notices[ $type ][] = $message;
808
+
809
+        update_option( 'wpinv_admin_notices', $notices );
810
+    }
811
+
812
+    /**
813
+     * Displays a success notice
814
+     *
815
+     * @param       string $msg The message to qeue.
816
+     * @access      public
817
+     * @since       1.0.19
818
+     */
819
+    public function show_success( $msg ) {
820
+        $this->save_notice( 'success', $msg );
821
+    }
822
+
823
+    /**
824
+     * Displays a error notice
825
+     *
826
+     * @access      public
827
+     * @param       string $msg The message to qeue.
828
+     * @since       1.0.19
829
+     */
830
+    public function show_error( $msg ) {
831
+        $this->save_notice( 'error', $msg );
832
+    }
833
+
834
+    /**
835
+     * Displays a warning notice
836
+     *
837
+     * @access      public
838
+     * @param       string $msg The message to qeue.
839
+     * @since       1.0.19
840
+     */
841
+    public function show_warning( $msg ) {
842
+        $this->save_notice( 'warning', $msg );
843
+    }
844
+
845
+    /**
846
+     * Displays a info notice
847
+     *
848
+     * @access      public
849
+     * @param       string $msg The message to qeue.
850
+     * @since       1.0.19
851
+     */
852
+    public function show_info( $msg ) {
853
+        $this->save_notice( 'info', $msg );
854
+    }
855
+
856
+    /**
857
+     * Show notices
858
+     *
859
+     * @access      public
860
+     * @since       1.0.19
861
+     */
862
+    public function show_notices() {
863 863
 
864 864
         $notices = $this->get_notices();
865 865
         $this->clear_notices();
866 866
 
867
-		foreach ( $notices as $type => $messages ) {
867
+        foreach ( $notices as $type => $messages ) {
868 868
 
869
-			if ( ! is_array( $messages ) ) {
870
-				continue;
871
-			}
869
+            if ( ! is_array( $messages ) ) {
870
+                continue;
871
+            }
872 872
 
873 873
             $type  = sanitize_key( $type );
874
-			foreach ( $messages as $message ) {
874
+            foreach ( $messages as $message ) {
875 875
                 $message = wp_kses_post( $message );
876
-				echo "<div class='notice notice-$type is-dismissible'><p>$message</p></div>";
876
+                echo "<div class='notice notice-$type is-dismissible'><p>$message</p></div>";
877 877
             }
878 878
 
879 879
         }
880 880
 
881
-		foreach ( array( 'checkout_page', 'invoice_history_page', 'success_page', 'failure_page', 'invoice_subscription_page' ) as $page ) {
882
-
883
-			if ( ! is_numeric( wpinv_get_option( $page, false ) ) ) {
884
-				$url     = wp_nonce_url(
885
-					add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
886
-					'getpaid-nonce',
887
-					'getpaid-nonce'
888
-				);
889
-				$message  = __( 'Some GetPaid pages are missing. To use GetPaid without any issues, click the button below to generate the missing pages.', 'invoicing' );
890
-				$message2 = __( 'Generate Pages', 'invoicing' );
891
-				echo "<div class='notice notice-warning is-dismissible'><p>$message<br><br><a href='$url' class='button button-primary'>$message2</a></p></div>";
892
-				break;
893
-			}
881
+        foreach ( array( 'checkout_page', 'invoice_history_page', 'success_page', 'failure_page', 'invoice_subscription_page' ) as $page ) {
882
+
883
+            if ( ! is_numeric( wpinv_get_option( $page, false ) ) ) {
884
+                $url     = wp_nonce_url(
885
+                    add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
886
+                    'getpaid-nonce',
887
+                    'getpaid-nonce'
888
+                );
889
+                $message  = __( 'Some GetPaid pages are missing. To use GetPaid without any issues, click the button below to generate the missing pages.', 'invoicing' );
890
+                $message2 = __( 'Generate Pages', 'invoicing' );
891
+                echo "<div class='notice notice-warning is-dismissible'><p>$message<br><br><a href='$url' class='button button-primary'>$message2</a></p></div>";
892
+                break;
893
+            }
894 894
 
895
-		}
895
+        }
896 896
 
897
-	}
897
+    }
898 898
 
899 899
 }
Please login to merge, or discard this patch.
invoicing.php 1 patch
Indentation   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -19,16 +19,16 @@  discard block
 block discarded – undo
19 19
 
20 20
 // Define constants.
21 21
 if ( ! defined( 'WPINV_PLUGIN_FILE' ) ) {
22
-	define( 'WPINV_PLUGIN_FILE', __FILE__ );
22
+    define( 'WPINV_PLUGIN_FILE', __FILE__ );
23 23
 }
24 24
 
25 25
 if ( ! defined( 'WPINV_VERSION' ) ) {
26
-	define( 'WPINV_VERSION', '2.4.5' );
26
+    define( 'WPINV_VERSION', '2.4.5' );
27 27
 }
28 28
 
29 29
 // Include the main Invoicing class.
30 30
 if ( ! class_exists( 'WPInv_Plugin', false ) ) {
31
-	require_once plugin_dir_path( WPINV_PLUGIN_FILE ) . 'includes/class-wpinv.php';
31
+    require_once plugin_dir_path( WPINV_PLUGIN_FILE ) . 'includes/class-wpinv.php';
32 32
 }
33 33
 
34 34
 /**
@@ -43,7 +43,7 @@  discard block
 block discarded – undo
43 43
         $GLOBALS['invoicing'] = new WPInv_Plugin();
44 44
     }
45 45
 
46
-	return $GLOBALS['invoicing'];
46
+    return $GLOBALS['invoicing'];
47 47
 }
48 48
 
49 49
 /**
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php 1 patch
Indentation   +18 added lines, -18 removed lines patch added patch discarded remove patch
@@ -7,40 +7,40 @@
 block discarded – undo
7 7
  * Bail if we are not in WP.
8 8
  */
9 9
 if ( ! defined( 'ABSPATH' ) ) {
10
-	exit;
10
+    exit;
11 11
 }
12 12
 
13 13
 /**
14 14
  * Set the version only if its the current newest while loading.
15 15
  */
16 16
 add_action('after_setup_theme', function () {
17
-	global $ayecode_ui_version,$ayecode_ui_file_key;
18
-	$this_version = "0.1.59";
19
-	if(version_compare($this_version , $ayecode_ui_version, '>')){
20
-		$ayecode_ui_version = $this_version ;
21
-		$ayecode_ui_file_key = wp_hash( __FILE__ );
22
-	}
17
+    global $ayecode_ui_version,$ayecode_ui_file_key;
18
+    $this_version = "0.1.59";
19
+    if(version_compare($this_version , $ayecode_ui_version, '>')){
20
+        $ayecode_ui_version = $this_version ;
21
+        $ayecode_ui_file_key = wp_hash( __FILE__ );
22
+    }
23 23
 },0);
24 24
 
25 25
 /**
26 26
  * Load this version of WP Bootstrap Settings only if the file hash is the current one.
27 27
  */
28 28
 add_action('after_setup_theme', function () {
29
-	global $ayecode_ui_file_key;
30
-	if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
-		include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
-		include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
-	}
29
+    global $ayecode_ui_file_key;
30
+    if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
+        include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
+        include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
+    }
34 34
 },1);
35 35
 
36 36
 /**
37 37
  * Add the function that calls the class.
38 38
  */
39 39
 if(!function_exists('aui')){
40
-	function aui(){
41
-		if(!class_exists("AUI",false)){
42
-			return false;
43
-		}
44
-		return AUI::instance();
45
-	}
40
+    function aui(){
41
+        if(!class_exists("AUI",false)){
42
+            return false;
43
+        }
44
+        return AUI::instance();
45
+    }
46 46
 }
47 47
\ No newline at end of file
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Indentation   +1046 added lines, -1046 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,1056 +11,1056 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI_Component_Input {
13 13
 
14
-	/**
15
-	 * Build the component.
16
-	 *
17
-	 * @param array $args
18
-	 *
19
-	 * @return string The rendered component.
20
-	 */
21
-	public static function input($args = array()){
22
-		$defaults = array(
23
-			'type'       => 'text',
24
-			'name'       => '',
25
-			'class'      => '',
26
-			'wrap_class' => '',
27
-			'id'         => '',
28
-			'placeholder'=> '',
29
-			'title'      => '',
30
-			'value'      => '',
31
-			'required'   => false,
32
-			'label'      => '',
33
-			'label_after'=> false,
34
-			'label_class'=> '',
35
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
36
-			'help_text'  => '',
37
-			'validation_text'   => '',
38
-			'validation_pattern' => '',
39
-			'no_wrap'    => false,
40
-			'input_group_right' => '',
41
-			'input_group_left' => '',
42
-			'input_group_right_inside' => false, // forces the input group inside the input
43
-			'input_group_left_inside' => false, // forces the input group inside the input
44
-			'step'       => '',
45
-			'switch'     => false, // to show checkbox as a switch
46
-			'checked'   => false, // set a checkbox or radio as selected
47
-			'password_toggle' => true, // toggle view/hide password
48
-			'element_require'   => '', // [%element_id%] == "1"
49
-			'extra_attributes'  => array(), // an array of extra attributes
50
-			'wrap_attributes' => array()
51
-		);
52
-
53
-		/**
54
-		 * Parse incoming $args into an array and merge it with $defaults
55
-		 */
56
-		$args   = wp_parse_args( $args, $defaults );
57
-		$output = '';
58
-		if ( ! empty( $args['type'] ) ) {
59
-			// hidden label option needs to be empty
60
-			$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
61
-
62
-			$type = sanitize_html_class( $args['type'] );
63
-
64
-			$help_text = '';
65
-			$label = '';
66
-			$label_after = $args['label_after'];
67
-			$label_args = array(
68
-				'title'=> $args['label'],
69
-				'for'=> $args['id'],
70
-				'class' => $args['label_class']." ",
71
-				'label_type' => $args['label_type']
72
-			);
73
-
74
-			// floating labels need label after
75
-			if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
76
-				$label_after = true;
77
-				$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
78
-			}
79
-
80
-			// Some special sauce for files
81
-			if($type=='file' ){
82
-				$label_after = true; // if type file we need the label after
83
-				$args['class'] .= ' custom-file-input ';
84
-			}elseif($type=='checkbox'){
85
-				$label_after = true; // if type file we need the label after
86
-				$args['class'] .= ' custom-control-input ';
87
-			}elseif($type=='datepicker' || $type=='timepicker'){
88
-				$type = 'text';
89
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
90
-				$args['class'] .= ' bg-initial ';
91
-
92
-				$args['extra_attributes']['data-aui-init'] = 'flatpickr';
93
-				// enqueue the script
94
-				$aui_settings = AyeCode_UI_Settings::instance();
95
-				$aui_settings->enqueue_flatpickr();
96
-			}
97
-
98
-
99
-			// open/type
100
-			$output .= '<input type="' . $type . '" ';
101
-
102
-			// name
103
-			if(!empty($args['name'])){
104
-				$output .= ' name="'.esc_attr($args['name']).'" ';
105
-			}
106
-
107
-			// id
108
-			if(!empty($args['id'])){
109
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
110
-			}
111
-
112
-			// placeholder
113
-			if(isset($args['placeholder']) && '' != $args['placeholder'] ){
114
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
115
-			}
116
-
117
-			// title
118
-			if(!empty($args['title'])){
119
-				$output .= ' title="'.esc_attr($args['title']).'" ';
120
-			}
121
-
122
-			// value
123
-			if(!empty($args['value'])){
124
-				$output .= AUI_Component_Helper::value($args['value']);
125
-			}
126
-
127
-			// checked, for radio and checkboxes
128
-			if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
129
-				$output .= ' checked ';
130
-			}
131
-
132
-			// validation text
133
-			if(!empty($args['validation_text'])){
134
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
135
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
136
-			}
137
-
138
-			// validation_pattern
139
-			if(!empty($args['validation_pattern'])){
140
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
141
-			}
142
-
143
-			// step (for numbers)
144
-			if(!empty($args['step'])){
145
-				$output .= ' step="'.$args['step'].'" ';
146
-			}
147
-
148
-			// required
149
-			if(!empty($args['required'])){
150
-				$output .= ' required ';
151
-			}
152
-
153
-			// class
154
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
155
-			$output .= ' class="form-control '.$class.'" ';
156
-
157
-			// data-attributes
158
-			$output .= AUI_Component_Helper::data_attributes($args);
159
-
160
-			// extra attributes
161
-			if(!empty($args['extra_attributes'])){
162
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
163
-			}
164
-
165
-			// close
166
-			$output .= ' >';
167
-
168
-
169
-			// label
170
-			if(!empty($args['label'])){
171
-				if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
172
-				elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
173
-				$label = self::label( $label_args, $type );
174
-			}
175
-
176
-			// help text
177
-			if(!empty($args['help_text'])){
178
-				$help_text = AUI_Component_Helper::help_text($args['help_text']);
179
-			}
180
-
181
-
182
-			// set help text in the correct possition
183
-			if($label_after){
184
-				$output .= $label . $help_text;
185
-			}
186
-
187
-			// some input types need a separate wrap
188
-			if($type == 'file') {
189
-				$output = self::wrap( array(
190
-					'content' => $output,
191
-					'class'   => 'form-group custom-file'
192
-				) );
193
-			}elseif($type == 'checkbox'){
194
-				$wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
195
-				$output = self::wrap( array(
196
-					'content' => $output,
197
-					'class'   => 'custom-control '.$wrap_class
198
-				) );
199
-
200
-				if($args['label_type']=='horizontal'){
201
-					$output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
202
-				}
203
-			}elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
204
-
205
-
206
-				// allow password field to toggle view
207
-				$args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
14
+    /**
15
+     * Build the component.
16
+     *
17
+     * @param array $args
18
+     *
19
+     * @return string The rendered component.
20
+     */
21
+    public static function input($args = array()){
22
+        $defaults = array(
23
+            'type'       => 'text',
24
+            'name'       => '',
25
+            'class'      => '',
26
+            'wrap_class' => '',
27
+            'id'         => '',
28
+            'placeholder'=> '',
29
+            'title'      => '',
30
+            'value'      => '',
31
+            'required'   => false,
32
+            'label'      => '',
33
+            'label_after'=> false,
34
+            'label_class'=> '',
35
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
36
+            'help_text'  => '',
37
+            'validation_text'   => '',
38
+            'validation_pattern' => '',
39
+            'no_wrap'    => false,
40
+            'input_group_right' => '',
41
+            'input_group_left' => '',
42
+            'input_group_right_inside' => false, // forces the input group inside the input
43
+            'input_group_left_inside' => false, // forces the input group inside the input
44
+            'step'       => '',
45
+            'switch'     => false, // to show checkbox as a switch
46
+            'checked'   => false, // set a checkbox or radio as selected
47
+            'password_toggle' => true, // toggle view/hide password
48
+            'element_require'   => '', // [%element_id%] == "1"
49
+            'extra_attributes'  => array(), // an array of extra attributes
50
+            'wrap_attributes' => array()
51
+        );
52
+
53
+        /**
54
+         * Parse incoming $args into an array and merge it with $defaults
55
+         */
56
+        $args   = wp_parse_args( $args, $defaults );
57
+        $output = '';
58
+        if ( ! empty( $args['type'] ) ) {
59
+            // hidden label option needs to be empty
60
+            $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
61
+
62
+            $type = sanitize_html_class( $args['type'] );
63
+
64
+            $help_text = '';
65
+            $label = '';
66
+            $label_after = $args['label_after'];
67
+            $label_args = array(
68
+                'title'=> $args['label'],
69
+                'for'=> $args['id'],
70
+                'class' => $args['label_class']." ",
71
+                'label_type' => $args['label_type']
72
+            );
73
+
74
+            // floating labels need label after
75
+            if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
76
+                $label_after = true;
77
+                $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
78
+            }
79
+
80
+            // Some special sauce for files
81
+            if($type=='file' ){
82
+                $label_after = true; // if type file we need the label after
83
+                $args['class'] .= ' custom-file-input ';
84
+            }elseif($type=='checkbox'){
85
+                $label_after = true; // if type file we need the label after
86
+                $args['class'] .= ' custom-control-input ';
87
+            }elseif($type=='datepicker' || $type=='timepicker'){
88
+                $type = 'text';
89
+                //$args['class'] .= ' aui-flatpickr bg-initial ';
90
+                $args['class'] .= ' bg-initial ';
91
+
92
+                $args['extra_attributes']['data-aui-init'] = 'flatpickr';
93
+                // enqueue the script
94
+                $aui_settings = AyeCode_UI_Settings::instance();
95
+                $aui_settings->enqueue_flatpickr();
96
+            }
97
+
98
+
99
+            // open/type
100
+            $output .= '<input type="' . $type . '" ';
101
+
102
+            // name
103
+            if(!empty($args['name'])){
104
+                $output .= ' name="'.esc_attr($args['name']).'" ';
105
+            }
106
+
107
+            // id
108
+            if(!empty($args['id'])){
109
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
110
+            }
111
+
112
+            // placeholder
113
+            if(isset($args['placeholder']) && '' != $args['placeholder'] ){
114
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
115
+            }
116
+
117
+            // title
118
+            if(!empty($args['title'])){
119
+                $output .= ' title="'.esc_attr($args['title']).'" ';
120
+            }
121
+
122
+            // value
123
+            if(!empty($args['value'])){
124
+                $output .= AUI_Component_Helper::value($args['value']);
125
+            }
126
+
127
+            // checked, for radio and checkboxes
128
+            if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
129
+                $output .= ' checked ';
130
+            }
131
+
132
+            // validation text
133
+            if(!empty($args['validation_text'])){
134
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
135
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
136
+            }
137
+
138
+            // validation_pattern
139
+            if(!empty($args['validation_pattern'])){
140
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
141
+            }
142
+
143
+            // step (for numbers)
144
+            if(!empty($args['step'])){
145
+                $output .= ' step="'.$args['step'].'" ';
146
+            }
147
+
148
+            // required
149
+            if(!empty($args['required'])){
150
+                $output .= ' required ';
151
+            }
152
+
153
+            // class
154
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
155
+            $output .= ' class="form-control '.$class.'" ';
156
+
157
+            // data-attributes
158
+            $output .= AUI_Component_Helper::data_attributes($args);
159
+
160
+            // extra attributes
161
+            if(!empty($args['extra_attributes'])){
162
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
163
+            }
164
+
165
+            // close
166
+            $output .= ' >';
167
+
168
+
169
+            // label
170
+            if(!empty($args['label'])){
171
+                if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
172
+                elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
173
+                $label = self::label( $label_args, $type );
174
+            }
175
+
176
+            // help text
177
+            if(!empty($args['help_text'])){
178
+                $help_text = AUI_Component_Helper::help_text($args['help_text']);
179
+            }
180
+
181
+
182
+            // set help text in the correct possition
183
+            if($label_after){
184
+                $output .= $label . $help_text;
185
+            }
186
+
187
+            // some input types need a separate wrap
188
+            if($type == 'file') {
189
+                $output = self::wrap( array(
190
+                    'content' => $output,
191
+                    'class'   => 'form-group custom-file'
192
+                ) );
193
+            }elseif($type == 'checkbox'){
194
+                $wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
195
+                $output = self::wrap( array(
196
+                    'content' => $output,
197
+                    'class'   => 'custom-control '.$wrap_class
198
+                ) );
199
+
200
+                if($args['label_type']=='horizontal'){
201
+                    $output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
202
+                }
203
+            }elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
204
+
205
+
206
+                // allow password field to toggle view
207
+                $args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
208 208
 onclick="var $el = jQuery(this).find(\'i\');$el.toggleClass(\'fa-eye fa-eye-slash\');
209 209
 var $eli = jQuery(this).parent().parent().find(\'input\');
210 210
 if($el.hasClass(\'fa-eye\'))
211 211
 {$eli.attr(\'type\',\'text\');}
212 212
 else{$eli.attr(\'type\',\'password\');}"
213 213
 ><i class="far fa-fw fa-eye-slash"></i></span>';
214
-			}
215
-
216
-			// input group wraps
217
-			if($args['input_group_left'] || $args['input_group_right']){
218
-				$w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
219
-				if($args['input_group_left']){
220
-					$output = self::wrap( array(
221
-						'content' => $output,
222
-						'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
223
-						'input_group_left' => $args['input_group_left'],
224
-						'input_group_left_inside'    => $args['input_group_left_inside']
225
-					) );
226
-				}
227
-				if($args['input_group_right']){
228
-					$output = self::wrap( array(
229
-						'content' => $output,
230
-						'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
231
-						'input_group_right' => $args['input_group_right'],
232
-						'input_group_right_inside'    => $args['input_group_right_inside']
233
-					) );
234
-				}
235
-
236
-			}
237
-
238
-			if(!$label_after){
239
-				$output .= $help_text;
240
-			}
241
-
242
-
243
-			if($args['label_type']=='horizontal' && $type != 'checkbox'){
244
-				$output = self::wrap( array(
245
-					'content' => $output,
246
-					'class'   => 'col-sm-10',
247
-				) );
248
-			}
249
-
250
-			if(!$label_after){
251
-				$output = $label . $output;
252
-			}
253
-
254
-			// wrap
255
-			if ( ! $args['no_wrap'] ) {
256
-				$form_group_class = $args['label_type']=='floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
257
-				$wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
258
-				$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
259
-				$output = self::wrap(array(
260
-					'content' => $output,
261
-					'class'   => $wrap_class,
262
-					'element_require'   => $args['element_require'],
263
-					'argument_id'  => $args['id'],
264
-					'wrap_attributes' => $args['wrap_attributes'],
265
-				));
266
-			}
267
-		}
268
-
269
-		return $output;
270
-	}
271
-
272
-	/**
273
-	 * Build the component.
274
-	 *
275
-	 * @param array $args
276
-	 *
277
-	 * @return string The rendered component.
278
-	 */
279
-	public static function textarea($args = array()){
280
-		$defaults = array(
281
-			'name'       => '',
282
-			'class'      => '',
283
-			'wrap_class' => '',
284
-			'id'         => '',
285
-			'placeholder'=> '',
286
-			'title'      => '',
287
-			'value'      => '',
288
-			'required'   => false,
289
-			'label'      => '',
290
-			'label_after'=> false,
291
-			'label_class'      => '',
292
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
293
-			'help_text'  => '',
294
-			'validation_text'   => '',
295
-			'validation_pattern' => '',
296
-			'no_wrap'    => false,
297
-			'rows'      => '',
298
-			'wysiwyg'   => false,
299
-			'allow_tags' => false, // Allow HTML tags
300
-			'element_require'   => '', // [%element_id%] == "1"
301
-			'extra_attributes'  => array(), // an array of extra attributes
302
-			'wrap_attributes'   => array(),
303
-		);
304
-
305
-		/**
306
-		 * Parse incoming $args into an array and merge it with $defaults
307
-		 */
308
-		$args   = wp_parse_args( $args, $defaults );
309
-		$output = '';
310
-
311
-		// hidden label option needs to be empty
312
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
313
-
314
-		// floating labels don't work with wysiwyg so set it as top
315
-		if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
316
-			$args['label_type'] = 'top';
317
-		}
318
-
319
-		$label_after = $args['label_after'];
320
-
321
-		// floating labels need label after
322
-		if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
323
-			$label_after = true;
324
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
325
-		}
326
-
327
-		// label
328
-		if(!empty($args['label']) && is_array($args['label'])){
329
-		}elseif(!empty($args['label']) && !$label_after){
330
-			$label_args = array(
331
-				'title'=> $args['label'],
332
-				'for'=> $args['id'],
333
-				'class' => $args['label_class']." ",
334
-				'label_type' => $args['label_type']
335
-			);
336
-			$output .= self::label( $label_args );
337
-		}
338
-
339
-		// maybe horizontal label
340
-		if($args['label_type']=='horizontal'){
341
-			$output .= '<div class="col-sm-10">';
342
-		}
343
-
344
-		if(!empty($args['wysiwyg'])){
345
-			ob_start();
346
-			$content = $args['value'];
347
-			$editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
348
-			$settings = array(
349
-				'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
350
-				'quicktags'     => false,
351
-				'media_buttons' => false,
352
-				'editor_class'  => 'form-control',
353
-				'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
354
-				'teeny'         => true,
355
-			);
356
-
357
-			// maybe set settings if array
358
-			if(is_array($args['wysiwyg'])){
359
-				$settings  = wp_parse_args( $args['wysiwyg'], $settings );
360
-			}
361
-
362
-			wp_editor( $content, $editor_id, $settings );
363
-			$output .= ob_get_clean();
364
-		}else{
365
-
366
-			// open
367
-			$output .= '<textarea ';
368
-
369
-			// name
370
-			if(!empty($args['name'])){
371
-				$output .= ' name="'.esc_attr($args['name']).'" ';
372
-			}
373
-
374
-			// id
375
-			if(!empty($args['id'])){
376
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
377
-			}
378
-
379
-			// placeholder
380
-			if(isset($args['placeholder']) && '' != $args['placeholder']){
381
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
382
-			}
383
-
384
-			// title
385
-			if(!empty($args['title'])){
386
-				$output .= ' title="'.esc_attr($args['title']).'" ';
387
-			}
388
-
389
-			// validation text
390
-			if(!empty($args['validation_text'])){
391
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
392
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
393
-			}
394
-
395
-			// validation_pattern
396
-			if(!empty($args['validation_pattern'])){
397
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
398
-			}
399
-
400
-			// required
401
-			if(!empty($args['required'])){
402
-				$output .= ' required ';
403
-			}
404
-
405
-			// rows
406
-			if(!empty($args['rows'])){
407
-				$output .= ' rows="'.absint($args['rows']).'" ';
408
-			}
409
-
410
-
411
-			// class
412
-			$class = !empty($args['class']) ? $args['class'] : '';
413
-			$output .= ' class="form-control '.$class.'" ';
414
-
415
-			// extra attributes
416
-			if(!empty($args['extra_attributes'])){
417
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
418
-			}
419
-
420
-			// close tag
421
-			$output .= ' >';
422
-
423
-			// value
424
-			if ( ! empty( $args['value'] ) ) {
425
-				if ( ! empty( $args['allow_tags'] ) ) {
426
-					$output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
427
-				} else {
428
-					$output .= sanitize_textarea_field( $args['value'] );
429
-				}
430
-			}
431
-
432
-			// closing tag
433
-			$output .= '</textarea>';
434
-
435
-		}
436
-
437
-		if(!empty($args['label']) && $label_after){
438
-			$label_args = array(
439
-				'title'=> $args['label'],
440
-				'for'=> $args['id'],
441
-				'class' => $args['label_class']." ",
442
-				'label_type' => $args['label_type']
443
-			);
444
-			$output .= self::label( $label_args );
445
-		}
446
-
447
-		// help text
448
-		if(!empty($args['help_text'])){
449
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
450
-		}
451
-
452
-		// maybe horizontal label
453
-		if($args['label_type']=='horizontal'){
454
-			$output .= '</div>';
455
-		}
456
-
457
-
458
-		// wrap
459
-		if(!$args['no_wrap']){
460
-			$form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
461
-			$wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
462
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
463
-			$output = self::wrap(array(
464
-				'content' => $output,
465
-				'class'   => $wrap_class,
466
-				'element_require'   => $args['element_require'],
467
-				'argument_id'  => $args['id'],
468
-				'wrap_attributes' => $args['wrap_attributes'],
469
-			));
470
-		}
471
-
472
-
473
-		return $output;
474
-	}
475
-
476
-	public static function label($args = array(), $type = ''){
477
-		//<label for="exampleInputEmail1">Email address</label>
478
-		$defaults = array(
479
-			'title'       => 'div',
480
-			'for'      => '',
481
-			'class'      => '',
482
-			'label_type'    => '', // empty = hidden, top, horizontal
483
-		);
484
-
485
-		/**
486
-		 * Parse incoming $args into an array and merge it with $defaults
487
-		 */
488
-		$args   = wp_parse_args( $args, $defaults );
489
-		$output = '';
490
-
491
-		if($args['title']){
492
-
493
-			// maybe hide labels //@todo set a global option for visibility class
494
-			if($type == 'file' || $type == 'checkbox' || $type == 'radio' || !empty($args['label_type']) ){
495
-				$class = $args['class'];
496
-			}else{
497
-				$class = 'sr-only '.$args['class'];
498
-			}
499
-
500
-			// maybe horizontal
501
-			if($args['label_type']=='horizontal' && $type != 'checkbox'){
502
-				$class .= ' col-sm-2 col-form-label';
503
-			}
504
-
505
-			// open
506
-			$output .= '<label ';
507
-
508
-			// for
509
-			if(!empty($args['for'])){
510
-				$output .= ' for="'.esc_attr($args['for']).'" ';
511
-			}
512
-
513
-			// class
514
-			$class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
515
-			$output .= ' class="'.$class.'" ';
516
-
517
-			// close
518
-			$output .= '>';
519
-
520
-
521
-			// title, don't escape fully as can contain html
522
-			if(!empty($args['title'])){
523
-				$output .= wp_kses_post($args['title']);
524
-			}
525
-
526
-			// close wrap
527
-			$output .= '</label>';
528
-
529
-
530
-		}
531
-
532
-
533
-		return $output;
534
-	}
535
-
536
-	/**
537
-	 * Wrap some content in a HTML wrapper.
538
-	 *
539
-	 * @param array $args
540
-	 *
541
-	 * @return string
542
-	 */
543
-	public static function wrap($args = array()){
544
-		$defaults = array(
545
-			'type'       => 'div',
546
-			'class'      => 'form-group',
547
-			'content'   => '',
548
-			'input_group_left' => '',
549
-			'input_group_right' => '',
550
-			'input_group_left_inside' => false,
551
-			'input_group_right_inside' => false,
552
-			'element_require'   => '',
553
-			'argument_id'   => '',
554
-			'wrap_attributes' => array()
555
-		);
556
-
557
-		/**
558
-		 * Parse incoming $args into an array and merge it with $defaults
559
-		 */
560
-		$args   = wp_parse_args( $args, $defaults );
561
-		$output = '';
562
-		if($args['type']){
563
-
564
-			// open
565
-			$output .= '<'.sanitize_html_class($args['type']);
566
-
567
-			// element require
568
-			if(!empty($args['element_require'])){
569
-				$output .= AUI_Component_Helper::element_require($args['element_require']);
570
-				$args['class'] .= " aui-conditional-field";
571
-			}
572
-
573
-			// argument_id
574
-			if( !empty($args['argument_id']) ){
575
-				$output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
576
-			}
577
-
578
-			// class
579
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
580
-			$output .= ' class="'.$class.'" ';
581
-
582
-			// Attributes
583
-			if ( ! empty( $args['wrap_attributes'] ) ) {
584
-				$output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
585
-			}
586
-
587
-			// close wrap
588
-			$output .= ' >';
589
-
590
-
591
-			// Input group left
592
-			if(!empty($args['input_group_left'])){
593
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
594
-				$input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
595
-				$output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
596
-			}
597
-
598
-			// content
599
-			$output .= $args['content'];
600
-
601
-			// Input group right
602
-			if(!empty($args['input_group_right'])){
603
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
604
-				$input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
605
-				$output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
606
-			}
607
-
608
-
609
-			// close wrap
610
-			$output .= '</'.sanitize_html_class($args['type']).'>';
611
-
612
-
613
-		}else{
614
-			$output = $args['content'];
615
-		}
616
-
617
-		return $output;
618
-	}
619
-
620
-	/**
621
-	 * Build the component.
622
-	 *
623
-	 * @param array $args
624
-	 *
625
-	 * @return string The rendered component.
626
-	 */
627
-	public static function select($args = array()){
628
-		$defaults = array(
629
-			'class'      => '',
630
-			'wrap_class' => '',
631
-			'id'         => '',
632
-			'title'      => '',
633
-			'value'      => '', // can be an array or a string
634
-			'required'   => false,
635
-			'label'      => '',
636
-			'label_after'=> false,
637
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
638
-			'label_class'      => '',
639
-			'help_text'  => '',
640
-			'placeholder'=> '',
641
-			'options'    => array(), // array or string
642
-			'icon'       => '',
643
-			'multiple'   => false,
644
-			'select2'    => false,
645
-			'no_wrap'    => false,
646
-			'element_require'   => '', // [%element_id%] == "1"
647
-			'extra_attributes'  => array(), // an array of extra attributes
648
-			'wrap_attributes'   => array(),
649
-		);
650
-
651
-		/**
652
-		 * Parse incoming $args into an array and merge it with $defaults
653
-		 */
654
-		$args   = wp_parse_args( $args, $defaults );
655
-		$output = '';
656
-
657
-		// for now lets hide floating labels
658
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
659
-
660
-		// hidden label option needs to be empty
661
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
662
-
663
-
664
-		$label_after = $args['label_after'];
665
-
666
-		// floating labels need label after
667
-		if( $args['label_type'] == 'floating' ){
668
-			$label_after = true;
669
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
670
-		}
671
-
672
-		// Maybe setup select2
673
-		$is_select2 = false;
674
-		if(!empty($args['select2'])){
675
-			$args['class'] .= ' aui-select2';
676
-			$is_select2 = true;
677
-		}elseif( strpos($args['class'], 'aui-select2') !== false){
678
-			$is_select2 = true;
679
-		}
680
-
681
-		// select2 tags
682
-		if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
683
-			$args['data-tags'] = 'true';
684
-			$args['data-token-separators'] = "[',']";
685
-			$args['multiple'] = true;
686
-		}
687
-
688
-		// select2 placeholder
689
-		if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
690
-			$args['data-placeholder'] = esc_attr($args['placeholder']);
691
-			$args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
692
-		}
693
-
694
-		// label
695
-		if(!empty($args['label']) && is_array($args['label'])){
696
-		}elseif(!empty($args['label']) && !$label_after){
697
-			$label_args = array(
698
-				'title'=> $args['label'],
699
-				'for'=> $args['id'],
700
-				'class' => $args['label_class']." ",
701
-				'label_type' => $args['label_type']
702
-			);
703
-			$output .= self::label($label_args);
704
-		}
705
-
706
-		// maybe horizontal label
707
-		if($args['label_type']=='horizontal'){
708
-			$output .= '<div class="col-sm-10">';
709
-		}
710
-
711
-		// Set hidden input to save empty value for multiselect.
712
-		if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
713
-			$output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
714
-		}
715
-
716
-		// open/type
717
-		$output .= '<select ';
718
-
719
-		// style
720
-		if($is_select2){
721
-			$output .= " style='width:100%;' ";
722
-		}
723
-
724
-		// element require
725
-		if(!empty($args['element_require'])){
726
-			$output .= AUI_Component_Helper::element_require($args['element_require']);
727
-			$args['class'] .= " aui-conditional-field";
728
-		}
729
-
730
-		// class
731
-		$class = !empty($args['class']) ? $args['class'] : '';
732
-		$output .= AUI_Component_Helper::class_attr('custom-select '.$class);
733
-
734
-		// name
735
-		if(!empty($args['name'])){
736
-			$output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
737
-		}
738
-
739
-		// id
740
-		if(!empty($args['id'])){
741
-			$output .= AUI_Component_Helper::id($args['id']);
742
-		}
743
-
744
-		// title
745
-		if(!empty($args['title'])){
746
-			$output .= AUI_Component_Helper::title($args['title']);
747
-		}
748
-
749
-		// data-attributes
750
-		$output .= AUI_Component_Helper::data_attributes($args);
751
-
752
-		// aria-attributes
753
-		$output .= AUI_Component_Helper::aria_attributes($args);
754
-
755
-		// extra attributes
756
-		if(!empty($args['extra_attributes'])){
757
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
758
-		}
759
-
760
-		// required
761
-		if(!empty($args['required'])){
762
-			$output .= ' required ';
763
-		}
764
-
765
-		// multiple
766
-		if(!empty($args['multiple'])){
767
-			$output .= ' multiple ';
768
-		}
769
-
770
-		// close opening tag
771
-		$output .= ' >';
772
-
773
-		// placeholder
774
-		if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
775
-			$output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
776
-		}elseif($is_select2 && !empty($args['placeholder'])){
777
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
778
-		}
779
-
780
-		// Options
781
-		if(!empty($args['options'])){
782
-
783
-			if(!is_array($args['options'])){
784
-				$output .= $args['options']; // not the preferred way but an option
785
-			}else{
786
-				foreach($args['options'] as $val => $name){
787
-					$selected = '';
788
-					if(is_array($name)){
789
-						if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
790
-							$option_label = isset($name['label']) ? $name['label'] : '';
791
-
792
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
793
-						} else {
794
-							$option_label = isset($name['label']) ? $name['label'] : '';
795
-							$option_value = isset($name['value']) ? $name['value'] : '';
796
-							if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
797
-								$selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
798
-							} elseif(!empty($args['value'])) {
799
-								$selected = selected($option_value,stripslashes_deep($args['value']), false);
800
-							}
801
-
802
-							$output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
803
-						}
804
-					}else{
805
-						if(!empty($args['value'])){
806
-							if(is_array($args['value'])){
807
-								$selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
808
-							} elseif(!empty($args['value'])) {
809
-								$selected = selected( $args['value'], $val, false);
810
-							}
811
-						}
812
-						$output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
813
-					}
814
-				}
815
-			}
816
-
817
-		}
818
-
819
-		// closing tag
820
-		$output .= '</select>';
821
-
822
-		if(!empty($args['label']) && $label_after){
823
-			$label_args = array(
824
-				'title'=> $args['label'],
825
-				'for'=> $args['id'],
826
-				'class' => $args['label_class']." ",
827
-				'label_type' => $args['label_type']
828
-			);
829
-			$output .= self::label($label_args);
830
-		}
831
-
832
-		// help text
833
-		if(!empty($args['help_text'])){
834
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
835
-		}
836
-
837
-		// maybe horizontal label
838
-		if($args['label_type']=='horizontal'){
839
-			$output .= '</div>';
840
-		}
841
-
842
-
843
-		// wrap
844
-		if(!$args['no_wrap']){
845
-			$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
846
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
847
-			$output = self::wrap(array(
848
-				'content' => $output,
849
-				'class'   => $wrap_class,
850
-				'element_require'   => $args['element_require'],
851
-				'argument_id'  => $args['id'],
852
-				'wrap_attributes' => $args['wrap_attributes'],
853
-			));
854
-		}
855
-
856
-
857
-		return $output;
858
-	}
859
-
860
-	/**
861
-	 * Build the component.
862
-	 *
863
-	 * @param array $args
864
-	 *
865
-	 * @return string The rendered component.
866
-	 */
867
-	public static function radio($args = array()){
868
-		$defaults = array(
869
-			'class'      => '',
870
-			'wrap_class' => '',
871
-			'id'         => '',
872
-			'title'      => '',
873
-			'horizontal' => false, // sets the lable horizontal
874
-			'value'      => '',
875
-			'label'      => '',
876
-			'label_class'=> '',
877
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
878
-			'help_text'  => '',
879
-			'inline'     => true,
880
-			'required'   => false,
881
-			'options'    => array(),
882
-			'icon'       => '',
883
-			'no_wrap'    => false,
884
-			'element_require'   => '', // [%element_id%] == "1"
885
-			'extra_attributes'  => array(), // an array of extra attributes
886
-			'wrap_attributes'   => array()
887
-		);
888
-
889
-		/**
890
-		 * Parse incoming $args into an array and merge it with $defaults
891
-		 */
892
-		$args   = wp_parse_args( $args, $defaults );
893
-
894
-		// for now lets use horizontal for floating
895
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
896
-
897
-		$label_args = array(
898
-			'title'=> $args['label'],
899
-			'class' => $args['label_class']." pt-0 ",
900
-			'label_type' => $args['label_type']
901
-		);
902
-
903
-		$output = '';
904
-
905
-
906
-
907
-		// label before
908
-		if(!empty($args['label'])){
909
-			$output .= self::label( $label_args, 'radio' );
910
-		}
911
-
912
-		// maybe horizontal label
913
-		if($args['label_type']=='horizontal'){
914
-			$output .= '<div class="col-sm-10">';
915
-		}
916
-
917
-		if(!empty($args['options'])){
918
-			$count = 0;
919
-			foreach($args['options'] as $value => $label){
920
-				$option_args = $args;
921
-				$option_args['value'] = $value;
922
-				$option_args['label'] = $label;
923
-				$option_args['checked'] = $value == $args['value'] ? true : false;
924
-				$output .= self::radio_option($option_args,$count);
925
-				$count++;
926
-			}
927
-		}
928
-
929
-		// help text
930
-		$help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
931
-		$output .= $help_text;
932
-
933
-		// maybe horizontal label
934
-		if($args['label_type']=='horizontal'){
935
-			$output .= '</div>';
936
-		}
937
-
938
-		// wrap
939
-		$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
940
-		$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
941
-		$output = self::wrap(array(
942
-			'content' => $output,
943
-			'class'   => $wrap_class,
944
-			'element_require'   => $args['element_require'],
945
-			'argument_id'  => $args['id'],
946
-			'wrap_attributes' => $args['wrap_attributes'],
947
-		));
948
-
949
-
950
-		return $output;
951
-	}
952
-
953
-	/**
954
-	 * Build the component.
955
-	 *
956
-	 * @param array $args
957
-	 *
958
-	 * @return string The rendered component.
959
-	 */
960
-	public static function radio_option($args = array(),$count = ''){
961
-		$defaults = array(
962
-			'class'      => '',
963
-			'id'         => '',
964
-			'title'      => '',
965
-			'value'      => '',
966
-			'required'   => false,
967
-			'inline'     => true,
968
-			'label'      => '',
969
-			'options'    => array(),
970
-			'icon'       => '',
971
-			'no_wrap'    => false,
972
-			'extra_attributes'  => array() // an array of extra attributes
973
-		);
974
-
975
-		/**
976
-		 * Parse incoming $args into an array and merge it with $defaults
977
-		 */
978
-		$args   = wp_parse_args( $args, $defaults );
979
-
980
-		$output = '';
981
-
982
-		// open/type
983
-		$output .= '<input type="radio"';
984
-
985
-		// class
986
-		$output .= ' class="form-check-input" ';
987
-
988
-		// name
989
-		if(!empty($args['name'])){
990
-			$output .= AUI_Component_Helper::name($args['name']);
991
-		}
992
-
993
-		// id
994
-		if(!empty($args['id'])){
995
-			$output .= AUI_Component_Helper::id($args['id'].$count);
996
-		}
997
-
998
-		// title
999
-		if(!empty($args['title'])){
1000
-			$output .= AUI_Component_Helper::title($args['title']);
1001
-		}
1002
-
1003
-		// value
1004
-		if(isset($args['value'])){
1005
-			$output .= AUI_Component_Helper::value($args['value']);
1006
-		}
1007
-
1008
-		// checked, for radio and checkboxes
1009
-		if( $args['checked'] ){
1010
-			$output .= ' checked ';
1011
-		}
1012
-
1013
-		// data-attributes
1014
-		$output .= AUI_Component_Helper::data_attributes($args);
1015
-
1016
-		// aria-attributes
1017
-		$output .= AUI_Component_Helper::aria_attributes($args);
1018
-
1019
-		// extra attributes
1020
-		if(!empty($args['extra_attributes'])){
1021
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1022
-		}
1023
-
1024
-		// required
1025
-		if(!empty($args['required'])){
1026
-			$output .= ' required ';
1027
-		}
1028
-
1029
-		// close opening tag
1030
-		$output .= ' >';
1031
-
1032
-		// label
1033
-		if(!empty($args['label']) && is_array($args['label'])){
1034
-		}elseif(!empty($args['label'])){
1035
-			$output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1036
-		}
1037
-
1038
-		// wrap
1039
-		if ( ! $args['no_wrap'] ) {
1040
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1041
-
1042
-			// Unique wrap class
1043
-			$uniq_class = 'fwrap';
1044
-			if ( ! empty( $args['name'] ) ) {
1045
-				$uniq_class .= '-' . $args['name'];
1046
-			} else if ( ! empty( $args['id'] ) ) {
1047
-				$uniq_class .= '-' . $args['id'];
1048
-			}
1049
-
1050
-			if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1051
-				$uniq_class .= '-' . $args['value'];
1052
-			} else {
1053
-				$uniq_class .= '-' . $count;
1054
-			}
1055
-			$wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1056
-
1057
-			$output = self::wrap(array(
1058
-				'content' => $output,
1059
-				'class' => $wrap_class
1060
-			));
1061
-		}
1062
-
1063
-		return $output;
1064
-	}
214
+            }
215
+
216
+            // input group wraps
217
+            if($args['input_group_left'] || $args['input_group_right']){
218
+                $w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
219
+                if($args['input_group_left']){
220
+                    $output = self::wrap( array(
221
+                        'content' => $output,
222
+                        'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
223
+                        'input_group_left' => $args['input_group_left'],
224
+                        'input_group_left_inside'    => $args['input_group_left_inside']
225
+                    ) );
226
+                }
227
+                if($args['input_group_right']){
228
+                    $output = self::wrap( array(
229
+                        'content' => $output,
230
+                        'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
231
+                        'input_group_right' => $args['input_group_right'],
232
+                        'input_group_right_inside'    => $args['input_group_right_inside']
233
+                    ) );
234
+                }
235
+
236
+            }
237
+
238
+            if(!$label_after){
239
+                $output .= $help_text;
240
+            }
241
+
242
+
243
+            if($args['label_type']=='horizontal' && $type != 'checkbox'){
244
+                $output = self::wrap( array(
245
+                    'content' => $output,
246
+                    'class'   => 'col-sm-10',
247
+                ) );
248
+            }
249
+
250
+            if(!$label_after){
251
+                $output = $label . $output;
252
+            }
253
+
254
+            // wrap
255
+            if ( ! $args['no_wrap'] ) {
256
+                $form_group_class = $args['label_type']=='floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
257
+                $wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
258
+                $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
259
+                $output = self::wrap(array(
260
+                    'content' => $output,
261
+                    'class'   => $wrap_class,
262
+                    'element_require'   => $args['element_require'],
263
+                    'argument_id'  => $args['id'],
264
+                    'wrap_attributes' => $args['wrap_attributes'],
265
+                ));
266
+            }
267
+        }
268
+
269
+        return $output;
270
+    }
271
+
272
+    /**
273
+     * Build the component.
274
+     *
275
+     * @param array $args
276
+     *
277
+     * @return string The rendered component.
278
+     */
279
+    public static function textarea($args = array()){
280
+        $defaults = array(
281
+            'name'       => '',
282
+            'class'      => '',
283
+            'wrap_class' => '',
284
+            'id'         => '',
285
+            'placeholder'=> '',
286
+            'title'      => '',
287
+            'value'      => '',
288
+            'required'   => false,
289
+            'label'      => '',
290
+            'label_after'=> false,
291
+            'label_class'      => '',
292
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
293
+            'help_text'  => '',
294
+            'validation_text'   => '',
295
+            'validation_pattern' => '',
296
+            'no_wrap'    => false,
297
+            'rows'      => '',
298
+            'wysiwyg'   => false,
299
+            'allow_tags' => false, // Allow HTML tags
300
+            'element_require'   => '', // [%element_id%] == "1"
301
+            'extra_attributes'  => array(), // an array of extra attributes
302
+            'wrap_attributes'   => array(),
303
+        );
304
+
305
+        /**
306
+         * Parse incoming $args into an array and merge it with $defaults
307
+         */
308
+        $args   = wp_parse_args( $args, $defaults );
309
+        $output = '';
310
+
311
+        // hidden label option needs to be empty
312
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
313
+
314
+        // floating labels don't work with wysiwyg so set it as top
315
+        if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
316
+            $args['label_type'] = 'top';
317
+        }
318
+
319
+        $label_after = $args['label_after'];
320
+
321
+        // floating labels need label after
322
+        if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
323
+            $label_after = true;
324
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
325
+        }
326
+
327
+        // label
328
+        if(!empty($args['label']) && is_array($args['label'])){
329
+        }elseif(!empty($args['label']) && !$label_after){
330
+            $label_args = array(
331
+                'title'=> $args['label'],
332
+                'for'=> $args['id'],
333
+                'class' => $args['label_class']." ",
334
+                'label_type' => $args['label_type']
335
+            );
336
+            $output .= self::label( $label_args );
337
+        }
338
+
339
+        // maybe horizontal label
340
+        if($args['label_type']=='horizontal'){
341
+            $output .= '<div class="col-sm-10">';
342
+        }
343
+
344
+        if(!empty($args['wysiwyg'])){
345
+            ob_start();
346
+            $content = $args['value'];
347
+            $editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
348
+            $settings = array(
349
+                'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
350
+                'quicktags'     => false,
351
+                'media_buttons' => false,
352
+                'editor_class'  => 'form-control',
353
+                'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
354
+                'teeny'         => true,
355
+            );
356
+
357
+            // maybe set settings if array
358
+            if(is_array($args['wysiwyg'])){
359
+                $settings  = wp_parse_args( $args['wysiwyg'], $settings );
360
+            }
361
+
362
+            wp_editor( $content, $editor_id, $settings );
363
+            $output .= ob_get_clean();
364
+        }else{
365
+
366
+            // open
367
+            $output .= '<textarea ';
368
+
369
+            // name
370
+            if(!empty($args['name'])){
371
+                $output .= ' name="'.esc_attr($args['name']).'" ';
372
+            }
373
+
374
+            // id
375
+            if(!empty($args['id'])){
376
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
377
+            }
378
+
379
+            // placeholder
380
+            if(isset($args['placeholder']) && '' != $args['placeholder']){
381
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
382
+            }
383
+
384
+            // title
385
+            if(!empty($args['title'])){
386
+                $output .= ' title="'.esc_attr($args['title']).'" ';
387
+            }
388
+
389
+            // validation text
390
+            if(!empty($args['validation_text'])){
391
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
392
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
393
+            }
394
+
395
+            // validation_pattern
396
+            if(!empty($args['validation_pattern'])){
397
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
398
+            }
399
+
400
+            // required
401
+            if(!empty($args['required'])){
402
+                $output .= ' required ';
403
+            }
404
+
405
+            // rows
406
+            if(!empty($args['rows'])){
407
+                $output .= ' rows="'.absint($args['rows']).'" ';
408
+            }
409
+
410
+
411
+            // class
412
+            $class = !empty($args['class']) ? $args['class'] : '';
413
+            $output .= ' class="form-control '.$class.'" ';
414
+
415
+            // extra attributes
416
+            if(!empty($args['extra_attributes'])){
417
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
418
+            }
419
+
420
+            // close tag
421
+            $output .= ' >';
422
+
423
+            // value
424
+            if ( ! empty( $args['value'] ) ) {
425
+                if ( ! empty( $args['allow_tags'] ) ) {
426
+                    $output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
427
+                } else {
428
+                    $output .= sanitize_textarea_field( $args['value'] );
429
+                }
430
+            }
431
+
432
+            // closing tag
433
+            $output .= '</textarea>';
434
+
435
+        }
436
+
437
+        if(!empty($args['label']) && $label_after){
438
+            $label_args = array(
439
+                'title'=> $args['label'],
440
+                'for'=> $args['id'],
441
+                'class' => $args['label_class']." ",
442
+                'label_type' => $args['label_type']
443
+            );
444
+            $output .= self::label( $label_args );
445
+        }
446
+
447
+        // help text
448
+        if(!empty($args['help_text'])){
449
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
450
+        }
451
+
452
+        // maybe horizontal label
453
+        if($args['label_type']=='horizontal'){
454
+            $output .= '</div>';
455
+        }
456
+
457
+
458
+        // wrap
459
+        if(!$args['no_wrap']){
460
+            $form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
461
+            $wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
462
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
463
+            $output = self::wrap(array(
464
+                'content' => $output,
465
+                'class'   => $wrap_class,
466
+                'element_require'   => $args['element_require'],
467
+                'argument_id'  => $args['id'],
468
+                'wrap_attributes' => $args['wrap_attributes'],
469
+            ));
470
+        }
471
+
472
+
473
+        return $output;
474
+    }
475
+
476
+    public static function label($args = array(), $type = ''){
477
+        //<label for="exampleInputEmail1">Email address</label>
478
+        $defaults = array(
479
+            'title'       => 'div',
480
+            'for'      => '',
481
+            'class'      => '',
482
+            'label_type'    => '', // empty = hidden, top, horizontal
483
+        );
484
+
485
+        /**
486
+         * Parse incoming $args into an array and merge it with $defaults
487
+         */
488
+        $args   = wp_parse_args( $args, $defaults );
489
+        $output = '';
490
+
491
+        if($args['title']){
492
+
493
+            // maybe hide labels //@todo set a global option for visibility class
494
+            if($type == 'file' || $type == 'checkbox' || $type == 'radio' || !empty($args['label_type']) ){
495
+                $class = $args['class'];
496
+            }else{
497
+                $class = 'sr-only '.$args['class'];
498
+            }
499
+
500
+            // maybe horizontal
501
+            if($args['label_type']=='horizontal' && $type != 'checkbox'){
502
+                $class .= ' col-sm-2 col-form-label';
503
+            }
504
+
505
+            // open
506
+            $output .= '<label ';
507
+
508
+            // for
509
+            if(!empty($args['for'])){
510
+                $output .= ' for="'.esc_attr($args['for']).'" ';
511
+            }
512
+
513
+            // class
514
+            $class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
515
+            $output .= ' class="'.$class.'" ';
516
+
517
+            // close
518
+            $output .= '>';
519
+
520
+
521
+            // title, don't escape fully as can contain html
522
+            if(!empty($args['title'])){
523
+                $output .= wp_kses_post($args['title']);
524
+            }
525
+
526
+            // close wrap
527
+            $output .= '</label>';
528
+
529
+
530
+        }
531
+
532
+
533
+        return $output;
534
+    }
535
+
536
+    /**
537
+     * Wrap some content in a HTML wrapper.
538
+     *
539
+     * @param array $args
540
+     *
541
+     * @return string
542
+     */
543
+    public static function wrap($args = array()){
544
+        $defaults = array(
545
+            'type'       => 'div',
546
+            'class'      => 'form-group',
547
+            'content'   => '',
548
+            'input_group_left' => '',
549
+            'input_group_right' => '',
550
+            'input_group_left_inside' => false,
551
+            'input_group_right_inside' => false,
552
+            'element_require'   => '',
553
+            'argument_id'   => '',
554
+            'wrap_attributes' => array()
555
+        );
556
+
557
+        /**
558
+         * Parse incoming $args into an array and merge it with $defaults
559
+         */
560
+        $args   = wp_parse_args( $args, $defaults );
561
+        $output = '';
562
+        if($args['type']){
563
+
564
+            // open
565
+            $output .= '<'.sanitize_html_class($args['type']);
566
+
567
+            // element require
568
+            if(!empty($args['element_require'])){
569
+                $output .= AUI_Component_Helper::element_require($args['element_require']);
570
+                $args['class'] .= " aui-conditional-field";
571
+            }
572
+
573
+            // argument_id
574
+            if( !empty($args['argument_id']) ){
575
+                $output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
576
+            }
577
+
578
+            // class
579
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
580
+            $output .= ' class="'.$class.'" ';
581
+
582
+            // Attributes
583
+            if ( ! empty( $args['wrap_attributes'] ) ) {
584
+                $output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
585
+            }
586
+
587
+            // close wrap
588
+            $output .= ' >';
589
+
590
+
591
+            // Input group left
592
+            if(!empty($args['input_group_left'])){
593
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
594
+                $input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
595
+                $output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
596
+            }
597
+
598
+            // content
599
+            $output .= $args['content'];
600
+
601
+            // Input group right
602
+            if(!empty($args['input_group_right'])){
603
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
604
+                $input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
605
+                $output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
606
+            }
607
+
608
+
609
+            // close wrap
610
+            $output .= '</'.sanitize_html_class($args['type']).'>';
611
+
612
+
613
+        }else{
614
+            $output = $args['content'];
615
+        }
616
+
617
+        return $output;
618
+    }
619
+
620
+    /**
621
+     * Build the component.
622
+     *
623
+     * @param array $args
624
+     *
625
+     * @return string The rendered component.
626
+     */
627
+    public static function select($args = array()){
628
+        $defaults = array(
629
+            'class'      => '',
630
+            'wrap_class' => '',
631
+            'id'         => '',
632
+            'title'      => '',
633
+            'value'      => '', // can be an array or a string
634
+            'required'   => false,
635
+            'label'      => '',
636
+            'label_after'=> false,
637
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
638
+            'label_class'      => '',
639
+            'help_text'  => '',
640
+            'placeholder'=> '',
641
+            'options'    => array(), // array or string
642
+            'icon'       => '',
643
+            'multiple'   => false,
644
+            'select2'    => false,
645
+            'no_wrap'    => false,
646
+            'element_require'   => '', // [%element_id%] == "1"
647
+            'extra_attributes'  => array(), // an array of extra attributes
648
+            'wrap_attributes'   => array(),
649
+        );
650
+
651
+        /**
652
+         * Parse incoming $args into an array and merge it with $defaults
653
+         */
654
+        $args   = wp_parse_args( $args, $defaults );
655
+        $output = '';
656
+
657
+        // for now lets hide floating labels
658
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
659
+
660
+        // hidden label option needs to be empty
661
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
662
+
663
+
664
+        $label_after = $args['label_after'];
665
+
666
+        // floating labels need label after
667
+        if( $args['label_type'] == 'floating' ){
668
+            $label_after = true;
669
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
670
+        }
671
+
672
+        // Maybe setup select2
673
+        $is_select2 = false;
674
+        if(!empty($args['select2'])){
675
+            $args['class'] .= ' aui-select2';
676
+            $is_select2 = true;
677
+        }elseif( strpos($args['class'], 'aui-select2') !== false){
678
+            $is_select2 = true;
679
+        }
680
+
681
+        // select2 tags
682
+        if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
683
+            $args['data-tags'] = 'true';
684
+            $args['data-token-separators'] = "[',']";
685
+            $args['multiple'] = true;
686
+        }
687
+
688
+        // select2 placeholder
689
+        if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
690
+            $args['data-placeholder'] = esc_attr($args['placeholder']);
691
+            $args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
692
+        }
693
+
694
+        // label
695
+        if(!empty($args['label']) && is_array($args['label'])){
696
+        }elseif(!empty($args['label']) && !$label_after){
697
+            $label_args = array(
698
+                'title'=> $args['label'],
699
+                'for'=> $args['id'],
700
+                'class' => $args['label_class']." ",
701
+                'label_type' => $args['label_type']
702
+            );
703
+            $output .= self::label($label_args);
704
+        }
705
+
706
+        // maybe horizontal label
707
+        if($args['label_type']=='horizontal'){
708
+            $output .= '<div class="col-sm-10">';
709
+        }
710
+
711
+        // Set hidden input to save empty value for multiselect.
712
+        if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
713
+            $output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
714
+        }
715
+
716
+        // open/type
717
+        $output .= '<select ';
718
+
719
+        // style
720
+        if($is_select2){
721
+            $output .= " style='width:100%;' ";
722
+        }
723
+
724
+        // element require
725
+        if(!empty($args['element_require'])){
726
+            $output .= AUI_Component_Helper::element_require($args['element_require']);
727
+            $args['class'] .= " aui-conditional-field";
728
+        }
729
+
730
+        // class
731
+        $class = !empty($args['class']) ? $args['class'] : '';
732
+        $output .= AUI_Component_Helper::class_attr('custom-select '.$class);
733
+
734
+        // name
735
+        if(!empty($args['name'])){
736
+            $output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
737
+        }
738
+
739
+        // id
740
+        if(!empty($args['id'])){
741
+            $output .= AUI_Component_Helper::id($args['id']);
742
+        }
743
+
744
+        // title
745
+        if(!empty($args['title'])){
746
+            $output .= AUI_Component_Helper::title($args['title']);
747
+        }
748
+
749
+        // data-attributes
750
+        $output .= AUI_Component_Helper::data_attributes($args);
751
+
752
+        // aria-attributes
753
+        $output .= AUI_Component_Helper::aria_attributes($args);
754
+
755
+        // extra attributes
756
+        if(!empty($args['extra_attributes'])){
757
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
758
+        }
759
+
760
+        // required
761
+        if(!empty($args['required'])){
762
+            $output .= ' required ';
763
+        }
764
+
765
+        // multiple
766
+        if(!empty($args['multiple'])){
767
+            $output .= ' multiple ';
768
+        }
769
+
770
+        // close opening tag
771
+        $output .= ' >';
772
+
773
+        // placeholder
774
+        if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
775
+            $output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
776
+        }elseif($is_select2 && !empty($args['placeholder'])){
777
+            $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
778
+        }
779
+
780
+        // Options
781
+        if(!empty($args['options'])){
782
+
783
+            if(!is_array($args['options'])){
784
+                $output .= $args['options']; // not the preferred way but an option
785
+            }else{
786
+                foreach($args['options'] as $val => $name){
787
+                    $selected = '';
788
+                    if(is_array($name)){
789
+                        if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
790
+                            $option_label = isset($name['label']) ? $name['label'] : '';
791
+
792
+                            $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
793
+                        } else {
794
+                            $option_label = isset($name['label']) ? $name['label'] : '';
795
+                            $option_value = isset($name['value']) ? $name['value'] : '';
796
+                            if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
797
+                                $selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
798
+                            } elseif(!empty($args['value'])) {
799
+                                $selected = selected($option_value,stripslashes_deep($args['value']), false);
800
+                            }
801
+
802
+                            $output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
803
+                        }
804
+                    }else{
805
+                        if(!empty($args['value'])){
806
+                            if(is_array($args['value'])){
807
+                                $selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
808
+                            } elseif(!empty($args['value'])) {
809
+                                $selected = selected( $args['value'], $val, false);
810
+                            }
811
+                        }
812
+                        $output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
813
+                    }
814
+                }
815
+            }
816
+
817
+        }
818
+
819
+        // closing tag
820
+        $output .= '</select>';
821
+
822
+        if(!empty($args['label']) && $label_after){
823
+            $label_args = array(
824
+                'title'=> $args['label'],
825
+                'for'=> $args['id'],
826
+                'class' => $args['label_class']." ",
827
+                'label_type' => $args['label_type']
828
+            );
829
+            $output .= self::label($label_args);
830
+        }
831
+
832
+        // help text
833
+        if(!empty($args['help_text'])){
834
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
835
+        }
836
+
837
+        // maybe horizontal label
838
+        if($args['label_type']=='horizontal'){
839
+            $output .= '</div>';
840
+        }
841
+
842
+
843
+        // wrap
844
+        if(!$args['no_wrap']){
845
+            $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
846
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
847
+            $output = self::wrap(array(
848
+                'content' => $output,
849
+                'class'   => $wrap_class,
850
+                'element_require'   => $args['element_require'],
851
+                'argument_id'  => $args['id'],
852
+                'wrap_attributes' => $args['wrap_attributes'],
853
+            ));
854
+        }
855
+
856
+
857
+        return $output;
858
+    }
859
+
860
+    /**
861
+     * Build the component.
862
+     *
863
+     * @param array $args
864
+     *
865
+     * @return string The rendered component.
866
+     */
867
+    public static function radio($args = array()){
868
+        $defaults = array(
869
+            'class'      => '',
870
+            'wrap_class' => '',
871
+            'id'         => '',
872
+            'title'      => '',
873
+            'horizontal' => false, // sets the lable horizontal
874
+            'value'      => '',
875
+            'label'      => '',
876
+            'label_class'=> '',
877
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
878
+            'help_text'  => '',
879
+            'inline'     => true,
880
+            'required'   => false,
881
+            'options'    => array(),
882
+            'icon'       => '',
883
+            'no_wrap'    => false,
884
+            'element_require'   => '', // [%element_id%] == "1"
885
+            'extra_attributes'  => array(), // an array of extra attributes
886
+            'wrap_attributes'   => array()
887
+        );
888
+
889
+        /**
890
+         * Parse incoming $args into an array and merge it with $defaults
891
+         */
892
+        $args   = wp_parse_args( $args, $defaults );
893
+
894
+        // for now lets use horizontal for floating
895
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
896
+
897
+        $label_args = array(
898
+            'title'=> $args['label'],
899
+            'class' => $args['label_class']." pt-0 ",
900
+            'label_type' => $args['label_type']
901
+        );
902
+
903
+        $output = '';
904
+
905
+
906
+
907
+        // label before
908
+        if(!empty($args['label'])){
909
+            $output .= self::label( $label_args, 'radio' );
910
+        }
911
+
912
+        // maybe horizontal label
913
+        if($args['label_type']=='horizontal'){
914
+            $output .= '<div class="col-sm-10">';
915
+        }
916
+
917
+        if(!empty($args['options'])){
918
+            $count = 0;
919
+            foreach($args['options'] as $value => $label){
920
+                $option_args = $args;
921
+                $option_args['value'] = $value;
922
+                $option_args['label'] = $label;
923
+                $option_args['checked'] = $value == $args['value'] ? true : false;
924
+                $output .= self::radio_option($option_args,$count);
925
+                $count++;
926
+            }
927
+        }
928
+
929
+        // help text
930
+        $help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
931
+        $output .= $help_text;
932
+
933
+        // maybe horizontal label
934
+        if($args['label_type']=='horizontal'){
935
+            $output .= '</div>';
936
+        }
937
+
938
+        // wrap
939
+        $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
940
+        $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
941
+        $output = self::wrap(array(
942
+            'content' => $output,
943
+            'class'   => $wrap_class,
944
+            'element_require'   => $args['element_require'],
945
+            'argument_id'  => $args['id'],
946
+            'wrap_attributes' => $args['wrap_attributes'],
947
+        ));
948
+
949
+
950
+        return $output;
951
+    }
952
+
953
+    /**
954
+     * Build the component.
955
+     *
956
+     * @param array $args
957
+     *
958
+     * @return string The rendered component.
959
+     */
960
+    public static function radio_option($args = array(),$count = ''){
961
+        $defaults = array(
962
+            'class'      => '',
963
+            'id'         => '',
964
+            'title'      => '',
965
+            'value'      => '',
966
+            'required'   => false,
967
+            'inline'     => true,
968
+            'label'      => '',
969
+            'options'    => array(),
970
+            'icon'       => '',
971
+            'no_wrap'    => false,
972
+            'extra_attributes'  => array() // an array of extra attributes
973
+        );
974
+
975
+        /**
976
+         * Parse incoming $args into an array and merge it with $defaults
977
+         */
978
+        $args   = wp_parse_args( $args, $defaults );
979
+
980
+        $output = '';
981
+
982
+        // open/type
983
+        $output .= '<input type="radio"';
984
+
985
+        // class
986
+        $output .= ' class="form-check-input" ';
987
+
988
+        // name
989
+        if(!empty($args['name'])){
990
+            $output .= AUI_Component_Helper::name($args['name']);
991
+        }
992
+
993
+        // id
994
+        if(!empty($args['id'])){
995
+            $output .= AUI_Component_Helper::id($args['id'].$count);
996
+        }
997
+
998
+        // title
999
+        if(!empty($args['title'])){
1000
+            $output .= AUI_Component_Helper::title($args['title']);
1001
+        }
1002
+
1003
+        // value
1004
+        if(isset($args['value'])){
1005
+            $output .= AUI_Component_Helper::value($args['value']);
1006
+        }
1007
+
1008
+        // checked, for radio and checkboxes
1009
+        if( $args['checked'] ){
1010
+            $output .= ' checked ';
1011
+        }
1012
+
1013
+        // data-attributes
1014
+        $output .= AUI_Component_Helper::data_attributes($args);
1015
+
1016
+        // aria-attributes
1017
+        $output .= AUI_Component_Helper::aria_attributes($args);
1018
+
1019
+        // extra attributes
1020
+        if(!empty($args['extra_attributes'])){
1021
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1022
+        }
1023
+
1024
+        // required
1025
+        if(!empty($args['required'])){
1026
+            $output .= ' required ';
1027
+        }
1028
+
1029
+        // close opening tag
1030
+        $output .= ' >';
1031
+
1032
+        // label
1033
+        if(!empty($args['label']) && is_array($args['label'])){
1034
+        }elseif(!empty($args['label'])){
1035
+            $output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1036
+        }
1037
+
1038
+        // wrap
1039
+        if ( ! $args['no_wrap'] ) {
1040
+            $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1041
+
1042
+            // Unique wrap class
1043
+            $uniq_class = 'fwrap';
1044
+            if ( ! empty( $args['name'] ) ) {
1045
+                $uniq_class .= '-' . $args['name'];
1046
+            } else if ( ! empty( $args['id'] ) ) {
1047
+                $uniq_class .= '-' . $args['id'];
1048
+            }
1049
+
1050
+            if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1051
+                $uniq_class .= '-' . $args['value'];
1052
+            } else {
1053
+                $uniq_class .= '-' . $count;
1054
+            }
1055
+            $wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1056
+
1057
+            $output = self::wrap(array(
1058
+                'content' => $output,
1059
+                'class' => $wrap_class
1060
+            ));
1061
+        }
1062
+
1063
+        return $output;
1064
+    }
1065 1065
 
1066 1066
 }
1067 1067
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/ayecode-ui-settings.php 1 patch
Indentation   +1186 added lines, -1186 removed lines patch added patch discarded remove patch
@@ -13,7 +13,7 @@  discard block
 block discarded – undo
13 13
  * Bail if we are not in WP.
14 14
  */
15 15
 if ( ! defined( 'ABSPATH' ) ) {
16
-	exit;
16
+    exit;
17 17
 }
18 18
 
19 19
 /**
@@ -21,243 +21,243 @@  discard block
 block discarded – undo
21 21
  */
22 22
 if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
23 23
 
24
-	/**
25
-	 * A Class to be able to change settings for Font Awesome.
26
-	 *
27
-	 * Class AyeCode_UI_Settings
28
-	 * @ver 1.0.0
29
-	 * @todo decide how to implement textdomain
30
-	 */
31
-	class AyeCode_UI_Settings {
32
-
33
-		/**
34
-		 * Class version version.
35
-		 *
36
-		 * @var string
37
-		 */
38
-		public $version = '0.1.59';
39
-
40
-		/**
41
-		 * Class textdomain.
42
-		 *
43
-		 * @var string
44
-		 */
45
-		public $textdomain = 'aui';
46
-
47
-		/**
48
-		 * Latest version of Bootstrap at time of publish published.
49
-		 *
50
-		 * @var string
51
-		 */
52
-		public $latest = "4.5.3";
53
-
54
-		/**
55
-		 * Current version of select2 being used.
56
-		 *
57
-		 * @var string
58
-		 */
59
-		public $select2_version = "4.0.11";
60
-
61
-		/**
62
-		 * The title.
63
-		 *
64
-		 * @var string
65
-		 */
66
-		public $name = 'AyeCode UI';
67
-
68
-		/**
69
-		 * The relative url to the assets.
70
-		 *
71
-		 * @var string
72
-		 */
73
-		public $url = '';
74
-
75
-		/**
76
-		 * Holds the settings values.
77
-		 *
78
-		 * @var array
79
-		 */
80
-		private $settings;
81
-
82
-		/**
83
-		 * AyeCode_UI_Settings instance.
84
-		 *
85
-		 * @access private
86
-		 * @since  1.0.0
87
-		 * @var    AyeCode_UI_Settings There can be only one!
88
-		 */
89
-		private static $instance = null;
90
-
91
-		/**
92
-		 * Main AyeCode_UI_Settings Instance.
93
-		 *
94
-		 * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
95
-		 *
96
-		 * @since 1.0.0
97
-		 * @static
98
-		 * @return AyeCode_UI_Settings - Main instance.
99
-		 */
100
-		public static function instance() {
101
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
102
-
103
-				self::$instance = new AyeCode_UI_Settings;
104
-
105
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
-
107
-				if ( is_admin() ) {
108
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
109
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
110
-
111
-					// Maybe show example page
112
-					add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
113
-				}
24
+    /**
25
+     * A Class to be able to change settings for Font Awesome.
26
+     *
27
+     * Class AyeCode_UI_Settings
28
+     * @ver 1.0.0
29
+     * @todo decide how to implement textdomain
30
+     */
31
+    class AyeCode_UI_Settings {
32
+
33
+        /**
34
+         * Class version version.
35
+         *
36
+         * @var string
37
+         */
38
+        public $version = '0.1.59';
39
+
40
+        /**
41
+         * Class textdomain.
42
+         *
43
+         * @var string
44
+         */
45
+        public $textdomain = 'aui';
46
+
47
+        /**
48
+         * Latest version of Bootstrap at time of publish published.
49
+         *
50
+         * @var string
51
+         */
52
+        public $latest = "4.5.3";
53
+
54
+        /**
55
+         * Current version of select2 being used.
56
+         *
57
+         * @var string
58
+         */
59
+        public $select2_version = "4.0.11";
60
+
61
+        /**
62
+         * The title.
63
+         *
64
+         * @var string
65
+         */
66
+        public $name = 'AyeCode UI';
67
+
68
+        /**
69
+         * The relative url to the assets.
70
+         *
71
+         * @var string
72
+         */
73
+        public $url = '';
74
+
75
+        /**
76
+         * Holds the settings values.
77
+         *
78
+         * @var array
79
+         */
80
+        private $settings;
81
+
82
+        /**
83
+         * AyeCode_UI_Settings instance.
84
+         *
85
+         * @access private
86
+         * @since  1.0.0
87
+         * @var    AyeCode_UI_Settings There can be only one!
88
+         */
89
+        private static $instance = null;
90
+
91
+        /**
92
+         * Main AyeCode_UI_Settings Instance.
93
+         *
94
+         * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
95
+         *
96
+         * @since 1.0.0
97
+         * @static
98
+         * @return AyeCode_UI_Settings - Main instance.
99
+         */
100
+        public static function instance() {
101
+            if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
102
+
103
+                self::$instance = new AyeCode_UI_Settings;
104
+
105
+                add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
+
107
+                if ( is_admin() ) {
108
+                    add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
109
+                    add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
110
+
111
+                    // Maybe show example page
112
+                    add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
113
+                }
114 114
 
115
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
115
+                add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
116 116
 
117
-				do_action( 'ayecode_ui_settings_loaded' );
118
-			}
117
+                do_action( 'ayecode_ui_settings_loaded' );
118
+            }
119 119
 
120
-			return self::$instance;
121
-		}
120
+            return self::$instance;
121
+        }
122 122
 
123
-		/**
124
-		 * Setup some constants.
125
-		 */
126
-		public function constants(){
127
-			define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be");
128
-			define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d');
129
-			if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL);
130
-			if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL);
131
-		}
123
+        /**
124
+         * Setup some constants.
125
+         */
126
+        public function constants(){
127
+            define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be");
128
+            define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d');
129
+            if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL);
130
+            if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL);
131
+        }
132 132
 
133
-		/**
134
-		 * Initiate the settings and add the required action hooks.
135
-		 */
136
-		public function init() {
137
-			$this->constants();
138
-			$this->settings = $this->get_settings();
139
-			$this->url = $this->get_url();
140
-
141
-			/**
142
-			 * Maybe load CSS
143
-			 *
144
-			 * We load super early in case there is a theme version that might change the colors
145
-			 */
146
-			if ( $this->settings['css'] ) {
147
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
148
-			}
149
-			if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
150
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
151
-			}
152
-
153
-			// maybe load JS
154
-			if ( $this->settings['js'] ) {
155
-				$priority = $this->is_bs3_compat() ? 100 : 1;
156
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
157
-			}
158
-			if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
159
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
160
-			}
161
-
162
-			// Maybe set the HTML font size
163
-			if ( $this->settings['html_font_size'] ) {
164
-				add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
165
-			}
133
+        /**
134
+         * Initiate the settings and add the required action hooks.
135
+         */
136
+        public function init() {
137
+            $this->constants();
138
+            $this->settings = $this->get_settings();
139
+            $this->url = $this->get_url();
140
+
141
+            /**
142
+             * Maybe load CSS
143
+             *
144
+             * We load super early in case there is a theme version that might change the colors
145
+             */
146
+            if ( $this->settings['css'] ) {
147
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
148
+            }
149
+            if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
150
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
151
+            }
166 152
 
153
+            // maybe load JS
154
+            if ( $this->settings['js'] ) {
155
+                $priority = $this->is_bs3_compat() ? 100 : 1;
156
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
157
+            }
158
+            if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
159
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
160
+            }
167 161
 
168
-		}
162
+            // Maybe set the HTML font size
163
+            if ( $this->settings['html_font_size'] ) {
164
+                add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
165
+            }
169 166
 
170
-		/**
171
-		 * Check if we should load the admin scripts or not.
172
-		 *
173
-		 * @return bool
174
-		 */
175
-		public function load_admin_scripts(){
176
-			$result = true;
177
-
178
-			// check if specifically disabled
179
-			if(!empty($this->settings['disable_admin'])){
180
-				$url_parts = explode("\n",$this->settings['disable_admin']);
181
-				foreach($url_parts as $part){
182
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
183
-						return false; // return early, no point checking further
184
-					}
185
-				}
186
-			}
187 167
 
188
-			return $result;
189
-		}
168
+        }
190 169
 
191
-		/**
192
-		 * Add a html font size to the footer.
193
-		 */
194
-		public function html_font_size(){
195
-			$this->settings = $this->get_settings();
196
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
197
-		}
170
+        /**
171
+         * Check if we should load the admin scripts or not.
172
+         *
173
+         * @return bool
174
+         */
175
+        public function load_admin_scripts(){
176
+            $result = true;
177
+
178
+            // check if specifically disabled
179
+            if(!empty($this->settings['disable_admin'])){
180
+                $url_parts = explode("\n",$this->settings['disable_admin']);
181
+                foreach($url_parts as $part){
182
+                    if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
183
+                        return false; // return early, no point checking further
184
+                    }
185
+                }
186
+            }
198 187
 
199
-		/**
200
-		 * Check if the current admin screen should load scripts.
201
-		 * 
202
-		 * @return bool
203
-		 */
204
-		public function is_aui_screen(){
205
-			$load = false;
206
-			// check if we should load or not
207
-			if ( is_admin() ) {
208
-				// Only enable on set pages
209
-				$aui_screens = array(
210
-					'page',
211
-					'post',
212
-					'settings_page_ayecode-ui-settings',
213
-					'appearance_page_gutenberg-widgets',
214
-					'widgets'
215
-				);
216
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
217
-
218
-				$screen = get_current_screen();
188
+            return $result;
189
+        }
190
+
191
+        /**
192
+         * Add a html font size to the footer.
193
+         */
194
+        public function html_font_size(){
195
+            $this->settings = $this->get_settings();
196
+            echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
197
+        }
198
+
199
+        /**
200
+         * Check if the current admin screen should load scripts.
201
+         * 
202
+         * @return bool
203
+         */
204
+        public function is_aui_screen(){
205
+            $load = false;
206
+            // check if we should load or not
207
+            if ( is_admin() ) {
208
+                // Only enable on set pages
209
+                $aui_screens = array(
210
+                    'page',
211
+                    'post',
212
+                    'settings_page_ayecode-ui-settings',
213
+                    'appearance_page_gutenberg-widgets',
214
+                    'widgets'
215
+                );
216
+                $screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
217
+
218
+                $screen = get_current_screen();
219 219
 
220 220
 //				echo '###'.$screen->id;
221 221
 
222
-				// check if we are on a AUI screen
223
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
224
-					$load = true;
225
-				}
222
+                // check if we are on a AUI screen
223
+                if ( $screen && in_array( $screen->id, $screen_ids ) ) {
224
+                    $load = true;
225
+                }
226 226
 
227
-				//load for widget previews in WP 5.8
228
-				if( !empty($_REQUEST['legacy-widget-preview'])){
229
-					$load = true;
230
-				}
231
-			}
227
+                //load for widget previews in WP 5.8
228
+                if( !empty($_REQUEST['legacy-widget-preview'])){
229
+                    $load = true;
230
+                }
231
+            }
232 232
 
233
-			return apply_filters( 'aui_load_on_admin' , $load );
234
-		}
233
+            return apply_filters( 'aui_load_on_admin' , $load );
234
+        }
235 235
 
236
-		/**
237
-		 * Adds the styles.
238
-		 */
239
-		public function enqueue_style() {
236
+        /**
237
+         * Adds the styles.
238
+         */
239
+        public function enqueue_style() {
240 240
 
241
-			if( is_admin() && !$this->is_aui_screen()){
242
-				// don't add wp-admin scripts if not requested to
243
-			}else{
244
-				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
241
+            if( is_admin() && !$this->is_aui_screen()){
242
+                // don't add wp-admin scripts if not requested to
243
+            }else{
244
+                $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
245 245
 
246
-				$rtl = is_rtl() ? '-rtl' : '';
246
+                $rtl = is_rtl() ? '-rtl' : '';
247 247
 
248
-				if($this->settings[$css_setting]){
249
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
250
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
251
-					wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
252
-					wp_enqueue_style( 'ayecode-ui' );
248
+                if($this->settings[$css_setting]){
249
+                    $compatibility = $this->settings[$css_setting]=='core' ? false : true;
250
+                    $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
251
+                    wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
252
+                    wp_enqueue_style( 'ayecode-ui' );
253 253
 
254
-					// flatpickr
255
-					wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
254
+                    // flatpickr
255
+                    wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
256 256
 
257 257
 
258
-					// fix some wp-admin issues
259
-					if(is_admin()){
260
-						$custom_css = "
258
+                    // fix some wp-admin issues
259
+                    if(is_admin()){
260
+                        $custom_css = "
261 261
                 body{
262 262
                     background-color: #f1f1f1;
263 263
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -299,35 +299,35 @@  discard block
 block discarded – undo
299 299
 				}
300 300
                 ";
301 301
 
302
-						// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
303
-						$custom_css .= "
302
+                        // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
303
+                        $custom_css .= "
304 304
 						.edit-post-sidebar input[type=color].components-text-control__input{
305 305
 						    padding: 0;
306 306
 						}
307 307
 					";
308
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
309
-					}
308
+                        wp_add_inline_style( 'ayecode-ui', $custom_css );
309
+                    }
310 310
 
311
-					// custom changes
312
-					wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
311
+                    // custom changes
312
+                    wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
313 313
 
314
-				}
315
-			}
314
+                }
315
+            }
316 316
 
317 317
 
318
-		}
318
+        }
319 319
 
320
-		/**
321
-		 * Get inline script used if bootstrap enqueued
322
-		 *
323
-		 * If this remains small then its best to use this than to add another JS file.
324
-		 */
325
-		public function inline_script() {
326
-			// Flatpickr calendar locale
327
-			$flatpickr_locale = self::flatpickr_locale();
328
-
329
-			ob_start();
330
-			?>
320
+        /**
321
+         * Get inline script used if bootstrap enqueued
322
+         *
323
+         * If this remains small then its best to use this than to add another JS file.
324
+         */
325
+        public function inline_script() {
326
+            // Flatpickr calendar locale
327
+            $flatpickr_locale = self::flatpickr_locale();
328
+
329
+            ob_start();
330
+            ?>
331 331
 			<script>
332 332
 				/**
333 333
 				 * An AUI bootstrap adaptation of GreedyNav.js ( by Luke Jackson ).
@@ -1016,29 +1016,29 @@  discard block
 block discarded – undo
1016 1016
 				});
1017 1017
 			</script>
1018 1018
 			<?php
1019
-			$output = ob_get_clean();
1019
+            $output = ob_get_clean();
1020 1020
 
1021 1021
 
1022 1022
 
1023
-			/*
1023
+            /*
1024 1024
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1025 1025
 			 */
1026
-			return str_replace( array(
1027
-				'<script>',
1028
-				'</script>'
1029
-			), '', self::minify_js($output) );
1030
-		}
1026
+            return str_replace( array(
1027
+                '<script>',
1028
+                '</script>'
1029
+            ), '', self::minify_js($output) );
1030
+        }
1031 1031
 
1032 1032
 
1033
-		/**
1034
-		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1035
-		 *
1036
-		 * @TODO we may need this when other conflicts arrise.
1037
-		 * @return mixed
1038
-		 */
1039
-		public static function bs3_compat_js() {
1040
-			ob_start();
1041
-			?>
1033
+        /**
1034
+         * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1035
+         *
1036
+         * @TODO we may need this when other conflicts arrise.
1037
+         * @return mixed
1038
+         */
1039
+        public static function bs3_compat_js() {
1040
+            ob_start();
1041
+            ?>
1042 1042
 			<script>
1043 1043
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1044 1044
 				/* With Avada builder */
@@ -1046,20 +1046,20 @@  discard block
 block discarded – undo
1046 1046
 				<?php } ?>
1047 1047
 			</script>
1048 1048
 			<?php
1049
-			return str_replace( array(
1050
-				'<script>',
1051
-				'</script>'
1052
-			), '', ob_get_clean());
1053
-		}
1049
+            return str_replace( array(
1050
+                '<script>',
1051
+                '</script>'
1052
+            ), '', ob_get_clean());
1053
+        }
1054 1054
 
1055
-		/**
1056
-		 * Get inline script used if bootstrap file browser enqueued.
1057
-		 *
1058
-		 * If this remains small then its best to use this than to add another JS file.
1059
-		 */
1060
-		public function inline_script_file_browser(){
1061
-			ob_start();
1062
-			?>
1055
+        /**
1056
+         * Get inline script used if bootstrap file browser enqueued.
1057
+         *
1058
+         * If this remains small then its best to use this than to add another JS file.
1059
+         */
1060
+        public function inline_script_file_browser(){
1061
+            ob_start();
1062
+            ?>
1063 1063
 			<script>
1064 1064
 				// run on doc ready
1065 1065
 				jQuery(document).ready(function () {
@@ -1067,192 +1067,192 @@  discard block
 block discarded – undo
1067 1067
 				});
1068 1068
 			</script>
1069 1069
 			<?php
1070
-			$output = ob_get_clean();
1070
+            $output = ob_get_clean();
1071 1071
 
1072
-			/*
1072
+            /*
1073 1073
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1074 1074
 			 */
1075
-			return str_replace( array(
1076
-				'<script>',
1077
-				'</script>'
1078
-			), '', $output );
1079
-		}
1075
+            return str_replace( array(
1076
+                '<script>',
1077
+                '</script>'
1078
+            ), '', $output );
1079
+        }
1080 1080
 
1081
-		/**
1082
-		 * Adds the Font Awesome JS.
1083
-		 */
1084
-		public function enqueue_scripts() {
1085
-
1086
-			if( is_admin() && !$this->is_aui_screen()){
1087
-				// don't add wp-admin scripts if not requested to
1088
-			}else {
1089
-
1090
-				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1091
-
1092
-				// select2
1093
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1094
-
1095
-				// flatpickr
1096
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1097
-
1098
-				// Bootstrap file browser
1099
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1100
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1101
-
1102
-				$load_inline = false;
1103
-
1104
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1105
-					// Bootstrap bundle
1106
-					$url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1107
-					wp_register_script( 'bootstrap-js-bundle', $url, array(
1108
-						'select2',
1109
-						'jquery'
1110
-					), $this->latest, $this->is_bs3_compat() );
1111
-					// if in admin then add to footer for compatibility.
1112
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1113
-					$script = $this->inline_script();
1114
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
1115
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1116
-					$url = $this->url . 'assets/js/popper.min.js';
1117
-					wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1118
-					wp_enqueue_script( 'bootstrap-js-popper' );
1119
-					$load_inline = true;
1120
-				} else {
1121
-					$load_inline = true;
1122
-				}
1081
+        /**
1082
+         * Adds the Font Awesome JS.
1083
+         */
1084
+        public function enqueue_scripts() {
1085
+
1086
+            if( is_admin() && !$this->is_aui_screen()){
1087
+                // don't add wp-admin scripts if not requested to
1088
+            }else {
1089
+
1090
+                $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1091
+
1092
+                // select2
1093
+                wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1094
+
1095
+                // flatpickr
1096
+                wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1097
+
1098
+                // Bootstrap file browser
1099
+                wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1100
+                wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1101
+
1102
+                $load_inline = false;
1103
+
1104
+                if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1105
+                    // Bootstrap bundle
1106
+                    $url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1107
+                    wp_register_script( 'bootstrap-js-bundle', $url, array(
1108
+                        'select2',
1109
+                        'jquery'
1110
+                    ), $this->latest, $this->is_bs3_compat() );
1111
+                    // if in admin then add to footer for compatibility.
1112
+                    is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1113
+                    $script = $this->inline_script();
1114
+                    wp_add_inline_script( 'bootstrap-js-bundle', $script );
1115
+                } elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1116
+                    $url = $this->url . 'assets/js/popper.min.js';
1117
+                    wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1118
+                    wp_enqueue_script( 'bootstrap-js-popper' );
1119
+                    $load_inline = true;
1120
+                } else {
1121
+                    $load_inline = true;
1122
+                }
1123 1123
 
1124
-				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1125
-				if ( $load_inline ) {
1126
-					wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1127
-					wp_enqueue_script( 'bootstrap-dummy' );
1128
-					$script = $this->inline_script();
1129
-					wp_add_inline_script( 'bootstrap-dummy', $script );
1130
-				}
1131
-			}
1124
+                // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1125
+                if ( $load_inline ) {
1126
+                    wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1127
+                    wp_enqueue_script( 'bootstrap-dummy' );
1128
+                    $script = $this->inline_script();
1129
+                    wp_add_inline_script( 'bootstrap-dummy', $script );
1130
+                }
1131
+            }
1132 1132
 
1133
-		}
1133
+        }
1134 1134
 
1135
-		/**
1136
-		 * Enqueue flatpickr if called.
1137
-		 */
1138
-		public function enqueue_flatpickr(){
1139
-			wp_enqueue_style( 'flatpickr' );
1140
-			wp_enqueue_script( 'flatpickr' );
1141
-		}
1135
+        /**
1136
+         * Enqueue flatpickr if called.
1137
+         */
1138
+        public function enqueue_flatpickr(){
1139
+            wp_enqueue_style( 'flatpickr' );
1140
+            wp_enqueue_script( 'flatpickr' );
1141
+        }
1142 1142
 
1143
-		/**
1144
-		 * Get the url path to the current folder.
1145
-		 *
1146
-		 * @return string
1147
-		 */
1148
-		public function get_url() {
1143
+        /**
1144
+         * Get the url path to the current folder.
1145
+         *
1146
+         * @return string
1147
+         */
1148
+        public function get_url() {
1149 1149
 
1150
-			$url = '';
1151
-			// check if we are inside a plugin
1152
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1150
+            $url = '';
1151
+            // check if we are inside a plugin
1152
+            $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1153 1153
 
1154
-			// add check in-case user has changed wp-content dir name.
1155
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
1156
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1157
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
1154
+            // add check in-case user has changed wp-content dir name.
1155
+            $wp_content_folder_name = basename(WP_CONTENT_DIR);
1156
+            $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1157
+            $url_parts = explode("/$wp_content_folder_name/",plugins_url());
1158 1158
 
1159
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1160
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1161
-			}
1159
+            if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1160
+                $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1161
+            }
1162 1162
 
1163
-			return $url;
1164
-		}
1163
+            return $url;
1164
+        }
1165 1165
 
1166
-		/**
1167
-		 * Register the database settings with WordPress.
1168
-		 */
1169
-		public function register_settings() {
1170
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1171
-		}
1166
+        /**
1167
+         * Register the database settings with WordPress.
1168
+         */
1169
+        public function register_settings() {
1170
+            register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1171
+        }
1172 1172
 
1173
-		/**
1174
-		 * Add the WordPress settings menu item.
1175
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1176
-		 */
1177
-		public function menu_item() {
1178
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1179
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1180
-				$this,
1181
-				'settings_page'
1182
-			) );
1183
-		}
1173
+        /**
1174
+         * Add the WordPress settings menu item.
1175
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1176
+         */
1177
+        public function menu_item() {
1178
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1179
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1180
+                $this,
1181
+                'settings_page'
1182
+            ) );
1183
+        }
1184 1184
 
1185
-		/**
1186
-		 * Get a list of themes and their default JS settings.
1187
-		 *
1188
-		 * @return array
1189
-		 */
1190
-		public function theme_js_settings(){
1191
-			return array(
1192
-				'ayetheme' => 'popper',
1193
-				'listimia' => 'required',
1194
-				'listimia_backend' => 'core-popper',
1195
-				//'avada'    => 'required', // removed as we now add compatibility
1196
-			);
1197
-		}
1185
+        /**
1186
+         * Get a list of themes and their default JS settings.
1187
+         *
1188
+         * @return array
1189
+         */
1190
+        public function theme_js_settings(){
1191
+            return array(
1192
+                'ayetheme' => 'popper',
1193
+                'listimia' => 'required',
1194
+                'listimia_backend' => 'core-popper',
1195
+                //'avada'    => 'required', // removed as we now add compatibility
1196
+            );
1197
+        }
1198 1198
 
1199
-		/**
1200
-		 * Get the current Font Awesome output settings.
1201
-		 *
1202
-		 * @return array The array of settings.
1203
-		 */
1204
-		public function get_settings() {
1205
-
1206
-			$db_settings = get_option( 'ayecode-ui-settings' );
1207
-			$js_default = 'core-popper';
1208
-			$js_default_backend = $js_default;
1209
-
1210
-			// maybe set defaults (if no settings set)
1211
-			if(empty($db_settings)){
1212
-				$active_theme = strtolower( get_template() ); // active parent theme.
1213
-				$theme_js_settings = self::theme_js_settings();
1214
-				if(isset($theme_js_settings[$active_theme])){
1215
-					$js_default = $theme_js_settings[$active_theme];
1216
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1217
-				}
1218
-			}
1219
-
1220
-			$defaults = array(
1221
-				'css'       => 'compatibility', // core, compatibility
1222
-				'js'        => $js_default, // js to load, core-popper, popper
1223
-				'html_font_size'        => '16', // js to load, core-popper, popper
1224
-				'css_backend'       => 'compatibility', // core, compatibility
1225
-				'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1226
-				'disable_admin'     =>  '', // URL snippets to disable loading on admin
1227
-			);
1228
-
1229
-			$settings = wp_parse_args( $db_settings, $defaults );
1230
-
1231
-			/**
1232
-			 * Filter the Bootstrap settings.
1233
-			 *
1234
-			 * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1235
-			 */
1236
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1237
-		}
1199
+        /**
1200
+         * Get the current Font Awesome output settings.
1201
+         *
1202
+         * @return array The array of settings.
1203
+         */
1204
+        public function get_settings() {
1205
+
1206
+            $db_settings = get_option( 'ayecode-ui-settings' );
1207
+            $js_default = 'core-popper';
1208
+            $js_default_backend = $js_default;
1209
+
1210
+            // maybe set defaults (if no settings set)
1211
+            if(empty($db_settings)){
1212
+                $active_theme = strtolower( get_template() ); // active parent theme.
1213
+                $theme_js_settings = self::theme_js_settings();
1214
+                if(isset($theme_js_settings[$active_theme])){
1215
+                    $js_default = $theme_js_settings[$active_theme];
1216
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1217
+                }
1218
+            }
1219
+
1220
+            $defaults = array(
1221
+                'css'       => 'compatibility', // core, compatibility
1222
+                'js'        => $js_default, // js to load, core-popper, popper
1223
+                'html_font_size'        => '16', // js to load, core-popper, popper
1224
+                'css_backend'       => 'compatibility', // core, compatibility
1225
+                'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1226
+                'disable_admin'     =>  '', // URL snippets to disable loading on admin
1227
+            );
1228
+
1229
+            $settings = wp_parse_args( $db_settings, $defaults );
1230
+
1231
+            /**
1232
+             * Filter the Bootstrap settings.
1233
+             *
1234
+             * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1235
+             */
1236
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1237
+        }
1238 1238
 
1239 1239
 
1240
-		/**
1241
-		 * The settings page html output.
1242
-		 */
1243
-		public function settings_page() {
1244
-			if ( ! current_user_can( 'manage_options' ) ) {
1245
-				wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1246
-			}
1247
-			?>
1240
+        /**
1241
+         * The settings page html output.
1242
+         */
1243
+        public function settings_page() {
1244
+            if ( ! current_user_can( 'manage_options' ) ) {
1245
+                wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1246
+            }
1247
+            ?>
1248 1248
 			<div class="wrap">
1249 1249
 				<h1><?php echo $this->name; ?></h1>
1250 1250
 				<p><?php _e("Here you can adjust settings if you are having compatibility issues.",'aui');?></p>
1251 1251
 				<form method="post" action="options.php">
1252 1252
 					<?php
1253
-					settings_fields( 'ayecode-ui-settings' );
1254
-					do_settings_sections( 'ayecode-ui-settings' );
1255
-					?>
1253
+                    settings_fields( 'ayecode-ui-settings' );
1254
+                    do_settings_sections( 'ayecode-ui-settings' );
1255
+                    ?>
1256 1256
 
1257 1257
 					<h2><?php _e( 'Frontend', 'aui' ); ?></h2>
1258 1258
 					<table class="form-table wpbs-table-settings">
@@ -1332,60 +1332,60 @@  discard block
 block discarded – undo
1332 1332
 					</table>
1333 1333
 
1334 1334
 					<?php
1335
-					submit_button();
1336
-					?>
1335
+                    submit_button();
1336
+                    ?>
1337 1337
 				</form>
1338 1338
 
1339 1339
 				<div id="wpbs-version"><?php echo $this->version; ?></div>
1340 1340
 			</div>
1341 1341
 
1342 1342
 			<?php
1343
-		}
1343
+        }
1344 1344
 
1345
-		public function customizer_settings($wp_customize){
1346
-			$wp_customize->add_section('aui_settings', array(
1347
-				'title'    => __('AyeCode UI','aui'),
1348
-				'priority' => 120,
1349
-			));
1350
-
1351
-			//  =============================
1352
-			//  = Color Picker              =
1353
-			//  =============================
1354
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1355
-				'default'           => AUI_PRIMARY_COLOR,
1356
-				'sanitize_callback' => 'sanitize_hex_color',
1357
-				'capability'        => 'edit_theme_options',
1358
-				'type'              => 'option',
1359
-				'transport'         => 'refresh',
1360
-			));
1361
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1362
-				'label'    => __('Primary Color','aui'),
1363
-				'section'  => 'aui_settings',
1364
-				'settings' => 'aui_options[color_primary]',
1365
-			)));
1366
-
1367
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1368
-				'default'           => '#6c757d',
1369
-				'sanitize_callback' => 'sanitize_hex_color',
1370
-				'capability'        => 'edit_theme_options',
1371
-				'type'              => 'option',
1372
-				'transport'         => 'refresh',
1373
-			));
1374
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1375
-				'label'    => __('Secondary Color','aui'),
1376
-				'section'  => 'aui_settings',
1377
-				'settings' => 'aui_options[color_secondary]',
1378
-			)));
1379
-		}
1345
+        public function customizer_settings($wp_customize){
1346
+            $wp_customize->add_section('aui_settings', array(
1347
+                'title'    => __('AyeCode UI','aui'),
1348
+                'priority' => 120,
1349
+            ));
1350
+
1351
+            //  =============================
1352
+            //  = Color Picker              =
1353
+            //  =============================
1354
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1355
+                'default'           => AUI_PRIMARY_COLOR,
1356
+                'sanitize_callback' => 'sanitize_hex_color',
1357
+                'capability'        => 'edit_theme_options',
1358
+                'type'              => 'option',
1359
+                'transport'         => 'refresh',
1360
+            ));
1361
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1362
+                'label'    => __('Primary Color','aui'),
1363
+                'section'  => 'aui_settings',
1364
+                'settings' => 'aui_options[color_primary]',
1365
+            )));
1366
+
1367
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1368
+                'default'           => '#6c757d',
1369
+                'sanitize_callback' => 'sanitize_hex_color',
1370
+                'capability'        => 'edit_theme_options',
1371
+                'type'              => 'option',
1372
+                'transport'         => 'refresh',
1373
+            ));
1374
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1375
+                'label'    => __('Secondary Color','aui'),
1376
+                'section'  => 'aui_settings',
1377
+                'settings' => 'aui_options[color_secondary]',
1378
+            )));
1379
+        }
1380 1380
 
1381
-		/**
1382
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1383
-		 *
1384
-		 * @return mixed
1385
-		 */
1386
-		public static function bs3_compat_css() {
1387
-			ob_start();
1388
-			?>
1381
+        /**
1382
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1383
+         *
1384
+         * @return mixed
1385
+         */
1386
+        public static function bs3_compat_css() {
1387
+            ob_start();
1388
+            ?>
1389 1389
 			<style>
1390 1390
 			/* Bootstrap 3 compatibility */
1391 1391
 			body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1411,579 +1411,579 @@  discard block
 block discarded – undo
1411 1411
 			<?php } ?>
1412 1412
 			</style>
1413 1413
 			<?php
1414
-			return str_replace( array(
1415
-				'<style>',
1416
-				'</style>'
1417
-			), '', self::minify_css( ob_get_clean() ) );
1418
-		}
1414
+            return str_replace( array(
1415
+                '<style>',
1416
+                '</style>'
1417
+            ), '', self::minify_css( ob_get_clean() ) );
1418
+        }
1419 1419
 
1420 1420
 
1421
-		public static function custom_css($compatibility = true) {
1422
-			$settings = get_option('aui_options');
1421
+        public static function custom_css($compatibility = true) {
1422
+            $settings = get_option('aui_options');
1423 1423
 
1424
-			ob_start();
1424
+            ob_start();
1425 1425
 
1426
-			$primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1427
-			$secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1428
-				//AUI_PRIMARY_COLOR_ORIGINAL
1429
-			?>
1426
+            $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1427
+            $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1428
+                //AUI_PRIMARY_COLOR_ORIGINAL
1429
+            ?>
1430 1430
 			<style>
1431 1431
 				<?php
1432 1432
 
1433
-					// BS v3 compat
1434
-					if( self::is_bs3_compat() ){
1435
-					    echo self::bs3_compat_css();
1436
-					}
1433
+                    // BS v3 compat
1434
+                    if( self::is_bs3_compat() ){
1435
+                        echo self::bs3_compat_css();
1436
+                    }
1437 1437
 
1438
-					if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1439
-						echo self::css_primary($primary_color,$compatibility);
1440
-					}
1438
+                    if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1439
+                        echo self::css_primary($primary_color,$compatibility);
1440
+                    }
1441 1441
 
1442
-					if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1443
-						echo self::css_secondary($settings['color_secondary'],$compatibility);
1444
-					}
1442
+                    if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1443
+                        echo self::css_secondary($settings['color_secondary'],$compatibility);
1444
+                    }
1445 1445
 
1446
-					// Set admin bar z-index lower when modal is open.
1447
-					echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1446
+                    // Set admin bar z-index lower when modal is open.
1447
+                    echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1448 1448
                 ?>
1449 1449
 			</style>
1450 1450
 			<?php
1451 1451
 
1452 1452
 
1453
-			/*
1453
+            /*
1454 1454
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1455 1455
 			 */
1456
-			return str_replace( array(
1457
-				'<style>',
1458
-				'</style>'
1459
-			), '', self::minify_css( ob_get_clean() ) );
1460
-		}
1456
+            return str_replace( array(
1457
+                '<style>',
1458
+                '</style>'
1459
+            ), '', self::minify_css( ob_get_clean() ) );
1460
+        }
1461 1461
 
1462
-		/**
1463
-		 * Check if we should add booststrap 3 compatibility changes.
1464
-		 *
1465
-		 * @return bool
1466
-		 */
1467
-		public static function is_bs3_compat(){
1468
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1469
-		}
1462
+        /**
1463
+         * Check if we should add booststrap 3 compatibility changes.
1464
+         *
1465
+         * @return bool
1466
+         */
1467
+        public static function is_bs3_compat(){
1468
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1469
+        }
1470 1470
 
1471
-		public static function css_primary($color_code,$compatibility){;
1472
-			$color_code = sanitize_hex_color($color_code);
1473
-			if(!$color_code){return '';}
1474
-			/**
1475
-			 * c = color, b = background color, o = border-color, f = fill
1476
-			 */
1477
-			$selectors = array(
1478
-				'a' => array('c'),
1479
-				'.btn-primary' => array('b','o'),
1480
-				'.btn-primary.disabled' => array('b','o'),
1481
-				'.btn-primary:disabled' => array('b','o'),
1482
-				'.btn-outline-primary' => array('c','o'),
1483
-				'.btn-outline-primary:hover' => array('b','o'),
1484
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1485
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1486
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1487
-				'.btn-link' => array('c'),
1488
-				'.dropdown-item.active' => array('b'),
1489
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1490
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1471
+        public static function css_primary($color_code,$compatibility){;
1472
+            $color_code = sanitize_hex_color($color_code);
1473
+            if(!$color_code){return '';}
1474
+            /**
1475
+             * c = color, b = background color, o = border-color, f = fill
1476
+             */
1477
+            $selectors = array(
1478
+                'a' => array('c'),
1479
+                '.btn-primary' => array('b','o'),
1480
+                '.btn-primary.disabled' => array('b','o'),
1481
+                '.btn-primary:disabled' => array('b','o'),
1482
+                '.btn-outline-primary' => array('c','o'),
1483
+                '.btn-outline-primary:hover' => array('b','o'),
1484
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1485
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1486
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1487
+                '.btn-link' => array('c'),
1488
+                '.dropdown-item.active' => array('b'),
1489
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1490
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1491 1491
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1492 1492
 //				'.custom-range::-moz-range-thumb' => array('b'),
1493 1493
 //				'.custom-range::-ms-thumb' => array('b'),
1494
-				'.nav-pills .nav-link.active' => array('b'),
1495
-				'.nav-pills .show>.nav-link' => array('b'),
1496
-				'.page-link' => array('c'),
1497
-				'.page-item.active .page-link' => array('b','o'),
1498
-				'.badge-primary' => array('b'),
1499
-				'.alert-primary' => array('b','o'),
1500
-				'.progress-bar' => array('b'),
1501
-				'.list-group-item.active' => array('b','o'),
1502
-				'.bg-primary' => array('b','f'),
1503
-				'.btn-link.btn-primary' => array('c'),
1504
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1505
-			);
1506
-
1507
-			$important_selectors = array(
1508
-				'.bg-primary' => array('b','f'),
1509
-				'.border-primary' => array('o'),
1510
-				'.text-primary' => array('c'),
1511
-			);
1512
-
1513
-			$color = array();
1514
-			$color_i = array();
1515
-			$background = array();
1516
-			$background_i = array();
1517
-			$border = array();
1518
-			$border_i = array();
1519
-			$fill = array();
1520
-			$fill_i = array();
1521
-
1522
-			$output = '';
1523
-
1524
-			// build rules into each type
1525
-			foreach($selectors as $selector => $types){
1526
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1527
-				$types = array_combine($types,$types);
1528
-				if(isset($types['c'])){$color[] = $selector;}
1529
-				if(isset($types['b'])){$background[] = $selector;}
1530
-				if(isset($types['o'])){$border[] = $selector;}
1531
-				if(isset($types['f'])){$fill[] = $selector;}
1532
-			}
1533
-
1534
-			// build rules into each type
1535
-			foreach($important_selectors as $selector => $types){
1536
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1537
-				$types = array_combine($types,$types);
1538
-				if(isset($types['c'])){$color_i[] = $selector;}
1539
-				if(isset($types['b'])){$background_i[] = $selector;}
1540
-				if(isset($types['o'])){$border_i[] = $selector;}
1541
-				if(isset($types['f'])){$fill_i[] = $selector;}
1542
-			}
1543
-
1544
-			// add any color rules
1545
-			if(!empty($color)){
1546
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1547
-			}
1548
-			if(!empty($color_i)){
1549
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1550
-			}
1551
-
1552
-			// add any background color rules
1553
-			if(!empty($background)){
1554
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1555
-			}
1556
-			if(!empty($background_i)){
1557
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1558
-			}
1559
-
1560
-			// add any border color rules
1561
-			if(!empty($border)){
1562
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1563
-			}
1564
-			if(!empty($border_i)){
1565
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1566
-			}
1567
-
1568
-			// add any fill color rules
1569
-			if(!empty($fill)){
1570
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1571
-			}
1572
-			if(!empty($fill_i)){
1573
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1574
-			}
1575
-
1576
-
1577
-			$prefix = $compatibility ? ".bsui " : "";
1578
-
1579
-			// darken
1580
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1581
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1582
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1583
-
1584
-			// lighten
1585
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1586
-
1587
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1588
-			$op_25 = $color_code."40"; // 25% opacity
1589
-
1590
-
1591
-			// button states
1592
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1593
-			$output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1594
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1595
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1596
-
1597
-
1598
-			// dropdown's
1599
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1600
-
1601
-
1602
-			// input states
1603
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1604
-
1605
-			// page link
1606
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1607
-
1608
-			return $output;
1609
-		}
1494
+                '.nav-pills .nav-link.active' => array('b'),
1495
+                '.nav-pills .show>.nav-link' => array('b'),
1496
+                '.page-link' => array('c'),
1497
+                '.page-item.active .page-link' => array('b','o'),
1498
+                '.badge-primary' => array('b'),
1499
+                '.alert-primary' => array('b','o'),
1500
+                '.progress-bar' => array('b'),
1501
+                '.list-group-item.active' => array('b','o'),
1502
+                '.bg-primary' => array('b','f'),
1503
+                '.btn-link.btn-primary' => array('c'),
1504
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1505
+            );
1506
+
1507
+            $important_selectors = array(
1508
+                '.bg-primary' => array('b','f'),
1509
+                '.border-primary' => array('o'),
1510
+                '.text-primary' => array('c'),
1511
+            );
1512
+
1513
+            $color = array();
1514
+            $color_i = array();
1515
+            $background = array();
1516
+            $background_i = array();
1517
+            $border = array();
1518
+            $border_i = array();
1519
+            $fill = array();
1520
+            $fill_i = array();
1521
+
1522
+            $output = '';
1523
+
1524
+            // build rules into each type
1525
+            foreach($selectors as $selector => $types){
1526
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1527
+                $types = array_combine($types,$types);
1528
+                if(isset($types['c'])){$color[] = $selector;}
1529
+                if(isset($types['b'])){$background[] = $selector;}
1530
+                if(isset($types['o'])){$border[] = $selector;}
1531
+                if(isset($types['f'])){$fill[] = $selector;}
1532
+            }
1610 1533
 
1611
-		public static function css_secondary($color_code,$compatibility){;
1612
-			$color_code = sanitize_hex_color($color_code);
1613
-			if(!$color_code){return '';}
1614
-			/**
1615
-			 * c = color, b = background color, o = border-color, f = fill
1616
-			 */
1617
-			$selectors = array(
1618
-				'.btn-secondary' => array('b','o'),
1619
-				'.btn-secondary.disabled' => array('b','o'),
1620
-				'.btn-secondary:disabled' => array('b','o'),
1621
-				'.btn-outline-secondary' => array('c','o'),
1622
-				'.btn-outline-secondary:hover' => array('b','o'),
1623
-				'.btn-outline-secondary.disabled' => array('c'),
1624
-				'.btn-outline-secondary:disabled' => array('c'),
1625
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1626
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1627
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1628
-				'.badge-secondary' => array('b'),
1629
-				'.alert-secondary' => array('b','o'),
1630
-				'.btn-link.btn-secondary' => array('c'),
1631
-			);
1632
-
1633
-			$important_selectors = array(
1634
-				'.bg-secondary' => array('b','f'),
1635
-				'.border-secondary' => array('o'),
1636
-				'.text-secondary' => array('c'),
1637
-			);
1638
-
1639
-			$color = array();
1640
-			$color_i = array();
1641
-			$background = array();
1642
-			$background_i = array();
1643
-			$border = array();
1644
-			$border_i = array();
1645
-			$fill = array();
1646
-			$fill_i = array();
1647
-
1648
-			$output = '';
1649
-
1650
-			// build rules into each type
1651
-			foreach($selectors as $selector => $types){
1652
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1653
-				$types = array_combine($types,$types);
1654
-				if(isset($types['c'])){$color[] = $selector;}
1655
-				if(isset($types['b'])){$background[] = $selector;}
1656
-				if(isset($types['o'])){$border[] = $selector;}
1657
-				if(isset($types['f'])){$fill[] = $selector;}
1658
-			}
1659
-
1660
-			// build rules into each type
1661
-			foreach($important_selectors as $selector => $types){
1662
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1663
-				$types = array_combine($types,$types);
1664
-				if(isset($types['c'])){$color_i[] = $selector;}
1665
-				if(isset($types['b'])){$background_i[] = $selector;}
1666
-				if(isset($types['o'])){$border_i[] = $selector;}
1667
-				if(isset($types['f'])){$fill_i[] = $selector;}
1668
-			}
1669
-
1670
-			// add any color rules
1671
-			if(!empty($color)){
1672
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1673
-			}
1674
-			if(!empty($color_i)){
1675
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1676
-			}
1677
-
1678
-			// add any background color rules
1679
-			if(!empty($background)){
1680
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1681
-			}
1682
-			if(!empty($background_i)){
1683
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1684
-			}
1685
-
1686
-			// add any border color rules
1687
-			if(!empty($border)){
1688
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1689
-			}
1690
-			if(!empty($border_i)){
1691
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1692
-			}
1693
-
1694
-			// add any fill color rules
1695
-			if(!empty($fill)){
1696
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1697
-			}
1698
-			if(!empty($fill_i)){
1699
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1700
-			}
1701
-
1702
-
1703
-			$prefix = $compatibility ? ".bsui " : "";
1704
-
1705
-			// darken
1706
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1707
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1708
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1709
-
1710
-			// lighten
1711
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1712
-
1713
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1714
-			$op_25 = $color_code."40"; // 25% opacity
1715
-
1716
-
1717
-			// button states
1718
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1719
-			$output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1720
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1721
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1722
-
1723
-
1724
-			return $output;
1725
-		}
1534
+            // build rules into each type
1535
+            foreach($important_selectors as $selector => $types){
1536
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1537
+                $types = array_combine($types,$types);
1538
+                if(isset($types['c'])){$color_i[] = $selector;}
1539
+                if(isset($types['b'])){$background_i[] = $selector;}
1540
+                if(isset($types['o'])){$border_i[] = $selector;}
1541
+                if(isset($types['f'])){$fill_i[] = $selector;}
1542
+            }
1726 1543
 
1727
-		/**
1728
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
1729
-		 *
1730
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1731
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1732
-		 *
1733
-		 * @return  string
1734
-		 */
1735
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1736
-			$hexCode = ltrim($hexCode, '#');
1544
+            // add any color rules
1545
+            if(!empty($color)){
1546
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1547
+            }
1548
+            if(!empty($color_i)){
1549
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1550
+            }
1737 1551
 
1738
-			if (strlen($hexCode) == 3) {
1739
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1740
-			}
1552
+            // add any background color rules
1553
+            if(!empty($background)){
1554
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1555
+            }
1556
+            if(!empty($background_i)){
1557
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1558
+            }
1741 1559
 
1742
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
1560
+            // add any border color rules
1561
+            if(!empty($border)){
1562
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1563
+            }
1564
+            if(!empty($border_i)){
1565
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1566
+            }
1743 1567
 
1744
-			foreach ($hexCode as & $color) {
1745
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1746
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
1568
+            // add any fill color rules
1569
+            if(!empty($fill)){
1570
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1571
+            }
1572
+            if(!empty($fill_i)){
1573
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1574
+            }
1747 1575
 
1748
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1749
-			}
1750 1576
 
1751
-			return '#' . implode($hexCode);
1752
-		}
1577
+            $prefix = $compatibility ? ".bsui " : "";
1753 1578
 
1754
-		/**
1755
-		 * Check if we should display examples.
1756
-		 */
1757
-		public function maybe_show_examples(){
1758
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1759
-				echo "<head>";
1760
-				wp_head();
1761
-				echo "</head>";
1762
-				echo "<body>";
1763
-				echo $this->get_examples();
1764
-				echo "</body>";
1765
-				exit;
1766
-			}
1767
-		}
1579
+            // darken
1580
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1581
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1582
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1768 1583
 
1769
-		/**
1770
-		 * Get developer examples.
1771
-		 *
1772
-		 * @return string
1773
-		 */
1774
-		public function get_examples(){
1775
-			$output = '';
1776
-
1777
-
1778
-			// open form
1779
-			$output .= "<form class='p-5 m-5 border rounded'>";
1780
-
1781
-			// input example
1782
-			$output .= aui()->input(array(
1783
-				'type'  =>  'text',
1784
-				'id'    =>  'text-example',
1785
-				'name'    =>  'text-example',
1786
-				'placeholder'   => 'text placeholder',
1787
-				'title'   => 'Text input example',
1788
-				'value' =>  '',
1789
-				'required'  => false,
1790
-				'help_text' => 'help text',
1791
-				'label' => 'Text input example label'
1792
-			));
1793
-
1794
-			// input example
1795
-			$output .= aui()->input(array(
1796
-				'type'  =>  'url',
1797
-				'id'    =>  'text-example2',
1798
-				'name'    =>  'text-example',
1799
-				'placeholder'   => 'url placeholder',
1800
-				'title'   => 'Text input example',
1801
-				'value' =>  '',
1802
-				'required'  => false,
1803
-				'help_text' => 'help text',
1804
-				'label' => 'Text input example label'
1805
-			));
1806
-
1807
-			// checkbox example
1808
-			$output .= aui()->input(array(
1809
-				'type'  =>  'checkbox',
1810
-				'id'    =>  'checkbox-example',
1811
-				'name'    =>  'checkbox-example',
1812
-				'placeholder'   => 'checkbox-example',
1813
-				'title'   => 'Checkbox example',
1814
-				'value' =>  '1',
1815
-				'checked'   => true,
1816
-				'required'  => false,
1817
-				'help_text' => 'help text',
1818
-				'label' => 'Checkbox checked'
1819
-			));
1820
-
1821
-			// checkbox example
1822
-			$output .= aui()->input(array(
1823
-				'type'  =>  'checkbox',
1824
-				'id'    =>  'checkbox-example2',
1825
-				'name'    =>  'checkbox-example2',
1826
-				'placeholder'   => 'checkbox-example',
1827
-				'title'   => 'Checkbox example',
1828
-				'value' =>  '1',
1829
-				'checked'   => false,
1830
-				'required'  => false,
1831
-				'help_text' => 'help text',
1832
-				'label' => 'Checkbox un-checked'
1833
-			));
1834
-
1835
-			// switch example
1836
-			$output .= aui()->input(array(
1837
-				'type'  =>  'checkbox',
1838
-				'id'    =>  'switch-example',
1839
-				'name'    =>  'switch-example',
1840
-				'placeholder'   => 'checkbox-example',
1841
-				'title'   => 'Switch example',
1842
-				'value' =>  '1',
1843
-				'checked'   => true,
1844
-				'switch'    => true,
1845
-				'required'  => false,
1846
-				'help_text' => 'help text',
1847
-				'label' => 'Switch on'
1848
-			));
1849
-
1850
-			// switch example
1851
-			$output .= aui()->input(array(
1852
-				'type'  =>  'checkbox',
1853
-				'id'    =>  'switch-example2',
1854
-				'name'    =>  'switch-example2',
1855
-				'placeholder'   => 'checkbox-example',
1856
-				'title'   => 'Switch example',
1857
-				'value' =>  '1',
1858
-				'checked'   => false,
1859
-				'switch'    => true,
1860
-				'required'  => false,
1861
-				'help_text' => 'help text',
1862
-				'label' => 'Switch off'
1863
-			));
1864
-
1865
-			// close form
1866
-			$output .= "</form>";
1867
-
1868
-			return $output;
1869
-		}
1584
+            // lighten
1585
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1870 1586
 
1871
-		/**
1872
-		 * Calendar params.
1873
-		 *
1874
-		 * @since 0.1.44
1875
-		 *
1876
-		 * @return array Calendar params.
1877
-		 */
1878
-		public static function calendar_params() {
1879
-			$params = array(
1880
-				'month_long_1' => __( 'January', 'aui' ),
1881
-				'month_long_2' => __( 'February', 'aui' ),
1882
-				'month_long_3' => __( 'March', 'aui' ),
1883
-				'month_long_4' => __( 'April', 'aui' ),
1884
-				'month_long_5' => __( 'May', 'aui' ),
1885
-				'month_long_6' => __( 'June', 'aui' ),
1886
-				'month_long_7' => __( 'July', 'aui' ),
1887
-				'month_long_8' => __( 'August', 'aui' ),
1888
-				'month_long_9' => __( 'September', 'aui' ),
1889
-				'month_long_10' => __( 'October', 'aui' ),
1890
-				'month_long_11' => __( 'November', 'aui' ),
1891
-				'month_long_12' => __( 'December', 'aui' ),
1892
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1893
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1894
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1895
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1896
-				'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1897
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1898
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1899
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1900
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1901
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1902
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1903
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1904
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1905
-				'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1906
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1907
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1908
-				'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1909
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1910
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1911
-				'day_s2_1' => __( 'Su', 'aui' ),
1912
-				'day_s2_2' => __( 'Mo', 'aui' ),
1913
-				'day_s2_3' => __( 'Tu', 'aui' ),
1914
-				'day_s2_4' => __( 'We', 'aui' ),
1915
-				'day_s2_5' => __( 'Th', 'aui' ),
1916
-				'day_s2_6' => __( 'Fr', 'aui' ),
1917
-				'day_s2_7' => __( 'Sa', 'aui' ),
1918
-				'day_s3_1' => __( 'Sun', 'aui' ),
1919
-				'day_s3_2' => __( 'Mon', 'aui' ),
1920
-				'day_s3_3' => __( 'Tue', 'aui' ),
1921
-				'day_s3_4' => __( 'Wed', 'aui' ),
1922
-				'day_s3_5' => __( 'Thu', 'aui' ),
1923
-				'day_s3_6' => __( 'Fri', 'aui' ),
1924
-				'day_s3_7' => __( 'Sat', 'aui' ),
1925
-				'day_s5_1' => __( 'Sunday', 'aui' ),
1926
-				'day_s5_2' => __( 'Monday', 'aui' ),
1927
-				'day_s5_3' => __( 'Tuesday', 'aui' ),
1928
-				'day_s5_4' => __( 'Wednesday', 'aui' ),
1929
-				'day_s5_5' => __( 'Thursday', 'aui' ),
1930
-				'day_s5_6' => __( 'Friday', 'aui' ),
1931
-				'day_s5_7' => __( 'Saturday', 'aui' ),
1932
-				'am_lower' => __( 'am', 'aui' ),
1933
-				'pm_lower' => __( 'pm', 'aui' ),
1934
-				'am_upper' => __( 'AM', 'aui' ),
1935
-				'pm_upper' => __( 'PM', 'aui' ),
1936
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1937
-				'time_24hr' => false,
1938
-				'year' => __( 'Year', 'aui' ),
1939
-				'hour' => __( 'Hour', 'aui' ),
1940
-				'minute' => __( 'Minute', 'aui' ),
1941
-				'weekAbbreviation' => __( 'Wk', 'aui' ),
1942
-				'rangeSeparator' => __( ' to ', 'aui' ),
1943
-				'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1944
-				'toggleTitle' => __( 'Click to toggle', 'aui' )
1945
-			);
1946
-
1947
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
1948
-		}
1587
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1588
+            $op_25 = $color_code."40"; // 25% opacity
1949 1589
 
1950
-		/**
1951
-		 * Flatpickr calendar localize.
1952
-		 *
1953
-		 * @since 0.1.44
1954
-		 *
1955
-		 * @return string Calendar locale.
1956
-		 */
1957
-		public static function flatpickr_locale() {
1958
-			$params = self::calendar_params();
1959
-
1960
-			if ( is_string( $params ) ) {
1961
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1962
-			} else {
1963
-				foreach ( (array) $params as $key => $value ) {
1964
-					if ( ! is_scalar( $value ) ) {
1965
-						continue;
1966
-					}
1967 1590
 
1968
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1969
-				}
1970
-			}
1591
+            // button states
1592
+            $output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1593
+            $output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1594
+            $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1595
+            $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1596
+
1597
+
1598
+            // dropdown's
1599
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1971 1600
 
1972
-			$day_s3 = array();
1973
-			$day_s5 = array();
1974 1601
 
1975
-			for ( $i = 1; $i <= 7; $i ++ ) {
1976
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1977
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1978
-			}
1602
+            // input states
1603
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1979 1604
 
1980
-			$month_s = array();
1981
-			$month_long = array();
1605
+            // page link
1606
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1607
+
1608
+            return $output;
1609
+        }
1610
+
1611
+        public static function css_secondary($color_code,$compatibility){;
1612
+            $color_code = sanitize_hex_color($color_code);
1613
+            if(!$color_code){return '';}
1614
+            /**
1615
+             * c = color, b = background color, o = border-color, f = fill
1616
+             */
1617
+            $selectors = array(
1618
+                '.btn-secondary' => array('b','o'),
1619
+                '.btn-secondary.disabled' => array('b','o'),
1620
+                '.btn-secondary:disabled' => array('b','o'),
1621
+                '.btn-outline-secondary' => array('c','o'),
1622
+                '.btn-outline-secondary:hover' => array('b','o'),
1623
+                '.btn-outline-secondary.disabled' => array('c'),
1624
+                '.btn-outline-secondary:disabled' => array('c'),
1625
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1626
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1627
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1628
+                '.badge-secondary' => array('b'),
1629
+                '.alert-secondary' => array('b','o'),
1630
+                '.btn-link.btn-secondary' => array('c'),
1631
+            );
1632
+
1633
+            $important_selectors = array(
1634
+                '.bg-secondary' => array('b','f'),
1635
+                '.border-secondary' => array('o'),
1636
+                '.text-secondary' => array('c'),
1637
+            );
1638
+
1639
+            $color = array();
1640
+            $color_i = array();
1641
+            $background = array();
1642
+            $background_i = array();
1643
+            $border = array();
1644
+            $border_i = array();
1645
+            $fill = array();
1646
+            $fill_i = array();
1647
+
1648
+            $output = '';
1649
+
1650
+            // build rules into each type
1651
+            foreach($selectors as $selector => $types){
1652
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1653
+                $types = array_combine($types,$types);
1654
+                if(isset($types['c'])){$color[] = $selector;}
1655
+                if(isset($types['b'])){$background[] = $selector;}
1656
+                if(isset($types['o'])){$border[] = $selector;}
1657
+                if(isset($types['f'])){$fill[] = $selector;}
1658
+            }
1659
+
1660
+            // build rules into each type
1661
+            foreach($important_selectors as $selector => $types){
1662
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1663
+                $types = array_combine($types,$types);
1664
+                if(isset($types['c'])){$color_i[] = $selector;}
1665
+                if(isset($types['b'])){$background_i[] = $selector;}
1666
+                if(isset($types['o'])){$border_i[] = $selector;}
1667
+                if(isset($types['f'])){$fill_i[] = $selector;}
1668
+            }
1982 1669
 
1983
-			for ( $i = 1; $i <= 12; $i ++ ) {
1984
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1985
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1986
-			}
1670
+            // add any color rules
1671
+            if(!empty($color)){
1672
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1673
+            }
1674
+            if(!empty($color_i)){
1675
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1676
+            }
1677
+
1678
+            // add any background color rules
1679
+            if(!empty($background)){
1680
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1681
+            }
1682
+            if(!empty($background_i)){
1683
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1684
+            }
1685
+
1686
+            // add any border color rules
1687
+            if(!empty($border)){
1688
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1689
+            }
1690
+            if(!empty($border_i)){
1691
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1692
+            }
1693
+
1694
+            // add any fill color rules
1695
+            if(!empty($fill)){
1696
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1697
+            }
1698
+            if(!empty($fill_i)){
1699
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1700
+            }
1701
+
1702
+
1703
+            $prefix = $compatibility ? ".bsui " : "";
1704
+
1705
+            // darken
1706
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1707
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1708
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1709
+
1710
+            // lighten
1711
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1712
+
1713
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1714
+            $op_25 = $color_code."40"; // 25% opacity
1715
+
1716
+
1717
+            // button states
1718
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1719
+            $output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1720
+            $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1721
+            $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1722
+
1723
+
1724
+            return $output;
1725
+        }
1726
+
1727
+        /**
1728
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
1729
+         *
1730
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1731
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1732
+         *
1733
+         * @return  string
1734
+         */
1735
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1736
+            $hexCode = ltrim($hexCode, '#');
1737
+
1738
+            if (strlen($hexCode) == 3) {
1739
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1740
+            }
1741
+
1742
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1743
+
1744
+            foreach ($hexCode as & $color) {
1745
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1746
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1747
+
1748
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1749
+            }
1750
+
1751
+            return '#' . implode($hexCode);
1752
+        }
1753
+
1754
+        /**
1755
+         * Check if we should display examples.
1756
+         */
1757
+        public function maybe_show_examples(){
1758
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1759
+                echo "<head>";
1760
+                wp_head();
1761
+                echo "</head>";
1762
+                echo "<body>";
1763
+                echo $this->get_examples();
1764
+                echo "</body>";
1765
+                exit;
1766
+            }
1767
+        }
1768
+
1769
+        /**
1770
+         * Get developer examples.
1771
+         *
1772
+         * @return string
1773
+         */
1774
+        public function get_examples(){
1775
+            $output = '';
1776
+
1777
+
1778
+            // open form
1779
+            $output .= "<form class='p-5 m-5 border rounded'>";
1780
+
1781
+            // input example
1782
+            $output .= aui()->input(array(
1783
+                'type'  =>  'text',
1784
+                'id'    =>  'text-example',
1785
+                'name'    =>  'text-example',
1786
+                'placeholder'   => 'text placeholder',
1787
+                'title'   => 'Text input example',
1788
+                'value' =>  '',
1789
+                'required'  => false,
1790
+                'help_text' => 'help text',
1791
+                'label' => 'Text input example label'
1792
+            ));
1793
+
1794
+            // input example
1795
+            $output .= aui()->input(array(
1796
+                'type'  =>  'url',
1797
+                'id'    =>  'text-example2',
1798
+                'name'    =>  'text-example',
1799
+                'placeholder'   => 'url placeholder',
1800
+                'title'   => 'Text input example',
1801
+                'value' =>  '',
1802
+                'required'  => false,
1803
+                'help_text' => 'help text',
1804
+                'label' => 'Text input example label'
1805
+            ));
1806
+
1807
+            // checkbox example
1808
+            $output .= aui()->input(array(
1809
+                'type'  =>  'checkbox',
1810
+                'id'    =>  'checkbox-example',
1811
+                'name'    =>  'checkbox-example',
1812
+                'placeholder'   => 'checkbox-example',
1813
+                'title'   => 'Checkbox example',
1814
+                'value' =>  '1',
1815
+                'checked'   => true,
1816
+                'required'  => false,
1817
+                'help_text' => 'help text',
1818
+                'label' => 'Checkbox checked'
1819
+            ));
1820
+
1821
+            // checkbox example
1822
+            $output .= aui()->input(array(
1823
+                'type'  =>  'checkbox',
1824
+                'id'    =>  'checkbox-example2',
1825
+                'name'    =>  'checkbox-example2',
1826
+                'placeholder'   => 'checkbox-example',
1827
+                'title'   => 'Checkbox example',
1828
+                'value' =>  '1',
1829
+                'checked'   => false,
1830
+                'required'  => false,
1831
+                'help_text' => 'help text',
1832
+                'label' => 'Checkbox un-checked'
1833
+            ));
1834
+
1835
+            // switch example
1836
+            $output .= aui()->input(array(
1837
+                'type'  =>  'checkbox',
1838
+                'id'    =>  'switch-example',
1839
+                'name'    =>  'switch-example',
1840
+                'placeholder'   => 'checkbox-example',
1841
+                'title'   => 'Switch example',
1842
+                'value' =>  '1',
1843
+                'checked'   => true,
1844
+                'switch'    => true,
1845
+                'required'  => false,
1846
+                'help_text' => 'help text',
1847
+                'label' => 'Switch on'
1848
+            ));
1849
+
1850
+            // switch example
1851
+            $output .= aui()->input(array(
1852
+                'type'  =>  'checkbox',
1853
+                'id'    =>  'switch-example2',
1854
+                'name'    =>  'switch-example2',
1855
+                'placeholder'   => 'checkbox-example',
1856
+                'title'   => 'Switch example',
1857
+                'value' =>  '1',
1858
+                'checked'   => false,
1859
+                'switch'    => true,
1860
+                'required'  => false,
1861
+                'help_text' => 'help text',
1862
+                'label' => 'Switch off'
1863
+            ));
1864
+
1865
+            // close form
1866
+            $output .= "</form>";
1867
+
1868
+            return $output;
1869
+        }
1870
+
1871
+        /**
1872
+         * Calendar params.
1873
+         *
1874
+         * @since 0.1.44
1875
+         *
1876
+         * @return array Calendar params.
1877
+         */
1878
+        public static function calendar_params() {
1879
+            $params = array(
1880
+                'month_long_1' => __( 'January', 'aui' ),
1881
+                'month_long_2' => __( 'February', 'aui' ),
1882
+                'month_long_3' => __( 'March', 'aui' ),
1883
+                'month_long_4' => __( 'April', 'aui' ),
1884
+                'month_long_5' => __( 'May', 'aui' ),
1885
+                'month_long_6' => __( 'June', 'aui' ),
1886
+                'month_long_7' => __( 'July', 'aui' ),
1887
+                'month_long_8' => __( 'August', 'aui' ),
1888
+                'month_long_9' => __( 'September', 'aui' ),
1889
+                'month_long_10' => __( 'October', 'aui' ),
1890
+                'month_long_11' => __( 'November', 'aui' ),
1891
+                'month_long_12' => __( 'December', 'aui' ),
1892
+                'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1893
+                'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1894
+                'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1895
+                'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1896
+                'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1897
+                'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1898
+                'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1899
+                'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1900
+                'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1901
+                'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1902
+                'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1903
+                'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1904
+                'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1905
+                'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1906
+                'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1907
+                'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1908
+                'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1909
+                'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1910
+                'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1911
+                'day_s2_1' => __( 'Su', 'aui' ),
1912
+                'day_s2_2' => __( 'Mo', 'aui' ),
1913
+                'day_s2_3' => __( 'Tu', 'aui' ),
1914
+                'day_s2_4' => __( 'We', 'aui' ),
1915
+                'day_s2_5' => __( 'Th', 'aui' ),
1916
+                'day_s2_6' => __( 'Fr', 'aui' ),
1917
+                'day_s2_7' => __( 'Sa', 'aui' ),
1918
+                'day_s3_1' => __( 'Sun', 'aui' ),
1919
+                'day_s3_2' => __( 'Mon', 'aui' ),
1920
+                'day_s3_3' => __( 'Tue', 'aui' ),
1921
+                'day_s3_4' => __( 'Wed', 'aui' ),
1922
+                'day_s3_5' => __( 'Thu', 'aui' ),
1923
+                'day_s3_6' => __( 'Fri', 'aui' ),
1924
+                'day_s3_7' => __( 'Sat', 'aui' ),
1925
+                'day_s5_1' => __( 'Sunday', 'aui' ),
1926
+                'day_s5_2' => __( 'Monday', 'aui' ),
1927
+                'day_s5_3' => __( 'Tuesday', 'aui' ),
1928
+                'day_s5_4' => __( 'Wednesday', 'aui' ),
1929
+                'day_s5_5' => __( 'Thursday', 'aui' ),
1930
+                'day_s5_6' => __( 'Friday', 'aui' ),
1931
+                'day_s5_7' => __( 'Saturday', 'aui' ),
1932
+                'am_lower' => __( 'am', 'aui' ),
1933
+                'pm_lower' => __( 'pm', 'aui' ),
1934
+                'am_upper' => __( 'AM', 'aui' ),
1935
+                'pm_upper' => __( 'PM', 'aui' ),
1936
+                'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1937
+                'time_24hr' => false,
1938
+                'year' => __( 'Year', 'aui' ),
1939
+                'hour' => __( 'Hour', 'aui' ),
1940
+                'minute' => __( 'Minute', 'aui' ),
1941
+                'weekAbbreviation' => __( 'Wk', 'aui' ),
1942
+                'rangeSeparator' => __( ' to ', 'aui' ),
1943
+                'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1944
+                'toggleTitle' => __( 'Click to toggle', 'aui' )
1945
+            );
1946
+
1947
+            return apply_filters( 'ayecode_ui_calendar_params', $params );
1948
+        }
1949
+
1950
+        /**
1951
+         * Flatpickr calendar localize.
1952
+         *
1953
+         * @since 0.1.44
1954
+         *
1955
+         * @return string Calendar locale.
1956
+         */
1957
+        public static function flatpickr_locale() {
1958
+            $params = self::calendar_params();
1959
+
1960
+            if ( is_string( $params ) ) {
1961
+                $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1962
+            } else {
1963
+                foreach ( (array) $params as $key => $value ) {
1964
+                    if ( ! is_scalar( $value ) ) {
1965
+                        continue;
1966
+                    }
1967
+
1968
+                    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1969
+                }
1970
+            }
1971
+
1972
+            $day_s3 = array();
1973
+            $day_s5 = array();
1974
+
1975
+            for ( $i = 1; $i <= 7; $i ++ ) {
1976
+                $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1977
+                $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1978
+            }
1979
+
1980
+            $month_s = array();
1981
+            $month_long = array();
1982
+
1983
+            for ( $i = 1; $i <= 12; $i ++ ) {
1984
+                $month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1985
+                $month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1986
+            }
1987 1987
 
1988 1988
 ob_start();
1989 1989
 if ( 0 ) { ?><script><?php } ?>
@@ -2025,189 +2025,189 @@  discard block
 block discarded – undo
2025 2025
 }
2026 2026
 <?php if ( 0 ) { ?></script><?php } ?>
2027 2027
 <?php
2028
-			$locale = ob_get_clean();
2028
+            $locale = ob_get_clean();
2029 2029
 
2030
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2031
-		}
2030
+            return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2031
+        }
2032 2032
 
2033
-		/**
2034
-		 * Select2 JS params.
2035
-		 *
2036
-		 * @since 0.1.44
2037
-		 *
2038
-		 * @return array Select2 JS params.
2039
-		 */
2040
-		public static function select2_params() {
2041
-			$params = array(
2042
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2043
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2044
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2045
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2046
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2047
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2048
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2049
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2050
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2051
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2052
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2053
-			);
2054
-
2055
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2056
-		}
2033
+        /**
2034
+         * Select2 JS params.
2035
+         *
2036
+         * @since 0.1.44
2037
+         *
2038
+         * @return array Select2 JS params.
2039
+         */
2040
+        public static function select2_params() {
2041
+            $params = array(
2042
+                'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2043
+                'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2044
+                'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2045
+                'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2046
+                'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2047
+                'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2048
+                'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2049
+                'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2050
+                'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2051
+                'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2052
+                'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2053
+            );
2054
+
2055
+            return apply_filters( 'ayecode_ui_select2_params', $params );
2056
+        }
2057 2057
 
2058
-		/**
2059
-		 * Select2 JS localize.
2060
-		 *
2061
-		 * @since 0.1.44
2062
-		 *
2063
-		 * @return string Select2 JS locale.
2064
-		 */
2065
-		public static function select2_locale() {
2066
-			$params = self::select2_params();
2067
-
2068
-			foreach ( (array) $params as $key => $value ) {
2069
-				if ( ! is_scalar( $value ) ) {
2070
-					continue;
2071
-				}
2058
+        /**
2059
+         * Select2 JS localize.
2060
+         *
2061
+         * @since 0.1.44
2062
+         *
2063
+         * @return string Select2 JS locale.
2064
+         */
2065
+        public static function select2_locale() {
2066
+            $params = self::select2_params();
2067
+
2068
+            foreach ( (array) $params as $key => $value ) {
2069
+                if ( ! is_scalar( $value ) ) {
2070
+                    continue;
2071
+                }
2072 2072
 
2073
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2074
-			}
2073
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2074
+            }
2075 2075
 
2076
-			$locale = json_encode( $params );
2076
+            $locale = json_encode( $params );
2077 2077
 
2078
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2079
-		}
2078
+            return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2079
+        }
2080 2080
 
2081
-		/**
2082
-		 * Time ago JS localize.
2083
-		 *
2084
-		 * @since 0.1.47
2085
-		 *
2086
-		 * @return string Time ago JS locale.
2087
-		 */
2088
-		public static function timeago_locale() {
2089
-			$params = array(
2090
-				'prefix_ago' => '',
2091
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2092
-				'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2093
-				'suffix_after' => '',
2094
-				'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2095
-				'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2096
-				'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2097
-				'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2098
-				'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2099
-				'day' => _x( 'a day', 'time ago', 'aui' ),
2100
-				'days' => _x( '%d days', 'time ago', 'aui' ),
2101
-				'month' => _x( 'about a month', 'time ago', 'aui' ),
2102
-				'months' => _x( '%d months', 'time ago', 'aui' ),
2103
-				'year' => _x( 'about a year', 'time ago', 'aui' ),
2104
-				'years' => _x( '%d years', 'time ago', 'aui' ),
2105
-			);
2106
-
2107
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2108
-
2109
-			foreach ( (array) $params as $key => $value ) {
2110
-				if ( ! is_scalar( $value ) ) {
2111
-					continue;
2112
-				}
2081
+        /**
2082
+         * Time ago JS localize.
2083
+         *
2084
+         * @since 0.1.47
2085
+         *
2086
+         * @return string Time ago JS locale.
2087
+         */
2088
+        public static function timeago_locale() {
2089
+            $params = array(
2090
+                'prefix_ago' => '',
2091
+                'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2092
+                'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2093
+                'suffix_after' => '',
2094
+                'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2095
+                'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2096
+                'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2097
+                'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2098
+                'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2099
+                'day' => _x( 'a day', 'time ago', 'aui' ),
2100
+                'days' => _x( '%d days', 'time ago', 'aui' ),
2101
+                'month' => _x( 'about a month', 'time ago', 'aui' ),
2102
+                'months' => _x( '%d months', 'time ago', 'aui' ),
2103
+                'year' => _x( 'about a year', 'time ago', 'aui' ),
2104
+                'years' => _x( '%d years', 'time ago', 'aui' ),
2105
+            );
2106
+
2107
+            $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2108
+
2109
+            foreach ( (array) $params as $key => $value ) {
2110
+                if ( ! is_scalar( $value ) ) {
2111
+                    continue;
2112
+                }
2113 2113
 
2114
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2115
-			}
2114
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2115
+            }
2116 2116
 
2117
-			$locale = json_encode( $params );
2117
+            $locale = json_encode( $params );
2118 2118
 
2119
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2120
-		}
2119
+            return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2120
+        }
2121 2121
 
2122
-		/**
2123
-		 * JavaScript Minifier
2124
-		 *
2125
-		 * @param $input
2126
-		 *
2127
-		 * @return mixed
2128
-		 */
2129
-		public static function minify_js($input) {
2130
-			if(trim($input) === "") return $input;
2131
-			return preg_replace(
2132
-				array(
2133
-					// Remove comment(s)
2134
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2135
-					// Remove white-space(s) outside the string and regex
2136
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2137
-					// Remove the last semicolon
2138
-					'#;+\}#',
2139
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2140
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2141
-					// --ibid. From `foo['bar']` to `foo.bar`
2142
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2143
-				),
2144
-				array(
2145
-					'$1',
2146
-					'$1$2',
2147
-					'}',
2148
-					'$1$3',
2149
-					'$1.$3'
2150
-				),
2151
-				$input);
2152
-		}
2122
+        /**
2123
+         * JavaScript Minifier
2124
+         *
2125
+         * @param $input
2126
+         *
2127
+         * @return mixed
2128
+         */
2129
+        public static function minify_js($input) {
2130
+            if(trim($input) === "") return $input;
2131
+            return preg_replace(
2132
+                array(
2133
+                    // Remove comment(s)
2134
+                    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2135
+                    // Remove white-space(s) outside the string and regex
2136
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2137
+                    // Remove the last semicolon
2138
+                    '#;+\}#',
2139
+                    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2140
+                    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2141
+                    // --ibid. From `foo['bar']` to `foo.bar`
2142
+                    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2143
+                ),
2144
+                array(
2145
+                    '$1',
2146
+                    '$1$2',
2147
+                    '}',
2148
+                    '$1$3',
2149
+                    '$1.$3'
2150
+                ),
2151
+                $input);
2152
+        }
2153 2153
 
2154
-		/**
2155
-		 * Minify CSS
2156
-		 *
2157
-		 * @param $input
2158
-		 *
2159
-		 * @return mixed
2160
-		 */
2161
-		public static function minify_css($input) {
2162
-			if(trim($input) === "") return $input;
2163
-			return preg_replace(
2164
-				array(
2165
-					// Remove comment(s)
2166
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2167
-					// Remove unused white-space(s)
2168
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2169
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2170
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2171
-					// Replace `:0 0 0 0` with `:0`
2172
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2173
-					// Replace `background-position:0` with `background-position:0 0`
2174
-					'#(background-position):0(?=[;\}])#si',
2175
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2176
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2177
-					// Minify string value
2178
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2179
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2180
-					// Minify HEX color code
2181
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2182
-					// Replace `(border|outline):none` with `(border|outline):0`
2183
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2184
-					// Remove empty selector(s)
2185
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2186
-				),
2187
-				array(
2188
-					'$1',
2189
-					'$1$2$3$4$5$6$7',
2190
-					'$1',
2191
-					':0',
2192
-					'$1:0 0',
2193
-					'.$1',
2194
-					'$1$3',
2195
-					'$1$2$4$5',
2196
-					'$1$2$3',
2197
-					'$1:0',
2198
-					'$1$2'
2199
-				),
2200
-				$input);
2201
-		}
2154
+        /**
2155
+         * Minify CSS
2156
+         *
2157
+         * @param $input
2158
+         *
2159
+         * @return mixed
2160
+         */
2161
+        public static function minify_css($input) {
2162
+            if(trim($input) === "") return $input;
2163
+            return preg_replace(
2164
+                array(
2165
+                    // Remove comment(s)
2166
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2167
+                    // Remove unused white-space(s)
2168
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2169
+                    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2170
+                    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2171
+                    // Replace `:0 0 0 0` with `:0`
2172
+                    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2173
+                    // Replace `background-position:0` with `background-position:0 0`
2174
+                    '#(background-position):0(?=[;\}])#si',
2175
+                    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2176
+                    '#(?<=[\s:,\-])0+\.(\d+)#s',
2177
+                    // Minify string value
2178
+                    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2179
+                    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2180
+                    // Minify HEX color code
2181
+                    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2182
+                    // Replace `(border|outline):none` with `(border|outline):0`
2183
+                    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2184
+                    // Remove empty selector(s)
2185
+                    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2186
+                ),
2187
+                array(
2188
+                    '$1',
2189
+                    '$1$2$3$4$5$6$7',
2190
+                    '$1',
2191
+                    ':0',
2192
+                    '$1:0 0',
2193
+                    '.$1',
2194
+                    '$1$3',
2195
+                    '$1$2$4$5',
2196
+                    '$1$2$3',
2197
+                    '$1:0',
2198
+                    '$1$2'
2199
+                ),
2200
+                $input);
2201
+        }
2202 2202
 
2203
-		/**
2204
-		 * Get the conditional fields JavaScript.
2205
-		 *
2206
-		 * @return mixed
2207
-		 */
2208
-		public function conditional_fields_js() {
2209
-			ob_start();
2210
-			?>
2203
+        /**
2204
+         * Get the conditional fields JavaScript.
2205
+         *
2206
+         * @return mixed
2207
+         */
2208
+        public function conditional_fields_js() {
2209
+            ob_start();
2210
+            ?>
2211 2211
 <script>
2212 2212
 /**
2213 2213
  * Conditional Fields
@@ -2682,14 +2682,14 @@  discard block
 block discarded – undo
2682 2682
 <?php do_action( 'aui_conditional_fields_js', $this ); ?>
2683 2683
 </script>
2684 2684
 			<?php
2685
-			$output = ob_get_clean();
2685
+            $output = ob_get_clean();
2686 2686
 
2687
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
2688
-		}
2689
-	}
2687
+            return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
2688
+        }
2689
+    }
2690 2690
 
2691
-	/**
2692
-	 * Run the class if found.
2693
-	 */
2694
-	AyeCode_UI_Settings::instance();
2691
+    /**
2692
+     * Run the class if found.
2693
+     */
2694
+    AyeCode_UI_Settings::instance();
2695 2695
 }
2696 2696
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/class-aui.php 1 patch
Indentation   +227 added lines, -227 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,231 +11,231 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI {
13 13
 
14
-	/**
15
-	 * Holds the class instance.
16
-	 *
17
-	 * @since 1.0.0
18
-	 * @var null
19
-	 */
20
-	private static $instance = null;
21
-
22
-	/**
23
-	 * Holds the current AUI version number.
24
-	 *
25
-	 * @var string $ver The current version number.
26
-	 */
27
-	public static $ver = '0.1.59';
28
-
29
-	public static $options = null;
30
-
31
-	/**
32
-	 * There can be only one.
33
-	 *
34
-	 * @since 1.0.0
35
-	 * @return AUI|null
36
-	 */
37
-	public static function instance() {
38
-		if ( self::$instance == null ) {
39
-			self::$instance = new AUI();
40
-		}
41
-
42
-		return self::$instance;
43
-	}
44
-
45
-	/**
46
-	 * AUI constructor.
47
-	 *
48
-	 * @since 1.0.0
49
-	 */
50
-	private function __construct() {
51
-		if ( function_exists( "__autoload" ) ) {
52
-			spl_autoload_register( "__autoload" );
53
-		}
54
-		spl_autoload_register( array( $this, 'autoload' ) );
55
-
56
-		// load options
57
-		self::$options = get_option('aui_options');
58
-	}
59
-
60
-	/**
61
-	 * Autoload any components on the fly.
62
-	 *
63
-	 * @since 1.0.0
64
-	 *
65
-	 * @param $classname
66
-	 */
67
-	private function autoload( $classname ) {
68
-		$class     = str_replace( '_', '-', strtolower( $classname ) );
69
-		$file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
-		if ( $file_path && is_readable( $file_path ) ) {
71
-			include_once( $file_path );
72
-		}
73
-	}
74
-
75
-	/**
76
-	 * Get the AUI options.
77
-	 *
78
-	 * @param $option
79
-	 *
80
-	 * @return string|void
81
-	 */
82
-	public function get_option( $option ){
83
-		$result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
-
85
-		if ( ! $result && $option) {
86
-			if( $option == 'color_primary' ){
87
-				$result = AUI_PRIMARY_COLOR;
88
-			}elseif( $option == 'color_secondary' ){
89
-				$result = AUI_SECONDARY_COLOR;
90
-			}
91
-		}
92
-		return $result;
93
-	}
94
-
95
-	public function render( $items = array() ) {
96
-		$output = '';
97
-
98
-		if ( ! empty( $items ) ) {
99
-			foreach ( $items as $args ) {
100
-				$render = isset( $args['render'] ) ? $args['render'] : '';
101
-				if ( $render && method_exists( __CLASS__, $render ) ) {
102
-					$output .= $this->$render( $args );
103
-				}
104
-			}
105
-		}
106
-
107
-		return $output;
108
-	}
109
-
110
-	/**
111
-	 * Render and return a bootstrap alert component.
112
-	 *
113
-	 * @since 1.0.0
114
-	 *
115
-	 * @param array $args
116
-	 *
117
-	 * @return string The rendered component.
118
-	 */
119
-	public function alert( $args = array() ) {
120
-		return AUI_Component_Alert::get( $args );
121
-	}
122
-
123
-	/**
124
-	 * Render and return a bootstrap input component.
125
-	 *
126
-	 * @since 1.0.0
127
-	 *
128
-	 * @param array $args
129
-	 *
130
-	 * @return string The rendered component.
131
-	 */
132
-	public function input( $args = array() ) {
133
-		return AUI_Component_Input::input( $args );
134
-	}
135
-
136
-	/**
137
-	 * Render and return a bootstrap textarea component.
138
-	 *
139
-	 * @since 1.0.0
140
-	 *
141
-	 * @param array $args
142
-	 *
143
-	 * @return string The rendered component.
144
-	 */
145
-	public function textarea( $args = array() ) {
146
-		return AUI_Component_Input::textarea( $args );
147
-	}
148
-
149
-	/**
150
-	 * Render and return a bootstrap button component.
151
-	 *
152
-	 * @since 1.0.0
153
-	 *
154
-	 * @param array $args
155
-	 *
156
-	 * @return string The rendered component.
157
-	 */
158
-	public function button( $args = array() ) {
159
-		return AUI_Component_Button::get( $args );
160
-	}
161
-
162
-	/**
163
-	 * Render and return a bootstrap button component.
164
-	 *
165
-	 * @since 1.0.0
166
-	 *
167
-	 * @param array $args
168
-	 *
169
-	 * @return string The rendered component.
170
-	 */
171
-	public function badge( $args = array() ) {
172
-		$defaults = array(
173
-			'class' => 'badge badge-primary align-middle',
174
-		);
175
-
176
-		// maybe set type
177
-		if ( empty( $args['href'] ) ) {
178
-			$defaults['type'] = 'badge';
179
-		}
180
-
181
-		/**
182
-		 * Parse incoming $args into an array and merge it with $defaults
183
-		 */
184
-		$args = wp_parse_args( $args, $defaults );
185
-
186
-		return AUI_Component_Button::get( $args );
187
-	}
188
-
189
-	/**
190
-	 * Render and return a bootstrap dropdown component.
191
-	 *
192
-	 * @since 1.0.0
193
-	 *
194
-	 * @param array $args
195
-	 *
196
-	 * @return string The rendered component.
197
-	 */
198
-	public function dropdown( $args = array() ) {
199
-		return AUI_Component_Dropdown::get( $args );
200
-	}
201
-
202
-	/**
203
-	 * Render and return a bootstrap select component.
204
-	 *
205
-	 * @since 1.0.0
206
-	 *
207
-	 * @param array $args
208
-	 *
209
-	 * @return string The rendered component.
210
-	 */
211
-	public function select( $args = array() ) {
212
-		return AUI_Component_Input::select( $args );
213
-	}
214
-
215
-	/**
216
-	 * Render and return a bootstrap radio component.
217
-	 *
218
-	 * @since 1.0.0
219
-	 *
220
-	 * @param array $args
221
-	 *
222
-	 * @return string The rendered component.
223
-	 */
224
-	public function radio( $args = array() ) {
225
-		return AUI_Component_Input::radio( $args );
226
-	}
227
-
228
-	/**
229
-	 * Render and return a bootstrap pagination component.
230
-	 *
231
-	 * @since 1.0.0
232
-	 *
233
-	 * @param array $args
234
-	 *
235
-	 * @return string The rendered component.
236
-	 */
237
-	public function pagination( $args = array() ) {
238
-		return AUI_Component_Pagination::get( $args );
239
-	}
14
+    /**
15
+     * Holds the class instance.
16
+     *
17
+     * @since 1.0.0
18
+     * @var null
19
+     */
20
+    private static $instance = null;
21
+
22
+    /**
23
+     * Holds the current AUI version number.
24
+     *
25
+     * @var string $ver The current version number.
26
+     */
27
+    public static $ver = '0.1.59';
28
+
29
+    public static $options = null;
30
+
31
+    /**
32
+     * There can be only one.
33
+     *
34
+     * @since 1.0.0
35
+     * @return AUI|null
36
+     */
37
+    public static function instance() {
38
+        if ( self::$instance == null ) {
39
+            self::$instance = new AUI();
40
+        }
41
+
42
+        return self::$instance;
43
+    }
44
+
45
+    /**
46
+     * AUI constructor.
47
+     *
48
+     * @since 1.0.0
49
+     */
50
+    private function __construct() {
51
+        if ( function_exists( "__autoload" ) ) {
52
+            spl_autoload_register( "__autoload" );
53
+        }
54
+        spl_autoload_register( array( $this, 'autoload' ) );
55
+
56
+        // load options
57
+        self::$options = get_option('aui_options');
58
+    }
59
+
60
+    /**
61
+     * Autoload any components on the fly.
62
+     *
63
+     * @since 1.0.0
64
+     *
65
+     * @param $classname
66
+     */
67
+    private function autoload( $classname ) {
68
+        $class     = str_replace( '_', '-', strtolower( $classname ) );
69
+        $file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
+        if ( $file_path && is_readable( $file_path ) ) {
71
+            include_once( $file_path );
72
+        }
73
+    }
74
+
75
+    /**
76
+     * Get the AUI options.
77
+     *
78
+     * @param $option
79
+     *
80
+     * @return string|void
81
+     */
82
+    public function get_option( $option ){
83
+        $result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
+
85
+        if ( ! $result && $option) {
86
+            if( $option == 'color_primary' ){
87
+                $result = AUI_PRIMARY_COLOR;
88
+            }elseif( $option == 'color_secondary' ){
89
+                $result = AUI_SECONDARY_COLOR;
90
+            }
91
+        }
92
+        return $result;
93
+    }
94
+
95
+    public function render( $items = array() ) {
96
+        $output = '';
97
+
98
+        if ( ! empty( $items ) ) {
99
+            foreach ( $items as $args ) {
100
+                $render = isset( $args['render'] ) ? $args['render'] : '';
101
+                if ( $render && method_exists( __CLASS__, $render ) ) {
102
+                    $output .= $this->$render( $args );
103
+                }
104
+            }
105
+        }
106
+
107
+        return $output;
108
+    }
109
+
110
+    /**
111
+     * Render and return a bootstrap alert component.
112
+     *
113
+     * @since 1.0.0
114
+     *
115
+     * @param array $args
116
+     *
117
+     * @return string The rendered component.
118
+     */
119
+    public function alert( $args = array() ) {
120
+        return AUI_Component_Alert::get( $args );
121
+    }
122
+
123
+    /**
124
+     * Render and return a bootstrap input component.
125
+     *
126
+     * @since 1.0.0
127
+     *
128
+     * @param array $args
129
+     *
130
+     * @return string The rendered component.
131
+     */
132
+    public function input( $args = array() ) {
133
+        return AUI_Component_Input::input( $args );
134
+    }
135
+
136
+    /**
137
+     * Render and return a bootstrap textarea component.
138
+     *
139
+     * @since 1.0.0
140
+     *
141
+     * @param array $args
142
+     *
143
+     * @return string The rendered component.
144
+     */
145
+    public function textarea( $args = array() ) {
146
+        return AUI_Component_Input::textarea( $args );
147
+    }
148
+
149
+    /**
150
+     * Render and return a bootstrap button component.
151
+     *
152
+     * @since 1.0.0
153
+     *
154
+     * @param array $args
155
+     *
156
+     * @return string The rendered component.
157
+     */
158
+    public function button( $args = array() ) {
159
+        return AUI_Component_Button::get( $args );
160
+    }
161
+
162
+    /**
163
+     * Render and return a bootstrap button component.
164
+     *
165
+     * @since 1.0.0
166
+     *
167
+     * @param array $args
168
+     *
169
+     * @return string The rendered component.
170
+     */
171
+    public function badge( $args = array() ) {
172
+        $defaults = array(
173
+            'class' => 'badge badge-primary align-middle',
174
+        );
175
+
176
+        // maybe set type
177
+        if ( empty( $args['href'] ) ) {
178
+            $defaults['type'] = 'badge';
179
+        }
180
+
181
+        /**
182
+         * Parse incoming $args into an array and merge it with $defaults
183
+         */
184
+        $args = wp_parse_args( $args, $defaults );
185
+
186
+        return AUI_Component_Button::get( $args );
187
+    }
188
+
189
+    /**
190
+     * Render and return a bootstrap dropdown component.
191
+     *
192
+     * @since 1.0.0
193
+     *
194
+     * @param array $args
195
+     *
196
+     * @return string The rendered component.
197
+     */
198
+    public function dropdown( $args = array() ) {
199
+        return AUI_Component_Dropdown::get( $args );
200
+    }
201
+
202
+    /**
203
+     * Render and return a bootstrap select component.
204
+     *
205
+     * @since 1.0.0
206
+     *
207
+     * @param array $args
208
+     *
209
+     * @return string The rendered component.
210
+     */
211
+    public function select( $args = array() ) {
212
+        return AUI_Component_Input::select( $args );
213
+    }
214
+
215
+    /**
216
+     * Render and return a bootstrap radio component.
217
+     *
218
+     * @since 1.0.0
219
+     *
220
+     * @param array $args
221
+     *
222
+     * @return string The rendered component.
223
+     */
224
+    public function radio( $args = array() ) {
225
+        return AUI_Component_Input::radio( $args );
226
+    }
227
+
228
+    /**
229
+     * Render and return a bootstrap pagination component.
230
+     *
231
+     * @since 1.0.0
232
+     *
233
+     * @param array $args
234
+     *
235
+     * @return string The rendered component.
236
+     */
237
+    public function pagination( $args = array() ) {
238
+        return AUI_Component_Pagination::get( $args );
239
+    }
240 240
 
241 241
 }
242 242
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/sd-functions.php 1 patch
Indentation   +13 added lines, -13 removed lines patch added patch discarded remove patch
@@ -11,18 +11,18 @@  discard block
 block discarded – undo
11 11
  * @return mixed|void
12 12
  */
13 13
 function sd_pagenow_exclude(){
14
-	return apply_filters( 'sd_pagenow_exclude', array(
15
-		'upload.php',
16
-		'edit-comments.php',
17
-		'edit-tags.php',
18
-		'index.php',
19
-		'media-new.php',
20
-		'options-discussion.php',
21
-		'options-writing.php',
22
-		'edit.php',
23
-		'themes.php',
24
-		'users.php',
25
-	) );
14
+    return apply_filters( 'sd_pagenow_exclude', array(
15
+        'upload.php',
16
+        'edit-comments.php',
17
+        'edit-tags.php',
18
+        'index.php',
19
+        'media-new.php',
20
+        'options-discussion.php',
21
+        'options-writing.php',
22
+        'edit.php',
23
+        'themes.php',
24
+        'users.php',
25
+    ) );
26 26
 }
27 27
 
28 28
 
@@ -34,5 +34,5 @@  discard block
 block discarded – undo
34 34
  * @return mixed|void
35 35
  */
36 36
 function sd_widget_exclude(){
37
-	return apply_filters( 'sd_widget_exclude', array() );
37
+    return apply_filters( 'sd_widget_exclude', array() );
38 38
 }
39 39
\ No newline at end of file
Please login to merge, or discard this patch.